@libs-ui/components-list 0.2.241 → 0.2.243

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.
@@ -29,7 +29,7 @@ export class LibsUiComponentsListTemplatesComponentAbstract {
29
29
  intervalCheckScrollSubscription;
30
30
  // #region INPUT
31
31
  functionGetItemsAutoAddList = input();
32
- paddingLeftItem = input(undefined);
32
+ paddingLeftItem = input();
33
33
  maxItemShow = input(0);
34
34
  searchConfig = input();
35
35
  config = input();
@@ -54,7 +54,7 @@ export class LibsUiComponentsListTemplatesComponentAbstract {
54
54
  loadingIconSize = input();
55
55
  resetKeyWhenSelectAllKeyDropdown = input();
56
56
  ignoreClassDisableDefaultWhenUseKeysDisableItem = input(); // bỏ chế độ disable item trên html để disable từng phần trong rows
57
- templateRefSearchNoData = input(undefined);
57
+ templateRefSearchNoData = input();
58
58
  autoSelectedFirstItemCallOutsideBefore = input(false);
59
59
  // #region OUTPUT
60
60
  outSortSingleSelect = output();
@@ -337,4 +337,4 @@ export class LibsUiComponentsListTemplatesComponentAbstract {
337
337
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsListTemplatesComponentAbstract, decorators: [{
338
338
  type: Directive
339
339
  }], ctorParameters: () => [] });
340
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"templates.component.abstract.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/list/src/templates/templates.component.abstract.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @angular-eslint/use-lifecycle-interface */\nimport { Directive, ElementRef, inject, input, model, OnDestroy, output, signal, TemplateRef, viewChild, WritableSignal } from \"@angular/core\";\nimport { ISort } from \"@libs-ui/components-buttons-sort\";\nimport { IInputSearchConfig } from \"@libs-ui/components-inputs-search\";\nimport { IFlagMouse } from \"@libs-ui/components-popover\";\nimport { IPaging, TYPE_TEMPLATE_REF } from \"@libs-ui/interfaces-types\";\nimport { LibsUiHttpRequestService } from \"@libs-ui/services-http-request\";\nimport { cloneDeep, convertObjectToSignal, convertSignalToObject, isNil } from \"@libs-ui/utils\";\nimport { TranslateService } from '@ngx-translate/core';\nimport { interval, Subject, Subscription } from 'rxjs';\nimport { skipWhile, take, takeUntil } from 'rxjs/operators';\nimport { getFieldKeyByType } from \"../defines/list.define\";\nimport { IDataUpdateToStore, IListDataEmitKey, IListDataEmitMultiKey } from \"../interfaces\";\nimport { IListConfigItem, IListConfigItemCheckbox, IListConfigItemRadio, IListConfigItemText, IListConfigItemTextCol } from \"../interfaces/config-item.interface\";\n\n@Directive()\nexport abstract class LibsUiComponentsListTemplatesComponentAbstract implements OnDestroy {\n  // #region PROPERTY\n  protected timeAnimationScrollToIndexItem = signal<number>(250);\n  protected loading = signal<boolean>(true);\n  protected heightViewPort = signal<number>(0);\n  protected store = signal<Array<WritableSignal<any>>>([]);\n  protected items = signal<Array<WritableSignal<any>>>([]);\n  protected loadedLastItem = signal<boolean>(false);\n  protected hasScroll = signal<boolean>(false);\n  protected fieldKeyDefault = signal<string>('id');\n  protected fieldKey = signal<string>('id');\n  protected timeAutoScrollItemSelected = signal<number>(0);\n  protected pagingStore = signal<IPaging | undefined>(undefined);\n  protected heightItem = signal<number>(0);\n  protected timeIntervalIntervalSetHeightViewPort = signal<number>(0);\n  protected timeIntervalCheckScroll = signal<number>(250);\n\n  protected onDestroy: Subject<void> = new Subject();\n  protected intervalSetHeightViewPortSubscription!: Subscription;\n  protected intervalCheckScrollSubscription!: Subscription;\n\n  // #region INPUT\n  readonly functionGetItemsAutoAddList = input<(() => Array<any>) | undefined>();\n  readonly paddingLeftItem = input<boolean | undefined>(undefined);\n  readonly maxItemShow = input<number>(0);\n  readonly searchConfig = input<IInputSearchConfig>();\n  readonly config = input<IListConfigItem>();\n  readonly keySearch = model<string>('');\n  readonly dropdownTabKeyActive = input<string | undefined>();\n  readonly isSearchOnline = input<boolean>(false);\n\n  readonly onSearch = input<Subject<string>>();\n  readonly onRefresh = input<Subject<void>>();\n  readonly onSetHiddenItemByKey = input<Subject<Array<unknown>>>();\n  readonly onRemoveItems = input<Subject<Array<unknown>>>();\n  readonly onSetDataStore = input<Subject<Array<any>>>();\n  readonly onUpdateMultiKeySelectedGroup = input<Subject<void>>();\n  readonly onUpdateData = input<Subject<IDataUpdateToStore>>();\n  readonly clickExactly = input<boolean>();\n  readonly keySelected = model<unknown>(); // sử dụng cho type radio,text.\n  readonly multiKeySelected = model<Array<unknown> | undefined>([]); // sử dụng cho type cho phép chọn nhiều.\n  readonly keysDisableItem = input<Array<unknown> | undefined>();\n  readonly keysHiddenItem = model<Array<unknown> | undefined>();\n  readonly disable = input<boolean | undefined>();\n  readonly disableLabel = input<boolean | undefined>();\n  readonly zIndex = input<number>(1200);\n  readonly loadingIconSize = input<'large' | 'medium' | 'small' | 'smaller' | undefined>();\n  readonly resetKeyWhenSelectAllKeyDropdown = input<boolean | undefined>();\n  readonly ignoreClassDisableDefaultWhenUseKeysDisableItem = input<boolean | undefined>(); // bỏ chế độ disable item trên html để disable từng phần trong rows\n  readonly templateRefSearchNoData = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>(undefined);\n  readonly autoSelectedFirstItemCallOutsideBefore = input<boolean>(false);\n\n  // #region OUTPUT\n  readonly outSortSingleSelect = output<ISort>();\n  readonly outSelectKey = output<IListDataEmitKey | undefined>(); // sử dụng cho type radio,text.\n  readonly outSelectMultiKey = output<IListDataEmitMultiKey>(); // sử dụng cho type cho phép chọn nhiều.\n  readonly outUnSelectMultiKey = output<Array<unknown>>(); // sử dụng cho type cho phép chọn nhiều.\n  readonly outFieldKey = output<string | undefined>();\n  readonly outChangeView = output<Array<any>>();\n  readonly outLoading = output<boolean>();\n  readonly outChangStageFlagMousePopover = output<IFlagMouse>();\n  readonly outLoadItemsComplete = output<{ items: Array<any>, paging?: IPaging }>();\n\n  /* VIEW CHILD */\n  protected itemRef = viewChild<ElementRef>('itemRef');\n  protected elementScroll = viewChild<ElementRef>('elementScroll');\n\n  // #region INJECT\n  protected translateService = inject(TranslateService);\n  protected httpRequestService = inject(LibsUiHttpRequestService);\n\n  constructor() {\n    this.outLoading.emit(this.loading());\n  }\n\n  ngOnInit() {\n    this.onSearch()?.pipe(takeUntil(this.onDestroy)).subscribe((keySearch: string) => {\n      this.keySearch.set(keySearch ?? '');\n      this.processSearch();\n    });\n    this.onRefresh()?.pipe(skipWhile(() => this.loading()), takeUntil(this.onDestroy)).subscribe(() => {\n      if (this.dropdownTabKeyActive()) {\n        this.items.set([]);\n        this.store.set([]);\n      }\n      this.callApiByService(true);\n    });\n    this.onSetHiddenItemByKey()?.pipe(takeUntil(this.onDestroy)).subscribe(this.setHiddenItemByKey.bind(this));\n    this.outFieldKey.emit(getFieldKeyByType(this.config(), this.fieldKeyDefault()));\n    this.onRemoveItems()?.pipe(takeUntil(this.onDestroy)).subscribe(this.removeItems.bind(this));\n    this.onUpdateData()?.pipe(takeUntil(this.onDestroy)).subscribe(this.updateData.bind(this));\n  }\n\n  /* FUNCTIONS */\n  private updateData(data: IDataUpdateToStore) {\n    if (!data) {\n      return;\n    }\n    const { newData, functionCustomAddDataToStore } = data;\n    if (!newData() || !newData().length) {\n      return;\n    }\n    if (this.config()?.type === 'checkbox') {\n      newData().forEach(item => item.update(value => ({ ...value, isAddNew: true })));\n    }\n    functionCustomAddDataToStore(newData, this.store);\n    this.processData();\n  }\n\n  private getFieldKey() {\n    let fieldKey: string | undefined;\n\n    const config = this.config();\n\n    if (!config) {\n      return 'id';\n    }\n\n    switch (config.type) {\n      case 'group':\n        fieldKey = config.configTemplateGroup?.()?.fieldKey;\n        break;\n\n      case 'tag':\n        fieldKey = config.configTemplateTag?.()?.fieldKey;\n        break;\n\n      case 'text':\n        fieldKey = config.configTemplateText?.()?.fieldKey;\n        break;\n\n      case 'checkbox':\n        fieldKey = config.configTemplateCheckbox?.()?.fieldKey;\n        break;\n\n      case 'radio':\n        fieldKey = config.configTemplateRadio?.()?.fieldKey;\n        break;\n    }\n\n    return fieldKey || 'id';\n  }\n\n  private removeItems(keys: Array<unknown>) {\n    const fieldKey = this.getFieldKey();\n\n    [this.store(), this.items()].forEach(element => {\n      if (this.config()?.type === 'group') {\n        element.forEach(item => {\n          this.removeItem(item()[this.config()?.configTemplateGroup?.()?.fieldGetItems || 'items'](), keys, fieldKey);\n        });\n\n        return;\n      }\n      this.removeItem(element, keys, fieldKey);\n    });\n    this.processData();\n  }\n\n  private removeItem(data: Array<WritableSignal<any>>, keys: Array<unknown>, fieldKey: string) {\n    if (!data || !data.length) {\n      return;\n    }\n    keys.forEach(key => {\n      const index = data.findIndex(item => item()[fieldKey] === key);\n\n      if (index > -1) {\n        data.splice(index, 1);\n      }\n    });\n  }\n\n  protected setHeightViewPort(callBackCalculatorHeightSuccess?: () => void) {\n    const lengthItems = this.getLengthItem();\n    this.heightItem.update(val => this.config()?.heightItem || val);\n\n    if (!lengthItems) {\n      this.outChangeView.emit([...this.items()]);\n      if (this.heightItem()) {\n        this.heightViewPort.set(this.heightItem());\n      }\n      callBackCalculatorHeightSuccess?.();\n\n      return;\n    }\n\n    const totalHeightByCountItem = lengthItems < this.maxItemShow() ? lengthItems * this.heightItem() : this.maxItemShow() * this.heightItem();\n    const heightByCheckboxAll = this.config()?.configTemplateGroup?.()?.configCheckboxCheckAll ? 27 : 0;\n    const heightConfigButtonSelectAndUndSelectItem = this.config()?.configTemplateGroup?.()?.configButtonSelectAndUndSelectItem ? 27 : 0;\n    const heightViewPort = this.getHeightGroupHasLine() + totalHeightByCountItem + heightByCheckboxAll + heightConfigButtonSelectAndUndSelectItem;\n\n    if (!this.maxItemShow()) {\n      this.heightViewPort.set(0);\n    }\n    if (this.heightItem() >= (this.config()?.minHeightItem ?? 13)) {\n      if (heightViewPort && heightViewPort !== this.heightViewPort()) {\n        this.heightViewPort.set(heightViewPort);\n      }\n      this.outChangeView.emit([...this.items()]);\n      callBackCalculatorHeightSuccess?.();\n\n      return;\n    }\n    this.intervalSetHeightViewPortSubscription?.unsubscribe();\n    this.intervalSetHeightViewPortSubscription = interval(this.timeIntervalIntervalSetHeightViewPort()).pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      if (!this.itemRef() || !this.itemRef()?.nativeElement) {\n        return;\n      }\n      this.heightItem.set(this.itemRef()?.nativeElement.getBoundingClientRect().height);\n\n      if (this.heightItem() < (this.config()?.minHeightItem || 13)) {\n        return;\n      }\n      this.intervalSetHeightViewPortSubscription?.unsubscribe();\n      this.setHeightViewPort(callBackCalculatorHeightSuccess);\n    });\n  }\n\n  protected setHiddenItemByKey(keys: Array<unknown>) {\n    this.keysHiddenItem.set(keys);\n    if (this.store() && this.store().length) {\n      this.processData(false);\n    }\n  }\n\n  protected checkViewPortScroll(callBack?: (pre: boolean, current: boolean) => void) {\n    const pre = this.hasScroll();\n\n    this.intervalCheckScrollSubscription?.unsubscribe();\n    this.intervalCheckScrollSubscription = interval(this.timeIntervalCheckScroll()).pipe(take(5)).subscribe(() => {\n      this.hasScroll.set(false);\n      if (this.items() && !this.items().length && pre && !this.hasScroll()) {\n        callBack?.(pre, this.hasScroll());\n        this.intervalCheckScrollSubscription?.unsubscribe();\n      }\n      callBack?.(pre, this.hasScroll());\n      this.intervalCheckScrollSubscription?.unsubscribe();\n    });\n  }\n\n  protected async callApiByService(firstCall = true) {\n    const config = this.config();\n\n    if (!config) {\n      return;\n    }\n    try {\n      const { httpRequestData, ignoreShowDataWhenNotSearch } = config;\n\n      if (!httpRequestData?.() || (ignoreShowDataWhenNotSearch && !this.keySearch())) {\n        this.loading.set(false);\n        this.outLoading.emit(this.loading());\n        this.loadedLastItem.set(true);\n        if (ignoreShowDataWhenNotSearch && !this.keySearch()) {\n          this.items.set([]);\n          this.store.set([]);\n          this.processData(true);\n        }\n\n        return;\n      }\n      this.loading.set(true);\n      this.outLoading.emit(this.loading());\n      const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestData();\n\n      if (firstCall) {\n        const loadedLastItem = this.httpRequestService.updateArguments(argumentsValue, { ...this.fakeResponseApi(), dropdownTabKeyActive: this.dropdownTabKeyActive() }, this.pagingStore() || {}, this.keySearch(), this.isSearchOnline(), this.loadedLastItem(), guideAutoUpdateArgumentsValue);\n        this.loadedLastItem.set(loadedLastItem);\n      }\n      const result = await this.httpRequestService.callApi(httpRequestData());\n\n      this.pagingStore.set(result.paging);\n      if (!this.pagingStore()) {\n        this.loadedLastItem.set(true);\n      }\n      const loadedLastItem = this.httpRequestService.updateArguments(argumentsValue, { ...result, dropdownTabKeyActive: this.dropdownTabKeyActive() }, this.pagingStore() || {}, this.keySearch(), this.isSearchOnline(), this.loadedLastItem(), guideAutoUpdateArgumentsValue);\n\n      this.loadedLastItem.set(loadedLastItem);\n\n      if (firstCall) {\n        this.store.set(convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(result.data || [])());\n\n        if (this.functionGetItemsAutoAddList()) {\n          const newItems = convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(this.functionGetItemsAutoAddList()?.() || []);\n\n          this.store.update(items => [...newItems(), ...items]);\n        }\n        this.processData(true);\n\n        return;\n      }\n      this.store.update(items => [...items, ...convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(result.data || [])()]);\n      this.processData(false);\n    } catch (error) {\n      this.loading.set(false);\n      this.outLoading.emit(this.loading());\n      console.log(error);\n    }\n  }\n\n  protected fakeResponseApi(): Record<string, any> {\n    this.loadedLastItem.set(false);\n    this.pagingStore.set({});\n\n    return this.httpRequestService.fakeResponsePagingApi();\n  }\n\n  protected buildValueByConfig(item: WritableSignal<any>, configTemplate?: IListConfigItemText | IListConfigItemRadio | IListConfigItemCheckbox): string {\n    const ref = item().ref || {};\n    const label: unknown = ref.label ?? ref.title ?? ref.value ?? ref.name;\n\n    if (!isNil(label) && typeof label !== 'object') {\n      item.update(currentItem => {\n        return { ...currentItem, fieldLabel: typeof label === 'string' ? this.translateService.instant(label) : `${label}` };\n      });\n    }\n\n    if (configTemplate?.getValue) {\n      const value = configTemplate.getValue(ref, item);\n      const label = typeof value === 'number' ? `${value}` : (value ? this.translateService.instant(`${value}`) : '');\n\n      item.update(currentItem => {\n        return { ...currentItem, fieldLabel: label };\n      });\n    }\n    if (configTemplate?.getPopover) {\n      item.update(currentItem => {\n        return { ...currentItem, popoverLabel: configTemplate?.getPopover?.(item()) };\n      });\n    }\n\n    if (!configTemplate?.rows?.()) {\n      return item().fieldLabel || ' ';\n    }\n    let textSearch = item().fieldLabel || ' ';\n\n    const rows = convertSignalToObject(configTemplate.rows()) as Array<any>;\n\n    rows.forEach((row, indexRow) => {\n      const fieldNameRow = `fieldLabelRow${indexRow}`;\n\n      const currentItem = cloneDeep(item());\n      const newItem = { ...currentItem };\n      newItem[fieldNameRow] = row.getValue && row.getValue(ref, item);\n      newItem[`fieldRowStylesDynamicCols${indexRow}`] = row.getRowStylesDynamicCols && row.getRowStylesDynamicCols(ref);\n      newItem[`fieldRowAvatarConfig${indexRow}`] = row.getAvatarConfig && row.getAvatarConfig(ref);\n      if (row.cols && row.cols.length) {\n        row.cols.forEach(async (col: IListConfigItemTextCol, indexCol: number) => {\n          const fieldNameCol = `fieldLabelCol${indexRow}${indexCol}`;\n\n          newItem[fieldNameCol] = col.getValue;\n          newItem[`fieldColClass${indexRow}${indexCol}`] = col.getClassCol && col.getClassCol(ref, indexCol);\n          newItem[`fieldColPopover${indexRow}${indexCol}`] = col.getPopover && col.getPopover(ref, indexCol);\n          newItem[`fieldBadge${indexRow}${indexCol}`] = col.getConfigBadge && col.getConfigBadge(ref, indexCol);\n          newItem[`fieldColStylesDynamic${indexRow}${indexCol}`] = col.getStylesDynamicCol;\n          newItem[`fieldColButton${indexRow}${indexCol}`] = col.getButton && col.getButton(ref, indexCol);\n          newItem[`fieldColSwitch${indexRow}${indexCol}`] = col.getLabelSwitch && col.getLabelSwitch(ref, indexCol);\n          newItem[`fieldColAvatarConfig${indexRow}${indexCol}`] = col.getAvatarConfig && col.getAvatarConfig(ref);\n\n          textSearch = ` ${textSearch} ${newItem[fieldNameCol] || ''} `;\n        });\n      }\n\n      item.update(() => newItem);\n      textSearch = ` ${textSearch} ${item()[fieldNameRow] || ''} `;\n    });\n\n    return textSearch || ' ';\n  }\n\n  protected handlerChangStageFlagMouse(flag: IFlagMouse) {\n    this.outChangStageFlagMousePopover.emit(flag);\n  }\n\n  protected abstract processData(isReplace?: boolean): any;\n  protected abstract processSearch(): any;\n  protected abstract getLengthItem(): number;\n  protected getHeightGroupHasLine(): number {\n    return 0;\n  }\n\n  ngOnDestroy() {\n    clearTimeout(this.timeAutoScrollItemSelected());\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}"]}
340
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"templates.component.abstract.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/list/src/templates/templates.component.abstract.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @angular-eslint/use-lifecycle-interface */\nimport { Directive, ElementRef, inject, input, model, OnDestroy, output, signal, TemplateRef, viewChild, WritableSignal } from \"@angular/core\";\nimport { ISort } from \"@libs-ui/components-buttons-sort\";\nimport { IInputSearchConfig } from \"@libs-ui/components-inputs-search\";\nimport { IFlagMouse } from \"@libs-ui/components-popover\";\nimport { IPaging, TYPE_TEMPLATE_REF } from \"@libs-ui/interfaces-types\";\nimport { LibsUiHttpRequestService } from \"@libs-ui/services-http-request\";\nimport { cloneDeep, convertObjectToSignal, convertSignalToObject, isNil } from \"@libs-ui/utils\";\nimport { TranslateService } from '@ngx-translate/core';\nimport { interval, Subject, Subscription } from 'rxjs';\nimport { skipWhile, take, takeUntil } from 'rxjs/operators';\nimport { getFieldKeyByType } from \"../defines/list.define\";\nimport { IDataUpdateToStore, IListDataEmitKey, IListDataEmitMultiKey } from \"../interfaces\";\nimport { IListConfigItem, IListConfigItemCheckbox, IListConfigItemRadio, IListConfigItemText, IListConfigItemTextCol } from \"../interfaces/config-item.interface\";\n\n@Directive()\nexport abstract class LibsUiComponentsListTemplatesComponentAbstract implements OnDestroy {\n  // #region PROPERTY\n  protected timeAnimationScrollToIndexItem = signal<number>(250);\n  protected loading = signal<boolean>(true);\n  protected heightViewPort = signal<number>(0);\n  protected store = signal<Array<WritableSignal<any>>>([]);\n  protected items = signal<Array<WritableSignal<any>>>([]);\n  protected loadedLastItem = signal<boolean>(false);\n  protected hasScroll = signal<boolean>(false);\n  protected fieldKeyDefault = signal<string>('id');\n  protected fieldKey = signal<string>('id');\n  protected timeAutoScrollItemSelected = signal<number>(0);\n  protected pagingStore = signal<IPaging | undefined>(undefined);\n  protected heightItem = signal<number>(0);\n  protected timeIntervalIntervalSetHeightViewPort = signal<number>(0);\n  protected timeIntervalCheckScroll = signal<number>(250);\n\n  protected onDestroy: Subject<void> = new Subject();\n  protected intervalSetHeightViewPortSubscription!: Subscription;\n  protected intervalCheckScrollSubscription!: Subscription;\n\n  // #region INPUT\n  readonly functionGetItemsAutoAddList = input<(() => Array<any>)>();\n  readonly paddingLeftItem = input<boolean>();\n  readonly maxItemShow = input<number>(0);\n  readonly searchConfig = input<IInputSearchConfig>();\n  readonly config = input<IListConfigItem>();\n  readonly keySearch = model<string>('');\n  readonly dropdownTabKeyActive = input<string>();\n  readonly isSearchOnline = input<boolean>(false);\n\n  readonly onSearch = input<Subject<string>>();\n  readonly onRefresh = input<Subject<void>>();\n  readonly onSetHiddenItemByKey = input<Subject<Array<unknown>>>();\n  readonly onRemoveItems = input<Subject<Array<unknown>>>();\n  readonly onSetDataStore = input<Subject<Array<any>>>();\n  readonly onUpdateMultiKeySelectedGroup = input<Subject<void>>();\n  readonly onUpdateData = input<Subject<IDataUpdateToStore>>();\n  readonly clickExactly = input<boolean>();\n  readonly keySelected = model<unknown>(); // sử dụng cho type radio,text.\n  readonly multiKeySelected = model<Array<unknown>>([]); // sử dụng cho type cho phép chọn nhiều.\n  readonly keysDisableItem = input<Array<unknown>>();\n  readonly keysHiddenItem = model<Array<unknown>>();\n  readonly disable = input<boolean>();\n  readonly disableLabel = input<boolean>();\n  readonly zIndex = input<number>(1200);\n  readonly loadingIconSize = input<'large' | 'medium' | 'small' | 'smaller'>();\n  readonly resetKeyWhenSelectAllKeyDropdown = input<boolean>();\n  readonly ignoreClassDisableDefaultWhenUseKeysDisableItem = input<boolean>(); // bỏ chế độ disable item trên html để disable từng phần trong rows\n  readonly templateRefSearchNoData = input<TemplateRef<TYPE_TEMPLATE_REF>>();\n  readonly autoSelectedFirstItemCallOutsideBefore = input<boolean>(false);\n\n  // #region OUTPUT\n  readonly outSortSingleSelect = output<ISort>();\n  readonly outSelectKey = output<IListDataEmitKey | undefined>(); // sử dụng cho type radio,text.\n  readonly outSelectMultiKey = output<IListDataEmitMultiKey>(); // sử dụng cho type cho phép chọn nhiều.\n  readonly outUnSelectMultiKey = output<Array<unknown>>(); // sử dụng cho type cho phép chọn nhiều.\n  readonly outFieldKey = output<string | undefined>();\n  readonly outChangeView = output<Array<any>>();\n  readonly outLoading = output<boolean>();\n  readonly outChangStageFlagMousePopover = output<IFlagMouse>();\n  readonly outLoadItemsComplete = output<{ items: Array<any>, paging?: IPaging }>();\n\n  /* VIEW CHILD */\n  protected itemRef = viewChild<ElementRef>('itemRef');\n  protected elementScroll = viewChild<ElementRef>('elementScroll');\n\n  // #region INJECT\n  protected translateService = inject(TranslateService);\n  protected httpRequestService = inject(LibsUiHttpRequestService);\n\n  constructor() {\n    this.outLoading.emit(this.loading());\n  }\n\n  ngOnInit() {\n    this.onSearch()?.pipe(takeUntil(this.onDestroy)).subscribe((keySearch: string) => {\n      this.keySearch.set(keySearch ?? '');\n      this.processSearch();\n    });\n    this.onRefresh()?.pipe(skipWhile(() => this.loading()), takeUntil(this.onDestroy)).subscribe(() => {\n      if (this.dropdownTabKeyActive()) {\n        this.items.set([]);\n        this.store.set([]);\n      }\n      this.callApiByService(true);\n    });\n    this.onSetHiddenItemByKey()?.pipe(takeUntil(this.onDestroy)).subscribe(this.setHiddenItemByKey.bind(this));\n    this.outFieldKey.emit(getFieldKeyByType(this.config(), this.fieldKeyDefault()));\n    this.onRemoveItems()?.pipe(takeUntil(this.onDestroy)).subscribe(this.removeItems.bind(this));\n    this.onUpdateData()?.pipe(takeUntil(this.onDestroy)).subscribe(this.updateData.bind(this));\n  }\n\n  /* FUNCTIONS */\n  private updateData(data: IDataUpdateToStore) {\n    if (!data) {\n      return;\n    }\n    const { newData, functionCustomAddDataToStore } = data;\n    if (!newData() || !newData().length) {\n      return;\n    }\n    if (this.config()?.type === 'checkbox') {\n      newData().forEach(item => item.update(value => ({ ...value, isAddNew: true })));\n    }\n    functionCustomAddDataToStore(newData, this.store);\n    this.processData();\n  }\n\n  private getFieldKey() {\n    let fieldKey: string | undefined;\n\n    const config = this.config();\n\n    if (!config) {\n      return 'id';\n    }\n\n    switch (config.type) {\n      case 'group':\n        fieldKey = config.configTemplateGroup?.()?.fieldKey;\n        break;\n\n      case 'tag':\n        fieldKey = config.configTemplateTag?.()?.fieldKey;\n        break;\n\n      case 'text':\n        fieldKey = config.configTemplateText?.()?.fieldKey;\n        break;\n\n      case 'checkbox':\n        fieldKey = config.configTemplateCheckbox?.()?.fieldKey;\n        break;\n\n      case 'radio':\n        fieldKey = config.configTemplateRadio?.()?.fieldKey;\n        break;\n    }\n\n    return fieldKey || 'id';\n  }\n\n  private removeItems(keys: Array<unknown>) {\n    const fieldKey = this.getFieldKey();\n\n    [this.store(), this.items()].forEach(element => {\n      if (this.config()?.type === 'group') {\n        element.forEach(item => {\n          this.removeItem(item()[this.config()?.configTemplateGroup?.()?.fieldGetItems || 'items'](), keys, fieldKey);\n        });\n\n        return;\n      }\n      this.removeItem(element, keys, fieldKey);\n    });\n    this.processData();\n  }\n\n  private removeItem(data: Array<WritableSignal<any>>, keys: Array<unknown>, fieldKey: string) {\n    if (!data || !data.length) {\n      return;\n    }\n    keys.forEach(key => {\n      const index = data.findIndex(item => item()[fieldKey] === key);\n\n      if (index > -1) {\n        data.splice(index, 1);\n      }\n    });\n  }\n\n  protected setHeightViewPort(callBackCalculatorHeightSuccess?: () => void) {\n    const lengthItems = this.getLengthItem();\n    this.heightItem.update(val => this.config()?.heightItem || val);\n\n    if (!lengthItems) {\n      this.outChangeView.emit([...this.items()]);\n      if (this.heightItem()) {\n        this.heightViewPort.set(this.heightItem());\n      }\n      callBackCalculatorHeightSuccess?.();\n\n      return;\n    }\n\n    const totalHeightByCountItem = lengthItems < this.maxItemShow() ? lengthItems * this.heightItem() : this.maxItemShow() * this.heightItem();\n    const heightByCheckboxAll = this.config()?.configTemplateGroup?.()?.configCheckboxCheckAll ? 27 : 0;\n    const heightConfigButtonSelectAndUndSelectItem = this.config()?.configTemplateGroup?.()?.configButtonSelectAndUndSelectItem ? 27 : 0;\n    const heightViewPort = this.getHeightGroupHasLine() + totalHeightByCountItem + heightByCheckboxAll + heightConfigButtonSelectAndUndSelectItem;\n\n    if (!this.maxItemShow()) {\n      this.heightViewPort.set(0);\n    }\n    if (this.heightItem() >= (this.config()?.minHeightItem ?? 13)) {\n      if (heightViewPort && heightViewPort !== this.heightViewPort()) {\n        this.heightViewPort.set(heightViewPort);\n      }\n      this.outChangeView.emit([...this.items()]);\n      callBackCalculatorHeightSuccess?.();\n\n      return;\n    }\n    this.intervalSetHeightViewPortSubscription?.unsubscribe();\n    this.intervalSetHeightViewPortSubscription = interval(this.timeIntervalIntervalSetHeightViewPort()).pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      if (!this.itemRef() || !this.itemRef()?.nativeElement) {\n        return;\n      }\n      this.heightItem.set(this.itemRef()?.nativeElement.getBoundingClientRect().height);\n\n      if (this.heightItem() < (this.config()?.minHeightItem || 13)) {\n        return;\n      }\n      this.intervalSetHeightViewPortSubscription?.unsubscribe();\n      this.setHeightViewPort(callBackCalculatorHeightSuccess);\n    });\n  }\n\n  protected setHiddenItemByKey(keys: Array<unknown>) {\n    this.keysHiddenItem.set(keys);\n    if (this.store() && this.store().length) {\n      this.processData(false);\n    }\n  }\n\n  protected checkViewPortScroll(callBack?: (pre: boolean, current: boolean) => void) {\n    const pre = this.hasScroll();\n\n    this.intervalCheckScrollSubscription?.unsubscribe();\n    this.intervalCheckScrollSubscription = interval(this.timeIntervalCheckScroll()).pipe(take(5)).subscribe(() => {\n      this.hasScroll.set(false);\n      if (this.items() && !this.items().length && pre && !this.hasScroll()) {\n        callBack?.(pre, this.hasScroll());\n        this.intervalCheckScrollSubscription?.unsubscribe();\n      }\n      callBack?.(pre, this.hasScroll());\n      this.intervalCheckScrollSubscription?.unsubscribe();\n    });\n  }\n\n  protected async callApiByService(firstCall = true) {\n    const config = this.config();\n\n    if (!config) {\n      return;\n    }\n    try {\n      const { httpRequestData, ignoreShowDataWhenNotSearch } = config;\n\n      if (!httpRequestData?.() || (ignoreShowDataWhenNotSearch && !this.keySearch())) {\n        this.loading.set(false);\n        this.outLoading.emit(this.loading());\n        this.loadedLastItem.set(true);\n        if (ignoreShowDataWhenNotSearch && !this.keySearch()) {\n          this.items.set([]);\n          this.store.set([]);\n          this.processData(true);\n        }\n\n        return;\n      }\n      this.loading.set(true);\n      this.outLoading.emit(this.loading());\n      const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestData();\n\n      if (firstCall) {\n        const loadedLastItem = this.httpRequestService.updateArguments(argumentsValue, { ...this.fakeResponseApi(), dropdownTabKeyActive: this.dropdownTabKeyActive() }, this.pagingStore() || {}, this.keySearch(), this.isSearchOnline(), this.loadedLastItem(), guideAutoUpdateArgumentsValue);\n        this.loadedLastItem.set(loadedLastItem);\n      }\n      const result = await this.httpRequestService.callApi(httpRequestData());\n\n      this.pagingStore.set(result.paging);\n      if (!this.pagingStore()) {\n        this.loadedLastItem.set(true);\n      }\n      const loadedLastItem = this.httpRequestService.updateArguments(argumentsValue, { ...result, dropdownTabKeyActive: this.dropdownTabKeyActive() }, this.pagingStore() || {}, this.keySearch(), this.isSearchOnline(), this.loadedLastItem(), guideAutoUpdateArgumentsValue);\n\n      this.loadedLastItem.set(loadedLastItem);\n\n      if (firstCall) {\n        this.store.set(convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(result.data || [])());\n\n        if (this.functionGetItemsAutoAddList()) {\n          const newItems = convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(this.functionGetItemsAutoAddList()?.() || []);\n\n          this.store.update(items => [...newItems(), ...items]);\n        }\n        this.processData(true);\n\n        return;\n      }\n      this.store.update(items => [...items, ...convertObjectToSignal<WritableSignal<Array<WritableSignal<any>>>>(result.data || [])()]);\n      this.processData(false);\n    } catch (error) {\n      this.loading.set(false);\n      this.outLoading.emit(this.loading());\n      console.log(error);\n    }\n  }\n\n  protected fakeResponseApi(): Record<string, any> {\n    this.loadedLastItem.set(false);\n    this.pagingStore.set({});\n\n    return this.httpRequestService.fakeResponsePagingApi();\n  }\n\n  protected buildValueByConfig(item: WritableSignal<any>, configTemplate?: IListConfigItemText | IListConfigItemRadio | IListConfigItemCheckbox): string {\n    const ref = item().ref || {};\n    const label: unknown = ref.label ?? ref.title ?? ref.value ?? ref.name;\n\n    if (!isNil(label) && typeof label !== 'object') {\n      item.update(currentItem => {\n        return { ...currentItem, fieldLabel: typeof label === 'string' ? this.translateService.instant(label) : `${label}` };\n      });\n    }\n\n    if (configTemplate?.getValue) {\n      const value = configTemplate.getValue(ref, item);\n      const label = typeof value === 'number' ? `${value}` : (value ? this.translateService.instant(`${value}`) : '');\n\n      item.update(currentItem => {\n        return { ...currentItem, fieldLabel: label };\n      });\n    }\n    if (configTemplate?.getPopover) {\n      item.update(currentItem => {\n        return { ...currentItem, popoverLabel: configTemplate?.getPopover?.(item()) };\n      });\n    }\n\n    if (!configTemplate?.rows?.()) {\n      return item().fieldLabel || ' ';\n    }\n    let textSearch = item().fieldLabel || ' ';\n\n    const rows = convertSignalToObject(configTemplate.rows()) as Array<any>;\n\n    rows.forEach((row, indexRow) => {\n      const fieldNameRow = `fieldLabelRow${indexRow}`;\n\n      const currentItem = cloneDeep(item());\n      const newItem = { ...currentItem };\n      newItem[fieldNameRow] = row.getValue && row.getValue(ref, item);\n      newItem[`fieldRowStylesDynamicCols${indexRow}`] = row.getRowStylesDynamicCols && row.getRowStylesDynamicCols(ref);\n      newItem[`fieldRowAvatarConfig${indexRow}`] = row.getAvatarConfig && row.getAvatarConfig(ref);\n      if (row.cols && row.cols.length) {\n        row.cols.forEach(async (col: IListConfigItemTextCol, indexCol: number) => {\n          const fieldNameCol = `fieldLabelCol${indexRow}${indexCol}`;\n\n          newItem[fieldNameCol] = col.getValue;\n          newItem[`fieldColClass${indexRow}${indexCol}`] = col.getClassCol && col.getClassCol(ref, indexCol);\n          newItem[`fieldColPopover${indexRow}${indexCol}`] = col.getPopover && col.getPopover(ref, indexCol);\n          newItem[`fieldBadge${indexRow}${indexCol}`] = col.getConfigBadge && col.getConfigBadge(ref, indexCol);\n          newItem[`fieldColStylesDynamic${indexRow}${indexCol}`] = col.getStylesDynamicCol;\n          newItem[`fieldColButton${indexRow}${indexCol}`] = col.getButton && col.getButton(ref, indexCol);\n          newItem[`fieldColSwitch${indexRow}${indexCol}`] = col.getLabelSwitch && col.getLabelSwitch(ref, indexCol);\n          newItem[`fieldColAvatarConfig${indexRow}${indexCol}`] = col.getAvatarConfig && col.getAvatarConfig(ref);\n\n          textSearch = ` ${textSearch} ${newItem[fieldNameCol] || ''} `;\n        });\n      }\n\n      item.update(() => newItem);\n      textSearch = ` ${textSearch} ${item()[fieldNameRow] || ''} `;\n    });\n\n    return textSearch || ' ';\n  }\n\n  protected handlerChangStageFlagMouse(flag: IFlagMouse) {\n    this.outChangStageFlagMousePopover.emit(flag);\n  }\n\n  protected abstract processData(isReplace?: boolean): any;\n  protected abstract processSearch(): any;\n  protected abstract getLengthItem(): number;\n  protected getHeightGroupHasLine(): number {\n    return 0;\n  }\n\n  ngOnDestroy() {\n    clearTimeout(this.timeAutoScrollItemSelected());\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}"]}
@@ -206,7 +206,7 @@ class LibsUiComponentsListTemplatesComponentAbstract {
206
206
  intervalCheckScrollSubscription;
207
207
  // #region INPUT
208
208
  functionGetItemsAutoAddList = input();
209
- paddingLeftItem = input(undefined);
209
+ paddingLeftItem = input();
210
210
  maxItemShow = input(0);
211
211
  searchConfig = input();
212
212
  config = input();
@@ -231,7 +231,7 @@ class LibsUiComponentsListTemplatesComponentAbstract {
231
231
  loadingIconSize = input();
232
232
  resetKeyWhenSelectAllKeyDropdown = input();
233
233
  ignoreClassDisableDefaultWhenUseKeysDisableItem = input(); // bỏ chế độ disable item trên html để disable từng phần trong rows
234
- templateRefSearchNoData = input(undefined);
234
+ templateRefSearchNoData = input();
235
235
  autoSelectedFirstItemCallOutsideBefore = input(false);
236
236
  // #region OUTPUT
237
237
  outSortSingleSelect = output();
@@ -774,7 +774,7 @@ class LibsUiComponentsListCheckboxComponent extends LibsUiComponentsListTemplate
774
774
  return this.items().length;
775
775
  }
776
776
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsListCheckboxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
777
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsListCheckboxComponent, isStandalone: true, selector: "libs_ui-components-list-templates_checkbox", viewQueries: [{ propertyName: "virtualScrollerComponent", first: true, predicate: VirtualScrollerComponent, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@if (configTemplateCheckbox(); as configTemplateCheckbox) {\n <div class=\"flex flex-col w-full h-full\">\n @if (items().length && configTemplateCheckbox.configButtonSelectAndUndSelectItem?.(); as configButtonSelectItem) {\n <div\n [class]=\"'flex items-center bg-[#ffffff] '+(configButtonSelectItem.classInclude ?? 'libs-ui-border-bottom-general')\">\n <libs_ui-components-buttons-button [type]=\"configButtonSelectItem.buttonCheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonCheckAll?.label ?? 'i18n_select_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonCheckAll?.classInclude || 'pr-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonCheckAll?.classLabel || 'libs-ui-font-h6r'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(true)\" />\n <div class=\"text-[#e6e7ea]\">|</div>\n <libs_ui-components-buttons-button\n [type]=\"configButtonSelectItem.buttonUncheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonUncheckAll?.label ?? 'i18n_unselect_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonUncheckAll?.classInclude || 'pl-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonUncheckAll?.classLabel || 'libs-ui-font-h6r'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(false)\" />\n </div>\n }\n @if (items().length && configTemplateCheckbox.configCheckboxCheckAll?.(); as configCheckBox) {\n <div\n [class]=\"'flex libs-ui-border-bottom-general bg-[#ffffff] pl-[12px] '+(configTemplateCheckbox.classIncludeHasConfigCheckBoxAll ?? 'py-[6px] libs-ui-border-bottom-general')\">\n <libs_ui-components-checkbox-single [label]=\"configCheckBox.label ?? 'i18n_all'\"\n [classLabelInclude]=\"configCheckBox.classLabelInclude || ''\"\n [checked]=\"(multiKeySelected()?.length && (multiKeySelected()?.length ||0) >= (store().length || -1)) || false\"\n [stillOtherOptions]=\"!!multiKeySelected()?.length && (multiKeySelected()?.length ||0) < (store().length || -1)\"\n [disable]=\"loading() || disable() || false\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerSelect($event.checked, true)\" />\n </div>\n }\n <div\n [class]=\"'relative h-full w-full ' +((!items() || !items().length) ? 'bg-[#ffffff]': configTemplateCheckbox.classListInclude || '')\">\n @if (items() && items().length) {\n <div #elementScroll\n LibsUiComponentsScrollOverlayDirective\n class=\"w-full\"\n [class.h-full]=\"!(heightViewPort() && !config()?.ignoreShowDataWhenNotSearch)\"\n [style.height]=\"heightViewPort() && !config()?.ignoreShowDataWhenNotSearch ? heightViewPort()+'px':'100%'\"\n (outScrollBottom)=\"handlerScrollBottom()\">\n <virtual-scroller #scroll\n [parentScroll]=\"elementScroll\"\n [items]=\"items()\"\n class=\"h-full\">\n @for (item of scroll.viewPortItems; track item()[fieldKey()]; let last = $last) {\n <div [class]=\"last ? (configTemplateCheckbox.classIncludeLastViewItem || '') : ''\">\n <div #itemRef\n LibsUiComponentsListHighlightKeySearchDirective\n [isHighlight]=\"config()?.highlightTextSearchInResult\"\n [keySearch]=\"keySearch()\"\n [attr.clickExactly]=\"clickExactly\"\n [class]=\"'libs-ui-list-template-checkbox-item flex ' + (configTemplateCheckbox.classItemInclude || '')\"\n [class.w-full]=\"!configTemplateCheckbox.ignoreItemWidth100\"\n [class.libs-ui-bg-list-hover]=\"!clickExactly()\"\n [class.libs-ui-bg-list-hover-active]=\"!clickExactly()\"\n [class.!pl-[12px]]=\"paddingLeftItem()\"\n [class.!py-[6px]]=\"clickExactly()\"\n [class.!pr-[4px]]=\"hasScroll() && configTemplateCheckbox.rows\"\n [class.!pr-[12px]]=\"!hasScroll() && configTemplateCheckbox.rows\"\n (click)=\"handlerChange($event,item())\">\n <div class=\"flex flex-col w-full\">\n @if (item().fieldLabel) {\n <libs_ui-components-checkbox-single [label]=\"item().fieldLabel\"\n [avatarConfig]=\"(item().avatarConfig|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [linkImage]=\"configTemplateCheckbox.getImage ? (('avatar' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImage:item()) | async) : item()[configTemplateCheckbox.fieldGetImage || '']\"\n [linkImageError]=\"configTemplateCheckbox.getImageError ? (('avatar_error' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImageError:item()) | async) : item()[configTemplateCheckbox.fieldGetLinkImageError || '']\"\n [classLabelInclude]=\"item().classLabelInclude || configTemplateCheckbox.classLabelInclude || 'libs-ui-font-h5r'\"\n [zIndexLabel]=\"configTemplateCheckbox.zIndexPopover ?? 1200\"\n [checked]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [key]=\"item()[fieldKey()]\"\n [imgTypeIcon]=\"configTemplateCheckbox.hasAvatarGroupSocial\"\n [classInclude]=\"configTemplateCheckbox.classInclude || ''\"\n [classImageInclude]=\"configTemplateCheckbox.classIncludeImage || ''\"\n [bullet]=\"(item().bullet|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [disable]=\"loading() || disable() || (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:keysDisableItem():keysDisableItem()?.length)\"\n [popover]=\"(item().popoverLabel|LibsUiPipesConvertObjectToSignalPipe)?.() | LibsUiPipesConvertSignalToObjectPipe\"\n [clickExactly]=\"clickExactly()\"\n [dataComponentOutlet]=\"(undefined | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getDataComponentOutlet:item():fieldKey():{valueIsEmpty:{item:item()}}) | async\"\n [componentOutlet]=\"(0 | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getComponentOutlet:item():fieldKey():{valueIs0:0}) | async\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerChange('checkbox',item())\" />\n }\n @if (configTemplateCheckbox?.rows) {\n <libs_ui-components-list-templates_rows\n class=\"{{ !configTemplateCheckbox.ignoreItemWidth100 ? 'w-full' : '' }} {{ configTemplateCheckbox.classRowsWrapper || configTemplateCheckbox.classRows ?? '' }}\"\n [item]=\"item()\"\n [zIndex]=\"zIndex()\"\n [fieldKey]=\"fieldKey()\"\n [keySelected]=\"(item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) ? item()[fieldKey()] : undefined\"\n [configTemplate]=\"configTemplateCheckbox\"\n (outEvent)=\"handlerChange('checkbox',$event.item)\" />\n }\n </div>\n </div>\n </div>\n }\n </virtual-scroller>\n </div>\n }\n @if ((!items() || !items().length) && (!config()?.ignoreShowDataWhenNotSearch || keySearch())) {\n <div [class]=\"'libs-ui-font-h5r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px] px-[12px]')\">\n @if (config()?.hasIconNoData && !loading()) {\n <div class=\"mb-[16px]\">\n <div\n *ngComponentOutlet=\"(keySearch() ? 'no-result' : 'no-data') | LibsUiIconsGetIconComponentPipe | async\">\n </div>\n </div>\n }\n @if (!keySearch() && !loading()) {\n <span>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</span>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <span>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</span>\n }\n @if (loading()) {\n <span>&nbsp;</span>\n }\n\n </div>\n }\n @if (loading()) {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n </div>\n}\n", styles: [".libs-ui-list-template-checkbox-item{padding:6px 0 6px 16px;margin-right:8px;font-size:12px;line-height:18px;position:relative}\n"], dependencies: [{ kind: "ngmodule", type: VirtualScrollerModule }, { kind: "component", type: i1$1.VirtualScrollerComponent, selector: "virtual-scroller,[virtualScroller]", inputs: ["executeRefreshOutsideAngularZone", "enableUnequalChildrenSizes", "RTL", "useMarginInsteadOfTranslate", "modifyOverflowStyleOfParentScroll", "stripedTable", "scrollbarWidth", "scrollbarHeight", "childWidth", "childHeight", "ssrChildWidth", "ssrChildHeight", "ssrViewportWidth", "ssrViewportHeight", "bufferAmount", "scrollAnimationTime", "resizeBypassRefreshThreshold", "scrollThrottlingTime", "scrollDebounceTime", "checkResizeInterval", "items", "compareItems", "horizontal", "parentScroll"], outputs: ["vsUpdate", "vsChange", "vsStart", "vsEnd"], exportAs: ["virtualScroller"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsCheckboxSingleComponent, selector: "libs_ui-components-checkbox-single", inputs: ["key", "checked", "label", "classLabelInclude", "ignoreShowPopoverLabel", "typeLabelPopover", "popover", "linkImage", "linkImageError", "avatarConfig", "classImageInclude", "imgTypeIcon", "bullet", "classInclude", "clickExactly", "disable", "disableLabel", "ignoreCheckbox", "zIndexLabel", "stillOtherOptions", "error", "showBorderError", "description", "iconImageClass", "classIconInclude", "modeBorder", "dataComponentOutlet", "componentOutlet"], outputs: ["checkedChange", "linkImageChange", "outChange", "outEventPopover", "outClickLabel", "outChangStageFlagMousePopover"] }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }, { kind: "pipe", type: LibsUiCheckSelectedByKeyPipe, name: "LibsUiCheckSelectedByKeyPipe" }, { kind: "pipe", type: LibsUiIconsGetIconComponentPipe, name: "LibsUiIconsGetIconComponentPipe" }, { kind: "directive", type: LibsUiComponentsListHighlightKeySearchDirective, selector: "[LibsUiComponentsListHighlightKeySearchDirective]", inputs: ["isHighlight", "keySearch", "classHighlight"] }, { kind: "component", type: LibsUiComponentsListRowsComponent, selector: "libs_ui-components-list-templates_rows", inputs: ["configTemplate", "item", "keySelected", "fieldKey", "zIndex"], outputs: ["outChangStageFlagMousePopover", "outEvent"] }, { kind: "pipe", type: LibsUiPipesCallFunctionInTemplatePipe, name: "LibsUiPipesCallFunctionInTemplatePipe" }, { kind: "pipe", type: LibsUiPipesConvertObjectToSignalPipe, name: "LibsUiPipesConvertObjectToSignalPipe" }, { kind: "pipe", type: LibsUiPipesConvertSignalToObjectPipe, name: "LibsUiPipesConvertSignalToObjectPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
777
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsListCheckboxComponent, isStandalone: true, selector: "libs_ui-components-list-templates_checkbox", viewQueries: [{ propertyName: "virtualScrollerComponent", first: true, predicate: VirtualScrollerComponent, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@if (configTemplateCheckbox(); as configTemplateCheckbox) {\n <div class=\"flex flex-col w-full h-full\">\n @if (items().length && configTemplateCheckbox.configButtonSelectAndUndSelectItem?.(); as configButtonSelectItem) {\n <div\n [class]=\"'flex items-center bg-[#ffffff] '+(configButtonSelectItem.classInclude ?? 'libs-ui-border-bottom-general')\">\n <libs_ui-components-buttons-button [type]=\"configButtonSelectItem.buttonCheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonCheckAll?.label ?? 'i18n_select_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonCheckAll?.classInclude || 'pr-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonCheckAll?.classLabel || 'libs-ui-font-h6ri'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(true)\" />\n <div class=\"text-[#e6e7ea]\">|</div>\n <libs_ui-components-buttons-button\n [type]=\"configButtonSelectItem.buttonUncheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonUncheckAll?.label ?? 'i18n_unselect_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonUncheckAll?.classInclude || 'pl-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonUncheckAll?.classLabel || 'libs-ui-font-h6ri'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(false)\" />\n </div>\n }\n @if (items().length && configTemplateCheckbox.configCheckboxCheckAll?.(); as configCheckBox) {\n @let lengthMultiKeySelected = multiKeySelected()?.length || 0;\n @let lengthStore = store().length || -1;\n <div\n [class]=\"'flex libs-ui-border-bottom-general bg-[#ffffff] pl-[12px] '+(configTemplateCheckbox.classIncludeHasConfigCheckBoxAll ?? 'py-[6px] libs-ui-border-bottom-general')\">\n <libs_ui-components-checkbox-single [label]=\"configCheckBox.label ?? 'i18n_all'\"\n [classLabelInclude]=\"configCheckBox.classLabelInclude || ''\"\n [checked]=\"(lengthMultiKeySelected && lengthMultiKeySelected >= lengthStore) || false\"\n [stillOtherOptions]=\"!!lengthMultiKeySelected && lengthMultiKeySelected < lengthStore\"\n [disable]=\"loading() || disable() || false\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerSelect($event.checked, true)\" />\n </div>\n }\n <div\n [class]=\"'relative h-full w-full ' +((!items() || !items().length) ? 'bg-[#ffffff]': configTemplateCheckbox.classListInclude || '')\">\n @if (items() && items().length) {\n <div #elementScroll\n LibsUiComponentsScrollOverlayDirective\n class=\"w-full\"\n [class.h-full]=\"!(heightViewPort() && !config()?.ignoreShowDataWhenNotSearch)\"\n [style.height]=\"heightViewPort() && !config()?.ignoreShowDataWhenNotSearch ? heightViewPort()+'px':'100%'\"\n (outScrollBottom)=\"handlerScrollBottom()\">\n <virtual-scroller #scroll\n [parentScroll]=\"elementScroll\"\n [items]=\"items()\"\n class=\"h-full\">\n @for (item of scroll.viewPortItems; track item()[fieldKey()]; let last = $last) {\n <div [class]=\"last ? (configTemplateCheckbox.classIncludeLastViewItem || '') : ''\">\n <div #itemRef\n LibsUiComponentsListHighlightKeySearchDirective\n [isHighlight]=\"config()?.highlightTextSearchInResult\"\n [keySearch]=\"keySearch()\"\n [attr.clickExactly]=\"clickExactly()\"\n [class]=\"'libs-ui-list-template-checkbox-item libs-ui-font-h5r flex ' + (configTemplateCheckbox.classItemInclude || '')\"\n [class.w-full]=\"!configTemplateCheckbox.ignoreItemWidth100\"\n [class.libs-ui-bg-list-hover]=\"!clickExactly()\"\n [class.libs-ui-bg-list-hover-active]=\"!clickExactly()\"\n [class.!pl-[12px]]=\"paddingLeftItem()\"\n [class.!py-[6px]]=\"clickExactly()\"\n [class.!pr-[4px]]=\"hasScroll() && configTemplateCheckbox.rows\"\n [class.!pr-[12px]]=\"!hasScroll() && configTemplateCheckbox.rows\"\n (click)=\"handlerChange($event,item())\">\n <div class=\"flex flex-col w-full\">\n @if (item().fieldLabel) {\n <libs_ui-components-checkbox-single [label]=\"item().fieldLabel\"\n [avatarConfig]=\"(item().avatarConfig|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [linkImage]=\"configTemplateCheckbox.getImage ? (('avatar' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImage:item()) | async) : item()[configTemplateCheckbox.fieldGetImage || '']\"\n [linkImageError]=\"configTemplateCheckbox.getImageError ? (('avatar_error' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImageError:item()) | async) : item()[configTemplateCheckbox.fieldGetLinkImageError || '']\"\n [classLabelInclude]=\"item().classLabelInclude || configTemplateCheckbox.classLabelInclude || 'libs-ui-font-h5r'\"\n [zIndexLabel]=\"configTemplateCheckbox.zIndexPopover ?? 1200\"\n [checked]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [key]=\"item()[fieldKey()]\"\n [imgTypeIcon]=\"configTemplateCheckbox.hasAvatarGroupSocial\"\n [classInclude]=\"configTemplateCheckbox.classInclude || ''\"\n [classImageInclude]=\"configTemplateCheckbox.classIncludeImage || ''\"\n [bullet]=\"(item().bullet|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [disable]=\"loading() || disable() || (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:keysDisableItem():keysDisableItem()?.length)\"\n [popover]=\"(item().popoverLabel|LibsUiPipesConvertObjectToSignalPipe)?.() | LibsUiPipesConvertSignalToObjectPipe\"\n [clickExactly]=\"clickExactly()\"\n [dataComponentOutlet]=\"(undefined | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getDataComponentOutlet:item():fieldKey():{valueIsEmpty:{item:item()}}) | async\"\n [componentOutlet]=\"(0 | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getComponentOutlet:item():fieldKey():{valueIs0:0}) | async\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerChange('checkbox',item())\" />\n }\n @if (configTemplateCheckbox?.rows) {\n <libs_ui-components-list-templates_rows\n class=\"{{ !configTemplateCheckbox.ignoreItemWidth100 ? 'w-full' : '' }} {{ (configTemplateCheckbox.classRowsWrapper || configTemplateCheckbox.classRows) ?? '' }}\"\n [item]=\"item()\"\n [zIndex]=\"zIndex()\"\n [fieldKey]=\"fieldKey()\"\n [keySelected]=\"(item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) ? item()[fieldKey()] : undefined\"\n [configTemplate]=\"configTemplateCheckbox\"\n (outEvent)=\"handlerChange('checkbox',$event.item)\" />\n }\n </div>\n </div>\n </div>\n }\n </virtual-scroller>\n </div>\n }\n @if ((!items() || !items().length) && (!config()?.ignoreShowDataWhenNotSearch || keySearch())) {\n <div [class]=\"'libs-ui-font-h5r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px] px-[12px]')\">\n @if (config()?.hasIconNoData && !loading()) {\n <div class=\"mb-[16px]\">\n <div\n *ngComponentOutlet=\"(keySearch() ? 'no-result' : 'no-data') | LibsUiIconsGetIconComponentPipe | async\">\n </div>\n </div>\n }\n @if (!keySearch() && !loading()) {\n <span>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</span>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <span>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</span>\n }\n @if (loading()) {\n <span>&nbsp;</span>\n }\n\n </div>\n }\n @if (loading()) {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n </div>\n}\n", styles: [".libs-ui-list-template-checkbox-item{padding:6px 16px;font-size:12px;line-height:18px;position:relative}\n"], dependencies: [{ kind: "ngmodule", type: VirtualScrollerModule }, { kind: "component", type: i1$1.VirtualScrollerComponent, selector: "virtual-scroller,[virtualScroller]", inputs: ["executeRefreshOutsideAngularZone", "enableUnequalChildrenSizes", "RTL", "useMarginInsteadOfTranslate", "modifyOverflowStyleOfParentScroll", "stripedTable", "scrollbarWidth", "scrollbarHeight", "childWidth", "childHeight", "ssrChildWidth", "ssrChildHeight", "ssrViewportWidth", "ssrViewportHeight", "bufferAmount", "scrollAnimationTime", "resizeBypassRefreshThreshold", "scrollThrottlingTime", "scrollDebounceTime", "checkResizeInterval", "items", "compareItems", "horizontal", "parentScroll"], outputs: ["vsUpdate", "vsChange", "vsStart", "vsEnd"], exportAs: ["virtualScroller"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsCheckboxSingleComponent, selector: "libs_ui-components-checkbox-single", inputs: ["key", "checked", "label", "classLabelInclude", "ignoreShowPopoverLabel", "typeLabelPopover", "popover", "linkImage", "linkImageError", "avatarConfig", "classImageInclude", "imgTypeIcon", "bullet", "classInclude", "clickExactly", "disable", "disableLabel", "ignoreCheckbox", "zIndexLabel", "stillOtherOptions", "error", "showBorderError", "description", "iconImageClass", "classIconInclude", "modeBorder", "dataComponentOutlet", "componentOutlet"], outputs: ["checkedChange", "linkImageChange", "outChange", "outEventPopover", "outClickLabel", "outChangStageFlagMousePopover"] }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }, { kind: "pipe", type: LibsUiCheckSelectedByKeyPipe, name: "LibsUiCheckSelectedByKeyPipe" }, { kind: "pipe", type: LibsUiIconsGetIconComponentPipe, name: "LibsUiIconsGetIconComponentPipe" }, { kind: "directive", type: LibsUiComponentsListHighlightKeySearchDirective, selector: "[LibsUiComponentsListHighlightKeySearchDirective]", inputs: ["isHighlight", "keySearch", "classHighlight"] }, { kind: "component", type: LibsUiComponentsListRowsComponent, selector: "libs_ui-components-list-templates_rows", inputs: ["configTemplate", "item", "keySelected", "fieldKey", "zIndex"], outputs: ["outChangStageFlagMousePopover", "outEvent"] }, { kind: "pipe", type: LibsUiPipesCallFunctionInTemplatePipe, name: "LibsUiPipesCallFunctionInTemplatePipe" }, { kind: "pipe", type: LibsUiPipesConvertObjectToSignalPipe, name: "LibsUiPipesConvertObjectToSignalPipe" }, { kind: "pipe", type: LibsUiPipesConvertSignalToObjectPipe, name: "LibsUiPipesConvertSignalToObjectPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
778
778
  }
779
779
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsListCheckboxComponent, decorators: [{
780
780
  type: Component,
@@ -791,7 +791,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
791
791
  LibsUiPipesCallFunctionInTemplatePipe,
792
792
  LibsUiPipesConvertObjectToSignalPipe,
793
793
  LibsUiPipesConvertSignalToObjectPipe
794
- ], template: "@if (configTemplateCheckbox(); as configTemplateCheckbox) {\n <div class=\"flex flex-col w-full h-full\">\n @if (items().length && configTemplateCheckbox.configButtonSelectAndUndSelectItem?.(); as configButtonSelectItem) {\n <div\n [class]=\"'flex items-center bg-[#ffffff] '+(configButtonSelectItem.classInclude ?? 'libs-ui-border-bottom-general')\">\n <libs_ui-components-buttons-button [type]=\"configButtonSelectItem.buttonCheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonCheckAll?.label ?? 'i18n_select_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonCheckAll?.classInclude || 'pr-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonCheckAll?.classLabel || 'libs-ui-font-h6r'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(true)\" />\n <div class=\"text-[#e6e7ea]\">|</div>\n <libs_ui-components-buttons-button\n [type]=\"configButtonSelectItem.buttonUncheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonUncheckAll?.label ?? 'i18n_unselect_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonUncheckAll?.classInclude || 'pl-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonUncheckAll?.classLabel || 'libs-ui-font-h6r'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(false)\" />\n </div>\n }\n @if (items().length && configTemplateCheckbox.configCheckboxCheckAll?.(); as configCheckBox) {\n <div\n [class]=\"'flex libs-ui-border-bottom-general bg-[#ffffff] pl-[12px] '+(configTemplateCheckbox.classIncludeHasConfigCheckBoxAll ?? 'py-[6px] libs-ui-border-bottom-general')\">\n <libs_ui-components-checkbox-single [label]=\"configCheckBox.label ?? 'i18n_all'\"\n [classLabelInclude]=\"configCheckBox.classLabelInclude || ''\"\n [checked]=\"(multiKeySelected()?.length && (multiKeySelected()?.length ||0) >= (store().length || -1)) || false\"\n [stillOtherOptions]=\"!!multiKeySelected()?.length && (multiKeySelected()?.length ||0) < (store().length || -1)\"\n [disable]=\"loading() || disable() || false\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerSelect($event.checked, true)\" />\n </div>\n }\n <div\n [class]=\"'relative h-full w-full ' +((!items() || !items().length) ? 'bg-[#ffffff]': configTemplateCheckbox.classListInclude || '')\">\n @if (items() && items().length) {\n <div #elementScroll\n LibsUiComponentsScrollOverlayDirective\n class=\"w-full\"\n [class.h-full]=\"!(heightViewPort() && !config()?.ignoreShowDataWhenNotSearch)\"\n [style.height]=\"heightViewPort() && !config()?.ignoreShowDataWhenNotSearch ? heightViewPort()+'px':'100%'\"\n (outScrollBottom)=\"handlerScrollBottom()\">\n <virtual-scroller #scroll\n [parentScroll]=\"elementScroll\"\n [items]=\"items()\"\n class=\"h-full\">\n @for (item of scroll.viewPortItems; track item()[fieldKey()]; let last = $last) {\n <div [class]=\"last ? (configTemplateCheckbox.classIncludeLastViewItem || '') : ''\">\n <div #itemRef\n LibsUiComponentsListHighlightKeySearchDirective\n [isHighlight]=\"config()?.highlightTextSearchInResult\"\n [keySearch]=\"keySearch()\"\n [attr.clickExactly]=\"clickExactly\"\n [class]=\"'libs-ui-list-template-checkbox-item flex ' + (configTemplateCheckbox.classItemInclude || '')\"\n [class.w-full]=\"!configTemplateCheckbox.ignoreItemWidth100\"\n [class.libs-ui-bg-list-hover]=\"!clickExactly()\"\n [class.libs-ui-bg-list-hover-active]=\"!clickExactly()\"\n [class.!pl-[12px]]=\"paddingLeftItem()\"\n [class.!py-[6px]]=\"clickExactly()\"\n [class.!pr-[4px]]=\"hasScroll() && configTemplateCheckbox.rows\"\n [class.!pr-[12px]]=\"!hasScroll() && configTemplateCheckbox.rows\"\n (click)=\"handlerChange($event,item())\">\n <div class=\"flex flex-col w-full\">\n @if (item().fieldLabel) {\n <libs_ui-components-checkbox-single [label]=\"item().fieldLabel\"\n [avatarConfig]=\"(item().avatarConfig|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [linkImage]=\"configTemplateCheckbox.getImage ? (('avatar' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImage:item()) | async) : item()[configTemplateCheckbox.fieldGetImage || '']\"\n [linkImageError]=\"configTemplateCheckbox.getImageError ? (('avatar_error' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImageError:item()) | async) : item()[configTemplateCheckbox.fieldGetLinkImageError || '']\"\n [classLabelInclude]=\"item().classLabelInclude || configTemplateCheckbox.classLabelInclude || 'libs-ui-font-h5r'\"\n [zIndexLabel]=\"configTemplateCheckbox.zIndexPopover ?? 1200\"\n [checked]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [key]=\"item()[fieldKey()]\"\n [imgTypeIcon]=\"configTemplateCheckbox.hasAvatarGroupSocial\"\n [classInclude]=\"configTemplateCheckbox.classInclude || ''\"\n [classImageInclude]=\"configTemplateCheckbox.classIncludeImage || ''\"\n [bullet]=\"(item().bullet|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [disable]=\"loading() || disable() || (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:keysDisableItem():keysDisableItem()?.length)\"\n [popover]=\"(item().popoverLabel|LibsUiPipesConvertObjectToSignalPipe)?.() | LibsUiPipesConvertSignalToObjectPipe\"\n [clickExactly]=\"clickExactly()\"\n [dataComponentOutlet]=\"(undefined | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getDataComponentOutlet:item():fieldKey():{valueIsEmpty:{item:item()}}) | async\"\n [componentOutlet]=\"(0 | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getComponentOutlet:item():fieldKey():{valueIs0:0}) | async\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerChange('checkbox',item())\" />\n }\n @if (configTemplateCheckbox?.rows) {\n <libs_ui-components-list-templates_rows\n class=\"{{ !configTemplateCheckbox.ignoreItemWidth100 ? 'w-full' : '' }} {{ configTemplateCheckbox.classRowsWrapper || configTemplateCheckbox.classRows ?? '' }}\"\n [item]=\"item()\"\n [zIndex]=\"zIndex()\"\n [fieldKey]=\"fieldKey()\"\n [keySelected]=\"(item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) ? item()[fieldKey()] : undefined\"\n [configTemplate]=\"configTemplateCheckbox\"\n (outEvent)=\"handlerChange('checkbox',$event.item)\" />\n }\n </div>\n </div>\n </div>\n }\n </virtual-scroller>\n </div>\n }\n @if ((!items() || !items().length) && (!config()?.ignoreShowDataWhenNotSearch || keySearch())) {\n <div [class]=\"'libs-ui-font-h5r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px] px-[12px]')\">\n @if (config()?.hasIconNoData && !loading()) {\n <div class=\"mb-[16px]\">\n <div\n *ngComponentOutlet=\"(keySearch() ? 'no-result' : 'no-data') | LibsUiIconsGetIconComponentPipe | async\">\n </div>\n </div>\n }\n @if (!keySearch() && !loading()) {\n <span>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</span>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <span>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</span>\n }\n @if (loading()) {\n <span>&nbsp;</span>\n }\n\n </div>\n }\n @if (loading()) {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n </div>\n}\n", styles: [".libs-ui-list-template-checkbox-item{padding:6px 0 6px 16px;margin-right:8px;font-size:12px;line-height:18px;position:relative}\n"] }]
794
+ ], template: "@if (configTemplateCheckbox(); as configTemplateCheckbox) {\n <div class=\"flex flex-col w-full h-full\">\n @if (items().length && configTemplateCheckbox.configButtonSelectAndUndSelectItem?.(); as configButtonSelectItem) {\n <div\n [class]=\"'flex items-center bg-[#ffffff] '+(configButtonSelectItem.classInclude ?? 'libs-ui-border-bottom-general')\">\n <libs_ui-components-buttons-button [type]=\"configButtonSelectItem.buttonCheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonCheckAll?.label ?? 'i18n_select_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonCheckAll?.classInclude || 'pr-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonCheckAll?.classLabel || 'libs-ui-font-h6ri'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(true)\" />\n <div class=\"text-[#e6e7ea]\">|</div>\n <libs_ui-components-buttons-button\n [type]=\"configButtonSelectItem.buttonUncheckAll?.type ?? 'button-link-primary'\"\n [label]=\"configButtonSelectItem.buttonUncheckAll?.label ?? 'i18n_unselect_all_searched_results'\"\n [classInclude]=\"configButtonSelectItem.buttonUncheckAll?.classInclude || 'pl-[8px]'\"\n [classLabel]=\"configButtonSelectItem.buttonUncheckAll?.classLabel || 'libs-ui-font-h6ri'\"\n [disable]=\"loading() || disable() || false\"\n (outClick)=\"handlerSelect(false)\" />\n </div>\n }\n @if (items().length && configTemplateCheckbox.configCheckboxCheckAll?.(); as configCheckBox) {\n @let lengthMultiKeySelected = multiKeySelected()?.length || 0;\n @let lengthStore = store().length || -1;\n <div\n [class]=\"'flex libs-ui-border-bottom-general bg-[#ffffff] pl-[12px] '+(configTemplateCheckbox.classIncludeHasConfigCheckBoxAll ?? 'py-[6px] libs-ui-border-bottom-general')\">\n <libs_ui-components-checkbox-single [label]=\"configCheckBox.label ?? 'i18n_all'\"\n [classLabelInclude]=\"configCheckBox.classLabelInclude || ''\"\n [checked]=\"(lengthMultiKeySelected && lengthMultiKeySelected >= lengthStore) || false\"\n [stillOtherOptions]=\"!!lengthMultiKeySelected && lengthMultiKeySelected < lengthStore\"\n [disable]=\"loading() || disable() || false\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerSelect($event.checked, true)\" />\n </div>\n }\n <div\n [class]=\"'relative h-full w-full ' +((!items() || !items().length) ? 'bg-[#ffffff]': configTemplateCheckbox.classListInclude || '')\">\n @if (items() && items().length) {\n <div #elementScroll\n LibsUiComponentsScrollOverlayDirective\n class=\"w-full\"\n [class.h-full]=\"!(heightViewPort() && !config()?.ignoreShowDataWhenNotSearch)\"\n [style.height]=\"heightViewPort() && !config()?.ignoreShowDataWhenNotSearch ? heightViewPort()+'px':'100%'\"\n (outScrollBottom)=\"handlerScrollBottom()\">\n <virtual-scroller #scroll\n [parentScroll]=\"elementScroll\"\n [items]=\"items()\"\n class=\"h-full\">\n @for (item of scroll.viewPortItems; track item()[fieldKey()]; let last = $last) {\n <div [class]=\"last ? (configTemplateCheckbox.classIncludeLastViewItem || '') : ''\">\n <div #itemRef\n LibsUiComponentsListHighlightKeySearchDirective\n [isHighlight]=\"config()?.highlightTextSearchInResult\"\n [keySearch]=\"keySearch()\"\n [attr.clickExactly]=\"clickExactly()\"\n [class]=\"'libs-ui-list-template-checkbox-item libs-ui-font-h5r flex ' + (configTemplateCheckbox.classItemInclude || '')\"\n [class.w-full]=\"!configTemplateCheckbox.ignoreItemWidth100\"\n [class.libs-ui-bg-list-hover]=\"!clickExactly()\"\n [class.libs-ui-bg-list-hover-active]=\"!clickExactly()\"\n [class.!pl-[12px]]=\"paddingLeftItem()\"\n [class.!py-[6px]]=\"clickExactly()\"\n [class.!pr-[4px]]=\"hasScroll() && configTemplateCheckbox.rows\"\n [class.!pr-[12px]]=\"!hasScroll() && configTemplateCheckbox.rows\"\n (click)=\"handlerChange($event,item())\">\n <div class=\"flex flex-col w-full\">\n @if (item().fieldLabel) {\n <libs_ui-components-checkbox-single [label]=\"item().fieldLabel\"\n [avatarConfig]=\"(item().avatarConfig|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [linkImage]=\"configTemplateCheckbox.getImage ? (('avatar' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImage:item()) | async) : item()[configTemplateCheckbox.fieldGetImage || '']\"\n [linkImageError]=\"configTemplateCheckbox.getImageError ? (('avatar_error' | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getImageError:item()) | async) : item()[configTemplateCheckbox.fieldGetLinkImageError || '']\"\n [classLabelInclude]=\"item().classLabelInclude || configTemplateCheckbox.classLabelInclude || 'libs-ui-font-h5r'\"\n [zIndexLabel]=\"configTemplateCheckbox.zIndexPopover ?? 1200\"\n [checked]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [key]=\"item()[fieldKey()]\"\n [imgTypeIcon]=\"configTemplateCheckbox.hasAvatarGroupSocial\"\n [classInclude]=\"configTemplateCheckbox.classInclude || ''\"\n [classImageInclude]=\"configTemplateCheckbox.classIncludeImage || ''\"\n [bullet]=\"(item().bullet|LibsUiPipesConvertObjectToSignalPipe)?.()\"\n [disable]=\"loading() || disable() || (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:keysDisableItem():keysDisableItem()?.length)\"\n [popover]=\"(item().popoverLabel|LibsUiPipesConvertObjectToSignalPipe)?.() | LibsUiPipesConvertSignalToObjectPipe\"\n [clickExactly]=\"clickExactly()\"\n [dataComponentOutlet]=\"(undefined | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getDataComponentOutlet:item():fieldKey():{valueIsEmpty:{item:item()}}) | async\"\n [componentOutlet]=\"(0 | LibsUiPipesCallFunctionInTemplatePipe:configTemplateCheckbox.getComponentOutlet:item():fieldKey():{valueIs0:0}) | async\"\n (outChangStageFlagMousePopover)='handlerChangStageFlagMouse($event)'\n (outChange)=\"handlerChange('checkbox',item())\" />\n }\n @if (configTemplateCheckbox?.rows) {\n <libs_ui-components-list-templates_rows\n class=\"{{ !configTemplateCheckbox.ignoreItemWidth100 ? 'w-full' : '' }} {{ (configTemplateCheckbox.classRowsWrapper || configTemplateCheckbox.classRows) ?? '' }}\"\n [item]=\"item()\"\n [zIndex]=\"zIndex()\"\n [fieldKey]=\"fieldKey()\"\n [keySelected]=\"(item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) ? item()[fieldKey()] : undefined\"\n [configTemplate]=\"configTemplateCheckbox\"\n (outEvent)=\"handlerChange('checkbox',$event.item)\" />\n }\n </div>\n </div>\n </div>\n }\n </virtual-scroller>\n </div>\n }\n @if ((!items() || !items().length) && (!config()?.ignoreShowDataWhenNotSearch || keySearch())) {\n <div [class]=\"'libs-ui-font-h5r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px] px-[12px]')\">\n @if (config()?.hasIconNoData && !loading()) {\n <div class=\"mb-[16px]\">\n <div\n *ngComponentOutlet=\"(keySearch() ? 'no-result' : 'no-data') | LibsUiIconsGetIconComponentPipe | async\">\n </div>\n </div>\n }\n @if (!keySearch() && !loading()) {\n <span>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</span>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <span>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</span>\n }\n @if (loading()) {\n <span>&nbsp;</span>\n }\n\n </div>\n }\n @if (loading()) {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n </div>\n}\n", styles: [".libs-ui-list-template-checkbox-item{padding:6px 16px;font-size:12px;line-height:18px;position:relative}\n"] }]
795
795
  }] });
796
796
 
797
797
  class LibsUiComponentsListGroupCalculatorLeftLineVerticalItemPipe {
@@ -2014,7 +2014,7 @@ class LibsUiComponentsListTagComponent extends LibsUiComponentsListTemplatesComp
2014
2014
  return this.items().length;
2015
2015
  }
2016
2016
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsListTagComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
2017
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsListTagComponent, isStandalone: true, selector: "libs_ui-components-list-templates_tag", usesInheritance: true, ngImport: i0, template: "@if (configTemplateTag(); as configTemplateTag) {\n <div class=\"w-full h-full relative\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n <div class=\"relative max-h-[150px] h-full {{ configTemplateTag.classIncludeContainer }}\"\n [ngClass]=\"{'flex flex-wrap': !configTemplateTag.ignoreItemFlexWrap}\"\n [class.min-h-[45px]]=\"!loading() && (!items() || !items().length)\"\n [class.min-h-[104px]]=\"loading() && items()\">\n @for (item of items(); track item()[fieldKey()]) {\n <div [class.libs-ui-disable]=\"loading() || disable()\"\n [class.pointer-events-none]=\"loading() || disable()\"\n [class]=\"item().classContainerItem\">\n @if (item().bullet; as bullet) {\n <div [class]=\"item().classItem || 'rounded-[10px] px-[8px] py-[1px] mb-[8px] mr-[8px]'\"\n [class.w-max]=\"configTemplateTag?.ignoreItemFlexWrap\"\n [style.background-color]=\"bullet().backgroundColor\"\n [style.color]=\"bullet().color\"\n (click)=\"handlerSelectItem($event,item())\">\n <span [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n } @else {\n <div (click)=\"handlerSelectItem($event, item())\"\n [class]=\"item().classItem || 'rounded-[20px] mb-[8px] mr-[8px] py-[4px] px-[8px] flex items-center cursor-pointer'\"\n [class.bg-[#e9f1fe]]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [class.libs-ui-color-global]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\">\n @if (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) {\n <div class=\"mr-[8px] text-[12px] libs-ui-icon-check libs-ui-color-global\"></div>\n }\n <span class=\"libs-ui-font-h6r\"\n [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n }\n </div>\n }\n @if (!items() || !items().length) {\n <div [class]=\"'libs-ui-font-h4r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px]')\">\n @if (!keySearch() && !loading()) {\n <ng-container>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</ng-container>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</ng-container>\n }\n @if (loading()) {\n <ng-container>&nbsp;</ng-container>\n }\n </div>\n }\n </div>\n @if (loading()) {\n <div class=\"w-full h-full absolute top-0\">\n <libs_ui-components-spinner [size]=\"'medium'\" />\n </div>\n }\n </div>\n}\n", dependencies: [{ kind: "ngmodule", type: VirtualScrollerModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }, { kind: "pipe", type: LibsUiCheckSelectedByKeyPipe, name: "LibsUiCheckSelectedByKeyPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2017
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsListTagComponent, isStandalone: true, selector: "libs_ui-components-list-templates_tag", usesInheritance: true, ngImport: i0, template: "@if (configTemplateTag(); as configTemplateTag) {\n <div class=\"w-full h-full relative\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n <div class=\"relative max-h-[150px] h-full {{ configTemplateTag.classIncludeContainer }}\"\n [ngClass]=\"{'flex flex-wrap': !configTemplateTag.ignoreItemFlexWrap}\"\n [class.min-h-[45px]]=\"!loading() && (!items() || !items().length)\"\n [class.min-h-[94px]]=\"loading() && items()\">\n @for (item of items(); track item()[fieldKey()]) {\n <div [class.libs-ui-disable]=\"loading() || disable()\"\n [class.pointer-events-none]=\"loading() || disable()\"\n [class]=\"item().classContainerItem\">\n @if (item().bullet; as bullet) {\n <div [class]=\"item().classItem || 'rounded-[10px] px-[8px] py-[1px] mb-[8px] mr-[8px]'\"\n [class.w-max]=\"configTemplateTag?.ignoreItemFlexWrap\"\n [style.background-color]=\"bullet().backgroundColor\"\n [style.color]=\"bullet().color\"\n (click)=\"handlerSelectItem($event,item())\">\n <span [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n } @else {\n @let isSelected = item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length;\n <div (click)=\"handlerSelectItem($event, item())\"\n [class]=\"item().classItem || 'rounded-[20px] mb-[8px] mr-[8px] py-[4px] px-[8px] flex items-center cursor-pointer'\"\n [class.bg-[var(--libs-ui-color-light-1)]]=\"isSelected\"\n [class.text-[var(--libs-ui-color-default)]]=\"isSelected\"\n [class.bg-white]=\"!isSelected\"\n [class.text-[#6a7383]]=\"!isSelected\"\n [class.libs-ui-border-general]=\"!isSelected\">\n @if (isSelected) {\n <div class=\"mr-[8px] text-[12px] libs-ui-icon-check before:text-[var(--libs-ui-color-default)]\"></div>\n }\n <span class=\"libs-ui-font-h6r break-word\"\n [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n }\n </div>\n }\n @if (!items() || !items().length) {\n <div [class]=\"'libs-ui-font-h4r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px]')\">\n @if (!keySearch() && !loading()) {\n <ng-container>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</ng-container>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</ng-container>\n }\n @if (loading()) {\n <ng-container>&nbsp;</ng-container>\n }\n </div>\n }\n </div>\n @if (loading()) {\n <div class=\"w-full h-full absolute top-0\">\n <libs_ui-components-spinner [size]=\"'medium'\" />\n </div>\n }\n </div>\n}", dependencies: [{ kind: "ngmodule", type: VirtualScrollerModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }, { kind: "pipe", type: LibsUiCheckSelectedByKeyPipe, name: "LibsUiCheckSelectedByKeyPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2018
2018
  }
2019
2019
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsListTagComponent, decorators: [{
2020
2020
  type: Component,
@@ -2023,7 +2023,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
2023
2023
  LibsUiComponentsSpinnerComponent,
2024
2024
  LibsUiComponentsScrollOverlayDirective,
2025
2025
  LibsUiCheckSelectedByKeyPipe
2026
- ], template: "@if (configTemplateTag(); as configTemplateTag) {\n <div class=\"w-full h-full relative\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n <div class=\"relative max-h-[150px] h-full {{ configTemplateTag.classIncludeContainer }}\"\n [ngClass]=\"{'flex flex-wrap': !configTemplateTag.ignoreItemFlexWrap}\"\n [class.min-h-[45px]]=\"!loading() && (!items() || !items().length)\"\n [class.min-h-[104px]]=\"loading() && items()\">\n @for (item of items(); track item()[fieldKey()]) {\n <div [class.libs-ui-disable]=\"loading() || disable()\"\n [class.pointer-events-none]=\"loading() || disable()\"\n [class]=\"item().classContainerItem\">\n @if (item().bullet; as bullet) {\n <div [class]=\"item().classItem || 'rounded-[10px] px-[8px] py-[1px] mb-[8px] mr-[8px]'\"\n [class.w-max]=\"configTemplateTag?.ignoreItemFlexWrap\"\n [style.background-color]=\"bullet().backgroundColor\"\n [style.color]=\"bullet().color\"\n (click)=\"handlerSelectItem($event,item())\">\n <span [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n } @else {\n <div (click)=\"handlerSelectItem($event, item())\"\n [class]=\"item().classItem || 'rounded-[20px] mb-[8px] mr-[8px] py-[4px] px-[8px] flex items-center cursor-pointer'\"\n [class.bg-[#e9f1fe]]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\"\n [class.libs-ui-color-global]=\"item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length\">\n @if (item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length) {\n <div class=\"mr-[8px] text-[12px] libs-ui-icon-check libs-ui-color-global\"></div>\n }\n <span class=\"libs-ui-font-h6r\"\n [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n }\n </div>\n }\n @if (!items() || !items().length) {\n <div [class]=\"'libs-ui-font-h4r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px]')\">\n @if (!keySearch() && !loading()) {\n <ng-container>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</ng-container>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</ng-container>\n }\n @if (loading()) {\n <ng-container>&nbsp;</ng-container>\n }\n </div>\n }\n </div>\n @if (loading()) {\n <div class=\"w-full h-full absolute top-0\">\n <libs_ui-components-spinner [size]=\"'medium'\" />\n </div>\n }\n </div>\n}\n" }]
2026
+ ], template: "@if (configTemplateTag(); as configTemplateTag) {\n <div class=\"w-full h-full relative\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n <div class=\"relative max-h-[150px] h-full {{ configTemplateTag.classIncludeContainer }}\"\n [ngClass]=\"{'flex flex-wrap': !configTemplateTag.ignoreItemFlexWrap}\"\n [class.min-h-[45px]]=\"!loading() && (!items() || !items().length)\"\n [class.min-h-[94px]]=\"loading() && items()\">\n @for (item of items(); track item()[fieldKey()]) {\n <div [class.libs-ui-disable]=\"loading() || disable()\"\n [class.pointer-events-none]=\"loading() || disable()\"\n [class]=\"item().classContainerItem\">\n @if (item().bullet; as bullet) {\n <div [class]=\"item().classItem || 'rounded-[10px] px-[8px] py-[1px] mb-[8px] mr-[8px]'\"\n [class.w-max]=\"configTemplateTag?.ignoreItemFlexWrap\"\n [style.background-color]=\"bullet().backgroundColor\"\n [style.color]=\"bullet().color\"\n (click)=\"handlerSelectItem($event,item())\">\n <span [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n } @else {\n @let isSelected = item()[fieldKey()] | LibsUiCheckSelectedByKeyPipe:multiKeySelected():multiKeySelected()?.length;\n <div (click)=\"handlerSelectItem($event, item())\"\n [class]=\"item().classItem || 'rounded-[20px] mb-[8px] mr-[8px] py-[4px] px-[8px] flex items-center cursor-pointer'\"\n [class.bg-[var(--libs-ui-color-light-1)]]=\"isSelected\"\n [class.text-[var(--libs-ui-color-default)]]=\"isSelected\"\n [class.bg-white]=\"!isSelected\"\n [class.text-[#6a7383]]=\"!isSelected\"\n [class.libs-ui-border-general]=\"!isSelected\">\n @if (isSelected) {\n <div class=\"mr-[8px] text-[12px] libs-ui-icon-check before:text-[var(--libs-ui-color-default)]\"></div>\n }\n <span class=\"libs-ui-font-h6r break-word\"\n [innerHTML]=\"item().fieldLabel\"></span>\n </div>\n }\n </div>\n }\n @if (!items() || !items().length) {\n <div [class]=\"'libs-ui-font-h4r text-[#9ca2ad] '+ (config()?.textNoDataClassInclude ?? 'py-[4px]')\">\n @if (!keySearch() && !loading()) {\n <ng-container>{{ (config()?.textNoData ?? 'i18n_have_no_selection') | translate }}</ng-container>\n }\n @if (templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container *ngTemplateOutlet=\"templateRefSearchNoData() || null;context:{keySearch:keySearch()}\" />\n }\n @if (!templateRefSearchNoData() && keySearch() && !loading()) {\n <ng-container>{{ (config()?.textSearchNoData ?? 'i18n_no_result') | translate }}</ng-container>\n }\n @if (loading()) {\n <ng-container>&nbsp;</ng-container>\n }\n </div>\n }\n </div>\n @if (loading()) {\n <div class=\"w-full h-full absolute top-0\">\n <libs_ui-components-spinner [size]=\"'medium'\" />\n </div>\n }\n </div>\n}" }]
2027
2027
  }] });
2028
2028
 
2029
2029
  /* eslint-disable @typescript-eslint/no-explicit-any */