Skip to content

Commit

Permalink
Merge branch 'develop' into feat/request-ooo
Browse files Browse the repository at this point in the history
  • Loading branch information
satyam73 authored Feb 20, 2024
2 parents 3e64e51 + b6aac58 commit 405c3fb
Show file tree
Hide file tree
Showing 13 changed files with 151 additions and 91 deletions.
1 change: 1 addition & 0 deletions app/components/profile-field.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
placeholder={{@placeholder}}
class="profile-field-input"
required={{@required}}
disabled={{@isDeveloper}}
{{on 'input' (fn this.inputFieldChanged)}}
{{on 'blur' (fn this.checkInputValidation)}}
/>
Expand Down
29 changes: 2 additions & 27 deletions app/components/progress-bar.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -12,40 +12,15 @@
step='10'
{{on 'change' this.onChange}}
{{on 'input' this.onInput}}
disabled={{not this.isEditable}}
/>
<button
data-test-progress-bar-button
{{on 'click' this.turnEditModeOn}}
class='progress-slider__button
{{unless this.isEditable "progress-slider__button--hover"}}'
type='button'
>
{{#if this.isEditable}}
<span class='progress-slider__button__text'>{{@value}}</span>
{{else}}
<svg
class='progress-slider__button__edit-icon'
viewBox='0 0 24 24'
fill='none'
xmlns='http://www.w3.org/2000/svg'
>
<path
class='progress-slider__button__edit-icon__inner'
opacity='0.5'
d='M4 20H8L18 10L14 6L4 16V20Z'
fill='#000000'
/>
<path
class='progress-slider__button__edit-icon__outer'
d='M18 10L21 7L17 3L14 6M18 10L8 20H4V16L14 6M18 10L14 6'
stroke='#000000'
stroke-width='1.5'
stroke-linecap='round'
stroke-linejoin='round'
/>
</svg>
{{/if}}
<span class='progress-slider__button__text'>{{@value}}</span>

</button>

</div>
21 changes: 0 additions & 21 deletions app/components/progress-bar.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,37 +4,16 @@ import { action } from '@ember/object';
import { debounce } from '@ember/runloop';

export default class ProgressBarComponent extends Component {
@tracked isEditable = false;
@tracked value = this.args.value;
lastEditTime = null;

@action turnEditModeOn() {
this.isEditable = true;
this.lastEditTime = Date.now();
this.setEditableToFalse();
}

setEditableToFalse() {
setTimeout(() => {
const timeDelta = Date.now() - this.lastEditTime;
if (this.isEditable && timeDelta >= 5000) {
this.isEditable = false;
} else if (this.isEditable) {
this.setEditableToFalse();
}
}, 5000);
}

@action onInput(e) {
this.lastEditTime = Date.now();
this.value = e.target.value;
if (this.args.onInput) {
this.args.onInput(this.value);
}
}

@action onChange(e) {
this.lastEditTime = Date.now();
if (this.args.onChange) {
debounce(this, this.debouncedChange, e, 600);
}
Expand Down
57 changes: 36 additions & 21 deletions app/components/task/modal.hbs
Original file line number Diff line number Diff line change
@@ -1,24 +1,39 @@
{{#if @showModal}}
<div class="overlay">
<div class="modal" data-test-modal>
<button type="button" class="close" {{on "click" @goBack}} disabled={{@closeDisabled}} data-test-closeBtn>
<i class="fa fa-close"></i>
</button>
<p class="modal-title" data-test-title>{{@message}}</p>
{{#if @isUpdating}}
<Spinner data-test-spinner />
{{/if}}
{{#if @buttonRequired}}
<button type="button" class={{if (eq @dev true) "not-assign" "proceed-btn" }} {{on "click" @markComplete}}
data-test-notAssignBtn>
{{if (eq @dev true) "Don't assign task" "Proceed" }}
</button>
{{#if @dev}}
<button type="button" class="proceed-btn" {{on "click" @markCompleteAndAssignTask}} data-test-assignBtn>
Assign task
</button>
{{/if}}
{{/if}}
<div class='overlay'>
<div class='modal' data-test-modal>
<button
type='button'
class='close'
{{on 'click' @goBack}}
disabled={{@closeDisabled}}
data-test-closeBtn
>
<i class='fa fa-close'></i>
</button>
<p class='modal-title' data-test-title>{{@message}}</p>
{{#if @isUpdating}}
<Spinner data-test-spinner />
{{/if}}
{{#if @buttonRequired}}
<button
type='button'
class='proceed-btn'
{{on 'click' @markComplete}}
data-test-notAssignBtn
>
Proceed
</button>
{{#if @dev}}
<button
type='button'
class='proceed-btn hidden'
{{on 'click' @markCompleteAndAssignTask}}
data-test-assignBtn
>
Assign task
</button>
{{/if}}
{{/if}}
</div>
</div>
</div>
{{/if}}
2 changes: 1 addition & 1 deletion app/components/tasks.hbs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<div class='tasks-container'>
{{#if @dev}}
{{#if @noInProgressTask}}
<div class='fetch-task' data-test-fetchSection>
<div class='fetch-task hidden' data-test-fetchSection>
<p>You have no task in progress! click below to fetch tasks</p>
<Button
@onClick={{@handleAssignment}}
Expand Down
3 changes: 1 addition & 2 deletions app/constants/tasks.js
Original file line number Diff line number Diff line change
Expand Up @@ -138,8 +138,7 @@ const TABS_TASK_STATUS_LIST = [
},
];
export const TASK_MESSAGES = {
MARK_DONE:
'This task will be marked as done and a new task will be assigned to you',
MARK_DONE: 'This task will be marked as Done',
UPDATE_TASK: 'Updating task',
FIND_TASK: 'Finding new task for you!',
};
Expand Down
5 changes: 5 additions & 0 deletions app/routes/profile.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,18 @@ export default class ProfileRoute extends Route {
@service toast;
async model() {
try {
const res = await fetch(`${ENV.BASE_API_URL}/users/isDeveloper`, {
credentials: 'include',
});
const { developerRoleExistsOnUser } = await res.json();
const response = await fetch(`${ENV.BASE_API_URL}/users/self`, {
credentials: 'include',
});
const userData = await response.json();
if (response.status === 401) {
throw new Error('You are not logged in. Please login to continue.');
}
userData.isDeveloper = developerRoleExistsOnUser;
return userData;
} catch (error) {
console.error(error.message);
Expand Down
11 changes: 11 additions & 0 deletions app/styles/profile.css
Original file line number Diff line number Diff line change
Expand Up @@ -39,13 +39,24 @@
border-color: var(--profile-input-outline-clr);
}

.profile-page-error {
text-align: center;
color: red;
}

.profile-field-input {
padding: 0 1.25rem;
border: none;
background: none;
outline: none;
}

.profile-field-input:disabled {
opacity: 0.6;
cursor: not-allowed;
pointer-events: none;
}

.profile-field-input:active {
border-color: var(--profile-input-outline-clr);
}
Expand Down
3 changes: 3 additions & 0 deletions app/styles/tasks.css
Original file line number Diff line number Diff line change
Expand Up @@ -736,3 +736,6 @@ div.buttons {
align-content: center;
justify-content: center;
}
.hidden {
display: none;
}
43 changes: 33 additions & 10 deletions app/templates/profile.hbs
Original file line number Diff line number Diff line change
@@ -1,35 +1,58 @@
{{page-title 'Profile'}}

<div class="profile-container">
<form class="profile-form" {{on 'submit' (fn this.handleSubmit)}}>
<div class='profile-container'>
<form class='profile-form' {{on 'submit' (fn this.handleSubmit)}}>
<div class='picture_container'>
{{#if @model.picture.url}}
<img class='user__pic' src={{@model.picture.url}} alt='user profile ' />
<img class='user__pic' src={{@model.picture.url}} alt='user profile ' />
{{else}}
<img class='user__pic' src={{'dummyProfilePicture.png'}} alt='user profile ' />
<img
class='user__pic'
src={{'dummyProfilePicture.png'}}
alt='user profile '
/>
{{/if}}
<Button @onClick={{this.handleShowEditProfilePictureModal}} @class='edit-btn btn' @data-test-btn='edit'>
<Button
@onClick={{this.handleShowEditProfilePictureModal}}
@class='edit-btn btn'
@data-test-btn='edit'
>
Update Picture
</Button>
</div>
<div class='profile-form-grid'>
{{#if (get @model 'isDeveloper')}}
<p class='profile-page-error'>You can't update the profile data from UI.
You have to create a profile service(if not created yet). Find more
details about profile service
<a
href='https://github.com/Real-Dev-Squad/sample-profile-service'
target='_blank'
rel="noopener noreferrer"
>here</a>.</p>
{{/if}}
{{#each this.fields as |field|}}
<ProfileField
@id={{field.id}}
<ProfileField
@id={{field.id}}
@type={{field.type}}
@value={{get @model field.id}}
@placeholder={{field.placeholder}}
@placeholder={{field.placeholder}}
@label={{field.label}}
@icon_url={{field.icon_url}}
@icon_url={{field.icon_url}}
@errorMessage={{field.errorMessage}}
@showError={{field.showError}}
@required={{field.required}}
@onChange={{this.handleFieldChange}}
@onBlur={{this.handleFieldValidation}}
@isDeveloper={{get @model 'isDeveloper'}}
/>
{{/each}}
</div>
<button type="submit" class="profile-form-submit" disabled={{this.isSubmitDisabled}}>Submit</button>
<button
type='submit'
class='profile-form-submit'
disabled={{this.isSubmitDisabled}}
>Submit</button>
</form>
</div>

Expand Down
54 changes: 54 additions & 0 deletions tests/integration/components/profile-field-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,4 +44,58 @@ module('Integration | Component | profile-field', function (hooks) {
assert.dom('[data-test-profile-field]').hasClass('profile-field-error');
assert.dom('[data-test-profile-field-error]').hasText(this.errorMessage);
});

test('disabled profile field renders when isDeveloper is true', async function (assert) {
this.setProperties({
label: 'First Name*',
icon_url: 'icons/user.svg',
isDeveloper: true,
});

await render(hbs`
<ProfileField
@label={{this.label}}
@icon_url={{this.icon_url}}
@isDeveloper={{this.isDeveloper}}
/>
`);

assert.dom('[data-test-profile-field-label]').hasText(this.label);
assert
.dom('[data-test-profile-field-icon]')
.exists()
.hasAttribute('src', this.icon_url);
assert
.dom('[data-test-profile-field-input]')
.hasProperty('disabled', true)
.exists();
assert.dom('[data-test-profile-field-error]').exists();
});

test('profile field renders when isDeveloper is false', async function (assert) {
this.setProperties({
label: 'First Name*',
icon_url: 'icons/user.svg',
isDeveloper: false,
});

await render(hbs`
<ProfileField
@label={{this.label}}
@icon_url={{this.icon_url}}
@isDeveloper={{this.isDeveloper}}
/>
`);

assert.dom('[data-test-profile-field-label]').hasText(this.label);
assert
.dom('[data-test-profile-field-icon]')
.exists()
.hasAttribute('src', this.icon_url);
assert
.dom('[data-test-profile-field-input]')
.hasProperty('disabled', false)
.exists();
assert.dom('[data-test-profile-field-error]').exists();
});
});
4 changes: 2 additions & 2 deletions tests/integration/components/tasks-test.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { module, test } from 'qunit';
import { module, skip, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { find, render, waitUntil, fillIn } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
Expand All @@ -17,7 +17,7 @@ module('Integration | Component | tasks', function (hooks) {
assert.ok(this.element.textContent.trim().includes('tasks'));
});

test('there is a fetch task button if no in progress task are there', async function (assert) {
skip('there is a fetch task button if no in progress task are there', async function (assert) {
this.setProperties({
onTaskChange: () => {},
onTaskUpdate: () => {},
Expand Down
9 changes: 2 additions & 7 deletions tests/integration/components/tasks/modal-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -200,8 +200,7 @@ module('Integration | Component | tasks/modal', function (hooks) {
showModal: true,
buttonRequired: true,
dev: false,
message:
'This task will be marked as done and a new task will be assigned to you',
message: 'This task will be marked as Done',
});

await render(hbs`
Expand All @@ -219,11 +218,7 @@ module('Integration | Component | tasks/modal', function (hooks) {

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-title]').hasText('This task will be marked as Done');
assert.dom('[data-test-notAssignBtn]').hasText('Proceed');
});
});

0 comments on commit 405c3fb

Please sign in to comment.