@po-ui/ng-components 18.0.1 → 18.2.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,34 @@ 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
+ * #### Tokens customizáveis
156
+ *
157
+ * É possível alterar o estilo do componente usando os seguintes tokens (CSS):
158
+ *
159
+ * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
160
+ *
161
+ * | Propriedade | Descrição | Valor Padrão |
162
+ * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|
163
+ * | **Default Values** | | |
164
+ * | `--font-family` | Família tipográfica usada | `var(--font-family-theme)` |
165
+ * | `--font-size` | Tamanho da fonte | `var(--font-size-default)` |
166
+ * | `--text-color-empty` | Cor do placeholder | `var(--color-neutral-light-30)` |
167
+ * | `--color` | Cor da borda | `var(--color-neutral-dark-70)` |
168
+ * | `--background` | Cor de background | `var(--color-neutral-light-05)` |
169
+ * | `--text-color` | Cor do texto | `var(--color-neutral-dark-90)` |
170
+ * | `--padding-horizontal` | Preenchimento horizontal | `0.5em` |
171
+ * | `--padding-vertical` | Preenchimento vertical | `0.7em` |
172
+ * | **Hover** | | |
173
+ * | `--color-hover` | Cor principal no estado hover | `var(--color-brand-01-dark)` |
174
+ * | `--background-hover` | Cor de background no estado hover | `var(--color-brand-01-lighter)` |
175
+ * | **Focused** | | |
176
+ * | `--outline-color-focused` | Cor do outline do estado de focus | `var(--color-action-focus)` |
177
+ * | `--color-focused` | Cor da borda no estado de focus | `var(--color-action-default)` |
178
+ * | **Disabled** | | |
179
+ * | `--color-disabled` | Cor principal no estado disabled | `var(--color-neutral-light-30)` |
180
+ * | `--background-color-disabled`  | Cor de background no estado disabled | `var(--color-neutral-light-20)` |
181
+ *
154
182
  */
155
183
  export class PoSelectComponent extends PoFieldValidateModel {
156
184
  changeDetector;
@@ -513,5 +541,5 @@ export class PoSelectComponent extends PoFieldValidateModel {
513
541
  type: Input,
514
542
  args: ['p-field-value']
515
543
  }] }); })();
