keevo-components 1.8.121 → 1.8.123

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 (50) hide show
  1. package/esm2022/lib/api/base-components/base-component-button.mjs +39 -0
  2. package/esm2022/lib/api/base-components/base-component-chart.mjs +92 -0
  3. package/esm2022/lib/api/base-components/base-component-crud-form.mjs +298 -0
  4. package/esm2022/lib/api/base-components/base-component-crud-list.mjs +78 -0
  5. package/esm2022/lib/api/base-components/base-component-crud.mjs +65 -0
  6. package/esm2022/lib/api/base-components/base-component.mjs +51 -0
  7. package/esm2022/lib/api/components/chart/chart.config.mjs +2 -0
  8. package/esm2022/lib/api/components/chart/chart.model.mjs +2 -0
  9. package/esm2022/lib/api/components/table/action-item.mjs +2 -0
  10. package/esm2022/lib/api/components/table/kv-menuitem.mjs +46 -0
  11. package/esm2022/lib/api/components/table/table-dropdown-control.mjs +2 -0
  12. package/esm2022/lib/api/components/table/table.config.column.mjs +2 -0
  13. package/esm2022/lib/api/components/table/table.config.mjs +2 -0
  14. package/esm2022/lib/api/components/table/table.paginate.mjs +9 -0
  15. package/esm2022/lib/api/components/tree-table/tree-table.config.mjs +3 -0
  16. package/esm2022/lib/api/services/component.service.mjs +27 -0
  17. package/esm2022/lib/api/services/form.service.mjs +85 -0
  18. package/esm2022/lib/api/services/notification.service.mjs +67 -0
  19. package/esm2022/lib/api/services/object.service.mjs +39 -0
  20. package/esm2022/lib/api/types/severity.mjs +2 -0
  21. package/esm2022/lib/components/kv-chart/kv-chart.component.mjs +145 -0
  22. package/esm2022/lib/components/kv-error/kv-error.component.mjs +26 -0
  23. package/esm2022/lib/components/kv-loader/kv-loader.service.mjs +29 -0
  24. package/esm2022/lib/components/kv-report/kv-report.component.mjs +6 -4
  25. package/fesm2022/keevo-components.mjs +5 -3
  26. package/fesm2022/keevo-components.mjs.map +1 -1
  27. package/lib/api/base-components/base-component-button.d.ts +15 -0
  28. package/lib/api/base-components/base-component-chart.d.ts +40 -0
  29. package/lib/api/base-components/base-component-crud-form.d.ts +145 -0
  30. package/lib/api/base-components/base-component-crud-list.d.ts +64 -0
  31. package/lib/api/base-components/base-component-crud.d.ts +36 -0
  32. package/lib/api/base-components/base-component.d.ts +22 -0
  33. package/lib/api/components/chart/chart.config.d.ts +11 -0
  34. package/lib/api/components/chart/chart.model.d.ts +9 -0
  35. package/lib/api/components/table/action-item.d.ts +11 -0
  36. package/lib/api/components/table/kv-menuitem.d.ts +152 -0
  37. package/lib/api/components/table/table-dropdown-control.d.ts +6 -0
  38. package/lib/api/components/table/table.config.column.d.ts +25 -0
  39. package/lib/api/components/table/table.config.d.ts +31 -0
  40. package/lib/api/components/table/table.paginate.d.ts +6 -0
  41. package/lib/api/components/tree-table/tree-table.config.d.ts +28 -0
  42. package/lib/api/services/component.service.d.ts +11 -0
  43. package/lib/api/services/form.service.d.ts +28 -0
  44. package/lib/api/services/notification.service.d.ts +25 -0
  45. package/lib/api/services/object.service.d.ts +9 -0
  46. package/lib/api/types/severity.d.ts +2 -0
  47. package/lib/components/kv-chart/kv-chart.component.d.ts +56 -0
  48. package/lib/components/kv-error/kv-error.component.d.ts +12 -0
  49. package/lib/components/kv-loader/kv-loader.service.d.ts +10 -0
  50. package/package.json +1 -1
