@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.
- package/esm2022/lib/components/po-field/po-select/po-select.component.mjs +31 -2
- package/esm2022/lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.mjs +58 -41
- package/fesm2022/po-ui-ng-components.mjs +86 -40
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-field/po-select/po-select.component.d.ts +29 -0
- package/package.json +4 -4
- package/po-ui-ng-components-17.22.0.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v17/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-17.21.0.tgz +0 -0
|
@@ -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:
|
|
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"]}
|
package/esm2022/lib/components/po-tree-view/po-tree-view-item/po-tree-view-item.component.mjs
CHANGED
|
@@ -1,25 +1,34 @@
|
|
|
1
|
-
import { animate,
|
|
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
|
|
8
|
-
i0.ɵɵelement(0, "po-tree-view-item",
|
|
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("
|
|
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,
|
|
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("
|
|
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,
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
style({ height: '*' }),
|
|
70
|
-
animate(100, style({ opacity:
|
|
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('
|
|
74
|
-
style({
|
|
75
|
-
|
|
76
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
style({ height: '*' }),
|
|
93
|
-
animate(100, style({ opacity:
|
|
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('
|
|
97
|
-
style({
|
|
98
|
-
|
|
99
|
-
|
|
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\"
|
|
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:
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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` | 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:
|
|
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
|
|
54623
|
-
i0.ɵɵelement(0, "po-tree-view-item",
|
|
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("
|
|
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,
|
|
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("
|
|
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,
|
|
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
|
-
|
|
54678
|
-
|
|
54679
|
-
|
|
54680
|
-
|
|
54681
|
-
|
|
54682
|
-
|
|
54683
|
-
|
|
54684
|
-
style({ height: '*' }),
|
|
54685
|
-
animate(100, style({ opacity:
|
|
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('
|
|
54689
|
-
style({
|
|
54690
|
-
|
|
54691
|
-
|
|
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
|
-
|
|
54701
|
-
|
|
54702
|
-
|
|
54703
|
-
|
|
54704
|
-
|
|
54705
|
-
|
|
54706
|
-
|
|
54707
|
-
style({ height: '*' }),
|
|
54708
|
-
animate(100, style({ opacity:
|
|
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('
|
|
54712
|
-
style({
|
|
54713
|
-
|
|
54714
|
-
|
|
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\"
|
|
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:
|
|
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);
|