@po-ui/ng-components 14.4.0 → 14.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/esm2020/lib/components/po-button-group/po-button-group-base.component.mjs +2 -2
  2. package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +6 -6
  3. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +5 -5
  4. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +7 -3
  5. package/esm2020/lib/components/po-field/po-decimal/po-decimal.component.mjs +5 -5
  6. package/esm2020/lib/components/po-field/po-email/po-email.component.mjs +9 -7
  7. package/esm2020/lib/components/po-field/po-input/po-input.component.mjs +9 -7
  8. package/esm2020/lib/components/po-field/po-login/po-login.component.mjs +12 -11
  9. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +3 -3
  10. package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +6 -5
  11. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +31 -20
  12. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +19 -13
  13. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.mjs +1 -1
  14. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.service.mjs +2 -2
  15. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +7 -4
  16. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +24 -17
  17. package/esm2020/lib/components/po-field/po-number/po-number.component.mjs +5 -5
  18. package/esm2020/lib/components/po-field/po-password/po-password.component.mjs +14 -13
  19. package/esm2020/lib/components/po-field/po-radio/po-radio-size.enum.mjs +10 -3
  20. package/esm2020/lib/components/po-field/po-radio/po-radio.component.mjs +98 -34
  21. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group-base.component.mjs +16 -2
  22. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group.component.mjs +18 -25
  23. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +38 -250
  24. package/esm2020/lib/components/po-field/po-textarea/po-textarea-base.component.mjs +11 -1
  25. package/esm2020/lib/components/po-field/po-textarea/po-textarea.component.mjs +6 -7
  26. package/esm2020/lib/components/po-field/po-url/po-url.component.mjs +9 -7
  27. package/esm2020/lib/components/po-page/po-page-list/po-page-list.component.mjs +3 -3
  28. package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +26 -73
  29. package/esm2020/lib/components/po-table/po-table-detail/po-table-detail.component.mjs +27 -8
  30. package/esm2020/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.mjs +111 -0
  31. package/esm2020/lib/components/po-table/po-table.module.mjs +4 -1
  32. package/esm2020/lib/components/po-tag/po-tag-base.component.mjs +11 -3
  33. package/esm2020/lib/components/po-tag/po-tag.component.mjs +16 -9
  34. package/esm2020/lib/components/po-tree-view/po-tree-view-base.component.mjs +6 -4
  35. package/fesm2015/po-ui-ng-components.mjs +889 -984
  36. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  37. package/fesm2020/po-ui-ng-components.mjs +871 -962
  38. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  39. package/lib/components/po-button-group/po-button-group-base.component.d.ts +1 -1
  40. package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +26 -15
  41. package/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.d.ts +5 -3
  42. package/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.d.ts +2 -2
  43. package/lib/components/po-field/po-multiselect/po-multiselect-filter.service.d.ts +2 -2
  44. package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +2 -1
  45. package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +7 -1
  46. package/lib/components/po-field/po-radio/po-radio-size.enum.d.ts +9 -2
  47. package/lib/components/po-field/po-radio/po-radio.component.d.ts +27 -10
  48. package/lib/components/po-field/po-radio-group/po-radio-group-base.component.d.ts +21 -1
  49. package/lib/components/po-field/po-select/po-select.component.d.ts +1 -32
  50. package/lib/components/po-field/po-textarea/po-textarea-base.component.d.ts +10 -0
  51. package/lib/components/po-modal/po-modal.component.d.ts +1 -1
  52. package/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.d.ts +4 -12
  53. package/lib/components/po-table/po-table-detail/po-table-detail.component.d.ts +1 -0
  54. package/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.d.ts +35 -0
  55. package/lib/components/po-table/po-table.module.d.ts +25 -24
  56. package/lib/components/po-tag/po-tag-base.component.d.ts +8 -2
  57. package/package.json +4 -4
  58. package/po-ui-ng-components-14.5.0.tgz +0 -0
  59. package/schematics/ng-add/index.js +1 -1
  60. package/schematics/ng-update/v14/index.js +1 -1
  61. package/schematics/ng-update/v2/index.js +1 -1
  62. package/schematics/ng-update/v3/index.js +1 -1
  63. package/schematics/ng-update/v4/index.js +1 -1
  64. package/schematics/ng-update/v5/index.js +1 -1
  65. package/schematics/ng-update/v6/index.js +1 -1
  66. package/esm2020/lib/components/po-field/po-radio/po-radio-base.component.mjs +0 -104
  67. package/lib/components/po-field/po-radio/po-radio-base.component.d.ts +0 -58
  68. package/po-ui-ng-components-14.4.0.tgz +0 -0
@@ -21,6 +21,16 @@ import * as i0 from "@angular/core";
21
21
  * [ngModelOptions]="{standalone: true}">
22
22
  * </po-textarea>
