vcomply-workflow-engine 6.2.1 → 6.2.3

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.
@@ -1,6 +1,6 @@
1
- import { Component, Input, Output, EventEmitter } from '@angular/core';
2
- import { PAGINATION_OPTIONS, PROGRAM_TYPE_LIST } from '../../program-list/constant';
3
- import { POLICY_CATEGORY_TABLE_HEADERS, POLICY_NO_DATA } from '../constants/policy.constants';
1
+ import { Component, Input, Output, EventEmitter, } from '@angular/core';
2
+ import { PAGINATION_OPTIONS, PROGRAM_TYPE_LIST, } from '../../program-list/constant';
3
+ import { POLICY_CATEGORY_TABLE_HEADERS, POLICY_NO_DATA, } from '../constants/policy.constants';
4
4
  import { Subject } from 'rxjs';
5
5
  import { debounceTime, takeUntil } from 'rxjs/operators';
6
6
  import { ASSETS } from '../../../constants/assets.constants';
@@ -10,7 +10,7 @@ import * as i1 from "../../program-list/services/list-utils.service";
10
10
  import * as i2 from "../services/policy-list-api.service";
11
11
  import * as i3 from "@angular/common";
12
12
  import * as i4 from "@angular/forms";
13
- import * as i5 from "../../../formgroup/cs-checkbox/cs-checkbox.component";
13
+ import * as i5 from "../../../formgroup/cs-radio/cs-radio.component";
14
14
  import * as i6 from "../../../ui-kit/no-data/no-data.component";
15
15
  import * as i7 from "../../../ui-kit/loaders/table-loader/table-loader.component";
16
16
  import * as i8 from "../../../pipes/search.pipe";
