@po-ui/ng-components 16.4.1 → 16.6.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 (49) hide show
  1. package/esm2022/lib/components/po-field/po-combo/interfaces/po-combo-literals-default.interface.mjs +9 -5
  2. package/esm2022/lib/components/po-field/po-combo/interfaces/po-combo-literals.interface.mjs +1 -1
  3. package/esm2022/lib/components/po-field/po-combo/po-combo-base.component.mjs +4 -1
  4. package/esm2022/lib/components/po-field/po-combo/po-combo.component.mjs +90 -41
  5. package/esm2022/lib/components/po-field/po-field.module.mjs +17 -13
  6. package/esm2022/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
  7. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +30 -7
  8. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +4 -4
  9. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.mjs +1 -1
  10. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +220 -51
  11. package/esm2022/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +3 -3
  12. package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +2 -2
  13. package/esm2022/lib/components/po-listbox/po-listbox.component.mjs +5 -4
  14. package/esm2022/lib/components/po-table/po-table-base.component.mjs +5 -5
  15. package/esm2022/lib/components/po-tag/index.mjs +2 -1
  16. package/esm2022/lib/components/po-tag/interfaces/po-tag-literals.interface.mjs +2 -0
  17. package/esm2022/lib/components/po-tag/po-tag-base.component.mjs +70 -4
  18. package/esm2022/lib/components/po-tag/po-tag.component.mjs +52 -44
  19. package/esm2022/lib/enums/po-key-code.enum.mjs +5 -1
  20. package/fesm2022/po-ui-ng-components.mjs +801 -574
  21. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  22. package/lib/components/po-field/po-combo/interfaces/po-combo-literals.interface.d.ts +2 -0
  23. package/lib/components/po-field/po-combo/po-combo.component.d.ts +8 -5
  24. package/lib/components/po-field/po-field.module.d.ts +44 -44
  25. package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +21 -2
  26. package/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.d.ts +2 -0
  27. package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +18 -6
  28. package/lib/components/po-table/po-table-base.component.d.ts +2 -2
  29. package/lib/components/po-tag/index.d.ts +1 -0
  30. package/lib/components/po-tag/interfaces/po-tag-literals.interface.d.ts +11 -0
  31. package/lib/components/po-tag/po-tag-base.component.d.ts +50 -2
  32. package/lib/components/po-tag/po-tag.component.d.ts +6 -6
  33. package/lib/enums/po-key-code.enum.d.ts +5 -1
  34. package/package.json +4 -4
  35. package/po-ui-ng-components-16.6.0.tgz +0 -0
  36. package/schematics/ng-add/index.js +1 -1
  37. package/schematics/ng-update/v14/index.js +1 -1
  38. package/schematics/ng-update/v15/index.js +1 -1
  39. package/schematics/ng-update/v16/index.js +1 -1
  40. package/schematics/ng-update/v2/index.js +1 -1
  41. package/schematics/ng-update/v3/index.js +1 -1
  42. package/schematics/ng-update/v4/index.js +1 -1
  43. package/schematics/ng-update/v5/index.js +1 -1
  44. package/schematics/ng-update/v6/index.js +1 -1
  45. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +0 -91
  46. package/esm2022/lib/components/po-tag/po-tag.literals.mjs +0 -15
  47. package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +0 -40
  48. package/lib/components/po-tag/po-tag.literals.d.ts +0 -14
  49. package/po-ui-ng-components-16.4.1.tgz +0 -0
@@ -1,11 +1,27 @@
1
1
  import { Directive, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';
3
3
  import { convertToBoolean } from '../../utils/util';
4
+ import { poLocaleDefault } from '../../services/po-language/po-language.constant';
4
5
  import { PoTagOrientation } from './enums/po-tag-orientation.enum';
5
6
  import { PoTagType } from './enums/po-tag-type.enum';
6
7
  import * as i0 from "@angular/core";
8
+ import * as i1 from "./../../services/po-language/po-language.service";
7
9
  const poTagColors = Object.values(PoColorPaletteEnum);
8
10
  const poTagOrientationDefault = PoTagOrientation.Vertical;
11
+ export const PoTagLiteralsDefault = {
12
+ en: {
13
+ remove: 'Clear'
14
+ },
15
+ es: {
16
+ remove: 'Eliminar'
17
+ },
18
+ pt: {
19
+ remove: 'Remover'
20
+ },
21
+ ru: {
22
+ remove: 'удалять'
23
+ }
24
+ };
9
25
  /**
10
26
  * @description
11
27
  *
@@ -81,6 +97,8 @@ export class PoTagBaseComponent {
81
97
  _inverse;
82
98
  _orientation = poTagOrientationDefault;
83
99
  _type;
100
+ _literals;
101
+ language;
84
102
  /**
85
103
  * @optional
86
104
  *
@@ -262,12 +280,57 @@ export class PoTagBaseComponent {
262
280
  get type() {
263
281
  return this._type;
264
282
  }
265
- static ɵfac = function PoTagBaseComponent_Factory(t) { return new (t || PoTagBaseComponent)(); };
266
- static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTagBaseComponent, inputs: { label: ["p-label", "label"], removable: ["p-removable", "removable", convertToBoolean], disabled: ["p-disabled", "disabled", convertToBoolean], value: ["p-value", "value"], color: ["p-color", "color"], textColor: ["p-text-color", "textColor"], icon: ["p-icon", "icon"], inverse: ["p-inverse", "inverse"], orientation: ["p-orientation", "orientation"], type: ["p-type", "type"] }, outputs: { click: "p-click", remove: "p-close" }, features: [i0.ɵɵInputTransformsFeature] });
283
+ /**
284
+ * @optional
285
+ *
286
+ * @description
287
+ *
288
+ * Objeto com as literais usadas no `po-tag`.
289
+ *
290
+ *
291
+ * Para utilizar, basta passar a literal customizada:
292
+ *
293
+ * ```
294
+ * const customLiterals: PoTagLiterals = {
295
+ * remove: 'Remover itens'
296
+ * };
297
+ * ```
298
+ *
299
+ * E para carregar as literais customizadas, basta apenas passar o objeto para o componente:
300
+ *
301
+ * ```
302
+ * <po-tag
303
+ * [p-literals]="customLiterals">
304
+ * </po-tag>
305
+ * ```
306
+ *
307
+ * > O objeto padrão de literais será traduzido de acordo com o idioma do
308
+ * [`PoI18nService`](/documentation/po-i18n) ou do browser.
309
+ */
310
+ set literals(value) {
311
+ if (value instanceof Object && !(value instanceof Array)) {
312
+ this._literals = {
313
+ ...PoTagLiteralsDefault[poLocaleDefault],
314
+ ...PoTagLiteralsDefault[this.language],
315
+ ...value
316
+ };
317
+ }
318
+ else {
319
+ this._literals = PoTagLiteralsDefault[this.language];
320
+ }
321
+ }
322
+ get literals() {
323
+ return this._literals || PoTagLiteralsDefault[this.language];
324
+ }
325
+ constructor(languageService) {
326
+ this.language = languageService.getShortLanguage();
327
+ }
328
+ static ɵfac = function PoTagBaseComponent_Factory(t) { return new (t || PoTagBaseComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
329
+ static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTagBaseComponent, inputs: { label: ["p-label", "label"], removable: ["p-removable", "removable", convertToBoolean], disabled: ["p-disabled", "disabled", convertToBoolean], value: ["p-value", "value"], color: ["p-color", "color"], textColor: ["p-text-color", "textColor"], icon: ["p-icon", "icon"], inverse: ["p-inverse", "inverse"], orientation: ["p-orientation", "orientation"], type: ["p-type", "type"], literals: ["p-literals", "literals"] }, outputs: { click: "p-click", remove: "p-close" }, features: [i0.ɵɵInputTransformsFeature] });
267
330
  }