23
23
  * ```
24
+ *
25
+ * #### Acessibilidade tratada no componente
26
+ * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas. São elas:
27
+ *
28
+ * - O Text area foi desenvolvido com uso de controles padrões HTML, o que permite a identificação do mesmo na interface por tecnologias
29
+ * assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)
30
+ * - O foco é visível e possui uma espessura superior a 2 pixels CSS, não ficando escondido por outros
31
+ * elementos da tela. [WCAG 2.4.12: Focus Appearance)](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)
32
+ * - A identificação do erro acontece também através da mudança de cor do campo, mas também de um ícone
33
+ * junto da mensagem. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)
24
34
  */
25
35
  export class PoTextareaBaseComponent {
26
36
  constructor(cd) {
@@ -296,4 +306,4 @@ __decorate([
296
306
  type: Input,
297
307
  args: ['p-rows']
298
308
  }] }); })();
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive, ChangeDetectorRef } from '@angular/core';\n\nimport { convertToBoolean, convertToInt } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, requiredFailed } from '../validators';\nimport { InputBoolean } from '../../../decorators';\n\n/**\n * @description\n *\n * Este é um componente de entrada de dados que possibilita o preechimento com múltiplas linhas.\n * É recomendado para observações, detalhamentos e outras situações onde o usuário deva preencher com um texto.\n *\n * Importante:\n *\n * - A propriedade `name` é obrigatória para que o formulário e o `model` funcionem corretamente. Do contrário, ocorrerá um erro de\n * _Angular_, onde será necessário informar o atributo `name` ou o atributo `[ngModelOptions]=\"{standalone: true}\"`, por exemplo:\n *\n * ```\n * <po-textarea\n *   [(ngModel)]=\"pessoa.nome\"\n *   [ngModelOptions]=\"{standalone: true}\">\n * </po-textarea>\n * ```\n */\n@Directive()\nexport abstract class PoTextareaBaseComponent implements ControlValueAccessor, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label do campo. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio do campo. */\n  @Input('p-help') help?: string;\n\n  /** Nome e Id do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao sair do campo.\n   */\n  @Output('p-blur') blur: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao entrar do campo.\n   */\n  @Output('p-enter') enter: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor e deixar o campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor do model.\n   */\n  @Output('p-change-model') changeModel: EventEmitter<any> = new EventEmitter<any>();\n\n  private _disabled: boolean = false;\n  private _maxlength: number;\n  private _minlength: number;\n  private _placeholder: string = '';\n  private _readonly: boolean = false;\n  private _required: boolean = false;\n  private _rows: number = 3;\n\n  private modelLastUpdate: any;\n  private onChangePropagate: any = null;\n  private validatorChange: any;\n  // eslint-disable-next-line\n  protected onTouched: any = null;\n\n  /** Placeholder, mensagem que aparecerá enquanto o campo não estiver preenchido. */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = convertToBoolean(disabled);\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') set readonly(readonly: boolean) {\n    this._readonly = convertToBoolean(readonly);\n  }\n\n  get readonly(): boolean {\n    return this._readonly;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório.\n   *\n   * > Esta propriedade é desconsiderada quando o _input_ está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  get required(): boolean {\n    return this._required;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade mínima de caracteres que o campo aceita.\n   */\n  @Input('p-minlength') set minlength(minlength: number) {\n    this._minlength = convertToInt(minlength);\n    this.validateModel();\n  }\n\n  get minlength(): number {\n    return this._minlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade máxima de caracteres que o campo aceita.\n   */\n  @Input('p-maxlength') set maxlength(maxlength: number) {\n    this._maxlength = convertToInt(maxlength);\n    this.validateModel();\n  }\n\n  get maxlength(): number {\n    return this._maxlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade de linhas que serão exibidas.\n   *\n   * @default `3`\n   */\n  @Input('p-rows') set rows(value: number) {\n    this._rows = isNaN(parseInt(<any>value, 10)) || value < 3 ? 3 : parseInt(<any>value, 10);\n  }\n  get rows(): number {\n    return this._rows;\n  }\n\n  constructor(public cd: ChangeDetectorRef) {}\n\n  callOnChange(value: any) {\n    // Quando o input não possui um formulário, então esta função não é registrada\n    if (this.onChangePropagate) {\n      this.onChangePropagate(value);\n    }\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value) {\n      this.changeModel.emit(value);\n      this.modelLastUpdate = value;\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cd.markForCheck();\n  }\n\n  // Funções `registerOnChange`, `registerOnTouched` e `registerOnValidatorChange` implementadas referentes ao ControlValueAccessor\n  // usadas para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(func: any): void {\n    this.validatorChange = func;\n  }\n\n  validate(abstractControl: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, abstractControl.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, abstractControl.value)) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, abstractControl.value)) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  writeValue(value: any) {\n    this.writeValueModel(value);\n    this.cd.markForCheck();\n  }\n\n  protected validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract writeValueModel(value: any): void;\n}\n"]}
309
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive, ChangeDetectorRef } from '@angular/core';\n\nimport { convertToBoolean, convertToInt } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, requiredFailed } from '../validators';\nimport { InputBoolean } from '../../../decorators';\n\n/**\n * @description\n *\n * Este é um componente de entrada de dados que possibilita o preechimento com múltiplas linhas.\n * É recomendado para observações, detalhamentos e outras situações onde o usuário deva preencher com um texto.\n *\n * Importante:\n *\n * - A propriedade `name` é obrigatória para que o formulário e o `model` funcionem corretamente. Do contrário, ocorrerá um erro de\n * _Angular_, onde será necessário informar o atributo `name` ou o atributo `[ngModelOptions]=\"{standalone: true}\"`, por exemplo:\n *\n * ```\n * <po-textarea\n *   [(ngModel)]=\"pessoa.nome\"\n *   [ngModelOptions]=\"{standalone: true}\">\n * </po-textarea>\n * ```\n *\n * #### Acessibilidade tratada no componente\n * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas. São elas:\n *\n * - O Text area foi desenvolvido com uso de controles padrões HTML, o que permite a identificação do mesmo na interface por tecnologias\n * assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)\n * - O foco é visível e possui uma espessura superior a 2 pixels CSS, não ficando escondido por outros\n * elementos da tela. [WCAG 2.4.12: Focus Appearance)](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)\n * - A identificação do erro acontece também através da mudança de cor do campo, mas também de um ícone\n * junto da mensagem. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)\n */\n@Directive()\nexport abstract class PoTextareaBaseComponent implements ControlValueAccessor, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label do campo. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio do campo. */\n  @Input('p-help') help?: string;\n\n  /** Nome e Id do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao sair do campo.\n   */\n  @Output('p-blur') blur: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao entrar do campo.\n   */\n  @Output('p-enter') enter: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor e deixar o campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor do model.\n   */\n  @Output('p-change-model') changeModel: EventEmitter<any> = new EventEmitter<any>();\n\n  private _disabled: boolean = false;\n  private _maxlength: number;\n  private _minlength: number;\n  private _placeholder: string = '';\n  private _readonly: boolean = false;\n  private _required: boolean = false;\n  private _rows: number = 3;\n\n  private modelLastUpdate: any;\n  private onChangePropagate: any = null;\n  private validatorChange: any;\n  // eslint-disable-next-line\n  protected onTouched: any = null;\n\n  /** Placeholder, mensagem que aparecerá enquanto o campo não estiver preenchido. */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = convertToBoolean(disabled);\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') set readonly(readonly: boolean) {\n    this._readonly = convertToBoolean(readonly);\n  }\n\n  get readonly(): boolean {\n    return this._readonly;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório.\n   *\n   * > Esta propriedade é desconsiderada quando o _input_ está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  get required(): boolean {\n    return this._required;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade mínima de caracteres que o campo aceita.\n   */\n  @Input('p-minlength') set minlength(minlength: number) {\n    this._minlength = convertToInt(minlength);\n    this.validateModel();\n  }\n\n  get minlength(): number {\n    return this._minlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade máxima de caracteres que o campo aceita.\n   */\n  @Input('p-maxlength') set maxlength(maxlength: number) {\n    this._maxlength = convertToInt(maxlength);\n    this.validateModel();\n  }\n\n  get maxlength(): number {\n    return this._maxlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade de linhas que serão exibidas.\n   *\n   * @default `3`\n   */\n  @Input('p-rows') set rows(value: number) {\n    this._rows = isNaN(parseInt(<any>value, 10)) || value < 3 ? 3 : parseInt(<any>value, 10);\n  }\n  get rows(): number {\n    return this._rows;\n  }\n\n  constructor(public cd: ChangeDetectorRef) {}\n\n  callOnChange(value: any) {\n    // Quando o input não possui um formulário, então esta função não é registrada\n    if (this.onChangePropagate) {\n      this.onChangePropagate(value);\n    }\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value) {\n      this.changeModel.emit(value);\n      this.modelLastUpdate = value;\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cd.markForCheck();\n  }\n\n  // Funções `registerOnChange`, `registerOnTouched` e `registerOnValidatorChange` implementadas referentes ao ControlValueAccessor\n  // usadas para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(func: any): void {\n    this.validatorChange = func;\n  }\n\n  validate(abstractControl: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, abstractControl.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, abstractControl.value)) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, abstractControl.value)) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  writeValue(value: any) {\n    this.writeValueModel(value);\n    this.cd.markForCheck();\n  }\n\n  protected validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract writeValueModel(value: any): void;\n}\n"]}
@@ -122,18 +122,17 @@ PoTextareaComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTexta
122
122
  useExisting: forwardRef(() => PoTextareaComponent),
123
123
  multi: true
124
124
  }
