@po-ui/ng-components 17.21.0 → 17.22.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.
@@ -151,6 +151,35 @@ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
151
151
  * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.
152
152
  *
153
153
  * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.
154
+ *
155
+ * *
156
+ * #### Tokens customizáveis
157
+ *
158
+ * É possível alterar o estilo do componente usando os seguintes tokens (CSS):
159
+ *
160
+ * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
161
+ *
162
+ * | Propriedade | Descrição | Valor Padrão |
163
+ * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|
164
+ * | **Default Values** | | |
165
+ * | `--font-family` | Família tipográfica usada | `var(--font-family-theme)` |
166
+ * | `--font-size` | Tamanho da fonte | `var(--font-size-default)` |
167
+ * | `--text-color-empty` | Cor do placeholder | `var(--color-neutral-light-30)` |
168
+ * | `--color` | Cor da borda | `var(--color-neutral-dark-70)` |
169
+ * | `--background` | Cor de background | `var(--color-neutral-light-05)` |
170
+ * | `--text-color` | Cor do texto | `var(--color-neutral-dark-90)` |
171
+ * | `--padding-horizontal` | Preenchimento horizontal | `0.5em` |
172
+ * | `--padding-vertical` | Preenchimento vertical | `0.7em` |
173
+ * | **Hover** | | |
174
+ * | `--color-hover` | Cor principal no estado hover | `var(--color-brand-01-dark)` |
175
+ * | `--background-hover` | Cor de background no estado hover | `var(--color-brand-01-lighter)` |
176
+ * | **Focused** | | |
177
+ * | `--outline-color-focused` | Cor do outline do estado de focus | `var(--color-action-focus)` |
178
+ * | `--color-focused` | Cor da borda no estado de focus | `var(--color-action-default)` |
179
+ * | **Disabled** | | |
180
+ * | `--color-disabled` | Cor principal no estado disabled | `var(--color-neutral-light-30)` |
181
+ * | `--background-color-disabled`  | Cor de background no estado disabled | `var(--color-neutral-light-20)` |
182
+ *
154
183
  */
155
184
  export class PoSelectComponent extends PoFieldValidateModel {
156
185
  changeDetector;
@@ -512,5 +541,5 @@ export class PoSelectComponent extends PoFieldValidateModel {
512
541
  type: Input,
513
542
  args: ['p-field-value']
514
543
  }] }); })();
