@po-ui/ng-components 16.14.0 → 16.15.0

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.
Files changed (56) hide show
  1. package/esm2022/lib/components/po-dropdown/po-dropdown.component.mjs +6 -2
  2. package/esm2022/lib/components/po-listbox/po-item-list/po-item-list-base.component.mjs +37 -4
  3. package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +15 -5
  4. package/esm2022/lib/components/po-listbox/po-listbox-base.component.mjs +20 -2
  5. package/esm2022/lib/components/po-listbox/po-listbox.component.mjs +27 -11
  6. package/esm2022/lib/components/po-page/po-page-default/po-page-default-base.component.mjs +13 -2
  7. package/esm2022/lib/components/po-page/po-page-default/po-page-default.component.mjs +5 -5
  8. package/esm2022/lib/components/po-page/po-page-detail/po-page-detail-base.component.mjs +13 -2
  9. package/esm2022/lib/components/po-page/po-page-detail/po-page-detail.component.mjs +5 -5
  10. package/esm2022/lib/components/po-page/po-page-edit/po-page-edit-base.component.mjs +13 -2
  11. package/esm2022/lib/components/po-page/po-page-edit/po-page-edit.component.mjs +5 -5
  12. package/esm2022/lib/components/po-page/po-page-header/po-page-header-base.component.mjs +7 -2
  13. package/esm2022/lib/components/po-page/po-page-header/po-page-header.component.mjs +29 -8
  14. package/esm2022/lib/components/po-page/po-page-list/po-page-list-base.component.mjs +13 -2
  15. package/esm2022/lib/components/po-page/po-page-list/po-page-list.component.mjs +37 -37
  16. package/esm2022/lib/components/po-popup/po-popup.component.mjs +3 -2
  17. package/esm2022/lib/components/po-tabs/index.mjs +2 -1
  18. package/esm2022/lib/components/po-tabs/po-tab/po-tab.component.mjs +13 -5
  19. package/esm2022/lib/components/po-tabs/po-tab-button/po-tab-button.component.mjs +39 -14
  20. package/esm2022/lib/components/po-tabs/po-tab-dropdown/po-tab-dropdown.component.mjs +30 -49
  21. package/esm2022/lib/components/po-tabs/po-tabs-base.component.mjs +8 -7
  22. package/esm2022/lib/components/po-tabs/po-tabs.component.mjs +225 -57
  23. package/esm2022/lib/components/po-tabs/po-tabs.module.mjs +11 -5
  24. package/esm2022/lib/components/po-tabs/po-tabs.service.mjs +16 -0
  25. package/fesm2022/po-ui-ng-components.mjs +813 -469
  26. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  27. package/lib/components/po-dropdown/po-dropdown.component.d.ts +1 -0
  28. package/lib/components/po-listbox/po-item-list/po-item-list-base.component.d.ts +9 -2
  29. package/lib/components/po-listbox/po-item-list/po-item-list.component.d.ts +3 -2
  30. package/lib/components/po-listbox/po-listbox-base.component.d.ts +6 -1
  31. package/lib/components/po-listbox/po-listbox.component.d.ts +3 -0
  32. package/lib/components/po-page/po-page-default/po-page-default-base.component.d.ts +9 -1
  33. package/lib/components/po-page/po-page-detail/po-page-detail-base.component.d.ts +9 -1
  34. package/lib/components/po-page/po-page-edit/po-page-edit-base.component.d.ts +9 -1
  35. package/lib/components/po-page/po-page-header/po-page-header-base.component.d.ts +3 -1
  36. package/lib/components/po-page/po-page-list/po-page-list-base.component.d.ts +9 -1
  37. package/lib/components/po-tabs/index.d.ts +1 -0
  38. package/lib/components/po-tabs/po-tab/po-tab.component.d.ts +6 -3
  39. package/lib/components/po-tabs/po-tab-button/po-tab-button.component.d.ts +7 -3
  40. package/lib/components/po-tabs/po-tab-dropdown/po-tab-dropdown.component.d.ts +5 -4
  41. package/lib/components/po-tabs/po-tabs-base.component.d.ts +7 -6
  42. package/lib/components/po-tabs/po-tabs.component.d.ts +52 -12
  43. package/lib/components/po-tabs/po-tabs.module.d.ts +5 -1
  44. package/lib/components/po-tabs/po-tabs.service.d.ts +8 -0
  45. package/package.json +4 -4
  46. package/po-ui-ng-components-16.15.0.tgz +0 -0
  47. package/schematics/ng-add/index.js +1 -1
  48. package/schematics/ng-update/v14/index.js +1 -1
  49. package/schematics/ng-update/v15/index.js +1 -1
  50. package/schematics/ng-update/v16/index.js +1 -1
  51. package/schematics/ng-update/v2/index.js +1 -1
  52. package/schematics/ng-update/v3/index.js +1 -1
  53. package/schematics/ng-update/v4/index.js +1 -1
  54. package/schematics/ng-update/v5/index.js +1 -1
  55. package/schematics/ng-update/v6/index.js +1 -1
  56. package/po-ui-ng-components-16.14.0.tgz +0 -0
@@ -67,10 +67,14 @@ export class PoDropdownComponent extends PoDropdownBaseComponent {
67
67
  window.addEventListener('scroll', this.onScroll, true);
68
68
  }
