@po-ui/ng-components 16.4.1 → 16.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/po-field/po-field.module.mjs +17 -13
- package/esm2022/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +30 -7
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +4 -4
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.mjs +1 -1
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +220 -51
- package/esm2022/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +3 -3
- package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +2 -2
- package/esm2022/lib/components/po-table/po-table-base.component.mjs +5 -5
- package/esm2022/lib/components/po-tag/index.mjs +2 -1
- package/esm2022/lib/components/po-tag/interfaces/po-tag-literals.interface.mjs +2 -0
- package/esm2022/lib/components/po-tag/po-tag-base.component.mjs +70 -4
- package/esm2022/lib/components/po-tag/po-tag.component.mjs +52 -44
- package/esm2022/lib/enums/po-key-code.enum.mjs +5 -1
- package/fesm2022/po-ui-ng-components.mjs +701 -532
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-field/po-field.module.d.ts +44 -44
- package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +21 -2
- package/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.d.ts +2 -0
- package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +18 -6
- package/lib/components/po-table/po-table-base.component.d.ts +2 -2
- package/lib/components/po-tag/index.d.ts +1 -0
- package/lib/components/po-tag/interfaces/po-tag-literals.interface.d.ts +11 -0
- package/lib/components/po-tag/po-tag-base.component.d.ts +50 -2
- package/lib/components/po-tag/po-tag.component.d.ts +6 -6
- package/lib/enums/po-key-code.enum.d.ts +5 -1
- package/package.json +4 -4
- package/po-ui-ng-components-16.5.0.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +0 -91
- package/esm2022/lib/components/po-tag/po-tag.literals.mjs +0 -15
- package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +0 -40
- package/lib/components/po-tag/po-tag.literals.d.ts +0 -14
- 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
|
-
|
|
266
|
-
|
|
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
|
-
}],
|
|
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 {
|
|
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
|
-
|
|
13
|
-
|
|
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
|
|
18
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
18
19
|
i0.ɵɵadvance(2);
|
|
19
|
-
i0.ɵɵtextInterpolate(
|
|
20
|
+
i0.ɵɵtextInterpolate(ctx_r0.tagOrientation ? ctx_r0.label + ":" : ctx_r0.label);
|
|
20
21
|
} }
|
|
21
|
-
const
|
|
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",
|
|
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,
|
|
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
|
|
29
|
-
const
|
|
30
|
-
i0.ɵɵelementStart(0, "span",
|
|
31
|
-
i0.ɵɵlistener("click", function
|
|
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
|
|
35
|
-
i0.ɵɵclassProp("po-clickable", !
|
|
36
|
-
i0.ɵɵproperty("tabindex", !
|
|
37
|
-
i0.ɵɵattribute("aria-label",
|
|
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(
|
|
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
|
-
|
|
153
|
-
i0.ɵɵ
|
|
154
|
-
|
|
155
|
-
i0.ɵɵelementStart(
|
|
156
|
-
i0.ɵɵ
|
|
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)(
|
|
159
|
-
i0.ɵɵtext(
|
|
159
|
+
i0.ɵɵelementStart(6, "div", 6, 7)(8, "span", 8);
|
|
160
|
+
i0.ɵɵtext(9);
|
|
160
161
|
i0.ɵɵelementEnd()();
|
|
161
|
-
i0.ɵɵtemplate(
|
|
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.ɵɵ
|
|
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(
|
|
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,
|
|
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
|
|
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":"AACA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAsB,SAAS,EAAE,MAAM,eAAe,CAAC;AAElG,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;ICAhD,8BAAuD,eAAA;IAC1B,YAA0C;IAAA,iBAAO,EAAA;;;IAAjD,eAA0C;IAA1C,+EAA0C;;;;IAmBnE,8BAYU;;;IATR,yEAAsC,8NAAA;;;;IAwBxC,gCASC;IAFC,0JAAS,eAAA,gBAAS,CAAA,IAAC,6JACF,eAAA,gBAAS,CAAA,IADP;IAGrB,iBAAO;;;IANL,gDAAgC;IAChC,oDAA+B;IAH/B,mDAAkC,0CAAA;;AD/C1C,MAAM,gBAAgB,GAAG,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC;AAEpD;;;;;;;;;;;;;;;;;;;GAmBG;AAMH,MAAM,OAAO,cAAe,SAAQ,kBAAkB;IAMhC;IAAwB;IALC,YAAY,CAAa;IAEtE,WAAW,CAAU;IACrB,QAAQ,CAAM;IAEd,YAAoB,EAAc,EAAU,eAAkC;QAC5E,KAAK,EAAE,CAAC;QADU,OAAE,GAAF,EAAE,CAAY;QAAU,oBAAe,GAAf,eAAe,CAAmB;QAE5E,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC;QACzD,IAAI,CAAC,QAAQ,GAAG;YACd,GAAG,aAAa,CAAC,QAAQ,CAAC;SAC3B,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC;IACrD,CAAC;IAED,IAAI,YAAY;QACd,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,SAAS,CAAC,MAAM;gBACnB,OAAO,SAAS,CAAC,MAAM,CAAC;YAE1B,KAAK,SAAS,CAAC,IAAI;gBACjB,OAAO,SAAS,CAAC,IAAI,CAAC;YAExB,KAAK,SAAS,CAAC,OAAO;gBACpB,OAAO,SAAS,CAAC,OAAO,CAAC;YAE3B,KAAK,SAAS,CAAC,OAAO;gBACpB,OAAO,SAAS,CAAC,OAAO,CAAC;SAC5B;IACH,CAAC;IAED,IAAI,QAAQ;QACV,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YAChC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC;SAC7E;QAED,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;SACpE;QAED,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACxC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,gBAAgB,UAAU,CAAC,CAAC,CAAC,gBAAgB,CAAC;SACxE;IACH,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC;IAC/D,CAAC;IAED,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACrC,MAAM,gBAAgB,GAAc,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;YAC3E,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SACnC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACtD,OAAO,EAAE,kBAAkB,EAAE,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;SACnE;aAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YAClE,OAAO,EAAE,QAAQ,EAAE,YAAY,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;SACtD;aAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,EAAE;YACjE,OAAO,EAAE,QAAQ,EAAE,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,kBAAkB,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;SAChG;aAAM;YACL,OAAO,EAAE,CAAC;SACX;IACH,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,GAAG,GAAG,CAAC;IAC3D,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;IACxG,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;SAChC;IACH,CAAC;wEAhGU,cAAc;6DAAd,cAAc;;;;;;YCpC3B,iCAMC;YACC,+DAEM;YAEN,8BAAkC,aAAA;YAW9B,wFAAS,aAAS,IAAC,iGACF,wBAAoB,IADlB,iGAEF,uBAAuB,IAFrB,6FAGJ,wBAAoB,IAHhB;YAKnB,uEAYU;YAEV,8BAA0B,cAAA;YASrB,YAAW;YAAA,iBACb,EAAA;YAGH,iEAUO;YACT,iBAAM,EAAA,EAAA;;YA9DR,iEAAoD;YACpD,8DAAwC;YAGlC,eAAW;YAAX,gCAAW;YAQb,eAA6D;YAA7D,kFAA6D,sFAAA,mCAAA,kDAAA;YAI7D,sCAAoB,2BAAA,wDAAA;YALpB,wEAAsD;YAcnD,eAAwB;YAAxB,iDAAwB;YAevB,eAMC;YAND,0OAMC;YACA,eAAW;YAAX,+BAAW;YAKb,eAAe;YAAf,oCAAe;;;uFDnBX,cAAc;cAL1B,SAAS;2BACE,QAAQ,mBAED,uBAAuB,CAAC,MAAM;6FAGF,YAAY;kBAAxD,SAAS;mBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","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,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8ta2V5LWNvZGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvZW51bXMvcG8ta2V5LWNvZGUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQU4sSUFBWSxhQW9DWDtBQXBDRCxXQUFZLGFBQWE7SUFDdkIsc0JBQXNCO0lBQ3RCLDREQUFjLENBQUE7SUFFZCxxQkFBcUI7SUFDckIsd0RBQVksQ0FBQTtJQUVaLGdCQUFnQjtJQUNoQiwyREFBYSxDQUFBO0lBRWIsYUFBYTtJQUNiLHNEQUFXLENBQUE7SUFFWCxZQUFZO0lBQ1osb0RBQVUsQ0FBQTtJQUVWLFVBQVU7SUFDVixnREFBUSxDQUFBO0lBRVIsY0FBYztJQUNkLGtEQUFTLENBQUE7SUFFVCxjQUFjO0lBQ2Qsa0RBQVMsQ0FBQTtJQUVULGFBQWE7SUFDYixvREFBVSxDQUFBO0lBRVYsVUFBVTtJQUNWLCtDQUFPLENBQUE7SUFFUCxpQkFBaUI7SUFDakIsa0RBQVMsQ0FBQTtJQUVULGtCQUFrQjtJQUNsQixvREFBVSxDQUFBO0FBQ1osQ0FBQyxFQXBDVyxhQUFhLEtBQWIsYUFBYSxRQW9DeEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkb2NzUHJpdmF0ZVxuICpcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIEVudW0gcXVlIGNvbnTDqW0gb3MgdmFsb3JlcyBudW3DqXJpY29zIGRvcyAqa2V5Q29kZXMqLlxuICovXG5leHBvcnQgZW51bSBQb0tleUNvZGVFbnVtIHtcbiAgLyoqIFNldGEgcGFyYSBiYWl4byAqL1xuICBhcnJvd0Rvd24gPSA0MCxcblxuICAvKiogU2V0YSBwYXJhIGNpbWEgKi9cbiAgYXJyb3dVcCA9IDM4LFxuXG4gIC8qKiBCYWNrc3BhY2UgKi9cbiAgYmFja3NwYWNlID0gOCxcblxuICAvKiogRGVsZXRlICovXG4gIGRlbGV0ZSA9IDQ2LFxuXG4gIC8qKiBFbnRlciAqL1xuICBlbnRlciA9IDEzLFxuXG4gIC8qKiBFc2MgKi9cbiAgZXNjID0gMjcsXG5cbiAgLyoqIFRlY2xhIEsgKi9cbiAga2V5SyA9IDc1LFxuXG4gIC8qKiBUZWNsYSBMICovXG4gIGtleUwgPSA3NixcblxuICAvKiogRXNwYcOnbyAqL1xuICBzcGFjZSA9IDMyLFxuXG4gIC8qKiBUYWIgKi9cbiAgdGFiID0gOSxcblxuICAvKiogQXJyb3cgTGVmdCAqL1xuICBsZWZ0ID0gMzcsXG5cbiAgLyoqIEFycm93IFJpZ2h0ICovXG4gIHJpZ2h0ID0gMzlcbn1cbiJdfQ==
|