vcomply-workflow-engine 3.4.23 → 3.4.25
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/esm2020/lib/add-multiple-responsibility/add-multiple-responsibility.component.mjs +2 -4
- package/esm2020/lib/add-multiple-risk/add-multiple-risk.component.mjs +2 -3
- package/esm2020/lib/formgroup/cs-select/cs-select.component.mjs +5 -5
- package/esm2020/lib/formgroup/cs-switch/cs-switch.component.mjs +1 -4
- package/esm2020/lib/log-an-issue/log-an-issue.component.mjs +1 -11
- package/esm2020/lib/more-option/more-option.component.mjs +5 -6
- package/esm2020/lib/pipes/filter.pipe.mjs +1 -2
- package/esm2020/lib/pipes/search.pipe.mjs +3 -5
- package/esm2020/lib/sharedComponents/approval-workflow/approval-create-form/approval-create-form.component.mjs +3 -7
- package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow-list/approval-workflow-list.component.mjs +1 -5
- package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow.component.mjs +1 -7
- package/esm2020/lib/sharedComponents/assessment-editor/create-assessment-container/create-assessment-container.component.mjs +80 -36
- package/esm2020/lib/sharedComponents/assessment-list/assessment-list.component.mjs +27 -21
- package/esm2020/lib/sharedComponents/assessment-preview/preview/preview.component.mjs +7 -4
- package/esm2020/lib/sharedComponents/audit-category-list/audit-category-list.component.mjs +3 -4
- package/esm2020/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.mjs +3 -9
- package/esm2020/lib/sharedComponents/bulk-view/bulk-view.component.mjs +9 -7
- package/esm2020/lib/sharedComponents/category-multiselect/category-multi-select.component.mjs +7 -9
- package/esm2020/lib/sharedComponents/checkpoint/checkpoints/checkpoints.component.mjs +93 -27
- package/esm2020/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.mjs +11 -9
- package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-container/checkpoints-policy-container.component.mjs +13 -12
- package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.mjs +28 -19
- package/esm2020/lib/sharedComponents/floating-bar/floating-bar.component.mjs +8 -8
- package/esm2020/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +35 -37
- package/esm2020/lib/sharedComponents/framework-list/parent-table/parent-table.component.mjs +7 -7
- package/esm2020/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +1 -12
- package/esm2020/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +1 -3
- package/esm2020/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +1 -13
- package/esm2020/lib/sharedComponents/frequency/frequency-due-date/frequency-due-date.component.mjs +1 -7
- package/esm2020/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.mjs +1 -26
- package/esm2020/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +1 -15
- package/esm2020/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +1 -14
- package/esm2020/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +14 -8
- package/esm2020/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +1 -13
- package/esm2020/lib/sharedComponents/frequency/frequency-radio-list/frequency-radio-list.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +1 -18
- package/esm2020/lib/sharedComponents/frequency/frequency-top/frequency-top.component.mjs +2 -2
- package/esm2020/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +1 -12
- package/esm2020/lib/sharedComponents/frequency/frequency.service.mjs +2 -11
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-annual/frequency-dialog-annual.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-biannual/frequency-dialog-biannual.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-monthly/frequency-dialog-monthly.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-one-time/frequency-dialog-one-time.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-quarterly/frequency-dialog-quarterly.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-radio-list/frequency-dialog-radio-list.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.mjs +2 -2
- package/esm2020/lib/sharedComponents/group-users-list/group-users-list.component.mjs +1 -3
- package/esm2020/lib/sharedComponents/link-program/link-program/link-program.component.mjs +48 -38
- package/esm2020/lib/sharedComponents/link-program/restapi.service.mjs +31 -16
- package/esm2020/lib/sharedComponents/no-data/no-data.component.mjs +2 -4
- package/esm2020/lib/sharedComponents/owner-list/owner-list.component.mjs +12 -10
- package/esm2020/lib/sharedComponents/program-listing/program-listing.component.mjs +127 -58
- package/esm2020/lib/sharedComponents/radio-list-with-pagination/radio-list.component.mjs +4 -7
- package/esm2020/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.mjs +9 -7
- package/esm2020/lib/sharedComponents/risk-classification/risk-classification.component.mjs +11 -6
- package/esm2020/lib/sharedComponents/select-approvers/select-approvers.component.mjs +1 -2
- package/esm2020/lib/sharedComponents/users-radio-list/users-radio-list.component.mjs +2 -3
- package/esm2020/lib/ui-kit/formgroup/cs-switch/cs-switch.component.mjs +1 -4
- package/esm2020/lib/ui-kit/popover/popover-longpress.directive.mjs +1 -3
- package/esm2020/lib/ui-kit/popover/popover.component.mjs +26 -12
- package/esm2020/lib/ui-kit/tooltip/tooltip.directive.mjs +8 -5
- package/esm2020/lib/workflow/shared/components/attributes/attributes.component.mjs +1 -2
- package/esm2020/lib/workflow/shared/components/edit-mode/edit-mode.component.mjs +1 -4
- package/esm2020/lib/workflow/shared/components/grc-object-list/grc-object-list.component.mjs +1 -2
- package/esm2020/lib/workflow/shared/components/list-popup/list-popup.component.mjs +1 -4
- package/esm2020/lib/workflow/shared/components/table-card/table-card.component.mjs +4 -8
- package/esm2020/lib/workflow-assessment/import-an-assessment/import-an-assessment.component.mjs +245 -108
- package/esm2020/lib/workflow-assessment/workflow-assessment.component.mjs +2 -4
- package/esm2020/lib/workflow-compliance/workflow-compliance.component.mjs +10 -8
- package/esm2020/lib/workflow-engine-container/workflow-engine-container.component.mjs +1 -5
- package/esm2020/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.mjs +45 -45
- package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/define-framework-listing.component.mjs +43 -25
- package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/pipes/sub-cat-indeter.pipe.mjs +4 -4
- package/esm2020/lib/workflow-program/create-program-ui/floating-bar/floating-bar.component.mjs +1 -2
- package/esm2020/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.mjs +25 -14
- package/esm2020/lib/workflow-program/create-program-ui/pipes/assessment-resolver.pipe.mjs +6 -3
- package/esm2020/lib/workflow-program/create-program-ui/role-list/role-list.component.mjs +25 -19
- package/esm2020/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +1 -4
- package/esm2020/lib/workflow-program/workflow-program.component.mjs +232 -110
- package/esm2020/lib/workflow-services/add-risk.service.mjs +1 -2
- package/esm2020/lib/workflow-services/assessment.service.mjs +1 -5
- package/esm2020/lib/workflow-services/programs.service.mjs +173 -57
- package/fesm2015/vcomply-workflow-engine.mjs +1381 -937
- package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
- package/fesm2020/vcomply-workflow-engine.mjs +1394 -945
- package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
- package/lib/sharedComponents/assessment-list/assessment-list.component.d.ts +4 -5
- package/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.d.ts +2 -3
- package/lib/sharedComponents/bulk-view/bulk-view.component.d.ts +2 -3
- package/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.d.ts +2 -4
- package/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.d.ts +1 -1
- package/lib/sharedComponents/link-program/restapi.service.d.ts +3 -3
- package/lib/sharedComponents/no-data/no-data.component.d.ts +2 -4
- package/lib/ui-kit/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
- package/lib/workflow/shared/components/edit-mode/edit-mode.component.d.ts +2 -3
- package/lib/workflow/shared/components/list-popup/list-popup.component.d.ts +2 -3
- package/lib/workflow/shared/components/table-card/table-card.component.d.ts +2 -5
- package/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.d.ts +8 -9
- package/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.d.ts +2 -4
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/forms";
|
|
4
4
|
import * as i2 from "@angular/common";
|
|
@@ -35,8 +35,7 @@ export class RadioListWithPaginationComponent {
|
|
|
35
35
|
this.setSelectedIds();
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
ngOnInit() {
|
|
39
|
-
}
|
|
38
|
+
ngOnInit() { }
|
|
40
39
|
//This method handles the page change
|
|
41
40
|
pageChanged(page) {
|
|
42
41
|
this.currentPage = page;
|
|
@@ -58,13 +57,11 @@ export class RadioListWithPaginationComponent {
|
|
|
58
57
|
this.selectedList = this.selectedList.filter((ele) => ele[this.config?.identifierKey] !== item[this.config?.identifierKey]);
|
|
59
58
|
this.setSelectedIds();
|
|
60
59
|
}
|
|
61
|
-
console.log(event, item);
|
|
62
60
|
}
|
|
63
61
|
}
|
|
64
62
|
setSelectedIds() {
|
|
65
63
|
this.selectedIds = this.selectedList.map((ele) => ele[this.config?.identifierKey]);
|
|
66
|
-
this.selectedList = Array.from(new Set(this.selectedList.map((a) => a.id)))
|
|
67
|
-
.map(id => {
|
|
64
|
+
this.selectedList = Array.from(new Set(this.selectedList.map((a) => a.id))).map((id) => {
|
|
68
65
|
return this.selectedList.find((a) => a.id === id);
|
|
69
66
|
});
|
|
70
67
|
}
|
|
@@ -128,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
128
125
|
type: Input,
|
|
129
126
|
args: ['selectedList']
|
|
130
127
|
}] } });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-list.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/radio-list-with-pagination/radio-list.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/radio-list-with-pagination/radio-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nexport interface ListEvent {\r\n  searchKey?: string;\r\n  page?: number;\r\n}\r\nexport interface panelConfig {\r\n  panelTitle: '',\r\n  entitySingular: '',\r\n  entityPlural: '',\r\n  displayKey: '',\r\n  identifierKey: '',\r\n  parentKey: '',\r\n  parentDisplayKey: ''\r\n  searchPlaceholder: '',\r\n  noDataText: ''\r\n}\r\n@Component({\r\n  selector: 'app-radio-list-with-pagination',\r\n  templateUrl: './radio-list.component.html',\r\n  styleUrls: ['./radio-list.component.less']\r\n})\r\nexport class RadioListWithPaginationComponent implements OnInit {\r\n  @Output() fetchData = new EventEmitter<ListEvent>();\r\n  @Output() back = new EventEmitter();\r\n  @Output() next = new EventEmitter();\r\n  @Output() cancel = new EventEmitter();\r\n  list = [];\r\n  searchKey = '';\r\n  selectedList: any = [];\r\n  @Input('categoryList') set setList(value: any) {\r\n    this.list = value;\r\n  }\r\n  @Input() config !: panelConfig;\r\n  @Input() currentPage: any = 1;\r\n  @Input() recordStart: any = 1;\r\n  @Input() recordEnd: any = 1;\r\n  @Input() totalRecords: any = 1;\r\n  @Input() totalPages: any = 1;\r\n  @Input() loading: any = true;\r\n  @Input('selectedList') set setSelected(value: any) {\r\n    if (value) {\r\n      this.selectedList = [...value];\r\n      this.setSelectedIds();\r\n    }\r\n  }\r\n  animation = true;\r\n  selectedIds: any = []\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  //This method handles the page change\r\n  pageChanged(page: number) {\r\n    this.currentPage = page;\r\n    this.fetchData.emit({ page: this.currentPage, searchKey: this.searchKey })\r\n  }\r\n\r\n  //This method handles the search\r\n  search() {\r\n    this.currentPage = 1;\r\n    this.fetchData.emit({ page: this.currentPage, searchKey: this.searchKey })\r\n  }\r\n\r\n  itemSelected(event: any, item: any) {\r\n\r\n    if (event) {\r\n      this.selectedList.push(item);\r\n      this.setSelectedIds();\r\n    }else{\r\n      let index =  this.selectedList.findIndex((x:any) => x?.id === item?.id);\r\n      if(index >= 0){\r\n        this.selectedList = this.selectedList.filter((ele: any) => ele[this.config?.identifierKey] !== item[this.config?.identifierKey])\r\n        this.setSelectedIds();\r\n      }\r\n      console.log(event,item)\r\n    }\r\n  }\r\n\r\n  setSelectedIds() {\r\n    this.selectedIds = this.selectedList.map((ele: any) => ele[this.config?.identifierKey])\r\n    this.selectedList = Array.from(new Set(this.selectedList.map((a:any) => a.id)))\r\n                      .map(id => {\r\n                        return this.selectedList.find((a:any) => a.id === id)\r\n                      })\r\n  }\r\n  deleteItem(evt: any) {\r\n    this.selectedList = this.selectedList.filter((ele: any) => ele[this.config?.identifierKey] !== evt[this.config?.identifierKey])\r\n    this.setSelectedIds();\r\n  }\r\n\r\n  close() {\r\n    this.cancel.emit();\r\n  }\r\n  save() {\r\n    this.next.emit(this.selectedList);\r\n  }\r\n\r\n\r\n  selectAll(evt:any){\r\n    if(evt){\r\n      this.selectedList = [...this.selectedList,...this.list]\r\n      this.setSelectedIds();\r\n    }else if(evt=== false){\r\n      const currentPageList = this.list.map((ele:any) => ele.id);\r\n      this.selectedList = this.selectedList.filter((ele:any)=> !currentPageList.includes(ele?.id));\r\n      this.setSelectedIds();\r\n    }\r\n   \r\n  }\r\n  checkSelectAll() {\r\n    const data = this.list.every((rc: any) => this.selectedIds.includes(rc[this.config.identifierKey]));\r\n    return data;\r\n  }\r\n\r\n}\r\n","<div class=\"radio-list\" [class.animate]=\"animation\">\r\n  <div class=\"radio-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">{{config?.panelTitle}}</div>\r\n    <!-- <button class=\"radio-list-close\">\r\n      <i class=\"icons\" (click)=\"close()\">&#xe90d;</i>\r\n    </button> -->\r\n  </div>\r\n\r\n  <div class=\"radio-list-body\">\r\n    <div class=\"search-block vx-mb-2\" *ngIf=\"true\">\r\n      <i class=\"icons\">&#xe90b;</i>\r\n      <input (keydown.enter)=\"search()\" type=\"text\" [placeholder]=\"config?.searchPlaceholder\"  [(ngModel)]=\"searchKey\" />\r\n    </div>\r\n   \r\n    <app-pagination *ngIf=\"totalPages > 1\" [start]=\"recordStart\" [end]=\"recordEnd\" [total]=\"totalRecords\" [pageCount]=\"totalPages\" [currentPage]=\"currentPage\" (selectedPage)=\"pageChanged($event)\"></app-pagination>\r\n\r\n    <!-- it is visible when list data is available -->\r\n    <ng-container *ngIf=\"!loading && list?.length\" >\r\n      <div class=\"categories vx-mb-4\" [class.mt-2]=\"totalPages === 0\">\r\n        <app-cs-checkbox [ngValue]=\"checkSelectAll()\" (ngValueChange)=\"selectAll($event)\">\r\n          <span class=\"vx-fw-600 vx-label-txt\">{{checkSelectAll() ? 'Deselect All' : 'Select All'}}</span>\r\n        </app-cs-checkbox>\r\n      </div>\r\n      <ul class=\"categories-list vx-mb-4\" [class.with-pagination]=\"totalPages > 1\">\r\n        <li *ngFor=\"let item of list;let i = index\">\r\n          <!-- [ngValue]=\"selectedIds.includes(category[categoryIdKey])\" -->\r\n          <app-cs-checkbox  \r\n          [ngValue]=\"selectedIds?.includes(item[config?.identifierKey])\"\r\n          (ngValueChange)=\"itemSelected($event,item)\"\r\n          [appTooltip]=\"item[config.displayKey]\" placement=\"bottom-left\"\r\n          delay=\"0\" [tooltipMandatory]=\"true\">\r\n          <div class=\"name\">{{item[config.displayKey]}}</div>\r\n          <div class=\"within vx-d-flex vx-align-center vx-justify-start vx-mt-1\">\r\n            <div class=\"block vx-fs-9 vx-fw-500 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2\" *ngIf=\"item[config?.parentDisplayKey] != ''\">WITHIN</div>\r\n            <div class=\"data vx-fs-11 vx-paragraph-txt vx-lh-4 vx-pr-5\" [appTooltip]=\"'test > test'\" placement=\"bottom-left\" delay=\"0\" [tooltipMandatory]=\"false\">{{item[config?.parentDisplayKey]}}</div>\r\n          </div>\r\n        </app-cs-checkbox>\r\n        </li>\r\n      </ul>\r\n    </ng-container>\r\n    <!-- It is visible when the list items are getting loaded -->\r\n    <app-listline-loader *ngIf=\"loading\"></app-listline-loader>\r\n    <ng-container *ngIf=\"!loading && list?.length === 0\">\r\n      <app-no-data  [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\"  [noDataText]=\"config?.noDataText?.length > 0 ? config?.noDataText:'No data to display'\"></app-no-data>\r\n    </ng-container>\r\n    \r\n    <app-floating-bar [selectedData]=\"selectedList\" [displayElementKey]=\"config?.displayKey\"\r\n    [singularText]=\"config?.entitySingular\"\r\n    [pluralText]=\"config?.entityPlural ?config?.entityPlural:'Users selected'\"\r\n      (closeEvent)=\"save()\"\r\n      (closeList)=\"close()\" (deleteEvent)=\"deleteItem($event)\"\r\n      [isDisabled]=\"selectedList.length === 0 || list?.length === 0 \">\r\n    </app-floating-bar>\r\n  </div>\r\n</div>\r\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-list.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/radio-list-with-pagination/radio-list.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/radio-list-with-pagination/radio-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nexport interface ListEvent {\r\n  searchKey?: string;\r\n  page?: number;\r\n}\r\nexport interface panelConfig {\r\n  panelTitle: '';\r\n  entitySingular: '';\r\n  entityPlural: '';\r\n  displayKey: '';\r\n  identifierKey: '';\r\n  parentKey: '';\r\n  parentDisplayKey: '';\r\n  searchPlaceholder: '';\r\n  noDataText: '';\r\n}\r\n@Component({\r\n  selector: 'app-radio-list-with-pagination',\r\n  templateUrl: './radio-list.component.html',\r\n  styleUrls: ['./radio-list.component.less'],\r\n})\r\nexport class RadioListWithPaginationComponent implements OnInit {\r\n  @Output() fetchData = new EventEmitter<ListEvent>();\r\n  @Output() back = new EventEmitter();\r\n  @Output() next = new EventEmitter();\r\n  @Output() cancel = new EventEmitter();\r\n  list = [];\r\n  searchKey = '';\r\n  selectedList: any = [];\r\n  @Input('categoryList') set setList(value: any) {\r\n    this.list = value;\r\n  }\r\n  @Input() config!: panelConfig;\r\n  @Input() currentPage: any = 1;\r\n  @Input() recordStart: any = 1;\r\n  @Input() recordEnd: any = 1;\r\n  @Input() totalRecords: any = 1;\r\n  @Input() totalPages: any = 1;\r\n  @Input() loading: any = true;\r\n  @Input('selectedList') set setSelected(value: any) {\r\n    if (value) {\r\n      this.selectedList = [...value];\r\n      this.setSelectedIds();\r\n    }\r\n  }\r\n  animation = true;\r\n  selectedIds: any = [];\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  //This method handles the page change\r\n  pageChanged(page: number) {\r\n    this.currentPage = page;\r\n    this.fetchData.emit({ page: this.currentPage, searchKey: this.searchKey });\r\n  }\r\n\r\n  //This method handles the search\r\n  search() {\r\n    this.currentPage = 1;\r\n    this.fetchData.emit({ page: this.currentPage, searchKey: this.searchKey });\r\n  }\r\n\r\n  itemSelected(event: any, item: any) {\r\n    if (event) {\r\n      this.selectedList.push(item);\r\n      this.setSelectedIds();\r\n    } else {\r\n      let index = this.selectedList.findIndex((x: any) => x?.id === item?.id);\r\n      if (index >= 0) {\r\n        this.selectedList = this.selectedList.filter(\r\n          (ele: any) =>\r\n            ele[this.config?.identifierKey] !== item[this.config?.identifierKey]\r\n        );\r\n        this.setSelectedIds();\r\n      }\r\n    }\r\n  }\r\n\r\n  setSelectedIds() {\r\n    this.selectedIds = this.selectedList.map(\r\n      (ele: any) => ele[this.config?.identifierKey]\r\n    );\r\n    this.selectedList = Array.from(\r\n      new Set(this.selectedList.map((a: any) => a.id))\r\n    ).map((id) => {\r\n      return this.selectedList.find((a: any) => a.id === id);\r\n    });\r\n  }\r\n  deleteItem(evt: any) {\r\n    this.selectedList = this.selectedList.filter(\r\n      (ele: any) =>\r\n        ele[this.config?.identifierKey] !== evt[this.config?.identifierKey]\r\n    );\r\n    this.setSelectedIds();\r\n  }\r\n\r\n  close() {\r\n    this.cancel.emit();\r\n  }\r\n  save() {\r\n    this.next.emit(this.selectedList);\r\n  }\r\n\r\n  selectAll(evt: any) {\r\n    if (evt) {\r\n      this.selectedList = [...this.selectedList, ...this.list];\r\n      this.setSelectedIds();\r\n    } else if (evt === false) {\r\n      const currentPageList = this.list.map((ele: any) => ele.id);\r\n      this.selectedList = this.selectedList.filter(\r\n        (ele: any) => !currentPageList.includes(ele?.id)\r\n      );\r\n      this.setSelectedIds();\r\n    }\r\n  }\r\n  checkSelectAll() {\r\n    const data = this.list.every((rc: any) =>\r\n      this.selectedIds.includes(rc[this.config.identifierKey])\r\n    );\r\n    return data;\r\n  }\r\n}\r\n","<div class=\"radio-list\" [class.animate]=\"animation\">\r\n  <div class=\"radio-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">{{config?.panelTitle}}</div>\r\n    <!-- <button class=\"radio-list-close\">\r\n      <i class=\"icons\" (click)=\"close()\">&#xe90d;</i>\r\n    </button> -->\r\n  </div>\r\n\r\n  <div class=\"radio-list-body\">\r\n    <div class=\"search-block vx-mb-2\" *ngIf=\"true\">\r\n      <i class=\"icons\">&#xe90b;</i>\r\n      <input (keydown.enter)=\"search()\" type=\"text\" [placeholder]=\"config?.searchPlaceholder\"  [(ngModel)]=\"searchKey\" />\r\n    </div>\r\n   \r\n    <app-pagination *ngIf=\"totalPages > 1\" [start]=\"recordStart\" [end]=\"recordEnd\" [total]=\"totalRecords\" [pageCount]=\"totalPages\" [currentPage]=\"currentPage\" (selectedPage)=\"pageChanged($event)\"></app-pagination>\r\n\r\n    <!-- it is visible when list data is available -->\r\n    <ng-container *ngIf=\"!loading && list?.length\" >\r\n      <div class=\"categories vx-mb-4\" [class.mt-2]=\"totalPages === 0\">\r\n        <app-cs-checkbox [ngValue]=\"checkSelectAll()\" (ngValueChange)=\"selectAll($event)\">\r\n          <span class=\"vx-fw-600 vx-label-txt\">{{checkSelectAll() ? 'Deselect All' : 'Select All'}}</span>\r\n        </app-cs-checkbox>\r\n      </div>\r\n      <ul class=\"categories-list vx-mb-4\" [class.with-pagination]=\"totalPages > 1\">\r\n        <li *ngFor=\"let item of list;let i = index\">\r\n          <!-- [ngValue]=\"selectedIds.includes(category[categoryIdKey])\" -->\r\n          <app-cs-checkbox  \r\n          [ngValue]=\"selectedIds?.includes(item[config?.identifierKey])\"\r\n          (ngValueChange)=\"itemSelected($event,item)\"\r\n          [appTooltip]=\"item[config.displayKey]\" placement=\"bottom-left\"\r\n          delay=\"0\" [tooltipMandatory]=\"true\">\r\n          <div class=\"name\">{{item[config.displayKey]}}</div>\r\n          <div class=\"within vx-d-flex vx-align-center vx-justify-start vx-mt-1\">\r\n            <div class=\"block vx-fs-9 vx-fw-500 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2\" *ngIf=\"item[config?.parentDisplayKey] != ''\">WITHIN</div>\r\n            <div class=\"data vx-fs-11 vx-paragraph-txt vx-lh-4 vx-pr-5\" [appTooltip]=\"'test > test'\" placement=\"bottom-left\" delay=\"0\" [tooltipMandatory]=\"false\">{{item[config?.parentDisplayKey]}}</div>\r\n          </div>\r\n        </app-cs-checkbox>\r\n        </li>\r\n      </ul>\r\n    </ng-container>\r\n    <!-- It is visible when the list items are getting loaded -->\r\n    <app-listline-loader *ngIf=\"loading\"></app-listline-loader>\r\n    <ng-container *ngIf=\"!loading && list?.length === 0\">\r\n      <app-no-data  [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\"  [noDataText]=\"config?.noDataText?.length > 0 ? config?.noDataText:'No data to display'\"></app-no-data>\r\n    </ng-container>\r\n    \r\n    <app-floating-bar [selectedData]=\"selectedList\" [displayElementKey]=\"config?.displayKey\"\r\n    [singularText]=\"config?.entitySingular\"\r\n    [pluralText]=\"config?.entityPlural ?config?.entityPlural:'Users selected'\"\r\n      (closeEvent)=\"save()\"\r\n      (closeList)=\"close()\" (deleteEvent)=\"deleteItem($event)\"\r\n      [isDisabled]=\"selectedList.length === 0 || list?.length === 0 \">\r\n    </app-floating-bar>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { cloneDeep } from 'lodash';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
@@ -23,9 +23,11 @@ export class ResponsibilityCentersListComponent {
|
|
|
23
23
|
this.search = '';
|
|
24
24
|
}
|
|
25
25
|
ngOnChanges() {
|
|
26
|
-
this.selectedIds = this.selectedResponsibilityCenters.map((ele) => {
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
this.selectedIds = this.selectedResponsibilityCenters.map((ele) => {
|
|
27
|
+
if (ele[this.rcIdKey]) {
|
|
28
|
+
return ele[this.rcIdKey];
|
|
29
|
+
}
|
|
30
|
+
});
|
|
29
31
|
}
|
|
30
32
|
ngOnInit() {
|
|
31
33
|
this.animation = true;
|
|
@@ -33,7 +35,7 @@ export class ResponsibilityCentersListComponent {
|
|
|
33
35
|
this.animation = false;
|
|
34
36
|
}, 300);
|
|
35
37
|
setTimeout(() => {
|
|
36
|
-
this.blockWidth = this.listBlock
|
|
38
|
+
this.blockWidth = this.listBlock?.nativeElement?.offsetWidth;
|
|
37
39
|
}, 10);
|
|
38
40
|
}
|
|
39
41
|
selectRc(rc, mode) {
|
|
@@ -64,7 +66,7 @@ export class ResponsibilityCentersListComponent {
|
|
|
64
66
|
if (mode) {
|
|
65
67
|
const list = [...this.responsibilityCentersList];
|
|
66
68
|
this.selectedIds = [];
|
|
67
|
-
list.forEach(element => {
|
|
69
|
+
list.forEach((element) => {
|
|
68
70
|
this.selectedIds.push(element[this.rcIdKey]);
|
|
69
71
|
});
|
|
70
72
|
}
|
|
@@ -120,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
120
122
|
}], singularText: [{
|
|
121
123
|
type: Input
|
|
122
124
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"responsibility-centers-list.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { cloneDeep } from 'lodash';\r\n\r\n@Component({\r\n  selector: 'app-responsibility-centers-list',\r\n  templateUrl: './responsibility-centers-list.component.html',\r\n  styleUrls: ['./responsibility-centers-list.component.less']\r\n})\r\nexport class ResponsibilityCentersListComponent implements OnInit, OnChanges {\r\n  @ViewChild('listBlock',{ static: false }) listBlock!: ElementRef;\r\n  @Input() responsibilityCentersList = [];\r\n  @Input() selectedResponsibilityCenters = [];\r\n  @Input() rcIdKey = '';\r\n  @Input() radioSelection = false;\r\n  @Output() saveSelectedList = new EventEmitter();\r\n  @Output() closeRcList = new EventEmitter();\r\n  @Input() pluralText: string = 'Responsibility Centers selected';\r\n  @Input() singularText: string = 'Responsibility Center selected';\r\n  selectedIds: any[] = [];\r\n  animation = false;\r\n  search = '';\r\n  blockWidth: any;\r\n  constructor() { }\r\n\r\n  ngOnChanges(): void {\r\n    this.selectedIds = this.selectedResponsibilityCenters.map((ele: any) => { if (ele[this.rcIdKey]) { return ele[this.rcIdKey]; } });\r\n  }\r\n  ngOnInit(): void {\r\n    this.animation = true;\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n    setTimeout(() => {\r\n      this.blockWidth =  this.listBlock.nativeElement.offsetWidth;\r\n    }, 10);\r\n  }\r\n\r\n  selectRc(rc: any, mode: any) {\r\n    if (this.radioSelection) {\r\n      if (mode) {\r\n        this.selectedIds=[];\r\n        this.selectedIds.push(rc);\r\n      }\r\n      this.setList();\r\n    }else{\r\n      if (mode) {\r\n        this.selectedIds.push(rc);\r\n      } else {\r\n        const index = this.selectedIds.findIndex((element: any) => element == rc);\r\n        this.selectedIds.splice(index, 1);\r\n      }\r\n      this.setList();\r\n    }\r\n\r\n\r\n  }\r\n  deleteEvent(event: any) {\r\n    const index = this.selectedIds.findIndex((element: any) => element == event[this.rcIdKey]);\r\n    this.selectedIds.splice(index, 1);\r\n    this.setList();\r\n  }\r\n\r\n  selectAll(mode: any) {\r\n    if (mode) {\r\n      const list = [...this.responsibilityCentersList];\r\n      this.selectedIds = [];\r\n      list.forEach(element => {\r\n        this.selectedIds.push(element[this.rcIdKey]);\r\n      });\r\n    } else {\r\n      this.selectedIds = [];\r\n    }\r\n    this.setList();\r\n  }\r\n\r\n\r\n  setList() {\r\n    const data: any = [];\r\n    const rcList = cloneDeep(this.responsibilityCentersList);\r\n    const selectedIds = cloneDeep(this.selectedIds);\r\n    rcList.forEach((element: any) => {\r\n      if (selectedIds.includes(element[this.rcIdKey])) {\r\n        data.push(element);\r\n      }\r\n    });\r\n    this.selectedResponsibilityCenters = data;\r\n  }\r\n\r\n  checkSelectAll() {\r\n    const data = this.responsibilityCentersList.every((rc: any) => this.selectedIds.includes(rc[this.rcIdKey]));\r\n    return data;\r\n  }\r\n\r\n  save(selectedIds: any) {\r\n    this.saveSelectedList.emit(selectedIds);\r\n  }\r\n\r\n  close() {\r\n    this.closeRcList.emit();\r\n  }\r\n\r\n}\r\n","<div class=\"add-risk-rc\" [class.animate]=\"animation\">\r\n  <div\r\n    class=\"add-risk-rc-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n  >\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n      Select Responsibility Center(s)\r\n    </div>\r\n  </div>\r\n  <div class=\"add-risk-rc-body\">\r\n    <div class=\"search-block\">\r\n      <i class=\"icons\">&#xe90b;</i>\r\n      <input\r\n        type=\"text\"\r\n        [(ngModel)]=\"search\"\r\n        placeholder=\"Search Responsibility Center\"\r\n      />\r\n    </div>\r\n    <!-- <app-workflow-pagination></app-workflow-pagination> -->\r\n    <ng-container\r\n      *ngIf=\"responsibilityCentersList | search : search as searchList\"\r\n    >\r\n      <div\r\n        class=\"body-top\"\r\n        *ngIf=\"\r\n          !radioSelection &&\r\n          searchList?.length > 0 &&\r\n          search?.trim()?.length === 0\r\n        \"\r\n      >\r\n        <app-cs-checkbox\r\n          [ngValue]=\"checkSelectAll()\"\r\n          (ngValueChange)=\"selectAll($event)\"\r\n          ><strong>{{\r\n            checkSelectAll() ? \"Deselect All\" : \"Select All\"\r\n          }}</strong>\r\n        </app-cs-checkbox>\r\n      </div>\r\n\r\n      <ul\r\n        class=\"add-risk-rc-list\"\r\n        [class.with-selectAll]=\"\r\n          !radioSelection &&\r\n          searchList?.length > 0 &&\r\n          search?.trim()?.length === 0\r\n        \"\r\n        *ngIf=\"searchList?.length > 0\"\r\n      >\r\n        <ng-container *ngIf=\"!radioSelection\">\r\n          <li *ngFor=\"let rc of searchList\" #ulElement>\r\n            <app-cs-checkbox\r\n              [ngValue]=\"selectedIds.includes(rc.item_id)\"\r\n              (ngValueChange)=\"selectRc(rc.item_id, $event)\"\r\n            >\r\n              <ul class=\"add-risk-rc-name\" #listBlock>\r\n                <!-- [style.max-width.px]=\"blockWidth / rc.rc_name\" -->\r\n                <li\r\n                  *ngFor=\"let entity of rc.rc_name; let j = index\"\r\n                  [appTooltip]=\"entity\"\r\n                  placement=\"bottom\"\r\n                  type=\"black\"\r\n                  delay=\"0\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  <i class=\"icons\" *ngIf=\"j !== 0\">&#xe910;</i>{{ entity }}\r\n                </li>\r\n              </ul>\r\n            </app-cs-checkbox>\r\n          </li>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"radioSelection\">\r\n          <li *ngFor=\"let rc of searchList\" #ulElement>\r\n            <app-cs-radio\r\n              (checkedEvent)=\"selectRc(rc.item_id, $event)\"\r\n              [checked]=\"selectedIds.includes(rc.item_id)\"\r\n            >\r\n              <ul class=\"add-risk-rc-name\">\r\n                <li\r\n                  *ngFor=\"let entity of rc.rc_name; let j = index\"\r\n                  [appTooltip]=\"entity\"\r\n                  placement=\"bottom\"\r\n                  type=\"black\"\r\n                  delay=\"0\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  <i class=\"icons\" *ngIf=\"j !== 0\">&#xe910;</i>{{ entity }}\r\n                </li>\r\n              </ul>\r\n            </app-cs-radio>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n      <app-no-data\r\n        *ngIf=\"!searchList?.length\"\r\n        [noDataImage]=\"\r\n          'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n        \"\r\n        [noDataText]=\"'No data to display'\"\r\n      ></app-no-data>\r\n    </ng-container>\r\n\r\n    <app-floating-bar\r\n      [selectedData]=\"selectedResponsibilityCenters\"\r\n      [displayElementKey]=\"'item_name'\"\r\n      [singularText]=\"singularText\"\r\n      [pluralText]=\"pluralText\"\r\n      (closeEvent)=\"save(selectedIds)\"\r\n      (deleteEvent)=\"deleteEvent($event)\"\r\n      (closeList)=\"close()\"\r\n      [isDisabled]=\"\r\n        selectedResponsibilityCenters?.length === 0 ||\r\n        responsibilityCentersList?.length === 0\r\n      \"\r\n    ></app-floating-bar>\r\n  </div>\r\n</div>\r\n\r\n<!-- <button (click)=\"save(selectedIds)\">Next</button> -->\r\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"responsibility-centers-list.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { cloneDeep } from 'lodash';\r\n\r\n@Component({\r\n  selector: 'app-responsibility-centers-list',\r\n  templateUrl: './responsibility-centers-list.component.html',\r\n  styleUrls: ['./responsibility-centers-list.component.less'],\r\n})\r\nexport class ResponsibilityCentersListComponent implements OnInit, OnChanges {\r\n  @ViewChild('listBlock', { static: false }) listBlock!: ElementRef;\r\n  @Input() responsibilityCentersList = [];\r\n  @Input() selectedResponsibilityCenters = [];\r\n  @Input() rcIdKey = '';\r\n  @Input() radioSelection = false;\r\n  @Output() saveSelectedList = new EventEmitter();\r\n  @Output() closeRcList = new EventEmitter();\r\n  @Input() pluralText: string = 'Responsibility Centers selected';\r\n  @Input() singularText: string = 'Responsibility Center selected';\r\n  selectedIds: any[] = [];\r\n  animation = false;\r\n  search = '';\r\n  blockWidth: any;\r\n  constructor() {}\r\n\r\n  ngOnChanges(): void {\r\n    this.selectedIds = this.selectedResponsibilityCenters.map((ele: any) => {\r\n      if (ele[this.rcIdKey]) {\r\n        return ele[this.rcIdKey];\r\n      }\r\n    });\r\n  }\r\n  ngOnInit(): void {\r\n    this.animation = true;\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n    setTimeout(() => {\r\n      this.blockWidth = this.listBlock?.nativeElement?.offsetWidth;\r\n    }, 10);\r\n  }\r\n\r\n  selectRc(rc: any, mode: any) {\r\n    if (this.radioSelection) {\r\n      if (mode) {\r\n        this.selectedIds = [];\r\n        this.selectedIds.push(rc);\r\n      }\r\n      this.setList();\r\n    } else {\r\n      if (mode) {\r\n        this.selectedIds.push(rc);\r\n      } else {\r\n        const index = this.selectedIds.findIndex(\r\n          (element: any) => element == rc\r\n        );\r\n        this.selectedIds.splice(index, 1);\r\n      }\r\n      this.setList();\r\n    }\r\n  }\r\n  deleteEvent(event: any) {\r\n    const index = this.selectedIds.findIndex(\r\n      (element: any) => element == event[this.rcIdKey]\r\n    );\r\n    this.selectedIds.splice(index, 1);\r\n    this.setList();\r\n  }\r\n\r\n  selectAll(mode: any) {\r\n    if (mode) {\r\n      const list = [...this.responsibilityCentersList];\r\n      this.selectedIds = [];\r\n      list.forEach((element) => {\r\n        this.selectedIds.push(element[this.rcIdKey]);\r\n      });\r\n    } else {\r\n      this.selectedIds = [];\r\n    }\r\n    this.setList();\r\n  }\r\n\r\n  setList() {\r\n    const data: any = [];\r\n    const rcList = cloneDeep(this.responsibilityCentersList);\r\n    const selectedIds = cloneDeep(this.selectedIds);\r\n    rcList.forEach((element: any) => {\r\n      if (selectedIds.includes(element[this.rcIdKey])) {\r\n        data.push(element);\r\n      }\r\n    });\r\n    this.selectedResponsibilityCenters = data;\r\n  }\r\n\r\n  checkSelectAll() {\r\n    const data = this.responsibilityCentersList.every((rc: any) =>\r\n      this.selectedIds.includes(rc[this.rcIdKey])\r\n    );\r\n    return data;\r\n  }\r\n\r\n  save(selectedIds: any) {\r\n    this.saveSelectedList.emit(selectedIds);\r\n  }\r\n\r\n  close() {\r\n    this.closeRcList.emit();\r\n  }\r\n}\r\n","<div class=\"add-risk-rc\" [class.animate]=\"animation\">\r\n  <div\r\n    class=\"add-risk-rc-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n  >\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n      Select Responsibility Center(s)\r\n    </div>\r\n  </div>\r\n  <div class=\"add-risk-rc-body\">\r\n    <div class=\"search-block\">\r\n      <i class=\"icons\">&#xe90b;</i>\r\n      <input\r\n        type=\"text\"\r\n        [(ngModel)]=\"search\"\r\n        placeholder=\"Search Responsibility Center\"\r\n      />\r\n    </div>\r\n    <!-- <app-workflow-pagination></app-workflow-pagination> -->\r\n    <ng-container\r\n      *ngIf=\"responsibilityCentersList | search : search as searchList\"\r\n    >\r\n      <div\r\n        class=\"body-top\"\r\n        *ngIf=\"\r\n          !radioSelection &&\r\n          searchList?.length > 0 &&\r\n          search?.trim()?.length === 0\r\n        \"\r\n      >\r\n        <app-cs-checkbox\r\n          [ngValue]=\"checkSelectAll()\"\r\n          (ngValueChange)=\"selectAll($event)\"\r\n          ><strong>{{\r\n            checkSelectAll() ? \"Deselect All\" : \"Select All\"\r\n          }}</strong>\r\n        </app-cs-checkbox>\r\n      </div>\r\n\r\n      <ul\r\n        class=\"add-risk-rc-list\"\r\n        [class.with-selectAll]=\"\r\n          !radioSelection &&\r\n          searchList?.length > 0 &&\r\n          search?.trim()?.length === 0\r\n        \"\r\n        *ngIf=\"searchList?.length > 0\"\r\n      >\r\n        <ng-container *ngIf=\"!radioSelection\">\r\n          <li *ngFor=\"let rc of searchList\" #ulElement>\r\n            <app-cs-checkbox\r\n              [ngValue]=\"selectedIds.includes(rc.item_id)\"\r\n              (ngValueChange)=\"selectRc(rc.item_id, $event)\"\r\n            >\r\n              <ul class=\"add-risk-rc-name\" #listBlock>\r\n                <!-- [style.max-width.px]=\"blockWidth / rc.rc_name\" -->\r\n                <li\r\n                  *ngFor=\"let entity of rc.rc_name; let j = index\"\r\n                  [appTooltip]=\"entity\"\r\n                  placement=\"bottom\"\r\n                  type=\"black\"\r\n                  delay=\"0\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  <i class=\"icons\" *ngIf=\"j !== 0\">&#xe910;</i>{{ entity }}\r\n                </li>\r\n              </ul>\r\n            </app-cs-checkbox>\r\n          </li>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"radioSelection\">\r\n          <li *ngFor=\"let rc of searchList\" #ulElement>\r\n            <app-cs-radio\r\n              (checkedEvent)=\"selectRc(rc.item_id, $event)\"\r\n              [checked]=\"selectedIds.includes(rc.item_id)\"\r\n            >\r\n              <ul class=\"add-risk-rc-name\">\r\n                <li\r\n                  *ngFor=\"let entity of rc.rc_name; let j = index\"\r\n                  [appTooltip]=\"entity\"\r\n                  placement=\"bottom\"\r\n                  type=\"black\"\r\n                  delay=\"0\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  <i class=\"icons\" *ngIf=\"j !== 0\">&#xe910;</i>{{ entity }}\r\n                </li>\r\n              </ul>\r\n            </app-cs-radio>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n      <app-no-data\r\n        *ngIf=\"!searchList?.length\"\r\n        [noDataImage]=\"\r\n          'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n        \"\r\n        [noDataText]=\"'No data to display'\"\r\n      ></app-no-data>\r\n    </ng-container>\r\n\r\n    <app-floating-bar\r\n      [selectedData]=\"selectedResponsibilityCenters\"\r\n      [displayElementKey]=\"'item_name'\"\r\n      [singularText]=\"singularText\"\r\n      [pluralText]=\"pluralText\"\r\n      (closeEvent)=\"save(selectedIds)\"\r\n      (deleteEvent)=\"deleteEvent($event)\"\r\n      (closeList)=\"close()\"\r\n      [isDisabled]=\"\r\n        selectedResponsibilityCenters?.length === 0 ||\r\n        responsibilityCentersList?.length === 0\r\n      \"\r\n    ></app-floating-bar>\r\n  </div>\r\n</div>\r\n\r\n<!-- <button (click)=\"save(selectedIds)\">Next</button> -->\r\n"]}
|
|
@@ -14,7 +14,7 @@ export class RiskClassificationComponent {
|
|
|
14
14
|
{ name: 'Low', value: 1, class: 'low' },
|
|
15
15
|
{ name: 'Low-Medium', value: 2, class: 'low-med' },
|
|
16
16
|
{ name: 'Medium-High', value: 3, class: 'med-high' },
|
|
17
|
-
{ name: 'High', value: 4, class: 'high' }
|
|
17
|
+
{ name: 'High', value: 4, class: 'high' },
|
|
18
18
|
];
|
|
19
19
|
this.riskIntensityList = [
|
|
20
20
|
{ name: 'Not Applicable', value: '0' },
|
|
@@ -33,7 +33,7 @@ export class RiskClassificationComponent {
|
|
|
33
33
|
machineThreat: '0',
|
|
34
34
|
lifeThreat: '0',
|
|
35
35
|
probability: '1',
|
|
36
|
-
identification: '1'
|
|
36
|
+
identification: '1',
|
|
37
37
|
};
|
|
38
38
|
}
|
|
39
39
|
ngOnInit() {
|
|
@@ -55,9 +55,11 @@ export class RiskClassificationComponent {
|
|
|
55
55
|
if (riskMatrices.length !== 6) {
|
|
56
56
|
return -1;
|
|
57
57
|
}
|
|
58
|
-
const impact = riskMatrices[0] * 1 +
|
|
58
|
+
const impact = riskMatrices[0] * 1 +
|
|
59
|
+
riskMatrices[1] * 2 +
|
|
60
|
+
riskMatrices[2] * 2 +
|
|
61
|
+
riskMatrices[3] * 3; // total impact
|
|
59
62
|
const risk = impact * riskMatrices[4] + impact * riskMatrices[5];
|
|
60
|
-
console.log(risk);
|
|
61
63
|
switch (true) {
|
|
62
64
|
case risk <= 9: {
|
|
63
65
|
return 1;
|
|
@@ -76,7 +78,10 @@ export class RiskClassificationComponent {
|
|
|
76
78
|
}
|
|
77
79
|
}
|
|
78
80
|
save() {
|
|
79
|
-
this.saveList.emit({
|
|
81
|
+
this.saveList.emit({
|
|
82
|
+
riskClass: this.currentRiskValue,
|
|
83
|
+
riskMatrix: this.getArrayFromObject(this.selectedValues).join(','),
|
|
84
|
+
});
|
|
80
85
|
}
|
|
81
86
|
close() {
|
|
82
87
|
this.closeList.emit();
|
|
@@ -94,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
94
99
|
}], closeList: [{
|
|
95
100
|
type: Output
|
|
96
101
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"risk-classification.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/risk-classification/risk-classification.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/risk-classification/risk-classification.component.html"],"names":[],"mappings":"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","sourcesContent":["import { cloneDeep } from 'lodash';\r\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n\r\n@Component({\r\n  selector: 'app-risk-classification',\r\n  templateUrl: './risk-classification.component.html',\r\n  styleUrls: ['./risk-classification.component.less', '../../forms.less']\r\n})\r\nexport class RiskClassificationComponent implements OnInit {\r\n  constructor() { }\r\n  animation = true;\r\n  @Input() currentRiskValue : any ;\r\n  @Output() saveList = new EventEmitter();\r\n  @Output() closeList = new EventEmitter();\r\n   riskClassification = [\r\n    {name: 'Low', value: 1, class: 'low' },\r\n    {name: 'Low-Medium', value: 2 , class: 'low-med'},\r\n    {name: 'Medium-High', value: 3, class: 'med-high'},\r\n    {name: 'High', value: 4, class: 'high'}\r\n  ];\r\n  riskIntensityList = [\r\n    { name: 'Not Applicable', value: '0' },\r\n    { name: 'Low', value: '1' },\r\n    { name: 'Medium', value: '2' },\r\n    { name: 'High', value: '3' },\r\n  ];\r\n  identificationList = [\r\n    { name: 'Easy to Identify', value: '1' },\r\n    { name: 'Intermediate', value: '2' },\r\n    { name: 'Difficult', value: '3' },\r\n  ];\r\n  selectedValues = {\r\n    envThreat: '0',\r\n    regThreat : '0',\r\n    machineThreat: '0',\r\n    lifeThreat : '0',\r\n    probability : '1',\r\n    identification: '1'\r\n  };\r\n  ngOnInit(): void {\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 500);\r\n  }\r\n  generateRiskClass(){\r\n   this.currentRiskValue = this.calculateRiskClass(this.getArrayFromObject(this.selectedValues));\r\n  }\r\n  getArrayFromObject(object: object){\r\n    const risk = [];\r\n    for (const value of Object.values(object)){\r\n      risk.push(parseInt(value, 10)); }\r\n    return risk;\r\n  }\r\n  calculateRiskClass(riskMatrices: number[]): number{\r\n    if (riskMatrices.length !== 6 ){return -1 ; }\r\n    const impact  = riskMatrices[0] * 1 + riskMatrices[1] * 2 + riskMatrices[2] * 2 + riskMatrices[3] * 3; // total impact\r\n    const risk = impact * riskMatrices[4] + impact * riskMatrices[5];\r\n    console.log(risk);\r\n    switch (true) {\r\n      case risk <= 9: {\r\n        return 1;\r\n      }\r\n      case risk >= 10 && risk <= 23: {\r\n        return 2;\r\n      }\r\n      case risk >= 24 && risk <= 39: {\r\n        return 3;\r\n      }\r\n      case risk >= 40 && risk <= 144: {\r\n        return 4;\r\n      }\r\n      default:\r\n        return 1;\r\n    }\r\n  }\r\n\r\n  save(){\r\n   this.saveList.emit({riskClass: this.currentRiskValue, riskMatrix: this.getArrayFromObject(this.selectedValues).join(',')});\r\n  }\r\n  close(){\r\n    this.closeList.emit();\r\n  }\r\n}\r\n","<div class=\"risk-classification\" [class.animate]=\"animation\">\r\n    <div class=\"risk-classification-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Risk Calculator</div>\r\n    </div>\r\n\r\n    <div class=\"risk-classification-body\">\r\n        <div class=\"risk-classification-body-inner\">\r\n            <div class=\"risk-classification-switch\">\r\n                <label  *ngFor=\"let idClass of riskClassification\" [ngClass]=\"[idClass.class]\">\r\n                    <input disabled type=\"radio\" [checked]=\"idClass.value === currentRiskValue\" name=\"classification-risk\" [value]=\"idClass.value\">\r\n                    <span>{{idClass?.name}}</span>\r\n                </label>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\" >\r\n                        <label class=\"vx-control-panel\">THREAT TO ENVIRONMENT</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.envThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option *ngFor=\"let list of riskIntensityList\" [value]=\"list.value\" >{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">REGULATORY THREAT</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.regThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">THREAT TO MACHINE</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.machineThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">THREAT TO LOSS OF LIFE</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.lifeThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">PROBABILITY</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.probability\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option  [value]=\"list.value\" *ngFor=\"let list of riskIntensityList|slice:1\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\" >IDENTIFICATION</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.identification\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of identificationList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"risk-classification-footer\">\r\n        <app-floating-bar (closeList)=\"close()\"   (closeEvent)=\"save()\"></app-floating-bar>\r\n    </div>\r\n</div>\r\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"risk-classification.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/risk-classification/risk-classification.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/risk-classification/risk-classification.component.html"],"names":[],"mappings":"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","sourcesContent":["import { cloneDeep } from 'lodash';\r\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-risk-classification',\r\n  templateUrl: './risk-classification.component.html',\r\n  styleUrls: ['./risk-classification.component.less', '../../forms.less'],\r\n})\r\nexport class RiskClassificationComponent implements OnInit {\r\n  constructor() {}\r\n  animation = true;\r\n  @Input() currentRiskValue: any;\r\n  @Output() saveList = new EventEmitter();\r\n  @Output() closeList = new EventEmitter();\r\n  riskClassification = [\r\n    { name: 'Low', value: 1, class: 'low' },\r\n    { name: 'Low-Medium', value: 2, class: 'low-med' },\r\n    { name: 'Medium-High', value: 3, class: 'med-high' },\r\n    { name: 'High', value: 4, class: 'high' },\r\n  ];\r\n  riskIntensityList = [\r\n    { name: 'Not Applicable', value: '0' },\r\n    { name: 'Low', value: '1' },\r\n    { name: 'Medium', value: '2' },\r\n    { name: 'High', value: '3' },\r\n  ];\r\n  identificationList = [\r\n    { name: 'Easy to Identify', value: '1' },\r\n    { name: 'Intermediate', value: '2' },\r\n    { name: 'Difficult', value: '3' },\r\n  ];\r\n  selectedValues = {\r\n    envThreat: '0',\r\n    regThreat: '0',\r\n    machineThreat: '0',\r\n    lifeThreat: '0',\r\n    probability: '1',\r\n    identification: '1',\r\n  };\r\n  ngOnInit(): void {\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 500);\r\n  }\r\n  generateRiskClass() {\r\n    this.currentRiskValue = this.calculateRiskClass(\r\n      this.getArrayFromObject(this.selectedValues)\r\n    );\r\n  }\r\n  getArrayFromObject(object: object) {\r\n    const risk = [];\r\n    for (const value of Object.values(object)) {\r\n      risk.push(parseInt(value, 10));\r\n    }\r\n    return risk;\r\n  }\r\n  calculateRiskClass(riskMatrices: number[]): number {\r\n    if (riskMatrices.length !== 6) {\r\n      return -1;\r\n    }\r\n    const impact =\r\n      riskMatrices[0] * 1 +\r\n      riskMatrices[1] * 2 +\r\n      riskMatrices[2] * 2 +\r\n      riskMatrices[3] * 3; // total impact\r\n    const risk = impact * riskMatrices[4] + impact * riskMatrices[5];\r\n    switch (true) {\r\n      case risk <= 9: {\r\n        return 1;\r\n      }\r\n      case risk >= 10 && risk <= 23: {\r\n        return 2;\r\n      }\r\n      case risk >= 24 && risk <= 39: {\r\n        return 3;\r\n      }\r\n      case risk >= 40 && risk <= 144: {\r\n        return 4;\r\n      }\r\n      default:\r\n        return 1;\r\n    }\r\n  }\r\n\r\n  save() {\r\n    this.saveList.emit({\r\n      riskClass: this.currentRiskValue,\r\n      riskMatrix: this.getArrayFromObject(this.selectedValues).join(','),\r\n    });\r\n  }\r\n  close() {\r\n    this.closeList.emit();\r\n  }\r\n}\r\n","<div class=\"risk-classification\" [class.animate]=\"animation\">\r\n    <div class=\"risk-classification-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Risk Calculator</div>\r\n    </div>\r\n\r\n    <div class=\"risk-classification-body\">\r\n        <div class=\"risk-classification-body-inner\">\r\n            <div class=\"risk-classification-switch\">\r\n                <label  *ngFor=\"let idClass of riskClassification\" [ngClass]=\"[idClass.class]\">\r\n                    <input disabled type=\"radio\" [checked]=\"idClass.value === currentRiskValue\" name=\"classification-risk\" [value]=\"idClass.value\">\r\n                    <span>{{idClass?.name}}</span>\r\n                </label>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\" >\r\n                        <label class=\"vx-control-panel\">THREAT TO ENVIRONMENT</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.envThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option *ngFor=\"let list of riskIntensityList\" [value]=\"list.value\" >{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">REGULATORY THREAT</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.regThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">THREAT TO MACHINE</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.machineThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">THREAT TO LOSS OF LIFE</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.lifeThreat\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of riskIntensityList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"row\">\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\">PROBABILITY</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.probability\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option  [value]=\"list.value\" *ngFor=\"let list of riskIntensityList|slice:1\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n                <div class=\"column\">\r\n                    <div class=\"vx-form-group\">\r\n                        <label class=\"vx-control-panel\" >IDENTIFICATION</label>\r\n                        <cs-select [(ngModel)]=\"selectedValues.identification\" (valueChanged)=\"generateRiskClass()\">\r\n                            <cs-option [value]=\"list.value\" *ngFor=\"let list of identificationList\">{{list.name}}</cs-option>\r\n                        </cs-select>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"risk-classification-footer\">\r\n        <app-floating-bar (closeList)=\"close()\"   (closeEvent)=\"save()\"></app-floating-bar>\r\n    </div>\r\n</div>\r\n"]}
|
|
@@ -14,7 +14,6 @@ export class SelectApproversComponent {
|
|
|
14
14
|
this.selectedApprover = new EventEmitter();
|
|
15
15
|
}
|
|
16
16
|
ngOnInit() {
|
|
17
|
-
console.log('this.levels ==>', this.levels);
|
|
18
17
|
this.approvalLevelName = `Level ${this.levels - 1}`;
|
|
19
18
|
if (this.editApprovalData?.length) {
|
|
20
19
|
this.approvalLevelName = this.editApprovalData[0]?.alias_name;
|
|
@@ -76,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
76
75
|
}], selectedApprover: [{
|
|
77
76
|
type: Output
|
|
78
77
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-approvers.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/select-approvers/select-approvers.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/select-approvers/select-approvers.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;AAO/E,MAAM,OAAO,wBAAwB;IAUnC;QATA,sBAAiB,GAAW,EAAE,CAAC;QAC/B,qBAAgB,GAAU,EAAE,CAAC;QAC7B,iBAAY,GAAW,YAAY,CAAC;QAE3B,WAAM,GAAW,CAAC,CAAC;QAElB,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,qBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;IAEjC,CAAC;IAEhB,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,iBAAiB,GAAG,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpD,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,EAAE;YACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC;YAC9D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC;SACpD;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;IAClC,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,+BAA+B;QAE/B,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,iBAAiB,CAAC,SAAc;QAC9B,IAAI,aAAa,GAAU,EAAE,CAAC;QAC9B,aAAa,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;YACzC,OAAO;gBACL,SAAS,EAAE,GAAG,CAAC,SAAS;gBACxB,WAAW,EAAE,GAAG,CAAC,WAAW;gBAC5B,aAAa,EAAE,KAAK;gBACpB,WAAW,EAAE,KAAK;gBAClB,WAAW,EAAE,KAAK;aACnB,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IACtC,CAAC;IAED,YAAY,CAAC,IAA4C;QACvD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG;YACtB;gBACE,SAAS,EAAE,KAAK;gBAChB,IAAI,EAAE,IAAI,CAAC,YAAY;gBACvB,aAAa,EAAE,KAAK;gBACpB,MAAM,EAAE,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;gBAClC,UAAU,EACR,IAAI,CAAC,iBAAiB,KAAK,EAAE;oBAC3B,CAAC,CAAC,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC5B,CAAC,CAAC,IAAI,CAAC,iBAAiB;aAC7B;SACF,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACpD,CAAC;;qHAhEU,wBAAwB;yGAAxB,wBAAwB,6PCPrC,o5LAuEA;2FDhEa,wBAAwB;kBALpC,SAAS;+BACE,sBAAsB;0EAQvB,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBACG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-select-approvers',\r\n  templateUrl: './select-approvers.component.html',\r\n  styleUrls: ['./select-approvers.component.less'],\r\n})\r\nexport class SelectApproversComponent implements OnInit {\r\n  approvalLevelName: string = '';\r\n  approversPayload: any[] = [];\r\n  selectedType: string = 'SEQUENTIAL';\r\n  @Input() allApprovers!: any;\r\n  @Input() levels: number = 1;\r\n  @Input() editApprovalData!: any;\r\n  @Output() closeSelectApprover = new EventEmitter();\r\n  @Output() selectedApprover = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    console.log('this.levels ==>', this.levels);\r\n    this.approvalLevelName = `Level ${this.levels - 1}`;\r\n    if (this.editApprovalData?.length) {\r\n      this.approvalLevelName = this.editApprovalData[0]?.alias_name;\r\n      this.selectedType = this.editApprovalData[0]?.type;\r\n    }\r\n  }\r\n\r\n  closeUserList() {\r\n    this.closeSelectApprover.emit();\r\n  }\r\n\r\n  selectedUsers(event: any) {\r\n    // this.generatePayload(event);\r\n\r\n    this.generateApprovers(event.users);\r\n  }\r\n\r\n  generateApprovers(approvers: any) {\r\n    let approversList: any[] = [];\r\n    approversList = approvers.map((ele: any) => {\r\n      return {\r\n        member_id: ele.member_id,\r\n        member_name: ele.member_name,\r\n        approval_flag: false,\r\n        reject_flag: false,\r\n        remove_flag: false,\r\n      };\r\n    });\r\n    this.generatePayload(approversList);\r\n  }\r\n\r\n  approvalType(type: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL') {\r\n    this.selectedType = type;\r\n  }\r\n\r\n  generatePayload(event: any) {\r\n    this.approversPayload = [];\r\n    this.approversPayload = [\r\n      {\r\n        approvers: event,\r\n        type: this.selectedType,\r\n        approval_done: false,\r\n        level1: `Level ${this.levels - 1}`,\r\n        alias_name:\r\n          this.approvalLevelName === ''\r\n            ? `Level ${this.levels - 1}`\r\n            : this.approvalLevelName,\r\n      },\r\n    ];\r\n    this.selectedApprover.emit(this.approversPayload);\r\n  }\r\n}\r\n","<div class=\"select-approvers-dialog\">\r\n    <div class=\"select-approvers-dialog-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Approvers & Approval Workflow</div>\r\n    </div>\r\n    <div class=\"select-approvers-dialog-body\">\r\n        <div class=\"select-approvers-dialog-body-inner\">\r\n            <!-- Step 1 -->\r\n            <div class=\"approvers-form-group vx-mb-2\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 1: APPROVAL LEVEL NAME <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <input [(ngModel)]=\"approvalLevelName\" class=\"textField\" type=\"text\" placeholder=\"Level 1\" />\r\n            </div>\r\n\r\n            <!-- Step 2 -->\r\n            <div class=\"approvers-form-group vx-mb-2\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 2: APPROVAL WORKFLOW TYPE <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <div class=\"vx-d-flex vx-align-center vx-justify-between\">\r\n                    <app-cs-radio [checked]=\"selectedType === 'SEQUENTIAL'\">\r\n                        <div (click)=\"approvalType('SEQUENTIAL')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/sequential.svg\" />\r\n                                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">SEQUENTIAL</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy would be sent for approval one at a time in the sequence defined by you.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                    <app-cs-radio [checked]=\"selectedType === 'ROUNDROBIN'\">\r\n                        <div (click)=\"approvalType('ROUNDROBIN')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/round-robin.svg\" />\r\n                                <div  class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">ROUND-ROBIN</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy will be sent for approval to all approvers at the same time. However, it is mandatory for all approvers to take action.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                    <app-cs-radio [checked]=\"selectedType === 'ANYONE'\">\r\n                        <div (click)=\"approvalType('ANYONE')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/anyone.svg\" />\r\n                                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">ANY ONE</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy will be sent for approval to all approvers at the same time. If anyone of the approver approves the policy, it will be considered as approved.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Step 3 -->\r\n            <div class=\"approvers-form-group\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 3: APPROVERS <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <div class=\"approvers-user-group\">\r\n                    <!-- <app-owner-list  [listHeading]=\"'Select Approvers'\" [singularText]=\"'User selected'\" [pluralText]=\"'Users selected'\" [usersList]=\"allApprovers\" [showWorkflow]=\"true\" [usersList]=\"allApprovers\" [userIdKey]=\"'member_id'\" [itemEmailKey]=\"'member_email'\" [itemNameKey]=\"'member_name'\" [mode]=\"'CREATE'\"></app-owner-list> -->\r\n                    <user-group-list [userlist]=\"allApprovers\" [groupEnabled]=\"false\" (cancel)=\"closeUserList()\" (save)=\"selectedUsers($event)\" [selectedUsers] = \"editApprovalData[0]?.approvers\r\n                    \" [fromApprovalWorkflow]=\"true\" [approvalType]=\"selectedType\"></user-group-list>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n"]}
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-approvers.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/select-approvers/select-approvers.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/select-approvers/select-approvers.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;AAO/E,MAAM,OAAO,wBAAwB;IAUnC;QATA,sBAAiB,GAAW,EAAE,CAAC;QAC/B,qBAAgB,GAAU,EAAE,CAAC;QAC7B,iBAAY,GAAW,YAAY,CAAC;QAE3B,WAAM,GAAW,CAAC,CAAC;QAElB,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,qBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;IAEjC,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,iBAAiB,GAAG,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpD,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,EAAE;YACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC;YAC9D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC;SACpD;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;IAClC,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,+BAA+B;QAE/B,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,iBAAiB,CAAC,SAAc;QAC9B,IAAI,aAAa,GAAU,EAAE,CAAC;QAC9B,aAAa,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;YACzC,OAAO;gBACL,SAAS,EAAE,GAAG,CAAC,SAAS;gBACxB,WAAW,EAAE,GAAG,CAAC,WAAW;gBAC5B,aAAa,EAAE,KAAK;gBACpB,WAAW,EAAE,KAAK;gBAClB,WAAW,EAAE,KAAK;aACnB,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IACtC,CAAC;IAED,YAAY,CAAC,IAA4C;QACvD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG;YACtB;gBACE,SAAS,EAAE,KAAK;gBAChB,IAAI,EAAE,IAAI,CAAC,YAAY;gBACvB,aAAa,EAAE,KAAK;gBACpB,MAAM,EAAE,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;gBAClC,UAAU,EACR,IAAI,CAAC,iBAAiB,KAAK,EAAE;oBAC3B,CAAC,CAAC,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC5B,CAAC,CAAC,IAAI,CAAC,iBAAiB;aAC7B;SACF,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACpD,CAAC;;qHA/DU,wBAAwB;yGAAxB,wBAAwB,6PCPrC,o5LAuEA;2FDhEa,wBAAwB;kBALpC,SAAS;+BACE,sBAAsB;0EAQvB,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBACG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-select-approvers',\r\n  templateUrl: './select-approvers.component.html',\r\n  styleUrls: ['./select-approvers.component.less'],\r\n})\r\nexport class SelectApproversComponent implements OnInit {\r\n  approvalLevelName: string = '';\r\n  approversPayload: any[] = [];\r\n  selectedType: string = 'SEQUENTIAL';\r\n  @Input() allApprovers!: any;\r\n  @Input() levels: number = 1;\r\n  @Input() editApprovalData!: any;\r\n  @Output() closeSelectApprover = new EventEmitter();\r\n  @Output() selectedApprover = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    this.approvalLevelName = `Level ${this.levels - 1}`;\r\n    if (this.editApprovalData?.length) {\r\n      this.approvalLevelName = this.editApprovalData[0]?.alias_name;\r\n      this.selectedType = this.editApprovalData[0]?.type;\r\n    }\r\n  }\r\n\r\n  closeUserList() {\r\n    this.closeSelectApprover.emit();\r\n  }\r\n\r\n  selectedUsers(event: any) {\r\n    // this.generatePayload(event);\r\n\r\n    this.generateApprovers(event.users);\r\n  }\r\n\r\n  generateApprovers(approvers: any) {\r\n    let approversList: any[] = [];\r\n    approversList = approvers.map((ele: any) => {\r\n      return {\r\n        member_id: ele.member_id,\r\n        member_name: ele.member_name,\r\n        approval_flag: false,\r\n        reject_flag: false,\r\n        remove_flag: false,\r\n      };\r\n    });\r\n    this.generatePayload(approversList);\r\n  }\r\n\r\n  approvalType(type: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL') {\r\n    this.selectedType = type;\r\n  }\r\n\r\n  generatePayload(event: any) {\r\n    this.approversPayload = [];\r\n    this.approversPayload = [\r\n      {\r\n        approvers: event,\r\n        type: this.selectedType,\r\n        approval_done: false,\r\n        level1: `Level ${this.levels - 1}`,\r\n        alias_name:\r\n          this.approvalLevelName === ''\r\n            ? `Level ${this.levels - 1}`\r\n            : this.approvalLevelName,\r\n      },\r\n    ];\r\n    this.selectedApprover.emit(this.approversPayload);\r\n  }\r\n}\r\n","<div class=\"select-approvers-dialog\">\r\n    <div class=\"select-approvers-dialog-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Approvers & Approval Workflow</div>\r\n    </div>\r\n    <div class=\"select-approvers-dialog-body\">\r\n        <div class=\"select-approvers-dialog-body-inner\">\r\n            <!-- Step 1 -->\r\n            <div class=\"approvers-form-group vx-mb-2\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 1: APPROVAL LEVEL NAME <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <input [(ngModel)]=\"approvalLevelName\" class=\"textField\" type=\"text\" placeholder=\"Level 1\" />\r\n            </div>\r\n\r\n            <!-- Step 2 -->\r\n            <div class=\"approvers-form-group vx-mb-2\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 2: APPROVAL WORKFLOW TYPE <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <div class=\"vx-d-flex vx-align-center vx-justify-between\">\r\n                    <app-cs-radio [checked]=\"selectedType === 'SEQUENTIAL'\">\r\n                        <div (click)=\"approvalType('SEQUENTIAL')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/sequential.svg\" />\r\n                                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">SEQUENTIAL</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy would be sent for approval one at a time in the sequence defined by you.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                    <app-cs-radio [checked]=\"selectedType === 'ROUNDROBIN'\">\r\n                        <div (click)=\"approvalType('ROUNDROBIN')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/round-robin.svg\" />\r\n                                <div  class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">ROUND-ROBIN</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy will be sent for approval to all approvers at the same time. However, it is mandatory for all approvers to take action.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                    <app-cs-radio [checked]=\"selectedType === 'ANYONE'\">\r\n                        <div (click)=\"approvalType('ANYONE')\"  class=\"approval-type vx-d-flex vx-align-center vx-justify-between vx-p-2 vx-pl-3 vx-pr-3\">\r\n                            <div class=\"vx-d-flex vx-align-center\">\r\n                                <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/anyone.svg\" />\r\n                                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase\">ANY ONE</div>\r\n                                <i class=\"icons vx-fs-12 vx-txt-blue vx-ml-2\" [appTooltip]=\"'The policy will be sent for approval to all approvers at the same time. If anyone of the approver approves the policy, it will be considered as approved.'\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i>\r\n                            </div>\r\n                            <div class=\"vx-d-block\">\r\n                                <span class=\"circle-selection\"></span>\r\n                                <i class=\"icons ckeck-selection vx-fs-16\">&#xe949;</i>\r\n                            </div>\r\n                        </div>\r\n                    </app-cs-radio>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Step 3 -->\r\n            <div class=\"approvers-form-group\">\r\n                <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">STEP 3: APPROVERS <span class=\"vx-fs-14 vx-txt-red\">*</span></div>\r\n                <div class=\"approvers-user-group\">\r\n                    <!-- <app-owner-list  [listHeading]=\"'Select Approvers'\" [singularText]=\"'User selected'\" [pluralText]=\"'Users selected'\" [usersList]=\"allApprovers\" [showWorkflow]=\"true\" [usersList]=\"allApprovers\" [userIdKey]=\"'member_id'\" [itemEmailKey]=\"'member_email'\" [itemNameKey]=\"'member_name'\" [mode]=\"'CREATE'\"></app-owner-list> -->\r\n                    <user-group-list [userlist]=\"allApprovers\" [groupEnabled]=\"false\" (cancel)=\"closeUserList()\" (save)=\"selectedUsers($event)\" [selectedUsers] = \"editApprovalData[0]?.approvers\r\n                    \" [fromApprovalWorkflow]=\"true\" [approvalType]=\"selectedType\"></user-group-list>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
1
|
+
import { Component, Input, Output, EventEmitter, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/forms";
|
|
4
4
|
import * as i2 from "@angular/common";
|
|
@@ -36,7 +36,6 @@ export class UserRadioListComponent {
|
|
|
36
36
|
}, 300);
|
|
37
37
|
}
|
|
38
38
|
selectUser(user) {
|
|
39
|
-
console.log("uuuuu", user);
|
|
40
39
|
this.selectedUser = user;
|
|
41
40
|
}
|
|
42
41
|
deleteEvent(event) {
|
|
@@ -81,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
81
80
|
}], headerText: [{
|
|
82
81
|
type: Input
|
|
83
82
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users-radio-list.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/users-radio-list/users-radio-list.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/users-radio-list/users-radio-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,GAGb,MAAM,eAAe,CAAC;;;;;;;;;;AAOvB,MAAM,OAAO,sBAAsB;IAmBjC;QAlBS,cAAS,GAAG,EAAE,CAAC;QACf,kBAAa,GAAQ,EAAE,CAAC;QACxB,cAAS,GAAG,EAAE,CAAC;QACf,gBAAW,GAAG,EAAE,CAAC;QACjB,iBAAY,GAAG,EAAE,CAAC;QACjB,qBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;QACtC,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QACrC,eAAU,GAAU,EAAE,CAAC;QAEvB,gBAAW,GAAU,EAAE,CAAC;QACxB,gBAAW,GAAU,EAAE,CAAC;QACxB,eAAU,GAAU,EAAE,CAAC;QAEvB,eAAU,GAAW,aAAa,CAAC;QAE5C,WAAM,GAAG,EAAE,CAAC;QACZ,gBAAW,GAAU,EAAE,CAAC;QACxB,cAAS,GAAG,KAAK,CAAC;IACH,CAAC;IAEhB,WAAW;QACT,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IACD,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IACD,IAAI;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IAED,KAAK;QACH,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;;mHA5CU,sBAAsB;uGAAtB,sBAAsB,4eCfnC,s9FAiCM;2FDlBO,sBAAsB;kBALlC,SAAS;+BACE,sBAAsB;0EAKvB,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACI,gBAAgB;sBAAzB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,UAAU;sBAAlB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  OnChanges,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { cloneDeep } from 'lodash';\r\n@Component({\r\n  selector: 'app-users-radio-list',\r\n  templateUrl: './users-radio-list.component.html',\r\n  styleUrls: ['./users-radio-list.component.less'],\r\n})\r\nexport class UserRadioListComponent implements OnInit, OnChanges {\r\n  @Input() usersList = [];\r\n  @Input() selectedUsers: any = '';\r\n  @Input() userIdKey = '';\r\n  @Input() itemNameKey = '';\r\n  @Input() itemEmailKey = '';\r\n  @Output() saveSelectedList = new EventEmitter();\r\n  @Output() closeUsersList = new EventEmitter();\r\n  @Input() disabledId: any[] = [];\r\n  @Input() fromResponsibility: any;\r\n  @Input() reviewerIds: any[] = [];\r\n  @Input() overseerIds: any[] = [];\r\n  @Input() assignorId: any[] = [];\r\n  selectedUser: any;\r\n  @Input() headerText: string = 'Select User';\r\n\r\n  search = '';\r\n  selectedIds: any[] = [];\r\n  animation = false;\r\n  constructor() {}\r\n\r\n  ngOnChanges(): void {\r\n    this.selectedUser = this.selectedUsers[0];\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.animation = true;\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n  }\r\n\r\n  selectUser(user: any) {\r\n    this.selectedUser = user;\r\n  }\r\n  deleteEvent(event: any) {\r\n    this.selectedUser = '';\r\n  }\r\n  save() {\r\n    this.saveSelectedList.emit(this.selectedUser);\r\n  }\r\n\r\n  close() {\r\n    this.closeUsersList.emit();\r\n  }\r\n}\r\n","<div class=\"add-risk-user-radio-list\" [class.animate]=\"animation\">\r\n    <div class=\"add-risk-user-radio-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">{{headerText}}</div>\r\n        <!-- <button class=\"add-risk-user-radio-list-close\" (click)=\"close()\">\r\n            <i class=\"icons\">&#xe90d;</i>\r\n        </button> -->\r\n    </div>\r\n    <div *ngIf=\"usersList?.length > 0\" class=\"add-risk-user-radio-list-body\">\r\n        <div class=\"search-block\">\r\n            <i class=\"icons\">&#xe90b;</i>\r\n            <input type=\"text\" [(ngModel)]=\"search\" placeholder=\"Search User\" />\r\n        </div>\r\n        <ng-container *ngIf=\"(usersList | filter:search) as searchList\">\r\n            <ul class=\"user-radio-list\" *ngIf=\"searchList?.length >0 \">\r\n                <li *ngFor=\"let user of usersList | filter:search\" [appTooltip]=\"user | tooltipMessage:fromResponsibility:reviewerIds:overseerIds:assignorId:[]:'my_member_id':disabledId?.includes(user[userIdKey])\" placement=\"bottom-left\" type=\"black\"\r\n                delay=\"0\" [tooltipMandatory]=true >\r\n                    <app-cs-radio (checkedEvent)=\"selectUser(user)\" [name]=\"'category'\"  [class.disabled]=\"(disabledId?.includes(user[userIdKey]))\"\r\n                        [checked]=\"selectedUser && (selectedUser[userIdKey]== user[userIdKey])\">\r\n                        <span class=\"name\" >\r\n                            {{user[itemNameKey] }}</span>\r\n                    </app-cs-radio>\r\n                </li>\r\n            </ul>\r\n            <app-no-data *ngIf=\"searchList?.length === 0\" [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\" [noDataText]=\"'No Users Found'\"></app-no-data>\r\n        </ng-container>\r\n \r\n        <app-floating-bar [selectedData]=\"selectedUser ? [selectedUser]:[]\" [displayElementKey]=\"itemNameKey\" [elementId]=\"userIdKey\" [singularText]=\"'User selected'\" [pluralText]=\"'Users selected'\" (closeEvent)=\"save()\" (closeList)=\"close()\" (deleteEvent)=\"deleteEvent($event)\" [isDisabled]=\"usersList?.length === 0 || (selectedUser ? [selectedUser]:[])?.length === 0\"></app-floating-bar>\r\n    </div>\r\n    <div class=\"add-risk-user-radio-list-body noUser\" *ngIf=\"usersList?.length === 0\">\r\n        <app-no-data [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\" [noDataText]=\"'No Users Found'\"></app-no-data>\r\n \r\n        <app-floating-bar [selectedData]=\"selectedUser ? [selectedUser]:[]\" [displayElementKey]=\"itemNameKey\" [elementId]=\"userIdKey\" [singularText]=\"'User selected'\" [pluralText]=\"'Users selected'\" (closeEvent)=\"save()\" (closeList)=\"close()\" (deleteEvent)=\"deleteEvent($event)\" [isDisabled]=\"usersList?.length === 0 || (selectedUser ? [selectedUser]:[])?.length === 0\"></app-floating-bar>\r\n    </div>\r\n</div>"]}
|
|
@@ -7,9 +7,6 @@ export class CsSwitchComponent {
|
|
|
7
7
|
constructor() {
|
|
8
8
|
this.ngValueChange = new EventEmitter();
|
|
9
9
|
}
|
|
10
|
-
ngOnInit() {
|
|
11
|
-
// console.log(this.value);
|
|
12
|
-
}
|
|
13
10
|
valueChanged() {
|
|
14
11
|
this.ngValueChange.emit(this.ngValue);
|
|
15
12
|
}
|
|
@@ -32,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
32
29
|
}], position: [{
|
|
33
30
|
type: Input
|
|
34
31
|
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Mtc3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3VpLWtpdC9mb3JtZ3JvdXAvY3Mtc3dpdGNoL2NzLXN3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi91aS1raXQvZm9ybWdyb3VwL2NzLXN3aXRjaC9jcy1zd2l0Y2guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFPdkUsTUFBTSxPQUFPLGlCQUFpQjtJQU81QjtRQUhVLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUduQyxDQUFDO0lBRWhCLFlBQVk7UUFDVixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7OEdBWFUsaUJBQWlCO2tHQUFqQixpQkFBaUIsZ09DUDlCLDB5Q0E4QkE7MkZEdkJhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxlQUFlOzBFQUtoQixRQUFRO3NCQUFoQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0ksYUFBYTtzQkFBdEIsTUFBTTtnQkFDRSxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtY3Mtc3dpdGNoJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY3Mtc3dpdGNoLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jcy1zd2l0Y2guY29tcG9uZW50Lmxlc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENzU3dpdGNoQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBkaXNhYmxlZCE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgbmdWYWx1ZTogYW55O1xyXG4gIEBJbnB1dCgpIHZhbHVlOiBhbnk7XHJcbiAgQE91dHB1dCgpIG5nVmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICBASW5wdXQoKSB0b29sdGlwTWVzc2FnZTogYW55O1xyXG4gIEBJbnB1dCgpIHBvc2l0aW9uOiBhbnk7XHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG5cclxuICB2YWx1ZUNoYW5nZWQoKSB7XHJcbiAgICB0aGlzLm5nVmFsdWVDaGFuZ2UuZW1pdCh0aGlzLm5nVmFsdWUpO1xyXG4gIH1cclxufVxyXG4iLCI8bGFiZWwgY2xhc3M9XCJjcy1zd2l0Y2hcIiBbY2xhc3MudG9wXT1cInBvc2l0aW9uID09ICd0b3AnXCI+XHJcbiAgPCEtLSBbY2xhc3MubGFyZ2VdPVwibGFyZ2VcIiAtLT5cclxuICA8c3BhbiBjbGFzcz1cInZhbHVlXCI+XHJcbiAgICA8c3BhbiBbaW5uZXJIVE1MXT1cInZhbHVlXCIgKm5nSWY9XCJ2YWx1ZSAhPSB1bmRlZmluZWRcIj48L3NwYW4+XHJcbiAgICA8IS0tIDxzcGFuIGNsYXNzPVwibm90aWZpY2F0aW9uXCIgKm5nSWY9XCIhdG9vbHRpcE1lc3NhZ2VcIiBbYXBwVG9vbHRpcF09XCJ0b29sdGlwTWVzc2FnZVwiIHBsYWNlbWVudD1cImJvdHRvbS1yaWdodFwiIGRlbGF5PVwiMFwiIHR5cGU9XCJibGFja1wiIFt0b29sdGlwTWFuZGF0b3J5XT1cInRydWVcIj5cclxuICAgICAgICA8aSBjbGFzcz1cInZjLWljb25zXCI+JiN4ZTlmMzs8L2k+XHJcbiAgICAgIDwvc3Bhbj4gLS0+XHJcbiAgPC9zcGFuPlxyXG4gIDwhLS0gW2NsYXNzLmxhc3RdPVwibGFzdFwiIC0tPlxyXG4gIDxzcGFuIGNsYXNzPVwic3dpdGNoXCIgKm5nSWY9XCJ0b29sdGlwTWVzc2FnZSA9PT0gJycgfHwgdG9vbHRpcE1lc3NhZ2UgPT09IHVuZGVmaW5lZFwiPlxyXG4gICAgPGlucHV0IHR5cGU9XCJjaGVja2JveFwiIFsobmdNb2RlbCldPVwibmdWYWx1ZVwiIChuZ01vZGVsQ2hhbmdlKT1cInZhbHVlQ2hhbmdlZCgpXCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgLz5cclxuICAgIDxzcGFuIGNsYXNzPVwic3dpdGNoLWJveFwiPlxyXG4gICAgICA8c3BhbiBjbGFzcz1cInN3aXRjaC1iYWxsXCI+PC9zcGFuPlxyXG4gICAgPC9zcGFuPlxyXG4gIDwvc3Bhbj5cclxuICA8c3BhblxyXG4gICAgY2xhc3M9XCJzd2l0Y2hcIlxyXG4gICAgKm5nSWY9XCJ0b29sdGlwTWVzc2FnZSAhPT0gJycgJiYgdG9vbHRpcE1lc3NhZ2UgIT09IHVuZGVmaW5lZFwiXHJcbiAgICBbYXBwVG9vbHRpcF09XCJ0b29sdGlwTWVzc2FnZVwiXHJcbiAgICBwbGFjZW1lbnQ9XCJib3R0b20tcmlnaHRcIlxyXG4gICAgZGVsYXk9XCIwXCJcclxuICAgIHR5cGU9XCJibGFja1wiXHJcbiAgICBbdG9vbHRpcE1hbmRhdG9yeV09XCJ0cnVlXCJcclxuICA+XHJcbiAgICA8aW5wdXQgdHlwZT1cImNoZWNrYm94XCIgWyhuZ01vZGVsKV09XCJuZ1ZhbHVlXCIgKG5nTW9kZWxDaGFuZ2UpPVwidmFsdWVDaGFuZ2VkKClcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiAvPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJzd2l0Y2gtYm94XCI+XHJcbiAgICAgIDxzcGFuIGNsYXNzPVwic3dpdGNoLWJhbGxcIj48L3NwYW4+XHJcbiAgICA8L3NwYW4+XHJcbiAgPC9zcGFuPlxyXG48L2xhYmVsPlxyXG4iXX0=
|
|
@@ -8,7 +8,6 @@ export class PopoverLongpressDirective {
|
|
|
8
8
|
}
|
|
9
9
|
mousedown(event) {
|
|
10
10
|
this.currentTime = Date.now();
|
|
11
|
-
// console.log('Current Time', this.currentTime);
|
|
12
11
|
this.timer = setInterval(() => {
|
|
13
12
|
if (Date.now() - this.currentTime > 1000) {
|
|
14
13
|
this.longPressPopover.emit();
|
|
@@ -20,7 +19,6 @@ export class PopoverLongpressDirective {
|
|
|
20
19
|
mouseup() {
|
|
21
20
|
clearInterval(this.timer);
|
|
22
21
|
this.currentTime = undefined;
|
|
23
|
-
// console.log('Hold Time', Date.now() - this.currentTime);
|
|
24
22
|
}
|
|
25
23
|
getEventPosition(event) {
|
|
26
24
|
this.popoverService.positionX = event.clientX;
|
|
@@ -43,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
43
41
|
type: HostListener,
|
|
44
42
|
args: ['mouseup']
|
|
45
43
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1sb25ncHJlc3MuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvdWkta2l0L3BvcG92ZXIvcG9wb3Zlci1sb25ncHJlc3MuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU05RSxNQUFNLE9BQU8seUJBQXlCO0lBTXBDLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUR4QyxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0lBQ0EsQ0FBQztJQUNmLFNBQVMsQ0FBQyxLQUFVO1FBQ3pELElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzlCLElBQUksQ0FBQyxLQUFLLEdBQUcsV0FBVyxDQUFDLEdBQUcsRUFBRTtZQUM1QixJQUFJLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksRUFBRTtnQkFDeEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxDQUFDO2dCQUM3QixhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUMxQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLENBQUM7YUFDOUI7UUFDSCxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDVCxDQUFDO0lBQ3dCLE9BQU87UUFDOUIsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLFNBQVMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsS0FBVTtRQUN6QixJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzlDLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUM7SUFDaEQsQ0FBQzs7c0hBeEJVLHlCQUF5QjswR0FBekIseUJBQXlCOzJGQUF6Qix5QkFBeUI7a0JBSHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtpQkFDbEM7cUdBTVcsZ0JBQWdCO3NCQUF6QixNQUFNO2dCQUVnQyxTQUFTO3NCQUEvQyxZQUFZO3VCQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFVWixPQUFPO3NCQUEvQixZQUFZO3VCQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUG9wb3ZlclNlcnZpY2UgfSBmcm9tICcuL3BvcG92ZXIuc2VydmljZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1thcHBQb3BvdmVyTG9uZ3ByZXNzXScsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQb3BvdmVyTG9uZ3ByZXNzRGlyZWN0aXZlIHtcclxuICBnZXRUaW1lOiBhbnk7XHJcbiAgY3VycmVudFRpbWU6IGFueTtcclxuXHJcbiAgdGltZXI6IGFueTtcclxuICBAT3V0cHV0KCkgbG9uZ1ByZXNzUG9wb3ZlciA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcG9wb3ZlclNlcnZpY2U6IFBvcG92ZXJTZXJ2aWNlKSB7fVxyXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlZG93bicsIFsnJGV2ZW50J10pIG1vdXNlZG93bihldmVudDogYW55KSB7XHJcbiAgICB0aGlzLmN1cnJlbnRUaW1lID0gRGF0ZS5ub3coKTtcclxuICAgIHRoaXMudGltZXIgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgIGlmIChEYXRlLm5vdygpIC0gdGhpcy5jdXJyZW50VGltZSA+IDEwMDApIHtcclxuICAgICAgICB0aGlzLmxvbmdQcmVzc1BvcG92ZXIuZW1pdCgpO1xyXG4gICAgICAgIGNsZWFySW50ZXJ2YWwodGhpcy50aW1lcik7XHJcbiAgICAgICAgdGhpcy5nZXRFdmVudFBvc2l0aW9uKGV2ZW50KTtcclxuICAgICAgfVxyXG4gICAgfSwgMTApO1xyXG4gIH1cclxuICBASG9zdExpc3RlbmVyKCdtb3VzZXVwJykgbW91c2V1cCgpIHtcclxuICAgIGNsZWFySW50ZXJ2YWwodGhpcy50aW1lcik7XHJcbiAgICB0aGlzLmN1cnJlbnRUaW1lID0gdW5kZWZpbmVkO1xyXG4gIH1cclxuICBnZXRFdmVudFBvc2l0aW9uKGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMucG9wb3ZlclNlcnZpY2UucG9zaXRpb25YID0gZXZlbnQuY2xpZW50WDtcclxuICAgIHRoaXMucG9wb3ZlclNlcnZpY2UucG9zaXRpb25ZID0gZXZlbnQuY2xpZW50WTtcclxuICB9XHJcbn1cclxuIl19
|