268
331
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTagBaseComponent, [{
269
332
  type: Directive
270
- }], null, { label: [{
333
+ }], function () { return [{ type: i1.PoLanguageService }]; }, { label: [{
271
334
  type: Input,
272
335
  args: ['p-label']
273
336
  }], removable: [{
@@ -303,5 +366,8 @@ export class PoTagBaseComponent {
303
366
  }], type: [{
304
367
  type: Input,
305
368
  args: ['p-type']
369
+ }], literals: [{
370
+ type: Input,
371
+ args: ['p-literals']
306
372
  }] }); })();
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-tag-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-tag/po-tag-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\n\nimport { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';\nimport { convertToBoolean } from '../../utils/util';\n\nimport { PoTagOrientation } from './enums/po-tag-orientation.enum';\nimport { PoTagType } from './enums/po-tag-type.enum';\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\n\nconst poTagColors = (<any>Object).values(PoColorPaletteEnum);\nconst poTagOrientationDefault = PoTagOrientation.Vertical;\n\n/**\n * @description\n *\n * Este componente permite exibir um valor em forma de um marcador colorido, sendo possível definir uma legenda e realizar customizações\n * na cor, iconografia e tipo.\n *\n * Além disso, é possível definir uma ação que será executada tanto ao *click* quanto através das teclas *enter/space* enquanto navega\n * utilizando a tecla *tab*.\n *\n * Seu uso é recomendado para informações que necessitem de destaque em forma de marcação.\n */\n@Directive()\nexport class PoTagBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define uma legenda que será exibida acima ou ao lado da *tag*, de acordo com a `p-orientation`.\n   */\n  @Input('p-label') label?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Habilita a opção de remover a tag\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-removable', transform: convertToBoolean }) removable: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Desabilita o `po-tag` e não permite que o usuário interaja com o mesmo.\n   * > A propriedade `p-disabled` somente terá efeito caso a propriedade `p-removable` esteja definida como `true`.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-disabled', transform: convertToBoolean }) disabled: boolean = false;\n\n  /** Texto da tag. */\n  @Input('p-value') value: string;\n\n  /**\n   * @deprecated 16.x.x\n   *\n   * @optional\n   *\n   * @description\n   *\n   * **Deprecated 16.x.x**.\n   *\n   * > Por regras de acessibilidade a tag não terá mais evento de click. Indicamos o uso do `Po-button` ou `Po-link`\n   * caso deseje esse comportamento.\n   *\n   * Ação que será executada ao clicar sobre o `po-tag` e que receberá como parâmetro um objeto contendo o seu valor e tipo.\n   */\n  @Output('p-click') click: EventEmitter<any> = new EventEmitter<PoTagItem>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação que sera executada quando clicar sobre o ícone de remover no `po-tag`\n   */\n  @Output('p-close') remove: EventEmitter<null> = new EventEmitter<null>();\n\n  public readonly poTagOrientation = PoTagOrientation;\n  public customColor;\n  public customTextColor;\n  private _color?: string;\n  private _textColor?: string;\n  private _icon?: boolean | string | TemplateRef<void>;\n  private _inverse?: boolean;\n  private _orientation?: PoTagOrientation = poTagOrientationDefault;\n  private _type?: PoTagType;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Determina a cor da tag. As maneiras de customizar as cores são:\n   * - Hexadeximal, por exemplo `#c64840`;\n   * - RGB, como `rgb(0, 0, 165)`;\n   * - O nome da cor, por exemplo `blue`;\n   * - Usando uma das cores do tema do PO:\n   * Valores válidos:\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\n   *\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\n   *\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\n   */\n  @Input('p-color') set color(value: string) {\n    this._color = poTagColors.includes(value) ? value : undefined;\n    if (this._color === undefined) {\n      CSS.supports('color', value) ? (this.customColor = value) : (this.customColor = undefined);\n    }\n  }\n\n  get color(): string {\n    return this._color;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Determina a cor do texto da tag. As maneiras de customizar as cores são:\n   * - Hexadeximal, por exemplo `#c64840`;\n   * - RGB, como `rgb(0, 0, 165)`;\n   * - O nome da cor, por exemplo `blue`;\n   * - Usando uma das cores do tema do PO:\n   * Valores válidos:\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\n   *\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\n   *\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\n   */\n  @Input('p-text-color') set textColor(value: string) {\n    this._textColor = poTagColors.includes(value) ? value : undefined;\n    if (this._textColor === undefined) {\n      CSS.supports('color', value) ? (this.customTextColor = value) : (this.customTextColor = undefined);\n    }\n  }\n\n  get textColor(): string {\n    return this._textColor;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define ou ativa um ícone que será exibido ao lado do valor da *tag*.\n   *\n   * Quando `p-type` estiver definida, basta informar um valor igual a `true` para que o ícone seja exibido conforme descrições abaixo:\n   * - <span class=\"po-icon po-icon-ok\"></span> - `success`\n   * - <span class=\"po-icon po-icon-warning\"></span> - `warning`\n   * - <span class=\"po-icon po-icon-close\"></span> - `danger`\n   * - <span class=\"po-icon po-icon-info\"></span> - `info`\n   *\n   * Também É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-tag p-icon=\"po-icon-user\" p-value=\"PO Tag\"></po-tag>\n   * ```\n   * como também utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-tag p-icon=\"fa fa-podcast\" p-value=\"PO Tag\"></po-button>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-tag [p-icon]=\"template\" p-value=\"Tag template ionic\"></po-button>\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   * @default `false`\n   */\n  @Input('p-icon') set icon(value: boolean | string | TemplateRef<void>) {\n    if (this.type) {\n      this._icon = convertToBoolean(value);\n    } else {\n      this._icon = value;\n    }\n  }\n\n  get icon() {\n    return this._icon;\n  }\n\n  /**\n   * @deprecated 16.x.x\n   *\n   * @optional\n   *\n   * @description\n   *\n   * > Por regras de acessibilidade e usabilidade a tag não terá a inversão de cores no componente.\n   *\n   * Ativa a inversão de cores configuradas no componente, possibilitando uma visualização de status ativo e inativo.\n   *\n   * > A cor do texto, do ícone e da borda ficam com a cor utilizada na propriedade `p-color` ou a cor correspondente ao `p-type`,\n   * e a cor do fundo fica branca.\n   *\n   * @default `false`\n   */\n  @Input('p-inverse') set inverse(value: boolean) {\n    this._inverse = convertToBoolean(value);\n  }\n\n  get inverse(): boolean {\n    return this._inverse;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o *layout* de exibição.\n   *\n   * @default `vertical`\n   */\n  @Input('p-orientation') set orientation(value: PoTagOrientation) {\n    this._orientation = (<any>Object).values(PoTagOrientation).includes(value) ? value : poTagOrientationDefault;\n  }\n\n  get orientation(): PoTagOrientation {\n    return this._orientation;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tipo da *tag*.\n   *\n   * Valores válidos:\n   *  - `success`: cor verde utilizada para simbolizar sucesso ou êxito.\n   *  - `warning`: cor amarela que representa aviso ou advertência.\n   *  - `danger`: cor vermelha para erro ou aviso crítico.\n   *  - `info`: cor azul claro que caracteriza conteúdo informativo.\n   *  - `neutral`: cor cinza claro para uso geral.\n   *\n   * > Quando esta propriedade for definida, irá sobrepor a definição de `p-color` e `p-icon` somente será exibido caso seja `true`.\n   *\n   * @default `info`\n   */\n  @Input('p-type') set type(value: PoTagType) {\n    if (!this.removable) {\n      this._type = (<any>Object).values(PoTagType).includes(value) ? value : undefined;\n    }\n  }\n\n  get type(): PoTagType {\n    return this._type;\n  }\n}\n"]}
373
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-tag-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-tag/po-tag-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\n\nimport { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';\nimport { convertToBoolean } from '../../utils/util';\n\nimport { PoLanguageService } from './../../services/po-language/po-language.service';\nimport { poLocaleDefault } from '../../services/po-language/po-language.constant';\nimport { PoTagOrientation } from './enums/po-tag-orientation.enum';\nimport { PoTagType } from './enums/po-tag-type.enum';\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\nimport { PoTagLiterals } from './interfaces/po-tag-literals.interface';\n\nconst poTagColors = (<any>Object).values(PoColorPaletteEnum);\nconst poTagOrientationDefault = PoTagOrientation.Vertical;\n\nexport const PoTagLiteralsDefault = {\n  en: {\n    remove: 'Clear'\n  },\n  es: {\n    remove: 'Eliminar'\n  },\n  pt: {\n    remove: 'Remover'\n  },\n  ru: {\n    remove: 'удалять'\n  }\n};\n\n/**\n * @description\n *\n * Este componente permite exibir um valor em forma de um marcador colorido, sendo possível definir uma legenda e realizar customizações\n * na cor, iconografia e tipo.\n *\n * Além disso, é possível definir uma ação que será executada tanto ao *click* quanto através das teclas *enter/space* enquanto navega\n * utilizando a tecla *tab*.\n *\n * Seu uso é recomendado para informações que necessitem de destaque em forma de marcação.\n */\n@Directive()\nexport class PoTagBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define uma legenda que será exibida acima ou ao lado da *tag*, de acordo com a `p-orientation`.\n   */\n  @Input('p-label') label?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Habilita a opção de remover a tag\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-removable', transform: convertToBoolean }) removable: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Desabilita o `po-tag` e não permite que o usuário interaja com o mesmo.\n   * > A propriedade `p-disabled` somente terá efeito caso a propriedade `p-removable` esteja definida como `true`.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-disabled', transform: convertToBoolean }) disabled: boolean = false;\n\n  /** Texto da tag. */\n  @Input('p-value') value: string;\n\n  /**\n   * @deprecated 16.x.x\n   *\n   * @optional\n   *\n   * @description\n   *\n   * **Deprecated 16.x.x**.\n   *\n   * > Por regras de acessibilidade a tag não terá mais evento de click. Indicamos o uso do `Po-button` ou `Po-link`\n   * caso deseje esse comportamento.\n   *\n   * Ação que será executada ao clicar sobre o `po-tag` e que receberá como parâmetro um objeto contendo o seu valor e tipo.\n   */\n  @Output('p-click') click: EventEmitter<any> = new EventEmitter<PoTagItem>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ação que sera executada quando clicar sobre o ícone de remover no `po-tag`\n   */\n  @Output('p-close') remove: EventEmitter<any> = new EventEmitter<any>();\n\n  public readonly poTagOrientation = PoTagOrientation;\n  public customColor;\n  public customTextColor;\n  private _color?: string;\n  private _textColor?: string;\n  private _icon?: boolean | string | TemplateRef<void>;\n  private _inverse?: boolean;\n  private _orientation?: PoTagOrientation = poTagOrientationDefault;\n  private _type?: PoTagType;\n  private _literals: PoTagLiterals;\n  private language: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Determina a cor da tag. As maneiras de customizar as cores são:\n   * - Hexadeximal, por exemplo `#c64840`;\n   * - RGB, como `rgb(0, 0, 165)`;\n   * - O nome da cor, por exemplo `blue`;\n   * - Usando uma das cores do tema do PO:\n   * Valores válidos:\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\n   *\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\n   *\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\n   */\n  @Input('p-color') set color(value: string) {\n    this._color = poTagColors.includes(value) ? value : undefined;\n    if (this._color === undefined) {\n      CSS.supports('color', value) ? (this.customColor = value) : (this.customColor = undefined);\n    }\n  }\n\n  get color(): string {\n    return this._color;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Determina a cor do texto da tag. As maneiras de customizar as cores são:\n   * - Hexadeximal, por exemplo `#c64840`;\n   * - RGB, como `rgb(0, 0, 165)`;\n   * - O nome da cor, por exemplo `blue`;\n   * - Usando uma das cores do tema do PO:\n   * Valores válidos:\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\n   *\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\n   *\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\n   */\n  @Input('p-text-color') set textColor(value: string) {\n    this._textColor = poTagColors.includes(value) ? value : undefined;\n    if (this._textColor === undefined) {\n      CSS.supports('color', value) ? (this.customTextColor = value) : (this.customTextColor = undefined);\n    }\n  }\n\n  get textColor(): string {\n    return this._textColor;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define ou ativa um ícone que será exibido ao lado do valor da *tag*.\n   *\n   * Quando `p-type` estiver definida, basta informar um valor igual a `true` para que o ícone seja exibido conforme descrições abaixo:\n   * - <span class=\"po-icon po-icon-ok\"></span> - `success`\n   * - <span class=\"po-icon po-icon-warning\"></span> - `warning`\n   * - <span class=\"po-icon po-icon-close\"></span> - `danger`\n   * - <span class=\"po-icon po-icon-info\"></span> - `info`\n   *\n   * Também É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\n   * ```\n   * <po-tag p-icon=\"po-icon-user\" p-value=\"PO Tag\"></po-tag>\n   * ```\n   * como também utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\n   * ```\n   * <po-tag p-icon=\"fa fa-podcast\" p-value=\"PO Tag\"></po-button>\n   * ```\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\n   * ```\n   * <po-tag [p-icon]=\"template\" p-value=\"Tag template ionic\"></po-button>\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   * @default `false`\n   */\n  @Input('p-icon') set icon(value: boolean | string | TemplateRef<void>) {\n    if (this.type) {\n      this._icon = convertToBoolean(value);\n    } else {\n      this._icon = value;\n    }\n  }\n\n  get icon() {\n    return this._icon;\n  }\n\n  /**\n   * @deprecated 16.x.x\n   *\n   * @optional\n   *\n   * @description\n   *\n   * > Por regras de acessibilidade e usabilidade a tag não terá a inversão de cores no componente.\n   *\n   * Ativa a inversão de cores configuradas no componente, possibilitando uma visualização de status ativo e inativo.\n   *\n   * > A cor do texto, do ícone e da borda ficam com a cor utilizada na propriedade `p-color` ou a cor correspondente ao `p-type`,\n   * e a cor do fundo fica branca.\n   *\n   * @default `false`\n   */\n  @Input('p-inverse') set inverse(value: boolean) {\n    this._inverse = convertToBoolean(value);\n  }\n\n  get inverse(): boolean {\n    return this._inverse;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o *layout* de exibição.\n   *\n   * @default `vertical`\n   */\n  @Input('p-orientation') set orientation(value: PoTagOrientation) {\n    this._orientation = (<any>Object).values(PoTagOrientation).includes(value) ? value : poTagOrientationDefault;\n  }\n\n  get orientation(): PoTagOrientation {\n    return this._orientation;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tipo da *tag*.\n   *\n   * Valores válidos:\n   *  - `success`: cor verde utilizada para simbolizar sucesso ou êxito.\n   *  - `warning`: cor amarela que representa aviso ou advertência.\n   *  - `danger`: cor vermelha para erro ou aviso crítico.\n   *  - `info`: cor azul claro que caracteriza conteúdo informativo.\n   *  - `neutral`: cor cinza claro para uso geral.\n   *\n   * > Quando esta propriedade for definida, irá sobrepor a definição de `p-color` e `p-icon` somente será exibido caso seja `true`.\n   *\n   * @default `info`\n   */\n  @Input('p-type') set type(value: PoTagType) {\n    if (!this.removable) {\n      this._type = (<any>Object).values(PoTagType).includes(value) ? value : undefined;\n    }\n  }\n\n  get type(): PoTagType {\n    return this._type;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-tag`.\n   *\n   *\n   * Para utilizar, basta passar a literal customizada:\n   *\n   * ```\n   *  const customLiterals: PoTagLiterals = {\n   *    remove: 'Remover itens'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente:\n   *\n   * ```\n   * <po-tag\n   *   [p-literals]=\"customLiterals\">\n   * </po-tag>\n   * ```\n   *\n   * > O objeto padrão de literais será traduzido de acordo com o idioma do\n   * [`PoI18nService`](/documentation/po-i18n) ou do browser.\n   */\n  @Input('p-literals') set literals(value: PoTagLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...PoTagLiteralsDefault[poLocaleDefault],\n        ...PoTagLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = PoTagLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || PoTagLiteralsDefault[this.language];\n  }\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n}\n"]}
@@ -1,40 +1,41 @@
1
1
  import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