@@ -0,0 +1,51 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import * as i0 from "@angular/core";
4
+ export class BaseComponent {
5
+ constructor() {
6
+ this.stateChanges = new Subject();
7
+ this.isRequired = false;
8
+ this.disabled = false;
9
+ }
10
+ set value(value) {
11
+ this._value = value;
12
+ if (this.onChange)
13
+ this.onChange(value);
14
+ this.stateChanges.next();
15
+ }
16
+ get value() {
17
+ return this._value;
18
+ }
19
+ registerOnChange(fn) {
20
+ this.onChange = fn;
21
+ }
22
+ registerOnTouched(fn) {
23
+ this.onTouched = fn;
24
+ }
25
+ setDisabledState(isDisabled) {
26
+ this.disabled = isDisabled;
27
+ }
28
+ writeValue(value) {
29
+ this.value = value;
30
+ }
31
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: BaseComponent, selector: "ng-component", inputs: { isRequired: ["required", "isRequired"], componentId: "componentId", label: "label", disabled: "disabled", maxLength: "maxLength" }, ngImport: i0, template: '', isInline: true }); }
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BaseComponent, decorators: [{
35
+ type: Component,
36
+ args: [{
37
+ template: ''
38
+ }]
39
+ }], propDecorators: { isRequired: [{
40
+ type: Input,
41
+ args: ['required']
42
+ }], componentId: [{
43
+ type: Input
44
+ }], label: [{
45
+ type: Input
46
+ }], disabled: [{
47
+ type: Input
48
+ }], maxLength: [{
49
+ type: Input
50
+ }] } });
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2Jhc2UtY29tcG9uZW50cy9iYXNlLWNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQUsvQixNQUFNLE9BQWdCLGFBQWE7SUFIbkM7UUFLWSxpQkFBWSxHQUFrQixJQUFJLE9BQU8sRUFBRSxDQUFDO1FBS25DLGVBQVUsR0FBWSxLQUFLLENBQUM7UUFjdEMsYUFBUSxHQUFZLEtBQUssQ0FBQztLQWtCcEM7SUE5QkMsSUFBVyxLQUFLLENBQUMsS0FBUTtRQUN2QixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixJQUFJLElBQUksQ0FBQyxRQUFRO1lBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQU9ELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELGdCQUFnQixDQUFFLFVBQW1CO1FBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFDO0lBQzdCLENBQUM7SUFFRCxVQUFVLENBQUMsS0FBUTtRQUNqQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDOzhHQXRDbUIsYUFBYTtrR0FBYixhQUFhLGtNQUZ2QixFQUFFOzsyRkFFUSxhQUFhO2tCQUhsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxFQUFFO2lCQUNiOzhCQVFvQixVQUFVO3NCQUE1QixLQUFLO3VCQUFDLFVBQVU7Z0JBWVIsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogJydcbn0pXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUNvbXBvbmVudDxUPiBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcblxuICBwcm90ZWN0ZWQgc3RhdGVDaGFuZ2VzOiBTdWJqZWN0PHZvaWQ+ID0gbmV3IFN1YmplY3QoKTtcbiAgcHJvdGVjdGVkIG9uQ2hhbmdlITogKHZhbHVlOiBUKSA9PiB2b2lkO1xuICBwcm90ZWN0ZWQgb25Ub3VjaGVkITogKCkgPT4gdm9pZDtcbiAgcHJvdGVjdGVkIF92YWx1ZSE6IFQ7XG5cbiAgQElucHV0KCdyZXF1aXJlZCcpIGlzUmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBwdWJsaWMgc2V0IHZhbHVlKHZhbHVlOiBUKSB7XG4gICAgdGhpcy5fdmFsdWUgPSB2YWx1ZTtcbiAgICBpZiAodGhpcy5vbkNoYW5nZSkgdGhpcy5vbkNoYW5nZSh2YWx1ZSk7XG4gICAgdGhpcy5zdGF0ZUNoYW5nZXMubmV4dCgpO1xuICB9XG5cbiAgcHVibGljIGdldCB2YWx1ZSgpOiBUIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XG4gIH1cblxuICBASW5wdXQoKSBjb21wb25lbnRJZCE6IHN0cmluZztcbiAgQElucHV0KCkgbGFiZWwhOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIG1heExlbmd0aCE6IG51bWJlcjtcblxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcbiAgfVxuXG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcbiAgfVxuXG4gIHdyaXRlVmFsdWUodmFsdWU6IFQpOiB2b2lkIHtcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9jb21wb25lbnRzL2NoYXJ0L2NoYXJ0LmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBDaGFydENvbmZpZyB7XG4gIGxhYmVsczogc3RyaW5nW107XG4gIGRhdGFzZXRzOiBDaGFydERhdGFzZXRDb25maWdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDaGFydERhdGFzZXRDb25maWcge1xuICBsYWJlbD86IHN0cmluZztcbiAgYmFja2dyb3VuZENvbG9yOiBzdHJpbmdbXTtcbiAgaG92ZXJCYWNrZ3JvdW5kQ29sb3I6IHN0cmluZ1tdO1xuICBib3JkZXJDb2xvcj86IHN0cmluZ1tdO1xuICBkYXRhOiBudW1iZXJbXTtcbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvY2hhcnQvY2hhcnQubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgY2hhcnRNb2RlbCB7XG4gIGxhYmVsczogc3RyaW5nO1xuICBudW1EYXRhc2V0czogbnVtYmVyO1xuICBsYWJlbERhdGFzZXQ/OiBzdHJpbmc7XG4gIGRhdGFzZXRzOiBudW1iZXI7XG4gIGJhY2tncm91bmRDb2xvcjogc3RyaW5nO1xuICBob3ZlckJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgYm9yZGVyQ29sb3I/OiBzdHJpbmc7XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvdGFibGUvYWN0aW9uLWl0ZW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uSXRlbSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGljb24/OiBzdHJpbmc7XG4gIGNvbG9yPzogc3RyaW5nO1xuICBjb2xvckhvdmVyPzogc3RyaW5nO1xuICB0ZXh0Q29sb3I/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgdmlzaWJsZT86IGJvb2xlYW47XG4gIGNsb3NlQWZ0ZXJDbGljaz86IGJvb2xlYW47XG4gIGNvbW1hbmQ/OiAoZXZlbnQ/OiBhbnkpID0+IHZvaWQ7XG59XG4iXX0=
@@ -0,0 +1,46 @@
1
+ export function getOrExecute(vof, data) {
2
+ if (typeof vof === "function") {
3
+ return vof(data);
4
+ }
5
+ else {
6
+ return vof;
7
+ }
8
+ }
9
+ export function mapToMenuItem(kvMenuItem, data) {
10
+ return {
11
+ label: getOrExecute(kvMenuItem.label, data),
12
+ icon: getOrExecute(kvMenuItem.icon, data),
13
+ command: kvMenuItem.command,
14
+ url: getOrExecute(kvMenuItem.url, data),
15
+ items: getOrExecute(kvMenuItem.items, data)?.map(x => mapToMenuItem(x, data)),
16
+ expanded: getOrExecute(kvMenuItem.expanded, data),
17
+ disabled: getOrExecute(kvMenuItem.disabled, data),
18
+ visible: getOrExecute(kvMenuItem.visible, data),
19
+ target: getOrExecute(kvMenuItem.target, data),
20
+ escape: kvMenuItem.escape,
21
+ routerLinkActiveOptions: getOrExecute(kvMenuItem.routerLinkActiveOptions, data),
22
+ separator: kvMenuItem.separator,
23
+ badge: getOrExecute(kvMenuItem.badge, data),
24
+ tooltip: getOrExecute(kvMenuItem.tooltip, data),
25
+ tooltipPosition: getOrExecute(kvMenuItem.tooltipPosition, data),
26
+ badgeStyleClass: getOrExecute(kvMenuItem.badgeStyleClass, data),
27
+ style: getOrExecute(kvMenuItem.style, data),
28
+ styleClass: getOrExecute(kvMenuItem.styleClass, data),
29
+ title: getOrExecute(kvMenuItem.title, data),
30
+ id: getOrExecute(kvMenuItem.id, data),
31
+ automationId: getOrExecute(kvMenuItem.automationId, data),
32
+ tabindex: getOrExecute(kvMenuItem.tabindex, data),
33
+ routerLink: getOrExecute(kvMenuItem.routerLink, data),
34
+ queryParams: getOrExecute(kvMenuItem.queryParams, data),
35
+ fragment: getOrExecute(kvMenuItem.fragment, data),
36
+ queryParamsHandling: getOrExecute(kvMenuItem.queryParamsHandling, data),
37
+ preserveFragment: getOrExecute(kvMenuItem.preserveFragment, data),
38
+ skipLocationChange: getOrExecute(kvMenuItem.skipLocationChange, data),
39
+ replaceUrl: getOrExecute(kvMenuItem.replaceUrl, data),
40
+ iconStyle: getOrExecute(kvMenuItem.iconStyle, data),
41
+ iconClass: getOrExecute(kvMenuItem.iconClass, data),
42
+ state: getOrExecute(kvMenuItem.state, data),
43
+ tooltipOptions: getOrExecute(kvMenuItem.tooltipOptions, data),
44
+ };
45
+ }
46
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-menuitem.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/api/components/table/kv-menuitem.ts"],"names":[],"mappings":"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","sourcesContent":["import { MenuItem, MenuItemCommandEvent } from \"primeng/api/menuitem\";\nimport { QueryParamsHandling } from \"@angular/router\";\nimport { TooltipOptions } from \"primeng/api\";\n\nexport interface KvMenuItem {\n  /**\n   * Texto do item.\n   */\n  label?: ValueOrFn<string | undefined>;\n  /**\n   * Ícone do item.\n   */\n  icon?: ValueOrFn<string | undefined>;\n  /**\n   * Callback a ser executada quando o item é clicado.\n   */\n  command?: (event: MenuItemCommandEvent) => void;\n  /**\n   * Link externo para navegar quando o item é clicado.\n   */\n  url?: ValueOrFn<string | undefined>;\n  /**\n   * Array de filhos do item.\n   */\n  items?: ValueOrFn<KvMenuItem[] | undefined>;\n  /**\n   * Visibilidade do submenu.\n   */\n  expanded?: ValueOrFn<boolean | undefined>;\n  /**\n   * Quando verdadeiro, desabilita o item.\n   */\n  disabled?: ValueOrFn<boolean | undefined>;\n  /**\n   * Define se o elemento da dom do item é ou não criado.\n   */\n  visible?: ValueOrFn<boolean | undefined>;\n  /**\n   * Specifies where to open the linked document.\n   */\n  target?: ValueOrFn<string | undefined>;\n  /**\n   * Whether to escape the label or not. Set to false to display html content.\n   */\n  escape?: boolean;\n  /**\n   * Configuration for active router link.\n   */\n  routerLinkActiveOptions?: ValueOrFn<any | undefined>;\n  /**\n   * Defines the item as a separator.\n   */\n  separator?: boolean;\n  /**\n   * Value of the badge.\n   */\n  badge?: ValueOrFn<string | undefined>;\n  /**\n   * Tooltip of the item.\n   */\n  tooltip?: ValueOrFn<string | undefined>;\n  /**\n   * Position of the tooltip item.\n   */\n  tooltipPosition?: ValueOrFn<string | undefined>;\n  /**\n   * Style class of the badge.\n   */\n  badgeStyleClass?: ValueOrFn<string | undefined>;\n  /**\n   * Inline style of the menuitem.\n   */\n  style?: ValueOrFn<{\n    [klass: string]: any;\n  } | null | undefined>;\n  /**\n   * Style class of the menuitem.\n   */\n  styleClass?: ValueOrFn<string | undefined>;\n  /**\n   * Tooltip text of the item.\n   */\n  title?: ValueOrFn<string | undefined>;\n  /**\n   * Identifier of the element.\n   */\n  id?: ValueOrFn<string | undefined>;\n  /**\n   * Value of HTML data-* attribute.\n   */\n  automationId?: ValueOrFn<any | undefined>;\n  /**\n   * Specifies tab order of the item.\n   */\n  tabindex?: ValueOrFn<string | undefined>;\n  /**\n   * RouterLink definition for internal navigation.\n   */\n  routerLink?: ValueOrFn<any | undefined>;\n  /**\n   * Query parameters for internal navigation via routerLink.\n   */\n  queryParams?: ValueOrFn<{\n    [k: string]: any;\n  } | undefined>;\n  /**\n   * Sets the hash fragment for the URL.\n   */\n  fragment?: ValueOrFn<string | undefined>;\n  /**\n   *  How to handle query parameters in the router link for the next navigation. One of:\n      merge : Merge new with current parameters.\n      preserve : Preserve current parameters.k.\n   */\n  queryParamsHandling?: ValueOrFn<QueryParamsHandling | undefined>;\n  /**\n   * When true, preserves the URL fragment for the next navigation.\n   */\n  preserveFragment?: ValueOrFn<boolean | undefined>;\n  /**\n   * When true, navigates without pushing a new state into history.\n   */\n  skipLocationChange?: ValueOrFn<boolean | undefined>;\n  /**\n   * When true, navigates while replacing the current state in history.\n   */\n  replaceUrl?: ValueOrFn<boolean | undefined>;\n  /**\n   * Inline style of the item's icon.\n   */\n  iconStyle?: ValueOrFn<{\n    [klass: string]: any;\n  } | null | undefined>;\n  /**\n   * Class of the item's icon.\n   */\n  iconClass?: ValueOrFn<string | undefined>;\n  /**\n   * Developer-defined state that can be passed to any navigation.\n   * @see {MenuItemState}\n   */\n  state?: ValueOrFn<{\n    [k: string]: any;\n  } | undefined>;\n  /**\n   * Options of the item's tooltip.\n   * @see {TooltipOptions}\n   */\n  tooltipOptions?: ValueOrFn<TooltipOptions | undefined>;\n}\n\nexport type ValueOrFn<T> = T | ((data: any) => T);\n\nexport function getOrExecute<T>(vof: ValueOrFn<T>, data: any): T {\n  if (typeof vof === \"function\") {\n    return (vof as (data: any) => T)(data);\n  } else {\n    return vof;\n  }\n}\n\nexport function mapToMenuItem(kvMenuItem: KvMenuItem, data: any): MenuItem {\n  return {\n    label: getOrExecute(kvMenuItem.label, data),\n    icon: getOrExecute(kvMenuItem.icon, data),\n    command: kvMenuItem.command,\n    url: getOrExecute(kvMenuItem.url, data),\n    items: getOrExecute(kvMenuItem.items, data)?.map(x => mapToMenuItem(x, data)),\n    expanded: getOrExecute(kvMenuItem.expanded, data),\n    disabled: getOrExecute(kvMenuItem.disabled, data),\n    visible: getOrExecute(kvMenuItem.visible, data),\n    target: getOrExecute(kvMenuItem.target, data),\n    escape: kvMenuItem.escape,\n    routerLinkActiveOptions: getOrExecute(kvMenuItem.routerLinkActiveOptions, data),\n    separator: kvMenuItem.separator,\n    badge: getOrExecute(kvMenuItem.badge, data),\n    tooltip: getOrExecute(kvMenuItem.tooltip, data),\n    tooltipPosition: getOrExecute(kvMenuItem.tooltipPosition, data),\n    badgeStyleClass: getOrExecute(kvMenuItem.badgeStyleClass, data),\n    style: getOrExecute(kvMenuItem.style, data),\n    styleClass: getOrExecute(kvMenuItem.styleClass, data),\n    title: getOrExecute(kvMenuItem.title, data),\n    id: getOrExecute(kvMenuItem.id, data),\n    automationId: getOrExecute(kvMenuItem.automationId, data),\n    tabindex: getOrExecute(kvMenuItem.tabindex, data),\n    routerLink: getOrExecute(kvMenuItem.routerLink, data),\n    queryParams: getOrExecute(kvMenuItem.queryParams, data),\n    fragment: getOrExecute(kvMenuItem.fragment, data),\n    queryParamsHandling: getOrExecute(kvMenuItem.queryParamsHandling, data),\n    preserveFragment: getOrExecute(kvMenuItem.preserveFragment, data),\n    skipLocationChange: getOrExecute(kvMenuItem.skipLocationChange, data),\n    replaceUrl: getOrExecute(kvMenuItem.replaceUrl, data),\n    iconStyle: getOrExecute(kvMenuItem.iconStyle, data),\n    iconClass: getOrExecute(kvMenuItem.iconClass, data),\n    state: getOrExecute(kvMenuItem.state, data),\n    tooltipOptions: getOrExecute(kvMenuItem.tooltipOptions, data),\n  };\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZHJvcGRvd24tY29udHJvbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvY29tcG9uZW50cy90YWJsZS90YWJsZS1kcm9wZG93bi1jb250cm9sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBpbnRlcmZhY2UgRmllbGREcm9wRG93bkNvbnRyb2wge1xuICBmaWVsZENvbnRyb2xEcm9wZG93blNlcnZpY2U/OiBhbnk7XG4gIGZpZWxkQ29udHJvbERyb3Bkb3duU291cmNlPzogYW55O1xuICBpZG9iamV0bzogc3RyaW5nO1xuICBkZXNjcmljYW9vYmpldG86IHN0cmluZztcbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmNvbHVtbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvY29tcG9uZW50cy90YWJsZS90YWJsZS5jb25maWcuY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgRmllbGREcm9wRG93bkNvbnRyb2wgZnJvbSBcIi4vdGFibGUtZHJvcGRvd24tY29udHJvbFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnQ29sdW1uIHtcbiAgcG9zaXRpb24/OiBudW1iZXI7XG4gIGZpZWxkOiBzdHJpbmc7XG4gIGhlYWRlcjogc3RyaW5nO1xuICBoZWFkZXJUb29sdGlwPzogc3RyaW5nO1xuICBmaWVsZFR5cGU/OiBzdHJpbmc7XG4gIG9ubHlSZWFkRmllbGQ/OiBib29sZWFuO1xuICB3aWR0aD86IHN0cmluZztcbiAgcGlwZT86ICdkYXRlJyB8ICdkYXRlTW9udGhZZWFyJyB8ICdkZWNpbWFsJyB8ICdjcGZjbnBqJyB8ICd0ZWxlZm9uZScgfCAnY29kaWdvZmlwZScgfCAnbW9uZXknIHwgJ3BlcmNlbnRhZ2UnO1xuICBzb3J0YWJsZTogYm9vbGVhbjtcbiAgZ3JvdXBlZD86IGJvb2xlYW47XG4gIGNlbnRyYWxpemU/OiBib29sZWFuO1xuICBleHBpcmVkRGF0ZT86IGJvb2xlYW47XG4gIGljb24/OiBzdHJpbmc7XG4gIGljb25GaWVsZD86IGJvb2xlYW47XG4gIGluZEljb25NYXRlcmlhbD86IGJvb2xlYW47XG4gIGNoZWNrZWQ/OiBib29sZWFuO1xuICBoaWRlQ29sdW1uPzogYm9vbGVhbjtcbiAgZml4ZWRDb2x1bW4/OiBib29sZWFuO1xuICB0ZW1wbGF0ZT86IGFueTtcbiAgYWxpZ24/OiBzdHJpbmc7XG4gIHN1YnRpdGxlPzogc3RyaW5nO1xuICBib29sZWFuPzogYm9vbGVhbjtcbiAgdGVtcGxhdGVPbmx5PzogJ3BhaScgfCAnZmlsaG8nXG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGFibGVDb25maWdDb2x1bW4gfSBmcm9tICcuL3RhYmxlLmNvbmZpZy5jb2x1bW4nO1xuaW1wb3J0IHsgS3ZNZW51SXRlbSwgVmFsdWVPckZuIH0gZnJvbSAnLi9rdi1tZW51aXRlbSc7XG5pbXBvcnQgU2V2ZXJpdHkgZnJvbSAnLi4vLi4vdHlwZXMvc2V2ZXJpdHknO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnIHtcbiAgYWN0aW9ucz86IEt2TWVudUl0ZW1bXTtcbiAgYWN0aW9uc0xvdGU/OiBBY3Rpb25zTG90ZUl0ZW1bXTtcbiAgY29sdW1uczogVGFibGVDb25maWdDb2x1bW5bXTtcbiAgZGF0YUtleT86IHN0cmluZztcbiAgcm93cz86IGFueTtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHN1YnRpdGxlPzogc3RyaW5nO1xuICBsYXp5OiBib29sZWFuO1xuICBmaWVsZEdyb3VwPzogc3RyaW5nO1xuICBlbmFibGVDYXRpb24/OiBib29sZWFuO1xuICBlbmFibGVGaWx0ZXI/OiBib29sZWFuO1xuICBlbmFibGVTZWxlY3Q/OiBib29sZWFuO1xuICBlbmFibGVUb2dnbGVOb2Rlcz86IGJvb2xlYW47XG4gIC8vIHZpc2libGVDb250cm9sQ2hlY2tib3hGdW5jdGlvbj86IChyb3dEYXRhOiBhbnkpID0+IGJvb2xlYW47IC8vIEEgZnVuw6fDo28gcXVlIGNvbnRyb2xhIGEgZWRpw6fDo29cbiAgZGlzYWJsZUNvbnRyb2xDaGVja2JveEZ1bmN0aW9uPzogKHJvd0RhdGE6IGFueSwgcm93Tm9kZT86IGFueSkgPT4gYm9vbGVhbjsgLy8gQSBmdW7Dp8OjbyBxdWUgY29udHJvbGEgYSBlZGnDp8Ojb1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbnNMb3RlSXRlbSB7XG4gIC8qKlxuICAgKiBJZ25vcmFkbyBwb3IgZW5xdWFudG9cbiAgICovXG4gIHNldmVyaXR5PzogU2V2ZXJpdHk7XG4gIGljb246IHN0cmluZztcbiAgc2hvd0Fjb2VzTG90ZT86IGJvb2xlYW47XG4gIHRvb2x0aXA/OiBWYWx1ZU9yRm48c3RyaW5nIHwgdW5kZWZpbmVkPjtcbiAgZGlzYWJsZWQ/OiBWYWx1ZU9yRm48Ym9vbGVhbiB8IHVuZGVmaW5lZD47XG4gIHZpc2libGU/OiBWYWx1ZU9yRm48Ym9vbGVhbiB8IHVuZGVmaW5lZD47XG4gIGNvbW1hbmQ/OiAoKSA9PiB2b2lkO1xufVxuIl19
@@ -0,0 +1,9 @@
1
+ export class TablePaginate {
2
+ constructor() {
3
+ this.paginaInicial = 1;
4
+ this.tamanhoPagina = 10;
5
+ this.termoPesquisa = '';
6
+ this.ordenacao = '';
7
+ }
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUucGFnaW5hdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvdGFibGUvdGFibGUucGFnaW5hdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWE7SUFBMUI7UUFDRSxrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUMxQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixjQUFTLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBUYWJsZVBhZ2luYXRlIHtcbiAgcGFnaW5hSW5pY2lhbDogbnVtYmVyID0gMTtcbiAgdGFtYW5ob1BhZ2luYTogbnVtYmVyID0gMTA7XG4gIHRlcm1vUGVzcXVpc2E6IHN0cmluZyA9ICcnO1xuICBvcmRlbmFjYW86IHN0cmluZyA9ICcnO1xufVxuIl19
@@ -0,0 +1,3 @@
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS10YWJsZS5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvdHJlZS10YWJsZS90cmVlLXRhYmxlLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRhYmxlQ29uZmlnQ29sdW1uIH0gZnJvbSAnLi4vdGFibGUvdGFibGUuY29uZmlnLmNvbHVtbic7XG5pbXBvcnQgeyBLdk1lbnVJdGVtLCBWYWx1ZU9yRm4gfSBmcm9tICcuLi90YWJsZS9rdi1tZW51aXRlbSc7XG5pbXBvcnQgU2V2ZXJpdHkgZnJvbSAnLi4vLi4vdHlwZXMvc2V2ZXJpdHknO1xuaW1wb3J0IHsgQWN0aW9uc0xvdGVJdGVtIH0gZnJvbSAnLi4vdGFibGUvdGFibGUuY29uZmlnJztcblxuZXhwb3J0IGludGVyZmFjZSBUcmVlVGFibGVDb25maWcge1xuICBhY3Rpb25zPzogS3ZNZW51SXRlbVtdO1xuICBhY3Rpb25zTG90ZT86IEFjdGlvbnNMb3RlSXRlbVtdO1xuICBhY3Rpb25zUGFpPzogQWN0aW9uc1BhaUl0ZW1bXTtcbiAgY29sdW1uczogVGFibGVDb25maWdDb2x1bW5bXTtcbiAgZGF0YUtleT86IHN0cmluZztcbiAgcm93cz86IGFueTtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHN1YnRpdGxlPzogc3RyaW5nO1xuICBsYXp5OiBib29sZWFuO1xuICBmaWVsZEdyb3VwPzogc3RyaW5nO1xuICBlbmFibGVDYXRpb24/OiBib29sZWFuO1xuICBlbmFibGVGaWx0ZXI/OiBib29sZWFuO1xuICBlbmFibGVTZWxlY3Q/OiBib29sZWFuO1xuICBlbmFibGVUb2dnbGVOb2Rlcz86IGJvb2xlYW47XG4gIC8vIHZpc2libGVDb250cm9sQ2hlY2tib3hGdW5jdGlvbj86IChyb3dEYXRhOiBhbnkpID0+IGJvb2xlYW47IC8vIEEgZnVuw6fDo28gcXVlIGNvbnRyb2xhIGEgZWRpw6fDo29cbiAgZGlzYWJsZUNvbnRyb2xDaGVja2JveEZ1bmN0aW9uPzogKHJvd0RhdGE6IGFueSwgcm93Tm9kZT86IGFueSkgPT4gYm9vbGVhbjsgLy8gQSBmdW7Dp8OjbyBxdWUgY29udHJvbGEgYSBlZGnDp8Ojb1xufVxuXG5pbnRlcmZhY2UgQWN0aW9uc1BhaUl0ZW0ge1xuICBzZXZlcml0eT86IFNldmVyaXR5O1xuICB2aXNpYmxlPzogVmFsdWVPckZuPGJvb2xlYW4gfCB1bmRlZmluZWQ+O1xuICBjb21tYW5kOiAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIGljb246IHN0cmluZztcbn07XG4iXX0=
@@ -0,0 +1,27 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { FormControlName, FormGroupDirective, NgControl } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ export class ComponentService {
5
+ constructor(injector, changeDetectorRef) {
6
+ this.injector = injector;
7
+ this.changeDetectorRef = changeDetectorRef;
8
+ }
9
+ getFormControl() {
10
+ try {
11
+ const control = this.injector.get(NgControl);
12
+ if (control.constructor === FormControlName) {
13
+ return this.injector.get(FormGroupDirective).getControl(control);
14
+ }
15
+ return undefined;
16
+ }
17
+ catch (ex) {
18
+ return undefined;
19
+ }
20
+ }
21
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ComponentService, deps: [{ token: i0.Injector }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Injectable }); }
22
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ComponentService }); }
23
+ }
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ComponentService, decorators: [{
25
+ type: Injectable
26
+ }], ctorParameters: () => [{ type: i0.Injector }, { type: i0.ChangeDetectorRef }] });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL3NlcnZpY2VzL2NvbXBvbmVudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxVQUFVLEVBRVgsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUVMLGVBQWUsRUFDZixrQkFBa0IsRUFDbEIsU0FBUyxFQUNWLE1BQU0sZ0JBQWdCLENBQUM7O0FBR3hCLE1BQU0sT0FBTyxnQkFBZ0I7SUFFM0IsWUFBNEIsUUFBa0IsRUFBUyxpQkFBb0M7UUFBL0QsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUFTLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7SUFBSSxDQUFDO0lBRWhHLGNBQWM7UUFDWixJQUFJLENBQUM7WUFDSCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUM3QyxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssZUFBZSxFQUFFLENBQUM7Z0JBQzVDLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxVQUFVLENBQUMsT0FBMEIsQ0FBQyxDQUFDO1lBQ3RGLENBQUM7WUFFRCxPQUFPLFNBQVMsQ0FBQztRQUNuQixDQUFDO1FBQ0QsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUNWLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUM7SUFDSCxDQUFDOzhHQWhCVSxnQkFBZ0I7a0hBQWhCLGdCQUFnQjs7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBJbmplY3RhYmxlLFxuICBJbmplY3RvclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgRm9ybUNvbnRyb2wsXG4gIEZvcm1Db250cm9sTmFtZSxcbiAgRm9ybUdyb3VwRGlyZWN0aXZlLFxuICBOZ0NvbnRyb2xcbn0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50U2VydmljZSB7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3RvciwgcHVibGljIGNoYW5nZURldGVjdG9yUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XG5cbiAgZ2V0Rm9ybUNvbnRyb2woKTogRm9ybUNvbnRyb2w8YW55PiB8IHVuZGVmaW5lZCB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGNvbnRyb2wgPSB0aGlzLmluamVjdG9yLmdldChOZ0NvbnRyb2wpO1xuICAgICAgaWYgKGNvbnRyb2wuY29uc3RydWN0b3IgPT09IEZvcm1Db250cm9sTmFtZSkge1xuICAgICAgICByZXR1cm4gdGhpcy5pbmplY3Rvci5nZXQoRm9ybUdyb3VwRGlyZWN0aXZlKS5nZXRDb250cm9sKGNvbnRyb2wgYXMgRm9ybUNvbnRyb2xOYW1lKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gICAgY2F0Y2ggKGV4KSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -0,0 +1,85 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { ObjectService } from './object.service';
3
+ import * as i0 from "@angular/core";
4
+ export class FormService {
5
+ static disableControl(formGroup, controName) {
6
+ formGroup?.controls[controName]?.disable();
7
+ }
8
+ static disableAndClearControl(formGroup, controName, value) {
9
+ this.disableControl(formGroup, controName);
10
+ this.setControlValue(formGroup, controName, null || value);
11
+ }
12
+ static enableControl(formGroup, controName) {
13
+ formGroup?.controls[controName]?.enable();
14
+ }
15
+ static getFormValue(formGroup, controName) {
16
+ return formGroup?.controls[controName]?.value;
17
+ }
18
+ static hasControlError(formGroup, control, errorCode) {
19
+ const formControl = formGroup.get(control);
20
+ let hasError = false;
21
+ if (!formControl)
22
+ return false;
23
+ if (errorCode)
24
+ hasError = formControl.hasError(errorCode);
25
+ else
26
+ hasError = formControl.errors ? true : false;
27
+ return hasError && formControl.touched;
28
+ }
29
+ static invalidForm(formGroup, notification) {
30
+ const keys = Object.keys(formGroup.getRawValue());
31
+ keys.forEach(k => {
32
+ const control = formGroup.controls[k];
33
+ if (notification) {
34
+ if (notification?.item2) {
35
+ const item = ObjectService.findObject(notification.item2, 'property', k);
36
+ if (item)
37
+ control.setErrors({ backendError: true, erroMessage: item.message });
38
+ }
39
+ else {
40
+ const item = ObjectService.findObject(notification, 'key', k);
41
+ if (item)
42
+ control.setErrors({ backendError: true, erroMessage: item.message });
43
+ }
44
+ }
45
+ if (!control.valid) {
46
+ control.markAsTouched();
47
+ }
48
+ });
49
+ }
50
+ static openDialog(dialogService, componentType, callBackFunction, paramsDialog) {
51
+ const ref = dialogService.open(componentType, {
52
+ closable: paramsDialog?.closable || false,
53
+ maximizable: paramsDialog?.maximizable || false,
54
+ height: paramsDialog?.height || 'auto',
55
+ width: paramsDialog?.width,
56
+ styleClass: paramsDialog?.styleClass,
57
+ showHeader: true,
58
+ header: paramsDialog?.header,
59
+ data: { id: paramsDialog?.id, popup: paramsDialog?.popup && true }
60
+ });
61
+ ref.onClose.subscribe((data) => {
62
+ if (data)
63
+ callBackFunction(data);
64
+ });
65
+ }
66
+ static setControlValue(formGroup, controName, value) {
67
+ formGroup?.controls[controName]?.setValue(value);
68
+ }
69
+ static setValidators(formGroup, controName, validators) {
70
+ formGroup?.controls[controName]?.setValidators(validators);
71
+ formGroup?.controls[controName]?.updateValueAndValidity();
72
+ }
73
+ static clearValidators(formGroup, controName) {
74
+ formGroup?.controls[controName]?.updateValueAndValidity();
75
+ }
76
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
77
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormService, providedIn: 'root' }); }
78
+ }
79
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormService, decorators: [{
80
+ type: Injectable,
81
+ args: [{
82
+ providedIn: 'root'
83
+ }]
84
+ }] });
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.service.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/services/form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Type\n} from '@angular/core';\n\nimport {\n  FormGroup,\n  ValidatorFn\n} from '@angular/forms';\n\nimport { ObjectService } from './object.service';\nimport { DialogService } from 'primeng/dynamicdialog';\n\nexport interface paramsDialog {\n  id?: any;\n  closable?: boolean;\n  maximizable?: boolean;\n  popup?: boolean;\n  height?: string;\n  width?: string;\n  styleClass?: string;\n  header?: string;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class FormService {\n\n  static disableControl(formGroup: FormGroup, controName: string) {\n    formGroup?.controls[controName]?.disable();\n  }\n\n  static disableAndClearControl(formGroup: FormGroup, controName: string, value?: any) {\n    this.disableControl(formGroup, controName);\n    this.setControlValue(formGroup, controName, null || value);\n  }\n\n  static enableControl(formGroup: FormGroup, controName: string) {\n    formGroup?.controls[controName]?.enable();\n  }\n\n  static getFormValue<T>(formGroup: FormGroup, controName: string): T {\n    return <T>formGroup?.controls[controName]?.value;\n  }\n\n  static hasControlError(formGroup: FormGroup, control: string, errorCode?: string): boolean {\n    const formControl = formGroup.get(control);\n    let hasError: boolean = false;\n\n    if (!formControl) return false;\n    if (errorCode) hasError = formControl.hasError(errorCode);\n    else hasError = formControl.errors ? true : false;\n\n    return hasError && formControl.touched;\n  }\n\n  static invalidForm(formGroup: FormGroup, notification?: any) {\n    const keys = Object.keys(formGroup.getRawValue());\n\n    keys.forEach(k => {\n      const control = formGroup.controls[k];\n\n      if (notification) {\n        if (notification?.item2) {\n          const item = ObjectService.findObject(notification.item2, 'property', k);\n          if (item) control.setErrors({ backendError: true, erroMessage: item.message });\n        }\n        else {\n          const item = ObjectService.findObject(notification, 'key', k);\n          if (item) control.setErrors({ backendError: true, erroMessage: item.message });\n        }\n      }\n\n      if (!control.valid) {\n        control.markAsTouched();\n      }\n    });\n  }\n\n  static openDialog(\n    dialogService: DialogService,\n    componentType: Type<any>,\n    callBackFunction: Function,\n    paramsDialog?: paramsDialog\n  ) {\n    const ref = dialogService.open(componentType, {\n      closable: paramsDialog?.closable || false,\n      maximizable: paramsDialog?.maximizable || false,\n      height: paramsDialog?.height || 'auto',\n      width: paramsDialog?.width,\n      styleClass: paramsDialog?.styleClass,\n      showHeader: true,\n      header: paramsDialog?.header,\n      data: { id: paramsDialog?.id, popup: paramsDialog?.popup && true }\n    });\n\n    ref.onClose.subscribe((data: any) => {\n      if (data) callBackFunction(data);\n    });\n  }\n\n  static setControlValue(formGroup: FormGroup, controName: string, value: any) {\n    formGroup?.controls[controName]?.setValue(value);\n  }\n\n  static setValidators(formGroup: FormGroup, controName: string, validators: ValidatorFn | ValidatorFn[] | null) {\n    formGroup?.controls[controName]?.setValidators(validators);\n    formGroup?.controls[controName]?.updateValueAndValidity();\n  }\n\n  static clearValidators(formGroup: FormGroup, controName: string) {\n    formGroup?.controls[controName]?.updateValueAndValidity();\n  }\n}\n"]}
@@ -0,0 +1,67 @@
1
+ import { Injectable } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "primeng/api";
4
+ export class NotificationService {
5
+ constructor(confirmationService, messageService) {
6
+ this.confirmationService = confirmationService;
7
+ this.messageService = messageService;
8
+ }
9
+ question(config) {
10
+ this.confirmationService.confirm({
11
+ header: config.type === 'alert' ? 'Atenção' : 'Confirmação',
12
+ icon: `pi ${config.type === 'alert' ? 'pi-exclamation-triangle' : 'pi-question-circle'}`,
13
+ acceptLabel: 'Sim',
14
+ acceptButtonStyleClass: 'p-button-success',
15
+ rejectLabel: 'Não',
16
+ rejectButtonStyleClass: 'p-button-secondary',
17
+ ...config,
18
+ });
19
+ }
20
+ dialog(config) {
21
+ let dialogHeader;
22
+ let dialogIcon;
23
+ switch (config.type) {
24
+ case 'alert':
25
+ dialogHeader = 'Atenção';
26
+ dialogIcon = 'pi pi-exclamation-triangle';
27
+ break;
28
+ case 'info':
29
+ dialogHeader = 'Infomação';
30
+ dialogIcon = 'pi pi-info-circle';
31
+ break;
32
+ case 'error':
33
+ dialogHeader = 'Erro';
34
+ dialogIcon = 'pi pi-times-circle';
35
+ break;
36
+ }
37
+ this.confirmationService.confirm({
38
+ header: dialogHeader,
39
+ icon: dialogIcon,
40
+ acceptLabel: 'Ok',
41
+ acceptButtonStyleClass: 'p-button-success',
42
+ rejectVisible: false,
43
+ message: config.message,
44
+ });
45
+ }
46
+ toastSuccess(message, time = 4000) {
47
+ this.messageService.add({ severity: 'success', summary: 'Sucesso', detail: message, life: time });
48
+ }
49
+ toastInfo(message, time = 4000) {
50
+ this.messageService.add({ severity: 'info', summary: 'Info', detail: message, life: time });
51
+ }
52
+ toastWarn(message, time = 4000) {
53
+ this.messageService.add({ severity: 'warn', summary: 'Aviso', detail: message, life: time });
54
+ }
55
+ toastError(message, time = 4000) {
56
+ this.messageService.add({ severity: 'error', summary: 'Erro', detail: message, life: time });
57
+ }
58
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: NotificationService, deps: [{ token: i1.ConfirmationService }, { token: i1.MessageService }], target: i0.ɵɵFactoryTarget.Injectable }); }
59
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: NotificationService, providedIn: 'root' }); }
60
+ }
61
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: NotificationService, decorators: [{
62
+ type: Injectable,
63
+ args: [{
64
+ providedIn: 'root',
65
+ }]
66
+ }], ctorParameters: () => [{ type: i1.ConfirmationService }, { type: i1.MessageService }] });
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL3NlcnZpY2VzL25vdGlmaWNhdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQXNCM0MsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixZQUNtQixtQkFBd0MsRUFDeEMsY0FBOEI7UUFEOUIsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtRQUN4QyxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7SUFDN0MsQ0FBQztJQUVMLFFBQVEsQ0FBQyxNQUFzQjtRQUM3QixJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDO1lBQy9CLE1BQU0sRUFBRSxNQUFNLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxhQUFhO1lBQzNELElBQUksRUFBRSxNQUFNLE1BQU0sQ0FBQyxJQUFJLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLEVBQUU7WUFDeEYsV0FBVyxFQUFFLEtBQUs7WUFDbEIsc0JBQXNCLEVBQUUsa0JBQWtCO1lBQzFDLFdBQVcsRUFBRSxLQUFLO1lBQ2xCLHNCQUFzQixFQUFFLG9CQUFvQjtZQUM1QyxHQUFHLE1BQU07U0FDVixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQW9CO1FBQ3pCLElBQUksWUFBb0IsQ0FBQztRQUN6QixJQUFJLFVBQWtCLENBQUM7UUFFdkIsUUFBUSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDcEIsS0FBSyxPQUFPO2dCQUNWLFlBQVksR0FBRyxTQUFTLENBQUM7Z0JBQ3pCLFVBQVUsR0FBRyw0QkFBNEIsQ0FBQztnQkFDMUMsTUFBTTtZQUNSLEtBQUssTUFBTTtnQkFDVCxZQUFZLEdBQUcsV0FBVyxDQUFDO2dCQUMzQixVQUFVLEdBQUcsbUJBQW1CLENBQUM7Z0JBQ2pDLE1BQU07WUFDUixLQUFLLE9BQU87Z0JBQ1YsWUFBWSxHQUFHLE1BQU0sQ0FBQztnQkFDdEIsVUFBVSxHQUFHLG9CQUFvQixDQUFDO2dCQUNsQyxNQUFNO1FBQ1YsQ0FBQztRQUVELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUM7WUFDL0IsTUFBTSxFQUFFLFlBQVk7WUFDcEIsSUFBSSxFQUFFLFVBQVU7WUFDaEIsV0FBVyxFQUFFLElBQUk7WUFDakIsc0JBQXNCLEVBQUUsa0JBQWtCO1lBQzFDLGFBQWEsRUFBRSxLQUFLO1lBQ3BCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTztTQUN4QixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsWUFBWSxDQUFDLE9BQWUsRUFBRSxPQUFlLElBQUk7UUFDL0MsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNwRyxDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQWUsRUFBRSxPQUFlLElBQUk7UUFDNUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUM5RixDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQWUsRUFBRSxPQUFlLElBQUk7UUFDNUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRixDQUFDO0lBRUQsVUFBVSxDQUFDLE9BQWUsRUFBRSxPQUFlLElBQUk7UUFDN0MsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRixDQUFDOzhHQTdEVSxtQkFBbUI7a0hBQW5CLG1CQUFtQixjQUZsQixNQUFNOzsyRkFFUCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7XG4gIENvbmZpcm1hdGlvblNlcnZpY2UsXG4gIE1lc3NhZ2VTZXJ2aWNlXG59IGZyb20gXCJwcmltZW5nL2FwaVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFF1ZXN0aW9uQ29uZmlnIHtcbiAgdHlwZT86ICdxdWVzdGlvbicgfCAnYWxlcnQnO1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIGFjY2VwdD86IEZ1bmN0aW9uO1xuICByZWplY3Q/OiBGdW5jdGlvbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEaWFsb2dDb25maWcge1xuICB0eXBlOiAnaW5mbycgfCAnYWxlcnQnIHwgJ2Vycm9yJztcbiAgbWVzc2FnZTogc3RyaW5nO1xufVxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgTm90aWZpY2F0aW9uU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVhZG9ubHkgY29uZmlybWF0aW9uU2VydmljZTogQ29uZmlybWF0aW9uU2VydmljZSxcbiAgICBwcml2YXRlIHJlYWRvbmx5IG1lc3NhZ2VTZXJ2aWNlOiBNZXNzYWdlU2VydmljZSxcbiAgKSB7IH1cblxuICBxdWVzdGlvbihjb25maWc6IFF1ZXN0aW9uQ29uZmlnKSB7XG4gICAgdGhpcy5jb25maXJtYXRpb25TZXJ2aWNlLmNvbmZpcm0oe1xuICAgICAgaGVhZGVyOiBjb25maWcudHlwZSA9PT0gJ2FsZXJ0JyA/ICdBdGVuw6fDo28nIDogJ0NvbmZpcm1hw6fDo28nLFxuICAgICAgaWNvbjogYHBpICR7Y29uZmlnLnR5cGUgPT09ICdhbGVydCcgPyAncGktZXhjbGFtYXRpb24tdHJpYW5nbGUnIDogJ3BpLXF1ZXN0aW9uLWNpcmNsZSd9YCxcbiAgICAgIGFjY2VwdExhYmVsOiAnU2ltJyxcbiAgICAgIGFjY2VwdEJ1dHRvblN0eWxlQ2xhc3M6ICdwLWJ1dHRvbi1zdWNjZXNzJyxcbiAgICAgIHJlamVjdExhYmVsOiAnTsOjbycsXG4gICAgICByZWplY3RCdXR0b25TdHlsZUNsYXNzOiAncC1idXR0b24tc2Vjb25kYXJ5JyxcbiAgICAgIC4uLmNvbmZpZyxcbiAgICB9KTtcbiAgfVxuXG4gIGRpYWxvZyhjb25maWc6IERpYWxvZ0NvbmZpZykge1xuICAgIGxldCBkaWFsb2dIZWFkZXI6IHN0cmluZztcbiAgICBsZXQgZGlhbG9nSWNvbjogc3RyaW5nO1xuXG4gICAgc3dpdGNoIChjb25maWcudHlwZSkge1xuICAgICAgY2FzZSAnYWxlcnQnOlxuICAgICAgICBkaWFsb2dIZWFkZXIgPSAnQXRlbsOnw6NvJztcbiAgICAgICAgZGlhbG9nSWNvbiA9ICdwaSBwaS1leGNsYW1hdGlvbi10cmlhbmdsZSc7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAnaW5mbyc6XG4gICAgICAgIGRpYWxvZ0hlYWRlciA9ICdJbmZvbWHDp8Ojbyc7XG4gICAgICAgIGRpYWxvZ0ljb24gPSAncGkgcGktaW5mby1jaXJjbGUnO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ2Vycm9yJzpcbiAgICAgICAgZGlhbG9nSGVhZGVyID0gJ0Vycm8nO1xuICAgICAgICBkaWFsb2dJY29uID0gJ3BpIHBpLXRpbWVzLWNpcmNsZSc7XG4gICAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIHRoaXMuY29uZmlybWF0aW9uU2VydmljZS5jb25maXJtKHtcbiAgICAgIGhlYWRlcjogZGlhbG9nSGVhZGVyLFxuICAgICAgaWNvbjogZGlhbG9nSWNvbixcbiAgICAgIGFjY2VwdExhYmVsOiAnT2snLFxuICAgICAgYWNjZXB0QnV0dG9uU3R5bGVDbGFzczogJ3AtYnV0dG9uLXN1Y2Nlc3MnLFxuICAgICAgcmVqZWN0VmlzaWJsZTogZmFsc2UsXG4gICAgICBtZXNzYWdlOiBjb25maWcubWVzc2FnZSxcbiAgICB9KTtcbiAgfVxuXG4gIHRvYXN0U3VjY2VzcyhtZXNzYWdlOiBzdHJpbmcsIHRpbWU6IG51bWJlciA9IDQwMDApIHtcbiAgICB0aGlzLm1lc3NhZ2VTZXJ2aWNlLmFkZCh7IHNldmVyaXR5OiAnc3VjY2VzcycsIHN1bW1hcnk6ICdTdWNlc3NvJywgZGV0YWlsOiBtZXNzYWdlLCBsaWZlOiB0aW1lIH0pO1xuICB9XG5cbiAgdG9hc3RJbmZvKG1lc3NhZ2U6IHN0cmluZywgdGltZTogbnVtYmVyID0gNDAwMCkge1xuICAgIHRoaXMubWVzc2FnZVNlcnZpY2UuYWRkKHsgc2V2ZXJpdHk6ICdpbmZvJywgc3VtbWFyeTogJ0luZm8nLCBkZXRhaWw6IG1lc3NhZ2UsIGxpZmU6IHRpbWUgfSk7XG4gIH1cblxuICB0b2FzdFdhcm4obWVzc2FnZTogc3RyaW5nLCB0aW1lOiBudW1iZXIgPSA0MDAwKSB7XG4gICAgdGhpcy5tZXNzYWdlU2VydmljZS5hZGQoeyBzZXZlcml0eTogJ3dhcm4nLCBzdW1tYXJ5OiAnQXZpc28nLCBkZXRhaWw6IG1lc3NhZ2UsIGxpZmU6IHRpbWUgfSk7XG4gIH1cblxuICB0b2FzdEVycm9yKG1lc3NhZ2U6IHN0cmluZywgdGltZTogbnVtYmVyID0gNDAwMCkge1xuICAgIHRoaXMubWVzc2FnZVNlcnZpY2UuYWRkKHsgc2V2ZXJpdHk6ICdlcnJvcicsIHN1bW1hcnk6ICdFcnJvJywgZGV0YWlsOiBtZXNzYWdlLCBsaWZlOiB0aW1lIH0pO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,39 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class ObjectService {
4
+ static filterObject(array, propertyName, value) {
5
+ return array.filter((e) => {
6
+ return e[propertyName] === value;
7
+ });
8
+ }
9
+ static findObject(array, propertyName, value) {
10
+ return array.find((e) => {
11
+ return e[propertyName] === value;
12
+ });
13
+ }
14
+ static getProperty(obj, propertyName) {
15
+ return obj[propertyName];
16
+ }
17
+ static objCompare(obj1, obj2) {
18
+ const Obj1_keys = Object.keys(obj1);
19
+ const Obj2_keys = Object.keys(obj2);
20
+ if (Obj1_keys.length !== Obj2_keys.length) {
21
+ return false;
22
+ }
23
+ for (let k of Obj1_keys) {
24
+ if (obj1[k] !== obj2[k]) {
25
+ return false;
26
+ }
27
+ }
28
+ return true;
29
+ }
30
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ObjectService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
31
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ObjectService, providedIn: 'root' }); }
32
+ }
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ObjectService, decorators: [{
34
+ type: Injectable,
35
+ args: [{
36
+ providedIn: 'root'
37
+ }]
38
+ }] });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL3NlcnZpY2VzL29iamVjdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxhQUFhO0lBQ3hCLE1BQU0sQ0FBQyxZQUFZLENBQUMsS0FBVSxFQUFFLFlBQW9CLEVBQUUsS0FBVTtRQUM5RCxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRTtZQUM3QixPQUFPLENBQUMsQ0FBQyxZQUFZLENBQUMsS0FBSyxLQUFLLENBQUM7UUFDbkMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBQ0QsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFVLEVBQUUsWUFBb0IsRUFBRSxLQUFVO1FBQzVELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFO1lBQzNCLE9BQU8sQ0FBQyxDQUFDLFlBQVksQ0FBQyxLQUFLLEtBQUssQ0FBQztRQUNuQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFDRCxNQUFNLENBQUMsV0FBVyxDQUFJLEdBQU0sRUFBRSxZQUFvQjtRQUNoRCxPQUFPLEdBQUcsQ0FBRSxZQUFpQyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUNELE1BQU0sQ0FBQyxVQUFVLENBQUMsSUFBUyxFQUFFLElBQVM7UUFDcEMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BDLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxTQUFTLENBQUMsTUFBTSxFQUFDLENBQUM7WUFDdkMsT0FBTyxLQUFLLENBQUM7UUFDakIsQ0FBQztRQUNELEtBQUssSUFBSSxDQUFDLElBQUksU0FBUyxFQUFDLENBQUM7WUFDckIsSUFBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFDLENBQUM7Z0JBQ3BCLE9BQU8sS0FBSyxDQUFDO1lBQ2pCLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzhHQTFCVSxhQUFhO2tIQUFiLGFBQWEsY0FGWixNQUFNOzsyRkFFUCxhQUFhO2tCQUh6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgT2JqZWN0U2VydmljZSB7XG4gIHN0YXRpYyBmaWx0ZXJPYmplY3QoYXJyYXk6IGFueSwgcHJvcGVydHlOYW1lOiBzdHJpbmcsIHZhbHVlOiBhbnkpIHtcbiAgICByZXR1cm4gYXJyYXkuZmlsdGVyKChlOiBhbnkpID0+IHtcbiAgICAgIHJldHVybiBlW3Byb3BlcnR5TmFtZV0gPT09IHZhbHVlO1xuICAgIH0pO1xuICB9XG4gIHN0YXRpYyBmaW5kT2JqZWN0KGFycmF5OiBhbnksIHByb3BlcnR5TmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KSB7XG4gICAgcmV0dXJuIGFycmF5LmZpbmQoKGU6IGFueSkgPT4ge1xuICAgICAgcmV0dXJuIGVbcHJvcGVydHlOYW1lXSA9PT0gdmFsdWU7XG4gICAgfSk7XG4gIH1cbiAgc3RhdGljIGdldFByb3BlcnR5PFQ+KG9iajogVCwgcHJvcGVydHlOYW1lOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gb2JqWyhwcm9wZXJ0eU5hbWUgYXMga2V5b2YgdHlwZW9mIG9iaildO1xuICB9XG4gIHN0YXRpYyBvYmpDb21wYXJlKG9iajE6IGFueSwgb2JqMjogYW55KXtcbiAgICBjb25zdCBPYmoxX2tleXMgPSBPYmplY3Qua2V5cyhvYmoxKTtcbiAgICBjb25zdCBPYmoyX2tleXMgPSBPYmplY3Qua2V5cyhvYmoyKTtcbiAgICBpZiAoT2JqMV9rZXlzLmxlbmd0aCAhPT0gT2JqMl9rZXlzLmxlbmd0aCl7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgZm9yIChsZXQgayBvZiBPYmoxX2tleXMpe1xuICAgICAgICBpZihvYmoxW2tdICE9PSBvYmoyW2tdKXtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2V2ZXJpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL3R5cGVzL3NldmVyaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ0eXBlIFNldmVyaXR5ID0gXCJwcmltYXJ5XCIgfCBcInNlY29uZGFyeVwiIHwgXCJzdWNjZXNzXCIgfCBcImluZm9cIiB8IFwid2FybmluZ1wiIHwgXCJoZWxwXCIgfCBcImRhbmdlclwiO1xuXG5leHBvcnQgZGVmYXVsdCBTZXZlcml0eTtcbiJdfQ==
@@ -0,0 +1,145 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "primeng/button";
5
+ import * as i3 from "primeng/chart";
6
+ import * as i4 from "primeng/dropdown";
7
+ import * as i5 from "primeng/menu";
8
+ import * as i6 from "primeng/ripple";
9
+ import * as i7 from "@angular/forms";
10
+ export const PeriodosChart = {
11
+ Ultimos180Dias: -180,
12
+ Ultimos120Dias: -120,
13
+ Ultimos90Dias: -90,
14
+ Ultimos60Dias: -60,
15
+ Ultimos45Dias: -45,
16
+ Ultimos30Dias: -30,
17
+ Ultimos15Dias: -15,
18
+ Ultimos7Dias: -7,
19
+ DataAtual: 0,
20
+ Proximos7Dias: 7,
21
+ Proximos15Dias: 15,
22
+ Proximos30Dias: 30,
23
+ Proximos45Dias: 45,
24
+ Proximos60Dias: 60,
25
+ Proximos90Dias: 90,
26
+ Proximos120Dias: 120,
27
+ Proximos180Dias: 180
28
+ };
29
+ export class KvChartComponent {
30
+ constructor() {
31
+ this.chartConfig = {
32
+ labels: [],
33
+ datasets: [],
34
+ };
35
+ this.periodosDisponiveis = [
36
+ { label: 'Últimos 180 dias', value: -180 },
37
+ { label: 'Últimos 120 dias', value: -120 },
38
+ { label: 'Últimos 90 dias', value: -90 },
39
+ { label: 'Últimos 60 dias', value: -60 },
40
+ { label: 'Últimos 45 dias', value: -45 },
41
+ { label: 'Últimos 30 dias', value: -30 },
42
+ { label: 'Últimos 15 dias', value: -15 },
43
+ { label: 'Últimos 7 dias', value: -7 },
44
+ { label: 'Data atual', value: 0 },
45
+ { label: 'Próximos 7 dias', value: 7 },
46
+ { label: 'Próximos 15 dias', value: 15 },
47
+ { label: 'Próximos 30 dias', value: 30 },
48
+ { label: 'Próximos 45 dias', value: 45 },
49
+ { label: 'Próximos 60 dias', value: 60 },
50
+ { label: 'Próximos 90 dias', value: 90 },
51
+ { label: 'Próximos 120 dias', value: 120 },
52
+ { label: 'Próximos 180 dias', value: 180 }
53
+ ];
54
+ this.showDatas = true;
55
+ this.showMenu = false;
56
+ this.enablePeriodos = [];
57
+ this.periodos = [];
58
+ this.menuItems = [];
59
+ this.onPrintReport = new EventEmitter();
60
+ this.onSelectionValue = new EventEmitter();
61
+ }
62
+ configureGraphic() {
63
+ this.data = this.chartConfig;
64
+ this.configOptions();
65
+ this.chart?.reinit();
66
+ }
67
+ configOptions() {
68
+ this.options = {
69
+ indexAxis: this.indexAxis || 'x',
70
+ maintainAspectRatio: false,
71
+ aspectRatio: 0.8,
72
+ animation: {
73
+ duration: 0
74
+ },
75
+ plugins: {
76
+ legend: {
77
+ display: this.displayLegend || false,
78
+ labels: {
79
+ color: '#1e293b',
80
+ usePointStyle: true,
81
+ font: {
82
+ weight: 700,
83
+ },
84
+ padding: 28
85
+ },
86
+ position: 'bottom'
87
+ }
88
+ }
89
+ };
90
+ this.menuItems = [
91
+ { label: 'Imprimir relatório', command: () => this.printReport() }
92
+ ];
93
+ }
94
+ initDatas() {
95
+ this.periodosDisponiveis.map((el) => {
96
+ if (this.enablePeriodos.includes(el.value)) {
97
+ this.periodos.push(el);
98
+ }
99
+ });
100
+ }
101
+ ngOnInit() {
102
+ this.initDatas();
103
+ this.configureGraphic();
104
+ }
105
+ printReport() {
106
+ this.onPrintReport.emit();
107
+ }
108
+ reInit(config) {
109
+ this.chartConfig = config;
110
+ this.configureGraphic();
111
+ }
112
+ selectionValue(event) {
113
+ this.onSelectionValue.emit(event);
114
+ }
115
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
116
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvChartComponent, selector: "kv-chart", inputs: { title: "title", type: "type", indexAxis: "indexAxis", displayLegend: "displayLegend", showDatas: "showDatas", showMenu: "showMenu", selectedData: "selectedData", enablePeriodos: "enablePeriodos" }, outputs: { onPrintReport: "onPrintReport", onSelectionValue: "onSelectionValue" }, viewQueries: [{ propertyName: "chart", first: true, predicate: ["chart"], descendants: true }], ngImport: i0, template: "<div class=\"card h-full\">\n <div class=\"flex align-items-start justify-content-between mb-6\">\n <label class=\"text-900 text-xl font-semibold\">{{ title }}</label>\n <div>\n <p-dropdown\n *ngIf=\"showDatas\"\n [options]=\"periodos\"\n [(ngModel)]=\"selectedData\"\n optionLabel=\"label\"\n optionValue=\"value\"\n styleClass=\"w-15rem\"\n (onChange)=\"selectionValue($event)\">\n </p-dropdown>\n <button\n *ngIf=\"showMenu\"\n pButton\n pRipple\n icon=\"pi pi-ellipsis-h\"\n class=\"p-button-rounded p-button-secondary\"\n style=\"margin-left: 10px;\"\n (click)=\"menu.toggle($event)\">\n </button>\n <p-menu\n #menu\n [popup]=\"true\"\n appendTo=\"body\"\n [model]=\"menuItems\">\n </p-menu>\n </div>\n </div>\n <p-chart\n #chart\n [type]=\"type\"\n [data]=\"data\"\n [options]=\"options\"\n height=\"300px\">\n </p-chart>\n</div>\n", styles: ["", "label{font-family:Inter var,Roboto,Arial,Helvetica,sans-serif}:host ::ng-deep .inputs{height:35px}*{margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i3.UIChart, selector: "p-chart", inputs: ["type", "plugins", "width", "height", "responsive", "ariaLabel", "ariaLabelledBy", "data", "options"], outputs: ["onDataSelect"] }, { kind: "component", type: i4.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i5.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
117
+ }
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvChartComponent, decorators: [{
119
+ type: Component,
120
+ args: [{ selector: 'kv-chart', template: "<div class=\"card h-full\">\n <div class=\"flex align-items-start justify-content-between mb-6\">\n <label class=\"text-900 text-xl font-semibold\">{{ title }}</label>\n <div>\n <p-dropdown\n *ngIf=\"showDatas\"\n [options]=\"periodos\"\n [(ngModel)]=\"selectedData\"\n optionLabel=\"label\"\n optionValue=\"value\"\n styleClass=\"w-15rem\"\n (onChange)=\"selectionValue($event)\">\n </p-dropdown>\n <button\n *ngIf=\"showMenu\"\n pButton\n pRipple\n icon=\"pi pi-ellipsis-h\"\n class=\"p-button-rounded p-button-secondary\"\n style=\"margin-left: 10px;\"\n (click)=\"menu.toggle($event)\">\n </button>\n <p-menu\n #menu\n [popup]=\"true\"\n appendTo=\"body\"\n [model]=\"menuItems\">\n </p-menu>\n </div>\n </div>\n <p-chart\n #chart\n [type]=\"type\"\n [data]=\"data\"\n [options]=\"options\"\n height=\"300px\">\n </p-chart>\n</div>\n", styles: ["label{font-family:Inter var,Roboto,Arial,Helvetica,sans-serif}:host ::ng-deep .inputs{height:35px}*{margin:0}\n"] }]
121
+ }], ctorParameters: () => [], propDecorators: { title: [{
122
+ type: Input
123
+ }], type: [{
124
+ type: Input
125
+ }], indexAxis: [{
126
+ type: Input
127
+ }], displayLegend: [{
128
+ type: Input
129
+ }], showDatas: [{
130
+ type: Input
131
+ }], showMenu: [{
132
+ type: Input
133
+ }], selectedData: [{
134
+ type: Input
135
+ }], enablePeriodos: [{
136
+ type: Input
137
+ }], onPrintReport: [{
138
+ type: Output
139
+ }], onSelectionValue: [{
140
+ type: Output
141
+ }], chart: [{
142
+ type: ViewChild,
143
+ args: ['chart']
144
+ }] } });
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-chart/kv-chart.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-chart/kv-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\n\nimport { MenuItem } from 'primeng/api';\nimport { UIChart } from 'primeng/chart';\n\nimport { ChartConfig } from '../../api/components/chart/chart.config';\n\nexport const PeriodosChart = {\n  Ultimos180Dias: -180,\n  Ultimos120Dias: -120,\n  Ultimos90Dias: -90,\n  Ultimos60Dias: -60,\n  Ultimos45Dias: -45,\n  Ultimos30Dias: -30,\n  Ultimos15Dias: -15,\n  Ultimos7Dias: -7,\n  DataAtual: 0,\n  Proximos7Dias: 7,\n  Proximos15Dias: 15,\n  Proximos30Dias: 30,\n  Proximos45Dias: 45,\n  Proximos60Dias: 60,\n  Proximos90Dias: 90,\n  Proximos120Dias: 120,\n  Proximos180Dias: 180\n}\n\n@Component({\n  selector: 'kv-chart',\n  templateUrl: './kv-chart.component.html',\n  styleUrls: [\n    './kv-chart.component.scss',\n    '../keevo-components-styles.scss'\n  ]\n})\nexport class KvChartComponent implements OnInit {\n\n  chartConfig: ChartConfig = {\n    labels: [],\n    datasets: [],\n  }\n\n  periodosDisponiveis = [\n    { label: 'Últimos 180 dias', value: -180 },\n    { label: 'Últimos 120 dias', value: -120 },\n    { label: 'Últimos 90 dias', value: -90 },\n    { label: 'Últimos 60 dias', value: -60 },\n    { label: 'Últimos 45 dias', value: -45 },\n    { label: 'Últimos 30 dias', value: -30 },\n    { label: 'Últimos 15 dias', value: -15 },\n    { label: 'Últimos 7 dias', value: -7 },\n    { label: 'Data atual', value: 0 },\n    { label: 'Próximos 7 dias', value: 7 },\n    { label: 'Próximos 15 dias', value: 15 },\n    { label: 'Próximos 30 dias', value: 30 },\n    { label: 'Próximos 45 dias', value: 45 },\n    { label: 'Próximos 60 dias', value: 60 },\n    { label: 'Próximos 90 dias', value: 90 },\n    { label: 'Próximos 120 dias', value: 120 },\n    { label: 'Próximos 180 dias', value: 180 }\n  ];\n\n  @Input() title!: string;\n  @Input() type!: 'doughnut' | 'pie' | 'bar' | 'line';\n  @Input() indexAxis!: 'y' | 'x';\n  @Input() displayLegend!: boolean;\n\n  @Input() showDatas: boolean = true;\n  @Input() showMenu: boolean = false;\n  @Input() selectedData!: number;\n  @Input() enablePeriodos: number[] = [];\n\n  data: any;\n  options: any;\n\n  periodos: any[] = [];\n\n  menuItems: MenuItem[] = [];\n\n  @Output() onPrintReport: EventEmitter<any> = new EventEmitter();\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\n  @ViewChild('chart') chart?: UIChart;\n\n  constructor() { }\n\n  configureGraphic() {\n    this.data = this.chartConfig;\n    this.configOptions();\n    this.chart?.reinit();\n  }\n\n  private configOptions(): void {\n    this.options = {\n      indexAxis: this.indexAxis || 'x',\n      maintainAspectRatio: false,\n      aspectRatio: 0.8,\n      animation: {\n        duration: 0\n      },\n      plugins: {\n        legend: {\n          display: this.displayLegend || false,\n          labels: {\n            color: '#1e293b',\n            usePointStyle: true,\n            font: {\n              weight: 700,\n            },\n            padding: 28\n          },\n          position: 'bottom'\n        }\n      }\n    };\n\n    this.menuItems = [\n      { label: 'Imprimir relatório', command: () => this.printReport() }\n    ]\n  }\n\n  private initDatas() {\n    this.periodosDisponiveis.map((el) => {\n      if (this.enablePeriodos.includes(el.value)) {\n        this.periodos.push(el);\n      }\n    });\n  }\n\n  ngOnInit() {\n    this.initDatas();\n    this.configureGraphic();\n  }\n\n  printReport() {\n    this.onPrintReport.emit();\n  }\n\n  public reInit(config: any) {\n    this.chartConfig = config;\n    this.configureGraphic();\n  }\n\n  protected selectionValue(event: any) {\n    this.onSelectionValue.emit(event);\n  }\n}\n","<div class=\"card h-full\">\n  <div class=\"flex align-items-start justify-content-between mb-6\">\n    <label class=\"text-900 text-xl font-semibold\">{{ title }}</label>\n    <div>\n      <p-dropdown\n        *ngIf=\"showDatas\"\n        [options]=\"periodos\"\n        [(ngModel)]=\"selectedData\"\n        optionLabel=\"label\"\n        optionValue=\"value\"\n        styleClass=\"w-15rem\"\n        (onChange)=\"selectionValue($event)\">\n      </p-dropdown>\n      <button\n        *ngIf=\"showMenu\"\n        pButton\n        pRipple\n        icon=\"pi pi-ellipsis-h\"\n        class=\"p-button-rounded p-button-secondary\"\n        style=\"margin-left: 10px;\"\n        (click)=\"menu.toggle($event)\">\n      </button>\n      <p-menu\n        #menu\n        [popup]=\"true\"\n        appendTo=\"body\"\n        [model]=\"menuItems\">\n      </p-menu>\n    </div>\n  </div>\n  <p-chart\n    #chart\n    [type]=\"type\"\n    [data]=\"data\"\n    [options]=\"options\"\n    height=\"300px\">\n  </p-chart>\n</div>\n"]}