515
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 95 }); })();
516
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  convertToBoolean,\n  isSafari,\n  removeDuplicatedOptions,\n  removeUndefinedAndNullOptions,\n  uuid,\n  validValue\n} from '../../../utils/util';\n\nimport { ICONS_DICTIONARY, PoIconDictionary } from '../../po-icon';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { PoSelectOptionGroup } from './po-select-option-group.interface';\nimport { PoSelectOption } from './po-select-option.interface';\n\nconst PO_SELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_SELECT_FIELD_VALUE_DEFAULT = 'value';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * <example name=\"po-select-companies\" title=\"PO Select Companies\">\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.html\"> </file>\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.ts\"> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements OnChanges {\n  private _iconToken: { [key: string]: string };\n\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-readonly', transform: convertToBoolean }) readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  id = `po-select[${uuid()}]`;\n  modelValue: any;\n  selectedValue: any;\n  optionsDefault = [];\n  listGroupOptions = [];\n  optionWithoutGroup = [];\n  isSafari: boolean = isSafari();\n\n  protected onModelTouched: any;\n\n  private _fieldLabel?: string = PO_SELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_SELECT_FIELD_VALUE_DEFAULT;\n  private _options: Array<PoSelectOption> | Array<PoSelectOptionGroup> | Array<any>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`,\n   * ou uma coleção de objetos dentro de grupos diferentes, que seriam da interface `PoSelectOptionGroup`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   *\n   * > Para coleção de objetos dentro de grupos distintos será exibido a label e opções somente se a propriedade `options` possua valores.\n   *  Sendo assim, a estrutura seguiria dessa forma:\n   *\n   * ```\n   * this.options = [{\n   *  label: 'Opções',\n   *  options: [\n   *    { value: 1, label: 'opção 1' },\n   *    { value: 2, label: 'opção 2' }\n   *  ],\n   * }];\n   * ```\n   *\n   * É possível a utilização de opções agrupadas e desagrupadas em conjunto, porém será feita a ordenação de exibir as opções\n   * desagrupadas acima.\n   *\n   */\n  @Input('p-options') set options(options: Array<PoSelectOption | PoSelectOptionGroup | any>) {\n    this.listGroupOptions = [];\n    this.optionWithoutGroup = [];\n\n    if (this.fieldLabel && this.fieldValue && options) {\n      options.map(option => {\n        if (this.isItemGroup(option)) {\n          option.options.map(opt => {\n            opt.label = opt[this.fieldLabel];\n            opt.value = opt[this.fieldValue];\n          });\n        } else {\n          option.label = option[this.fieldLabel];\n          option.value = option[this.fieldValue];\n        }\n      });\n    }\n\n    if (options) {\n      this.optionsDefault = [...options];\n      this.separateOptions();\n\n      this.optionsDefault = [];\n      this.optionsDefault = [...this.optionWithoutGroup, ...this.transformInArray(this.listGroupOptions)];\n      this.onUpdateOptions();\n      this._options = [...this.optionsDefault];\n    }\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  get iconNameLib() {\n    return this._iconToken.NAME_LIB;\n  }\n\n  /* istanbul ignore next */\n  constructor(\n    @Optional() @Inject(ICONS_DICTIONARY) value: { [key: string]: string },\n    private changeDetector: ChangeDetectorRef,\n    public renderer: Renderer2\n  ) {\n    super();\n\n    this._iconToken = value ?? PoIconDictionary;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.options?.currentValue) {\n      this.options = changes.options.currentValue;\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    this.onModelTouched?.();\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  // Atualiza valores\n  updateValues(option: any): void {\n    if (this.selectedValue !== option[this.fieldValue]) {\n      this.selectedValue = option[this.fieldValue];\n      this.selectElement.nativeElement.value = option[this.fieldValue];\n      this.updateModel(option[this.fieldValue]);\n      this.displayValue = option[this.fieldLabel];\n      this.emitChange(option[this.fieldValue]);\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: any = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound[this.fieldValue];\n      this.displayValue = optionFound[this.fieldLabel];\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  isItemGroup(item: PoSelectOption | PoSelectOptionGroup | any): boolean {\n    if (item.options) {\n      return Array.isArray(item.options) ? true : false;\n    }\n    return false;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  private findOptionValue(value: any) {\n    if (this.options) {\n      return this.options.find(option => this.isEqual(option.value, value));\n    }\n  }\n\n  private transformInArray(objectWithArray: Array<any>): Array<PoSelectOptionGroup | any> {\n    return objectWithArray.reduce((options, items) => {\n      if (items.options) {\n        return options.concat(items.options);\n      }\n      return [];\n    }, []);\n  }\n\n  private separateOptions() {\n    this.optionsDefault.forEach(option => {\n      if (this.isItemGroup(option)) {\n        this.validateOptions(option.options);\n        this.listGroupOptions.push(option);\n      } else {\n        this.optionWithoutGroup.push(option);\n      }\n    });\n\n    if (this.optionWithoutGroup.length > 0) {\n      this.validateOptions(this.optionWithoutGroup);\n    }\n  }\n\n  private validateOptions(options: Array<any>) {\n    removeDuplicatedOptions(options);\n    removeUndefinedAndNullOptions(options);\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-id]=\"id\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div class=\"po-field-container-content\">\n    <select\n      #select\n      class=\"po-select\"\n      [ngClass]=\"iconNameLib === 'PhosphorIcon' ? 'po-select-phosphor' : 'po-select-poicon'\"\n      [attr.name]=\"name\"\n      [class.po-select-placeholder]=\"!selectedValue?.toString() && !!placeholder\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\n      [required]=\"required\"\n      (change)=\"onSelectChange($event.target.value)\"\n    >\n      <ng-container *ngIf=\"!isSafari\">\n        <option\n          *ngIf=\"!selectedValue?.toString() || !!placeholder\"\n          [disabled]=\"!!placeholder\"\n          [hidden]=\"!selectedValue?.toString() && !placeholder\"\n          [selected]=\"!selectedValue?.toString()\"\n          [value]=\"placeholder ?? ''\"\n        >\n          {{ placeholder }}\n        </option>\n        <option [hidden]=\"true\">{{ displayValue }}</option>\n      </ng-container>\n\n      <ng-container *ngIf=\"isSafari\">\n        <option>{{ displayValue || placeholder }}</option>\n      </ng-container>\n\n      <ng-container *ngIf=\"optionWithoutGroup.length > 0\">\n        <option *ngFor=\"let item of optionWithoutGroup\" [disabled]=\"readonly\" [value]=\"item?.[this.fieldValue]\">\n          {{ item?.[this.fieldLabel] }}\n        </option>\n      </ng-container>\n      <ng-container *ngIf=\"listGroupOptions.length > 0\">\n        <ng-container *ngFor=\"let item of listGroupOptions\">\n          <optgroup *ngIf=\"item?.options.length > 0\" label=\"{{ item?.label }}\" [disabled]=\"readonly\">\n            <option *ngFor=\"let subItem of item.options\" [value]=\"subItem?.[this.fieldValue]\" [disabled]=\"readonly\">\n              {{ subItem?.[this.fieldLabel] }}\n            </option>\n          </optgroup>\n        </ng-container>\n      </ng-container>\n    </select>\n  </div>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n"]}
544
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 124 }); })();
545
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  convertToBoolean,\n  isSafari,\n  removeDuplicatedOptions,\n  removeUndefinedAndNullOptions,\n  uuid,\n  validValue\n} from '../../../utils/util';\n\nimport { ICONS_DICTIONARY, PoIconDictionary } from '../../po-icon';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { PoSelectOptionGroup } from './po-select-option-group.interface';\nimport { PoSelectOption } from './po-select-option.interface';\n\nconst PO_SELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_SELECT_FIELD_VALUE_DEFAULT = 'value';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * <example name=\"po-select-companies\" title=\"PO Select Companies\">\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.html\"> </file>\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.ts\"> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n *\n *  *\n * #### Tokens customizáveis\n *\n * É possível alterar o estilo do componente usando os seguintes tokens (CSS):\n *\n * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).\n *\n * | Propriedade                            | Descrição                                             | Valor Padrão                                    |\n * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|\n * | **Default Values**                     |                                                       |                                                 |\n * | `--font-family`                        | Família tipográfica usada                             | `var(--font-family-theme)`                      |\n * | `--font-size`                          | Tamanho da fonte                                      | `var(--font-size-default)`                      |\n * | `--text-color-empty`                   | Cor do placeholder                                    | `var(--color-neutral-light-30)`                 |\n * | `--color`                              | Cor da borda                                          | `var(--color-neutral-dark-70)`                  |\n * | `--background`                         | Cor de background                                     | `var(--color-neutral-light-05)`                 |\n * | `--text-color`                         | Cor do texto                                          | `var(--color-neutral-dark-90)`                  |\n * | `--padding-horizontal`                 | Preenchimento horizontal                              | `0.5em`                                         |\n * | `--padding-vertical`                   | Preenchimento vertical                                | `0.7em`                                         |\n * | **Hover**                              |                                                       |                                                 |\n * | `--color-hover`                        | Cor principal no estado hover                         | `var(--color-brand-01-dark)`                    |\n * | `--background-hover`                   | Cor de background no estado hover                     | `var(--color-brand-01-lighter)`                 |\n * | **Focused**                            |                                                       |                                                 |\n * | `--outline-color-focused`              | Cor do outline do estado de focus                     | `var(--color-action-focus)`                     |\n * | `--color-focused`                      | Cor da borda no estado de focus                       | `var(--color-action-default)`                   |\n * | **Disabled**                           |                                                       |                                                 |\n * | `--color-disabled`                     | Cor principal no estado disabled                      | `var(--color-neutral-light-30)`                 |\n * | `--background-color-disabled`&nbsp;    | Cor de background no estado disabled                  | `var(--color-neutral-light-20)`                 |\n *\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements OnChanges {\n  private _iconToken: { [key: string]: string };\n\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-readonly', transform: convertToBoolean }) readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  id = `po-select[${uuid()}]`;\n  modelValue: any;\n  selectedValue: any;\n  optionsDefault = [];\n  listGroupOptions = [];\n  optionWithoutGroup = [];\n  isSafari: boolean = isSafari();\n\n  protected onModelTouched: any;\n\n  private _fieldLabel?: string = PO_SELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_SELECT_FIELD_VALUE_DEFAULT;\n  private _options: Array<PoSelectOption> | Array<PoSelectOptionGroup> | Array<any>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`,\n   * ou uma coleção de objetos dentro de grupos diferentes, que seriam da interface `PoSelectOptionGroup`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   *\n   * > Para coleção de objetos dentro de grupos distintos será exibido a label e opções somente se a propriedade `options` possua valores.\n   *  Sendo assim, a estrutura seguiria dessa forma:\n   *\n   * ```\n   * this.options = [{\n   *  label: 'Opções',\n   *  options: [\n   *    { value: 1, label: 'opção 1' },\n   *    { value: 2, label: 'opção 2' }\n   *  ],\n   * }];\n   * ```\n   *\n   * É possível a utilização de opções agrupadas e desagrupadas em conjunto, porém será feita a ordenação de exibir as opções\n   * desagrupadas acima.\n   *\n   */\n  @Input('p-options') set options(options: Array<PoSelectOption | PoSelectOptionGroup | any>) {\n    this.listGroupOptions = [];\n    this.optionWithoutGroup = [];\n\n    if (this.fieldLabel && this.fieldValue && options) {\n      options.map(option => {\n        if (this.isItemGroup(option)) {\n          option.options.map(opt => {\n            opt.label = opt[this.fieldLabel];\n            opt.value = opt[this.fieldValue];\n          });\n        } else {\n          option.label = option[this.fieldLabel];\n          option.value = option[this.fieldValue];\n        }\n      });\n    }\n\n    if (options) {\n      this.optionsDefault = [...options];\n      this.separateOptions();\n\n      this.optionsDefault = [];\n      this.optionsDefault = [...this.optionWithoutGroup, ...this.transformInArray(this.listGroupOptions)];\n      this.onUpdateOptions();\n      this._options = [...this.optionsDefault];\n    }\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  get iconNameLib() {\n    return this._iconToken.NAME_LIB;\n  }\n\n  /* istanbul ignore next */\n  constructor(\n    @Optional() @Inject(ICONS_DICTIONARY) value: { [key: string]: string },\n    private changeDetector: ChangeDetectorRef,\n    public renderer: Renderer2\n  ) {\n    super();\n\n    this._iconToken = value ?? PoIconDictionary;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.options?.currentValue) {\n      this.options = changes.options.currentValue;\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    this.onModelTouched?.();\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  // Atualiza valores\n  updateValues(option: any): void {\n    if (this.selectedValue !== option[this.fieldValue]) {\n      this.selectedValue = option[this.fieldValue];\n      this.selectElement.nativeElement.value = option[this.fieldValue];\n      this.updateModel(option[this.fieldValue]);\n      this.displayValue = option[this.fieldLabel];\n      this.emitChange(option[this.fieldValue]);\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: any = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound[this.fieldValue];\n      this.displayValue = optionFound[this.fieldLabel];\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  isItemGroup(item: PoSelectOption | PoSelectOptionGroup | any): boolean {\n    if (item.options) {\n      return Array.isArray(item.options) ? true : false;\n    }\n    return false;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  private findOptionValue(value: any) {\n    if (this.options) {\n      return this.options.find(option => this.isEqual(option.value, value));\n    }\n  }\n\n  private transformInArray(objectWithArray: Array<any>): Array<PoSelectOptionGroup | any> {\n    return objectWithArray.reduce((options, items) => {\n      if (items.options) {\n        return options.concat(items.options);\n      }\n      return [];\n    }, []);\n  }\n\n  private separateOptions() {\n    this.optionsDefault.forEach(option => {\n      if (this.isItemGroup(option)) {\n        this.validateOptions(option.options);\n        this.listGroupOptions.push(option);\n      } else {\n        this.optionWithoutGroup.push(option);\n      }\n    });\n\n    if (this.optionWithoutGroup.length > 0) {\n      this.validateOptions(this.optionWithoutGroup);\n    }\n  }\n\n  private validateOptions(options: Array<any>) {\n    removeDuplicatedOptions(options);\n    removeUndefinedAndNullOptions(options);\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-id]=\"id\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div class=\"po-field-container-content\">\n    <select\n      #select\n      class=\"po-select\"\n      [ngClass]=\"iconNameLib === 'PhosphorIcon' ? 'po-select-phosphor' : 'po-select-poicon'\"\n      [attr.name]=\"name\"\n      [class.po-select-placeholder]=\"!selectedValue?.toString() && !!placeholder\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\n      [required]=\"required\"\n      (change)=\"onSelectChange($event.target.value)\"\n    >\n      <ng-container *ngIf=\"!isSafari\">\n        <option\n          *ngIf=\"!selectedValue?.toString() || !!placeholder\"\n          [disabled]=\"!!placeholder\"\n          [hidden]=\"!selectedValue?.toString() && !placeholder\"\n          [selected]=\"!selectedValue?.toString()\"\n          [value]=\"placeholder ?? ''\"\n        >\n          {{ placeholder }}\n        </option>\n        <option [hidden]=\"true\">{{ displayValue }}</option>\n      </ng-container>\n\n      <ng-container *ngIf=\"isSafari\">\n        <option>{{ displayValue || placeholder }}</option>\n      </ng-container>\n\n      <ng-container *ngIf=\"optionWithoutGroup.length > 0\">\n        <option *ngFor=\"let item of optionWithoutGroup\" [disabled]=\"readonly\" [value]=\"item?.[this.fieldValue]\">\n          {{ item?.[this.fieldLabel] }}\n        </option>\n      </ng-container>\n      <ng-container *ngIf=\"listGroupOptions.length > 0\">\n        <ng-container *ngFor=\"let item of listGroupOptions\">\n          <optgroup *ngIf=\"item?.options.length > 0\" label=\"{{ item?.label }}\" [disabled]=\"readonly\">\n            <option *ngFor=\"let subItem of item.options\" [value]=\"subItem?.[this.fieldValue]\" [disabled]=\"readonly\">\n              {{ subItem?.[this.fieldLabel] }}\n            </option>\n          </optgroup>\n        </ng-container>\n      </ng-container>\n    </select>\n  </div>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n"]}
@@ -1,25 +1,34 @@
1
- import { animate, state, style, transition, trigger } from '@angular/animations';
1
+ import { animate, style, transition, trigger } from '@angular/animations';
2
2
  import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../services/po-tree-view.service";