516
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 95 }); })();
517
- //# 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, PhosphorIconDictionary } 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 ?? PhosphorIconDictionary;\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: 123 }); })();
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, PhosphorIconDictionary } 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 * #### 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 ?? PhosphorIconDictionary;\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
9
  } if (rf & 2) {
10
10
  const subItem_r1 = ctx.$implicit;
11
- const ctx_r1 = i0.ɵɵnextContext(2);
11
+ const ctx_r1 = i0.ɵɵnextContext(3);
12
12
  i0.ɵɵproperty("p-item", subItem_r1)("p-selectable", ctx_r1.selectable)("p-single-select", ctx_r1.singleSelect)("p-selected-value", ctx_r1.selectedValue);
13
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();
18
+ } if (rf & 2) {
19
+ const ctx_r1 = i0.ɵɵnextContext(2);
20
+ i0.ɵɵproperty("@toggleBody", undefined);
21
+ i0.ɵɵadvance();
22
+ i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
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_r1 = i0.ɵɵnextContext();
20
- i0.ɵɵproperty("@toggleBody", ctx_r1.item.expanded ? "expanded" : "collapsed");
21
30
  i0.ɵɵadvance();
22
- i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
31
+ i0.ɵɵproperty("ngIf", ctx_r1.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: [0, "p-item", "item"], selectable: [0, "p-selectable", "selectable"], singleSelect: [0, "p-single-select", "singleSelect"], selectedValue: [0, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-expanded", "p-selected", "p-item", "p-selectable", "p-single-select", "p-selected-value"], ["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: [0, "p-item", "item"], selectable: [0, "p-selectable", "selectable"], singleSelect: [0, "p-single-select", "singleSelect"], selectedValue: [0, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-expanded", "p-selected", "p-item", "p-selectable", "p-single-select", "p-selected-value"], ["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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXRyZWUtdmlldy9wby10cmVlLXZpZXctaXRlbS9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdHJlZS12aWV3L3BvLXRyZWUtdmlldy1pdGVtL3BvLXRyZWUtdmlldy1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztJQ1d0RSx1Q0FPb0I7Ozs7SUFGbEIsQUFEQSxBQURBLEFBREEsbUNBQWtCLG1DQUNTLHdDQUNLLDBDQUNFOzs7SUFOdEMsNkJBQWlIO0lBQy9HLHlHQU1DO0lBRUgsaUJBQUs7OztJQVRtRCw2RUFBd0Q7SUFFeEYsY0FBa0I7SUFBQSxBQUFsQiw4Q0FBa0Isd0NBQXdCOztBRHFCcEUsTUFBTSxPQUFPLHVCQUF1QjtJQWFkO0lBWkgsSUFBSSxDQUFpQjtJQUVmLFVBQVUsQ0FBVTtJQUVqQixZQUFZLENBQVU7SUFFckIsYUFBYSxDQUFrQjtJQUUxRCxJQUFJLFdBQVc7UUFDYixPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxZQUFvQixlQUFrQztRQUFsQyxvQkFBZSxHQUFmLGVBQWUs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QUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUM7NEJBQ3RCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7NEJBQ25DLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7eUJBQ3JDLENBQUM7cUJBQ0gsQ0FBQztpQkFDSDtrREFHZ0IsSUFBSTtrQkFBcEIsS0FBSzttQkFBQyxRQUFRO1lBRVEsVUFBVTtrQkFBaEMsS0FBSzttQkFBQyxjQUFjO1lBRUssWUFBWTtrQkFBckMsS0FBSzttQkFBQyxpQkFBaUI7WUFFRyxhQUFhO2tCQUF2QyxLQUFLO21CQUFDLGtCQUFrQjs7a0ZBUGQsdUJBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBQb1RyZWVWaWV3SXRlbSB9IGZyb20gJy4vcG8tdHJlZS12aWV3LWl0ZW0uaW50ZXJmYWNlJztcbmltcG9ydCB7IFBvVHJlZVZpZXdTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvcG8tdHJlZS12aWV3LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwby10cmVlLXZpZXctaXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBhbmltYXRpb25zOiBbXG4gICAgdHJpZ2dlcigndG9nZ2xlQm9keScsIFtcbiAgICAgIHN0YXRlKFxuICAgICAgICAnY29sbGFwc2VkJyxcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgICdvdmVyZmxvdy15JzogJ2hpZGRlbicsXG4gICAgICAgICAgdmlzaWJpbGl0eTogJ2hpZGRlbicsXG4gICAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgICBoZWlnaHQ6ICcwJ1xuICAgICAgICB9KVxuICAgICAgKSxcbiAgICAgIHRyYW5zaXRpb24oJ2V4cGFuZGVkID0+IGNvbGxhcHNlZCcsIFtcbiAgICAgICAgc3R5bGUoeyBoZWlnaHQ6ICcqJyB9KSxcbiAgICAgICAgYW5pbWF0ZSgxMDAsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSksXG4gICAgICAgIGFuaW1hdGUoMjAwLCBzdHlsZSh7IGhlaWdodDogMCB9KSlcbiAgICAgIF0pLFxuICAgICAgdHJhbnNpdGlvbignY29sbGFwc2VkID0+IGV4cGFuZGVkJywgW1xuICAgICAgICBzdHlsZSh7IGhlaWdodDogJzAnIH0pLFxuICAgICAgICBhbmltYXRlKDEwMCwgc3R5bGUoeyBvcGFjaXR5OiAxIH0pKSxcbiAgICAgICAgYW5pbWF0ZSgyMDAsIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSkpXG4gICAgICBdKVxuICAgIF0pXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgUG9UcmVlVmlld0l0ZW1Db21wb25lbnQge1xuICBASW5wdXQoJ3AtaXRlbScpIGl0ZW06IFBvVHJlZVZpZXdJdGVtO1xuXG4gIEBJbnB1dCgncC1zZWxlY3RhYmxlJykgc2VsZWN0YWJsZTogYm9vbGVhbjtcblxuICBASW5wdXQoJ3Atc2luZ2xlLXNlbGVjdCcpIHNpbmdsZVNlbGVjdDogYm9vbGVhbjtcblxuICBASW5wdXQoJ3Atc2VsZWN0ZWQtdmFsdWUnKSBzZWxlY3RlZFZhbHVlOiBzdHJpbmcgfCBudW1iZXI7XG5cbiAgZ2V0IGhhc1N1Ykl0ZW1zKCkge1xuICAgIHJldHVybiAhISh0aGlzLml0ZW0uc3ViSXRlbXMgJiYgdGhpcy5pdGVtLnN1Ykl0ZW1zLmxlbmd0aCk7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyZWVWaWV3U2VydmljZTogUG9UcmVlVmlld1NlcnZpY2UpIHt9XG5cbiAgb25DbGljayhldmVudDogTW91c2VFdmVudCkge1xuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG5cbiAgICB0aGlzLml0ZW0uZXhwYW5kZWQgPSAhdGhpcy5pdGVtLmV4cGFuZGVkO1xuXG4gICAgdGhpcy50cmVlVmlld1NlcnZpY2UuZW1pdEV4cGFuZGVkRXZlbnQoeyAuLi50aGlzLml0ZW0gfSk7XG4gIH1cblxuICBvblNlbGVjdChzZWxlY3RlZEl0ZW06IFBvVHJlZVZpZXdJdGVtKSB7XG4gICAgdGhpcy50cmVlVmlld1NlcnZpY2UuZW1pdFNlbGVjdGVkRXZlbnQoeyAuLi5zZWxlY3RlZEl0ZW0gfSk7XG4gIH1cblxuICB0cmFja0J5RnVuY3Rpb24oaW5kZXg6IG51bWJlcikge1xuICAgIHJldHVybiBpbmRleDtcbiAgfVxufVxuIiwiPGxpIGNsYXNzPVwicG8tdHJlZS12aWV3LWl0ZW1cIj5cbiAgPHBvLXRyZWUtdmlldy1pdGVtLWhlYWRlclxuICAgIFtwLWl0ZW1dPVwiaXRlbVwiXG4gICAgW3Atc2VsZWN0YWJsZV09XCJzZWxlY3RhYmxlXCJcbiAgICBbcC1zaW5nbGUtc2VsZWN0XT1cInNpbmdsZVNlbGVjdFwiXG4gICAgW3Atc2VsZWN0ZWQtdmFsdWVdPVwic2VsZWN0ZWRWYWx1ZVwiXG4gICAgKHAtZXhwYW5kZWQpPVwib25DbGljaygkZXZlbnQpXCJcbiAgICAocC1zZWxlY3RlZCk9XCJvblNlbGVjdChpdGVtKVwiXG4gID5cbiAgPC9wby10cmVlLXZpZXctaXRlbS1oZWFkZXI+XG5cbiAgPHVsICpuZ0lmPVwiaGFzU3ViSXRlbXNcIiBjbGFzcz1cInBvLXRyZWUtdmlldy1pdGVtLWdyb3VwXCIgW0B0b2dnbGVCb2R5XT1cIml0ZW0uZXhwYW5kZWQgPyAnZXhwYW5kZWQnIDogJ2NvbGxhcHNlZCdcIj5cbiAgICA8cG8tdHJlZS12aWV3LWl0ZW1cbiAgICAgICpuZ0Zvcj1cImxldCBzdWJJdGVtIG9mIGl0ZW0uc3ViSXRlbXM7IHRyYWNrQnk6IHRyYWNrQnlGdW5jdGlvblwiXG4gICAgICBbcC1pdGVtXT1cInN1Ykl0ZW1cIlxuICAgICAgW3Atc2VsZWN0YWJsZV09XCJzZWxlY3RhYmxlXCJcbiAgICAgIFtwLXNpbmdsZS1zZWxlY3RdPVwic2luZ2xlU2VsZWN0XCJcbiAgICAgIFtwLXNlbGVjdGVkLXZhbHVlXT1cInNlbGVjdGVkVmFsdWVcIlxuICAgID5cbiAgICA8L3BvLXRyZWUtdmlldy1pdGVtPlxuICA8L3VsPlxuPC9saT5cbiJdfQ==
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXRyZWUtdmlldy9wby10cmVlLXZpZXctaXRlbS9wby10cmVlLXZpZXctaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdHJlZS12aWV3L3BvLXRyZWUtdmlldy1pdGVtL3BvLXRyZWUtdmlldy1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQVMsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNqRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0lDWXBFLHVDQU9vQjs7OztJQUZsQixBQURBLEFBREEsQUFEQSxtQ0FBa0IsbUNBQ1Msd0NBQ0ssMENBQ0U7OztJQU50QywyQkFBdUM7SUFDckMsK0dBTUM7SUFFSCxpQkFBTTs7O0lBVHFCLHVDQUFXO0lBRWQsY0FBa0I7SUFBQSxBQUFsQiw4Q0FBa0Isd0NBQXdCOzs7SUFIcEUsNkJBQXdEO0lBQ3RELDZFQUF1QztJQVV6QyxpQkFBSzs7O0lBVkcsY0FBbUI7SUFBbkIsMkNBQW1COztBRHVCN0IsTUFBTSxPQUFPLHVCQUF1QjtJQWFkO0lBWkgsSUFBSSxDQUFpQjtJQUVmLFVBQVUsQ0FBVTtJQUVqQixZQUFZLENBQVU7SUFFckIsYUFBYSxDQUFrQjtJQUUxRCxJQUFJLFdBQVc7UUFDYixPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxD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QUFVLEVBQUUsU0FBUztnQ0FDckIsT0FBTyxFQUFFLENBQUM7Z0NBQ1YsTUFBTSxFQUFFLEdBQUc7NkJBQ1osQ0FBQzs0QkFDRixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUNsQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3lCQUNwQyxDQUFDO3FCQUNILENBQUM7aUJBQ0g7a0RBR2dCLElBQUk7a0JBQXBCLEtBQUs7bUJBQUMsUUFBUTtZQUVRLFVBQVU7a0JBQWhDLEtBQUs7bUJBQUMsY0FBYztZQUVLLFlBQVk7a0JBQXJDLEtBQUs7bUJBQUMsaUJBQWlCO1lBRUcsYUFBYTtrQkFBdkMsS0FBSzttQkFBQyxrQkFBa0I7O2tGQVBkLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuaW1hdGUsIHN0YXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUG9UcmVlVmlld0l0ZW0gfSBmcm9tICcuL3BvLXRyZWUtdmlldy1pdGVtLmludGVyZmFjZSc7XG5pbXBvcnQgeyBQb1RyZWVWaWV3U2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3BvLXRyZWUtdmlldy5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tdHJlZS12aWV3LWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vcG8tdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgYW5pbWF0aW9uczogW1xuICAgIHRyaWdnZXIoJ3RvZ2dsZUJvZHknLCBbXG4gICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbXG4gICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAnb3ZlcmZsb3cteSc6ICdoaWRkZW4nLFxuICAgICAgICAgIHZpc2liaWxpdHk6ICdoaWRkZW4nLFxuICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgaGVpZ2h0OiAnMCdcbiAgICAgICAgfSksXG4gICAgICAgIGFuaW1hdGUoMjAwLCBzdHlsZSh7IGhlaWdodDogJyonIH0pKSxcbiAgICAgICAgYW5pbWF0ZSgxMDAsIHN0eWxlKHsgb3BhY2l0eTogMSB9KSlcbiAgICAgIF0pLFxuICAgICAgdHJhbnNpdGlvbignOmxlYXZlJywgW1xuICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgJ292ZXJmbG93LXknOiAnaGlkZGVuJyxcbiAgICAgICAgICB2aXNpYmlsaXR5OiAndmlzaWJsZScsXG4gICAgICAgICAgb3BhY2l0eTogMSxcbiAgICAgICAgICBoZWlnaHQ6ICcqJ1xuICAgICAgICB9KSxcbiAgICAgICAgYW5pbWF0ZSgyMDAsIHN0eWxlKHsgaGVpZ2h0OiAwIH0pKSxcbiAgICAgICAgYW5pbWF0ZSgxMDAsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSlcbiAgICAgIF0pXG4gICAgXSlcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBQb1RyZWVWaWV3SXRlbUNvbXBvbmVudCB7XG4gIEBJbnB1dCgncC1pdGVtJykgaXRlbTogUG9UcmVlVmlld0l0ZW07XG5cbiAgQElucHV0KCdwLXNlbGVjdGFibGUnKSBzZWxlY3RhYmxlOiBib29sZWFuO1xuXG4gIEBJbnB1dCgncC1zaW5nbGUtc2VsZWN0Jykgc2luZ2xlU2VsZWN0OiBib29sZWFuO1xuXG4gIEBJbnB1dCgncC1zZWxlY3RlZC12YWx1ZScpIHNlbGVjdGVkVmFsdWU6IHN0cmluZyB8IG51bWJlcjtcblxuICBnZXQgaGFzU3ViSXRlbXMoKSB7XG4gICAgcmV0dXJuICEhKHRoaXMuaXRlbS5zdWJJdGVtcyAmJiB0aGlzLml0ZW0uc3ViSXRlbXMubGVuZ3RoKTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJlZVZpZXdTZXJ2aWNlOiBQb1RyZWVWaWV3U2VydmljZSkge31cblxuICBvbkNsaWNrKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcblxuICAgIHRoaXMuaXRlbS5leHBhbmRlZCA9ICF0aGlzLml0ZW0uZXhwYW5kZWQ7XG5cbiAgICB0aGlzLnRyZWVWaWV3U2VydmljZS5lbWl0RXhwYW5kZWRFdmVudCh7IC4uLnRoaXMuaXRlbSB9KTtcbiAgfVxuXG4gIG9uU2VsZWN0KHNlbGVjdGVkSXRlbTogUG9UcmVlVmlld0l0ZW0pIHtcbiAgICB0aGlzLnRyZWVWaWV3U2VydmljZS5lbWl0U2VsZWN0ZWRFdmVudCh7IC4uLnNlbGVjdGVkSXRlbSB9KTtcbiAgfVxuXG4gIHRyYWNrQnlGdW5jdGlvbihpbmRleDogbnVtYmVyKSB7XG4gICAgcmV0dXJuIGluZGV4O1xuICB9XG59XG4iLCI8bGkgY2xhc3M9XCJwby10cmVlLXZpZXctaXRlbVwiPlxuICA8cG8tdHJlZS12aWV3LWl0ZW0taGVhZGVyXG4gICAgW3AtaXRlbV09XCJpdGVtXCJcbiAgICBbcC1zZWxlY3RhYmxlXT1cInNlbGVjdGFibGVcIlxuICAgIFtwLXNpbmdsZS1zZWxlY3RdPVwic2luZ2xlU2VsZWN0XCJcbiAgICBbcC1zZWxlY3RlZC12YWx1ZV09XCJzZWxlY3RlZFZhbHVlXCJcbiAgICAocC1leHBhbmRlZCk9XCJvbkNsaWNrKCRldmVudClcIlxuICAgIChwLXNlbGVjdGVkKT1cIm9uU2VsZWN0KGl0ZW0pXCJcbiAgPlxuICA8L3BvLXRyZWUtdmlldy1pdGVtLWhlYWRlcj5cblxuICA8dWwgKm5nSWY9XCJoYXNTdWJJdGVtc1wiIGNsYXNzPVwicG8tdHJlZS12aWV3LWl0ZW0tZ3JvdXBcIj5cbiAgICA8ZGl2ICpuZ0lmPVwiaXRlbS5leHBhbmRlZFwiIEB0b2dnbGVCb2R5PlxuICAgICAgPHBvLXRyZWUtdmlldy1pdGVtXG4gICAgICAgICpuZ0Zvcj1cImxldCBzdWJJdGVtIG9mIGl0ZW0uc3ViSXRlbXM7IHRyYWNrQnk6IHRyYWNrQnlGdW5jdGlvblwiXG4gICAgICAgIFtwLWl0ZW1dPVwic3ViSXRlbVwiXG4gICAgICAgIFtwLXNlbGVjdGFibGVdPVwic2VsZWN0YWJsZVwiXG4gICAgICAgIFtwLXNpbmdsZS1zZWxlY3RdPVwic2luZ2xlU2VsZWN0XCJcbiAgICAgICAgW3Atc2VsZWN0ZWQtdmFsdWVdPVwic2VsZWN0ZWRWYWx1ZVwiXG4gICAgICA+XG4gICAgICA8L3BvLXRyZWUtdmlldy1pdGVtPlxuICAgIDwvZGl2PlxuICA8L3VsPlxuPC9saT5cbiJdfQ==
@@ -39519,6 +39519,34 @@ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
39519
39519
  * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.
39520
39520
  *
39521
39521
  * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.
39522
+ *
39523
+ * #### Tokens customizáveis
39524
+ *
39525
+ * É possível alterar o estilo do componente usando os seguintes tokens (CSS):
39526
+ *
39527
+ * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
39528
+ *
39529
+ * | Propriedade | Descrição | Valor Padrão |
39530
+ * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|
39531
+ * | **Default Values** | | |
39532
+ * | `--font-family` | Família tipográfica usada | `var(--font-family-theme)` |
39533
+ * | `--font-size` | Tamanho da fonte | `var(--font-size-default)` |
39534
+ * | `--text-color-empty` | Cor do placeholder | `var(--color-neutral-light-30)` |
39535
+ * | `--color` | Cor da borda | `var(--color-neutral-dark-70)` |
39536
+ * | `--background` | Cor de background | `var(--color-neutral-light-05)` |
39537
+ * | `--text-color` | Cor do texto | `var(--color-neutral-dark-90)` |
39538
+ * | `--padding-horizontal` | Preenchimento horizontal | `0.5em` |
39539
+ * | `--padding-vertical` | Preenchimento vertical | `0.7em` |
39540
+ * | **Hover** | | |
39541
+ * | `--color-hover` | Cor principal no estado hover | `var(--color-brand-01-dark)` |
39542
+ * | `--background-hover` | Cor de background no estado hover | `var(--color-brand-01-lighter)` |
39543
+ * | **Focused** | | |
39544
+ * | `--outline-color-focused` | Cor do outline do estado de focus | `var(--color-action-focus)` |
39545
+ * | `--color-focused` | Cor da borda no estado de focus | `var(--color-action-default)` |
39546
+ * | **Disabled** | | |
39547
+ * | `--color-disabled` | Cor principal no estado disabled | `var(--color-neutral-light-30)` |
39548
+ * | `--background-color-disabled`&nbsp; | Cor de background no estado disabled | `var(--color-neutral-light-20)` |
39549
+ *
39522
39550
  */
39523
39551
  class PoSelectComponent extends PoFieldValidateModel {
39524
39552
  changeDetector;
@@ -39881,7 +39909,7 @@ class PoSelectComponent extends PoFieldValidateModel {
39881
39909
  type: Input,
39882
39910
  args: ['p-field-value']
39883
39911
  }] }); })();