@@ -48,18 +48,21 @@ export class PolicyCategoryListComponent {
48
48
  this.POLICY_NO_DATA = POLICY_NO_DATA;
49
49
  this.ASSETS = ASSETS;
50
50
  this.programCategoryList = {};
51
+ this.policyCategoryList = [];
51
52
  /** Subject for handling debounced search */
52
53
  this.searchSubject = new Subject();
53
54
  /** Subject for cleanup subscriptions */
54
55
  this.destroy$ = new Subject();
55
56
  // Initialize debounced search
56
- this.searchSubject.pipe(debounceTime(300), takeUntil(this.destroy$)).subscribe(() => {
57
+ this.searchSubject
58
+ .pipe(debounceTime(300), takeUntil(this.destroy$))
59
+ .subscribe(() => {
57
60
  this.performSearch();
58
61
  });
59
62
  }
60
63
  /** Initialize component by fetching program list */
61
64
  ngOnInit() {
62
- console.log("PolicyCategoryListComponent", this.items);
65
+ console.log('PolicyCategoryListComponent', this.items);
63
66
  this.getProgramList();
64
67
  }
65
68
  /** Handle changes to inputs */
@@ -71,7 +74,10 @@ export class PolicyCategoryListComponent {
71
74
  /** Fetch program list from API */
72
75
  getProgramList() {
73
76
  this.loaderState.programList = true;
74
- this.items = POLICY_CATEGORY_LIST_STUBS.data.policyCategories;
77
+ this.items = this.prepareCategoryList(POLICY_CATEGORY_LIST_STUBS.data.policyCategories);
78
+ this.viewCategory(this.items[0]);
79
+ console.log(this.items, 'items');
80
+ // this.items = POLICY_CATEGORY_LIST_STUBS.data.policyCategories as any;
75
81
  this.loadData(this.items);
76
82
  this.loaderState.programList = false;
77
83
  // this.programListApiService.getProgramList(this.url.programList).subscribe((res: any) => {
@@ -87,6 +93,51 @@ export class PolicyCategoryListComponent {
87
93
  loadData(data) {
88
94
  this.goToPage(1, data);
89
95
  }
96
+ prepareCategoryList(categories) {
97
+ const map = new Map();
98
+ categories.forEach((cat) => map.set(cat.id, cat));
99
+ // Check if category is a root
100
+ const isRoot = (cat) => (cat.parent === null && cat.origin === null) ||
101
+ (!map.has(cat.parent) && !map.has(cat.origin));
102
+ return categories.filter(isRoot).map((root) => ({
103
+ id: root.id,
104
+ name: root.name,
105
+ children: [
106
+ {
107
+ id: root.id,
108
+ name: root.name,
109
+ children: [],
110
+ display_name: '',
111
+ },
112
+ ...this.buildChildren(root, categories, map),
113
+ ],
114
+ }));
115
+ }
116
+ buildPath(categories, map) {
117
+ const names = []; // start with child name
118
+ let current = categories;
119
+ while (current && current.parent !== null) {
120
+ const parent = map.get(current.parent);
121
+ if (parent) {
122
+ names.push(parent.name);
123
+ current = parent;
124
+ }
125
+ else {
126
+ break;
127
+ }
128
+ }
129
+ return names.join(" < ");
130
+ }
131
+ buildChildren(root, categories, map) {
132
+ return categories
133
+ .filter((c) => c.origin === root.id || c.parent === root.id)
134
+ .map((child) => ({
135
+ id: child.id,
136
+ name: child.name,
137
+ children: [],
138
+ display_name: this.buildPath(child, map),
139
+ }));
140
+ }
90
141
  /**
91
142
  * Handle item selection/deselection
92
143
  * @param event Selection event
@@ -151,10 +202,13 @@ export class PolicyCategoryListComponent {
151
202
  */
152
203
  viewCategory(item) {
153
204
  this.activeProgram = item;
154
- if (!item || this.categoryList[item.id])
155
- return;
156
205
  this.loaderState.categoryList = true;
157
- this.checkProgramCategoryExists(item?.id);
206
+ this.policyCategoryList = this.items.find((category) => category.id === item.id)?.children;
207
+ this.loaderState.categoryList = false;
208
+ console.log(this.activeProgram, this.policyCategoryList, 'activeProgram');
209
+ // if (!item || this.categoryList[item.id]) return;
210
+ // this.loaderState.categoryList = true;
211
+ // this.checkProgramCategoryExists(item?.id);
158
212
  }
159
213
  checkProgramCategoryExists(id) {
160
214
  if (this.programCategoryList[id]) {
@@ -166,7 +220,9 @@ export class PolicyCategoryListComponent {
166
220
  }
167
221
  fetchProgramCategoryList(id) {
168
222
  const URL = `${this.url.categoryList}&id=${id}`;
169
- this.policyListApiService.getPolicyCategoryList(URL).subscribe((res) => {
223
+ this.policyListApiService
224
+ .getPolicyCategoryList(URL)
225
+ .subscribe((res) => {
170
226
  this.programCategoryList[id] = res?.data?.categories ?? [];
171
227
  this.categoryList[id] = this.addParentTreeToCategories(this.programCategoryList[id]);
172
228
  this.loaderState.categoryList = false;
@@ -180,7 +236,7 @@ export class PolicyCategoryListComponent {
180
236
  addParentTreeToCategories(categories) {
181
237
  if (!categories?.length)
182
238
  return [];
183
- const categoryMap = new Map(categories.map(category => [category.id, category]));
239
+ const categoryMap = new Map(categories.map((category) => [category.id, category]));
184
240
  const getParentTree = (category) => {
185
241
  const parentTree = [];
186
242
  let currentParent = category.parent;
@@ -193,9 +249,9 @@ export class PolicyCategoryListComponent {
193
249
  }
194
250
  return parentTree;
195
251
  };
196
- return categories.map(category => ({
252
+ return categories.map((category) => ({
197
253
  ...category,
198
- parentTree: getParentTree(category)
254
+ parentTree: getParentTree(category),
199
255
  }));
200
256
  }
201
257
  /**
@@ -235,8 +291,15 @@ export class PolicyCategoryListComponent {
235
291
  }
236
292
  }
237
293
  /** Trigger debounced search */
238
- search() {
239
- this.searchSubject.next(this.searchTerm);
294
+ search(header) {
295
+ if (header.toLowerCase() === 'policy category') {
296
+ this.searchTerm = this.searchTerm.toLowerCase();
297
+ this.paginatedItems = this.items.filter((item) => item?.name?.toLowerCase().includes(this.searchTerm));
298
+ }
299
+ else if (header.toLowerCase() === 'policy sub categories') {
300
+ this.searchTerm = this.searchTerm.toLowerCase();
301
+ this.paginatedItems = this.items.filter((item) => item?.name?.toLowerCase().includes(this.searchTerm));
302
+ }
240
303
  }
241
304
  /** Perform search on items */
242
305
  performSearch() {
@@ -255,11 +318,11 @@ export class PolicyCategoryListComponent {
255
318
  }
256
319
  }
257
320
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PolicyCategoryListComponent, deps: [{ token: i1.ListUtilsService }, { token: i2.PolicyListApiService }], target: i0.ɵɵFactoryTarget.Component }); }
258
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PolicyCategoryListComponent, selector: "app-policy-category-list", inputs: { items: "items", selectedItems: "selectedItems", url: "url" }, outputs: { itemSelected: "itemSelected", itemDeselected: "itemDeselected", itemsSelectedChange: "itemsSelectedChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"dynamic-list-container\">\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"\n paginatedItems?.length > 0 ||\n loaderState.programList ||\n loaderState.categoryList;\n else defaultTemplate\n \"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n <div class=\"vx-d-flex vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n <div class=\"search-block\">\n <i class=\"icons\">&#xe90b;</i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search..\"\n (keyup)=\"search()\"\n />\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n <div\n *ngFor=\"\n let item of paginatedItems | search : searchTerm : 'name';\n let i = index\n \"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n {{\n selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n }}\n SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\"> &#xe970; </i>\n </button>\n </div>\n </div>\n </ng-container>\n <ng-template #programListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n <div class=\"right-column\">\n <ng-container\n *ngIf=\"\n !loaderState.categoryList && !loaderState.programList;\n else categoryListLoader\n \"\n >\n <ng-container\n *ngIf=\"\n categoryList[activeProgram?.id]?.length > 0;\n else defaultSubCategoryTemplate\n \"\n >\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"\n let item of categoryList[activeProgram?.id];\n let i = index\n \"\n >\n <app-cs-checkbox\n [value]=\"item?.id\"\n [ngValue]=\"\n item.id\n | checkSelectedItems : selectedItems[activeProgram?.id]\n \"\n (ngValueChange)=\"selectItem($event, item)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n *ngIf=\"item?.parentTree?.length\"\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"item?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ item?.parentTree?.join(\" > \") }}\n </div>\n </div>\n </span>\n </app-cs-checkbox>\n </div>\n </ng-container>\n <ng-template #defaultSubCategoryTemplate>\n <div class=\"sub-no-data\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n ></app-no-data>\n </div>\n </ng-template>\n </ng-container>\n <ng-template #categoryListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n \"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 3rem)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:24px;line-height:1.5rem;padding:4px 4px 4px 24px;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:11px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:8px;top:8px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-container .list-no-data-container{height:calc(100% - 2.5rem)}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .search-box{width:50%}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .right-column .sub-no-data{display:contents}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.CsCheckboxComponent, selector: "app-cs-checkbox", inputs: ["disabled", "ngValue", "value", "readonly", "oneLine"], outputs: ["ngValueChange"] }, { kind: "component", type: i6.NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: i7.TableLoaderComponent, selector: "app-table-loader", inputs: ["listSize"] }, { kind: "pipe", type: i8.SearchPipe, name: "search" }] }); }
321
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PolicyCategoryListComponent, selector: "app-policy-category-list", inputs: { items: "items", selectedItems: "selectedItems", url: "url" }, outputs: { itemSelected: "itemSelected", itemDeselected: "itemDeselected", itemsSelectedChange: "itemsSelectedChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"dynamic-list-container\">\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"\n paginatedItems?.length > 0 ||\n loaderState.programList ||\n loaderState.categoryList;\n else defaultTemplate\n \"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n <div class=\"vx-d-flex vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n <div class=\"search-block\">\n <i class=\"icons\">&#xe90b;</i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search..\"\n (keyup)=\"search(header)\"\n />\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n <div\n *ngFor=\"\n let item of paginatedItems | search : searchTerm : 'name';\n let i = index\n \"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n {{\n selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n }}\n SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\"> &#xe970; </i>\n </button>\n </div>\n </div>\n </ng-container>\n <ng-template #programListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n <div class=\"right-column\">\n <ng-container\n *ngIf=\"\n !loaderState.categoryList && !loaderState.programList;\n else categoryListLoader\n \"\n >\n <ng-container\n *ngIf=\"\n policyCategoryList?.length > 0;\n else defaultSubCategoryTemplate\n \"\n >\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"let data of policyCategoryList; let i = index\"\n >\n <app-cs-radio\n [value]=\"data?.id\"\n [checked]=\"data.id\"\n (checkedEvent)=\"selectItem($event, data)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ data?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n *ngIf=\"data?.display_name\"\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"data?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ data?.display_name }}\n </div>\n </div>\n </span>\n </app-cs-radio>\n </div>\n </ng-container>\n <ng-template #defaultSubCategoryTemplate>\n <div class=\"sub-no-data\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n ></app-no-data>\n </div>\n </ng-template>\n </ng-container>\n <ng-template #categoryListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n \"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 3rem)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:24px;line-height:1.5rem;padding:4px 4px 4px 24px;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:11px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:8px;top:8px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-container .list-no-data-container{height:calc(100% - 2.5rem)}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .search-box{width:50%}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .right-column .sub-no-data{display:contents}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "component", type: i6.NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: i7.TableLoaderComponent, selector: "app-table-loader", inputs: ["listSize"] }, { kind: "pipe", type: i8.SearchPipe, name: "search" }] }); }
259
322
  }
260
323
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PolicyCategoryListComponent, decorators: [{
261
324
  type: Component,
262
- args: [{ selector: 'app-policy-category-list', template: "<div class=\"dynamic-list-container\">\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"\n paginatedItems?.length > 0 ||\n loaderState.programList ||\n loaderState.categoryList;\n else defaultTemplate\n \"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n <div class=\"vx-d-flex vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n <div class=\"search-block\">\n <i class=\"icons\">&#xe90b;</i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search..\"\n (keyup)=\"search()\"\n />\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n <div\n *ngFor=\"\n let item of paginatedItems | search : searchTerm : 'name';\n let i = index\n \"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n {{\n selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n }}\n SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\"> &#xe970; </i>\n </button>\n </div>\n </div>\n </ng-container>\n <ng-template #programListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n <div class=\"right-column\">\n <ng-container\n *ngIf=\"\n !loaderState.categoryList && !loaderState.programList;\n else categoryListLoader\n \"\n >\n <ng-container\n *ngIf=\"\n categoryList[activeProgram?.id]?.length > 0;\n else defaultSubCategoryTemplate\n \"\n >\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"\n let item of categoryList[activeProgram?.id];\n let i = index\n \"\n >\n <app-cs-checkbox\n [value]=\"item?.id\"\n [ngValue]=\"\n item.id\n | checkSelectedItems : selectedItems[activeProgram?.id]\n \"\n (ngValueChange)=\"selectItem($event, item)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n *ngIf=\"item?.parentTree?.length\"\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"item?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ item?.parentTree?.join(\" > \") }}\n </div>\n </div>\n </span>\n </app-cs-checkbox>\n </div>\n </ng-container>\n <ng-template #defaultSubCategoryTemplate>\n <div class=\"sub-no-data\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n ></app-no-data>\n </div>\n </ng-template>\n </ng-container>\n <ng-template #categoryListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n \"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 3rem)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:24px;line-height:1.5rem;padding:4px 4px 4px 24px;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:11px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:8px;top:8px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-container .list-no-data-container{height:calc(100% - 2.5rem)}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .search-box{width:50%}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .right-column .sub-no-data{display:contents}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
325
+ args: [{ selector: 'app-policy-category-list', template: "<div class=\"dynamic-list-container\">\n <div\n class=\"dynamic-list-table\"\n *ngIf=\"\n paginatedItems?.length > 0 ||\n loaderState.programList ||\n loaderState.categoryList;\n else defaultTemplate\n \"\n >\n <div class=\"dynamic-list-header vx-d-flex\">\n <ng-container *ngFor=\"let header of tableHeaders\">\n <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n <div class=\"vx-d-flex vx-pl-1\">\n <div\n class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n >\n #\n </div>\n <div\n class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n >\n {{ header }}\n </div>\n </div>\n <div class=\"search-block\">\n <i class=\"icons\">&#xe90b;</i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchTerm\"\n placeholder=\"Search..\"\n (keyup)=\"search(header)\"\n />\n </div>\n </div>\n </ng-container>\n </div>\n <div class=\"dynamic-list-body vx-d-flex\">\n <div class=\"left-column\">\n <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n <div\n *ngFor=\"\n let item of paginatedItems | search : searchTerm : 'name';\n let i = index\n \"\n class=\"list-row\"\n [class.selected]=\"activeProgram?.id === item.id\"\n (click)=\"viewCategory(item)\"\n >\n <div class=\"list-column serial\">\n <div class=\"srNo\">{{ i + 1 }}</div>\n </div>\n <div\n class=\"list-column name\"\n [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n >\n <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n </div>\n <div\n class=\"list-column count\"\n *ngIf=\"selectedItems[item.id]?.length > 0\"\n >\n <div\n class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n >\n {{ selectedItems[item.id].length }}\n </div>\n <div\n class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n >\n {{\n selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n }}\n SELECTED\n </div>\n </div>\n <div class=\"list-column action\">\n <button\n class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n >\n <i class=\"icons\"> &#xe970; </i>\n </button>\n </div>\n </div>\n </ng-container>\n <ng-template #programListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n <div class=\"right-column\">\n <ng-container\n *ngIf=\"\n !loaderState.categoryList && !loaderState.programList;\n else categoryListLoader\n \"\n >\n <ng-container\n *ngIf=\"\n policyCategoryList?.length > 0;\n else defaultSubCategoryTemplate\n \"\n >\n <div\n class=\"list-row vx-pl-2 vx-pr-2\"\n *ngFor=\"let data of policyCategoryList; let i = index\"\n >\n <app-cs-radio\n [value]=\"data?.id\"\n [checked]=\"data.id\"\n (checkedEvent)=\"selectItem($event, data)\"\n >\n <span class=\"value-inner\">\n <div class=\"item-name vx-fs-13\">{{ data?.name }}</div>\n <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n <div\n *ngIf=\"data?.display_name\"\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n >\n Within\n </div>\n <div\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\n [appTooltip]=\"data?.parentTree?.join(' > ')\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ data?.display_name }}\n </div>\n </div>\n </span>\n </app-cs-radio>\n </div>\n </ng-container>\n <ng-template #defaultSubCategoryTemplate>\n <div class=\"sub-no-data\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n ></app-no-data>\n </div>\n </ng-template>\n </ng-container>\n <ng-template #categoryListLoader>\n <app-table-loader></app-table-loader>\n </ng-template>\n </div>\n </div>\n </div>\n <ng-template #defaultTemplate>\n <div class=\"list-no-data-container\">\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n \"\n ></app-no-data>\n </div>\n </ng-template>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .dynamic-list-container{height:calc(100% - 3rem)}::ng-deep .dynamic-list-container.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .dynamic-list-container .search-block{position:relative}::ng-deep .dynamic-list-container .search-block input{height:24px;line-height:1.5rem;padding:4px 4px 4px 24px;outline:none;border:1px solid #cdced6;border-radius:.25rem;width:100%;font-size:11px;color:#747576}::ng-deep .dynamic-list-container .search-block input::placeholder{font-weight:400}::ng-deep .dynamic-list-container .search-block input:focus{border-color:#1e5dd3}::ng-deep .dynamic-list-container .search-block i{position:absolute;left:8px;top:8px;pointer-events:none;color:#e3e3e9;font-size:12px}::ng-deep .dynamic-list-container .list-no-data-container{height:calc(100% - 2.5rem)}::ng-deep .dynamic-list-filter{position:relative;min-width:240px;height:2.5rem;border:1px solid #cdced6;border-radius:.25rem;margin-left:6px;color:#a9aab6;font-size:13px;padding:0 .75rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between}::ng-deep .dynamic-list-filter .filter-icon{color:#787a8c;font-size:12px}::ng-deep .dynamic-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .dynamic-list-head button.back-btn{background:transparent;border-radius:0;border:none;position:relative;top:.125rem}::ng-deep .dynamic-list-header .search-box{width:50%}::ng-deep .dynamic-list-header .serialNo{color:#787a8c;min-width:2rem;height:2rem}::ng-deep .dynamic-list-header .headerText{color:#787a8c;min-width:calc(100% - 2rem);height:2rem}::ng-deep .dynamic-list-table{width:100%;border-collapse:collapse;height:calc(100% - 3rem)}::ng-deep .dynamic-list-body{height:calc(100% - 2rem);width:calc(100% + .75rem);position:relative}::ng-deep .dynamic-list-body .left-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .left-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .left-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .left-column .list-row.selected{background-color:#f2f2f5}::ng-deep .dynamic-list-body .left-column .list-row.selected:before{background:#1e5dd3;border-radius:.125rem .125rem 0 0;content:\"\";position:absolute;left:0;top:-1px;width:100%;height:.125rem;z-index:1}::ng-deep .dynamic-list-body .left-column .list-row.selected .list-column.serial .srNo{background:#e3e3e9;color:#565a6f}::ng-deep .dynamic-list-body .left-column .list-row .list-column{color:#000;font-size:11px;height:3rem;position:relative;display:flex;align-items:center;padding:0 .25rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial{width:2rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.serial .srNo{background:#f9f9fa;writing-mode:vertical-lr;color:#787a8c;font-size:11px;font-weight:500;height:46px;display:flex;justify-content:center;transition:all .2s ease-in-out;position:relative}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name{width:calc(100% - 4.5rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name .name-inner{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .left-column .list-row .list-column.name.with-count{width:calc(100% - 16rem)}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count{width:11.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-box{background:#1e5dd3;border-radius:1.25rem;color:#fff;padding:0 .125rem;min-width:1rem;height:1rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.count .count-text{color:#787a8c}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action{width:2.5rem;justify-content:center}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow{background:transparent;border-radius:.25rem;border:none;color:#565a6f;min-width:1.5rem;height:1.5rem}::ng-deep .dynamic-list-body .left-column .list-row .list-column.action button.arrow:hover{background:#e3e3e9}::ng-deep .dynamic-list-body .right-column{width:calc(50% + .5rem);padding-right:.5rem;position:relative;overflow-y:auto;scrollbar-width:thin}::ng-deep .dynamic-list-body .right-column .list-row{background-color:#fff;border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;display:flex;align-items:center;margin-bottom:.25rem;position:relative;transition:all .2s ease-in-out;width:100%;height:3rem}::ng-deep .dynamic-list-body .right-column .list-row:hover{background:#f8f8f8}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox{width:100%;display:flex}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value{width:100%;justify-content:start}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner{width:100%}::ng-deep .dynamic-list-body .right-column .list-row app-cs-checkbox .checkbox-item .value .value-inner .item-name{color:#000;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .dynamic-list-body .right-column .sub-no-data{display:contents}::ng-deep .new-action-list{background:#fff;border-radius:.25rem;border:1px solid #e3e3e9;box-shadow:0 4px 8px #1e5dd326;width:240px}::ng-deep .new-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;max-height:220px;overflow:auto}::ng-deep .new-action-list ul.action-item{display:block}::ng-deep .new-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .new-action-list ul.action-item li:last-child{border-bottom:none}::ng-deep .new-action-list ul.action-item li app-cs-checkbox{display:flex}::ng-deep .new-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .new-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .new-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .new-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .new-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .new-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .new-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .new-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .new-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .new-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .new-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .new-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .new-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .new-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .new-action-list ul.action-item li .chip-item app-cs-checkbox .checkbox-item .value{color:#000;font-size:11px}::ng-deep .new-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .new-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .new-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .new-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .new-action-list .program-type-text{color:#787a8c;border-bottom:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom{border-top:1px solid #f2f2f5}::ng-deep .new-action-list .program-type-bottom button{background:#fff;border-radius:.125rem;margin:0 .125rem!important;transition:all .3s ease-out}::ng-deep .new-action-list .program-type-bottom button.reset-btn{border:1px solid #cdced6;color:#1e5dd3}::ng-deep .new-action-list .program-type-bottom button.reset-btn:hover{background:#f9f9fa}::ng-deep .new-action-list .program-type-bottom button.apply-btn{background:#1e5dd3;border:1px solid #1e5dd3;color:#fff}::ng-deep .new-action-list .program-type-bottom button.apply-btn:hover{background:#1146a8}::ng-deep .new-action-list .program-type-bottom button.apply-btn.disabled{background:#e3e3e9;border-color:#e3e3e9;color:#a9aab6;pointer-events:none}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
263
326
  }], ctorParameters: function () { return [{ type: i1.ListUtilsService }, { type: i2.PolicyListApiService }]; }, propDecorators: { items: [{
264
327
  type: Input
265
328
  }], selectedItems: [{
@@ -273,4 +336,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
273
336
  }], itemsSelectedChange: [{
274
337
  type: Output
275
338
  }] } });
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-category-list/category-list/category-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-category-list/category-list/category-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, OnInit, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\nimport { ListItem } from '../../program-list/interfaces/list-item.interface';\nimport { PROGRAM_TABLE_HEADERS, PAGINATION_OPTIONS, PROGRAM_TYPE_LIST, PROGRAM_NO_DATA } from '../../program-list/constant';\nimport {POLICY_CATEGORY_TABLE_HEADERS, POLICY_NO_DATA} from '../constants/policy.constants';\nimport { Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { ListUtilsService } from '../../program-list/services/list-utils.service';\nimport { ProgramListApiService } from '../../program-list/services/program-list-api.service';\nimport { POLICY_CATEGORY_LIST_STUBS } from '../constants/stubs';\nimport { PolicyListApiService } from '../services/policy-list-api.service';\n/**\n * A reusable component for displaying and managing a list of programs with filtering, pagination, and category viewing capabilities.\n * \n * Features:\n * - Program listing with pagination\n * - Search functionality with debounce\n * - Program type filtering\n * - Category viewing for selected programs\n * - Multi-select capability\n * \n * @template T Extends ListItem interface for type safety of list items\n */\n\ninterface Category {\n  id: string;\n  name: string;\n  parent?: string;\n  parentTree?: string[];\n  [key: string]: any;\n}\n@Component({\n  selector: 'app-policy-category-list',\n  templateUrl: './category-list.component.html',\n  styleUrls: ['./category-list.component.less']\n})\nexport class PolicyCategoryListComponent<T extends ListItem> implements OnInit, OnChanges, OnDestroy {\n  /** Array of items to be displayed in the list */\n  @Input() items: T[] = [];\n  \n  /** Object containing selected items, keyed by program ID */\n  @Input() selectedItems: any | null = {};\n  \n  /** URL configuration object for API endpoints */\n  @Input() url: any = {};\n\n  /** Event emitted when an item is selected */\n  @Output() itemSelected = new EventEmitter<T>();\n  \n  /** Event emitted when an item is deselected */\n  @Output() itemDeselected = new EventEmitter<T>();\n  \n  /** Event emitted when the selection changes */\n  @Output() itemsSelectedChange = new EventEmitter<T[]>();\n\n  tableHeaders = POLICY_CATEGORY_TABLE_HEADERS;\n  currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n  pageSize = PAGINATION_OPTIONS.PAGE_SIZE;\n  totalPages = 0;\n  searchTerm = '';\n  paginatedItems: T[] = [];\n  activeProgram: any | null = null;\n  categoryList: any = {};\n  programTypeList: any[] = PROGRAM_TYPE_LIST;\n  selectedProgramType: any[] = [];\n  loaderState: any = {\n    programList: false,\n    categoryList: false,\n  };\n  appliedProgramType: any[] = [];\n  POLICY_NO_DATA: any = POLICY_NO_DATA;\n  ASSETS: any = ASSETS;\n  programCategoryList: any = {};\n\n\n  /** Subject for handling debounced search */\n  private searchSubject = new Subject<string>();\n  \n  /** Subject for cleanup subscriptions */\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private listUtils: ListUtilsService,\n    private policyListApiService: PolicyListApiService\n  ) {\n    // Initialize debounced search\n    this.searchSubject.pipe(\n      debounceTime(300),\n      takeUntil(this.destroy$)\n    ).subscribe(() => {\n      this.performSearch();\n    });\n  }\n\n  /** Initialize component by fetching program list */\n  ngOnInit(): void {\n    console.log(\"PolicyCategoryListComponent\", this.items);\n    this.getProgramList();\n  }\n\n  /** Handle changes to inputs */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['items'] || changes['selectedItems']) {\n      this.paginateItems(this.items);\n    }\n  }\n\n  /** Fetch program list from API */\n  getProgramList(): void {\n    this.loaderState.programList = true;\n    this.items = POLICY_CATEGORY_LIST_STUBS.data.policyCategories as any;\n    this.loadData(this.items);\n    this.loaderState.programList = false;\n    // this.programListApiService.getProgramList(this.url.programList).subscribe((res: any) => {\n    //   this.items = res?.data?.programs;\n    //   this.loadData(this.items);\n    //   this.loaderState.programList = false;\n    // });\n  }\n\n  /**\n   * Load data and initialize pagination\n   * @param data Array of items to load\n   */\n  loadData(data: any): void {\n    this.goToPage(1, data);\n  }\n\n  /**\n   * Handle item selection/deselection\n   * @param event Selection event\n   * @param item Item being selected/deselected\n   */\n  selectItem(event: any, item: any): void {\n    const selectedObject =  this.activeProgram.id.toString();\n    if (event) {\n      if(!this.selectedItems[selectedObject]) {\n        this.selectedItems[selectedObject] = [];\n      }\n      this.selectedItems[selectedObject].push(item);\n          } else {\n      this.selectedItems[selectedObject] = this.selectedItems[this.activeProgram.id].filter((selected: any) => selected.id !== item.id);\n    }\n    this.itemsSelectedChange.emit(this.selectedItems);\n  }\n\n  /**\n   * Deselect a specific item\n   * @param item Item to deselect\n   */\n  deselectItem(item: T): void {\n    this.itemsSelectedChange.emit(this.selectedItems);\n    this.itemDeselected.emit(item);\n  }\n\n  /**\n   * Check if an item is selected\n   * @param item Item to check\n   * @returns Boolean indicating if item is selected\n   */\n  isSelected(item: T): boolean {\n    return false;\n  }\n\n  /**\n   * Navigate to specific page\n   * @param page Page number to navigate to\n   * @param data Data to paginate\n   */\n  goToPage(page: number, data: any): void {\n    this.currentPage = page;\n    this.paginateItems(data);\n  }\n\n  /**\n   * Get array of page numbers for pagination\n   * @returns Array of page numbers\n   */\n  getPageNumbers(): number[] {\n    return this.listUtils.getPageNumbers(this.items.length, this.pageSize);\n  }\n\n  /**\n   * Paginate items and update view\n   * @param data Data to paginate\n   */\n  paginateItems(data: any): void {\n    this.totalPages = Math.ceil(data.length / this.pageSize);\n    this.paginatedItems = data;\n  }\n\n  /**\n   * View categories for a selected program\n   * @param item Program to view categories for\n   */\n  viewCategory(item?: any): void {\n    this.activeProgram = item;\n    if(!item || this.categoryList[item.id]) return;\n    this.loaderState.categoryList = true;\n    this.checkProgramCategoryExists(item?.id);\n  }\n\n  checkProgramCategoryExists(id: string): void {\n    if(this.programCategoryList[id]) {\n      this.categoryList[id] = this.addParentTreeToCategories(this.programCategoryList[id]);\n      this.loaderState.categoryList = false;\n      return;\n    }\n    this.fetchProgramCategoryList(id);\n  }\n\n  fetchProgramCategoryList(id: string): void {\n    const URL = `${this.url.categoryList}&id=${id}`;\n    this.policyListApiService.getPolicyCategoryList(URL).subscribe((res: any) => {\n      this.programCategoryList[id] = res?.data?.categories ?? [];\n      this.categoryList[id] = this.addParentTreeToCategories(this.programCategoryList[id]);\n      this.loaderState.categoryList = false;\n    });\n  }\n\n\n  /**\n   * Add parent tree information to categories\n   * @param categories Array of categories\n   * @returns Categories with parent tree information\n   */\n  addParentTreeToCategories(categories: any[]): any[] {\n    if (!categories?.length) return [];\n\n    const categoryMap = new Map(categories.map(category => [category.id, category]));\n\n    const getParentTree = (category: Category): string[] => {\n      const parentTree: string[] = [];\n      let currentParent = category.parent;\n\n      while (currentParent) {\n        const parentCategory = categoryMap.get(currentParent);\n        if (!parentCategory) break;\n        \n        parentTree.push(parentCategory.name);\n        currentParent = parentCategory.parent;\n      }\n\n      return parentTree;\n    };\n\n    return categories.map(category => ({\n      ...category,\n      parentTree: getParentTree(category)\n    }));\n\n  }\n\n  /**\n   * Handle program type filter selection\n   * @param event Selection event\n   * @param item Program type being selected/deselected\n   */\n  selectFilter(event: any, item: any): void {\n    if(event) {\n      this.selectedProgramType.push(item.id);\n    } else {\n      this.selectedProgramType = this.selectedProgramType.filter((selected: any) => selected !== item.id);\n    }\n  }\n\n  /** Reset all applied filters */\n  resetFilter(): void {\n    this.selectedProgramType = [];\n  }\n\n  /** Apply selected filters to the program list */\n  onFilterChange(): void {\n    if(this.selectedProgramType.length > 0) {\n      const filteredItems = this.items.filter((item: any) => this.selectedProgramType.includes(item.type));\n      this.paginatedItems = [...filteredItems];\n    } else {\n      this.paginatedItems = this.items;\n    }\n\n    this.appliedProgramType = this.programTypeList.filter((item: any) => this.selectedProgramType.includes(item.id));\n   this.checkCategoryAvailbility();\n    \n  }\n \n  checkCategoryAvailbility(): void {\n    const isSelectedProgramAvailable = this.paginatedItems.some((item: any) => item?.id === this.activeProgram?.id);\n    if(!isSelectedProgramAvailable) {\n      this.categoryList = [];\n      this.activeProgram = null;\n    }\n  }\n\n  /** Trigger debounced search */\n  search(): void {\n    this.searchSubject.next(this.searchTerm);\n  }\n\n  /** Perform search on items */\n  private performSearch(): void {\n    const filteredItems = this.items.filter((item: any) => item?.name?.toLowerCase().includes(this.searchTerm?.toLowerCase()));\n    this.paginatedItems = filteredItems;\n    this.checkCategoryAvailbility();\n  }\n\n  /** Cleanup subscriptions on component destruction */\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  closePopover(event: any): void {\n    if(event) {\n      this.selectedProgramType = this.appliedProgramType.map((item: any) => item?.id);\n    }\n  }\n}\n","<div class=\"dynamic-list-container\">\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"\n      paginatedItems?.length > 0 ||\n        loaderState.programList ||\n        loaderState.categoryList;\n      else defaultTemplate\n    \"\n  >\n    <div class=\"dynamic-list-header vx-d-flex\">\n      <ng-container *ngFor=\"let header of tableHeaders\">\n        <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n          <div class=\"vx-d-flex vx-pl-1\">\n            <div\n              class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n            >\n              #\n            </div>\n            <div\n              class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n            >\n              {{ header }}\n            </div>\n          </div>\n          <div class=\"search-block\">\n            <i class=\"icons\">&#xe90b;</i>\n            <input\n              type=\"text\"\n              [(ngModel)]=\"searchTerm\"\n              placeholder=\"Search..\"\n              (keyup)=\"search()\"\n            />\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"dynamic-list-body vx-d-flex\">\n      <div class=\"left-column\">\n        <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n          <div\n            *ngFor=\"\n              let item of paginatedItems | search : searchTerm : 'name';\n              let i = index\n            \"\n            class=\"list-row\"\n            [class.selected]=\"activeProgram?.id === item.id\"\n            (click)=\"viewCategory(item)\"\n          >\n            <div class=\"list-column serial\">\n              <div class=\"srNo\">{{ i + 1 }}</div>\n            </div>\n            <div\n              class=\"list-column name\"\n              [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n            >\n              <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n            </div>\n            <div\n              class=\"list-column count\"\n              *ngIf=\"selectedItems[item.id]?.length > 0\"\n            >\n              <div\n                class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n              >\n                {{ selectedItems[item.id].length }}\n              </div>\n              <div\n                class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n              >\n                {{\n                  selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n                }}\n                SELECTED\n              </div>\n            </div>\n            <div class=\"list-column action\">\n              <button\n                class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n              >\n                <i class=\"icons\"> &#xe970; </i>\n              </button>\n            </div>\n          </div>\n        </ng-container>\n        <ng-template #programListLoader>\n          <app-table-loader></app-table-loader>\n        </ng-template>\n      </div>\n      <div class=\"right-column\">\n        <ng-container\n          *ngIf=\"\n            !loaderState.categoryList && !loaderState.programList;\n            else categoryListLoader\n          \"\n        >\n          <ng-container\n            *ngIf=\"\n              categoryList[activeProgram?.id]?.length > 0;\n              else defaultSubCategoryTemplate\n            \"\n          >\n            <div\n              class=\"list-row vx-pl-2 vx-pr-2\"\n              *ngFor=\"\n                let item of categoryList[activeProgram?.id];\n                let i = index\n              \"\n            >\n              <app-cs-checkbox\n                [value]=\"item?.id\"\n                [ngValue]=\"\n                  item.id\n                    | checkSelectedItems : selectedItems[activeProgram?.id]\n                \"\n                (ngValueChange)=\"selectItem($event, item)\"\n              >\n                <span class=\"value-inner\">\n                  <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n                  <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n                    <div\n                      *ngIf=\"item?.parentTree?.length\"\n                      class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n                    >\n                      Within\n                    </div>\n                    <div\n                      class=\"within-value vx-fs-11 vx-paragraph-txt\"\n                      [appTooltip]=\"item?.parentTree?.join(' > ')\"\n                      placement=\"bottom-left\"\n                      delay=\"0\"\n                      type=\"black\"\n                      [tooltipMandatory]=\"true\"\n                    >\n                      {{ item?.parentTree?.join(\" > \") }}\n                    </div>\n                  </div>\n                </span>\n              </app-cs-checkbox>\n            </div>\n          </ng-container>\n          <ng-template #defaultSubCategoryTemplate>\n            <div class=\"sub-no-data\">\n              <app-no-data\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n              ></app-no-data>\n            </div>\n          </ng-template>\n        </ng-container>\n        <ng-template #categoryListLoader>\n          <app-table-loader></app-table-loader>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n  <ng-template #defaultTemplate>\n    <div class=\"list-no-data-container\">\n      <app-no-data\n        [noDataImage]=\"ASSETS.search_data\"\n        [noDataText]=\"\n          searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n        \"\n      ></app-no-data>\n    </div>\n  </ng-template>\n</div>\n"]}
339
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-category-list/category-list/category-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-category-list/category-list/category-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  TemplateRef,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  OnDestroy,\n} from '@angular/core';\nimport { ListItem } from '../../program-list/interfaces/list-item.interface';\nimport {\n  PROGRAM_TABLE_HEADERS,\n  PAGINATION_OPTIONS,\n  PROGRAM_TYPE_LIST,\n  PROGRAM_NO_DATA,\n} from '../../program-list/constant';\nimport {\n  POLICY_CATEGORY_TABLE_HEADERS,\n  POLICY_NO_DATA,\n} from '../constants/policy.constants';\nimport { Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { ListUtilsService } from '../../program-list/services/list-utils.service';\nimport { ProgramListApiService } from '../../program-list/services/program-list-api.service';\nimport { POLICY_CATEGORY_LIST_STUBS } from '../constants/stubs';\nimport { PolicyListApiService } from '../services/policy-list-api.service';\n/**\n * A reusable component for displaying and managing a list of programs with filtering, pagination, and category viewing capabilities.\n *\n * Features:\n * - Program listing with pagination\n * - Search functionality with debounce\n * - Program type filtering\n * - Category viewing for selected programs\n * - Multi-select capability\n *\n * @template T Extends ListItem interface for type safety of list items\n */\n\ninterface Category {\n  id: string;\n  name: string;\n  parent?: string;\n  parentTree?: string[];\n  [key: string]: any;\n}\n@Component({\n  selector: 'app-policy-category-list',\n  templateUrl: './category-list.component.html',\n  styleUrls: ['./category-list.component.less'],\n})\nexport class PolicyCategoryListComponent\n  implements OnInit, OnChanges, OnDestroy\n{\n  /** Array of items to be displayed in the list */\n  @Input() items: any[] = [];\n\n  /** Object containing selected items, keyed by program ID */\n  @Input() selectedItems: any | null = {};\n\n  /** URL configuration object for API endpoints */\n  @Input() url: any = {};\n\n  /** Event emitted when an item is selected */\n  @Output() itemSelected = new EventEmitter<any>();\n\n  /** Event emitted when an item is deselected */\n  @Output() itemDeselected = new EventEmitter<any>();\n\n  /** Event emitted when the selection changes */\n  @Output() itemsSelectedChange = new EventEmitter<any[]>();\n\n  tableHeaders = POLICY_CATEGORY_TABLE_HEADERS;\n  currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n  pageSize = PAGINATION_OPTIONS.PAGE_SIZE;\n  totalPages = 0;\n  searchTerm = '';\n  paginatedItems: any[] = [];\n  activeProgram: any | null = null;\n  categoryList: any = {};\n  programTypeList: any[] = PROGRAM_TYPE_LIST;\n  selectedProgramType: any[] = [];\n  loaderState: any = {\n    programList: false,\n    categoryList: false,\n  };\n  appliedProgramType: any[] = [];\n  POLICY_NO_DATA: any = POLICY_NO_DATA;\n  ASSETS: any = ASSETS;\n  programCategoryList: any = {};\n  policyCategoryList: any = [];\n\n  /** Subject for handling debounced search */\n  private searchSubject = new Subject<string>();\n\n  /** Subject for cleanup subscriptions */\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private listUtils: ListUtilsService,\n    private policyListApiService: PolicyListApiService\n  ) {\n    // Initialize debounced search\n    this.searchSubject\n      .pipe(debounceTime(300), takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.performSearch();\n      });\n  }\n\n  /** Initialize component by fetching program list */\n  ngOnInit(): void {\n    console.log('PolicyCategoryListComponent', this.items);\n    this.getProgramList();\n  }\n\n  /** Handle changes to inputs */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['items'] || changes['selectedItems']) {\n      this.paginateItems(this.items);\n    }\n  }\n\n  /** Fetch program list from API */\n  getProgramList(): void {\n    this.loaderState.programList = true;\n    this.items = this.prepareCategoryList(\n      POLICY_CATEGORY_LIST_STUBS.data.policyCategories\n    );\n    this.viewCategory(this.items[0]);\n    console.log(this.items, 'items');\n    // this.items = POLICY_CATEGORY_LIST_STUBS.data.policyCategories as any;\n    this.loadData(this.items);\n    this.loaderState.programList = false;\n    // this.programListApiService.getProgramList(this.url.programList).subscribe((res: any) => {\n    //   this.items = res?.data?.programs;\n    //   this.loadData(this.items);\n    //   this.loaderState.programList = false;\n    // });\n  }\n\n  /**\n   * Load data and initialize pagination\n   * @param data Array of items to load\n   */\n  loadData(data: any): void {\n    this.goToPage(1, data);\n  }\n\n  prepareCategoryList(categories: any[]) {\n    const map = new Map<number, any>();\n    categories.forEach((cat) => map.set(cat.id, cat));\n\n    // Check if category is a root\n    const isRoot = (cat: any) =>\n      (cat.parent === null && cat.origin === null) ||\n      (!map.has(cat.parent!) && !map.has(cat.origin!));\n\n    return categories.filter(isRoot).map((root: any) => ({\n      id: root.id,\n      name: root.name,\n      children: [\n        {\n          id: root.id,\n          name: root.name,\n          children: [],\n          display_name: '',\n        },\n        ...this.buildChildren(root, categories, map),\n      ],\n    }));\n  }\n\n  buildPath(categories: any, map: any) {\n    const names: string[] = []; // start with child name\n    let current = categories;\n  \n    while (current && current.parent !== null) {\n      const parent = map.get(current.parent);\n      if (parent) {\n        names.push(parent.name);\n        current = parent;\n      } else {\n        break;\n      }\n    }\n  \n    return names.join(\" < \"); \n  }\n\n  buildChildren(root: any, categories: any, map: any) {\n    return categories\n      .filter((c: any) => c.origin === root.id || c.parent === root.id)\n      .map((child: any) => ({\n        id: child.id,\n        name: child.name,\n        children: [], // flatten children\n        display_name: this.buildPath(child, map),\n      }));\n  }\n\n  /**\n   * Handle item selection/deselection\n   * @param event Selection event\n   * @param item Item being selected/deselected\n   */\n  selectItem(event: any, item: any): void {\n    const selectedObject = this.activeProgram.id.toString();\n    if (event) {\n      if (!this.selectedItems[selectedObject]) {\n        this.selectedItems[selectedObject] = [];\n      }\n      this.selectedItems[selectedObject].push(item);\n    } else {\n      this.selectedItems[selectedObject] = this.selectedItems[\n        this.activeProgram.id\n      ].filter((selected: any) => selected.id !== item.id);\n    }\n    this.itemsSelectedChange.emit(this.selectedItems);\n  }\n\n  /**\n   * Deselect a specific item\n   * @param item Item to deselect\n   */\n  deselectItem(item: any): void {\n    this.itemsSelectedChange.emit(this.selectedItems);\n    this.itemDeselected.emit(item);\n  }\n\n  /**\n   * Check if an item is selected\n   * @param item Item to check\n   * @returns Boolean indicating if item is selected\n   */\n  isSelected(item: any): boolean {\n    return false;\n  }\n\n  /**\n   * Navigate to specific page\n   * @param page Page number to navigate to\n   * @param data Data to paginate\n   */\n  goToPage(page: number, data: any): void {\n    this.currentPage = page;\n    this.paginateItems(data);\n  }\n\n  /**\n   * Get array of page numbers for pagination\n   * @returns Array of page numbers\n   */\n  getPageNumbers(): number[] {\n    return this.listUtils.getPageNumbers(this.items.length, this.pageSize);\n  }\n\n  /**\n   * Paginate items and update view\n   * @param data Data to paginate\n   */\n  paginateItems(data: any): void {\n    this.totalPages = Math.ceil(data.length / this.pageSize);\n    this.paginatedItems = data;\n  }\n\n  /**\n   * View categories for a selected program\n   * @param item Program to view categories for\n   */\n  viewCategory(item?: any): void {\n    this.activeProgram = item;\n    this.loaderState.categoryList = true;\n    this.policyCategoryList = this.items.find(\n      (category: any) => category.id === item.id\n    )?.children;\n    this.loaderState.categoryList = false;\n    console.log(this.activeProgram, this.policyCategoryList, 'activeProgram');\n    // if (!item || this.categoryList[item.id]) return;\n    // this.loaderState.categoryList = true;\n    // this.checkProgramCategoryExists(item?.id);\n  }\n\n  checkProgramCategoryExists(id: string): void {\n    if (this.programCategoryList[id]) {\n      this.categoryList[id] = this.addParentTreeToCategories(\n        this.programCategoryList[id]\n      );\n      this.loaderState.categoryList = false;\n      return;\n    }\n    this.fetchProgramCategoryList(id);\n  }\n\n  fetchProgramCategoryList(id: string): void {\n    const URL = `${this.url.categoryList}&id=${id}`;\n    this.policyListApiService\n      .getPolicyCategoryList(URL)\n      .subscribe((res: any) => {\n        this.programCategoryList[id] = res?.data?.categories ?? [];\n        this.categoryList[id] = this.addParentTreeToCategories(\n          this.programCategoryList[id]\n        );\n        this.loaderState.categoryList = false;\n      });\n  }\n\n  /**\n   * Add parent tree information to categories\n   * @param categories Array of categories\n   * @returns Categories with parent tree information\n   */\n  addParentTreeToCategories(categories: any[]): any[] {\n    if (!categories?.length) return [];\n\n    const categoryMap = new Map(\n      categories.map((category) => [category.id, category])\n    );\n\n    const getParentTree = (category: Category): string[] => {\n      const parentTree: string[] = [];\n      let currentParent = category.parent;\n\n      while (currentParent) {\n        const parentCategory = categoryMap.get(currentParent);\n        if (!parentCategory) break;\n\n        parentTree.push(parentCategory.name);\n        currentParent = parentCategory.parent;\n      }\n\n      return parentTree;\n    };\n\n    return categories.map((category) => ({\n      ...category,\n      parentTree: getParentTree(category),\n    }));\n  }\n\n  /**\n   * Handle program type filter selection\n   * @param event Selection event\n   * @param item Program type being selected/deselected\n   */\n  selectFilter(event: any, item: any): void {\n    if (event) {\n      this.selectedProgramType.push(item.id);\n    } else {\n      this.selectedProgramType = this.selectedProgramType.filter(\n        (selected: any) => selected !== item.id\n      );\n    }\n  }\n\n  /** Reset all applied filters */\n  resetFilter(): void {\n    this.selectedProgramType = [];\n  }\n\n  /** Apply selected filters to the program list */\n  onFilterChange(): void {\n    if (this.selectedProgramType.length > 0) {\n      const filteredItems = this.items.filter((item: any) =>\n        this.selectedProgramType.includes(item.type)\n      );\n      this.paginatedItems = [...filteredItems];\n    } else {\n      this.paginatedItems = this.items;\n    }\n\n    this.appliedProgramType = this.programTypeList.filter((item: any) =>\n      this.selectedProgramType.includes(item.id)\n    );\n    this.checkCategoryAvailbility();\n  }\n\n  checkCategoryAvailbility(): void {\n    const isSelectedProgramAvailable = this.paginatedItems.some(\n      (item: any) => item?.id === this.activeProgram?.id\n    );\n    if (!isSelectedProgramAvailable) {\n      this.categoryList = [];\n      this.activeProgram = null;\n    }\n  }\n\n  /** Trigger debounced search */\n  search(header: string): void {\n    if(header.toLowerCase() === 'policy category') {\n        this.searchTerm = this.searchTerm.toLowerCase();\n        this.paginatedItems = this.items.filter((item: any) =>\n            item?.name?.toLowerCase().includes(this.searchTerm)\n        );\n    } else if(header.toLowerCase() === 'policy sub categories') {\n        this.searchTerm = this.searchTerm.toLowerCase();\n        this.paginatedItems = this.items.filter((item: any) =>\n            item?.name?.toLowerCase().includes(this.searchTerm)\n        );\n    }\n  }\n\n  /** Perform search on items */\n  private performSearch(): void {\n    const filteredItems = this.items.filter((item: any) =>\n      item?.name?.toLowerCase().includes(this.searchTerm?.toLowerCase())\n    );\n    this.paginatedItems = filteredItems;\n    this.checkCategoryAvailbility();\n  }\n\n  /** Cleanup subscriptions on component destruction */\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  closePopover(event: any): void {\n    if (event) {\n      this.selectedProgramType = this.appliedProgramType.map(\n        (item: any) => item?.id\n      );\n    }\n  }\n}\n","<div class=\"dynamic-list-container\">\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"\n      paginatedItems?.length > 0 ||\n        loaderState.programList ||\n        loaderState.categoryList;\n      else defaultTemplate\n    \"\n  >\n    <div class=\"dynamic-list-header vx-d-flex\">\n      <ng-container *ngFor=\"let header of tableHeaders\">\n        <div class=\"vx-d-flex vx-w-100 vx-justify-between\">\n          <div class=\"vx-d-flex vx-pl-1\">\n            <div\n              class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n            >\n              #\n            </div>\n            <div\n              class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n            >\n              {{ header }}\n            </div>\n          </div>\n          <div class=\"search-block\">\n            <i class=\"icons\">&#xe90b;</i>\n            <input\n              type=\"text\"\n              [(ngModel)]=\"searchTerm\"\n              placeholder=\"Search..\"\n              (keyup)=\"search(header)\"\n            />\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"dynamic-list-body vx-d-flex\">\n      <div class=\"left-column\">\n        <ng-container *ngIf=\"!loaderState.programList; else programListLoader\">\n          <div\n            *ngFor=\"\n              let item of paginatedItems | search : searchTerm : 'name';\n              let i = index\n            \"\n            class=\"list-row\"\n            [class.selected]=\"activeProgram?.id === item.id\"\n            (click)=\"viewCategory(item)\"\n          >\n            <div class=\"list-column serial\">\n              <div class=\"srNo\">{{ i + 1 }}</div>\n            </div>\n            <div\n              class=\"list-column name\"\n              [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n            >\n              <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n            </div>\n            <div\n              class=\"list-column count\"\n              *ngIf=\"selectedItems[item.id]?.length > 0\"\n            >\n              <div\n                class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n              >\n                {{ selectedItems[item.id].length }}\n              </div>\n              <div\n                class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n              >\n                {{\n                  selectedItems[item.id].length > 1 ? \"CATEGORIES\" : \"CATEGORY\"\n                }}\n                SELECTED\n              </div>\n            </div>\n            <div class=\"list-column action\">\n              <button\n                class=\"arrow vx-fs-12 vx-p-0 vx-m-0 vx-d-flex vx-align-center vx-justify-center\"\n              >\n                <i class=\"icons\"> &#xe970; </i>\n              </button>\n            </div>\n          </div>\n        </ng-container>\n        <ng-template #programListLoader>\n          <app-table-loader></app-table-loader>\n        </ng-template>\n      </div>\n      <div class=\"right-column\">\n        <ng-container\n          *ngIf=\"\n            !loaderState.categoryList && !loaderState.programList;\n            else categoryListLoader\n          \"\n        >\n          <ng-container\n            *ngIf=\"\n              policyCategoryList?.length > 0;\n              else defaultSubCategoryTemplate\n            \"\n          >\n            <div\n              class=\"list-row vx-pl-2 vx-pr-2\"\n              *ngFor=\"let data of policyCategoryList; let i = index\"\n            >\n              <app-cs-radio\n                [value]=\"data?.id\"\n                [checked]=\"data.id\"\n                (checkedEvent)=\"selectItem($event, data)\"\n              >\n                <span class=\"value-inner\">\n                  <div class=\"item-name vx-fs-13\">{{ data?.name }}</div>\n                  <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n                    <div\n                      *ngIf=\"data?.display_name\"\n                      class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\n                    >\n                      Within\n                    </div>\n                    <div\n                      class=\"within-value vx-fs-11 vx-paragraph-txt\"\n                      [appTooltip]=\"data?.parentTree?.join(' > ')\"\n                      placement=\"bottom-left\"\n                      delay=\"0\"\n                      type=\"black\"\n                      [tooltipMandatory]=\"true\"\n                    >\n                      {{ data?.display_name }}\n                    </div>\n                  </div>\n                </span>\n              </app-cs-radio>\n            </div>\n          </ng-container>\n          <ng-template #defaultSubCategoryTemplate>\n            <div class=\"sub-no-data\">\n              <app-no-data\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"POLICY_NO_DATA.policySubCategoryList\"\n              ></app-no-data>\n            </div>\n          </ng-template>\n        </ng-container>\n        <ng-template #categoryListLoader>\n          <app-table-loader></app-table-loader>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n  <ng-template #defaultTemplate>\n    <div class=\"list-no-data-container\">\n      <app-no-data\n        [noDataImage]=\"ASSETS.search_data\"\n        [noDataText]=\"\n          searchTerm ? POLICY_NO_DATA.search : POLICY_NO_DATA.programList\n        \"\n      ></app-no-data>\n    </div>\n  </ng-template>\n</div>\n"]}