bpm-core 0.0.55 → 0.0.56
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +13 -10
- package/esm2022/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.mjs +5 -3
- package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +7 -5
- package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +5 -3
- package/esm2022/lib/components/app-component-sections/previous-requests/previous-requests.component.mjs +196 -36
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +5 -3
- package/esm2022/lib/components/app-component-sections/workflow-section/workflow-section.component.mjs +5 -3
- package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs +6 -4
- package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +5 -3
- package/esm2022/lib/components/shared-components/form-field/attachment-section/attachment-section.component.mjs +5 -3
- package/esm2022/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/doc-uploader/docs-uploader.component.mjs +6 -4
- package/esm2022/lib/components/shared-components/form-field/search-employee/search-employee.component.mjs +5 -3
- package/esm2022/lib/components/shared-components/table/table.component.mjs +240 -0
- package/esm2022/lib/directives/skip-location.directive.mjs +28 -0
- package/esm2022/lib/enums/actions.enum.mjs +21 -0
- package/esm2022/lib/enums/colors.enum.mjs +6 -0
- package/esm2022/lib/enums/events.enum.mjs +6 -0
- package/esm2022/lib/helpers/shared.helper.mjs +26 -0
- package/esm2022/lib/interfaces/action.interface.mjs +2 -0
- package/esm2022/lib/regex/index.mjs +2 -0
- package/esm2022/lib/services/core.service.ts.mjs +7 -5
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +5 -3
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +7 -4
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/bpm-core.mjs +241 -67
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +2 -0
- package/lib/components/app-component-sections/feedback-section/feedback-section.component.d.ts +2 -1
- package/lib/components/app-component-sections/form-section/form-section.component.d.ts +2 -1
- package/lib/components/app-component-sections/previous-requests/previous-requests.component.d.ts +123 -1
- package/lib/components/app-component-sections/service-header/service-header.component.d.ts +2 -1
- package/lib/components/app-component-sections/workflow-section/workflow-section.component.d.ts +2 -1
- package/lib/components/shared-components/action-buttons/action-buttons.component.d.ts +2 -1
- package/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.d.ts +2 -1
- package/lib/components/shared-components/form-field/attachment-section/attachment-section.component.d.ts +2 -1
- package/lib/components/shared-components/form-field/doc-uploader/docs-uploader.component.d.ts +2 -1
- package/lib/components/shared-components/form-field/search-employee/search-employee.component.d.ts +2 -1
- package/lib/components/shared-components/form-field/shared-imports.d.ts +2 -2
- package/lib/components/shared-components/table/table.component.d.ts +76 -0
- package/lib/directives/skip-location.directive.d.ts +10 -0
- package/lib/enums/actions.enum.d.ts +19 -0
- package/lib/enums/colors.enum.d.ts +4 -0
- package/lib/enums/events.enum.d.ts +4 -0
- package/lib/helpers/shared.helper.d.ts +1 -0
- package/lib/interfaces/action.interface.d.ts +7 -0
- package/lib/regex/index.d.ts +1 -0
- package/lib/services/core.service.ts.d.ts +2 -0
- package/lib/testComponent/general-approver-section/general-approver-section.component.d.ts +2 -1
- package/lib/testComponent/request-details-section/request-details-section.component.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input } from '@angular/core';
|
|
2
2
|
import * as Constants from '../../../constants/constants';
|
|
3
3
|
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
4
|
import { FeedBackService } from '../../../services';
|
|
@@ -12,6 +12,7 @@ import { FaqSidenavComponent } from '../faq-sidenav/faq-sidenav.component';
|
|
|
12
12
|
import { ActivitiesComponent } from '../activities/activities.component';
|
|
13
13
|
import { format } from 'date-fns';
|
|
14
14
|
import { PreviousRequestsComponent } from "../previous-requests/previous-requests.component";
|
|
15
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
15
16
|
import * as i0 from "@angular/core";
|
|
16
17
|
import * as i1 from "../../../services";
|
|
17
18
|
import * as i2 from "@angular/material/dialog";
|
|
@@ -45,6 +46,7 @@ export class ServiceHeaderComponent {
|
|
|
45
46
|
serviceFaq = [];
|
|
46
47
|
approvals = [];
|
|
47
48
|
flagPriority;
|
|
49
|
+
destroyRef = inject(DestroyRef);
|
|
48
50
|
constructor(cdRef, coreService, i18n, feedBackService, dialog, sidenavService, toasterService) {
|
|
49
51
|
this.cdRef = cdRef;
|
|
50
52
|
this.coreService = coreService;
|
|
@@ -143,7 +145,7 @@ export class ServiceHeaderComponent {
|
|
|
143
145
|
* @return {void}
|
|
144
146
|
*/
|
|
145
147
|
subscribeToSetFlagPriority(id) {
|
|
146
|
-
this.coreService.setFlagPriority(id).subscribe((response) => {
|
|
148
|
+
this.coreService.setFlagPriority(id).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((response) => {
|
|
147
149
|
if (response) {
|
|
148
150
|
this.toasterService.success(this.i18n.translate('flagStatusUpdated'));
|
|
149
151
|
}
|
|
@@ -266,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
266
268
|
}], serviceFaq: [{
|
|
267
269
|
type: Input
|
|
268
270
|
}] } });
|
|
269
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAmC,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AAEzG,OAAO,KAAK,SAAS,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAC,eAAe,EAAY,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAA+B,eAAe,EAAiB,MAAM,mBAAmB,CAAC;AAChG,OAAO,EAAC,uBAAuB,EAAC,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAC,wBAAwB,EAAC,MAAM,gDAAgD,CAAC;AACxF,OAAO,EAAC,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAC,UAAU,EAAC,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAC,OAAO,EAAE,WAAW,EAAE,cAAc,EAAC,MAAM,wBAAwB,CAAC;AAC5E,OAAO,EAAC,mBAAmB,EAAC,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAC,mBAAmB,EAAC,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAC;AAEhC,OAAO,EAAC,yBAAyB,EAAC,MAAM,kDAAkD,CAAC;;;;;AAE3F,MAAM,SAAS,GAAG;IAChB,CAAC,SAAS,CAAC,oBAAoB,CAAC,EAAE,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAC;IAClE,CAAC,SAAS,CAAC,qBAAqB,CAAC,EAAE,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAC;IACnE,CAAC,SAAS,CAAC,kBAAkB,CAAC,EAAE,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAC;IAChE,CAAC,SAAS,CAAC,0BAA0B,CAAC,EAAE,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAC;IACxE,CAAC,SAAS,CAAC,kBAAkB,CAAC,EAAE,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAC;IAChE,CAAC,SAAS,CAAC,mBAAmB,CAAC,EAAE,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAC;IAClE,SAAS,EAAE,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAC;CAC7C,CAAA;AA6BD,MAAM,OAAO,sBAAsB;IAed;IACV;IACA;IAAwC;IAC9B;IAAoC;IACpC;IAlBV,IAAI,CAAO;IACX,WAAW,GAAG,KAAK,CAAC;IACpB,SAAS,GAAG,KAAK,CAAC;IAClB,UAAU,GAAG,KAAK,CAAC;IACnB,mBAAmB,GAAG,KAAK,CAAC;IAC5B,eAAe,CAAM;IACrB,YAAY,CAAS;IACrB,SAAS,CAAS;IAClB,OAAO,CAAU;IACjB,UAAU,GAAU,EAAE,CAAC;IAChC,SAAS,GAAU,EAAE,CAAC;IACtB,YAAY,CAAS;IAErB,YACmB,KAAwB,EAClC,WAAwB,EACxB,IAAqB,EAAmB,eAAgC,EAC9D,MAAiB,EAAmB,cAA8B,EAClE,cAA6B;QAJ7B,UAAK,GAAL,KAAK,CAAmB;QAClC,gBAAW,GAAX,WAAW,CAAa;QACxB,SAAI,GAAJ,IAAI,CAAiB;QAAmB,oBAAe,GAAf,eAAe,CAAiB;QAC9D,WAAM,GAAN,MAAM,CAAW;QAAmB,mBAAc,GAAd,cAAc,CAAgB;QAClE,mBAAc,GAAd,cAAc,CAAe;IAC7C,CAAC;IAEJ;;;;OAIG;IACH,eAAe;QACb,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC9C,IAAI,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,qBAAqB,CAAC,CAAC;QAC/F,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB;QACjB,MAAM,YAAY,GAAQ,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;QACjD,MAAM,mBAAmB,GAAG,EAAE,CAAC;QAC/B,KAAK,MAAM,OAAO,IAAI,YAAY,EAAE,CAAC;YACnC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,mBAAmB,CAAC;QAClD,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACK,oBAAoB,CAAC,IAAI;QAC/B,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC;YAC1B,KAAK,EAAE,IAAI,CAAC,WAAW;YACvB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC;YAC7B,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,YAAY,CAAC;YACzD,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,QAAQ,CAAC;YACrD,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC;YAC5B,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC;SAChC,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE;YACzC,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE;gBACJ,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe;gBAClC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS;gBAC9B,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,cAAc,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,eAAe,CAAC;YACtD,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,uBAAuB,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,EAAU;QACxB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,EAAE,CAAC;QACtC,IAAI,CAAC,0BAA0B,CAAC,EAAE,CAAC,CAAC;IACtC,CAAC;IAED;;;;;OAKG;IACH,0BAA0B,CAAC,EAAU;QACnC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,QAAa,EAAE,EAAE;YAC/D,IAAI,QAAQ,EAAE,CAAC;gBACb,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAC;YACxE,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,MAAc;QACxB,+CAA+C;QAC/C,IAAI,cAAc,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,SAAS,CAAC,CAAC;QAC/D,OAAO,cAAc,CAAC,KAAK,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3F,CAAC;IAED;;;;;;OAMG;IACH,kBAAkB,CAAC,eAAsC;QACvD,eAAe,EAAE,OAAO,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE;YAC/C,IAAI,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YACnD,IAAI,mBAAmB,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;YAC7D,MAAM,GAAG,GAAG;gBACV,EAAE,EAAE,KAAK,GAAG,CAAC;gBACb,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,UAAU;gBACtC,KAAK,EAAE,YAAY,CAAC,YAAY;gBAChC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,WAAW,CAAC;gBAC1D,MAAM,EAAE,cAAc;gBACtB,WAAW,EAAE,mBAAmB;aACjC,CAAC;YACF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACK,iBAAiB,CAAC,KAAa;QACrC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;YAClC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACrF,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;OAKG;IACK,sBAAsB,CAAC,KAAa;QAC1C,IAAI,WAAW,GAAG,EAAE,CAAC;QACrB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;YAClC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC;QAC1E,CAAC;QACD,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;;;;OAKG;IACK,WAAW,CAAC,KAAa;QAC/B,OAAO,oDAAoD,GAAG,KAAK,CAAC;IACtE,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAC;IACjE,CAAC;uGA/MU,sBAAsB;2FAAtB,sBAAsB,8VAJtB,CAAC,eAAe;YACzB,EAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,EAAE,EAAC;SACzC,0BCpDH,k+eA+OA,23JDtMI,IAAI,4FACJ,gBAAgB,+BAGhB,OAAO;;2FASE,sBAAsB;kBAnBlC,SAAS;+BACE,qBAAqB,cAGnB,IAAI,WACP;wBACP,IAAI;wBACJ,gBAAgB;wBAChB,UAAU;wBACV,cAAc;wBACd,OAAO;wBACP,OAAO;wBACP,WAAW;qBACZ,WACQ,CAAC,sBAAsB,CAAC,aACtB,CAAC,eAAe;wBACzB,EAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,EAAE,EAAC;qBACzC;6PAGQ,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, Input} from '@angular/core';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants/constants';\r\nimport {MAT_DIALOG_DATA, MatDialog} from '@angular/material/dialog';\r\nimport {CoreI18nService, CoreService, FeedBackService, SidenavService} from '../../../services';\r\nimport {ProfileSectionComponent} from '../profile-section/profile-section.component';\r\nimport {FeedbackSectionComponent} from '../feedback-section/feedback-section.component';\r\nimport {NgClass, NgIf} from '@angular/common';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatDivider} from '@angular/material/divider';\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from '@angular/material/menu';\r\nimport {FaqSidenavComponent} from '../faq-sidenav/faq-sidenav.component';\r\nimport {ActivitiesComponent} from '../activities/activities.component';\r\nimport {format} from 'date-fns';\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {PreviousRequestsComponent} from \"../previous-requests/previous-requests.component\";\r\n\r\nconst StatusMap = {\r\n  [Constants.FORM_STATUS_REJECTED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCELLED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_REJECT]: {class: 'danger', icon: 'close'},\r\n  [Constants.SECTION_STATUS_UNSATISFIED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCEL]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_PENDING]: {class: 'warning', icon: 'clock'},\r\n  'default': {class: 'success', icon: 'check'}\r\n}\r\n\r\ninterface ApprovalHistoryItem {\r\n  approver: {\r\n    personName: string;\r\n    personEmail: string;\r\n  };\r\n  positionType: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-service-header',\r\n  templateUrl: './service-header.component.html',\r\n  styleUrls: ['./service-header.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgIf,\r\n    SatPopoverModule,\r\n    MatDivider,\r\n    MatMenuTrigger,\r\n    NgClass,\r\n    MatMenu,\r\n    MatMenuItem\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [FeedBackService,\r\n    {provide: MAT_DIALOG_DATA, useValue: {}},\r\n  ]\r\n})\r\nexport class ServiceHeaderComponent implements AfterViewInit {\r\n  @Input() form: Form;\r\n  @Input() showHistory = false;\r\n  @Input() isLoading = false;\r\n  @Input() isReadOnly = false;\r\n  @Input() showApprovalHistory = false;\r\n  @Input() approvalHistory: any;\r\n  @Input() creationDate: string;\r\n  @Input() formTitle: string;\r\n  @Input() section: Section;\r\n  @Input() serviceFaq: any[] = [];\r\n  approvals: any[] = [];\r\n  flagPriority: string;\r\n\r\n  constructor(\r\n    private readonly cdRef: ChangeDetectorRef,\r\n    public coreService: CoreService,\r\n    public i18n: CoreI18nService, private readonly feedBackService: FeedBackService,\r\n    private readonly dialog: MatDialog, private readonly sidenavService: SidenavService,\r\n    private readonly toasterService: ToastrService\r\n  ) {}\r\n\r\n  /**\r\n   * Executes after the view has been fully initialized.\r\n   *\r\n   * @return {void}\r\n   */\r\n  ngAfterViewInit() {\r\n    this.getApprovalHistory(this.approvalHistory);\r\n    if (this.form?.header?.creationDate) {\r\n      this.creationDate = format(new Date(this.form?.header?.creationDate), \"dd/MM/yyyy hh:mm:ss\");\r\n    }\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Handles the click event on the comments form.\r\n   * Retrieves comments from the form, transforms them, and updates activities in the core service.\r\n   * Finally, publishes an 'open' event to the sidenav service to open the ActivitiesComponent.\r\n   *\r\n   * @return {void}\r\n   */\r\n  onCommentsFormClick() {\r\n    const formComments: any = this.form.commentsDrop;\r\n    const transformedComments = [];\r\n    for (const comment of formComments) {\r\n      transformedComments.push(this.transformCommentItem(comment));\r\n    }\r\n    this.coreService.activities = transformedComments;\r\n    this.sidenavService.publish('open', ActivitiesComponent);\r\n  }\r\n\r\n  /**\r\n   * Transforms a comment item into a different format for display.\r\n   *\r\n   * @param {Object} item - The original comment item to transform.\r\n   * @return {Object} - The transformed comment item with specific properties including name, title, image, date, time, comment, and attachments.\r\n   */\r\n  private transformCommentItem(item) {\r\n    return {\r\n      name: item['employeeName'],\r\n      title: item.jobPosition,\r\n      image: item['profilePicture'],\r\n      date: format(new Date(item['commentDate']), 'yyyy-MM-dd'),\r\n      time: format(new Date(item['commentDate']), 'h:mm a'),\r\n      comment: item['commentBody'],\r\n      attachments: item['attachment']\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Opens a dialog for providing feedback.\r\n   *\r\n   * @return {void}\r\n   */\r\n  feedback(): void {\r\n    this.dialog.open(FeedbackSectionComponent, {\r\n      panelClass: ['main-popup'],\r\n      data: {\r\n        profile: this.form.profileInfoDrop,\r\n        inboxItem: this.form.inboxItem,\r\n        form: this.form\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Updates the sidenav with user profile information if not already loading.\r\n   *\r\n   * @return {void}\r\n   */\r\n  showUserInfo(): void {\r\n    if (!this.isLoading) {\r\n      this.sidenavService.data = this.form?.profileInfoDrop;\r\n      this.sidenavService.publish('open', ProfileSectionComponent);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set the priority flag for the inbox item with the provided ID.\r\n   *\r\n   * @param {string} id - The ID of the priority flag to be set for the inbox item.\r\n   * @return {void}\r\n   */\r\n  setFlagPriority(id: string) {\r\n    this.flagPriority = id;\r\n    this.form.inboxItem.flagPriority = id;\r\n    this.subscribeToSetFlagPriority(id);\r\n  }\r\n\r\n  /**\r\n   * Subscribe to set flag priority for a specific identifier.\r\n   *\r\n   * @param {string} id - The identifier of the flag to set priority for.\r\n   * @return {void}\r\n   */\r\n  subscribeToSetFlagPriority(id: string): void {\r\n    this.coreService.setFlagPriority(id).subscribe((response: any) => {\r\n      if (response) {\r\n        this.toasterService.success(this.i18n.translate('flagStatusUpdated'));\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS class associated with the input status.\r\n   *\r\n   * @param {string} status - The status for which the CSS class is needed.\r\n   * @return {string} - The CSS class corresponding to the given status.\r\n   */\r\n  statusClass(status: string): string {\r\n    // status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.class;\r\n  }\r\n\r\n  /**\r\n   * Opens the FAQ side navigation.\r\n   * @return {void}\r\n   */\r\n  openFaq() {\r\n    this.sidenavService.publish('open', FaqSidenavComponent, 'end', 'over', this.serviceFaq);\r\n  }\r\n\r\n  /**\r\n   * Retrieves approval history information for each approval item in the provided array.\r\n   *\r\n   * @param {ApprovalHistoryItem[]} approvalHistory - The array containing approval history items.\r\n   *\r\n   * @return {void} - This method does not return any value. It updates the internal 'approvals' array.\r\n   */\r\n  getApprovalHistory(approvalHistory: ApprovalHistoryItem[]) {\r\n    approvalHistory?.forEach((approvalItem, index) => {\r\n      let approvalStatus = this.getApprovalStatus(index);\r\n      let approvalStatusLabel = this.getApprovalStatusLabel(index);\r\n      const obj = {\r\n        id: index + 1,\r\n        name: approvalItem.approver.personName,\r\n        title: approvalItem.positionType,\r\n        image: this.getImageUrl(approvalItem.approver.personEmail),\r\n        status: approvalStatus,\r\n        statusLabel: approvalStatusLabel,\r\n      };\r\n      this.approvals.push(obj);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Retrieves the approval status for a specific section in the form.\r\n   *\r\n   * @param {number} index - The index of the section for which the approval status is required.\r\n   * @return {string} The approval status of the specified section. Returns an empty string if the section does not exist.\r\n   */\r\n  private getApprovalStatus(index: number): string {\r\n    let status = '';\r\n    if (this.form.sections[index + 1]) {\r\n      status = this.statusClass(this.form.sections[index + 1].body.details.decision.key);\r\n    }\r\n    return status;\r\n  }\r\n\r\n  /**\r\n   * Retrieves the approval status label from the form section based on the given index.\r\n   *\r\n   * @param {number} index - The index of the form section for which the approval status label will be retrieved.\r\n   * @return {string} The approval status label retrieved from the specified form section.\r\n   */\r\n  private getApprovalStatusLabel(index: number): string {\r\n    let statusLabel = '';\r\n    if (this.form.sections[index + 1]) {\r\n      statusLabel = this.form.sections[index + 1].body.details.decision.value;\r\n    }\r\n    return statusLabel;\r\n  }\r\n\r\n  /**\r\n   * Retrieves the URL of the user's portrait image based on the provided email.\r\n   *\r\n   * @param {string} email - The email address of the user for whom the portrait URL is to be retrieved.\r\n   * @return {string} - The URL used to fetch the user's portrait image.\r\n   */\r\n  private getImageUrl(email: string): string {\r\n    return '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + email;\r\n  }\r\n\r\n  showPreviousRequests() {\r\n    this.sidenavService.publish('open', PreviousRequestsComponent);\r\n  }\r\n}\r\n","@if (form?.header?.status?.['key'] === 'NEW') {\r\n  <section\r\n    class=\"main-sidenav main-sidenav-full mb-4\"\r\n\r\n  >\r\n    <div class=\"sidenav-title\">\r\n      <div class=\"d-flex align-items-center gap-3 w-100\">\r\n        <!-- <ds-button icon class=\"rotate-arrow\" size=\"small\" (click)=\"goBack()\" *ngIf=\"!isInMobileApp() && showBack\">\r\n           <ds-icon icon=\"arrow-right\" class=\"fs-19 fc-black\"></ds-icon>\r\n         </ds-button>-->\r\n\r\n        <!--  <h3 class=\"flex-grow-0\">\r\n            {{ formTitle }}\r\n          </h3>-->\r\n\r\n        <section>\r\n          <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n            {{ i18n.translate('Hello') }}\r\n            {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n          </h6>\r\n          <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n            {{ formTitle }}\r\n            @if (serviceFaq.length) {\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            }\r\n          </h1>\r\n        </section>\r\n        <div class=\"d-flex align-items-center justify-content-end gap-2 flex-grow-1\">\r\n          @if (serviceFaq.length) {\r\n            <ds-button size=\"small\" icon>\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            </ds-button>\r\n          }\r\n          <!-- <ds-button size=\"small\" icon (click)=\"openWorkflow()\">\r\n            <ds-icon icon=\"bell-2-o\" class=\"fs-20 fc-coral\"></ds-icon>\r\n          </ds-button> -->\r\n          @if (!isReadOnly) {\r\n            <ds-button size=\"small\" icon (click)=\"showPreviousRequests()\">\r\n              <ds-icon icon=\"clock\" class=\"fs-20 fc-coral\"></ds-icon>\r\n            </ds-button>\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </section>\r\n\r\n  <!--  <header class=\"mb-4 mt-4 d-flex align-items-center justify-content-between align-items-end gap-2\">\r\n      <section>\r\n        <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n          {{ i18n.translate('Hello') }}\r\n          {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n        </h6>\r\n        <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n          {{ formTitle }}\r\n          @if (serviceFaq.length) {\r\n            <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n            </ds-icon>\r\n          }\r\n        </h1>\r\n      </section>\r\n    </header>-->\r\n} @else {\r\n\r\n  <div class=\"w-100\">\r\n    <section class=\"request-main-info  {{statusClass(form?.header?.status?.['key'])}}\">\r\n      <section class=\"request-info\">\r\n        <div class=\"request-info--body\">\r\n          <div class=\"d-flex align-items-center gap-2 flex-grow-1\">\r\n            <img\r\n              alt=\"\"\r\n              src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n            <h4 class=\"fs-22 fs-md-16 fc-black fw-medium mb-0 flex-grow-1 line-height-1-2\">\r\n              {{ formTitle }}\r\n            </h4>\r\n          </div>\r\n          <div class=\"d-flex align-items-center gap-2 request-info--status-action\">\r\n            <div class=\"d-inline-flex flex-column align-items-end\">\r\n              @if (!isLoading) {\r\n                <ds-status\r\n                  status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n                </ds-status>\r\n              }\r\n            </div>\r\n            <div class=\"d-flex align-items-center gap-2\">\r\n              <!-- <ds-button\r\n                 *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback =='true'|| form?.inboxItem?.hasFeedback=='true')\"\r\n                 square icon size=\"small\">\r\n                 <ds-icon icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\">\r\n                   &lt;!&ndash;                  [ngClass]=\"{'fc-green':feedBackIcon == 'feedbackResponded' , 'fc-red': feedBackIcon == 'respondToFeedback' , 'fc-yellow': feedBackIcon == 'waitingFeedback'}\"&ndash;&gt;\r\n                 </ds-icon>\r\n               </ds-button>-->\r\n              <!-- history-->\r\n              <ds-button\r\n                *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n                (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n                <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n              </ds-button>\r\n              <ng-content></ng-content>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"request-info--footer\">\r\n          @if (!isLoading) {\r\n            <ds-avatar\r\n              image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n              class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n          }\r\n          <div\r\n            class=\"d-flex align-items-center flex-wrap flex-grow-1 gap-1 gap-sm-2 line-height-1 request-info--header__details\">\r\n            <span\r\n              [ngClass]=\"{'loading-bg loading-width': isLoading}\"\r\n              class=\"fs-12 fw-medium d-none d-sm-inline-block\">{{ coreService.getShortName(form?.header?.['requesterName']) }}</span>\r\n            <span class=\"fs-20\">&#8226;</span>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\"> {{ form?.header?.formId }}</span>\r\n            <span class=\"fs-20\" *ngIf=\"creationDate\">&#8226;</span>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\"> {{ creationDate }}</span>\r\n          </div>\r\n        </div>\r\n      </section>\r\n    </section>\r\n\r\n  </div>\r\n\r\n\r\n  <!--<ng-container>\r\n    <div class=\"d-flex align-items-center justify-content-end gap-2 my-2\">\r\n      <ds-button\r\n        *ngIf=\"form?.inboxItem && !form.sections[form.sections.length -1].header.readOnly && !isLoading\"\r\n        square\r\n        icon\r\n        size=\"small\"\r\n        [matMenuTriggerFor]=\"menu\"\r\n        class=\"icon-btn-shadow\">\r\n        <ds-icon\r\n          [ngClass]=\"{'fc-purple' : (flagPriority === '0' ||  flagPriority === null),'fc-yellow' : flagPriority === '1','fc-green' : flagPriority === '2','fc-coral' : flagPriority === '3'}\"\r\n          icon=\"flag-o\" class=\"fs-20 fs-md-17 fc-purple\">\r\n        </ds-icon>\r\n      </ds-button>\r\n      <mat-menu #menu=\"matMenu\" panelClass=\"action-menu\">\r\n        <button mat-menu-item (click)=\"setFlagPriority('0')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-purple fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('1')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-yellow fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('2')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-green fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('3')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n      </mat-menu>\r\n\r\n      <ng-content></ng-content>\r\n    </div>\r\n    <header class=\"service-header bc-white p-3 p-sm-4 py-4 gap-3 {{statusClass(form?.header?.status?.['key'])}}\">\r\n\r\n      <div class=\"service-header-icon\">\r\n        <img\r\n          alt=\"\"\r\n          src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n      </div>\r\n\r\n      <div class=\"flex-grow-1 d-flex flex-column flex-sm-row align-items-sm-center gap-2\">\r\n        <div class=\"flex-grow-1\">\r\n          <h1 class=\"fs-20 fs-md-16 fw-bold fc-black header-title m-0\">{{ formTitle }}\r\n            @if (serviceFaq.length) {\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            }\r\n          </h1>\r\n          <div class=\"header-user d-flex align-items-sm-center gap-2 mt-sm-1\">\r\n            @if (!isLoading) {\r\n              <ds-avatar\r\n                image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n                class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n            }\r\n            <span\r\n              class=\"fs-12 text-truncate d-sm-block cursor-pointer\" (click)=\"showUserInfo()\"\r\n              [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ coreService.getShortName(form?.header?.requesterName) }}</span>\r\n            <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ form?.header?.formId }}</span>\r\n            @if (creationDate) {\r\n              <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n              <span class=\"fs-14\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ creationDate }}</span>\r\n            }\r\n          </div>\r\n\r\n        </div>\r\n        <div class=\"header-actions d-flex flex-row flex-sm-column justify-content-between justify-content-sm-center gap-2 mt-2 mt-sm-0\">\r\n          @if (!isLoading) {\r\n            <ds-status\r\n              status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n            </ds-status>\r\n          }\r\n          <div class=\"d-flex align-items-center justify-content-end gap-2\">\r\n            &lt;!&ndash; feedback&ndash;&gt;\r\n            &lt;!&ndash;            *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback ==='true'|| form?.inboxItem?.hasFeedback==='true') && !isLoading\"&ndash;&gt;\r\n            &lt;!&ndash;  <ds-button\r\n                square icon size=\"small\" (click)=\"feedback()\">\r\n                <ds-icon\r\n                  icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\"\r\n                  [ngClass]=\"{'fc-green':feedBackIcon === 'feedbackResponded' , 'fc-red': feedBackIcon === 'respondToFeedback' , 'fc-yellow': feedBackIcon === 'waitingFeedback'}\">\r\n                </ds-icon>\r\n              </ds-button>&ndash;&gt;\r\n            <ds-button\r\n              *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n              (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n              <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n            </ds-button>\r\n            @if (showApprovalHistory) {\r\n              <ng-container>\r\n                <ds-button\r\n                  color=\"white\" shape=\"text\" square size=\"small\" [satPopoverAnchor]=\"workflow\"\r\n                  #workflowAnchor=\"satPopoverAnchor\" (click)=\"workflowAnchor.popover.open()\">\r\n                  <slot name=\"prefix\">\r\n                    <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n                  </slot>\r\n                </ds-button>\r\n                <sat-popover\r\n                  #workflow [anchor]=\"workflowAnchor\" [hasBackdrop]=\"true\" verticalAlign=\"below\"\r\n                  horizontalAlign=\"end\">\r\n                  <div class=\"default-popover p-3\" style=\"min-width: 330px;\">\r\n                    <ds-approvals *ngIf=\"approvalHistory\" class=\"popover-approvals\" approvalsData=\"{{approvals}}\">\r\n                    </ds-approvals>\r\n                  </div>\r\n                </sat-popover>\r\n              </ng-container>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n    </header>\r\n  </ng-container>-->\r\n}\r\n"]}
|
|
271
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/service-header/service-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, inject, Input} from '@angular/core';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants/constants';\r\nimport {MAT_DIALOG_DATA, MatDialog} from '@angular/material/dialog';\r\nimport {CoreI18nService, CoreService, FeedBackService, SidenavService} from '../../../services';\r\nimport {ProfileSectionComponent} from '../profile-section/profile-section.component';\r\nimport {FeedbackSectionComponent} from '../feedback-section/feedback-section.component';\r\nimport {NgClass, NgIf} from '@angular/common';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatDivider} from '@angular/material/divider';\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from '@angular/material/menu';\r\nimport {FaqSidenavComponent} from '../faq-sidenav/faq-sidenav.component';\r\nimport {ActivitiesComponent} from '../activities/activities.component';\r\nimport {format} from 'date-fns';\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {PreviousRequestsComponent} from \"../previous-requests/previous-requests.component\";\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\nconst StatusMap = {\r\n  [Constants.FORM_STATUS_REJECTED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCELLED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_REJECT]: {class: 'danger', icon: 'close'},\r\n  [Constants.SECTION_STATUS_UNSATISFIED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCEL]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_PENDING]: {class: 'warning', icon: 'clock'},\r\n  'default': {class: 'success', icon: 'check'}\r\n}\r\n\r\ninterface ApprovalHistoryItem {\r\n  approver: {\r\n    personName: string;\r\n    personEmail: string;\r\n  };\r\n  positionType: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-service-header',\r\n  templateUrl: './service-header.component.html',\r\n  styleUrls: ['./service-header.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    NgIf,\r\n    SatPopoverModule,\r\n    MatDivider,\r\n    MatMenuTrigger,\r\n    NgClass,\r\n    MatMenu,\r\n    MatMenuItem\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [FeedBackService,\r\n    {provide: MAT_DIALOG_DATA, useValue: {}},\r\n  ]\r\n})\r\nexport class ServiceHeaderComponent implements AfterViewInit {\r\n  @Input() form: Form;\r\n  @Input() showHistory = false;\r\n  @Input() isLoading = false;\r\n  @Input() isReadOnly = false;\r\n  @Input() showApprovalHistory = false;\r\n  @Input() approvalHistory: any;\r\n  @Input() creationDate: string;\r\n  @Input() formTitle: string;\r\n  @Input() section: Section;\r\n  @Input() serviceFaq: any[] = [];\r\n  approvals: any[] = [];\r\n  flagPriority: string;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    private readonly cdRef: ChangeDetectorRef,\r\n    public coreService: CoreService,\r\n    public i18n: CoreI18nService, private readonly feedBackService: FeedBackService,\r\n    private readonly dialog: MatDialog, private readonly sidenavService: SidenavService,\r\n    private readonly toasterService: ToastrService\r\n  ) {}\r\n\r\n  /**\r\n   * Executes after the view has been fully initialized.\r\n   *\r\n   * @return {void}\r\n   */\r\n  ngAfterViewInit() {\r\n    this.getApprovalHistory(this.approvalHistory);\r\n    if (this.form?.header?.creationDate) {\r\n      this.creationDate = format(new Date(this.form?.header?.creationDate), \"dd/MM/yyyy hh:mm:ss\");\r\n    }\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Handles the click event on the comments form.\r\n   * Retrieves comments from the form, transforms them, and updates activities in the core service.\r\n   * Finally, publishes an 'open' event to the sidenav service to open the ActivitiesComponent.\r\n   *\r\n   * @return {void}\r\n   */\r\n  onCommentsFormClick() {\r\n    const formComments: any = this.form.commentsDrop;\r\n    const transformedComments = [];\r\n    for (const comment of formComments) {\r\n      transformedComments.push(this.transformCommentItem(comment));\r\n    }\r\n    this.coreService.activities = transformedComments;\r\n    this.sidenavService.publish('open', ActivitiesComponent);\r\n  }\r\n\r\n  /**\r\n   * Transforms a comment item into a different format for display.\r\n   *\r\n   * @param {Object} item - The original comment item to transform.\r\n   * @return {Object} - The transformed comment item with specific properties including name, title, image, date, time, comment, and attachments.\r\n   */\r\n  private transformCommentItem(item) {\r\n    return {\r\n      name: item['employeeName'],\r\n      title: item.jobPosition,\r\n      image: item['profilePicture'],\r\n      date: format(new Date(item['commentDate']), 'yyyy-MM-dd'),\r\n      time: format(new Date(item['commentDate']), 'h:mm a'),\r\n      comment: item['commentBody'],\r\n      attachments: item['attachment']\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Opens a dialog for providing feedback.\r\n   *\r\n   * @return {void}\r\n   */\r\n  feedback(): void {\r\n    this.dialog.open(FeedbackSectionComponent, {\r\n      panelClass: ['main-popup'],\r\n      data: {\r\n        profile: this.form.profileInfoDrop,\r\n        inboxItem: this.form.inboxItem,\r\n        form: this.form\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Updates the sidenav with user profile information if not already loading.\r\n   *\r\n   * @return {void}\r\n   */\r\n  showUserInfo(): void {\r\n    if (!this.isLoading) {\r\n      this.sidenavService.data = this.form?.profileInfoDrop;\r\n      this.sidenavService.publish('open', ProfileSectionComponent);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set the priority flag for the inbox item with the provided ID.\r\n   *\r\n   * @param {string} id - The ID of the priority flag to be set for the inbox item.\r\n   * @return {void}\r\n   */\r\n  setFlagPriority(id: string) {\r\n    this.flagPriority = id;\r\n    this.form.inboxItem.flagPriority = id;\r\n    this.subscribeToSetFlagPriority(id);\r\n  }\r\n\r\n  /**\r\n   * Subscribe to set flag priority for a specific identifier.\r\n   *\r\n   * @param {string} id - The identifier of the flag to set priority for.\r\n   * @return {void}\r\n   */\r\n  subscribeToSetFlagPriority(id: string): void {\r\n    this.coreService.setFlagPriority(id).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((response: any) => {\r\n      if (response) {\r\n        this.toasterService.success(this.i18n.translate('flagStatusUpdated'));\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS class associated with the input status.\r\n   *\r\n   * @param {string} status - The status for which the CSS class is needed.\r\n   * @return {string} - The CSS class corresponding to the given status.\r\n   */\r\n  statusClass(status: string): string {\r\n    // status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.class;\r\n  }\r\n\r\n  /**\r\n   * Opens the FAQ side navigation.\r\n   * @return {void}\r\n   */\r\n  openFaq() {\r\n    this.sidenavService.publish('open', FaqSidenavComponent, 'end', 'over', this.serviceFaq);\r\n  }\r\n\r\n  /**\r\n   * Retrieves approval history information for each approval item in the provided array.\r\n   *\r\n   * @param {ApprovalHistoryItem[]} approvalHistory - The array containing approval history items.\r\n   *\r\n   * @return {void} - This method does not return any value. It updates the internal 'approvals' array.\r\n   */\r\n  getApprovalHistory(approvalHistory: ApprovalHistoryItem[]) {\r\n    approvalHistory?.forEach((approvalItem, index) => {\r\n      let approvalStatus = this.getApprovalStatus(index);\r\n      let approvalStatusLabel = this.getApprovalStatusLabel(index);\r\n      const obj = {\r\n        id: index + 1,\r\n        name: approvalItem.approver.personName,\r\n        title: approvalItem.positionType,\r\n        image: this.getImageUrl(approvalItem.approver.personEmail),\r\n        status: approvalStatus,\r\n        statusLabel: approvalStatusLabel,\r\n      };\r\n      this.approvals.push(obj);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Retrieves the approval status for a specific section in the form.\r\n   *\r\n   * @param {number} index - The index of the section for which the approval status is required.\r\n   * @return {string} The approval status of the specified section. Returns an empty string if the section does not exist.\r\n   */\r\n  private getApprovalStatus(index: number): string {\r\n    let status = '';\r\n    if (this.form.sections[index + 1]) {\r\n      status = this.statusClass(this.form.sections[index + 1].body.details.decision.key);\r\n    }\r\n    return status;\r\n  }\r\n\r\n  /**\r\n   * Retrieves the approval status label from the form section based on the given index.\r\n   *\r\n   * @param {number} index - The index of the form section for which the approval status label will be retrieved.\r\n   * @return {string} The approval status label retrieved from the specified form section.\r\n   */\r\n  private getApprovalStatusLabel(index: number): string {\r\n    let statusLabel = '';\r\n    if (this.form.sections[index + 1]) {\r\n      statusLabel = this.form.sections[index + 1].body.details.decision.value;\r\n    }\r\n    return statusLabel;\r\n  }\r\n\r\n  /**\r\n   * Retrieves the URL of the user's portrait image based on the provided email.\r\n   *\r\n   * @param {string} email - The email address of the user for whom the portrait URL is to be retrieved.\r\n   * @return {string} - The URL used to fetch the user's portrait image.\r\n   */\r\n  private getImageUrl(email: string): string {\r\n    return '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + email;\r\n  }\r\n\r\n  showPreviousRequests() {\r\n    this.sidenavService.publish('open', PreviousRequestsComponent);\r\n  }\r\n}\r\n","@if (form?.header?.status?.['key'] === 'NEW') {\r\n  <section\r\n    class=\"main-sidenav main-sidenav-full mb-4\"\r\n\r\n  >\r\n    <div class=\"sidenav-title\">\r\n      <div class=\"d-flex align-items-center gap-3 w-100\">\r\n        <!-- <ds-button icon class=\"rotate-arrow\" size=\"small\" (click)=\"goBack()\" *ngIf=\"!isInMobileApp() && showBack\">\r\n           <ds-icon icon=\"arrow-right\" class=\"fs-19 fc-black\"></ds-icon>\r\n         </ds-button>-->\r\n\r\n        <!--  <h3 class=\"flex-grow-0\">\r\n            {{ formTitle }}\r\n          </h3>-->\r\n\r\n        <section>\r\n          <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n            {{ i18n.translate('Hello') }}\r\n            {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n          </h6>\r\n          <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n            {{ formTitle }}\r\n            @if (serviceFaq.length) {\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            }\r\n          </h1>\r\n        </section>\r\n        <div class=\"d-flex align-items-center justify-content-end gap-2 flex-grow-1\">\r\n          @if (serviceFaq.length) {\r\n            <ds-button size=\"small\" icon>\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            </ds-button>\r\n          }\r\n          <!-- <ds-button size=\"small\" icon (click)=\"openWorkflow()\">\r\n            <ds-icon icon=\"bell-2-o\" class=\"fs-20 fc-coral\"></ds-icon>\r\n          </ds-button> -->\r\n          @if (!isReadOnly) {\r\n            <ds-button size=\"small\" icon (click)=\"showPreviousRequests()\">\r\n              <ds-icon icon=\"clock\" class=\"fs-20 fc-coral\"></ds-icon>\r\n            </ds-button>\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </section>\r\n\r\n  <!--  <header class=\"mb-4 mt-4 d-flex align-items-center justify-content-between align-items-end gap-2\">\r\n      <section>\r\n        <h6 class=\"fs-14 fs-md-12 fw-normal fc-dark-gray mb-0\">\r\n          {{ i18n.translate('Hello') }}\r\n          {{ coreService.getShortName(form?.header?.requesterName) }}, {{ i18n.translate('welcomeBack') }}!\r\n        </h6>\r\n        <h1 class=\"fs-26 fs-md-20 fw-bold fc-black d-flex align-items-center gap-2 mb-1\">\r\n          {{ formTitle }}\r\n          @if (serviceFaq.length) {\r\n            <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n            </ds-icon>\r\n          }\r\n        </h1>\r\n      </section>\r\n    </header>-->\r\n} @else {\r\n\r\n  <div class=\"w-100\">\r\n    <section class=\"request-main-info  {{statusClass(form?.header?.status?.['key'])}}\">\r\n      <section class=\"request-info\">\r\n        <div class=\"request-info--body\">\r\n          <div class=\"d-flex align-items-center gap-2 flex-grow-1\">\r\n            <img\r\n              alt=\"\"\r\n              src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n            <h4 class=\"fs-22 fs-md-16 fc-black fw-medium mb-0 flex-grow-1 line-height-1-2\">\r\n              {{ formTitle }}\r\n            </h4>\r\n          </div>\r\n          <div class=\"d-flex align-items-center gap-2 request-info--status-action\">\r\n            <div class=\"d-inline-flex flex-column align-items-end\">\r\n              @if (!isLoading) {\r\n                <ds-status\r\n                  status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n                </ds-status>\r\n              }\r\n            </div>\r\n            <div class=\"d-flex align-items-center gap-2\">\r\n              <!-- <ds-button\r\n                 *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback =='true'|| form?.inboxItem?.hasFeedback=='true')\"\r\n                 square icon size=\"small\">\r\n                 <ds-icon icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\">\r\n                   &lt;!&ndash;                  [ngClass]=\"{'fc-green':feedBackIcon == 'feedbackResponded' , 'fc-red': feedBackIcon == 'respondToFeedback' , 'fc-yellow': feedBackIcon == 'waitingFeedback'}\"&ndash;&gt;\r\n                 </ds-icon>\r\n               </ds-button>-->\r\n              <!-- history-->\r\n              <ds-button\r\n                *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n                (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n                <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n              </ds-button>\r\n              <ng-content></ng-content>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"request-info--footer\">\r\n          @if (!isLoading) {\r\n            <ds-avatar\r\n              image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n              class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n          }\r\n          <div\r\n            class=\"d-flex align-items-center flex-wrap flex-grow-1 gap-1 gap-sm-2 line-height-1 request-info--header__details\">\r\n            <span\r\n              [ngClass]=\"{'loading-bg loading-width': isLoading}\"\r\n              class=\"fs-12 fw-medium d-none d-sm-inline-block\">{{ coreService.getShortName(form?.header?.['requesterName']) }}</span>\r\n            <span class=\"fs-20\">&#8226;</span>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\"> {{ form?.header?.formId }}</span>\r\n            <span class=\"fs-20\" *ngIf=\"creationDate\">&#8226;</span>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\"> {{ creationDate }}</span>\r\n          </div>\r\n        </div>\r\n      </section>\r\n    </section>\r\n\r\n  </div>\r\n\r\n\r\n  <!--<ng-container>\r\n    <div class=\"d-flex align-items-center justify-content-end gap-2 my-2\">\r\n      <ds-button\r\n        *ngIf=\"form?.inboxItem && !form.sections[form.sections.length -1].header.readOnly && !isLoading\"\r\n        square\r\n        icon\r\n        size=\"small\"\r\n        [matMenuTriggerFor]=\"menu\"\r\n        class=\"icon-btn-shadow\">\r\n        <ds-icon\r\n          [ngClass]=\"{'fc-purple' : (flagPriority === '0' ||  flagPriority === null),'fc-yellow' : flagPriority === '1','fc-green' : flagPriority === '2','fc-coral' : flagPriority === '3'}\"\r\n          icon=\"flag-o\" class=\"fs-20 fs-md-17 fc-purple\">\r\n        </ds-icon>\r\n      </ds-button>\r\n      <mat-menu #menu=\"matMenu\" panelClass=\"action-menu\">\r\n        <button mat-menu-item (click)=\"setFlagPriority('0')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-purple fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('1')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-yellow fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('2')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-green fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n        <button mat-menu-item (click)=\"setFlagPriority('3')\">\r\n          <ds-icon icon=\"flag-o\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n        </button>\r\n      </mat-menu>\r\n\r\n      <ng-content></ng-content>\r\n    </div>\r\n    <header class=\"service-header bc-white p-3 p-sm-4 py-4 gap-3 {{statusClass(form?.header?.status?.['key'])}}\">\r\n\r\n      <div class=\"service-header-icon\">\r\n        <img\r\n          alt=\"\"\r\n          src=\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjkiIHZpZXdCb3g9IjAgMCAzMCAyOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI1LjEgMEg0LjlDMi4yIDAgMCAyLjIgMCA0LjlWMjguNkgyNS4xQzI3LjggMjguNiAzMCAyNi40IDMwIDIzLjdWNC45QzMwIDIuMiAyNy44IDAgMjUuMSAwWk0yIDQuOUMyIDMuMyAzLjMgMiA0LjkgMkgyNS4xQzI2LjcgMiAyOCAzLjMgMjggNC45VjIzLjdDMjggMjUuMyAyNi43IDI2LjYgMjUuMSAyNi42SDJWNC45Wk0xMS41IDYuM0M3LjEgNi4zIDMuNSA5LjkgMy41IDE0LjNDMy41IDE4LjcgNy4xIDIyLjMgMTEuNSAyMi4zQzE1LjkgMjIuMyAxOS41IDE4LjcgMTkuNSAxNC4zQzE5LjUgOS45IDE1LjkgNi4zIDExLjUgNi4zWk0xNS4xIDE5QzE0LjEgMTkuOCAxMi44IDIwLjIgMTEuNSAyMC4yQzEwLjIgMjAuMiA4LjkgMTkuOCA3LjkgMTlDOC43IDE3LjcgMTAgMTcgMTEuNSAxN0MxMyAxNyAxNC40IDE3LjggMTUuMSAxOVpNMTMuMSAxMy40QzEzLjEgMTQuMyAxMi40IDE1IDExLjUgMTVDMTAuNiAxNSA5LjkgMTQuMyA5LjkgMTMuNEM5LjkgMTIuNSAxMC42IDExLjggMTEuNSAxMS44QzEyLjQgMTEuOCAxMy4xIDEyLjUgMTMuMSAxMy40Wk0xNS4xIDEzLjRDMTUuMSAxMS40IDEzLjUgOS44IDExLjUgOS44QzkuNSA5LjggNy45IDExLjQgNy45IDEzLjRDNy45IDE0LjIgOC4yIDE1IDguNyAxNS43QzcuOCAxNi4xIDcuMSAxNi44IDYuNSAxNy42QzUuOCAxNi42IDUuNSAxNS41IDUuNSAxNC4zQzUuNSAxMSA4LjIgOC4zIDExLjUgOC4zQzE0LjggOC4zIDE3LjUgMTEgMTcuNSAxNC4zQzE3LjUgMTUuNSAxNy4yIDE2LjYgMTYuNSAxNy42QzE1LjkgMTYuOCAxNS4yIDE2LjIgMTQuMyAxNS43QzE0LjggMTUuMSAxNS4xIDE0LjIgMTUuMSAxMy40Wk0yMSA5LjFDMjEgOC42IDIxLjQgOC4xIDIyIDguMUgyNS41QzI2IDguMSAyNi41IDguNSAyNi41IDkuMUMyNi41IDkuNiAyNi4xIDEwLjEgMjUuNSAxMC4xSDIyQzIxLjQgMTAuMSAyMSA5LjYgMjEgOS4xWk0yMSAxMi41QzIxIDEyIDIxLjQgMTEuNSAyMiAxMS41SDI1LjVDMjYgMTEuNSAyNi41IDExLjkgMjYuNSAxMi41QzI2LjUgMTMgMjYuMSAxMy41IDI1LjUgMTMuNUgyMkMyMS40IDEzLjUgMjEgMTMuMSAyMSAxMi41Wk0yMSAxNkMyMSAxNS41IDIxLjQgMTUgMjIgMTVIMjUuNUMyNiAxNSAyNi41IDE1LjQgMjYuNSAxNkMyNi41IDE2LjUgMjYuMSAxNyAyNS41IDE3SDIyQzIxLjQgMTcgMjEgMTYuNiAyMSAxNlpNMjUuNSAyMC41SDIyQzIxLjUgMjAuNSAyMSAyMC4xIDIxIDE5LjVDMjEgMTguOSAyMS40IDE4LjUgMjIgMTguNUgyNS41QzI2IDE4LjUgMjYuNSAxOC45IDI2LjUgMTkuNUMyNi41IDIwLjEgMjYuMSAyMC41IDI1LjUgMjAuNVoiIGZpbGw9IiNGRjM3NUUiLz4KPC9zdmc+Cg==\"/>\r\n      </div>\r\n\r\n      <div class=\"flex-grow-1 d-flex flex-column flex-sm-row align-items-sm-center gap-2\">\r\n        <div class=\"flex-grow-1\">\r\n          <h1 class=\"fs-20 fs-md-16 fw-bold fc-black header-title m-0\">{{ formTitle }}\r\n            @if (serviceFaq.length) {\r\n              <ds-icon icon=\"info\" class=\"fs-22 fc-dark-gray cursor-pointer\" (click)=\"openFaq()\">\r\n              </ds-icon>\r\n            }\r\n          </h1>\r\n          <div class=\"header-user d-flex align-items-sm-center gap-2 mt-sm-1\">\r\n            @if (!isLoading) {\r\n              <ds-avatar\r\n                image=\"{{form?.header?.requesterPhoto}}\" size=\"xx-small\"\r\n                class=\"d-inline-flex cursor-pointer\" (click)=\"showUserInfo()\"></ds-avatar>\r\n            }\r\n            <span\r\n              class=\"fs-12 text-truncate d-sm-block cursor-pointer\" (click)=\"showUserInfo()\"\r\n              [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ coreService.getShortName(form?.header?.requesterName) }}</span>\r\n            <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n            <span class=\"fs-12\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ form?.header?.formId }}</span>\r\n            @if (creationDate) {\r\n              <mat-divider class=\"divider circle mx-2 d-none d-sm-block\"></mat-divider>\r\n              <span class=\"fs-14\" [ngClass]=\"{'loading-bg loading-width': isLoading}\">{{ creationDate }}</span>\r\n            }\r\n          </div>\r\n\r\n        </div>\r\n        <div class=\"header-actions d-flex flex-row flex-sm-column justify-content-between justify-content-sm-center gap-2 mt-2 mt-sm-0\">\r\n          @if (!isLoading) {\r\n            <ds-status\r\n              status=\"{{statusClass(form?.header?.status?.['key'])}}\" class=\"header-status\">{{ form?.header?.status?.['value'] }}\r\n            </ds-status>\r\n          }\r\n          <div class=\"d-flex align-items-center justify-content-end gap-2\">\r\n            &lt;!&ndash; feedback&ndash;&gt;\r\n            &lt;!&ndash;            *ngIf=\"form?.inboxItem && (form?.inboxItem?.canRequestFeedback ==='true'|| form?.inboxItem?.hasFeedback==='true') && !isLoading\"&ndash;&gt;\r\n            &lt;!&ndash;  <ds-button\r\n                square icon size=\"small\" (click)=\"feedback()\">\r\n                <ds-icon\r\n                  icon=\"chat-o\" class=\"fs-20 fs-md-17 fc-coral\"\r\n                  [ngClass]=\"{'fc-green':feedBackIcon === 'feedbackResponded' , 'fc-red': feedBackIcon === 'respondToFeedback' , 'fc-yellow': feedBackIcon === 'waitingFeedback'}\">\r\n                </ds-icon>\r\n              </ds-button>&ndash;&gt;\r\n            <ds-button\r\n              *ngIf=\"form?.commentsDrop?.length > 0 && !isLoading\" square icon size=\"small\"\r\n              (click)=\"onCommentsFormClick()\" class=\"has-comments\">\r\n              <ds-icon icon=\"clock\" class=\"fc-coral fs-20 fs-md-17\"></ds-icon>\r\n            </ds-button>\r\n            @if (showApprovalHistory) {\r\n              <ng-container>\r\n                <ds-button\r\n                  color=\"white\" shape=\"text\" square size=\"small\" [satPopoverAnchor]=\"workflow\"\r\n                  #workflowAnchor=\"satPopoverAnchor\" (click)=\"workflowAnchor.popover.open()\">\r\n                  <slot name=\"prefix\">\r\n                    <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n                  </slot>\r\n                </ds-button>\r\n                <sat-popover\r\n                  #workflow [anchor]=\"workflowAnchor\" [hasBackdrop]=\"true\" verticalAlign=\"below\"\r\n                  horizontalAlign=\"end\">\r\n                  <div class=\"default-popover p-3\" style=\"min-width: 330px;\">\r\n                    <ds-approvals *ngIf=\"approvalHistory\" class=\"popover-approvals\" approvalsData=\"{{approvals}}\">\r\n                    </ds-approvals>\r\n                  </div>\r\n                </sat-popover>\r\n              </ng-container>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n    </header>\r\n  </ng-container>-->\r\n}\r\n"]}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import * as constants from '../../../constants';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { NgClass, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
5
5
|
import { MatAccordion } from '@angular/material/expansion';
|
|
6
6
|
import { FormSectionComponent } from '../form-section/form-section.component';
|
|
7
7
|
import { MainRequestDetailsComponent } from '../main-request-details/main-request-details.component';
|
|
8
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "../../../services";
|
|
10
11
|
import * as i2 from "@angular/forms";
|
|
@@ -24,6 +25,7 @@ export class WorkflowSectionComponent {
|
|
|
24
25
|
segmentDynamicLoaderService = null;
|
|
25
26
|
sectionFormComponent = null;
|
|
26
27
|
sectionName = constants.SECTION_ID_REQUEST_DETAILS;
|
|
28
|
+
destroyRef = inject(DestroyRef);
|
|
27
29
|
constructor(i18n, cdRef) {
|
|
28
30
|
this.i18n = i18n;
|
|
29
31
|
this.cdRef = cdRef;
|
|
@@ -40,7 +42,7 @@ export class WorkflowSectionComponent {
|
|
|
40
42
|
}
|
|
41
43
|
ngAfterViewChecked() {
|
|
42
44
|
if (this.formStateObject && this.form && !this.startedListener) {
|
|
43
|
-
this.formStateObject.valueChanges.subscribe(
|
|
45
|
+
this.formStateObject.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(
|
|
44
46
|
/* istanbul ignore next */
|
|
45
47
|
(form) => {
|
|
46
48
|
Object.keys(form).forEach((key) => {
|
|
@@ -159,4 +161,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
159
161
|
}], sectionName: [{
|
|
160
162
|
type: Input
|
|
161
163
|
}] } });
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/workflow-section/workflow-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/workflow-section/workflow-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, Output, ViewChild} from '@angular/core';\r\nimport * as constants from '../../../constants';\r\nimport {FormsModule, NgForm} from '@angular/forms';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport {CoreI18nService} from '../../../services';\r\nimport {NgClass, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\r\nimport {MatAccordion} from '@angular/material/expansion';\r\nimport {FormSectionComponent} from '../form-section/form-section.component';\r\nimport {MainRequestDetailsComponent} from '../main-request-details/main-request-details.component';\r\n\r\n@Component({\r\n  selector: 'app-workflow-section',\r\n  templateUrl: './workflow-section.component.html',\r\n  styleUrls: ['./workflow-section.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    MatAccordion,\r\n    NgTemplateOutlet,\r\n    NgIf,\r\n    FormSectionComponent,\r\n    MainRequestDetailsComponent,\r\n    NgForOf,\r\n    FormsModule\r\n  ],\r\n  standalone: true\r\n})\r\nexport class WorkflowSectionComponent {\r\n  @ViewChild('f') public formStateObject: NgForm;\r\n  @Output() sectionSubmitted: EventEmitter<any> = new EventEmitter();\r\n  @Input() sections: Section[];\r\n  @Input() isReadOnly: boolean;\r\n  @Input() isLoading: boolean;\r\n  @Input() form: Form;\r\n  @Input() contentClass = 'default-box box-shadow p-4';\r\n  startedListener = false;\r\n  @Input() sectionsController: any;\r\n  showButtonMenu = false;\r\n  @Input() segmentDynamicLoaderService = null;\r\n  @Input() sectionFormComponent = null;\r\n  @Input() sectionName = constants.SECTION_ID_REQUEST_DETAILS;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private cdRef: ChangeDetectorRef,\r\n  ) {\r\n/*    _listenerService.listen().subscribe((result: any) => {\r\n      if (result?.function == 'resetForm') {\r\n        this.resetForm();\r\n      } else if (result?.function == 'onSubmit') {\r\n        const sectionSize = this.sections.length - 1;\r\n        const section = this.sections[sectionSize];\r\n        const data = result.data ? result.data : section;\r\n        this.onSubmit(result?.action, data);\r\n      }\r\n    });*/\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (this.formStateObject && this.form && !this.startedListener) {\r\n      this.formStateObject.valueChanges.subscribe(\r\n        /* istanbul ignore next  */\r\n        (form) => {\r\n          Object.keys(form).forEach((key) => {\r\n            if (\r\n              this.sections[this.sections.length - 1].body.details[key] !==\r\n              form[key] &&\r\n              form[key] !== undefined\r\n            )\r\n              this.sections[this.sections.length - 1].body.details[key] =\r\n                form[key];\r\n          });\r\n        }\r\n      );\r\n      this.sectionsController = this.formStateObject.controls;\r\n      this.startedListener = true;\r\n    }\r\n    this.checkButtons();\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n/*  isSubmitting = {};\r\n  disableButtons = false;*/\r\n\r\n/*  onSubmit(action: any, section: any) {\r\n    const sectionSize = this.sections.length - 1;\r\n    let sectionDecision = this.sections[sectionSize].body.details.decision;\r\n    if (sectionDecision && action === 'SUBMIT') {\r\n      sectionDecision = { key: action };\r\n    }\r\n    if (sectionDecision && action !== 'SUBMIT') {\r\n      sectionDecision = { key: action };\r\n    }\r\n    this.sections[sectionSize].body.details.decision = sectionDecision;\r\n    this.profileRequesterService.isSubmitting[action] = true;\r\n    this.profileRequesterService.disableButtons = true;\r\n    this.stateMachineService\r\n      .dispatch(\r\n        constants.STATE_MACHINE_ACTION_SUBMIT_FORM,\r\n        section,\r\n        action\r\n      )\r\n      .then((form: any) => {\r\n        this.profileRequesterService.isSubmitting[action] = true;\r\n        this.profileRequesterService.disableButtons = true;\r\n        const obj = {\r\n          form: form,\r\n          action: action\r\n        };\r\n        this.sectionSubmitted.emit(obj);\r\n      });\r\n  }*/\r\n\r\n/*  resetForm() {\r\n    this.formStateObject.reset();\r\n    this.resetPropagator.propagate();\r\n  }*/\r\n\r\n  get isExpandableFromBackend(): boolean {\r\n    return this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);\r\n  }\r\n\r\n  buttonTypes(type) {\r\n    switch (type) {\r\n      case 'APPROVE':\r\n        return '';\r\n      case 'SENDBACK':\r\n        return 'red';\r\n      case 'REJECT':\r\n        return 'red';\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n\r\n  checkButtons() {\r\n    const options = this.form?.lovs?.decision?.options;\r\n    if (!Array.isArray(options)) return;\r\n    options.forEach((item) => {\r\n      if (\r\n        item?.value != 'APPROVE' &&\r\n        item?.value != 'REJECT' &&\r\n        item?.value != 'SENDBACK' &&\r\n        item?.value != 'SUBMIT' &&\r\n        item?.value != 'CANCEL'\r\n      ) {\r\n        this.showButtonMenu = true;\r\n      }\r\n    });\r\n  }\r\n}\r\n","<form #f=\"ngForm\" autocomplete=\"off\">\r\n  <div *ngIf=\"form?.header?.status?.key !== 'NEW' \" class=\"mt-n3\" id=\"accordion\" role=\"tablist\"\r\n    aria-multiselectable=\"true\">\r\n    <app-main-request-details [lov]=\"form?.lovs\" [form]=\"form\" [section]=\"form?.sections[0]\">\r\n      <ng-container *ngTemplateOutlet=\"contentReqDet\"></ng-container>\r\n    </app-main-request-details>\r\n    <header class=\"header-line fs-12 fw-medium fc-dark-gray mt-sm-5 mt-4 mb-4\" *ngIf=\"form?.sections.length > 1\">\r\n      {{i18n.translate('Approvals')}}\r\n    </header>\r\n    <mat-accordion class=\"primary-accordion main-approval\">\r\n      <ng-container *ngFor=\"let section of form?.sections; let i = index\">\r\n        <app-form-section *ngIf=\"i !== 0\" class=\"app-form-section\" [segmentDynamicLoaderService]=\"segmentDynamicLoaderService\" [section]=section [lov]=\"form?.lovs\"\r\n          [isReadOnly]=\"section.header.readOnly\" [form]=\"form\" [controllers]=\"sectionsController\">\r\n        </app-form-section>\r\n      </ng-container>\r\n    </mat-accordion>\r\n  </div>\r\n\r\n  <section *ngIf=\"form?.header?.status?.key === 'NEW' \" class=\"default-box box-shadow p-4\">\r\n    <ng-container *ngTemplateOutlet=\"contentReqDet\"></ng-container>\r\n  </section>\r\n\r\n</form>\r\n\r\n\r\n<ng-template #contentReqDet><ng-content></ng-content></ng-template>\r\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/workflow-section/workflow-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/workflow-section/workflow-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,sBAAsB,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AAC/I,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAC,WAAW,EAAS,MAAM,gBAAgB,CAAC;AAGnD,OAAO,EAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AACzE,OAAO,EAAC,YAAY,EAAC,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAC,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAC,2BAA2B,EAAC,MAAM,wDAAwD,CAAC;AACnG,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;;;;AAmBhE,MAAM,OAAO,wBAAwB;IAkB1B;IACC;IAlBa,eAAe,CAAS;IACrC,gBAAgB,GAAsB,IAAI,YAAY,EAAE,CAAC;IAC1D,QAAQ,CAAY;IACpB,UAAU,CAAU;IACpB,SAAS,CAAU;IACnB,IAAI,CAAO;IACX,YAAY,GAAG,4BAA4B,CAAC;IACrD,eAAe,GAAG,KAAK,CAAC;IACf,kBAAkB,CAAM;IACjC,cAAc,GAAG,KAAK,CAAC;IACd,2BAA2B,GAAG,IAAI,CAAC;IACnC,oBAAoB,GAAG,IAAI,CAAC;IAC5B,WAAW,GAAG,SAAS,CAAC,0BAA0B,CAAC;IAC5D,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAGhC,YACS,IAAqB,EACpB,KAAwB;QADzB,SAAI,GAAJ,IAAI,CAAiB;QACpB,UAAK,GAAL,KAAK,CAAmB;QAEpC;;;;;;;;;iBASS;IACP,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC/D,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CACpC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CACpC,CAAC,SAAS;YACT,2BAA2B;YAC3B,CAAC,IAAI,EAAE,EAAE;gBACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;oBAChC,IACE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;wBACzD,IAAI,CAAC,GAAG,CAAC;wBACT,IAAI,CAAC,GAAG,CAAC,KAAK,SAAS;wBAEvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;4BACvD,IAAI,CAAC,GAAG,CAAC,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC,CACF,CAAC;YACF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;YACxD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,CAAC;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAEH;+BAC2B;IAE3B;;;;;;;;;;;;;;;;;;;;;;;;;;;SA2BK;IAEL;;;SAGK;IAEH,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,IAAI,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;IACpH,CAAC;IAED,WAAW,CAAC,IAAI;QACd,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,SAAS;gBACZ,OAAO,EAAE,CAAC;YACZ,KAAK,UAAU;gBACb,OAAO,KAAK,CAAC;YACf,KAAK,QAAQ;gBACX,OAAO,KAAK,CAAC;YACf;gBACE,OAAO,EAAE,CAAC;QACd,CAAC;IACH,CAAC;IAED,YAAY;QACV,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC;QACnD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;YAAE,OAAO;QACpC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACvB,IACE,IAAI,EAAE,KAAK,IAAI,SAAS;gBACxB,IAAI,EAAE,KAAK,IAAI,QAAQ;gBACvB,IAAI,EAAE,KAAK,IAAI,UAAU;gBACzB,IAAI,EAAE,KAAK,IAAI,QAAQ;gBACvB,IAAI,EAAE,KAAK,IAAI,QAAQ,EACvB,CAAC;gBACD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC7B,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;uGA9HU,wBAAwB;2FAAxB,wBAAwB,yhBC5BrC,82CA0BA,6kCDRI,YAAY,+IACZ,gBAAgB,oJAChB,IAAI,6FACJ,oBAAoB,sNACpB,2BAA2B,yGAC3B,OAAO,kHACP,WAAW;;2FAIF,wBAAwB;kBAjBpC,SAAS;+BACE,sBAAsB,WAGvB,CAAC,sBAAsB,CAAC,WACxB;wBACP,OAAO;wBACP,YAAY;wBACZ,gBAAgB;wBAChB,IAAI;wBACJ,oBAAoB;wBACpB,2BAA2B;wBAC3B,OAAO;wBACP,WAAW;qBACZ,cACW,IAAI;oHAGO,eAAe;sBAArC,SAAS;uBAAC,GAAG;gBACJ,gBAAgB;sBAAzB,MAAM;gBACE,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEG,kBAAkB;sBAA1B,KAAK;gBAEG,2BAA2B;sBAAnC,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,WAAW;sBAAnB,KAAK","sourcesContent":["import {ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, inject, Input, Output, ViewChild} from '@angular/core';\r\nimport * as constants from '../../../constants';\r\nimport {FormsModule, NgForm} from '@angular/forms';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport {CoreI18nService} from '../../../services';\r\nimport {NgClass, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\r\nimport {MatAccordion} from '@angular/material/expansion';\r\nimport {FormSectionComponent} from '../form-section/form-section.component';\r\nimport {MainRequestDetailsComponent} from '../main-request-details/main-request-details.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'app-workflow-section',\r\n  templateUrl: './workflow-section.component.html',\r\n  styleUrls: ['./workflow-section.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    MatAccordion,\r\n    NgTemplateOutlet,\r\n    NgIf,\r\n    FormSectionComponent,\r\n    MainRequestDetailsComponent,\r\n    NgForOf,\r\n    FormsModule\r\n  ],\r\n  standalone: true\r\n})\r\nexport class WorkflowSectionComponent {\r\n  @ViewChild('f') public formStateObject: NgForm;\r\n  @Output() sectionSubmitted: EventEmitter<any> = new EventEmitter();\r\n  @Input() sections: Section[];\r\n  @Input() isReadOnly: boolean;\r\n  @Input() isLoading: boolean;\r\n  @Input() form: Form;\r\n  @Input() contentClass = 'default-box box-shadow p-4';\r\n  startedListener = false;\r\n  @Input() sectionsController: any;\r\n  showButtonMenu = false;\r\n  @Input() segmentDynamicLoaderService = null;\r\n  @Input() sectionFormComponent = null;\r\n  @Input() sectionName = constants.SECTION_ID_REQUEST_DETAILS;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private cdRef: ChangeDetectorRef,\r\n  ) {\r\n/*    _listenerService.listen().subscribe((result: any) => {\r\n      if (result?.function == 'resetForm') {\r\n        this.resetForm();\r\n      } else if (result?.function == 'onSubmit') {\r\n        const sectionSize = this.sections.length - 1;\r\n        const section = this.sections[sectionSize];\r\n        const data = result.data ? result.data : section;\r\n        this.onSubmit(result?.action, data);\r\n      }\r\n    });*/\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (this.formStateObject && this.form && !this.startedListener) {\r\n      this.formStateObject.valueChanges.pipe(\r\n        takeUntilDestroyed(this.destroyRef)\r\n      ).subscribe(\r\n        /* istanbul ignore next  */\r\n        (form) => {\r\n          Object.keys(form).forEach((key) => {\r\n            if (\r\n              this.sections[this.sections.length - 1].body.details[key] !==\r\n              form[key] &&\r\n              form[key] !== undefined\r\n            )\r\n              this.sections[this.sections.length - 1].body.details[key] =\r\n                form[key];\r\n          });\r\n        }\r\n      );\r\n      this.sectionsController = this.formStateObject.controls;\r\n      this.startedListener = true;\r\n    }\r\n    this.checkButtons();\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n/*  isSubmitting = {};\r\n  disableButtons = false;*/\r\n\r\n/*  onSubmit(action: any, section: any) {\r\n    const sectionSize = this.sections.length - 1;\r\n    let sectionDecision = this.sections[sectionSize].body.details.decision;\r\n    if (sectionDecision && action === 'SUBMIT') {\r\n      sectionDecision = { key: action };\r\n    }\r\n    if (sectionDecision && action !== 'SUBMIT') {\r\n      sectionDecision = { key: action };\r\n    }\r\n    this.sections[sectionSize].body.details.decision = sectionDecision;\r\n    this.profileRequesterService.isSubmitting[action] = true;\r\n    this.profileRequesterService.disableButtons = true;\r\n    this.stateMachineService\r\n      .dispatch(\r\n        constants.STATE_MACHINE_ACTION_SUBMIT_FORM,\r\n        section,\r\n        action\r\n      )\r\n      .then((form: any) => {\r\n        this.profileRequesterService.isSubmitting[action] = true;\r\n        this.profileRequesterService.disableButtons = true;\r\n        const obj = {\r\n          form: form,\r\n          action: action\r\n        };\r\n        this.sectionSubmitted.emit(obj);\r\n      });\r\n  }*/\r\n\r\n/*  resetForm() {\r\n    this.formStateObject.reset();\r\n    this.resetPropagator.propagate();\r\n  }*/\r\n\r\n  get isExpandableFromBackend(): boolean {\r\n    return this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);\r\n  }\r\n\r\n  buttonTypes(type) {\r\n    switch (type) {\r\n      case 'APPROVE':\r\n        return '';\r\n      case 'SENDBACK':\r\n        return 'red';\r\n      case 'REJECT':\r\n        return 'red';\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n\r\n  checkButtons() {\r\n    const options = this.form?.lovs?.decision?.options;\r\n    if (!Array.isArray(options)) return;\r\n    options.forEach((item) => {\r\n      if (\r\n        item?.value != 'APPROVE' &&\r\n        item?.value != 'REJECT' &&\r\n        item?.value != 'SENDBACK' &&\r\n        item?.value != 'SUBMIT' &&\r\n        item?.value != 'CANCEL'\r\n      ) {\r\n        this.showButtonMenu = true;\r\n      }\r\n    });\r\n  }\r\n}\r\n","<form #f=\"ngForm\" autocomplete=\"off\">\r\n  <div *ngIf=\"form?.header?.status?.key !== 'NEW' \" class=\"mt-n3\" id=\"accordion\" role=\"tablist\"\r\n    aria-multiselectable=\"true\">\r\n    <app-main-request-details [lov]=\"form?.lovs\" [form]=\"form\" [section]=\"form?.sections[0]\">\r\n      <ng-container *ngTemplateOutlet=\"contentReqDet\"></ng-container>\r\n    </app-main-request-details>\r\n    <header class=\"header-line fs-12 fw-medium fc-dark-gray mt-sm-5 mt-4 mb-4\" *ngIf=\"form?.sections.length > 1\">\r\n      {{i18n.translate('Approvals')}}\r\n    </header>\r\n    <mat-accordion class=\"primary-accordion main-approval\">\r\n      <ng-container *ngFor=\"let section of form?.sections; let i = index\">\r\n        <app-form-section *ngIf=\"i !== 0\" class=\"app-form-section\" [segmentDynamicLoaderService]=\"segmentDynamicLoaderService\" [section]=section [lov]=\"form?.lovs\"\r\n          [isReadOnly]=\"section.header.readOnly\" [form]=\"form\" [controllers]=\"sectionsController\">\r\n        </app-form-section>\r\n      </ng-container>\r\n    </mat-accordion>\r\n  </div>\r\n\r\n  <section *ngIf=\"form?.header?.status?.key === 'NEW' \" class=\"default-box box-shadow p-4\">\r\n    <ng-container *ngTemplateOutlet=\"contentReqDet\"></ng-container>\r\n  </section>\r\n\r\n</form>\r\n\r\n\r\n<ng-template #contentReqDet><ng-content></ng-content></ng-template>\r\n"]}
|
package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, NO_ERRORS_SCHEMA, Output } from '@angular/core';
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, inject, Input, NO_ERRORS_SCHEMA, Output } from '@angular/core';
|
|
2
2
|
import * as constants from "../../../constants";
|
|
3
3
|
import { NgClass, NgForOf, NgIf } from "@angular/common";
|
|
4
4
|
import { InputComponent } from "../form-field";
|
|
5
5
|
import { SubmitDialogComponent } from "../dialogs/submit-dialog/submit-dialog.component";
|
|
6
6
|
import { NoopScrollStrategy } from "@angular/cdk/overlay";
|
|
7
7
|
import { ApprovalsWorkflowComponent } from "../../app-component-sections/approvals-workflow/approvals-workflow.component";
|
|
8
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "../../../services";
|
|
10
11
|
import * as i2 from "@angular/material/dialog";
|
|
@@ -31,6 +32,7 @@ export class ActionButtonsComponent {
|
|
|
31
32
|
'SUBMIT': false
|
|
32
33
|
};
|
|
33
34
|
submittingForm;
|
|
35
|
+
destroyRef = inject(DestroyRef);
|
|
34
36
|
constructor(i18n, actionStateService, coreService, dialog, toasterService, cdRef) {
|
|
35
37
|
this.i18n = i18n;
|
|
36
38
|
this.actionStateService = actionStateService;
|
|
@@ -38,7 +40,7 @@ export class ActionButtonsComponent {
|
|
|
38
40
|
this.dialog = dialog;
|
|
39
41
|
this.toasterService = toasterService;
|
|
40
42
|
this.cdRef = cdRef;
|
|
41
|
-
this.actionStateService.actionStates$.subscribe(states => this.actionStates = states);
|
|
43
|
+
this.actionStateService.actionStates$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(states => this.actionStates = states);
|
|
42
44
|
}
|
|
43
45
|
ngAfterViewInit() {
|
|
44
46
|
this.lovOptions?.forEach((item) => {
|
|
@@ -64,7 +66,7 @@ export class ActionButtonsComponent {
|
|
|
64
66
|
}
|
|
65
67
|
this.isSubmitting[action] = true;
|
|
66
68
|
this.submittingForm = true;
|
|
67
|
-
this.coreService.submitForm(section, action).subscribe((response) => {
|
|
69
|
+
this.coreService.submitForm(section, action).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((response) => {
|
|
68
70
|
if (response) {
|
|
69
71
|
this.isSubmitting[action] = false;
|
|
70
72
|
this.success(response);
|
|
@@ -133,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
133
135
|
}], customCallEmit: [{
|
|
134
136
|
type: Output
|
|
135
137
|
}] } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-buttons.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.ts","../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, NO_ERRORS_SCHEMA, Output} from '@angular/core';\r\nimport * as constants from \"../../../constants\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {InputComponent} from \"../form-field\";\r\nimport {ActionStateService, CoreI18nService, CoreService, SidenavService} from \"../../../services\";\r\nimport {Form, Section} from \"../../../interfaces\";\r\nimport {SubmitDialogComponent} from \"../dialogs/submit-dialog/submit-dialog.component\";\r\nimport {NoopScrollStrategy} from \"@angular/cdk/overlay\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {ApprovalsWorkflowComponent} from \"../../app-component-sections/approvals-workflow/approvals-workflow.component\";\r\n\r\n@Component({\r\n  selector: 'lib-action-buttons',\r\n  templateUrl: './action-buttons.component.html',\r\n  styleUrl: './action-buttons.component.scss',\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ApprovalsWorkflowComponent\r\n  ]\r\n})\r\nexport class ActionButtonsComponent implements AfterViewInit {\r\n  @Input() lovOptions: any[];\r\n  @Input() lovType: string;\r\n  @Input() fieldsForm: FormGroup;\r\n  @Input() form: Form;\r\n  @Input() section: Section;\r\n  @Input() sections: Section[];\r\n  @Input() showApprovalCycle: boolean = true;\r\n  @Input() customCall: boolean = false;\r\n  @Output() resetFormEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() customCallEmit: EventEmitter<any> = new EventEmitter();\r\n  actionStates: { [action: string]: boolean };\r\n  isSubmitting = {\r\n    'SUBMIT':false\r\n  };\r\n  submittingForm: boolean;\r\n\r\n  constructor(public i18n: CoreI18nService,\r\n              private actionStateService: ActionStateService,\r\n              private coreService: CoreService,\r\n              public dialog: MatDialog,\r\n              private toasterService: ToastrService,\r\n              private cdRef: ChangeDetectorRef\r\n  ) {\r\n    this.actionStateService.actionStates$.subscribe(states => this.actionStates = states);\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.lovOptions?.forEach((item) => {\r\n      this.isSubmitting[item.value] = false\r\n    })\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  resetForm() {\r\n    this.resetFormEmit.emit()\r\n  }\r\n\r\n  onSubmit(action: string) {\r\n    if (this.customCall) {\r\n      this.customCallEmit.emit(action)\r\n    } else {\r\n      this.submitForm(action, this.section)\r\n    }\r\n  }\r\n\r\n  submitForm(action: string, section: Section) {\r\n    const lastSection = this.sections[this.sections.length - 1];\r\n\r\n    if (lastSection.body.details.decision) {\r\n      lastSection.body.details.decision = {key: action};\r\n    }\r\n\r\n    this.isSubmitting[action] = true;\r\n    this.submittingForm = true;\r\n\r\n    this.coreService.submitForm(section, action).subscribe(\r\n      (response: any) => {\r\n        if (response) {\r\n          this.isSubmitting[action] = false;\r\n          this.success(response);\r\n        }\r\n      },\r\n      (err: any) => {\r\n        err?.error?.meta?.messages?.forEach((msg) => {\r\n          this.submittingForm = false;\r\n          this.isSubmitting[action] = false;\r\n          this.toasterService.error(msg.message);\r\n        });\r\n      }\r\n    );\r\n  }\r\n\r\n  success(response) {\r\n    console.log('success', response)\r\n    const dialogRef = this.dialog.open(SubmitDialogComponent, {\r\n      data: response,\r\n      panelClass: ['main-popup', 'confirm-dialog'],\r\n      scrollStrategy: new NoopScrollStrategy(),\r\n    });\r\n    dialogRef.afterClosed().subscribe(() => {\r\n      window.location.reload();\r\n    });\r\n  }\r\n\r\n  buttonShape(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_CANCEL || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'outline';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  buttonColor(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'red';\r\n    }\r\n    return '';\r\n  }\r\n}\r\n","<div class=\"mt-4\">\r\n  @if (lovType === 'button') {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n        @for (item of lovOptions; track $index) {\r\n          <ds-button\r\n            loading=\"{{isSubmitting[item.value]}}\"\r\n            [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n            shape=\"{{ buttonShape(item) }}\"\r\n            color=\"{{ buttonColor(item) }}\"\r\n            (click)=\"onSubmit(item?.value)\">\r\n            {{ item?.['description'] }}\r\n          </ds-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  } @else {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n      <ds-button\r\n        [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n        loading=\"{{isSubmitting['SUBMIT']}}\"\r\n        (click)=\"onSubmit('SUBMIT')\">\r\n        {{ i18n.translate('submit') }}\r\n      </ds-button>\r\n    </div>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-buttons.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.ts","../../../../../../../projects/bpm-core/src/lib/components/shared-components/action-buttons/action-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, inject, Input, NO_ERRORS_SCHEMA, Output} from '@angular/core';\r\nimport * as constants from \"../../../constants\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {InputComponent} from \"../form-field\";\r\nimport {ActionStateService, CoreI18nService, CoreService, SidenavService} from \"../../../services\";\r\nimport {Form, Section} from \"../../../interfaces\";\r\nimport {SubmitDialogComponent} from \"../dialogs/submit-dialog/submit-dialog.component\";\r\nimport {NoopScrollStrategy} from \"@angular/cdk/overlay\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {ApprovalsWorkflowComponent} from \"../../app-component-sections/approvals-workflow/approvals-workflow.component\";\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'lib-action-buttons',\r\n  templateUrl: './action-buttons.component.html',\r\n  styleUrl: './action-buttons.component.scss',\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ApprovalsWorkflowComponent\r\n  ]\r\n})\r\nexport class ActionButtonsComponent implements AfterViewInit {\r\n  @Input() lovOptions: any[];\r\n  @Input() lovType: string;\r\n  @Input() fieldsForm: FormGroup;\r\n  @Input() form: Form;\r\n  @Input() section: Section;\r\n  @Input() sections: Section[];\r\n  @Input() showApprovalCycle: boolean = true;\r\n  @Input() customCall: boolean = false;\r\n  @Output() resetFormEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() customCallEmit: EventEmitter<any> = new EventEmitter();\r\n  actionStates: { [action: string]: boolean };\r\n  isSubmitting = {\r\n    'SUBMIT':false\r\n  };\r\n  submittingForm: boolean;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(public i18n: CoreI18nService,\r\n              private actionStateService: ActionStateService,\r\n              private coreService: CoreService,\r\n              public dialog: MatDialog,\r\n              private toasterService: ToastrService,\r\n              private cdRef: ChangeDetectorRef\r\n  ) {\r\n    this.actionStateService.actionStates$.pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe(states => this.actionStates = states);\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.lovOptions?.forEach((item) => {\r\n      this.isSubmitting[item.value] = false\r\n    })\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  resetForm() {\r\n    this.resetFormEmit.emit()\r\n  }\r\n\r\n  onSubmit(action: string) {\r\n    if (this.customCall) {\r\n      this.customCallEmit.emit(action)\r\n    } else {\r\n      this.submitForm(action, this.section)\r\n    }\r\n  }\r\n\r\n  submitForm(action: string, section: Section) {\r\n    const lastSection = this.sections[this.sections.length - 1];\r\n\r\n    if (lastSection.body.details.decision) {\r\n      lastSection.body.details.decision = {key: action};\r\n    }\r\n\r\n    this.isSubmitting[action] = true;\r\n    this.submittingForm = true;\r\n\r\n    this.coreService.submitForm(section, action).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe(\r\n      (response: any) => {\r\n        if (response) {\r\n          this.isSubmitting[action] = false;\r\n          this.success(response);\r\n        }\r\n      },\r\n      (err: any) => {\r\n        err?.error?.meta?.messages?.forEach((msg) => {\r\n          this.submittingForm = false;\r\n          this.isSubmitting[action] = false;\r\n          this.toasterService.error(msg.message);\r\n        });\r\n      }\r\n    );\r\n  }\r\n\r\n  success(response) {\r\n    console.log('success', response)\r\n    const dialogRef = this.dialog.open(SubmitDialogComponent, {\r\n      data: response,\r\n      panelClass: ['main-popup', 'confirm-dialog'],\r\n      scrollStrategy: new NoopScrollStrategy(),\r\n    });\r\n    dialogRef.afterClosed().subscribe(() => {\r\n      window.location.reload();\r\n    });\r\n  }\r\n\r\n  buttonShape(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_CANCEL || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'outline';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  buttonColor(item) {\r\n    if (item?.value === constants.FORM_STATUS_REJECT || item?.value === constants.FORM_STATUS_SEND_BACK) {\r\n      return 'red';\r\n    }\r\n    return '';\r\n  }\r\n}\r\n","<div class=\"mt-4\">\r\n  @if (lovType === 'button') {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n        @for (item of lovOptions; track $index) {\r\n          <ds-button\r\n            loading=\"{{isSubmitting[item.value]}}\"\r\n            [ngClass]=\"{'disabled': !actionStates[item.value] || submittingForm}\"\r\n            shape=\"{{ buttonShape(item) }}\"\r\n            color=\"{{ buttonColor(item) }}\"\r\n            (click)=\"onSubmit(item?.value)\">\r\n            {{ item?.['description'] }}\r\n          </ds-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  } @else {\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button shape=\"text\" color=\"red\" (click)=\"resetForm()\">\r\n        <span class=\"fs-16 fw-medium\">{{ i18n.translate('reset') }}</span>\r\n      </ds-button>\r\n      @if (form?.sections?.length == 1 && showApprovalCycle) {\r\n        <lib-approvals-workflow [section]=\"section\" [form]=\"form\"></lib-approvals-workflow>\r\n      }\r\n      <div class=\"d-flex flex-wrap align-items-center flex-grow-1 flex-row-reverse gap-3\">\r\n      <ds-button\r\n        [ngClass]=\"{'disabled': !actionStates['SUBMIT'] || submittingForm}\"\r\n        loading=\"{{isSubmitting['SUBMIT']}}\"\r\n        (click)=\"onSubmit('SUBMIT')\">\r\n        {{ i18n.translate('submit') }}\r\n      </ds-button>\r\n    </div>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, forwardRef, Inject, Input, } from '@angular/core';
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, forwardRef, inject, Inject, Input, } from '@angular/core';
|
|
2
2
|
import { TextareaComponent } from '../textarea/textarea.component';
|
|
3
3
|
import { MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogModule, } from '@angular/material/dialog';
|
|
4
4
|
import { NgIf } from '@angular/common';
|
|
5
5
|
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
6
6
|
import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
7
7
|
import { DocsUploaderComponent } from '../doc-uploader/docs-uploader.component';
|
|
8
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "../../../../services";
|
|
10
11
|
import * as i2 from "ngx-toastr";
|
|
@@ -21,6 +22,7 @@ export class AttachmentSectionDataComponent extends ControlValueAccessorDirectiv
|
|
|
21
22
|
hasColumnBreak;
|
|
22
23
|
section;
|
|
23
24
|
formGroup;
|
|
25
|
+
destroyRef = inject(DestroyRef);
|
|
24
26
|
constructor(injector, i18n, toasterService, coreService, sanitizer, fb, dialogRef, dialogData) {
|
|
25
27
|
super(injector, i18n, toasterService, coreService, sanitizer, fb);
|
|
26
28
|
this.dialogRef = dialogRef;
|
|
@@ -71,7 +73,7 @@ export class AttachmentSectionDataComponent extends ControlValueAccessorDirectiv
|
|
|
71
73
|
fileContents: this.formGroup.controls['file'].value.fileContents,
|
|
72
74
|
};
|
|
73
75
|
this.uploading = true;
|
|
74
|
-
this.coreService.getAttachments(data).subscribe((Response) => {
|
|
76
|
+
this.coreService.getAttachments(data).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((Response) => {
|
|
75
77
|
this.uploading = false;
|
|
76
78
|
if (Response) {
|
|
77
79
|
const newObj = {
|
|
@@ -121,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
121
123
|
}], section: [{
|
|
122
124
|
type: Input
|
|
123
125
|
}] } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  CUSTOM_ELEMENTS_SCHEMA,\r\n  forwardRef,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { TextareaComponent } from '../textarea/textarea.component';\r\nimport {\r\n  MAT_DIALOG_DATA,\r\n  MatDialogActions,\r\n  MatDialogClose,\r\n  MatDialogContent,\r\n  MatDialogModule,\r\n  MatDialogRef,\r\n} from '@angular/material/dialog';\r\nimport { NgIf } from '@angular/common';\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { Section } from '../../../../interfaces';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  ReactiveFormsModule,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { DocsUploaderComponent } from '../doc-uploader/docs-uploader.component';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport {CoreI18nService, CoreService} from \"../../../../services\";\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    TextareaComponent,\r\n    MatDialogContent,\r\n    DocsUploaderComponent,\r\n    MatDialogActions,\r\n    NgIf,\r\n    MatDialogModule,\r\n    ReactiveFormsModule,\r\n    MatDialogClose,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionDataComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class AttachmentSectionDataComponent<\r\n  Type\r\n> extends ControlValueAccessorDirective<Type> {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n  @Input() section: Section;\r\n  formGroup: FormGroup;\r\n\r\n  constructor(\r\n    injector: Injector,\r\n    i18n: CoreI18nService,\r\n    toasterService: ToastrService,\r\n    coreService: CoreService,\r\n    sanitizer: DomSanitizer,\r\n    fb: FormBuilder,\r\n    public dialogRef: MatDialogRef<any>,\r\n    @Inject(MAT_DIALOG_DATA) public dialogData: any\r\n  ) {\r\n    super(injector, i18n, toasterService, coreService, sanitizer, fb);\r\n  }\r\n\r\n  override ngOnInit() {\r\n    // super.ngOnInit()\r\n    this.createForm();\r\n    if (this.dialogData?.attachmentListData) {\r\n      this.popupData = this.dialogData.attachmentListData;\r\n      this.popupDataOrg = Object.assign({}, this.popupData);\r\n      this.formGroup.controls['file'].setValue(\r\n        this.dialogData.attachmentListData\r\n      );\r\n      this.formGroup.controls['description'].setValue(\r\n        this.dialogData.attachmentListData.fileDescription\r\n      );\r\n      this.formGroup.controls['comments'].setValue(\r\n        this.dialogData.attachmentListData.fileComments\r\n      );\r\n      this.editMode = true;\r\n    }\r\n  }\r\n  createForm() {\r\n    this.formGroup = this.fb.group({\r\n      file: new FormControl(null, Validators.required),\r\n      description: new FormControl(null,this.dialogData.descriptionRequired ? Validators.required: null),\r\n      comments: new FormControl(null, this.dialogData.commentsRequired ? Validators.required: null),\r\n    });\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      fileContents: data?.fileContents,\r\n      fileName: data?.fileName,\r\n      mimeType: data?.mimeType,\r\n      fileDescription: this.popupData?.fileDescription,\r\n      attachmentcomment: this.popupData?.attachmentcomment,\r\n      fileComments: this.popupData?.attachmentcomment,\r\n    };\r\n  }\r\n\r\n  addAttachments() {\r\n    const data = {\r\n      fileDescription: this.formGroup.controls['description'].value,\r\n      attachmentcomment: this.formGroup.controls['comments'].value,\r\n      fileComments: this.formGroup.controls['comments'].value,\r\n      fileName: this.formGroup.controls['file'].value.fileName,\r\n      mimeType: this.formGroup.controls['file'].value.mimeType,\r\n      fileContents: this.formGroup.controls['file'].value.fileContents,\r\n    };\r\n    this.uploading = true;\r\n    this.coreService.getAttachments(data).subscribe((Response: any) => {\r\n      this.uploading = false;\r\n      if (Response) {\r\n        const newObj = {\r\n          fileDescription: this.formGroup.controls['description'].value,\r\n          attachmentcomment: this.formGroup.controls['comments'].value,\r\n          fileComments: this.formGroup.controls['comments'].value,\r\n          fileName: this.formGroup.controls['file'].value.fileName,\r\n          attachmentId: Response.attachment.attachmentId,\r\n          mimeType: this.formGroup.controls['file'].value.mimeType,\r\n        };\r\n        this.dialogRef.close(newObj);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n    <ds-button  icon matDialogClose>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <!-- add [callApi]=\"true\"  input mobile issue not able to download it by base 64 -->\r\n<form [formGroup]=\"formGroup\">\r\n  <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n  [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n  [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"false\" [allowedExtensions]=\"dialogData?.data\"\r\n  [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\"\r\n  formControlName=\"file\"\r\n  >\r\n</app-file-uploader>\r\n\r\n<app-textarea class=\"section-item d-block mt-4 mb-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n  [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n  [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n  [label]=\"i18n.translate('description')\" [required]=\"dialogData?.isRequired\" [minLength]='1' [maxLength]='500'\r\n  [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\"\r\n  formControlName=\"description\" >\r\n  \r\n</app-textarea>\r\n\r\n<app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n  [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n  [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n  [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n  [errorMessage]=\"i18n.translate('lenghtMin1Max500')\"\r\n  formControlName=\"comments\">\r\n</app-textarea>\r\n</form>\r\n   \r\n\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button  shape=\"outline\"  matDialogClose [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n    </ds-button>\r\n    <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!(formGroup?.value?.file?.fileContents || formGroup?.value?.file?.attachmentId ) ||( dialogData?.isRequired && !formGroup?.value?.description )|| uploading || !formGroup.valid)\">\r\n      @if(!editMode){\r\n      <span>{{i18n.translate('add')}}</span>\r\n      }\r\n      @if(editMode){\r\n      <span>{{i18n.translate('edit')}}</span>\r\n      }\r\n\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n\r\n</div>\r\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  CUSTOM_ELEMENTS_SCHEMA,\r\n  DestroyRef,\r\n  forwardRef,\r\n  inject,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { TextareaComponent } from '../textarea/textarea.component';\r\nimport {\r\n  MAT_DIALOG_DATA,\r\n  MatDialogActions,\r\n  MatDialogClose,\r\n  MatDialogContent,\r\n  MatDialogModule,\r\n  MatDialogRef,\r\n} from '@angular/material/dialog';\r\nimport { NgIf } from '@angular/common';\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { Section } from '../../../../interfaces';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  ReactiveFormsModule,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { DocsUploaderComponent } from '../doc-uploader/docs-uploader.component';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport {CoreI18nService, CoreService} from \"../../../../services\";\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    TextareaComponent,\r\n    MatDialogContent,\r\n    DocsUploaderComponent,\r\n    MatDialogActions,\r\n    NgIf,\r\n    MatDialogModule,\r\n    ReactiveFormsModule,\r\n    MatDialogClose,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionDataComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class AttachmentSectionDataComponent<\r\n  Type\r\n> extends ControlValueAccessorDirective<Type> {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n  @Input() section: Section;\r\n  formGroup: FormGroup;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    injector: Injector,\r\n    i18n: CoreI18nService,\r\n    toasterService: ToastrService,\r\n    coreService: CoreService,\r\n    sanitizer: DomSanitizer,\r\n    fb: FormBuilder,\r\n    public dialogRef: MatDialogRef<any>,\r\n    @Inject(MAT_DIALOG_DATA) public dialogData: any\r\n  ) {\r\n    super(injector, i18n, toasterService, coreService, sanitizer, fb);\r\n  }\r\n\r\n  override ngOnInit() {\r\n    // super.ngOnInit()\r\n    this.createForm();\r\n    if (this.dialogData?.attachmentListData) {\r\n      this.popupData = this.dialogData.attachmentListData;\r\n      this.popupDataOrg = Object.assign({}, this.popupData);\r\n      this.formGroup.controls['file'].setValue(\r\n        this.dialogData.attachmentListData\r\n      );\r\n      this.formGroup.controls['description'].setValue(\r\n        this.dialogData.attachmentListData.fileDescription\r\n      );\r\n      this.formGroup.controls['comments'].setValue(\r\n        this.dialogData.attachmentListData.fileComments\r\n      );\r\n      this.editMode = true;\r\n    }\r\n  }\r\n  createForm() {\r\n    this.formGroup = this.fb.group({\r\n      file: new FormControl(null, Validators.required),\r\n      description: new FormControl(null,this.dialogData.descriptionRequired ? Validators.required: null),\r\n      comments: new FormControl(null, this.dialogData.commentsRequired ? Validators.required: null),\r\n    });\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      fileContents: data?.fileContents,\r\n      fileName: data?.fileName,\r\n      mimeType: data?.mimeType,\r\n      fileDescription: this.popupData?.fileDescription,\r\n      attachmentcomment: this.popupData?.attachmentcomment,\r\n      fileComments: this.popupData?.attachmentcomment,\r\n    };\r\n  }\r\n\r\n  addAttachments() {\r\n    const data = {\r\n      fileDescription: this.formGroup.controls['description'].value,\r\n      attachmentcomment: this.formGroup.controls['comments'].value,\r\n      fileComments: this.formGroup.controls['comments'].value,\r\n      fileName: this.formGroup.controls['file'].value.fileName,\r\n      mimeType: this.formGroup.controls['file'].value.mimeType,\r\n      fileContents: this.formGroup.controls['file'].value.fileContents,\r\n    };\r\n    this.uploading = true;\r\n    this.coreService.getAttachments(data).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((Response: any) => {\r\n      this.uploading = false;\r\n      if (Response) {\r\n        const newObj = {\r\n          fileDescription: this.formGroup.controls['description'].value,\r\n          attachmentcomment: this.formGroup.controls['comments'].value,\r\n          fileComments: this.formGroup.controls['comments'].value,\r\n          fileName: this.formGroup.controls['file'].value.fileName,\r\n          attachmentId: Response.attachment.attachmentId,\r\n          mimeType: this.formGroup.controls['file'].value.mimeType,\r\n        };\r\n        this.dialogRef.close(newObj);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{i18n.translate('addAttachments')}}</h3>\r\n    <ds-button  icon matDialogClose>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <!-- add [callApi]=\"true\"  input mobile issue not able to download it by base 64 -->\r\n<form [formGroup]=\"formGroup\">\r\n  <app-file-uploader class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n  [labelTextReadMode]=\"i18n.translate('Attachment')\" [labelTextWriteMode]=\"i18n.translate('Attachment')\"\r\n  [hasColumnBreak]=\"false\" [label]=\"i18n.translate('Attachment')\" [required]=\"true\" [multiple]=\"false\" [allowedExtensions]=\"dialogData?.data\"\r\n  [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\"\r\n  formControlName=\"file\"\r\n  >\r\n</app-file-uploader>\r\n\r\n<app-textarea class=\"section-item d-block mt-4 mb-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n  [labelTextReadMode]=\"i18n.translate('description')\" [labelTextWriteMode]=\"i18n.translate('description')\"\r\n  [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n  [label]=\"i18n.translate('description')\" [required]=\"dialogData?.isRequired\" [minLength]='1' [maxLength]='500'\r\n  [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"i18n.translate('lenghtMin1Max500')\"\r\n  formControlName=\"description\" >\r\n  \r\n</app-textarea>\r\n\r\n<app-textarea class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n  [labelTextReadMode]=\"i18n.translate('comments')\" [labelTextWriteMode]=\"i18n.translate('comments')\"\r\n  [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\" [label]=\"i18n.translate('comments')\"\r\n  [required]=\"false\" [minLength]='1' [maxLength]='500' [isReadOnly]=\"section?.header?.readOnly\"\r\n  [errorMessage]=\"i18n.translate('lenghtMin1Max500')\"\r\n  formControlName=\"comments\">\r\n</app-textarea>\r\n</form>\r\n   \r\n\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button  shape=\"outline\"  matDialogClose [disabled]=\"(uploading)\" color=\"red\">{{i18n.translate('cancel')}}\r\n    </ds-button>\r\n    <ds-button (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!(formGroup?.value?.file?.fileContents || formGroup?.value?.file?.attachmentId ) ||( dialogData?.isRequired && !formGroup?.value?.description )|| uploading || !formGroup.valid)\">\r\n      @if(!editMode){\r\n      <span>{{i18n.translate('add')}}</span>\r\n      }\r\n      @if(editMode){\r\n      <span>{{i18n.translate('edit')}}</span>\r\n      }\r\n\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n\r\n</div>\r\n"]}
|