vcomply-workflow-engine 6.1.77 → 6.1.78
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +1 -2
- package/esm2022/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.mjs +11 -6
- package/fesm2022/vcomply-workflow-engine.mjs +10 -6
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/package.json +1 -1
package/esm2022/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs
CHANGED
|
@@ -268,7 +268,6 @@ export class FrequencyContainerComponent {
|
|
|
268
268
|
onFrequencySelected(event) {
|
|
269
269
|
this.frequencyData = event;
|
|
270
270
|
this.isNextDisabled = this.isInvalid();
|
|
271
|
-
console.log(this.frequencyData, 'On Completiioon');
|
|
272
271
|
}
|
|
273
272
|
openedRadio(event) {
|
|
274
273
|
this.openedRadioForm = event;
|
|
@@ -303,4 +302,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
303
302
|
}], onCompletionResponsibility: [{
|
|
304
303
|
type: Input
|
|
305
304
|
}] } });
|
|
306
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-container/frequency-container.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-container/frequency-container.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,GAEb,MAAM,eAAe,CAAC;AACvB,OAAO,MAAM,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;;AASnC,MAAM,OAAO,2BAA2B;IA6DtC,YACU,gBAAkC,EAClC,QAAyB;QADzB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,aAAQ,GAAR,QAAQ,CAAiB;QA9DnC,iBAAY,GAAG,OAAO,CAAC;QACvB,mBAAc,GAAG,SAAS,CAAC;QAGjB,sBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC5C,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,SAAI,GAAQ,EAAE,CAAC;QAEf,aAAQ,GAAgC,gBAAgB,CAAC;QAKlE,kBAAa,GAAG;YACd;gBACE,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,OAAO;aACd;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE,SAAS;aAChB;YACD;gBACE,IAAI,EAAE,WAAW;gBACjB,IAAI,EAAE,WAAW;aAClB;YACD;gBACE,IAAI,EAAE,UAAU;gBAChB,IAAI,EAAE,UAAU;aACjB;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,IAAI,EAAE,UAAU;gBAChB,IAAI,EAAE,SAAS;aAChB;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,IAAI,EAAE,kBAAkB;gBACxB,IAAI,EAAE,aAAa;aACpB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE,SAAS;aAChB;SACF,CAAC;QAGF,mBAAc,GAAQ,KAAK,CAAC;QAE5B,oBAAe,GAAY,KAAK,CAAC;IAI9B,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAC/D,+BAA+B,CAChC,CAAC;QACF,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,IAAI,EAAE,EAAE;YACvC,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;QACD,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,aAAa,EAAE,SAAS,CAAC,CAAC;QAC1D,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ,EAAE;YACzB,YAAY,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;gBACpC,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CACxC,CAAC,YAAiB,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,IAAI,OAAO,CACpD,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;SACJ;QACD,MAAM,aAAa,GAAG,CAAC,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,CAAC,CAAC;QACpE,IAAI,IAAI,CAAC,IAAI,IAAI,mBAAmB,EAAE;YACpC,IAAI,CAAC,YAAY;gBACf,IAAI,CAAC,gBAAgB,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACtE,IAAI,CAAC,cAAc;gBACjB,IAAI,CAAC,gBAAgB,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;YAE1E,aAAa,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;gBACrC,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CACxC,CAAC,YAAiB,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,IAAI,OAAO,CACpD,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,qBAAqB,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,iBAAiB;QACf,MAAM,gBAAgB,GAAG,QAAQ,CAC/B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAC5C,CAAC;QAEF,QAAQ,gBAAgB,EAAE;YACxB,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;gBAC9B,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;gBACnC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;gBAC5B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;gBAChC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;gBAC7B,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;gBACjC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;gBAC9B,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC;gBAClC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;gBAC7B,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;gBACnC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;gBAC5B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;gBAChC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;gBAClC,IAAI,CAAC,cAAc,GAAG,qBAAqB,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC;gBACpE,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;gBAChC,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;gBACpC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;gBAC7B,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;gBACjC,MAAM;YACR,KAAK,CAAC;gBACJ,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC;gBAC/B,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;gBACnC,MAAM;YACR,KAAK,EAAE;gBACL,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;gBAC9B,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;gBACnC,MAAM;SACT;QACD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,kBAAkB,CAAC,SAAc;QAC/B,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,IAAI,CAAC;QAEnC,IAAI,SAAS,CAAC,IAAI,IAAI,UAAU,EAAE;YAChC,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,cAAc;gBACjB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;oBAC/B,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,QAAQ;oBACvC,CAAC,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI;oBACxB,CAAC,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;SAC7B;IACH,CAAC;IAED,SAAS;QACP,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QACjE,QAAQ,IAAI,CAAC,YAAY,EAAE;YACzB,KAAK,OAAO;gBACV,IAAI,IAAI,CAAC,aAAa,CAAC,sBAAsB,GAAG,CAAC,EAAE;oBACjD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,uCAAuC,EAAE,OAAO,CAAC,CAAC;oBACrE,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;oBAClB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;iBAC7B;gBACD,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,IAAI,CAAC,aAAa,CAAC,sBAAsB,GAAG,CAAC,EAAE;oBACjD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,uCAAuC,EAAE,OAAO,CAAC,CAAC;oBACrE,SAAS,GAAG,IAAI,CAAC;oBACjB,MAAM;iBACP;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;oBAClB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;iBAC7B;gBAED,IACE,gBAAgB,CAAC,CAAC,CAAC,IAAI,EAAE;oBACzB,CAAC,gBAAgB,CAAC,CAAC,CAAC;oBACpB,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAC3B;oBACA,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;iBACnB;gBAED,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,IAAI,CAAC,aAAa,CAAC,sBAAsB,GAAG,CAAC,EAAE;oBACjD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,uCAAuC,EAAE,OAAO,CAAC,CAAC;oBACrE,SAAS,GAAG,IAAI,CAAC;oBACjB,MAAM;iBACP;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;oBAClB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;iBAC7B;gBAED,IACE,gBAAgB,CAAC,CAAC,CAAC,IAAI,EAAE;oBACzB,CAAC,gBAAgB,CAAC,CAAC,CAAC;oBACpB,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAC3B;oBACA,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;iBACnB;gBAED,MAAM;YACR,KAAK,UAAU;gBACb,IACE,gBAAgB,CAAC,MAAM,KAAK,CAAC;oBAC7B,gBAAgB,CAAC,CAAC,CAAC,KAAK,EAAE;oBAC1B,gBAAgB,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,EAC1C;oBACA,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;iBACnB;gBACD,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,gBAAgB,EAAE,MAAM,GAAG,CAAC,EAAE;oBAChC,MAAM,YAAY,GAAG,MAAM,CACzB,GAAG,gBAAgB,CAAC,CAAC,CAAC,IAAI,gBAAgB,CAAC,CAAC,CAAC,IAAI,gBAAgB,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,EACvG,oBAAoB,CACrB,CAAC,IAAI,EAAE,CAAC;oBACT,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,YAAY,EAAE;wBACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,2BAA2B,EAAE,OAAO,CAAC,CAAC;wBACzD,SAAS,GAAG,IAAI,CAAC;wBACjB,MAAM;qBACP;yBAAM;wBACL,SAAS,GAAG,KAAK,CAAC;wBAClB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;qBAC7B;iBACF;qBAAM;oBACL,SAAS,GAAG,IAAI,CAAC;iBAClB;gBACD,MAAM;YACR,KAAK,aAAa;gBAChB,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,cAAc,GAAG,CAAC,EAAE;oBACvD,SAAS,GAAG,KAAK,CAAC;iBACnB;qBAAM;oBACL,SAAS,GAAG,IAAI,CAAC;iBAClB;gBACD,MAAM;YAER,KAAK,QAAQ;gBACX,IACE,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAClC,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,EAAE;wBACxB,CAAC,gBAAgB,CAAC,CAAC,CAAC;wBACpB,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,EAC9B;oBACA,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,SAAS,GAAG,KAAK,CAAC;iBACnB;gBACD,MAAM;YACR;gBACE,SAAS,GAAG,KAAK,CAAC;SACrB;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QACvC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,iBAAiB,CAAC,CAAC;IACrD,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,wBAAwB;IACxB,IAAI;IAEJ,IAAI;IAEJ,IAAI;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAClD,CAAC;IACD,KAAK;QACH,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;+GA9SU,2BAA2B;mGAA3B,2BAA2B,+UCjBxC,6rRAuIM;;4FDtHO,2BAA2B;kBALvC,SAAS;+BACE,yBAAyB;qIAQ1B,gBAAgB;sBAAxB,KAAK;gBACI,iBAAiB;sBAA1B,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n} from '@angular/core';\nimport moment from 'moment/moment';\nimport { FrequencyService } from '../frequency.service';\nimport { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';\n\n@Component({\n  selector: 'app-frequency-container',\n  templateUrl: './frequency-container.component.html',\n  styleUrls: ['./frequency-container.component.less'],\n})\nexport class FrequencyContainerComponent implements OnInit, OnChanges {\n  frequencyTab = 'daily';\n  currentTabName = 'a Daily';\n\n  @Input() frequencyDetails: any;\n  @Output() selectedFrequency = new EventEmitter<any>();\n  @Output() closeFrequency = new EventEmitter<any>();\n  @Input() mode: any = '';\n  @Input() feature: any;\n  @Input() pageType: 'responsibility' | 'policy' = 'responsibility';\n  @Input() onCompletionResponsibility: any;\n\n  frequencyData: any;\n\n  frequencyList = [\n    {\n      name: 'Daily',\n      type: 'daily',\n    },\n    {\n      name: 'Weekly',\n      type: 'weekly',\n    },\n    {\n      name: 'Monthly',\n      type: 'monthly',\n    },\n    {\n      name: 'Quarterly',\n      type: 'quarterly',\n    },\n    {\n      name: 'Biannual',\n      type: 'biannual',\n    },\n    {\n      name: 'Annual',\n      type: 'annual',\n    },\n    {\n      name: 'One Time',\n      type: 'oneTime',\n    },\n    {\n      name: 'Random',\n      type: 'random',\n    },\n    {\n      name: 'On Completion Of',\n      type: 'on_complete',\n    },\n    {\n      name: 'Ongoing',\n      type: 'ongoing',\n    },\n  ];\n\n  selectedFrequencyData: any;\n  isNextDisabled: any = false;\n  featureFlag_on_completion_of: any;\n  openedRadioForm: boolean = false;\n  constructor(\n    private frequencyService: FrequencyService,\n    private snackbar: SnackBarService\n  ) {}\n\n  ngOnInit(): void {\n    this.featureFlag_on_completion_of = this.feature.isFeatureEnabled(\n      'ff_frequency_on_completion_of'\n    );\n    if (this.frequencyDetails.pattern != '') {\n      this.populateFrequency();\n    }\n    const hideElements = ['random', 'on_complete', 'ongoing'];\n    if (this.mode == 'policy') {\n      hideElements.forEach((element: any) => {\n        const index = this.frequencyList.findIndex(\n          (elementIndex: any) => elementIndex.type == element\n        );\n        this.frequencyList.splice(index, 1);\n      });\n    }\n    const hideElements2 = ['daily', 'random', 'on_complete', 'ongoing'];\n    if (this.mode == 'reviewerFrequency') {\n      this.frequencyTab =\n        this.frequencyDetails?.pattern == '' ? 'weekly' : this.frequencyTab;\n      this.currentTabName =\n        this.frequencyDetails?.pattern == '' ? 'a weekly' : this.currentTabName;\n\n      hideElements2.forEach((element: any) => {\n        const index = this.frequencyList.findIndex(\n          (elementIndex: any) => elementIndex.type == element\n        );\n        this.frequencyList.splice(index, 1);\n      });\n    }\n  }\n\n  ngOnChanges() {\n    this.selectedFrequencyData = Object.assign({ ...this.frequencyDetails });\n    this.frequencyData = Object.assign({ ...this.frequencyDetails });\n  }\n\n  populateFrequency() {\n    const frequencyPattern = parseInt(\n      this.frequencyDetails.pattern.split('~')[0]\n    );\n\n    switch (frequencyPattern) {\n      case 0:\n        this.frequencyTab = 'oneTime';\n        this.currentTabName = 'a one time';\n        break;\n      case 1:\n        this.frequencyTab = 'daily';\n        this.currentTabName = 'a daily';\n        break;\n      case 2:\n        this.frequencyTab = 'weekly';\n        this.currentTabName = 'a weekly';\n        break;\n      case 3:\n        this.frequencyTab = 'monthly';\n        this.currentTabName = 'a monthly';\n        break;\n      case 4:\n        this.frequencyTab = 'annual';\n        this.currentTabName = 'an annual ';\n        break;\n      case 5:\n        this.frequencyTab = 'daily';\n        this.currentTabName = 'a daily';\n        break;\n      case 6:\n        this.frequencyTab = 'on_complete';\n        this.currentTabName = 'an on completion of';\n        this.frequencyData.report_id = this.frequencyDetails.selectedReport;\n        break;\n      case 7:\n        this.frequencyTab = 'quarterly';\n        this.currentTabName = 'a quarterly';\n        break;\n      case 8:\n        this.frequencyTab = 'random';\n        this.currentTabName = 'a random';\n        break;\n      case 9:\n        this.frequencyTab = 'biannual';\n        this.currentTabName = 'a biannual';\n        break;\n      case 10:\n        this.frequencyTab = 'ongoing';\n        this.currentTabName = 'an ongoing';\n        break;\n    }\n    this.isNextDisabled = false;\n  }\n\n  changeFrequencyTab(frequency: any) {\n    this.frequencyTab = frequency.type;\n\n    if (frequency.name == 'One Time') {\n      this.currentTabName = 'a one time';\n    } else {\n      this.currentTabName =\n        frequency.name.startsWith('On') ||\n        frequency.name.toLowerCase() === 'annual'\n          ? 'an ' + frequency.name\n          : 'a ' + frequency.name;\n    }\n  }\n\n  isInvalid(): boolean {\n    let isInvalid = false;\n    const frequencyDetails = this.frequencyData?.pattern?.split('~');\n    switch (this.frequencyTab) {\n      case 'daily':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n        break;\n      case 'weekly':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n          break;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n\n        if (\n          frequencyDetails[1] == '' ||\n          !frequencyDetails[1] ||\n          frequencyDetails.length < 4\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n\n        break;\n      case 'monthly':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n          break;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n\n        if (\n          frequencyDetails[2] == '' ||\n          !frequencyDetails[2] ||\n          frequencyDetails.length < 4\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n\n        break;\n      case 'biannual':\n        if (\n          frequencyDetails.length === 0 ||\n          frequencyDetails[2] === '' ||\n          frequencyDetails[2].split(',')?.length < 2\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n        break;\n      case 'oneTime':\n        if (frequencyDetails?.length > 0) {\n          const selectedTime = moment(\n            `${frequencyDetails[3]}-${frequencyDetails[2]}-${frequencyDetails[1]} ${this.frequencyData.timeIn12hr}`,\n            'DD-MM-YYYY HH:mm a'\n          ).unix();\n          if (Date.now() / 1000 > selectedTime) {\n            this.snackbar.show('Please set a future date.', 'alert');\n            isInvalid = true;\n            break;\n          } else {\n            isInvalid = false;\n            this.isNextDisabled = false;\n          }\n        } else {\n          isInvalid = true;\n        }\n        break;\n      case 'on_complete':\n        if (this.frequencyData.onCompletion?.responsibility > 0) {\n          isInvalid = false;\n        } else {\n          isInvalid = true;\n        }\n        break;\n\n      case 'random':\n        if (\n          parseInt(frequencyDetails[1]) == 2 &&\n          (frequencyDetails[2] == '' ||\n            !frequencyDetails[2] ||\n            frequencyDetails.length < 4)\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n        break;\n      default:\n        isInvalid = false;\n    }\n    return isInvalid;\n  }\n\n  onFrequencySelected(event: any) {\n    this.frequencyData = event;\n    this.isNextDisabled = this.isInvalid();\n    console.log(this.frequencyData, 'On Completiioon');\n  }\n\n  openedRadio(event: any) {\n    this.openedRadioForm = event;\n  }\n\n  //   checkNextValidity()\n  // {\n\n  // }\n\n  save() {\n    this.selectedFrequency.emit(this.frequencyData);\n  }\n  close() {\n    this.closeFrequency.emit();\n  }\n}\n","<ng-container *ngIf=\"mode !== 'policy'\">\n  <div class=\"frequency-dialog\" *ngIf=\"mode !== 'policy'\">\n    <div class=\"frequency-dialog-head vx-p-3 vx-mb-4 vx-d-flex vx-align-center vx-justify-between\">\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Set a Frequency</div>\n    </div>\n    <div class=\"frequency-dialog-body vx-pl-4 vx-pr-4\">\n      <div class=\"frequency-dialog-body-inner\" [ngSwitch]=\"frequencyTab\">\n        <div class=\"frequency-tab vx-d-flex vx-align-center\">\n          <ng-container *ngFor=\"let frequencyType of frequencyList; let i = index\">\n            <button (click)=\"changeFrequencyTab(frequencyType)\"\n              class=\"tab-btn vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0\"\n              [class.active]=\"frequencyType?.type == frequencyTab\">{{ frequencyType?.name }}</button>\n          </ng-container>\n        </div>\n        <div class=\"frequency-tab-bottom vx-pl-4 vx-pr-4\">\n          <!-- Daily Frequency Start -->\n          <app-frequency-daily *ngSwitchCase=\"'daily'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-daily>\n          <!-- Daily Frequency End -->\n          <!-- Weekly Frequency Start -->\n          <app-frequency-weekly *ngSwitchCase=\"'weekly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-weekly>\n          <!-- Weekly Frequency End -->\n          <!-- Monthly Frequency Start -->\n          <app-frequency-monthly *ngSwitchCase=\"'monthly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-monthly>\n          <!-- Monthly Frequency End -->\n          <!-- Quarterly Frequency Start -->\n          <app-frequency-quarterly *ngSwitchCase=\"'quarterly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-quarterly>\n          <!-- Quarterly Frequency End -->\n          <!-- Biannual Frequency Start -->\n          <app-frequency-biannual *ngSwitchCase=\"'biannual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-biannual>\n          <!-- Biannual Frequency End -->\n          <!-- Annual Frequency Start -->\n          <app-frequency-annual *ngSwitchCase=\"'annual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-annual>\n          <!-- Annual Frequency End -->\n          <!-- One Time Frequency Start -->\n          <app-frequency-one-time *ngSwitchCase=\"'oneTime'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-one-time>\n          <!-- One Time Frequency End -->\n          <!-- Random Frequency Start -->\n          <app-frequency-random *ngSwitchCase=\"'random'\" [mode]=\"mode\" (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-random>\n          <!-- Random Frequency End -->\n          <!-- On Completion Frequency Start -->\n          <app-frequency-on-completion-of *ngSwitchCase=\"'on_complete'\" [mode]=\"mode\" [feature]=\"feature\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"\n            [onCompletionResponsibility]=\"onCompletionResponsibility\"\n            (radioForm)=\"openedRadio($event)\"></app-frequency-on-completion-of>\n          <!-- On Completion Frequency End -->\n          <!-- Ongoing Frequency Start -->\n          <app-frequency-ongoing *ngSwitchCase=\"'ongoing'\" (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-ongoing>\n          <!-- Ongoing Frequency End -->\n        </div>\n      </div>\n    </div>\n\n    <div class=\"frequency-dialog-footer\" *ngIf=\"!openedRadioForm\">\n      <app-floating-bar [showFrequencyText]=\"true\" [currentFrequency]=\"currentTabName\" [isDisabled]=\"isNextDisabled\"\n        (closeEvent)=\"save()\" (closeList)=\"close()\"></app-floating-bar>\n    </div>\n  </div>\n</ng-container>\n<!-- When responsibility list show then hide frequency-dialog html -->\n\n<!-- For Policy -->\n<div class=\"frequency-dialog\" *ngIf=\"mode === 'policy'\">\n  <div class=\"frequency-dialog-head vx-p-3 vx-mb-4 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Set a Frequency</div>\n  </div>\n  <div class=\"frequency-dialog-body vx-pl-4 vx-pr-4\">\n    <div class=\"frequency-dialog-body-inner\" [ngSwitch]=\"frequencyTab\">\n      <div class=\"frequency-tab vx-d-flex vx-align-center\">\n        <ng-container *ngFor=\"let frequencyType of frequencyList; let i = index\">\n          <button (click)=\"changeFrequencyTab(frequencyType)\"\n            class=\"tab-btn vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0\"\n            [class.active]=\"frequencyType?.type == frequencyTab\">{{ frequencyType?.name }}</button>\n        </ng-container>\n      </div>\n      <div class=\"frequency-tab-bottom vx-pl-4 vx-pr-4\">\n        <!-- Daily Frequency Start -->\n        <app-frequency-daily *ngSwitchCase=\"'daily'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-daily>\n        <!-- Daily Frequency End -->\n        <!-- Weekly Frequency Start -->\n        <app-frequency-weekly *ngSwitchCase=\"'weekly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-weekly>\n        <!-- Weekly Frequency End -->\n        <!-- Monthly Frequency Start -->\n        <app-frequency-monthly *ngSwitchCase=\"'monthly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-monthly>\n        <!-- Monthly Frequency End -->\n        <!-- Quarterly Frequency Start -->\n        <app-frequency-quarterly *ngSwitchCase=\"'quarterly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-quarterly>\n        <!-- Quarterly Frequency End -->\n        <!-- Biannual Frequency Start -->\n        <app-frequency-biannual *ngSwitchCase=\"'biannual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-biannual>\n        <!-- Biannual Frequency End -->\n        <!-- Annual Frequency Start -->\n        <app-frequency-annual *ngSwitchCase=\"'annual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-annual>\n        <!-- Annual Frequency End -->\n        <!-- One Time Frequency Start -->\n        <app-frequency-one-time *ngSwitchCase=\"'oneTime'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-one-time>\n        <!-- One Time Frequency End -->\n        <!-- Random Frequency Start -->\n        <app-frequency-random *ngSwitchCase=\"'random'\" [mode]=\"mode\" (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-random>\n        <!-- Random Frequency End -->\n        <!-- On Completion Frequency Start -->\n        <app-frequency-on-completion-of *ngSwitchCase=\"'on_complete'\" [mode]=\"mode\"\n          (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-on-completion-of>\n        <!-- On Completion Frequency End -->\n        <!-- Ongoing Frequency Start -->\n        <app-frequency-ongoing *ngSwitchCase=\"'ongoing'\" (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-ongoing>\n        <!-- Ongoing Frequency End -->\n      </div>\n    </div>\n  </div>\n  <div class=\"frequency-dialog-footer\">\n    <app-floating-bar [showFrequencyText]=\"true\" [currentFrequency]=\"currentTabName\" [isDisabled]=\"isNextDisabled\"\n      (closeEvent)=\"save()\" (closeList)=\"close()\"></app-floating-bar>\n  </div>\n</div>"]}
|
|
305
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-container/frequency-container.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-container/frequency-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n} from '@angular/core';\nimport moment from 'moment/moment';\nimport { FrequencyService } from '../frequency.service';\nimport { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';\n\n@Component({\n  selector: 'app-frequency-container',\n  templateUrl: './frequency-container.component.html',\n  styleUrls: ['./frequency-container.component.less'],\n})\nexport class FrequencyContainerComponent implements OnInit, OnChanges {\n  frequencyTab = 'daily';\n  currentTabName = 'a Daily';\n\n  @Input() frequencyDetails: any;\n  @Output() selectedFrequency = new EventEmitter<any>();\n  @Output() closeFrequency = new EventEmitter<any>();\n  @Input() mode: any = '';\n  @Input() feature: any;\n  @Input() pageType: 'responsibility' | 'policy' = 'responsibility';\n  @Input() onCompletionResponsibility: any;\n\n  frequencyData: any;\n\n  frequencyList = [\n    {\n      name: 'Daily',\n      type: 'daily',\n    },\n    {\n      name: 'Weekly',\n      type: 'weekly',\n    },\n    {\n      name: 'Monthly',\n      type: 'monthly',\n    },\n    {\n      name: 'Quarterly',\n      type: 'quarterly',\n    },\n    {\n      name: 'Biannual',\n      type: 'biannual',\n    },\n    {\n      name: 'Annual',\n      type: 'annual',\n    },\n    {\n      name: 'One Time',\n      type: 'oneTime',\n    },\n    {\n      name: 'Random',\n      type: 'random',\n    },\n    {\n      name: 'On Completion Of',\n      type: 'on_complete',\n    },\n    {\n      name: 'Ongoing',\n      type: 'ongoing',\n    },\n  ];\n\n  selectedFrequencyData: any;\n  isNextDisabled: any = false;\n  featureFlag_on_completion_of: any;\n  openedRadioForm: boolean = false;\n  constructor(\n    private frequencyService: FrequencyService,\n    private snackbar: SnackBarService\n  ) {}\n\n  ngOnInit(): void {\n    this.featureFlag_on_completion_of = this.feature.isFeatureEnabled(\n      'ff_frequency_on_completion_of'\n    );\n    if (this.frequencyDetails.pattern != '') {\n      this.populateFrequency();\n    }\n    const hideElements = ['random', 'on_complete', 'ongoing'];\n    if (this.mode == 'policy') {\n      hideElements.forEach((element: any) => {\n        const index = this.frequencyList.findIndex(\n          (elementIndex: any) => elementIndex.type == element\n        );\n        this.frequencyList.splice(index, 1);\n      });\n    }\n    const hideElements2 = ['daily', 'random', 'on_complete', 'ongoing'];\n    if (this.mode == 'reviewerFrequency') {\n      this.frequencyTab =\n        this.frequencyDetails?.pattern == '' ? 'weekly' : this.frequencyTab;\n      this.currentTabName =\n        this.frequencyDetails?.pattern == '' ? 'a weekly' : this.currentTabName;\n\n      hideElements2.forEach((element: any) => {\n        const index = this.frequencyList.findIndex(\n          (elementIndex: any) => elementIndex.type == element\n        );\n        this.frequencyList.splice(index, 1);\n      });\n    }\n  }\n\n  ngOnChanges() {\n    this.selectedFrequencyData = Object.assign({ ...this.frequencyDetails });\n    this.frequencyData = Object.assign({ ...this.frequencyDetails });\n  }\n\n  populateFrequency() {\n    const frequencyPattern = parseInt(\n      this.frequencyDetails.pattern.split('~')[0]\n    );\n\n    switch (frequencyPattern) {\n      case 0:\n        this.frequencyTab = 'oneTime';\n        this.currentTabName = 'a one time';\n        break;\n      case 1:\n        this.frequencyTab = 'daily';\n        this.currentTabName = 'a daily';\n        break;\n      case 2:\n        this.frequencyTab = 'weekly';\n        this.currentTabName = 'a weekly';\n        break;\n      case 3:\n        this.frequencyTab = 'monthly';\n        this.currentTabName = 'a monthly';\n        break;\n      case 4:\n        this.frequencyTab = 'annual';\n        this.currentTabName = 'an annual ';\n        break;\n      case 5:\n        this.frequencyTab = 'daily';\n        this.currentTabName = 'a daily';\n        break;\n      case 6:\n        this.frequencyTab = 'on_complete';\n        this.currentTabName = 'an on completion of';\n        this.frequencyData.report_id = this.frequencyDetails.selectedReport;\n        break;\n      case 7:\n        this.frequencyTab = 'quarterly';\n        this.currentTabName = 'a quarterly';\n        break;\n      case 8:\n        this.frequencyTab = 'random';\n        this.currentTabName = 'a random';\n        break;\n      case 9:\n        this.frequencyTab = 'biannual';\n        this.currentTabName = 'a biannual';\n        break;\n      case 10:\n        this.frequencyTab = 'ongoing';\n        this.currentTabName = 'an ongoing';\n        break;\n    }\n    this.isNextDisabled = false;\n  }\n\n  changeFrequencyTab(frequency: any) {\n    this.frequencyTab = frequency.type;\n\n    if (frequency.name == 'One Time') {\n      this.currentTabName = 'a one time';\n    } else {\n      this.currentTabName =\n        frequency.name.startsWith('On') ||\n        frequency.name.toLowerCase() === 'annual'\n          ? 'an ' + frequency.name\n          : 'a ' + frequency.name;\n    }\n  }\n\n  isInvalid(): boolean {\n    let isInvalid = false;\n    const frequencyDetails = this.frequencyData?.pattern?.split('~');\n    switch (this.frequencyTab) {\n      case 'daily':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n        break;\n      case 'weekly':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n          break;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n\n        if (\n          frequencyDetails[1] == '' ||\n          !frequencyDetails[1] ||\n          frequencyDetails.length < 4\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n\n        break;\n      case 'monthly':\n        if (this.frequencyData.continuous_failed_days < 2) {\n          this.snackbar.show('Input value should be greater than 1.', 'alert');\n          isInvalid = true;\n          break;\n        } else {\n          isInvalid = false;\n          this.isNextDisabled = false;\n        }\n\n        if (\n          frequencyDetails[2] == '' ||\n          !frequencyDetails[2] ||\n          frequencyDetails.length < 4\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n\n        break;\n      case 'biannual':\n        if (\n          frequencyDetails.length === 0 ||\n          frequencyDetails[2] === '' ||\n          frequencyDetails[2].split(',')?.length < 2\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n        break;\n      case 'oneTime':\n        if (frequencyDetails?.length > 0) {\n          const selectedTime = moment(\n            `${frequencyDetails[3]}-${frequencyDetails[2]}-${frequencyDetails[1]} ${this.frequencyData.timeIn12hr}`,\n            'DD-MM-YYYY HH:mm a'\n          ).unix();\n          if (Date.now() / 1000 > selectedTime) {\n            this.snackbar.show('Please set a future date.', 'alert');\n            isInvalid = true;\n            break;\n          } else {\n            isInvalid = false;\n            this.isNextDisabled = false;\n          }\n        } else {\n          isInvalid = true;\n        }\n        break;\n      case 'on_complete':\n        if (this.frequencyData.onCompletion?.responsibility > 0) {\n          isInvalid = false;\n        } else {\n          isInvalid = true;\n        }\n        break;\n\n      case 'random':\n        if (\n          parseInt(frequencyDetails[1]) == 2 &&\n          (frequencyDetails[2] == '' ||\n            !frequencyDetails[2] ||\n            frequencyDetails.length < 4)\n        ) {\n          isInvalid = true;\n        } else {\n          isInvalid = false;\n        }\n        break;\n      default:\n        isInvalid = false;\n    }\n    return isInvalid;\n  }\n\n  onFrequencySelected(event: any) {\n    this.frequencyData = event;\n    this.isNextDisabled = this.isInvalid();\n  }\n\n  openedRadio(event: any) {\n    this.openedRadioForm = event;\n  }\n\n  //   checkNextValidity()\n  // {\n\n  // }\n\n  save() {\n    this.selectedFrequency.emit(this.frequencyData);\n  }\n  close() {\n    this.closeFrequency.emit();\n  }\n}\n","<ng-container *ngIf=\"mode !== 'policy'\">\n  <div class=\"frequency-dialog\" *ngIf=\"mode !== 'policy'\">\n    <div class=\"frequency-dialog-head vx-p-3 vx-mb-4 vx-d-flex vx-align-center vx-justify-between\">\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Set a Frequency</div>\n    </div>\n    <div class=\"frequency-dialog-body vx-pl-4 vx-pr-4\">\n      <div class=\"frequency-dialog-body-inner\" [ngSwitch]=\"frequencyTab\">\n        <div class=\"frequency-tab vx-d-flex vx-align-center\">\n          <ng-container *ngFor=\"let frequencyType of frequencyList; let i = index\">\n            <button (click)=\"changeFrequencyTab(frequencyType)\"\n              class=\"tab-btn vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0\"\n              [class.active]=\"frequencyType?.type == frequencyTab\">{{ frequencyType?.name }}</button>\n          </ng-container>\n        </div>\n        <div class=\"frequency-tab-bottom vx-pl-4 vx-pr-4\">\n          <!-- Daily Frequency Start -->\n          <app-frequency-daily *ngSwitchCase=\"'daily'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-daily>\n          <!-- Daily Frequency End -->\n          <!-- Weekly Frequency Start -->\n          <app-frequency-weekly *ngSwitchCase=\"'weekly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-weekly>\n          <!-- Weekly Frequency End -->\n          <!-- Monthly Frequency Start -->\n          <app-frequency-monthly *ngSwitchCase=\"'monthly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-monthly>\n          <!-- Monthly Frequency End -->\n          <!-- Quarterly Frequency Start -->\n          <app-frequency-quarterly *ngSwitchCase=\"'quarterly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-quarterly>\n          <!-- Quarterly Frequency End -->\n          <!-- Biannual Frequency Start -->\n          <app-frequency-biannual *ngSwitchCase=\"'biannual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-biannual>\n          <!-- Biannual Frequency End -->\n          <!-- Annual Frequency Start -->\n          <app-frequency-annual *ngSwitchCase=\"'annual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-annual>\n          <!-- Annual Frequency End -->\n          <!-- One Time Frequency Start -->\n          <app-frequency-one-time *ngSwitchCase=\"'oneTime'\" [mode]=\"mode\" [pageType]=\"pageType\"\n            (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-one-time>\n          <!-- One Time Frequency End -->\n          <!-- Random Frequency Start -->\n          <app-frequency-random *ngSwitchCase=\"'random'\" [mode]=\"mode\" (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-random>\n          <!-- Random Frequency End -->\n          <!-- On Completion Frequency Start -->\n          <app-frequency-on-completion-of *ngSwitchCase=\"'on_complete'\" [mode]=\"mode\" [feature]=\"feature\"\n            (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"\n            [onCompletionResponsibility]=\"onCompletionResponsibility\"\n            (radioForm)=\"openedRadio($event)\"></app-frequency-on-completion-of>\n          <!-- On Completion Frequency End -->\n          <!-- Ongoing Frequency Start -->\n          <app-frequency-ongoing *ngSwitchCase=\"'ongoing'\" (frequencyDetails)=\"onFrequencySelected($event)\"\n            [frequencyData]=\"frequencyDetails\"></app-frequency-ongoing>\n          <!-- Ongoing Frequency End -->\n        </div>\n      </div>\n    </div>\n\n    <div class=\"frequency-dialog-footer\" *ngIf=\"!openedRadioForm\">\n      <app-floating-bar [showFrequencyText]=\"true\" [currentFrequency]=\"currentTabName\" [isDisabled]=\"isNextDisabled\"\n        (closeEvent)=\"save()\" (closeList)=\"close()\"></app-floating-bar>\n    </div>\n  </div>\n</ng-container>\n<!-- When responsibility list show then hide frequency-dialog html -->\n\n<!-- For Policy -->\n<div class=\"frequency-dialog\" *ngIf=\"mode === 'policy'\">\n  <div class=\"frequency-dialog-head vx-p-3 vx-mb-4 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Set a Frequency</div>\n  </div>\n  <div class=\"frequency-dialog-body vx-pl-4 vx-pr-4\">\n    <div class=\"frequency-dialog-body-inner\" [ngSwitch]=\"frequencyTab\">\n      <div class=\"frequency-tab vx-d-flex vx-align-center\">\n        <ng-container *ngFor=\"let frequencyType of frequencyList; let i = index\">\n          <button (click)=\"changeFrequencyTab(frequencyType)\"\n            class=\"tab-btn vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0\"\n            [class.active]=\"frequencyType?.type == frequencyTab\">{{ frequencyType?.name }}</button>\n        </ng-container>\n      </div>\n      <div class=\"frequency-tab-bottom vx-pl-4 vx-pr-4\">\n        <!-- Daily Frequency Start -->\n        <app-frequency-daily *ngSwitchCase=\"'daily'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-daily>\n        <!-- Daily Frequency End -->\n        <!-- Weekly Frequency Start -->\n        <app-frequency-weekly *ngSwitchCase=\"'weekly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-weekly>\n        <!-- Weekly Frequency End -->\n        <!-- Monthly Frequency Start -->\n        <app-frequency-monthly *ngSwitchCase=\"'monthly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-monthly>\n        <!-- Monthly Frequency End -->\n        <!-- Quarterly Frequency Start -->\n        <app-frequency-quarterly *ngSwitchCase=\"'quarterly'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-quarterly>\n        <!-- Quarterly Frequency End -->\n        <!-- Biannual Frequency Start -->\n        <app-frequency-biannual *ngSwitchCase=\"'biannual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-biannual>\n        <!-- Biannual Frequency End -->\n        <!-- Annual Frequency Start -->\n        <app-frequency-annual *ngSwitchCase=\"'annual'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-annual>\n        <!-- Annual Frequency End -->\n        <!-- One Time Frequency Start -->\n        <app-frequency-one-time *ngSwitchCase=\"'oneTime'\" [mode]=\"mode\" [pageType]=\"pageType\"\n          (frequencyDetails)=\"onFrequencySelected($event)\" [frequencyData]=\"frequencyDetails\"></app-frequency-one-time>\n        <!-- One Time Frequency End -->\n        <!-- Random Frequency Start -->\n        <app-frequency-random *ngSwitchCase=\"'random'\" [mode]=\"mode\" (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-random>\n        <!-- Random Frequency End -->\n        <!-- On Completion Frequency Start -->\n        <app-frequency-on-completion-of *ngSwitchCase=\"'on_complete'\" [mode]=\"mode\"\n          (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-on-completion-of>\n        <!-- On Completion Frequency End -->\n        <!-- Ongoing Frequency Start -->\n        <app-frequency-ongoing *ngSwitchCase=\"'ongoing'\" (frequencyDetails)=\"onFrequencySelected($event)\"\n          [frequencyData]=\"frequencyDetails\"></app-frequency-ongoing>\n        <!-- Ongoing Frequency End -->\n      </div>\n    </div>\n  </div>\n  <div class=\"frequency-dialog-footer\">\n    <app-floating-bar [showFrequencyText]=\"true\" [currentFrequency]=\"currentTabName\" [isDisabled]=\"isNextDisabled\"\n      (closeEvent)=\"save()\" (closeList)=\"close()\"></app-floating-bar>\n  </div>\n</div>"]}
|
|
@@ -150,10 +150,13 @@ export class FrequencyResponsibilityListComponent {
|
|
|
150
150
|
let assigneeDetails = (item.assigneeDetails || [])
|
|
151
151
|
.filter((ad) => ad.status && ad.status.toLowerCase() === 'active');
|
|
152
152
|
if (assigneeDetails?.length === 0 && item?.assigneeType === 'any' && [null, 'any'].includes(item?.rcType)) {
|
|
153
|
-
assigneeDetails =
|
|
154
|
-
|
|
153
|
+
assigneeDetails = item.assignees?.activeUserId?.map((id) => {
|
|
154
|
+
return {
|
|
155
|
+
...item.assigneeDetails[0],
|
|
155
156
|
status: 'active',
|
|
156
|
-
|
|
157
|
+
assignee: id,
|
|
158
|
+
};
|
|
159
|
+
});
|
|
157
160
|
}
|
|
158
161
|
assigneeDetails = assigneeDetails.map((ad) => ({
|
|
159
162
|
...ad,
|
|
@@ -166,6 +169,8 @@ export class FrequencyResponsibilityListComponent {
|
|
|
166
169
|
id: item.id,
|
|
167
170
|
title: item.title,
|
|
168
171
|
controlId: item?.controlId ? '[CID-' + item?.controlId + '] ' : '',
|
|
172
|
+
assigneeType: item?.assigneeType,
|
|
173
|
+
rcType: item?.rcType,
|
|
169
174
|
assigneeDetails,
|
|
170
175
|
allAssignee,
|
|
171
176
|
allRc
|
|
@@ -215,11 +220,11 @@ export class FrequencyResponsibilityListComponent {
|
|
|
215
220
|
this.selectedResponsibilityValues = event;
|
|
216
221
|
}
|
|
217
222
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FrequencyResponsibilityListComponent, deps: [{ token: i1.FrequencyService }, { token: i2.CommonService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
218
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FrequencyResponsibilityListComponent, selector: "app-frequency-responsibility-list", inputs: { selectedResponsibilityDetails: "selectedResponsibilityDetails" }, outputs: { backButton: "backButton", selectedResponsibility: "selectedResponsibility" }, ngImport: i0, template: "<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n <div class=\"vx-d-flex vx-align-center\">\n <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\"></i>\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n </div>\n </div>\n <div class=\"frequency-responsibility-list-body\">\n <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n <div class=\"frequency-responsibility-list-search vx-mb-2\">\n <i class=\"icons vx-fs-12\"></i>\n <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n placeholder=\"Search Responsibilities\" />\n </div>\n <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n (selectedPage)=\"responsibilityPageChange($event)\">\n </app-pagination>\n </ng-container>\n\n <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n !responsibilityLoader && responsibilitiesData?.total_pages > 1\n \">\n <app-no-data *ngIf=\"\n responsibilitiesData?.responsibilities?.length === 0 &&\n !responsibilityLoader\n \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n <ng-container *ngIf=\"\n responsibilitiesData?.responsibilities?.length > 0 &&\n !responsibilityLoader\n \">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n RESPONSIBILITIES\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n RESPONSIBILITY CENTER\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <!-- when click on radio then active class should be true -->\n <ng-container *ngFor=\"\n let responsibility of responsibilitiesData?.responsibilities;\n let i = index\n \">\n <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n responsibilitiesData?.limit +\n i +\n 1) as srNo\">\n <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n <div class=\"sr-no\" [appTooltip]=\"\n srNo \n \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{srNo}}\n </div>\n <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n \"\n (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n <div class=\"value vx-fs-12 vx-label-txt vx-pr-5 vx-d-flex vx-align-center\">\n <div class=\"avatar-list vx-d-flex vx-align-center\">\n <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n </div>\n\n <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n responsibility?.controlId }} {{\n responsibility?.title\n }}</span>\n </div>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n <ng-container *ngIf=\"responsibility?.allRc as rc\">\n <div class=\"program-inner vx-d-block\">\n <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n rc?.length\n ? rc[0]?.name\n : '--'\n \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{\n rc?.length\n ? rc[0]?.name\n : \"--\"\n }}\n </div>\n <ng-container *ngIf=\"\n rc?.length \n \">\n </ng-container>\n </div>\n <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n +{{ rc?.length - 1 }}\n </button>\n <app-popover #rcPopup>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"\n let data of rc?.slice(\n 1,\n rc?.length\n )\n \">\n <div class=\"avatar-card\">\n <div class=\"vx-d-block vx-w-100\">\n <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n </div>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </div>\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n (click)=\"onToggleResponsibility(responsibility)\">\n <ng-container *ngIf=\"assigneeDetails?.length > 1; else closeIcon\">\n <i *ngIf=\"\n openedResponsibility.includes(responsibility.id);\n else closeIcon\n \" class=\"icons vx-fs-10\"></i>\n <ng-template #closeIcon>\n <i class=\"icons vx-fs-10\"> </i>\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/table-card/table-card.css\";::ng-deep .frequency-responsibility-list{border-top:3px solid #1e5dd3;position:fixed;top:0;right:32.5rem;bottom:0;left:0}::ng-deep .frequency-responsibility-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .frequency-responsibility-list-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .frequency-responsibility-list-head .arrow{cursor:pointer}::ng-deep .frequency-responsibility-list-body{background:#fff;height:calc(100% - 2.75rem);padding:1.5rem .75rem 1.5rem 2rem}::ng-deep .frequency-responsibility-list-body app-pagination .wk-pagination-sec-ds{border-radius:0;padding:0 0 .5rem}::ng-deep .frequency-responsibility-list-body app-floating-bar .floating-bar{padding:0;position:relative;left:-1rem;width:calc(100% + 2rem)}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar{padding-left:0!important;padding-right:0!important}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar .userGroup-floating-bar-container .left .chip span{max-width:240px}::ng-deep .frequency-responsibility-list-search{position:relative}::ng-deep .frequency-responsibility-list-search input{height:2.75rem;line-height:1.5rem;padding:.75rem .75rem .75rem 2.5rem;outline:none;border:1px solid #7475763F;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .frequency-responsibility-list-search input::placeholder{color:#747576;opacity:1}::ng-deep .frequency-responsibility-list-search i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .frequency-responsibility-list-mid{height:calc(100% - 8rem);overflow:auto}::ng-deep .frequency-responsibility-list-mid::-webkit-scrollbar-track{background-color:#fff}::ng-deep .frequency-responsibility-list-mid.with-pagination{height:calc(100% - 10rem)}::ng-deep .frequency-responsibility-list-mid .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .frequency-responsibility-list-mid .table-header .table-column{color:#161b2f!important;line-height:.75rem!important;min-height:1.875rem!important}::ng-deep .frequency-responsibility-list-mid .table-body{position:relative}::ng-deep .frequency-responsibility-list-mid .table-body .table-row{background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;margin-bottom:.25rem}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial .sr-no,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial .sr-no{opacity:0}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial app-cs-radio,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .frequency-responsibility-list-mid .table-body .table-row lib-sub-responsibility{position:relative;top:2.5rem;left:0;width:100%;z-index:1;background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;padding:.5rem}::ng-deep .frequency-responsibility-list-mid .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .frequency-responsibility-list-mid .table-row .table-column{color:#747576;min-height:2.5rem;position:relative;width:100%}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial .sr-no{width:1rem;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio{position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio .radio-item{position:absolute}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility{width:calc(100% - 19rem);min-width:calc(100% - 19rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list{width:2.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list app-avatar~app-avatar{margin-left:-.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .resp-name{text-overflow:ellipsis;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center{width:14rem;min-width:14rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-inner{max-width:calc(100% - 2rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center button.program-count{background:#1e5dd3;border-radius:.125rem;border:none;min-width:1.5rem;height:1.25rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action{width:3rem;min-width:3rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action.active{cursor:pointer}::ng-deep .frequency-responsibility-list-mid .table-row.with-sub-responsibility{background:#f9f9fa;margin-bottom:0}@keyframes animate-right{0%{transform:translate(5px);opacity:0}to{transform:translate(0);opacity:1}}.wf-action-list{width:220px}.wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.wf-action-list ul.action-item{display:block}.wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: i6.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i7.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"], outputs: ["closePopoverEvent"] }, { kind: "directive", type: i8.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.NoDataComponent, selector: "app-no-data", inputs: ["action", "noDataImage", "noDataText", "noDataButton", "noDataSecButton", "altText", "smallButton", "button"], outputs: ["buttonAction"] }, { kind: "component", type: i10.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i11.PaginationComponentUI, selector: "app-pagination", inputs: ["activeAlphabet", "pageCount", "start", "end", "total", "currentPage"], outputs: ["selectedPage", "selectedAlphabet"] }, { kind: "component", type: i12.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "isResponsibility", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "component", type: i13.SubResponsibilityComponent, selector: "lib-sub-responsibility", inputs: ["responsibility", "srNo", "selectedResponsibility"], outputs: ["onCompletionChange"] }, { kind: "component", type: i14.AvatarV2Component, selector: "lib-avatar-v2", inputs: ["avatarList", "type"] }] }); }
|
|
223
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FrequencyResponsibilityListComponent, selector: "app-frequency-responsibility-list", inputs: { selectedResponsibilityDetails: "selectedResponsibilityDetails" }, outputs: { backButton: "backButton", selectedResponsibility: "selectedResponsibility" }, ngImport: i0, template: "<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n <div class=\"vx-d-flex vx-align-center\">\n <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\"></i>\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n </div>\n </div>\n <div class=\"frequency-responsibility-list-body\">\n <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n <div class=\"frequency-responsibility-list-search vx-mb-2\">\n <i class=\"icons vx-fs-12\"></i>\n <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n placeholder=\"Search Responsibilities\" />\n </div>\n <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n (selectedPage)=\"responsibilityPageChange($event)\">\n </app-pagination>\n </ng-container>\n\n <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n !responsibilityLoader && responsibilitiesData?.total_pages > 1\n \">\n <app-no-data *ngIf=\"\n responsibilitiesData?.responsibilities?.length === 0 &&\n !responsibilityLoader\n \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n <ng-container *ngIf=\"\n responsibilitiesData?.responsibilities?.length > 0 &&\n !responsibilityLoader\n \">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n RESPONSIBILITIES\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n RESPONSIBILITY CENTER\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <!-- when click on radio then active class should be true -->\n <ng-container *ngFor=\"\n let responsibility of responsibilitiesData?.responsibilities;\n let i = index\n \">\n <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n responsibilitiesData?.limit +\n i +\n 1) as srNo\">\n <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n <div class=\"sr-no\" [appTooltip]=\"\n srNo \n \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{srNo}}\n </div>\n <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n \"\n (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n <div class=\"value vx-fs-12 vx-label-txt vx-pr-5 vx-d-flex vx-align-center\">\n <div class=\"avatar-list vx-d-flex vx-align-center\">\n <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n </div>\n\n <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n responsibility?.controlId }} {{\n responsibility?.title\n }}</span>\n </div>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n <ng-container *ngIf=\"responsibility?.allRc as rc\">\n <div class=\"program-inner vx-d-block\">\n <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n rc?.length\n ? rc[0]?.name\n : '--'\n \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{\n rc?.length\n ? rc[0]?.name\n : \"--\"\n }}\n </div>\n <ng-container *ngIf=\"\n rc?.length \n \">\n </ng-container>\n </div>\n <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n +{{ rc?.length - 1 }}\n </button>\n <app-popover #rcPopup>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"\n let data of rc?.slice(\n 1,\n rc?.length\n )\n \">\n <div class=\"avatar-card\">\n <div class=\"vx-d-block vx-w-100\">\n <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n </div>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </div>\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n (click)=\"onToggleResponsibility(responsibility)\">\n <ng-container\n *ngIf=\"assigneeDetails?.length > 1 && !(responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType)); else closeIcon\">\n <i *ngIf=\"\n openedResponsibility.includes(responsibility.id);\n else closeIcon\n \" class=\"icons vx-fs-10\"></i>\n <ng-template #closeIcon>\n <i class=\"icons vx-fs-10\"> </i>\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/table-card/table-card.css\";::ng-deep .frequency-responsibility-list{border-top:3px solid #1e5dd3;position:fixed;top:0;right:32.5rem;bottom:0;left:0}::ng-deep .frequency-responsibility-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .frequency-responsibility-list-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .frequency-responsibility-list-head .arrow{cursor:pointer}::ng-deep .frequency-responsibility-list-body{background:#fff;height:calc(100% - 2.75rem);padding:1.5rem .75rem 1.5rem 2rem}::ng-deep .frequency-responsibility-list-body app-pagination .wk-pagination-sec-ds{border-radius:0;padding:0 0 .5rem}::ng-deep .frequency-responsibility-list-body app-floating-bar .floating-bar{padding:0;position:relative;left:-1rem;width:calc(100% + 2rem)}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar{padding-left:0!important;padding-right:0!important}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar .userGroup-floating-bar-container .left .chip span{max-width:240px}::ng-deep .frequency-responsibility-list-search{position:relative}::ng-deep .frequency-responsibility-list-search input{height:2.75rem;line-height:1.5rem;padding:.75rem .75rem .75rem 2.5rem;outline:none;border:1px solid #7475763F;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .frequency-responsibility-list-search input::placeholder{color:#747576;opacity:1}::ng-deep .frequency-responsibility-list-search i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .frequency-responsibility-list-mid{height:calc(100% - 8rem);overflow:auto}::ng-deep .frequency-responsibility-list-mid::-webkit-scrollbar-track{background-color:#fff}::ng-deep .frequency-responsibility-list-mid.with-pagination{height:calc(100% - 10rem)}::ng-deep .frequency-responsibility-list-mid .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .frequency-responsibility-list-mid .table-header .table-column{color:#161b2f!important;line-height:.75rem!important;min-height:1.875rem!important}::ng-deep .frequency-responsibility-list-mid .table-body{position:relative}::ng-deep .frequency-responsibility-list-mid .table-body .table-row{background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;margin-bottom:.25rem}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial .sr-no,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial .sr-no{opacity:0}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial app-cs-radio,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .frequency-responsibility-list-mid .table-body .table-row lib-sub-responsibility{position:relative;top:2.5rem;left:0;width:100%;z-index:1;background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;padding:.5rem}::ng-deep .frequency-responsibility-list-mid .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .frequency-responsibility-list-mid .table-row .table-column{color:#747576;min-height:2.5rem;position:relative;width:100%}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial .sr-no{width:1rem;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio{position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio .radio-item{position:absolute}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility{width:calc(100% - 19rem);min-width:calc(100% - 19rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list{width:2.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list app-avatar~app-avatar{margin-left:-.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .resp-name{text-overflow:ellipsis;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center{width:14rem;min-width:14rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-inner{max-width:calc(100% - 2rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center button.program-count{background:#1e5dd3;border-radius:.125rem;border:none;min-width:1.5rem;height:1.25rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action{width:3rem;min-width:3rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action.active{cursor:pointer}::ng-deep .frequency-responsibility-list-mid .table-row.with-sub-responsibility{background:#f9f9fa;margin-bottom:0}@keyframes animate-right{0%{transform:translate(5px);opacity:0}to{transform:translate(0);opacity:1}}.wf-action-list{width:220px}.wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.wf-action-list ul.action-item{display:block}.wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: i6.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i7.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"], outputs: ["closePopoverEvent"] }, { kind: "directive", type: i8.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.NoDataComponent, selector: "app-no-data", inputs: ["action", "noDataImage", "noDataText", "noDataButton", "noDataSecButton", "altText", "smallButton", "button"], outputs: ["buttonAction"] }, { kind: "component", type: i10.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i11.PaginationComponentUI, selector: "app-pagination", inputs: ["activeAlphabet", "pageCount", "start", "end", "total", "currentPage"], outputs: ["selectedPage", "selectedAlphabet"] }, { kind: "component", type: i12.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "isResponsibility", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "component", type: i13.SubResponsibilityComponent, selector: "lib-sub-responsibility", inputs: ["responsibility", "srNo", "selectedResponsibility"], outputs: ["onCompletionChange"] }, { kind: "component", type: i14.AvatarV2Component, selector: "lib-avatar-v2", inputs: ["avatarList", "type"] }] }); }
|
|
219
224
|
}
|
|
220
225
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FrequencyResponsibilityListComponent, decorators: [{
|
|
221
226
|
type: Component,
|
|
222
|
-
args: [{ selector: 'app-frequency-responsibility-list', template: "<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n <div class=\"vx-d-flex vx-align-center\">\n <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\"></i>\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n </div>\n </div>\n <div class=\"frequency-responsibility-list-body\">\n <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n <div class=\"frequency-responsibility-list-search vx-mb-2\">\n <i class=\"icons vx-fs-12\"></i>\n <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n placeholder=\"Search Responsibilities\" />\n </div>\n <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n (selectedPage)=\"responsibilityPageChange($event)\">\n </app-pagination>\n </ng-container>\n\n <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n !responsibilityLoader && responsibilitiesData?.total_pages > 1\n \">\n <app-no-data *ngIf=\"\n responsibilitiesData?.responsibilities?.length === 0 &&\n !responsibilityLoader\n \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n <ng-container *ngIf=\"\n responsibilitiesData?.responsibilities?.length > 0 &&\n !responsibilityLoader\n \">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n RESPONSIBILITIES\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n RESPONSIBILITY CENTER\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <!-- when click on radio then active class should be true -->\n <ng-container *ngFor=\"\n let responsibility of responsibilitiesData?.responsibilities;\n let i = index\n \">\n <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n responsibilitiesData?.limit +\n i +\n 1) as srNo\">\n <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n <div class=\"sr-no\" [appTooltip]=\"\n srNo \n \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{srNo}}\n </div>\n <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n \"\n (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n <div class=\"value vx-fs-12 vx-label-txt vx-pr-5 vx-d-flex vx-align-center\">\n <div class=\"avatar-list vx-d-flex vx-align-center\">\n <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n </div>\n\n <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n responsibility?.controlId }} {{\n responsibility?.title\n }}</span>\n </div>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n <ng-container *ngIf=\"responsibility?.allRc as rc\">\n <div class=\"program-inner vx-d-block\">\n <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n rc?.length\n ? rc[0]?.name\n : '--'\n \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{\n rc?.length\n ? rc[0]?.name\n : \"--\"\n }}\n </div>\n <ng-container *ngIf=\"\n rc?.length \n \">\n </ng-container>\n </div>\n <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n +{{ rc?.length - 1 }}\n </button>\n <app-popover #rcPopup>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"\n let data of rc?.slice(\n 1,\n rc?.length\n )\n \">\n <div class=\"avatar-card\">\n <div class=\"vx-d-block vx-w-100\">\n <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n </div>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </div>\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n (click)=\"onToggleResponsibility(responsibility)\">\n <ng-container *ngIf=\"assigneeDetails?.length > 1; else closeIcon\">\n <i *ngIf=\"\n openedResponsibility.includes(responsibility.id);\n else closeIcon\n \" class=\"icons vx-fs-10\"></i>\n <ng-template #closeIcon>\n <i class=\"icons vx-fs-10\"> </i>\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/table-card/table-card.css\";::ng-deep .frequency-responsibility-list{border-top:3px solid #1e5dd3;position:fixed;top:0;right:32.5rem;bottom:0;left:0}::ng-deep .frequency-responsibility-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .frequency-responsibility-list-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .frequency-responsibility-list-head .arrow{cursor:pointer}::ng-deep .frequency-responsibility-list-body{background:#fff;height:calc(100% - 2.75rem);padding:1.5rem .75rem 1.5rem 2rem}::ng-deep .frequency-responsibility-list-body app-pagination .wk-pagination-sec-ds{border-radius:0;padding:0 0 .5rem}::ng-deep .frequency-responsibility-list-body app-floating-bar .floating-bar{padding:0;position:relative;left:-1rem;width:calc(100% + 2rem)}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar{padding-left:0!important;padding-right:0!important}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar .userGroup-floating-bar-container .left .chip span{max-width:240px}::ng-deep .frequency-responsibility-list-search{position:relative}::ng-deep .frequency-responsibility-list-search input{height:2.75rem;line-height:1.5rem;padding:.75rem .75rem .75rem 2.5rem;outline:none;border:1px solid #7475763F;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .frequency-responsibility-list-search input::placeholder{color:#747576;opacity:1}::ng-deep .frequency-responsibility-list-search i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .frequency-responsibility-list-mid{height:calc(100% - 8rem);overflow:auto}::ng-deep .frequency-responsibility-list-mid::-webkit-scrollbar-track{background-color:#fff}::ng-deep .frequency-responsibility-list-mid.with-pagination{height:calc(100% - 10rem)}::ng-deep .frequency-responsibility-list-mid .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .frequency-responsibility-list-mid .table-header .table-column{color:#161b2f!important;line-height:.75rem!important;min-height:1.875rem!important}::ng-deep .frequency-responsibility-list-mid .table-body{position:relative}::ng-deep .frequency-responsibility-list-mid .table-body .table-row{background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;margin-bottom:.25rem}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial .sr-no,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial .sr-no{opacity:0}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial app-cs-radio,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .frequency-responsibility-list-mid .table-body .table-row lib-sub-responsibility{position:relative;top:2.5rem;left:0;width:100%;z-index:1;background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;padding:.5rem}::ng-deep .frequency-responsibility-list-mid .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .frequency-responsibility-list-mid .table-row .table-column{color:#747576;min-height:2.5rem;position:relative;width:100%}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial .sr-no{width:1rem;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio{position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio .radio-item{position:absolute}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility{width:calc(100% - 19rem);min-width:calc(100% - 19rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list{width:2.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list app-avatar~app-avatar{margin-left:-.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .resp-name{text-overflow:ellipsis;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center{width:14rem;min-width:14rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-inner{max-width:calc(100% - 2rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center button.program-count{background:#1e5dd3;border-radius:.125rem;border:none;min-width:1.5rem;height:1.25rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action{width:3rem;min-width:3rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action.active{cursor:pointer}::ng-deep .frequency-responsibility-list-mid .table-row.with-sub-responsibility{background:#f9f9fa;margin-bottom:0}@keyframes animate-right{0%{transform:translate(5px);opacity:0}to{transform:translate(0);opacity:1}}.wf-action-list{width:220px}.wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.wf-action-list ul.action-item{display:block}.wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
|
|
227
|
+
args: [{ selector: 'app-frequency-responsibility-list', template: "<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n <div class=\"vx-d-flex vx-align-center\">\n <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\"></i>\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n </div>\n </div>\n <div class=\"frequency-responsibility-list-body\">\n <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n <div class=\"frequency-responsibility-list-search vx-mb-2\">\n <i class=\"icons vx-fs-12\"></i>\n <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n placeholder=\"Search Responsibilities\" />\n </div>\n <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n (selectedPage)=\"responsibilityPageChange($event)\">\n </app-pagination>\n </ng-container>\n\n <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n !responsibilityLoader && responsibilitiesData?.total_pages > 1\n \">\n <app-no-data *ngIf=\"\n responsibilitiesData?.responsibilities?.length === 0 &&\n !responsibilityLoader\n \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n <ng-container *ngIf=\"\n responsibilitiesData?.responsibilities?.length > 0 &&\n !responsibilityLoader\n \">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n RESPONSIBILITIES\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n RESPONSIBILITY CENTER\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <!-- when click on radio then active class should be true -->\n <ng-container *ngFor=\"\n let responsibility of responsibilitiesData?.responsibilities;\n let i = index\n \">\n <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n responsibilitiesData?.limit +\n i +\n 1) as srNo\">\n <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n <div class=\"sr-no\" [appTooltip]=\"\n srNo \n \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{srNo}}\n </div>\n <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n \"\n (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n <div class=\"value vx-fs-12 vx-label-txt vx-pr-5 vx-d-flex vx-align-center\">\n <div class=\"avatar-list vx-d-flex vx-align-center\">\n <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n </div>\n\n <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n responsibility?.controlId }} {{\n responsibility?.title\n }}</span>\n </div>\n </div>\n\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n <ng-container *ngIf=\"responsibility?.allRc as rc\">\n <div class=\"program-inner vx-d-block\">\n <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n rc?.length\n ? rc[0]?.name\n : '--'\n \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n {{\n rc?.length\n ? rc[0]?.name\n : \"--\"\n }}\n </div>\n <ng-container *ngIf=\"\n rc?.length \n \">\n </ng-container>\n </div>\n <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n +{{ rc?.length - 1 }}\n </button>\n <app-popover #rcPopup>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"\n let data of rc?.slice(\n 1,\n rc?.length\n )\n \">\n <div class=\"avatar-card\">\n <div class=\"vx-d-block vx-w-100\">\n <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n </div>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </div>\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n (click)=\"onToggleResponsibility(responsibility)\">\n <ng-container\n *ngIf=\"assigneeDetails?.length > 1 && !(responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType)); else closeIcon\">\n <i *ngIf=\"\n openedResponsibility.includes(responsibility.id);\n else closeIcon\n \" class=\"icons vx-fs-10\"></i>\n <ng-template #closeIcon>\n <i class=\"icons vx-fs-10\"> </i>\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </div>\n <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/table-card/table-card.css\";::ng-deep .frequency-responsibility-list{border-top:3px solid #1e5dd3;position:fixed;top:0;right:32.5rem;bottom:0;left:0}::ng-deep .frequency-responsibility-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .frequency-responsibility-list-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .frequency-responsibility-list-head .arrow{cursor:pointer}::ng-deep .frequency-responsibility-list-body{background:#fff;height:calc(100% - 2.75rem);padding:1.5rem .75rem 1.5rem 2rem}::ng-deep .frequency-responsibility-list-body app-pagination .wk-pagination-sec-ds{border-radius:0;padding:0 0 .5rem}::ng-deep .frequency-responsibility-list-body app-floating-bar .floating-bar{padding:0;position:relative;left:-1rem;width:calc(100% + 2rem)}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar{padding-left:0!important;padding-right:0!important}::ng-deep .frequency-responsibility-list-body app-floating-bar .userGroup-floating-bar .userGroup-floating-bar-container .left .chip span{max-width:240px}::ng-deep .frequency-responsibility-list-search{position:relative}::ng-deep .frequency-responsibility-list-search input{height:2.75rem;line-height:1.5rem;padding:.75rem .75rem .75rem 2.5rem;outline:none;border:1px solid #7475763F;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .frequency-responsibility-list-search input::placeholder{color:#747576;opacity:1}::ng-deep .frequency-responsibility-list-search i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .frequency-responsibility-list-mid{height:calc(100% - 8rem);overflow:auto}::ng-deep .frequency-responsibility-list-mid::-webkit-scrollbar-track{background-color:#fff}::ng-deep .frequency-responsibility-list-mid.with-pagination{height:calc(100% - 10rem)}::ng-deep .frequency-responsibility-list-mid .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .frequency-responsibility-list-mid .table-header .table-column{color:#161b2f!important;line-height:.75rem!important;min-height:1.875rem!important}::ng-deep .frequency-responsibility-list-mid .table-body{position:relative}::ng-deep .frequency-responsibility-list-mid .table-body .table-row{background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;margin-bottom:.25rem}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial .sr-no,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial .sr-no{opacity:0}::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp:hover .table-column.serial app-cs-radio,::ng-deep .frequency-responsibility-list-mid .table-body .table-row.resp.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .frequency-responsibility-list-mid .table-body .table-row lib-sub-responsibility{position:relative;top:2.5rem;left:0;width:100%;z-index:1;background:#fff;border-radius:.25rem;border:1px solid #f1f1f1;padding:.5rem}::ng-deep .frequency-responsibility-list-mid .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .frequency-responsibility-list-mid .table-row .table-column{color:#747576;min-height:2.5rem;position:relative;width:100%}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial .sr-no{width:1rem;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio{position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.serial app-cs-radio .radio-item{position:absolute}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility{width:calc(100% - 19rem);min-width:calc(100% - 19rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list{width:2.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .avatar-list app-avatar~app-avatar{margin-left:-.5rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility .resp-name{text-overflow:ellipsis;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center{width:14rem;min-width:14rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-inner{max-width:calc(100% - 2rem)}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center .program-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.responsibility-center button.program-count{background:#1e5dd3;border-radius:.125rem;border:none;min-width:1.5rem;height:1.25rem}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action{width:3rem;min-width:3rem;justify-content:center}::ng-deep .frequency-responsibility-list-mid .table-row .table-column.action.active{cursor:pointer}::ng-deep .frequency-responsibility-list-mid .table-row.with-sub-responsibility{background:#f9f9fa;margin-bottom:0}@keyframes animate-right{0%{transform:translate(5px);opacity:0}to{transform:translate(0);opacity:1}}.wf-action-list{width:220px}.wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.wf-action-list ul.action-item{display:block}.wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
|
|
223
228
|
}], ctorParameters: function () { return [{ type: i1.FrequencyService }, { type: i2.CommonService }]; }, propDecorators: { selectedResponsibilityDetails: [{
|
|
224
229
|
type: Input
|
|
225
230
|
}], backButton: [{
|
|
@@ -227,4 +232,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
227
232
|
}], selectedResponsibility: [{
|
|
228
233
|
type: Output
|
|
229
234
|
}] } });
|
|
230
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-responsibility-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { slice } from 'lodash';\n\n@Component({\n  selector: 'app-frequency-responsibility-list',\n  templateUrl: './frequency-responsibility-list.component.html',\n  styleUrls: ['./frequency-responsibility-list.component.less'],\n})\nexport class FrequencyResponsibilityListComponent implements OnInit {\n  @Input() selectedResponsibilityDetails: any = {};\n\n  @Output() backButton = new EventEmitter();\n  @Output() selectedResponsibility = new EventEmitter();\n  \n  animation = false;\n  ASSETS = ASSETS;\n  responsibilitiesData: any = {};\n  responsibilityLoader: boolean = false;\n  selectedResponsibilityId: any = [];\n  selectedResponsibilityValues: any;\n  \n  responsibilitySearchText: string = '';\n  responsibilityCurrentPage: number = 1;\n  isValidObj = false;\n\n  responsibilityPayload = {\n    type: 'active',\n    paginationType: 'large',\n    a: '',\n    searchTerm: '',\n    filterData: {\n      appList: [],\n      riskIds: [],\n      reviewerId: [],\n      responsibilityCenter: [],\n      entrustedBy: [],\n      entrustedTo: [],\n      responsibilityCategory: [],\n      complianceType: [1],\n    },\n    pageNo: 1,\n    sortObj: {\n      sortBy: '',\n      type: '',\n    },\n    pageName: 'overview',\n  };\n  responsibilityList: any;\n  close: any;\n  openedResponsibility: any[] = [];\n\n\n  constructor(\n    private frequencyService: FrequencyService,\n    private commonService: CommonService\n  ) { }\n\n  ngOnInit(): void {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.getResponsibilityList();\n    this.populateResponsibility();\n  }\n\n  back() {\n    this.backButton.emit('backToOnCompletion');\n  }\n\n\n  getResponsibilityList() {\n    this.responsibilityLoader = true;\n    this.frequencyService\n      ?.getResponsibilityList(this.responsibilityPayload)\n      .subscribe((res: any) => {\n        this.responsibilitiesData = res?.data;\n        const pagination = this.commonService.setPagination(res?.data);\n        this.responsibilitiesData['pagination'] = pagination;\n        this.responsibilitiesData['responsibilities'] = this.mapResponsibilityData( this.responsibilitiesData)\n\n        this.responsibilityLoader = false;\n        const hasResponsibility = this.responsibilitiesData?.responsibilities?.find((responsibility: any) => responsibility.id === this.selectedResponsibilityValues?.responsibility?.id);\n        if(hasResponsibility) {\n          this.onToggleResponsibility(hasResponsibility);\n        }\n      }, (error: any) => {\n        this.responsibilityLoader = false;\n        console.log({ error }, \"Error in getting responsibility list\");\n      });\n  }\n\n  responsibilityPageChange(pageNumber: number) {\n    this.responsibilityCurrentPage = pageNumber;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.getResponsibilityList();\n  }\n\n\n  deleteItem(item: any) {\n    this.selectedResponsibilityValues = {};\n    this.isValidObj = false;\n    this.selectedResponsibilityId = [];\n  }\n  save(event: any) {\n    this.backButton.emit('backToOnCompletion');\n    this.selectedResponsibility.emit(this.selectedResponsibilityValues);\n  }\n\n\n  search() {\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.responsibilityCurrentPage = 1;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.getResponsibilityList();\n  }\n\n \n  \n  onToggleResponsibility(responsibility: any) {\n    if(this.openedResponsibility.includes(responsibility.id)) {\n      this.openedResponsibility = this.openedResponsibility.filter((id: any) => id !== responsibility.id);\n    } else {\n      this.openedResponsibility.push(responsibility.id);\n    }\n  }\n\n\n    // Main method exposed outside\n    public mapResponsibilityData(responsibility: any): any[] {\n      if (!responsibility) return [];\n  \n      const users = this.mapShortNames(responsibility.users, this.mapShortName);\n      const userMap = this.buildMap(users);\n      const rcMap = this.buildMap(responsibility.responsibilityCenters);\n  \n      return (responsibility.responsibilities || []).map((item: any) =>\n        this.mapResponsibilityItem(item, userMap, rcMap)\n      );\n    }\n  \n    // Helper methods below:\n  \n    private mapShortNames(users: any[], mapShortName: (name: string) => string): any[] {\n      return (users || []).map(user => ({\n        ...user,\n        shortName: mapShortName(user.name),\n      }));\n    }\n  \n    private buildMap(arr: any[]): Map<string, any> {\n      return new Map((arr || []).map(item => [item.id, item]));\n    }\n  \n    private mapAssigneeUsers(assignee: any, activeUserIds: string[], userMap: Map<string, any>): any[] {\n      if (!assignee.assignee) {\n        return (activeUserIds || []).map(id => userMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.assignee) ? assignee.assignee : [assignee.assignee];\n      return ids.map((id: any) => userMap.get((id))).filter(Boolean);\n    }\n  \n    private mapResponsibilityCenters(assignee: any, itemRCIds: string[], rcMap: Map<string, any>): any[] {\n      if (!assignee.responsibilityCenter) {\n        return (itemRCIds || []).map(id => rcMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.responsibilityCenter) ? assignee.responsibilityCenter : [assignee.responsibilityCenter];\n      return ids.map((id: any) => rcMap.get(id)).filter(Boolean);\n    }\n  \n    private mapResponsibilityItem(item: any, userMap: Map<string, any>, rcMap: Map<string, any>): any {\n\n      let  assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        if(assigneeDetails?.length === 0 && item?.assigneeType === 'any' && [null, 'any'].includes(item?.rcType)) {\n          assigneeDetails = [{\n            ...item.assigneeDetails,\n            status: 'active',\n          }]\n        }\n        assigneeDetails =  assigneeDetails.map((ad: any) => ({\n          ...ad,\n          assigneeInfo: this.mapAssigneeUsers(ad, item.assignees?.activeUserId || [], userMap),\n          responsibilityCenterInfo: this.mapResponsibilityCenters(ad, item.responsibilityCenters || [], rcMap),\n        }));\n        const allAssignee = this.removeDuplicateAssignee(assigneeDetails).map((ad: any) => ad.assigneeInfo[0]);\n        const allRc = this.mapRcs(item.responsibilityCenters);\n      return {\n        id: item.id,\n        title: item.title,\n        controlId: item?.controlId ? '[CID-' + item?.controlId + '] ' : '',\n        assigneeDetails,\n         allAssignee,\n         allRc\n      };\n    }\n\n    removeDuplicateAssignee(assigneeDetails: any) {\n      const uniqueMap = new Map();\n      assigneeDetails.forEach((obj: any) => {\n        uniqueMap.set(obj.assignee, obj);\n      });\n      const uniqueArray = Array.from(uniqueMap.values());\n          return uniqueArray;\n        }\n\n      mapRcs(rcs: any) {\n        return this.responsibilitiesData?.responsibilityCenters?.filter((rc: any) => rcs?.includes(rc?.id));\n      }\n  \n  mapShortName(name: string) {\n    const nameArray = name?.split(' ');\n    if(nameArray?.length > 1) {\n      return nameArray[0]?.charAt(0) + nameArray[nameArray?.length - 1]?.charAt(0);\n    }\n    return nameArray[0]?.charAt(0) + nameArray[0]?.charAt(1)?.toUpperCase();\n  }\n\n  populateResponsibility() {\n    if(!this.selectedResponsibilityDetails?.assignee) {\n      return;\n    }\n    this.selectedResponsibilityValues =  {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [{\n          assignee: this.selectedResponsibilityDetails.assignee,\n          responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n        }],\n        eachAssignee: {},\n      }\n    }\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\n  }\n}\n","<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n  <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-d-flex vx-align-center\">\n      <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\">&#xe91d;</i>\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n    </div>\n  </div>\n  <div class=\"frequency-responsibility-list-body\">\n    <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n    <div class=\"frequency-responsibility-list-search vx-mb-2\">\n      <i class=\"icons vx-fs-12\">&#xe90b;</i>\n      <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n        placeholder=\"Search Responsibilities\" />\n    </div>\n    <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n      <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n        [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n        [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n        (selectedPage)=\"responsibilityPageChange($event)\">\n      </app-pagination>\n    </ng-container>\n\n    <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n    <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n        !responsibilityLoader && responsibilitiesData?.total_pages > 1\n      \">\n      <app-no-data *ngIf=\"\n          responsibilitiesData?.responsibilities?.length === 0 &&\n          !responsibilityLoader\n        \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n      <ng-container *ngIf=\"\n          responsibilitiesData?.responsibilities?.length > 0 &&\n          !responsibilityLoader\n        \">\n        <div class=\"table-header\">\n          <div class=\"table-row\">\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n              #\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n              RESPONSIBILITIES\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n              RESPONSIBILITY CENTER\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n            </div>\n          </div>\n        </div>\n        <div class=\"table-body\">\n          <!-- when click on radio then active class should be true -->\n          <ng-container *ngFor=\"\n              let responsibility of responsibilitiesData?.responsibilities;\n              let i = index\n            \">\n            <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n            responsibilitiesData?.limit +\n            i +\n            1) as srNo\">\n              <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n                selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n              \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n                <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n                    <div class=\"sr-no\" [appTooltip]=\"\n                      srNo  \n                    \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                      {{srNo}}\n                    </div>\n                    <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n                      selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n                    \"\n                      (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n                    <div class=\"value vx-fs-12 vx-label-txt vx-pr-5  vx-d-flex vx-align-center\">\n                      <div class=\"avatar-list vx-d-flex vx-align-center\">\n                        <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n                          [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n                      </div>\n\n                      <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n                        placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                        responsibility?.controlId }} {{\n                        responsibility?.title\n                        }}</span>\n                    </div>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n                    <ng-container *ngIf=\"responsibility?.allRc as rc\">\n                      <div class=\"program-inner vx-d-block\">\n                        <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n                        rc?.length\n                          ? rc[0]?.name\n                          : '--'\n                      \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                          {{\n                          rc?.length\n                          ? rc[0]?.name\n                          : \"--\"\n                          }}\n                        </div>\n                        <ng-container *ngIf=\"\n                        rc?.length \n                      \">\n                        </ng-container>\n                      </div>\n                      <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n                        class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n                        +{{ rc?.length - 1 }}\n                      </button>\n                      <app-popover #rcPopup>\n                        <div class=\"wf-action-list\">\n                          <ul class=\"action-item\">\n                            <li *ngFor=\"\n                            let data of rc?.slice(\n                              1,\n                              rc?.length\n                            )\n                          \">\n                              <div class=\"avatar-card\">\n                                <div class=\"vx-d-block vx-w-100\">\n                                  <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n                                    type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n                                </div>\n                              </div>\n                            </li>\n                          </ul>\n                        </div>\n                      </app-popover>\n                    </ng-container>\n                  </div>\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n                    (click)=\"onToggleResponsibility(responsibility)\">\n                    <ng-container *ngIf=\"assigneeDetails?.length > 1; else closeIcon\">\n                      <i *ngIf=\"\n                        openedResponsibility.includes(responsibility.id);\n                        else closeIcon\n                      \" class=\"icons vx-fs-10\">&#xe9e7;</i>\n                      <ng-template #closeIcon>\n                        <i class=\"icons vx-fs-10\"> &#xe9e8;</i>\n                      </ng-template>\n                    </ng-container>\n                  </div>\n                </ng-container>\n              </div>\n              <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n                [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n                (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n      (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n      [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n  </div>\n</div>"]}
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-responsibility-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,MAAM,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;;;;;;AAS7D,MAAM,OAAO,oCAAoC;IA4C/C,YACU,gBAAkC,EAClC,aAA4B;QAD5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QA7C7B,kCAA6B,GAAQ,EAAE,CAAC;QAEvC,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAChC,2BAAsB,GAAG,IAAI,YAAY,EAAE,CAAC;QAEtD,cAAS,GAAG,KAAK,CAAC;QAClB,WAAM,GAAG,MAAM,CAAC;QAChB,yBAAoB,GAAQ,EAAE,CAAC;QAC/B,yBAAoB,GAAY,KAAK,CAAC;QACtC,6BAAwB,GAAQ,EAAE,CAAC;QAGnC,6BAAwB,GAAW,EAAE,CAAC;QACtC,8BAAyB,GAAW,CAAC,CAAC;QACtC,eAAU,GAAG,KAAK,CAAC;QAEnB,0BAAqB,GAAG;YACtB,IAAI,EAAE,QAAQ;YACd,cAAc,EAAE,OAAO;YACvB,CAAC,EAAE,EAAE;YACL,UAAU,EAAE,EAAE;YACd,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE;gBACX,OAAO,EAAE,EAAE;gBACX,UAAU,EAAE,EAAE;gBACd,oBAAoB,EAAE,EAAE;gBACxB,WAAW,EAAE,EAAE;gBACf,WAAW,EAAE,EAAE;gBACf,sBAAsB,EAAE,EAAE;gBAC1B,cAAc,EAAE,CAAC,CAAC,CAAC;aACpB;YACD,MAAM,EAAE,CAAC;YACT,OAAO,EAAE;gBACP,MAAM,EAAE,EAAE;gBACV,IAAI,EAAE,EAAE;aACT;YACD,QAAQ,EAAE,UAAU;SACrB,CAAC;QAGF,yBAAoB,GAAU,EAAE,CAAC;IAM7B,CAAC;IAEL,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;QACR,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,IAAI;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IAC7C,CAAC;IAGD,qBAAqB;QACnB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,gBAAgB;YACnB,EAAE,qBAAqB,CAAC,IAAI,CAAC,qBAAqB,CAAC;aAClD,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,IAAI,CAAC,oBAAoB,GAAG,GAAG,EAAE,IAAI,CAAC;YACtC,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAC/D,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,GAAG,UAAU,CAAC;YACrD,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,qBAAqB,CAAE,IAAI,CAAC,oBAAoB,CAAC,CAAA;YAEtG,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,EAAE,gBAAgB,EAAE,IAAI,CAAC,CAAC,cAAmB,EAAE,EAAE,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC,4BAA4B,EAAE,cAAc,EAAE,EAAE,CAAC,CAAC;YAClL,IAAG,iBAAiB,EAAE;gBACpB,IAAI,CAAC,sBAAsB,CAAC,iBAAiB,CAAC,CAAC;aAChD;QACH,CAAC,EAAE,CAAC,KAAU,EAAE,EAAE;YAChB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,sCAAsC,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,wBAAwB,CAAC,UAAkB;QACzC,IAAI,CAAC,yBAAyB,GAAG,UAAU,CAAC;QAC5C,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,IAAI,CAAC,yBAAyB,CAAC;QACnE,IAAI,CAAC,qBAAqB,CAAC,UAAU,GAAG,IAAI,CAAC,wBAAwB,CAAC;QACtE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAGD,UAAU,CAAC,IAAS;QAClB,IAAI,CAAC,4BAA4B,GAAG,EAAE,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;IACrC,CAAC;IACD,IAAI,CAAC,KAAU;QACb,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC3C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IACtE,CAAC;IAGD,MAAM;QACJ,IAAI,CAAC,qBAAqB,CAAC,UAAU,GAAG,IAAI,CAAC,wBAAwB,CAAC;QACtE,IAAI,CAAC,yBAAyB,GAAG,CAAC,CAAC;QACnC,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,IAAI,CAAC,yBAAyB,CAAC;QACnE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAID,sBAAsB,CAAC,cAAmB;QACxC,IAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE;YACxD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,KAAK,cAAc,CAAC,EAAE,CAAC,CAAC;SACrG;aAAM;YACL,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SACnD;IACH,CAAC;IAGC,8BAA8B;IACvB,qBAAqB,CAAC,cAAmB;QAC9C,IAAI,CAAC,cAAc;YAAE,OAAO,EAAE,CAAC;QAE/B,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1E,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC;QAElE,OAAO,CAAC,cAAc,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAC/D,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,CACjD,CAAC;IACJ,CAAC;IAED,wBAAwB;IAEhB,aAAa,CAAC,KAAY,EAAE,YAAsC;QACxE,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChC,GAAG,IAAI;YACP,SAAS,EAAE,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;SACnC,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,QAAQ,CAAC,GAAU;QACzB,OAAO,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;IAEO,gBAAgB,CAAC,QAAa,EAAE,aAAuB,EAAE,OAAyB;QACxF,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACtB,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SACzE;QACD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACvF,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC;IAEO,wBAAwB,CAAC,QAAa,EAAE,SAAmB,EAAE,KAAuB;QAC1F,IAAI,CAAC,QAAQ,CAAC,oBAAoB,EAAE;YAClC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SACnE;QACD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QAC3H,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC7D,CAAC;IAEO,qBAAqB,CAAC,IAAS,EAAE,OAAyB,EAAE,KAAuB;QAEzF,IAAK,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;aAChD,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,CAAA;QACvE,IAAG,eAAe,EAAE,MAAM,KAAK,CAAC,IAAI,IAAI,EAAE,YAAY,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE;YAExG,eAAe,GAAI,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE;gBAC/D,OAAO;oBACL,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;oBAC1B,MAAM,EAAE,QAAQ;oBAChB,QAAQ,EAAE,EAAE;iBACb,CAAA;YACH,CAAC,CAAC,CAAC;SACJ;QACD,eAAe,GAAI,eAAe,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,CAAC;YACnD,GAAG,EAAE;YACL,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY,IAAI,EAAE,EAAE,OAAO,CAAC;YACpF,wBAAwB,EAAE,IAAI,CAAC,wBAAwB,CAAC,EAAE,EAAE,IAAI,CAAC,qBAAqB,IAAI,EAAE,EAAE,KAAK,CAAC;SACrG,CAAC,CAAC,CAAC;QACJ,MAAM,WAAW,GAAG,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QACvG,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACxD,OAAO;YACL,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,SAAS,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,OAAO,GAAG,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE;YAClE,YAAY,EAAE,IAAI,EAAE,YAAY;YAChC,MAAM,EAAE,IAAI,EAAE,MAAM;YACpB,eAAe;YACd,WAAW;YACX,KAAK;SACP,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,eAAoB;QAC1C,MAAM,SAAS,GAAG,IAAI,GAAG,EAAE,CAAC;QAC5B,eAAe,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YACnC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/C,OAAO,WAAW,CAAC;IACrB,CAAC;IAEH,MAAM,CAAC,GAAQ;QACb,OAAO,IAAI,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACtG,CAAC;IAEL,YAAY,CAAC,IAAY;QACvB,MAAM,SAAS,GAAG,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,IAAG,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE;YACxB,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;SAC9E;QACD,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC;IAC1E,CAAC;IAED,sBAAsB;QACpB,IAAG,CAAC,IAAI,CAAC,6BAA6B,EAAE,QAAQ,EAAE;YAChD,OAAO;SACR;QACD,IAAI,CAAC,4BAA4B,GAAI;YACnC,YAAY,EAAE;gBACZ,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ;gBACrD,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB;aAC9E;YACD,cAAc,EAAE;gBACd,KAAK,EAAE,IAAI,CAAC,6BAA6B,CAAC,KAAK;gBAC/C,EAAE,EAAE,IAAI,CAAC,6BAA6B,CAAC,EAAE;gBACzC,KAAK,EAAE,EAAE;gBACT,WAAW,EAAE,EAAE;gBACf,eAAe,EAAE,CAAC;wBAChB,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ;wBACrD,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB;qBAC9E,CAAC;gBACF,YAAY,EAAE,EAAE;aACjB;SACF,CAAA;IACH,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAA;IAC3C,CAAC;+GAlPU,oCAAoC;mGAApC,oCAAoC,8OCXjD,gnSAuKM;;4FD5JO,oCAAoC;kBALhD,SAAS;+BACE,mCAAmC;mIAKpC,6BAA6B;sBAArC,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBACG,sBAAsB;sBAA/B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { slice } from 'lodash';\n\n@Component({\n  selector: 'app-frequency-responsibility-list',\n  templateUrl: './frequency-responsibility-list.component.html',\n  styleUrls: ['./frequency-responsibility-list.component.less'],\n})\nexport class FrequencyResponsibilityListComponent implements OnInit {\n  @Input() selectedResponsibilityDetails: any = {};\n\n  @Output() backButton = new EventEmitter();\n  @Output() selectedResponsibility = new EventEmitter();\n  \n  animation = false;\n  ASSETS = ASSETS;\n  responsibilitiesData: any = {};\n  responsibilityLoader: boolean = false;\n  selectedResponsibilityId: any = [];\n  selectedResponsibilityValues: any;\n  \n  responsibilitySearchText: string = '';\n  responsibilityCurrentPage: number = 1;\n  isValidObj = false;\n\n  responsibilityPayload = {\n    type: 'active',\n    paginationType: 'large',\n    a: '',\n    searchTerm: '',\n    filterData: {\n      appList: [],\n      riskIds: [],\n      reviewerId: [],\n      responsibilityCenter: [],\n      entrustedBy: [],\n      entrustedTo: [],\n      responsibilityCategory: [],\n      complianceType: [1],\n    },\n    pageNo: 1,\n    sortObj: {\n      sortBy: '',\n      type: '',\n    },\n    pageName: 'overview',\n  };\n  responsibilityList: any;\n  close: any;\n  openedResponsibility: any[] = [];\n\n\n  constructor(\n    private frequencyService: FrequencyService,\n    private commonService: CommonService\n  ) { }\n\n  ngOnInit(): void {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.getResponsibilityList();\n    this.populateResponsibility();\n  }\n\n  back() {\n    this.backButton.emit('backToOnCompletion');\n  }\n\n\n  getResponsibilityList() {\n    this.responsibilityLoader = true;\n    this.frequencyService\n      ?.getResponsibilityList(this.responsibilityPayload)\n      .subscribe((res: any) => {\n        this.responsibilitiesData = res?.data;\n        const pagination = this.commonService.setPagination(res?.data);\n        this.responsibilitiesData['pagination'] = pagination;\n        this.responsibilitiesData['responsibilities'] = this.mapResponsibilityData( this.responsibilitiesData)\n\n        this.responsibilityLoader = false;\n        const hasResponsibility = this.responsibilitiesData?.responsibilities?.find((responsibility: any) => responsibility.id === this.selectedResponsibilityValues?.responsibility?.id);\n        if(hasResponsibility) {\n          this.onToggleResponsibility(hasResponsibility);\n        }\n      }, (error: any) => {\n        this.responsibilityLoader = false;\n        console.log({ error }, \"Error in getting responsibility list\");\n      });\n  }\n\n  responsibilityPageChange(pageNumber: number) {\n    this.responsibilityCurrentPage = pageNumber;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.getResponsibilityList();\n  }\n\n\n  deleteItem(item: any) {\n    this.selectedResponsibilityValues = {};\n    this.isValidObj = false;\n    this.selectedResponsibilityId = [];\n  }\n  save(event: any) {\n    this.backButton.emit('backToOnCompletion');\n    this.selectedResponsibility.emit(this.selectedResponsibilityValues);\n  }\n\n\n  search() {\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.responsibilityCurrentPage = 1;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.getResponsibilityList();\n  }\n\n \n  \n  onToggleResponsibility(responsibility: any) {\n    if(this.openedResponsibility.includes(responsibility.id)) {\n      this.openedResponsibility = this.openedResponsibility.filter((id: any) => id !== responsibility.id);\n    } else {\n      this.openedResponsibility.push(responsibility.id);\n    }\n  }\n\n\n    // Main method exposed outside\n    public mapResponsibilityData(responsibility: any): any[] {\n      if (!responsibility) return [];\n  \n      const users = this.mapShortNames(responsibility.users, this.mapShortName);\n      const userMap = this.buildMap(users);\n      const rcMap = this.buildMap(responsibility.responsibilityCenters);\n  \n      return (responsibility.responsibilities || []).map((item: any) =>\n        this.mapResponsibilityItem(item, userMap, rcMap)\n      );\n    }\n  \n    // Helper methods below:\n  \n    private mapShortNames(users: any[], mapShortName: (name: string) => string): any[] {\n      return (users || []).map(user => ({\n        ...user,\n        shortName: mapShortName(user.name),\n      }));\n    }\n  \n    private buildMap(arr: any[]): Map<string, any> {\n      return new Map((arr || []).map(item => [item.id, item]));\n    }\n  \n    private mapAssigneeUsers(assignee: any, activeUserIds: string[], userMap: Map<string, any>): any[] {\n      if (!assignee.assignee) {\n        return (activeUserIds || []).map(id => userMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.assignee) ? assignee.assignee : [assignee.assignee];\n      return ids.map((id: any) => userMap.get((id))).filter(Boolean);\n    }\n  \n    private mapResponsibilityCenters(assignee: any, itemRCIds: string[], rcMap: Map<string, any>): any[] {\n      if (!assignee.responsibilityCenter) {\n        return (itemRCIds || []).map(id => rcMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.responsibilityCenter) ? assignee.responsibilityCenter : [assignee.responsibilityCenter];\n      return ids.map((id: any) => rcMap.get(id)).filter(Boolean);\n    }\n  \n    private mapResponsibilityItem(item: any, userMap: Map<string, any>, rcMap: Map<string, any>): any {\n\n      let  assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        if(assigneeDetails?.length === 0 && item?.assigneeType === 'any' && [null, 'any'].includes(item?.rcType)) {\n\n          assigneeDetails =  item.assignees?.activeUserId?.map((id: any) => {\n            return {\n              ...item.assigneeDetails[0],\n              status: 'active',\n              assignee: id,\n            }\n          });\n        }\n        assigneeDetails =  assigneeDetails.map((ad: any) => ({\n          ...ad,\n          assigneeInfo: this.mapAssigneeUsers(ad, item.assignees?.activeUserId || [], userMap),\n          responsibilityCenterInfo: this.mapResponsibilityCenters(ad, item.responsibilityCenters || [], rcMap),\n        }));\n        const allAssignee = this.removeDuplicateAssignee(assigneeDetails).map((ad: any) => ad.assigneeInfo[0]);\n        const allRc = this.mapRcs(item.responsibilityCenters);\n      return {\n        id: item.id,\n        title: item.title,\n        controlId: item?.controlId ? '[CID-' + item?.controlId + '] ' : '',\n        assigneeType: item?.assigneeType,\n        rcType: item?.rcType,\n        assigneeDetails,\n         allAssignee,\n         allRc\n      };\n    }\n\n    removeDuplicateAssignee(assigneeDetails: any) {\n      const uniqueMap = new Map();\n      assigneeDetails.forEach((obj: any) => {\n        uniqueMap.set(obj.assignee, obj);\n      });\n      const uniqueArray = Array.from(uniqueMap.values());\n          return uniqueArray;\n        }\n\n      mapRcs(rcs: any) {\n        return this.responsibilitiesData?.responsibilityCenters?.filter((rc: any) => rcs?.includes(rc?.id));\n      }\n  \n  mapShortName(name: string) {\n    const nameArray = name?.split(' ');\n    if(nameArray?.length > 1) {\n      return nameArray[0]?.charAt(0) + nameArray[nameArray?.length - 1]?.charAt(0);\n    }\n    return nameArray[0]?.charAt(0) + nameArray[0]?.charAt(1)?.toUpperCase();\n  }\n\n  populateResponsibility() {\n    if(!this.selectedResponsibilityDetails?.assignee) {\n      return;\n    }\n    this.selectedResponsibilityValues =  {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [{\n          assignee: this.selectedResponsibilityDetails.assignee,\n          responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n        }],\n        eachAssignee: {},\n      }\n    }\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\n  }\n}\n","<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n  <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-d-flex vx-align-center\">\n      <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\">&#xe91d;</i>\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n    </div>\n  </div>\n  <div class=\"frequency-responsibility-list-body\">\n    <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n    <div class=\"frequency-responsibility-list-search vx-mb-2\">\n      <i class=\"icons vx-fs-12\">&#xe90b;</i>\n      <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n        placeholder=\"Search Responsibilities\" />\n    </div>\n    <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n      <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n        [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n        [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n        (selectedPage)=\"responsibilityPageChange($event)\">\n      </app-pagination>\n    </ng-container>\n\n    <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n    <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n        !responsibilityLoader && responsibilitiesData?.total_pages > 1\n      \">\n      <app-no-data *ngIf=\"\n          responsibilitiesData?.responsibilities?.length === 0 &&\n          !responsibilityLoader\n        \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n      <ng-container *ngIf=\"\n          responsibilitiesData?.responsibilities?.length > 0 &&\n          !responsibilityLoader\n        \">\n        <div class=\"table-header\">\n          <div class=\"table-row\">\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n              #\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n              RESPONSIBILITIES\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n              RESPONSIBILITY CENTER\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n            </div>\n          </div>\n        </div>\n        <div class=\"table-body\">\n          <!-- when click on radio then active class should be true -->\n          <ng-container *ngFor=\"\n              let responsibility of responsibilitiesData?.responsibilities;\n              let i = index\n            \">\n            <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n            responsibilitiesData?.limit +\n            i +\n            1) as srNo\">\n              <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n                selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n              \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n                <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n                    <div class=\"sr-no\" [appTooltip]=\"\n                      srNo  \n                    \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                      {{srNo}}\n                    </div>\n                    <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n                      selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n                    \"\n                      (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n                    <div class=\"value vx-fs-12 vx-label-txt vx-pr-5  vx-d-flex vx-align-center\">\n                      <div class=\"avatar-list vx-d-flex vx-align-center\">\n                        <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n                          [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n                      </div>\n\n                      <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n                        placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                        responsibility?.controlId }} {{\n                        responsibility?.title\n                        }}</span>\n                    </div>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n                    <ng-container *ngIf=\"responsibility?.allRc as rc\">\n                      <div class=\"program-inner vx-d-block\">\n                        <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n                        rc?.length\n                          ? rc[0]?.name\n                          : '--'\n                      \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                          {{\n                          rc?.length\n                          ? rc[0]?.name\n                          : \"--\"\n                          }}\n                        </div>\n                        <ng-container *ngIf=\"\n                        rc?.length \n                      \">\n                        </ng-container>\n                      </div>\n                      <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n                        class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n                        +{{ rc?.length - 1 }}\n                      </button>\n                      <app-popover #rcPopup>\n                        <div class=\"wf-action-list\">\n                          <ul class=\"action-item\">\n                            <li *ngFor=\"\n                            let data of rc?.slice(\n                              1,\n                              rc?.length\n                            )\n                          \">\n                              <div class=\"avatar-card\">\n                                <div class=\"vx-d-block vx-w-100\">\n                                  <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n                                    type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n                                </div>\n                              </div>\n                            </li>\n                          </ul>\n                        </div>\n                      </app-popover>\n                    </ng-container>\n                  </div>\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n                    (click)=\"onToggleResponsibility(responsibility)\">\n                    <ng-container\n                      *ngIf=\"assigneeDetails?.length > 1 && !(responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType)); else closeIcon\">\n                      <i *ngIf=\"\n                        openedResponsibility.includes(responsibility.id);\n                        else closeIcon\n                      \" class=\"icons vx-fs-10\">&#xe9e7;</i>\n                      <ng-template #closeIcon>\n                        <i class=\"icons vx-fs-10\"> &#xe9e8;</i>\n                      </ng-template>\n                    </ng-container>\n                  </div>\n                </ng-container>\n              </div>\n              <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n                [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n                (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n      (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n      [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n  </div>\n</div>"]}
|