vcomply-workflow-engine 6.0.93 → 6.0.94

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.
@@ -227,6 +227,14 @@ export class ProgramListComponent {
227
227
  this.paginatedItems = this.items;
228
228
  }
229
229
  this.appliedProgramType = this.programTypeList.filter((item) => this.selectedProgramType.includes(item.id));
230
+ this.checkCategoryAvailbility();
231
+ }
232
+ checkCategoryAvailbility() {
233
+ const isSelectedProgramAvailable = this.paginatedItems.some((item) => item?.id === this.activeProgram?.id);
234
+ if (!isSelectedProgramAvailable) {
235
+ this.categoryList = [];
236
+ this.activeProgram = null;
237
+ }
230
238
  }
231
239
  /** Trigger debounced search */
232
240
  search() {
@@ -235,12 +243,8 @@ export class ProgramListComponent {
235
243
  /** Perform search on items */
236
244
  performSearch() {
237
245
  const filteredItems = this.items.filter((item) => item?.name?.toLowerCase().includes(this.searchTerm?.toLowerCase()));
238
- const isSelectedProgramAvailable = filteredItems.some((item) => item?.id === this.activeProgram?.id);
239
- if (!isSelectedProgramAvailable) {
240
- this.categoryList = [];
241
- this.activeProgram = null;
242
- }
243
246
  this.paginatedItems = filteredItems;
247
+ this.checkCategoryAvailbility();
244
248
  }
245
249
  /** Cleanup subscriptions on component destruction */
246
250
  ngOnDestroy() {
@@ -266,4 +270,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
266
270
  }], itemsSelectedChange: [{
267
271
  type: Output
268
272
  }] } });
