From 15e680cbe646ff33cbd6b091ccda53b929e4a07a Mon Sep 17 00:00:00 2001 From: Lakshay Manchanda Date: Wed, 24 Jan 2024 01:57:56 +0530 Subject: [PATCH 1/7] Removed the feature flag from identity page --- app/controllers/identity.js | 7 -- app/templates/identity.hbs | 173 ++++++++---------------------------- 2 files changed, 38 insertions(+), 142 deletions(-) diff --git a/app/controllers/identity.js b/app/controllers/identity.js index 7af80206..4497d190 100644 --- a/app/controllers/identity.js +++ b/app/controllers/identity.js @@ -37,13 +37,6 @@ export default class IdentityController extends Controller { return 'getStarted'; } - get isDev() { - if (this.router.currentRoute) { - return this.router.currentRoute.queryParams.dev; - } - return false; - } - @tracked state = this.intialState; @action setState(value) { diff --git a/app/templates/identity.hbs b/app/templates/identity.hbs index 2a6e1883..4167f53c 100644 --- a/app/templates/identity.hbs +++ b/app/templates/identity.hbs @@ -1,140 +1,43 @@ {{page-title 'Identity'}} -{{#if this.isDev}} -
- header - hero - +
+ header + hero + + {{#if (eq this.state 'getStarted')}} +
Connect your Profile Service with Identity + Service
+ {{/if}} +
{{#if (eq this.state 'getStarted')}} -
Connect your Profile Service with Identity - Service
+ + {{else if (eq this.state 'step1')}} + + {{else if (eq this.state 'step2')}} + + {{else if (eq this.state 'step3')}} + + {{else if (eq this.state 'reload')}} + + {{else if (eq this.state 'verified')}} + + {{else if (eq this.state 'blocked')}} + {{/if}} -
- {{#if (eq this.state 'getStarted')}} - - {{else if (eq this.state 'step1')}} - - {{else if (eq this.state 'step2')}} - - {{else if (eq this.state 'step3')}} - - {{else if (eq this.state 'reload')}} - - {{else if (eq this.state 'verified')}} - - {{else if (eq this.state 'blocked')}} - - {{/if}} -
- header-hero - footer
-{{else}} -

- Identity Service Verification -

-
- {{#if (eq @model.profileStatus 'PENDING')}} -

Verification process is Pending!

- - {{else if (eq @model.profileStatus 'VERIFIED')}} -

Verification Done!

- {{else}} - {{#if (eq @model.profileStatus 'BLOCKED')}} -

Your previous chaincode is blocked for some reason. Please generate a - new chaincode.

- {{/if}} -
- -
- -
-
- - -
-
- -
-
- - - -

{{this.identityError}}

- {{/if}} -
-{{/if}} \ No newline at end of file + header-hero + footer +
\ No newline at end of file From 4cd68b1f65cd73e1fd426f1c93652e30a0ebb4d6 Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Sat, 3 Feb 2024 09:28:57 +0530 Subject: [PATCH 2/7] Added STATUS_SITE env var for staging --- config/environment.js | 1 + 1 file changed, 1 insertion(+) diff --git a/config/environment.js b/config/environment.js index 3a402a68..7292d216 100644 --- a/config/environment.js +++ b/config/environment.js @@ -63,6 +63,7 @@ module.exports = function (environment) { if (environment === 'staging') { ENV.BASE_API_URL = 'https://staging-api.realdevsquad.com'; + ENV.STATUS_SITE = 'https://staging-status.realdevsquad.com'; } if (environment === 'production') { From 222dbdbce4bf39fab972c5cafa87dcc2eb04e56b Mon Sep 17 00:00:00 2001 From: Joy <56365512+ardourApeX@users.noreply.github.com> Date: Tue, 6 Feb 2024 09:10:05 +0530 Subject: [PATCH 3/7] Chore : Removed feature flag from extension request (#564) * Chore : Removed feature flag from extension request * Style : Fixed progress bar issue * Style : Converted % into rem --- app/components/task/extension-form.hbs | 78 ----- app/components/task/extension-form.js | 160 ----------- app/components/task/holder.hbs | 21 +- app/styles/tasks.css | 18 ++ .../components/tasks/extension-form-test.js | 267 ------------------ .../tasks/multiple-extension-form-test.js | 72 +---- 6 files changed, 27 insertions(+), 589 deletions(-) delete mode 100644 app/components/task/extension-form.hbs delete mode 100644 app/components/task/extension-form.js delete mode 100644 tests/integration/components/tasks/extension-form-test.js diff --git a/app/components/task/extension-form.hbs b/app/components/task/extension-form.hbs deleted file mode 100644 index 0f32dce7..00000000 --- a/app/components/task/extension-form.hbs +++ /dev/null @@ -1,78 +0,0 @@ -
-
-
-

{{@title}}

- {{#if this.createExtensionRequest}} -
-

Create Extension Request!!!

-
- {{#if this.createExtensionRequestError}} -

Error: {{this.createExtensionRequestError}}

- {{/if}} - - - -

Old ETA - {{this.oldETA}}

- - - - -
-
- {{else}} -
- {{#if this.extensionData.value}} -
- {{#each this.extensionData.value as |extension|}} - - {{/each}} -
- {{else if this.extensionData.isLoading}} -
- -
- {{else if this.extensionData.error}} -

{{this.extensionData.error}}

- - {{/if}} -
- {{/if}} - -
-
\ No newline at end of file diff --git a/app/components/task/extension-form.js b/app/components/task/extension-form.js deleted file mode 100644 index c9867b83..00000000 --- a/app/components/task/extension-form.js +++ /dev/null @@ -1,160 +0,0 @@ -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; - @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}`, - { - 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); - 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 - createExtensionRequestToggle(e) { - e.stopPropagation(); - this.createExtensionRequest = !this.createExtensionRequest; - } - - @action - async submitExtensionRequest(e) { - e.preventDefault(); - this.disableExtensionRequestClose = true; - this.createExtensionRequestError = null; - //submit button - e.submitter.disabled = 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', - }); - e.submitter.disabled = false; - this.disableExtensionRequestClose = false; - this.createExtensionRequestError = - 'The newEndsOn value cannot be smaller than the oldEndsOn value'; - 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`, { - 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.args.closeModel, 2000); - return; - } - this.toast.error('Something went wrong!', '', { - ...toastNotificationTimeoutOptions, - timeOut: '3000', - }); - e.submitter.disabled = false; - } catch (error) { - this.toast.error(error.message, '', { - ...toastNotificationTimeoutOptions, - timeOut: '3000', - }); - setTimeout(this.args.closeModel, 2000); - } - } - - @action - changeExtensionRequestETA(e) { - 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', - }); - e.target.value = ''; - this.createExtensionRequestError = - 'The newEndsOn value cannot be smaller than the oldEndsOn value'; - return; - } else this.createExtensionRequestError = null; - } -} diff --git a/app/components/task/holder.hbs b/app/components/task/holder.hbs index f4cb4708..56adab52 100644 --- a/app/components/task/holder.hbs +++ b/app/components/task/holder.hbs @@ -15,21 +15,12 @@
{{#if this.extensionFormOpened}} - {{#if @dev}} - - {{else}} - - {{/if}} + {{/if}} {{#if (not-eq this.status this.TASK_KEYS.VERIFIED)}} diff --git a/app/styles/tasks.css b/app/styles/tasks.css index 22788c88..09a86c65 100644 --- a/app/styles/tasks.css +++ b/app/styles/tasks.css @@ -182,6 +182,24 @@ justify-content: space-between; align-items: center; } +.task-details__title-container a { + max-width: 18.5rem; +} +@media screen and (min-width: 900px) { + .task-details__title-container a { + max-width: 18.3rem; + } +} +@media screen and ((max-width: 900px) and (min-width: 720px)) { + .task-details__title-container a { + max-width: 18.3rem; + } +} +@media screen and (max-width: 720px) { + .task-details__title-container a { + max-width: 100%; + } +} #task-update { border: 1px solid var(--tasks-page--text); diff --git a/tests/integration/components/tasks/extension-form-test.js b/tests/integration/components/tasks/extension-form-test.js deleted file mode 100644 index f63b8a31..00000000 --- a/tests/integration/components/tasks/extension-form-test.js +++ /dev/null @@ -1,267 +0,0 @@ -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 } from '@ember/test-helpers'; -import { hbs } from 'ember-cli-htmlbars'; -import makeServer from 'website-my/mirage/config'; - -module('Integration | Component | Extension Request 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[0]); - 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}}` - ); - assert - .dom(this.element.querySelector('[data-test-title]')) - .hasText('Form for extension Request'); - await click( - this.element.querySelector('[data-test-extension-form-container-close]') - ); - assert.dom(this.element.querySelector('[data-test-title]')).doesNotExist(); - - extensionFormOpened = true; - this.set('extensionFormOpened', extensionFormOpened); - assert - .dom(this.element.querySelector('[data-test-title]')) - .hasText('Form for extension Request'); - await click( - this.element.querySelector('[data-test-extension-form-container-back]') - ); - 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('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(); - }); - - 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]', - '2022-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' - ); - - // if filled valid time then remove the error - await fillIn( - '[data-test-extension-form-newEndsOn-input]', - '2023-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'); - }); - - test('When extension requests found, it should display the data', async function (assert) { - let extensionRequestData = extensionRequests[0]; - this.set('task', tasksData[0]); - 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']); - }); -}); diff --git a/tests/integration/components/tasks/multiple-extension-form-test.js b/tests/integration/components/tasks/multiple-extension-form-test.js index 9e101ae2..913d557d 100644 --- a/tests/integration/components/tasks/multiple-extension-form-test.js +++ b/tests/integration/components/tasks/multiple-extension-form-test.js @@ -134,17 +134,13 @@ module('Integration | Component | Multiple Extension Form', function (hooks) { ); 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]') ); @@ -162,9 +158,7 @@ module('Integration | Component | Multiple Extension Form', function (hooks) { ); assert .dom(this.element.querySelector('[data-test-extension-from-error]')) - .hasText( - 'Error: The newEndsOn value cannot be smaller than the oldEndsOn value' - ); + .hasText('New ETA must be greater than Old ETA'); await settled(); // if filled valid time then remove the error @@ -174,67 +168,7 @@ module('Integration | Component | Multiple Extension Form', function (hooks) { ); 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'); + .doesNotContainText(); }); test('When previous extension request is approved, the button to create extension request should be there', async function (assert) { From b5b1bae9258db0365c21c6a9c68f5667a8bd9490 Mon Sep 17 00:00:00 2001 From: Lakshay Manchanda <45519620+lakshayman@users.noreply.github.com> Date: Wed, 7 Feb 2024 23:57:22 +0530 Subject: [PATCH 4/7] Revert "Removed the feature flag from identity page (#551)" (#566) This reverts commit fe497aee425321e36141a1261d2533175b7cfc69. --- app/controllers/identity.js | 7 ++ app/templates/identity.hbs | 173 ++++++++++++++++++++++++++++-------- 2 files changed, 142 insertions(+), 38 deletions(-) diff --git a/app/controllers/identity.js b/app/controllers/identity.js index 4497d190..7af80206 100644 --- a/app/controllers/identity.js +++ b/app/controllers/identity.js @@ -37,6 +37,13 @@ export default class IdentityController extends Controller { return 'getStarted'; } + get isDev() { + if (this.router.currentRoute) { + return this.router.currentRoute.queryParams.dev; + } + return false; + } + @tracked state = this.intialState; @action setState(value) { diff --git a/app/templates/identity.hbs b/app/templates/identity.hbs index 4167f53c..2a6e1883 100644 --- a/app/templates/identity.hbs +++ b/app/templates/identity.hbs @@ -1,43 +1,140 @@ {{page-title 'Identity'}} -
- header - hero - - {{#if (eq this.state 'getStarted')}} -
Connect your Profile Service with Identity - Service
- {{/if}} -
+{{#if this.isDev}} +
+ header + hero + {{#if (eq this.state 'getStarted')}} - - {{else if (eq this.state 'step1')}} - - {{else if (eq this.state 'step2')}} - - {{else if (eq this.state 'step3')}} - - {{else if (eq this.state 'reload')}} - - {{else if (eq this.state 'verified')}} - - {{else if (eq this.state 'blocked')}} - +
Connect your Profile Service with Identity + Service
{{/if}} +
+ {{#if (eq this.state 'getStarted')}} + + {{else if (eq this.state 'step1')}} + + {{else if (eq this.state 'step2')}} + + {{else if (eq this.state 'step3')}} + + {{else if (eq this.state 'reload')}} + + {{else if (eq this.state 'verified')}} + + {{else if (eq this.state 'blocked')}} + + {{/if}} +
+ header-hero + footer
- header-hero - footer -
\ No newline at end of file +{{else}} +

+ Identity Service Verification +

+
+ {{#if (eq @model.profileStatus 'PENDING')}} +

Verification process is Pending!

+ + {{else if (eq @model.profileStatus 'VERIFIED')}} +

Verification Done!

+ {{else}} + {{#if (eq @model.profileStatus 'BLOCKED')}} +

Your previous chaincode is blocked for some reason. Please generate a + new chaincode.

+ {{/if}} +
+ +
+ +
+
+ + +
+
+ +
+
+ + + +

{{this.identityError}}

+ {{/if}} +
+{{/if}} \ No newline at end of file From 6eb5dbb90643c7ba38d0f6e4972b6eed564355ff Mon Sep 17 00:00:00 2001 From: OJAS ELAWADHI <83074474+ojas-elawadhi@users.noreply.github.com> Date: Wed, 14 Feb 2024 05:26:25 +0530 Subject: [PATCH 5/7] fixed responsiveness of height (#570) * fixed responsiveness of height * fixed responsiveness --- app/styles/identity.css | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/app/styles/identity.css b/app/styles/identity.css index 13c53764..59ed7783 100644 --- a/app/styles/identity.css +++ b/app/styles/identity.css @@ -454,3 +454,32 @@ font-size: 12px; } } + +@media (max-height: 870px) and (min-width: 460px) { + .identity-rds-logo { + width: 174px; + margin-top: 3%; + } + + .identity-heading { + font-size: 24px; + } + + .identity-box { + height: 202px; + } + + .identity-box-heading { + font-size: 22px; + } + + .identity-box-desc { + font-size: 18px; + } + + .identity-box-button { + padding: 10px; + font-size: 16px; + margin-top: 18px; + } +} From d130a5150b7d52d07d50375514f5ff65774c4f8a Mon Sep 17 00:00:00 2001 From: Lakshay Manchanda Date: Wed, 14 Feb 2024 02:16:40 +0530 Subject: [PATCH 6/7] Profile page disabled for developers --- app/components/profile-field.hbs | 1 + app/routes/profile.js | 5 ++++ app/styles/profile.css | 11 ++++++++ app/templates/profile.hbs | 43 ++++++++++++++++++++++++-------- 4 files changed, 50 insertions(+), 10 deletions(-) diff --git a/app/components/profile-field.hbs b/app/components/profile-field.hbs index e1c00879..ca4060e5 100644 --- a/app/components/profile-field.hbs +++ b/app/components/profile-field.hbs @@ -10,6 +10,7 @@ placeholder={{@placeholder}} class="profile-field-input" required={{@required}} + disabled={{@isDeveloper}} {{on 'input' (fn this.inputFieldChanged)}} {{on 'blur' (fn this.checkInputValidation)}} /> diff --git a/app/routes/profile.js b/app/routes/profile.js index 45527b20..7254d6ce 100644 --- a/app/routes/profile.js +++ b/app/routes/profile.js @@ -8,6 +8,10 @@ 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', }); @@ -15,6 +19,7 @@ export default class ProfileRoute extends Route { 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); diff --git a/app/styles/profile.css b/app/styles/profile.css index 9178b7ac..f518b6b6 100644 --- a/app/styles/profile.css +++ b/app/styles/profile.css @@ -39,6 +39,11 @@ border-color: var(--profile-input-outline-clr); } +.profile-page-error { + text-align: center; + color: red; +} + .profile-field-input { padding: 0 1.25rem; border: none; @@ -46,6 +51,12 @@ 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); } diff --git a/app/templates/profile.hbs b/app/templates/profile.hbs index 88403f18..0132af9d 100644 --- a/app/templates/profile.hbs +++ b/app/templates/profile.hbs @@ -1,35 +1,58 @@ {{page-title 'Profile'}} -
-
+
+
{{#if @model.picture.url}} - user profile + user profile {{else}} - user profile + user profile {{/if}} -
+ {{#if (get @model 'isDeveloper')}} +

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 + here.

+ {{/if}} {{#each this.fields as |field|}} - {{/each}}
- +
From 02a1dd6c6885cf1f523fd3c10f7339c27bca1f56 Mon Sep 17 00:00:00 2001 From: Lakshay Manchanda Date: Thu, 15 Feb 2024 00:17:58 +0530 Subject: [PATCH 7/7] Tests added --- .../components/profile-field-test.js | 54 +++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/tests/integration/components/profile-field-test.js b/tests/integration/components/profile-field-test.js index 9fb35415..c1287b9a 100644 --- a/tests/integration/components/profile-field-test.js +++ b/tests/integration/components/profile-field-test.js @@ -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` + + `); + + 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` + + `); + + 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(); + }); });