5
5
  import * as i2 from "@angular/common";
6
6
  import * as i3 from "../po-tree-view-item-header/po-tree-view-item-header.component";
7
- function PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
8
- i0.ɵɵelement(0, "po-tree-view-item", 5);
7
+ function PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
8
+ i0.ɵɵelement(0, "po-tree-view-item", 6);
9
+ } if (rf & 2) {
10
+ const subItem_r3 = ctx.$implicit;
11
+ const ctx_r2 = i0.ɵɵnextContext(3);
12
+ i0.ɵɵproperty("p-item", subItem_r3)("p-selectable", ctx_r2.selectable)("p-single-select", ctx_r2.singleSelect)("p-selected-value", ctx_r2.selectedValue);
13
+ } }
14
+ function PoTreeViewItemComponent_ul_2_div_1_Template(rf, ctx) { if (rf & 1) {
15
+ i0.ɵɵelementStart(0, "div");
16
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 5);
17
+ i0.ɵɵelementEnd();
9
18
  } if (rf & 2) {
10
- const subItem_r2 = ctx.$implicit;
11
19
  const ctx_r1 = i0.ɵɵnextContext(2);
12
- i0.ɵɵproperty("p-item", subItem_r2)("p-selectable", ctx_r1.selectable)("p-single-select", ctx_r1.singleSelect)("p-selected-value", ctx_r1.selectedValue);
20
+ i0.ɵɵproperty("@toggleBody", undefined);
21
+ i0.ɵɵadvance();
22
+ i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
13
23
  } }
14
24
  function PoTreeViewItemComponent_ul_2_Template(rf, ctx) { if (rf & 1) {
15
25
  i0.ɵɵelementStart(0, "ul", 3);
16
- i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 4);
26
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_Template, 2, 3, "div", 4);
17
27
  i0.ɵɵelementEnd();
18
28
  } if (rf & 2) {
19
29
  const ctx_r0 = i0.ɵɵnextContext();
20
- i0.ɵɵproperty("@toggleBody", ctx_r0.item.expanded ? "expanded" : "collapsed");
21
30
  i0.ɵɵadvance();
22
- i0.ɵɵproperty("ngForOf", ctx_r0.item.subItems)("ngForTrackBy", ctx_r0.trackByFunction);
31
+ i0.ɵɵproperty("ngIf", ctx_r0.item.expanded);
23
32
  } }
