@po-ui/ng-components 17.17.1 → 17.18.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.
@@ -131,6 +131,7 @@ export class PoListBoxComponent extends PoListBoxBaseComponent {
131
131
  ngAfterViewInit() {
132
132
  this.setListBoxMaxHeight();
133
133
  this.listboxItemList?.nativeElement.focus();
134
+ this.changeDetector.detectChanges();
134
135
  }
135
136
  ngOnChanges(changes) {
136
137
  if (changes?.items) {
@@ -344,4 +345,4 @@ export class PoListBoxComponent extends PoListBoxBaseComponent {
344
345
  args: ['searchElement']
345
346
  }] }); })();
346
347
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoListBoxComponent, { className: "PoListBoxComponent", filePath: "lib/components/po-listbox/po-listbox.component.ts", lineNumber: 29 }); })();
347
- //# 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 (this.isTabs && !itemListAction.disabled && !itemListAction.hide) {\n      this.onClickTabs(itemListAction);\n    }\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  onSelectAllCheckboxKeyDown(event: KeyboardEvent) {\n    if (event.code === 'Tab') {\n      this.closeEvent.emit();\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  onSelectTabs(tab) {\n    if (this.isTabs && tab) {\n      this.changeStateTabs.emit(tab);\n    }\n  }\n\n  onActivatedTabs(tab) {\n    this.activatedTab.emit(tab);\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  onClickTabs(tab) {\n    if (!tab.disabled) {\n      this.clickTab.emit(tab);\n    }\n  }\n\n  formatItemList(item: any): string {\n    if (this.isTabs) {\n      return item.id;\n    } else {\n      try {\n        return JSON.stringify(item);\n      } catch (error) {\n        return item;\n      }\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        (keydown)=\"onSelectAllCheckboxKeyDown($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]=\"formatItemList(item)\"\n          [p-label]=\"item[fieldLabel]\"\n          [p-value]=\"item[fieldValue]\"\n          [p-selected]=\"isSelectedItem(item) || item.selected\"\n          [p-active-tabs]=\"item.active\"\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-tab-hide]=\"item.hide\"\n          [p-is-tabs]=\"isTabs\"\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(item)\"\n          (p-emit-item-tabs)=\"onSelectTabs($event)\"\n          (p-activated-tabs)=\"onActivatedTabs($event)\"\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-listbox-container-loading-default]=\"!infiniteLoading\">\n    <po-loading-overlay p-size=\"md\"></po-loading-overlay>\n  </div>\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"]}
348
+ //# 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    this.changeDetector.detectChanges();\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 (this.isTabs && !itemListAction.disabled && !itemListAction.hide) {\n      this.onClickTabs(itemListAction);\n    }\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  onSelectAllCheckboxKeyDown(event: KeyboardEvent) {\n    if (event.code === 'Tab') {\n      this.closeEvent.emit();\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  onSelectTabs(tab) {\n    if (this.isTabs && tab) {\n      this.changeStateTabs.emit(tab);\n    }\n  }\n\n  onActivatedTabs(tab) {\n    this.activatedTab.emit(tab);\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  onClickTabs(tab) {\n    if (!tab.disabled) {\n      this.clickTab.emit(tab);\n    }\n  }\n\n  formatItemList(item: any): string {\n    if (this.isTabs) {\n      return item.id;\n    } else {\n      try {\n        return JSON.stringify(item);\n      } catch (error) {\n        return item;\n      }\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        (keydown)=\"onSelectAllCheckboxKeyDown($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]=\"formatItemList(item)\"\n          [p-label]=\"item[fieldLabel]\"\n          [p-value]=\"item[fieldValue]\"\n          [p-selected]=\"isSelectedItem(item) || item.selected\"\n          [p-active-tabs]=\"item.active\"\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-tab-hide]=\"item.hide\"\n          [p-is-tabs]=\"isTabs\"\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(item)\"\n          (p-emit-item-tabs)=\"onSelectTabs($event)\"\n          (p-activated-tabs)=\"onActivatedTabs($event)\"\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-listbox-container-loading-default]=\"!infiniteLoading\">\n    <po-loading-overlay p-size=\"md\"></po-loading-overlay>\n  </div>\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"]}
@@ -131,7 +131,7 @@ export class PoStepperBaseComponent {
131
131
  */
132
132
  set steps(steps) {
133
133
  this._steps = Array.isArray(steps) ? steps : [];
134
- this._steps.forEach(step => (step.status = PoStepperStatus.Default));
134
+ this._steps.forEach(step => (step.status = step.status ?? PoStepperStatus.Default));
135
135
  this.step = 1;
136
136
  }
137
137
  get steps() {
@@ -181,4 +181,4 @@ export class PoStepperBaseComponent {
181
181
  type: Input,
182
182
  args: ['p-sequential']
183
183
  }] }); })();
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-stepper-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-stepper/po-stepper-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAIpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;;AAEjE,MAAM,2BAA2B,GAAG,oBAAoB,CAAC,UAAU,CAAC;AAEpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAEH,MAAM,OAAO,sBAAsB;IACjC;;;;;;;;;;;OAWG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;OAYG;IACmB,QAAQ,CAAS;IAEvC,8EAA8E;IACrD,YAAY,GAAG,IAAI,YAAY,EAA4B,CAAC;IAE7E,YAAY,GAA0B,2BAA2B,CAAC;IAClE,WAAW,GAAa,IAAI,CAAC;IAC7B,KAAK,GAAW,CAAC,CAAC;IAClB,MAAM,GAAyB,EAAE,CAAC;IAE1C;;;;;;;;;;OAUG;IACH,IAA4B,WAAW,CAAC,KAA2B;QACjE,IAAI,CAAC,YAAY,GAAS,MAAO,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC5E,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,2BAA2B,CAAC;IAClC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,IAAqB,IAAI,CAAC,IAAY;QACpC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC;SAC7D;IACH,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;;;;OASG;IACH,IAAsB,KAAK,CAAC,KAA2B;QACrD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;IAChB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAA2B,UAAU,CAAC,UAAmB;QACvD,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAClD,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;gFAvHU,sBAAsB;6DAAtB,sBAAsB;;iFAAtB,sBAAsB;cADlC,SAAS;gBAce,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAeC,QAAQ;kBAA7B,KAAK;mBAAC,aAAa;YAGK,YAAY;kBAApC,MAAM;mBAAC,eAAe;YAkBK,WAAW;kBAAtC,KAAK;mBAAC,eAAe;YAsBD,IAAI;kBAAxB,KAAK;mBAAC,QAAQ;YAqBO,KAAK;kBAA1B,KAAK;mBAAC,SAAS;YAqBW,UAAU;kBAApC,KAAK;mBAAC,cAAc","sourcesContent":["import { EventEmitter, Input, Output, Directive } from '@angular/core';\n\nimport { convertToBoolean } from '../../utils/util';\n\nimport { PoStepComponent } from './po-step/po-step.component';\nimport { PoStepperItem } from './po-stepper-item.interface';\nimport { PoStepperOrientation } from './enums/po-stepper-orientation.enum';\nimport { PoStepperStatus } from './enums/po-stepper-status.enum';\n\nconst poStepperOrientationDefault = PoStepperOrientation.Horizontal;\n\n/**\n * @description\n *\n * O `po-stepper` permite que um processo seja dividido em passos para que o usuário o realize\n * mais facilmente.\n *\n * Existem duas formas de utilização:\n *\n * 1 - Usando o componente [**po-step**](/documentation/po-step) para renderizar e descrever os passos.\n *\n * 2 - Através da propriedade `p-steps` para descrever os passos do processo, sendo responsabilidade do desenvolvedor o controle\n * de renderização do que será exibido a cada *step* ativo.\n *\n * Através de suas propriedades, é possível definir se sua orientação será horizontal ou vertical,\n * além da possibilidade de aumentar o tamanho dos *steps*.\n *\n * Também é possível navegar entre os *steps* através do teclado utilizando a tecla *tab* e, para ativar o *step* em foco basta\n * pressionar a tecla *enter*. Além disso, é possível ativar a exibição de ícones no lugar de números nos *steps* através da\n * propriedade [`p-step-icons`](/documentation/po-stepper#stepIconsProperty).\n *\n * #### Utilizando os métodos do componente:\n *\n * Para acessar os métodos do componente é necessário ter a referência do mesmo.\n *\n * Por exemplo, utilizando um [**ViewChild**](https://angular.io/api/core/ViewChild):\n *\n * ```\n * @ViewChild(PoStepperComponent) poStepperComponent: PoStepperComponent;\n * ```\n *\n * E para acessar o método:\n *\n * ```\n * poStepperComponent.next();\n * ```\n *\n * #### Boas práticas\n *\n * - Evite `labels` extensos que quebram o layout do `po-stepper`, use `labels` diretos, curtos e intuitivos.\n * - Utilize apenas um `po-stepper` por página.\n */\n@Directive()\nexport class PoStepperBaseComponent {\n  /**\n   *\n   * @optional\n   *\n   * @description\n   *\n   * <a id=\"stepIconsProperty\"></a>\n   *\n   * Habilita a exibição de ícone ao invés de número no centro do círculo dos *steps*.\n   *\n   * @default `false`\n   */\n  @Input('p-step-icons') stepIcons: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tamanho dos *steps* em *pixels*, possibilitando um maior destaque.\n   *\n   * O valor informado deve ser entre `24` e `64`.\n   *\n   * > Valores que não se enquadrarem a esta regra serão ignorados, mantendo-se o valor *default*.\n   *\n   * @default `24`\n   */\n  @Input('p-step-size') stepSize: number;\n\n  /** Ação que será executada quando o usuário mudar o passo do `po-stepper`. */\n  @Output('p-change-step') onChangeStep = new EventEmitter<number | PoStepComponent>();\n\n  private _orientation?: PoStepperOrientation = poStepperOrientationDefault;\n  private _sequential?: boolean = true;\n  private _step: number = 1;\n  private _steps: Array<PoStepperItem> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a orientação de exibição do `po-stepper`.\n   *\n   * > Veja os valores válidos no *enum* [PoStepperOrientation](documentation/po-stepper#stepperOrientation).\n   *\n   * @default `PoStepperOrientation.Horizontal`\n   */\n  @Input('p-orientation') set orientation(value: PoStepperOrientation) {\n    this._orientation = (<any>Object).values(PoStepperOrientation).includes(value)\n      ? value\n      : poStepperOrientationDefault;\n  }\n\n  get orientation(): PoStepperOrientation {\n    return this._orientation;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla o passo atual do `po-stepper`.\n   *\n   * > Ao utilizar esta propriedade e também utilizar o componente [**po-step**](/documentation/po-step),\n   * o valor desta propriedade será ignorada permanecendo a definição do [**po-step**](/documentation/po-step).\n   *\n   * @default `1`\n   */\n  @Input('p-step') set step(step: number) {\n    if (step >= 1 && step <= this.steps.length) {\n      this._step = step;\n      this._steps[this._step - 1].status = PoStepperStatus.Active;\n    }\n  }\n\n  get step(): number {\n    return this._step;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista dos itens do stepper. Se o valor estiver indefinido ou inválido, será inicializado como um array vazio.\n   *\n   * > Ao utilizar esta propriedade e também utilizar o componente [**po-step**](/documentation/po-step),\n   * o valor desta propriedade será ignorada permanecendo a definição do [**po-step**](/documentation/po-step).\n   */\n  @Input('p-steps') set steps(steps: Array<PoStepperItem>) {\n    this._steps = Array.isArray(steps) ? steps : [];\n    this._steps.forEach(step => (step.status = PoStepperStatus.Default));\n    this.step = 1;\n  }\n\n  get steps(): Array<PoStepperItem> {\n    return this._steps;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se o `po-stepper` será sequencial ou aleatório.\n   *\n   * > Ao utilizar o componente [**po-step**](/documentation/po-step), o valor desta propriedade sempre será verdadeiro.\n   *\n   * @default `true`\n   */\n  @Input('p-sequential') set sequential(sequential: boolean) {\n    this._sequential = convertToBoolean(sequential);\n  }\n\n  get sequential(): boolean {\n    return this._sequential;\n  }\n}\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-stepper-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-stepper/po-stepper-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAIpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;;AAEjE,MAAM,2BAA2B,GAAG,oBAAoB,CAAC,UAAU,CAAC;AAEpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAEH,MAAM,OAAO,sBAAsB;IACjC;;;;;;;;;;;OAWG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;OAYG;IACmB,QAAQ,CAAS;IAEvC,8EAA8E;IACrD,YAAY,GAAG,IAAI,YAAY,EAA4B,CAAC;IAE7E,YAAY,GAA0B,2BAA2B,CAAC;IAClE,WAAW,GAAa,IAAI,CAAC;IAC7B,KAAK,GAAW,CAAC,CAAC;IAClB,MAAM,GAAyB,EAAE,CAAC;IAE1C;;;;;;;;;;OAUG;IACH,IAA4B,WAAW,CAAC,KAA2B;QACjE,IAAI,CAAC,YAAY,GAAS,MAAO,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC5E,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,2BAA2B,CAAC;IAClC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,IAAqB,IAAI,CAAC,IAAY;QACpC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC;SAC7D;IACH,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;;;;OASG;IACH,IAAsB,KAAK,CAAC,KAA2B;QACrD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;IAChB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAA2B,UAAU,CAAC,UAAmB;QACvD,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAClD,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;gFAvHU,sBAAsB;6DAAtB,sBAAsB;;iFAAtB,sBAAsB;cADlC,SAAS;gBAce,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAeC,QAAQ;kBAA7B,KAAK;mBAAC,aAAa;YAGK,YAAY;kBAApC,MAAM;mBAAC,eAAe;YAkBK,WAAW;kBAAtC,KAAK;mBAAC,eAAe;YAsBD,IAAI;kBAAxB,KAAK;mBAAC,QAAQ;YAqBO,KAAK;kBAA1B,KAAK;mBAAC,SAAS;YAqBW,UAAU;kBAApC,KAAK;mBAAC,cAAc","sourcesContent":["import { EventEmitter, Input, Output, Directive } from '@angular/core';\n\nimport { convertToBoolean } from '../../utils/util';\n\nimport { PoStepComponent } from './po-step/po-step.component';\nimport { PoStepperItem } from './po-stepper-item.interface';\nimport { PoStepperOrientation } from './enums/po-stepper-orientation.enum';\nimport { PoStepperStatus } from './enums/po-stepper-status.enum';\n\nconst poStepperOrientationDefault = PoStepperOrientation.Horizontal;\n\n/**\n * @description\n *\n * O `po-stepper` permite que um processo seja dividido em passos para que o usuário o realize\n * mais facilmente.\n *\n * Existem duas formas de utilização:\n *\n * 1 - Usando o componente [**po-step**](/documentation/po-step) para renderizar e descrever os passos.\n *\n * 2 - Através da propriedade `p-steps` para descrever os passos do processo, sendo responsabilidade do desenvolvedor o controle\n * de renderização do que será exibido a cada *step* ativo.\n *\n * Através de suas propriedades, é possível definir se sua orientação será horizontal ou vertical,\n * além da possibilidade de aumentar o tamanho dos *steps*.\n *\n * Também é possível navegar entre os *steps* através do teclado utilizando a tecla *tab* e, para ativar o *step* em foco basta\n * pressionar a tecla *enter*. Além disso, é possível ativar a exibição de ícones no lugar de números nos *steps* através da\n * propriedade [`p-step-icons`](/documentation/po-stepper#stepIconsProperty).\n *\n * #### Utilizando os métodos do componente:\n *\n * Para acessar os métodos do componente é necessário ter a referência do mesmo.\n *\n * Por exemplo, utilizando um [**ViewChild**](https://angular.io/api/core/ViewChild):\n *\n * ```\n * @ViewChild(PoStepperComponent) poStepperComponent: PoStepperComponent;\n * ```\n *\n * E para acessar o método:\n *\n * ```\n * poStepperComponent.next();\n * ```\n *\n * #### Boas práticas\n *\n * - Evite `labels` extensos que quebram o layout do `po-stepper`, use `labels` diretos, curtos e intuitivos.\n * - Utilize apenas um `po-stepper` por página.\n */\n@Directive()\nexport class PoStepperBaseComponent {\n  /**\n   *\n   * @optional\n   *\n   * @description\n   *\n   * <a id=\"stepIconsProperty\"></a>\n   *\n   * Habilita a exibição de ícone ao invés de número no centro do círculo dos *steps*.\n   *\n   * @default `false`\n   */\n  @Input('p-step-icons') stepIcons: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tamanho dos *steps* em *pixels*, possibilitando um maior destaque.\n   *\n   * O valor informado deve ser entre `24` e `64`.\n   *\n   * > Valores que não se enquadrarem a esta regra serão ignorados, mantendo-se o valor *default*.\n   *\n   * @default `24`\n   */\n  @Input('p-step-size') stepSize: number;\n\n  /** Ação que será executada quando o usuário mudar o passo do `po-stepper`. */\n  @Output('p-change-step') onChangeStep = new EventEmitter<number | PoStepComponent>();\n\n  private _orientation?: PoStepperOrientation = poStepperOrientationDefault;\n  private _sequential?: boolean = true;\n  private _step: number = 1;\n  private _steps: Array<PoStepperItem> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a orientação de exibição do `po-stepper`.\n   *\n   * > Veja os valores válidos no *enum* [PoStepperOrientation](documentation/po-stepper#stepperOrientation).\n   *\n   * @default `PoStepperOrientation.Horizontal`\n   */\n  @Input('p-orientation') set orientation(value: PoStepperOrientation) {\n    this._orientation = (<any>Object).values(PoStepperOrientation).includes(value)\n      ? value\n      : poStepperOrientationDefault;\n  }\n\n  get orientation(): PoStepperOrientation {\n    return this._orientation;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla o passo atual do `po-stepper`.\n   *\n   * > Ao utilizar esta propriedade e também utilizar o componente [**po-step**](/documentation/po-step),\n   * o valor desta propriedade será ignorada permanecendo a definição do [**po-step**](/documentation/po-step).\n   *\n   * @default `1`\n   */\n  @Input('p-step') set step(step: number) {\n    if (step >= 1 && step <= this.steps.length) {\n      this._step = step;\n      this._steps[this._step - 1].status = PoStepperStatus.Active;\n    }\n  }\n\n  get step(): number {\n    return this._step;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista dos itens do stepper. Se o valor estiver indefinido ou inválido, será inicializado como um array vazio.\n   *\n   * > Ao utilizar esta propriedade e também utilizar o componente [**po-step**](/documentation/po-step),\n   * o valor desta propriedade será ignorada permanecendo a definição do [**po-step**](/documentation/po-step).\n   */\n  @Input('p-steps') set steps(steps: Array<PoStepperItem>) {\n    this._steps = Array.isArray(steps) ? steps : [];\n    this._steps.forEach(step => (step.status = step.status ?? PoStepperStatus.Default));\n    this.step = 1;\n  }\n\n  get steps(): Array<PoStepperItem> {\n    return this._steps;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se o `po-stepper` será sequencial ou aleatório.\n   *\n   * > Ao utilizar o componente [**po-step**](/documentation/po-step), o valor desta propriedade sempre será verdadeiro.\n   *\n   * @default `true`\n   */\n  @Input('p-sequential') set sequential(sequential: boolean) {\n    this._sequential = convertToBoolean(sequential);\n  }\n\n  get sequential(): boolean {\n    return this._sequential;\n  }\n}\n"]}