@po-ui/ng-components 18.8.0 → 18.9.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 (42) hide show
  1. package/esm2022/lib/components/po-field/po-input/po-input-base.component.mjs +5 -1
  2. package/esm2022/lib/components/po-field/po-login/po-login.component.mjs +19 -6
  3. package/esm2022/lib/components/po-field/po-password/po-password.component.mjs +13 -3
  4. package/esm2022/lib/components/po-modal/po-modal-base.component.mjs +14 -12
  5. package/esm2022/lib/components/po-page/po-page-default/po-page-default-base.component.mjs +15 -2
  6. package/esm2022/lib/components/po-page/po-page-slide/po-page-slide-base.component.mjs +3 -1
  7. package/esm2022/lib/components/po-tabs/po-tabs-base.component.mjs +23 -20
  8. package/esm2022/lib/services/index.mjs +2 -1
  9. package/esm2022/lib/services/po-media-query/index.mjs +4 -0
  10. package/esm2022/lib/services/po-media-query/po-media-query.interface.mjs +12 -0
  11. package/esm2022/lib/services/po-media-query/po-media-query.module.mjs +21 -0
  12. package/esm2022/lib/services/po-media-query/po-media-query.service.mjs +145 -0
  13. package/esm2022/lib/services/services.module.mjs +8 -1
  14. package/fesm2022/po-ui-ng-components.mjs +259 -34
  15. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  16. package/lib/components/po-field/po-input/po-input-base.component.d.ts +4 -0
  17. package/lib/components/po-field/po-login/po-login.component.d.ts +5 -1
  18. package/lib/components/po-field/po-password/po-password.component.d.ts +5 -2
  19. package/lib/components/po-modal/po-modal-base.component.d.ts +13 -11
  20. package/lib/components/po-page/po-page-default/po-page-default-base.component.d.ts +14 -1
  21. package/lib/components/po-page/po-page-slide/po-page-slide-base.component.d.ts +2 -0
  22. package/lib/components/po-tabs/po-tabs-base.component.d.ts +22 -19
  23. package/lib/services/index.d.ts +1 -0
  24. package/lib/services/po-media-query/index.d.ts +3 -0
  25. package/lib/services/po-media-query/po-media-query.interface.d.ts +138 -0
  26. package/lib/services/po-media-query/po-media-query.module.d.ts +11 -0
  27. package/lib/services/po-media-query/po-media-query.service.d.ts +73 -0
  28. package/lib/services/services.module.d.ts +4 -3
  29. package/package.json +4 -4
  30. package/po-ui-ng-components-18.9.0.tgz +0 -0
  31. package/schematics/ng-add/index.js +1 -1
  32. package/schematics/ng-update/v14/index.js +1 -1
  33. package/schematics/ng-update/v15/index.js +1 -1
  34. package/schematics/ng-update/v16/index.js +1 -1
  35. package/schematics/ng-update/v17/index.js +1 -1
  36. package/schematics/ng-update/v18/index.js +2 -2
  37. package/schematics/ng-update/v2/index.js +1 -1
  38. package/schematics/ng-update/v3/index.js +1 -1
  39. package/schematics/ng-update/v4/index.js +1 -1
  40. package/schematics/ng-update/v5/index.js +1 -1
  41. package/schematics/ng-update/v6/index.js +1 -1
  42. package/po-ui-ng-components-18.8.0.tgz +0 -0
@@ -23,6 +23,8 @@ import * as i0 from "@angular/core";
23
23
  * É possível alterar o estilo do componente usando os seguintes tokens (CSS): <br>
24
24
  * Obs: Só é possível realizar alterações ao adicionar a classe `.po-input`
25
25
  *
26
+ * > Para correto alinhamento é recomendado o uso das classes de espaçamento do [Grid System](https://po-ui.io/guides/grid-system).
27
+ *
26
28
  * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
27
29
  *
28
30
  * | Propriedade | Descrição | Valor Padrão |
@@ -185,6 +187,8 @@ export class PoInputBaseComponent {
185
187
  *
186
188
  * > No componente `po-password` será definido como `new-password`.
187
189
  *
190
+ * Nos componentes `po-password` e `po-login` o valor padrão será `true`.
191
+ *
188
192
  * @default `false`
189
193
  */
190
194
  set noAutocomplete(value) {
@@ -515,4 +519,4 @@ export class PoInputBaseComponent {
515
519
  type: Input,
516
520
  args: ['p-mask-format-model']
517
521
  }] }); })();