24
33
  export class PoTreeViewItemComponent {
25
34
  treeViewService;
@@ -46,11 +55,11 @@ export class PoTreeViewItemComponent {
46
55
  return index;
47
56
  }
48
57
  static ɵfac = function PoTreeViewItemComponent_Factory(t) { return new (t || PoTreeViewItemComponent)(i0.ɵɵdirectiveInject(i1.PoTreeViewService)); };
49
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [i0.ɵɵInputFlags.None, "p-item", "item"], selectable: [i0.ɵɵInputFlags.None, "p-selectable", "selectable"], singleSelect: [i0.ɵɵInputFlags.None, "p-single-select", "singleSelect"], selectedValue: [i0.ɵɵInputFlags.None, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", "p-expanded", "p-selected"], ["class", "po-tree-view-item-group", 4, "ngIf"], [1, "po-tree-view-item-group"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", 4, "ngFor", "ngForOf", "ngForTrackBy"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value"]], template: function PoTreeViewItemComponent_Template(rf, ctx) { if (rf & 1) {
58
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [i0.ɵɵInputFlags.None, "p-item", "item"], selectable: [i0.ɵɵInputFlags.None, "p-selectable", "selectable"], singleSelect: [i0.ɵɵInputFlags.None, "p-single-select", "singleSelect"], selectedValue: [i0.ɵɵInputFlags.None, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", "p-expanded", "p-selected"], ["class", "po-tree-view-item-group", 4, "ngIf"], [1, "po-tree-view-item-group"], [4, "ngIf"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", 4, "ngFor", "ngForOf", "ngForTrackBy"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value"]], template: function PoTreeViewItemComponent_Template(rf, ctx) { if (rf & 1) {
50
59
  i0.ɵɵelementStart(0, "li", 0)(1, "po-tree-view-item-header", 1);
51
60
  i0.ɵɵlistener("p-expanded", function PoTreeViewItemComponent_Template_po_tree_view_item_header_p_expanded_1_listener($event) { return ctx.onClick($event); })("p-selected", function PoTreeViewItemComponent_Template_po_tree_view_item_header_p_selected_1_listener() { return ctx.onSelect(ctx.item); });
52
61
  i0.ɵɵelementEnd();
53
- i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 3, "ul", 2);
62
+ i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 1, "ul", 2);
54
63
  i0.ɵɵelementEnd();
55
64
  } if (rf & 2) {
56
65
  i0.ɵɵadvance();
@@ -59,21 +68,25 @@ export class PoTreeViewItemComponent {
59
68
  i0.ɵɵproperty("ngIf", ctx.hasSubItems);
60
69
  } }, dependencies: [i2.NgForOf, i2.NgIf, PoTreeViewItemComponent, i3.PoTreeViewItemHeaderComponent], encapsulation: 2, data: { animation: [
61
70
  trigger('toggleBody', [
62
- state('collapsed', style({
63
- 'overflow-y': 'hidden',
64
- visibility: 'hidden',
65
- opacity: 0,
66
- height: '0'
67
- })),
68
- transition('expanded => collapsed', [
69
- style({ height: '*' }),
70
- animate(100, style({ opacity: 0 })),
71
- animate(200, style({ height: 0 }))
71
+ transition(':enter', [
72
+ style({
73
+ 'overflow-y': 'hidden',
74
+ visibility: 'hidden',
75
+ opacity: 0,
76
+ height: '0'
77
+ }),
78
+ animate(200, style({ height: '*' })),
79
+ animate(100, style({ opacity: 1 }))
72
80
  ]),
73
- transition('collapsed => expanded', [
74
- style({ height: '0' }),
75
- animate(100, style({ opacity: 1 })),
76
- animate(200, style({ height: '*' }))
81
+ transition(':leave', [
82
+ style({
83
+ 'overflow-y': 'hidden',
84
+ visibility: 'visible',
85
+ opacity: 1,
86
+ height: '*'
87
+ }),
88
+ animate(200, style({ height: 0 })),
89
+ animate(100, style({ opacity: 0 }))
77
90
  ])
78
91
  ])
79
92
  ] }, changeDetection: 0 });
@@ -82,24 +95,28 @@ export class PoTreeViewItemComponent {
82
95
  type: Component,
83
96
  args: [{ selector: 'po-tree-view-item', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
84
97
  trigger('toggleBody', [
85
- state('collapsed', style({
86
- 'overflow-y': 'hidden',
87
- visibility: 'hidden',
88
- opacity: 0,
89
- height: '0'
90
- })),
91
- transition('expanded => collapsed', [
92
- style({ height: '*' }),
93
- animate(100, style({ opacity: 0 })),
94
- animate(200, style({ height: 0 }))
98
+ transition(':enter', [
99
+ style({
100
+ 'overflow-y': 'hidden',
101
+ visibility: 'hidden',
102
+ opacity: 0,
103
+ height: '0'
104
+ }),
105
+ animate(200, style({ height: '*' })),
106
+ animate(100, style({ opacity: 1 }))
95
107
  ]),
96
- transition('collapsed => expanded', [
97
- style({ height: '0' }),
98
- animate(100, style({ opacity: 1 })),
99
- animate(200, style({ height: '*' }))
108
+ transition(':leave', [
109
+ style({
110
+ 'overflow-y': 'hidden',
111
+ visibility: 'visible',
112
+ opacity: 1,
113
+ height: '*'
114
+ }),
115
+ animate(200, style({ height: 0 })),
116
+ animate(100, style({ opacity: 0 }))
100
117
  ])
101
118
  ])
102
- ], template: "<li class=\"po-tree-view-item\">\n <po-tree-view-item-header\n [p-item]=\"item\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n (p-expanded)=\"onClick($event)\"\n (p-selected)=\"onSelect(item)\"\n >\n </po-tree-view-item-header>\n\n <ul *ngIf=\"hasSubItems\" class=\"po-tree-view-item-group\" [@toggleBody]=\"item.expanded ? 'expanded' : 'collapsed'\">\n <po-tree-view-item\n *ngFor=\"let subItem of item.subItems; trackBy: trackByFunction\"\n [p-item]=\"subItem\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n >\n </po-tree-view-item>\n </ul>\n</li>\n" }]
119
+ ], template: "<li class=\"po-tree-view-item\">\n <po-tree-view-item-header\n [p-item]=\"item\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n (p-expanded)=\"onClick($event)\"\n (p-selected)=\"onSelect(item)\"\n >\n </po-tree-view-item-header>\n\n <ul *ngIf=\"hasSubItems\" class=\"po-tree-view-item-group\">\n <div *ngIf=\"item.expanded\" @toggleBody>\n <po-tree-view-item\n *ngFor=\"let subItem of item.subItems; trackBy: trackByFunction\"\n [p-item]=\"subItem\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n >\n </po-tree-view-item>\n </div>\n </ul>\n</li>\n" }]
103
120
  }], () => [{ type: i1.PoTreeViewService }], { item: [{
104
121
  type: Input,
105
122
  args: ['p-item']
@@ -113,5 +130,5 @@ export class PoTreeViewItemComponent {
113
130
  type: Input,
114
131
  args: ['p-selected-value']
115
132
  }] }); })();