69
69
  onScroll = ({ target }) => {
70
- if (this.open && target.className !== 'po-popup-container' && this.actions.length < 6) {
70
+ if (this.open && target.className !== 'po-popup-container' && !this.isDropdownClosed()) {
71
71
  this.hideDropdown();
72
72
  }
73
73
  };
74
+ isDropdownClosed() {
75
+ const dropdownRect = this.dropdownRef.nativeElement.getBoundingClientRect();
76
+ return dropdownRect.top >= 0 && dropdownRect.bottom <= window.innerHeight;
77
+ }
74
78
  removeListeners() {
75
79
  if (this.clickoutListener) {
76
80
  this.clickoutListener();
@@ -132,4 +136,4 @@ export class PoDropdownComponent extends PoDropdownBaseComponent {
132
136
  type: ViewChild,
133
137
  args: ['popupRef']
134
138
  }] }); })();
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-dropdown/po-dropdown.component.ts","../../../../../../projects/ui/src/lib/components/po-dropdown/po-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Renderer2, ViewChild } from '@angular/core';\n\nimport { isKeyCodeEnter } from './../../utils/util';\n\nimport { PoDropdownBaseComponent } from './po-dropdown-base.component';\n\n/**\n * @docsExtends PoDropdownBaseComponent\n *\n * @example\n *\n * <example name=\"po-dropdown-basic\" title=\"PO Dropdown Basic\" >\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.ts\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.e2e-spec.ts\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.po.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dropdown-labs\" title=\"PO Dropdown Labs\" >\n *  <file name=\"sample-po-dropdown-labs/sample-po-dropdown-labs.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-labs/sample-po-dropdown-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dropdown-social-network\" title=\"PO Dropdown - Social Network\" >\n *  <file name=\"sample-po-dropdown-social-network/sample-po-dropdown-social-network.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-social-network/sample-po-dropdown-social-network.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-dropdown',\n  templateUrl: './po-dropdown.component.html'\n})\nexport class PoDropdownComponent extends PoDropdownBaseComponent {\n  @ViewChild('dropdownRef', { read: ElementRef, static: true }) dropdownRef: ElementRef;\n  @ViewChild('popupRef') popupRef: any;\n\n  private clickoutListener: () => void;\n  private resizeListener: () => void;\n\n  constructor(private renderer: Renderer2) {\n    super();\n  }\n\n  onKeyDown(event: any) {\n    if (isKeyCodeEnter(event)) {\n      this.toggleDropdown();\n    }\n  }\n\n  toggleDropdown(): void {\n    this.dropdownRef && !this.open && !this.disabled ? this.showDropdown() : this.hideDropdown();\n  }\n\n  private checkClickArea(event: MouseEvent) {\n    return this.dropdownRef && this.dropdownRef.nativeElement.contains(event.target);\n  }\n\n  private hideDropdown() {\n    this.icon = 'po-icon-arrow-down';\n    this.removeListeners();\n    this.popupRef.close();\n    this.open = false;\n  }\n\n  private initializeListeners() {\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnDropdown(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.hideDropdown();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = ({ target }): void => {\n    if (this.open && target.className !== 'po-popup-container' && this.actions.length < 6) {\n      this.hideDropdown();\n    }\n  };\n\n  private removeListeners() {\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  }\n\n  private showDropdown() {\n    this.icon = 'po-icon-arrow-up';\n    this.initializeListeners();\n    this.popupRef.open();\n    this.open = true;\n  }\n\n  private wasClickedOnDropdown(event: MouseEvent) {\n    const clickedOnDropdown = this.checkClickArea(event);\n\n    if (!clickedOnDropdown) {\n      this.hideDropdown();\n    }\n  }\n}\n","<div\n  #dropdownRef\n  class=\"po-dropdown\"\n  [attr.disabled]=\"disabled\"\n  tabindex=\"{{ disabled ? -1 : 0 }}\"\n  (click)=\"toggleDropdown()\"\n  (keydown)=\"onKeyDown($event)\"\n>\n  <div\n    class=\"po-dropdown-button\"\n    [ngClass]=\"{ 'po-dropdown-button-disabled': disabled, 'po-dropdown-button-open': open }\"\n  >\n    {{ label }}\n    <div class=\"po-dropdown-icon po-icon {{ icon }}\"></div>\n  </div>\n</div>\n\n<po-popup\n  #popupRef\n  p-hide-arrow\n  p-is-corner-align\n  p-position=\"bottom-left\"\n  [p-actions]=\"actions\"\n  [p-custom-positions]=\"['bottom-left', 'top-left']\"\n  [p-target]=\"dropdownRef\"\n>\n</po-popup>\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-dropdown/po-dropdown.component.ts","../../../../../../projects/ui/src/lib/components/po-dropdown/po-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Renderer2, ViewChild } from '@angular/core';\n\nimport { isKeyCodeEnter } from './../../utils/util';\n\nimport { PoDropdownBaseComponent } from './po-dropdown-base.component';\n\n/**\n * @docsExtends PoDropdownBaseComponent\n *\n * @example\n *\n * <example name=\"po-dropdown-basic\" title=\"PO Dropdown Basic\" >\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.ts\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.e2e-spec.ts\"> </file>\n *  <file name=\"sample-po-dropdown-basic/sample-po-dropdown-basic.component.po.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dropdown-labs\" title=\"PO Dropdown Labs\" >\n *  <file name=\"sample-po-dropdown-labs/sample-po-dropdown-labs.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-labs/sample-po-dropdown-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dropdown-social-network\" title=\"PO Dropdown - Social Network\" >\n *  <file name=\"sample-po-dropdown-social-network/sample-po-dropdown-social-network.component.html\"> </file>\n *  <file name=\"sample-po-dropdown-social-network/sample-po-dropdown-social-network.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-dropdown',\n  templateUrl: './po-dropdown.component.html'\n})\nexport class PoDropdownComponent extends PoDropdownBaseComponent {\n  @ViewChild('dropdownRef', { read: ElementRef, static: true }) dropdownRef: ElementRef;\n  @ViewChild('popupRef') popupRef: any;\n\n  private clickoutListener: () => void;\n  private resizeListener: () => void;\n\n  constructor(private renderer: Renderer2) {\n    super();\n  }\n\n  onKeyDown(event: any) {\n    if (isKeyCodeEnter(event)) {\n      this.toggleDropdown();\n    }\n  }\n\n  toggleDropdown(): void {\n    this.dropdownRef && !this.open && !this.disabled ? this.showDropdown() : this.hideDropdown();\n  }\n\n  private checkClickArea(event: MouseEvent) {\n    return this.dropdownRef && this.dropdownRef.nativeElement.contains(event.target);\n  }\n\n  private hideDropdown() {\n    this.icon = 'po-icon-arrow-down';\n    this.removeListeners();\n    this.popupRef.close();\n    this.open = false;\n  }\n\n  private initializeListeners() {\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnDropdown(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.hideDropdown();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = ({ target }): void => {\n    if (this.open && target.className !== 'po-popup-container' && !this.isDropdownClosed()) {\n      this.hideDropdown();\n    }\n  };\n\n  private isDropdownClosed(): boolean {\n    const dropdownRect = this.dropdownRef.nativeElement.getBoundingClientRect();\n\n    return dropdownRect.top >= 0 && dropdownRect.bottom <= window.innerHeight;\n  }\n\n  private removeListeners() {\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  }\n\n  private showDropdown() {\n    this.icon = 'po-icon-arrow-up';\n    this.initializeListeners();\n    this.popupRef.open();\n    this.open = true;\n  }\n\n  private wasClickedOnDropdown(event: MouseEvent) {\n    const clickedOnDropdown = this.checkClickArea(event);\n\n    if (!clickedOnDropdown) {\n      this.hideDropdown();\n    }\n  }\n}\n","<div\n  #dropdownRef\n  class=\"po-dropdown\"\n  [attr.disabled]=\"disabled\"\n  tabindex=\"{{ disabled ? -1 : 0 }}\"\n  (click)=\"toggleDropdown()\"\n  (keydown)=\"onKeyDown($event)\"\n>\n  <div\n    class=\"po-dropdown-button\"\n    [ngClass]=\"{ 'po-dropdown-button-disabled': disabled, 'po-dropdown-button-open': open }\"\n  >\n    {{ label }}\n    <div class=\"po-dropdown-icon po-icon {{ icon }}\"></div>\n  </div>\n</div>\n\n<po-popup\n  #popupRef\n  p-hide-arrow\n  p-is-corner-align\n  p-position=\"bottom-left\"\n  [p-actions]=\"actions\"\n  [p-custom-positions]=\"['bottom-left', 'top-left']\"\n  [p-target]=\"dropdownRef\"\n>\n</po-popup>\n"]}
@@ -14,6 +14,7 @@ export class PoItemListBaseComponent {
14
14
  _type;
15
15
  _visible = true;
16
16
  _disabled = false;
17
+ _activeTabs = false;
17
18
  set type(value) {
18
19
  this._type = PoItemListType[value] ?? 'action';
19
20
  }
@@ -126,15 +127,32 @@ export class PoItemListBaseComponent {
126
127
  shouldMarkLetters = true;
127
128
  compareCache = false;
128
129
  comboService;
129
- constructor() { }
130
+ // TABS PROPERTIES
131
+ isTabs = false;
132
+ tabHide = false;
133
+ tabsItem = new EventEmitter();
134
+ activatedTab = new EventEmitter();
135
+ // Ativa o botão
136
+ set activeTabs(value) {
137
+ this._activeTabs = value;
138
+ this.emitActiveTabs(this.item);
139
+ }
140
+ get activeTabs() {
141
+ return this._activeTabs;
142
+ }
143
+ emitActiveTabs(tab) {
144
+ if (tab?.active) {
145
+ this.activatedTab.emit(tab);
146
+ }
147
+ }
130
148
  static ɵfac = function PoItemListBaseComponent_Factory(t) { return new (t || PoItemListBaseComponent)(); };
131
149
  static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoItemListBaseComponent, hostVars: 1, hostBindings: function PoItemListBaseComponent_HostBindings(rf, ctx) { if (rf & 2) {
132
150
  i0.ɵɵattribute("p-type", ctx.type);
133
- } }, inputs: { type: ["p-type", "type"], visible: ["p-visible", "visible"], item: ["p-item", "item"], label: ["p-label", "label"], value: ["p-value", "value"], danger: ["p-danger", "danger", convertToBoolean], disabled: ["p-disabled", "disabled"], selected: ["p-selected", "selected", convertToBoolean], separator: ["p-separator", "separator", convertToBoolean], icon: ["p-icon", "icon"], checkboxValue: ["p-checkbox-value", "checkboxValue"], fieldValue: ["p-field-value", "fieldValue"], fieldLabel: ["p-field-label", "fieldLabel"], template: ["p-template", "template"], templateContext: ["p-template-context", "templateContext"], searchValue: ["p-search-value", "searchValue"], filterMode: ["p-filter-mode", "filterMode"], isFiltering: ["p-filtering", "isFiltering"], shouldMarkLetters: ["p-should-mark-letter", "shouldMarkLetters"], compareCache: ["p-compare-cache", "compareCache"], comboService: ["p-combo-service", "comboService"] }, outputs: { clickItem: "p-click-item", selectItem: "p-select-item", checkboxItem: "p-selectcheckbox-item", comboItem: "p-selectcombo-item" }, features: [i0.ɵɵInputTransformsFeature] });
151
+ } }, inputs: { type: ["p-type", "type"], visible: ["p-visible", "visible"], item: ["p-item", "item"], label: ["p-label", "label"], value: ["p-value", "value"], danger: ["p-danger", "danger", convertToBoolean], disabled: ["p-disabled", "disabled"], selected: ["p-selected", "selected", convertToBoolean], separator: ["p-separator", "separator", convertToBoolean], icon: ["p-icon", "icon"], checkboxValue: ["p-checkbox-value", "checkboxValue"], fieldValue: ["p-field-value", "fieldValue"], fieldLabel: ["p-field-label", "fieldLabel"], template: ["p-template", "template"], templateContext: ["p-template-context", "templateContext"], searchValue: ["p-search-value", "searchValue"], filterMode: ["p-filter-mode", "filterMode"], isFiltering: ["p-filtering", "isFiltering"], shouldMarkLetters: ["p-should-mark-letter", "shouldMarkLetters"], compareCache: ["p-compare-cache", "compareCache"], comboService: ["p-combo-service", "comboService"], isTabs: ["p-is-tabs", "isTabs"], tabHide: ["p-tab-hide", "tabHide"], activeTabs: ["p-active-tabs", "activeTabs"] }, outputs: { clickItem: "p-click-item", selectItem: "p-select-item", checkboxItem: "p-selectcheckbox-item", comboItem: "p-selectcombo-item", tabsItem: "p-emit-item-tabs", activatedTab: "p-activated-tabs" }, features: [i0.ɵɵInputTransformsFeature] });
134
152
  }
135
153
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoItemListBaseComponent, [{
136
154
  type: Directive
137
- }], function () { return []; }, { type: [{
155
+ }], null, { type: [{
138
156
  type: HostBinding,
139
157
  args: ['attr.p-type']
140
158
  }, {
@@ -212,5 +230,20 @@ export class PoItemListBaseComponent {
212
230
  }], comboService: [{
213
231
  type: Input,
214
232
  args: ['p-combo-service']
233
+ }], isTabs: [{
234
+ type: Input,
235
+ args: ['p-is-tabs']
236
+ }], tabHide: [{
237
+ type: Input,
238
+ args: ['p-tab-hide']
239
+ }], tabsItem: [{
240
+ type: Output,
241
+ args: ['p-emit-item-tabs']
242
+ }], activatedTab: [{
243
+ type: Output,
244
+ args: ['p-activated-tabs']
245
+ }], activeTabs: [{
246
+ type: Input,
247
+ args: ['p-active-tabs']
215
248
  }] }); })();
216
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-item-list-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core';\nimport { InputBoolean } from '../../../decorators';\nimport { convertToBoolean } from '../../../utils/util';\nimport { PoItemListType } from '../enums/po-item-list-type.enum';\nimport { PoItemListAction } from './interfaces/po-item-list-action.interface';\nimport { PoItemListOptionGroup } from './interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './interfaces/po-item-list-option.interface';\nimport { PoItemListFilterMode } from '../enums/po-item-list-filter-mode.enum';\n\n/**\n * @description\n *\n * O componente `po-item-list` é a menor parte da lista de ação que compõem o componente [**PO Listbox**](/documentation/po-listbox).\n */\n@Directive()\nexport class PoItemListBaseComponent {\n  private _label: string;\n  private _value: string;\n  private _type!: PoItemListType;\n  private _visible: boolean = true;\n  private _disabled: boolean = false;\n\n  @HostBinding('attr.p-type')\n  @Input('p-type')\n  set type(value: string) {\n    this._type = PoItemListType[value] ?? 'action';\n  }\n\n  get type(): PoItemListType {\n    return this._type;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o estado como visível.\n   *\n   * @default `true`\n   */\n  @Input('p-visible')\n  set visible(value: any) {\n    if (value === true || value === null || value === undefined) {\n      this._visible = true;\n    } else {\n      this._visible = false;\n    }\n  }\n\n  get visible(): boolean {\n    return this._visible;\n  }\n\n  @Input('p-item') item: PoItemListAction | PoItemListOption | PoItemListOptionGroup | any;\n\n  /** Texto de exibição do item. */\n  @Input('p-label') label: string;\n\n  /** Valor do item. */\n  @Input('p-value') value: string;\n\n  @Input({ alias: 'p-danger', transform: convertToBoolean }) danger: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o estado como desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled')\n  set disabled(value: any) {\n    if (value === false || value === null || value === undefined) {\n      this._disabled = false;\n    } else {\n      this._disabled = true;\n    }\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a ação está selecionada.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-selected', transform: convertToBoolean }) selected: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Atribui uma linha separadora acima do item.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-separator', transform: convertToBoolean }) separator: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define um ícone que será exibido ao lado esquerdo do rótulo.\n   */\n  @Input('p-icon') icon: string | TemplateRef<void>;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação a ser realizada ao clicar no item do tipo `option`.\n   */\n  @Output('p-click-item') clickItem = new EventEmitter<PoItemListAction | any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação a ser realizada ao selecionar no item do type `check`.\n   */\n  @Output('p-select-item') selectItem = new EventEmitter<PoItemListOption | PoItemListOptionGroup | any>();\n\n  // MULTISELECT PROPERTIES\n  //emissao de evento do checkbox\n  @Output('p-selectcheckbox-item') checkboxItem = new EventEmitter<any>();\n\n  @Output('p-selectcombo-item') comboItem = new EventEmitter<any>();\n\n  //valor do checkbox de selecionar todos\n  @Input('p-checkbox-value') checkboxValue: any;\n\n  @Input('p-field-value') fieldValue: string = 'value';\n\n  @Input('p-field-label') fieldLabel: string = 'label';\n\n  @Input('p-template') template: TemplateRef<any> | any;\n\n  @Input('p-template-context') templateContext: any;\n\n  @Input('p-search-value') searchValue: string = '';\n\n  @Input('p-filter-mode') filterMode: PoItemListFilterMode = PoItemListFilterMode.contains;\n\n  @Input('p-filtering') isFiltering: boolean = false;\n\n  @Input('p-should-mark-letter') shouldMarkLetters: boolean = true;\n\n  @Input('p-compare-cache') compareCache: boolean = false;\n\n  @Input('p-combo-service') comboService: any;\n\n  constructor() {}\n}\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-item-list-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-listbox/po-item-list/po-item-list-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core';\nimport { InputBoolean } from '../../../decorators';\nimport { convertToBoolean } from '../../../utils/util';\nimport { PoItemListType } from '../enums/po-item-list-type.enum';\nimport { PoItemListAction } from './interfaces/po-item-list-action.interface';\nimport { PoItemListOptionGroup } from './interfaces/po-item-list-option-group.interface';\nimport { PoItemListOption } from './interfaces/po-item-list-option.interface';\nimport { PoItemListFilterMode } from '../enums/po-item-list-filter-mode.enum';\n\n/**\n * @description\n *\n * O componente `po-item-list` é a menor parte da lista de ação que compõem o componente [**PO Listbox**](/documentation/po-listbox).\n */\n@Directive()\nexport class PoItemListBaseComponent {\n  private _label: string;\n  private _value: string;\n  private _type!: PoItemListType;\n  private _visible: boolean = true;\n  private _disabled: boolean = false;\n  _activeTabs: boolean = false;\n\n  @HostBinding('attr.p-type')\n  @Input('p-type')\n  set type(value: string) {\n    this._type = PoItemListType[value] ?? 'action';\n  }\n\n  get type(): PoItemListType {\n    return this._type;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o estado como visível.\n   *\n   * @default `true`\n   */\n  @Input('p-visible')\n  set visible(value: any) {\n    if (value === true || value === null || value === undefined) {\n      this._visible = true;\n    } else {\n      this._visible = false;\n    }\n  }\n\n  get visible(): boolean {\n    return this._visible;\n  }\n\n  @Input('p-item') item: PoItemListAction | PoItemListOption | PoItemListOptionGroup | any;\n\n  /** Texto de exibição do item. */\n  @Input('p-label') label: string;\n\n  /** Valor do item. */\n  @Input('p-value') value: string;\n\n  @Input({ alias: 'p-danger', transform: convertToBoolean }) danger: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o estado como desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled')\n  set disabled(value: any) {\n    if (value === false || value === null || value === undefined) {\n      this._disabled = false;\n    } else {\n      this._disabled = true;\n    }\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a ação está selecionada.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-selected', transform: convertToBoolean }) selected: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Atribui uma linha separadora acima do item.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-separator', transform: convertToBoolean }) separator: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define um ícone que será exibido ao lado esquerdo do rótulo.\n   */\n  @Input('p-icon') icon: string | TemplateRef<void>;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação a ser realizada ao clicar no item do tipo `option`.\n   */\n  @Output('p-click-item') clickItem = new EventEmitter<PoItemListAction | any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação a ser realizada ao selecionar no item do type `check`.\n   */\n  @Output('p-select-item') selectItem = new EventEmitter<PoItemListOption | PoItemListOptionGroup | any>();\n\n  // MULTISELECT PROPERTIES\n  //emissao de evento do checkbox\n  @Output('p-selectcheckbox-item') checkboxItem = new EventEmitter<any>();\n\n  @Output('p-selectcombo-item') comboItem = new EventEmitter<any>();\n\n  //valor do checkbox de selecionar todos\n  @Input('p-checkbox-value') checkboxValue: any;\n\n  @Input('p-field-value') fieldValue: string = 'value';\n\n  @Input('p-field-label') fieldLabel: string = 'label';\n\n  @Input('p-template') template: TemplateRef<any> | any;\n\n  @Input('p-template-context') templateContext: any;\n\n  @Input('p-search-value') searchValue: string = '';\n\n  @Input('p-filter-mode') filterMode: PoItemListFilterMode = PoItemListFilterMode.contains;\n\n  @Input('p-filtering') isFiltering: boolean = false;\n\n  @Input('p-should-mark-letter') shouldMarkLetters: boolean = true;\n\n  @Input('p-compare-cache') compareCache: boolean = false;\n\n  @Input('p-combo-service') comboService: any;\n\n  // TABS PROPERTIES\n\n  @Input('p-is-tabs') isTabs?: boolean = false;\n\n  @Input('p-tab-hide') tabHide?: boolean = false;\n\n  @Output('p-emit-item-tabs') tabsItem = new EventEmitter<any>();\n\n  @Output('p-activated-tabs') activatedTab = new EventEmitter();\n\n  // Ativa o botão\n  @Input('p-active-tabs') set activeTabs(value: boolean) {\n    this._activeTabs = value;\n\n    this.emitActiveTabs(this.item);\n  }\n\n  get activeTabs() {\n    return this._activeTabs;\n  }\n\n  protected emitActiveTabs(tab) {\n    if (tab?.active) {\n      this.activatedTab.emit(tab);\n    }\n  }\n}\n"]}
@@ -21,7 +21,7 @@ function PoItemListComponent_div_1_Template(rf, ctx) { if (rf & 1) {
21
21
  i0.ɵɵelementEnd()();
22
22
  } if (rf & 2) {
23
23
  const ctx_r0 = i0.ɵɵnextContext();
24
- i0.ɵɵclassProp("po-item-list__separator", ctx_r0.separator)("po-item-list__disabled", ctx_r0.disabled || !ctx_r0.visible)("po-item-list__selected", ctx_r0.selected && !ctx_r0.disabled)("po-item-list__danger", ctx_r0.danger);
24
+ i0.ɵɵclassProp("po-item-list__separator", ctx_r0.separator)("po-item-list__disabled", ctx_r0.disabled || !ctx_r0.visible)("po-item-list__selected", (ctx_r0.selected || ctx_r0.activeTabs) && !ctx_r0.disabled)("po-item-list__hidden", ctx_r0.tabHide)("po-item-list__danger", ctx_r0.danger);
25
25
  i0.ɵɵattribute("aria-disabled", ctx_r0.disabled || !ctx_r0.visible)("aria-label", ctx_r0.label);
26
26
  i0.ɵɵadvance(2);
27
27
  i0.ɵɵproperty("ngIf", ctx_r0.icon);
@@ -93,6 +93,16 @@ export class PoItemListComponent extends PoItemListBaseComponent {
93
93
  super();
94
94
  this.sanitized = sanitized;
95
95
  }
96
+ ngOnChanges(changes) {
97
+ if (this.isTabs) {
98
+ if (changes.tabHide?.currentValue || changes.disabled?.currentValue) {
99
+ this.tabsItem.emit(this.item);
100
+ }
101
+ else if (changes.activeTabs?.currentValue) {
102
+ this.emitActiveTabs(this.item);
103
+ }
104
+ }
105
+ }
96
106
  onSelectItem(itemListOption) {
97
107
  this.selectedView = itemListOption;
98
108
  this.selectItem.emit(itemListOption);
@@ -164,10 +174,10 @@ export class PoItemListComponent extends PoItemListBaseComponent {
164
174
  } if (rf & 2) {
165
175
  let _t;
166
176
  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", "click", "p-change"], ["class", "po-item-list__label", 4, "ngIf"], [1, "po-item-list__label"]], template: function PoItemListComponent_Template(rf, ctx) { if (rf & 1) {
177
+ } }, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], 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__hidden", "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
178
  i0.ɵɵelementContainerStart(0, 0);
169
179
  i0.ɵɵlistener("keydown", function PoItemListComponent_Template_ng_container_keydown_0_listener($event) { return ctx.onCheckboxItemEmit($event); });
170
- i0.ɵɵtemplate(1, PoItemListComponent_div_1_Template, 5, 12, "div", 1);
180
+ i0.ɵɵtemplate(1, PoItemListComponent_div_1_Template, 5, 14, "div", 1);
171
181
  i0.ɵɵtemplate(2, PoItemListComponent_div_2_Template, 4, 11, "div", 2);
172
182
  i0.ɵɵtemplate(3, PoItemListComponent_div_3_Template, 4, 16, "div", 3);
173
183
  i0.ɵɵelementContainerEnd();
@@ -181,9 +191,9 @@ export class PoItemListComponent extends PoItemListBaseComponent {
181
191
  }
182
192
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoItemListComponent, [{
183
193
  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 (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" }]
194
+ 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 || activeTabs) && !disabled\"\n [class.po-item-list__hidden]=\"tabHide\"\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
195
  }], function () { return [{ type: i1.DomSanitizer }]; }, { itemList: [{
186
196
  type: ViewChild,
187
197
  args: ['itemList', { static: true }]
188
198
  }] }); })();
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;;;IAwBvD,gCAAoD;IAAA,YAAW;IAAA,iBAAO;;;IAAlB,eAAW;IAAX,mCAAW;;;;;IApBjE,+BAWC;IAHC,+JAAS,eAAA,wBAAgB,CAAA,IAAC,4JACf,eAAA,kCAA0B,CAAA,IADX,wJAEjB,eAAA,kCAA0B,CAAA,IAFT;IAI1B,uCAMC;IAFC,uKAAS,eAAA,wBAAgB,CAAA,IAAC,gKACd,eAAA,8CAAqB,CAAA,IADP;IAE3B,iBAAc;IAEf,6EAAsE;IAEtE,2FACc;IAChB,iBAAM;;;IArBJ,2DAA2C,+DAAA,2CAAA;IAG3C,gDAA+B,4BAAA;IAO7B,eAA4B;IAA5B,0CAA4B,mFAAA,+BAAA;IAOK,eAAe;IAAf,uCAAe;IAErC,eAA0C;IAA1C,+FAA0C,gFAAA;;AD1C3D,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,qEAwBM;YACR,0BAAe;;YAzDD,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      (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"]}
199
+ //# 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, OnChanges, SimpleChanges, 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 implements OnChanges {\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  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isTabs) {\n      if (changes.tabHide?.currentValue || changes.disabled?.currentValue) {\n        this.tabsItem.emit(this.item);\n      } else if (changes.activeTabs?.currentValue) {\n        this.emitActiveTabs(this.item);\n      }\n    }\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 || activeTabs) && !disabled\"\n    [class.po-item-list__hidden]=\"tabHide\"\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"]}
@@ -59,6 +59,7 @@ export class PoListBoxBaseComponent {
59
59
  get isItemListGroup() {
60
60
  return this.items.length && this.items[0].hasOwnProperty('options');
61
61
  }
62
+ isTabs = false;
62
63
  // parâmetro que pode ser passado para o popup ao clicar em um item
63
64
  param;
64
65
  selectItem = new EventEmitter();
@@ -104,11 +105,16 @@ export class PoListBoxBaseComponent {
104
105
  shouldMarkLetters = true;
105
106
  compareCache = false;
106
107
  comboService;
108
+ // Evento disparado quando uma tab é ativada
109
+ activatedTab = new EventEmitter();
110
+ // Evento disparado no click de uma aba do tabs
111
+ clickTab = new EventEmitter();
112
+ changeStateTabs = new EventEmitter();
107
113
  constructor(languageService) {
108
114
  this.language = languageService.getShortLanguage();
109
115
  }
110
116
  static ɵfac = function PoListBoxBaseComponent_Factory(t) { return new (t || PoListBoxBaseComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
111
- static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoListBoxBaseComponent, inputs: { visible: ["p-visible", "visible", convertToBoolean], type: ["p-type", "type"], items: ["p-items", "items"], literals: ["p-literals", "literals"], param: ["p-param", "param"], checkboxAllValue: ["p-checkboxAllValue", "checkboxAllValue"], selectedOptions: ["p-selected-options", "selectedOptions"], selectedOption: ["p-selected-option", "selectedOption"], fieldValue: ["p-field-value", "fieldValue"], fieldLabel: ["p-field-label", "fieldLabel"], literalSearch: ["p-literal-search", "literalSearch"], fieldValueSearch: ["p-field-value-search", "fieldValueSearch"], hideSearch: ["p-hide-search", "hideSearch"], hideSelectAll: ["p-hide-select-all", "hideSelectAll"], multiselectTemplate: ["p-multiselect-template", "multiselectTemplate"], template: ["p-template", "template"], placeholderSearch: ["p-placeholder-search", "placeholderSearch"], searchValue: ["p-search-value", "searchValue"], isServerSearching: ["p-is-searching", "isServerSearching", convertToBoolean], infiniteLoading: ["p-infinite-loading", "infiniteLoading", convertToBoolean], infiniteScroll: ["p-infinite-scroll", "infiniteScroll", convertToBoolean], cache: ["p-cache", "cache", convertToBoolean], infiniteScrollDistance: ["p-infinite-scroll-distance", "infiniteScrollDistance"], filterMode: ["p-filter-mode", "filterMode"], isFiltering: ["p-filtering", "isFiltering"], shouldMarkLetters: ["p-should-mark-letter", "shouldMarkLetters"], compareCache: ["p-compare-cache", "compareCache"], comboService: ["p-combo-service", "comboService"] }, outputs: { selectItem: "p-select-item", closeEvent: "p-close", change: "p-change", selectCombo: "p-selectcombo-item", changeAll: "p-change-all", UpdateInfiniteScroll: "p-update-infinite-scroll", changeSearch: "p-change-search" }, features: [i0.ɵɵInputTransformsFeature] });
117
+ static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoListBoxBaseComponent, inputs: { visible: ["p-visible", "visible", convertToBoolean], type: ["p-type", "type"], items: ["p-items", "items"], literals: ["p-literals", "literals"], isTabs: ["p-is-tabs", "isTabs", convertToBoolean], param: ["p-param", "param"], checkboxAllValue: ["p-checkboxAllValue", "checkboxAllValue"], selectedOptions: ["p-selected-options", "selectedOptions"], selectedOption: ["p-selected-option", "selectedOption"], fieldValue: ["p-field-value", "fieldValue"], fieldLabel: ["p-field-label", "fieldLabel"], literalSearch: ["p-literal-search", "literalSearch"], fieldValueSearch: ["p-field-value-search", "fieldValueSearch"], hideSearch: ["p-hide-search", "hideSearch"], hideSelectAll: ["p-hide-select-all", "hideSelectAll"], multiselectTemplate: ["p-multiselect-template", "multiselectTemplate"], template: ["p-template", "template"], placeholderSearch: ["p-placeholder-search", "placeholderSearch"], searchValue: ["p-search-value", "searchValue"], isServerSearching: ["p-is-searching", "isServerSearching", convertToBoolean], infiniteLoading: ["p-infinite-loading", "infiniteLoading", convertToBoolean], infiniteScroll: ["p-infinite-scroll", "infiniteScroll", convertToBoolean], cache: ["p-cache", "cache", convertToBoolean], infiniteScrollDistance: ["p-infinite-scroll-distance", "infiniteScrollDistance"], filterMode: ["p-filter-mode", "filterMode"], isFiltering: ["p-filtering", "isFiltering"], shouldMarkLetters: ["p-should-mark-letter", "shouldMarkLetters"], compareCache: ["p-compare-cache", "compareCache"], comboService: ["p-combo-service", "comboService"] }, outputs: { selectItem: "p-select-item", closeEvent: "p-close", change: "p-change", selectCombo: "p-selectcombo-item", changeAll: "p-change-all", UpdateInfiniteScroll: "p-update-infinite-scroll", changeSearch: "p-change-search", activatedTab: "p-activated-tabs", clickTab: "p-click-tabs", changeStateTabs: "p-change-state-tabs" }, features: [i0.ɵɵInputTransformsFeature] });
112
118
  }
