bpm-core 0.0.25 → 0.0.27
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/app/app.component.mjs +12 -13
- package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +20 -34
- package/esm2022/lib/components/app-component-sections/approvals/approvals.component.mjs +26 -0
- package/esm2022/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.mjs +98 -0
- package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +4 -40
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +15 -13
- package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs +95 -11
- package/esm2022/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.mjs +12 -17
- package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +9 -11
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +3 -5
- package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +9 -42
- package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +42 -0
- package/esm2022/lib/constants/constants.mjs +3 -1
- package/esm2022/lib/services/core.service.ts.mjs +309 -301
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +72 -27
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +33 -11
- package/fesm2022/bpm-core.mjs +789 -719
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/app/app.component.d.ts +1 -2
- package/lib/components/app-component-sections/activities/activities.component.d.ts +5 -14
- package/lib/components/app-component-sections/approvals/approvals.component.d.ts +11 -0
- package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +20 -0
- package/lib/components/app-component-sections/form-section/form-section.component.d.ts +3 -4
- package/lib/components/app-component-sections/service-header/service-header.component.d.ts +4 -3
- package/lib/components/shared-components/action-buttons/action-buttons.component.d.ts +29 -6
- package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +4 -4
- package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +3 -2
- package/lib/components/shared-components/form-field/input/input.component.d.ts +1 -4
- package/lib/components/shared-components/form-field/validation-errors/validation-errors.component.d.ts +16 -0
- package/lib/constants/constants.d.ts +2 -0
- package/lib/services/core.service.ts.d.ts +35 -2
- package/lib/testComponent/general-approver-section/general-approver-section.component.d.ts +21 -13
- package/lib/testComponent/request-details-section/request-details-section.component.d.ts +14 -6
- package/package.json +1 -1
- package/src/lib/assets/scss/_upgrade.scss +3 -3
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { Component, Inject } from '@angular/core';
|
|
2
|
-
import { LayoutComponent } from "../components/app-component-sections";
|
|
2
|
+
import { LayoutComponent, ServiceHeaderComponent, WorkflowSectionComponent } from "../components/app-component-sections";
|
|
3
3
|
import { DOCUMENT } from "@angular/common";
|
|
4
|
-
import { Form
|
|
4
|
+
import { Form } from "../interfaces";
|
|
5
5
|
import * as constants from "../constants";
|
|
6
6
|
import loadFormHooks from "../hooks/load-form";
|
|
7
|
-
import { ServiceHeaderComponent, WorkflowSectionComponent } from "../components/app-component-sections";
|
|
8
7
|
import { RequestDetailsSectionComponent } from "../testComponent/request-details-section/request-details-section.component";
|
|
9
8
|
import { DynamicComponentInjectorToken } from "ng-dynamic-component";
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
@@ -29,14 +28,14 @@ export class CoreAppComponent {
|
|
|
29
28
|
this.sidenavService = sidenavService;
|
|
30
29
|
this.coreService = coreService;
|
|
31
30
|
this.loading['form'] = true;
|
|
32
|
-
this.coreService.loadForm().
|
|
33
|
-
|
|
31
|
+
this.coreService.loadForm().subscribe({
|
|
32
|
+
next: (form) => {
|
|
34
33
|
this.form = form;
|
|
34
|
+
this.loading['form'] = false;
|
|
35
|
+
},
|
|
36
|
+
error: (err) => {
|
|
37
|
+
this.errorResponse(err);
|
|
35
38
|
}
|
|
36
|
-
else if (form instanceof Messages) {
|
|
37
|
-
this.errorResponse(form);
|
|
38
|
-
}
|
|
39
|
-
this.loading['form'] = false;
|
|
40
39
|
});
|
|
41
40
|
}
|
|
42
41
|
errorResponse(form) {
|
|
@@ -52,9 +51,9 @@ export class CoreAppComponent {
|
|
|
52
51
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CoreAppComponent, deps: [{ token: i1.SegmentDynamicLoaderService }, { token: DOCUMENT }, { token: i2.Router }, { token: i3.SidenavService }, { token: i3.CoreService }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
52
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: CoreAppComponent, isStandalone: true, selector: "lib-app", providers: [
|
|
54
53
|
{ provide: DynamicComponentInjectorToken, useValue: { /* your value here */} }
|
|
55
|
-
], ngImport: i0, template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [segmentDynamicLoaderService]=\"segmentDynamicLoader\"\r\n [sections]=\"form?.sections\">\r\n
|
|
54
|
+
], ngImport: i0, template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [segmentDynamicLoaderService]=\"segmentDynamicLoader\"\r\n [sections]=\"form?.sections\">\r\n\r\n <app-request-details-section [form]=\"form\" [section]=\"form?.sections[0]\" [lov]=\"form?.lovs\" className=\"form-section\"></app-request-details-section>\r\n <!-- [isReadOnly]=\"form.sections[0].header.readOnly\"-->\r\n </app-workflow-section>\r\n } @else {\r\n <core-service-header header [formTitle]=\"formTitle\" [isLoading]=\"true\">\r\n </core-service-header>\r\n }\r\n</core-layout>\r\n", styles: [""], dependencies: [{ kind: "component", type:
|
|
56
55
|
// DynamicModule,
|
|
57
|
-
LayoutComponent, selector: "core-layout", inputs: ["form", "formTitle", "isLoading", "serviceBrief"] }, { kind: "component", type: ServiceHeaderComponent, selector: "core-service-header", inputs: ["form", "showHistory", "isLoading", "showApprovalHistory", "approvalHistory", "creationDate", "formTitle", "section", "serviceBrief"] }, { kind: "component", type: WorkflowSectionComponent, selector: "app-workflow-section", inputs: ["sections", "isReadOnly", "isLoading", "form", "contentClass", "sectionsController", "segmentDynamicLoaderService", "sectionFormComponent", "sectionName"], outputs: ["sectionSubmitted"] }, { kind: "component", type: RequestDetailsSectionComponent, selector: "app-request-details-section", inputs: ["isReadOnly", "section", "lov", "className"] }] });
|
|
56
|
+
LayoutComponent, selector: "core-layout", inputs: ["form", "formTitle", "isLoading", "serviceBrief"] }, { kind: "component", type: ServiceHeaderComponent, selector: "core-service-header", inputs: ["form", "showHistory", "isLoading", "showApprovalHistory", "approvalHistory", "creationDate", "formTitle", "section", "serviceBrief"] }, { kind: "component", type: WorkflowSectionComponent, selector: "app-workflow-section", inputs: ["sections", "isReadOnly", "isLoading", "form", "contentClass", "sectionsController", "segmentDynamicLoaderService", "sectionFormComponent", "sectionName"], outputs: ["sectionSubmitted"] }, { kind: "component", type: RequestDetailsSectionComponent, selector: "app-request-details-section", inputs: ["isReadOnly", "section", "form", "lov", "className"] }] });
|
|
58
57
|
}
|
|
59
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CoreAppComponent, decorators: [{
|
|
60
59
|
type: Component,
|
|
@@ -66,9 +65,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
66
65
|
RequestDetailsSectionComponent
|
|
67
66
|
], providers: [
|
|
68
67
|
{ provide: DynamicComponentInjectorToken, useValue: { /* your value here */} }
|
|
69
|
-
], template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [segmentDynamicLoaderService]=\"segmentDynamicLoader\"\r\n [sections]=\"form?.sections\">\r\n
|
|
68
|
+
], template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [segmentDynamicLoaderService]=\"segmentDynamicLoader\"\r\n [sections]=\"form?.sections\">\r\n\r\n <app-request-details-section [form]=\"form\" [section]=\"form?.sections[0]\" [lov]=\"form?.lovs\" className=\"form-section\"></app-request-details-section>\r\n <!-- [isReadOnly]=\"form.sections[0].header.readOnly\"-->\r\n </app-workflow-section>\r\n } @else {\r\n <core-service-header header [formTitle]=\"formTitle\" [isLoading]=\"true\">\r\n </core-service-header>\r\n }\r\n</core-layout>\r\n" }]
|
|
70
69
|
}], ctorParameters: () => [{ type: i1.SegmentDynamicLoaderService }, { type: Document, decorators: [{
|
|
71
70
|
type: Inject,
|
|
72
71
|
args: [DOCUMENT]
|
|
73
72
|
}] }, { type: i2.Router }, { type: i3.SidenavService }, { type: i3.CoreService }] });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JwbS1jb3JlL3NyYy9saWIvYXBwL2FwcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2FwcC9hcHAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLGVBQWUsRUFBRSxzQkFBc0IsRUFBRSx3QkFBd0IsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZILE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUd6QyxPQUFPLEVBQUMsSUFBSSxFQUFXLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sS0FBSyxTQUFTLE1BQU0sY0FBYyxDQUFDO0FBQzFDLE9BQU8sYUFBYSxNQUFNLG9CQUFvQixDQUFDO0FBQy9DLE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBRTFILE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLHNCQUFzQixDQUFDOzs7OztBQW1CbkUsTUFBTSxPQUFPLGdCQUFnQjtJQVFsQjtJQUM0QjtJQUNsQjtJQUNBO0lBQ1Q7SUFYVixPQUFPLEdBQUc7UUFDUixJQUFJLEVBQUUsS0FBSztLQUNaLENBQUE7SUFDRCxJQUFJLENBQU07SUFDVixTQUFTLEdBQVcsTUFBTSxDQUFDO0lBRTNCLFlBQ1Msb0JBQWlELEVBQ3JCLFFBQWtCLEVBQ3BDLE1BQWMsRUFDZCxjQUE4QixFQUN2QyxXQUF3QjtRQUp6Qix5QkFBb0IsR0FBcEIsb0JBQW9CLENBQTZCO1FBQ3JCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDcEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUN2QyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUVoQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQTtRQUMzQixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxDQUFDLFNBQVMsQ0FBQztZQUNwQyxJQUFJLEVBQUUsQ0FBQyxJQUFTLEVBQUUsRUFBRTtnQkFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7Z0JBQ2pCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFBO1lBQzlCLENBQUM7WUFDRCxLQUFLLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDYixJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFBO1lBQ3pCLENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsYUFBYSxDQUFDLElBQVM7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLFNBQVMsQ0FBQyxRQUFRLEVBQ2xCLElBQUksQ0FDTCxDQUFDO1FBQ0osQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDMUIsSUFBSSxDQUFDLElBQUksR0FBRyxhQUFhLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzdELENBQUM7UUFDRCxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN4QixDQUFDO3VHQTFDVSxnQkFBZ0IsNkRBU2pCLFFBQVE7MkZBVFAsZ0JBQWdCLHNEQUxoQjtZQUNULEVBQUMsT0FBTyxFQUFFLDZCQUE2QixFQUFFLFFBQVEsRUFBRSxFQUFFLHFCQUFxQixDQUFDLEVBQUM7U0FDN0UsMEJDMUJILCt4QkFxQkE7Z0JESEksaUJBQWlCO2dCQUNqQixlQUFlLG9IQUNmLHNCQUFzQixnTkFDdEIsd0JBQXdCLHFRQUN4Qiw4QkFBOEI7OzJGQU9yQixnQkFBZ0I7a0JBakI1QixTQUFTOytCQUNFLFNBQVMsY0FDUCxJQUFJLFdBR1A7d0JBQ1AsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLHNCQUFzQjt3QkFDdEIsd0JBQXdCO3dCQUN4Qiw4QkFBOEI7cUJBQy9CLGFBQ1U7d0JBQ1QsRUFBQyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsUUFBUSxFQUFFLEVBQUUscUJBQXFCLENBQUMsRUFBQztxQkFDN0U7OzBCQVlFLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0xheW91dENvbXBvbmVudCwgU2VydmljZUhlYWRlckNvbXBvbmVudCwgV29ya2Zsb3dTZWN0aW9uQ29tcG9uZW50fSBmcm9tIFwiLi4vY29tcG9uZW50cy9hcHAtY29tcG9uZW50LXNlY3Rpb25zXCI7XHJcbmltcG9ydCB7RE9DVU1FTlR9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtSb3V0ZXJ9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuaW1wb3J0IHtDb3JlU2VydmljZSwgU2lkZW5hdlNlcnZpY2V9IGZyb20gXCIuLi9zZXJ2aWNlc1wiO1xyXG5pbXBvcnQge0Zvcm0sIE1lc3NhZ2VzfSBmcm9tIFwiLi4vaW50ZXJmYWNlc1wiO1xyXG5pbXBvcnQgKiBhcyBjb25zdGFudHMgZnJvbSBcIi4uL2NvbnN0YW50c1wiO1xyXG5pbXBvcnQgbG9hZEZvcm1Ib29rcyBmcm9tIFwiLi4vaG9va3MvbG9hZC1mb3JtXCI7XHJcbmltcG9ydCB7UmVxdWVzdERldGFpbHNTZWN0aW9uQ29tcG9uZW50fSBmcm9tIFwiLi4vdGVzdENvbXBvbmVudC9yZXF1ZXN0LWRldGFpbHMtc2VjdGlvbi9yZXF1ZXN0LWRldGFpbHMtc2VjdGlvbi5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtTZWdtZW50RHluYW1pY0xvYWRlclNlcnZpY2V9IGZyb20gXCIuLi90ZXN0Q29tcG9uZW50L3NlcnZpY2VzL3NlZ21lbnQtZHluYW1pYy1sb2FkZXIuc2VydmljZVwiO1xyXG5pbXBvcnQge0R5bmFtaWNDb21wb25lbnRJbmplY3RvclRva2VufSBmcm9tIFwibmctZHluYW1pYy1jb21wb25lbnRcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWFwcCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXBwLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYXBwLmNvbXBvbmVudC5jc3MnLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIC8vIER5bmFtaWNNb2R1bGUsXHJcbiAgICBMYXlvdXRDb21wb25lbnQsXHJcbiAgICBTZXJ2aWNlSGVhZGVyQ29tcG9uZW50LFxyXG4gICAgV29ya2Zsb3dTZWN0aW9uQ29tcG9uZW50LFxyXG4gICAgUmVxdWVzdERldGFpbHNTZWN0aW9uQ29tcG9uZW50XHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtwcm92aWRlOiBEeW5hbWljQ29tcG9uZW50SW5qZWN0b3JUb2tlbiwgdXNlVmFsdWU6IHsgLyogeW91ciB2YWx1ZSBoZXJlICovfX1cclxuICBdXHJcblxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29yZUFwcENvbXBvbmVudCB7XHJcbiAgbG9hZGluZyA9IHtcclxuICAgIGZvcm06IGZhbHNlXHJcbiAgfVxyXG4gIGZvcm06IEZvcm1cclxuICBmb3JtVGl0bGU6IHN0cmluZyA9ICdUZXN0JztcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgc2VnbWVudER5bmFtaWNMb2FkZXI6IFNlZ21lbnREeW5hbWljTG9hZGVyU2VydmljZSxcclxuICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQ6IERvY3VtZW50LFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSByb3V0ZXI6IFJvdXRlcixcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgc2lkZW5hdlNlcnZpY2U6IFNpZGVuYXZTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBjb3JlU2VydmljZTogQ29yZVNlcnZpY2VcclxuICApIHtcclxuICAgIHRoaXMubG9hZGluZ1snZm9ybSddID0gdHJ1ZVxyXG4gICAgdGhpcy5jb3JlU2VydmljZS5sb2FkRm9ybSgpLnN1YnNjcmliZSh7XHJcbiAgICAgIG5leHQ6IChmb3JtOiBhbnkpID0+IHtcclxuICAgICAgICB0aGlzLmZvcm0gPSBmb3JtO1xyXG4gICAgICAgIHRoaXMubG9hZGluZ1snZm9ybSddID0gZmFsc2VcclxuICAgICAgfSxcclxuICAgICAgZXJyb3I6IChlcnIpID0+IHtcclxuICAgICAgICB0aGlzLmVycm9yUmVzcG9uc2UoZXJyKVxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGVycm9yUmVzcG9uc2UoZm9ybTogYW55KSB7XHJcbiAgICBpZiAoIXRoaXMuZm9ybSkge1xyXG4gICAgICB0aGlzLmZvcm0gPSBuZXcgRm9ybShcclxuICAgICAgICBjb25zdGFudHMuTk9fVkFMVUUsXHJcbiAgICAgICAgY29uc3RhbnRzLk5PX1ZBTFVFLFxyXG4gICAgICAgIGNvbnN0YW50cy5OT19WQUxVRSxcclxuICAgICAgICBjb25zdGFudHMuTk9fVkFMVUUsXHJcbiAgICAgICAgY29uc3RhbnRzLk5PX1ZBTFVFLFxyXG4gICAgICAgIGNvbnN0YW50cy5OT19WQUxVRSxcclxuICAgICAgICBmb3JtXHJcbiAgICAgICk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmZvcm0ubWVzc2FnZXMgPSBmb3JtO1xyXG4gICAgICB0aGlzLmZvcm0gPSBsb2FkRm9ybUhvb2tzLmFmdGVyVHJhbnNwaWxlUGF5bG9hZCh0aGlzLmZvcm0pO1xyXG4gICAgfVxyXG4gICAgd2luZG93LnNjcm9sbFRvKDAsIDApO1xyXG4gIH1cclxufVxyXG4iLCI8Y29yZS1sYXlvdXQ+XHJcbiAgQGlmICghbG9hZGluZ1snZm9ybSddKSB7XHJcbiAgICA8Y29yZS1zZXJ2aWNlLWhlYWRlclxyXG4gICAgICBbaXNMb2FkaW5nXT1cImZhbHNlXCJcclxuICAgICAgW2Zvcm1UaXRsZV09XCJmb3JtVGl0bGVcIlxyXG4gICAgICBbZm9ybV09XCJmb3JtXCI+XHJcbiAgICA8L2NvcmUtc2VydmljZS1oZWFkZXI+XHJcbiAgPGFwcC13b3JrZmxvdy1zZWN0aW9uXHJcbiAgICAgIHdvcmtmbG93XHJcbiAgICAgIFtmb3JtXT1cImZvcm1cIlxyXG4gICAgICAgW3NlZ21lbnREeW5hbWljTG9hZGVyU2VydmljZV09XCJzZWdtZW50RHluYW1pY0xvYWRlclwiXHJcbiAgICAgIFtzZWN0aW9uc109XCJmb3JtPy5zZWN0aW9uc1wiPlxyXG5cclxuICAgICAgPGFwcC1yZXF1ZXN0LWRldGFpbHMtc2VjdGlvbiBbZm9ybV09XCJmb3JtXCIgW3NlY3Rpb25dPVwiZm9ybT8uc2VjdGlvbnNbMF1cIiBbbG92XT1cImZvcm0/LmxvdnNcIiBjbGFzc05hbWU9XCJmb3JtLXNlY3Rpb25cIj48L2FwcC1yZXF1ZXN0LWRldGFpbHMtc2VjdGlvbj5cclxuICAgICAgPCEtLSAgICAgIFtpc1JlYWRPbmx5XT1cImZvcm0uc2VjdGlvbnNbMF0uaGVhZGVyLnJlYWRPbmx5XCItLT5cclxuICAgIDwvYXBwLXdvcmtmbG93LXNlY3Rpb24+XHJcbiAgfSBAZWxzZSB7XHJcbiAgICA8Y29yZS1zZXJ2aWNlLWhlYWRlciBoZWFkZXIgW2Zvcm1UaXRsZV09XCJmb3JtVGl0bGVcIiBbaXNMb2FkaW5nXT1cInRydWVcIj5cclxuICAgIDwvY29yZS1zZXJ2aWNlLWhlYWRlcj5cclxuICB9XHJcbjwvY29yZS1sYXlvdXQ+XHJcbiJdfQ==
|
|
@@ -1,51 +1,37 @@
|
|
|
1
1
|
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
2
|
-
import { NgIf } from '@angular/common';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "../../../services";
|
|
5
4
|
export class ActivitiesComponent {
|
|
6
5
|
sidenavService;
|
|
7
6
|
i18n;
|
|
8
|
-
|
|
7
|
+
coreService;
|
|
8
|
+
parsedData;
|
|
9
|
+
constructor(sidenavService, i18n, coreService) {
|
|
9
10
|
this.sidenavService = sidenavService;
|
|
10
11
|
this.i18n = i18n;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
console.log(data.detail);
|
|
14
|
-
if (data.detail.type == 'download') {
|
|
15
|
-
this.downloadFile(data);
|
|
16
|
-
}
|
|
12
|
+
this.coreService = coreService;
|
|
13
|
+
this.parsedData = JSON.stringify(this.coreService.activities);
|
|
17
14
|
}
|
|
18
15
|
downloadFile(event) {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
dataURItoBlob(dataURI) {
|
|
30
|
-
const byteString = atob(dataURI);
|
|
31
|
-
const arrayBuffer = new ArrayBuffer(byteString.length);
|
|
32
|
-
const int8Array = new Uint8Array(arrayBuffer);
|
|
33
|
-
for (let i = 0; i < byteString.length; i++) {
|
|
34
|
-
int8Array[i] = byteString.charCodeAt(i);
|
|
35
|
-
}
|
|
36
|
-
const blob = new Blob([arrayBuffer], { type: 'image/jpeg' });
|
|
37
|
-
return blob;
|
|
16
|
+
console.log(event.detail.value);
|
|
17
|
+
const placeholder = event.target.nextElementSibling;
|
|
18
|
+
this.coreService.loadFile(event.detail.value.id).then((responseObject) => {
|
|
19
|
+
const fileInformation = responseObject.body;
|
|
20
|
+
const fileBlob = this.coreService.dataURItoBlob(fileInformation.fileContents);
|
|
21
|
+
const file = new File([fileBlob], fileInformation.fileName, { type: fileInformation.mimeType });
|
|
22
|
+
placeholder.href = URL.createObjectURL(file);
|
|
23
|
+
placeholder.download = file.name;
|
|
24
|
+
placeholder.click();
|
|
25
|
+
});
|
|
38
26
|
}
|
|
39
27
|
closeSidenav() {
|
|
40
28
|
this.sidenavService.publish('close', null);
|
|
41
29
|
}
|
|
42
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ActivitiesComponent, deps: [{ token: i1.SidenavService }, { token: i1.CoreI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
43
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
30
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ActivitiesComponent, deps: [{ token: i1.SidenavService }, { token: i1.CoreI18nService }, { token: i1.CoreService }], target: i0.ɵɵFactoryTarget.Component });
|
|
31
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ActivitiesComponent, isStandalone: true, selector: "app-activities", ngImport: i0, template: "<section class=\"main-sidenav\">\r\n <div class=\"sidenav-title\">\r\n <h3>{{ i18n.translate('commentHistory') }}</h3>\r\n\r\n <ds-button (click)=\"closeSidenav()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n\r\n </div>\r\n <div class=\"sidenav-body\">\r\n @if (coreService.activities) {\r\n <ds-activity-log activitiesData=\"{{parsedData}}\" readOnly (downloadEvent)=\"downloadFile($event)\">\r\n </ds-activity-log>\r\n } @else {\r\n <ds-message *ngIf=\"!coreService.activities\" label=\"{{i18n.translate('NoData1')}}\"></ds-message>\r\n }\r\n </div>\r\n</section>\r\n", styles: [""] });
|
|
44
32
|
}
|
|
45
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ActivitiesComponent, decorators: [{
|
|
46
34
|
type: Component,
|
|
47
|
-
args: [{ selector: 'app-activities', standalone: true, imports: [
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
}], ctorParameters: () => [{ type: i1.SidenavService }, { type: i1.CoreI18nService }] });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdGllcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2NvbXBvbmVudHMvYXBwLWNvbXBvbmVudC1zZWN0aW9ucy9hY3Rpdml0aWVzL2FjdGl2aXRpZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL2FwcC1jb21wb25lbnQtc2VjdGlvbnMvYWN0aXZpdGllcy9hY3Rpdml0aWVzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbEUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFZdkMsTUFBTSxPQUFPLG1CQUFtQjtJQUVwQjtJQUNEO0lBRlQsWUFDVSxjQUE4QixFQUMvQixJQUFxQjtRQURwQixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDL0IsU0FBSSxHQUFKLElBQUksQ0FBaUI7SUFDM0IsQ0FBQztJQUdKLEtBQUssQ0FBQyxJQUFTO1FBQ2IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDekIsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFCLENBQUM7SUFFSCxDQUFDO0lBR0QsWUFBWSxDQUFDLEtBQWtGO1FBQ2hHOzs7Ozs7OztnQkFRUTtJQUNQLENBQUM7SUFFRCxhQUFhLENBQUMsT0FBWTtRQUN4QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsTUFBTSxXQUFXLEdBQUcsSUFBSSxXQUFXLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZELE1BQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzlDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDM0MsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUMsQ0FBQztRQUNELE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztRQUM3RCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFHRCxZQUFZO1FBQ1YsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzdDLENBQUM7dUdBMUNVLG1CQUFtQjsyRkFBbkIsbUJBQW1CLDBFQ2ZoQywwcUJBZ0JBOzsyRkREYSxtQkFBbUI7a0JBVi9CLFNBQVM7K0JBQ0UsZ0JBQWdCLGNBR2QsSUFBSSxXQUNQO3dCQUNQLElBQUk7cUJBQ0wsV0FDUSxDQUFDLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDVVNUT01fRUxFTUVOVFNfU0NIRU1BIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvcmVJMThuU2VydmljZSwgIFNpZGVuYXZTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMnO1xyXG5pbXBvcnQgKiBhcyBDb25zdGFudHMgZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2NvbnN0YW50cyc7XHJcbmltcG9ydCB7IE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtYWN0aXZpdGllcycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2FjdGl2aXRpZXMuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2FjdGl2aXRpZXMuY29tcG9uZW50LnNjc3MnXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE5nSWZcclxuICBdLFxyXG4gIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQWN0aXZpdGllc0NvbXBvbmVudCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHNpZGVuYXZTZXJ2aWNlOiBTaWRlbmF2U2VydmljZSxcclxuICAgIHB1YmxpYyBpMThuOiBDb3JlSTE4blNlcnZpY2UsXHJcbiAgKSB7fVxyXG5cclxuXHJcbiAgYXR0Y2goZGF0YTogYW55KSB7XHJcbiAgICBjb25zb2xlLmxvZyhkYXRhLmRldGFpbCk7XHJcbiAgICBpZiAoZGF0YS5kZXRhaWwudHlwZSA9PSAnZG93bmxvYWQnKSB7XHJcbiAgICAgIHRoaXMuZG93bmxvYWRGaWxlKGRhdGEpO1xyXG4gICAgfVxyXG5cclxuICB9XHJcblxyXG5cclxuICBkb3dubG9hZEZpbGUoZXZlbnQ6IHsgdGFyZ2V0OiB7IG5leHRFbGVtZW50U2libGluZzogYW55OyB9OyBkZXRhaWw6IHsgdmFsdWU6IHsgaWQ6IGFueTsgfTsgfTsgfSkge1xyXG4gLyogICBjb25zdCBwbGFjZWhvbGRlciA9IGV2ZW50LnRhcmdldC5uZXh0RWxlbWVudFNpYmxpbmc7XHJcbiAgICB0aGlzLmNvcmVTdGF0ZU1hY2hpbmVTZXJ2aWNlLmRpc3BhdGNoKENvbnN0YW50cy5TVEFURV9NQUNISU5FX0FDVElPTl9MT0FEX0ZJTEUsIGV2ZW50LmRldGFpbC52YWx1ZS5pZCkudGhlbigocmVzcG9uc2VPYmplY3Q6IHsgYm9keTogYW55OyB9KSA9PiB7XHJcbiAgICAgIGNvbnN0IGZpbGVJbmZvcm1hdGlvbiA9IHJlc3BvbnNlT2JqZWN0LmJvZHk7XHJcbiAgICAgIGNvbnN0IGZpbGVCbG9iID0gdGhpcy5kYXRhVVJJdG9CbG9iKGZpbGVJbmZvcm1hdGlvbi5maWxlQ29udGVudHMpO1xyXG4gICAgICBjb25zdCBmaWxlID0gbmV3IEZpbGUoW2ZpbGVCbG9iXSwgZmlsZUluZm9ybWF0aW9uLmZpbGVOYW1lLCB7IHR5cGU6IGZpbGVJbmZvcm1hdGlvbi5taW1lVHlwZSB9KTtcclxuICAgICAgcGxhY2Vob2xkZXIuaHJlZiA9IFVSTC5jcmVhdGVPYmplY3RVUkwoZmlsZSk7XHJcbiAgICAgIHBsYWNlaG9sZGVyLmRvd25sb2FkID0gZmlsZS5uYW1lO1xyXG4gICAgICBwbGFjZWhvbGRlci5jbGljaygpO1xyXG4gICAgfSk7Ki9cclxuICB9XHJcblxyXG4gIGRhdGFVUkl0b0Jsb2IoZGF0YVVSSTogYW55KSB7XHJcbiAgICBjb25zdCBieXRlU3RyaW5nID0gYXRvYihkYXRhVVJJKTtcclxuICAgIGNvbnN0IGFycmF5QnVmZmVyID0gbmV3IEFycmF5QnVmZmVyKGJ5dGVTdHJpbmcubGVuZ3RoKTtcclxuICAgIGNvbnN0IGludDhBcnJheSA9IG5ldyBVaW50OEFycmF5KGFycmF5QnVmZmVyKTtcclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYnl0ZVN0cmluZy5sZW5ndGg7IGkrKykge1xyXG4gICAgICBpbnQ4QXJyYXlbaV0gPSBieXRlU3RyaW5nLmNoYXJDb2RlQXQoaSk7XHJcbiAgICB9XHJcbiAgICBjb25zdCBibG9iID0gbmV3IEJsb2IoW2FycmF5QnVmZmVyXSwgeyB0eXBlOiAnaW1hZ2UvanBlZycgfSk7XHJcbiAgICByZXR1cm4gYmxvYjtcclxuICB9XHJcblxyXG5cclxuICBjbG9zZVNpZGVuYXYoKSB7XHJcbiAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnB1Ymxpc2goJ2Nsb3NlJywgbnVsbCk7XHJcbiAgfVxyXG59XHJcbiIsIjxzZWN0aW9uIGNsYXNzPVwibWFpbi1zaWRlbmF2XCI+XHJcbiAgPGRpdiBjbGFzcz1cInNpZGVuYXYtdGl0bGVcIj5cclxuICAgIDxoMz57eyBpMThuLnRyYW5zbGF0ZSgnY29tbWVudEhpc3RvcnknKSB9fTwvaDM+XHJcblxyXG4gICAgPGRzLWJ1dHRvbiAoY2xpY2spPVwiY2xvc2VTaWRlbmF2KClcIiBpY29uPlxyXG4gICAgICA8ZHMtaWNvbiBpY29uPVwiY2xvc2VcIiBjbGFzcz1cImZzLTIwIGZjLWJsYWNrXCI+PC9kcy1pY29uPlxyXG4gICAgPC9kcy1idXR0b24+XHJcblxyXG4gIDwvZGl2PlxyXG48IS0tICA8ZGl2IGNsYXNzPVwic2lkZW5hdi1ib2R5XCI+XHJcbiAgICA8ZHMtYWN0aXZpdHktbG9nIGFjdGl2aXRpZXNEYXRhPVwie3twcm9maWxlUmVxdWVzdG9yU2VydmljZS5hY3Rpdml0aWVzfX1cIiByZWFkT25seSAoYXR0YWNobWVudEV2ZW50KT1cImF0dGNoKCRldmVudClcIj5cclxuICAgIDwvZHMtYWN0aXZpdHktbG9nPlxyXG4gICAgPGEgaHJlZj1cIlwiIGNsYXNzPVwiaGlkZGVuLXBsYWNlaG9sZGVyXCI+PC9hPlxyXG4gICAgPGRzLW1lc3NhZ2UgKm5nSWY9XCIhcHJvZmlsZVJlcXVlc3RvclNlcnZpY2UuYWN0aXZpdGllc1wiIGxhYmVsPVwie3tpMThuLnRyYW5zbGF0ZSgnTm9EYXRhMScpfX1cIj48L2RzLW1lc3NhZ2U+XHJcbiAgPC9kaXY+LS0+XHJcbjwvc2VjdGlvbj5cclxuIl19
|
|
35
|
+
args: [{ selector: 'app-activities', standalone: true, imports: [], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<section class=\"main-sidenav\">\r\n <div class=\"sidenav-title\">\r\n <h3>{{ i18n.translate('commentHistory') }}</h3>\r\n\r\n <ds-button (click)=\"closeSidenav()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n\r\n </div>\r\n <div class=\"sidenav-body\">\r\n @if (coreService.activities) {\r\n <ds-activity-log activitiesData=\"{{parsedData}}\" readOnly (downloadEvent)=\"downloadFile($event)\">\r\n </ds-activity-log>\r\n } @else {\r\n <ds-message *ngIf=\"!coreService.activities\" label=\"{{i18n.translate('NoData1')}}\"></ds-message>\r\n }\r\n </div>\r\n</section>\r\n" }]
|
|
36
|
+
}], ctorParameters: () => [{ type: i1.SidenavService }, { type: i1.CoreI18nService }, { type: i1.CoreService }] });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdGllcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2NvbXBvbmVudHMvYXBwLWNvbXBvbmVudC1zZWN0aW9ucy9hY3Rpdml0aWVzL2FjdGl2aXRpZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL2FwcC1jb21wb25lbnQtc2VjdGlvbnMvYWN0aXZpdGllcy9hY3Rpdml0aWVzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsc0JBQXNCLEVBQUMsTUFBTSxlQUFlLENBQUM7OztBQVdoRSxNQUFNLE9BQU8sbUJBQW1CO0lBSXBCO0lBQ0Q7SUFDQTtJQUxULFVBQVUsQ0FBSztJQUVmLFlBQ1UsY0FBOEIsRUFDL0IsSUFBcUIsRUFDckIsV0FBd0I7UUFGdkIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQy9CLFNBQUksR0FBSixJQUFJLENBQWlCO1FBQ3JCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBRS9CLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxDQUFBO0lBQy9ELENBQUM7SUFFRCxZQUFZLENBQUMsS0FBVTtRQUNyQixPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDL0IsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQztRQUNwRCxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxjQUE4QixFQUFFLEVBQUU7WUFDdkYsTUFBTSxlQUFlLEdBQUcsY0FBYyxDQUFDLElBQUksQ0FBQztZQUM1QyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDOUUsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxlQUFlLENBQUMsUUFBUSxFQUFFLEVBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxRQUFRLEVBQUMsQ0FBQyxDQUFDO1lBQzlGLFdBQVcsQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM3QyxXQUFXLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDakMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3RCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUdELFlBQVk7UUFDVixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQzt1R0EzQlUsbUJBQW1COzJGQUFuQixtQkFBbUIsMEVDWGhDLG9wQkFrQkE7OzJGRFBhLG1CQUFtQjtrQkFSL0IsU0FBUzsrQkFDRSxnQkFBZ0IsY0FHZCxJQUFJLFdBQ1AsRUFBRyxXQUNILENBQUMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29yZUkxOG5TZXJ2aWNlLCBDb3JlU2VydmljZSwgU2lkZW5hdlNlcnZpY2V9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWFjdGl2aXRpZXMnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hY3Rpdml0aWVzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hY3Rpdml0aWVzLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbIF0sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY3Rpdml0aWVzQ29tcG9uZW50IHtcclxuICBwYXJzZWREYXRhOiBhbnlcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHNpZGVuYXZTZXJ2aWNlOiBTaWRlbmF2U2VydmljZSxcclxuICAgIHB1YmxpYyBpMThuOiBDb3JlSTE4blNlcnZpY2UsXHJcbiAgICBwdWJsaWMgY29yZVNlcnZpY2U6IENvcmVTZXJ2aWNlXHJcbiAgKSB7XHJcbiAgICB0aGlzLnBhcnNlZERhdGEgPSBKU09OLnN0cmluZ2lmeSh0aGlzLmNvcmVTZXJ2aWNlLmFjdGl2aXRpZXMpXHJcbiAgfVxyXG5cclxuICBkb3dubG9hZEZpbGUoZXZlbnQ6IGFueSkge1xyXG4gICAgY29uc29sZS5sb2coZXZlbnQuZGV0YWlsLnZhbHVlKVxyXG4gICAgY29uc3QgcGxhY2Vob2xkZXIgPSBldmVudC50YXJnZXQubmV4dEVsZW1lbnRTaWJsaW5nO1xyXG4gICAgdGhpcy5jb3JlU2VydmljZS5sb2FkRmlsZShldmVudC5kZXRhaWwudmFsdWUuaWQpLnRoZW4oKHJlc3BvbnNlT2JqZWN0OiB7IGJvZHk6IGFueTsgfSkgPT4ge1xyXG4gICAgICBjb25zdCBmaWxlSW5mb3JtYXRpb24gPSByZXNwb25zZU9iamVjdC5ib2R5O1xyXG4gICAgICBjb25zdCBmaWxlQmxvYiA9IHRoaXMuY29yZVNlcnZpY2UuZGF0YVVSSXRvQmxvYihmaWxlSW5mb3JtYXRpb24uZmlsZUNvbnRlbnRzKTtcclxuICAgICAgY29uc3QgZmlsZSA9IG5ldyBGaWxlKFtmaWxlQmxvYl0sIGZpbGVJbmZvcm1hdGlvbi5maWxlTmFtZSwge3R5cGU6IGZpbGVJbmZvcm1hdGlvbi5taW1lVHlwZX0pO1xyXG4gICAgICBwbGFjZWhvbGRlci5ocmVmID0gVVJMLmNyZWF0ZU9iamVjdFVSTChmaWxlKTtcclxuICAgICAgcGxhY2Vob2xkZXIuZG93bmxvYWQgPSBmaWxlLm5hbWU7XHJcbiAgICAgIHBsYWNlaG9sZGVyLmNsaWNrKCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG5cclxuICBjbG9zZVNpZGVuYXYoKSB7XHJcbiAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnB1Ymxpc2goJ2Nsb3NlJywgbnVsbCk7XHJcbiAgfVxyXG59XHJcbiIsIjxzZWN0aW9uIGNsYXNzPVwibWFpbi1zaWRlbmF2XCI+XHJcbiAgPGRpdiBjbGFzcz1cInNpZGVuYXYtdGl0bGVcIj5cclxuICAgIDxoMz57eyBpMThuLnRyYW5zbGF0ZSgnY29tbWVudEhpc3RvcnknKSB9fTwvaDM+XHJcblxyXG4gICAgPGRzLWJ1dHRvbiAoY2xpY2spPVwiY2xvc2VTaWRlbmF2KClcIiBpY29uPlxyXG4gICAgICA8ZHMtaWNvbiBpY29uPVwiY2xvc2VcIiBjbGFzcz1cImZzLTIwIGZjLWJsYWNrXCI+PC9kcy1pY29uPlxyXG4gICAgPC9kcy1idXR0b24+XHJcblxyXG4gIDwvZGl2PlxyXG4gIDxkaXYgY2xhc3M9XCJzaWRlbmF2LWJvZHlcIj5cclxuICAgIEBpZiAoY29yZVNlcnZpY2UuYWN0aXZpdGllcykge1xyXG4gICAgICA8ZHMtYWN0aXZpdHktbG9nIGFjdGl2aXRpZXNEYXRhPVwie3twYXJzZWREYXRhfX1cIiByZWFkT25seSAoZG93bmxvYWRFdmVudCk9XCJkb3dubG9hZEZpbGUoJGV2ZW50KVwiPlxyXG4gICAgICA8L2RzLWFjdGl2aXR5LWxvZz5cclxuICAgIH0gQGVsc2Uge1xyXG4gICAgICA8ZHMtbWVzc2FnZSAqbmdJZj1cIiFjb3JlU2VydmljZS5hY3Rpdml0aWVzXCIgbGFiZWw9XCJ7e2kxOG4udHJhbnNsYXRlKCdOb0RhdGExJyl9fVwiPjwvZHMtbWVzc2FnZT5cclxuICAgIH1cclxuICA8L2Rpdj5cclxuPC9zZWN0aW9uPlxyXG4iXX0=
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
2
|
+
import { NgIf } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../../services";
|
|
5
|
+
export class ApprovalsComponent {
|
|
6
|
+
sidenavService;
|
|
7
|
+
i18n;
|
|
8
|
+
coreService;
|
|
9
|
+
constructor(sidenavService, i18n, coreService) {
|
|
10
|
+
this.sidenavService = sidenavService;
|
|
11
|
+
this.i18n = i18n;
|
|
12
|
+
this.coreService = coreService;
|
|
13
|
+
}
|
|
14
|
+
closeSidenav() {
|
|
15
|
+
this.sidenavService.publish('close', null);
|
|
16
|
+
}
|
|
17
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ApprovalsComponent, deps: [{ token: i1.SidenavService }, { token: i1.CoreI18nService }, { token: i1.CoreService }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: ApprovalsComponent, isStandalone: true, selector: "app-approvals", ngImport: i0, template: "<section class=\"main-sidenav\">\r\n\r\n <div class=\"sidenav-title\">\r\n <h3>{{ i18n.translate('approvalcycle') }}</h3>\r\n\r\n <ds-button (click)=\"closeSidenav()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n\r\n </div>\r\n <div class=\"sidenav-body p-4\">\r\n <ds-approvals *ngIf=\"coreService.approvals\" approvalsData=\"{{coreService.approvals}}\"></ds-approvals>\r\n <ds-message *ngIf=\"!coreService.approvals\" label=\"{{i18n.translate('NoData2')}}\"></ds-message>\r\n </div>\r\n</section>\r\n", styles: [""], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ApprovalsComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{ selector: 'app-approvals', standalone: true, schemas: [CUSTOM_ELEMENTS_SCHEMA], imports: [
|
|
23
|
+
NgIf
|
|
24
|
+
], template: "<section class=\"main-sidenav\">\r\n\r\n <div class=\"sidenav-title\">\r\n <h3>{{ i18n.translate('approvalcycle') }}</h3>\r\n\r\n <ds-button (click)=\"closeSidenav()\" icon>\r\n <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n </ds-button>\r\n\r\n </div>\r\n <div class=\"sidenav-body p-4\">\r\n <ds-approvals *ngIf=\"coreService.approvals\" approvalsData=\"{{coreService.approvals}}\"></ds-approvals>\r\n <ds-message *ngIf=\"!coreService.approvals\" label=\"{{i18n.translate('NoData2')}}\"></ds-message>\r\n </div>\r\n</section>\r\n" }]
|
|
25
|
+
}], ctorParameters: () => [{ type: i1.SidenavService }, { type: i1.CoreI18nService }, { type: i1.CoreService }] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwcm92YWxzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JwbS1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9hcHAtY29tcG9uZW50LXNlY3Rpb25zL2FwcHJvdmFscy9hcHByb3ZhbHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL2FwcC1jb21wb25lbnQtc2VjdGlvbnMvYXBwcm92YWxzL2FwcHJvdmFscy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLHNCQUFzQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWhFLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBWXJDLE1BQU0sT0FBTyxrQkFBa0I7SUFFVDtJQUNEO0lBQ0E7SUFGbkIsWUFBb0IsY0FBOEIsRUFDL0IsSUFBcUIsRUFDckIsV0FBd0I7UUFGdkIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQy9CLFNBQUksR0FBSixJQUFJLENBQWlCO1FBQ3JCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO0lBQ3ZDLENBQUM7SUFJTCxZQUFZO1FBQ1YsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzdDLENBQUM7dUdBWFUsa0JBQWtCOzJGQUFsQixrQkFBa0IseUVDZC9CLDhqQkFlQSwwRERKSSxJQUFJOzsyRkFHSyxrQkFBa0I7a0JBVjlCLFNBQVM7K0JBQ0UsZUFBZSxjQUdiLElBQUksV0FDUCxDQUFDLHNCQUFzQixDQUFDLFdBQ3hCO3dCQUNQLElBQUk7cUJBQ0wiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29yZUkxOG5TZXJ2aWNlLCBDb3JlU2VydmljZSwgU2lkZW5hdlNlcnZpY2V9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzJztcclxuaW1wb3J0IHtOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtYXBwcm92YWxzJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXBwcm92YWxzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hcHByb3ZhbHMuY29tcG9uZW50LnNjc3MnXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBOZ0lmXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXBwcm92YWxzQ29tcG9uZW50ICB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2lkZW5hdlNlcnZpY2U6IFNpZGVuYXZTZXJ2aWNlLFxyXG4gICAgICAgICAgICAgIHB1YmxpYyBpMThuOiBDb3JlSTE4blNlcnZpY2UsXHJcbiAgICAgICAgICAgICAgcHVibGljIGNvcmVTZXJ2aWNlOiBDb3JlU2VydmljZVxyXG4gICkgeyB9XHJcblxyXG5cclxuXHJcbiAgY2xvc2VTaWRlbmF2KCkge1xyXG4gICAgdGhpcy5zaWRlbmF2U2VydmljZS5wdWJsaXNoKCdjbG9zZScsIG51bGwpO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPHNlY3Rpb24gY2xhc3M9XCJtYWluLXNpZGVuYXZcIj5cclxuXHJcbiAgPGRpdiBjbGFzcz1cInNpZGVuYXYtdGl0bGVcIj5cclxuICAgIDxoMz57eyBpMThuLnRyYW5zbGF0ZSgnYXBwcm92YWxjeWNsZScpIH19PC9oMz5cclxuXHJcbiAgICA8ZHMtYnV0dG9uIChjbGljayk9XCJjbG9zZVNpZGVuYXYoKVwiIGljb24+XHJcbiAgICAgIDxkcy1pY29uIGljb249XCJjbG9zZVwiIGNsYXNzPVwiZnMtMjAgZmMtYmxhY2tcIj48L2RzLWljb24+XHJcbiAgICA8L2RzLWJ1dHRvbj5cclxuXHJcbiAgPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cInNpZGVuYXYtYm9keSBwLTRcIj5cclxuICAgIDxkcy1hcHByb3ZhbHMgKm5nSWY9XCJjb3JlU2VydmljZS5hcHByb3ZhbHNcIiBhcHByb3ZhbHNEYXRhPVwie3tjb3JlU2VydmljZS5hcHByb3ZhbHN9fVwiPjwvZHMtYXBwcm92YWxzPlxyXG4gICAgPGRzLW1lc3NhZ2UgKm5nSWY9XCIhY29yZVNlcnZpY2UuYXBwcm92YWxzXCIgbGFiZWw9XCJ7e2kxOG4udHJhbnNsYXRlKCdOb0RhdGEyJyl9fVwiPjwvZHMtbWVzc2FnZT5cclxuICA8L2Rpdj5cclxuPC9zZWN0aW9uPlxyXG4iXX0=
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
2
|
+
import * as Constants from '../../../constants/constants';
|
|
3
|
+
import { ApprovalsComponent } from '../approvals/approvals.component';
|
|
4
|
+
import { SatPopoverModule } from "@ncstate/sat-popover";
|
|
5
|
+
import { NgIf } from "@angular/common";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../../services";
|
|
8
|
+
import * as i2 from "ngx-toastr";
|
|
9
|
+
export class ApprovalsWorkflowComponent {
|
|
10
|
+
i18n;
|
|
11
|
+
sidenavService;
|
|
12
|
+
coreService;
|
|
13
|
+
toasterService;
|
|
14
|
+
section;
|
|
15
|
+
form;
|
|
16
|
+
approvals = [];
|
|
17
|
+
loading = false;
|
|
18
|
+
constructor(i18n, sidenavService, coreService, toasterService) {
|
|
19
|
+
this.i18n = i18n;
|
|
20
|
+
this.sidenavService = sidenavService;
|
|
21
|
+
this.coreService = coreService;
|
|
22
|
+
this.toasterService = toasterService;
|
|
23
|
+
}
|
|
24
|
+
getApproves() {
|
|
25
|
+
if (!this.loading) {
|
|
26
|
+
this.approvals = [];
|
|
27
|
+
this.loading = true;
|
|
28
|
+
this.coreService.prespectiveApprovers(this.section.body.details).subscribe((response) => {
|
|
29
|
+
this.loading = false;
|
|
30
|
+
if (response) {
|
|
31
|
+
const resultData = [];
|
|
32
|
+
for (let index = 0; index < response['approvals'].length; index++) {
|
|
33
|
+
const element = response['approvals'][index];
|
|
34
|
+
const stageDetails = this.form.sections.find((stage) => {
|
|
35
|
+
return stage.id == ((element?.role)?.toLowerCase() + 'Approval');
|
|
36
|
+
});
|
|
37
|
+
const obj = {
|
|
38
|
+
id: 1,
|
|
39
|
+
name: element.value,
|
|
40
|
+
// title: element.role ? this.i18n.translate((element?.role).toLowerCase() + 'Role') : '',
|
|
41
|
+
title: element.key,
|
|
42
|
+
image: '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + element.key,
|
|
43
|
+
status: stageDetails ? this.statusClass(stageDetails.header.status) : '',
|
|
44
|
+
statusLabel: stageDetails ? this.statusClass(stageDetails.header.status) : ''
|
|
45
|
+
// status: '',
|
|
46
|
+
// statusLabel: ''
|
|
47
|
+
};
|
|
48
|
+
resultData.push(obj);
|
|
49
|
+
}
|
|
50
|
+
this.approvals = resultData;
|
|
51
|
+
this.showProspectiveApprovals();
|
|
52
|
+
}
|
|
53
|
+
}, (err) => {
|
|
54
|
+
this.loading = false;
|
|
55
|
+
err?.error?.meta?.messages?.forEach((msg) => {
|
|
56
|
+
this.toasterService.error(msg.message);
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
statusClass(status) {
|
|
62
|
+
if (!status) {
|
|
63
|
+
return 'success';
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
if (status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED
|
|
67
|
+
|| status?.toLowerCase().includes('deny')
|
|
68
|
+
|| status?.toLowerCase().includes('reject')
|
|
69
|
+
|| status?.toLowerCase() === 'reject' || status?.toLowerCase() === 'unsatisfied' || status?.toLowerCase() === 'cancel') {
|
|
70
|
+
return 'danger';
|
|
71
|
+
}
|
|
72
|
+
else if (status === Constants.FORM_STATUS_PENDING || status?.toLowerCase() === 'pending') {
|
|
73
|
+
return 'warning';
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
return 'success';
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
showProspectiveApprovals() {
|
|
81
|
+
this.coreService.approvals = JSON.stringify(this.approvals);
|
|
82
|
+
this.sidenavService.publish('open', ApprovalsComponent);
|
|
83
|
+
}
|
|
84
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ApprovalsWorkflowComponent, deps: [{ token: i1.CoreI18nService }, { token: i1.SidenavService }, { token: i1.CoreService }, { token: i2.ToastrService }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ApprovalsWorkflowComponent, isStandalone: true, selector: "lib-approvals-workflow", inputs: { section: "section", form: "form" }, ngImport: i0, template: "<ds-button\r\n color=\"white\" shape=\"text\" square size=\"small\"\r\n (click)=\"getApproves()\">\r\n <slot name=\"prefix\">\r\n @if (loading) {\r\n <ds-icon class=\"sfi sfi-spinner d-inline-block spin fc-coral fs-30-imp\"></ds-icon>\r\n } @else {\r\n <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n }\r\n </slot>\r\n</ds-button>\r\n", styles: ["::ng-deep .sat-popover-container.sat-popover-before .default-popover:before{display:none}\n"], dependencies: [{ kind: "ngmodule", type: SatPopoverModule }] });
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ApprovalsWorkflowComponent, decorators: [{
|
|
88
|
+
type: Component,
|
|
89
|
+
args: [{ selector: 'lib-approvals-workflow', standalone: true, imports: [
|
|
90
|
+
SatPopoverModule,
|
|
91
|
+
NgIf
|
|
92
|
+
], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<ds-button\r\n color=\"white\" shape=\"text\" square size=\"small\"\r\n (click)=\"getApproves()\">\r\n <slot name=\"prefix\">\r\n @if (loading) {\r\n <ds-icon class=\"sfi sfi-spinner d-inline-block spin fc-coral fs-30-imp\"></ds-icon>\r\n } @else {\r\n <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n }\r\n </slot>\r\n</ds-button>\r\n", styles: ["::ng-deep .sat-popover-container.sat-popover-before .default-popover:before{display:none}\n"] }]
|
|
93
|
+
}], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i1.SidenavService }, { type: i1.CoreService }, { type: i2.ToastrService }], propDecorators: { section: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], form: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"approvals-workflow.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, Input} from '@angular/core';\r\nimport * as Constants from '../../../constants/constants';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {Form, Section} from '../../../interfaces';\r\nimport {ApprovalsComponent} from '../approvals/approvals.component';\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport {SatPopoverModule} from \"@ncstate/sat-popover\";\r\nimport {NgIf} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'lib-approvals-workflow',\r\n  templateUrl: './approvals-workflow.component.html',\r\n  styleUrls: ['./approvals-workflow.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    SatPopoverModule,\r\n    NgIf\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class ApprovalsWorkflowComponent {\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  approvals: unknown[] = [];\r\n  loading = false;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private sidenavService: SidenavService,\r\n    private coreService: CoreService,\r\n    private toasterService: ToastrService\r\n  ) { }\r\n\r\n  getApproves() {\r\n    if (!this.loading) {\r\n      this.approvals = [];\r\n      this.loading = true;\r\n      this.coreService.prespectiveApprovers(this.section.body.details).subscribe(\r\n        (response: any) => {\r\n          this.loading = false;\r\n          if (response) {\r\n            const resultData = [];\r\n            for (let index = 0; index < response['approvals'].length; index++) {\r\n              const element = response['approvals'][index];\r\n              const stageDetails = this.form.sections.find((stage) => {\r\n                return stage.id == ((element?.role)?.toLowerCase() + 'Approval');\r\n              });\r\n              const obj = {\r\n                id: 1,\r\n                name: element.value,\r\n                // title: element.role ? this.i18n.translate((element?.role).toLowerCase() + 'Role') : '',\r\n                title: element.key,\r\n                image: '/group/i-gate/wm-bpm/forms/-/proxy/portrait?email=' + element.key,\r\n                status: stageDetails ? this.statusClass(stageDetails.header.status) : '',\r\n                statusLabel: stageDetails ? this.statusClass(stageDetails.header.status) : ''\r\n                // status: '',\r\n                // statusLabel: ''\r\n              };\r\n              resultData.push(obj);\r\n            }\r\n            this.approvals = resultData;\r\n            this.showProspectiveApprovals();\r\n          }\r\n        },\r\n        (err: any) => {\r\n          this.loading = false;\r\n          err?.error?.meta?.messages?.forEach((msg) => {\r\n            this.toasterService.error(msg.message);\r\n          });\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (!status) {\r\n      return 'success';\r\n    } else {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status?.toLowerCase().includes('deny')\r\n        || status?.toLowerCase().includes('reject')\r\n        || status?.toLowerCase() === 'reject' || status?.toLowerCase() === 'unsatisfied' || status?.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status?.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    }\r\n  }\r\n\r\n  showProspectiveApprovals() {\r\n    this.coreService.approvals = JSON.stringify(this.approvals);\r\n    this.sidenavService.publish('open', ApprovalsComponent);\r\n  }\r\n\r\n}\r\n","<ds-button\r\n  color=\"white\" shape=\"text\" square size=\"small\"\r\n  (click)=\"getApproves()\">\r\n  <slot name=\"prefix\">\r\n    @if (loading) {\r\n      <ds-icon class=\"sfi sfi-spinner d-inline-block spin fc-coral fs-30-imp\"></ds-icon>\r\n    } @else {\r\n      <ds-icon icon=\"workflow\" class=\"fs-24\"></ds-icon>\r\n    }\r\n  </slot>\r\n</ds-button>\r\n"]}
|
package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs
CHANGED
|
@@ -63,8 +63,9 @@ export class FormSectionComponent {
|
|
|
63
63
|
isReadOnly: this.isReadOnly,
|
|
64
64
|
lov: this.lov,
|
|
65
65
|
section: this.section,
|
|
66
|
-
controllers: this.controllers,
|
|
67
|
-
requestDetails: this.requestDetails
|
|
66
|
+
// controllers: this.controllers,
|
|
67
|
+
// requestDetails: this.requestDetails,
|
|
68
|
+
form: this.form
|
|
68
69
|
};
|
|
69
70
|
if (this.section.header && this.section.header.processingDate) {
|
|
70
71
|
this.processingDate = moment(this.section.header.processingDate)
|
|
@@ -77,49 +78,12 @@ export class FormSectionComponent {
|
|
|
77
78
|
this.sectionNumber = x.length;
|
|
78
79
|
}
|
|
79
80
|
}
|
|
80
|
-
/* ngOnChanges() {
|
|
81
|
-
if (
|
|
82
|
-
this.section.id !== 'requestDetails' &&
|
|
83
|
-
this.section.id !== 'hrRequestDetails' &&
|
|
84
|
-
!this.sectionStatusKey &&
|
|
85
|
-
this.section.body.details.decision &&
|
|
86
|
-
this.section.body.details.decision.key
|
|
87
|
-
) {
|
|
88
|
-
this.sectionStatusKey = this.section.body.details.decision.key;
|
|
89
|
-
}
|
|
90
|
-
if (
|
|
91
|
-
this.section.id !== 'requestDetails' &&
|
|
92
|
-
this.section.id !== 'hrRequestDetails' &&
|
|
93
|
-
!this.sectionStatusValue &&
|
|
94
|
-
this.section.body.details.decision &&
|
|
95
|
-
this.section.body.details.decision.value
|
|
96
|
-
) {
|
|
97
|
-
this.sectionStatusValue = this.section.body.details.decision.value;
|
|
98
|
-
}
|
|
99
|
-
}*/
|
|
100
|
-
/* ngAfterViewInit() {
|
|
101
|
-
this.ServicesSubScriptions();
|
|
102
|
-
}*/
|
|
103
81
|
get isExpanded() {
|
|
104
82
|
const isExpandableFromBackend = this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);
|
|
105
83
|
if (!isExpandableFromBackend)
|
|
106
84
|
return true;
|
|
107
85
|
return this.section?.body?.details?.expandStage === 'true';
|
|
108
86
|
}
|
|
109
|
-
/* public ServicesSubScriptions() {
|
|
110
|
-
/!* this.profileRequestorService.getForm().subscribe((data) => {
|
|
111
|
-
this.form = data;
|
|
112
|
-
});*!/
|
|
113
|
-
}*/
|
|
114
|
-
ngAfterViewChecked() {
|
|
115
|
-
this.input = {
|
|
116
|
-
isReadOnly: this.isReadOnly,
|
|
117
|
-
lov: this.lov,
|
|
118
|
-
section: this.section,
|
|
119
|
-
controllers: this.controllers,
|
|
120
|
-
sectionId: this.section
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
87
|
sectionId() {
|
|
124
88
|
return this.section.id.split(' ').join('') + this.randomID;
|
|
125
89
|
}
|
|
@@ -218,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
218
182
|
}], sectionName: [{
|
|
219
183
|
type: Input
|
|
220
184
|
}] } });
|
|
221
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewChecked, AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, Input, OnInit, ViewChild} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport * as moment from 'moment'\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit, AfterViewChecked {\r\n  userType = 'recipient';\r\n  // @ViewChild('popover') popover?: any;\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  // @Input() isOpen: boolean;\r\n  // @Input() isFinalApproval: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionNumber: number;\r\n  sectionStatusValue: string;\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  // highlightFlag: boolean;\r\n\r\n  processingDate: string;\r\n  public randomID: number =\r\n    Math.floor(Math.random() * (999999 - 100000)) + 100000;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n    // this.highlightFlag = false;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n    if (this.section.body.details.stageName) {\r\n      this.sectionName = this.section.body.details.stageName;\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      controllers: this.controllers,\r\n      requestDetails: this.requestDetails\r\n    };\r\n    if (this.section.header && this.section.header.processingDate) {\r\n      this.processingDate = moment(this.section.header.processingDate)\r\n        .locale('en-US')\r\n        .format('DD/MM/YYYY HH:mm:ss');\r\n    }\r\n\r\n    // this.highlightFlag = this.isOpen;\r\n    const x = document.querySelectorAll('#collapse' + this.sectionId());\r\n    if (x.length > 0) {\r\n      this.sectionNumber = x.length;\r\n    }\r\n  }\r\n\r\n  /*  ngOnChanges() {\r\n      if (\r\n        this.section.id !== 'requestDetails' &&\r\n        this.section.id !== 'hrRequestDetails' &&\r\n        !this.sectionStatusKey &&\r\n        this.section.body.details.decision &&\r\n        this.section.body.details.decision.key\r\n      ) {\r\n        this.sectionStatusKey = this.section.body.details.decision.key;\r\n      }\r\n      if (\r\n        this.section.id !== 'requestDetails' &&\r\n        this.section.id !== 'hrRequestDetails' &&\r\n        !this.sectionStatusValue &&\r\n        this.section.body.details.decision &&\r\n        this.section.body.details.decision.value\r\n      ) {\r\n        this.sectionStatusValue = this.section.body.details.decision.value;\r\n      }\r\n    }*/\r\n\r\n  /* ngAfterViewInit() {\r\n     this.ServicesSubScriptions();\r\n   }*/\r\n\r\n  get isExpanded(): boolean {\r\n    const isExpandableFromBackend = this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);\r\n    if (!isExpandableFromBackend) return true;\r\n    return this.section?.body?.details?.expandStage === 'true';\r\n  }\r\n\r\n  /* public ServicesSubScriptions() {\r\n     /!*  this.profileRequestorService.getForm().subscribe((data) => {\r\n         this.form = data;\r\n       });*!/\r\n   }*/\r\n\r\n  ngAfterViewChecked() {\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      controllers: this.controllers,\r\n      sectionId: this.section\r\n    };\r\n  }\r\n\r\n  sectionId() {\r\n    return this.section.id.split(' ').join('') + this.randomID;\r\n  }\r\n\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      response?.[\"Users\"][0]?.employeeNumber,\r\n      response?.[\"Users\"][0]?.email,\r\n      response?.[\"Users\"][0]?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.name,\r\n      response?.[\"Users\"][0]?.position?.name,\r\n      response?.[\"Users\"][0]?.sector?.name,\r\n      response?.[\"Users\"][0]?.department?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.code,\r\n      response?.[\"Users\"][0]?.location,\r\n      response?.[\"Users\"][0]?.nationality?.desc,\r\n      response?.[\"Users\"][0]?.contact?.mobile,\r\n      response?.[\"Users\"][0]?.manager?.name,\r\n      response?.[\"Users\"][0]?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  toggleSmallProfileInfo(event, personType) {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (userInfo.profile === null) {\r\n      this.popoverType = personType;\r\n      let userEmail = (personType === 'recipient' ? this.section.header.personToThumbnail.split('=')[1] : this?.section?.header?.delegatedToThumbnail.split('=')[1]);\r\n      this.coreService.employeeProfile(userEmail).subscribe((response: any) => {\r\n        if (response) {\r\n          let userData = this.createUserProfileFromResponse(response);\r\n          this.openOrCreateUserProfile(userData, personType);\r\n        }\r\n      });\r\n    } else {\r\n      this.openOrCreateUserProfile(this[personType].profile, personType);\r\n    }\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    } else {\r\n      return 'success';\r\n    }\r\n  }\r\n\r\n  statusIcon(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'close';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'clock';\r\n      } else {\r\n        return 'check';\r\n      }\r\n    } else {\r\n      return 'check';\r\n    }\r\n  }\r\n}\r\n","<mat-expansion-panel\r\n  class=\"mb-4\" [expanded]=\"isExpanded\" *ngIf=\"form?.header?.status?.['key'] !== 'NEW' \" hideToggle\r\n  #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\" *ngIf=\"section.header?.processedBy\">\r\n            {{ processingDate }}\r\n          </bdi>\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n\r\n        <ng-container *ngIf=\"(!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false')\">\r\n          <div\r\n            class=\"d-flex align-items-center gap-3\" *ngIf=\"section?.header?.personTo;\"\r\n            (click)=\"$event.stopImmediatePropagation();\">\r\n            <div\r\n              (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n              class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n              [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n              <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n              <span\r\n                class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\" [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                *ngIf=\"!section?.header?.delegatedTo\">{{ section?.header?.personTo }}</span>\r\n            </div>\r\n\r\n            <div\r\n              *ngIf=\"section?.header?.delegatedTo\" class=\"d-flex align-items-center gap-3\"\r\n              (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n              <img\r\n                class=\"rotate-arrow\"\r\n                alt=\"\"\r\n                src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n              <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                <span\r\n                  class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n              </div>\r\n\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n        <ds-status\r\n          class=\"main-status\" *ngIf=\"section?.body?.details?.['decision']?.key;\"\r\n          status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n        </ds-status>\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\" *ngIf=\"!approvalPanel.expanded\"></ds-icon>\r\n        <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\" *ngIf=\"approvalPanel.expanded\"></ds-icon>\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container  *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n<ng-container *ngIf=\"form?.header?.status?.['key'] == 'NEW' \">\r\n  <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n</ng-container>\r\n"]}
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewChecked, AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, Input, OnInit, ViewChild} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport * as moment from 'moment'\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit {\r\n  userType = 'recipient';\r\n  // @ViewChild('popover') popover?: any;\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  // @Input() isOpen: boolean;\r\n  // @Input() isFinalApproval: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionNumber: number;\r\n  sectionStatusValue: string;\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  // highlightFlag: boolean;\r\n\r\n  processingDate: string;\r\n  public randomID: number =\r\n    Math.floor(Math.random() * (999999 - 100000)) + 100000;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n    // this.highlightFlag = false;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n    if (this.section.body.details.stageName) {\r\n      this.sectionName = this.section.body.details.stageName;\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      // controllers: this.controllers,\r\n      // requestDetails: this.requestDetails,\r\n      form:this.form\r\n    };\r\n    if (this.section.header && this.section.header.processingDate) {\r\n      this.processingDate = moment(this.section.header.processingDate)\r\n        .locale('en-US')\r\n        .format('DD/MM/YYYY HH:mm:ss');\r\n    }\r\n\r\n    // this.highlightFlag = this.isOpen;\r\n    const x = document.querySelectorAll('#collapse' + this.sectionId());\r\n    if (x.length > 0) {\r\n      this.sectionNumber = x.length;\r\n    }\r\n  }\r\n\r\n\r\n  get isExpanded(): boolean {\r\n    const isExpandableFromBackend = this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);\r\n    if (!isExpandableFromBackend) return true;\r\n    return this.section?.body?.details?.expandStage === 'true';\r\n  }\r\n\r\n  sectionId() {\r\n    return this.section.id.split(' ').join('') + this.randomID;\r\n  }\r\n\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      response?.[\"Users\"][0]?.employeeNumber,\r\n      response?.[\"Users\"][0]?.email,\r\n      response?.[\"Users\"][0]?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.name,\r\n      response?.[\"Users\"][0]?.position?.name,\r\n      response?.[\"Users\"][0]?.sector?.name,\r\n      response?.[\"Users\"][0]?.department?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.code,\r\n      response?.[\"Users\"][0]?.location,\r\n      response?.[\"Users\"][0]?.nationality?.desc,\r\n      response?.[\"Users\"][0]?.contact?.mobile,\r\n      response?.[\"Users\"][0]?.manager?.name,\r\n      response?.[\"Users\"][0]?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  toggleSmallProfileInfo(event, personType) {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (userInfo.profile === null) {\r\n      this.popoverType = personType;\r\n      let userEmail = (personType === 'recipient' ? this.section.header.personToThumbnail.split('=')[1] : this?.section?.header?.delegatedToThumbnail.split('=')[1]);\r\n      this.coreService.employeeProfile(userEmail).subscribe((response: any) => {\r\n        if (response) {\r\n          let userData = this.createUserProfileFromResponse(response);\r\n          this.openOrCreateUserProfile(userData, personType);\r\n        }\r\n      });\r\n    } else {\r\n      this.openOrCreateUserProfile(this[personType].profile, personType);\r\n    }\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    } else {\r\n      return 'success';\r\n    }\r\n  }\r\n\r\n  statusIcon(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'close';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'clock';\r\n      } else {\r\n        return 'check';\r\n      }\r\n    } else {\r\n      return 'check';\r\n    }\r\n  }\r\n}\r\n","<mat-expansion-panel\r\n  class=\"mb-4\" [expanded]=\"isExpanded\" *ngIf=\"form?.header?.status?.['key'] !== 'NEW' \" hideToggle\r\n  #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\" *ngIf=\"section.header?.processedBy\">\r\n            {{ processingDate }}\r\n          </bdi>\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n\r\n        <ng-container *ngIf=\"(!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false')\">\r\n          <div\r\n            class=\"d-flex align-items-center gap-3\" *ngIf=\"section?.header?.personTo;\"\r\n            (click)=\"$event.stopImmediatePropagation();\">\r\n            <div\r\n              (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n              class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n              [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n              <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n              <span\r\n                class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\" [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                *ngIf=\"!section?.header?.delegatedTo\">{{ section?.header?.personTo }}</span>\r\n            </div>\r\n\r\n            <div\r\n              *ngIf=\"section?.header?.delegatedTo\" class=\"d-flex align-items-center gap-3\"\r\n              (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n              <img\r\n                class=\"rotate-arrow\"\r\n                alt=\"\"\r\n                src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n              <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                <span\r\n                  class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n              </div>\r\n\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n        <ds-status\r\n          class=\"main-status\" *ngIf=\"section?.body?.details?.['decision']?.key;\"\r\n          status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n        </ds-status>\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\" *ngIf=\"!approvalPanel.expanded\"></ds-icon>\r\n        <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\" *ngIf=\"approvalPanel.expanded\"></ds-icon>\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container  *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n<ng-container *ngIf=\"form?.header?.status?.['key'] == 'NEW' \">\r\n  <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n</ng-container>\r\n"]}
|