116
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoTreeViewItemComponent, { className: "PoTreeViewItemComponent", filePath: "lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.ts", lineNumber: 35 }); })();
117
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXRyZWUtdmlldy9wby10cmVlLXZpZXctaXRlbS9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdHJlZS12aWV3L3BvLXRyZWUtdmlldy1pdGVtL3BvLXRyZWUtdmlldy1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztJQ1d0RSx1Q0FPb0I7Ozs7SUFMbEIsbUNBQWtCLG1DQUFBLHdDQUFBLDBDQUFBOzs7SUFIdEIsNkJBQWlIO0lBQy9HLHlHQU9vQjtJQUN0QixpQkFBSzs7O0lBVG1ELDZFQUF3RDtJQUV4RixjQUFrQjtJQUFsQiw4Q0FBa0Isd0NBQUE7O0FEcUI1QyxNQUFNLE9BQU8sdUJBQXVCO0lBYWQ7SUFaSCxJQUFJLENBQWlCO0lBRWYsVUFBVSxDQUFVO0lBRWpCLFlBQVksQ0FBVTtJQUVyQixhQUFhLENBQWtCO0lBRTFELElBQUksV0FBVztRQUNiLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVELFlBQW9CLGVBQWtDO1FBQWxDLG9CQUFlLEdBQWYsZUFBZSxDQUFtQjtJQUFHLENBQUM7SUFFMUQsT0FBTyxDQUFDLEtBQWlCO1FBQ3ZCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUV6QyxJQUFJLENBQUMsZUFBZSxDQUFDLGlCQUFpQixDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQsUUFBUSxDQUFDLFlBQTRCO1FBQ25DLElBQUksQ0FBQyxlQUFlLENBQUMsaUJBQWlCLENBQUMsRUFBRSxHQUFHLFlBQVksRUFBRSxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVELGVBQWUsQ0FBQyxLQUFhO1FBQzNCLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztpRkE5QlUsdUJBQXVCOzZEQUF2Qix1QkFBdUI7WUNsQ3BDLDZCQUE4QixrQ0FBQTtZQU0xQixzSUFBYyxtQkFBZSxJQUFDLG1IQUNoQixzQkFBYyxJQURFO1lBR2hDLGlCQUEyQjtZQUUzQixzRUFTSztZQUNQLGlCQUFLOztZQW5CRCxjQUFlO1lBQWYsaUNBQWUsZ0NBQUEscUNBQUEsdUNBQUE7WUFTWixjQUFpQjtZQUFqQixzQ0FBaUI7aUREdUJYLHVCQUF1QiwwRUF4QnRCO2dCQUNWLE9BQU8sQ0FBQyxZQUFZLEVBQUU7b0JBQ3BCLEtBQUssQ0FDSCxXQUFXLEVBQ1gsS0FBSyxDQUFDO3dCQUNKLFlBQVksRUFBRSxRQUFRO3dCQUN0QixVQUFVLEVBQUUsUUFBUTt3QkFDcEIsT0FBTyxFQUFFLENBQUM7d0JBQ1YsTUFBTSxFQUFFLEdBQUc7cUJBQ1osQ0FBQyxDQUNIO29CQUNELFVBQVUsQ0FBQyx1QkFBdUIsRUFBRTt3QkFDbEMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDO3dCQUN0QixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3dCQUNuQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3FCQUNuQyxDQUFDO29CQUNGLFVBQVUsQ0FBQyx1QkFBdUIsRUFBRTt3QkFDbEMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDO3dCQUN0QixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3dCQUNuQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO3FCQUNyQyxDQUFDO2lCQUNILENBQUM7YUFDSDs7aUZBRVUsdUJBQXVCO2NBNUJuQyxTQUFTOzJCQUNFLG1CQUFtQixtQkFFWix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DO29CQUNWLE9BQU8sQ0FBQyxZQUFZLEVBQUU7d0JBQ3BCLEtBQUssQ0FDSCxXQUFXLEVBQ1gsS0FBSyxDQUFDOzRCQUNKLFlBQVksRUFBRSxRQUFROzRCQUN0QixVQUFVLEVBQUUsUUFBUTs0QkFDcEIsT0FBTyxFQUFFLENBQUM7NEJBQ1YsTUFBTSxFQUFFLEdBQUc7eUJBQ1osQ0FBQyxDQUNIO3dCQUNELFVBQVUsQ0FBQyx1QkFBdUIsRUFBRTs0QkFDbEMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDOzRCQUN0QixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUNuQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3lCQUNuQyxDQUFDO3dCQUNGLFVBQVUsQ0FBQyx1QkFBdUIsRUFBRTs0QkFDbEMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDOzRCQUN0QixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUNuQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO3lCQUNyQyxDQUFDO3FCQUNILENBQUM7aUJBQ0g7a0RBR2dCLElBQUk7a0JBQXBCLEtBQUs7bUJBQUMsUUFBUTtZQUVRLFVBQVU7a0JBQWhDLEtBQUs7bUJBQUMsY0FBYztZQUVLLFlBQVk7a0JBQXJDLEtBQUs7bUJBQUMsaUJBQWlCO1lBRUcsYUFBYTtrQkFBdkMsS0FBSzttQkFBQyxrQkFBa0I7O2tGQVBkLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuaW1hdGUsIHN0YXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUG9UcmVlVmlld0l0ZW0gfSBmcm9tICcuL3BvLXRyZWUtdmlldy1pdGVtLmludGVyZmFjZSc7XG5pbXBvcnQgeyBQb1RyZWVWaWV3U2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3BvLXRyZWUtdmlldy5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tdHJlZS12aWV3LWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vcG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgYW5pbWF0aW9uczogW1xuICAgIHRyaWdnZXIoJ3RvZ2dsZUJvZHknLCBbXG4gICAgICBzdGF0ZShcbiAgICAgICAgJ2NvbGxhcHNlZCcsXG4gICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAnb3ZlcmZsb3cteSc6ICdoaWRkZW4nLFxuICAgICAgICAgIHZpc2liaWxpdHk6ICdoaWRkZW4nLFxuICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgaGVpZ2h0OiAnMCdcbiAgICAgICAgfSlcbiAgICAgICksXG4gICAgICB0cmFuc2l0aW9uKCdleHBhbmRlZCA9PiBjb2xsYXBzZWQnLCBbXG4gICAgICAgIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSksXG4gICAgICAgIGFuaW1hdGUoMTAwLCBzdHlsZSh7IG9wYWNpdHk6IDAgfSkpLFxuICAgICAgICBhbmltYXRlKDIwMCwgc3R5bGUoeyBoZWlnaHQ6IDAgfSkpXG4gICAgICBdKSxcbiAgICAgIHRyYW5zaXRpb24oJ2NvbGxhcHNlZCA9PiBleHBhbmRlZCcsIFtcbiAgICAgICAgc3R5bGUoeyBoZWlnaHQ6ICcwJyB9KSxcbiAgICAgICAgYW5pbWF0ZSgxMDAsIHN0eWxlKHsgb3BhY2l0eTogMSB9KSksXG4gICAgICAgIGFuaW1hdGUoMjAwLCBzdHlsZSh7IGhlaWdodDogJyonIH0pKVxuICAgICAgXSlcbiAgICBdKVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFBvVHJlZVZpZXdJdGVtQ29tcG9uZW50IHtcbiAgQElucHV0KCdwLWl0ZW0nKSBpdGVtOiBQb1RyZWVWaWV3SXRlbTtcblxuICBASW5wdXQoJ3Atc2VsZWN0YWJsZScpIHNlbGVjdGFibGU6IGJvb2xlYW47XG5cbiAgQElucHV0KCdwLXNpbmdsZS1zZWxlY3QnKSBzaW5nbGVTZWxlY3Q6IGJvb2xlYW47XG5cbiAgQElucHV0KCdwLXNlbGVjdGVkLXZhbHVlJykgc2VsZWN0ZWRWYWx1ZTogc3RyaW5nIHwgbnVtYmVyO1xuXG4gIGdldCBoYXNTdWJJdGVtcygpIHtcbiAgICByZXR1cm4gISEodGhpcy5pdGVtLnN1Ykl0ZW1zICYmIHRoaXMuaXRlbS5zdWJJdGVtcy5sZW5ndGgpO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmVlVmlld1NlcnZpY2U6IFBvVHJlZVZpZXdTZXJ2aWNlKSB7fVxuXG4gIG9uQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgdGhpcy5pdGVtLmV4cGFuZGVkID0gIXRoaXMuaXRlbS5leHBhbmRlZDtcblxuICAgIHRoaXMudHJlZVZpZXdTZXJ2aWNlLmVtaXRFeHBhbmRlZEV2ZW50KHsgLi4udGhpcy5pdGVtIH0pO1xuICB9XG5cbiAgb25TZWxlY3Qoc2VsZWN0ZWRJdGVtOiBQb1RyZWVWaWV3SXRlbSkge1xuICAgIHRoaXMudHJlZVZpZXdTZXJ2aWNlLmVtaXRTZWxlY3RlZEV2ZW50KHsgLi4uc2VsZWN0ZWRJdGVtIH0pO1xuICB9XG5cbiAgdHJhY2tCeUZ1bmN0aW9uKGluZGV4OiBudW1iZXIpIHtcbiAgICByZXR1cm4gaW5kZXg7XG4gIH1cbn1cbiIsIjxsaSBjbGFzcz1cInBvLXRyZWUtdmlldy1pdGVtXCI+XG4gIDxwby10cmVlLXZpZXctaXRlbS1oZWFkZXJcbiAgICBbcC1pdGVtXT1cIml0ZW1cIlxuICAgIFtwLXNlbGVjdGFibGVdPVwic2VsZWN0YWJsZVwiXG4gICAgW3Atc2luZ2xlLXNlbGVjdF09XCJzaW5nbGVTZWxlY3RcIlxuICAgIFtwLXNlbGVjdGVkLXZhbHVlXT1cInNlbGVjdGVkVmFsdWVcIlxuICAgIChwLWV4cGFuZGVkKT1cIm9uQ2xpY2soJGV2ZW50KVwiXG4gICAgKHAtc2VsZWN0ZWQpPVwib25TZWxlY3QoaXRlbSlcIlxuICA+XG4gIDwvcG8tdHJlZS12aWV3LWl0ZW0taGVhZGVyPlxuXG4gIDx1bCAqbmdJZj1cImhhc1N1Ykl0ZW1zXCIgY2xhc3M9XCJwby10cmVlLXZpZXctaXRlbS1ncm91cFwiIFtAdG9nZ2xlQm9keV09XCJpdGVtLmV4cGFuZGVkID8gJ2V4cGFuZGVkJyA6ICdjb2xsYXBzZWQnXCI+XG4gICAgPHBvLXRyZWUtdmlldy1pdGVtXG4gICAgICAqbmdGb3I9XCJsZXQgc3ViSXRlbSBvZiBpdGVtLnN1Ykl0ZW1zOyB0cmFja0J5OiB0cmFja0J5RnVuY3Rpb25cIlxuICAgICAgW3AtaXRlbV09XCJzdWJJdGVtXCJcbiAgICAgIFtwLXNlbGVjdGFibGVdPVwic2VsZWN0YWJsZVwiXG4gICAgICBbcC1zaW5nbGUtc2VsZWN0XT1cInNpbmdsZVNlbGVjdFwiXG4gICAgICBbcC1zZWxlY3RlZC12YWx1ZV09XCJzZWxlY3RlZFZhbHVlXCJcbiAgICA+XG4gICAgPC9wby10cmVlLXZpZXctaXRlbT5cbiAgPC91bD5cbjwvbGk+XG4iXX0=
133
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoTreeViewItemComponent, { className: "PoTreeViewItemComponent", filePath: "lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.ts", lineNumber: 36 }); })();
134
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXRyZWUtdmlldy9wby10cmVlLXZpZXctaXRlbS9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdHJlZS12aWV3L3BvLXRyZWUtdmlldy1pdGVtL3BvLXRyZWUtdmlldy1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQVMsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNqRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0lDWXBFLHVDQU9vQjs7OztJQUxsQixtQ0FBa0IsbUNBQUEsd0NBQUEsMENBQUE7OztJQUh0QiwyQkFBdUM7SUFDckMsK0dBT29CO0lBQ3RCLGlCQUFNOzs7SUFUcUIsdUNBQVc7SUFFZCxjQUFrQjtJQUFsQiw4Q0FBa0Isd0NBQUE7OztJQUg1Qyw2QkFBd0Q7SUFDdEQsNkVBU007SUFDUixpQkFBSzs7O0lBVkcsY0FBbUI7SUFBbkIsMkNBQW1COztBRHVCN0IsTUFBTSxPQUFPLHVCQUF1QjtJQWFkO0lBWkgsSUFBSSxDQUFpQjtJQUVmLFVBQVUsQ0FBVTtJQUVqQixZQUFZLENBQVU7SUFFckIsYUFBYSxDQUFrQjtJQUUxRCxJQUFJLFdBQVc7UUFDYixPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxZ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QUUsR0FBRzs2QkFDWixDQUFDOzRCQUNGLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7NEJBQ2xDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7eUJBQ3BDLENBQUM7cUJBQ0gsQ0FBQztpQkFDSDtrREFHZ0IsSUFBSTtrQkFBcEIsS0FBSzttQkFBQyxRQUFRO1lBRVEsVUFBVTtrQkFBaEMsS0FBSzttQkFBQyxjQUFjO1lBRUssWUFBWTtrQkFBckMsS0FBSzttQkFBQyxpQkFBaUI7WUFFRyxhQUFhO2tCQUF2QyxLQUFLO21CQUFDLGtCQUFrQjs7a0ZBUGQsdUJBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBQb1RyZWVWaWV3SXRlbSB9IGZyb20gJy4vcG8tdHJlZS12aWV3LWl0ZW0uaW50ZXJmYWNlJztcbmltcG9ydCB7IFBvVHJlZVZpZXdTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvcG8tdHJlZS12aWV3LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwby10cmVlLXZpZXctaXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBhbmltYXRpb25zOiBbXG4gICAgdHJpZ2dlcigndG9nZ2xlQm9keScsIFtcbiAgICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgICdvdmVyZmxvdy15JzogJ2hpZGRlbicsXG4gICAgICAgICAgdmlzaWJpbGl0eTogJ2hpZGRlbicsXG4gICAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgICBoZWlnaHQ6ICcwJ1xuICAgICAgICB9KSxcbiAgICAgICAgYW5pbWF0ZSgyMDAsIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSkpLFxuICAgICAgICBhbmltYXRlKDEwMCwgc3R5bGUoeyBvcGFjaXR5OiAxIH0pKVxuICAgICAgXSksXG4gICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbXG4gICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAnb3ZlcmZsb3cteSc6ICdoaWRkZW4nLFxuICAgICAgICAgIHZpc2liaWxpdHk6ICd2aXNpYmxlJyxcbiAgICAgICAgICBvcGFjaXR5OiAxLFxuICAgICAgICAgIGhlaWdodDogJyonXG4gICAgICAgIH0pLFxuICAgICAgICBhbmltYXRlKDIwMCwgc3R5bGUoeyBoZWlnaHQ6IDAgfSkpLFxuICAgICAgICBhbmltYXRlKDEwMCwgc3R5bGUoeyBvcGFjaXR5OiAwIH0pKVxuICAgICAgXSlcbiAgICBdKVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFBvVHJlZVZpZXdJdGVtQ29tcG9uZW50IHtcbiAgQElucHV0KCdwLWl0ZW0nKSBpdGVtOiBQb1RyZWVWaWV3SXRlbTtcblxuICBASW5wdXQoJ3Atc2VsZWN0YWJsZScpIHNlbGVjdGFibGU6IGJvb2xlYW47XG5cbiAgQElucHV0KCdwLXNpbmdsZS1zZWxlY3QnKSBzaW5nbGVTZWxlY3Q6IGJvb2xlYW47XG5cbiAgQElucHV0KCdwLXNlbGVjdGVkLXZhbHVlJykgc2VsZWN0ZWRWYWx1ZTogc3RyaW5nIHwgbnVtYmVyO1xuXG4gIGdldCBoYXNTdWJJdGVtcygpIHtcbiAgICByZXR1cm4gISEodGhpcy5pdGVtLnN1Ykl0ZW1zICYmIHRoaXMuaXRlbS5zdWJJdGVtcy5sZW5ndGgpO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmVlVmlld1NlcnZpY2U6IFBvVHJlZVZpZXdTZXJ2aWNlKSB7fVxuXG4gIG9uQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgdGhpcy5pdGVtLmV4cGFuZGVkID0gIXRoaXMuaXRlbS5leHBhbmRlZDtcblxuICAgIHRoaXMudHJlZVZpZXdTZXJ2aWNlLmVtaXRFeHBhbmRlZEV2ZW50KHsgLi4udGhpcy5pdGVtIH0pO1xuICB9XG5cbiAgb25TZWxlY3Qoc2VsZWN0ZWRJdGVtOiBQb1RyZWVWaWV3SXRlbSkge1xuICAgIHRoaXMudHJlZVZpZXdTZXJ2aWNlLmVtaXRTZWxlY3RlZEV2ZW50KHsgLi4uc2VsZWN0ZWRJdGVtIH0pO1xuICB9XG5cbiAgdHJhY2tCeUZ1bmN0aW9uKGluZGV4OiBudW1iZXIpIHtcbiAgICByZXR1cm4gaW5kZXg7XG4gIH1cbn1cbiIsIjxsaSBjbGFzcz1cInBvLXRyZWUtdmlldy1pdGVtXCI+XG4gIDxwby10cmVlLXZpZXctaXRlbS1oZWFkZXJcbiAgICBbcC1pdGVtXT1cIml0ZW1cIlxuICAgIFtwLXNlbGVjdGFibGVdPVwic2VsZWN0YWJsZVwiXG4gICAgW3Atc2luZ2xlLXNlbGVjdF09XCJzaW5nbGVTZWxlY3RcIlxuICAgIFtwLXNlbGVjdGVkLXZhbHVlXT1cInNlbGVjdGVkVmFsdWVcIlxuICAgIChwLWV4cGFuZGVkKT1cIm9uQ2xpY2soJGV2ZW50KVwiXG4gICAgKHAtc2VsZWN0ZWQpPVwib25TZWxlY3QoaXRlbSlcIlxuICA+XG4gIDwvcG8tdHJlZS12aWV3LWl0ZW0taGVhZGVyPlxuXG4gIDx1bCAqbmdJZj1cImhhc1N1Ykl0ZW1zXCIgY2xhc3M9XCJwby10cmVlLXZpZXctaXRlbS1ncm91cFwiPlxuICAgIDxkaXYgKm5nSWY9XCJpdGVtLmV4cGFuZGVkXCIgQHRvZ2dsZUJvZHk+XG4gICAgICA8cG8tdHJlZS12aWV3LWl0ZW1cbiAgICAgICAgKm5nRm9yPVwibGV0IHN1Ykl0ZW0gb2YgaXRlbS5zdWJJdGVtczsgdHJhY2tCeTogdHJhY2tCeUZ1bmN0aW9uXCJcbiAgICAgICAgW3AtaXRlbV09XCJzdWJJdGVtXCJcbiAgICAgICAgW3Atc2VsZWN0YWJsZV09XCJzZWxlY3RhYmxlXCJcbiAgICAgICAgW3Atc2luZ2xlLXNlbGVjdF09XCJzaW5nbGVTZWxlY3RcIlxuICAgICAgICBbcC1zZWxlY3RlZC12YWx1ZV09XCJzZWxlY3RlZFZhbHVlXCJcbiAgICAgID5cbiAgICAgIDwvcG8tdHJlZS12aWV3LWl0ZW0+XG4gICAgPC9kaXY+XG4gIDwvdWw+XG48L2xpPlxuIl19
@@ -39523,6 +39523,35 @@ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
39523
39523
  * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.