113
119
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoListBoxBaseComponent, [{
114
120
  type: Directive
@@ -124,6 +130,9 @@ export class PoListBoxBaseComponent {
124
130
  }], literals: [{
125
131
  type: Input,
126
132
  args: ['p-literals']
133
+ }], isTabs: [{
134
+ type: Input,
135
+ args: [{ alias: 'p-is-tabs', transform: convertToBoolean }]
127
136
  }], param: [{
128
137
  type: Input,
129
138
  args: ['p-param']
@@ -217,5 +226,14 @@ export class PoListBoxBaseComponent {
217
226
  }], comboService: [{
218
227
  type: Input,
219
228
  args: ['p-combo-service']
229
+ }], activatedTab: [{
230
+ type: Output,
231
+ args: ['p-activated-tabs']
232
+ }], clickTab: [{
233
+ type: Output,
234
+ args: ['p-click-tabs']
235
+ }], changeStateTabs: [{
236
+ type: Output,
237
+ args: ['p-change-state-tabs']
220
238
  }] }); })();
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-listbox-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\n\nimport { poLocaleDefault } from '../../services/po-language/po-language.constant';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoItemListType } from './enums/po-item-list-type.enum';\nimport { PoItemListAction } from './po-item-list/interfaces/po-item-list-action.interface';\n\nimport { convertToBoolean } from '../../utils/util';\nimport { PoItemListFilterMode } from './enums/po-item-list-filter-mode.enum';\nimport { PoListBoxLiterals } from './interfaces/po-listbox-literals.interface';\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';\n\nexport const poListBoxLiteralsDefault = {\n  en: <PoListBoxLiterals>{\n    noItems: 'No items found'\n  },\n  es: <PoListBoxLiterals>{\n    noItems: 'No se encontraron artículos'\n  },\n  pt: <PoListBoxLiterals>{\n    noItems: 'Nenhum item encontrado'\n  },\n  ru: <PoListBoxLiterals>{\n    noItems: 'ничего не найдено'\n  }\n};\n\n/**\n * @description\n * O componente `po-listbox` é uma caixa suspensa que aparece sobre a interface após ser acionado por um gatilho visível em tela, como o dropdown. Ele apoia trazendo agrupamentos de opções. O componente listbox é composto pelo componente [**PO Item List**](/documentation/po-item-list).\n */\n@Directive()\nexport class PoListBoxBaseComponent {\n  private _items: Array<PoItemListOption | PoItemListOptionGroup | any> = [];\n  private _type!: PoItemListType;\n  private _literals: PoListBoxLiterals;\n  private language: string = poLocaleDefault;\n\n  @Input({ alias: 'p-visible', transform: convertToBoolean }) visible: boolean = false;\n\n  @Input('p-type') set type(value: string) {\n    this._type = PoItemListType[value] ?? 'action';\n  }\n\n  get type(): PoItemListType {\n    return this._type;\n  }\n\n  @Input('p-items') set items(items: Array<PoItemListAction | PoItemListOption | PoItemListOptionGroup | any>) {\n    this._items = Array.isArray(items) ? items : [];\n  }\n\n  get items(): Array<PoItemListAction | PoItemListOption | PoItemListOptionGroup | any> {\n    return this._items;\n  }\n\n  @Input('p-literals') set literals(value: PoListBoxLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poListBoxLiteralsDefault[poLocaleDefault],\n        ...poListBoxLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poListBoxLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || poListBoxLiteralsDefault[this.language];\n  }\n\n  get isItemListGroup(): boolean {\n    return this.items.length && this.items[0].hasOwnProperty('options');\n  }\n\n  // parâmetro que pode ser passado para o popup ao clicar em um item\n  @Input('p-param') param?;\n\n  @Output('p-select-item') selectItem = new EventEmitter<PoItemListOption | PoItemListOptionGroup | any>();\n\n  @Output('p-close') closeEvent = new EventEmitter<any>();\n  // MULTISELECT PROPERTIES\n\n  //output para evento do checkbox\n  @Output('p-change') change = new EventEmitter();\n\n  //output para evento do checkbox\n  @Output('p-selectcombo-item') selectCombo = new EventEmitter();\n\n  //output para evento do checkbox de selecionar todos\n  @Output('p-change-all') changeAll = new EventEmitter();\n\n  @Output('p-update-infinite-scroll') UpdateInfiniteScroll = new EventEmitter();\n\n  //valor do checkbox de selecionar todos\n  @Input('p-checkboxAllValue') checkboxAllValue: any;\n\n  // Propriedade que recebe a lista de opções selecionadas.\n  @Input('p-selected-options') selectedOptions: Array<any> = [];\n\n  // Propriedade que recebe um item selecionado.\n  @Input('p-selected-option') selectedOption?: any;\n\n  @Input('p-field-value') fieldValue: string = 'value';\n\n  @Input('p-field-label') fieldLabel: string = 'label';\n\n  // Evento disparado a cada tecla digitada na pesquisa.\n  @Output('p-change-search') changeSearch = new EventEmitter();\n\n  // Propriedade que recebe as literais definidas no componente `po-multiselect`.\n  @Input('p-literal-search') literalSearch?: any;\n\n  // Propriedade que recebe o valor de comparação de pesquisa\n  @Input('p-field-value-search') fieldValueSearch: string = 'value';\n\n  // Propriedade que indica se o campo de pesquisa deverá ser escondido.\n  @Input('p-hide-search') hideSearch?: boolean = false;\n\n  // Propriedade que indica se o campo \"Selecionar todos\" deverá ser escondido.\n  @Input('p-hide-select-all') hideSelectAll?: boolean = false;\n\n  //Propriedades relacionados ao template customizado do multiselect\n  @Input('p-multiselect-template') multiselectTemplate: TemplateRef<any> | any;\n\n  @Input('p-template') template: TemplateRef<any> | any;\n\n  @Input('p-placeholder-search') placeholderSearch: string;\n\n  @Input('p-search-value') searchValue: string;\n\n  @Input({ alias: 'p-is-searching', transform: convertToBoolean }) isServerSearching: boolean = false;\n\n  @Input({ alias: 'p-infinite-loading', transform: convertToBoolean }) infiniteLoading: boolean = false;\n\n  @Input({ alias: 'p-infinite-scroll', transform: convertToBoolean }) infiniteScroll: boolean = false;\n\n  @Input({ alias: 'p-cache', transform: convertToBoolean }) cache: boolean = false;\n\n  @Input('p-infinite-scroll-distance') infiniteScrollDistance: number = 100;\n\n  @Input('p-filter-mode') filterMode: PoItemListFilterMode = PoItemListFilterMode.contains;\n\n  @Input('p-filtering') isFiltering: boolean = false;\n\n  @Input('p-should-mark-letter') shouldMarkLetters: boolean = true;\n\n  @Input('p-compare-cache') compareCache: boolean = false;\n\n  @Input('p-combo-service') comboService: any;\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n}\n"]}
239
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-listbox-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-listbox/po-listbox-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\n\nimport { poLocaleDefault } from '../../services/po-language/po-language.constant';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoItemListType } from './enums/po-item-list-type.enum';\nimport { PoItemListAction } from './po-item-list/interfaces/po-item-list-action.interface';\n\nimport { convertToBoolean } from '../../utils/util';\nimport { PoItemListFilterMode } from './enums/po-item-list-filter-mode.enum';\nimport { PoListBoxLiterals } from './interfaces/po-listbox-literals.interface';\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';\n\nexport const poListBoxLiteralsDefault = {\n  en: <PoListBoxLiterals>{\n    noItems: 'No items found'\n  },\n  es: <PoListBoxLiterals>{\n    noItems: 'No se encontraron artículos'\n  },\n  pt: <PoListBoxLiterals>{\n    noItems: 'Nenhum item encontrado'\n  },\n  ru: <PoListBoxLiterals>{\n    noItems: 'ничего не найдено'\n  }\n};\n\n/**\n * @description\n * O componente `po-listbox` é uma caixa suspensa que aparece sobre a interface após ser acionado por um gatilho visível em tela, como o dropdown. Ele apoia trazendo agrupamentos de opções. O componente listbox é composto pelo componente [**PO Item List**](/documentation/po-item-list).\n */\n@Directive()\nexport class PoListBoxBaseComponent {\n  private _items: Array<PoItemListOption | PoItemListOptionGroup | any> = [];\n  private _type!: PoItemListType;\n  private _literals: PoListBoxLiterals;\n  private language: string = poLocaleDefault;\n\n  @Input({ alias: 'p-visible', transform: convertToBoolean }) visible: boolean = false;\n\n  @Input('p-type') set type(value: string) {\n    this._type = PoItemListType[value] ?? 'action';\n  }\n\n  get type(): PoItemListType {\n    return this._type;\n  }\n\n  @Input('p-items') set items(items: Array<PoItemListAction | PoItemListOption | PoItemListOptionGroup | any>) {\n    this._items = Array.isArray(items) ? items : [];\n  }\n\n  get items(): Array<PoItemListAction | PoItemListOption | PoItemListOptionGroup | any> {\n    return this._items;\n  }\n\n  @Input('p-literals') set literals(value: PoListBoxLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poListBoxLiteralsDefault[poLocaleDefault],\n        ...poListBoxLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poListBoxLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || poListBoxLiteralsDefault[this.language];\n  }\n\n  get isItemListGroup(): boolean {\n    return this.items.length && this.items[0].hasOwnProperty('options');\n  }\n\n  @Input({ alias: 'p-is-tabs', transform: convertToBoolean }) isTabs: boolean = false;\n\n  // parâmetro que pode ser passado para o popup ao clicar em um item\n  @Input('p-param') param?;\n\n  @Output('p-select-item') selectItem = new EventEmitter<PoItemListOption | PoItemListOptionGroup | any>();\n\n  @Output('p-close') closeEvent = new EventEmitter<any>();\n  // MULTISELECT PROPERTIES\n\n  //output para evento do checkbox\n  @Output('p-change') change = new EventEmitter();\n\n  //output para evento do checkbox\n  @Output('p-selectcombo-item') selectCombo = new EventEmitter();\n\n  //output para evento do checkbox de selecionar todos\n  @Output('p-change-all') changeAll = new EventEmitter();\n\n  @Output('p-update-infinite-scroll') UpdateInfiniteScroll = new EventEmitter();\n\n  //valor do checkbox de selecionar todos\n  @Input('p-checkboxAllValue') checkboxAllValue: any;\n\n  // Propriedade que recebe a lista de opções selecionadas.\n  @Input('p-selected-options') selectedOptions: Array<any> = [];\n\n  // Propriedade que recebe um item selecionado.\n  @Input('p-selected-option') selectedOption?: any;\n\n  @Input('p-field-value') fieldValue: string = 'value';\n\n  @Input('p-field-label') fieldLabel: string = 'label';\n\n  // Evento disparado a cada tecla digitada na pesquisa.\n  @Output('p-change-search') changeSearch = new EventEmitter();\n\n  // Propriedade que recebe as literais definidas no componente `po-multiselect`.\n  @Input('p-literal-search') literalSearch?: any;\n\n  // Propriedade que recebe o valor de comparação de pesquisa\n  @Input('p-field-value-search') fieldValueSearch: string = 'value';\n\n  // Propriedade que indica se o campo de pesquisa deverá ser escondido.\n  @Input('p-hide-search') hideSearch?: boolean = false;\n\n  // Propriedade que indica se o campo \"Selecionar todos\" deverá ser escondido.\n  @Input('p-hide-select-all') hideSelectAll?: boolean = false;\n\n  //Propriedades relacionados ao template customizado do multiselect\n  @Input('p-multiselect-template') multiselectTemplate: TemplateRef<any> | any;\n\n  @Input('p-template') template: TemplateRef<any> | any;\n\n  @Input('p-placeholder-search') placeholderSearch: string;\n\n  @Input('p-search-value') searchValue: string;\n\n  @Input({ alias: 'p-is-searching', transform: convertToBoolean }) isServerSearching: boolean = false;\n\n  @Input({ alias: 'p-infinite-loading', transform: convertToBoolean }) infiniteLoading: boolean = false;\n\n  @Input({ alias: 'p-infinite-scroll', transform: convertToBoolean }) infiniteScroll: boolean = false;\n\n  @Input({ alias: 'p-cache', transform: convertToBoolean }) cache: boolean = false;\n\n  @Input('p-infinite-scroll-distance') infiniteScrollDistance: number = 100;\n\n  @Input('p-filter-mode') filterMode: PoItemListFilterMode = PoItemListFilterMode.contains;\n\n  @Input('p-filtering') isFiltering: boolean = false;\n\n  @Input('p-should-mark-letter') shouldMarkLetters: boolean = true;\n\n  @Input('p-compare-cache') compareCache: boolean = false;\n\n  @Input('p-combo-service') comboService: any;\n\n  // Evento disparado quando uma tab é ativada\n  @Output('p-activated-tabs') activatedTab = new EventEmitter();\n\n  // Evento disparado no click de uma aba do tabs\n  @Output('p-click-tabs') clickTab = new EventEmitter();\n\n  @Output('p-change-state-tabs') changeStateTabs = new EventEmitter();\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n}\n"]}