@po-ui/ng-components 15.8.2 → 15.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/po-tag/po-tag-base.component.mjs +51 -3
- package/esm2020/lib/components/po-tag/po-tag.component.mjs +68 -26
- package/esm2020/lib/components/po-tag/po-tag.literals.mjs +15 -0
- package/fesm2015/po-ui-ng-components.mjs +125 -23
- package/fesm2015/po-ui-ng-components.mjs.map +1 -1
- package/fesm2020/po-ui-ng-components.mjs +124 -23
- package/fesm2020/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-tag/po-tag-base.component.d.ts +30 -1
- package/lib/components/po-tag/po-tag.component.d.ts +8 -0
- package/lib/components/po-tag/po-tag.literals.d.ts +14 -0
- package/package.json +4 -4
- package/po-ui-ng-components-15.9.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/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-15.8.2.tgz +0 -0
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
1
2
|
import { EventEmitter, Input, Output, Directive } from '@angular/core';
|
|
2
3
|
import { convertToBoolean } from '../../utils/util';
|
|
3
4
|
import { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';
|
|
4
5
|
import { PoTagOrientation } from './enums/po-tag-orientation.enum';
|
|
5
6
|
import { PoTagType } from './enums/po-tag-type.enum';
|
|
7
|
+
import { InputBoolean } from '../../decorators';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
const poTagColors = Object.values(PoColorPaletteEnum);
|
|
8
10
|
const poTagOrientationDefault = PoTagOrientation.Vertical;
|
|
@@ -19,6 +21,27 @@ const poTagOrientationDefault = PoTagOrientation.Vertical;
|
|
|
19
21
|
*/
|
|
20
22
|
export class PoTagBaseComponent {
|
|
21
23
|
constructor() {
|
|
24
|
+
/**
|
|
25
|
+
* @optional
|
|
26
|
+
*
|
|
27
|
+
* @description
|
|
28
|
+
*
|
|
29
|
+
* Habilita a opção de remover a tag
|
|
30
|
+
*
|
|
31
|
+
* @default `false`
|
|
32
|
+
*/
|
|
33
|
+
this.removable = false;
|
|
34
|
+
/**
|
|
35
|
+
* @optional
|
|
36
|
+
*
|
|
37
|
+
* @description
|
|
38
|
+
*
|
|
39
|
+
* Desabilita o `po-tag` e não permite que o usuário interaja com o mesmo.
|
|
40
|
+
* > A propriedade `p-disabled` somente terá efeito caso a propriedade `p-removable` esteja definida como `true`.
|
|
41
|
+
*
|
|
42
|
+
* @default `false`
|
|
43
|
+
*/
|
|
44
|
+
this.disabled = false;
|
|
22
45
|
/**
|
|
23
46
|
* @deprecated 16.x.x
|
|
24
47
|
*
|
|
@@ -34,6 +57,14 @@ export class PoTagBaseComponent {
|
|
|
34
57
|
* 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.
|
|
35
58
|
*/
|
|
36
59
|
this.click = new EventEmitter();
|
|
60
|
+
/**
|
|
61
|
+
* @optional
|
|
62
|
+
*
|
|
63
|
+
* @description
|
|
64
|
+
*
|
|
65
|
+
* Ação que sera executada quando clicar sobre o ícone de remover no `po-tag`
|
|
66
|
+
*/
|
|
67
|
+
this.remove = new EventEmitter();
|
|
37
68
|
this.poTagOrientation = PoTagOrientation;
|
|
38
69
|
this._orientation = poTagOrientationDefault;
|
|
39
70
|
}
|
|
@@ -210,25 +241,42 @@ export class PoTagBaseComponent {
|
|
|
210
241
|
* @default `info`
|
|
211
242
|
*/
|
|
212
243
|
set type(value) {
|
|
213
|
-
|
|
244
|
+
if (!this.removable) {
|
|
245
|
+
this._type = Object.values(PoTagType).includes(value) ? value : undefined;
|
|
246
|
+
}
|
|
214
247
|
}
|
|
215
248
|
get type() {
|
|
216
249
|
return this._type;
|
|
217
250
|
}
|
|
218
251
|
}
|
|
219
252
|
PoTagBaseComponent.ɵfac = function PoTagBaseComponent_Factory(t) { return new (t || PoTagBaseComponent)(); };
|
|
220
|
-
PoTagBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTagBaseComponent, inputs: { label: ["p-label", "label"], 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" } });
|
|
253
|
+
PoTagBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTagBaseComponent, inputs: { label: ["p-label", "label"], removable: ["p-removable", "removable"], disabled: ["p-disabled", "disabled"], 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" } });
|
|
254
|
+
__decorate([
|
|
255
|
+
InputBoolean()
|
|
256
|
+
], PoTagBaseComponent.prototype, "removable", void 0);
|
|
257
|
+
__decorate([
|
|
258
|
+
InputBoolean()
|
|
259
|
+
], PoTagBaseComponent.prototype, "disabled", void 0);
|
|
221
260
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTagBaseComponent, [{
|
|
222
261
|
type: Directive
|
|
223
262
|
}], null, { label: [{
|
|
224
263
|
type: Input,
|
|
225
264
|
args: ['p-label']
|
|
265
|
+
}], removable: [{
|
|
266
|
+
type: Input,
|
|
267
|
+
args: ['p-removable']
|
|
268
|
+
}], disabled: [{
|
|
269
|
+
type: Input,
|
|
270
|
+
args: ['p-disabled']
|
|
226
271
|
}], value: [{
|
|
227
272
|
type: Input,
|
|
228
273
|
args: ['p-value']
|
|
229
274
|
}], click: [{
|
|
230
275
|
type: Output,
|
|
231
276
|
args: ['p-click']
|
|
277
|
+
}], remove: [{
|
|
278
|
+
type: Output,
|
|
279
|
+
args: ['p-close']
|
|
232
280
|
}], color: [{
|
|
233
281
|
type: Input,
|
|
234
282
|
args: ['p-color']
|
|
@@ -248,4 +296,4 @@ PoTagBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTagBas
|
|
|
248
296
|
type: Input,
|
|
249
297
|
args: ['p-type']
|
|
250
298
|
}] }); })();
|
|
251
|
-
//# 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 { EventEmitter, Input, Output, Directive, TemplateRef } from '@angular/core';\r\n\r\nimport { convertToBoolean } from '../../utils/util';\r\nimport { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';\r\n\r\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\r\nimport { PoTagOrientation } from './enums/po-tag-orientation.enum';\r\nimport { PoTagType } from './enums/po-tag-type.enum';\r\n\r\nconst poTagColors = (<any>Object).values(PoColorPaletteEnum);\r\nconst poTagOrientationDefault = PoTagOrientation.Vertical;\r\n\r\n/**\r\n * @description\r\n *\r\n * Este componente permite exibir um valor em forma de um marcador colorido, sendo possível definir uma legenda e realizar customizações\r\n * na cor, iconografia e tipo.\r\n *\r\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\r\n * utilizando a tecla *tab*.\r\n *\r\n * Seu uso é recomendado para informações que necessitem de destaque em forma de marcação.\r\n */\r\n@Directive()\r\nexport class PoTagBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define uma legenda que será exibida acima ou ao lado da *tag*, de acordo com a `p-orientation`.\r\n   */\r\n  @Input('p-label') label?: string;\r\n\r\n  /** Texto da tag. */\r\n  @Input('p-value') value: string;\r\n\r\n  /**\r\n   * @deprecated 16.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * **Deprecated 16.x.x**.\r\n   *\r\n   * > Por regras de acessibilidade a tag não terá mais evento de click. Indicamos o uso do `Po-button` ou `Po-link`\r\n   * caso deseje esse comportamento.\r\n   *\r\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.\r\n   */\r\n  @Output('p-click') click: EventEmitter<any> = new EventEmitter<PoTagItem>();\r\n\r\n  public readonly poTagOrientation = PoTagOrientation;\r\n  public customColor;\r\n  public customTextColor;\r\n  private _color?: string;\r\n  private _textColor?: string;\r\n  private _icon?: boolean | string | TemplateRef<void>;\r\n  private _inverse?: boolean;\r\n  private _orientation?: PoTagOrientation = poTagOrientationDefault;\r\n  private _type?: PoTagType;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Determina a cor da tag. As maneiras de customizar as cores são:\r\n   * - Hexadeximal, por exemplo `#c64840`;\r\n   * - RGB, como `rgb(0, 0, 165)`;\r\n   * - O nome da cor, por exemplo `blue`;\r\n   * - Usando uma das cores do tema do PO:\r\n   * Valores válidos:\r\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\r\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\r\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\r\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\r\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\r\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\r\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\r\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\r\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\r\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\r\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\r\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\r\n   *\r\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\r\n   *\r\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\r\n   */\r\n  @Input('p-color') set color(value: string) {\r\n    this._color = poTagColors.includes(value) ? value : undefined;\r\n    if (this._color === undefined) {\r\n      CSS.supports('color', value) ? (this.customColor = value) : (this.customColor = undefined);\r\n    }\r\n  }\r\n\r\n  get color(): string {\r\n    return this._color;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Determina a cor do texto da tag. As maneiras de customizar as cores são:\r\n   * - Hexadeximal, por exemplo `#c64840`;\r\n   * - RGB, como `rgb(0, 0, 165)`;\r\n   * - O nome da cor, por exemplo `blue`;\r\n   * - Usando uma das cores do tema do PO:\r\n   * Valores válidos:\r\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\r\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\r\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\r\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\r\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\r\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\r\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\r\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\r\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\r\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\r\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\r\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\r\n   *\r\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\r\n   *\r\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\r\n   */\r\n  @Input('p-text-color') set textColor(value: string) {\r\n    this._textColor = poTagColors.includes(value) ? value : undefined;\r\n    if (this._textColor === undefined) {\r\n      CSS.supports('color', value) ? (this.customTextColor = value) : (this.customTextColor = undefined);\r\n    }\r\n  }\r\n\r\n  get textColor(): string {\r\n    return this._textColor;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define ou ativa um ícone que será exibido ao lado do valor da *tag*.\r\n   *\r\n   * Quando `p-type` estiver definida, basta informar um valor igual a `true` para que o ícone seja exibido conforme descrições abaixo:\r\n   * - <span class=\"po-icon po-icon-ok\"></span> - `success`\r\n   * - <span class=\"po-icon po-icon-warning\"></span> - `warning`\r\n   * - <span class=\"po-icon po-icon-close\"></span> - `danger`\r\n   * - <span class=\"po-icon po-icon-info\"></span> - `info`\r\n   *\r\n   * Também É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\r\n   * ```\r\n   * <po-tag p-icon=\"po-icon-user\" p-value=\"PO Tag\"></po-tag>\r\n   * ```\r\n   * como também utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\r\n   * ```\r\n   * <po-tag p-icon=\"fa fa-podcast\" p-value=\"PO Tag\"></po-button>\r\n   * ```\r\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\r\n   * ```\r\n   * <po-tag [p-icon]=\"template\" p-value=\"Tag template ionic\"></po-button>\r\n   *\r\n   * <ng-template #template>\r\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\r\n   * </ng-template>\r\n   * ```\r\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-icon') set icon(value: boolean | string | TemplateRef<void>) {\r\n    if (this.type) {\r\n      this._icon = convertToBoolean(value);\r\n    } else {\r\n      this._icon = value;\r\n    }\r\n  }\r\n\r\n  get icon() {\r\n    return this._icon;\r\n  }\r\n\r\n  /**\r\n   * @deprecated 16.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * > Por regras de acessibilidade e usabilidade a tag não terá a inversão de cores no componente.\r\n   *\r\n   * Ativa a inversão de cores configuradas no componente, possibilitando uma visualização de status ativo e inativo.\r\n   *\r\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`,\r\n   * e a cor do fundo fica branca.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-inverse') set inverse(value: boolean) {\r\n    this._inverse = convertToBoolean(value);\r\n  }\r\n\r\n  get inverse(): boolean {\r\n    return this._inverse;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o *layout* de exibição.\r\n   *\r\n   * @default `vertical`\r\n   */\r\n  @Input('p-orientation') set orientation(value: PoTagOrientation) {\r\n    this._orientation = (<any>Object).values(PoTagOrientation).includes(value) ? value : poTagOrientationDefault;\r\n  }\r\n\r\n  get orientation(): PoTagOrientation {\r\n    return this._orientation;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o tipo da *tag*.\r\n   *\r\n   * Valores válidos:\r\n   *  - `success`: cor verde utilizada para simbolizar sucesso ou êxito.\r\n   *  - `warning`: cor amarela que representa aviso ou advertência.\r\n   *  - `danger`: cor vermelha para erro ou aviso crítico.\r\n   *  - `info`: cor cinza escuro que caracteriza conteúdo informativo.\r\n   *\r\n   * > Quando esta propriedade for definida, irá sobrepor a definição de `p-color` e `p-icon` somente será exibido caso seja `true`.\r\n   *\r\n   * @default `info`\r\n   */\r\n  @Input('p-type') set type(value: PoTagType) {\r\n    this._type = (<any>Object).values(PoTagType).includes(value) ? value : undefined;\r\n  }\r\n\r\n  get type(): PoTagType {\r\n    return this._type;\r\n  }\r\n}\r\n"]}
|
|
299
|
+
//# 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 { EventEmitter, Input, Output, Directive, TemplateRef } from '@angular/core';\r\n\r\nimport { convertToBoolean } from '../../utils/util';\r\nimport { PoColorPaletteEnum } from '../../enums/po-color-palette.enum';\r\n\r\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\r\nimport { PoTagOrientation } from './enums/po-tag-orientation.enum';\r\nimport { PoTagType } from './enums/po-tag-type.enum';\r\nimport { InputBoolean } from '../../decorators';\r\n\r\nconst poTagColors = (<any>Object).values(PoColorPaletteEnum);\r\nconst poTagOrientationDefault = PoTagOrientation.Vertical;\r\n\r\n/**\r\n * @description\r\n *\r\n * Este componente permite exibir um valor em forma de um marcador colorido, sendo possível definir uma legenda e realizar customizações\r\n * na cor, iconografia e tipo.\r\n *\r\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\r\n * utilizando a tecla *tab*.\r\n *\r\n * Seu uso é recomendado para informações que necessitem de destaque em forma de marcação.\r\n */\r\n@Directive()\r\nexport class PoTagBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define uma legenda que será exibida acima ou ao lado da *tag*, de acordo com a `p-orientation`.\r\n   */\r\n  @Input('p-label') label?: string;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Habilita a opção de remover a tag\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-removable') @InputBoolean() removable: boolean = false;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Desabilita o `po-tag` e não permite que o usuário interaja com o mesmo.\r\n   * > A propriedade `p-disabled` somente terá efeito caso a propriedade `p-removable` esteja definida como `true`.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-disabled') @InputBoolean() disabled: boolean = false;\r\n\r\n  /** Texto da tag. */\r\n  @Input('p-value') value: string;\r\n\r\n  /**\r\n   * @deprecated 16.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * **Deprecated 16.x.x**.\r\n   *\r\n   * > Por regras de acessibilidade a tag não terá mais evento de click. Indicamos o uso do `Po-button` ou `Po-link`\r\n   * caso deseje esse comportamento.\r\n   *\r\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.\r\n   */\r\n  @Output('p-click') click: EventEmitter<any> = new EventEmitter<PoTagItem>();\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Ação que sera executada quando clicar sobre o ícone de remover no `po-tag`\r\n   */\r\n  @Output('p-close') remove: EventEmitter<null> = new EventEmitter<null>();\r\n\r\n  public readonly poTagOrientation = PoTagOrientation;\r\n  public customColor;\r\n  public customTextColor;\r\n  private _color?: string;\r\n  private _textColor?: string;\r\n  private _icon?: boolean | string | TemplateRef<void>;\r\n  private _inverse?: boolean;\r\n  private _orientation?: PoTagOrientation = poTagOrientationDefault;\r\n  private _type?: PoTagType;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Determina a cor da tag. As maneiras de customizar as cores são:\r\n   * - Hexadeximal, por exemplo `#c64840`;\r\n   * - RGB, como `rgb(0, 0, 165)`;\r\n   * - O nome da cor, por exemplo `blue`;\r\n   * - Usando uma das cores do tema do PO:\r\n   * Valores válidos:\r\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\r\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\r\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\r\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\r\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\r\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\r\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\r\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\r\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\r\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\r\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\r\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\r\n   *\r\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\r\n   *\r\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\r\n   */\r\n  @Input('p-color') set color(value: string) {\r\n    this._color = poTagColors.includes(value) ? value : undefined;\r\n    if (this._color === undefined) {\r\n      CSS.supports('color', value) ? (this.customColor = value) : (this.customColor = undefined);\r\n    }\r\n  }\r\n\r\n  get color(): string {\r\n    return this._color;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Determina a cor do texto da tag. As maneiras de customizar as cores são:\r\n   * - Hexadeximal, por exemplo `#c64840`;\r\n   * - RGB, como `rgb(0, 0, 165)`;\r\n   * - O nome da cor, por exemplo `blue`;\r\n   * - Usando uma das cores do tema do PO:\r\n   * Valores válidos:\r\n   *  - <span class=\"dot po-color-01\"></span> `color-01`\r\n   *  - <span class=\"dot po-color-02\"></span> `color-02`\r\n   *  - <span class=\"dot po-color-03\"></span> `color-03`\r\n   *  - <span class=\"dot po-color-04\"></span> `color-04`\r\n   *  - <span class=\"dot po-color-05\"></span> `color-05`\r\n   *  - <span class=\"dot po-color-06\"></span> `color-06`\r\n   *  - <span class=\"dot po-color-07\"></span> `color-07`\r\n   *  - <span class=\"dot po-color-08\"></span> `color-08`\r\n   *  - <span class=\"dot po-color-09\"></span> `color-09`\r\n   *  - <span class=\"dot po-color-10\"></span> `color-10`\r\n   *  - <span class=\"dot po-color-11\"></span> `color-11`\r\n   *  - <span class=\"dot po-color-12\"></span> `color-12`\r\n   *\r\n   * - Para uma melhor acessibilidade no uso do componente é recomendável utilizar cores com um melhor contraste em relação ao background.\r\n   *\r\n   * > **Atenção:** A propriedade `p-type` sobrepõe esta definição.\r\n   */\r\n  @Input('p-text-color') set textColor(value: string) {\r\n    this._textColor = poTagColors.includes(value) ? value : undefined;\r\n    if (this._textColor === undefined) {\r\n      CSS.supports('color', value) ? (this.customTextColor = value) : (this.customTextColor = undefined);\r\n    }\r\n  }\r\n\r\n  get textColor(): string {\r\n    return this._textColor;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define ou ativa um ícone que será exibido ao lado do valor da *tag*.\r\n   *\r\n   * Quando `p-type` estiver definida, basta informar um valor igual a `true` para que o ícone seja exibido conforme descrições abaixo:\r\n   * - <span class=\"po-icon po-icon-ok\"></span> - `success`\r\n   * - <span class=\"po-icon po-icon-warning\"></span> - `warning`\r\n   * - <span class=\"po-icon po-icon-close\"></span> - `danger`\r\n   * - <span class=\"po-icon po-icon-info\"></span> - `info`\r\n   *\r\n   * Também É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\r\n   * ```\r\n   * <po-tag p-icon=\"po-icon-user\" p-value=\"PO Tag\"></po-tag>\r\n   * ```\r\n   * como também utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\r\n   * ```\r\n   * <po-tag p-icon=\"fa fa-podcast\" p-value=\"PO Tag\"></po-button>\r\n   * ```\r\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\r\n   * ```\r\n   * <po-tag [p-icon]=\"template\" p-value=\"Tag template ionic\"></po-button>\r\n   *\r\n   * <ng-template #template>\r\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\r\n   * </ng-template>\r\n   * ```\r\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-icon') set icon(value: boolean | string | TemplateRef<void>) {\r\n    if (this.type) {\r\n      this._icon = convertToBoolean(value);\r\n    } else {\r\n      this._icon = value;\r\n    }\r\n  }\r\n\r\n  get icon() {\r\n    return this._icon;\r\n  }\r\n\r\n  /**\r\n   * @deprecated 16.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * > Por regras de acessibilidade e usabilidade a tag não terá a inversão de cores no componente.\r\n   *\r\n   * Ativa a inversão de cores configuradas no componente, possibilitando uma visualização de status ativo e inativo.\r\n   *\r\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`,\r\n   * e a cor do fundo fica branca.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-inverse') set inverse(value: boolean) {\r\n    this._inverse = convertToBoolean(value);\r\n  }\r\n\r\n  get inverse(): boolean {\r\n    return this._inverse;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o *layout* de exibição.\r\n   *\r\n   * @default `vertical`\r\n   */\r\n  @Input('p-orientation') set orientation(value: PoTagOrientation) {\r\n    this._orientation = (<any>Object).values(PoTagOrientation).includes(value) ? value : poTagOrientationDefault;\r\n  }\r\n\r\n  get orientation(): PoTagOrientation {\r\n    return this._orientation;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o tipo da *tag*.\r\n   *\r\n   * Valores válidos:\r\n   *  - `success`: cor verde utilizada para simbolizar sucesso ou êxito.\r\n   *  - `warning`: cor amarela que representa aviso ou advertência.\r\n   *  - `danger`: cor vermelha para erro ou aviso crítico.\r\n   *  - `info`: cor cinza escuro que caracteriza conteúdo informativo.\r\n   *\r\n   * > Quando esta propriedade for definida, irá sobrepor a definição de `p-color` e `p-icon` somente será exibido caso seja `true`.\r\n   *\r\n   * @default `info`\r\n   */\r\n  @Input('p-type') set type(value: PoTagType) {\r\n    if (!this.removable) {\r\n      this._type = (<any>Object).values(PoTagType).includes(value) ? value : undefined;\r\n    }\r\n  }\r\n\r\n  get type(): PoTagType {\r\n    return this._type;\r\n  }\r\n}\r\n"]}
|
|
@@ -2,13 +2,15 @@ import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
|
|
|
2
2
|
import { PoTagBaseComponent } from './po-tag-base.component';
|
|
3
3
|
import { PoTagIcon } from './enums/po-tag-icon.enum';
|
|
4
4
|
import { PoTagType } from './enums/po-tag-type.enum';
|
|
5
|
+
import { PoTagLiterals } from './po-tag.literals';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "
|
|
7
|
+
import * as i1 from "./../../services/po-language/po-language.service";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "../po-icon/po-icon.component";
|
|
10
|
+
import * as i4 from "../../directives/po-tooltip/po-tooltip.directive";
|
|
9
11
|
const _c0 = ["tagContainer"];
|
|
10
12
|
function PoTagComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
11
|
-
i0.ɵɵelementStart(0, "div",
|
|
13
|
+
i0.ɵɵelementStart(0, "div", 9)(1, "span", 10);
|
|
12
14
|
i0.ɵɵtext(2);
|
|
13
15
|
i0.ɵɵelementEnd()();
|
|
14
16
|
} if (rf & 2) {
|
|
@@ -18,11 +20,22 @@ function PoTagComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
|
18
20
|
} }
|
|
19
21
|
const _c1 = function (a0) { return { "color": a0 }; };
|
|
20
22
|
function PoTagComponent_po_icon_5_Template(rf, ctx) { if (rf & 1) {
|
|
21
|
-
i0.ɵɵelement(0, "po-icon",
|
|
23
|
+
i0.ɵɵelement(0, "po-icon", 11);
|
|
22
24
|
} if (rf & 2) {
|
|
23
25
|
const ctx_r2 = i0.ɵɵnextContext();
|
|
24
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) : "");
|
|
25
27
|
} }
|
|
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()); });
|
|
32
|
+
i0.ɵɵelementEnd();
|
|
33
|
+
} 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" : "");
|
|
38
|
+
} }
|
|
26
39
|
const poTagTypeDefault = 'po-tag-' + PoTagType.Info;
|
|
27
40
|
/**
|
|
28
41
|
* @docsExtends PoTagBaseComponent
|
|
@@ -45,6 +58,15 @@ const poTagTypeDefault = 'po-tag-' + PoTagType.Info;
|
|
|
45
58
|
* </example>
|
|
46
59
|
*/
|
|
47
60
|
export class PoTagComponent extends PoTagBaseComponent {
|
|
61
|
+
constructor(el, languageService) {
|
|
62
|
+
super();
|
|
63
|
+
this.el = el;
|
|
64
|
+
this.languageService = languageService;
|
|
65
|
+
const language = this.languageService.getShortLanguage();
|
|
66
|
+
this.literals = {
|
|
67
|
+
...PoTagLiterals[language]
|
|
68
|
+
};
|
|
69
|
+
}
|
|
48
70
|
ngOnInit() {
|
|
49
71
|
this.isClickable = this.click.observers.length > 0;
|
|
50
72
|
}
|
|
@@ -61,13 +83,13 @@ export class PoTagComponent extends PoTagBaseComponent {
|
|
|
61
83
|
}
|
|
62
84
|
}
|
|
63
85
|
get tagColor() {
|
|
64
|
-
if (this.type) {
|
|
86
|
+
if (this.type && !this.removable) {
|
|
65
87
|
return this.inverse ? `po-tag-${this.type}-inverse` : `po-tag-${this.type}`;
|
|
66
88
|
}
|
|
67
|
-
if (this.color) {
|
|
89
|
+
if (this.color && !this.removable) {
|
|
68
90
|
return this.inverse ? `po-text-${this.color}` : `po-${this.color}`;
|
|
69
91
|
}
|
|
70
|
-
if (!this.customColor) {
|
|
92
|
+
if (!this.customColor && !this.removable) {
|
|
71
93
|
return this.inverse ? `${poTagTypeDefault}-inverse` : poTagTypeDefault;
|
|
72
94
|
}
|
|
73
95
|
}
|
|
@@ -75,8 +97,16 @@ export class PoTagComponent extends PoTagBaseComponent {
|
|
|
75
97
|
return this.orientation === this.poTagOrientation.Horizontal;
|
|
76
98
|
}
|
|
77
99
|
onClick() {
|
|
78
|
-
|
|
79
|
-
|
|
100
|
+
if (!this.removable && !this.disabled) {
|
|
101
|
+
const submittedTagItem = { value: this.value, type: this.type };
|
|
102
|
+
this.click.emit(submittedTagItem);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
onClose() {
|
|
106
|
+
if (!this.disabled) {
|
|
107
|
+
this.click.emit(null);
|
|
108
|
+
this.onRemove();
|
|
109
|
+
}
|
|
80
110
|
}
|
|
81
111
|
onKeyPressed(event) {
|
|
82
112
|
event.preventDefault();
|
|
@@ -84,7 +114,7 @@ export class PoTagComponent extends PoTagBaseComponent {
|
|
|
84
114
|
this.onClick();
|
|
85
115
|
}
|
|
86
116
|
styleTag() {
|
|
87
|
-
if (!this.tagColor && !this.inverse) {
|
|
117
|
+
if (!this.tagColor && !this.inverse && !this.removable) {
|
|
88
118
|
return { 'background-color': this.customColor, 'color': 'white' };
|
|
89
119
|
}
|
|
90
120
|
else if (!this.tagColor && this.inverse && !this.customTextColor) {
|
|
@@ -100,43 +130,55 @@ export class PoTagComponent extends PoTagBaseComponent {
|
|
|
100
130
|
getWidthTag() {
|
|
101
131
|
return this.tagContainer.nativeElement.offsetWidth > 155;
|
|
102
132
|
}
|
|
133
|
+
setAriaLabel() {
|
|
134
|
+
return this.label ? this.label + ' ' + this.literals.remove : this.value + ' ' + this.literals.remove;
|
|
135
|
+
}
|
|
136
|
+
onRemove() {
|
|
137
|
+
if (!this.disabled) {
|
|
138
|
+
this.el.nativeElement.remove();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
103
141
|
}
|
|
104
|
-
PoTagComponent.ɵfac =
|
|
142
|
+
PoTagComponent.ɵfac = function PoTagComponent_Factory(t) { return new (t || PoTagComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
|
|
105
143
|
PoTagComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTagComponent, selectors: [["po-tag"]], viewQuery: function PoTagComponent_Query(rf, ctx) { if (rf & 1) {
|
|
106
144
|
i0.ɵɵviewQuery(_c0, 7);
|
|
107
145
|
} if (rf & 2) {
|
|
108
146
|
let _t;
|
|
109
147
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tagContainer = _t.first);
|
|
110
|
-
} }, features: [i0.ɵɵInheritDefinitionFeature], decls:
|
|
148
|
+
} }, 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) {
|
|
111
149
|
i0.ɵɵelementStart(0, "div", 0, 1);
|
|
112
150
|
i0.ɵɵtemplate(2, PoTagComponent_div_2_Template, 3, 1, "div", 2);
|
|
113
151
|
i0.ɵɵelementStart(3, "div", 3)(4, "div", 4);
|
|
114
152
|
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); });
|
|
115
153
|
i0.ɵɵtemplate(5, PoTagComponent_po_icon_5_Template, 1, 6, "po-icon", 5);
|
|
116
|
-
i0.ɵɵelementStart(6, "
|
|
117
|
-
i0.ɵɵtext(
|
|
118
|
-
i0.ɵɵelementEnd()()
|
|
154
|
+
i0.ɵɵelementStart(6, "div", 6)(7, "span", 7);
|
|
155
|
+
i0.ɵɵtext(8);
|
|
156
|
+
i0.ɵɵelementEnd()();
|
|
157
|
+
i0.ɵɵtemplate(9, PoTagComponent_span_9_Template, 1, 5, "span", 8);
|
|
158
|
+
i0.ɵɵelementEnd()()();
|
|
119
159
|
} if (rf & 2) {
|
|
120
160
|
i0.ɵɵclassProp("po-tag-container-horizontal", ctx.tagOrientation);
|
|
121
161
|
i0.ɵɵproperty("p-tooltip", ctx.getWidthTag() ? ctx.value : "");
|
|
122
162
|
i0.ɵɵadvance(2);
|
|
123
163
|
i0.ɵɵproperty("ngIf", ctx.label);
|
|
124
164
|
i0.ɵɵadvance(2);
|
|
125
|
-
i0.ɵɵclassProp("po-clickable", ctx.isClickable)("po-tag-inverse", ctx.inverse && !ctx.type && !ctx.customTextColor);
|
|
126
|
-
i0.ɵɵproperty("ngClass", ctx.tagColor)("ngStyle", ctx.styleTag());
|
|
127
|
-
i0.ɵɵattribute("role", ctx.isClickable ? "button" : "");
|
|
165
|
+
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);
|
|
166
|
+
i0.ɵɵproperty("ngClass", ctx.tagColor)("ngStyle", ctx.styleTag())("tabindex", ctx.isClickable && !ctx.removable ? 0 : -1);
|
|
167
|
+
i0.ɵɵattribute("role", ctx.isClickable && !ctx.disabled ? "button" : "");
|
|
128
168
|
i0.ɵɵadvance(1);
|
|
129
|
-
i0.ɵɵproperty("ngIf", ctx.icon);
|
|
130
|
-
i0.ɵɵadvance(
|
|
131
|
-
i0.ɵɵproperty("ngStyle", !ctx.tagColor && ctx.inverse && !ctx.customTextColor ? i0.ɵɵpureFunction1(
|
|
169
|
+
i0.ɵɵproperty("ngIf", ctx.icon && !ctx.removable);
|
|
170
|
+
i0.ɵɵadvance(2);
|
|
171
|
+
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) : "");
|
|
132
172
|
i0.ɵɵadvance(1);
|
|
133
173
|
i0.ɵɵtextInterpolate(ctx.value);
|
|
134
|
-
|
|
174
|
+
i0.ɵɵadvance(1);
|
|
175
|
+
i0.ɵɵproperty("ngIf", ctx.removable);
|
|
176
|
+
} }, dependencies: [i2.NgClass, i2.NgIf, i2.NgStyle, i3.PoIconComponent, i4.PoTooltipDirective], encapsulation: 2, changeDetection: 0 });
|
|
135
177
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTagComponent, [{
|
|
136
178
|
type: Component,
|
|
137
|
-
args: [{ selector: 'po-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n #tagContainer\r\n class=\"po-tag-container\"\r\n [class.po-tag-container-horizontal]=\"tagOrientation\"\r\n [p-tooltip]=\"getWidthTag() ? value : ''\"\r\n p-tooltip-position=\"top\"\r\n>\r\n <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\r\n <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\r\n </div>\r\n\r\n <div class=\"po-tag-sub-container\">\r\n <div\r\n class=\"po-tag\"\r\n [attr.role]=\"isClickable ? 'button' : ''\"\r\n [class.po-clickable]=\"isClickable\"\r\n [class.po-tag-inverse]=\"inverse && !type && !customTextColor\"\r\n [ngClass]=\"tagColor\"\r\n [ngStyle]=\"styleTag()\"\r\n tabindex=\"0\"\r\n (click)=\"onClick()\"\r\n (keydown.enter)=\"onKeyPressed($event)\"\r\n (keydown.space)=\"$event.preventDefault()\"\r\n (keyup.space)=\"onKeyPressed($event)\"\r\n >\r\n <po-icon\r\n *ngIf=\"icon\"\r\n class=\"po-tag-icon\"\r\n [p-icon]=\"!type ? icon : iconFromType\"\r\n [ngStyle]=\"\r\n !tagColor && inverse && !customTextColor\r\n ? { 'color': customColor }\r\n : !type && customTextColor\r\n ? { 'color': customTextColor }\r\n : ''\r\n \"\r\n >\r\n </po-icon>\r\n\r\n <
|
|
138
|
-
}],
|
|
179
|
+
args: [{ selector: 'po-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n #tagContainer\r\n class=\"po-tag-container\"\r\n [class.po-tag-container-horizontal]=\"tagOrientation\"\r\n [p-tooltip]=\"getWidthTag() ? value : ''\"\r\n p-tooltip-position=\"top\"\r\n>\r\n <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\r\n <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\r\n </div>\r\n\r\n <div class=\"po-tag-sub-container\">\r\n <div\r\n class=\"po-tag\"\r\n [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\r\n [class.po-clickable]=\"isClickable && !disabled && !removable\"\r\n [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\r\n [class.po-tag-removable]=\"removable\"\r\n [class.po-tag-disabled]=\"disabled && removable\"\r\n [ngClass]=\"tagColor\"\r\n [ngStyle]=\"styleTag()\"\r\n [tabindex]=\"isClickable && !removable ? 0 : -1\"\r\n (click)=\"onClick()\"\r\n (keydown.enter)=\"onKeyPressed($event)\"\r\n (keydown.space)=\"$event.preventDefault()\"\r\n (keyup.space)=\"onKeyPressed($event)\"\r\n >\r\n <po-icon\r\n *ngIf=\"icon && !removable\"\r\n class=\"po-tag-icon\"\r\n [p-icon]=\"!type ? icon : iconFromType\"\r\n [ngStyle]=\"\r\n !tagColor && inverse && !customTextColor\r\n ? { 'color': customColor }\r\n : !type && customTextColor\r\n ? { 'color': customTextColor }\r\n : ''\r\n \"\r\n >\r\n </po-icon>\r\n\r\n <div class=\"po-tag-value\">\r\n <span\r\n [ngStyle]=\"\r\n !tagColor && inverse && !customTextColor\r\n ? { 'color': customColor }\r\n : !type && customTextColor && !removable\r\n ? { 'color': customTextColor }\r\n : ''\r\n \"\r\n >{{ value }}</span\r\n >\r\n </div>\r\n\r\n <span\r\n *ngIf=\"removable\"\r\n [attr.aria-label]=\"setAriaLabel()\"\r\n class=\"po-tag-remove po-icon po-icon-close\"\r\n [class.po-clickable]=\"!disabled\"\r\n [tabindex]=\"!disabled ? 0 : -1\"\r\n [attr.role]=\"!disabled ? 'button' : ''\"\r\n (click)=\"onClose()\"\r\n (keydown.enter)=\"onClose()\"\r\n >\r\n </span>\r\n </div>\r\n </div>\r\n</div>\r\n" }]
|
|
180
|
+
}], function () { return [{ type: i0.ElementRef }, { type: i1.PoLanguageService }]; }, { tagContainer: [{
|
|
139
181
|
type: ViewChild,
|
|
140
182
|
args: ['tagContainer', { static: true }]
|
|
141
183
|
}] }); })();
|
|
142
|
-
//# 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';\r\n\r\nimport { PoTagBaseComponent } from './po-tag-base.component';\r\nimport { PoTagIcon } from './enums/po-tag-icon.enum';\r\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\r\nimport { PoTagType } from './enums/po-tag-type.enum';\r\n\r\nconst poTagTypeDefault = 'po-tag-' + PoTagType.Info;\r\n\r\n/**\r\n * @docsExtends PoTagBaseComponent\r\n *\r\n * @example\r\n *\r\n * <example name=\"po-tag-basic\" title=\"PO Tag Basic\">\r\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.ts\"> </file>\r\n * </example>\r\n *\r\n * <example name=\"po-tag-labs\" title=\"PO Tag Labs\">\r\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.ts\"> </file>\r\n * </example>\r\n *\r\n * <example name=\"po-tag-bank-account\" title=\"PO Tag - Bank Account\">\r\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.ts\"> </file>\r\n * </example>\r\n */\r\n@Component({\r\n  selector: 'po-tag',\r\n  templateUrl: './po-tag.component.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PoTagComponent extends PoTagBaseComponent implements OnInit {\r\n  @ViewChild('tagContainer', { static: true }) tagContainer: ElementRef;\r\n\r\n  isClickable: boolean;\r\n\r\n  ngOnInit() {\r\n    this.isClickable = this.click.observers.length > 0;\r\n  }\r\n\r\n  get iconFromType() {\r\n    switch (this.type) {\r\n      case PoTagType.Danger:\r\n        return PoTagIcon.Danger;\r\n\r\n      case PoTagType.Info:\r\n        return PoTagIcon.Info;\r\n\r\n      case PoTagType.Success:\r\n        return PoTagIcon.Success;\r\n\r\n      case PoTagType.Warning:\r\n        return PoTagIcon.Warning;\r\n    }\r\n  }\r\n\r\n  get tagColor() {\r\n    if (this.type) {\r\n      return this.inverse ? `po-tag-${this.type}-inverse` : `po-tag-${this.type}`;\r\n    }\r\n\r\n    if (this.color) {\r\n      return this.inverse ? `po-text-${this.color}` : `po-${this.color}`;\r\n    }\r\n\r\n    if (!this.customColor) {\r\n      return this.inverse ? `${poTagTypeDefault}-inverse` : poTagTypeDefault;\r\n    }\r\n  }\r\n\r\n  get tagOrientation() {\r\n    return this.orientation === this.poTagOrientation.Horizontal;\r\n  }\r\n\r\n  onClick() {\r\n    const submittedTagItem: PoTagItem = { value: this.value, type: this.type };\r\n    this.click.emit(submittedTagItem);\r\n  }\r\n\r\n  onKeyPressed(event) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.onClick();\r\n  }\r\n\r\n  styleTag() {\r\n    if (!this.tagColor && !this.inverse) {\r\n      return { 'background-color': this.customColor, 'color': 'white' };\r\n    } else if (!this.tagColor && this.inverse && !this.customTextColor) {\r\n      return { 'border': '1px solid ' + this.customColor };\r\n    } else if (!this.tagColor && this.inverse && this.customTextColor) {\r\n      return { 'border': '1px solid ' + this.customTextColor, 'background-color': this.customColor };\r\n    } else {\r\n      return {};\r\n    }\r\n  }\r\n\r\n  getWidthTag() {\r\n    return this.tagContainer.nativeElement.offsetWidth > 155;\r\n  }\r\n}\r\n","<div\r\n  #tagContainer\r\n  class=\"po-tag-container\"\r\n  [class.po-tag-container-horizontal]=\"tagOrientation\"\r\n  [p-tooltip]=\"getWidthTag() ? value : ''\"\r\n  p-tooltip-position=\"top\"\r\n>\r\n  <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\r\n    <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\r\n  </div>\r\n\r\n  <div class=\"po-tag-sub-container\">\r\n    <div\r\n      class=\"po-tag\"\r\n      [attr.role]=\"isClickable ? 'button' : ''\"\r\n      [class.po-clickable]=\"isClickable\"\r\n      [class.po-tag-inverse]=\"inverse && !type && !customTextColor\"\r\n      [ngClass]=\"tagColor\"\r\n      [ngStyle]=\"styleTag()\"\r\n      tabindex=\"0\"\r\n      (click)=\"onClick()\"\r\n      (keydown.enter)=\"onKeyPressed($event)\"\r\n      (keydown.space)=\"$event.preventDefault()\"\r\n      (keyup.space)=\"onKeyPressed($event)\"\r\n    >\r\n      <po-icon\r\n        *ngIf=\"icon\"\r\n        class=\"po-tag-icon\"\r\n        [p-icon]=\"!type ? icon : iconFromType\"\r\n        [ngStyle]=\"\r\n          !tagColor && inverse && !customTextColor\r\n            ? { 'color': customColor }\r\n            : !type && customTextColor\r\n            ? { 'color': customTextColor }\r\n            : ''\r\n        \"\r\n      >\r\n      </po-icon>\r\n\r\n      <span\r\n        class=\"po-tag-value\"\r\n        [ngStyle]=\"\r\n          !tagColor && inverse && !customTextColor\r\n            ? { 'color': customColor }\r\n            : !type && customTextColor\r\n            ? { 'color': customTextColor }\r\n            : ''\r\n        \"\r\n        >{{ value }}</span\r\n      >\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
184
|
+
//# 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';\r\nimport { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\r\n\r\nimport { PoTagBaseComponent } from './po-tag-base.component';\r\nimport { PoTagIcon } from './enums/po-tag-icon.enum';\r\nimport { PoTagItem } from './interfaces/po-tag-item.interface';\r\nimport { PoTagType } from './enums/po-tag-type.enum';\r\nimport { PoTagLiterals } from './po-tag.literals';\r\n\r\nconst poTagTypeDefault = 'po-tag-' + PoTagType.Info;\r\n\r\n/**\r\n * @docsExtends PoTagBaseComponent\r\n *\r\n * @example\r\n *\r\n * <example name=\"po-tag-basic\" title=\"PO Tag Basic\">\r\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-basic/sample-po-tag-basic.component.ts\"> </file>\r\n * </example>\r\n *\r\n * <example name=\"po-tag-labs\" title=\"PO Tag Labs\">\r\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-labs/sample-po-tag-labs.component.ts\"> </file>\r\n * </example>\r\n *\r\n * <example name=\"po-tag-bank-account\" title=\"PO Tag - Bank Account\">\r\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.html\"> </file>\r\n *  <file name=\"sample-po-tag-bank-account/sample-po-tag-bank-account.component.ts\"> </file>\r\n * </example>\r\n */\r\n@Component({\r\n  selector: 'po-tag',\r\n  templateUrl: './po-tag.component.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PoTagComponent extends PoTagBaseComponent implements OnInit {\r\n  @ViewChild('tagContainer', { static: true }) tagContainer: ElementRef;\r\n\r\n  isClickable: boolean;\r\n  literals: any;\r\n\r\n  constructor(private el: ElementRef, private languageService: PoLanguageService) {\r\n    super();\r\n    const language = this.languageService.getShortLanguage();\r\n    this.literals = {\r\n      ...PoTagLiterals[language]\r\n    };\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.isClickable = this.click.observers.length > 0;\r\n  }\r\n\r\n  get iconFromType() {\r\n    switch (this.type) {\r\n      case PoTagType.Danger:\r\n        return PoTagIcon.Danger;\r\n\r\n      case PoTagType.Info:\r\n        return PoTagIcon.Info;\r\n\r\n      case PoTagType.Success:\r\n        return PoTagIcon.Success;\r\n\r\n      case PoTagType.Warning:\r\n        return PoTagIcon.Warning;\r\n    }\r\n  }\r\n\r\n  get tagColor() {\r\n    if (this.type && !this.removable) {\r\n      return this.inverse ? `po-tag-${this.type}-inverse` : `po-tag-${this.type}`;\r\n    }\r\n\r\n    if (this.color && !this.removable) {\r\n      return this.inverse ? `po-text-${this.color}` : `po-${this.color}`;\r\n    }\r\n\r\n    if (!this.customColor && !this.removable) {\r\n      return this.inverse ? `${poTagTypeDefault}-inverse` : poTagTypeDefault;\r\n    }\r\n  }\r\n\r\n  get tagOrientation() {\r\n    return this.orientation === this.poTagOrientation.Horizontal;\r\n  }\r\n\r\n  onClick() {\r\n    if (!this.removable && !this.disabled) {\r\n      const submittedTagItem: PoTagItem = { value: this.value, type: this.type };\r\n      this.click.emit(submittedTagItem);\r\n    }\r\n  }\r\n\r\n  onClose() {\r\n    if (!this.disabled) {\r\n      this.click.emit(null);\r\n      this.onRemove();\r\n    }\r\n  }\r\n\r\n  onKeyPressed(event) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.onClick();\r\n  }\r\n\r\n  styleTag() {\r\n    if (!this.tagColor && !this.inverse && !this.removable) {\r\n      return { 'background-color': this.customColor, 'color': 'white' };\r\n    } else if (!this.tagColor && this.inverse && !this.customTextColor) {\r\n      return { 'border': '1px solid ' + this.customColor };\r\n    } else if (!this.tagColor && this.inverse && this.customTextColor) {\r\n      return { 'border': '1px solid ' + this.customTextColor, 'background-color': this.customColor };\r\n    } else {\r\n      return {};\r\n    }\r\n  }\r\n\r\n  getWidthTag() {\r\n    return this.tagContainer.nativeElement.offsetWidth > 155;\r\n  }\r\n\r\n  setAriaLabel() {\r\n    return this.label ? this.label + ' ' + this.literals.remove : this.value + ' ' + this.literals.remove;\r\n  }\r\n\r\n  private onRemove() {\r\n    if (!this.disabled) {\r\n      this.el.nativeElement.remove();\r\n    }\r\n  }\r\n}\r\n","<div\r\n  #tagContainer\r\n  class=\"po-tag-container\"\r\n  [class.po-tag-container-horizontal]=\"tagOrientation\"\r\n  [p-tooltip]=\"getWidthTag() ? value : ''\"\r\n  p-tooltip-position=\"top\"\r\n>\r\n  <div *ngIf=\"label\" class=\"po-tag-title po-text-nowrap\">\r\n    <span class=\"po-tag-label\">{{ tagOrientation ? label + ':' : label }}</span>\r\n  </div>\r\n\r\n  <div class=\"po-tag-sub-container\">\r\n    <div\r\n      class=\"po-tag\"\r\n      [attr.role]=\"isClickable && !disabled ? 'button' : ''\"\r\n      [class.po-clickable]=\"isClickable && !disabled && !removable\"\r\n      [class.po-tag-inverse]=\"inverse && !type && !customTextColor && !removable\"\r\n      [class.po-tag-removable]=\"removable\"\r\n      [class.po-tag-disabled]=\"disabled && removable\"\r\n      [ngClass]=\"tagColor\"\r\n      [ngStyle]=\"styleTag()\"\r\n      [tabindex]=\"isClickable && !removable ? 0 : -1\"\r\n      (click)=\"onClick()\"\r\n      (keydown.enter)=\"onKeyPressed($event)\"\r\n      (keydown.space)=\"$event.preventDefault()\"\r\n      (keyup.space)=\"onKeyPressed($event)\"\r\n    >\r\n      <po-icon\r\n        *ngIf=\"icon && !removable\"\r\n        class=\"po-tag-icon\"\r\n        [p-icon]=\"!type ? icon : iconFromType\"\r\n        [ngStyle]=\"\r\n          !tagColor && inverse && !customTextColor\r\n            ? { 'color': customColor }\r\n            : !type && customTextColor\r\n            ? { 'color': customTextColor }\r\n            : ''\r\n        \"\r\n      >\r\n      </po-icon>\r\n\r\n      <div class=\"po-tag-value\">\r\n        <span\r\n          [ngStyle]=\"\r\n            !tagColor && inverse && !customTextColor\r\n              ? { 'color': customColor }\r\n              : !type && customTextColor && !removable\r\n              ? { 'color': customTextColor }\r\n              : ''\r\n          \"\r\n          >{{ value }}</span\r\n        >\r\n      </div>\r\n\r\n      <span\r\n        *ngIf=\"removable\"\r\n        [attr.aria-label]=\"setAriaLabel()\"\r\n        class=\"po-tag-remove po-icon po-icon-close\"\r\n        [class.po-clickable]=\"!disabled\"\r\n        [tabindex]=\"!disabled ? 0 : -1\"\r\n        [attr.role]=\"!disabled ? 'button' : ''\"\r\n        (click)=\"onClose()\"\r\n        (keydown.enter)=\"onClose()\"\r\n      >\r\n      </span>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export const PoTagLiterals = {
|
|
2
|
+
en: {
|
|
3
|
+
remove: 'Remove'
|
|
4
|
+
},
|
|
5
|
+
es: {
|
|
6
|
+
remove: 'Eliminar'
|
|
7
|
+
},
|
|
8
|
+
pt: {
|
|
9
|
+
remove: 'Remover'
|
|
10
|
+
},
|
|
11
|
+
ru: {
|
|
12
|
+
remove: 'удалять'
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdGFnLmxpdGVyYWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXRhZy9wby10YWcubGl0ZXJhbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHO0lBQzNCLEVBQUUsRUFBRTtRQUNGLE1BQU0sRUFBRSxRQUFRO0tBQ2pCO0lBQ0QsRUFBRSxFQUFFO1FBQ0YsTUFBTSxFQUFFLFVBQVU7S0FDbkI7SUFDRCxFQUFFLEVBQUU7UUFDRixNQUFNLEVBQUUsU0FBUztLQUNsQjtJQUNELEVBQUUsRUFBRTtRQUNGLE1BQU0sRUFBRSxTQUFTO0tBQ2xCO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBQb1RhZ0xpdGVyYWxzID0ge1xyXG4gIGVuOiB7XHJcbiAgICByZW1vdmU6ICdSZW1vdmUnXHJcbiAgfSxcclxuICBlczoge1xyXG4gICAgcmVtb3ZlOiAnRWxpbWluYXInXHJcbiAgfSxcclxuICBwdDoge1xyXG4gICAgcmVtb3ZlOiAnUmVtb3ZlcidcclxuICB9LFxyXG4gIHJ1OiB7XHJcbiAgICByZW1vdmU6ICfRg9C00LDQu9GP0YLRjCdcclxuICB9XHJcbn07XHJcbiJdfQ==
|