@po-ui/ng-components 14.6.0 → 14.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/esm2020/lib/components/components.module.mjs +14 -7
  2. package/esm2020/lib/components/index.mjs +2 -1
  3. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.mjs +1 -1
  4. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +5 -5
  5. package/esm2020/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-field.interface.mjs +1 -1
  6. package/esm2020/lib/components/po-field/index.mjs +2 -1
  7. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox-base.component.mjs +27 -2
  8. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox-size.enum.mjs +15 -0
  9. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox.component.mjs +4 -4
  10. package/esm2020/lib/components/po-field/po-lookup/interfaces/po-lookup-column.interface.mjs +1 -1
  11. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +2 -2
  12. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +5 -1
  13. package/esm2020/lib/components/po-link/index.mjs +3 -0
  14. package/esm2020/lib/components/po-link/po-link-base.component.mjs +54 -0
  15. package/esm2020/lib/components/po-link/po-link.component.mjs +40 -0
  16. package/esm2020/lib/components/po-link/po-link.module.mjs +24 -0
  17. package/esm2020/lib/components/po-table/interfaces/po-table-column.interface.mjs +1 -1
  18. package/esm2020/lib/components/po-table/po-table-detail/po-table-detail-column.interface.mjs +1 -1
  19. package/esm2020/lib/services/po-language/po-language.service.mjs +3 -1
  20. package/fesm2015/po-ui-ng-components.mjs +184 -16
  21. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  22. package/fesm2020/po-ui-ng-components.mjs +174 -16
  23. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  24. package/lib/components/components.module.d.ts +2 -1
  25. package/lib/components/index.d.ts +1 -0
  26. package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.d.ts +3 -3
  27. package/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-field.interface.d.ts +7 -4
  28. package/lib/components/po-field/index.d.ts +1 -0
  29. package/lib/components/po-field/po-checkbox/po-checkbox-base.component.d.ts +18 -1
  30. package/lib/components/po-field/po-checkbox/po-checkbox-size.enum.d.ts +13 -0
  31. package/lib/components/po-field/po-lookup/interfaces/po-lookup-column.interface.d.ts +1 -1
  32. package/lib/components/po-field/po-select/po-select.component.d.ts +2 -1
  33. package/lib/components/po-link/index.d.ts +2 -0
  34. package/lib/components/po-link/po-link-base.component.d.ts +37 -0
  35. package/lib/components/po-link/po-link.component.d.ts +26 -0
  36. package/lib/components/po-link/po-link.module.d.ts +13 -0
  37. package/lib/components/po-table/interfaces/po-table-column.interface.d.ts +1 -1
  38. package/lib/components/po-table/po-table-detail/po-table-detail-column.interface.d.ts +1 -1
  39. package/package.json +4 -4
  40. package/po-ui-ng-components-14.7.0.tgz +0 -0
  41. package/schematics/ng-add/index.js +1 -1
  42. package/schematics/ng-update/v14/index.js +1 -1
  43. package/schematics/ng-update/v2/index.js +1 -1
  44. package/schematics/ng-update/v3/index.js +1 -1
  45. package/schematics/ng-update/v4/index.js +1 -1
  46. package/schematics/ng-update/v5/index.js +1 -1
  47. package/schematics/ng-update/v6/index.js +1 -1
  48. package/po-ui-ng-components-14.6.0.tgz +0 -0