2
- import { PoTagBaseComponent } from './po-tag-base.component';
3
2
  import { PoTagIcon } from './enums/po-tag-icon.enum';
4
3
  import { PoTagType } from './enums/po-tag-type.enum';
5
- import { PoTagLiterals } from './po-tag.literals';
4
+ import { PoTagBaseComponent } from './po-tag-base.component';
6
5
  import * as i0 from "@angular/core";
7
6
  import * as i1 from "./../../services/po-language/po-language.service";
8
7
  import * as i2 from "@angular/common";
9
8
  import * as i3 from "../po-icon/po-icon.component";
10
9
  import * as i4 from "../../directives/po-tooltip/po-tooltip.directive";
11
10
  const _c0 = ["tagContainer"];
12
- function PoTagComponent_div_2_Template(rf, ctx) { if (rf & 1) {
13
- i0.ɵɵelementStart(0, "div", 9)(1, "span", 10);
11
+ const _c1 = ["tagClose"];
12
+ const _c2 = ["poTag"];
13
+ function PoTagComponent_div_1_Template(rf, ctx) { if (rf & 1) {
14
+ i0.ɵɵelementStart(0, "div", 10)(1, "span", 11);
14
15
  i0.ɵɵtext(2);
15
16
  i0.ɵɵelementEnd()();
16
17
  } if (rf & 2) {
17
- const ctx_r1 = i0.ɵɵnextContext();
18
+ const ctx_r0 = i0.ɵɵnextContext();
18
19
  i0.ɵɵadvance(2);
19
- i0.ɵɵtextInterpolate(ctx_r1.tagOrientation ? ctx_r1.label + ":" : ctx_r1.label);
20
+ i0.ɵɵtextInterpolate(ctx_r0.tagOrientation ? ctx_r0.label + ":" : ctx_r0.label);
20
21
  } }
21
- const _c1 = function (a0) { return { "color": a0 }; };
22
+ const _c3 = function (a0) { return { "color": a0 }; };
22
23
  function PoTagComponent_po_icon_5_Template(rf, ctx) { if (rf & 1) {
23
- i0.ɵɵelement(0, "po-icon", 11);
24
+ i0.ɵɵelement(0, "po-icon", 12);
24
25
  } if (rf & 2) {
25
26
  const ctx_r2 = i0.ɵɵnextContext();
26
- i0.ɵɵproperty("p-icon", !ctx_r2.type ? ctx_r2.icon : ctx_r2.iconFromType)("ngStyle", !ctx_r2.tagColor && ctx_r2.inverse && !ctx_r2.customTextColor ? i0.ɵɵpureFunction1(2, _c1, ctx_r2.customColor) : !ctx_r2.type && ctx_r2.customTextColor ? i0.ɵɵpureFunction1(4, _c1, ctx_r2.customTextColor) : "");
27
+ i0.ɵɵproperty("p-icon", !ctx_r2.type ? ctx_r2.icon : ctx_r2.iconFromType)("ngStyle", !ctx_r2.tagColor && ctx_r2.inverse && !ctx_r2.customTextColor ? i0.ɵɵpureFunction1(2, _c3, ctx_r2.customColor) : !ctx_r2.type && ctx_r2.customTextColor ? i0.ɵɵpureFunction1(4, _c3, ctx_r2.customTextColor) : "");
27
28
  } }
28
- function PoTagComponent_span_9_Template(rf, ctx) { if (rf & 1) {
29
- const _r5 = i0.ɵɵgetCurrentView();
30
- i0.ɵɵelementStart(0, "span", 12);
31
- i0.ɵɵlistener("click", function PoTagComponent_span_9_Template_span_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.onClose()); })("keydown.enter", function PoTagComponent_span_9_Template_span_keydown_enter_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onClose()); });
29
+ function PoTagComponent_span_10_Template(rf, ctx) { if (rf & 1) {
30
+ const _r7 = i0.ɵɵgetCurrentView();
31
+ i0.ɵɵelementStart(0, "span", 13, 14);
32
+ i0.ɵɵlistener("click", function PoTagComponent_span_10_Template_span_click_0_listener() { i0.ɵɵrestoreView(_r7); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onClose()); })("keydown.enter", function PoTagComponent_span_10_Template_span_keydown_enter_0_listener() { i0.ɵɵrestoreView(_r7); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onClose("enter")); });
32
33
  i0.ɵɵelementEnd();