39524
39524
  *
39525
39525
  * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.
39526
+ *
39527
+ * *
39528
+ * #### Tokens customizáveis
39529
+ *
39530
+ * É possível alterar o estilo do componente usando os seguintes tokens (CSS):
39531
+ *
39532
+ * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
39533
+ *
39534
+ * | Propriedade | Descrição | Valor Padrão |
39535
+ * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|
39536
+ * | **Default Values** | | |
39537
+ * | `--font-family` | Família tipográfica usada | `var(--font-family-theme)` |
39538
+ * | `--font-size` | Tamanho da fonte | `var(--font-size-default)` |
39539
+ * | `--text-color-empty` | Cor do placeholder | `var(--color-neutral-light-30)` |
39540
+ * | `--color` | Cor da borda | `var(--color-neutral-dark-70)` |
39541
+ * | `--background` | Cor de background | `var(--color-neutral-light-05)` |
39542
+ * | `--text-color` | Cor do texto | `var(--color-neutral-dark-90)` |
39543
+ * | `--padding-horizontal` | Preenchimento horizontal | `0.5em` |
39544
+ * | `--padding-vertical` | Preenchimento vertical | `0.7em` |
39545
+ * | **Hover** | | |
39546
+ * | `--color-hover` | Cor principal no estado hover | `var(--color-brand-01-dark)` |
39547
+ * | `--background-hover` | Cor de background no estado hover | `var(--color-brand-01-lighter)` |
39548
+ * | **Focused** | | |
39549
+ * | `--outline-color-focused` | Cor do outline do estado de focus | `var(--color-action-focus)` |
39550
+ * | `--color-focused` | Cor da borda no estado de focus | `var(--color-action-default)` |
39551
+ * | **Disabled** | | |
39552
+ * | `--color-disabled` | Cor principal no estado disabled | `var(--color-neutral-light-30)` |
39553
+ * | `--background-color-disabled`&nbsp; | Cor de background no estado disabled | `var(--color-neutral-light-20)` |
39554
+ *
39526
39555
  */