@@ -0,0 +1,40 @@
1
+ import { Component } from '@angular/core';
2
+ import { PoLinkBaseComponent } from './po-link-base.component';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * @docsExtends PoLinkBaseComponent
6
+ *
7
+ * @example
8
+ *
9
+ * <example name="po-link-basic" title="PO Link Basic" >
10
+ * <file name="sample-po-link-basic/sample-po-link-basic.component.html"> </file>
11
+ * <file name="sample-po-link-basic/sample-po-link-basic.component.ts"> </file>
12
+ * </example>
13
+ *
14
+ * <example name="po-link-labs" title="PO Link Labs" >
15
+ * <file name="sample-po-link-labs/sample-po-link-labs.component.html"> </file>
16
+ * <file name="sample-po-link-labs/sample-po-link-labs.component.ts"> </file>
17
+ * </example>
18
+ *
19
+ * <example name="po-link-heroes" title="PO Link Heroes" >
20
+ * <file name="sample-po-link-heroes/sample-po-link-heroes.component.html"> </file>
21
+ * <file name="sample-po-link-heroes/sample-po-link-heroes.component.ts"> </file>
22
+ * </example>
23
+ */
24
+ export class PoLinkComponent extends PoLinkBaseComponent {
25
+ }
26
+ PoLinkComponent.ɵfac = /*@__PURE__*/ function () { let ɵPoLinkComponent_BaseFactory; return function PoLinkComponent_Factory(t) { return (ɵPoLinkComponent_BaseFactory || (ɵPoLinkComponent_BaseFactory = i0.ɵɵgetInheritedFactory(PoLinkComponent)))(t || PoLinkComponent); }; }();
27
+ PoLinkComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoLinkComponent, selectors: [["po-link"]], features: [i0.ɵɵInheritDefinitionFeature], decls: 2, vars: 3, consts: [[1, "po-link"]], template: function PoLinkComponent_Template(rf, ctx) { if (rf & 1) {
28
+ i0.ɵɵelementStart(0, "a", 0);
29
+ i0.ɵɵtext(1);
30
+ i0.ɵɵelementEnd();
31
+ } if (rf & 2) {
32
+ i0.ɵɵattribute("href", ctx.url, i0.ɵɵsanitizeUrl)("target", ctx.openNewTab ? "_blank" : undefined);
33
+ i0.ɵɵadvance(1);
34
+ i0.ɵɵtextInterpolate(ctx.label);
35
+ } }, encapsulation: 2 });
36
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoLinkComponent, [{
37
+ type: Component,
38
+ args: [{ selector: 'po-link', template: "<a class=\"po-link\" [attr.href]=\"url\" [attr.target]=\"openNewTab ? '_blank' : undefined\">{{ label }}</a>\n" }]
39
+ }], null, null); })();
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tbGluay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tbGluay9wby1saW5rLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1saW5rL3BvLWxpbmsuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFL0Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQkc7QUFLSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxtQkFBbUI7O21PQUEzQyxlQUFlLFNBQWYsZUFBZTtrRUFBZixlQUFlO1FDNUI1Qiw0QkFBdUY7UUFBQSxZQUFXO1FBQUEsaUJBQUk7O1FBQW5GLGlEQUFpQixpREFBQTtRQUFtRCxlQUFXO1FBQVgsK0JBQVc7O3VGRDRCckYsZUFBZTtjQUozQixTQUFTOzJCQUNFLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUG9MaW5rQmFzZUNvbXBvbmVudCB9IGZyb20gJy4vcG8tbGluay1iYXNlLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQGRvY3NFeHRlbmRzIFBvTGlua0Jhc2VDb21wb25lbnRcbiAqXG4gKiBAZXhhbXBsZVxuICpcbiAqIDxleGFtcGxlIG5hbWU9XCJwby1saW5rLWJhc2ljXCIgdGl0bGU9XCJQTyBMaW5rIEJhc2ljXCIgPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbGluay1iYXNpYy9zYW1wbGUtcG8tbGluay1iYXNpYy5jb21wb25lbnQuaHRtbFwiPiA8L2ZpbGU+XG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1saW5rLWJhc2ljL3NhbXBsZS1wby1saW5rLWJhc2ljLmNvbXBvbmVudC50c1wiPiA8L2ZpbGU+XG4gKiA8L2V4YW1wbGU+XG4gKlxuICogPGV4YW1wbGUgbmFtZT1cInBvLWxpbmstbGFic1wiIHRpdGxlPVwiUE8gTGluayBMYWJzXCIgPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbGluay1sYWJzL3NhbXBsZS1wby1saW5rLWxhYnMuY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbGluay1sYWJzL3NhbXBsZS1wby1saW5rLWxhYnMuY29tcG9uZW50LnRzXCI+IDwvZmlsZT5cbiAqIDwvZXhhbXBsZT5cbiAqXG4gKiA8ZXhhbXBsZSBuYW1lPVwicG8tbGluay1oZXJvZXNcIiB0aXRsZT1cIlBPIExpbmsgSGVyb2VzXCIgPlxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tbGluay1oZXJvZXMvc2FtcGxlLXBvLWxpbmstaGVyb2VzLmNvbXBvbmVudC5odG1sXCI+IDwvZmlsZT5cbiAqICA8ZmlsZSBuYW1lPVwic2FtcGxlLXBvLWxpbmstaGVyb2VzL3NhbXBsZS1wby1saW5rLWhlcm9lcy5jb21wb25lbnQudHNcIj4gPC9maWxlPlxuICogPC9leGFtcGxlPlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwby1saW5rJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3BvLWxpbmsuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIFBvTGlua0NvbXBvbmVudCBleHRlbmRzIFBvTGlua0Jhc2VDb21wb25lbnQge31cbiIsIjxhIGNsYXNzPVwicG8tbGlua1wiIFthdHRyLmhyZWZdPVwidXJsXCIgW2F0dHIudGFyZ2V0XT1cIm9wZW5OZXdUYWIgPyAnX2JsYW5rJyA6IHVuZGVmaW5lZFwiPnt7IGxhYmVsIH19PC9hPlxuIl19
@@ -0,0 +1,24 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { PoLinkComponent } from './po-link.component';
4
+ import * as i0 from "@angular/core";
5
+ /**
6
+ * @description
7
+ *
8
+ * Módulo do componente po-link.
9
+ */
10
+ export class PoLinkModule {
11
+ }
12
+ PoLinkModule.ɵfac = function PoLinkModule_Factory(t) { return new (t || PoLinkModule)(); };
13
+ PoLinkModule.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: PoLinkModule });
14
+ PoLinkModule.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule] });
15
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoLinkModule, [{
16
+ type: NgModule,
17
+ args: [{
18
+ declarations: [PoLinkComponent],
19
+ imports: [CommonModule],
20
+ exports: [PoLinkComponent]
21
+ }]
22
+ }], null, null); })();
23
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(PoLinkModule, { declarations: [PoLinkComponent], imports: [CommonModule], exports: [PoLinkComponent] }); })();
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tbGluay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tbGluay9wby1saW5rLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBRXREOzs7O0dBSUc7QUFNSCxNQUFNLE9BQU8sWUFBWTs7d0VBQVosWUFBWTs4REFBWixZQUFZO2tFQUhiLFlBQVk7dUZBR1gsWUFBWTtjQUx4QixRQUFRO2VBQUM7Z0JBQ1IsWUFBWSxFQUFFLENBQUMsZUFBZSxDQUFDO2dCQUMvQixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7Z0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLGVBQWUsQ0FBQzthQUMzQjs7d0ZBQ1ksWUFBWSxtQkFKUixlQUFlLGFBQ3BCLFlBQVksYUFDWixlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBQb0xpbmtDb21wb25lbnQgfSBmcm9tICcuL3BvLWxpbmsuY29tcG9uZW50JztcblxuLyoqXG4gKiBAZGVzY3JpcHRpb25cbiAqXG4gKiBNw7NkdWxvIGRvIGNvbXBvbmVudGUgcG8tbGluay5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbUG9MaW5rQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtQb0xpbmtDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIFBvTGlua01vZHVsZSB7fVxuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-table-column.interface.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-table/interfaces/po-table-column.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { PoTableBoolean } from './po-table-boolean.interface';\nimport { PoTableColumnIcon } from '../po-table-column-icon/po-table-column-icon.interface';\nimport { PoTableColumnLabel } from '../po-table-column-label/po-table-column-label.interface';\nimport { PoTableDetail } from '../po-table-detail/po-table-detail.interface';\nimport { PoTableSubtitleColumn } from '../po-table-subtitle-footer/po-table-subtitle-column.interface';\n\n/**\n * @usedBy PoTableComponent\n *\n * @description\n *\n * Interface para configuração das colunas do `po-table`.\n *\n * As definições das colunas serão aplicadas linha a linha.\n */\nexport interface PoTableColumn {\n  /**\n   * Define uma ação na coluna quando o tipo da coluna for `link` ou `icon`.\n   *\n   * > Quando for do tipo `link` será enviado como primeiro parâmetro o valor da coluna\n   * e no segundo parâmetro o objeto completo da linha. Caso tenha sido definido uma ação e um link na coluna, a ação\n   * será executada ao invés do link.\n   *\n   * > Quando for do tipo `icon` enviará o objeto completo da linha e o segundo parâmetro será a definição da coluna.\n   */\n  action?: Function;\n\n  /**\n   * Define um objeto do tipo `PoTableBoolean` para as colunas do tipo _boolean_. Por exemplo:\n   *\n   * ```\n   *  { property: 'approbation', type: 'boolean', boolean: {\n   *    trueLabel: 'Accepted', falseLabel: 'Rejected'\n   *  }}\n   * ```\n   *\n   * > Caso não seja definido um objeto para colunas do tipo *boolean*,\n   * esta exibirá por padrão `Sim` e `Não` de acordo com os valores _booleanos_.\n   */\n  boolean?: PoTableBoolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a cor que será aplicada no conteúdo da coluna.\n   *\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   * > Existe a possibilidade de informar uma função que retorne um dos valores aceitos, serão passados\n   * por parâmetro a linha e a coluna atual, por exemplo:\n   *\n   * ```\n   * (row, column) => { row[column] == 'text' ? 'color-03' : 'color-09' }\n   * ```\n   *\n   * > É possível também usá-la na coluna do tipo `icons` para alteração das cores de seu conteúdo conforme exemplo abaixo,\n   * contudo, desta forma sobrepõe a cor especificada em cada objeto caso haja:\n   *\n   * ```\n   * { property: 'columnIcon', label: 'Like', type: 'icon', color: 'color-08', icons: [\n   *   { value: 'po-icon-star', action: () => this.notification() }\n   * ]},\n   * ```\n   */\n  color?: string | Function;\n\n  /**\n   * Define um objeto que segue a interface `PoTableDetail`, para as colunas de detalhes. Por exemplo:\n   *\n   * ```\n   * { columns: [{ property: 'package', label: 'Pacote' }], typeHeader: 'top' }\n   * ```\n   *\n   */\n  detail?: PoTableDetail;\n\n  /**\n   * Função que deve retornar um booleano para habilitar ou desabilitar o *link* e sua ação.\n   *\n   * > Propriedade disponível nas colunas do tipo `link`.\n   */\n  disabled?: Function;\n\n  /**\n   * Formato de exibição do valor da coluna:\n   * - Formato para moeda (currency). Exemplos: 'BRL', 'USD'.\n   * - Formato para data (date): aceita apenas os caracteres de dia(dd), mês(MM ou mm) e ano (yyyy ou yy),\n   * caso não seja informado um formato o mesmo será 'dd/MM/yyyy'. Exemplos: 'dd/MM/yyyy', 'dd-MM-yy', 'mm/dd/yyyy'.\n   * - Formato para horário (time): aceita apenas os caracteres de hora(HH), minutos(mm), segundos(ss) e\n   *  milisegundos(f-ffffff), os milisegundos são opcionais, caso não seja informado um formato o mesmo será\n   * 'HH:mm:ss'. Exemplos: 'HH:mm', 'HH:mm:ss.ffffff', 'HH:mm:ss.ff', 'mm:ss.fff'.\n   * - Formato para números (number): aceita um valor seguindo o padrão [**DecimalPipe**](https://angular.io/api/common/DecimalPipe)\n   *  para formatação, e caso não seja informado, o número será exibido na sua forma original. Exemplo:\n   *\n   *  +  Com o valor de entrada: `50` e a valor para formatação: `'1.2-5'` o resultado será: `50.00`\n   */\n  format?: string;\n\n  /**\n   * @description\n   *\n   * Define um *array* de objetos para colunas de ícones que irá sobrepor os valores como `action` e `color`\n   * definidos na coluna, à partir do *value* da [`PoTableColumnIcon`](documentation/po-table#tableColumnIcon), por exemplo:\n   *\n   * ```\n   *  { property: 'columnIcon', label: 'Icons', type: 'icon', action: this.favorite.bind(this), icons: [\n   *    { value: 'delete', icon: 'po-icon-plus', color: 'color-06', action: this.add.bind(this), tooltip: 'Adiciona um novo item' },\n   *    { value: 'edit', icon: 'po-icon-edit', action: this.edit.bind(this) },\n   *    { value: 'delete', icon: 'po-icon-delete', color: 'color-12', action: this.remove.bind(this) }\n   *  ]},\n   * ```\n   *\n   * ```\n   *  ...\n   *  { id: 1, columnIcon: ['po-icon-edit', 'po-icon-remove', 'po-icon-star'] }\n   *  ...\n   *\n   * ```\n   */\n  icons?: Array<PoTableColumnIcon>;\n\n  /**\n   * Texto para título da coluna.\n   *\n   * Caso não seja informado, será utilizado como *label* o valor da propriedade *property* com a primeira letra em maiúsculo.\n   */\n  label?: string;\n\n  /**\n   * Define um array de objetos para as colunas de label, onde 'labels' é uma lista de objetos\n   * do tipo `PoTableColumnLabel` na qual devem ser definidas os labels. Por exemplo:\n   *\n   * ```\n   * { property: 'flightStatus', label: 'Status', type: 'label', width:'100px', labels: [\n   *  { value: 'confirmed', color: 'color-11', label: 'Confirmado', tooltip: 'Flight Status' },\n   *  { value: 'delayed', color: 'color-08', label: 'Atrasado', tooltip: 'Flight Status' }\n   * }\n   * ```\n   *\n   */\n  labels?: Array<PoTableColumnLabel>;\n\n  /**\n   * Define o nome da propriedade que conterá o `link` a ser redirecionado.\n   *\n   * @default link\n   */\n  link?: string;\n\n  /** Nome identificador da coluna. Também permite objetos aninhados conforme exemplo abaixo.\n   *\n   * ```\n   * { property: 'address.street', label: 'Rua' }\n   * ```\n   */\n  property?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla se a coluna será considerada como \"ordenavel\". Caso seja definido um valor falso, a coluna não será usada para\n   * ordenação.\n   *\n   * @default `true`\n   */\n  sortable?: boolean;\n\n  /**\n   * Define um array de objetos para as colunas de legenda. Onde, `subtitles` é uma lista de objetos do tipo PoTableSubtitle na qual\n   * devem ser definidas as opções de legenda. Por exemplo:\n   *\n   * ```\n   * { property: 'flightStatus', label: 'Status', color: 'subtitle', width:'100px', subtitles: [\n   *  { value: 'confirmed', color: 'color-11', label: 'Confirmado', content: '1' },\n   *  { value: 'delayed', color: 'color-08', label: 'Atrasado', content: '2' }\n   * }\n   * ```\n   * Nesse exemplo a coluna escolhida para legenda é 'flightStatus', se o valor dessa coluna for 'confirmed', o texto da legenda será\n   * 'Confirmado'.\n   *\n   */\n  subtitles?: Array<PoTableSubtitleColumn>;\n\n  /**\n   * Define um texto de ajuda que será exibido ao passar o *mouse* sobre um texto.\n   *\n   * > O tooltip só será visível se for uma coluna do tipo *link*.\n   *\n   * > Caso a propriedade `p-hide-text-overflow` esteja habilitada e o conteúdo da célula exceder a largura da coluna,\n   * é ignorado o valor atribuído ao *tooltip* e será exibido justamente o conteúdo da célula.\n   */\n  tooltip?: string;\n\n  /**\n   * Tipo da coluna.\n   *\n   * Valores válidos:\n   * - `boolean`: Exibirá por padrão `Sim` e `Não` de acordo com os valores *booleanos*.\n   * > Caso necessite exibir valores diferentes do padrão, deve-se utilizar a propriedade `boolean` desta interface.\n   * - `currency`: valores monetários.\n   *\n   * - `date`: valor de datas.\n   *  + Aceita os tipos _string_ e _Date_ padrão do Javascript,\n   *  por exemplo: `'2017-11-28'` ou `new Date(2017, 10, 28)`.\n   *\n   * - `dateTime`: valor de data com horário.\n   *  + Aceita o tipo _string_ no formato **ISO-8601** extendido **'yyyy-mm-ddThh:mm:ss+|-hh:mm'**\n   * e o tipo _Date_ padrão do Javascript, por exemplo: `'2017-11-28T00:00:00-02:00'` ou `new Date(2017, 10, 28)`.\n   *\n   * - `detail`: array de objetos para o master-detail.\n   * - `icon`: *array* de *string* ou objetos para a coluna de ícones.\n   * - `label`: texto com destaque.\n   * - `link`: habilita link na coluna para ação ou navegação.\n   * - `number`: valores numéricos.\n   * - `string`: textos.\n   * - `subtitle`: array de objetos para a coluna de legenda.\n   *\n   * - `time`: valor de horário.\n   *  + Aceita o tipo _string_ nos formatos **'HH:mm:ss'** ou **'HH:mm:ss.ffffff'**, por exemplo: `'23:12:45'`.\n   * - `cellTemplate`: Indica que a coluna será utilizada como template, em conjunto com o\n   * [PoTableCellTemplate](/documentation/po-table-cell-template).\n   * - `columnTemplate`: Indica que a coluna será utilizada como template, em conjunto com o\n   * [PoTableColumnTemplate](/documentation/po-table-column-template).\n   *\n   * @default `string`\n   */\n  type?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla a exibição da coluna. Caso seja definido um valor falso, a coluna não será exibida mas mas será possível torná-la\n   * visível através do **gerenciador de colunas**.\n   *\n   * > A disponibilidade de visualização pode limitar-se de acordo com a definição de `p-max-columns`.\n   *\n   * @default `true`\n   */\n  visible?: boolean;\n\n  /**\n   * A largura da coluna pode ser informada em pixels ou porcentagem.\n   * > Exemplo: '100px' ou '20%'.\n   */\n  width?: string;\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-table-column.interface.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-table/interfaces/po-table-column.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { PoTableBoolean } from './po-table-boolean.interface';\nimport { PoTableColumnIcon } from '../po-table-column-icon/po-table-column-icon.interface';\nimport { PoTableColumnLabel } from '../po-table-column-label/po-table-column-label.interface';\nimport { PoTableDetail } from '../po-table-detail/po-table-detail.interface';\nimport { PoTableSubtitleColumn } from '../po-table-subtitle-footer/po-table-subtitle-column.interface';\n\n/**\n * @usedBy PoTableComponent\n *\n * @description\n *\n * Interface para configuração das colunas do `po-table`.\n *\n * As definições das colunas serão aplicadas linha a linha.\n */\nexport interface PoTableColumn {\n  /**\n   * Define uma ação na coluna quando o tipo da coluna for `link` ou `icon`.\n   *\n   * > Quando for do tipo `link` será enviado como primeiro parâmetro o valor da coluna\n   * e no segundo parâmetro o objeto completo da linha. Caso tenha sido definido uma ação e um link na coluna, a ação\n   * será executada ao invés do link.\n   *\n   * > Quando for do tipo `icon` enviará o objeto completo da linha e o segundo parâmetro será a definição da coluna.\n   */\n  action?: Function;\n\n  /**\n   * Define um objeto do tipo `PoTableBoolean` para as colunas do tipo _boolean_. Por exemplo:\n   *\n   * ```\n   *  { property: 'approbation', type: 'boolean', boolean: {\n   *    trueLabel: 'Accepted', falseLabel: 'Rejected'\n   *  }}\n   * ```\n   *\n   * > Caso não seja definido um objeto para colunas do tipo *boolean*,\n   * esta exibirá por padrão `Sim` e `Não` de acordo com os valores _booleanos_.\n   */\n  boolean?: PoTableBoolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a cor que será aplicada no conteúdo da coluna.\n   *\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   * > Existe a possibilidade de informar uma função que retorne um dos valores aceitos, serão passados\n   * por parâmetro a linha e a coluna atual, por exemplo:\n   *\n   * ```\n   * (row, column) => { row[column] == 'text' ? 'color-03' : 'color-09' }\n   * ```\n   *\n   * > É possível também usá-la na coluna do tipo `icons` para alteração das cores de seu conteúdo conforme exemplo abaixo,\n   * contudo, desta forma sobrepõe a cor especificada em cada objeto caso haja:\n   *\n   * ```\n   * { property: 'columnIcon', label: 'Like', type: 'icon', color: 'color-08', icons: [\n   *   { value: 'po-icon-star', action: () => this.notification() }\n   * ]},\n   * ```\n   */\n  color?: string | Function;\n\n  /**\n   * Define um objeto que segue a interface `PoTableDetail`, para as colunas de detalhes. Por exemplo:\n   *\n   * ```\n   * { columns: [{ property: 'package', label: 'Pacote' }], typeHeader: 'top' }\n   * ```\n   *\n   */\n  detail?: PoTableDetail;\n\n  /**\n   * Função que deve retornar um booleano para habilitar ou desabilitar o *link* e sua ação.\n   *\n   * > Propriedade disponível nas colunas do tipo `link`.\n   */\n  disabled?: Function;\n\n  /**\n   * Formato de exibição do valor da coluna:\n   * - Formato para moeda (currency). Exemplos: 'BRL', 'USD'.\n   * - Formato para data (date): aceita apenas os caracteres de dia(dd), mês(MM) e ano (yyyy ou yy),\n   * caso não seja informado um formato o mesmo será 'dd/MM/yyyy'. Exemplos: 'dd/MM/yyyy', 'dd-MM-yy', 'mm/dd/yyyy'.\n   * - Formato para horário (time): aceita apenas os caracteres de hora(HH), minutos(mm), segundos(ss) e\n   *  milisegundos(f-ffffff), os milisegundos são opcionais, caso não seja informado um formato o mesmo será\n   * 'HH:mm:ss'. Exemplos: 'HH:mm', 'HH:mm:ss.ffffff', 'HH:mm:ss.ff', 'mm:ss.fff'.\n   * - Formato para números (number): aceita um valor seguindo o padrão [**DecimalPipe**](https://angular.io/api/common/DecimalPipe)\n   *  para formatação, e caso não seja informado, o número será exibido na sua forma original. Exemplo:\n   *\n   *  +  Com o valor de entrada: `50` e a valor para formatação: `'1.2-5'` o resultado será: `50.00`\n   */\n  format?: string;\n\n  /**\n   * @description\n   *\n   * Define um *array* de objetos para colunas de ícones que irá sobrepor os valores como `action` e `color`\n   * definidos na coluna, à partir do *value* da [`PoTableColumnIcon`](documentation/po-table#tableColumnIcon), por exemplo:\n   *\n   * ```\n   *  { property: 'columnIcon', label: 'Icons', type: 'icon', action: this.favorite.bind(this), icons: [\n   *    { value: 'delete', icon: 'po-icon-plus', color: 'color-06', action: this.add.bind(this), tooltip: 'Adiciona um novo item' },\n   *    { value: 'edit', icon: 'po-icon-edit', action: this.edit.bind(this) },\n   *    { value: 'delete', icon: 'po-icon-delete', color: 'color-12', action: this.remove.bind(this) }\n   *  ]},\n   * ```\n   *\n   * ```\n   *  ...\n   *  { id: 1, columnIcon: ['po-icon-edit', 'po-icon-remove', 'po-icon-star'] }\n   *  ...\n   *\n   * ```\n   */\n  icons?: Array<PoTableColumnIcon>;\n\n  /**\n   * Texto para título da coluna.\n   *\n   * Caso não seja informado, será utilizado como *label* o valor da propriedade *property* com a primeira letra em maiúsculo.\n   */\n  label?: string;\n\n  /**\n   * Define um array de objetos para as colunas de label, onde 'labels' é uma lista de objetos\n   * do tipo `PoTableColumnLabel` na qual devem ser definidas os labels. Por exemplo:\n   *\n   * ```\n   * { property: 'flightStatus', label: 'Status', type: 'label', width:'100px', labels: [\n   *  { value: 'confirmed', color: 'color-11', label: 'Confirmado', tooltip: 'Flight Status' },\n   *  { value: 'delayed', color: 'color-08', label: 'Atrasado', tooltip: 'Flight Status' }\n   * }\n   * ```\n   *\n   */\n  labels?: Array<PoTableColumnLabel>;\n\n  /**\n   * Define o nome da propriedade que conterá o `link` a ser redirecionado.\n   *\n   * @default link\n   */\n  link?: string;\n\n  /** Nome identificador da coluna. Também permite objetos aninhados conforme exemplo abaixo.\n   *\n   * ```\n   * { property: 'address.street', label: 'Rua' }\n   * ```\n   */\n  property?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla se a coluna será considerada como \"ordenavel\". Caso seja definido um valor falso, a coluna não será usada para\n   * ordenação.\n   *\n   * @default `true`\n   */\n  sortable?: boolean;\n\n  /**\n   * Define um array de objetos para as colunas de legenda. Onde, `subtitles` é uma lista de objetos do tipo PoTableSubtitle na qual\n   * devem ser definidas as opções de legenda. Por exemplo:\n   *\n   * ```\n   * { property: 'flightStatus', label: 'Status', color: 'subtitle', width:'100px', subtitles: [\n   *  { value: 'confirmed', color: 'color-11', label: 'Confirmado', content: '1' },\n   *  { value: 'delayed', color: 'color-08', label: 'Atrasado', content: '2' }\n   * }\n   * ```\n   * Nesse exemplo a coluna escolhida para legenda é 'flightStatus', se o valor dessa coluna for 'confirmed', o texto da legenda será\n   * 'Confirmado'.\n   *\n   */\n  subtitles?: Array<PoTableSubtitleColumn>;\n\n  /**\n   * Define um texto de ajuda que será exibido ao passar o *mouse* sobre um texto.\n   *\n   * > O tooltip só será visível se for uma coluna do tipo *link*.\n   *\n   * > Caso a propriedade `p-hide-text-overflow` esteja habilitada e o conteúdo da célula exceder a largura da coluna,\n   * é ignorado o valor atribuído ao *tooltip* e será exibido justamente o conteúdo da célula.\n   */\n  tooltip?: string;\n\n  /**\n   * Tipo da coluna.\n   *\n   * Valores válidos:\n   * - `boolean`: Exibirá por padrão `Sim` e `Não` de acordo com os valores *booleanos*.\n   * > Caso necessite exibir valores diferentes do padrão, deve-se utilizar a propriedade `boolean` desta interface.\n   * - `currency`: valores monetários.\n   *\n   * - `date`: valor de datas.\n   *  + Aceita os tipos _string_ e _Date_ padrão do Javascript,\n   *  por exemplo: `'2017-11-28'` ou `new Date(2017, 10, 28)`.\n   *\n   * - `dateTime`: valor de data com horário.\n   *  + Aceita o tipo _string_ no formato **ISO-8601** extendido **'yyyy-mm-ddThh:mm:ss+|-hh:mm'**\n   * e o tipo _Date_ padrão do Javascript, por exemplo: `'2017-11-28T00:00:00-02:00'` ou `new Date(2017, 10, 28)`.\n   *\n   * - `detail`: array de objetos para o master-detail.\n   * - `icon`: *array* de *string* ou objetos para a coluna de ícones.\n   * - `label`: texto com destaque.\n   * - `link`: habilita link na coluna para ação ou navegação.\n   * - `number`: valores numéricos.\n   * - `string`: textos.\n   * - `subtitle`: array de objetos para a coluna de legenda.\n   *\n   * - `time`: valor de horário.\n   *  + Aceita o tipo _string_ nos formatos **'HH:mm:ss'** ou **'HH:mm:ss.ffffff'**, por exemplo: `'23:12:45'`.\n   * - `cellTemplate`: Indica que a coluna será utilizada como template, em conjunto com o\n   * [PoTableCellTemplate](/documentation/po-table-cell-template).\n   * - `columnTemplate`: Indica que a coluna será utilizada como template, em conjunto com o\n   * [PoTableColumnTemplate](/documentation/po-table-column-template).\n   *\n   * @default `string`\n   */\n  type?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Controla a exibição da coluna. Caso seja definido um valor falso, a coluna não será exibida mas mas será possível torná-la\n   * visível através do **gerenciador de colunas**.\n   *\n   * > A disponibilidade de visualização pode limitar-se de acordo com a definição de `p-max-columns`.\n   *\n   * @default `true`\n   */\n  visible?: boolean;\n\n  /**\n   * A largura da coluna pode ser informada em pixels ou porcentagem.\n   * > Exemplo: '100px' ou '20%'.\n   */\n  width?: string;\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdGFibGUtZGV0YWlsLWNvbHVtbi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdGFibGUvcG8tdGFibGUtZGV0YWlsL3BvLXRhYmxlLWRldGFpbC1jb2x1bW4uaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEB1c2VkQnkgUG9UYWJsZUNvbXBvbmVudFxuICpcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIEludGVyZmFjZSBwYXJhIGNvbmZpZ3VyYcOnw6NvIGRhcyBjb2x1bmFzIGRvIGBwby10YWJsZS1kZXRhaWxgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBvVGFibGVEZXRhaWxDb2x1bW4ge1xuICAvKipcbiAgICogRm9ybWF0byBkZSBleGliacOnw6NvIGRvIHZhbG9yIGRhIGNvbHVuYTpcbiAgICogLSBGb3JtYXRvIHBhcmEgbW9lZGEgKGN1cnJlbmN5KS4gRXhlbXBsb3M6ICdCUkwnLCAnVVNEJy5cbiAgICogLSBGb3JtYXRvIHBhcmEgZGF0YSAoZGF0ZSk6IGFjZWl0YSBhcGVuYXMgb3MgY2FyYWN0ZXJlcyBkZSBkaWEoZGQpLCBtw6pzKE1NIG91IG1tKSBlIGFubyAoeXl5eSBvdSB5eSksXG4gICAqIGNhc28gbsOjbyBzZWphIGluZm9ybWFkbyB1bSBmb3JtYXRvIG8gbWVzbW8gc2Vyw6EgJ2RkL01NL3l5eXknLiBFeGVtcGxvczogJ2RkL01NL3l5eXknLCAnZGQtTU0teXknLCAnbW0vZGQveXl5eScuXG4gICAqIC0gRm9ybWF0byBwYXJhIGhvcsOhcmlvICh0aW1lKTogYWNlaXRhIGFwZW5hcyBvcyBjYXJhY3RlcmVzIGRlIGhvcmEoSEgpLCBtaW51dG9zKG1tKSwgc2VndW5kb3Moc3MpIGVcbiAgICogIG1pbGlzZWd1bmRvcyhmLWZmZmZmZiksIG9zIG1pbGlzZWd1bmRvcyBzw6NvIG9wY2lvbmFpcywgY2FzbyBuw6NvIHNlamEgaW5mb3JtYWRvIHVtIGZvcm1hdG8gbyBtZXNtbyBzZXLDoVxuICAgKiAnSEg6bW06c3MnLiBFeGVtcGxvczogJ0hIOm1tJywgJ0hIOm1tOnNzLmZmZmZmZicsICdISDptbTpzcy5mZicsICdtbTpzcy5mZmYnLlxuICAgKiAtIEZvcm1hdG8gcGFyYSBuw7ptZXJvcyAobnVtYmVyKTogYWNlaXRhIHVtIHZhbG9yIHNlZ3VpbmRvIG8gcGFkcsOjbyBbKipEZWNpbWFsUGlwZSoqXShodHRwczovL2FuZ3VsYXIuaW8vYXBpL2NvbW1vbi9EZWNpbWFsUGlwZSlcbiAgICogIHBhcmEgZm9ybWF0YcOnw6NvLCBlIGNhc28gbsOjbyBzZWphIGluZm9ybWFkbywgbyBuw7ptZXJvIHNlcsOhIGV4aWJpZG8gbmEgc3VhIGZvcm1hIG9yaWdpbmFsLiBFeGVtcGxvOlxuICAgKlxuICAgKiAgKyAgVmFsb3IgZGUgZW50cmFkYTogYDUwYCBlIHZhbG9yIHBhcmEgZm9ybWF0YcOnw6NvOiBgJzEuMi01J2AgbyByZXN1bHRhZG8gc2Vyw6E6IGA1MC4wMGBcbiAgICovXG4gIGZvcm1hdD86IHN0cmluZztcblxuICAvKipcbiAgICogQG9wdGlvbmFsXG4gICAqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKlxuICAgKiBUZXh0byBwYXJhIHTDrXR1bG8gZGEgY29sdW5hLlxuICAgKi9cbiAgbGFiZWw/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEBvcHRpb25hbFxuICAgKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICpcbiAgICogTm9tZSBpZGVudGlmaWNhZG9yIGRhIGNvbHVuYS5cbiAgICovXG4gIHByb3BlcnR5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaXBvIGRhIGNvbHVuYS5cbiAgICpcbiAgICogVmFsb3JlcyB2w6FsaWRvczpcbiAgICogLSBgY3VycmVuY3lgOiB2YWxvcmVzIG1vbmV0w6FyaW9zLlxuICAgKlxuICAgKiAtIGBkYXRlYDogdmFsb3IgZGUgZGF0YXMuXG4gICAqICArIEFjZWl0YSBvcyB0aXBvcyBfc3RyaW5nXyBlIF9EYXRlXyBwYWRyw6NvIGRvIEphdmFzY3JpcHQsXG4gICAqICBwb3IgZXhlbXBsbzogYCcyMDE3LTExLTI4J2Agb3UgYG5ldyBEYXRlKDIwMTcsIDEwLCAyOClgLlxuICAgKlxuICAgKiAtIGB0aW1lYDogdmFsb3IgZGUgaG9yw6FyaW8uXG4gICAqIC0gYG51bWJlcmA6IHZhbG9yZXMgbnVtw6lyaWNvcy5cbiAgICpcbiAgICogLSBgZGF0ZVRpbWVgOiB2YWxvciBkZSBkYXRhIGNvbSBob3LDoXJpby5cbiAgICogICsgQWNlaXRhIG8gdGlwbyBfc3RyaW5nXyBubyBmb3JtYXRvICoqSVNPLTg2MDEqKiBleHRlbmRpZG8gKioneXl5eS1tbS1kZFRoaDptbTpzcyt8LWhoOm1tJyoqXG4gICAqIGUgbyB0aXBvIF9EYXRlXyBwYWRyw6NvIGRvIEphdmFzY3JpcHQsIHBvciBleGVtcGxvOiBgJzIwMTctMTEtMjhUMDA6MDA6MDAtMDI6MDAnYCBvdSBgbmV3IERhdGUoMjAxNywgMTAsIDI4KWAuXG4gICAqXG4gICAqICArIEFjZWl0YSBvIHRpcG8gX3N0cmluZ18gbm9zIGZvcm1hdG9zICoqJ0hIOm1tOnNzJyoqIG91ICoqJ0hIOm1tOnNzLmZmZmZmZicqKiwgcG9yIGV4ZW1wbG86IGAnMjM6MTI6NDUnYC5cbiAgICpcbiAgICogQGRlZmF1bHQgYHN0cmluZ2BcbiAgICovXG4gIHR5cGU/OiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdGFibGUtZGV0YWlsLWNvbHVtbi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tdGFibGUvcG8tdGFibGUtZGV0YWlsL3BvLXRhYmxlLWRldGFpbC1jb2x1bW4uaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEB1c2VkQnkgUG9UYWJsZUNvbXBvbmVudFxuICpcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIEludGVyZmFjZSBwYXJhIGNvbmZpZ3VyYcOnw6NvIGRhcyBjb2x1bmFzIGRvIGBwby10YWJsZS1kZXRhaWxgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBvVGFibGVEZXRhaWxDb2x1bW4ge1xuICAvKipcbiAgICogRm9ybWF0byBkZSBleGliacOnw6NvIGRvIHZhbG9yIGRhIGNvbHVuYTpcbiAgICogLSBGb3JtYXRvIHBhcmEgbW9lZGEgKGN1cnJlbmN5KS4gRXhlbXBsb3M6ICdCUkwnLCAnVVNEJy5cbiAgICogLSBGb3JtYXRvIHBhcmEgZGF0YSAoZGF0ZSk6IGFjZWl0YSBhcGVuYXMgb3MgY2FyYWN0ZXJlcyBkZSBkaWEoZGQpLCBtw6pzKE1NKSBlIGFubyAoeXl5eSBvdSB5eSksXG4gICAqIGNhc28gbsOjbyBzZWphIGluZm9ybWFkbyB1bSBmb3JtYXRvIG8gbWVzbW8gc2Vyw6EgJ2RkL01NL3l5eXknLiBFeGVtcGxvczogJ2RkL01NL3l5eXknLCAnZGQtTU0teXknLCAnbW0vZGQveXl5eScuXG4gICAqIC0gRm9ybWF0byBwYXJhIGhvcsOhcmlvICh0aW1lKTogYWNlaXRhIGFwZW5hcyBvcyBjYXJhY3RlcmVzIGRlIGhvcmEoSEgpLCBtaW51dG9zKG1tKSwgc2VndW5kb3Moc3MpIGVcbiAgICogIG1pbGlzZWd1bmRvcyhmLWZmZmZmZiksIG9zIG1pbGlzZWd1bmRvcyBzw6NvIG9wY2lvbmFpcywgY2FzbyBuw6NvIHNlamEgaW5mb3JtYWRvIHVtIGZvcm1hdG8gbyBtZXNtbyBzZXLDoVxuICAgKiAnSEg6bW06c3MnLiBFeGVtcGxvczogJ0hIOm1tJywgJ0hIOm1tOnNzLmZmZmZmZicsICdISDptbTpzcy5mZicsICdtbTpzcy5mZmYnLlxuICAgKiAtIEZvcm1hdG8gcGFyYSBuw7ptZXJvcyAobnVtYmVyKTogYWNlaXRhIHVtIHZhbG9yIHNlZ3VpbmRvIG8gcGFkcsOjbyBbKipEZWNpbWFsUGlwZSoqXShodHRwczovL2FuZ3VsYXIuaW8vYXBpL2NvbW1vbi9EZWNpbWFsUGlwZSlcbiAgICogIHBhcmEgZm9ybWF0YcOnw6NvLCBlIGNhc28gbsOjbyBzZWphIGluZm9ybWFkbywgbyBuw7ptZXJvIHNlcsOhIGV4aWJpZG8gbmEgc3VhIGZvcm1hIG9yaWdpbmFsLiBFeGVtcGxvOlxuICAgKlxuICAgKiAgKyAgVmFsb3IgZGUgZW50cmFkYTogYDUwYCBlIHZhbG9yIHBhcmEgZm9ybWF0YcOnw6NvOiBgJzEuMi01J2AgbyByZXN1bHRhZG8gc2Vyw6E6IGA1MC4wMGBcbiAgICovXG4gIGZvcm1hdD86IHN0cmluZztcblxuICAvKipcbiAgICogQG9wdGlvbmFsXG4gICAqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKlxuICAgKiBUZXh0byBwYXJhIHTDrXR1bG8gZGEgY29sdW5hLlxuICAgKi9cbiAgbGFiZWw/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEBvcHRpb25hbFxuICAgKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICpcbiAgICogTm9tZSBpZGVudGlmaWNhZG9yIGRhIGNvbHVuYS5cbiAgICovXG4gIHByb3BlcnR5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaXBvIGRhIGNvbHVuYS5cbiAgICpcbiAgICogVmFsb3JlcyB2w6FsaWRvczpcbiAgICogLSBgY3VycmVuY3lgOiB2YWxvcmVzIG1vbmV0w6FyaW9zLlxuICAgKlxuICAgKiAtIGBkYXRlYDogdmFsb3IgZGUgZGF0YXMuXG4gICAqICArIEFjZWl0YSBvcyB0aXBvcyBfc3RyaW5nXyBlIF9EYXRlXyBwYWRyw6NvIGRvIEphdmFzY3JpcHQsXG4gICAqICBwb3IgZXhlbXBsbzogYCcyMDE3LTExLTI4J2Agb3UgYG5ldyBEYXRlKDIwMTcsIDEwLCAyOClgLlxuICAgKlxuICAgKiAtIGB0aW1lYDogdmFsb3IgZGUgaG9yw6FyaW8uXG4gICAqIC0gYG51bWJlcmA6IHZhbG9yZXMgbnVtw6lyaWNvcy5cbiAgICpcbiAgICogLSBgZGF0ZVRpbWVgOiB2YWxvciBkZSBkYXRhIGNvbSBob3LDoXJpby5cbiAgICogICsgQWNlaXRhIG8gdGlwbyBfc3RyaW5nXyBubyBmb3JtYXRvICoqSVNPLTg2MDEqKiBleHRlbmRpZG8gKioneXl5eS1tbS1kZFRoaDptbTpzcyt8LWhoOm1tJyoqXG4gICAqIGUgbyB0aXBvIF9EYXRlXyBwYWRyw6NvIGRvIEphdmFzY3JpcHQsIHBvciBleGVtcGxvOiBgJzIwMTctMTEtMjhUMDA6MDA6MDAtMDI6MDAnYCBvdSBgbmV3IERhdGUoMjAxNywgMTAsIDI4KWAuXG4gICAqXG4gICAqICArIEFjZWl0YSBvIHRpcG8gX3N0cmluZ18gbm9zIGZvcm1hdG9zICoqJ0hIOm1tOnNzJyoqIG91ICoqJ0hIOm1tOnNzLmZmZmZmZicqKiwgcG9yIGV4ZW1wbG86IGAnMjM6MTI6NDUnYC5cbiAgICpcbiAgICogQGRlZmF1bHQgYHN0cmluZ2BcbiAgICovXG4gIHR5cGU/OiBzdHJpbmc7XG59XG4iXX0=
@@ -2,6 +2,8 @@ import { Injectable } from '@angular/core';
2
2
  import { getBrowserLanguage, getShortLanguage, isLanguage } from '../../utils/util';
3
3
  import { poLocaleDecimalSeparatorList, poLocaleDefault, poLocales, poLocaleThousandSeparatorList } from './po-language.constant';
4
4
  import * as i0 from "@angular/core";
5
+ localStorage.removeItem('PO_DEFAULT_LANGUAGE');
6
+ localStorage.removeItem('PO_USER_LOCALE');
5
7
  const poDefaultLanguage = 'PO_DEFAULT_LANGUAGE';
6
8
  const poLocaleKey = 'PO_USER_LOCALE';
7
9
  /**
@@ -133,4 +135,4 @@ PoLanguageService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: PoLang
133
135
  providedIn: 'root'
134
136
  }]
135
137
  }], function () { return []; }, null); })();
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-language.service.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/services/po-language/po-language.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACpF,OAAO,EACL,4BAA4B,EAC5B,eAAe,EACf,SAAS,EACT,6BAA6B,EAC9B,MAAM,wBAAwB,CAAC;;AAEhC,MAAM,iBAAiB,GAAG,qBAAqB,CAAC;AAChD,MAAM,WAAW,GAAG,gBAAgB,CAAC;AAErC;;;;;;GAMG;AAIH,MAAM,OAAO,iBAAiB;IAC5B,gBAAe,CAAC;IAEhB,IAAI,eAAe,CAAC,QAAgB;QAClC,IAAI,QAAQ,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE;YACpC,YAAY,CAAC,OAAO,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;SACnD;IACH,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,YAAY,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;IACjD,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,WAAW;QACT,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,eAAe,IAAI,kBAAkB,EAAE,CAAC;QACnG,OAAO,QAAQ,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;;;;;;OAOG;IACH,kBAAkB;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED;;;;;;;;OAQG;IACH,gBAAgB;QACd,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEjD,OAAO,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YACzB,OAAO;SACR;QAED,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,kBAAkB,CAAC,QAAgB;QACjC,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;IAClC,CAAC;IAED;;;;;;;;;;OAUG;IACH,mBAAmB,CAAC,QAAiB;QACnC,QAAQ,GAAG,QAAQ,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC/C,MAAM,OAAO,GAAG,4BAA4B,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtG,MAAM,QAAQ,GAAG,6BAA6B,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC;QACxG,MAAM,gBAAgB,GAAG,OAAO,CAAC,SAAS,IAAI,GAAG,CAAC;QAClD,MAAM,iBAAiB,GAAG,QAAQ,CAAC,SAAS,IAAI,GAAG,CAAC;QAEpD,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,CAAC;IACjD,CAAC;;kFA3HU,iBAAiB;uEAAjB,iBAAiB,WAAjB,iBAAiB,mBAFhB,MAAM;uFAEP,iBAAiB;cAH7B,UAAU;eAAC;gBACV,UAAU,EAAE,MAAM;aACnB","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport { getBrowserLanguage, getShortLanguage, isLanguage } from '../../utils/util';\nimport {\n  poLocaleDecimalSeparatorList,\n  poLocaleDefault,\n  poLocales,\n  poLocaleThousandSeparatorList\n} from './po-language.constant';\n\nconst poDefaultLanguage = 'PO_DEFAULT_LANGUAGE';\nconst poLocaleKey = 'PO_USER_LOCALE';\n\n/**\n * @docsPrivate\n *\n * @description\n *\n * Serviço responsável por gerenciar as linguagens da aplicação.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PoLanguageService {\n  constructor() {}\n\n  set languageDefault(language: string) {\n    if (language && isLanguage(language)) {\n      localStorage.setItem(poDefaultLanguage, language);\n    }\n  }\n\n  get languageDefault(): string {\n    return localStorage.getItem(poDefaultLanguage);\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar o idioma ativo.\n   *\n   * A busca do idioma será feita na seguinte ordem:\n   *\n   *   1 - o idioma que foi armazenado no *localStorage*, através do método `setLanguage()` utilizado pelo i18n.\n   *\n   *   2 - o valor inserido nas configurações do módulo do i18n através do parâmetro `config`, sendo o idioma inserido\n   * na propriedade `language` da interface `PoI18nConfigDefault`.\n   *\n   *   3 - o idioma do navegador utilizado.\n   *\n   * > Caso o idioma do navegador não seja suportado pelo PO (`pt`, `en`, `es` ou `ru`), será retornado valor `pt`.\n   *\n   * **Retorno:** `string` com a sigla do idioma ativo.\n   */\n  getLanguage(): string {\n    const language = localStorage.getItem(poLocaleKey) || this.languageDefault || getBrowserLanguage();\n    return language && language.toLowerCase();\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar o idioma *default* da aplicação definido nas configurações do módulo do i18n através\n   * do parâmetro `config`.\n   *\n   * **Retorno:** `string` com a sigla do idioma *default*.\n   */\n  getLanguageDefault(): string {\n    return this.languageDefault;\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar a abreviação do idioma ativo na aplicação.\n   *\n   * @default `pt`\n   *\n   * **Retorno:** `string` com a sigla abreviada do idioma ativo.\n   */\n  getShortLanguage(): string {\n    const language = this.getLanguage();\n    const shortLanguage = getShortLanguage(language);\n\n    return poLocales.includes(shortLanguage) ? shortLanguage : poLocaleDefault;\n  }\n\n  /**\n   * @description\n   *\n   * Método para salvar o idioma da aplicação no *storage*, utilizado pelo serviço do i18n.\n   *\n   * > Ao definir um idioma por este método, todos os módulos da aplicação utilizarão o idioma definido.\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma,\n   * podendo ser adicionado outras duas letras representando o país, por exemplo: `pt`, `pt-BR`, `pt-br`, `en` ou `en-US`.\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  setLanguage(language: string): void {\n    if (!isLanguage(language)) {\n      return;\n    }\n\n    localStorage.setItem(poLocaleKey, language.toLowerCase());\n  }\n\n  /**\n   * @description\n   *\n   * Método que define o idioma configurado a partir do parâmetro `config` utilizado pelo módulo do i18n.\n   *\n   * > Ao definir um idioma por este serviço, apenas o módulo do i18n referente a esta configuração utilizará o idioma definido.\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma,\n   * podendo ser adicionado outras duas letras representando o país, por exemplo: `pt`, `pt-BR`, `pt-br`, `en` ou `en-US`.\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  setLanguageDefault(language: string): void {\n    this.languageDefault = language;\n  }\n\n  /**\n   * @description\n   *\n   * Método que retorna o separador\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  getNumberSeparators(language?: string) {\n    language = language || this.getShortLanguage();\n    const decimal = poLocaleDecimalSeparatorList.find(separator => separator.language === language) ?? {};\n    const thousand = poLocaleThousandSeparatorList.find(separator => separator.language === language) ?? {};\n    const decimalSeparator = decimal.separator ?? ',';\n    const thousandSeparator = thousand.separator ?? '.';\n\n    return { decimalSeparator, thousandSeparator };\n  }\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-language.service.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/services/po-language/po-language.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACpF,OAAO,EACL,4BAA4B,EAC5B,eAAe,EACf,SAAS,EACT,6BAA6B,EAC9B,MAAM,wBAAwB,CAAC;;AAEhC,YAAY,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;AAC/C,YAAY,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;AAE1C,MAAM,iBAAiB,GAAG,qBAAqB,CAAC;AAChD,MAAM,WAAW,GAAG,gBAAgB,CAAC;AAErC;;;;;;GAMG;AAIH,MAAM,OAAO,iBAAiB;IAC5B,gBAAe,CAAC;IAEhB,IAAI,eAAe,CAAC,QAAgB;QAClC,IAAI,QAAQ,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE;YACpC,YAAY,CAAC,OAAO,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;SACnD;IACH,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,YAAY,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;IACjD,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,WAAW;QACT,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,eAAe,IAAI,kBAAkB,EAAE,CAAC;QACnG,OAAO,QAAQ,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;;;;;;OAOG;IACH,kBAAkB;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED;;;;;;;;OAQG;IACH,gBAAgB;QACd,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAEjD,OAAO,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC;IAC7E,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YACzB,OAAO;SACR;QAED,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,kBAAkB,CAAC,QAAgB;QACjC,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;IAClC,CAAC;IAED;;;;;;;;;;OAUG;IACH,mBAAmB,CAAC,QAAiB;QACnC,QAAQ,GAAG,QAAQ,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC/C,MAAM,OAAO,GAAG,4BAA4B,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtG,MAAM,QAAQ,GAAG,6BAA6B,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC;QACxG,MAAM,gBAAgB,GAAG,OAAO,CAAC,SAAS,IAAI,GAAG,CAAC;QAClD,MAAM,iBAAiB,GAAG,QAAQ,CAAC,SAAS,IAAI,GAAG,CAAC;QAEpD,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,CAAC;IACjD,CAAC;;kFA3HU,iBAAiB;uEAAjB,iBAAiB,WAAjB,iBAAiB,mBAFhB,MAAM;uFAEP,iBAAiB;cAH7B,UAAU;eAAC;gBACV,UAAU,EAAE,MAAM;aACnB","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport { getBrowserLanguage, getShortLanguage, isLanguage } from '../../utils/util';\nimport {\n  poLocaleDecimalSeparatorList,\n  poLocaleDefault,\n  poLocales,\n  poLocaleThousandSeparatorList\n} from './po-language.constant';\n\nlocalStorage.removeItem('PO_DEFAULT_LANGUAGE');\nlocalStorage.removeItem('PO_USER_LOCALE');\n\nconst poDefaultLanguage = 'PO_DEFAULT_LANGUAGE';\nconst poLocaleKey = 'PO_USER_LOCALE';\n\n/**\n * @docsPrivate\n *\n * @description\n *\n * Serviço responsável por gerenciar as linguagens da aplicação.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PoLanguageService {\n  constructor() {}\n\n  set languageDefault(language: string) {\n    if (language && isLanguage(language)) {\n      localStorage.setItem(poDefaultLanguage, language);\n    }\n  }\n\n  get languageDefault(): string {\n    return localStorage.getItem(poDefaultLanguage);\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar o idioma ativo.\n   *\n   * A busca do idioma será feita na seguinte ordem:\n   *\n   *   1 - o idioma que foi armazenado no *localStorage*, através do método `setLanguage()` utilizado pelo i18n.\n   *\n   *   2 - o valor inserido nas configurações do módulo do i18n através do parâmetro `config`, sendo o idioma inserido\n   * na propriedade `language` da interface `PoI18nConfigDefault`.\n   *\n   *   3 - o idioma do navegador utilizado.\n   *\n   * > Caso o idioma do navegador não seja suportado pelo PO (`pt`, `en`, `es` ou `ru`), será retornado valor `pt`.\n   *\n   * **Retorno:** `string` com a sigla do idioma ativo.\n   */\n  getLanguage(): string {\n    const language = localStorage.getItem(poLocaleKey) || this.languageDefault || getBrowserLanguage();\n    return language && language.toLowerCase();\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar o idioma *default* da aplicação definido nas configurações do módulo do i18n através\n   * do parâmetro `config`.\n   *\n   * **Retorno:** `string` com a sigla do idioma *default*.\n   */\n  getLanguageDefault(): string {\n    return this.languageDefault;\n  }\n\n  /**\n   * @description\n   *\n   * Método responsável por retornar a abreviação do idioma ativo na aplicação.\n   *\n   * @default `pt`\n   *\n   * **Retorno:** `string` com a sigla abreviada do idioma ativo.\n   */\n  getShortLanguage(): string {\n    const language = this.getLanguage();\n    const shortLanguage = getShortLanguage(language);\n\n    return poLocales.includes(shortLanguage) ? shortLanguage : poLocaleDefault;\n  }\n\n  /**\n   * @description\n   *\n   * Método para salvar o idioma da aplicação no *storage*, utilizado pelo serviço do i18n.\n   *\n   * > Ao definir um idioma por este método, todos os módulos da aplicação utilizarão o idioma definido.\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma,\n   * podendo ser adicionado outras duas letras representando o país, por exemplo: `pt`, `pt-BR`, `pt-br`, `en` ou `en-US`.\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  setLanguage(language: string): void {\n    if (!isLanguage(language)) {\n      return;\n    }\n\n    localStorage.setItem(poLocaleKey, language.toLowerCase());\n  }\n\n  /**\n   * @description\n   *\n   * Método que define o idioma configurado a partir do parâmetro `config` utilizado pelo módulo do i18n.\n   *\n   * > Ao definir um idioma por este serviço, apenas o módulo do i18n referente a esta configuração utilizará o idioma definido.\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma,\n   * podendo ser adicionado outras duas letras representando o país, por exemplo: `pt`, `pt-BR`, `pt-br`, `en` ou `en-US`.\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  setLanguageDefault(language: string): void {\n    this.languageDefault = language;\n  }\n\n  /**\n   * @description\n   *\n   * Método que retorna o separador\n   *\n   * @param language sigla do idioma.\n   *\n   * Esta sigla deve ser composta por duas letras representando o idioma\n   *\n   * > Caso seja informado um valor diferente deste padrão, o mesmo será ignorado.\n   */\n  getNumberSeparators(language?: string) {\n    language = language || this.getShortLanguage();\n    const decimal = poLocaleDecimalSeparatorList.find(separator => separator.language === language) ?? {};\n    const thousand = poLocaleThousandSeparatorList.find(separator => separator.language === language) ?? {};\n    const decimalSeparator = decimal.separator ?? ',';\n    const thousandSeparator = thousand.separator ?? '.';\n\n    return { decimalSeparator, thousandSeparator };\n  }\n}\n"]}