vcomply-workflow-engine 6.0.47 → 6.0.49
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/constants/mock.mjs +130 -0
- package/esm2022/lib/interfaces/frequency.interface.mjs +2 -0
- package/esm2022/lib/interfaces/responsibilty.interface.mjs +1 -1
- package/esm2022/lib/more-option/more-option.component.mjs +3 -46
- package/esm2022/lib/sharedComponents/category-list-selection/category-list-selection/category-list-selection.component.mjs +3 -3
- package/esm2022/lib/sharedComponents/document-section/document-section.component.mjs +9 -40
- package/esm2022/lib/sharedComponents/frequency/frequency-annual/frequency-annual.component.mjs +5 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +5 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +2 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +6 -2
- package/esm2022/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +2 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +3 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +5 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +3 -1
- package/esm2022/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +4 -2
- package/esm2022/lib/sharedComponents/frequency/frequency.service.mjs +185 -1
- package/esm2022/lib/sharedComponents/list-container/list-container.component.mjs +52 -0
- package/esm2022/lib/sharedComponents/policy-template/policy-template.module.mjs +5 -5
- package/esm2022/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.mjs +33 -31
- package/esm2022/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.mjs +3 -9
- package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.mjs +93 -0
- package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy.module.mjs +19 -0
- package/esm2022/lib/sharedComponents/program-list/constant.mjs +10 -0
- package/esm2022/lib/sharedComponents/program-list/interfaces/data-source.interface.mjs +2 -0
- package/esm2022/lib/sharedComponents/program-list/interfaces/list-item.interface.mjs +2 -0
- package/esm2022/lib/sharedComponents/program-list/interfaces/selection-predicate.interface.mjs +2 -0
- package/esm2022/lib/sharedComponents/program-list/program-list/program-list.component.mjs +162 -0
- package/esm2022/lib/sharedComponents/program-list/program-list.module.mjs +40 -0
- package/esm2022/lib/sharedComponents/program-list/services/list-utils.service.mjs +27 -0
- package/esm2022/lib/sharedComponents/program-list/services/program-list-api.service.mjs +32 -0
- package/esm2022/lib/workflow-compliance/workflow-compliance.component.mjs +303 -153
- package/esm2022/lib/workflow-engine-container/workflow-engine-container.component.mjs +5 -13
- package/esm2022/lib/workflow-engine.module.mjs +13 -6
- package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +3 -3
- package/esm2022/lib/workflow-program/workflow-program.component.mjs +83 -240
- package/esm2022/lib/workflow-services/programs.service.mjs +28 -112
- package/esm2022/lib/workflow-services/responsibility.service.mjs +9 -9
- package/fesm2022/vcomply-workflow-engine.mjs +1222 -710
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/constants/mock.d.ts +15 -0
- package/lib/interfaces/frequency.interface.d.ts +37 -0
- package/lib/interfaces/responsibilty.interface.d.ts +1 -1
- package/lib/sharedComponents/document-section/document-section.component.d.ts +2 -10
- package/lib/sharedComponents/frequency/frequency.service.d.ts +30 -0
- package/lib/sharedComponents/list-container/list-container.component.d.ts +9 -0
- package/lib/sharedComponents/policy-template/policy-template.module.d.ts +2 -2
- package/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.d.ts +5 -7
- package/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.d.ts +3 -6
- package/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.d.ts +25 -0
- package/lib/sharedComponents/policy-template/view-policy/view-policy.module.d.ts +9 -0
- package/lib/sharedComponents/program-list/constant.d.ts +5 -0
- package/lib/sharedComponents/program-list/interfaces/data-source.interface.d.ts +4 -0
- package/lib/sharedComponents/program-list/interfaces/list-item.interface.d.ts +5 -0
- package/lib/sharedComponents/program-list/interfaces/selection-predicate.interface.d.ts +3 -0
- package/lib/sharedComponents/program-list/program-list/program-list.component.d.ts +42 -0
- package/lib/sharedComponents/program-list/program-list.module.d.ts +12 -0
- package/lib/sharedComponents/program-list/services/list-utils.service.d.ts +7 -0
- package/lib/sharedComponents/program-list/services/program-list-api.service.d.ts +14 -0
- package/lib/workflow-compliance/workflow-compliance.component.d.ts +33 -5
- package/lib/workflow-engine-container/workflow-engine-container.component.d.ts +2 -3
- package/lib/workflow-engine.module.d.ts +42 -40
- package/lib/workflow-program/workflow-program.component.d.ts +6 -4
- package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
- package/lib/workflow-services/programs.service.d.ts +13 -53
- package/package.json +1 -1
- package/esm2022/lib/workflow-policy/ms-word.constants.mjs +0 -21
- package/esm2022/lib/workflow-services/policy-api.service.mjs +0 -38
- package/lib/workflow-policy/ms-word.constants.d.ts +0 -20
- package/lib/workflow-services/policy-api.service.d.ts +0 -27
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { Component, Input, Optional, ViewChild, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../../../configurations";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@syncfusion/ej2-angular-documenteditor";
|
|
6
|
+
export class ViewPolicyComponent {
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.resizeEditor = false;
|
|
9
|
+
this.serviceUrl = '';
|
|
10
|
+
this.settings = { optimizeSfdt: false };
|
|
11
|
+
this.isContentLoaded = false;
|
|
12
|
+
this.hasComments = false;
|
|
13
|
+
this.palette = [
|
|
14
|
+
'#011f4b',
|
|
15
|
+
'#009688',
|
|
16
|
+
'#ee4035',
|
|
17
|
+
'#f37736',
|
|
18
|
+
'#7bc043',
|
|
19
|
+
'#854442',
|
|
20
|
+
'#ffa700',
|
|
21
|
+
'#d11141',
|
|
22
|
+
'#ff3377',
|
|
23
|
+
'#8d5524',
|
|
24
|
+
];
|
|
25
|
+
this.userName = ''; // current user name
|
|
26
|
+
this.serviceUrl = config?.envConfig?.cpEditor;
|
|
27
|
+
}
|
|
28
|
+
ngOnChanges(changes) {
|
|
29
|
+
if (changes?.contents?.currentValue) {
|
|
30
|
+
this.onCreating();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() { }
|
|
34
|
+
onCreating() {
|
|
35
|
+
this.isContentLoaded = true;
|
|
36
|
+
this.contents = JSON.stringify(JSON.parse(this.contents));
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
if (this.documentEditor?.documentEditor) {
|
|
39
|
+
this.configureEditor();
|
|
40
|
+
}
|
|
41
|
+
}, 100);
|
|
42
|
+
}
|
|
43
|
+
onCreated() {
|
|
44
|
+
if (this.documentEditor &&
|
|
45
|
+
this.documentEditor?.documentEditor &&
|
|
46
|
+
this.documentEditor?.documentEditor?.isDocumentLoaded) {
|
|
47
|
+
this.configureEditor();
|
|
48
|
+
this.documentEditor.documentEditor.height = `${window.innerHeight - 220}px`;
|
|
49
|
+
this.documentEditor.documentEditor.userColor =
|
|
50
|
+
this.palette[Math.floor(Math.random() * this.palette.length)];
|
|
51
|
+
this.resizeEditor = true;
|
|
52
|
+
this.checkComments();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
configureEditor() {
|
|
56
|
+
if (this.documentEditor.documentEditor) {
|
|
57
|
+
this.documentEditor.documentEditor.showRevisions = false;
|
|
58
|
+
this.documentEditor.documentEditor.showComments = false;
|
|
59
|
+
this.documentEditor.documentEditor.resize();
|
|
60
|
+
this.documentEditor.documentEditor.focusIn();
|
|
61
|
+
if (this.contents) {
|
|
62
|
+
this.documentEditor.documentEditor.open(this.contents);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
checkComments() {
|
|
67
|
+
const commentsLength = this.documentEditor?.documentEditor?.documentHelper?.comments?.length ||
|
|
68
|
+
0;
|
|
69
|
+
this.hasComments = commentsLength > 0;
|
|
70
|
+
}
|
|
71
|
+
viewComment() {
|
|
72
|
+
if (this.documentEditor) {
|
|
73
|
+
this.documentEditor.documentEditor.showComments =
|
|
74
|
+
!this.documentEditor.documentEditor.showComments;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyComponent, deps: [{ token: i1.Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ViewPolicyComponent, selector: "app-view-policy", inputs: { contents: "contents", userName: "userName" }, viewQueries: [{ propertyName: "documentEditor", first: true, predicate: ["document_editor"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ejs-documenteditorcontainer\n *ngIf=\"isContentLoaded\"\n (created)=\"onCreated()\"\n #document_editor\n style=\"width: 100%; height: 100%; display: block\"\n [enableToolbar]=\"false\"\n [serviceUrl]=\"serviceUrl\"\n [restrictEditing]=\"true\"\n class=\"e-documenteditor\"\n [documentEditorSettings]=\"settings\"\n>\n</ejs-documenteditorcontainer>\n", styles: ["button.commentBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;color:#1e5dd3;font-size:11px;font-weight:500;text-transform:uppercase;padding:0 .5rem;margin:0;height:1.5rem;display:flex;align-items:center;position:absolute;top:-18px;left:229px;z-index:2}button.commentBtn i{font-size:12px;margin-right:.25rem}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar{background:#fff!important;border-top:1px solid #dbdbdb;box-shadow:0 -3px 6px #1e5dd326!important;padding:0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout{padding-top:0;width:calc(100% - 100px);color:#000;font-size:13px}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout span{border:1px solid transparent}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px!important;align-items:center;display:flex}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label input{font-size:11px;height:16px;background:#fff;border:1px solid #eee;border-radius:2px;color:#000;padding:0;text-align:center}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-pageweb{display:none}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom{height:24px;padding:0 20px;margin:0;white-space:nowrap;border-radius:0;box-shadow:none;background:#fafafa;border:0;color:#000;font-weight:400}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon{position:relative}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon:before{content:\"\";position:absolute;top:8px;right:-16px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #000}::ng-deep .e-dlg-container.e-dlg-center-center{display:none!important}::ng-deep .e-dropdown-popup{background:#fff;position:absolute}::ng-deep .e-dropdown-popup ul{border:none;border-radius:0;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f;box-sizing:border-box;font-size:14px;font-weight:400;list-style-image:none;list-style-position:outside;list-style-type:none;margin:0;min-width:120px;overflow:hidden;padding:8px 0;-webkit-user-select:none;user-select:none;white-space:nowrap}::ng-deep .e-dropdown-popup ul .e-item{cursor:pointer;display:flex;height:36px;line-height:36px;padding:0 16px}::ng-deep .e-dropdown-popup ul .e-item:hover{background-color:#e0e0e0;color:#000000de}::ng-deep .e-dropdown-popup ul .e-item.e-separator{border-bottom-style:solid;border-bottom-width:1px;border-bottom-color:#0000001f;cursor:auto;height:auto;line-height:normal;margin:8px 0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DocumentEditorContainerComponent, selector: "ejs-documenteditorcontainer", inputs: ["autoResizeOnVisibilityChange", "currentUser", "documentEditorSettings", "documentSettings", "enableAutoFocus", "enableComment", "enableCsp", "enableLocalPaste", "enableLockAndEdit", "enablePersistence", "enableRtl", "enableSpellCheck", "enableToolbar", "enableTrackChanges", "headers", "height", "layoutType", "locale", "restrictEditing", "serverActionSettings", "serviceUrl", "showPropertiesPane", "toolbarItems", "userColor", "width", "zIndex"], outputs: ["beforeAcceptRejectChanges", "beforeCommentAction", "beforePaneSwitch", "commentDelete", "contentChange", "contentControl", "created", "customContextMenuBeforeOpen", "customContextMenuSelect", "destroyed", "documentChange", "selectionChange", "serviceFailure", "toolbarClick", "trackChange", "beforeXmlHttpRequestSend"] }] }); }
|
|
79
|
+
}
|
|
80
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyComponent, decorators: [{
|
|
81
|
+
type: Component,
|
|
82
|
+
args: [{ selector: 'app-view-policy', template: "<ejs-documenteditorcontainer\n *ngIf=\"isContentLoaded\"\n (created)=\"onCreated()\"\n #document_editor\n style=\"width: 100%; height: 100%; display: block\"\n [enableToolbar]=\"false\"\n [serviceUrl]=\"serviceUrl\"\n [restrictEditing]=\"true\"\n class=\"e-documenteditor\"\n [documentEditorSettings]=\"settings\"\n>\n</ejs-documenteditorcontainer>\n", styles: ["button.commentBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;color:#1e5dd3;font-size:11px;font-weight:500;text-transform:uppercase;padding:0 .5rem;margin:0;height:1.5rem;display:flex;align-items:center;position:absolute;top:-18px;left:229px;z-index:2}button.commentBtn i{font-size:12px;margin-right:.25rem}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar{background:#fff!important;border-top:1px solid #dbdbdb;box-shadow:0 -3px 6px #1e5dd326!important;padding:0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout{padding-top:0;width:calc(100% - 100px);color:#000;font-size:13px}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout span{border:1px solid transparent}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px!important;align-items:center;display:flex}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label input{font-size:11px;height:16px;background:#fff;border:1px solid #eee;border-radius:2px;color:#000;padding:0;text-align:center}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-pageweb{display:none}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom{height:24px;padding:0 20px;margin:0;white-space:nowrap;border-radius:0;box-shadow:none;background:#fafafa;border:0;color:#000;font-weight:400}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon{position:relative}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon:before{content:\"\";position:absolute;top:8px;right:-16px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #000}::ng-deep .e-dlg-container.e-dlg-center-center{display:none!important}::ng-deep .e-dropdown-popup{background:#fff;position:absolute}::ng-deep .e-dropdown-popup ul{border:none;border-radius:0;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f;box-sizing:border-box;font-size:14px;font-weight:400;list-style-image:none;list-style-position:outside;list-style-type:none;margin:0;min-width:120px;overflow:hidden;padding:8px 0;-webkit-user-select:none;user-select:none;white-space:nowrap}::ng-deep .e-dropdown-popup ul .e-item{cursor:pointer;display:flex;height:36px;line-height:36px;padding:0 16px}::ng-deep .e-dropdown-popup ul .e-item:hover{background-color:#e0e0e0;color:#000000de}::ng-deep .e-dropdown-popup ul .e-item.e-separator{border-bottom-style:solid;border-bottom-width:1px;border-bottom-color:#0000001f;cursor:auto;height:auto;line-height:normal;margin:8px 0;pointer-events:none}\n"] }]
|
|
83
|
+
}], ctorParameters: function () { return [{ type: i1.Configurations, decorators: [{
|
|
84
|
+
type: Optional
|
|
85
|
+
}] }]; }, propDecorators: { contents: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], userName: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], documentEditor: [{
|
|
90
|
+
type: ViewChild,
|
|
91
|
+
args: ['document_editor']
|
|
92
|
+
}] } });
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-policy.component.js","sourceRoot":"","sources":["../../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.ts","../../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport {\n  DocumentEditorContainerComponent,\n  DocumentEditorSettingsModel,\n} from '@syncfusion/ej2-angular-documenteditor';\nimport { Configurations } from '../../../../configurations';\n\n@Component({\n  selector: 'app-view-policy',\n  templateUrl: './view-policy.component.html',\n  styleUrls: ['./view-policy.component.less'],\n})\nexport class ViewPolicyComponent implements OnInit, OnChanges {\n  public resizeEditor: boolean = false;\n  public serviceUrl: string = '';\n  public settings: DocumentEditorSettingsModel = { optimizeSfdt: false };\n  public isContentLoaded: boolean = false;\n  public hasComments: boolean = false;\n\n  private readonly palette = [\n    '#011f4b',\n    '#009688',\n    '#ee4035',\n    '#f37736',\n    '#7bc043',\n    '#854442',\n    '#ffa700',\n    '#d11141',\n    '#ff3377',\n    '#8d5524',\n  ];\n\n  @Input() contents: any;\n\n  @Input() userName: string = ''; // current user name\n\n  @ViewChild('document_editor')\n  public documentEditor!: DocumentEditorContainerComponent;\n\n  constructor(@Optional() config?: Configurations) {\n    this.serviceUrl = config?.envConfig?.cpEditor;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes?.contents?.currentValue) {\n      this.onCreating();\n    }\n  }\n\n  ngOnInit(): void {}\n\n  private onCreating(): void {\n    this.isContentLoaded = true;\n    this.contents = JSON.stringify(JSON.parse(this.contents));\n    setTimeout(() => {\n      if (this.documentEditor?.documentEditor) {\n        this.configureEditor();\n      }\n    }, 100);\n  }\n\n  public onCreated(): void {\n    if (\n      this.documentEditor &&\n      this.documentEditor?.documentEditor &&\n      this.documentEditor?.documentEditor?.isDocumentLoaded\n    ) {\n      this.configureEditor();\n      this.documentEditor.documentEditor.height = `${\n        window.innerHeight - 220\n      }px`;\n      this.documentEditor.documentEditor.userColor =\n        this.palette[Math.floor(Math.random() * this.palette.length)];\n      this.resizeEditor = true;\n      this.checkComments();\n    }\n  }\n\n  public configureEditor(): void {\n    if (this.documentEditor.documentEditor) {\n      this.documentEditor.documentEditor.showRevisions = false;\n      this.documentEditor.documentEditor.showComments = false;\n      this.documentEditor.documentEditor.resize();\n      this.documentEditor.documentEditor.focusIn();\n      if (this.contents) {\n        this.documentEditor.documentEditor.open(this.contents);\n      }\n    }\n  }\n\n  checkComments() {\n    const commentsLength =\n      this.documentEditor?.documentEditor?.documentHelper?.comments?.length ||\n      0;\n    this.hasComments = commentsLength > 0;\n  }\n\n  public viewComment(): void {\n    if (this.documentEditor) {\n      this.documentEditor.documentEditor.showComments =\n        !this.documentEditor.documentEditor.showComments;\n    }\n  }\n}\n","<ejs-documenteditorcontainer\n  *ngIf=\"isContentLoaded\"\n  (created)=\"onCreated()\"\n  #document_editor\n  style=\"width: 100%; height: 100%; display: block\"\n  [enableToolbar]=\"false\"\n  [serviceUrl]=\"serviceUrl\"\n  [restrictEditing]=\"true\"\n  class=\"e-documenteditor\"\n  [documentEditorSettings]=\"settings\"\n>\n</ejs-documenteditorcontainer>\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { ViewPolicyComponent } from "./view-policy/view-policy.component";
|
|
4
|
+
import { DocumentEditorContainerModule } from "@syncfusion/ej2-angular-documenteditor";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class ViewPolicyModule {
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, declarations: [ViewPolicyComponent], imports: [CommonModule, DocumentEditorContainerModule], exports: [ViewPolicyComponent] }); }
|
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, imports: [CommonModule, DocumentEditorContainerModule] }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, decorators: [{
|
|
12
|
+
type: NgModule,
|
|
13
|
+
args: [{
|
|
14
|
+
declarations: [ViewPolicyComponent],
|
|
15
|
+
imports: [CommonModule, DocumentEditorContainerModule],
|
|
16
|
+
exports: [ViewPolicyComponent],
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1wb2xpY3kubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wb2xpY3ktdGVtcGxhdGUvdmlldy1wb2xpY3kvdmlldy1wb2xpY3kubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOztBQU92RixNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsYUFDeEIsWUFBWSxFQUFFLDZCQUE2QixhQUMzQyxtQkFBbUI7Z0hBRWxCLGdCQUFnQixZQUhqQixZQUFZLEVBQUUsNkJBQTZCOzs0RkFHMUMsZ0JBQWdCO2tCQUw1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNuQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsNkJBQTZCLENBQUM7b0JBQ3RELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IFZpZXdQb2xpY3lDb21wb25lbnQgfSBmcm9tIFwiLi92aWV3LXBvbGljeS92aWV3LXBvbGljeS5jb21wb25lbnRcIjtcbmltcG9ydCB7IERvY3VtZW50RWRpdG9yQ29udGFpbmVyTW9kdWxlIH0gZnJvbSBcIkBzeW5jZnVzaW9uL2VqMi1hbmd1bGFyLWRvY3VtZW50ZWRpdG9yXCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1ZpZXdQb2xpY3lDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBEb2N1bWVudEVkaXRvckNvbnRhaW5lck1vZHVsZV0sXG4gIGV4cG9ydHM6IFtWaWV3UG9saWN5Q29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgVmlld1BvbGljeU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// constants.ts
|
|
2
|
+
export const PROGRAM_TABLE_HEADERS = [
|
|
3
|
+
'Program Name',
|
|
4
|
+
'Program Categories'
|
|
5
|
+
];
|
|
6
|
+
export const PAGINATION_OPTIONS = {
|
|
7
|
+
PAGE_SIZE: 30,
|
|
8
|
+
DEFAULT_CURRENT_PAGE: 1
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL3Byb2dyYW0tbGlzdC9jb25zdGFudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxlQUFlO0FBQ2YsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUc7SUFDakMsY0FBYztJQUNkLG9CQUFvQjtDQUNyQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUc7SUFDaEMsU0FBUyxFQUFFLEVBQUU7SUFDYixvQkFBb0IsRUFBRSxDQUFDO0NBQ3hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBjb25zdGFudHMudHNcbmV4cG9ydCBjb25zdCBQUk9HUkFNX1RBQkxFX0hFQURFUlMgPSBbXG4gICAgJ1Byb2dyYW0gTmFtZScsXG4gICAgJ1Byb2dyYW0gQ2F0ZWdvcmllcydcbiAgXTtcbiAgXG4gIGV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX09QVElPTlMgPSB7XG4gICAgUEFHRV9TSVpFOiAzMCxcbiAgICBERUZBVUxUX0NVUlJFTlRfUEFHRTogMVxuICB9OyJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1zb3VyY2UuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wcm9ncmFtLWxpc3QvaW50ZXJmYWNlcy9kYXRhLXNvdXJjZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIGRhdGEtc291cmNlLmludGVyZmFjZS50c1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhdGFTb3VyY2U8VD4ge1xuICBsb2FkKHNlYXJjaFRlcm0/OiBzdHJpbmcpOiBPYnNlcnZhYmxlPFRbXT47XG59Il19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1pdGVtLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3NoYXJlZENvbXBvbmVudHMvcHJvZ3JhbS1saXN0L2ludGVyZmFjZXMvbGlzdC1pdGVtLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbGlzdC1pdGVtLmludGVyZmFjZS50c1xuZXhwb3J0IGludGVyZmFjZSBMaXN0SXRlbSB7XG4gICAgICBpZDogc3RyaW5nO1xuICAgICAgbmFtZTogc3RyaW5nO1xuICAgICAgdHlwZTogXCJyZWd1bGF0aW9uc1wiIHwgXCJzdGFuZGFyZHNcIiB8IFwiaW50ZXJuYWxfY29udHJvbHNcIiB8IFwib3RoZXJzXCI7XG4gICAgICBcbiAgfVxuICAiXX0=
|
package/esm2022/lib/sharedComponents/program-list/interfaces/selection-predicate.interface.mjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLXByZWRpY2F0ZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL3Byb2dyYW0tbGlzdC9pbnRlcmZhY2VzL3NlbGVjdGlvbi1wcmVkaWNhdGUuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBzZWxlY3Rpb24tcHJlZGljYXRlLmludGVyZmFjZS50c1xuZXhwb3J0IGludGVyZmFjZSBTZWxlY3Rpb25QcmVkaWNhdGU8VD4ge1xuICAgIChpdGVtOiBUKTogYm9vbGVhbjtcbiAgfSJdfQ==
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import { PROGRAM_TABLE_HEADERS, PAGINATION_OPTIONS } from '../constant';
|
|
3
|
+
import { MOCK_CATEGORIES } from '../../../constants/mock';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../services/list-utils.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "../../../formgroup/cs-checkbox/cs-checkbox.component";
|
|
9
|
+
import * as i5 from "../../../ui-kit/no-data/no-data.component";
|
|
10
|
+
import * as i6 from "../../../ui-kit/popover/popover.component";
|
|
11
|
+
import * as i7 from "../../../ui-kit/popover/popover.directive";
|
|
12
|
+
export class ProgramListComponent {
|
|
13
|
+
constructor(listUtils) {
|
|
14
|
+
this.listUtils = listUtils;
|
|
15
|
+
this.items = [];
|
|
16
|
+
this.selectedItems = {};
|
|
17
|
+
this.itemSelected = new EventEmitter();
|
|
18
|
+
this.itemDeselected = new EventEmitter();
|
|
19
|
+
this.itemsSelectedChange = new EventEmitter();
|
|
20
|
+
this.tableHeaders = PROGRAM_TABLE_HEADERS;
|
|
21
|
+
this.currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;
|
|
22
|
+
this.pageSize = PAGINATION_OPTIONS.PAGE_SIZE;
|
|
23
|
+
this.totalPages = 0;
|
|
24
|
+
this.searchTerm = '';
|
|
25
|
+
this.paginatedItems = [];
|
|
26
|
+
this.activeProgram = null;
|
|
27
|
+
this.categoryList = [
|
|
28
|
+
{ name: 'Program Details 1' },
|
|
29
|
+
{ name: 'Program Details 2' },
|
|
30
|
+
{ name: 'Program Details 3' },
|
|
31
|
+
{ name: 'Program Details 4' },
|
|
32
|
+
];
|
|
33
|
+
this.programTypeList = [
|
|
34
|
+
{ name: 'Regulations', id: 'regulations' },
|
|
35
|
+
{ name: 'Standards', id: 'standards' },
|
|
36
|
+
{ name: 'Internal Controls', id: 'internal-controls' },
|
|
37
|
+
{ name: 'Others', id: 'others' },
|
|
38
|
+
];
|
|
39
|
+
this.selectedProgramType = [];
|
|
40
|
+
}
|
|
41
|
+
ngOnInit() {
|
|
42
|
+
this.loadData();
|
|
43
|
+
}
|
|
44
|
+
ngOnChanges(changes) {
|
|
45
|
+
if (changes['items'] || changes['selectedItems']) {
|
|
46
|
+
this.paginateItems();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
getProgramList() {
|
|
50
|
+
}
|
|
51
|
+
loadData() {
|
|
52
|
+
if (this.dataSource) {
|
|
53
|
+
this.dataSource.load(this.searchTerm).subscribe(items => {
|
|
54
|
+
this.items = items;
|
|
55
|
+
this.viewCategory(items[0]);
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
this.viewCategory();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
search() {
|
|
63
|
+
this.currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;
|
|
64
|
+
this.loadData();
|
|
65
|
+
}
|
|
66
|
+
selectItem(event, item) {
|
|
67
|
+
if (event) {
|
|
68
|
+
if (!this.selectedItems[this.activeProgram.id]) {
|
|
69
|
+
this.selectedItems[this.activeProgram.id] = [];
|
|
70
|
+
}
|
|
71
|
+
this.selectedItems[this.activeProgram.id].push(item);
|
|
72
|
+
this.itemsSelectedChange.emit(this.selectedItems);
|
|
73
|
+
this.itemSelected.emit(item);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
this.selectedItems = this.selectedItems[this.activeProgram.id].filter((selected) => selected.id !== item.id);
|
|
77
|
+
this.itemsSelectedChange.emit(this.selectedItems);
|
|
78
|
+
this.itemDeselected.emit(item);
|
|
79
|
+
}
|
|
80
|
+
console.log('selectedItems', this.selectedItems);
|
|
81
|
+
}
|
|
82
|
+
deselectItem(item) {
|
|
83
|
+
//this.selectedItems = this.selectedItems.filter(selected => selected.id !== item.id);
|
|
84
|
+
this.itemsSelectedChange.emit(this.selectedItems);
|
|
85
|
+
this.itemDeselected.emit(item);
|
|
86
|
+
}
|
|
87
|
+
isSelected(item) {
|
|
88
|
+
return false;
|
|
89
|
+
// return this.selectionPredicate(item);
|
|
90
|
+
}
|
|
91
|
+
goToPage(page) {
|
|
92
|
+
this.currentPage = page;
|
|
93
|
+
this.paginateItems();
|
|
94
|
+
}
|
|
95
|
+
getPageNumbers() {
|
|
96
|
+
return this.listUtils.getPageNumbers(this.items.length, this.pageSize);
|
|
97
|
+
}
|
|
98
|
+
paginateItems() {
|
|
99
|
+
this.totalPages = Math.ceil(this.items.length / this.pageSize);
|
|
100
|
+
this.paginatedItems = this.listUtils.paginate(this.items, this.currentPage, this.pageSize);
|
|
101
|
+
}
|
|
102
|
+
viewCategory(item) {
|
|
103
|
+
console.log(item);
|
|
104
|
+
this.activeProgram = item;
|
|
105
|
+
this.categoryList = this.addParentTreeToCategories(MOCK_CATEGORIES);
|
|
106
|
+
console.log('categoryList', this.categoryList);
|
|
107
|
+
}
|
|
108
|
+
addParentTreeToCategories(categories) {
|
|
109
|
+
// Create a map for quick lookup of categories by ID
|
|
110
|
+
const categoryMap = new Map(categories.map(category => [category.id, category]));
|
|
111
|
+
function getParentTree(category) {
|
|
112
|
+
const parentTree = [];
|
|
113
|
+
let currentParent = category.parent;
|
|
114
|
+
while (currentParent) {
|
|
115
|
+
const parentCategory = categoryMap.get(currentParent);
|
|
116
|
+
if (parentCategory) {
|
|
117
|
+
parentTree.push(parentCategory.name);
|
|
118
|
+
currentParent = parentCategory.parent;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
break;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
return parentTree;
|
|
125
|
+
}
|
|
126
|
+
return categories.map(category => ({
|
|
127
|
+
...category,
|
|
128
|
+
parentTree: getParentTree(category)
|
|
129
|
+
}));
|
|
130
|
+
}
|
|
131
|
+
selectFilter(event, item) {
|
|
132
|
+
console.log(event, item);
|
|
133
|
+
if (event) {
|
|
134
|
+
this.selectedProgramType.push(item);
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
this.selectedProgramType = this.selectedProgramType.filter((selected) => selected.id !== item.id);
|
|
138
|
+
}
|
|
139
|
+
console.log('selectedProgramType', this.selectedProgramType);
|
|
140
|
+
}
|
|
141
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramListComponent, deps: [{ token: i1.ListUtilsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
142
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ProgramListComponent, selector: "app-program-list", inputs: { items: "items", selectedItems: "selectedItems", itemTemplate: "itemTemplate", dataSource: "dataSource" }, outputs: { itemSelected: "itemSelected", itemDeselected: "itemDeselected", itemsSelectedChange: "itemsSelectedChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"dynamic-list-container\">\n <div class=\"vx-d-flex\">\n <div class=\"search-block vx-w-100\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search...\"\n (keyup)=\"search()\"\n />\n </div>\n <div\n class=\"dynamic-list-filter\"\n appPopover\n (click)=\"programTypePopover.popover()\"\n placement=\"right\"\n >\n <div class=\"filter-text\">All Program Type</div>\n <i class=\"icons filter-icon\">  </i>\n </div>\n </div>\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"paginatedItems?.length > 0; else defaultTemplate\"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-50 vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <div\n *ngFor=\"let item of paginatedItems; let i = index\"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n CATEGORIES SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\">  </i>\n </button>\n </div>\n </div>\n </div>\n <div class=\"right-column\">\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"let item of categoryList; let i = index\"\n >\n <app-cs-checkbox\n [value]=\"item.id\"\n [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n (ngValueChange)=\"selectItem($event, item)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"item?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ item?.parentTree?.join(\" > \") }}\n </div>\n </div>\n </span>\n </app-cs-checkbox>\n </div>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\n \"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n\n<app-popover #programTypePopover>\n <div class=\"new-action-list\">\n <div\n class=\"program-type-text vx-fs-11 vx-fw-500 vx-gray-60 vx-lh-16 vx-p-2 vx-tt-uppercase\"\n >\n Program Type:\n </div>\n <ul class=\"action-item\">\n <li *ngFor=\"let item of programTypeList\">\n <div class=\"chip-item\">\n <app-cs-checkbox\n [value]=\"item.id\"\n [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n (ngValueChange)=\"selectFilter($event, item)\"\n >\n {{ item?.name }}\n </app-cs-checkbox>\n </div>\n </li>\n </ul>\n <div\n class=\"program-type-bottom vx-d-flex vx-align-center vx-justify-center vx-pt-3 vx-pb-3\"\n >\n <button\n class=\"reset-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n >\n RESET\n </button>\n <button\n class=\"apply-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n [class.disabled]=\"!selectedItems[activeProgram.id]?.length\"\n >\n APPLY\n </button>\n </div>\n </div>\n</app-popover>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 48px)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:2.5rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:13px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:1rem;top:14px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.CsCheckboxComponent, selector: "app-cs-checkbox", inputs: ["disabled", "ngValue", "value", "readonly", "oneLine"], outputs: ["ngValueChange"] }, { kind: "component", type: i5.NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: i6.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: i7.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }] }); }
|
|
143
|
+
}
|
|
144
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramListComponent, decorators: [{
|
|
145
|
+
type: Component,
|
|
146
|
+
args: [{ selector: 'app-program-list', template: "<div class=\"dynamic-list-container\">\n <div class=\"vx-d-flex\">\n <div class=\"search-block vx-w-100\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search...\"\n (keyup)=\"search()\"\n />\n </div>\n <div\n class=\"dynamic-list-filter\"\n appPopover\n (click)=\"programTypePopover.popover()\"\n placement=\"right\"\n >\n <div class=\"filter-text\">All Program Type</div>\n <i class=\"icons filter-icon\">  </i>\n </div>\n </div>\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"paginatedItems?.length > 0; else defaultTemplate\"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-50 vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <div\n *ngFor=\"let item of paginatedItems; let i = index\"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n CATEGORIES SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\">  </i>\n </button>\n </div>\n </div>\n </div>\n <div class=\"right-column\">\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"let item of categoryList; let i = index\"\n >\n <app-cs-checkbox\n [value]=\"item.id\"\n [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n (ngValueChange)=\"selectItem($event, item)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"item?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ item?.parentTree?.join(\" > \") }}\n </div>\n </div>\n </span>\n </app-cs-checkbox>\n </div>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\n \"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n\n<app-popover #programTypePopover>\n <div class=\"new-action-list\">\n <div\n class=\"program-type-text vx-fs-11 vx-fw-500 vx-gray-60 vx-lh-16 vx-p-2 vx-tt-uppercase\"\n >\n Program Type:\n </div>\n <ul class=\"action-item\">\n <li *ngFor=\"let item of programTypeList\">\n <div class=\"chip-item\">\n <app-cs-checkbox\n [value]=\"item.id\"\n [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n (ngValueChange)=\"selectFilter($event, item)\"\n >\n {{ item?.name }}\n </app-cs-checkbox>\n </div>\n </li>\n </ul>\n <div\n class=\"program-type-bottom vx-d-flex vx-align-center vx-justify-center vx-pt-3 vx-pb-3\"\n >\n <button\n class=\"reset-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n >\n RESET\n </button>\n <button\n class=\"apply-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n [class.disabled]=\"!selectedItems[activeProgram.id]?.length\"\n >\n APPLY\n </button>\n </div>\n </div>\n</app-popover>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 48px)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:2.5rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:13px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:1rem;top:14px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
|
|
147
|
+
}], ctorParameters: function () { return [{ type: i1.ListUtilsService }]; }, propDecorators: { items: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], selectedItems: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], itemTemplate: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], dataSource: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], itemSelected: [{
|
|
156
|
+
type: Output
|
|
157
|
+
}], itemDeselected: [{
|
|
158
|
+
type: Output
|
|
159
|
+
}], itemsSelectedChange: [{
|
|
160
|
+
type: Output
|
|
161
|
+
}] } });
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, OnInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { ListItem } from '../interfaces/list-item.interface';\nimport { SelectionPredicate } from '../interfaces/selection-predicate.interface';\nimport { DataSource } from '../interfaces/data-source.interface';\nimport { PROGRAM_TABLE_HEADERS, PAGINATION_OPTIONS } from '../constant';\nimport { ListUtilsService } from '../services/list-utils.service';\nimport { MOCK_CATEGORIES } from '../../../constants/mock';\n\n@Component({\n  selector: 'app-program-list',\n  templateUrl: './program-list.component.html',\n  styleUrls: ['./program-list.component.less']\n})\nexport class ProgramListComponent<T extends ListItem> implements OnInit, OnChanges {\n  @Input() items: T[] = [];\n  @Input() selectedItems: any | null = {};\n  //@Input() selectionPredicate: SelectionPredicate<T> = (item) => this.selectedItems.some(selected => selected.id === item.id);\n  @Input() itemTemplate: TemplateRef<any> | undefined;\n  @Input() dataSource: DataSource<T> | undefined;\n\n  @Output() itemSelected = new EventEmitter<T>();\n  @Output() itemDeselected = new EventEmitter<T>();\n  @Output() itemsSelectedChange = new EventEmitter<T[]>();\n\n  tableHeaders = PROGRAM_TABLE_HEADERS;\n  currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n  pageSize = PAGINATION_OPTIONS.PAGE_SIZE;\n  totalPages = 0;\n  searchTerm = '';\n  paginatedItems: T[] = [];\n  activeProgram: any |  null = null;\n  categoryList: any[]= [\n    {name: 'Program Details 1'},\n    {name: 'Program Details 2'},\n    {name: 'Program Details 3'},\n    {name: 'Program Details 4'},\n  ];\n\n  programTypeList: any[] = [\n    {name: 'Regulations', id: 'regulations'},\n    {name: 'Standards', id: 'standards'},\n    {name: 'Internal Controls', id: 'internal-controls'},\n    {name: 'Others', id: 'others'},\n  ];\n\n  selectedProgramType: any[] = [];\n\n  constructor(private listUtils: ListUtilsService) {}\n\n  ngOnInit(): void {\n    this.loadData();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['items'] || changes['selectedItems']) {\n      this.paginateItems();\n    }\n  }\n\n  getProgramList() {\n\n  }\n\n  loadData(): void {\n    if (this.dataSource) {\n      this.dataSource.load(this.searchTerm).subscribe(items => {\n        this.items = items;\n        this.viewCategory(items[0]);\n      });\n    } else {\n      this.viewCategory();\n    }\n  }\n\n  search(): void {\n    this.currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n    this.loadData();\n  }\n\n  selectItem(event: any, item: any): void {\n    if (event) {\n      if(!this.selectedItems[this.activeProgram.id]) {\n        this.selectedItems[this.activeProgram.id] = [];\n      }\n      this.selectedItems[this.activeProgram.id].push(item);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemSelected.emit(item);\n    } else {\n      this.selectedItems = this.selectedItems[this.activeProgram.id].filter((selected: any) => selected.id !== item.id);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemDeselected.emit(item);\n    }\n    console.log('selectedItems', this.selectedItems);\n  }\n\n  deselectItem(item: T): void {\n    //this.selectedItems = this.selectedItems.filter(selected => selected.id !== item.id);\n    this.itemsSelectedChange.emit(this.selectedItems);\n    this.itemDeselected.emit(item);\n  }\n\n  isSelected(item: T): boolean {\n    return false;\n   // return this.selectionPredicate(item);\n  }\n\n  goToPage(page: number): void {\n    this.currentPage = page;\n    this.paginateItems();\n  }\n\n  getPageNumbers(): number[] {\n    return this.listUtils.getPageNumbers(this.items.length, this.pageSize);\n  }\n\n  paginateItems(): void {\n    this.totalPages = Math.ceil(this.items.length / this.pageSize);\n    this.paginatedItems = this.listUtils.paginate(this.items, this.currentPage, this.pageSize);\n  }\n\n  viewCategory(item?: any): void {\n    console.log(item);\n    this.activeProgram = item;\n    this.categoryList = this.addParentTreeToCategories(MOCK_CATEGORIES);\n    console.log('categoryList', this.categoryList);\n  }\n\n  addParentTreeToCategories(categories: any[]): any[] {\n    // Create a map for quick lookup of categories by ID\n    const categoryMap = new Map(categories.map(category => [category.id, category]));\n  \n    function getParentTree(category: any): string[] {\n      const parentTree: string[] = [];\n      let currentParent = category.parent;\n  \n      while (currentParent) {\n        const parentCategory = categoryMap.get(currentParent);\n        if (parentCategory) {\n          parentTree.push(parentCategory.name);\n          currentParent = parentCategory.parent;\n        } else {\n          break;\n        }\n      }\n  \n      return parentTree;\n    }\n  \n    return categories.map(category => ({\n      ...category,\n      parentTree: getParentTree(category)\n    }));\n  }\n\n  selectFilter(event: any, item: any): void {\n    console.log(event, item);\n    if(event) {\n      this.selectedProgramType.push(item);\n    } else {\n      this.selectedProgramType = this.selectedProgramType.filter((selected: any) => selected.id !== item.id);\n    }\n    console.log('selectedProgramType', this.selectedProgramType);\n  }\n}\n","<div class=\"dynamic-list-container\">\n  <div class=\"vx-d-flex\">\n    <div class=\"search-block vx-w-100\">\n      <i class=\"icons\">&#xe90b;</i>\n      <input\n        type=\"text\"\n        [(ngModel)]=\"searchTerm\"\n        placeholder=\"Search...\"\n        (keyup)=\"search()\"\n      />\n    </div>\n    <div\n      class=\"dynamic-list-filter\"\n      appPopover\n      (click)=\"programTypePopover.popover()\"\n      placement=\"right\"\n    >\n      <div class=\"filter-text\">All Program Type</div>\n      <i class=\"icons filter-icon\"> &#xe9e8; </i>\n    </div>\n  </div>\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"paginatedItems?.length > 0; else defaultTemplate\"\n  >\n    <div class=\"dynamic-list-header vx-d-flex\">\n      <ng-container *ngFor=\"let header of tableHeaders\">\n        <div class=\"vx-d-flex vx-w-50 vx-pl-1\">\n          <div\n            class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n          >\n            #\n          </div>\n          <div\n            class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n          >\n            {{ header }}\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"dynamic-list-body vx-d-flex\">\n      <div class=\"left-column\">\n        <div\n          *ngFor=\"let item of paginatedItems; let i = index\"\n          class=\"list-row\"\n          [class.selected]=\"activeProgram?.id === item.id\"\n          (click)=\"viewCategory(item)\"\n        >\n          <div class=\"list-column serial\">\n            <div class=\"srNo\">{{ i + 1 }}</div>\n          </div>\n          <div\n            class=\"list-column name\"\n            [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n          </div>\n          <div\n            class=\"list-column count\"\n            *ngIf=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div\n              class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n            >\n              {{ selectedItems[item.id].length }}\n            </div>\n            <div\n              class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n            >\n              CATEGORIES SELECTED\n            </div>\n          </div>\n          <div class=\"list-column action\">\n            <button\n              class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n            >\n              <i class=\"icons\"> &#xe970; </i>\n            </button>\n          </div>\n        </div>\n      </div>\n      <div class=\"right-column\">\n        <div\n          class=\"list-row vx-pl-2 vx-pr-2\"\n          *ngFor=\"let item of categoryList; let i = index\"\n        >\n          <app-cs-checkbox\n            [value]=\"item.id\"\n            [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n            (ngValueChange)=\"selectItem($event, item)\"\n          >\n            <span class=\"value-inner\">\n              <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n              <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n                <div\n                  class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n                >\n                  Within\n                </div>\n                <div\n                  class=\"within-value vx-fs-11 vx-paragraph-txt\"\n                  [appTooltip]=\"item?.parentTree?.join(' > ')\"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"true\"\n                >\n                  {{ item?.parentTree?.join(\" > \") }}\n                </div>\n              </div>\n            </span>\n          </app-cs-checkbox>\n        </div>\n      </div>\n    </div>\n  </div>\n  <ng-template #defaultTemplate>\n    <div class=\"list-no-data-container\">\n      <app-no-data\n        [noDataImage]=\"\n          'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\n        \"\n        [noDataText]=\"'No data to display'\"\n      ></app-no-data>\n    </div>\n  </ng-template>\n</div>\n\n<app-popover #programTypePopover>\n  <div class=\"new-action-list\">\n    <div\n      class=\"program-type-text vx-fs-11 vx-fw-500 vx-gray-60 vx-lh-16 vx-p-2 vx-tt-uppercase\"\n    >\n      Program Type:\n    </div>\n    <ul class=\"action-item\">\n      <li *ngFor=\"let item of programTypeList\">\n        <div class=\"chip-item\">\n          <app-cs-checkbox\n            [value]=\"item.id\"\n            [ngValue]=\"selectedItems[activeProgram.id]?.id === item.id\"\n            (ngValueChange)=\"selectFilter($event, item)\"\n          >\n            {{ item?.name }}\n          </app-cs-checkbox>\n        </div>\n      </li>\n    </ul>\n    <div\n      class=\"program-type-bottom vx-d-flex vx-align-center vx-justify-center vx-pt-3 vx-pb-3\"\n    >\n      <button\n        class=\"reset-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n      >\n        RESET\n      </button>\n      <button\n        class=\"apply-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n        [class.disabled]=\"!selectedItems[activeProgram.id]?.length\"\n      >\n        APPLY\n      </button>\n    </div>\n  </div>\n</app-popover>\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { ProgramListComponent } from './program-list/program-list.component';
|
|
5
|
+
import { FormgroupModule } from "../../formgroup/formgroup.module";
|
|
6
|
+
import { NoDataModule } from '../../ui-kit/no-data/no-data.module';
|
|
7
|
+
import { PopoverModule } from '../../ui-kit/popover/popover.module';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class ProgramListModule {
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
11
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ProgramListModule, declarations: [ProgramListComponent], imports: [CommonModule,
|
|
12
|
+
FormsModule,
|
|
13
|
+
FormgroupModule,
|
|
14
|
+
NoDataModule,
|
|
15
|
+
PopoverModule], exports: [ProgramListComponent] }); }
|
|
16
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramListModule, imports: [CommonModule,
|
|
17
|
+
FormsModule,
|
|
18
|
+
FormgroupModule,
|
|
19
|
+
NoDataModule,
|
|
20
|
+
PopoverModule] }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramListModule, decorators: [{
|
|
23
|
+
type: NgModule,
|
|
24
|
+
args: [{
|
|
25
|
+
declarations: [
|
|
26
|
+
ProgramListComponent
|
|
27
|
+
],
|
|
28
|
+
imports: [
|
|
29
|
+
CommonModule,
|
|
30
|
+
FormsModule,
|
|
31
|
+
FormgroupModule,
|
|
32
|
+
NoDataModule,
|
|
33
|
+
PopoverModule
|
|
34
|
+
],
|
|
35
|
+
exports: [
|
|
36
|
+
ProgramListComponent
|
|
37
|
+
]
|
|
38
|
+
}]
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3JhbS1saXN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3NoYXJlZENvbXBvbmVudHMvcHJvZ3JhbS1saXN0L3Byb2dyYW0tbGlzdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOztBQWdCcEUsTUFBTSxPQUFPLGlCQUFpQjsrR0FBakIsaUJBQWlCO2dIQUFqQixpQkFBaUIsaUJBYjFCLG9CQUFvQixhQUdwQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixZQUFZO1lBQ1osYUFBYSxhQUdiLG9CQUFvQjtnSEFHWCxpQkFBaUIsWUFWMUIsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsWUFBWTtZQUNaLGFBQWE7OzRGQU1KLGlCQUFpQjtrQkFmN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWixhQUFhO3FCQUNoQjtvQkFDQyxPQUFPLEVBQUU7d0JBQ1Asb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IFByb2dyYW1MaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9wcm9ncmFtLWxpc3QvcHJvZ3JhbS1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3JtZ3JvdXBNb2R1bGUgfSBmcm9tIFwiLi4vLi4vZm9ybWdyb3VwL2Zvcm1ncm91cC5tb2R1bGVcIjtcbmltcG9ydCB7IE5vRGF0YU1vZHVsZSB9IGZyb20gJy4uLy4uL3VpLWtpdC9uby1kYXRhL25vLWRhdGEubW9kdWxlJztcbmltcG9ydCB7IFBvcG92ZXJNb2R1bGUgfSBmcm9tICcuLi8uLi91aS1raXQvcG9wb3Zlci9wb3BvdmVyLm1vZHVsZSc7XG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBQcm9ncmFtTGlzdENvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIEZvcm1ncm91cE1vZHVsZSxcbiAgICBOb0RhdGFNb2R1bGUsXG4gICAgUG9wb3Zlck1vZHVsZVxuXSxcbiAgZXhwb3J0czogW1xuICAgIFByb2dyYW1MaXN0Q29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgUHJvZ3JhbUxpc3RNb2R1bGUgeyB9XG4iXX0=
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// list-utils.service.ts
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ListUtilsService {
|
|
5
|
+
paginate(items, currentPage, pageSize) {
|
|
6
|
+
const startIndex = (currentPage - 1) * pageSize;
|
|
7
|
+
const endIndex = startIndex + pageSize;
|
|
8
|
+
return items.slice(startIndex, endIndex);
|
|
9
|
+
}
|
|
10
|
+
getPageNumbers(totalItems, pageSize) {
|
|
11
|
+
const totalPages = Math.ceil(totalItems / pageSize);
|
|
12
|
+
const pages = [];
|
|
13
|
+
for (let i = 1; i <= totalPages; i++) {
|
|
14
|
+
pages.push(i);
|
|
15
|
+
}
|
|
16
|
+
return pages;
|
|
17
|
+
}
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListUtilsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
19
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListUtilsService, providedIn: 'root' }); }
|
|
20
|
+
}
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListUtilsService, decorators: [{
|
|
22
|
+
type: Injectable,
|
|
23
|
+
args: [{
|
|
24
|
+
providedIn: 'root'
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC11dGlscy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wcm9ncmFtLWxpc3Qvc2VydmljZXMvbGlzdC11dGlscy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdCQUF3QjtBQUN4QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFFBQVEsQ0FBSSxLQUFVLEVBQUUsV0FBbUIsRUFBRSxRQUFnQjtRQUMzRCxNQUFNLFVBQVUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUMsR0FBRyxRQUFRLENBQUM7UUFDaEQsTUFBTSxRQUFRLEdBQUcsVUFBVSxHQUFHLFFBQVEsQ0FBQztRQUN2QyxPQUFPLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxjQUFjLENBQUMsVUFBa0IsRUFBRSxRQUFnQjtRQUNqRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLENBQUMsQ0FBQztRQUNwRCxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7UUFDakIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLFVBQVUsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUNwQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2Y7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7K0dBZFUsZ0JBQWdCO21IQUFoQixnQkFBZ0IsY0FGZixNQUFNOzs0RkFFUCxnQkFBZ0I7a0JBSDVCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbGlzdC11dGlscy5zZXJ2aWNlLnRzXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIExpc3RVdGlsc1NlcnZpY2Uge1xuICBwYWdpbmF0ZTxUPihpdGVtczogVFtdLCBjdXJyZW50UGFnZTogbnVtYmVyLCBwYWdlU2l6ZTogbnVtYmVyKTogVFtdIHtcbiAgICBjb25zdCBzdGFydEluZGV4ID0gKGN1cnJlbnRQYWdlIC0gMSkgKiBwYWdlU2l6ZTtcbiAgICBjb25zdCBlbmRJbmRleCA9IHN0YXJ0SW5kZXggKyBwYWdlU2l6ZTtcbiAgICByZXR1cm4gaXRlbXMuc2xpY2Uoc3RhcnRJbmRleCwgZW5kSW5kZXgpO1xuICB9XG5cbiAgZ2V0UGFnZU51bWJlcnModG90YWxJdGVtczogbnVtYmVyLCBwYWdlU2l6ZTogbnVtYmVyKTogbnVtYmVyW10ge1xuICAgIGNvbnN0IHRvdGFsUGFnZXMgPSBNYXRoLmNlaWwodG90YWxJdGVtcyAvIHBhZ2VTaXplKTtcbiAgICBjb25zdCBwYWdlcyA9IFtdO1xuICAgIGZvciAobGV0IGkgPSAxOyBpIDw9IHRvdGFsUGFnZXM7IGkrKykge1xuICAgICAgcGFnZXMucHVzaChpKTtcbiAgICB9XG4gICAgcmV0dXJuIHBhZ2VzO1xuICB9XG59Il19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Injectable, Optional } from '@angular/core';
|
|
2
|
+
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common/http";
|
|
5
|
+
import * as i2 from "../../../workflow-services/auth.service";
|
|
6
|
+
import * as i3 from "../../../configurations";
|
|
7
|
+
export class WorkflowComplianceService {
|
|
8
|
+
constructor(http, authService, config) {
|
|
9
|
+
this.http = http;
|
|
10
|
+
this.authService = authService;
|
|
11
|
+
if (config) {
|
|
12
|
+
this.env = config.envConfig;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
getProgramList() {
|
|
16
|
+
let httpOptions = {};
|
|
17
|
+
let headers = new HttpHeaders();
|
|
18
|
+
httpOptions.headers = headers.append('token', this.authService.getAuthorizationToken());
|
|
19
|
+
return this.http.get(`${this.env.complianceGet}sailsProgramList`, httpOptions);
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowComplianceService, deps: [{ token: i1.HttpClient }, { token: i2.AuthService }, { token: i3.Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
22
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowComplianceService, providedIn: 'root' }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowComplianceService, decorators: [{
|
|
25
|
+
type: Injectable,
|
|
26
|
+
args: [{
|
|
27
|
+
providedIn: 'root'
|
|
28
|
+
}]
|
|
29
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.AuthService }, { type: i3.Configurations, decorators: [{
|
|
30
|
+
type: Optional
|
|
31
|
+
}] }]; } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3JhbS1saXN0LWFwaS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wcm9ncmFtLWxpc3Qvc2VydmljZXMvcHJvZ3JhbS1saXN0LWFwaS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JELE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7QUFPL0QsTUFBTSxPQUFPLHlCQUF5QjtJQUdsQyxZQUNZLElBQWdCLEVBQ2hCLFdBQXdCLEVBQ3BCLE1BQXVCO1FBRjNCLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFHaEMsSUFBSSxNQUFNLEVBQUU7WUFDVixJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7U0FDN0I7SUFDSCxDQUFDO0lBQ0gsY0FBYztRQUNWLElBQUksV0FBVyxHQUFRLEVBQUUsQ0FBQztRQUM5QixJQUFJLE9BQU8sR0FBRyxJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQ2hDLFdBQVcsQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FDbEMsT0FBTyxFQUNQLElBQUksQ0FBQyxXQUFXLENBQUMscUJBQXFCLEVBQUUsQ0FDekMsQ0FBQztRQUNFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQU0sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsa0JBQWtCLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDeEYsQ0FBQzsrR0FwQlEseUJBQXlCO21IQUF6Qix5QkFBeUIsY0FGeEIsTUFBTTs7NEZBRVAseUJBQXlCO2tCQUhyQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBT1EsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50LCBIdHRwSGVhZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbmZpZ3VyYXRpb25zIH0gZnJvbSAnLi4vLi4vLi4vY29uZmlndXJhdGlvbnMnO1xuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi93b3JrZmxvdy1zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgV29ya2Zsb3dDb21wbGlhbmNlU2VydmljZSB7XG4gICAgZW52ITogYW55O1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCxcbiAgICAgICAgcHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgICAgIEBPcHRpb25hbCgpIGNvbmZpZz86IENvbmZpZ3VyYXRpb25zXG4gICAgICApIHtcbiAgICAgICAgaWYgKGNvbmZpZykge1xuICAgICAgICAgIHRoaXMuZW52ID0gY29uZmlnLmVudkNvbmZpZztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGdldFByb2dyYW1MaXN0KCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgICAgIGxldCBodHRwT3B0aW9uczogYW55ID0ge307XG4gICAgbGV0IGhlYWRlcnMgPSBuZXcgSHR0cEhlYWRlcnMoKTtcbiAgICBodHRwT3B0aW9ucy5oZWFkZXJzID0gaGVhZGVycy5hcHBlbmQoXG4gICAgICAndG9rZW4nLFxuICAgICAgdGhpcy5hdXRoU2VydmljZS5nZXRBdXRob3JpemF0aW9uVG9rZW4oKVxuICAgICk7XG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PGFueT4oYCR7dGhpcy5lbnYuY29tcGxpYW5jZUdldH1zYWlsc1Byb2dyYW1MaXN0YCwgaHR0cE9wdGlvbnMpO1xuICAgIH1cbiAgfSJdfQ==
|