269
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, OnInit, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\nimport { ListItem } from '../interfaces/list-item.interface';\nimport { PROGRAM_TABLE_HEADERS, PAGINATION_OPTIONS, PROGRAM_TYPE_LIST, PROGRAM_NO_DATA } from '../constant';\nimport { ListUtilsService } from '../services/list-utils.service';\nimport { ProgramListApiService } from '../services/program-list-api.service';\nimport { Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ASSETS } from '../../../constants/assets.constants';\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@Component({\n  selector: 'app-program-list',\n  templateUrl: './program-list.component.html',\n  styleUrls: ['./program-list.component.less']\n})\nexport class ProgramListComponent<T extends ListItem> implements OnInit, OnChanges, 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 = PROGRAM_TABLE_HEADERS;\n  currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n  pageSize = PAGINATION_OPTIONS.PAGE_SIZE;\n  totalPages = 0;\n  searchTerm = '';\n  paginatedItems: T[] = [];\n  activeProgram: any | null = null;\n  categoryList: any[] = [];\n  programTypeList: any[] = PROGRAM_TYPE_LIST;\n  selectedProgramType: any[] = [];\n  loaderState: any = {\n    programList: false,\n    categoryList: false,\n  };\n  appliedProgramType: any[] = [];\n  PROGRAM_NO_DATA: any = PROGRAM_NO_DATA;\n  ASSETS: any = ASSETS;\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 programListApiService: ProgramListApiService\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    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.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    if (event) {\n      if(!this.selectedItems[this.activeProgram.id]) {\n        this.selectedItems[this.activeProgram.id] = [];\n      }\n      this.selectedItems[this.activeProgram.id].push(item);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemSelected.emit(item);\n    } else {\n      this.selectedItems = this.selectedItems[this.activeProgram.id].filter((selected: any) => selected.id !== item.id);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemDeselected.emit(item);\n    }\n  }\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    this.categoryList = [];\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    if(!item) return;\n    this.loaderState.categoryList = true;\n    const URL = `${this.url.categoryList}&id=${item.id}`;\n    this.activeProgram = item;\n    this.programListApiService.getProgramList(URL).subscribe((res: any) => {\n      this.categoryList = res.data.categories;\n      this.loaderState.categoryList = false;\n      this.categoryList = this.addParentTreeToCategories(this.categoryList);\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    const categoryMap = new Map(categories?.map(category => [category?.id, category]));\n  \n    function getParentTree(category: any): string[] {\n      const parentTree: string[] = [];\n      let currentParent = category?.parent;\n  \n      while (currentParent) {\n        const parentCategory = categoryMap.get(currentParent);\n        if (parentCategory) {\n          parentTree.push(parentCategory.name);\n          currentParent = parentCategory.parent;\n        } else {\n          break;\n        }\n      }\n  \n      return parentTree;\n    }\n  \n    return categories.map(category => ({\n      ...category,\n      parentTree: getParentTree(category)\n    }));\n  }\n\n  /**\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    this.onFilterChange();\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 = this.listUtils.paginate(filteredItems, this.currentPage, this.pageSize);\n    } else {\n      this.paginatedItems = this.items;\n    }\n\n    this.appliedProgramType = this.programTypeList.filter((item: any) => this.selectedProgramType.includes(item.id));\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    const isSelectedProgramAvailable = filteredItems.some((item: any) => item?.id === this.activeProgram?.id);\n    if(!isSelectedProgramAvailable) {\n      this.categoryList = [];\n      this.activeProgram = null;\n    }\n    this.paginatedItems = filteredItems;\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 class=\"vx-d-flex\">\n    <div class=\"search-block vx-w-100\">\n      <i class=\"icons\">&#xe90b;</i>\n      <input\n        type=\"text\"\n        [(ngModel)]=\"searchTerm\"\n        placeholder=\"Search...\"\n        (keyup)=\"search()\"\n      />\n    </div>\n    <div\n      class=\"dynamic-list-filter\"\n      appPopover\n      (click)=\"programTypePopover.popover()\"\n      placement=\"right\"\n    >\n      <div *ngIf=\"appliedProgramType.length === 0; else selectedTypeFilter\" class=\"filter-text\">Select Program Type</div>\n      <ng-template #selectedTypeFilter>\n        <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"appliedProgramType.length\"\n            >\n      \n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  appliedProgramType[0]?.name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  appliedProgramType[0]?.name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                placement=\"right\"\n                *ngIf=\"appliedProgramType.length > 1\"\n              >\n                +{{ appliedProgramType.length - 1 }}\n              </button>\n            </div>\n      </ng-template>\n      <i class=\"icons filter-icon\"> &#xe9e8; </i>\n    </div>\n  </div>\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"paginatedItems?.length > 0 ||  (loaderState.programList || loaderState.categoryList); else defaultTemplate\"\n  >\n    <div class=\"dynamic-list-header vx-d-flex\">\n      <ng-container *ngFor=\"let header of tableHeaders\">\n        <div class=\"vx-d-flex vx-w-50 vx-pl-1\">\n          <div\n            class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n          >\n            #\n          </div>\n          <div\n            class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n          >\n            {{ header }}\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"dynamic-list-body vx-d-flex\">\n      <div class=\"left-column\">\n        <ng-container *ngIf=\"!loaderState.programList;else programListLoader\">\n          <div\n          *ngFor=\"let item of paginatedItems | search: searchTerm : 'name'; let i = index\"\n          class=\"list-row\"\n          [class.selected]=\"activeProgram?.id === item.id\"\n          (click)=\"viewCategory(item)\"\n        >\n          <div class=\"list-column serial\">\n            <div class=\"srNo\">{{ i + 1 }}</div>\n          </div>\n          <div\n            class=\"list-column name\"\n            [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n          </div>\n          <div\n            class=\"list-column count\"\n            *ngIf=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div\n              class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n            >\n              {{ selectedItems[item.id].length }}\n            </div>\n            <div\n              class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n            >\n              {{selectedItems[item.id].length > 1 ? 'CATEGORIES' : '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        <ng-template #programListLoader>\n          <app-table-loader></app-table-loader>\n\n        </ng-template>\n      </div>\n      <div class=\"right-column\">\n        <ng-container *ngIf=\"!loaderState.categoryList && !loaderState.programList;else categoryListLoader\">\n          <ng-container *ngIf=\"categoryList?.length > 0;else defaultSubCategoryTemplate\">    \n            <div\n            class=\"list-row vx-pl-2 vx-pr-2\"\n            *ngFor=\"let item of categoryList; let i = index\"\n        > \n          <app-cs-checkbox\n            [value]=\"item?.id\"\n            [ngValue]=\"item.id | checkSelectedItems: selectedItems[activeProgram.id]\"\n            (ngValueChange)=\"selectItem($event, item)\"\n          >\n            <span class=\"value-inner\">\n              <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n              <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n                <div *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]=\"\n                ASSETS.search_data\n              \"\n              [noDataText]=\"PROGRAM_NO_DATA.categoryList\"\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       \n      </div>\n    </div>\n  </div>\n  <ng-template #defaultTemplate>\n    <div class=\"list-no-data-container\">\n      <app-no-data\n        [noDataImage]=\"\n          ASSETS.search_data\n        \"\n        [noDataText]=\"searchTerm ? PROGRAM_NO_DATA.search : PROGRAM_NO_DATA.programList\"\n      ></app-no-data>\n    </div>\n  </ng-template>\n</div>\n\n<app-popover #programTypePopover>\n  <div class=\"new-action-list\">\n    <div\n      class=\"program-type-text vx-fs-11 vx-fw-500 vx-gray-60 vx-lh-16 vx-p-2 vx-tt-uppercase\"\n    >\n      Program Type:\n    </div>\n    <ul class=\"action-item\">\n      <li *ngFor=\"let item of programTypeList\">\n        <div class=\"chip-item\">\n          <app-cs-checkbox\n            [value]=\"item.id\"\n            [ngValue]=\"selectedProgramType.includes(item.id)\"\n            (ngValueChange)=\"selectFilter($event, item)\"\n          >\n            {{ item?.name }}\n          </app-cs-checkbox>\n        </div>\n      </li>\n    </ul>\n    <div\n      class=\"program-type-bottom vx-d-flex vx-align-center vx-justify-center vx-pt-3 vx-pb-3\"\n    >\n      <button\n        (click)=\"resetFilter();programTypePopover.closePopover('top')\"\n        class=\"reset-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n      >\n        RESET\n      </button>\n      <button\n        (click)=\"onFilterChange(); programTypePopover.closePopover('top')\"\n        class=\"apply-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n        [class.disabled]=\"selectedProgramType?.length === 0\"\n      >\n        APPLY\n      </button>\n    </div>\n  </div>\n</app-popover>\n"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/program-list/program-list/program-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, TemplateRef, OnInit, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\nimport { ListItem } from '../interfaces/list-item.interface';\nimport { PROGRAM_TABLE_HEADERS, PAGINATION_OPTIONS, PROGRAM_TYPE_LIST, PROGRAM_NO_DATA } from '../constant';\nimport { ListUtilsService } from '../services/list-utils.service';\nimport { ProgramListApiService } from '../services/program-list-api.service';\nimport { Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ASSETS } from '../../../constants/assets.constants';\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@Component({\n  selector: 'app-program-list',\n  templateUrl: './program-list.component.html',\n  styleUrls: ['./program-list.component.less']\n})\nexport class ProgramListComponent<T extends ListItem> implements OnInit, OnChanges, 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 = PROGRAM_TABLE_HEADERS;\n  currentPage = PAGINATION_OPTIONS.DEFAULT_CURRENT_PAGE;\n  pageSize = PAGINATION_OPTIONS.PAGE_SIZE;\n  totalPages = 0;\n  searchTerm = '';\n  paginatedItems: T[] = [];\n  activeProgram: any | null = null;\n  categoryList: any[] = [];\n  programTypeList: any[] = PROGRAM_TYPE_LIST;\n  selectedProgramType: any[] = [];\n  loaderState: any = {\n    programList: false,\n    categoryList: false,\n  };\n  appliedProgramType: any[] = [];\n  PROGRAM_NO_DATA: any = PROGRAM_NO_DATA;\n  ASSETS: any = ASSETS;\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 programListApiService: ProgramListApiService\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    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.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    if (event) {\n      if(!this.selectedItems[this.activeProgram.id]) {\n        this.selectedItems[this.activeProgram.id] = [];\n      }\n      this.selectedItems[this.activeProgram.id].push(item);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemSelected.emit(item);\n    } else {\n      this.selectedItems = this.selectedItems[this.activeProgram.id].filter((selected: any) => selected.id !== item.id);\n      this.itemsSelectedChange.emit(this.selectedItems);\n      this.itemDeselected.emit(item);\n    }\n  }\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    this.categoryList = [];\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    if(!item) return;\n    this.loaderState.categoryList = true;\n    const URL = `${this.url.categoryList}&id=${item.id}`;\n    this.activeProgram = item;\n    this.programListApiService.getProgramList(URL).subscribe((res: any) => {\n      this.categoryList = res.data.categories;\n      this.loaderState.categoryList = false;\n      this.categoryList = this.addParentTreeToCategories(this.categoryList);\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    const categoryMap = new Map(categories?.map(category => [category?.id, category]));\n  \n    function getParentTree(category: any): string[] {\n      const parentTree: string[] = [];\n      let currentParent = category?.parent;\n  \n      while (currentParent) {\n        const parentCategory = categoryMap.get(currentParent);\n        if (parentCategory) {\n          parentTree.push(parentCategory.name);\n          currentParent = parentCategory.parent;\n        } else {\n          break;\n        }\n      }\n  \n      return parentTree;\n    }\n  \n    return categories.map(category => ({\n      ...category,\n      parentTree: getParentTree(category)\n    }));\n  }\n\n  /**\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    this.onFilterChange();\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 = this.listUtils.paginate(filteredItems, this.currentPage, this.pageSize);\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","<div class=\"dynamic-list-container\">\n  <div class=\"vx-d-flex\">\n    <div class=\"search-block vx-w-100\">\n      <i class=\"icons\">&#xe90b;</i>\n      <input\n        type=\"text\"\n        [(ngModel)]=\"searchTerm\"\n        placeholder=\"Search...\"\n        (keyup)=\"search()\"\n      />\n    </div>\n    <div\n      class=\"dynamic-list-filter\"\n      appPopover\n      (click)=\"programTypePopover.popover()\"\n      placement=\"right\"\n    >\n      <div *ngIf=\"appliedProgramType.length === 0; else selectedTypeFilter\" class=\"filter-text\">Select Program Type</div>\n      <ng-template #selectedTypeFilter>\n        <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"appliedProgramType.length\"\n            >\n      \n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  appliedProgramType[0]?.name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  appliedProgramType[0]?.name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                placement=\"right\"\n                *ngIf=\"appliedProgramType.length > 1\"\n              >\n                +{{ appliedProgramType.length - 1 }}\n              </button>\n            </div>\n      </ng-template>\n      <i class=\"icons filter-icon\"> &#xe9e8; </i>\n    </div>\n  </div>\n  <div\n    class=\"dynamic-list-table\"\n    *ngIf=\"paginatedItems?.length > 0 ||  (loaderState.programList || loaderState.categoryList); else defaultTemplate\"\n  >\n    <div class=\"dynamic-list-header vx-d-flex\">\n      <ng-container *ngFor=\"let header of tableHeaders\">\n        <div class=\"vx-d-flex vx-w-50 vx-pl-1\">\n          <div\n            class=\"serialNo vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center\"\n          >\n            #\n          </div>\n          <div\n            class=\"headerText vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center\"\n          >\n            {{ header }}\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"dynamic-list-body vx-d-flex\">\n      <div class=\"left-column\">\n        <ng-container *ngIf=\"!loaderState.programList;else programListLoader\">\n          <div\n          *ngFor=\"let item of paginatedItems | search: searchTerm : 'name'; let i = index\"\n          class=\"list-row\"\n          [class.selected]=\"activeProgram?.id === item.id\"\n          (click)=\"viewCategory(item)\"\n        >\n          <div class=\"list-column serial\">\n            <div class=\"srNo\">{{ i + 1 }}</div>\n          </div>\n          <div\n            class=\"list-column name\"\n            [class.with-count]=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div class=\"name-inner vx-fs-13 vx-pr-2\">{{ item.name }}</div>\n          </div>\n          <div\n            class=\"list-column count\"\n            *ngIf=\"selectedItems[item.id]?.length > 0\"\n          >\n            <div\n              class=\"count-box vx-fs-9 vx-fw-600 vx-lh-4 vx-d-flex vx-align-center vx-justify-center\"\n            >\n              {{ selectedItems[item.id].length }}\n            </div>\n            <div\n              class=\"count-text vx-fs-11 vx-fw-500 vx-tt-uppercase vx-lh-4 vx-ml-2\"\n            >\n              {{selectedItems[item.id].length > 1 ? 'CATEGORIES' : '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        <ng-template #programListLoader>\n          <app-table-loader></app-table-loader>\n\n        </ng-template>\n      </div>\n      <div class=\"right-column\">\n        <ng-container *ngIf=\"!loaderState.categoryList && !loaderState.programList;else categoryListLoader\">\n          <ng-container *ngIf=\"categoryList?.length > 0;else defaultSubCategoryTemplate\">    \n            <div\n            class=\"list-row vx-pl-2 vx-pr-2\"\n            *ngFor=\"let item of categoryList; let i = index\"\n        > \n          <app-cs-checkbox\n            [value]=\"item?.id\"\n            [ngValue]=\"item.id | checkSelectedItems: selectedItems[activeProgram.id]\"\n            (ngValueChange)=\"selectItem($event, item)\"\n          >\n            <span class=\"value-inner\">\n              <div class=\"item-name vx-fs-13\">{{ item?.name }}</div>\n              <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\n                <div *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]=\"\n                ASSETS.search_data\n              \"\n              [noDataText]=\"PROGRAM_NO_DATA.categoryList\"\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       \n      </div>\n    </div>\n  </div>\n  <ng-template #defaultTemplate>\n    <div class=\"list-no-data-container\">\n      <app-no-data\n        [noDataImage]=\"\n          ASSETS.search_data\n        \"\n        [noDataText]=\"searchTerm ? PROGRAM_NO_DATA.search : PROGRAM_NO_DATA.programList\"\n      ></app-no-data>\n    </div>\n  </ng-template>\n</div>\n\n<app-popover #programTypePopover>\n  <div class=\"new-action-list\">\n    <div\n      class=\"program-type-text vx-fs-11 vx-fw-500 vx-gray-60 vx-lh-16 vx-p-2 vx-tt-uppercase\"\n    >\n      Program Type:\n    </div>\n    <ul class=\"action-item\">\n      <li *ngFor=\"let item of programTypeList\">\n        <div class=\"chip-item\">\n          <app-cs-checkbox\n            [value]=\"item.id\"\n            [ngValue]=\"selectedProgramType.includes(item.id)\"\n            (ngValueChange)=\"selectFilter($event, item)\"\n          >\n            {{ item?.name }}\n          </app-cs-checkbox>\n        </div>\n      </li>\n    </ul>\n    <div\n      class=\"program-type-bottom vx-d-flex vx-align-center vx-justify-center vx-pt-3 vx-pb-3\"\n    >\n      <button\n        (click)=\"resetFilter();programTypePopover.closePopover('top')\"\n        class=\"reset-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n      >\n        RESET\n      </button>\n      <button\n        (click)=\"onFilterChange(); programTypePopover.closePopover('top')\"\n        class=\"apply-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-lh-6\"\n        [class.disabled]=\"selectedProgramType?.length === 0\"\n      >\n        APPLY\n      </button>\n    </div>\n  </div>\n</app-popover>\n"]}
@@ -25480,6 +25480,14 @@ class ProgramListComponent {
25480
25480
  this.paginatedItems = this.items;
25481
25481
  }
25482
25482
  this.appliedProgramType = this.programTypeList.filter((item) => this.selectedProgramType.includes(item.id));
25483
+ this.checkCategoryAvailbility();
25484
+ }
25485
+ checkCategoryAvailbility() {
25486
+ const isSelectedProgramAvailable = this.paginatedItems.some((item) => item?.id === this.activeProgram?.id);
25487
+ if (!isSelectedProgramAvailable) {
25488
+ this.categoryList = [];
25489
+ this.activeProgram = null;
25490
+ }
25483
25491
  }
25484
25492
  /** Trigger debounced search */
25485
25493
  search() {
@@ -25488,12 +25496,8 @@ class ProgramListComponent {
25488
25496
  /** Perform search on items */
25489
25497
  performSearch() {
25490
25498
  const filteredItems = this.items.filter((item) => item?.name?.toLowerCase().includes(this.searchTerm?.toLowerCase()));
25491
- const isSelectedProgramAvailable = filteredItems.some((item) => item?.id === this.activeProgram?.id);
25492
- if (!isSelectedProgramAvailable) {
25493
- this.categoryList = [];
25494
- this.activeProgram = null;
25495
- }
25496
25499
  this.paginatedItems = filteredItems;
25500
+ this.checkCategoryAvailbility();
25497
25501
  }
25498
25502
  /** Cleanup subscriptions on component destruction */
25499
25503
  ngOnDestroy() {