518
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-input-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-input/po-input-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\n\nimport { convertToBoolean } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, patternFailed, requiredFailed } from './../validators';\nimport { PoMask } from './po-mask';\n\n/**\n * @description\n *\n * Este é um componente baseado em input, com várias propriedades do input nativo e outras\n * propriedades extras como: máscara, pattern, mensagem de erro e etc.\n * Você deve informar a variável que contém o valor como [(ngModel)]=\"variavel\", para que o\n * input receba o valor da variável e para que ela receba as alterações do valor (two-way-databinding).\n * A propriedade name é obrigatória para que o formulário e o model funcionem corretamente.\n *\n * Importante:\n *\n * - Caso o input tenha um [(ngModel)] sem o atributo name, ocorrerá um erro de angular.\n * Então você precisa informar o atributo name ou o atributo [ngModelOptions]=\"{standalone: true}\".\n * Exemplo: [(ngModel)]=\"pessoa.nome\" [ngModelOptions]=\"{standalone: true}\".\n *\n * #### Tokens customizáveis\n *\n * É possível alterar o estilo do componente usando os seguintes tokens (CSS): <br>\n * Obs: Só é possível realizar alterações ao adicionar a classe `.po-input`\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-placeholder`             | Cor do texto placeholder                              | `var(--color-neutral-light-30)`                 |\n * | `--color`                              | Cor pincipal do input                                 | `var(--color-neutral-dark-70)`                  |\n * | `--background`                         | Cor de background                                     | `var(--color-neutral-light-05)`                 |\n * | `--padding`                            | Preenchimento                                         |  `0 0.5rem`                                     |\n * | `--text-color`                         | Cor do texto                                          | `var(--color-neutral-dark-90)`                  |\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-lightest)`                |\n * | **Focused**                            |                                                       |                                                 |\n * | `--color-focused`                      | Cor principal no estado de focus                      | `var(--color-action-default)`                   |\n * | `--outline-color-focused`              | Cor do outline do estado de focus                     | `var(--color-action-focus)`                     |\n * | **Disabled**                           |                                                       |                                                 |\n * | `--color-disabled`                     | Cor principal no estado disabled                      | `var(--color-neutral-light-30)`                 |\n * | `--background-disabled`                | Cor de background no estado disabled                  | `var(--color-neutral-light-20)`                 |\n * | `--text-color-disabled`                | Cor do texto no estado disabled                       | `var(--color-neutral-dark-70)`                  |\n *\n * <br>\n */\n@Directive()\nexport abstract class PoInputBaseComponent 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({ alias: 'p-auto-focus', transform: convertToBoolean }) autoFocus: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o ícone que será exibido no início do campo.\n   *\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-input p-icon=\"ph ph-user\" p-label=\"PO input\"></po-input>\n   * ```\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-input p-icon=\"fa fa-podcast\" p-label=\"PO input\"></po-input>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-input [p-icon]=\"template\" p-label=\"input template ionic\"></po-input>\n   *\n   * <ng-template #template>\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\n   * </ng-template>\n   * ```\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\n   */\n  @Input('p-icon') icon?: string | TemplateRef<void>;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Sempre emite as alterações do model mesmo quando o valor atual for igual ao valor anterior.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-emit-all-changes', transform: convertToBoolean }) emitAllChanges: boolean = false;\n\n  /** Rótulo 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 identificador do campo. */\n  @Input('name') name: string;\n\n  /**\n   * @description\n   *\n   * Mensagem que será apresentada quando o `pattern` ou a máscara não for satisfeita.\n   *\n   * > Esta mensagem não é apresentada quando o campo estiver vazio, mesmo que ele seja requerido.\n   */\n  @Input('p-error-pattern') errorPattern?: 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   * @description\n   *\n   * Converte o conteúdo do campo em maiúsulo automaticamente.\n   *\n   */\n  @Input({ alias: 'p-upper-case', transform: convertToBoolean }) upperCase: boolean = false;\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();\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();\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();\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();\n\n  type: string;\n\n  onChangePropagate: any = null;\n  objMask: any;\n  modelLastUpdate: any;\n  protected onTouched: any = null;\n\n  protected passedWriteValue: boolean = false;\n  protected validatorChange: any;\n\n  private _maxlength?: number;\n  private _minlength?: number;\n  private _noAutocomplete?: boolean = false;\n  private _placeholder?: string = '';\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a propriedade nativa `autocomplete` do campo como `off`.\n   *\n   * > No componente `po-password` será definido como `new-password`.\n   *\n   * @default `false`\n   */\n  @Input('p-no-autocomplete') set noAutocomplete(value: boolean) {\n    this._noAutocomplete = convertToBoolean(value);\n  }\n\n  get noAutocomplete() {\n    return this._noAutocomplete;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Mensagem que aparecerá enquanto o campo não estiver preenchido.\n   *\n   * @default ''\n   */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @description\n   *\n   * Se verdadeiro, desabilita o campo.\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  disabled?: boolean = false;\n  @Input('p-disabled') set setDisabled(disabled: string) {\n    this.disabled = disabled === '' ? true : convertToBoolean(disabled);\n\n    this.validateModel();\n  }\n\n  /** Indica que o campo será somente leitura. */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  readonly?: boolean = false;\n  @Input('p-readonly') set setReadonly(readonly: string) {\n    this.readonly = readonly === '' ? true : convertToBoolean(readonly);\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define que o campo será obrigatório.\n   * > Esta propriedade é desconsiderada quando o input está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  required?: boolean = false;\n  @Input('p-required') set setRequired(required: string) {\n    this.required = required === '' ? true : convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  /**\n   * Define se a indicação de campo obrigatório será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - Não possuir `p-help` e/ou `p-label`.\n   */\n  @Input('p-show-required') showRequired: boolean = false;\n\n  /** Se verdadeiro, o campo receberá um botão para ser limpo. */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  clean?: boolean = false;\n  @Input('p-clean') set setClean(clean: string) {\n    this.clean = clean === '' ? true : convertToBoolean(clean);\n  }\n\n  /**\n   * @description\n   *\n   * Expressão regular para validar o campo.\n   * Quando o campo possuir uma máscara `(p-mask)` será automaticamente validado por ela, porém\n   * é possível definir um p-pattern para substituir a validação da máscara.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  pattern?: string;\n  @Input('p-pattern') set setPattern(pattern: string) {\n    this.pattern = pattern;\n\n    this.validateModel();\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(value: number) {\n    if (!isNaN(parseInt(<any>value, 10))) {\n      this._maxlength = parseInt(<any>value, 10);\n\n      this.validateModel();\n    } else if (!value) {\n      this._maxlength = undefined;\n\n      this.validateModel();\n    }\n  }\n\n  get maxlength() {\n    return this._maxlength;\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(value: number) {\n    if (!isNaN(parseInt(<any>value, 10))) {\n      this._minlength = parseInt(<any>value, 10);\n\n      this.validateModel();\n    } else if (!value) {\n      this._minlength = undefined;\n\n      this.validateModel();\n    }\n  }\n\n  get minlength() {\n    return this._minlength;\n  }\n\n  /**\n   * @description\n   *\n   * Indica uma máscara para o campo. Exemplos: (+99) (99) 99999?-9999, 99999-999, 999.999.999-99.\n   * A máscara gera uma validação automática do campo, podendo esta ser substituída por um REGEX específico\n   * através da propriedade p-pattern.\n   * O campo será sinalizado e o formulário ficará inválido quando o valor informado estiver fora do padrão definido,\n   * mesmo quando desabilitado.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  mask?: string = '';\n  @Input('p-mask') set setMask(mask: string) {\n    this.mask = mask;\n\n    // Atualiza Máscara do Campo\n    this.objMask = new PoMask(this.mask, this.maskFormatModel);\n  }\n\n  /**\n   * @description\n   *\n   * Indica se o `model` receberá o valor formatado pela máscara ou apenas o valor puro (sem formatação).\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  maskFormatModel?: boolean = false;\n  @Input('p-mask-format-model') set setMaskFormatModel(maskFormatModel: string) {\n    this.maskFormatModel = maskFormatModel === '' ? true : convertToBoolean(maskFormatModel);\n\n    if (this.objMask instanceof PoMask) {\n      this.objMask.formatModel = this.maskFormatModel;\n\n      this.validateModel();\n    }\n  }\n\n  constructor(private cd?: ChangeDetectorRef) {\n    this.objMask = new PoMask(this.mask, this.maskFormatModel);\n  }\n\n  callOnChange(value: any) {\n    this.updateModel(value);\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  callUpdateModelWithTimeout(value) {\n    setTimeout(() => this.updateModel(value));\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value || this.emitAllChanges) {\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ção implementada do ControlValueAccessor\n  // Usada para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.validatorChange = fn;\n  }\n\n  updateModel(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\n  validate(c: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, this.getScreenValue())) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, this.getScreenValue())) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, this.getScreenValue())) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (patternFailed(this.pattern, c.value)) {\n      this.validatePatternOnWriteValue(c.value);\n      return {\n        pattern: {\n          valid: false\n        }\n      };\n    }\n\n    return this.extraValidation(c);\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  // utilizado para validar o pattern na inicializacao, fazendo dessa forma o campo fica sujo (dirty).\n  private validatePatternOnWriteValue(value: string) {\n    if (value && this.passedWriteValue) {\n      setTimeout(() => {\n        this.updateModel(value);\n      });\n\n      this.passedWriteValue = false;\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 { PoNomeDoComponenteComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoNomeDoComponenteComponent, { static: true }) nomeDoComponente: PoNomeDoComponenteComponent;\n   *\n   * focusComponent() {\n   *   this.nomeDoComponente.focus();\n   * }\n   * ```\n   */\n  abstract focus(): void;\n\n  // Método que receberá o valor do model\n  abstract writeValueModel(value: any): void;\n\n  // Validações do campo\n  abstract extraValidation(c: AbstractControl): { [key: string]: any };\n\n  // Deve retornar o valor do campo\n  abstract getScreenValue(): string;\n}\n"]}
522
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-input-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-input/po-input-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\n\nimport { convertToBoolean } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, patternFailed, requiredFailed } from './../validators';\nimport { PoMask } from './po-mask';\n\n/**\n * @description\n *\n * Este é um componente baseado em input, com várias propriedades do input nativo e outras\n * propriedades extras como: máscara, pattern, mensagem de erro e etc.\n * Você deve informar a variável que contém o valor como [(ngModel)]=\"variavel\", para que o\n * input receba o valor da variável e para que ela receba as alterações do valor (two-way-databinding).\n * A propriedade name é obrigatória para que o formulário e o model funcionem corretamente.\n *\n * Importante:\n *\n * - Caso o input tenha um [(ngModel)] sem o atributo name, ocorrerá um erro de angular.\n * Então você precisa informar o atributo name ou o atributo [ngModelOptions]=\"{standalone: true}\".\n * Exemplo: [(ngModel)]=\"pessoa.nome\" [ngModelOptions]=\"{standalone: true}\".\n *\n * #### Tokens customizáveis\n *\n * É possível alterar o estilo do componente usando os seguintes tokens (CSS): <br>\n * Obs: Só é possível realizar alterações ao adicionar a classe `.po-input`\n *\n * > Para correto alinhamento é recomendado o uso das classes de espaçamento do [Grid System](https://po-ui.io/guides/grid-system).\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-placeholder`             | Cor do texto placeholder                              | `var(--color-neutral-light-30)`                 |\n * | `--color`                              | Cor pincipal do input                                 | `var(--color-neutral-dark-70)`                  |\n * | `--background`                         | Cor de background                                     | `var(--color-neutral-light-05)`                 |\n * | `--padding`                            | Preenchimento                                         |  `0 0.5rem`                                     |\n * | `--text-color`                         | Cor do texto                                          | `var(--color-neutral-dark-90)`                  |\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-lightest)`                |\n * | **Focused**                            |                                                       |                                                 |\n * | `--color-focused`                      | Cor principal no estado de focus                      | `var(--color-action-default)`                   |\n * | `--outline-color-focused`              | Cor do outline do estado de focus                     | `var(--color-action-focus)`                     |\n * | **Disabled**                           |                                                       |                                                 |\n * | `--color-disabled`                     | Cor principal no estado disabled                      | `var(--color-neutral-light-30)`                 |\n * | `--background-disabled`                | Cor de background no estado disabled                  | `var(--color-neutral-light-20)`                 |\n * | `--text-color-disabled`                | Cor do texto no estado disabled                       | `var(--color-neutral-dark-70)`                  |\n *\n * <br>\n */\n@Directive()\nexport abstract class PoInputBaseComponent 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({ alias: 'p-auto-focus', transform: convertToBoolean }) autoFocus: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o ícone que será exibido no início do campo.\n   *\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-input p-icon=\"ph ph-user\" p-label=\"PO input\"></po-input>\n   * ```\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-input p-icon=\"fa fa-podcast\" p-label=\"PO input\"></po-input>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-input [p-icon]=\"template\" p-label=\"input template ionic\"></po-input>\n   *\n   * <ng-template #template>\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\n   * </ng-template>\n   * ```\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\n   */\n  @Input('p-icon') icon?: string | TemplateRef<void>;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Sempre emite as alterações do model mesmo quando o valor atual for igual ao valor anterior.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-emit-all-changes', transform: convertToBoolean }) emitAllChanges: boolean = false;\n\n  /** Rótulo 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 identificador do campo. */\n  @Input('name') name: string;\n\n  /**\n   * @description\n   *\n   * Mensagem que será apresentada quando o `pattern` ou a máscara não for satisfeita.\n   *\n   * > Esta mensagem não é apresentada quando o campo estiver vazio, mesmo que ele seja requerido.\n   */\n  @Input('p-error-pattern') errorPattern?: 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   * @description\n   *\n   * Converte o conteúdo do campo em maiúsulo automaticamente.\n   *\n   */\n  @Input({ alias: 'p-upper-case', transform: convertToBoolean }) upperCase: boolean = false;\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();\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();\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();\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();\n\n  type: string;\n\n  onChangePropagate: any = null;\n  objMask: any;\n  modelLastUpdate: any;\n  protected onTouched: any = null;\n\n  protected passedWriteValue: boolean = false;\n  protected validatorChange: any;\n\n  private _maxlength?: number;\n  private _minlength?: number;\n  private _noAutocomplete?: boolean = false;\n  private _placeholder?: string = '';\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a propriedade nativa `autocomplete` do campo como `off`.\n   *\n   * > No componente `po-password` será definido como `new-password`.\n   *\n   * Nos componentes `po-password` e `po-login` o valor padrão será `true`.\n   *\n   * @default `false`\n   */\n  @Input('p-no-autocomplete') set noAutocomplete(value: boolean) {\n    this._noAutocomplete = convertToBoolean(value);\n  }\n\n  get noAutocomplete() {\n    return this._noAutocomplete;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Mensagem que aparecerá enquanto o campo não estiver preenchido.\n   *\n   * @default ''\n   */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @description\n   *\n   * Se verdadeiro, desabilita o campo.\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  disabled?: boolean = false;\n  @Input('p-disabled') set setDisabled(disabled: string) {\n    this.disabled = disabled === '' ? true : convertToBoolean(disabled);\n\n    this.validateModel();\n  }\n\n  /** Indica que o campo será somente leitura. */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  readonly?: boolean = false;\n  @Input('p-readonly') set setReadonly(readonly: string) {\n    this.readonly = readonly === '' ? true : convertToBoolean(readonly);\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define que o campo será obrigatório.\n   * > Esta propriedade é desconsiderada quando o input está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  required?: boolean = false;\n  @Input('p-required') set setRequired(required: string) {\n    this.required = required === '' ? true : convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  /**\n   * Define se a indicação de campo obrigatório será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - Não possuir `p-help` e/ou `p-label`.\n   */\n  @Input('p-show-required') showRequired: boolean = false;\n\n  /** Se verdadeiro, o campo receberá um botão para ser limpo. */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  clean?: boolean = false;\n  @Input('p-clean') set setClean(clean: string) {\n    this.clean = clean === '' ? true : convertToBoolean(clean);\n  }\n\n  /**\n   * @description\n   *\n   * Expressão regular para validar o campo.\n   * Quando o campo possuir uma máscara `(p-mask)` será automaticamente validado por ela, porém\n   * é possível definir um p-pattern para substituir a validação da máscara.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  pattern?: string;\n  @Input('p-pattern') set setPattern(pattern: string) {\n    this.pattern = pattern;\n\n    this.validateModel();\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(value: number) {\n    if (!isNaN(parseInt(<any>value, 10))) {\n      this._maxlength = parseInt(<any>value, 10);\n\n      this.validateModel();\n    } else if (!value) {\n      this._maxlength = undefined;\n\n      this.validateModel();\n    }\n  }\n\n  get maxlength() {\n    return this._maxlength;\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(value: number) {\n    if (!isNaN(parseInt(<any>value, 10))) {\n      this._minlength = parseInt(<any>value, 10);\n\n      this.validateModel();\n    } else if (!value) {\n      this._minlength = undefined;\n\n      this.validateModel();\n    }\n  }\n\n  get minlength() {\n    return this._minlength;\n  }\n\n  /**\n   * @description\n   *\n   * Indica uma máscara para o campo. Exemplos: (+99) (99) 99999?-9999, 99999-999, 999.999.999-99.\n   * A máscara gera uma validação automática do campo, podendo esta ser substituída por um REGEX específico\n   * através da propriedade p-pattern.\n   * O campo será sinalizado e o formulário ficará inválido quando o valor informado estiver fora do padrão definido,\n   * mesmo quando desabilitado.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  mask?: string = '';\n  @Input('p-mask') set setMask(mask: string) {\n    this.mask = mask;\n\n    // Atualiza Máscara do Campo\n    this.objMask = new PoMask(this.mask, this.maskFormatModel);\n  }\n\n  /**\n   * @description\n   *\n   * Indica se o `model` receberá o valor formatado pela máscara ou apenas o valor puro (sem formatação).\n   *\n   * @default `false`\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  maskFormatModel?: boolean = false;\n  @Input('p-mask-format-model') set setMaskFormatModel(maskFormatModel: string) {\n    this.maskFormatModel = maskFormatModel === '' ? true : convertToBoolean(maskFormatModel);\n\n    if (this.objMask instanceof PoMask) {\n      this.objMask.formatModel = this.maskFormatModel;\n\n      this.validateModel();\n    }\n  }\n\n  constructor(private cd?: ChangeDetectorRef) {\n    this.objMask = new PoMask(this.mask, this.maskFormatModel);\n  }\n\n  callOnChange(value: any) {\n    this.updateModel(value);\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  callUpdateModelWithTimeout(value) {\n    setTimeout(() => this.updateModel(value));\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value || this.emitAllChanges) {\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ção implementada do ControlValueAccessor\n  // Usada para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.validatorChange = fn;\n  }\n\n  updateModel(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\n  validate(c: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, this.getScreenValue())) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, this.getScreenValue())) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, this.getScreenValue())) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (patternFailed(this.pattern, c.value)) {\n      this.validatePatternOnWriteValue(c.value);\n      return {\n        pattern: {\n          valid: false\n        }\n      };\n    }\n\n    return this.extraValidation(c);\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  // utilizado para validar o pattern na inicializacao, fazendo dessa forma o campo fica sujo (dirty).\n  private validatePatternOnWriteValue(value: string) {\n    if (value && this.passedWriteValue) {\n      setTimeout(() => {\n        this.updateModel(value);\n      });\n\n      this.passedWriteValue = false;\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 { PoNomeDoComponenteComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoNomeDoComponenteComponent, { static: true }) nomeDoComponente: PoNomeDoComponenteComponent;\n   *\n   * focusComponent() {\n   *   this.nomeDoComponente.focus();\n   * }\n   * ```\n   */\n  abstract focus(): void;\n\n  // Método que receberá o valor do model\n  abstract writeValueModel(value: any): void;\n\n  // Validações do campo\n  abstract extraValidation(c: AbstractControl): { [key: string]: any };\n\n  // Deve retornar o valor do campo\n  abstract getScreenValue(): string;\n}\n"]}
@@ -1,6 +1,6 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef } from '@angular/core';
2
- import { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
3
- import { uuid } from '../../../utils/util';
1
+ import { ChangeDetectionStrategy, Component, forwardRef, Input } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { convertToBoolean, uuid } from '../../../utils/util';
4
4
  import { PoInputGeneric } from '../po-input-generic/po-input-generic';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/common";
@@ -59,6 +59,16 @@ const providers = [
59
59
  export class PoLoginComponent extends PoInputGeneric {
60
60
  id = `po-login[${uuid()}]`;
61
61
  type = 'text';
62
+ _noAutocompleteLogin = true;
63
+ set noAutocomplete(value) {
64
+ this._noAutocompleteLogin = convertToBoolean(value);
65
+ }
66
+ get noAutocomplete() {
67
+ return this._noAutocompleteLogin;
68
+ }
69
+ get autocomplete() {
70
+ return this.noAutocomplete ? 'off' : 'on';
71
+ }
62
72
  /* istanbul ignore next */
63
73
  constructor(el, cd) {
64
74
  super(el, cd);
@@ -67,7 +77,7 @@ export class PoLoginComponent extends PoInputGeneric {
67
77
  return null;
68
78
  }
69
79
  static ɵfac = function PoLoginComponent_Factory(t) { return new (t || PoLoginComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
70
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoLoginComponent, selectors: [["po-login"]], features: [i0.ɵɵProvidersFeature(providers), i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 25, consts: [["inp", ""], [3, "p-disabled", "p-id", "p-label", "p-optional", "p-required", "p-show-required"], [1, "po-field-container-content"], [1, "po-field-icon-container-left"], ["p-icon", "ICON_USER"], [1, "po-input", "po-input-icon-left", 3, "blur", "click", "focus", "input", "autocomplete", "disabled", "id", "placeholder", "readonly", "required", "type"], [1, "po-field-icon-container-right"], ["class", "po-icon-input", 3, "p-element-ref", "p-change-event", 4, "ngIf"], [3, "p-help", "p-disabled", "p-error-pattern"], [1, "po-icon-input", 3, "p-change-event", "p-element-ref"]], template: function PoLoginComponent_Template(rf, ctx) { if (rf & 1) {
80
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoLoginComponent, selectors: [["po-login"]], inputs: { noAutocomplete: [0, "p-no-autocomplete", "noAutocomplete"] }, features: [i0.ɵɵProvidersFeature(providers), i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 25, consts: [["inp", ""], [3, "p-disabled", "p-id", "p-label", "p-optional", "p-required", "p-show-required"], [1, "po-field-container-content"], [1, "po-field-icon-container-left"], ["p-icon", "ICON_USER"], [1, "po-input", "po-input-icon-left", 3, "blur", "click", "focus", "input", "autocomplete", "disabled", "id", "placeholder", "readonly", "required", "type"], [1, "po-field-icon-container-right"], ["class", "po-icon-input", 3, "p-element-ref", "p-change-event", 4, "ngIf"], [3, "p-help", "p-disabled", "p-error-pattern"], [1, "po-icon-input", 3, "p-change-event", "p-element-ref"]], template: function PoLoginComponent_Template(rf, ctx) { if (rf & 1) {
71
81
  const _r1 = i0.ɵɵgetCurrentView();
72
82
  i0.ɵɵelementStart(0, "po-field-container", 1)(1, "div", 2)(2, "div", 3);
73
83
  i0.ɵɵelement(3, "po-icon", 4);
@@ -98,6 +108,9 @@ export class PoLoginComponent extends PoInputGeneric {
98
108
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoLoginComponent, [{
99
109
  type: Component,
100
110
  args: [{ selector: 'po-login', changeDetection: ChangeDetectionStrategy.OnPush, providers: providers, template: "<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 <div class=\"po-field-icon-container-left\">\n <po-icon\n p-icon=\"ICON_USER\"\n class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n [class.po-field-icon-disabled]=\"disabled\"\n ></po-icon>\n </div>\n\n <input\n #inp\n class=\"po-input po-input-icon-left\"\n [attr.name]=\"name\"\n [autocomplete]=\"autocomplete\"\n [class.po-input-icon-right]=\"clean\"\n [disabled]=\"disabled\"\n [id]=\"id\"\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=\"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-help]=\"help\" [p-disabled]=\"disabled\" [p-error-pattern]=\"getErrorPattern()\">\n </po-field-container-bottom>\n</po-field-container>\n" }]
101
- }], () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], null); })();
111
+ }], () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], { noAutocomplete: [{
112
+ type: Input,
113
+ args: ['p-no-autocomplete']
114
+ }] }); })();
102
115
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoLoginComponent, { className: "PoLoginComponent", filePath: "lib/components/po-field/po-login/po-login.component.ts", lineNumber: 54 }); })();
103
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tbG9naW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLWZpZWxkL3BvLWxvZ2luL3BvLWxvZ2luLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1maWVsZC9wby1sb2dpbi9wby1sb2dpbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBYyxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUcsT0FBTyxFQUFtQixpQkFBaUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVuRixPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFM0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOzs7Ozs7Ozs7SUMrQmhFLG1DQUtDO0lBREMsMk1BQWtCLG9CQUFhLEtBQUM7SUFFbEMsaUJBQVc7OztJQUhULDhDQUF5Qjs7QURoQ2pDLDBCQUEwQjtBQUMxQixNQUFNLFNBQVMsR0FBRztJQUNoQjtRQUNFLE9BQU8sRUFBRSxpQkFBaUI7UUFDMUIsMkJBQTJCO1FBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7UUFDL0MsS0FBSyxFQUFFLElBQUk7S0FDWjtJQUNEO1FBQ0UsT0FBTyxFQUFFLGFBQWE7UUFDdEIsMkJBQTJCO1FBQzNCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7UUFDL0MsS0FBSyxFQUFFLElBQUk7S0FDWjtDQUNGLENBQUM7QUFFRjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F1Qkc7QUFPSCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsY0FBYztJQUNsRCxFQUFFLEdBQUcsWUFBWSxJQUFJLEVBQUUsR0FBRyxDQUFDO0lBQzNCLElBQUksR0FBRyxNQUFNLENBQUM7SUFFZCwwQkFBMEI7SUFDMUIsWUFBWSxFQUFjLEVBQUUsRUFBcUI7UUFDL0MsS0FBSyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNoQixDQUFDO0lBRUQsZUFBZSxDQUFDLENBQWtCO1FBQ2hDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzswRUFYVSxnQkFBZ0I7NkRBQWhCLGdCQUFnQiw4REFGM0IsU0FBUzs7WUMxQ1AsQUFERixBQVJGLDZDQU9DLGFBQ3lDLGFBQ0k7WUFDeEMsNkJBSVc7WUFDYixpQkFBTTtZQUVOLG1DQWdCRTtZQURBLEFBREEsQUFEQSxBQURBLHNJQUFRLHVCQUFtQixLQUFDLDJIQUNuQix3QkFBb0IsS0FBQywySEFDckIsd0JBQW9CLEtBQUMsMkhBQ3JCLHdCQUFvQixLQUFDO1lBZmhDLGlCQWdCRTtZQUVGLDhCQUEyQztZQUN6QywyRUFLQztZQUdMLEFBREUsaUJBQU0sRUFDRjtZQUVOLCtDQUM0QjtZQUM5QixpQkFBcUI7O1lBMUNuQixBQURBLEFBREEsQUFEQSxBQURBLEFBREEseUNBQXVCLGdCQUNaLHNCQUNNLDRCQUNNLDRCQUNBLHFDQUNTO1lBTTFCLGVBQWlGO1lBQWpGLDBHQUFpRjtZQUNqRixzREFBeUM7WUFTM0MsY0FBbUM7WUFBbkMsZ0RBQW1DO1lBTW5DLEFBREEsQUFEQSxBQURBLEFBREEsQUFEQSxBQUZBLCtDQUE2QiwwQkFFUixjQUNaLG9EQUNrQywwQkFDdEIsMEJBQ0Esa0JBQ1I7O1lBVVYsZUFBcUM7WUFBckMsa0VBQXFDO1lBUWpCLGNBQWU7WUFBeUIsQUFBeEIsQUFBaEIsaUNBQWUsNEJBQXdCLDBDQUFzQzs7O2lGRE83RixnQkFBZ0I7Y0FONUIsU0FBUzsyQkFDRSxVQUFVLG1CQUVILHVCQUF1QixDQUFDLE1BQU0sYUFDL0MsU0FBUzs7a0ZBRUUsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgTkdfVkFMVUVfQUNDRVNTT1IsIE5HX1ZBTElEQVRPUlMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IHV1aWQgfSBmcm9tICcuLi8uLi8uLi91dGlscy91dGlsJztcblxuaW1wb3J0IHsgUG9JbnB1dEdlbmVyaWMgfSBmcm9tICcuLi9wby1pbnB1dC1nZW5lcmljL3BvLWlucHV0LWdlbmVyaWMnO1xuXG4vKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuY29uc3QgcHJvdmlkZXJzID0gW1xuICB7XG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gUG9Mb2dpbkNvbXBvbmVudCksXG4gICAgbXVsdGk6IHRydWVcbiAgfSxcbiAge1xuICAgIHByb3ZpZGU6IE5HX1ZBTElEQVRPUlMsXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gUG9Mb2dpbkNvbXBvbmVudCksXG4gICAgbXVsdGk6IHRydWVcbiAgfVxuXTtcblxuLyoqXG4gKiBAZG9jc0V4dGVuZHMgUG9JbnB1dEJhc2VDb21wb25lbnRcbiAqXG4gKiBAZGVzY3JpcHRpb25cbiAqIE8gYHBvLWxvZ2luYCDDqSB1bSBpbnB1dCBlc3BlY8OtZmljbyBwYXJhIGxvZ2luLiBKw6EgcG9zc3VpIHRpcG8sIGVzdGlsbyBlIMOtY29uZSBwcmVkZWZpbmlkb3MuXG4gKlxuICogQGV4YW1wbGVcbiAqXG4gKiA8ZXhhbXBsZSBuYW1lPVwicG8tbG9naW4tYmFzaWNcIiB0aXRsZT1cIlBPIExvZ2luIEJhc2ljXCI+XG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1sb2dpbi1iYXNpYy9zYW1wbGUtcG8tbG9naW4tYmFzaWMuY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbG9naW4tYmFzaWMvc2FtcGxlLXBvLWxvZ2luLWJhc2ljLmNvbXBvbmVudC50c1wiPiA8L2ZpbGU+XG4gKiA8L2V4YW1wbGU+XG4gKlxuICogPGV4YW1wbGUgbmFtZT1cInBvLWxvZ2luLWxhYnNcIiB0aXRsZT1cIlBPIExvZ2luIExhYnNcIj5cbiAqICA8ZmlsZSBuYW1lPVwic2FtcGxlLXBvLWxvZ2luLWxhYnMvc2FtcGxlLXBvLWxvZ2luLWxhYnMuY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbG9naW4tbGFicy9zYW1wbGUtcG8tbG9naW4tbGFicy5jb21wb25lbnQudHNcIj4gPC9maWxlPlxuICogPC9leGFtcGxlPlxuICpcbiAqIDxleGFtcGxlIG5hbWU9XCJwby1sb2dpbi1jb25maXJtXCIgdGl0bGU9XCJQTyBMb2dpbiAtIENvbmZpcm0gSWRlbnRpdHlcIj5cbiAqICA8ZmlsZSBuYW1lPVwic2FtcGxlLXBvLWxvZ2luLWNvbmZpcm0vc2FtcGxlLXBvLWxvZ2luLWNvbmZpcm0uY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbG9naW4tY29uZmlybS9zYW1wbGUtcG8tbG9naW4tY29uZmlybS5jb21wb25lbnQudHNcIj4gPC9maWxlPlxuICogPC9leGFtcGxlPlxuICpcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tbG9naW4nLFxuICB0ZW1wbGF0ZVVybDogJy4vcG8tbG9naW4uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgcHJvdmlkZXJzXG59KVxuZXhwb3J0IGNsYXNzIFBvTG9naW5Db21wb25lbnQgZXh0ZW5kcyBQb0lucHV0R2VuZXJpYyB7XG4gIGlkID0gYHBvLWxvZ2luWyR7dXVpZCgpfV1gO1xuICB0eXBlID0gJ3RleHQnO1xuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGNvbnN0cnVjdG9yKGVsOiBFbGVtZW50UmVmLCBjZDogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICBzdXBlcihlbCwgY2QpO1xuICB9XG5cbiAgZXh0cmFWYWxpZGF0aW9uKGM6IEFic3RyYWN0Q29udHJvbCk6IHsgW2tleTogc3RyaW5nXTogYW55IH0ge1xuICAgIHJldHVybiBudWxsO1xuICB9XG59XG4iLCI8cG8tZmllbGQtY29udGFpbmVyXG4gIFtwLWRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW3AtaWRdPVwiaWRcIlxuICBbcC1sYWJlbF09XCJsYWJlbFwiXG4gIFtwLW9wdGlvbmFsXT1cIm9wdGlvbmFsXCJcbiAgW3AtcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICBbcC1zaG93LXJlcXVpcmVkXT1cInNob3dSZXF1aXJlZFwiXG4+XG4gIDxkaXYgY2xhc3M9XCJwby1maWVsZC1jb250YWluZXItY29udGVudFwiPlxuICAgIDxkaXYgY2xhc3M9XCJwby1maWVsZC1pY29uLWNvbnRhaW5lci1sZWZ0XCI+XG4gICAgICA8cG8taWNvblxuICAgICAgICBwLWljb249XCJJQ09OX1VTRVJcIlxuICAgICAgICBjbGFzcz1cInBvLWZpZWxkLWljb24ge3sgZGlzYWJsZWQgPyAncG8taWNvbi1pbnB1dC1kaXNhYmxlZCcgOiAncG8taWNvbi1pbnB1dCcgfX1cIlxuICAgICAgICBbY2xhc3MucG8tZmllbGQtaWNvbi1kaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICA+PC9wby1pY29uPlxuICAgIDwvZGl2PlxuXG4gICAgPGlucHV0XG4gICAgICAjaW5wXG4gICAgICBjbGFzcz1cInBvLWlucHV0IHBvLWlucHV0LWljb24tbGVmdFwiXG4gICAgICBbYXR0ci5uYW1lXT1cIm5hbWVcIlxuICAgICAgW2F1dG9jb21wbGV0ZV09XCJhdXRvY29tcGxldGVcIlxuICAgICAgW2NsYXNzLnBvLWlucHV0LWljb24tcmlnaHRdPVwiY2xlYW5cIlxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgIFtpZF09XCJpZFwiXG4gICAgICBbcGxhY2Vob2xkZXJdPVwiZGlzYWJsZWQgPyAnJyA6IHBsYWNlaG9sZGVyXCJcbiAgICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXG4gICAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICAgICAgW3R5cGVdPVwidHlwZVwiXG4gICAgICAoYmx1cik9XCJldmVudE9uQmx1cigkZXZlbnQpXCJcbiAgICAgIChjbGljayk9XCJldmVudE9uQ2xpY2soJGV2ZW50KVwiXG4gICAgICAoZm9jdXMpPVwiZXZlbnRPbkZvY3VzKCRldmVudClcIlxuICAgICAgKGlucHV0KT1cImV2ZW50T25JbnB1dCgkZXZlbnQpXCJcbiAgICAvPlxuXG4gICAgPGRpdiBjbGFzcz1cInBvLWZpZWxkLWljb24tY29udGFpbmVyLXJpZ2h0XCI+XG4gICAgICA8cG8tY2xlYW5cbiAgICAgICAgY2xhc3M9XCJwby1pY29uLWlucHV0XCJcbiAgICAgICAgKm5nSWY9XCJjbGVhbiAmJiAhZGlzYWJsZWQgJiYgIXJlYWRvbmx5XCJcbiAgICAgICAgW3AtZWxlbWVudC1yZWZdPVwiaW5wdXRFbFwiXG4gICAgICAgIChwLWNoYW5nZS1ldmVudCk9XCJjbGVhcigkZXZlbnQpXCJcbiAgICAgID5cbiAgICAgIDwvcG8tY2xlYW4+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuXG4gIDxwby1maWVsZC1jb250YWluZXItYm90dG9tIFtwLWhlbHBdPVwiaGVscFwiIFtwLWRpc2FibGVkXT1cImRpc2FibGVkXCIgW3AtZXJyb3ItcGF0dGVybl09XCJnZXRFcnJvclBhdHRlcm4oKVwiPlxuICA8L3BvLWZpZWxkLWNvbnRhaW5lci1ib3R0b20+XG48L3BvLWZpZWxkLWNvbnRhaW5lcj5cbiJdfQ==
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-login.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-login/po-login.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-login/po-login.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAc,UAAU,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACrH,OAAO,EAAmB,aAAa,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnF,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;IC+BhE,mCAKC;IADC,2MAAkB,oBAAa,KAAC;IAElC,iBAAW;;;IAHT,8CAAyB;;ADhCjC,0BAA0B;AAC1B,MAAM,SAAS,GAAG;IAChB;QACE,OAAO,EAAE,iBAAiB;QAC1B,2BAA2B;QAC3B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;QAC/C,KAAK,EAAE,IAAI;KACZ;IACD;QACE,OAAO,EAAE,aAAa;QACtB,2BAA2B;QAC3B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;QAC/C,KAAK,EAAE,IAAI;KACZ;CACF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAOH,MAAM,OAAO,gBAAiB,SAAQ,cAAc;IAClD,EAAE,GAAG,YAAY,IAAI,EAAE,GAAG,CAAC;IAC3B,IAAI,GAAG,MAAM,CAAC;IACN,oBAAoB,GAAa,IAAI,CAAC;IAE9C,IAAyC,cAAc,CAAC,KAAc;QACpE,IAAI,CAAC,oBAAoB,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACtD,CAAC;IAED,IAAa,cAAc;QACzB,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAED,IAAa,YAAY;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAC5C,CAAC;IAED,0BAA0B;IAC1B,YAAY,EAAc,EAAE,EAAqB;QAC/C,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IAChB,CAAC;IAED,eAAe,CAAC,CAAkB;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;0EAxBU,gBAAgB;6DAAhB,gBAAgB,sIAF3B,SAAS;;YC1CP,AADF,AARF,6CAOC,aACyC,aACI;YACxC,6BAIW;YACb,iBAAM;YAEN,mCAgBE;YADA,AADA,AADA,AADA,sIAAQ,uBAAmB,KAAC,2HACnB,wBAAoB,KAAC,2HACrB,wBAAoB,KAAC,2HACrB,wBAAoB,KAAC;YAfhC,iBAgBE;YAEF,8BAA2C;YACzC,2EAKC;YAGL,AADE,iBAAM,EACF;YAEN,+CAC4B;YAC9B,iBAAqB;;YA1CnB,AADA,AADA,AADA,AADA,AADA,yCAAuB,gBACZ,sBACM,4BACM,4BACA,qCACS;YAM1B,eAAiF;YAAjF,0GAAiF;YACjF,sDAAyC;YAS3C,cAAmC;YAAnC,gDAAmC;YAMnC,AADA,AADA,AADA,AADA,AADA,AAFA,+CAA6B,0BAER,cACZ,oDACkC,0BACtB,0BACA,kBACR;;YAUV,eAAqC;YAArC,kEAAqC;YAQjB,cAAe;YAAyB,AAAxB,AAAhB,iCAAe,4BAAwB,0CAAsC;;;iFDO7F,gBAAgB;cAN5B,SAAS;2BACE,UAAU,mBAEH,uBAAuB,CAAC,MAAM,aAC/C,SAAS;2EAOgC,cAAc;kBAAtD,KAAK;mBAAC,mBAAmB;;kFALf,gBAAgB","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input } from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { convertToBoolean, uuid } from '../../../utils/util';\n\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/* istanbul ignore next */\nconst providers = [\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoLoginComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoLoginComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n * O `po-login` é um input específico para login. Já possui tipo, estilo e ícone predefinidos.\n *\n * @example\n *\n * <example name=\"po-login-basic\" title=\"PO Login Basic\">\n *  <file name=\"sample-po-login-basic/sample-po-login-basic.component.html\"> </file>\n *  <file name=\"sample-po-login-basic/sample-po-login-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-login-labs\" title=\"PO Login Labs\">\n *  <file name=\"sample-po-login-labs/sample-po-login-labs.component.html\"> </file>\n *  <file name=\"sample-po-login-labs/sample-po-login-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-login-confirm\" title=\"PO Login - Confirm Identity\">\n *  <file name=\"sample-po-login-confirm/sample-po-login-confirm.component.html\"> </file>\n *  <file name=\"sample-po-login-confirm/sample-po-login-confirm.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-login',\n  templateUrl: './po-login.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class PoLoginComponent extends PoInputGeneric {\n  id = `po-login[${uuid()}]`;\n  type = 'text';\n  private _noAutocompleteLogin?: boolean = true;\n\n  @Input('p-no-autocomplete') override set noAutocomplete(value: boolean) {\n    this._noAutocompleteLogin = convertToBoolean(value);\n  }\n\n  override get noAutocomplete() {\n    return this._noAutocompleteLogin;\n  }\n\n  override get autocomplete(): string {\n    return this.noAutocomplete ? 'off' : 'on';\n  }\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\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    <div class=\"po-field-icon-container-left\">\n      <po-icon\n        p-icon=\"ICON_USER\"\n        class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        [class.po-field-icon-disabled]=\"disabled\"\n      ></po-icon>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input po-input-icon-left\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-icon-right]=\"clean\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\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=\"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-help]=\"help\" [p-disabled]=\"disabled\" [p-error-pattern]=\"getErrorPattern()\">\n  </po-field-container-bottom>\n</po-field-container>\n"]}
@@ -1,5 +1,5 @@
1
- import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
2
1
  import { ChangeDetectionStrategy, Component, forwardRef, Input } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { convertToBoolean, uuid } from '../../../utils/util';