39527
39556
  class PoSelectComponent extends PoFieldValidateModel {
39528
39557
  changeDetector;
@@ -39884,7 +39913,7 @@ class PoSelectComponent extends PoFieldValidateModel {
39884
39913
  type: Input,
39885
39914
  args: ['p-field-value']
39886
39915
  }] }); })();
39887
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 95 }); })();
39916
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 124 }); })();
39888
39917
 
39889
39918
  /**
39890
39919
  * @description
@@ -54619,22 +54648,31 @@ class PoTreeViewItemHeaderComponent {
54619
54648
  }] }); })();
54620
54649
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoTreeViewItemHeaderComponent, { className: "PoTreeViewItemHeaderComponent", filePath: "lib/components/po-tree-view/po-tree-view-item-header/po-tree-view-item-header.component.ts", lineNumber: 11 }); })();
54621
54650
 
54622
- function PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
54623
- i0.ɵɵelement(0, "po-tree-view-item", 5);
54651
+ function PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
54652
+ i0.ɵɵelement(0, "po-tree-view-item", 6);
54653
+ } if (rf & 2) {
54654
+ const subItem_r3 = ctx.$implicit;
54655
+ const ctx_r2 = i0.ɵɵnextContext(3);
54656
+ i0.ɵɵproperty("p-item", subItem_r3)("p-selectable", ctx_r2.selectable)("p-single-select", ctx_r2.singleSelect)("p-selected-value", ctx_r2.selectedValue);
54657
+ } }
54658
+ function PoTreeViewItemComponent_ul_2_div_1_Template(rf, ctx) { if (rf & 1) {
54659
+ i0.ɵɵelementStart(0, "div");
54660
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 5);
54661
+ i0.ɵɵelementEnd();
54624
54662
  } if (rf & 2) {
54625
- const subItem_r2 = ctx.$implicit;
54626
54663
  const ctx_r1 = i0.ɵɵnextContext(2);
54627
- i0.ɵɵproperty("p-item", subItem_r2)("p-selectable", ctx_r1.selectable)("p-single-select", ctx_r1.singleSelect)("p-selected-value", ctx_r1.selectedValue);
54664
+ i0.ɵɵproperty("@toggleBody", undefined);
54665
+ i0.ɵɵadvance();
54666
+ i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
54628
54667
  } }
54629
54668
  function PoTreeViewItemComponent_ul_2_Template(rf, ctx) { if (rf & 1) {
54630
54669
  i0.ɵɵelementStart(0, "ul", 3);
54631
- i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 4);
54670
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_Template, 2, 3, "div", 4);
54632
54671
  i0.ɵɵelementEnd();
54633
54672
  } if (rf & 2) {
54634
54673
  const ctx_r0 = i0.ɵɵnextContext();
54635
- i0.ɵɵproperty("@toggleBody", ctx_r0.item.expanded ? "expanded" : "collapsed");
54636
54674
  i0.ɵɵadvance();
54637
- i0.ɵɵproperty("ngForOf", ctx_r0.item.subItems)("ngForTrackBy", ctx_r0.trackByFunction);
54675
+ i0.ɵɵproperty("ngIf", ctx_r0.item.expanded);
54638
54676
  } }
54639
54677
  class PoTreeViewItemComponent {
54640
54678
  treeViewService;
@@ -54661,11 +54699,11 @@ class PoTreeViewItemComponent {
54661
54699
  return index;
54662
54700
  }
54663
54701
  static ɵfac = function PoTreeViewItemComponent_Factory(t) { return new (t || PoTreeViewItemComponent)(i0.ɵɵdirectiveInject(PoTreeViewService)); };
54664
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [i0.ɵɵInputFlags.None, "p-item", "item"], selectable: [i0.ɵɵInputFlags.None, "p-selectable", "selectable"], singleSelect: [i0.ɵɵInputFlags.None, "p-single-select", "singleSelect"], selectedValue: [i0.ɵɵInputFlags.None, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", "p-expanded", "p-selected"], ["class", "po-tree-view-item-group", 4, "ngIf"], [1, "po-tree-view-item-group"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", 4, "ngFor", "ngForOf", "ngForTrackBy"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value"]], template: function PoTreeViewItemComponent_Template(rf, ctx) { if (rf & 1) {
54702
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [i0.ɵɵInputFlags.None, "p-item", "item"], selectable: [i0.ɵɵInputFlags.None, "p-selectable", "selectable"], singleSelect: [i0.ɵɵInputFlags.None, "p-single-select", "singleSelect"], selectedValue: [i0.ɵɵInputFlags.None, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", "p-expanded", "p-selected"], ["class", "po-tree-view-item-group", 4, "ngIf"], [1, "po-tree-view-item-group"], [4, "ngIf"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value", 4, "ngFor", "ngForOf", "ngForTrackBy"], [3, "p-item", "p-selectable", "p-single-select", "p-selected-value"]], template: function PoTreeViewItemComponent_Template(rf, ctx) { if (rf & 1) {
54665
54703
  i0.ɵɵelementStart(0, "li", 0)(1, "po-tree-view-item-header", 1);
54666
54704
  i0.ɵɵlistener("p-expanded", function PoTreeViewItemComponent_Template_po_tree_view_item_header_p_expanded_1_listener($event) { return ctx.onClick($event); })("p-selected", function PoTreeViewItemComponent_Template_po_tree_view_item_header_p_selected_1_listener() { return ctx.onSelect(ctx.item); });
54667
54705
  i0.ɵɵelementEnd();
54668
- i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 3, "ul", 2);
54706
+ i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 1, "ul", 2);
54669
54707
  i0.ɵɵelementEnd();
54670
54708
  } if (rf & 2) {
54671
54709
  i0.ɵɵadvance();
@@ -54674,21 +54712,25 @@ class PoTreeViewItemComponent {
54674
54712
  i0.ɵɵproperty("ngIf", ctx.hasSubItems);
54675
54713
  } }, dependencies: [i1.NgForOf, i1.NgIf, PoTreeViewItemComponent, PoTreeViewItemHeaderComponent], encapsulation: 2, data: { animation: [
54676
54714
  trigger('toggleBody', [
54677
- state('collapsed', style({
54678
- 'overflow-y': 'hidden',
54679
- visibility: 'hidden',
54680
- opacity: 0,
54681
- height: '0'
54682
- })),
54683
- transition('expanded => collapsed', [
54684
- style({ height: '*' }),
54685
- animate(100, style({ opacity: 0 })),
54686
- animate(200, style({ height: 0 }))
54715
+ transition(':enter', [
54716
+ style({
54717
+ 'overflow-y': 'hidden',
54718
+ visibility: 'hidden',
54719
+ opacity: 0,
54720
+ height: '0'
54721
+ }),
54722
+ animate(200, style({ height: '*' })),
54723
+ animate(100, style({ opacity: 1 }))
54687
54724
  ]),
54688
- transition('collapsed => expanded', [
54689
- style({ height: '0' }),
54690
- animate(100, style({ opacity: 1 })),
54691
- animate(200, style({ height: '*' }))
54725
+ transition(':leave', [
54726
+ style({
54727
+ 'overflow-y': 'hidden',
54728
+ visibility: 'visible',
54729
+ opacity: 1,
54730
+ height: '*'
54731
+ }),
54732
+ animate(200, style({ height: 0 })),
54733
+ animate(100, style({ opacity: 0 }))
54692
54734
  ])
54693
54735
  ])
54694
54736
  ] }, changeDetection: 0 });
@@ -54697,24 +54739,28 @@ class PoTreeViewItemComponent {
54697
54739
  type: Component,
54698
54740
  args: [{ selector: 'po-tree-view-item', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
54699
54741
  trigger('toggleBody', [
54700
- state('collapsed', style({
54701
- 'overflow-y': 'hidden',
54702
- visibility: 'hidden',
54703
- opacity: 0,
54704
- height: '0'
54705
- })),
54706
- transition('expanded => collapsed', [
54707
- style({ height: '*' }),
54708
- animate(100, style({ opacity: 0 })),
54709
- animate(200, style({ height: 0 }))
54742
+ transition(':enter', [
54743
+ style({
54744
+ 'overflow-y': 'hidden',
54745
+ visibility: 'hidden',
54746
+ opacity: 0,
54747
+ height: '0'
54748
+ }),
54749
+ animate(200, style({ height: '*' })),
54750
+ animate(100, style({ opacity: 1 }))
54710
54751
  ]),
54711
- transition('collapsed => expanded', [
54712
- style({ height: '0' }),
54713
- animate(100, style({ opacity: 1 })),
54714
- animate(200, style({ height: '*' }))
54752
+ transition(':leave', [
54753
+ style({
54754
+ 'overflow-y': 'hidden',
54755
+ visibility: 'visible',
54756
+ opacity: 1,
54757
+ height: '*'
54758
+ }),
54759
+ animate(200, style({ height: 0 })),
54760
+ animate(100, style({ opacity: 0 }))
54715
54761
  ])
54716
54762
  ])
54717
- ], template: "<li class=\"po-tree-view-item\">\n <po-tree-view-item-header\n [p-item]=\"item\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n (p-expanded)=\"onClick($event)\"\n (p-selected)=\"onSelect(item)\"\n >\n </po-tree-view-item-header>\n\n <ul *ngIf=\"hasSubItems\" class=\"po-tree-view-item-group\" [@toggleBody]=\"item.expanded ? 'expanded' : 'collapsed'\">\n <po-tree-view-item\n *ngFor=\"let subItem of item.subItems; trackBy: trackByFunction\"\n [p-item]=\"subItem\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n >\n </po-tree-view-item>\n </ul>\n</li>\n" }]
54763
+ ], template: "<li class=\"po-tree-view-item\">\n <po-tree-view-item-header\n [p-item]=\"item\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n (p-expanded)=\"onClick($event)\"\n (p-selected)=\"onSelect(item)\"\n >\n </po-tree-view-item-header>\n\n <ul *ngIf=\"hasSubItems\" class=\"po-tree-view-item-group\">\n <div *ngIf=\"item.expanded\" @toggleBody>\n <po-tree-view-item\n *ngFor=\"let subItem of item.subItems; trackBy: trackByFunction\"\n [p-item]=\"subItem\"\n [p-selectable]=\"selectable\"\n [p-single-select]=\"singleSelect\"\n [p-selected-value]=\"selectedValue\"\n >\n </po-tree-view-item>\n </div>\n </ul>\n</li>\n" }]
54718
54764
  }], () => [{ type: PoTreeViewService }], { item: [{
54719
54765
  type: Input,
54720
54766
  args: ['p-item']
@@ -54728,7 +54774,7 @@ class PoTreeViewItemComponent {
54728
54774
  type: Input,
54729
54775
  args: ['p-selected-value']
54730
54776
  }] }); })();
54731
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoTreeViewItemComponent, { className: "PoTreeViewItemComponent", filePath: "lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.ts", lineNumber: 35 }); })();
54777
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoTreeViewItemComponent, { className: "PoTreeViewItemComponent", filePath: "lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.ts", lineNumber: 36 }); })();
54732
54778
 
54733
54779
  function PoTreeViewComponent_po_container_0_po_tree_view_item_2_Template(rf, ctx) { if (rf & 1) {
54734
54780
  i0.ɵɵelement(0, "po-tree-view-item", 4);