39884
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 95 }); })();
39912
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSelectComponent, { className: "PoSelectComponent", filePath: "lib/components/po-field/po-select/po-select.component.ts", lineNumber: 123 }); })();
39885
39913
 
39886
39914
  /**
39887
39915
  * @description
@@ -54589,22 +54617,31 @@ class PoTreeViewItemHeaderComponent {
54589
54617
  }] }); })();
54590
54618
  (() => { (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 }); })();
54591
54619
 
54592
- function PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
54593
- i0.ɵɵelement(0, "po-tree-view-item", 5);
54620
+ function PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template(rf, ctx) { if (rf & 1) {
54621
+ i0.ɵɵelement(0, "po-tree-view-item", 6);
54594
54622
  } if (rf & 2) {
54595
54623
  const subItem_r1 = ctx.$implicit;
54596
- const ctx_r1 = i0.ɵɵnextContext(2);
54624
+ const ctx_r1 = i0.ɵɵnextContext(3);
54597
54625
  i0.ɵɵproperty("p-item", subItem_r1)("p-selectable", ctx_r1.selectable)("p-single-select", ctx_r1.singleSelect)("p-selected-value", ctx_r1.selectedValue);
54598
54626
  } }
54627
+ function PoTreeViewItemComponent_ul_2_div_1_Template(rf, ctx) { if (rf & 1) {
54628
+ i0.ɵɵelementStart(0, "div");
54629
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 5);
54630
+ i0.ɵɵelementEnd();
54631
+ } if (rf & 2) {
54632
+ const ctx_r1 = i0.ɵɵnextContext(2);
54633
+ i0.ɵɵproperty("@toggleBody", undefined);
54634
+ i0.ɵɵadvance();
54635
+ i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
54636
+ } }
54599
54637
  function PoTreeViewItemComponent_ul_2_Template(rf, ctx) { if (rf & 1) {
54600
54638
  i0.ɵɵelementStart(0, "ul", 3);
54601
- i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_po_tree_view_item_1_Template, 1, 4, "po-tree-view-item", 4);
54639
+ i0.ɵɵtemplate(1, PoTreeViewItemComponent_ul_2_div_1_Template, 2, 3, "div", 4);
54602
54640
  i0.ɵɵelementEnd();
54603
54641
  } if (rf & 2) {
54604
54642
  const ctx_r1 = i0.ɵɵnextContext();
54605
- i0.ɵɵproperty("@toggleBody", ctx_r1.item.expanded ? "expanded" : "collapsed");
54606
54643
  i0.ɵɵadvance();
54607
- i0.ɵɵproperty("ngForOf", ctx_r1.item.subItems)("ngForTrackBy", ctx_r1.trackByFunction);
54644
+ i0.ɵɵproperty("ngIf", ctx_r1.item.expanded);
54608
54645
  } }
54609
54646
  class PoTreeViewItemComponent {
54610
54647
  treeViewService;
@@ -54631,11 +54668,11 @@ class PoTreeViewItemComponent {
54631
54668
  return index;
54632
54669
  }
54633
54670
  static ɵfac = function PoTreeViewItemComponent_Factory(t) { return new (t || PoTreeViewItemComponent)(i0.ɵɵdirectiveInject(PoTreeViewService)); };
54634
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [0, "p-item", "item"], selectable: [0, "p-selectable", "selectable"], singleSelect: [0, "p-single-select", "singleSelect"], selectedValue: [0, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-expanded", "p-selected", "p-item", "p-selectable", "p-single-select", "p-selected-value"], ["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) {
54671
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTreeViewItemComponent, selectors: [["po-tree-view-item"]], inputs: { item: [0, "p-item", "item"], selectable: [0, "p-selectable", "selectable"], singleSelect: [0, "p-single-select", "singleSelect"], selectedValue: [0, "p-selected-value", "selectedValue"] }, decls: 3, vars: 5, consts: [[1, "po-tree-view-item"], [3, "p-expanded", "p-selected", "p-item", "p-selectable", "p-single-select", "p-selected-value"], ["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) {
54635
54672
  i0.ɵɵelementStart(0, "li", 0)(1, "po-tree-view-item-header", 1);
54636
54673
  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); });
54637
54674
  i0.ɵɵelementEnd();
54638
- i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 3, "ul", 2);
54675
+ i0.ɵɵtemplate(2, PoTreeViewItemComponent_ul_2_Template, 2, 1, "ul", 2);
54639
54676
  i0.ɵɵelementEnd();
54640
54677
  } if (rf & 2) {
54641
54678
  i0.ɵɵadvance();
@@ -54644,21 +54681,25 @@ class PoTreeViewItemComponent {
54644
54681
  i0.ɵɵproperty("ngIf", ctx.hasSubItems);
54645
54682
  } }, dependencies: [i1.NgForOf, i1.NgIf, PoTreeViewItemComponent, PoTreeViewItemHeaderComponent], encapsulation: 2, data: { animation: [
54646
54683
  trigger('toggleBody', [
54647
- state('collapsed', style({
54648
- 'overflow-y': 'hidden',
54649
- visibility: 'hidden',
54650
- opacity: 0,
54651
- height: '0'
54652
- })),
54653
- transition('expanded => collapsed', [
54654
- style({ height: '*' }),
54655
- animate(100, style({ opacity: 0 })),
54656
- animate(200, style({ height: 0 }))
54684
+ transition(':enter', [
54685
+ style({
54686
+ 'overflow-y': 'hidden',
54687
+ visibility: 'hidden',
54688
+ opacity: 0,
54689
+ height: '0'
54690
+ }),
54691
+ animate(200, style({ height: '*' })),
54692
+ animate(100, style({ opacity: 1 }))
54657
54693
  ]),
54658
- transition('collapsed => expanded', [
54659
- style({ height: '0' }),
54660
- animate(100, style({ opacity: 1 })),
54661
- animate(200, style({ height: '*' }))
54694
+ transition(':leave', [
54695
+ style({
54696
+ 'overflow-y': 'hidden',
54697
+ visibility: 'visible',
54698
+ opacity: 1,
54699
+ height: '*'
54700
+ }),
54701
+ animate(200, style({ height: 0 })),
54702
+ animate(100, style({ opacity: 0 }))
54662
54703
  ])
54663
54704
  ])
54664
54705
  ] }, changeDetection: 0 });
@@ -54667,24 +54708,28 @@ class PoTreeViewItemComponent {
54667
54708
  type: Component,
54668
54709
  args: [{ selector: 'po-tree-view-item', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
54669
54710
  trigger('toggleBody', [
54670
- state('collapsed', style({
54671
- 'overflow-y': 'hidden',
54672
- visibility: 'hidden',
54673
- opacity: 0,
54674
- height: '0'
54675
- })),
54676
- transition('expanded => collapsed', [
54677
- style({ height: '*' }),
54678
- animate(100, style({ opacity: 0 })),
54679
- animate(200, style({ height: 0 }))
54711
+ transition(':enter', [
54712
+ style({
54713
+ 'overflow-y': 'hidden',
54714
+ visibility: 'hidden',
54715
+ opacity: 0,
54716
+ height: '0'
54717
+ }),
54718
+ animate(200, style({ height: '*' })),
54719
+ animate(100, style({ opacity: 1 }))
54680
54720
  ]),
54681
- transition('collapsed => expanded', [
54682
- style({ height: '0' }),
54683
- animate(100, style({ opacity: 1 })),
54684
- animate(200, style({ height: '*' }))
54721
+ transition(':leave', [
54722
+ style({
54723
+ 'overflow-y': 'hidden',
54724
+ visibility: 'visible',
54725
+ opacity: 1,
54726
+ height: '*'
54727
+ }),
54728
+ animate(200, style({ height: 0 })),
54729
+ animate(100, style({ opacity: 0 }))
54685
54730
  ])
54686
54731
  ])
54687
- ], 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" }]
54732
+ ], 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" }]
54688
54733
  }], () => [{ type: PoTreeViewService }], { item: [{
54689
54734
  type: Input,
54690
54735
  args: ['p-item']
@@ -54698,7 +54743,7 @@ class PoTreeViewItemComponent {
54698
54743
  type: Input,
54699
54744
  args: ['p-selected-value']
54700
54745
  }] }); })();
54701
- (() => { (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 }); })();
54746
+ (() => { (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 }); })();
54702
54747
 
54703
54748
  function PoTreeViewComponent_po_container_0_po_tree_view_item_2_Template(rf, ctx) { if (rf & 1) {
54704
54749
  i0.ɵɵelement(0, "po-tree-view-item", 4);