vcomply-workflow-engine 6.2.10 → 6.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm2022/lib/sharedComponents/policy-category-list/category-list/category-list.component.mjs
CHANGED
|
@@ -94,24 +94,24 @@ export class PolicyCategoryListComponent {
|
|
|
94
94
|
this.goToPage(1, data);
|
|
95
95
|
}
|
|
96
96
|
prepareCategoryList(categories) {
|
|
97
|
-
const editorCategories = categories.filter((category) => category
|
|
97
|
+
const editorCategories = categories.filter((category) => category?.role === 'editor' || category?.role === 'owner');
|
|
98
98
|
const map = new Map();
|
|
99
|
-
editorCategories.forEach((cat) => map.set(cat
|
|
99
|
+
editorCategories.forEach((cat) => map.set(cat?.id, cat));
|
|
100
100
|
// Check if category is a root
|
|
101
|
-
const isRoot = (cat) => cat
|
|
101
|
+
const isRoot = (cat) => cat?.parent === null || !map.has(cat?.parent);
|
|
102
102
|
return editorCategories.filter(isRoot).map((root) => ({
|
|
103
|
-
id: root
|
|
104
|
-
name: root
|
|
103
|
+
id: root?.id,
|
|
104
|
+
name: root?.name,
|
|
105
105
|
children: [...this.buildChildren(root, editorCategories, map)],
|
|
106
106
|
}));
|
|
107
107
|
}
|
|
108
108
|
buildPath(categories, map) {
|
|
109
109
|
const names = []; // start with child name
|
|
110
110
|
let current = categories;
|
|
111
|
-
while (current && current
|
|
112
|
-
const parent = map.get(current
|
|
111
|
+
while (current && current?.parent !== null) {
|
|
112
|
+
const parent = map.get(current?.parent);
|
|
113
113
|
if (parent) {
|
|
114
|
-
names.push(parent
|
|
114
|
+
names.push(parent?.name);
|
|
115
115
|
current = parent;
|
|
116
116
|
}
|
|
117
117
|
else {
|
|
@@ -122,14 +122,14 @@ export class PolicyCategoryListComponent {
|
|
|
122
122
|
}
|
|
123
123
|
buildChildren(root, categories, map) {
|
|
124
124
|
return categories
|
|
125
|
-
.filter((c) => c
|
|
125
|
+
.filter((c) => c?.origin === root?.id || c?.parent === root?.id)
|
|
126
126
|
.map((child) => ({
|
|
127
|
-
id: child
|
|
128
|
-
name: child
|
|
127
|
+
id: child?.id,
|
|
128
|
+
name: child?.name,
|
|
129
129
|
children: [],
|
|
130
130
|
display_name: this.buildPath(child, map),
|
|
131
|
-
origin: child
|
|
132
|
-
parent: child
|
|
131
|
+
origin: child?.origin,
|
|
132
|
+
parent: child?.parent,
|
|
133
133
|
}));
|
|
134
134
|
}
|
|
135
135
|
/**
|
|
@@ -271,4 +271,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
271
271
|
}], itemsSelectedChange: [{
|
|
272
272
|
type: Output
|
|
273
273
|
}] } });
|
|
274
|
-
//# 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 {\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 {\n  POLICY_CATEGORY_LIST_STUBS,\n  POLICY_CATEGORY_LIST_STUBS_2,\n} 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  selectedCategory: any[] = [];\n  searchConfig: { [key: string]: { term: string; placeholder: string } } = {\n    'POLICY CATEGORY': { term: '', placeholder: 'Search Category' },\n    'POLICY SUB CATEGORY': { term: '', placeholder: 'Search Sub Category' },\n  };\n\n  filteredCategories: any[] = []; // after applying category search\n  filteredSubcategories: any[] = []; // after applying subcategory search\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    this.getPolicyCategoryList();\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  getPolicyCategoryList(): void {\n    this.loaderState.programList = true;\n    this.policyListApiService.getPolicyCategoryList().subscribe((res: any) => {\n      this.items = this.prepareCategoryList(res?.data?.policyCategories);\n      this.viewCategory(this.items[0]);\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 editorCategories = categories.filter(\n      (category: any) => category.role === 'editor'\n    );\n    const map = new Map<number, any>();\n    editorCategories.forEach((cat) => map.set(cat.id, cat));\n\n    // Check if category is a root\n    const isRoot = (cat: any) => cat.parent === null || !map.has(cat.parent);\n\n    return editorCategories.filter(isRoot).map((root: any) => ({\n      id: root.id,\n      name: root.name,\n      children: [...this.buildChildren(root, editorCategories, map)],\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        origin: child.origin,\n        parent: child.parent,\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    this.selectedCategory = item;\n    this.itemsSelectedChange.emit(this.selectedCategory);\n    this.selectedItems = item;\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  }\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  }\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  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    const term = this.searchConfig[header].term.toLowerCase();\n\n    if (header.toLowerCase() === 'policy category') {\n      this.paginatedItems = this.items.filter((item: any) =>\n        item?.name?.toLowerCase().includes(term)\n      );\n      this.checkCategoryAvailbility();\n    } else if (header.toLowerCase() === 'policy sub category') {\n      this.policyCategoryList =\n        this.items\n          .find((category: any) => category.id === this.activeProgram?.id)\n          ?.children.filter((sub: any) =>\n            sub?.name?.toLowerCase().includes(term)\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","<div class=\"dynamic-list-container\">\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"\n      items?.length > 0 || loaderState.programList || 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\">\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)]=\"searchConfig[header].term\"\n              [placeholder]=\"searchConfig[header].placeholder\"\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          <!-- Show items when they exist -->\n          <ng-container\n            *ngIf=\"\n              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length > 0\n            \"\n          >\n            <div\n              *ngFor=\"\n                let item of paginatedItems\n                  | search\n                    : searchConfig['POLICY CATEGORY'].term\n                    : 'name' as filteredParentCategories;\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=\"\n                  selectedItems[0]?.origin === item.id ||\n                  selectedItems[0]?.id === item.id\n                \"\n              >\n              <i class=\"icons checked\">&#xe949;</i>\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                  {{ 1 }}\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                  CATEGORY 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\n          <!-- Show no-data when search returns no results -->\n          <ng-container\n            *ngIf=\"\n              searchConfig['POLICY CATEGORY'].term &&\n              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length === 0\n            \"\n          >\n            <div class=\"list-no-data-container\">\n              <app-no-data\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"POLICY_NO_DATA.search\"\n              ></app-no-data>\n            </div>\n          </ng-container>\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              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length > 0 && 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]=\"selectedItems[0]?.id === 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"]}
|
|
274
|
+
//# 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 {\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 {\n  POLICY_CATEGORY_LIST_STUBS,\n  POLICY_CATEGORY_LIST_STUBS_2,\n} 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  selectedCategory: any[] = [];\n  searchConfig: { [key: string]: { term: string; placeholder: string } } = {\n    'POLICY CATEGORY': { term: '', placeholder: 'Search Category' },\n    'POLICY SUB CATEGORY': { term: '', placeholder: 'Search Sub Category' },\n  };\n\n  filteredCategories: any[] = []; // after applying category search\n  filteredSubcategories: any[] = []; // after applying subcategory search\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    this.getPolicyCategoryList();\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  getPolicyCategoryList(): void {\n    this.loaderState.programList = true;\n    this.policyListApiService.getPolicyCategoryList().subscribe((res: any) => {\n      this.items = this.prepareCategoryList(res?.data?.policyCategories);\n      this.viewCategory(this.items[0]);\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 editorCategories = categories.filter(\n      (category: any) =>\n        category?.role === 'editor' || category?.role === 'owner'\n    );\n    const map = new Map<number, any>();\n    editorCategories.forEach((cat) => map.set(cat?.id, cat));\n\n    // Check if category is a root\n    const isRoot = (cat: any) => cat?.parent === null || !map.has(cat?.parent);\n\n    return editorCategories.filter(isRoot).map((root: any) => ({\n      id: root?.id,\n      name: root?.name,\n      children: [...this.buildChildren(root, editorCategories, map)],\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        origin: child?.origin,\n        parent: child?.parent,\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    this.selectedCategory = item;\n    this.itemsSelectedChange.emit(this.selectedCategory);\n    this.selectedItems = item;\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  }\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  }\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  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    const term = this.searchConfig[header].term.toLowerCase();\n\n    if (header.toLowerCase() === 'policy category') {\n      this.paginatedItems = this.items.filter((item: any) =>\n        item?.name?.toLowerCase().includes(term)\n      );\n      this.checkCategoryAvailbility();\n    } else if (header.toLowerCase() === 'policy sub category') {\n      this.policyCategoryList =\n        this.items\n          .find((category: any) => category.id === this.activeProgram?.id)\n          ?.children.filter((sub: any) =>\n            sub?.name?.toLowerCase().includes(term)\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","<div class=\"dynamic-list-container\">\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"\n      items?.length > 0 || loaderState.programList || 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\">\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)]=\"searchConfig[header].term\"\n              [placeholder]=\"searchConfig[header].placeholder\"\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          <!-- Show items when they exist -->\n          <ng-container\n            *ngIf=\"\n              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length > 0\n            \"\n          >\n            <div\n              *ngFor=\"\n                let item of paginatedItems\n                  | search\n                    : searchConfig['POLICY CATEGORY'].term\n                    : 'name' as filteredParentCategories;\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=\"\n                  selectedItems[0]?.origin === item.id ||\n                  selectedItems[0]?.id === item.id\n                \"\n              >\n              <i class=\"icons checked\">&#xe949;</i>\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                  {{ 1 }}\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                  CATEGORY 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\n          <!-- Show no-data when search returns no results -->\n          <ng-container\n            *ngIf=\"\n              searchConfig['POLICY CATEGORY'].term &&\n              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length === 0\n            \"\n          >\n            <div class=\"list-no-data-container\">\n              <app-no-data\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"POLICY_NO_DATA.search\"\n              ></app-no-data>\n            </div>\n          </ng-container>\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              (\n                paginatedItems\n                | search : searchConfig['POLICY CATEGORY'].term : 'name'\n              )?.length > 0 && 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]=\"selectedItems[0]?.id === 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"]}
|
|
@@ -35836,24 +35836,24 @@ class PolicyCategoryListComponent {
|
|
|
35836
35836
|
this.goToPage(1, data);
|
|
35837
35837
|
}
|
|
35838
35838
|
prepareCategoryList(categories) {
|
|
35839
|
-
const editorCategories = categories.filter((category) => category
|
|
35839
|
+
const editorCategories = categories.filter((category) => category?.role === 'editor' || category?.role === 'owner');
|
|
35840
35840
|
const map = new Map();
|
|
35841
|
-
editorCategories.forEach((cat) => map.set(cat
|
|
35841
|
+
editorCategories.forEach((cat) => map.set(cat?.id, cat));
|
|
35842
35842
|
// Check if category is a root
|
|
35843
|
-
const isRoot = (cat) => cat
|
|
35843
|
+
const isRoot = (cat) => cat?.parent === null || !map.has(cat?.parent);
|
|
35844
35844
|
return editorCategories.filter(isRoot).map((root) => ({
|
|
35845
|
-
id: root
|
|
35846
|
-
name: root
|
|
35845
|
+
id: root?.id,
|
|
35846
|
+
name: root?.name,
|
|
35847
35847
|
children: [...this.buildChildren(root, editorCategories, map)],
|
|
35848
35848
|
}));
|
|
35849
35849
|
}
|
|
35850
35850
|
buildPath(categories, map) {
|
|
35851
35851
|
const names = []; // start with child name
|
|
35852
35852
|
let current = categories;
|
|
35853
|
-
while (current && current
|
|
35854
|
-
const parent = map.get(current
|
|
35853
|
+
while (current && current?.parent !== null) {
|
|
35854
|
+
const parent = map.get(current?.parent);
|
|
35855
35855
|
if (parent) {
|
|
35856
|
-
names.push(parent
|
|
35856
|
+
names.push(parent?.name);
|
|
35857
35857
|
current = parent;
|
|
35858
35858
|
}
|
|
35859
35859
|
else {
|
|
@@ -35864,14 +35864,14 @@ class PolicyCategoryListComponent {
|
|
|
35864
35864
|
}
|
|
35865
35865
|
buildChildren(root, categories, map) {
|
|
35866
35866
|
return categories
|
|
35867
|
-
.filter((c) => c
|
|
35867
|
+
.filter((c) => c?.origin === root?.id || c?.parent === root?.id)
|
|
35868
35868
|
.map((child) => ({
|
|
35869
|
-
id: child
|
|
35870
|
-
name: child
|
|
35869
|
+
id: child?.id,
|
|
35870
|
+
name: child?.name,
|
|
35871
35871
|
children: [],
|
|
35872
35872
|
display_name: this.buildPath(child, map),
|
|
35873
|
-
origin: child
|
|
35874
|
-
parent: child
|
|
35873
|
+
origin: child?.origin,
|
|
35874
|
+
parent: child?.parent,
|
|
35875
35875
|
}));
|
|
35876
35876
|
}
|
|
35877
35877
|
/**
|