33
34
  } if (rf & 2) {
34
- const ctx_r3 = i0.ɵɵnextContext();
35
- i0.ɵɵclassProp("po-clickable", !ctx_r3.disabled);
36
- i0.ɵɵproperty("tabindex", !ctx_r3.disabled ? 0 : -1);
37
- i0.ɵɵattribute("aria-label", ctx_r3.setAriaLabel())("role", !ctx_r3.disabled ? "button" : "");
35
+ const ctx_r4 = i0.ɵɵnextContext();
36
+ i0.ɵɵclassProp("po-clickable", !ctx_r4.disabled);
37
+ i0.ɵɵproperty("p-tooltip", ctx_r4.literals.remove)("tabindex", !ctx_r4.disabled ? 0 : -1);
38
+ i0.ɵɵattribute("aria-label", ctx_r4.setAriaLabel())("role", !ctx_r4.disabled ? "button" : "");
38
39
  } }
39
40
  const poTagTypeDefault = 'po-tag-' + PoTagType.Info;
40
41
  /**
@@ -59,18 +60,13 @@ const poTagTypeDefault = 'po-tag-' + PoTagType.Info;
59
60
  */
60
61
  export class PoTagComponent extends PoTagBaseComponent {
61
62
  el;
62
- languageService;
63
63
  tagContainer;
64
+ tagClose;
65
+ poTag;
64
66
  isClickable;
65
- literals;
66
67
  constructor(el, languageService) {
67
- super();
68
+ super(languageService);
68
69
  this.el = el;
69
- this.languageService = languageService;
70
- const language = this.languageService.getShortLanguage();
71
- this.literals = {
72
- ...PoTagLiterals[language]
73
- };
74
70
  }
75
71
  ngOnInit() {
76
72
  this.isClickable = this.click.observers.length > 0;
@@ -101,22 +97,23 @@ export class PoTagComponent extends PoTagBaseComponent {
101
97
  get tagOrientation() {
102
98
  return this.orientation === this.poTagOrientation.Horizontal;
103
99
  }
104
- onClick() {
100
+ onClick(event = 'click') {
105
101
  if (!this.removable && !this.disabled) {
106
- const submittedTagItem = { value: this.value, type: this.type };
102
+ const submittedTagItem = { value: this.value, type: this.type, event: event };
107
103
  this.click.emit(submittedTagItem);
108
104
  }
109
105
  }
110
- onClose() {
106
+ onClose(event = 'click') {
111
107
  if (!this.disabled) {
112
- this.click.emit(null);
108
+ this.click.emit(event);
113
109
  this.onRemove();
110
+ this.remove.emit(event);
114
111
  }
115
112
  }
116
113
  onKeyPressed(event) {
117
114
  event.preventDefault();
118
115
  event.stopPropagation();
119
- this.onClick();
116
+ this.onClick('enter');
120
117
  }
121
118
  styleTag() {
122
119
  if (!this.tagColor && !this.inverse && !this.removable) {
@@ -146,33 +143,38 @@ export class PoTagComponent extends PoTagBaseComponent {
146
143
  static ɵfac = function PoTagComponent_Factory(t) { return new (t || PoTagComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
147
144
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTagComponent, selectors: [["po-tag"]], viewQuery: function PoTagComponent_Query(rf, ctx) { if (rf & 1) {
148
145
  i0.ɵɵviewQuery(_c0, 7);
146
+ i0.ɵɵviewQuery(_c1, 7);
147
+ i0.ɵɵviewQuery(_c2, 7);
149
148
  } if (rf & 2) {
150
149
  let _t;
151
150
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tagContainer = _t.first);
152
- } }, features: [i0.ɵɵInheritDefinitionFeature], decls: 10, vars: 24, consts: [["p-tooltip-position", "top", 1, "po-tag-container", 3, "p-tooltip"], ["tagContainer", ""], ["class", "po-tag-title po-text-nowrap", 4, "ngIf"], [1, "po-tag-sub-container"], [1, "po-tag", 3, "ngClass", "ngStyle", "tabindex", "click", "keydown.enter", "keydown.space", "keyup.space"], ["class", "po-tag-icon", 3, "p-icon", "ngStyle", 4, "ngIf"], [1, "po-tag-value"], [3, "ngStyle"], ["class", "po-tag-remove po-icon po-icon-close", 3, "po-clickable", "tabindex", "click", "keydown.enter", 4, "ngIf"], [1, "po-tag-title", "po-text-nowrap"], [1, "po-tag-label"], [1, "po-tag-icon", 3, "p-icon", "ngStyle"], [1, "po-tag-remove", "po-icon", "po-icon-close", 3, "tabindex", "click", "keydown.enter"]], template: function PoTagComponent_Template(rf, ctx) { if (rf & 1) {
153
- i0.ɵɵelementStart(0, "div", 0, 1);
154
- i0.ɵɵtemplate(2, PoTagComponent_div_2_Template, 3, 1, "div", 2);
155
- i0.ɵɵelementStart(3, "div", 3)(4, "div", 4);
156
- i0.ɵɵlistener("click", function PoTagComponent_Template_div_click_4_listener() { return ctx.onClick(); })("keydown.enter", function PoTagComponent_Template_div_keydown_enter_4_listener($event) { return ctx.onKeyPressed($event); })("keydown.space", function PoTagComponent_Template_div_keydown_space_4_listener($event) { return $event.preventDefault(); })("keyup.space", function PoTagComponent_Template_div_keyup_space_4_listener($event) { return ctx.onKeyPressed($event); });
151
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tagClose = _t.first);
152
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poTag = _t.first);
153
+ } }, features: [i0.ɵɵInheritDefinitionFeature], decls: 11, vars: 24, consts: [[1, "po-tag-container"], ["class", "po-tag-title po-text-nowrap", 4, "ngIf"], [1, "po-tag-sub-container"], [1, "po-tag", 3, "ngClass", "ngStyle", "tabindex", "click", "keydown.enter", "keydown.space", "keyup.space"], ["poTag", ""], ["class", "po-tag-icon", 3, "p-icon", "ngStyle", 4, "ngIf"], ["p-tooltip-position", "top", 1, "po-tag-value", 3, "p-tooltip"], ["tagContainer", ""], [3, "ngStyle"], ["p-tooltip-position", "top", "class", "po-tag-remove po-icon po-icon-close", 3, "p-tooltip", "po-clickable", "tabindex", "click", "keydown.enter", 4, "ngIf"], [1, "po-tag-title", "po-text-nowrap"], [1, "po-tag-label"], [1, "po-tag-icon", 3, "p-icon", "ngStyle"], ["p-tooltip-position", "top", 1, "po-tag-remove", "po-icon", "po-icon-close", 3, "p-tooltip", "tabindex", "click", "keydown.enter"], ["tagClose", ""]], template: function PoTagComponent_Template(rf, ctx) { if (rf & 1) {
154
+ i0.ɵɵelementStart(0, "div", 0);
155
+ i0.ɵɵtemplate(1, PoTagComponent_div_1_Template, 3, 1, "div", 1);
156
+ i0.ɵɵelementStart(2, "div", 2)(3, "div", 3, 4);
157
+ i0.ɵɵlistener("click", function PoTagComponent_Template_div_click_3_listener() { return ctx.onClick(); })("keydown.enter", function PoTagComponent_Template_div_keydown_enter_3_listener($event) { return ctx.onKeyPressed($event); })("keydown.space", function PoTagComponent_Template_div_keydown_space_3_listener($event) { return $event.preventDefault(); })("keyup.space", function PoTagComponent_Template_div_keyup_space_3_listener($event) { return ctx.onKeyPressed($event); });
157
158
  i0.ɵɵtemplate(5, PoTagComponent_po_icon_5_Template, 1, 6, "po-icon", 5);
158
- i0.ɵɵelementStart(6, "div", 6)(7, "span", 7);
159
- i0.ɵɵtext(8);
159
+ i0.ɵɵelementStart(6, "div", 6, 7)(8, "span", 8);
160
+ i0.ɵɵtext(9);
160
161
  i0.ɵɵelementEnd()();
161
- i0.ɵɵtemplate(9, PoTagComponent_span_9_Template, 1, 5, "span", 8);
162
+ i0.ɵɵtemplate(10, PoTagComponent_span_10_Template, 2, 6, "span", 9);
162
163
  i0.ɵɵelementEnd()()();
163
164
  } if (rf & 2) {
164
165
  i0.ɵɵclassProp("po-tag-container-horizontal", ctx.tagOrientation);
165
- i0.ɵɵproperty("p-tooltip", ctx.getWidthTag() ? ctx.value : "");
166
- i0.ɵɵadvance(2);
166
+ i0.ɵɵadvance(1);
167
167
  i0.ɵɵproperty("ngIf", ctx.label);
168
168
  i0.ɵɵadvance(2);
169
169
  i0.ɵɵclassProp("po-clickable", ctx.isClickable && !ctx.disabled && !ctx.removable)("po-tag-inverse", ctx.inverse && !ctx.type && !ctx.customTextColor && !ctx.removable)("po-tag-removable", ctx.removable)("po-tag-disabled", ctx.disabled && ctx.removable);
170
170
  i0.ɵɵproperty("ngClass", ctx.tagColor)("ngStyle", ctx.styleTag())("tabindex", ctx.isClickable && !ctx.removable ? 0 : -1);
171
171
  i0.ɵɵattribute("role", ctx.isClickable && !ctx.disabled ? "button" : "");
172
- i0.ɵɵadvance(1);
172
+ i0.ɵɵadvance(2);
173
173
  i0.ɵɵproperty("ngIf", ctx.icon && !ctx.removable);
174
+ i0.ɵɵadvance(1);
175
+ i0.ɵɵproperty("p-tooltip", ctx.getWidthTag() ? ctx.value : "");
174
176
  i0.ɵɵadvance(2);
175
- i0.ɵɵproperty("ngStyle", !ctx.tagColor && ctx.inverse && !ctx.customTextColor ? i0.ɵɵpureFunction1(20, _c1, ctx.customColor) : !ctx.type && ctx.customTextColor && !ctx.removable ? i0.ɵɵpureFunction1(22, _c1, ctx.customTextColor) : "");
177
+ i0.ɵɵproperty("ngStyle", !ctx.tagColor && ctx.inverse && !ctx.customTextColor ? i0.ɵɵpureFunction1(20, _c3, ctx.customColor) : !ctx.type && ctx.customTextColor && !ctx.removable ? i0.ɵɵpureFunction1(22, _c3, ctx.customTextColor) : "");
176
178
  i0.ɵɵadvance(1);
177
179
  i0.ɵɵtextInterpolate(ctx.value);
178
180
  i0.ɵɵadvance(1);
@@ -181,9 +183,15 @@ export class PoTagComponent extends PoTagBaseComponent {
181
183
  }
182
184
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTagComponent, [{
183
185
  type: Component,
184
- args: [{ selector: 'po-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #tagContainer\n class=\"po-tag-container\"\n [class.po-tag-container-horizontal]=\"tagOrientation\"\n [p-tooltip]=\"getWidthTag() ? value : ''\"\n p-tooltip-position=\"top\"\n>\n <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\n <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\n </div>\n\n <div class=\"po-tag-sub-container\">\n <div\n class=\"po-tag\"\n [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\n [class.po-clickable]=\"isClickable && !disabled && !removable\"\n [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\n [class.po-tag-removable]=\"removable\"\n [class.po-tag-disabled]=\"disabled && removable\"\n [ngClass]=\"tagColor\"\n [ngStyle]=\"styleTag()\"\n [tabindex]=\"isClickable && !removable ? 0 : -1\"\n (click)=\"onClick()\"\n (keydown.enter)=\"onKeyPressed($event)\"\n (keydown.space)=\"$event.preventDefault()\"\n (keyup.space)=\"onKeyPressed($event)\"\n >\n <po-icon\n *ngIf=\"icon && !removable\"\n class=\"po-tag-icon\"\n [p-icon]=\"!type ? icon : iconFromType\"\n [ngStyle]=\"\n !tagColor && inverse && !customTextColor\n ? { 'color': customColor }\n : !type && customTextColor\n ? { 'color': customTextColor }\n : ''\n \"\n >\n </po-icon>\n\n <div class=\"po-tag-value\">\n <span\n [ngStyle]=\"\n !tagColor && inverse && !customTextColor\n ? { 'color': customColor }\n : !type && customTextColor && !removable\n ? { 'color': customTextColor }\n : ''\n \"\n >{{ value }}</span\n >\n </div>\n\n <span\n *ngIf=\"removable\"\n [attr.aria-label]=\"setAriaLabel()\"\n class=\"po-tag-remove po-icon po-icon-close\"\n [class.po-clickable]=\"!disabled\"\n [tabindex]=\"!disabled ? 0 : -1\"\n [attr.role]=\"!disabled ? 'button' : ''\"\n (click)=\"onClose()\"\n (keydown.enter)=\"onClose()\"\n >\n </span>\n </div>\n </div>\n</div>\n" }]
186
+ args: [{ selector: 'po-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"po-tag-container\" [class.po-tag-container-horizontal]=\"tagOrientation\">\n <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\n <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\n </div>\n\n <div class=\"po-tag-sub-container\">\n <div\n #poTag\n class=\"po-tag\"\n [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\n [class.po-clickable]=\"isClickable && !disabled && !removable\"\n [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\n [class.po-tag-removable]=\"removable\"\n [class.po-tag-disabled]=\"disabled && removable\"\n [ngClass]=\"tagColor\"\n [ngStyle]=\"styleTag()\"\n [tabindex]=\"isClickable && !removable ? 0 : -1\"\n (click)=\"onClick()\"\n (keydown.enter)=\"onKeyPressed($event)\"\n (keydown.space)=\"$event.preventDefault()\"\n (keyup.space)=\"onKeyPressed($event)\"\n >\n <po-icon\n *ngIf=\"icon && !removable\"\n class=\"po-tag-icon\"\n [p-icon]=\"!type ? icon : iconFromType\"\n [ngStyle]=\"\n !tagColor && inverse && !customTextColor\n ? { 'color': customColor }\n : !type && customTextColor\n ? { 'color': customTextColor }\n : ''\n \"\n >\n </po-icon>\n\n <div #tagContainer class=\"po-tag-value\" [p-tooltip]=\"getWidthTag() ? value : ''\" p-tooltip-position=\"top\">\n <span\n [ngStyle]=\"\n !tagColor && inverse && !customTextColor\n ? { 'color': customColor }\n : !type && customTextColor && !removable\n ? { 'color': customTextColor }\n : ''\n \"\n >{{ value }}</span\n >\n </div>\n\n <span\n #tagClose\n *ngIf=\"removable\"\n p-tooltip-position=\"top\"\n [p-tooltip]=\"literals.remove\"\n [attr.aria-label]=\"setAriaLabel()\"\n class=\"po-tag-remove po-icon po-icon-close\"\n [class.po-clickable]=\"!disabled\"\n [tabindex]=\"!disabled ? 0 : -1\"\n [attr.role]=\"!disabled ? 'button' : ''\"\n (click)=\"onClose()\"\n (keydown.enter)=\"onClose('enter')\"\n >\n </span>\n </div>\n </div>\n</div>\n" }]
185
187
  }], function () { return [{ type: i0.ElementRef }, { type: i1.PoLanguageService }]; }, { tagContainer: [{
186
188
  type: ViewChild,
187
189
  args: ['tagContainer', { static: true }]
190
+ }], tagClose: [{
191
+ type: ViewChild,
192
+ args: ['tagClose', { static: true }]
193
+ }], poTag: [{
194
+ type: ViewChild,
195
+ args: ['poTag', { static: true }]
188
196
  }] }); })();
189
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-tag/po-tag.component.ts","../../../../../../projects/ui/src/lib/components/po-tag/po-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { PoLanguageService } from './../../services/po-language/po-language.service';\nimport { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\n\nimport { PoTagBaseComponent } from './po-tag-base.component';\nimport { PoTagIcon } from './enums/po-tag-icon.enum';\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\nimport { PoTagType } from './enums/po-tag-type.enum';\nimport { PoTagLiterals } from './po-tag.literals';\n\nconst poTagTypeDefault = 'po-tag-' + PoTagType.Info;\n\n/**\n * @docsExtends PoTagBaseComponent\n *\n * @example\n *\n * <example name=\"po-tag-basic\" title=\"PO Tag Basic\">\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.html\"> </file>\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-tag-labs\" title=\"PO Tag Labs\">\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.html\"> </file>\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-tag-bank-account\" title=\"PO Tag - Bank Account\">\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.html\"> </file>\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-tag',\n  templateUrl: './po-tag.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PoTagComponent extends PoTagBaseComponent implements OnInit {\n  @ViewChild('tagContainer', { static: true }) tagContainer: ElementRef;\n\n  isClickable: boolean;\n  literals: any;\n\n  constructor(private el: ElementRef, private languageService: PoLanguageService) {\n    super();\n    const language = this.languageService.getShortLanguage();\n    this.literals = {\n      ...PoTagLiterals[language]\n    };\n  }\n\n  ngOnInit() {\n    this.isClickable = this.click.observers.length > 0;\n  }\n\n  get iconFromType() {\n    switch (this.type) {\n      case PoTagType.Danger:\n        return PoTagIcon.Danger;\n\n      case PoTagType.Info:\n        return PoTagIcon.Info;\n\n      case PoTagType.Success:\n        return PoTagIcon.Success;\n\n      case PoTagType.Warning:\n        return PoTagIcon.Warning;\n    }\n  }\n\n  get tagColor() {\n    if (this.type && !this.removable) {\n      return this.inverse ? `po-tag-${this.type}-inverse` : `po-tag-${this.type}`;\n    }\n\n    if (this.color && !this.removable) {\n      return this.inverse ? `po-text-${this.color}` : `po-${this.color}`;\n    }\n\n    if (!this.customColor && !this.removable) {\n      return this.inverse ? `${poTagTypeDefault}-inverse` : poTagTypeDefault;\n    }\n  }\n\n  get tagOrientation() {\n    return this.orientation === this.poTagOrientation.Horizontal;\n  }\n\n  onClick() {\n    if (!this.removable && !this.disabled) {\n      const submittedTagItem: PoTagItem = { value: this.value, type: this.type };\n      this.click.emit(submittedTagItem);\n    }\n  }\n\n  onClose() {\n    if (!this.disabled) {\n      this.click.emit(null);\n      this.onRemove();\n    }\n  }\n\n  onKeyPressed(event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.onClick();\n  }\n\n  styleTag() {\n    if (!this.tagColor && !this.inverse && !this.removable) {\n      return { 'background-color': this.customColor, 'color': 'white' };\n    } else if (!this.tagColor && this.inverse && !this.customTextColor) {\n      return { 'border': '1px solid ' + this.customColor };\n    } else if (!this.tagColor && this.inverse && this.customTextColor) {\n      return { 'border': '1px solid ' + this.customTextColor, 'background-color': this.customColor };\n    } else {\n      return {};\n    }\n  }\n\n  getWidthTag() {\n    return this.tagContainer.nativeElement.offsetWidth > 155;\n  }\n\n  setAriaLabel() {\n    return this.label ? this.label + ' ' + this.literals.remove : this.value + ' ' + this.literals.remove;\n  }\n\n  private onRemove() {\n    if (!this.disabled) {\n      this.el.nativeElement.remove();\n    }\n  }\n}\n","<div\n  #tagContainer\n  class=\"po-tag-container\"\n  [class.po-tag-container-horizontal]=\"tagOrientation\"\n  [p-tooltip]=\"getWidthTag() ? value : ''\"\n  p-tooltip-position=\"top\"\n>\n  <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\n    <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\n  </div>\n\n  <div class=\"po-tag-sub-container\">\n    <div\n      class=\"po-tag\"\n      [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\n      [class.po-clickable]=\"isClickable && !disabled && !removable\"\n      [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\n      [class.po-tag-removable]=\"removable\"\n      [class.po-tag-disabled]=\"disabled && removable\"\n      [ngClass]=\"tagColor\"\n      [ngStyle]=\"styleTag()\"\n      [tabindex]=\"isClickable && !removable ? 0 : -1\"\n      (click)=\"onClick()\"\n      (keydown.enter)=\"onKeyPressed($event)\"\n      (keydown.space)=\"$event.preventDefault()\"\n      (keyup.space)=\"onKeyPressed($event)\"\n    >\n      <po-icon\n        *ngIf=\"icon && !removable\"\n        class=\"po-tag-icon\"\n        [p-icon]=\"!type ? icon : iconFromType\"\n        [ngStyle]=\"\n          !tagColor && inverse && !customTextColor\n            ? { 'color': customColor }\n            : !type && customTextColor\n            ? { 'color': customTextColor }\n            : ''\n        \"\n      >\n      </po-icon>\n\n      <div class=\"po-tag-value\">\n        <span\n          [ngStyle]=\"\n            !tagColor && inverse && !customTextColor\n              ? { 'color': customColor }\n              : !type && customTextColor && !removable\n              ? { 'color': customTextColor }\n              : ''\n          \"\n          >{{ value }}</span\n        >\n      </div>\n\n      <span\n        *ngIf=\"removable\"\n        [attr.aria-label]=\"setAriaLabel()\"\n        class=\"po-tag-remove po-icon po-icon-close\"\n        [class.po-clickable]=\"!disabled\"\n        [tabindex]=\"!disabled ? 0 : -1\"\n        [attr.role]=\"!disabled ? 'button' : ''\"\n        (click)=\"onClose()\"\n        (keydown.enter)=\"onClose()\"\n      >\n      </span>\n    </div>\n  </div>\n</div>\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-tag/po-tag.component.ts","../../../../../../projects/ui/src/lib/components/po-tag/po-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\nimport { PoLanguageService } from './../../services/po-language/po-language.service';\n\nimport { PoTagIcon } from './enums/po-tag-icon.enum';\nimport { PoTagType } from './enums/po-tag-type.enum';\nimport { PoTagBaseComponent } from './po-tag-base.component';\nimport { PoTagLiterals } from './interfaces/po-tag-literals.interface';\n\nconst poTagTypeDefault = 'po-tag-' + PoTagType.Info;\n\n/**\n * @docsExtends PoTagBaseComponent\n *\n * @example\n *\n * <example name=\"po-tag-basic\" title=\"PO Tag Basic\">\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.html\"> </file>\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-tag-labs\" title=\"PO Tag Labs\">\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.html\"> </file>\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-tag-bank-account\" title=\"PO Tag - Bank Account\">\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.html\"> </file>\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-tag',\n  templateUrl: './po-tag.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PoTagComponent extends PoTagBaseComponent implements OnInit {\n  @ViewChild('tagContainer', { static: true }) tagContainer: ElementRef;\n  @ViewChild('tagClose', { static: true }) tagClose: ElementRef;\n  @ViewChild('poTag', { static: true }) poTag: ElementRef;\n\n  isClickable: boolean;\n\n  constructor(private el: ElementRef, languageService: PoLanguageService) {\n    super(languageService);\n  }\n\n  ngOnInit() {\n    this.isClickable = this.click.observers.length > 0;\n  }\n\n  get iconFromType() {\n    switch (this.type) {\n      case PoTagType.Danger:\n        return PoTagIcon.Danger;\n\n      case PoTagType.Info:\n        return PoTagIcon.Info;\n\n      case PoTagType.Success:\n        return PoTagIcon.Success;\n\n      case PoTagType.Warning:\n        return PoTagIcon.Warning;\n    }\n  }\n\n  get tagColor() {\n    if (this.type && !this.removable) {\n      return this.inverse ? `po-tag-${this.type}-inverse` : `po-tag-${this.type}`;\n    }\n\n    if (this.color && !this.removable) {\n      return this.inverse ? `po-text-${this.color}` : `po-${this.color}`;\n    }\n\n    if (!this.customColor && !this.removable) {\n      return this.inverse ? `${poTagTypeDefault}-inverse` : poTagTypeDefault;\n    }\n  }\n\n  get tagOrientation() {\n    return this.orientation === this.poTagOrientation.Horizontal;\n  }\n\n  onClick(event = 'click') {\n    if (!this.removable && !this.disabled) {\n      const submittedTagItem = { value: this.value, type: this.type, event: event };\n      this.click.emit(submittedTagItem);\n    }\n  }\n\n  onClose(event = 'click') {\n    if (!this.disabled) {\n      this.click.emit(event);\n      this.onRemove();\n      this.remove.emit(event);\n    }\n  }\n\n  onKeyPressed(event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.onClick('enter');\n  }\n\n  styleTag() {\n    if (!this.tagColor && !this.inverse && !this.removable) {\n      return { 'background-color': this.customColor, 'color': 'white' };\n    } else if (!this.tagColor && this.inverse && !this.customTextColor) {\n      return { 'border': '1px solid ' + this.customColor };\n    } else if (!this.tagColor && this.inverse && this.customTextColor) {\n      return { 'border': '1px solid ' + this.customTextColor, 'background-color': this.customColor };\n    } else {\n      return {};\n    }\n  }\n\n  getWidthTag() {\n    return this.tagContainer.nativeElement.offsetWidth > 155;\n  }\n\n  setAriaLabel() {\n    return this.label ? this.label + ' ' + this.literals.remove : this.value + ' ' + this.literals.remove;\n  }\n\n  private onRemove() {\n    if (!this.disabled) {\n      this.el.nativeElement.remove();\n    }\n  }\n}\n","<div class=\"po-tag-container\" [class.po-tag-container-horizontal]=\"tagOrientation\">\n  <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\n    <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\n  </div>\n\n  <div class=\"po-tag-sub-container\">\n    <div\n      #poTag\n      class=\"po-tag\"\n      [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\n      [class.po-clickable]=\"isClickable && !disabled && !removable\"\n      [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\n      [class.po-tag-removable]=\"removable\"\n      [class.po-tag-disabled]=\"disabled && removable\"\n      [ngClass]=\"tagColor\"\n      [ngStyle]=\"styleTag()\"\n      [tabindex]=\"isClickable && !removable ? 0 : -1\"\n      (click)=\"onClick()\"\n      (keydown.enter)=\"onKeyPressed($event)\"\n      (keydown.space)=\"$event.preventDefault()\"\n      (keyup.space)=\"onKeyPressed($event)\"\n    >\n      <po-icon\n        *ngIf=\"icon && !removable\"\n        class=\"po-tag-icon\"\n        [p-icon]=\"!type ? icon : iconFromType\"\n        [ngStyle]=\"\n          !tagColor && inverse && !customTextColor\n            ? { 'color': customColor }\n            : !type && customTextColor\n            ? { 'color': customTextColor }\n            : ''\n        \"\n      >\n      </po-icon>\n\n      <div #tagContainer class=\"po-tag-value\" [p-tooltip]=\"getWidthTag() ? value : ''\" p-tooltip-position=\"top\">\n        <span\n          [ngStyle]=\"\n            !tagColor && inverse && !customTextColor\n              ? { 'color': customColor }\n              : !type && customTextColor && !removable\n              ? { 'color': customTextColor }\n              : ''\n          \"\n          >{{ value }}</span\n        >\n      </div>\n\n      <span\n        #tagClose\n        *ngIf=\"removable\"\n        p-tooltip-position=\"top\"\n        [p-tooltip]=\"literals.remove\"\n        [attr.aria-label]=\"setAriaLabel()\"\n        class=\"po-tag-remove po-icon po-icon-close\"\n        [class.po-clickable]=\"!disabled\"\n        [tabindex]=\"!disabled ? 0 : -1\"\n        [attr.role]=\"!disabled ? 'button' : ''\"\n        (click)=\"onClose()\"\n        (keydown.enter)=\"onClose('enter')\"\n      >\n      </span>\n    </div>\n  </div>\n</div>\n"]}
@@ -27,5 +27,9 @@ export var PoKeyCodeEnum;
27
27
  PoKeyCodeEnum[PoKeyCodeEnum["space"] = 32] = "space";
28
28
  /** Tab */
29
29
  PoKeyCodeEnum[PoKeyCodeEnum["tab"] = 9] = "tab";
30
+ /** Arrow Left */
31
+ PoKeyCodeEnum[PoKeyCodeEnum["left"] = 37] = "left";
32
+ /** Arrow Right */
33
+ PoKeyCodeEnum[PoKeyCodeEnum["right"] = 39] = "right";
30
34
  })(PoKeyCodeEnum || (PoKeyCodeEnum = {}));
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8ta2V5LWNvZGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvZW51bXMvcG8ta2V5LWNvZGUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQU4sSUFBWSxhQThCWDtBQTlCRCxXQUFZLGFBQWE7SUFDdkIsc0JBQXNCO0lBQ3RCLDREQUFjLENBQUE7SUFFZCxxQkFBcUI7SUFDckIsd0RBQVksQ0FBQTtJQUVaLGdCQUFnQjtJQUNoQiwyREFBYSxDQUFBO0lBRWIsYUFBYTtJQUNiLHNEQUFXLENBQUE7SUFFWCxZQUFZO0lBQ1osb0RBQVUsQ0FBQTtJQUVWLFVBQVU7SUFDVixnREFBUSxDQUFBO0lBRVIsY0FBYztJQUNkLGtEQUFTLENBQUE7SUFFVCxjQUFjO0lBQ2Qsa0RBQVMsQ0FBQTtJQUVULGFBQWE7SUFDYixvREFBVSxDQUFBO0lBRVYsVUFBVTtJQUNWLCtDQUFPLENBQUE7QUFDVCxDQUFDLEVBOUJXLGFBQWEsS0FBYixhQUFhLFFBOEJ4QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRvY3NQcml2YXRlXG4gKlxuICogQGRlc2NyaXB0aW9uXG4gKlxuICogRW51bSBxdWUgY29udMOpbSBvcyB2YWxvcmVzIG51bcOpcmljb3MgZG9zICprZXlDb2RlcyouXG4gKi9cbmV4cG9ydCBlbnVtIFBvS2V5Q29kZUVudW0ge1xuICAvKiogU2V0YSBwYXJhIGJhaXhvICovXG4gIGFycm93RG93biA9IDQwLFxuXG4gIC8qKiBTZXRhIHBhcmEgY2ltYSAqL1xuICBhcnJvd1VwID0gMzgsXG5cbiAgLyoqIEJhY2tzcGFjZSAqL1xuICBiYWNrc3BhY2UgPSA4LFxuXG4gIC8qKiBEZWxldGUgKi9cbiAgZGVsZXRlID0gNDYsXG5cbiAgLyoqIEVudGVyICovXG4gIGVudGVyID0gMTMsXG5cbiAgLyoqIEVzYyAqL1xuICBlc2MgPSAyNyxcblxuICAvKiogVGVjbGEgSyAqL1xuICBrZXlLID0gNzUsXG5cbiAgLyoqIFRlY2xhIEwgKi9cbiAga2V5TCA9IDc2LFxuXG4gIC8qKiBFc3Bhw6dvICovXG4gIHNwYWNlID0gMzIsXG5cbiAgLyoqIFRhYiAqL1xuICB0YWIgPSA5XG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8ta2V5LWNvZGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvZW51bXMvcG8ta2V5LWNvZGUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQU4sSUFBWSxhQW9DWDtBQXBDRCxXQUFZLGFBQWE7SUFDdkIsc0JBQXNCO0lBQ3RCLDREQUFjLENBQUE7SUFFZCxxQkFBcUI7SUFDckIsd0RBQVksQ0FBQTtJQUVaLGdCQUFnQjtJQUNoQiwyREFBYSxDQUFBO0lBRWIsYUFBYTtJQUNiLHNEQUFXLENBQUE7SUFFWCxZQUFZO0lBQ1osb0RBQVUsQ0FBQTtJQUVWLFVBQVU7SUFDVixnREFBUSxDQUFBO0lBRVIsY0FBYztJQUNkLGtEQUFTLENBQUE7SUFFVCxjQUFjO0lBQ2Qsa0RBQVMsQ0FBQTtJQUVULGFBQWE7SUFDYixvREFBVSxDQUFBO0lBRVYsVUFBVTtJQUNWLCtDQUFPLENBQUE7SUFFUCxpQkFBaUI7SUFDakIsa0RBQVMsQ0FBQTtJQUVULGtCQUFrQjtJQUNsQixvREFBVSxDQUFBO0FBQ1osQ0FBQyxFQXBDVyxhQUFhLEtBQWIsYUFBYSxRQW9DeEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkb2NzUHJpdmF0ZVxuICpcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIEVudW0gcXVlIGNvbnTDqW0gb3MgdmFsb3JlcyBudW3DqXJpY29zIGRvcyAqa2V5Q29kZXMqLlxuICovXG5leHBvcnQgZW51bSBQb0tleUNvZGVFbnVtIHtcbiAgLyoqIFNldGEgcGFyYSBiYWl4byAqL1xuICBhcnJvd0Rvd24gPSA0MCxcblxuICAvKiogU2V0YSBwYXJhIGNpbWEgKi9cbiAgYXJyb3dVcCA9IDM4LFxuXG4gIC8qKiBCYWNrc3BhY2UgKi9cbiAgYmFja3NwYWNlID0gOCxcblxuICAvKiogRGVsZXRlICovXG4gIGRlbGV0ZSA9IDQ2LFxuXG4gIC8qKiBFbnRlciAqL1xuICBlbnRlciA9IDEzLFxuXG4gIC8qKiBFc2MgKi9cbiAgZXNjID0gMjcsXG5cbiAgLyoqIFRlY2xhIEsgKi9cbiAga2V5SyA9IDc1LFxuXG4gIC8qKiBUZWNsYSBMICovXG4gIGtleUwgPSA3NixcblxuICAvKiogRXNwYcOnbyAqL1xuICBzcGFjZSA9IDMyLFxuXG4gIC8qKiBUYWIgKi9cbiAgdGFiID0gOSxcblxuICAvKiogQXJyb3cgTGVmdCAqL1xuICBsZWZ0ID0gMzcsXG5cbiAgLyoqIEFycm93IFJpZ2h0ICovXG4gIHJpZ2h0ID0gMzlcbn1cbiJdfQ==