Skip to content

Commit

Permalink
Replace 'COMPLETED' Option with 'DONE' (#515)
Browse files Browse the repository at this point in the history
* change completed to done

* modify test

* written test for model of 100% progress bar

* written test for DONE option

* written test for DONE option

* added statusNotOverDueList under feature flag

* added statusNotOverDueList under feature flag

* added feature flag when on ompletedPercentage

* added feature flag in select option

* remove redudant code
  • Loading branch information
shubhamsinghbundela authored Oct 31, 2023
1 parent 83f4a06 commit b6078ed
Show file tree
Hide file tree
Showing 7 changed files with 132 additions and 13 deletions.
17 changes: 8 additions & 9 deletions app/components/task/holder.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -39,15 +39,14 @@
id='task-update'
{{on 'change' this.onStatusChange}}
>
{{#each this.availabletaskStatusList as |taskStatus|}}
{{#if (not-eq taskStatus.key this.TASK_KEYS.ALL)}}
<option
value={{taskStatus.key}}
selected={{eq taskStatus.key this.status}}
>
{{taskStatus.displayLabel}}
</option>
{{/if}}
{{#each this.taskStatusList as |taskStatus|}}
<option
data-test-dropdown-option={{taskStatus.displayLabel}}
value={{taskStatus.key}}
selected={{eq taskStatus.key this.status}}
>
{{taskStatus.displayLabel}}
</option>
{{/each}}
</select>
</div>
Expand Down
15 changes: 14 additions & 1 deletion app/components/task/holder.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,22 @@ export default class TasksHolderComponent extends Component {
TASK_KEYS = TASK_KEYS;
availabletaskStatusList = TASK_STATUS_LIST;

get taskStatusList() {
const statusToDisplay = this.availabletaskStatusList.filter(
(taskStatus) => {
if (this.args.dev === true) {
return taskStatus.key !== 'ALL' && taskStatus.key !== 'COMPLETED';
} else {
return taskStatus.key !== 'ALL' && taskStatus.key !== 'DONE';
}
}
);
return statusToDisplay;
}

get taskStyleClass() {
const statusNotOverDueList = [
TASK_KEYS.COMPLETED,
this.args.dev === true ? TASK_KEYS.DONE : TASK_KEYS.COMPLETED,
TASK_KEYS.VERIFIED,
TASK_KEYS.AVAILABLE,
];
Expand Down
8 changes: 7 additions & 1 deletion app/constants/tasks.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ const TASK_KEYS = {
BLOCKED: 'BLOCKED',
SMOKE_TESTING: 'SMOKE_TESTING',
COMPLETED: 'COMPLETED',
DONE: 'DONE',
NEEDS_REVIEW: 'NEEDS_REVIEW',
IN_REVIEW: 'IN_REVIEW',
APPROVED: 'APPROVED',
Expand All @@ -24,6 +25,7 @@ const {
BLOCKED,
SMOKE_TESTING,
COMPLETED,
DONE,
NEEDS_REVIEW,
IN_REVIEW,
APPROVED,
Expand Down Expand Up @@ -63,6 +65,10 @@ const TASK_STATUS_LIST = [
displayLabel: 'Completed',
key: COMPLETED,
},
{
displayLabel: 'Done',
key: DONE,
},
{
displayLabel: 'Needs Review',
key: NEEDS_REVIEW,
Expand Down Expand Up @@ -133,7 +139,7 @@ const TABS_TASK_STATUS_LIST = [
];
export const TASK_MESSAGES = {
MARK_DONE:
'This task will be marked as complete and a new task will be assigned to you',
'This task will be marked as done and a new task will be assigned to you',
UPDATE_TASK: 'Updating task',
FIND_TASK: 'Finding new task for you!',
};
Expand Down
9 changes: 8 additions & 1 deletion app/controllers/tasks.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ const API_BASE_URL = ENV.BASE_API_URL;
export default class TasksController extends Controller {
queryParams = ['dev'];
@service toast;
@service featureFlag;
TASK_KEYS = TASK_KEYS;
taskStatusList = TASK_STATUS_LIST;
tabsTaskStatusList = TABS_TASK_STATUS_LIST;
Expand All @@ -42,6 +43,10 @@ export default class TasksController extends Controller {
@tracked showFetchButton = this.isShowFetchButton() && !this.alreadyFetched;
alreadyFetched = localStorage.getItem('already-fetched');

get isDevMode() {
return this.featureFlag.isDevMode;
}

@action toggleDropDown() {
this.showDropDown = !this.showDropDown;
}
Expand Down Expand Up @@ -93,7 +98,9 @@ export default class TasksController extends Controller {
const taskCompletionPercentage = object.percentCompleted;
if (taskCompletionPercentage) {
if (taskCompletionPercentage === TASK_PERCENTAGE.completedPercentage) {
requestBody.status = 'COMPLETED';
this.isDevMode === true
? (requestBody.status = 'DONE')
: (requestBody.status = 'COMPLETED');
}
requestBody.percentCompleted = parseInt(taskCompletionPercentage);
}
Expand Down
2 changes: 1 addition & 1 deletion tests/integration/components/tasks-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ module('Integration | Component | tasks', function (hooks) {

assert.dom('[data-test-task-spinner]').doesNotExist();

await fillIn('[data-test-task-status-select]', TASK_KEYS.COMPLETED);
await fillIn('[data-test-task-status-select]', TASK_KEYS.DONE);

assert.dom('[data-test-task-spinner]').exists({ count: 1 });

Expand Down
58 changes: 58 additions & 0 deletions tests/integration/components/tasks/holder-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,41 @@ module('Integration | Component | Tasks Holder', function (hooks) {
.hasValue(TASK_KEYS.IN_PROGRESS);
});

test('Verify values of task status upon api failures under feature flag', async function (assert) {
const testTask = tasksData[3];
testTask.status = TASK_KEYS.IN_PROGRESS;

this.set('task', testTask);
this.set('mock', () => {});
this.set('onTaskUpdate', (taskId, error) => {
error();
});
this.set('isLoading', false);
this.set('disabled', false);
this.set('defaultType', DEFAULT_TASK_TYPE);
this.set('dev', true);

await render(hbs`<Task::Holder
@task={{this.task}}
@onTaskChange={{this.mock}}
@onStausChange={{this.mock}}
@onTaskUpdate={{this.onTaskUpdate}}
@userSelectedTask={{this.defaultType}}
@disabled={{this.disabled}}
@dev={{this.dev}}
/>`);

assert
.dom('[data-test-task-status-select]')
.hasValue(TASK_KEYS.IN_PROGRESS);

await select('[data-test-task-status-select]', TASK_KEYS.DONE);

assert
.dom('[data-test-task-status-select]')
.hasValue(TASK_KEYS.IN_PROGRESS);
});

test('Verify status change to VERIFIED', async function (assert) {
const testTask = tasksData[3];

Expand Down Expand Up @@ -242,4 +277,27 @@ module('Integration | Component | Tasks Holder', function (hooks) {

assert.equal(onTaskUpdateCalled, 1, 'onTaskUpdate should be called once');
});

test('Render Task holder and check whether it has select tag with option DONE under feature flag', async function (assert) {
this.set('task', tasksData[3]);
this.set('mock', () => {});
this.set('isLoading', false);
this.set('disabled', false);
this.set('defaultType', DEFAULT_TASK_TYPE);
this.set('dev', true);

await render(hbs`<Task::Holder
@task={{this.task}}
@onTaskChange={{this.mock}}
@onStausChange={{this.mock}}
@onTaskUpdate={{this.mock}}
@isLoading={{this.isLoading}}
@userSelectedTask={{this.defaultType}}
@disabled={{this.disabled}}
@dev={{this.dev}}
/>`);

assert.dom('[data-test-task-status-select]').exists();
assert.dom('[data-test-dropdown-option=Done]').hasText('Done');
});
});
36 changes: 36 additions & 0 deletions tests/integration/components/tasks/modal-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -190,4 +190,40 @@ module('Integration | Component | tasks/modal', function (hooks) {
this.set('isUpdating', false);
assert.dom('[data-test-spinner]').doesNotExist();
});

test('when the progress bar reaches 100%, a model ais displayed with a message and a "Proceed" button', async function (assert) {
this.setProperties({
goBack: () => {},
isUpdating: false,
markComplete: () => {},
markCompleteAndAssignTask: () => {},
showModal: true,
buttonRequired: true,
dev: false,
message:
'This task will be marked as done and a new task will be assigned to you',
});

await render(hbs`
<Task::Modal
@goBack={{this.goBack}}
@markComplete={{this.markComplete}}
@markCompleteAndAssignTask={{this.markCompleteAndAssignTask}}
@message={{this.message}}
@showModal={{this.showModal}}
@buttonRequired={{this.buttonRequired}}
@isUpdating={{this.isUpdating}}
@dev={{this.dev}}
/>
`);

assert.dom('[data-test-notAssignBtn]').exists();
assert.dom('[data-test-notAssignBtn]').hasProperty('button');
assert
.dom('[data-test-title]')
.hasText(
'This task will be marked as done and a new task will be assigned to you'
);
assert.dom('[data-test-notAssignBtn]').hasText('Proceed');
});
});

0 comments on commit b6078ed

Please sign in to comment.