From 046c2d13c5b99857f62b8703a234bc6261c5216c Mon Sep 17 00:00:00 2001
From: Prakash Choudhary <34452139+prakashchoudhary07@users.noreply.github.com>
Date: Wed, 25 Oct 2023 06:25:41 +0000
Subject: [PATCH] Dev to Main sync (#504)
---
app/components/task/holder.hbs | 21 +-
app/components/task/holder.js | 1 +
app/components/task/latest-extension-info.hbs | 35 ++
app/components/task/latest-extension-info.js | 11 +
.../task/multiple-extension-form.hbs | 143 +++++++
.../task/multiple-extension-form.js | 181 ++++++++
app/constants/user-status.js | 2 +
app/styles/tasks.css | 142 ++++++-
tests/fixtures/extension-requests.js | 1 +
.../tasks/multiple-extension-form-test.js | 387 ++++++++++++++++++
10 files changed, 913 insertions(+), 11 deletions(-)
create mode 100644 app/components/task/latest-extension-info.hbs
create mode 100644 app/components/task/latest-extension-info.js
create mode 100644 app/components/task/multiple-extension-form.hbs
create mode 100644 app/components/task/multiple-extension-form.js
create mode 100644 tests/integration/components/tasks/multiple-extension-form-test.js
diff --git a/app/components/task/holder.hbs b/app/components/task/holder.hbs
index 3fd9d2f5..b6b38809 100644
--- a/app/components/task/holder.hbs
+++ b/app/components/task/holder.hbs
@@ -14,12 +14,21 @@
{{#if this.extensionFormOpened}}
-
+ {{#if @dev}}
+
+ {{else}}
+
+ {{/if}}
{{/if}}
{{#if (not-eq this.status this.TASK_KEYS.VERIFIED)}}
diff --git a/app/components/task/holder.js b/app/components/task/holder.js
index 0673890f..4e058848 100644
--- a/app/components/task/holder.js
+++ b/app/components/task/holder.js
@@ -9,6 +9,7 @@ export default class TasksHolderComponent extends Component {
@tracked status = this.args.task.status;
@tracked extensionFormOpened = false;
@tracked isLoading = false;
+ queryParams = ['dev'];
TASK_KEYS = TASK_KEYS;
availabletaskStatusList = TASK_STATUS_LIST;
diff --git a/app/components/task/latest-extension-info.hbs b/app/components/task/latest-extension-info.hbs
new file mode 100644
index 00000000..456a0322
--- /dev/null
+++ b/app/components/task/latest-extension-info.hbs
@@ -0,0 +1,35 @@
+
+
+
+
+ Request : |
+ {{#if (eq this.extension.requestNumber undefined)}}
+ #1
+ {{else}}
+ #{{this.extension.requestNumber}}
+ {{/if}}
+ |
+
+
+ Reason : |
+ {{this.extension.reason}} |
+
+
+ Title : |
+ {{this.extension.title}} |
+
+
+ Old Ends On : |
+ {{this.oldEndsOn}} |
+
+
+ New Ends On : |
+ {{this.newEndsOn}} |
+
+
+ Status : |
+ {{this.extension.status}} |
+
+
+
+
\ No newline at end of file
diff --git a/app/components/task/latest-extension-info.js b/app/components/task/latest-extension-info.js
new file mode 100644
index 00000000..aeb1d4f3
--- /dev/null
+++ b/app/components/task/latest-extension-info.js
@@ -0,0 +1,11 @@
+import Component from '@glimmer/component';
+
+export default class LatestExtensionInfoComponent extends Component {
+ extension = this.args.extension;
+ newEndsOn = this.localTime(this.extension.newEndsOn);
+ oldEndsOn = this.localTime(this.extension.oldEndsOn);
+
+ localTime(time) {
+ return new Date(time * 1000).toLocaleString();
+ }
+}
diff --git a/app/components/task/multiple-extension-form.hbs b/app/components/task/multiple-extension-form.hbs
new file mode 100644
index 00000000..ac0ba8ed
--- /dev/null
+++ b/app/components/task/multiple-extension-form.hbs
@@ -0,0 +1,143 @@
+
\ No newline at end of file
diff --git a/app/components/task/multiple-extension-form.js b/app/components/task/multiple-extension-form.js
new file mode 100644
index 00000000..ffdaeb0f
--- /dev/null
+++ b/app/components/task/multiple-extension-form.js
@@ -0,0 +1,181 @@
+import Component from '@glimmer/component';
+import { tracked } from '@glimmer/tracking';
+import { resource, use } from 'ember-resources';
+import { TrackedMap } from 'tracked-maps-and-sets';
+import ENV from 'website-my/config/environment';
+import { action } from '@ember/object';
+import { WARNING_INVALID_NEW_ETA } from '../../constants/user-status';
+import { toastNotificationTimeoutOptions } from '../../constants/toast-notification';
+import { inject as service } from '@ember/service';
+
+export default class ExtensionFormComponent extends Component {
+ @tracked createExtensionRequest = false;
+ @tracked createExtensionRequestError = null;
+ @tracked disableExtensionRequestClose = false;
+ @tracked previousExtensionStatus = null;
+ @tracked isSubmitButtonDisabled = false;
+
+ @service toast;
+ @service userState;
+
+ oldETA = new Date(this.args.task.endsOn * 1000).toLocaleString();
+
+ @use load = resource(({ on }) => {
+ const state = new TrackedMap();
+ const controller = new AbortController();
+
+ on.cleanup(() => controller.abort());
+ (async () => {
+ if (this.args.task) {
+ state.set('isLoading', true);
+ try {
+ const response = await fetch(
+ `${ENV.BASE_API_URL}/extension-requests/self/?taskId=${this.args.task.id}&dev=true`,
+ {
+ credentials: 'include',
+ signal: controller.signal,
+ }
+ );
+ if (response.status === 200) {
+ const data = await response.json();
+ if (!data.allExtensionRequests.length) {
+ throw Error(
+ 'No extension request found for this task, want to create one?'
+ );
+ }
+ state.set('value', data.allExtensionRequests);
+ // Set the status of the previous extension request
+ this.previousExtensionStatus = data.allExtensionRequests[0].status;
+ state.set('isLoading', false);
+ return;
+ }
+ this.toast.error('Something went wrong!', '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ } catch (error) {
+ state.set('error', error.message);
+ state.set('isLoading', false);
+ console.error(error);
+ this.toast.error(error.message, '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ }
+ }
+ })();
+
+ return state;
+ });
+
+ get extensionData() {
+ const result = {};
+ result['isLoading'] = this.load.get('isLoading');
+ result['value'] = this.load.get('value');
+ result['error'] = this.load.get('error');
+ return result;
+ }
+
+ @action
+ createNewExtensionRequest() {
+ this.createExtensionRequest = true;
+ }
+
+ @action
+ closeForm() {
+ this.createExtensionRequest = false;
+ }
+
+ @action
+ async submitExtensionRequest(e) {
+ e.preventDefault();
+ this.disableExtensionRequestClose = true;
+ this.createExtensionRequestError = null;
+ this.isSubmitButtonDisabled = true;
+ const formData = new FormData(e.target);
+ const extensionTime = new Date(formData.get('newEndsOn')).getTime() / 1000;
+ const json = {};
+ formData.forEach(function (value, key) {
+ json[key] = value;
+ });
+
+ if (extensionTime < this.args.task.endsOn) {
+ this.toast.error(WARNING_INVALID_NEW_ETA, '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ this.disableExtensionRequestClose = false;
+ this.createExtensionRequestError = 'New ETA must be greater than Old ETA';
+ return;
+ }
+
+ json['newEndsOn'] = extensionTime;
+ //setting default values
+ json['taskId'] = this.args.task.id;
+ json['assignee'] = this.userState.get('id');
+ json['oldEndsOn'] = this.args.task.endsOn;
+ json['status'] = 'PENDING';
+
+ try {
+ const response = await fetch(
+ `${ENV.BASE_API_URL}/extension-requests?dev=true`,
+ {
+ credentials: 'include',
+ method: 'POST',
+ body: JSON.stringify(json),
+ headers: {
+ 'Content-Type': 'application/json',
+ },
+ }
+ );
+ const data = await response.json();
+ if (data.message === 'Extension Request created successfully!') {
+ this.disableExtensionRequestClose = false;
+ this.toast.success(data.message, '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ setTimeout(
+ (this.isSubmitButtonDisabled = true),
+ this.args.closeModel(),
+ 2000
+ );
+ return;
+ }
+ this.toast.error('Something went wrong!', '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ } catch (error) {
+ this.toast.error(error.message, '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ } finally {
+ this.isSubmitButtonDisabled = false;
+ }
+ }
+
+ @action
+ changeExtensionRequestETA(e) {
+ const errorPlaceholder = document.querySelector('.error-placeholder');
+ const extensionTime = new Date(e.target.value).getTime() / 1000;
+ if (extensionTime < this.args.task.endsOn) {
+ this.toast.error(WARNING_INVALID_NEW_ETA, '', {
+ ...toastNotificationTimeoutOptions,
+ timeOut: '3000',
+ });
+ this.isSubmitButtonDisabled = true;
+ this.createExtensionRequestError = 'New ETA must be greater than Old ETA';
+ errorPlaceholder.textContent = this.createExtensionRequestError;
+ errorPlaceholder.style.visibility = 'visible';
+ return;
+ } else {
+ this.createExtensionRequestError = null;
+ this.isSubmitButtonDisabled = false;
+ errorPlaceholder.textContent = this.createExtensionRequestError;
+ errorPlaceholder.style.visibility = 'hidden';
+ return;
+ }
+ }
+}
diff --git a/app/constants/user-status.js b/app/constants/user-status.js
index 915b78a3..e3686682 100644
--- a/app/constants/user-status.js
+++ b/app/constants/user-status.js
@@ -11,6 +11,8 @@ export const USER_STATES = {
ONBOARDING: 'ONBOARDING',
DNE: 'DNE',
};
+export const WARNING_INVALID_NEW_ETA =
+ 'The newEndsOn value cannot be smaller than the oldEndsOn value';
export const WARNING_FROM_DATE_EXCEEDS_UNTIL_DATE =
'Until date cant lie before the From date. Please recheck the dates again.';
export const THREE_DAYS_TIME_DIFFERENCE_MS = 172800000;
diff --git a/app/styles/tasks.css b/app/styles/tasks.css
index 7fa599d1..1d859611 100644
--- a/app/styles/tasks.css
+++ b/app/styles/tasks.css
@@ -420,7 +420,7 @@
padding: 18px;
border-radius: 10px;
background-color: var(--white);
- overflow-y: scroll;
+ /* overflow-y: scroll; */
position: absolute;
left: 30%;
right: 30%;
@@ -452,6 +452,7 @@
justify-content: center;
align-items: center;
height: 100%;
+ width: 100%;
flex-direction: column;
margin: 10px 0px;
}
@@ -467,7 +468,7 @@
.extension-form__content-wrapper {
width: 100%;
- display: flex;
+ /* display: flex; */
flex-direction: column;
align-items: center;
justify-content: center;
@@ -479,7 +480,7 @@
flex-direction: column;
justify-content: center;
align-items: flex-start;
- width: 80%;
+ width: 100%;
}
.extension-form__content form > label {
font-weight: bold;
@@ -494,10 +495,26 @@
color: var(--button-proceed--text);
font-size: 1.2rem;
border: none;
+ width: 100%;
border-radius: 8px;
+ margin-top: 1rem;
padding: 5px 9px;
}
+.multiple-extension-form__content form > button,
+.multiple-extension-form__container-close {
+ background-color: var(--button-proceed--bg);
+ color: var(--button-proceed--text);
+ font-size: 1.2rem;
+ border: none;
+ width: 40%;
+ border-radius: 8px;
+ margin-top: 1rem;
+ padding: 5px 9px;
+ display: flex;
+ align-items: center;
+}
+
.extension-form__container-close:disabled {
opacity: 0.7;
background-color: #888;
@@ -511,8 +528,8 @@
margin: 5px 0px 15px 0px;
padding: 5px;
width: 100%;
- border: none;
- border-bottom: 1px solid var(--input-field-border);
+ border: 1px solid var(--input-field-border);
+ /* border-bottom: 1px solid var(--input-field-border); */
}
.extension-info__content > table,
@@ -582,3 +599,118 @@
align-items: center;
}
}
+
+.extension-info__content {
+ border-bottom: 1px solid var(--light-black);
+ margin: 10px;
+}
+.latest-extension-info__content table td {
+ white-space: normal;
+}
+
+ .multiple-extension-form__container-close {
+ background-color:#a70606;
+ color: var(--button-proceed--text);
+ font-size: 1.2rem;
+ border: none;
+ border-radius: 8px;
+ padding: 5px 9px;
+ width: 40%;
+ display: flex;
+ justify-content: center;
+ margin:0 auto;
+ }
+
+.error-message {
+ color: red;
+}
+.error-container {
+ align-items: center;
+ height: 25px;
+ width: 100%;
+}
+
+
+.error-placeholder {
+ color: red;
+ text-align: center;
+ visibility: hidden;
+}
+
+.multiple-extension-form__create-button[disabled] {
+ cursor: not-allowed;
+
+ background-color: #888;
+}
+
+.multiple-extension-form__create-button[disabled]:hover {
+ background-color: #888;
+}
+
+
+.multiple-extension-form__open-button:hover ,
+.multiple-extension-form__create-button:hover {
+ background-color: #01ad01;
+ color: #fff;
+}
+
+.multiple-extension-form__container-close:hover{
+ background-color: #d50707;
+ color:#fff
+}
+
+.multiple-extension-form__create-button {
+ width: 60%;
+}
+
+.primary-button-style {
+ background-color: #008000;
+ color: var(--button-proceed--text);
+ font-size: 1.2rem;
+ width: 40%;
+ display: flex;
+ justify-content: center;
+ margin:0 auto;
+ border: none;
+ border-radius: 8px;
+ padding: 5px 9px;
+ transition: background-color 0.3s ease;
+}
+
+ .latest-extension-info__content th {
+ text-align: right;
+ width: 50%;
+ }
+
+.latest-extension-info__content th, td {
+ padding: 8px 2px;
+ vertical-align: top;
+ min-width: 50%;
+}
+.latest-table{
+ width: 100%;
+}
+.latest-extension-info__content th {
+ text-align: right;
+}
+.latest-extension-info__content td {
+ text-align: left;
+ word-wrap: normal;
+}
+tr>th,tr>td{
+ vertical-align: top;
+}
+
+textarea {
+ width: 100%;
+ height: 50%;
+ overflow-y: auto;
+}
+
+div.buttons{
+ display: flex;
+ flex-direction:row;
+ min-width: 100%;
+ align-content: center;
+ justify-content: center;
+}
diff --git a/tests/fixtures/extension-requests.js b/tests/fixtures/extension-requests.js
index 57daf0c3..241dfe34 100644
--- a/tests/fixtures/extension-requests.js
+++ b/tests/fixtures/extension-requests.js
@@ -9,6 +9,7 @@ const extensionRequests = [
id: 'T0S56aa3zaNsNghEPLeS',
timestamp: 1673784012,
assignee: 'ivinayakg',
+ reviewedBy: 'Joy Gupta',
},
{
oldEndsOn: 57658796,
diff --git a/tests/integration/components/tasks/multiple-extension-form-test.js b/tests/integration/components/tasks/multiple-extension-form-test.js
new file mode 100644
index 00000000..9e101ae2
--- /dev/null
+++ b/tests/integration/components/tasks/multiple-extension-form-test.js
@@ -0,0 +1,387 @@
+import { module, test } from 'qunit';
+import { setupRenderingTest } from 'ember-qunit';
+import { tasks } from 'website-my/tests/fixtures/tasks';
+import { extensionRequests } from 'website-my/tests/fixtures/extension-requests';
+import { render, click, fillIn, waitFor, settled } from '@ember/test-helpers';
+import { hbs } from 'ember-cli-htmlbars';
+import makeServer from 'website-my/mirage/config';
+
+module('Integration | Component | Multiple Extension Form', function (hooks) {
+ setupRenderingTest(hooks);
+ let tasksData, extensionFormOpened, server;
+
+ hooks.after(function () {
+ server.shutdown();
+ });
+
+ hooks.before(function () {
+ tasksData = tasks;
+ extensionFormOpened = true;
+ server = makeServer({ environment: 'test' });
+ extensionRequests.forEach((obj) => {
+ server.create('extensionRequest', obj);
+ });
+ });
+
+ const toggleExtensionForm = (setter, name) => {
+ extensionFormOpened = !extensionFormOpened;
+ if (setter) {
+ setter(name, extensionFormOpened);
+ }
+ };
+
+ const closeExtensionForm = (setter, name) => () => {
+ extensionFormOpened = false;
+ if (setter) {
+ setter(name, false);
+ }
+ };
+
+ const closeExtensionModel = (setter, name) => (e) => {
+ if (!e) {
+ toggleExtensionForm(setter, name);
+ return;
+ }
+ e.stopPropagation();
+ if (e.target.classList.contains('extension-form__container-back')) {
+ toggleExtensionForm(setter, name);
+ }
+ };
+
+ test('When Clicked /"Close Form/" button or background task extension form should unmount', async function (assert) {
+ this.set('task', tasksData[3]);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+ this.set('extensionFormOpened', extensionFormOpened);
+ await render(
+ hbs`
+ {{#if this.extensionFormOpened}}
+
+ {{/if}}`
+ );
+ await waitFor('[data-test-create-extension-button]');
+ assert
+ .dom(this.element.querySelector('[data-test-create-extension-button]'))
+ .hasText('Request Extension');
+
+ await click(
+ this.element.querySelector('[data-test-create-extension-button]')
+ );
+ assert.dom('[data-test-extension-form-container-close]').exists();
+ const closeButton = this.element.querySelector(
+ '[data-test-extension-form-container-close]'
+ );
+ assert.ok(closeButton, 'Close button should exist');
+ await click(closeButton);
+ assert.dom(this.element.querySelector('[data-test-title]')).doesNotExist();
+ });
+
+ test('When no extension requests found, the option to create extension request should show and then later open form', async function (assert) {
+ this.set('task', tasksData[3]);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
`
+ );
+ await waitFor('[data-test-create-extension-button]');
+ assert
+ .dom(this.element.querySelector('[data-test-create-extension-button]'))
+ .hasText('Request Extension');
+
+ await click(
+ this.element.querySelector('[data-test-create-extension-button]')
+ );
+ assert
+ .dom(
+ this.element
+ .querySelector('[data-test-extension-from-content]')
+ .querySelector('button[type=submit]')
+ )
+ .exists();
+ });
+
+ test('When creating extension request, if the newEndsOn is smaller than the oldEndsOn then should throw error', async function (assert) {
+ this.set('task', tasksData[3]);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
`
+ );
+ await waitFor('[data-test-create-extension-button]');
+ assert
+ .dom(this.element.querySelector('[data-test-create-extension-button]'))
+ .hasText('Create an extension request');
+
+ await click(
+ this.element.querySelector('[data-test-create-extension-button]')
+ );
+ assert
+ .dom(
+ this.element
+ .querySelector('[data-test-extension-from-content]')
+ .querySelector('button[type=submit]')
+ )
+ .exists();
+
+ await fillIn(
+ '[data-test-extension-form-newEndsOn-input]',
+ '2021-09-09T09:45'
+ );
+ assert
+ .dom(this.element.querySelector('[data-test-extension-from-error]'))
+ .hasText(
+ 'Error: The newEndsOn value cannot be smaller than the oldEndsOn value'
+ );
+
+ await settled();
+ // if filled valid time then remove the error
+ await fillIn(
+ '[data-test-extension-form-newEndsOn-input]',
+ '2024-09-09T09:45'
+ );
+ assert
+ .dom(this.element.querySelector('[data-test-extension-from-error]'))
+ .doesNotExist();
+ });
+
+ test('When no extension requests found, we should be able to create one', async function (assert) {
+ this.set('task', tasksData[3]);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
`
+ );
+ await waitFor('[data-test-create-extension-button]');
+ assert
+ .dom(this.element.querySelector('[data-test-create-extension-button]'))
+ .hasText('Create an extension request');
+
+ await click(
+ this.element.querySelector('[data-test-create-extension-button]')
+ );
+ assert
+ .dom(
+ this.element
+ .querySelector('[data-test-extension-from-content]')
+ .querySelector('button[type=submit]')
+ )
+ .exists();
+
+ //create extension request
+ await fillIn('[data-test-extension-form-reason-input]', 'Testing');
+ await fillIn(
+ '[data-test-extension-form-newEndsOn-input]',
+ '2030-12-31T02:43'
+ );
+ await fillIn('[data-test-extension-form-title-input]', 'TestingAgain');
+ await click(this.element.querySelector('button[type=submit]'));
+
+ // rendering the component again to check the new data
+ await render(
+ hbs`
`
+ );
+ await waitFor('[data-test-extension-info-content]');
+ assert
+ .dom(this.element.querySelector('[data-test-extension-info-content]'))
+ .containsText('Testing')
+ .containsText('TestingAgain')
+ .containsText('PENDING')
+ .containsText('1');
+ });
+
+ test('When previous extension request is approved, the button to create extension request should be there', async function (assert) {
+ let extensionRequestData = extensionRequests[0];
+ this.set('task', tasksData[0]);
+ this.set('previousExtensionStatus', extensionRequestData.status);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
+ }`
+ );
+ await waitFor('[data-test-extension-info-content]');
+ assert
+ .dom(this.element.querySelector('[data-test-extension-info-content]'))
+ .containsText(extensionRequestData['title'])
+ .containsText(extensionRequestData['reason'])
+ .containsText(extensionRequestData['status']);
+ // Assert the initial state
+ if (['APPROVED', 'DENIED'].includes(this.previousExtensionStatus)) {
+ assert.dom('button[data-test-create-another-extension]').exists();
+
+ // Trigger the action to create a new extension request
+ await click('button[data-test-create-another-extension]');
+
+ assert
+ .dom(
+ this.element
+ .querySelector('[data-test-extension-from-content]')
+ .querySelector('button[type=submit]')
+ )
+ .exists();
+ } else {
+ assert.dom('[data-test-create-another-extension] button').doesNotExist();
+ }
+ });
+
+ test('Review log should present if extension status is either approved or denied and reviewedBy field is present', async function (assert) {
+ const extensionRequestData = extensionRequests[0];
+ this.set('task', tasksData[0]);
+ this.set('value', [extensionRequestData]);
+ this.set('previousExtensionStatus', extensionRequestData.status);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
+ }`
+ );
+ await waitFor('[data-test-extension-info-content]');
+
+ // Assert the initial state
+ if (['APPROVED', 'DENIED'].includes(this.previousExtensionStatus)) {
+ assert
+ .dom(this.element.querySelector('[data-reviewed-log]'))
+ .containsText(extensionRequestData['reviewedBy'])
+ .exists();
+ } else {
+ assert
+ .dom(this.element.querySelector('[data-reviewed-log]'))
+ .doesNotExist();
+ }
+ });
+
+ test('Review log should not be present as extensionRequestData does not contains reviewedBy field', async function (assert) {
+ const extensionRequestData = extensionRequests[2];
+ this.set('task', tasksData[2]);
+ this.set('value', [extensionRequestData]);
+ this.set('previousExtensionStatus', extensionRequestData.status);
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
+ }`
+ );
+ await waitFor('[data-test-extension-info-content]');
+
+ // Assert the initial state
+ assert
+ .dom(this.element.querySelector('[data-reviewed-log]'))
+ .doesNotExist();
+ });
+
+ test('When previous extension request is pending, the option to create extension request should show and then later open form', async function (assert) {
+ // Set up test data and conditions, such as setting this.previousExtensionStatus
+ let extensionRequestData = extensionRequests[1];
+ this.set('task', tasksData[0]);
+ this.set('previousExtensionStatus', extensionRequestData.status);
+
+ this.set(
+ 'closeExtensionModel',
+ closeExtensionModel(this.set, 'extensionFormOpened')
+ );
+ this.set(
+ 'closeExtensionForm',
+ closeExtensionForm(this.set, 'extensionFormOpened')
+ );
+
+ await render(
+ hbs`
`
+ );
+
+ await waitFor('[data-test-extension-info-content]');
+
+ // Assert the initial state
+ assert.dom('[data-test-extension-form-container]').doesNotExist(); // Replace with the actual selector for the component
+
+ // Trigger the action to create a new extension request
+ assert.dom('[data-test-create-another-extension] button').doesNotExist();
+
+ // Assert the resulting state after the action
+ assert.dom('[data-test-extension-form]').doesNotExist(); // Replace with the actual selector for the extension form
+ });
+});