4
4
  import { PoInputGeneric } from '../po-input-generic/po-input-generic';
5
5
  import * as i0 from "@angular/core";
@@ -54,6 +54,7 @@ export class PoPasswordComponent extends PoInputGeneric {
54
54
  type = 'password';
55
55
  visiblePassword = false;
56
56
  _hidePasswordPeek = false;
57
+ _noAutocompletePassword = true;
57
58
  /**
58
59
  * @optional
59
60
  *
@@ -70,6 +71,12 @@ export class PoPasswordComponent extends PoInputGeneric {
70
71
  this.type = 'password';
71
72
  }
72
73
  }
74
+ set noAutocomplete(value) {
75
+ this._noAutocompletePassword = convertToBoolean(value);
76
+ }
77
+ get noAutocomplete() {
78
+ return this._noAutocompletePassword;
79
+ }
73
80
  get hidePasswordPeek() {
74
81
  return this._hidePasswordPeek;
75
82
  }
@@ -88,7 +95,7 @@ export class PoPasswordComponent extends PoInputGeneric {
88
95
  this.type = this.type === 'password' ? 'text' : 'password';
89
96
  }
90
97
  static ɵfac = function PoPasswordComponent_Factory(t) { return new (t || PoPasswordComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
91
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPasswordComponent, selectors: [["po-password"]], inputs: { hidePasswordPeek: [0, "p-hide-password-peek", "hidePasswordPeek"] }, features: [i0.ɵɵProvidersFeature([
98
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPasswordComponent, selectors: [["po-password"]], inputs: { hidePasswordPeek: [0, "p-hide-password-peek", "hidePasswordPeek"], noAutocomplete: [0, "p-no-autocomplete", "noAutocomplete"] }, features: [i0.ɵɵProvidersFeature([
92
99
  {
93
100
  provide: NG_VALUE_ACCESSOR,
94
101
  useExisting: forwardRef(() => PoPasswordComponent),
@@ -147,6 +154,9 @@ export class PoPasswordComponent extends PoInputGeneric {
147
154
  }], () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], { hidePasswordPeek: [{
148
155
  type: Input,
149
156
  args: ['p-hide-password-peek']
157
+ }], noAutocomplete: [{
158
+ type: Input,
159
+ args: ['p-no-autocomplete']
150
160
  }] }); })();
151
161
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoPasswordComponent, { className: "PoPasswordComponent", filePath: "lib/components/po-field/po-password/po-password.component.ts", lineNumber: 47 }); })();
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-password.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input } from '@angular/core';\n\nimport { convertToBoolean, uuid } from '../../../utils/util';\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n * O `po-password` é um input específico para senhas. Já possui tipo, estilo e ícone predefinidos.\n *\n * @example\n *\n * <example name=\"po-password-basic\" title=\"PO Password Basic\">\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.html\"> </file>\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-labs\" title=\"PO Password Labs\">\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.html\"> </file>\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-reset\" title=\"PO Password - Reset\">\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.html\"> </file>\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-password',\n  templateUrl: './po-password.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoPasswordComponent extends PoInputGeneric {\n  id = `po-password[${uuid()}]`;\n  type = 'password';\n  visiblePassword = false;\n\n  private _hidePasswordPeek?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Permite esconder a função de espiar a senha digitada.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-password-peek') set hidePasswordPeek(value: boolean) {\n    this._hidePasswordPeek = convertToBoolean(value);\n    if (value) {\n      this.visiblePassword = false;\n      this.type = 'password';\n    }\n  }\n\n  get hidePasswordPeek(): boolean {\n    return this._hidePasswordPeek;\n  }\n\n  get autocomplete(): string {\n    return this.noAutocomplete ? 'new-password' : 'on';\n  }\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  showPassword() {\n    this.visiblePassword = !this.visiblePassword;\n    this.type = this.type === 'password' ? 'text' : 'password';\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    <div class=\"po-field-icon-container-left\">\n      <po-icon\n        p-icon=\"ICON_LOCK\"\n        class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        [class.po-field-icon-disabled]=\"disabled\"\n      >\n      </po-icon>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input po-input-icon-left\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n      [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"disabled ? 'password' : 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=\"po-icon-input\"\n        *ngIf=\"clean && !disabled && !readonly\"\n        [p-element-ref]=\"inputEl\"\n        (p-change-event)=\"clear($event)\"\n      >\n      </po-clean>\n\n      <po-icon\n        *ngIf=\"!hidePasswordPeek && !disabled\"\n        [p-icon]=\"visiblePassword ? 'ICON_EYE' : 'ICON_EYE_OFF po-field-icon-disabled'\"\n        class=\"po-field-icon po-icon-input\"\n        [ngClass]=\"!visiblePassword ? 'po-field-icon-disabled' : ''\"\n        (click)=\"showPassword()\"\n      >\n      </po-icon>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\" [p-error-pattern]=\"getErrorPattern()\">\n  </po-field-container-bottom>\n</po-field-container>\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-password.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input } from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { convertToBoolean, uuid } from '../../../utils/util';\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n * O `po-password` é um input específico para senhas. Já possui tipo, estilo e ícone predefinidos.\n *\n * @example\n *\n * <example name=\"po-password-basic\" title=\"PO Password Basic\">\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.html\"> </file>\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-labs\" title=\"PO Password Labs\">\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.html\"> </file>\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-reset\" title=\"PO Password - Reset\">\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.html\"> </file>\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-password',\n  templateUrl: './po-password.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoPasswordComponent extends PoInputGeneric {\n  id = `po-password[${uuid()}]`;\n  type = 'password';\n  visiblePassword = false;\n\n  private _hidePasswordPeek?: boolean = false;\n  private _noAutocompletePassword?: boolean = true;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Permite esconder a função de espiar a senha digitada.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-password-peek') set hidePasswordPeek(value: boolean) {\n    this._hidePasswordPeek = convertToBoolean(value);\n    if (value) {\n      this.visiblePassword = false;\n      this.type = 'password';\n    }\n  }\n\n  @Input('p-no-autocomplete') override set noAutocomplete(value: boolean) {\n    this._noAutocompletePassword = convertToBoolean(value);\n  }\n\n  override get noAutocomplete() {\n    return this._noAutocompletePassword;\n  }\n\n  get hidePasswordPeek(): boolean {\n    return this._hidePasswordPeek;\n  }\n\n  get autocomplete(): string {\n    return this.noAutocomplete ? 'new-password' : 'on';\n  }\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  showPassword() {\n    this.visiblePassword = !this.visiblePassword;\n    this.type = this.type === 'password' ? 'text' : 'password';\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    <div class=\"po-field-icon-container-left\">\n      <po-icon\n        p-icon=\"ICON_LOCK\"\n        class=\"po-field-icon {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        [class.po-field-icon-disabled]=\"disabled\"\n      >\n      </po-icon>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input po-input-icon-left\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n      [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"disabled ? 'password' : 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=\"po-icon-input\"\n        *ngIf=\"clean && !disabled && !readonly\"\n        [p-element-ref]=\"inputEl\"\n        (p-change-event)=\"clear($event)\"\n      >\n      </po-clean>\n\n      <po-icon\n        *ngIf=\"!hidePasswordPeek && !disabled\"\n        [p-icon]=\"visiblePassword ? 'ICON_EYE' : 'ICON_EYE_OFF po-field-icon-disabled'\"\n        class=\"po-field-icon po-icon-input\"\n        [ngClass]=\"!visiblePassword ? 'po-field-icon-disabled' : ''\"\n        (click)=\"showPassword()\"\n      >\n      </po-icon>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\" [p-error-pattern]=\"getErrorPattern()\">\n  </po-field-container-bottom>\n</po-field-container>\n"]}
@@ -25,17 +25,19 @@ import * as i1 from "../../services/po-language/po-language.service";
25
25
  *
26
26
  * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
27
27
  *
28
- * | Propriedade | Descrição | Valor Padrão |
29
- * |----------------------------------------------|-------------------------------------------------------|--------------------------------------------------|
30
- * | **Default Values** | | |
31
- * | `--border-radius` &nbsp; | Contém o valor do raio dos cantos do elemento&nbsp; | `var(--border-radius-md)` |
32
- * | `--border-width` &nbsp; | Contém o valor da largura dos cantos do elemento&nbsp;| `var(--border-width-sm)` |
33
- * | `--border-color` &nbsp; | Cor da borda | `var(--color-neutral-light-20)` |
34
- * | `--background` &nbsp; | Cor de background | `var(--color-neutral-light-00)` |
35
- * | `--shadow` &nbsp; | Contém o valor da sombra do elemento | `var(--shadow-md)` |
36
- * | `--color-overlay` &nbsp; | Cor da camada visual temporária | `var(--color-neutral-dark-80)` |
37
- * | `--opacity-overlay` &nbsp; | Opacidade da camada visual temporária &nbsp; | `0.7` |
38
- * | `--color-divider` &nbsp; | Cor das divisões do modal | `var(--color-neutral-light-20)` |
28
+ * | Propriedade | Descrição | Valor Padrão |
29
+ * |----------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------|
30
+ * | **Default Values** | | |
31
+ * | `--border-radius` &nbsp; | Contém o valor do raio dos cantos do elemento&nbsp; | `var(--border-radius-md)` |
32
+ * | `--border-width` &nbsp; | Contém o valor da largura dos cantos do elemento&nbsp;| `var(--border-width-sm)` |
33
+ * | `--border-color` &nbsp; | Cor da borda | `var(--color-neutral-light-20)` |
34
+ * | `--background` &nbsp; | Cor de background | `var(--color-neutral-light-00)` |
35
+ * | `--shadow` &nbsp; | Contém o valor da sombra do elemento | `var(--shadow-md)` |
36
+ * | `--color-overlay` &nbsp; | Cor da camada visual temporária | `var(--color-neutral-dark-80)` |
37
+ * | `--opacity-overlay` &nbsp; | Opacidade da camada visual temporária &nbsp; | `0.7` |
38
+ * | `--color-divider` &nbsp; | Cor das divisões do modal | `var(--color-neutral-light-20)` |
39
+ * | `--padding-header` &nbsp; | Padding do header do modal | `var(--spacing-sm) var(--spacing-md)` |
40
+ * | `--padding-body` &nbsp; | Padding do corpo do modal | `var(--spacing-md) var(--spacing-2xl) var(--spacing-2xl) var(--spacing-md) ` |
39
41
  *
40
42
  */
41
43
  export class PoModalBaseComponent {
@@ -194,4 +196,4 @@ export class PoModalBaseComponent {
194
196
  type: Input,
195
197
  args: ['p-icon']
196
198
  }] }); })();
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-modal-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-modal/po-modal-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, EventEmitter, Directive, Output, TemplateRef } from '@angular/core';\n\nimport { convertToBoolean } from './../../utils/util';\nimport { PoModalAction } from './po-modal-action.interface';\n\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { poModalLiterals } from './po-modal.literals';\n\n/**\n * @description\n *\n * O componente `po-modal` é utilizado para incluir conteúdos rápidos e informativos.\n *\n * No cabeçalho do componente é possível definir um título e como também permite ocultar o ícone de fechamento da modal.\n *\n * Em seu corpo é possível definir um conteúdo informativo, podendo utilizar componentes como por exemplo `po-chart`,\n * `po-table` e os demais componentes do PO.\n *\n * No rodapé encontram-se os botões de ação primária e secundária, no qual permitem definir uma ação e um rótulo, bem como\n * definir um estado de carregando e / ou desabilitado e / ou definir o botão com o tipo *danger*. Também é possível utilizar\n * o componente [`PoModalFooter`](/documentation/po-modal-footer).\n *\n * > É possível fechar a modal através da tecla *ESC*, quando a propriedade `p-hide-close` não estiver habilitada.\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 * | `--border-radius` &nbsp;                     | Contém o valor do raio dos cantos do elemento&nbsp;   | `var(--border-radius-md)`                        |\n * | `--border-width` &nbsp;                      | Contém o valor da largura dos cantos do elemento&nbsp;| `var(--border-width-sm)`                         |\n * | `--border-color` &nbsp;                      | Cor da borda                                          | `var(--color-neutral-light-20)`                  |\n * | `--background` &nbsp;                        | Cor de background                                     | `var(--color-neutral-light-00)`                  |\n * | `--shadow` &nbsp;                            | Contém o valor da sombra do elemento                  | `var(--shadow-md)`                               |\n * | `--color-overlay` &nbsp;                     | Cor da camada visual temporária                       | `var(--color-neutral-dark-80)`                   |\n * | `--opacity-overlay` &nbsp;                   | Opacidade da camada visual temporária &nbsp;          | `0.7`                                            |\n * | `--color-divider` &nbsp;                     | Cor das divisões do modal                             | `var(--color-neutral-light-20)`                  |\n *\n */\n@Directive()\nexport class PoModalBaseComponent {\n  /** Título da modal. */\n  @Input('p-title') title: string;\n\n  /** Evento disparado ao fechar o modal. */\n  @Output('p-close') closeModal: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * Deve ser definido um objeto que implementa a interface `PoModalAction` contendo a label e a função da primeira ação.\n   * Caso esta propriedade não seja definida ou esteja incompleta, automaticamente será adicionado um botão de ação com\n   * a função de fechar a modal.\n   */\n  @Input('p-primary-action') primaryAction?: PoModalAction;\n\n  /** Deve ser definido um objeto que implementa a interface `PoModalAction` contendo a label e a função da segunda ação. */\n  @Input('p-secondary-action') secondaryAction?: PoModalAction;\n\n  language;\n  literals;\n\n  // Controla se a modal fica oculto ou visível, por padrão é oculto\n  isHidden = true;\n\n  // Event emmiter para quando a modal é fechada pelo 'X'.\n  public onXClosed = new EventEmitter<boolean>();\n\n  private _hideClose?: boolean = false;\n  private _size?: string = 'md';\n\n  /**\n   * Define o tamanho da modal.\n   *\n   * Valores válidos:\n   *  - `sm` (pequeno)\n   *  - `md` (médio)\n   *  - `lg` (grande)\n   *  - `xl` (extra grande)\n   *  - `auto` (automático)\n   *\n   * > Quando informado `auto` a modal calculará automaticamente seu tamanho baseado em seu conteúdo.\n   * Caso não seja informado um valor, a modal terá o tamanho definido como `md`.\n   *\n   * > Todas as opções de tamanho possuem uma largura máxima de **768px**.\n   */\n  @Input('p-size') set size(value: string) {\n    const sizes = ['sm', 'md', 'lg', 'xl', 'auto'];\n    this._size = sizes.indexOf(value) > -1 ? value : 'md';\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  /**\n   * Define o fechamento da modal ao clicar fora da mesma.\n   * Informe o valor `true` para ativar o fechamento ao clicar fora da modal.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  clickOut?: boolean = false;\n  @Input('p-click-out') set setClickOut(value: boolean | string) {\n    this.clickOut = value === '' ? false : convertToBoolean(value);\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Oculta o ícone de fechar do cabeçalho da modal.\n   *\n   * > Caso a propriedade estiver habilitada, não será possível fechar a modal através da tecla *ESC*.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-close') set hideClose(value: boolean) {\n    this._hideClose = convertToBoolean(value);\n  }\n\n  get hideClose() {\n    return this._hideClose;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ícone exibido ao lado esquerdo do label do titúlo da modal.\n   *\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-modal p-icon=\"ph ph-user\" p-title=\"PO Modal\"></po-modal>\n   * ```\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-modal p-icon=\"fa fa-podcast\" p-title=\"PO Modal\"></po-modal>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-modal [p-icon]=\"template\" p-title=\"PO Modal\"></po-modal>\n   *\n   * <ng-template #template>\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\n   * </ng-template>\n   * ```\n   */\n  @Input('p-icon') icon?: string | TemplateRef<void>;\n\n  constructor(poLanguageService: PoLanguageService) {\n    this.language = poLanguageService.getShortLanguage();\n\n    this.literals = {\n      ...poModalLiterals[this.language]\n    };\n  }\n\n  /** Função para fechar a modal. */\n  close(xClosed = false): void {\n    this.closeModal.emit();\n\n    this.isHidden = true;\n    if (xClosed) {\n      this.onXClosed.emit(xClosed);\n    }\n  }\n\n  /** Função para abrir a modal. */\n  open(): void {\n    this.validPrimaryAction();\n\n    this.isHidden = false;\n  }\n\n  validPrimaryAction() {\n    if (!this.primaryAction) {\n      this.primaryAction = {\n        action: () => this.close(),\n        label: this.literals.close\n      };\n    }\n\n    if (!this.primaryAction['action']) {\n      this.primaryAction['action'] = () => this.close();\n    }\n    if (!this.primaryAction['label']) {\n      this.primaryAction['label'] = this.literals.close;\n    }\n  }\n}\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-modal-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-modal/po-modal-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, EventEmitter, Directive, Output, TemplateRef } from '@angular/core';\n\nimport { convertToBoolean } from './../../utils/util';\nimport { PoModalAction } from './po-modal-action.interface';\n\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { poModalLiterals } from './po-modal.literals';\n\n/**\n * @description\n *\n * O componente `po-modal` é utilizado para incluir conteúdos rápidos e informativos.\n *\n * No cabeçalho do componente é possível definir um título e como também permite ocultar o ícone de fechamento da modal.\n *\n * Em seu corpo é possível definir um conteúdo informativo, podendo utilizar componentes como por exemplo `po-chart`,\n * `po-table` e os demais componentes do PO.\n *\n * No rodapé encontram-se os botões de ação primária e secundária, no qual permitem definir uma ação e um rótulo, bem como\n * definir um estado de carregando e / ou desabilitado e / ou definir o botão com o tipo *danger*. Também é possível utilizar\n * o componente [`PoModalFooter`](/documentation/po-modal-footer).\n *\n * > É possível fechar a modal através da tecla *ESC*, quando a propriedade `p-hide-close` não estiver habilitada.\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 * | `--border-radius` &nbsp;                     | Contém o valor do raio dos cantos do elemento&nbsp;   | `var(--border-radius-md)`                                                           |\n * | `--border-width` &nbsp;                      | Contém o valor da largura dos cantos do elemento&nbsp;| `var(--border-width-sm)`                                                            |\n * | `--border-color` &nbsp;                      | Cor da borda                                          | `var(--color-neutral-light-20)`                                                     |\n * | `--background` &nbsp;                        | Cor de background                                     | `var(--color-neutral-light-00)`                                                     |\n * | `--shadow` &nbsp;                            | Contém o valor da sombra do elemento                  | `var(--shadow-md)`                                                                  |\n * | `--color-overlay` &nbsp;                     | Cor da camada visual temporária                       | `var(--color-neutral-dark-80)`                                                      |\n * | `--opacity-overlay` &nbsp;                   | Opacidade da camada visual temporária &nbsp;          | `0.7`                                                                               |\n * | `--color-divider` &nbsp;                     | Cor das divisões do modal                             | `var(--color-neutral-light-20)`                                                     |\n * | `--padding-header` &nbsp;                    | Padding do header do modal                            | `var(--spacing-sm) var(--spacing-md)`                                               |\n * | `--padding-body` &nbsp;                      | Padding do corpo do modal                             | `var(--spacing-md) var(--spacing-2xl) var(--spacing-2xl) var(--spacing-md) `        |\n *\n */\n@Directive()\nexport class PoModalBaseComponent {\n  /** Título da modal. */\n  @Input('p-title') title: string;\n\n  /** Evento disparado ao fechar o modal. */\n  @Output('p-close') closeModal: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * Deve ser definido um objeto que implementa a interface `PoModalAction` contendo a label e a função da primeira ação.\n   * Caso esta propriedade não seja definida ou esteja incompleta, automaticamente será adicionado um botão de ação com\n   * a função de fechar a modal.\n   */\n  @Input('p-primary-action') primaryAction?: PoModalAction;\n\n  /** Deve ser definido um objeto que implementa a interface `PoModalAction` contendo a label e a função da segunda ação. */\n  @Input('p-secondary-action') secondaryAction?: PoModalAction;\n\n  language;\n  literals;\n\n  // Controla se a modal fica oculto ou visível, por padrão é oculto\n  isHidden = true;\n\n  // Event emmiter para quando a modal é fechada pelo 'X'.\n  public onXClosed = new EventEmitter<boolean>();\n\n  private _hideClose?: boolean = false;\n  private _size?: string = 'md';\n\n  /**\n   * Define o tamanho da modal.\n   *\n   * Valores válidos:\n   *  - `sm` (pequeno)\n   *  - `md` (médio)\n   *  - `lg` (grande)\n   *  - `xl` (extra grande)\n   *  - `auto` (automático)\n   *\n   * > Quando informado `auto` a modal calculará automaticamente seu tamanho baseado em seu conteúdo.\n   * Caso não seja informado um valor, a modal terá o tamanho definido como `md`.\n   *\n   * > Todas as opções de tamanho possuem uma largura máxima de **768px**.\n   */\n  @Input('p-size') set size(value: string) {\n    const sizes = ['sm', 'md', 'lg', 'xl', 'auto'];\n    this._size = sizes.indexOf(value) > -1 ? value : 'md';\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  /**\n   * Define o fechamento da modal ao clicar fora da mesma.\n   * Informe o valor `true` para ativar o fechamento ao clicar fora da modal.\n   */\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  clickOut?: boolean = false;\n  @Input('p-click-out') set setClickOut(value: boolean | string) {\n    this.clickOut = value === '' ? false : convertToBoolean(value);\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Oculta o ícone de fechar do cabeçalho da modal.\n   *\n   * > Caso a propriedade estiver habilitada, não será possível fechar a modal através da tecla *ESC*.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-close') set hideClose(value: boolean) {\n    this._hideClose = convertToBoolean(value);\n  }\n\n  get hideClose() {\n    return this._hideClose;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ícone exibido ao lado esquerdo do label do titúlo da modal.\n   *\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-modal p-icon=\"ph ph-user\" p-title=\"PO Modal\"></po-modal>\n   * ```\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-modal p-icon=\"fa fa-podcast\" p-title=\"PO Modal\"></po-modal>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-modal [p-icon]=\"template\" p-title=\"PO Modal\"></po-modal>\n   *\n   * <ng-template #template>\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\n   * </ng-template>\n   * ```\n   */\n  @Input('p-icon') icon?: string | TemplateRef<void>;\n\n  constructor(poLanguageService: PoLanguageService) {\n    this.language = poLanguageService.getShortLanguage();\n\n    this.literals = {\n      ...poModalLiterals[this.language]\n    };\n  }\n\n  /** Função para fechar a modal. */\n  close(xClosed = false): void {\n    this.closeModal.emit();\n\n    this.isHidden = true;\n    if (xClosed) {\n      this.onXClosed.emit(xClosed);\n    }\n  }\n\n  /** Função para abrir a modal. */\n  open(): void {\n    this.validPrimaryAction();\n\n    this.isHidden = false;\n  }\n\n  validPrimaryAction() {\n    if (!this.primaryAction) {\n      this.primaryAction = {\n        action: () => this.close(),\n        label: this.literals.close\n      };\n    }\n\n    if (!this.primaryAction['action']) {\n      this.primaryAction['action'] = () => this.close();\n    }\n    if (!this.primaryAction['label']) {\n      this.primaryAction['label'] = this.literals.close;\n    }\n  }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Input, ViewChild, Directive } from '@angular/core';
1
+ import { Directive, Input, ViewChild } from '@angular/core';
2
2
  import { poLocaleDefault } from './../../../services/po-language/po-language.constant';
3
3
  import { PoPageContentComponent } from '../po-page-content/po-page-content.component';
4
4
  import * as i0 from "@angular/core";
@@ -21,6 +21,19 @@ export const poPageDefaultLiteralsDefault = {
21
21
  * @description
22
22
  *
23
23
  * O componente `po-page-default` é utilizado como o container principal para as telas sem um template definido.
24
+ *
25
+ * #### Tokens customizáveis
26
+ *
27
+ * > Para maiores informações, acesse o guia [Personalizando o Tema Padrão com Tokens CSS](https://po-ui.io/guides/theme-customization).
28
+ *
29
+ * | Propriedade | Descrição | Valor Padrão |
30
+ * |----------------------------------------|-------------------------------------------------------|-------------------------------------------------|
31
+ * | **Default Values** | | |
32
+ * | `--padding` | Espaçamento do componente | `var(--spacing-xs) var(--spacing-md)` |
33
+ * | `--gap` | Gap entre o header e o conteúdo | `var(--spacing-md)` |
34
+ * | `--padding-top-header` | Espaçamento do topo do header | `var(--color-neutral-light-30)` |
35
+ * | `--gap-actions` | Gap entre os botões de action | `var(--spacing-xs)` |
36
+ * | `--padding-content` | Espaçamento do conteúdo | `var(--spacing-xs) var(--spacing-sm)` |
24
37
  */
25
38
  export class PoPageDefaultBaseComponent {
26
39
  poPageContent;
@@ -142,4 +155,4 @@ export class PoPageDefaultBaseComponent {
142
155
  type: Input,
143
156
  args: ['p-subtitle']
144
157
  }] }); })();
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-default-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-default/po-page-default-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, ViewChild, Directive } from '@angular/core';\n\nimport { PoLanguageService } from './../../../services/po-language/po-language.service';\nimport { poLocaleDefault } from './../../../services/po-language/po-language.constant';\n\nimport { PoBreadcrumb } from '../../po-breadcrumb/po-breadcrumb.interface';\nimport { PoPageAction } from '../po-page-action.interface';\nimport { PoPageDefaultLiterals } from './po-page-default-literals.interface';\nimport { PoPageContentComponent } from '../po-page-content/po-page-content.component';\n\nexport const poPageDefaultLiteralsDefault = {\n  en: <PoPageDefaultLiterals>{\n    otherActions: 'Other actions'\n  },\n  es: <PoPageDefaultLiterals>{\n    otherActions: 'Otras acciones'\n  },\n  pt: <PoPageDefaultLiterals>{\n    otherActions: 'Outras ações'\n  },\n  ru: <PoPageDefaultLiterals>{\n    otherActions: 'Другие действия'\n  }\n};\n\n/**\n * @description\n *\n * O componente `po-page-default` é utilizado como o container principal para as telas sem um template definido.\n */\n@Directive()\nexport abstract class PoPageDefaultBaseComponent {\n  @ViewChild(PoPageContentComponent, { static: true }) poPageContent: PoPageContentComponent;\n\n  /** Objeto com propriedades do breadcrumb. */\n  @Input('p-breadcrumb') breadcrumb?: PoBreadcrumb;\n\n  visibleActions: Array<PoPageAction> = [];\n\n  protected language: string;\n\n  private _actions?: Array<PoPageAction> = [];\n  private _literals: PoPageDefaultLiterals;\n  private _title: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nesta propriedade deve ser definido um array de objetos que implementam a interface `PoPageAction`.\n   */\n  @Input('p-actions') set actions(actions: Array<PoPageAction>) {\n    this._actions = Array.isArray(actions) ? actions : [];\n    this.visibleActions = this.actions.filter(action => action.visible !== false);\n    this.setDropdownActions();\n  }\n\n  get actions(): Array<PoPageAction> {\n    return this._actions;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-page-default`.\n   *\n   * Existem duas maneiras de customizar o componente, passando um objeto com todas as literais disponíveis:\n   *\n   * ```\n   *  const customLiterals: PoPageDefaultLiterals = {\n   *    otherActions: 'Mais ações'\n   *  };\n   * ```\n   *\n   * Ou passando apenas as literais que deseja customizar:\n   *\n   * ```\n   *  const customLiterals: PoPageDefaultLiterals = {\n   *    otherActions: 'Ações da página'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente.\n   *\n   * ```\n   * <po-page-default\n   *   [p-literals]=\"customLiterals\">\n   * </po-page-default>\n   * ```\n   *\n   * > O valor padrão será traduzido de acordo com o idioma configurado no [`PoI18nService`](/documentation/po-i18n) ou *browser*.\n   */\n  @Input('p-literals') set literals(value: PoPageDefaultLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poPageDefaultLiteralsDefault[poLocaleDefault],\n        ...poPageDefaultLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poPageDefaultLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || poPageDefaultLiteralsDefault[this.language];\n  }\n\n  /** Título da página. */\n  @Input('p-title') set title(title: string) {\n    this._title = title;\n    setTimeout(() => this.poPageContent.recalculateHeaderSize());\n  }\n\n  get title() {\n    return this._title;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Subtitulo do Header da página\n   */\n  @Input('p-subtitle') subtitle: string;\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  // Seta a lista de ações no dropdown.\n  abstract setDropdownActions();\n}\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-default-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-default/po-page-default-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ViewChild } from '@angular/core';\n\nimport { poLocaleDefault } from './../../../services/po-language/po-language.constant';\nimport { PoLanguageService } from './../../../services/po-language/po-language.service';\n\nimport { PoBreadcrumb } from '../../po-breadcrumb/po-breadcrumb.interface';\nimport { PoPageAction } from '../po-page-action.interface';\nimport { PoPageContentComponent } from '../po-page-content/po-page-content.component';\nimport { PoPageDefaultLiterals } from './po-page-default-literals.interface';\n\nexport const poPageDefaultLiteralsDefault = {\n  en: <PoPageDefaultLiterals>{\n    otherActions: 'Other actions'\n  },\n  es: <PoPageDefaultLiterals>{\n    otherActions: 'Otras acciones'\n  },\n  pt: <PoPageDefaultLiterals>{\n    otherActions: 'Outras ações'\n  },\n  ru: <PoPageDefaultLiterals>{\n    otherActions: 'Другие действия'\n  }\n};\n\n/**\n * @description\n *\n * O componente `po-page-default` é utilizado como o container principal para as telas sem um template definido.\n *\n * #### Tokens customizáveis\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 * | `--padding`                            | Espaçamento do componente                             | `var(--spacing-xs) var(--spacing-md)`           |\n * | `--gap`                                | Gap entre o header e o conteúdo                       | `var(--spacing-md)`                             |\n * | `--padding-top-header`                 | Espaçamento do topo do header                         | `var(--color-neutral-light-30)`                 |\n * | `--gap-actions`                        | Gap entre os botões de action                         | `var(--spacing-xs)`                             |\n * | `--padding-content`                    | Espaçamento do conteúdo                               | `var(--spacing-xs) var(--spacing-sm)`           |\n */\n@Directive()\nexport abstract class PoPageDefaultBaseComponent {\n  @ViewChild(PoPageContentComponent, { static: true }) poPageContent: PoPageContentComponent;\n\n  /** Objeto com propriedades do breadcrumb. */\n  @Input('p-breadcrumb') breadcrumb?: PoBreadcrumb;\n\n  visibleActions: Array<PoPageAction> = [];\n\n  protected language: string;\n\n  private _actions?: Array<PoPageAction> = [];\n  private _literals: PoPageDefaultLiterals;\n  private _title: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nesta propriedade deve ser definido um array de objetos que implementam a interface `PoPageAction`.\n   */\n  @Input('p-actions') set actions(actions: Array<PoPageAction>) {\n    this._actions = Array.isArray(actions) ? actions : [];\n    this.visibleActions = this.actions.filter(action => action.visible !== false);\n    this.setDropdownActions();\n  }\n\n  get actions(): Array<PoPageAction> {\n    return this._actions;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-page-default`.\n   *\n   * Existem duas maneiras de customizar o componente, passando um objeto com todas as literais disponíveis:\n   *\n   * ```\n   *  const customLiterals: PoPageDefaultLiterals = {\n   *    otherActions: 'Mais ações'\n   *  };\n   * ```\n   *\n   * Ou passando apenas as literais que deseja customizar:\n   *\n   * ```\n   *  const customLiterals: PoPageDefaultLiterals = {\n   *    otherActions: 'Ações da página'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente.\n   *\n   * ```\n   * <po-page-default\n   *   [p-literals]=\"customLiterals\">\n   * </po-page-default>\n   * ```\n   *\n   * > O valor padrão será traduzido de acordo com o idioma configurado no [`PoI18nService`](/documentation/po-i18n) ou *browser*.\n   */\n  @Input('p-literals') set literals(value: PoPageDefaultLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poPageDefaultLiteralsDefault[poLocaleDefault],\n        ...poPageDefaultLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poPageDefaultLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || poPageDefaultLiteralsDefault[this.language];\n  }\n\n  /** Título da página. */\n  @Input('p-title') set title(title: string) {\n    this._title = title;\n    setTimeout(() => this.poPageContent.recalculateHeaderSize());\n  }\n\n  get title() {\n    return this._title;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Subtitulo do Header da página\n   */\n  @Input('p-subtitle') subtitle: string;\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  // Seta a lista de ações no dropdown.\n  abstract setDropdownActions();\n}\n"]}
@@ -15,6 +15,8 @@ import * as i0 from "@angular/core";
15
15
  * > Para o correto funcionamento do componente `po-page-slide`, deve ser
16
16
  * > importado o módulo `BrowserAnimationsModule` no módulo principal da sua
17
17
  * > aplicação.
18
+ *
19
+ * Caso utilize componentes de field dentro do page-slide, recomenda-se o uso do [Grid System](https://po-ui.io/guides/grid-system).
18
20
  */
19
21
  export class PoPageSlideBaseComponent {
20
22
  /**
@@ -171,4 +173,4 @@ export class PoPageSlideBaseComponent {
171
173
  type: Input,
172
174
  args: ['p-size']
173
175
  }] }); })();
174
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tcGFnZS1zbGlkZS1iYXNlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1wYWdlL3BvLXBhZ2Utc2xpZGUvcG8tcGFnZS1zbGlkZS1iYXNlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUV2RDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUVILE1BQU0sT0FBTyx3QkFBd0I7SUFDbkM7Ozs7T0FJRztJQUNlLEtBQUssQ0FBUztJQUVoQzs7OztPQUlHO0lBQ2tCLFFBQVEsQ0FBVTtJQUV2Qzs7Ozs7Ozs7OztPQVVHO0lBQzRELFNBQVMsR0FBWSxLQUFLLENBQUM7SUFFMUY7Ozs7Ozs7O09BUUc7SUFDMkQsUUFBUSxHQUFZLEtBQUssQ0FBQztJQUV4Rjs7Ozs7Ozs7O09BU0c7SUFDZ0UsYUFBYSxHQUFZLEtBQUssQ0FBQztJQUVsRzs7Ozs7T0FLRztJQUNnQixjQUFjLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7SUFFL0UsZ0VBQWdFO0lBQ3pELE1BQU0sR0FBRyxJQUFJLENBQUM7SUFFYixLQUFLLEdBQUcsSUFBSSxDQUFDO0lBRXJCOzs7Ozs7Ozs7Ozs7Ozs7OztPQWlCRztJQUNILElBQXFCLElBQUksQ0FBQyxLQUFhO1FBQ3JDLE1BQU0sS0FBSyxHQUFHLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDeEQsQ0FBQztJQUVELElBQUksSUFBSTtRQUNOLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNwQixDQUFDO0lBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7O09BaUJHO0lBQ0ksSUFBSTtRQUNULHFFQUFxRTtRQUNyRSxJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDckMsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDekIsQ0FBQztRQUVELElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7T0FpQkc7SUFDSSxLQUFLO1FBQ1YsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUM7UUFDbkIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM3QixDQUFDO2tGQTNJVSx3QkFBd0I7NkRBQXhCLHdCQUF3QixpSUEwQlEsZ0JBQWdCLDRDQVdqQixnQkFBZ0IsMkRBWVgsZ0JBQWdCOztpRkFqRHBELHdCQUF3QjtjQURwQyxTQUFTO2dCQU9VLEtBQUs7a0JBQXRCLEtBQUs7bUJBQUMsU0FBUztZQU9LLFFBQVE7a0JBQTVCLEtBQUs7bUJBQUMsWUFBWTtZQWE0QyxTQUFTO2tCQUF2RSxLQUFLO21CQUFDLEVBQUUsS0FBSyxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7WUFXQyxRQUFRO2tCQUFyRSxLQUFLO21CQUFDLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7WUFZTyxhQUFhO2tCQUEvRSxLQUFLO21CQUFDLEVBQUUsS0FBSyxFQUFFLGtCQUFrQixFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtZQVE5QyxjQUFjO2tCQUFoQyxNQUFNO21CQUFDLFNBQVM7WUF5QkksSUFBSTtrQkFBeEIsS0FBSzttQkFBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgY29udmVydFRvQm9vbGVhbiB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL3V0aWwnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIE8gY29tcG9uZW50ZSBgcG8tcGFnZS1zbGlkZWAgw6kgdXRpbGl6YWRvIHBhcmEgaW5jbHVpciBjb250ZcO6ZG9zIHNlY3VuZMOhcmlvc1xuICogYWRpY2lvbmFuZG8gY29udHJvbGVzIGUgbmF2ZWdhw6fDtWVzIGFkaWNpb25haXMsIG1hcyBtYW50ZW5kbyBvIHVzdcOhcmlvIG5hXG4gKiBww6FnaW5hIHByaW5jaXBhbC5cbiAqXG4gKiBFc3RlIGNvbXBvbmVudGUgw6kgYXRpdmFkbyBhIHBhcnRpciBkbyBtw6l0b2RvIGAjb3BlbigpYCBlIHBvZGUgc2VyICBlbmNlcnJhZG9cbiAqIGF0cmF2w6lzIGRvIGJvdMOjbyBxdWUgZW5jb250cmEtc2Ugbm8gY2FiZcOnYWxobyBkbyBtZXNtbyBvdSBhdHJhdsOpcyBkbyBtw6l0b2RvXG4gKiBgI2Nsb3NlKClgLlxuICpcbiAqID4gUGFyYSBvIGNvcnJldG8gZnVuY2lvbmFtZW50byBkbyBjb21wb25lbnRlIGBwby1wYWdlLXNsaWRlYCwgZGV2ZSBzZXJcbiAqID4gaW1wb3J0YWRvIG8gbcOzZHVsbyBgQnJvd3NlckFuaW1hdGlvbnNNb2R1bGVgIG5vIG3Ds2R1bG8gcHJpbmNpcGFsIGRhIHN1YVxuICogPiBhcGxpY2HDp8Ojby5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgUG9QYWdlU2xpZGVCYXNlQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKlxuICAgKiBUw610dWxvIGRhIHDDoWdpbmEuXG4gICAqL1xuICBASW5wdXQoJ3AtdGl0bGUnKSB0aXRsZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICpcbiAgICogU3VidMOtdHVsbyBkYSBww6FnaW5hLlxuICAgKi9cbiAgQElucHV0KCdwLXN1YnRpdGxlJykgc3VidGl0bGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEBvcHRpb25hbFxuICAgKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICpcbiAgICogT2N1bHRhIG8gYm90w6NvIGRlIGVuY2VycmFtZW50byBkYSBww6FnaW5hLlxuICAgKlxuICAgKiBFc3RhIG9ww6fDo28gc8OzIMOpIHBvc3PDrXZlbCBzZSBhIHByb3ByaWVkYWRlIGBwLWNsaWNrLW91dGAgZXN0aXZlciBoYWJpbGl0YWRhLlxuICAgKlxuICAgKiBAZGVmYXVsdCBgZmFsc2VgXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ3AtaGlkZS1jbG9zZScsIHRyYW5zZm9ybTogY29udmVydFRvQm9vbGVhbiB9KSBoaWRlQ2xvc2U6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAvKipcbiAgICogQG9wdGlvbmFsXG4gICAqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKlxuICAgKiBEZWZpbmUgc2UgcGVybWl0ZSBvIGVuY2VycmFtZW50byBkYSBww6FnaW5hIGFvIGNsaWNhciBmb3JhIGRhIG1lc21hLlxuICAgKlxuICAgKiBAZGVmYXVsdCBgZmFsc2VgXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ3AtY2xpY2stb3V0JywgdHJhbnNmb3JtOiBjb252ZXJ0VG9Cb29sZWFuIH0pIGNsaWNrT3V0OiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEBvcHRpb25hbFxuICAgKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICpcbiAgICogUGVybWl0ZSBhIGV4cGFuc8OjbyBkaW7Dom1pY2EgZGEgbGFyZ3VyYSBkbyBgcG8tcGFnZS1zbGlkZWAgcXVhbmRvIGBwLXNpemVgIGZvciBgYXV0b2AgKGF1dG9tw6F0aWNvKS5cbiAgICogUHJvcHJpZWRhZGUgbmVjZXNzw6FyaWEgcGFyYSBjb3JyZXRvIGZ1bmNpb25hbWVudG8gZGEgYHBvLXRhYmxlYCBkZW50cm8gZG8gYHBvLXBhZ2Utc2xpZGVgXG4gICAqXG4gICAqIEBkZWZhdWx0IGBmYWxzZWBcbiAgICovXG4gIEBJbnB1dCh7IGFsaWFzOiAncC1mbGV4aWJsZS13aWR0aCcsIHRyYW5zZm9ybTogY29udmVydFRvQm9vbGVhbiB9KSBmbGV4aWJsZVdpZHRoOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEBvcHRpb25hbFxuICAgKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICogRXZlbnRvIGV4ZWN1dGFkbyBhbyBmZWNoYXIgbyBwYWdlIHNsaWRlLlxuICAgKi9cbiAgQE91dHB1dCgncC1jbG9zZScpIGNsb3NlUGFnZVNsaWRlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIC8vIENvbnRyb2xhIHNlIGEgcMOhZ2luYSBlc3TDoSBvdSBuw6NvIG9jdWx0YSwgcG9yIHBhZHLDo28gw6kgb2N1bHRvLlxuICBwdWJsaWMgaGlkZGVuID0gdHJ1ZTtcblxuICBwcml2YXRlIF9zaXplID0gJ21kJztcblxuICAvKipcbiAgICogQG9wdGlvbmFsXG4gICAqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKlxuICAgKiBEZWZpbmUgbyB0YW1hbmhvIGRhIHDDoWdpbmEuXG4gICAqXG4gICAqIFZhbG9yZXMgdsOhbGlkb3M6XG4gICAqICAtIGBzbWAgKHBlcXVlbm8pXG4gICAqICAtIGBtZGAgKG3DqWRpbylcbiAgICogIC0gYGxnYCAoZ3JhbmRlKVxuICAgKiAgLSBgeGxgIChleHRyYS1ncmFuZGUpXG4gICAqICAtIGBhdXRvYCAoYXV0b23DoXRpY28pXG4gICAqXG4gICAqID4gVG9kYXMgYXMgb3DDp8O1ZXMgZGUgdGFtYW5obywgZXhjZXRvIGBhdXRvYCwgcG9zc3VlbSB1bWEgbGFyZ3VyYSBtw6F4aW1hIGRlICoqNzY4cHgqKi5cbiAgICpcbiAgICogQGRlZmF1bHQgYG1kYFxuICAgKi9cbiAgQElucHV0KCdwLXNpemUnKSBzZXQgc2l6ZSh2YWx1ZTogc3RyaW5nKSB7XG4gICAgY29uc3Qgc2l6ZXMgPSBbJ3NtJywgJ21kJywgJ2xnJywgJ3hsJywgJ2F1dG8nXTtcbiAgICB0aGlzLl9zaXplID0gc2l6ZXMuaW5kZXhPZih2YWx1ZSkgPiAtMSA/IHZhbHVlIDogJ21kJztcbiAgfVxuXG4gIGdldCBzaXplKCkge1xuICAgIHJldHVybiB0aGlzLl9zaXplO1xuICB9XG5cbiAgLyoqXG4gICAqIEF0aXZhIGEgdmlzdWFsaXphw6fDo28gZGEgcMOhZ2luYS5cbiAgICpcbiAgICogUGFyYSB1dGlsaXrDoS1sYSDDqSBuZWNlc3PDoXJpbyB0ZXIgYSBpbnN0w6JuY2lhIGRvIGNvbXBvbmVudGUgbm8gRE9NLCBwb2RlbmRvXG4gICAqIHNlciB1dGlsaXphZG8gbyBgVmlld0NoaWxkYCBkYSBzZWd1aW50ZSBmb3JtYTpcbiAgICpcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiBpbXBvcnQgeyBQb1BhZ2VTbGlkZUNvbXBvbmVudCB9IGZyb20gJ0Bwby9uZy1jb21wb25lbnRzJztcbiAgICpcbiAgICogLi4uXG4gICAqXG4gICAqIEBWaWV3Q2hpbGQoUG9QYWdlU2xpZGVDb21wb25lbnQsIHsgc3RhdGljOiB0cnVlIH0pIHBhZ2VTbGlkZTogUG9QYWdlU2xpZGVDb21wb25lbnQ7XG4gICAqXG4gICAqIHB1YmxpYyBvcGVuUGFnZSgpIHtcbiAgICogICB0aGlzLnBhZ2VTbGlkZS5vcGVuKCk7XG4gICAqIH1cbiAgICogYGBgXG4gICAqL1xuICBwdWJsaWMgb3BlbigpIHtcbiAgICAvLyBFdml0YSBjb20gcXVlIGEgcMOhZ2luYSBzZWphIGFiZXJ0YSBzZW0gcXVlIHNlamEgcG9zc8OtdmVsIGZlY2jDoS1sYS5cbiAgICBpZiAodGhpcy5oaWRlQ2xvc2UgJiYgIXRoaXMuY2xpY2tPdXQpIHtcbiAgICAgIHRoaXMuaGlkZUNsb3NlID0gZmFsc2U7XG4gICAgfVxuXG4gICAgdGhpcy5oaWRkZW4gPSBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFbmNlcnJhIGEgdmlzdWFsaXphw6fDo28gZGEgcMOhZ2luYS5cbiAgICpcbiAgICogUGFyYSB1dGlsaXrDoS1sYSDDqSBuZWNlc3PDoXJpbyB0ZXIgYSBpbnN0w6JuY2lhIGRvIGNvbXBvbmVudGUgbm8gRE9NLCBwb2RlbmRvXG4gICAqIHNlciB1dGlsaXphZG8gbyBgVmlld0NoaWxkYCBkYSBzZWd1aW50ZSBmb3JtYTpcbiAgICpcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiBpbXBvcnQgeyBQb1BhZ2VTbGlkZUNvbXBvbmVudCB9IGZyb20gJ0Bwby11aS9uZy1jb21wb25lbnRzJztcbiAgICpcbiAgICogLi4uXG4gICAqXG4gICAqIEBWaWV3Q2hpbGQoUG9QYWdlU2xpZGVDb21wb25lbnQsIHsgc3RhdGljOiB0cnVlIH0pIHBhZ2VTbGlkZTogUG9QYWdlU2xpZGVDb21wb25lbnQ7XG4gICAqXG4gICAqIHB1YmxpYyBjbG9zZVBhZ2UoKSB7XG4gICAqICAgdGhpcy5wYWdlU2xpZGUuY2xvc2UoKTtcbiAgICogfVxuICAgKiBgYGBcbiAgICovXG4gIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICB0aGlzLmhpZGRlbiA9IHRydWU7XG4gICAgdGhpcy5jbG9zZVBhZ2VTbGlkZS5lbWl0KCk7XG4gIH1cbn1cbiJdfQ==
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-slide-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAEvD;;;;;;;;;;;;;;;;GAgBG;AAEH,MAAM,OAAO,wBAAwB;IACnC;;;;OAIG;IACe,KAAK,CAAS;IAEhC;;;;OAIG;IACkB,QAAQ,CAAU;IAEvC;;;;;;;;;;OAUG;IAC4D,SAAS,GAAY,KAAK,CAAC;IAE1F;;;;;;;;OAQG;IAC2D,QAAQ,GAAY,KAAK,CAAC;IAExF;;;;;;;;;OASG;IACgE,aAAa,GAAY,KAAK,CAAC;IAElG;;;;;OAKG;IACgB,cAAc,GAAsB,IAAI,YAAY,EAAO,CAAC;IAE/E,gEAAgE;IACzD,MAAM,GAAG,IAAI,CAAC;IAEb,KAAK,GAAG,IAAI,CAAC;IAErB;;;;;;;;;;;;;;;;;OAiBG;IACH,IAAqB,IAAI,CAAC,KAAa;QACrC,MAAM,KAAK,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IACxD,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACI,IAAI;QACT,qEAAqE;QACrE,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACI,KAAK;QACV,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;kFA3IU,wBAAwB;6DAAxB,wBAAwB,iIA0BQ,gBAAgB,4CAWjB,gBAAgB,2DAYX,gBAAgB;;iFAjDpD,wBAAwB;cADpC,SAAS;gBAOU,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAOK,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YAa4C,SAAS;kBAAvE,KAAK;mBAAC,EAAE,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,gBAAgB,EAAE;YAWC,QAAQ;kBAArE,KAAK;mBAAC,EAAE,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,gBAAgB,EAAE;YAYO,aAAa;kBAA/E,KAAK;mBAAC,EAAE,KAAK,EAAE,kBAAkB,EAAE,SAAS,EAAE,gBAAgB,EAAE;YAQ9C,cAAc;kBAAhC,MAAM;mBAAC,SAAS;YAyBI,IAAI;kBAAxB,KAAK;mBAAC,QAAQ","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\n\nimport { convertToBoolean } from '../../../utils/util';\n\n/**\n * @description\n *\n * O componente `po-page-slide` é utilizado para incluir conteúdos secundários\n * adicionando controles e navegações adicionais, mas mantendo o usuário na\n * página principal.\n *\n * Este componente é ativado a partir do método `#open()` e pode ser  encerrado\n * através do botão que encontra-se no cabeçalho do mesmo ou através do método\n * `#close()`.\n *\n * > Para o correto funcionamento do componente `po-page-slide`, deve ser\n * > importado o módulo `BrowserAnimationsModule` no módulo principal da sua\n * > aplicação.\n *\n *  Caso utilize componentes de field dentro do page-slide, recomenda-se o uso do [Grid System](https://po-ui.io/guides/grid-system).\n */\n@Directive()\nexport class PoPageSlideBaseComponent {\n  /**\n   * @description\n   *\n   * Título da página.\n   */\n  @Input('p-title') title: string;\n\n  /**\n   * @description\n   *\n   * Subtítulo da página.\n   */\n  @Input('p-subtitle') subtitle?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Oculta o botão de encerramento da página.\n   *\n   * Esta opção só é possível se a propriedade `p-click-out` estiver habilitada.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-hide-close', transform: convertToBoolean }) hideClose: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se permite o encerramento da página ao clicar fora da mesma.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-click-out', transform: convertToBoolean }) clickOut: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Permite a expansão dinâmica da largura do `po-page-slide` quando `p-size` for `auto` (automático).\n   * Propriedade necessária para correto funcionamento da `po-table` dentro do `po-page-slide`\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-flexible-width', transform: convertToBoolean }) flexibleWidth: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Evento executado ao fechar o page slide.\n   */\n  @Output('p-close') closePageSlide: EventEmitter<any> = new EventEmitter<any>();\n\n  // Controla se a página está ou não oculta, por padrão é oculto.\n  public hidden = true;\n\n  private _size = 'md';\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tamanho da página.\n   *\n   * Valores válidos:\n   *  - `sm` (pequeno)\n   *  - `md` (médio)\n   *  - `lg` (grande)\n   *  - `xl` (extra-grande)\n   *  - `auto` (automático)\n   *\n   * > Todas as opções de tamanho, exceto `auto`, possuem uma largura máxima de **768px**.\n   *\n   * @default `md`\n   */\n  @Input('p-size') set size(value: string) {\n    const sizes = ['sm', 'md', 'lg', 'xl', 'auto'];\n    this._size = sizes.indexOf(value) > -1 ? value : 'md';\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  /**\n   * Ativa a visualização da página.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo\n   * ser utilizado o `ViewChild` da seguinte forma:\n   *\n   * ```typescript\n   * import { PoPageSlideComponent } from '@po/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoPageSlideComponent, { static: true }) pageSlide: PoPageSlideComponent;\n   *\n   * public openPage() {\n   *   this.pageSlide.open();\n   * }\n   * ```\n   */\n  public open() {\n    // Evita com que a página seja aberta sem que seja possível fechá-la.\n    if (this.hideClose && !this.clickOut) {\n      this.hideClose = false;\n    }\n\n    this.hidden = false;\n  }\n\n  /**\n   * Encerra a visualização da página.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo\n   * ser utilizado o `ViewChild` da seguinte forma:\n   *\n   * ```typescript\n   * import { PoPageSlideComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoPageSlideComponent, { static: true }) pageSlide: PoPageSlideComponent;\n   *\n   * public closePage() {\n   *   this.pageSlide.close();\n   * }\n   * ```\n   */\n  public close(): void {\n    this.hidden = true;\n    this.closePageSlide.emit();\n  }\n}\n"]}