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.
Files changed (69) hide show
  1. package/esm2022/lib/constants/mock.mjs +130 -0
  2. package/esm2022/lib/interfaces/frequency.interface.mjs +2 -0
  3. package/esm2022/lib/interfaces/responsibilty.interface.mjs +1 -1
  4. package/esm2022/lib/more-option/more-option.component.mjs +3 -46
  5. package/esm2022/lib/sharedComponents/category-list-selection/category-list-selection/category-list-selection.component.mjs +3 -3
  6. package/esm2022/lib/sharedComponents/document-section/document-section.component.mjs +9 -40
  7. package/esm2022/lib/sharedComponents/frequency/frequency-annual/frequency-annual.component.mjs +5 -1
  8. package/esm2022/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +5 -1
  9. package/esm2022/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +2 -1
  10. package/esm2022/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +6 -2
  11. package/esm2022/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +2 -1
  12. package/esm2022/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +3 -1
  13. package/esm2022/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +5 -1
  14. package/esm2022/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +3 -1
  15. package/esm2022/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +4 -2
  16. package/esm2022/lib/sharedComponents/frequency/frequency.service.mjs +185 -1
  17. package/esm2022/lib/sharedComponents/list-container/list-container.component.mjs +52 -0
  18. package/esm2022/lib/sharedComponents/policy-template/policy-template.module.mjs +5 -5
  19. package/esm2022/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.mjs +33 -31
  20. package/esm2022/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.mjs +3 -9
  21. package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.mjs +93 -0
  22. package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy.module.mjs +19 -0
  23. package/esm2022/lib/sharedComponents/program-list/constant.mjs +10 -0
  24. package/esm2022/lib/sharedComponents/program-list/interfaces/data-source.interface.mjs +2 -0
  25. package/esm2022/lib/sharedComponents/program-list/interfaces/list-item.interface.mjs +2 -0
  26. package/esm2022/lib/sharedComponents/program-list/interfaces/selection-predicate.interface.mjs +2 -0
  27. package/esm2022/lib/sharedComponents/program-list/program-list/program-list.component.mjs +162 -0
  28. package/esm2022/lib/sharedComponents/program-list/program-list.module.mjs +40 -0
  29. package/esm2022/lib/sharedComponents/program-list/services/list-utils.service.mjs +27 -0
  30. package/esm2022/lib/sharedComponents/program-list/services/program-list-api.service.mjs +32 -0
  31. package/esm2022/lib/workflow-compliance/workflow-compliance.component.mjs +303 -153
  32. package/esm2022/lib/workflow-engine-container/workflow-engine-container.component.mjs +5 -13
  33. package/esm2022/lib/workflow-engine.module.mjs +13 -6
  34. package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +3 -3
  35. package/esm2022/lib/workflow-program/workflow-program.component.mjs +83 -240
  36. package/esm2022/lib/workflow-services/programs.service.mjs +28 -112
  37. package/esm2022/lib/workflow-services/responsibility.service.mjs +9 -9
  38. package/fesm2022/vcomply-workflow-engine.mjs +1222 -710
  39. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  40. package/lib/constants/mock.d.ts +15 -0
  41. package/lib/interfaces/frequency.interface.d.ts +37 -0
  42. package/lib/interfaces/responsibilty.interface.d.ts +1 -1
  43. package/lib/sharedComponents/document-section/document-section.component.d.ts +2 -10
  44. package/lib/sharedComponents/frequency/frequency.service.d.ts +30 -0
  45. package/lib/sharedComponents/list-container/list-container.component.d.ts +9 -0
  46. package/lib/sharedComponents/policy-template/policy-template.module.d.ts +2 -2
  47. package/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.d.ts +5 -7
  48. package/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.d.ts +3 -6
  49. package/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.d.ts +25 -0
  50. package/lib/sharedComponents/policy-template/view-policy/view-policy.module.d.ts +9 -0
  51. package/lib/sharedComponents/program-list/constant.d.ts +5 -0
  52. package/lib/sharedComponents/program-list/interfaces/data-source.interface.d.ts +4 -0
  53. package/lib/sharedComponents/program-list/interfaces/list-item.interface.d.ts +5 -0
  54. package/lib/sharedComponents/program-list/interfaces/selection-predicate.interface.d.ts +3 -0
  55. package/lib/sharedComponents/program-list/program-list/program-list.component.d.ts +42 -0
  56. package/lib/sharedComponents/program-list/program-list.module.d.ts +12 -0
  57. package/lib/sharedComponents/program-list/services/list-utils.service.d.ts +7 -0
  58. package/lib/sharedComponents/program-list/services/program-list-api.service.d.ts +14 -0
  59. package/lib/workflow-compliance/workflow-compliance.component.d.ts +33 -5
  60. package/lib/workflow-engine-container/workflow-engine-container.component.d.ts +2 -3
  61. package/lib/workflow-engine.module.d.ts +42 -40
  62. package/lib/workflow-program/workflow-program.component.d.ts +6 -4
  63. package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
  64. package/lib/workflow-services/programs.service.d.ts +13 -53
  65. package/package.json +1 -1
  66. package/esm2022/lib/workflow-policy/ms-word.constants.mjs +0 -21
  67. package/esm2022/lib/workflow-services/policy-api.service.mjs +0 -38
  68. package/lib/workflow-policy/ms-word.constants.d.ts +0 -20
  69. 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=
@@ -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\">&#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", 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\">&#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", 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==