125
- ]), i0.ɵɵInheritDefinitionFeature], decls: 6, vars: 9, consts: [[3, "p-help", "p-label", "p-optional"], [1, "po-field-container-content"], [1, "po-textarea", 3, "disabled", "placeholder", "readonly", "required", "rows", "blur", "focus", "input"], ["inp", ""]], template: function PoTextareaComponent_Template(rf, ctx) { if (rf & 1) {
125
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 10, consts: [[3, "p-help", "p-label", "p-optional"], [1, "po-field-container-content"], [1, "po-textarea", 3, "disabled", "placeholder", "readonly", "required", "rows", "blur", "focus", "input"], ["inp", ""]], template: function PoTextareaComponent_Template(rf, ctx) { if (rf & 1) {
126
126
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "textarea", 2, 3);
127
127
  i0.ɵɵlistener("blur", function PoTextareaComponent_Template_textarea_blur_2_listener() { return ctx.eventOnBlur(); })("focus", function PoTextareaComponent_Template_textarea_focus_2_listener() { return ctx.eventOnFocus(); })("input", function PoTextareaComponent_Template_textarea_input_2_listener($event) { return ctx.eventOnInput($event); });
128
- i0.ɵɵtext(4, " ");
129
128
  i0.ɵɵelementEnd()();
130
- i0.ɵɵelement(5, "po-field-container-bottom");
129
+ i0.ɵɵelement(4, "po-field-container-bottom");
131
130
  i0.ɵɵelementEnd();
132
131
  } if (rf & 2) {
133
132
  i0.ɵɵproperty("p-help", ctx.help)("p-label", ctx.label)("p-optional", !ctx.required && ctx.optional);
134
133
  i0.ɵɵadvance(2);
135
- i0.ɵɵproperty("disabled", ctx.disabled)("placeholder", ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("rows", ctx.rows);
136
- i0.ɵɵattribute("name", ctx.name);
134
+ i0.ɵɵproperty("disabled", ctx.disabled)("placeholder", ctx.disabled ? "" : ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("rows", ctx.rows);
135
+ i0.ɵɵattribute("name", ctx.name)("aria-label", ctx.label);
137
136
  } }, dependencies: [i1.PoFieldContainerBottomComponent, i2.PoFieldContainerComponent], encapsulation: 2, changeDetection: 0 });
138
137
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTextareaComponent, [{
139
138
  type: Component,
@@ -148,9 +147,9 @@ PoTextareaComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTexta
148
147
  useExisting: forwardRef(() => PoTextareaComponent),
149
148
  multi: true
150
149
  }
151
- ], template: "<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <textarea\n #inp\n class=\"po-textarea\"\n (blur)=\"eventOnBlur()\"\n (focus)=\"eventOnFocus()\"\n (input)=\"eventOnInput($event)\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [rows]=\"rows\"\n >\n </textarea>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
150
+ ], template: "<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <textarea\n #inp\n class=\"po-textarea\"\n (blur)=\"eventOnBlur()\"\n (focus)=\"eventOnFocus()\"\n (input)=\"eventOnInput($event)\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"label\"\n [disabled]=\"disabled\"\n [placeholder]=\"disabled ? '' : placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [rows]=\"rows\"\n ></textarea>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
152
151
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { inputEl: [{
153
152
  type: ViewChild,
154
153
  args: ['inp', { read: ElementRef, static: true }]
155
154
  }] }); })();
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  ChangeDetectorRef,\n  forwardRef,\n  ViewChild,\n  AfterViewInit,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PoTextareaBaseComponent } from './po-textarea-base.component';\n\n/**\n * @docsExtends PoTextareaBaseComponent\n *\n * @example\n *\n * <example name=\"po-textarea-basic\" title=\"PO Textarea Basic\" >\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.html\"> </file>\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-labs\" title=\"PO Textarea Labs\" >\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.html\"> </file>\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email\" title=\"PO Textarea - Email\" >\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email-reactive-form\" title=\"PO Textarea - Email Reactive Form\" >\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-textarea',\n  templateUrl: './po-textarea.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoTextareaComponent extends PoTextareaBaseComponent implements AfterViewInit {\n  @ViewChild('inp', { read: ElementRef, static: true }) inputEl: ElementRef;\n\n  valueBeforeChange: any;\n  fireChange: boolean = false;\n\n  constructor(cd: ChangeDetectorRef) {\n    super(cd);\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 { PoTextareaComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoTextareaComponent, { static: true }) textarea: PoTextareaComponent;\n   *\n   * focusTextarea() {\n   *   this.textarea.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputEl.nativeElement.focus();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n  }\n\n  writeValueModel(value: any): void {\n    if (this.inputEl) {\n      if (!value) {\n        // Se for o valor for undefined, deve limpar o campo\n        this.inputEl.nativeElement.value = '';\n      } else {\n        this.inputEl.nativeElement.value = value;\n      }\n    }\n\n    // Emite evento quando o model é atualizado, inclusive a primeira vez\n    if (value) {\n      this.change.emit(value);\n    }\n  }\n\n  validMaxLength(maxlength: number, value: string) {\n    return maxlength && value.length > maxlength ? value.toString().substring(0, maxlength) : value;\n  }\n\n  eventOnInput(event: any) {\n    const value = this.validMaxLength(this.maxlength, event.target.value);\n    this.callOnChange(value);\n    this.inputEl.nativeElement.value = value;\n  }\n\n  eventOnFocus() {\n    // Atualiza valor da variável que será usada para verificar se o campo teve alteração\n    this.valueBeforeChange = this.inputEl.nativeElement.value;\n\n    // Dispara evento quando o usuário entrar no campo\n    // Este evento também é disparado quando o campo inicia com foco.\n    this.enter.emit();\n  }\n\n  eventOnBlur() {\n    this.onTouched?.();\n    this.blur.emit();\n    this.controlChangeEmitter();\n  }\n\n  controlChangeEmitter() {\n    const elementValue = this.inputEl.nativeElement.value;\n\n    if (elementValue !== this.valueBeforeChange) {\n      this.change.emit(elementValue);\n    }\n  }\n}\n","<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <textarea\n      #inp\n      class=\"po-textarea\"\n      (blur)=\"eventOnBlur()\"\n      (focus)=\"eventOnFocus()\"\n      (input)=\"eventOnInput($event)\"\n      [attr.name]=\"name\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [rows]=\"rows\"\n    >\n    </textarea>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  ChangeDetectorRef,\n  forwardRef,\n  ViewChild,\n  AfterViewInit,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PoTextareaBaseComponent } from './po-textarea-base.component';\n\n/**\n * @docsExtends PoTextareaBaseComponent\n *\n * @example\n *\n * <example name=\"po-textarea-basic\" title=\"PO Textarea Basic\" >\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.html\"> </file>\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-labs\" title=\"PO Textarea Labs\" >\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.html\"> </file>\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email\" title=\"PO Textarea - Email\" >\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email-reactive-form\" title=\"PO Textarea - Email Reactive Form\" >\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-textarea',\n  templateUrl: './po-textarea.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoTextareaComponent extends PoTextareaBaseComponent implements AfterViewInit {\n  @ViewChild('inp', { read: ElementRef, static: true }) inputEl: ElementRef;\n\n  valueBeforeChange: any;\n  fireChange: boolean = false;\n\n  constructor(cd: ChangeDetectorRef) {\n    super(cd);\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 { PoTextareaComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoTextareaComponent, { static: true }) textarea: PoTextareaComponent;\n   *\n   * focusTextarea() {\n   *   this.textarea.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputEl.nativeElement.focus();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n  }\n\n  writeValueModel(value: any): void {\n    if (this.inputEl) {\n      if (!value) {\n        // Se for o valor for undefined, deve limpar o campo\n        this.inputEl.nativeElement.value = '';\n      } else {\n        this.inputEl.nativeElement.value = value;\n      }\n    }\n\n    // Emite evento quando o model é atualizado, inclusive a primeira vez\n    if (value) {\n      this.change.emit(value);\n    }\n  }\n\n  validMaxLength(maxlength: number, value: string) {\n    return maxlength && value.length > maxlength ? value.toString().substring(0, maxlength) : value;\n  }\n\n  eventOnInput(event: any) {\n    const value = this.validMaxLength(this.maxlength, event.target.value);\n    this.callOnChange(value);\n    this.inputEl.nativeElement.value = value;\n  }\n\n  eventOnFocus() {\n    // Atualiza valor da variável que será usada para verificar se o campo teve alteração\n    this.valueBeforeChange = this.inputEl.nativeElement.value;\n\n    // Dispara evento quando o usuário entrar no campo\n    // Este evento também é disparado quando o campo inicia com foco.\n    this.enter.emit();\n  }\n\n  eventOnBlur() {\n    this.onTouched?.();\n    this.blur.emit();\n    this.controlChangeEmitter();\n  }\n\n  controlChangeEmitter() {\n    const elementValue = this.inputEl.nativeElement.value;\n\n    if (elementValue !== this.valueBeforeChange) {\n      this.change.emit(elementValue);\n    }\n  }\n}\n","<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <textarea\n      #inp\n      class=\"po-textarea\"\n      (blur)=\"eventOnBlur()\"\n      (focus)=\"eventOnFocus()\"\n      (input)=\"eventOnInput($event)\"\n      [attr.name]=\"name\"\n      [attr.aria-label]=\"label\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [rows]=\"rows\"\n    ></textarea>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
@@ -14,6 +14,7 @@ function PoUrlComponent_div_2_Template(rf, ctx) { if (rf & 1) {
14
14
  } if (rf & 2) {
15
15
  const ctx_r0 = i0.ɵɵnextContext();
16
16
  i0.ɵɵadvance(1);
17
+ i0.ɵɵclassMapInterpolate1("po-field-icon ", ctx_r0.disabled ? "po-icon-input-disabled" : "po-icon-input", "");
17
18
  i0.ɵɵclassProp("po-field-icon-disabled", ctx_r0.disabled);
18
19
  i0.ɵɵproperty("p-icon", ctx_r0.icon);
19
20
  } }
@@ -24,6 +25,7 @@ function PoUrlComponent_po_clean_6_Template(rf, ctx) { if (rf & 1) {
24
25
  i0.ɵɵelementEnd();
25
26
  } if (rf & 2) {
26
27
  const ctx_r2 = i0.ɵɵnextContext();
28
+ i0.ɵɵclassMap(ctx_r2.disabled ? "po-icon-input-disabled" : "po-icon-input");
27
29
  i0.ɵɵproperty("p-element-ref", ctx_r2.inputEl);
28
30
  } }
29
31
  /**
@@ -97,14 +99,14 @@ PoUrlComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoUrlCompone
97
99
  useExisting: forwardRef(() => PoUrlComponent),
98
100
  multi: true
99
101
  }
100
- ]), i0.ɵɵInheritDefinitionFeature], decls: 8, vars: 17, consts: [[3, "p-help", "p-label", "p-optional"], [1, "po-field-container-content"], ["class", "po-field-icon-container-left", 4, "ngIf"], [1, "po-input", 3, "autocomplete", "disabled", "placeholder", "readonly", "required", "type", "blur", "click", "focus", "input"], ["inp", ""], [1, "po-field-icon-container-right"], [3, "p-element-ref", "p-change-event", 4, "ngIf"], [3, "p-error-pattern"], [1, "po-field-icon-container-left"], [1, "po-field-icon", 3, "p-icon"], [3, "p-element-ref", "p-change-event"]], template: function PoUrlComponent_Template(rf, ctx) { if (rf & 1) {
102
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 8, vars: 18, consts: [[3, "p-help", "p-label", "p-optional"], [1, "po-field-container-content"], ["class", "po-field-icon-container-left", 4, "ngIf"], [1, "po-input", 3, "autocomplete", "disabled", "placeholder", "readonly", "required", "type", "blur", "click", "focus", "input"], ["inp", ""], [1, "po-field-icon-container-right"], [3, "class", "p-element-ref", "p-change-event", 4, "ngIf"], [3, "p-error-pattern"], [1, "po-field-icon-container-left"], [3, "p-icon"], [3, "p-element-ref", "p-change-event"]], template: function PoUrlComponent_Template(rf, ctx) { if (rf & 1) {
101
103
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1);
102
- i0.ɵɵtemplate(2, PoUrlComponent_div_2_Template, 2, 3, "div", 2);
104
+ i0.ɵɵtemplate(2, PoUrlComponent_div_2_Template, 2, 6, "div", 2);
103
105
  i0.ɵɵelementStart(3, "input", 3, 4);
104
106
  i0.ɵɵlistener("blur", function PoUrlComponent_Template_input_blur_3_listener($event) { return ctx.eventOnBlur($event); })("click", function PoUrlComponent_Template_input_click_3_listener($event) { return ctx.eventOnClick($event); })("focus", function PoUrlComponent_Template_input_focus_3_listener($event) { return ctx.eventOnFocus($event); })("input", function PoUrlComponent_Template_input_input_3_listener($event) { return ctx.eventOnInput($event); });
105
107
  i0.ɵɵelementEnd();
106
108
  i0.ɵɵelementStart(5, "div", 5);
107
- i0.ɵɵtemplate(6, PoUrlComponent_po_clean_6_Template, 1, 1, "po-clean", 6);
109
+ i0.ɵɵtemplate(6, PoUrlComponent_po_clean_6_Template, 1, 4, "po-clean", 6);
108
110
  i0.ɵɵelementEnd()();
109
111
  i0.ɵɵelement(7, "po-field-container-bottom", 7);
110
112
  i0.ɵɵelementEnd();
@@ -114,8 +116,8 @@ PoUrlComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoUrlCompone
114
116
  i0.ɵɵproperty("ngIf", ctx.icon);
115
117
  i0.ɵɵadvance(1);
116
118
  i0.ɵɵclassProp("po-input-icon-left", ctx.icon)("po-input-icon-right", ctx.clean);
117
- i0.ɵɵproperty("autocomplete", ctx.autocomplete)("disabled", ctx.disabled)("placeholder", ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("type", ctx.type);
118
- i0.ɵɵattribute("name", ctx.name);
119
+ i0.ɵɵproperty("autocomplete", ctx.autocomplete)("disabled", ctx.disabled)("placeholder", ctx.disabled ? "" : ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("type", ctx.type);
120
+ i0.ɵɵattribute("name", ctx.name)("aria-label", ctx.label);
119
121
  i0.ɵɵadvance(3);
120
122
  i0.ɵɵproperty("ngIf", ctx.clean && !ctx.disabled && !ctx.readonly);
121
123
  i0.ɵɵadvance(1);
@@ -134,6 +136,6 @@ PoUrlComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoUrlCompone
134
136
  useExisting: forwardRef(() => PoUrlComponent),
135
137
  multi: true
136
138
  }
137
- ], template: "<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <div *ngIf=\"icon\" class=\"po-field-icon-container-left\">\n <po-icon class=\"po-field-icon\" [class.po-field-icon-disabled]=\"disabled\" [p-icon]=\"icon\"></po-icon>\n </div>\n\n <input\n #inp\n class=\"po-input\"\n [attr.name]=\"name\"\n [autocomplete]=\"autocomplete\"\n [class.po-input-icon-left]=\"icon\"\n [class.po-input-icon-right]=\"clean\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [type]=\"type\"\n (blur)=\"eventOnBlur($event)\"\n (click)=\"eventOnClick($event)\"\n (focus)=\"eventOnFocus($event)\"\n (input)=\"eventOnInput($event)\"\n />\n\n <div class=\"po-field-icon-container-right\">\n <po-clean *ngIf=\"clean && !disabled && !readonly\" [p-element-ref]=\"inputEl\" (p-change-event)=\"clear($event)\">\n </po-clean>\n </div>\n </div>\n\n <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n" }]
139
+ ], template: "<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <div *ngIf=\"icon\" class=\"po-field-icon-container-left\">\n <po-icon\n class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n [class.po-field-icon-disabled]=\"disabled\"\n [p-icon]=\"icon\"\n ></po-icon>\n </div>\n\n <input\n #inp\n class=\"po-input\"\n [attr.name]=\"name\"\n [autocomplete]=\"autocomplete\"\n [class.po-input-icon-left]=\"icon\"\n [class.po-input-icon-right]=\"clean\"\n [attr.aria-label]=\"label\"\n [disabled]=\"disabled\"\n [placeholder]=\"disabled ? '' : placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [type]=\"type\"\n (blur)=\"eventOnBlur($event)\"\n (click)=\"eventOnClick($event)\"\n (focus)=\"eventOnFocus($event)\"\n (input)=\"eventOnInput($event)\"\n />\n\n <div class=\"po-field-icon-container-right\">\n <po-clean\n class=\"{{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n *ngIf=\"clean && !disabled && !readonly\"\n [p-element-ref]=\"inputEl\"\n (p-change-event)=\"clear($event)\"\n >\n </po-clean>\n </div>\n </div>\n\n <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n" }]
138
140
  }], function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, null); })();
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-url.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-url/po-url.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-input/po-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,UAAU,EAEX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,iBAAiB,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAEnF,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;ICTlE,8BAAuD;IACrD,6BAAmG;IACrG,iBAAM;;;IAD2B,eAAyC;IAAzC,yDAAyC;IAAC,oCAAe;;;;IAsBxF,oCAA6G;IAAjC,0LAAkB,eAAA,oBAAa,CAAA,IAAC;IAC5G,iBAAW;;;IADuC,8CAAyB;;ADZjF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAkBH,MAAM,OAAO,cAAe,SAAQ,cAAc;IAiBhD,0BAA0B;IAC1B,YAAY,EAAc,EAAE,EAAqB;QAC/C,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAlBhB,SAAI,GAAG,eAAe,CAAC;QAEvB,SAAI,GAAG,KAAK,CAAC;QAEb,YAAO,GACL,yBAAyB,GAAG,WAAW;YACvC,kDAAkD,GAAG,cAAc;YACnE,6BAA6B,GAAG,qBAAqB;YACrD,oCAAoC,GAAG,gBAAgB;YACvD,6BAA6B,GAAG,eAAe;YAC/C,uBAAuB,CAAC;QAE1B,SAAI,GAAG,EAAE,CAAC;QAEF,aAAQ,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAK3D,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;IACvB,CAAC;IAED,eAAe;QACb,yEAAyE;QACzE,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAC3B,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aACrE;QACH,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;SACxE;IACH,CAAC;IAED,eAAe,CAAC,CAAkB;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;;4EAzCU,cAAc;iEAAd,cAAc,4DAbd;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;gBAC7C,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,aAAa;gBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;gBAC7C,KAAK,EAAE,IAAI;aACZ;SACF;QCrDH,6CAA2F,aAAA;QAEvF,+DAEM;QAEN,mCAgBE;QAJA,8FAAQ,uBAAmB,IAAC,mFACnB,wBAAoB,IADD,mFAEnB,wBAAoB,IAFD,mFAGnB,wBAAoB,IAHD;QAZ9B,iBAgBE;QAEF,8BAA2C;QACzC,yEACW;QACb,iBAAM,EAAA;QAGR,+CAA8F;QAChG,iBAAqB;;QA/BD,iCAAe,sBAAA,6CAAA;QAEzB,eAAU;QAAV,+BAAU;QASd,eAAiC;QAAjC,8CAAiC,kCAAA;QADjC,+CAA6B,0BAAA,gCAAA,0BAAA,0BAAA,kBAAA;QAD7B,gCAAkB;QAgBP,eAAqC;QAArC,kEAAqC;QAKzB,eAAqC;QAArC,uDAAqC;;uFDyBrD,cAAc;cAjB1B,SAAS;2BACE,QAAQ,mBAED,uBAAuB,CAAC,MAAM,aACpC;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,eAAe,CAAC;wBAC7C,KAAK,EAAE,IAAI;qBACZ;oBACD;wBACE,OAAO,EAAE,aAAa;wBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,eAAe,CAAC;wBAC7C,KAAK,EAAE,IAAI;qBACZ;iBACF","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  forwardRef,\n  OnDestroy\n} from '@angular/core';\nimport { AbstractControl, NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n *\n * po-url é um input específico para receber URL, com o pattern já configurado.\n *\n * @example\n *\n * <example name=\"po-url-basic\" title=\"PO Url Basic\">\n *   <file name=\"sample-po-url-basic/sample-po-url-basic.component.html\"> </file>\n *   <file name=\"sample-po-url-basic/sample-po-url-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-url-labs\" title=\"PO Url Labs\">\n *   <file name=\"sample-po-url-labs/sample-po-url-labs.component.html\"> </file>\n *   <file name=\"sample-po-url-labs/sample-po-url-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-url-shortener\" title=\"PO Url - Shortener\">\n *   <file name=\"sample-po-url-shortener/sample-po-url-shortener.component.html\"> </file>\n *   <file name=\"sample-po-url-shortener/sample-po-url-shortener.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-url',\n  templateUrl: '../po-input/po-input.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoUrlComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoUrlComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoUrlComponent extends PoInputGeneric implements AfterViewInit, OnDestroy {\n  icon = 'po-icon-world';\n\n  type = 'url';\n\n  pattern =\n    '^((https|http):\\\\/\\\\/)?' + // protocol\n    '((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|' + // domain name\n    '((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))' + // OR ip (v4) address\n    '(\\\\:\\\\d+)?(\\\\/[-A-Za-z\\\\d%_.~+]*)*' + // port and path\n    '(\\\\?[;&A-Za-z\\\\d%_.~+=-]*)?' + // query string\n    '(\\\\#[-A-Za-z\\\\d_]*)?$';\n\n  mask = '';\n\n  private listener = this.validateClassesForPattern.bind(this);\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n    this.maxlength = 254;\n  }\n\n  ngAfterViewInit() {\n    // Se não tem ngModel ou reactive form adiciona validação com classes css\n    setTimeout(() => {\n      if (!this.onChangePropagate) {\n        this.inputEl.nativeElement.addEventListener('keyup', this.listener);\n      }\n    });\n    super.ngAfterViewInit();\n  }\n\n  ngOnDestroy() {\n    if (!this.onChangePropagate) {\n      this.inputEl.nativeElement.removeEventListener('keyup', this.listener);\n    }\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n}\n","<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <div *ngIf=\"icon\" class=\"po-field-icon-container-left\">\n      <po-icon class=\"po-field-icon\" [class.po-field-icon-disabled]=\"disabled\" [p-icon]=\"icon\"></po-icon>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-icon-left]=\"icon\"\n      [class.po-input-icon-right]=\"clean\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"type\"\n      (blur)=\"eventOnBlur($event)\"\n      (click)=\"eventOnClick($event)\"\n      (focus)=\"eventOnFocus($event)\"\n      (input)=\"eventOnInput($event)\"\n    />\n\n    <div class=\"po-field-icon-container-right\">\n      <po-clean *ngIf=\"clean && !disabled && !readonly\" [p-element-ref]=\"inputEl\" (p-change-event)=\"clear($event)\">\n      </po-clean>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-url.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-url/po-url.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-input/po-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  forwardRef,\n  OnDestroy\n} from '@angular/core';\nimport { AbstractControl, NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n *\n * po-url é um input específico para receber URL, com o pattern já configurado.\n *\n * @example\n *\n * <example name=\"po-url-basic\" title=\"PO Url Basic\">\n *   <file name=\"sample-po-url-basic/sample-po-url-basic.component.html\"> </file>\n *   <file name=\"sample-po-url-basic/sample-po-url-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-url-labs\" title=\"PO Url Labs\">\n *   <file name=\"sample-po-url-labs/sample-po-url-labs.component.html\"> </file>\n *   <file name=\"sample-po-url-labs/sample-po-url-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-url-shortener\" title=\"PO Url - Shortener\">\n *   <file name=\"sample-po-url-shortener/sample-po-url-shortener.component.html\"> </file>\n *   <file name=\"sample-po-url-shortener/sample-po-url-shortener.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-url',\n  templateUrl: '../po-input/po-input.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoUrlComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoUrlComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoUrlComponent extends PoInputGeneric implements AfterViewInit, OnDestroy {\n  icon = 'po-icon-world';\n\n  type = 'url';\n\n  pattern =\n    '^((https|http):\\\\/\\\\/)?' + // protocol\n    '((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|' + // domain name\n    '((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))' + // OR ip (v4) address\n    '(\\\\:\\\\d+)?(\\\\/[-A-Za-z\\\\d%_.~+]*)*' + // port and path\n    '(\\\\?[;&A-Za-z\\\\d%_.~+=-]*)?' + // query string\n    '(\\\\#[-A-Za-z\\\\d_]*)?$';\n\n  mask = '';\n\n  private listener = this.validateClassesForPattern.bind(this);\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n    this.maxlength = 254;\n  }\n\n  ngAfterViewInit() {\n    // Se não tem ngModel ou reactive form adiciona validação com classes css\n    setTimeout(() => {\n      if (!this.onChangePropagate) {\n        this.inputEl.nativeElement.addEventListener('keyup', this.listener);\n      }\n    });\n    super.ngAfterViewInit();\n  }\n\n  ngOnDestroy() {\n    if (!this.onChangePropagate) {\n      this.inputEl.nativeElement.removeEventListener('keyup', this.listener);\n    }\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n}\n","<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <div *ngIf=\"icon\" class=\"po-field-icon-container-left\">\n      <po-icon\n        class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        [class.po-field-icon-disabled]=\"disabled\"\n        [p-icon]=\"icon\"\n      ></po-icon>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-icon-left]=\"icon\"\n      [class.po-input-icon-right]=\"clean\"\n      [attr.aria-label]=\"label\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"type\"\n      (blur)=\"eventOnBlur($event)\"\n      (click)=\"eventOnClick($event)\"\n      (focus)=\"eventOnFocus($event)\"\n      (input)=\"eventOnInput($event)\"\n    />\n\n    <div class=\"po-field-icon-container-right\">\n      <po-clean\n        class=\"{{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        *ngIf=\"clean && !disabled && !readonly\"\n        [p-element-ref]=\"inputEl\"\n        (p-change-event)=\"clear($event)\"\n      >\n      </po-clean>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n"]}
@@ -289,7 +289,7 @@ PoPageListComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPageL
289
289
  let _t;
290
290
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.filterInput = _t.first);
291
291
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poPageContent = _t.first);
292
- } }, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c1, decls: 4, vars: 1, consts: [[3, "po-page-list-header-padding", "p-breadcrumb", "p-title", 4, "ngIf"], [3, "p-breadcrumb", "p-title"], [1, "po-page-list-operations"], [1, "po-page-list-actions"], ["p-kind", "primary", 3, "p-disabled", "p-icon", "p-label", "p-click", 4, "ngIf"], [3, "p-disabled", "p-label", "p-click", 4, "ngIf"], [3, "p-actions", "p-label", 4, "ngIf"], ["class", "po-page-list-filter-wrapper", 3, "ngClass", 4, "ngIf"], [3, "po-page-list-disclaimer-group", "p-disclaimers", "p-hide-remove-all", "p-title", "p-change", "p-remove", "p-remove-all", 4, "ngIf"], ["p-kind", "primary", 3, "p-disabled", "p-icon", "p-label", "p-click"], [3, "p-disabled", "p-label", "p-click"], [3, "p-actions", "p-label"], [1, "po-page-list-filter-wrapper", 3, "ngClass"], [1, "po-field-container-content", "po-page-filter-content", 3, "ngClass"], [1, "po-field-icon-container-right"], [1, "po-icon", "po-icon-search", "po-field-icon", 3, "click"], ["name", "model", "type", "text", 1, "po-input", "po-input-icon-right", 3, "placeholder", "keypress"], ["filterInput", ""], ["class", "po-page-list-filter-search", 4, "ngIf"], [1, "po-page-list-filter-search"], ["tabindex", "0", 1, "po-page-list-filter-search-link", 3, "click", "keydown.enter"], [3, "p-disclaimers", "p-hide-remove-all", "p-title", "p-change", "p-remove", "p-remove-all"]], template: function PoPageListComponent_Template(rf, ctx) { if (rf & 1) {
292
+ } }, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c1, decls: 4, vars: 1, consts: [[3, "po-page-list-header-padding", "p-breadcrumb", "p-title", 4, "ngIf"], [3, "p-breadcrumb", "p-title"], [1, "po-page-list-operations"], [1, "po-page-list-actions"], ["p-kind", "primary", 3, "p-disabled", "p-icon", "p-label", "p-click", 4, "ngIf"], [3, "p-disabled", "p-label", "p-click", 4, "ngIf"], [3, "p-actions", "p-label", 4, "ngIf"], ["class", "po-page-list-filter-wrapper", 3, "ngClass", 4, "ngIf"], [3, "po-page-list-disclaimer-group", "p-disclaimers", "p-hide-remove-all", "p-title", "p-change", "p-remove", "p-remove-all", 4, "ngIf"], ["p-kind", "primary", 3, "p-disabled", "p-icon", "p-label", "p-click"], [3, "p-disabled", "p-label", "p-click"], [3, "p-actions", "p-label"], [1, "po-page-list-filter-wrapper", 3, "ngClass"], [1, "po-field-container-content", "po-page-filter-content", 3, "ngClass"], [1, "po-field-icon-container-right"], [1, "po-icon", "po-icon-search", "po-field-icon", "po-icon-input", 3, "click"], ["name", "model", "type", "text", 1, "po-input", "po-input-icon-right", 3, "placeholder", "keypress"], ["filterInput", ""], ["class", "po-page-list-filter-search", 4, "ngIf"], [1, "po-page-list-filter-search"], ["tabindex", "0", 1, "po-page-list-filter-search-link", 3, "click", "keydown.enter"], [3, "p-disclaimers", "p-hide-remove-all", "p-title", "p-change", "p-remove", "p-remove-all"]], template: function PoPageListComponent_Template(rf, ctx) { if (rf & 1) {
293
293
  i0.ɵɵprojectionDef();
294
294
  i0.ɵɵelementStart(0, "po-page");
295
295
  i0.ɵɵtemplate(1, PoPageListComponent_po_page_header_1_Template, 9, 12, "po-page-header", 0);
@@ -302,7 +302,7 @@ PoPageListComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPageL
302
302
  } }, dependencies: [i3.NgClass, i3.NgIf, i4.PoButtonComponent, i5.PoDisclaimerGroupComponent, i6.PoDropdownComponent, i7.PoPageComponent, i8.PoPageContentComponent, i9.PoPageHeaderComponent], encapsulation: 2 });
303
303
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoPageListComponent, [{
304
304
  type: Component,
305
- args: [{ selector: 'po-page-list', template: "<po-page>\n <!-- HEADER -->\n <po-page-header\n *ngIf=\"hasPageHeader()\"\n [class.po-page-list-header-padding]=\"filter && !visibleActions.length\"\n [p-breadcrumb]=\"breadcrumb\"\n [p-title]=\"title\"\n >\n <!-- OPERATIONS -->\n <div class=\"po-page-list-operations\">\n <div class=\"po-page-list-actions\" [class.po-page-list-actions-padding]=\"filter\">\n <po-button\n *ngIf=\"visibleActions[0]\"\n p-kind=\"primary\"\n [p-disabled]=\"actionIsDisabled(actions[0])\"\n [p-icon]=\"visibleActions[0].icon\"\n [p-label]=\"visibleActions[0].label\"\n (p-click)=\"callAction(visibleActions[0])\"\n >\n </po-button>\n\n <po-button\n *ngIf=\"visibleActions[1] && (visibleActions.length === 2 || !isMobile)\"\n [p-disabled]=\"actionIsDisabled(actions[1])\"\n [p-label]=\"visibleActions[1].label\"\n (p-click)=\"callAction(visibleActions[1])\"\n >\n </po-button>\n\n <po-button\n *ngIf=\"visibleActions.length === 3 && visibleActions[2] && !isMobile\"\n [p-disabled]=\"actionIsDisabled(visibleActions[2])\"\n [p-label]=\"visibleActions[2].label\"\n (p-click)=\"callAction(visibleActions[2])\"\n >\n </po-button>\n\n <po-dropdown\n *ngIf=\"visibleActions.length > limitPrimaryActions\"\n [p-actions]=\"dropdownActions\"\n [p-label]=\"literals.otherActions\"\n >\n </po-dropdown>\n </div>\n\n <!-- FILTER -->\n <div\n class=\"po-page-list-filter-wrapper\"\n *ngIf=\"filter\"\n [ngClass]=\"hasCustomFilterSize() ? filterSizeClass(filter.width) : ''\"\n >\n <div\n class=\"po-field-container-content po-page-filter-content\"\n [ngClass]=\"\n hasCustomFilterSize()\n ? filter.advancedAction\n ? 'po-page-filter-input-variable-size'\n : 'po-page-filter-input-variable-size-wo-adv-search'\n : ''\n \"\n >\n <div class=\"po-field-icon-container-right\">\n <span class=\"po-icon po-icon-search po-field-icon\" (click)=\"callActionFilter('action')\"> </span>\n </div>\n\n <input\n #filterInput\n class=\"po-input po-input-icon-right\"\n name=\"model\"\n type=\"text\"\n [placeholder]=\"filter.placeholder || ''\"\n (keypress)=\"onkeypress($event.keyCode)\"\n />\n </div>\n\n <div class=\"po-page-list-filter-search\" *ngIf=\"filter.advancedAction\">\n <span\n class=\"po-page-list-filter-search-link\"\n tabindex=\"0\"\n (click)=\"callActionFilter('advancedAction')\"\n (keydown.enter)=\"callActionFilter('advancedAction')\"\n >\n {{ advancedSearch }}\n </span>\n </div>\n </div>\n </div>\n\n <!-- DISCLAIMER -->\n <po-disclaimer-group\n *ngIf=\"!!disclaimerGroup\"\n [class.po-page-list-disclaimer-group]=\"!!disclaimerGroup?.disclaimers?.length\"\n [p-disclaimers]=\"disclaimerGroup?.disclaimers\"\n [p-hide-remove-all]=\"disclaimerGroup?.hideRemoveAll\"\n [p-title]=\"disclaimerGroup?.title\"\n (p-change)=\"onChangeDisclaimerGroup($event)\"\n (p-remove)=\"onRemoveDisclaimer($event)\"\n (p-remove-all)=\"onRemoveAllDisclaimers($event)\"\n >\n </po-disclaimer-group>\n </po-page-header>\n\n <!-- CONTENT -->\n <po-page-content>\n <ng-content></ng-content>\n </po-page-content>\n</po-page>\n" }]
305
+ args: [{ selector: 'po-page-list', template: "<po-page>\n <!-- HEADER -->\n <po-page-header\n *ngIf=\"hasPageHeader()\"\n [class.po-page-list-header-padding]=\"filter && !visibleActions.length\"\n [p-breadcrumb]=\"breadcrumb\"\n [p-title]=\"title\"\n >\n <!-- OPERATIONS -->\n <div class=\"po-page-list-operations\">\n <div class=\"po-page-list-actions\" [class.po-page-list-actions-padding]=\"filter\">\n <po-button\n *ngIf=\"visibleActions[0]\"\n p-kind=\"primary\"\n [p-disabled]=\"actionIsDisabled(actions[0])\"\n [p-icon]=\"visibleActions[0].icon\"\n [p-label]=\"visibleActions[0].label\"\n (p-click)=\"callAction(visibleActions[0])\"\n >\n </po-button>\n\n <po-button\n *ngIf=\"visibleActions[1] && (visibleActions.length === 2 || !isMobile)\"\n [p-disabled]=\"actionIsDisabled(actions[1])\"\n [p-label]=\"visibleActions[1].label\"\n (p-click)=\"callAction(visibleActions[1])\"\n >\n </po-button>\n\n <po-button\n *ngIf=\"visibleActions.length === 3 && visibleActions[2] && !isMobile\"\n [p-disabled]=\"actionIsDisabled(visibleActions[2])\"\n [p-label]=\"visibleActions[2].label\"\n (p-click)=\"callAction(visibleActions[2])\"\n >\n </po-button>\n\n <po-dropdown\n *ngIf=\"visibleActions.length > limitPrimaryActions\"\n [p-actions]=\"dropdownActions\"\n [p-label]=\"literals.otherActions\"\n >\n </po-dropdown>\n </div>\n\n <!-- FILTER -->\n <div\n class=\"po-page-list-filter-wrapper\"\n *ngIf=\"filter\"\n [ngClass]=\"hasCustomFilterSize() ? filterSizeClass(filter.width) : ''\"\n >\n <div\n class=\"po-field-container-content po-page-filter-content\"\n [ngClass]=\"\n hasCustomFilterSize()\n ? filter.advancedAction\n ? 'po-page-filter-input-variable-size'\n : 'po-page-filter-input-variable-size-wo-adv-search'\n : ''\n \"\n >\n <div class=\"po-field-icon-container-right\">\n <span class=\"po-icon po-icon-search po-field-icon po-icon-input\" (click)=\"callActionFilter('action')\">\n </span>\n </div>\n\n <input\n #filterInput\n class=\"po-input po-input-icon-right\"\n name=\"model\"\n type=\"text\"\n [placeholder]=\"filter.placeholder || ''\"\n (keypress)=\"onkeypress($event.keyCode)\"\n />\n </div>\n\n <div class=\"po-page-list-filter-search\" *ngIf=\"filter.advancedAction\">\n <span\n class=\"po-page-list-filter-search-link\"\n tabindex=\"0\"\n (click)=\"callActionFilter('advancedAction')\"\n (keydown.enter)=\"callActionFilter('advancedAction')\"\n >\n {{ advancedSearch }}\n </span>\n </div>\n </div>\n </div>\n\n <!-- DISCLAIMER -->\n <po-disclaimer-group\n *ngIf=\"!!disclaimerGroup\"\n [class.po-page-list-disclaimer-group]=\"!!disclaimerGroup?.disclaimers?.length\"\n [p-disclaimers]=\"disclaimerGroup?.disclaimers\"\n [p-hide-remove-all]=\"disclaimerGroup?.hideRemoveAll\"\n [p-title]=\"disclaimerGroup?.title\"\n (p-change)=\"onChangeDisclaimerGroup($event)\"\n (p-remove)=\"onRemoveDisclaimer($event)\"\n (p-remove-all)=\"onRemoveAllDisclaimers($event)\"\n >\n </po-disclaimer-group>\n </po-page-header>\n\n <!-- CONTENT -->\n <po-page-content>\n <ng-content></ng-content>\n </po-page-content>\n</po-page>\n" }]
306
306
  }], function () { return [{ type: i0.ViewContainerRef }, { type: i1.PoLanguageService }, { type: i0.Renderer2 }, { type: i2.Router }, { type: i0.ChangeDetectorRef }]; }, { filterInput: [{
307
307
  type: ViewChild,
308
308
  args: ['filterInput']
@@ -310,4 +310,4 @@ PoPageListComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPageL
310
310
  type: ViewChild,
311
311
  args: [PoPageContentComponent, { static: true }]
312
312
  }] }); })();
313
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-list/po-page-list.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-list/po-page-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChange,\n  ViewChild,\n  ViewContainerRef,\n  ChangeDetectorRef,\n  ElementRef\n} from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport { callFunction, isExternalLink, isTypeof, openExternalLink } from '../../../utils/util';\nimport { PoLanguageService } from './../../../services/po-language/po-language.service';\n\nimport { PoPageAction } from '../po-page-action.interface';\nimport { PoDisclaimer } from '../../po-disclaimer/po-disclaimer.interface';\nimport { PoDisclaimerGroupRemoveAction } from '../../po-disclaimer-group/po-disclaimer-group-remove-action.interface';\n\nimport { PoPageContentComponent } from '../po-page-content/po-page-content.component';\nimport { PoPageListBaseComponent } from './po-page-list-base.component';\n\n/**\n * @docsExtends PoPageListBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-list-basic\" title=\"PO Page List Basic\">\n *  <file name=\"sample-po-page-list-basic/sample-po-page-list-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-list-basic/sample-po-page-list-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-list-labs\" title=\"PO Page List Labs\">\n *  <file name=\"sample-po-page-list-labs/sample-po-page-list-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-list-labs/sample-po-page-list-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-list-hiring-processes\" title=\"PO Page List - Hiring Processes\">\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.component.html\"> </file>\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.component.ts\"> </file>\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.service.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-list',\n  templateUrl: './po-page-list.component.html'\n})\nexport class PoPageListComponent\n  extends PoPageListBaseComponent\n  implements AfterContentInit, OnChanges, OnDestroy, OnInit {\n  @ViewChild('filterInput') filterInput: ElementRef;\n  @ViewChild(PoPageContentComponent, { static: true }) poPageContent: PoPageContentComponent;\n\n  advancedSearch: string;\n  dropdownActions: Array<PoPageAction>;\n  isMobile: boolean;\n  limitPrimaryActions: number = 3;\n\n  callFunction = callFunction;\n\n  private isRecalculate = true;\n  private maxWidthMobile: number = 480;\n\n  /* istanbul ignore next */\n  constructor(\n    viewRef: ViewContainerRef,\n    languageService: PoLanguageService,\n    public renderer: Renderer2,\n    private router: Router,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    super(languageService);\n    this.initializeListeners();\n  }\n\n  ngOnInit(): void {\n    this.advancedSearch = this.initializeFixedLiterals();\n  }\n\n  ngAfterContentInit(): void {\n    this.setIsMobile();\n    this.setDropdownActions();\n  }\n\n  ngOnChanges(changes: { [propName: string]: SimpleChange }) {\n    this.setDropdownActions();\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n  }\n\n  actionIsDisabled(action: any) {\n    return isTypeof(action.disabled, 'function') ? action.disabled(action) : action.disabled;\n  }\n\n  callAction(item: PoPageAction): void {\n    if (item.url) {\n      isExternalLink(item.url) ? openExternalLink(item.url) : this.router.navigate([item.url]);\n    } else if (item.action) {\n      item.action();\n    }\n  }\n\n  hasPageHeader(): boolean {\n    return !!(\n      this.title ||\n      (this.visibleActions && this.visibleActions.length) ||\n      (this.breadcrumb && this.breadcrumb.items.length)\n    );\n  }\n\n  hasCustomFilterSize(): boolean {\n    if (!this.filter) {\n      return false;\n    }\n    return this.filter.width >= 1 && this.filter.width <= 6;\n  }\n\n  filterSizeClass(width: number): string {\n    const smWidth = Math.max(this.filter?.advancedAction ? 6 : 2, width);\n    const mdWidth = Math.max(this.filter?.advancedAction ? 4 : 1, width);\n    if (this.filter?.advancedAction) {\n      width = Math.max(width, 2);\n    }\n    return `po-sm-${smWidth} po-md-${mdWidth} po-lg-${width} po-xl-${width}`;\n  }\n\n  setDropdownActions(): void {\n    if (this.visibleActions.length > this.limitPrimaryActions) {\n      this.dropdownActions = this.visibleActions.slice(this.limitPrimaryActions - 1);\n    }\n  }\n\n  callActionFilter(field: string) {\n    this.filter[field](this.filterInput.nativeElement.value);\n    this.changeDetector.detectChanges();\n  }\n  /**\n   * Limpa o campo de pesquisa.\n   */\n  clearInputSearch() {\n    this.filterInput.nativeElement.value = null;\n  }\n\n  onkeypress(key) {\n    if (key === 13) {\n      this.callActionFilter('action');\n    }\n  }\n\n  // Recebe evento change do disclaimer e recalcula tela\n  onChangeDisclaimerGroup(disclaimers) {\n    if (\n      (disclaimers && disclaimers.length && this.isRecalculate) ||\n      (disclaimers.length === 0 && !this.isRecalculate)\n    ) {\n      this.poPageContent.recalculateHeaderSize();\n      this.isRecalculate = !this.isRecalculate;\n    }\n\n    if (this.disclaimerGroup && this.disclaimerGroup.change) {\n      this.disclaimerGroup.change(disclaimers);\n    }\n  }\n\n  onRemoveDisclaimer(removeData: PoDisclaimerGroupRemoveAction) {\n    if (this.disclaimerGroup.remove) {\n      this.disclaimerGroup.remove(removeData);\n    }\n  }\n\n  onRemoveAllDisclaimers(removedDisclaimers: Array<PoDisclaimer>) {\n    if (this.disclaimerGroup.removeAll) {\n      this.disclaimerGroup.removeAll(removedDisclaimers);\n    }\n  }\n\n  private initializeFixedLiterals() {\n    const literal = {\n      pt: {\n        advancedSearch: 'Busca avançada'\n      },\n      en: {\n        advancedSearch: 'Advanced search'\n      },\n      es: {\n        advancedSearch: 'Búsqueda avanzada'\n      },\n      ru: {\n        advancedSearch: 'полный поиск'\n      }\n    };\n\n    return literal[this.language].advancedSearch;\n  }\n\n  private initializeListeners() {\n    this.resizeListener = this.renderer.listen('window', 'resize', (event: MouseEvent) => {\n      this.onResize(event);\n    });\n  }\n\n  private removeListeners() {\n    this.resizeListener();\n  }\n\n  private onResize(event: Event): void {\n    const width = (event.target as Window).innerWidth;\n\n    if (width < this.maxWidthMobile) {\n      this.isMobile = true;\n      this.limitPrimaryActions = 2;\n      this.setDropdownActions();\n    } else {\n      this.isMobile = false;\n      this.limitPrimaryActions = 3;\n      this.setDropdownActions();\n    }\n  }\n\n  private setIsMobile(): void {\n    if (window.innerWidth < this.maxWidthMobile) {\n      this.isMobile = true;\n      this.limitPrimaryActions = 2;\n    }\n  }\n}\n","<po-page>\n  <!-- HEADER -->\n  <po-page-header\n    *ngIf=\"hasPageHeader()\"\n    [class.po-page-list-header-padding]=\"filter && !visibleActions.length\"\n    [p-breadcrumb]=\"breadcrumb\"\n    [p-title]=\"title\"\n  >\n    <!-- OPERATIONS -->\n    <div class=\"po-page-list-operations\">\n      <div class=\"po-page-list-actions\" [class.po-page-list-actions-padding]=\"filter\">\n        <po-button\n          *ngIf=\"visibleActions[0]\"\n          p-kind=\"primary\"\n          [p-disabled]=\"actionIsDisabled(actions[0])\"\n          [p-icon]=\"visibleActions[0].icon\"\n          [p-label]=\"visibleActions[0].label\"\n          (p-click)=\"callAction(visibleActions[0])\"\n        >\n        </po-button>\n\n        <po-button\n          *ngIf=\"visibleActions[1] && (visibleActions.length === 2 || !isMobile)\"\n          [p-disabled]=\"actionIsDisabled(actions[1])\"\n          [p-label]=\"visibleActions[1].label\"\n          (p-click)=\"callAction(visibleActions[1])\"\n        >\n        </po-button>\n\n        <po-button\n          *ngIf=\"visibleActions.length === 3 && visibleActions[2] && !isMobile\"\n          [p-disabled]=\"actionIsDisabled(visibleActions[2])\"\n          [p-label]=\"visibleActions[2].label\"\n          (p-click)=\"callAction(visibleActions[2])\"\n        >\n        </po-button>\n\n        <po-dropdown\n          *ngIf=\"visibleActions.length > limitPrimaryActions\"\n          [p-actions]=\"dropdownActions\"\n          [p-label]=\"literals.otherActions\"\n        >\n        </po-dropdown>\n      </div>\n\n      <!-- FILTER -->\n      <div\n        class=\"po-page-list-filter-wrapper\"\n        *ngIf=\"filter\"\n        [ngClass]=\"hasCustomFilterSize() ? filterSizeClass(filter.width) : ''\"\n      >\n        <div\n          class=\"po-field-container-content po-page-filter-content\"\n          [ngClass]=\"\n            hasCustomFilterSize()\n              ? filter.advancedAction\n                ? 'po-page-filter-input-variable-size'\n                : 'po-page-filter-input-variable-size-wo-adv-search'\n              : ''\n          \"\n        >\n          <div class=\"po-field-icon-container-right\">\n            <span class=\"po-icon po-icon-search po-field-icon\" (click)=\"callActionFilter('action')\"> </span>\n          </div>\n\n          <input\n            #filterInput\n            class=\"po-input po-input-icon-right\"\n            name=\"model\"\n            type=\"text\"\n            [placeholder]=\"filter.placeholder || ''\"\n            (keypress)=\"onkeypress($event.keyCode)\"\n          />\n        </div>\n\n        <div class=\"po-page-list-filter-search\" *ngIf=\"filter.advancedAction\">\n          <span\n            class=\"po-page-list-filter-search-link\"\n            tabindex=\"0\"\n            (click)=\"callActionFilter('advancedAction')\"\n            (keydown.enter)=\"callActionFilter('advancedAction')\"\n          >\n            {{ advancedSearch }}\n          </span>\n        </div>\n      </div>\n    </div>\n\n    <!-- DISCLAIMER -->\n    <po-disclaimer-group\n      *ngIf=\"!!disclaimerGroup\"\n      [class.po-page-list-disclaimer-group]=\"!!disclaimerGroup?.disclaimers?.length\"\n      [p-disclaimers]=\"disclaimerGroup?.disclaimers\"\n      [p-hide-remove-all]=\"disclaimerGroup?.hideRemoveAll\"\n      [p-title]=\"disclaimerGroup?.title\"\n      (p-change)=\"onChangeDisclaimerGroup($event)\"\n      (p-remove)=\"onRemoveDisclaimer($event)\"\n      (p-remove-all)=\"onRemoveAllDisclaimers($event)\"\n    >\n    </po-disclaimer-group>\n  </po-page-header>\n\n  <!-- CONTENT -->\n  <po-page-content>\n    <ng-content></ng-content>\n  </po-page-content>\n</po-page>\n"]}
313
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-list/po-page-list.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-list/po-page-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChange,\n  ViewChild,\n  ViewContainerRef,\n  ChangeDetectorRef,\n  ElementRef\n} from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport { callFunction, isExternalLink, isTypeof, openExternalLink } from '../../../utils/util';\nimport { PoLanguageService } from './../../../services/po-language/po-language.service';\n\nimport { PoPageAction } from '../po-page-action.interface';\nimport { PoDisclaimer } from '../../po-disclaimer/po-disclaimer.interface';\nimport { PoDisclaimerGroupRemoveAction } from '../../po-disclaimer-group/po-disclaimer-group-remove-action.interface';\n\nimport { PoPageContentComponent } from '../po-page-content/po-page-content.component';\nimport { PoPageListBaseComponent } from './po-page-list-base.component';\n\n/**\n * @docsExtends PoPageListBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-list-basic\" title=\"PO Page List Basic\">\n *  <file name=\"sample-po-page-list-basic/sample-po-page-list-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-list-basic/sample-po-page-list-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-list-labs\" title=\"PO Page List Labs\">\n *  <file name=\"sample-po-page-list-labs/sample-po-page-list-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-list-labs/sample-po-page-list-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-list-hiring-processes\" title=\"PO Page List - Hiring Processes\">\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.component.html\"> </file>\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.component.ts\"> </file>\n *  <file name=\"sample-po-page-list-hiring-processes/sample-po-page-list-hiring-processes.service.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-list',\n  templateUrl: './po-page-list.component.html'\n})\nexport class PoPageListComponent\n  extends PoPageListBaseComponent\n  implements AfterContentInit, OnChanges, OnDestroy, OnInit {\n  @ViewChild('filterInput') filterInput: ElementRef;\n  @ViewChild(PoPageContentComponent, { static: true }) poPageContent: PoPageContentComponent;\n\n  advancedSearch: string;\n  dropdownActions: Array<PoPageAction>;\n  isMobile: boolean;\n  limitPrimaryActions: number = 3;\n\n  callFunction = callFunction;\n\n  private isRecalculate = true;\n  private maxWidthMobile: number = 480;\n\n  /* istanbul ignore next */\n  constructor(\n    viewRef: ViewContainerRef,\n    languageService: PoLanguageService,\n    public renderer: Renderer2,\n    private router: Router,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    super(languageService);\n    this.initializeListeners();\n  }\n\n  ngOnInit(): void {\n    this.advancedSearch = this.initializeFixedLiterals();\n  }\n\n  ngAfterContentInit(): void {\n    this.setIsMobile();\n    this.setDropdownActions();\n  }\n\n  ngOnChanges(changes: { [propName: string]: SimpleChange }) {\n    this.setDropdownActions();\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n  }\n\n  actionIsDisabled(action: any) {\n    return isTypeof(action.disabled, 'function') ? action.disabled(action) : action.disabled;\n  }\n\n  callAction(item: PoPageAction): void {\n    if (item.url) {\n      isExternalLink(item.url) ? openExternalLink(item.url) : this.router.navigate([item.url]);\n    } else if (item.action) {\n      item.action();\n    }\n  }\n\n  hasPageHeader(): boolean {\n    return !!(\n      this.title ||\n      (this.visibleActions && this.visibleActions.length) ||\n      (this.breadcrumb && this.breadcrumb.items.length)\n    );\n  }\n\n  hasCustomFilterSize(): boolean {\n    if (!this.filter) {\n      return false;\n    }\n    return this.filter.width >= 1 && this.filter.width <= 6;\n  }\n\n  filterSizeClass(width: number): string {\n    const smWidth = Math.max(this.filter?.advancedAction ? 6 : 2, width);\n    const mdWidth = Math.max(this.filter?.advancedAction ? 4 : 1, width);\n    if (this.filter?.advancedAction) {\n      width = Math.max(width, 2);\n    }\n    return `po-sm-${smWidth} po-md-${mdWidth} po-lg-${width} po-xl-${width}`;\n  }\n\n  setDropdownActions(): void {\n    if (this.visibleActions.length > this.limitPrimaryActions) {\n      this.dropdownActions = this.visibleActions.slice(this.limitPrimaryActions - 1);\n    }\n  }\n\n  callActionFilter(field: string) {\n    this.filter[field](this.filterInput.nativeElement.value);\n    this.changeDetector.detectChanges();\n  }\n  /**\n   * Limpa o campo de pesquisa.\n   */\n  clearInputSearch() {\n    this.filterInput.nativeElement.value = null;\n  }\n\n  onkeypress(key) {\n    if (key === 13) {\n      this.callActionFilter('action');\n    }\n  }\n\n  // Recebe evento change do disclaimer e recalcula tela\n  onChangeDisclaimerGroup(disclaimers) {\n    if (\n      (disclaimers && disclaimers.length && this.isRecalculate) ||\n      (disclaimers.length === 0 && !this.isRecalculate)\n    ) {\n      this.poPageContent.recalculateHeaderSize();\n      this.isRecalculate = !this.isRecalculate;\n    }\n\n    if (this.disclaimerGroup && this.disclaimerGroup.change) {\n      this.disclaimerGroup.change(disclaimers);\n    }\n  }\n\n  onRemoveDisclaimer(removeData: PoDisclaimerGroupRemoveAction) {\n    if (this.disclaimerGroup.remove) {\n      this.disclaimerGroup.remove(removeData);\n    }\n  }\n\n  onRemoveAllDisclaimers(removedDisclaimers: Array<PoDisclaimer>) {\n    if (this.disclaimerGroup.removeAll) {\n      this.disclaimerGroup.removeAll(removedDisclaimers);\n    }\n  }\n\n  private initializeFixedLiterals() {\n    const literal = {\n      pt: {\n        advancedSearch: 'Busca avançada'\n      },\n      en: {\n        advancedSearch: 'Advanced search'\n      },\n      es: {\n        advancedSearch: 'Búsqueda avanzada'\n      },\n      ru: {\n        advancedSearch: 'полный поиск'\n      }\n    };\n\n    return literal[this.language].advancedSearch;\n  }\n\n  private initializeListeners() {\n    this.resizeListener = this.renderer.listen('window', 'resize', (event: MouseEvent) => {\n      this.onResize(event);\n    });\n  }\n\n  private removeListeners() {\n    this.resizeListener();\n  }\n\n  private onResize(event: Event): void {\n    const width = (event.target as Window).innerWidth;\n\n    if (width < this.maxWidthMobile) {\n      this.isMobile = true;\n      this.limitPrimaryActions = 2;\n      this.setDropdownActions();\n    } else {\n      this.isMobile = false;\n      this.limitPrimaryActions = 3;\n      this.setDropdownActions();\n    }\n  }\n\n  private setIsMobile(): void {\n    if (window.innerWidth < this.maxWidthMobile) {\n      this.isMobile = true;\n      this.limitPrimaryActions = 2;\n    }\n  }\n}\n","<po-page>\n  <!-- HEADER -->\n  <po-page-header\n    *ngIf=\"hasPageHeader()\"\n    [class.po-page-list-header-padding]=\"filter && !visibleActions.length\"\n    [p-breadcrumb]=\"breadcrumb\"\n    [p-title]=\"title\"\n  >\n    <!-- OPERATIONS -->\n    <div class=\"po-page-list-operations\">\n      <div class=\"po-page-list-actions\" [class.po-page-list-actions-padding]=\"filter\">\n        <po-button\n          *ngIf=\"visibleActions[0]\"\n          p-kind=\"primary\"\n          [p-disabled]=\"actionIsDisabled(actions[0])\"\n          [p-icon]=\"visibleActions[0].icon\"\n          [p-label]=\"visibleActions[0].label\"\n          (p-click)=\"callAction(visibleActions[0])\"\n        >\n        </po-button>\n\n        <po-button\n          *ngIf=\"visibleActions[1] && (visibleActions.length === 2 || !isMobile)\"\n          [p-disabled]=\"actionIsDisabled(actions[1])\"\n          [p-label]=\"visibleActions[1].label\"\n          (p-click)=\"callAction(visibleActions[1])\"\n        >\n        </po-button>\n\n        <po-button\n          *ngIf=\"visibleActions.length === 3 && visibleActions[2] && !isMobile\"\n          [p-disabled]=\"actionIsDisabled(visibleActions[2])\"\n          [p-label]=\"visibleActions[2].label\"\n          (p-click)=\"callAction(visibleActions[2])\"\n        >\n        </po-button>\n\n        <po-dropdown\n          *ngIf=\"visibleActions.length > limitPrimaryActions\"\n          [p-actions]=\"dropdownActions\"\n          [p-label]=\"literals.otherActions\"\n        >\n        </po-dropdown>\n      </div>\n\n      <!-- FILTER -->\n      <div\n        class=\"po-page-list-filter-wrapper\"\n        *ngIf=\"filter\"\n        [ngClass]=\"hasCustomFilterSize() ? filterSizeClass(filter.width) : ''\"\n      >\n        <div\n          class=\"po-field-container-content po-page-filter-content\"\n          [ngClass]=\"\n            hasCustomFilterSize()\n              ? filter.advancedAction\n                ? 'po-page-filter-input-variable-size'\n                : 'po-page-filter-input-variable-size-wo-adv-search'\n              : ''\n          \"\n        >\n          <div class=\"po-field-icon-container-right\">\n            <span class=\"po-icon po-icon-search po-field-icon po-icon-input\" (click)=\"callActionFilter('action')\">\n            </span>\n          </div>\n\n          <input\n            #filterInput\n            class=\"po-input po-input-icon-right\"\n            name=\"model\"\n            type=\"text\"\n            [placeholder]=\"filter.placeholder || ''\"\n            (keypress)=\"onkeypress($event.keyCode)\"\n          />\n        </div>\n\n        <div class=\"po-page-list-filter-search\" *ngIf=\"filter.advancedAction\">\n          <span\n            class=\"po-page-list-filter-search-link\"\n            tabindex=\"0\"\n            (click)=\"callActionFilter('advancedAction')\"\n            (keydown.enter)=\"callActionFilter('advancedAction')\"\n          >\n            {{ advancedSearch }}\n          </span>\n        </div>\n      </div>\n    </div>\n\n    <!-- DISCLAIMER -->\n    <po-disclaimer-group\n      *ngIf=\"!!disclaimerGroup\"\n      [class.po-page-list-disclaimer-group]=\"!!disclaimerGroup?.disclaimers?.length\"\n      [p-disclaimers]=\"disclaimerGroup?.disclaimers\"\n      [p-hide-remove-all]=\"disclaimerGroup?.hideRemoveAll\"\n      [p-title]=\"disclaimerGroup?.title\"\n      (p-change)=\"onChangeDisclaimerGroup($event)\"\n      (p-remove)=\"onRemoveDisclaimer($event)\"\n      (p-remove-all)=\"onRemoveAllDisclaimers($event)\"\n    >\n    </po-disclaimer-group>\n  </po-page-header>\n\n  <!-- CONTENT -->\n  <po-page-content>\n    <ng-content></ng-content>\n  </po-page-content>\n</po-page>\n"]}