@po-ui/ng-components 16.5.0 → 16.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/po-field/po-combo/interfaces/po-combo-literals-default.interface.mjs +9 -5
- package/esm2022/lib/components/po-field/po-combo/interfaces/po-combo-literals.interface.mjs +1 -1
- package/esm2022/lib/components/po-field/po-combo/po-combo-base.component.mjs +4 -1
- package/esm2022/lib/components/po-field/po-combo/po-combo.component.mjs +94 -41
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +8 -3
- package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +4 -4
- package/esm2022/lib/components/po-listbox/po-listbox.component.mjs +5 -4
- package/fesm2022/po-ui-ng-components.mjs +114 -47
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-field/po-combo/interfaces/po-combo-literals.interface.d.ts +2 -0
- package/lib/components/po-field/po-combo/po-combo.component.d.ts +8 -5
- package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +1 -0
- package/package.json +4 -4
- package/po-ui-ng-components-16.6.1.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-16.5.0.tgz +0 -0
|
@@ -176,6 +176,7 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
176
176
|
initCalculateItems = true;
|
|
177
177
|
isCalculateVisibleItems = true;
|
|
178
178
|
cacheOptions;
|
|
179
|
+
focusOnTag = false;
|
|
179
180
|
constructor(renderer, changeDetector, el, controlPosition, defaultService, languageService) {
|
|
180
181
|
super(languageService);
|
|
181
182
|
this.renderer = renderer;
|
|
@@ -327,8 +328,11 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
327
328
|
this.onModelTouched?.();
|
|
328
329
|
}
|
|
329
330
|
onKeyDown(event) {
|
|
330
|
-
if (
|
|
331
|
-
|
|
331
|
+
if (event.shiftKey && event.keyCode === PoKeyCodeEnum.tab && !this.focusOnTag) {
|
|
332
|
+
this.controlDropdownVisibility(false);
|
|
333
|
+
}
|
|
334
|
+
this.focusOnTag = false;
|
|
335
|
+
if (event.keyCode === PoKeyCodeEnum.tab) {
|
|
332
336
|
return;
|
|
333
337
|
}
|
|
334
338
|
if (event.keyCode === PoKeyCodeEnum.esc) {
|
|
@@ -531,6 +535,7 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
531
535
|
const KEY_SPACE = 'Space';
|
|
532
536
|
const KEY_ARROW_LEFT = 'ArrowLeft';
|
|
533
537
|
const KEY_ARROW_RIGHT = 'ArrowRight';
|
|
538
|
+
this.focusOnTag = true;
|
|
534
539
|
if (event.code === KEY_SPACE) {
|
|
535
540
|
event.preventDefault();
|
|
536
541
|
event.stopPropagation();
|
|
@@ -668,4 +673,4 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
668
673
|
type: ViewChild,
|
|
669
674
|
args: ['inputElement', { read: ElementRef, static: true }]
|
|
670
675
|
}] }); })();
|
|
671
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  DoCheck,\n  ElementRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, Subscription, fromEvent, of } from 'rxjs';\nimport { catchError, tap } from 'rxjs/operators';\n\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { isMobile } from './../../../utils/util';\n\nimport { poLocaleDefault } from '../../../services/po-language/po-language.constant';\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\nimport { PoMultiselectOptionTemplateDirective } from './po-multiselect-option-template/po-multiselect-option-template.directive';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\nconst poMultiselectInputPaddingRight = 52;\nconst poMultiselectSpaceBetweenTags = 8;\n\nconst literalsTagRemoveOthers = {\n  pt: {\n    remove: 'Remover todos os itens selecionados'\n  },\n  ru: {\n    remove: 'Удалить все выбранные элементы'\n  },\n  es: {\n    remove: 'Eliminar todos los elementos seleccionados'\n  },\n  en: {\n    remove: 'Clear all selected items'\n  }\n};\n\n/* istanbul ignore next */\nconst providers = [\n  PoMultiselectFilterService,\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-template\" title=\"PO Multiselect - Template\">\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-any-array\" title=\"PO Multiselect - Array Any\">\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class PoMultiselectComponent\n  extends PoMultiselectBaseComponent\n  implements AfterViewInit, DoCheck, OnDestroy, OnChanges {\n  @ContentChild(PoMultiselectOptionTemplateDirective, { static: true })\n  multiselectOptionTemplate: PoMultiselectOptionTemplateDirective;\n\n  @ViewChild('dropdownElement', { read: ElementRef }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement') dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  literalsTag;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  hasMoreTag: boolean;\n  timeoutResize;\n  visibleElement = false;\n  private subscription: Subscription = new Subscription();\n  private enterCloseTag = false;\n  private initCalculateItems = true;\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption | any>;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    public defaultService: PoMultiselectFilterService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n    const language = languageService.getShortLanguage();\n    this.literalsTag = {\n      ...literalsTagRemoveOthers[poLocaleDefault],\n      ...literalsTagRemoveOthers[language]\n    };\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.filterService && (changes.filterService || changes.fieldValue || changes.fieldLabel)) {\n      this.setService(this.filterService);\n    }\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que as tags sejam calculadas na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n    this.subscription.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-multiselect-input').offsetWidth - poMultiselectInputPaddingRight;\n  }\n\n  getTagsWidth() {\n    const tags = this.el.nativeElement.querySelectorAll('po-tag');\n    return Array.from(tags).map(tag => tag['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    this.hasMoreTag = false;\n    const tagsWidth = this.getTagsWidth();\n    const inputWidth = this.getInputWidth();\n    const extraTagSize = 63;\n    const tagsVisible = tagsWidth[0];\n\n    this.visibleTags = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += tagsWidth[i] + poMultiselectSpaceBetweenTags;\n        this.visibleTags.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= tagsWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (tagsVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        this.hasMoreTag = true;\n        if (sum + extraTagSize > inputWidth) {\n          this.visibleTags.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        } else {\n          this.visibleTags.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        }\n      }\n      if (this.initCalculateItems) {\n        setTimeout(() => {\n          this.handleKeyboardNavigationTag();\n        }, 300);\n      }\n      this.initCalculateItems = false;\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n    setTimeout(() => {\n      this.handleKeyboardNavigationTag();\n    }, 300);\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleTags = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  onBlur() {\n    if (\n      typeof this.inputElement.nativeElement.getAttribute('aria-label') === 'string' &&\n      this.inputElement.nativeElement.getAttribute('aria-label').includes('Unselected')\n    ) {\n      this.inputElement.nativeElement.setAttribute('aria-label', this.label ? this.label : '');\n    }\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (\n      (event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length > 1) ||\n      (event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length < 1)\n    ) {\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.esc) {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.arrowDown && this.visibleTags.length > 0) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      this.dropdown?.listbox?.setFocus();\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.enter && !this.enterCloseTag) {\n      if (this.visibleTags.length === 0) {\n        this.toggleDropdownVisibility();\n        this.focus();\n        return;\n      } else {\n        event.preventDefault();\n        this.toggleDropdownVisibility();\n        return;\n      }\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.space) {\n      event.preventDefault();\n      this.toggleDropdownVisibility();\n    }\n    this.enterCloseTag = false;\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  onKeyDownDropdown(event: KeyboardEvent, index: number) {\n    if (event.key === 'Escape') {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(\n        option => option[this.fieldValue] === this.selectedOptions[0][this.fieldValue]\n      );\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n    this.changeDetector.markForCheck();\n  }\n\n  changeSearch(event) {\n    if (event && event[this.fieldValue] !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event[this.fieldValue]);\n      } else {\n        this.searchByLabel(event[this.fieldValue], this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeTag(value, event) {\n    let index;\n    this.enterCloseTag = true;\n    if (!value || (typeof value === 'string' && value.includes('+'))) {\n      index = null;\n      const itemsNotInVisibleTags = this.selectedOptions.filter(option => !this.visibleTags.includes(option));\n      for (const option of this.visibleTags) {\n        if (!this.selectedOptions.includes(option)) {\n          this.selectedOptions.splice(this.visibleTags.length - 1, itemsNotInVisibleTags.length);\n          this.updateVisibleItems();\n          this.callOnChange(this.selectedOptions);\n        }\n      }\n    } else {\n      index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);\n      this.selectedOptions.splice(index, 1);\n      this.updateVisibleItems();\n      this.callOnChange(this.selectedOptions);\n    }\n\n    setTimeout(() => {\n      this.focusOnNextTag(index, event);\n    }, 300);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption | any>> {\n    const param = { property: this.fieldLabel, value: value };\n    return this.service.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption | any>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      // necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel\n      // pois temos o distinctUntilChange no pipe do filterSubject\n      /* eslint-disable no-new-wrappers */\n      this.filterSubject.next(new String());\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption | any>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private focusOnNextTag(indexClosed: number, clickOrEnter: string) {\n    if (clickOrEnter === 'enter') {\n      const tagRemoveElements: Array<any> = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n      indexClosed = indexClosed || indexClosed === 0 ? indexClosed : tagRemoveElements.length;\n      if (tagRemoveElements.length === 0) {\n        this.inputElement.nativeElement.focus();\n        this.inputElement.nativeElement.setAttribute('aria-label', `Unselected items ${this.label}`);\n        this.controlDropdownVisibility(true);\n      }\n      this.focusOnRemoveTag(tagRemoveElements, indexClosed);\n    } else {\n      indexClosed = 0;\n    }\n    this.handleKeyboardNavigationTag(indexClosed);\n  }\n\n  private focusOnRemoveTag(tag: any, indexClosed: number) {\n    if (tag.length === indexClosed) {\n      tag[indexClosed - 1]?.focus();\n    } else {\n      tag[indexClosed]?.focus();\n    }\n  }\n\n  public handleKeyboardNavigationTag(initialIndex = 0) {\n    this.subscription.unsubscribe();\n    this.subscription = new Subscription();\n    const tagRemoveElements = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n    this.initializeTagRemoveElements(tagRemoveElements, initialIndex);\n  }\n\n  private setTabIndex(element, tabIndex) {\n    element.setAttribute('tabindex', tabIndex);\n  }\n\n  private handleArrowLeft(tagRemoveElements, index) {\n    if (index > 0) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index - 1].focus();\n      this.setTabIndex(tagRemoveElements[index - 1], 0);\n    }\n  }\n\n  private handleArrowRight(tagRemoveElements, index) {\n    if (index < tagRemoveElements.length - 1) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index + 1].focus();\n      this.setTabIndex(tagRemoveElements[index + 1], 0);\n    }\n  }\n\n  private handleKeyDown(event: KeyboardEvent, tagRemoveElements, index) {\n    const KEY_SPACE = 'Space';\n    const KEY_ARROW_LEFT = 'ArrowLeft';\n    const KEY_ARROW_RIGHT = 'ArrowRight';\n\n    if (event.code === KEY_SPACE) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    if (event.key === KEY_ARROW_LEFT) {\n      this.handleArrowLeft(tagRemoveElements, index);\n    } else if (event.key === KEY_ARROW_RIGHT) {\n      this.handleArrowRight(tagRemoveElements, index);\n    }\n  }\n\n  private initializeTagRemoveElements(tagRemoveElements, initialIndex) {\n    tagRemoveElements.forEach((tagRemoveElement, index) => {\n      if (index === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex], 0);\n      } else if (tagRemoveElements.length === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex - 1], 0);\n      } else {\n        this.setTabIndex(tagRemoveElement, -1);\n      }\n\n      this.subscription.add(\n        fromEvent(tagRemoveElement, 'keydown').subscribe((event: KeyboardEvent) => {\n          this.handleKeyDown(event, tagRemoveElements, index);\n        })\n      );\n    });\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n    this.changeDetector.markForCheck();\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    class=\"po-field-container-content\"\n    [class.po-multiselect-show]=\"dropdownOpen\"\n  >\n    <div\n      #inputElement\n      [tabindex]=\"disabled ? -1 : 0\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"label\"\n      class=\"po-input-icon-right po-multiselect-input\"\n      [class.po-multiselect-input-auto]=\"autoHeight\"\n      [class.po-multiselect-input-static]=\"!autoHeight\"\n      [class.po-multiselect-input-disabled]=\"disabled\"\n      [class.po-multiselect-input-font]=\"!disabled && !visibleTags?.length\"\n      (keydown)=\"onKeyDown($event)\"\n      (click)=\"toggleDropdownVisibility()\"\n      (blur)=\"onBlur()\"\n    >\n      <span *ngIf=\"!disabled && !visibleTags?.length\" class=\"po-multiselect-input-placeholder\" aria-hidden=\"true\">\n        {{ placeholder ? placeholder : literals.selectItem }}\n      </span>\n\n      <po-tag\n        *ngFor=\"let tag of visibleTags; index as i\"\n        [p-value]=\"tag[fieldLabel]\"\n        [p-literals]=\"i + 1 === visibleTags.length && hasMoreTag ? literalsTag : undefined\"\n        [p-removable]=\"true\"\n        [class.po-clickable]=\"tag[fieldValue] === '' && !disabled\"\n        [p-disabled]=\"disabled\"\n        (p-close)=\"closeTag(tag[fieldValue], $event)\"\n      ></po-tag>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #iconElement\n          class=\"po-icon po-field-icon {{ dropdownIcon }} {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n          [ngClass]=\"disabled ? 'po-field-icon-disabled' : ''\"\n        >\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"appendBox; then dropdownCDK; else dropdownDefault\"> </ng-container>\n\n  <ng-template #dropdownDefault>\n    <ng-container *ngTemplateOutlet=\"dropdownListbox\"> </ng-container>\n  </ng-template>\n\n  <ng-template #dropdownCDK>\n    <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"true\">\n      <ng-container *ngTemplateOutlet=\"dropdownListbox\"></ng-container>\n    </ng-template>\n  </ng-template>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n\n<ng-template #dropdownListbox>\n  <po-multiselect-dropdown\n    #dropdownElement\n    [p-searching]=\"isServerSearching\"\n    [p-hide-search]=\"hideSearch\"\n    [p-hide-select-all]=\"hideSelectAll\"\n    [p-literals]=\"literals\"\n    [p-options]=\"options\"\n    [p-visible-options]=\"visibleOptionsDropdown\"\n    [p-selected-options]=\"selectedOptions\"\n    [p-placeholder-search]=\"placeholderSearch\"\n    [p-field-value]=\"fieldValue\"\n    [p-field-label]=\"fieldLabel\"\n    [p-multiselect-template]=\"multiselectOptionTemplate\"\n    (p-change)=\"changeItems($event)\"\n    (p-change-search)=\"changeSearch($event)\"\n    (p-close-dropdown)=\"controlDropdownVisibility(false)\"\n    (keydown)=\"onKeyDownDropdown($event, 0)\"\n  >\n  </po-multiselect-dropdown>\n</ng-template>\n"]}
|
|
676
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  DoCheck,\n  ElementRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, Subscription, fromEvent, of } from 'rxjs';\nimport { catchError, tap } from 'rxjs/operators';\n\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { isMobile } from './../../../utils/util';\n\nimport { poLocaleDefault } from '../../../services/po-language/po-language.constant';\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\nimport { PoMultiselectOptionTemplateDirective } from './po-multiselect-option-template/po-multiselect-option-template.directive';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\nconst poMultiselectInputPaddingRight = 52;\nconst poMultiselectSpaceBetweenTags = 8;\n\nconst literalsTagRemoveOthers = {\n  pt: {\n    remove: 'Remover todos os itens selecionados'\n  },\n  ru: {\n    remove: 'Удалить все выбранные элементы'\n  },\n  es: {\n    remove: 'Eliminar todos los elementos seleccionados'\n  },\n  en: {\n    remove: 'Clear all selected items'\n  }\n};\n\n/* istanbul ignore next */\nconst providers = [\n  PoMultiselectFilterService,\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-template\" title=\"PO Multiselect - Template\">\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-any-array\" title=\"PO Multiselect - Array Any\">\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class PoMultiselectComponent\n  extends PoMultiselectBaseComponent\n  implements AfterViewInit, DoCheck, OnDestroy, OnChanges {\n  @ContentChild(PoMultiselectOptionTemplateDirective, { static: true })\n  multiselectOptionTemplate: PoMultiselectOptionTemplateDirective;\n\n  @ViewChild('dropdownElement', { read: ElementRef }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement') dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  literalsTag;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  hasMoreTag: boolean;\n  timeoutResize;\n  visibleElement = false;\n  private subscription: Subscription = new Subscription();\n  private enterCloseTag = false;\n  private initCalculateItems = true;\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption | any>;\n  private focusOnTag = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    public defaultService: PoMultiselectFilterService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n    const language = languageService.getShortLanguage();\n    this.literalsTag = {\n      ...literalsTagRemoveOthers[poLocaleDefault],\n      ...literalsTagRemoveOthers[language]\n    };\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.filterService && (changes.filterService || changes.fieldValue || changes.fieldLabel)) {\n      this.setService(this.filterService);\n    }\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que as tags sejam calculadas na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n    this.subscription.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-multiselect-input').offsetWidth - poMultiselectInputPaddingRight;\n  }\n\n  getTagsWidth() {\n    const tags = this.el.nativeElement.querySelectorAll('po-tag');\n    return Array.from(tags).map(tag => tag['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    this.hasMoreTag = false;\n    const tagsWidth = this.getTagsWidth();\n    const inputWidth = this.getInputWidth();\n    const extraTagSize = 63;\n    const tagsVisible = tagsWidth[0];\n\n    this.visibleTags = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += tagsWidth[i] + poMultiselectSpaceBetweenTags;\n        this.visibleTags.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= tagsWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (tagsVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        this.hasMoreTag = true;\n        if (sum + extraTagSize > inputWidth) {\n          this.visibleTags.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        } else {\n          this.visibleTags.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        }\n      }\n      if (this.initCalculateItems) {\n        setTimeout(() => {\n          this.handleKeyboardNavigationTag();\n        }, 300);\n      }\n      this.initCalculateItems = false;\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n    setTimeout(() => {\n      this.handleKeyboardNavigationTag();\n    }, 300);\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleTags = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  onBlur() {\n    if (\n      typeof this.inputElement.nativeElement.getAttribute('aria-label') === 'string' &&\n      this.inputElement.nativeElement.getAttribute('aria-label').includes('Unselected')\n    ) {\n      this.inputElement.nativeElement.setAttribute('aria-label', this.label ? this.label : '');\n    }\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (event.shiftKey && event.keyCode === PoKeyCodeEnum.tab && !this.focusOnTag) {\n      this.controlDropdownVisibility(false);\n    }\n    this.focusOnTag = false;\n\n    if (event.keyCode === PoKeyCodeEnum.tab) {\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.esc) {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.arrowDown && this.visibleTags.length > 0) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      this.dropdown?.listbox?.setFocus();\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.enter && !this.enterCloseTag) {\n      if (this.visibleTags.length === 0) {\n        this.toggleDropdownVisibility();\n        this.focus();\n        return;\n      } else {\n        event.preventDefault();\n        this.toggleDropdownVisibility();\n        return;\n      }\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.space) {\n      event.preventDefault();\n      this.toggleDropdownVisibility();\n    }\n    this.enterCloseTag = false;\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  onKeyDownDropdown(event: KeyboardEvent, index: number) {\n    if (event.key === 'Escape') {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(\n        option => option[this.fieldValue] === this.selectedOptions[0][this.fieldValue]\n      );\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n    this.changeDetector.markForCheck();\n  }\n\n  changeSearch(event) {\n    if (event && event[this.fieldValue] !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event[this.fieldValue]);\n      } else {\n        this.searchByLabel(event[this.fieldValue], this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeTag(value, event) {\n    let index;\n    this.enterCloseTag = true;\n    if (!value || (typeof value === 'string' && value.includes('+'))) {\n      index = null;\n      const itemsNotInVisibleTags = this.selectedOptions.filter(option => !this.visibleTags.includes(option));\n      for (const option of this.visibleTags) {\n        if (!this.selectedOptions.includes(option)) {\n          this.selectedOptions.splice(this.visibleTags.length - 1, itemsNotInVisibleTags.length);\n          this.updateVisibleItems();\n          this.callOnChange(this.selectedOptions);\n        }\n      }\n    } else {\n      index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);\n      this.selectedOptions.splice(index, 1);\n      this.updateVisibleItems();\n      this.callOnChange(this.selectedOptions);\n    }\n\n    setTimeout(() => {\n      this.focusOnNextTag(index, event);\n    }, 300);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption | any>> {\n    const param = { property: this.fieldLabel, value: value };\n    return this.service.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption | any>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      // necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel\n      // pois temos o distinctUntilChange no pipe do filterSubject\n      /* eslint-disable no-new-wrappers */\n      this.filterSubject.next(new String());\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption | any>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private focusOnNextTag(indexClosed: number, clickOrEnter: string) {\n    if (clickOrEnter === 'enter') {\n      const tagRemoveElements: Array<any> = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n      indexClosed = indexClosed || indexClosed === 0 ? indexClosed : tagRemoveElements.length;\n      if (tagRemoveElements.length === 0) {\n        this.inputElement.nativeElement.focus();\n        this.inputElement.nativeElement.setAttribute('aria-label', `Unselected items ${this.label}`);\n        this.controlDropdownVisibility(true);\n      }\n      this.focusOnRemoveTag(tagRemoveElements, indexClosed);\n    } else {\n      indexClosed = 0;\n    }\n    this.handleKeyboardNavigationTag(indexClosed);\n  }\n\n  private focusOnRemoveTag(tag: any, indexClosed: number) {\n    if (tag.length === indexClosed) {\n      tag[indexClosed - 1]?.focus();\n    } else {\n      tag[indexClosed]?.focus();\n    }\n  }\n\n  public handleKeyboardNavigationTag(initialIndex = 0) {\n    this.subscription.unsubscribe();\n    this.subscription = new Subscription();\n    const tagRemoveElements = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n    this.initializeTagRemoveElements(tagRemoveElements, initialIndex);\n  }\n\n  private setTabIndex(element, tabIndex) {\n    element.setAttribute('tabindex', tabIndex);\n  }\n\n  private handleArrowLeft(tagRemoveElements, index) {\n    if (index > 0) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index - 1].focus();\n      this.setTabIndex(tagRemoveElements[index - 1], 0);\n    }\n  }\n\n  private handleArrowRight(tagRemoveElements, index) {\n    if (index < tagRemoveElements.length - 1) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index + 1].focus();\n      this.setTabIndex(tagRemoveElements[index + 1], 0);\n    }\n  }\n\n  private handleKeyDown(event: KeyboardEvent, tagRemoveElements, index) {\n    const KEY_SPACE = 'Space';\n    const KEY_ARROW_LEFT = 'ArrowLeft';\n    const KEY_ARROW_RIGHT = 'ArrowRight';\n    this.focusOnTag = true;\n\n    if (event.code === KEY_SPACE) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    if (event.key === KEY_ARROW_LEFT) {\n      this.handleArrowLeft(tagRemoveElements, index);\n    } else if (event.key === KEY_ARROW_RIGHT) {\n      this.handleArrowRight(tagRemoveElements, index);\n    }\n  }\n\n  private initializeTagRemoveElements(tagRemoveElements, initialIndex) {\n    tagRemoveElements.forEach((tagRemoveElement, index) => {\n      if (index === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex], 0);\n      } else if (tagRemoveElements.length === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex - 1], 0);\n      } else {\n        this.setTabIndex(tagRemoveElement, -1);\n      }\n\n      this.subscription.add(\n        fromEvent(tagRemoveElement, 'keydown').subscribe((event: KeyboardEvent) => {\n          this.handleKeyDown(event, tagRemoveElements, index);\n        })\n      );\n    });\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n    this.changeDetector.markForCheck();\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    class=\"po-field-container-content\"\n    [class.po-multiselect-show]=\"dropdownOpen\"\n  >\n    <div\n      #inputElement\n      [tabindex]=\"disabled ? -1 : 0\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"label\"\n      class=\"po-input-icon-right po-multiselect-input\"\n      [class.po-multiselect-input-auto]=\"autoHeight\"\n      [class.po-multiselect-input-static]=\"!autoHeight\"\n      [class.po-multiselect-input-disabled]=\"disabled\"\n      [class.po-multiselect-input-font]=\"!disabled && !visibleTags?.length\"\n      (keydown)=\"onKeyDown($event)\"\n      (click)=\"toggleDropdownVisibility()\"\n      (blur)=\"onBlur()\"\n    >\n      <span *ngIf=\"!disabled && !visibleTags?.length\" class=\"po-multiselect-input-placeholder\" aria-hidden=\"true\">\n        {{ placeholder ? placeholder : literals.selectItem }}\n      </span>\n\n      <po-tag\n        *ngFor=\"let tag of visibleTags; index as i\"\n        [p-value]=\"tag[fieldLabel]\"\n        [p-literals]=\"i + 1 === visibleTags.length && hasMoreTag ? literalsTag : undefined\"\n        [p-removable]=\"true\"\n        [class.po-clickable]=\"tag[fieldValue] === '' && !disabled\"\n        [p-disabled]=\"disabled\"\n        (p-close)=\"closeTag(tag[fieldValue], $event)\"\n      ></po-tag>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #iconElement\n          class=\"po-icon po-field-icon {{ dropdownIcon }} {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n          [ngClass]=\"disabled ? 'po-field-icon-disabled' : ''\"\n        >\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"appendBox; then dropdownCDK; else dropdownDefault\"> </ng-container>\n\n  <ng-template #dropdownDefault>\n    <ng-container *ngTemplateOutlet=\"dropdownListbox\"> </ng-container>\n  </ng-template>\n\n  <ng-template #dropdownCDK>\n    <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"true\">\n      <ng-container *ngTemplateOutlet=\"dropdownListbox\"></ng-container>\n    </ng-template>\n  </ng-template>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n\n<ng-template #dropdownListbox>\n  <po-multiselect-dropdown\n    #dropdownElement\n    [p-searching]=\"isServerSearching\"\n    [p-hide-search]=\"hideSearch\"\n    [p-hide-select-all]=\"hideSelectAll\"\n    [p-literals]=\"literals\"\n    [p-options]=\"options\"\n    [p-visible-options]=\"visibleOptionsDropdown\"\n    [p-selected-options]=\"selectedOptions\"\n    [p-placeholder-search]=\"placeholderSearch\"\n    [p-field-value]=\"fieldValue\"\n    [p-field-label]=\"fieldLabel\"\n    [p-multiselect-template]=\"multiselectOptionTemplate\"\n    (p-change)=\"changeItems($event)\"\n    (p-change-search)=\"changeSearch($event)\"\n    (p-close-dropdown)=\"controlDropdownVisibility(false)\"\n    (keydown)=\"onKeyDownDropdown($event, 0)\"\n  >\n  </po-multiselect-dropdown>\n</ng-template>\n"]}
|
|
@@ -67,7 +67,7 @@ function PoItemListComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
|
67
67
|
i0.ɵɵelementStart(0, "div", 13);
|
|
68
68
|
i0.ɵɵlistener("click", function PoItemListComponent_div_3_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r13); const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r12.onCheckboxItem()); })("keydown", function PoItemListComponent_div_3_Template_div_keydown_0_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r14 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r14.onCheckboxItemEmit($event)); })("keyup", function PoItemListComponent_div_3_Template_div_keyup_0_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r15 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r15.onCheckboxItemEmit($event)); });
|
|
69
69
|
i0.ɵɵelementStart(1, "po-checkbox", 14);
|
|
70
|
-
i0.ɵɵlistener("p-change", function PoItemListComponent_div_3_Template_po_checkbox_p_change_1_listener() { i0.ɵɵrestoreView(_r13); const
|
|
70
|
+
i0.ɵɵlistener("click", function PoItemListComponent_div_3_Template_po_checkbox_click_1_listener() { i0.ɵɵrestoreView(_r13); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.onCheckboxItem()); })("p-change", function PoItemListComponent_div_3_Template_po_checkbox_p_change_1_listener() { i0.ɵɵrestoreView(_r13); const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.onSelectItem({ label: ctx_r17.label })); });
|
|
71
71
|
i0.ɵɵelementEnd();
|
|
72
72
|
i0.ɵɵtemplate(2, PoItemListComponent_div_3_span_2_Template, 2, 1, "span", 15);
|
|
73
73
|
i0.ɵɵtemplate(3, PoItemListComponent_div_3_ng_template_3_Template, 0, 0, "ng-template", 11);
|
|
@@ -164,7 +164,7 @@ export class PoItemListComponent extends PoItemListBaseComponent {
|
|
|
164
164
|
} if (rf & 2) {
|
|
165
165
|
let _t;
|
|
166
166
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.itemList = _t.first);
|
|
167
|
-
} }, features: [i0.ɵɵInheritDefinitionFeature], decls: 4, vars: 3, consts: [[3, "ngSwitch", "keydown"], ["class", "po-item-list po-item-list__action", 3, "po-item-list__separator", "po-item-list__disabled", "po-item-list__selected", "po-item-list__danger", 4, "ngSwitchDefault"], ["class", "po-item-list po-item-list__option", 3, "po-item-list__separator", "po-item-list__selected", "click", 4, "ngSwitchCase"], ["class", "po-item-list po-item-list__check", 3, "po-item-list__separator", "po-item-list__selected", "po-item-list__disabled", "click", "keydown", "keyup", 4, "ngSwitchCase"], [1, "po-item-list", "po-item-list__action"], ["itemList", ""], ["class", "po-popup-icon-item po-icon", 3, "p-icon", 4, "ngIf"], [1, "po-item-list-label"], [1, "po-popup-icon-item", "po-icon", 3, "p-icon"], [1, "po-item-list", "po-item-list__option", 3, "click"], ["class", "po-item-list-label", 3, "innerHTML", 4, "ngIf"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [1, "po-item-list-label", 3, "innerHTML"], [1, "po-item-list", "po-item-list__check", 3, "click", "keydown", "keyup"], [3, "p-disabled-tabindex", "p-checkboxValue", "p-disabled", "p-change"], ["class", "po-item-list__label", 4, "ngIf"], [1, "po-item-list__label"]], template: function PoItemListComponent_Template(rf, ctx) { if (rf & 1) {
|
|
167
|
+
} }, features: [i0.ɵɵInheritDefinitionFeature], decls: 4, vars: 3, consts: [[3, "ngSwitch", "keydown"], ["class", "po-item-list po-item-list__action", 3, "po-item-list__separator", "po-item-list__disabled", "po-item-list__selected", "po-item-list__danger", 4, "ngSwitchDefault"], ["class", "po-item-list po-item-list__option", 3, "po-item-list__separator", "po-item-list__selected", "click", 4, "ngSwitchCase"], ["class", "po-item-list po-item-list__check", 3, "po-item-list__separator", "po-item-list__selected", "po-item-list__disabled", "click", "keydown", "keyup", 4, "ngSwitchCase"], [1, "po-item-list", "po-item-list__action"], ["itemList", ""], ["class", "po-popup-icon-item po-icon", 3, "p-icon", 4, "ngIf"], [1, "po-item-list-label"], [1, "po-popup-icon-item", "po-icon", 3, "p-icon"], [1, "po-item-list", "po-item-list__option", 3, "click"], ["class", "po-item-list-label", 3, "innerHTML", 4, "ngIf"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [1, "po-item-list-label", 3, "innerHTML"], [1, "po-item-list", "po-item-list__check", 3, "click", "keydown", "keyup"], [3, "p-disabled-tabindex", "p-checkboxValue", "p-disabled", "click", "p-change"], ["class", "po-item-list__label", 4, "ngIf"], [1, "po-item-list__label"]], template: function PoItemListComponent_Template(rf, ctx) { if (rf & 1) {
|
|
168
168
|
i0.ɵɵelementContainerStart(0, 0);
|
|
169
169
|
i0.ɵɵlistener("keydown", function PoItemListComponent_Template_ng_container_keydown_0_listener($event) { return ctx.onCheckboxItemEmit($event); });
|
|
170
170
|
i0.ɵɵtemplate(1, PoItemListComponent_div_1_Template, 5, 12, "div", 1);
|
|
@@ -181,9 +181,9 @@ export class PoItemListComponent extends PoItemListBaseComponent {
|
|
|
181
181
|
}
|
|
182
182
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoItemListComponent, [{
|
|
183
183
|
type: Component,
|
|
184
|
-
args: [{ selector: 'po-item-list', template: "<ng-container [ngSwitch]=\"type\" (keydown)=\"onCheckboxItemEmit($event)\">\n <div\n *ngSwitchDefault\n #itemList\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__disabled]=\"disabled || !visible\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [attr.aria-disabled]=\"disabled || !visible\"\n [attr.aria-label]=\"label\"\n [class.po-item-list__danger]=\"danger\"\n class=\"po-item-list po-item-list__action\"\n >\n <po-icon *ngIf=\"icon\" class=\"po-popup-icon-item po-icon\" [p-icon]=\"icon\"></po-icon>\n <span class=\"po-item-list-label\">{{ label }}</span>\n </div>\n\n <div\n *ngSwitchCase=\"'option'\"\n #itemList\n class=\"po-item-list po-item-list__option\"\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n (click)=\"onComboItem(item, $event)\"\n >\n <span *ngIf=\"!template\" class=\"po-item-list-label\" [innerHTML]=\"getLabelFormatted(label)\"></span>\n\n <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n </ng-template>\n </div>\n\n <div\n *ngSwitchCase=\"'check'\"\n class=\"po-item-list po-item-list__check\"\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [class.po-item-list__disabled]=\"disabled\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n (click)=\"onCheckboxItem()\"\n (keydown)=\"onCheckboxItemEmit($event)\"\n (keyup)=\"onCheckboxItemEmit($event)\"\n >\n <po-checkbox\n [p-disabled-tabindex]=\"true\"\n [p-checkboxValue]=\"checkboxValue === null ? 'mixed' : checkboxValue\"\n [p-disabled]=\"disabled\"\n (p-change)=\"onSelectItem({label})\"\n ></po-checkbox>\n\n <span class=\"po-item-list__label\" *ngIf=\"!template\">{{ label }}</span>\n\n <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n </ng-template>\n </div>\n</ng-container>\n" }]
|
|
184
|
+
args: [{ selector: 'po-item-list', template: "<ng-container [ngSwitch]=\"type\" (keydown)=\"onCheckboxItemEmit($event)\">\n <div\n *ngSwitchDefault\n #itemList\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__disabled]=\"disabled || !visible\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [attr.aria-disabled]=\"disabled || !visible\"\n [attr.aria-label]=\"label\"\n [class.po-item-list__danger]=\"danger\"\n class=\"po-item-list po-item-list__action\"\n >\n <po-icon *ngIf=\"icon\" class=\"po-popup-icon-item po-icon\" [p-icon]=\"icon\"></po-icon>\n <span class=\"po-item-list-label\">{{ label }}</span>\n </div>\n\n <div\n *ngSwitchCase=\"'option'\"\n #itemList\n class=\"po-item-list po-item-list__option\"\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n (click)=\"onComboItem(item, $event)\"\n >\n <span *ngIf=\"!template\" class=\"po-item-list-label\" [innerHTML]=\"getLabelFormatted(label)\"></span>\n\n <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n </ng-template>\n </div>\n\n <div\n *ngSwitchCase=\"'check'\"\n class=\"po-item-list po-item-list__check\"\n [class.po-item-list__separator]=\"separator\"\n [class.po-item-list__selected]=\"selected && !disabled\"\n [class.po-item-list__disabled]=\"disabled\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n (click)=\"onCheckboxItem()\"\n (keydown)=\"onCheckboxItemEmit($event)\"\n (keyup)=\"onCheckboxItemEmit($event)\"\n >\n <po-checkbox\n [p-disabled-tabindex]=\"true\"\n [p-checkboxValue]=\"checkboxValue === null ? 'mixed' : checkboxValue\"\n [p-disabled]=\"disabled\"\n (click)=\"onCheckboxItem()\"\n (p-change)=\"onSelectItem({label})\"\n ></po-checkbox>\n\n <span class=\"po-item-list__label\" *ngIf=\"!template\">{{ label }}</span>\n\n <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n </ng-template>\n </div>\n</ng-container>\n" }]
|
|
185
185
|
}], function () { return [{ type: i1.DomSanitizer }]; }, { itemList: [{
|
|
186
186
|
type: ViewChild,
|
|
187
187
|
args: ['itemList', { static: true }]
|
|
188
188
|
}] }); })();
|
|
189
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-item-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list.component.ts","../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,SAAS,EAAE,MAAM,eAAe,CAAC;AAKjE,OAAO,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;;;;;;;;ICM1E,6BAAmF;;;IAA1B,oCAAe;;;IAX1E,iCAUC;IACC,kFAAmF;IACnF,+BAAiC;IAAA,YAAW;IAAA,iBAAO,EAAA;;;IATnD,2DAA2C,8DAAA,+DAAA,uCAAA;IAG3C,mEAA2C,4BAAA;IAKjC,eAAU;IAAV,kCAAU;IACa,eAAW;IAAX,kCAAW;;;IAa5C,2BAAiG;;;IAA9C,qFAAsC;;;;;;IAV3F,iCASC;IADC,mKAAS,eAAA,uCAAyB,CAAA,IAAC;IAEnC,6EAAiG;IAEjG,2FACc;IAChB,iBAAM;;;IAVJ,2DAA2C,+DAAA;IAE3C,gDAA+B,4BAAA;IAIxB,eAAe;IAAf,uCAAe;IAET,eAA0C;IAA1C,+FAA0C,+EAAA;;;IAuBvD,gCAAoD;IAAA,YAAW;IAAA,iBAAO;;;IAAlB,eAAW;IAAX,mCAAW;;;;;IAnBjE,+BAWC;IAHC,+JAAS,eAAA,wBAAgB,CAAA,IAAC,4JACf,eAAA,kCAA0B,CAAA,IADX,wJAEjB,eAAA,kCAA0B,CAAA,IAFT;IAI1B,uCAKC;IADC,6KAAY,eAAA,8CAAqB,CAAA,IAAC;IACnC,iBAAc;IAEf,6EAAsE;IAEtE,2FACc;IAChB,iBAAM;;;IApBJ,2DAA2C,+DAAA,2CAAA;IAG3C,gDAA+B,4BAAA;IAO7B,eAA4B;IAA5B,0CAA4B,mFAAA,+BAAA;IAMK,eAAe;IAAf,uCAAe;IAErC,eAA0C;IAA1C,+FAA0C,gFAAA;;ADzC3D,MAAM,OAAO,mBAAoB,SAAQ,uBAAuB;IAQ1C;IAPqB,QAAQ,CAAa;IAE9D,YAAY,CAAmB;IAErB,KAAK,CAAC;IACN,aAAa,CAAa;IAEpC,YAAoB,SAAuB;QACzC,KAAK,EAAE,CAAC;QADU,cAAS,GAAT,SAAS,CAAc;IAE3C,CAAC;IAED,YAAY,CAAC,cAA8D;QACzE,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC;QACnC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACvC,CAAC;IAED,cAAc;QACZ,MAAM,MAAM,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;QAChF,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC;QACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,OAAY,EAAE,KAAU;QAClC,MAAM,MAAM,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;QAChF,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,cAAc,CAAC,IAAS,EAAE,IAAS;QACjC,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC;IAED,kBAAkB,CAAC,KAAoB;QACrC,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC/D,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,MAAM,GAAW,cAAc,CAAC;QAEpC,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,uBAAuB,EAAE,EAAE;YACtD,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YACnF,MAAM,cAAc,GAAG,cAAc,CAAC,WAAW,EAAE,CAAC;YAEpD,MAAM,WAAW,GAAG,wCAAwC,CAAC;YAC7D,MAAM,YAAY,GAAG,SAAS,CAAC;YAE/B,IAAI,WAAW,CAAC;YAChB,IAAI,YAAY,CAAC;YACjB,IAAI,SAAS,CAAC;YAEd,QAAQ,IAAI,CAAC,UAAU,EAAE;gBACvB,KAAK,oBAAoB,CAAC,UAAU,CAAC;gBACrC,KAAK,oBAAoB,CAAC,QAAQ;oBAChC,MAAM,iBAAiB,GAAG,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;oBAE7D,IAAI,iBAAiB,GAAG,CAAC,CAAC,EAAE;wBAC1B,WAAW,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC;wBAE7D,YAAY,GAAG,cAAc,CAAC,SAAS,CAAC,iBAAiB,EAAE,iBAAiB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;wBAClG,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC,iBAAiB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;wBAE5E,MAAM,GAAG,WAAW,GAAG,WAAW,GAAG,YAAY,GAAG,YAAY,GAAG,SAAS,CAAC;qBAC9E;oBAED,MAAM;gBACR,KAAK,oBAAoB,CAAC,QAAQ;oBAChC,MAAM,qBAAqB,GAAG,cAAc,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;oBAErE,IAAI,qBAAqB,GAAG,CAAC,CAAC,EAAE;wBAC9B,WAAW,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,EAAE,qBAAqB,CAAC,CAAC;wBACjE,YAAY,GAAG,cAAc,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC;wBAE/D,MAAM,GAAG,WAAW,GAAG,WAAW,GAAG,YAAY,GAAG,YAAY,CAAC;qBAClE;oBACD,MAAM;aACT;SACF;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,uBAAuB;QACrB,OAAO,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,iBAAiB,CAAC;IAC/F,CAAC;IAED,QAAQ,CAAC,KAAK;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC;IAEO,eAAe,CAAC,QAAgB,EAAE;QACxC,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;6EA/FU,mBAAmB;6DAAnB,mBAAmB;;;;;;YCZhC,gCAAuE;YAAvC,gHAAW,8BAA0B,IAAC;YACpE,qEAaM;YAEN,qEAcM;YAEN,qEAuBM;YACR,0BAAe;;YAxDD,mCAAiB;YAiB1B,eAAsB;YAAtB,uCAAsB;YAgBtB,eAAqB;YAArB,sCAAqB;;;uFDrBb,mBAAmB;cAJ/B,SAAS;2BACE,cAAc;+DAIiB,QAAQ;kBAAhD,SAAS;mBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport { PoItemListOptionGroup } from './interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './interfaces/po-item-list-option.interface';\nimport { PoItemListBaseComponent } from './po-item-list-base.component';\nimport { PoItemListFilterMode } from '../enums/po-item-list-filter-mode.enum';\n\n@Component({\n  selector: 'po-item-list',\n  templateUrl: './po-item-list.component.html'\n})\nexport class PoItemListComponent extends PoItemListBaseComponent {\n  @ViewChild('itemList', { static: true }) itemList: ElementRef;\n\n  selectedView: PoItemListOption;\n\n  protected param;\n  protected clickListener: () => void;\n\n  constructor(private sanitized: DomSanitizer) {\n    super();\n  }\n\n  onSelectItem(itemListOption: PoItemListOption | PoItemListOptionGroup | any): void {\n    this.selectedView = itemListOption;\n    this.selectItem.emit(itemListOption);\n  }\n\n  onCheckboxItem() {\n    const option = { [this.fieldValue]: this.value, [this.fieldLabel]: this.label };\n    const selected = !this.checkboxValue;\n    this.checkboxItem.emit({ option, selected });\n  }\n\n  onComboItem(options: any, event: any) {\n    const option = { [this.fieldValue]: this.value, [this.fieldLabel]: this.label };\n    this.selectedView = options;\n    this.comboItem.emit({ ...option, event });\n  }\n\n  compareObjects(obj1: any, obj2: any) {\n    return JSON.stringify(obj1) === JSON.stringify(obj2);\n  }\n\n  onCheckboxItemEmit(event: KeyboardEvent) {\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      this.onCheckboxItem();\n    }\n  }\n\n  getLabelFormatted(label: string): SafeHtml {\n    const sanitizedLabel = this.sanitizeTagHTML(label);\n    let format: string = sanitizedLabel;\n\n    if (this.isFiltering || this.validateForOptionsLabel()) {\n      const labelInput = this.sanitizeTagHTML(this.searchValue.toString().toLowerCase());\n      const labelLowerCase = sanitizedLabel.toLowerCase();\n\n      const openTagBold = '<span class=\"po-font-text-large-bold\">';\n      const closeTagBold = '</span>';\n\n      let startString;\n      let middleString;\n      let endString;\n\n      switch (this.filterMode) {\n        case PoItemListFilterMode.startsWith:\n        case PoItemListFilterMode.contains:\n          const indexOfLabelInput = labelLowerCase.indexOf(labelInput);\n\n          if (indexOfLabelInput > -1) {\n            startString = sanitizedLabel.substring(0, indexOfLabelInput);\n\n            middleString = sanitizedLabel.substring(indexOfLabelInput, indexOfLabelInput + labelInput.length);\n            endString = sanitizedLabel.substring(indexOfLabelInput + labelInput.length);\n\n            format = startString + openTagBold + middleString + closeTagBold + endString;\n          }\n\n          break;\n        case PoItemListFilterMode.endsWith:\n          const lastIndexOfLabelInput = labelLowerCase.lastIndexOf(labelInput);\n\n          if (lastIndexOfLabelInput > -1) {\n            startString = sanitizedLabel.substring(0, lastIndexOfLabelInput);\n            middleString = sanitizedLabel.substring(lastIndexOfLabelInput);\n\n            format = startString + openTagBold + middleString + closeTagBold;\n          }\n          break;\n      }\n    }\n\n    return this.safeHtml(format);\n  }\n\n  validateForOptionsLabel(): boolean {\n    return this.comboService && this.searchValue && !this.compareCache && this.shouldMarkLetters;\n  }\n\n  safeHtml(value): SafeHtml {\n    return this.sanitized.bypassSecurityTrustHtml(value);\n  }\n\n  private sanitizeTagHTML(value: string = '') {\n    return value.replace(/\\</gm, '&lt;').replace(/\\>/g, '&gt;');\n  }\n}\n","<ng-container [ngSwitch]=\"type\" (keydown)=\"onCheckboxItemEmit($event)\">\n  <div\n    *ngSwitchDefault\n    #itemList\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__disabled]=\"disabled || !visible\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [attr.aria-disabled]=\"disabled || !visible\"\n    [attr.aria-label]=\"label\"\n    [class.po-item-list__danger]=\"danger\"\n    class=\"po-item-list po-item-list__action\"\n  >\n    <po-icon *ngIf=\"icon\" class=\"po-popup-icon-item po-icon\" [p-icon]=\"icon\"></po-icon>\n    <span class=\"po-item-list-label\">{{ label }}</span>\n  </div>\n\n  <div\n    *ngSwitchCase=\"'option'\"\n    #itemList\n    class=\"po-item-list po-item-list__option\"\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [attr.aria-label]=\"label\"\n    (click)=\"onComboItem(item, $event)\"\n  >\n    <span *ngIf=\"!template\" class=\"po-item-list-label\" [innerHTML]=\"getLabelFormatted(label)\"></span>\n\n    <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n    </ng-template>\n  </div>\n\n  <div\n    *ngSwitchCase=\"'check'\"\n    class=\"po-item-list po-item-list__check\"\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [class.po-item-list__disabled]=\"disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [attr.aria-label]=\"label\"\n    (click)=\"onCheckboxItem()\"\n    (keydown)=\"onCheckboxItemEmit($event)\"\n    (keyup)=\"onCheckboxItemEmit($event)\"\n  >\n    <po-checkbox\n      [p-disabled-tabindex]=\"true\"\n      [p-checkboxValue]=\"checkboxValue === null ? 'mixed' : checkboxValue\"\n      [p-disabled]=\"disabled\"\n      (p-change)=\"onSelectItem({label})\"\n    ></po-checkbox>\n\n    <span class=\"po-item-list__label\" *ngIf=\"!template\">{{ label }}</span>\n\n    <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n    </ng-template>\n  </div>\n</ng-container>\n"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-item-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list.component.ts","../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport { PoItemListOptionGroup } from './interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './interfaces/po-item-list-option.interface';\nimport { PoItemListBaseComponent } from './po-item-list-base.component';\nimport { PoItemListFilterMode } from '../enums/po-item-list-filter-mode.enum';\n\n@Component({\n  selector: 'po-item-list',\n  templateUrl: './po-item-list.component.html'\n})\nexport class PoItemListComponent extends PoItemListBaseComponent {\n  @ViewChild('itemList', { static: true }) itemList: ElementRef;\n\n  selectedView: PoItemListOption;\n\n  protected param;\n  protected clickListener: () => void;\n\n  constructor(private sanitized: DomSanitizer) {\n    super();\n  }\n\n  onSelectItem(itemListOption: PoItemListOption | PoItemListOptionGroup | any): void {\n    this.selectedView = itemListOption;\n    this.selectItem.emit(itemListOption);\n  }\n\n  onCheckboxItem() {\n    const option = { [this.fieldValue]: this.value, [this.fieldLabel]: this.label };\n    const selected = !this.checkboxValue;\n    this.checkboxItem.emit({ option, selected });\n  }\n\n  onComboItem(options: any, event: any) {\n    const option = { [this.fieldValue]: this.value, [this.fieldLabel]: this.label };\n    this.selectedView = options;\n    this.comboItem.emit({ ...option, event });\n  }\n\n  compareObjects(obj1: any, obj2: any) {\n    return JSON.stringify(obj1) === JSON.stringify(obj2);\n  }\n\n  onCheckboxItemEmit(event: KeyboardEvent) {\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      this.onCheckboxItem();\n    }\n  }\n\n  getLabelFormatted(label: string): SafeHtml {\n    const sanitizedLabel = this.sanitizeTagHTML(label);\n    let format: string = sanitizedLabel;\n\n    if (this.isFiltering || this.validateForOptionsLabel()) {\n      const labelInput = this.sanitizeTagHTML(this.searchValue.toString().toLowerCase());\n      const labelLowerCase = sanitizedLabel.toLowerCase();\n\n      const openTagBold = '<span class=\"po-font-text-large-bold\">';\n      const closeTagBold = '</span>';\n\n      let startString;\n      let middleString;\n      let endString;\n\n      switch (this.filterMode) {\n        case PoItemListFilterMode.startsWith:\n        case PoItemListFilterMode.contains:\n          const indexOfLabelInput = labelLowerCase.indexOf(labelInput);\n\n          if (indexOfLabelInput > -1) {\n            startString = sanitizedLabel.substring(0, indexOfLabelInput);\n\n            middleString = sanitizedLabel.substring(indexOfLabelInput, indexOfLabelInput + labelInput.length);\n            endString = sanitizedLabel.substring(indexOfLabelInput + labelInput.length);\n\n            format = startString + openTagBold + middleString + closeTagBold + endString;\n          }\n\n          break;\n        case PoItemListFilterMode.endsWith:\n          const lastIndexOfLabelInput = labelLowerCase.lastIndexOf(labelInput);\n\n          if (lastIndexOfLabelInput > -1) {\n            startString = sanitizedLabel.substring(0, lastIndexOfLabelInput);\n            middleString = sanitizedLabel.substring(lastIndexOfLabelInput);\n\n            format = startString + openTagBold + middleString + closeTagBold;\n          }\n          break;\n      }\n    }\n\n    return this.safeHtml(format);\n  }\n\n  validateForOptionsLabel(): boolean {\n    return this.comboService && this.searchValue && !this.compareCache && this.shouldMarkLetters;\n  }\n\n  safeHtml(value): SafeHtml {\n    return this.sanitized.bypassSecurityTrustHtml(value);\n  }\n\n  private sanitizeTagHTML(value: string = '') {\n    return value.replace(/\\</gm, '&lt;').replace(/\\>/g, '&gt;');\n  }\n}\n","<ng-container [ngSwitch]=\"type\" (keydown)=\"onCheckboxItemEmit($event)\">\n  <div\n    *ngSwitchDefault\n    #itemList\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__disabled]=\"disabled || !visible\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [attr.aria-disabled]=\"disabled || !visible\"\n    [attr.aria-label]=\"label\"\n    [class.po-item-list__danger]=\"danger\"\n    class=\"po-item-list po-item-list__action\"\n  >\n    <po-icon *ngIf=\"icon\" class=\"po-popup-icon-item po-icon\" [p-icon]=\"icon\"></po-icon>\n    <span class=\"po-item-list-label\">{{ label }}</span>\n  </div>\n\n  <div\n    *ngSwitchCase=\"'option'\"\n    #itemList\n    class=\"po-item-list po-item-list__option\"\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [attr.aria-label]=\"label\"\n    (click)=\"onComboItem(item, $event)\"\n  >\n    <span *ngIf=\"!template\" class=\"po-item-list-label\" [innerHTML]=\"getLabelFormatted(label)\"></span>\n\n    <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n    </ng-template>\n  </div>\n\n  <div\n    *ngSwitchCase=\"'check'\"\n    class=\"po-item-list po-item-list__check\"\n    [class.po-item-list__separator]=\"separator\"\n    [class.po-item-list__selected]=\"selected && !disabled\"\n    [class.po-item-list__disabled]=\"disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [attr.aria-label]=\"label\"\n    (click)=\"onCheckboxItem()\"\n    (keydown)=\"onCheckboxItemEmit($event)\"\n    (keyup)=\"onCheckboxItemEmit($event)\"\n  >\n    <po-checkbox\n      [p-disabled-tabindex]=\"true\"\n      [p-checkboxValue]=\"checkboxValue === null ? 'mixed' : checkboxValue\"\n      [p-disabled]=\"disabled\"\n      (click)=\"onCheckboxItem()\"\n      (p-change)=\"onSelectItem({label})\"\n    ></po-checkbox>\n\n    <span class=\"po-item-list__label\" *ngIf=\"!template\">{{ label }}</span>\n\n    <ng-template [ngTemplateOutlet]=\"template?.templateRef\" [ngTemplateOutletContext]=\"{ $implicit: templateContext }\">\n    </ng-template>\n  </div>\n</ng-container>\n"]}
|
|
@@ -66,6 +66,7 @@ function PoListBoxComponent_ng_container_4_li_4_Template(rf, ctx) { if (rf & 1)
|
|
|
66
66
|
} if (rf & 2) {
|
|
67
67
|
const item_r19 = ctx.$implicit;
|
|
68
68
|
const ctx_r15 = i0.ɵɵnextContext(2);
|
|
69
|
+
i0.ɵɵclassProp("po-listbox-item", ctx_r15.visible);
|
|
69
70
|
i0.ɵɵproperty("cdkOption", item_r19[ctx_r15.fieldLabel])("cdkOptionDisabled", ctx_r15.returnBooleanValue(item_r19, "disabled") || ctx_r15.returnBooleanValue(item_r19, "visible") === false || item_r19.options);
|
|
70
71
|
i0.ɵɵattribute("aria-selected", ctx_r15.isSelectedItem(item_r19) || item_r19.selected);
|
|
71
72
|
i0.ɵɵadvance(1);
|
|
@@ -77,7 +78,7 @@ function PoListBoxComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
|
|
|
77
78
|
i0.ɵɵelementContainerStart(0);
|
|
78
79
|
i0.ɵɵelementStart(1, "ul", 10, 11);
|
|
79
80
|
i0.ɵɵtemplate(3, PoListBoxComponent_ng_container_4_li_3_Template, 2, 4, "li", 12);
|
|
80
|
-
i0.ɵɵtemplate(4, PoListBoxComponent_ng_container_4_li_4_Template, 3,
|
|
81
|
+
i0.ɵɵtemplate(4, PoListBoxComponent_ng_container_4_li_4_Template, 3, 7, "li", 13);
|
|
81
82
|
i0.ɵɵelementEnd();
|
|
82
83
|
i0.ɵɵelementContainerEnd();
|
|
83
84
|
} if (rf & 2) {
|
|
@@ -292,7 +293,7 @@ export class PoListBoxComponent extends PoListBoxBaseComponent {
|
|
|
292
293
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.listbox = _t.first);
|
|
293
294
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.listboxItemList = _t.first);
|
|
294
295
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.searchElement = _t.first);
|
|
295
|
-
} }, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c4, decls: 12, vars: 8, consts: [[1, "po-listbox", 3, "hidden"], ["listbox", ""], [3, "p-literals", "p-field-value", "p-placeholder", "p-change", 4, "ngIf"], [4, "ngIf", "ngIfElse"], ["class", "po-text-center", 4, "ngIf"], ["scrollLoadingTemplate", ""], ["defaultLoadingTemplate", ""], ["noDataTemplate", ""], [3, "p-literals", "p-field-value", "p-placeholder", "p-change"], ["searchElement", ""], ["cdkListbox", "", 1, "po-listbox-list", 3, "cdkListboxMultiple"], ["listboxItemList", ""], ["cdkOption", "selectAll", 3, "click", "keydown", 4, "ngIf"], [
|
|
296
|
+
} }, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c4, decls: 12, vars: 8, consts: [[1, "po-listbox", 3, "hidden"], ["listbox", ""], [3, "p-literals", "p-field-value", "p-placeholder", "p-change", 4, "ngIf"], [4, "ngIf", "ngIfElse"], ["class", "po-text-center", 4, "ngIf"], ["scrollLoadingTemplate", ""], ["defaultLoadingTemplate", ""], ["noDataTemplate", ""], [3, "p-literals", "p-field-value", "p-placeholder", "p-change"], ["searchElement", ""], ["cdkListbox", "", 1, "po-listbox-list", 3, "cdkListboxMultiple"], ["listboxItemList", ""], ["cdkOption", "selectAll", 3, "click", "keydown", 4, "ngIf"], [3, "po-listbox-item", "cdkOption", "cdkOptionDisabled", "click", "keydown", 4, "ngFor", "ngForOf"], ["cdkOption", "selectAll", 3, "click", "keydown"], ["p-type", "check", "p-value", "selectAll", 3, "p-selected", "p-label", "p-checkbox-value"], [3, "cdkOption", "cdkOptionDisabled", "click", "keydown"], ["class", "po-combo-item-title", 4, "ngIf"], [3, "p-disabled", "p-visible", "p-checkbox-value", "p-label", "p-value", "p-selected", "p-separator", "p-danger", "p-icon", "p-type", "p-item", "p-field-value", "p-field-label", "p-template", "p-template-context", "p-search-value", "p-filter-mode", "p-filtering", "p-should-mark-letter", "p-compare-cache", "p-combo-service", "p-selectcheckbox-item", "p-selectcombo-item", "p-select-item", 4, "ngIf"], [1, "po-combo-item-title"], [3, "p-disabled", "p-visible", "p-checkbox-value", "p-label", "p-value", "p-selected", "p-separator", "p-danger", "p-icon", "p-type", "p-item", "p-field-value", "p-field-label", "p-template", "p-template-context", "p-search-value", "p-filter-mode", "p-filtering", "p-should-mark-letter", "p-compare-cache", "p-combo-service", "p-selectcheckbox-item", "p-selectcombo-item", "p-select-item"], [1, "po-text-center"], [4, "ngIf", "ngIfThen", "ngIfElse"], [1, "po-listbox-container-loading-scroll"], [1, "po-listbox-container-loading-default"], ["class", "po-listbox-container-no-data po-text-center", 4, "ngIf"], [1, "po-listbox-container-no-data", "po-text-center"]], template: function PoListBoxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
296
297
|
i0.ɵɵprojectionDef(_c3);
|
|
297
298
|
i0.ɵɵelementStart(0, "div", 0, 1);
|
|
298
299
|
i0.ɵɵprojection(2);
|
|
@@ -318,7 +319,7 @@ export class PoListBoxComponent extends PoListBoxBaseComponent {
|
|
|
318
319
|
}
|
|
319
320
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoListBoxComponent, [{
|
|
320
321
|
type: Component,
|
|
321
|
-
args: [{ selector: 'po-listbox', template: "<div\n #listbox\n class=\"po-listbox\"\n [class.po-listbox-check]=\"type === 'check' || type === 'option'\"\n [attr.data-type]=\"type\"\n [hidden]=\"visible\"\n>\n <ng-content select=\"[p-popup-header-template]\"></ng-content>\n\n <po-search-list\n #searchElement\n *ngIf=\"!hideSearch && type === 'check'\"\n (p-change)=\"callChangeSearch($event)\"\n [p-literals]=\"literalSearch\"\n [p-field-value]=\"fieldValueSearch\"\n [p-placeholder]=\"placeholderSearch\"\n ></po-search-list>\n\n <ng-container *ngIf=\"checkTemplate(); else noDataTemplate\">\n <ul #listboxItemList cdkListbox [cdkListboxMultiple]=\"type === 'check'\" class=\"po-listbox-list\">\n <li\n cdkOption=\"selectAll\"\n *ngIf=\"type === 'check' && items.length && !searchElement?.inputValue && !hideSelectAll\"\n [attr.aria-checked]=\"checkboxAllValue === null ? 'mixed' : checkboxAllValue\"\n (click)=\"changeAll.emit()\"\n (keydown)=\"changeAllEmit($event)\"\n >\n <po-item-list\n [p-selected]=\"checkboxAllValue\"\n p-type=\"check\"\n [p-label]=\"literals.selectAll\"\n p-value=\"selectAll\"\n [p-checkbox-value]=\"checkboxAllValue\"\n >\n </po-item-list>\n </li>\n <li\n class
|
|
322
|
+
args: [{ selector: 'po-listbox', template: "<div\n #listbox\n class=\"po-listbox\"\n [class.po-listbox-check]=\"type === 'check' || type === 'option'\"\n [attr.data-type]=\"type\"\n [hidden]=\"visible\"\n>\n <ng-content select=\"[p-popup-header-template]\"></ng-content>\n\n <po-search-list\n #searchElement\n *ngIf=\"!hideSearch && type === 'check'\"\n (p-change)=\"callChangeSearch($event)\"\n [p-literals]=\"literalSearch\"\n [p-field-value]=\"fieldValueSearch\"\n [p-placeholder]=\"placeholderSearch\"\n ></po-search-list>\n\n <ng-container *ngIf=\"checkTemplate(); else noDataTemplate\">\n <ul #listboxItemList cdkListbox [cdkListboxMultiple]=\"type === 'check'\" class=\"po-listbox-list\">\n <li\n cdkOption=\"selectAll\"\n *ngIf=\"type === 'check' && items.length && !searchElement?.inputValue && !hideSelectAll\"\n [attr.aria-checked]=\"checkboxAllValue === null ? 'mixed' : checkboxAllValue\"\n (click)=\"changeAll.emit()\"\n (keydown)=\"changeAllEmit($event)\"\n >\n <po-item-list\n [p-selected]=\"checkboxAllValue\"\n p-type=\"check\"\n [p-label]=\"literals.selectAll\"\n p-value=\"selectAll\"\n [p-checkbox-value]=\"checkboxAllValue\"\n >\n </po-item-list>\n </li>\n <li\n [class.po-listbox-item]=\"visible\"\n *ngFor=\"let item of items\"\n [cdkOption]=\"item[fieldLabel]\"\n [cdkOptionDisabled]=\"\n returnBooleanValue(item, 'disabled') || returnBooleanValue(item, 'visible') === false || item.options\n \"\n [attr.aria-selected]=\"isSelectedItem(item) || item.selected\"\n (click)=\"onSelectItem(item)\"\n (keydown)=\"onKeyDown(item, $event)\"\n >\n <label *ngIf=\"item.options\" class=\"po-combo-item-title\">\n {{ item.label }}\n </label>\n <po-item-list\n *ngIf=\"returnBooleanValue(item, 'visible') !== false && !item.options\"\n [p-disabled]=\"returnBooleanValue(item, 'disabled')\"\n [p-visible]=\"returnBooleanValue(item, 'visible')\"\n [p-checkbox-value]=\"isSelectedItem(item)\"\n [attr.data-item-list]=\"item | json\"\n [p-label]=\"item[fieldLabel]\"\n [p-value]=\"item[fieldValue]\"\n [p-selected]=\"isSelectedItem(item) || item.selected\"\n [p-separator]=\"item.separator\"\n [p-danger]=\"item.danger || item.type === 'danger'\"\n [p-icon]=\"item.icon\"\n [p-type]=\"type\"\n [p-item]=\"item\"\n [p-field-value]=\"fieldValue\"\n [p-field-label]=\"fieldLabel\"\n [p-template]=\"template\"\n [p-template-context]=\"item\"\n (p-selectcheckbox-item)=\"checkboxClicked($event)\"\n (p-selectcombo-item)=\"optionClicked($event)\"\n (p-select-item)=\"onSelectCheckBoxItem(item)\"\n [p-search-value]=\"searchValue\"\n [p-filter-mode]=\"filterMode\"\n [p-filtering]=\"isFiltering\"\n [p-should-mark-letter]=\"shouldMarkLetters\"\n [p-compare-cache]=\"compareCache\"\n [p-combo-service]=\"comboService\"\n ></po-item-list>\n </li>\n </ul>\n </ng-container>\n\n <div *ngIf=\"isServerSearching && type !== 'action'\" class=\"po-text-center\">\n <ng-container *ngIf=\"infiniteLoading; then scrollLoadingTemplate; else defaultLoadingTemplate\"></ng-container>\n </div>\n\n <ng-template #scrollLoadingTemplate>\n <po-loading-overlay class=\"po-listbox-container-loading-scroll\"></po-loading-overlay>\n </ng-template>\n\n <ng-template #defaultLoadingTemplate>\n <po-loading class=\"po-listbox-container-loading-default\"></po-loading>\n </ng-template>\n\n <ng-template #noDataTemplate>\n <div\n *ngIf=\"!items.length && !isServerSearching && type !== 'action'\"\n class=\"po-listbox-container-no-data po-text-center\"\n >\n <span> {{ literals.noItems }}</span>\n </div>\n </ng-template>\n</div>\n" }]
|
|
322
323
|
}], function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.PoLanguageService }, { type: i2.Router }, { type: i0.ChangeDetectorRef }]; }, { listbox: [{
|
|
323
324
|
type: ViewChild,
|
|
324
325
|
args: ['listbox', { static: true }]
|
|
@@ -329,4 +330,4 @@ export class PoListBoxComponent extends PoListBoxBaseComponent {
|
|
|
329
330
|
type: ViewChild,
|
|
330
331
|
args: ['searchElement']
|
|
331
332
|
}] }); })();
|
|
332
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-listbox.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox.component.ts","../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,EAMT,SAAS,EAEV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAKrE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAE9E,OAAO,EAA4B,YAAY,EAAE,SAAS,EAAS,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;ICb9E,4CAOC;IAJC,gMAAY,eAAA,gCAAwB,CAAA,IAAC;IAItC,iBAAiB;;;IAHhB,iDAA4B,0CAAA,2CAAA;;;;IAO1B,8BAMC;IAFC,4KAAS,eAAA,wBAAgB,CAAA,IAAC,yKACf,eAAA,6BAAqB,CAAA,IADN;IAG1B,mCAOe;IACjB,iBAAK;;;IAZH,sGAA4E;IAK1E,eAA+B;IAA/B,qDAA+B,uCAAA,8CAAA;;;IAmBjC,iCAAwD;IACtD,YACF;IAAA,iBAAQ;;;IADN,eACF;IADE,+CACF;;;;IACA,wCA2BC;IATC,2OAAyB,eAAA,+BAAuB,CAAA,IAAC,wNAC3B,eAAA,6BAAqB,CAAA,IADM,uPAEhC,eAAA,sCAA0B,CAAA,IAFM;;IASlD,iBAAe;;;;IAzBd,6EAAmD,8DAAA,sDAAA,yCAAA,yCAAA,qEAAA,mCAAA,2DAAA,yBAAA,wBAAA,oBAAA,qCAAA,qCAAA,gCAAA,gCAAA,uCAAA,qCAAA,oCAAA,mDAAA,yCAAA,yCAAA;IAGnD,iEAAmC;;;;IAnBvC,8BAUC;IAFC,wOAAS,eAAA,8BAAkB,CAAA,IAAC,qOACjB,eAAA,mCAAuB,CAAA,IADN;IAG5B,4FAEQ;IACR,2GA2BgB;IAClB,iBAAK;;;;IAvCH,wDAA8B,wJAAA;IAI9B,sFAA4D;IAIpD,eAAkB;IAAlB,uCAAkB;IAIvB,eAAoE;IAApE,qGAAoE;;;IAjC7E,6BAA2D;IACzD,kCAAgG;IAC9F,iFAeK;IACL,iFA0CK;IACP,iBAAK;IACP,0BAAe;;;IA7DmB,eAAuC;IAAvC,4DAAuC;IAGlE,eAAsF;IAAtF,0KAAsF;IAgBtE,eAAQ;IAAR,sCAAQ;;;IA6C7B,wBAA8G;;;IADhH,+BAA2E;IACzE,4FAA8G;IAChH,iBAAM;;;;;IADW,eAAuB;IAAvB,6CAAuB,iBAAA,iBAAA;;;IAItC,yCAAqF;;;IAIrF,iCAAsE;;;IAItE,+BAGC,WAAA;IACQ,YAAsB;IAAA,iBAAO,EAAA;;;IAA7B,eAAsB;IAAtB,wDAAsB;;;IAJ/B,mFAKM;;;IAJH,oGAA8D;;;;ADpErE,MAAM,OAAO,kBAAmB,SAAQ,sBAAsB;IASnD;IACC;IAEA;IACA;IAZ8B,OAAO,CAAa;IACX,eAAe,CAAa;IACjD,aAAa,CAAwB;IAEzD,YAAY,CAAkB;IAC9B,uBAAuB,CAAe;IAE9C,YACS,OAAmB,EAClB,QAAmB,EAC3B,eAAkC,EAC1B,MAAc,EACd,cAAiC;QAEzC,KAAK,CAAC,eAAe,CAAC,CAAC;QANhB,YAAO,GAAP,OAAO,CAAY;QAClB,aAAQ,GAAR,QAAQ,CAAW;QAEnB,WAAM,GAAN,MAAM,CAAQ;QACd,mBAAc,GAAd,cAAc,CAAmB;IAG3C,CAAC;IAED,eAAe;QACb,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;IAC9C,CAAC;IAED,WAAW,CAAC,OAAuB;QACjC,IAAI,OAAO,EAAE,KAAK,EAAE;YAClB,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;QAED,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YACvC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,uBAAuB,IAAI,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE;YAC5E,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;SAC5C;IACH,CAAC;IAED,YAAY,CAAC,cAA8D;QACzE,MAAM,UAAU,GACd,cAAc,CAAC,cAAc,CAAC,UAAU,CAAC;YACzC,cAAc,CAAC,QAAQ,KAAK,IAAI;YAChC,cAAc,CAAC,QAAQ,KAAK,SAAS;YACnC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,UAAU,CAAC;YACrD,CAAC,CAAC,KAAK,CAAC;QACZ,MAAM,SAAS,GACb,cAAc,CAAC,cAAc,CAAC,SAAS,CAAC;YACxC,cAAc,CAAC,OAAO,KAAK,IAAI;YAC/B,cAAc,CAAC,OAAO,KAAK,SAAS;YAClC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,SAAS,CAAC;YACpD,CAAC,CAAC,IAAI,CAAC;QAEX,IAAI,cAAc,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,UAAU,IAAI,SAAS,EAAE;YACvE,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,cAAc,CAAC,CAAC;SACrD;QAED,IAAI,cAAc,IAAI,cAAc,CAAC,GAAG,IAAI,CAAC,UAAU,IAAI,SAAS,EAAE;YACpE,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SACzC;IACH,CAAC;IAED,SAAS,CAAC,cAA8D,EAAE,KAAqB;QAC7F,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC/D,QAAQ,IAAI,CAAC,IAAI,EAAE;gBACjB,KAAK,OAAO;oBACV,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;oBAC1C,MAAM;gBACR,KAAK,QAAQ;oBACX,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;oBACnC,MAAM;gBACR,KAAK,QAAQ;oBACX,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;oBAClC,MAAM;aACT;SACF;QAED,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE;YAC9D,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;SACxB;IACH,CAAC;IAED,eAAe,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE;QAClC,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;YACzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;SACxC;IACH,CAAC;IAED,aAAa,CAAC,MAAW;QACvB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC1B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CACvB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,CAC3G,CAAC;YACF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;SACtC;IACH,CAAC;IAED,oBAAoB,CAAC,MAAM;QACzB,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC9C,IAAI,CAAC,eAAe,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,cAAc,CAAC,MAAM;QACnB,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IAC9G,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACvB;IACH,CAAC;IAED,gBAAgB,CAAC,KAAK;QACpB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,sBAAsB,CAAC,EAAE,MAAM,EAAE;QAC/B,MAAM,cAAc,GAAG,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,SAAS,CAAC;QAC9D,IAAI,cAAc,IAAI,MAAM,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,sBAAsB,GAAG,GAAG,CAAC,EAAE;YAC/E,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;SAClC;IACH,CAAC;IAED,cAAc,CAAC,gBAA6B;QAC1C,OAAO,SAAS,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC7C,CAAC;IAES,mBAAmB;QAC3B,IAAI,IAAI,CAAC,iBAAiB,EAAE,EAAE;YAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,YAAY,CAAC;IACjF,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,cAAc,EAAE;YACrC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;SAC1B;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;SACrD;IACH,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;QAE7E,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACjE,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IAES,kBAAkB,CAAC,cAAmB,EAAE,QAAgB;QAChE,OAAO,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC;YACnD,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,cAAc,CAAC;YACxD,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAEO,mBAAmB;QACzB,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;QACtC,IAAI,WAAW,GAAG,CAAC,EAAE;YACnB,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBAC7C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,WAAW,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;aAC9F;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,WAAW,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;aACzF;SACF;IACH,CAAC;IAEO,OAAO,CAAC,GAAW;QACzB,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE;YACvB,OAAO,gBAAgB,CAAC,GAAG,CAAC,CAAC;SAC9B;QAED,IAAI,GAAG,EAAE;YACP,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;SACpC;IACH,CAAC;4EAzLU,kBAAkB;6DAAlB,kBAAkB;;;;;;;;;;;YC5B/B,iCAMC;YACC,kBAA4D;YAE5D,yFAOkB;YAElB,qFA8De;YAEf,mEAEM;YAEN,oHAEc;YAEd,oHAEc;YAEd,sHAOc;YAChB,iBAAM;;;YAnGJ,iFAAgE;YAEhE,oCAAkB;YADlB,qCAAuB;YAOpB,eAAqC;YAArC,8DAAqC;YAOzB,eAAuB;YAAvB,0CAAuB,iBAAA;YAgEhC,eAA4C;YAA5C,qEAA4C;;;uFDtDvC,kBAAkB;cAJ9B,SAAS;2BACE,YAAY;0KAIkB,OAAO;kBAA9C,SAAS;mBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;YACW,eAAe;kBAA/D,SAAS;mBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACnB,aAAa;kBAAxC,SAAS;mBAAC,eAAe","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport { PoListBoxBaseComponent } from './po-listbox-base.component';\n\nimport { PoItemListOptionGroup } from './po-item-list/interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './po-item-list/interfaces/po-item-list-option.interface';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { isExternalLink, isTypeof, openExternalLink } from '../../utils/util';\nimport { PoSearchListComponent } from './po-search-list/po-search-list.component';\nimport { Observable, Subscription, debounceTime, fromEvent, merge } from 'rxjs';\n\n@Component({\n  selector: 'po-listbox',\n  templateUrl: './po-listbox.component.html'\n})\nexport class PoListBoxComponent extends PoListBoxBaseComponent implements AfterViewInit, OnChanges, OnDestroy {\n  @ViewChild('listbox', { static: true }) listbox: ElementRef;\n  @ViewChild('listboxItemList', { static: false }) listboxItemList: ElementRef;\n  @ViewChild('searchElement') searchElement: PoSearchListComponent;\n\n  private scrollEvent$: Observable<any>;\n  private subscriptionScrollEvent: Subscription;\n\n  constructor(\n    public element: ElementRef,\n    private renderer: Renderer2,\n    languageService: PoLanguageService,\n    private router: Router,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    super(languageService);\n  }\n\n  ngAfterViewInit(): void {\n    this.setListBoxMaxHeight();\n    this.listboxItemList?.nativeElement.focus();\n  }\n\n  ngOnChanges(changes?: SimpleChanges): void {\n    if (changes?.items) {\n      this.setListBoxMaxHeight();\n    }\n\n    if (this.visible && this.infiniteScroll) {\n      this.checkInfiniteScroll();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subscriptionScrollEvent && this.subscriptionScrollEvent.unsubscribe) {\n      this.subscriptionScrollEvent.unsubscribe();\n    }\n  }\n\n  onSelectItem(itemListAction: PoItemListOption | PoItemListOptionGroup | any) {\n    const isDisabled =\n      itemListAction.hasOwnProperty('disabled') &&\n      itemListAction.disabled !== null &&\n      itemListAction.disabled !== undefined\n        ? this.returnBooleanValue(itemListAction, 'disabled')\n        : false;\n    const isVisible =\n      itemListAction.hasOwnProperty('visible') &&\n      itemListAction.visible !== null &&\n      itemListAction.visible !== undefined\n        ? this.returnBooleanValue(itemListAction, 'visible')\n        : true;\n\n    if (itemListAction && itemListAction.action && !isDisabled && isVisible) {\n      itemListAction.action(this.param || itemListAction);\n    }\n\n    if (itemListAction && itemListAction.url && !isDisabled && isVisible) {\n      return this.openUrl(itemListAction.url);\n    }\n  }\n\n  onKeyDown(itemListAction: PoItemListOption | PoItemListOptionGroup | any, event?: KeyboardEvent) {\n    event.preventDefault();\n\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      switch (this.type) {\n        case 'check':\n          this.onSelectCheckBoxItem(itemListAction);\n          break;\n        case 'option':\n          this.optionClicked(itemListAction);\n          break;\n        case 'action':\n          this.onSelectItem(itemListAction);\n          break;\n      }\n    }\n\n    if ((event && event.code === 'Escape') || event.code === 'Tab') {\n      this.closeEvent.emit();\n    }\n  }\n\n  checkboxClicked({ option, selected }) {\n    if (this.type === 'check') {\n      this.change.emit({ selected, option });\n    }\n  }\n\n  optionClicked(option: any) {\n    if (this.type === 'option') {\n      this.items.filter(item =>\n        item[this.fieldValue] === option[this.fieldValue] ? (item['selected'] = true) : (item['selected'] = false)\n      );\n      this.selectCombo.emit({ ...option });\n    }\n  }\n\n  onSelectCheckBoxItem(option) {\n    const selected = !this.isSelectedItem(option);\n    this.checkboxClicked({ option, selected });\n  }\n\n  isSelectedItem(option) {\n    return this.selectedOptions.some(selectedItem => selectedItem[this.fieldValue] === option[this.fieldValue]);\n  }\n\n  changeAllEmit(event: KeyboardEvent) {\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      this.changeAll.emit();\n    }\n  }\n\n  callChangeSearch(event) {\n    this.changeSearch.emit(event);\n  }\n\n  showMoreInfiniteScroll({ target }): void {\n    const scrollPosition = target.offsetHeight + target.scrollTop;\n    if (scrollPosition >= target.scrollHeight * (this.infiniteScrollDistance / 110)) {\n      this.UpdateInfiniteScroll.emit();\n    }\n  }\n\n  scrollListener(componentListner: HTMLElement): Observable<any> {\n    return fromEvent(componentListner, 'scroll').pipe(debounceTime(100));\n  }\n\n  setFocus() {\n    this.listboxItemList.nativeElement.focus();\n  }\n\n  protected checkInfiniteScroll(): void {\n    if (this.hasInfiniteScroll()) {\n      this.includeInfiniteScroll();\n    }\n  }\n\n  private hasInfiniteScroll(): boolean {\n    this.changeDetector.detectChanges();\n    return this.infiniteScroll && this.listboxItemList?.nativeElement.scrollHeight;\n  }\n\n  checkTemplate() {\n    if (this.cache || this.infiniteScroll) {\n      return this.items.length;\n    } else {\n      return !this.isServerSearching && this.items.length;\n    }\n  }\n\n  private includeInfiniteScroll(): void {\n    this.scrollEvent$ = this.scrollListener(this.listboxItemList?.nativeElement);\n\n    this.subscriptionScrollEvent = this.scrollEvent$.subscribe(event => {\n      this.showMoreInfiniteScroll(event);\n    });\n  }\n\n  protected returnBooleanValue(itemListAction: any, property: string) {\n    return isTypeof(itemListAction[property], 'function')\n      ? itemListAction[property](this.param || itemListAction)\n      : itemListAction[property];\n  }\n\n  private setListBoxMaxHeight(): void {\n    const itemsLength = this.items.length;\n    if (itemsLength > 6) {\n      if (this.type === 'check' && !this.hideSearch) {\n        this.renderer.setStyle(this.listbox.nativeElement, 'maxHeight', `${44 * 6 - 44 / 3 + 60}px`);\n      } else {\n        this.renderer.setStyle(this.listbox.nativeElement, 'maxHeight', `${44 * 6 - 44 / 3}px`);\n      }\n    }\n  }\n\n  private openUrl(url: string) {\n    if (isExternalLink(url)) {\n      return openExternalLink(url);\n    }\n\n    if (url) {\n      return this.router.navigate([url]);\n    }\n  }\n}\n","<div\n  #listbox\n  class=\"po-listbox\"\n  [class.po-listbox-check]=\"type === 'check' || type === 'option'\"\n  [attr.data-type]=\"type\"\n  [hidden]=\"visible\"\n>\n  <ng-content select=\"[p-popup-header-template]\"></ng-content>\n\n  <po-search-list\n    #searchElement\n    *ngIf=\"!hideSearch && type === 'check'\"\n    (p-change)=\"callChangeSearch($event)\"\n    [p-literals]=\"literalSearch\"\n    [p-field-value]=\"fieldValueSearch\"\n    [p-placeholder]=\"placeholderSearch\"\n  ></po-search-list>\n\n  <ng-container *ngIf=\"checkTemplate(); else noDataTemplate\">\n    <ul #listboxItemList cdkListbox [cdkListboxMultiple]=\"type === 'check'\" class=\"po-listbox-list\">\n      <li\n        cdkOption=\"selectAll\"\n        *ngIf=\"type === 'check' && items.length && !searchElement?.inputValue && !hideSelectAll\"\n        [attr.aria-checked]=\"checkboxAllValue === null ? 'mixed' : checkboxAllValue\"\n        (click)=\"changeAll.emit()\"\n        (keydown)=\"changeAllEmit($event)\"\n      >\n        <po-item-list\n          [p-selected]=\"checkboxAllValue\"\n          p-type=\"check\"\n          [p-label]=\"literals.selectAll\"\n          p-value=\"selectAll\"\n          [p-checkbox-value]=\"checkboxAllValue\"\n        >\n        </po-item-list>\n      </li>\n      <li\n        class=\"po-listbox-item\"\n        *ngFor=\"let item of items\"\n        [cdkOption]=\"item[fieldLabel]\"\n        [cdkOptionDisabled]=\"\n          returnBooleanValue(item, 'disabled') || returnBooleanValue(item, 'visible') === false || item.options\n        \"\n        [attr.aria-selected]=\"isSelectedItem(item) || item.selected\"\n        (click)=\"onSelectItem(item)\"\n        (keydown)=\"onKeyDown(item, $event)\"\n      >\n        <label *ngIf=\"item.options\" class=\"po-combo-item-title\">\n          {{ item.label }}\n        </label>\n        <po-item-list\n          *ngIf=\"returnBooleanValue(item, 'visible') !== false && !item.options\"\n          [p-disabled]=\"returnBooleanValue(item, 'disabled')\"\n          [p-visible]=\"returnBooleanValue(item, 'visible')\"\n          [p-checkbox-value]=\"isSelectedItem(item)\"\n          [attr.data-item-list]=\"item | json\"\n          [p-label]=\"item[fieldLabel]\"\n          [p-value]=\"item[fieldValue]\"\n          [p-selected]=\"isSelectedItem(item) || item.selected\"\n          [p-separator]=\"item.separator\"\n          [p-danger]=\"item.danger || item.type === 'danger'\"\n          [p-icon]=\"item.icon\"\n          [p-type]=\"type\"\n          [p-item]=\"item\"\n          [p-field-value]=\"fieldValue\"\n          [p-field-label]=\"fieldLabel\"\n          [p-template]=\"template\"\n          [p-template-context]=\"item\"\n          (p-selectcheckbox-item)=\"checkboxClicked($event)\"\n          (p-selectcombo-item)=\"optionClicked($event)\"\n          (p-select-item)=\"onSelectCheckBoxItem(item)\"\n          [p-search-value]=\"searchValue\"\n          [p-filter-mode]=\"filterMode\"\n          [p-filtering]=\"isFiltering\"\n          [p-should-mark-letter]=\"shouldMarkLetters\"\n          [p-compare-cache]=\"compareCache\"\n          [p-combo-service]=\"comboService\"\n        ></po-item-list>\n      </li>\n    </ul>\n  </ng-container>\n\n  <div *ngIf=\"isServerSearching && type !== 'action'\" class=\"po-text-center\">\n    <ng-container *ngIf=\"infiniteLoading; then scrollLoadingTemplate; else defaultLoadingTemplate\"></ng-container>\n  </div>\n\n  <ng-template #scrollLoadingTemplate>\n    <po-loading-overlay class=\"po-listbox-container-loading-scroll\"></po-loading-overlay>\n  </ng-template>\n\n  <ng-template #defaultLoadingTemplate>\n    <po-loading class=\"po-listbox-container-loading-default\"></po-loading>\n  </ng-template>\n\n  <ng-template #noDataTemplate>\n    <div\n      *ngIf=\"!items.length && !isServerSearching && type !== 'action'\"\n      class=\"po-listbox-container-no-data po-text-center\"\n    >\n      <span> {{ literals.noItems }}</span>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-listbox.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox.component.ts","../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport { PoListBoxBaseComponent } from './po-listbox-base.component';\n\nimport { PoItemListOptionGroup } from './po-item-list/interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './po-item-list/interfaces/po-item-list-option.interface';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { isExternalLink, isTypeof, openExternalLink } from '../../utils/util';\nimport { PoSearchListComponent } from './po-search-list/po-search-list.component';\nimport { Observable, Subscription, debounceTime, fromEvent, merge } from 'rxjs';\n\n@Component({\n  selector: 'po-listbox',\n  templateUrl: './po-listbox.component.html'\n})\nexport class PoListBoxComponent extends PoListBoxBaseComponent implements AfterViewInit, OnChanges, OnDestroy {\n  @ViewChild('listbox', { static: true }) listbox: ElementRef;\n  @ViewChild('listboxItemList', { static: false }) listboxItemList: ElementRef;\n  @ViewChild('searchElement') searchElement: PoSearchListComponent;\n\n  private scrollEvent$: Observable<any>;\n  private subscriptionScrollEvent: Subscription;\n\n  constructor(\n    public element: ElementRef,\n    private renderer: Renderer2,\n    languageService: PoLanguageService,\n    private router: Router,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    super(languageService);\n  }\n\n  ngAfterViewInit(): void {\n    this.setListBoxMaxHeight();\n    this.listboxItemList?.nativeElement.focus();\n  }\n\n  ngOnChanges(changes?: SimpleChanges): void {\n    if (changes?.items) {\n      this.setListBoxMaxHeight();\n    }\n\n    if (this.visible && this.infiniteScroll) {\n      this.checkInfiniteScroll();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subscriptionScrollEvent && this.subscriptionScrollEvent.unsubscribe) {\n      this.subscriptionScrollEvent.unsubscribe();\n    }\n  }\n\n  onSelectItem(itemListAction: PoItemListOption | PoItemListOptionGroup | any) {\n    const isDisabled =\n      itemListAction.hasOwnProperty('disabled') &&\n      itemListAction.disabled !== null &&\n      itemListAction.disabled !== undefined\n        ? this.returnBooleanValue(itemListAction, 'disabled')\n        : false;\n    const isVisible =\n      itemListAction.hasOwnProperty('visible') &&\n      itemListAction.visible !== null &&\n      itemListAction.visible !== undefined\n        ? this.returnBooleanValue(itemListAction, 'visible')\n        : true;\n\n    if (itemListAction && itemListAction.action && !isDisabled && isVisible) {\n      itemListAction.action(this.param || itemListAction);\n    }\n\n    if (itemListAction && itemListAction.url && !isDisabled && isVisible) {\n      return this.openUrl(itemListAction.url);\n    }\n  }\n\n  onKeyDown(itemListAction: PoItemListOption | PoItemListOptionGroup | any, event?: KeyboardEvent) {\n    event.preventDefault();\n\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      switch (this.type) {\n        case 'check':\n          this.onSelectCheckBoxItem(itemListAction);\n          break;\n        case 'option':\n          this.optionClicked(itemListAction);\n          break;\n        case 'action':\n          this.onSelectItem(itemListAction);\n          break;\n      }\n    }\n\n    if ((event && event.code === 'Escape') || event.code === 'Tab') {\n      this.closeEvent.emit();\n    }\n  }\n\n  checkboxClicked({ option, selected }) {\n    if (this.type === 'check') {\n      this.change.emit({ selected, option });\n    }\n  }\n\n  optionClicked(option: any) {\n    if (this.type === 'option') {\n      this.items.filter(item =>\n        item[this.fieldValue] === option[this.fieldValue] ? (item['selected'] = true) : (item['selected'] = false)\n      );\n      this.selectCombo.emit({ ...option });\n    }\n  }\n\n  onSelectCheckBoxItem(option) {\n    const selected = !this.isSelectedItem(option);\n    this.checkboxClicked({ option, selected });\n  }\n\n  isSelectedItem(option) {\n    return this.selectedOptions.some(selectedItem => selectedItem[this.fieldValue] === option[this.fieldValue]);\n  }\n\n  changeAllEmit(event: KeyboardEvent) {\n    if ((event && event.code === 'Enter') || event.code === 'Space') {\n      this.changeAll.emit();\n    }\n  }\n\n  callChangeSearch(event) {\n    this.changeSearch.emit(event);\n  }\n\n  showMoreInfiniteScroll({ target }): void {\n    const scrollPosition = target.offsetHeight + target.scrollTop;\n    if (scrollPosition >= target.scrollHeight * (this.infiniteScrollDistance / 110)) {\n      this.UpdateInfiniteScroll.emit();\n    }\n  }\n\n  scrollListener(componentListner: HTMLElement): Observable<any> {\n    return fromEvent(componentListner, 'scroll').pipe(debounceTime(100));\n  }\n\n  setFocus() {\n    this.listboxItemList.nativeElement.focus();\n  }\n\n  protected checkInfiniteScroll(): void {\n    if (this.hasInfiniteScroll()) {\n      this.includeInfiniteScroll();\n    }\n  }\n\n  private hasInfiniteScroll(): boolean {\n    this.changeDetector.detectChanges();\n    return this.infiniteScroll && this.listboxItemList?.nativeElement.scrollHeight;\n  }\n\n  checkTemplate() {\n    if (this.cache || this.infiniteScroll) {\n      return this.items.length;\n    } else {\n      return !this.isServerSearching && this.items.length;\n    }\n  }\n\n  private includeInfiniteScroll(): void {\n    this.scrollEvent$ = this.scrollListener(this.listboxItemList?.nativeElement);\n\n    this.subscriptionScrollEvent = this.scrollEvent$.subscribe(event => {\n      this.showMoreInfiniteScroll(event);\n    });\n  }\n\n  protected returnBooleanValue(itemListAction: any, property: string) {\n    return isTypeof(itemListAction[property], 'function')\n      ? itemListAction[property](this.param || itemListAction)\n      : itemListAction[property];\n  }\n\n  private setListBoxMaxHeight(): void {\n    const itemsLength = this.items.length;\n    if (itemsLength > 6) {\n      if (this.type === 'check' && !this.hideSearch) {\n        this.renderer.setStyle(this.listbox.nativeElement, 'maxHeight', `${44 * 6 - 44 / 3 + 60}px`);\n      } else {\n        this.renderer.setStyle(this.listbox.nativeElement, 'maxHeight', `${44 * 6 - 44 / 3}px`);\n      }\n    }\n  }\n\n  private openUrl(url: string) {\n    if (isExternalLink(url)) {\n      return openExternalLink(url);\n    }\n\n    if (url) {\n      return this.router.navigate([url]);\n    }\n  }\n}\n","<div\n  #listbox\n  class=\"po-listbox\"\n  [class.po-listbox-check]=\"type === 'check' || type === 'option'\"\n  [attr.data-type]=\"type\"\n  [hidden]=\"visible\"\n>\n  <ng-content select=\"[p-popup-header-template]\"></ng-content>\n\n  <po-search-list\n    #searchElement\n    *ngIf=\"!hideSearch && type === 'check'\"\n    (p-change)=\"callChangeSearch($event)\"\n    [p-literals]=\"literalSearch\"\n    [p-field-value]=\"fieldValueSearch\"\n    [p-placeholder]=\"placeholderSearch\"\n  ></po-search-list>\n\n  <ng-container *ngIf=\"checkTemplate(); else noDataTemplate\">\n    <ul #listboxItemList cdkListbox [cdkListboxMultiple]=\"type === 'check'\" class=\"po-listbox-list\">\n      <li\n        cdkOption=\"selectAll\"\n        *ngIf=\"type === 'check' && items.length && !searchElement?.inputValue && !hideSelectAll\"\n        [attr.aria-checked]=\"checkboxAllValue === null ? 'mixed' : checkboxAllValue\"\n        (click)=\"changeAll.emit()\"\n        (keydown)=\"changeAllEmit($event)\"\n      >\n        <po-item-list\n          [p-selected]=\"checkboxAllValue\"\n          p-type=\"check\"\n          [p-label]=\"literals.selectAll\"\n          p-value=\"selectAll\"\n          [p-checkbox-value]=\"checkboxAllValue\"\n        >\n        </po-item-list>\n      </li>\n      <li\n        [class.po-listbox-item]=\"visible\"\n        *ngFor=\"let item of items\"\n        [cdkOption]=\"item[fieldLabel]\"\n        [cdkOptionDisabled]=\"\n          returnBooleanValue(item, 'disabled') || returnBooleanValue(item, 'visible') === false || item.options\n        \"\n        [attr.aria-selected]=\"isSelectedItem(item) || item.selected\"\n        (click)=\"onSelectItem(item)\"\n        (keydown)=\"onKeyDown(item, $event)\"\n      >\n        <label *ngIf=\"item.options\" class=\"po-combo-item-title\">\n          {{ item.label }}\n        </label>\n        <po-item-list\n          *ngIf=\"returnBooleanValue(item, 'visible') !== false && !item.options\"\n          [p-disabled]=\"returnBooleanValue(item, 'disabled')\"\n          [p-visible]=\"returnBooleanValue(item, 'visible')\"\n          [p-checkbox-value]=\"isSelectedItem(item)\"\n          [attr.data-item-list]=\"item | json\"\n          [p-label]=\"item[fieldLabel]\"\n          [p-value]=\"item[fieldValue]\"\n          [p-selected]=\"isSelectedItem(item) || item.selected\"\n          [p-separator]=\"item.separator\"\n          [p-danger]=\"item.danger || item.type === 'danger'\"\n          [p-icon]=\"item.icon\"\n          [p-type]=\"type\"\n          [p-item]=\"item\"\n          [p-field-value]=\"fieldValue\"\n          [p-field-label]=\"fieldLabel\"\n          [p-template]=\"template\"\n          [p-template-context]=\"item\"\n          (p-selectcheckbox-item)=\"checkboxClicked($event)\"\n          (p-selectcombo-item)=\"optionClicked($event)\"\n          (p-select-item)=\"onSelectCheckBoxItem(item)\"\n          [p-search-value]=\"searchValue\"\n          [p-filter-mode]=\"filterMode\"\n          [p-filtering]=\"isFiltering\"\n          [p-should-mark-letter]=\"shouldMarkLetters\"\n          [p-compare-cache]=\"compareCache\"\n          [p-combo-service]=\"comboService\"\n        ></po-item-list>\n      </li>\n    </ul>\n  </ng-container>\n\n  <div *ngIf=\"isServerSearching && type !== 'action'\" class=\"po-text-center\">\n    <ng-container *ngIf=\"infiniteLoading; then scrollLoadingTemplate; else defaultLoadingTemplate\"></ng-container>\n  </div>\n\n  <ng-template #scrollLoadingTemplate>\n    <po-loading-overlay class=\"po-listbox-container-loading-scroll\"></po-loading-overlay>\n  </ng-template>\n\n  <ng-template #defaultLoadingTemplate>\n    <po-loading class=\"po-listbox-container-loading-default\"></po-loading>\n  </ng-template>\n\n  <ng-template #noDataTemplate>\n    <div\n      *ngIf=\"!items.length && !isServerSearching && type !== 'action'\"\n      class=\"po-listbox-container-no-data po-text-center\"\n    >\n      <span> {{ literals.noItems }}</span>\n    </div>\n  </ng-template>\n</div>\n"]}
|