ng-firebase-table-kxp 1.2.4 → 1.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/table/table.component.mjs +1557 -0
- package/esm2020/lib/components/table-tabs/table-tabs.component.mjs +129 -0
- package/esm2020/lib/components/table-tooltip/table-tooltip.component.mjs +49 -0
- package/esm2020/lib/ng-firebase-table-kxp.component.mjs +15 -0
- package/esm2020/lib/ng-firebase-table-kxp.module.mjs +103 -0
- package/esm2020/lib/ng-firebase-table-kxp.service.mjs +14 -0
- package/esm2020/lib/services/filter.service.mjs +416 -0
- package/esm2020/lib/services/pagination.service.mjs +115 -0
- package/esm2020/lib/services/table.service.mjs +1140 -0
- package/esm2020/lib/services/tooltip.service.mjs +141 -0
- package/esm2020/lib/types/Table.mjs +9 -0
- package/esm2020/lib/utils/table.utils.mjs +75 -0
- package/esm2020/ng-firebase-table-kxp.mjs +5 -0
- package/esm2020/public-api.mjs +22 -0
- package/fesm2015/ng-firebase-table-kxp.mjs +4026 -0
- package/fesm2015/ng-firebase-table-kxp.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/ng-firebase-table-kxp.mjs +3666 -3659
- package/fesm2020/ng-firebase-table-kxp.mjs.map +1 -0
- package/index.d.ts +5 -666
- package/lib/components/table/table.component.d.ts +135 -0
- package/lib/components/table-tabs/table-tabs.component.d.ts +34 -0
- package/lib/components/table-tooltip/table-tooltip.component.d.ts +18 -0
- package/lib/ng-firebase-table-kxp.component.d.ts +5 -0
- package/lib/ng-firebase-table-kxp.module.d.ts +24 -0
- package/lib/ng-firebase-table-kxp.service.d.ts +6 -0
- package/lib/services/filter.service.d.ts +88 -0
- package/lib/services/pagination.service.d.ts +34 -0
- package/lib/services/table.service.d.ts +80 -0
- package/lib/services/tooltip.service.d.ts +73 -0
- package/lib/types/Table.d.ts +162 -0
- package/lib/utils/table.utils.d.ts +25 -0
- package/package.json +11 -3
- package/public-api.d.ts +12 -0
- package/fesm2022/ng-firebase-table-kxp.mjs.map +0 -1
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TooltipService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.tooltipTimeout = null;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Cria um estado inicial para o tooltip
|
|
9
|
+
*/
|
|
10
|
+
createInitialState() {
|
|
11
|
+
return {
|
|
12
|
+
hoveredCell: null,
|
|
13
|
+
showTooltip: false,
|
|
14
|
+
tooltipContent: '',
|
|
15
|
+
tooltipPosition: { x: 0, y: 0 },
|
|
16
|
+
tooltipBgColor: 'bg-gray-800',
|
|
17
|
+
tooltipBgStyle: null,
|
|
18
|
+
tooltipTextColor: 'text-white',
|
|
19
|
+
tooltipTextStyle: null,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Processa as cores do tooltip
|
|
24
|
+
*/
|
|
25
|
+
processTooltipColors(config) {
|
|
26
|
+
const result = {
|
|
27
|
+
bgColor: 'bg-gray-800',
|
|
28
|
+
bgStyle: null,
|
|
29
|
+
textColor: 'text-white',
|
|
30
|
+
textStyle: null,
|
|
31
|
+
};
|
|
32
|
+
const tooltipBgColor = config?.color || 'bg-gray-800';
|
|
33
|
+
if (tooltipBgColor.startsWith('#') || tooltipBgColor.startsWith('rgb')) {
|
|
34
|
+
result.bgColor = '';
|
|
35
|
+
result.bgStyle = { 'background-color': tooltipBgColor };
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
result.bgColor = tooltipBgColor;
|
|
39
|
+
result.bgStyle = null;
|
|
40
|
+
}
|
|
41
|
+
const tooltipTextColor = config?.text || 'text-white';
|
|
42
|
+
if (tooltipTextColor.startsWith('#') ||
|
|
43
|
+
tooltipTextColor.startsWith('rgb')) {
|
|
44
|
+
result.textColor = '';
|
|
45
|
+
result.textStyle = { color: tooltipTextColor };
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
result.textColor = tooltipTextColor;
|
|
49
|
+
result.textStyle = null;
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Manipula o evento de mouse enter na célula
|
|
55
|
+
*/
|
|
56
|
+
handleMouseEnter(event, row, col, getDisplayValue, onShow) {
|
|
57
|
+
// Só mostrar tooltip se a coluna tiver charLimit definido
|
|
58
|
+
if (!col.charLimit) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
const fullValue = getDisplayValue(col, row, true);
|
|
62
|
+
// Só mostrar tooltip se o valor completo for maior que o limite
|
|
63
|
+
if (fullValue.length <= col.charLimit) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const colors = this.processTooltipColors(col.tooltip);
|
|
67
|
+
const state = {
|
|
68
|
+
hoveredCell: { row, col },
|
|
69
|
+
tooltipContent: fullValue,
|
|
70
|
+
tooltipBgColor: colors.bgColor,
|
|
71
|
+
tooltipBgStyle: colors.bgStyle,
|
|
72
|
+
tooltipTextColor: colors.textColor,
|
|
73
|
+
tooltipTextStyle: colors.textStyle,
|
|
74
|
+
tooltipPosition: {
|
|
75
|
+
x: event.clientX + 10,
|
|
76
|
+
y: event.clientY - 10,
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
onShow(state);
|
|
80
|
+
// Limpar timeout anterior se existir
|
|
81
|
+
if (this.tooltipTimeout) {
|
|
82
|
+
clearTimeout(this.tooltipTimeout);
|
|
83
|
+
}
|
|
84
|
+
// Timeout para mostrar o tooltip
|
|
85
|
+
this.tooltipTimeout = setTimeout(() => {
|
|
86
|
+
onShow({ showTooltip: true });
|
|
87
|
+
}, 500);
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Manipula o evento de mouse leave na célula
|
|
91
|
+
*/
|
|
92
|
+
handleMouseLeave(onHide) {
|
|
93
|
+
if (this.tooltipTimeout) {
|
|
94
|
+
clearTimeout(this.tooltipTimeout);
|
|
95
|
+
this.tooltipTimeout = null;
|
|
96
|
+
}
|
|
97
|
+
onHide(this.createInitialState());
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Manipula o movimento do mouse
|
|
101
|
+
*/
|
|
102
|
+
handleMouseMove(event, showTooltip, onMove) {
|
|
103
|
+
if (showTooltip) {
|
|
104
|
+
onMove({
|
|
105
|
+
x: event.clientX + 10,
|
|
106
|
+
y: event.clientY - 10,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Combina estilos do tooltip para aplicação
|
|
112
|
+
*/
|
|
113
|
+
getTooltipStyles(state) {
|
|
114
|
+
const styles = {};
|
|
115
|
+
if (state.tooltipBgStyle) {
|
|
116
|
+
Object.assign(styles, state.tooltipBgStyle);
|
|
117
|
+
}
|
|
118
|
+
if (state.tooltipTextStyle) {
|
|
119
|
+
Object.assign(styles, state.tooltipTextStyle);
|
|
120
|
+
}
|
|
121
|
+
return styles;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Limpa recursos ao destruir
|
|
125
|
+
*/
|
|
126
|
+
destroy() {
|
|
127
|
+
if (this.tooltipTimeout) {
|
|
128
|
+
clearTimeout(this.tooltipTimeout);
|
|
129
|
+
this.tooltipTimeout = null;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
TooltipService.ɵfac = function TooltipService_Factory(t) { return new (t || TooltipService)(); };
|
|
134
|
+
TooltipService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: TooltipService, factory: TooltipService.ɵfac, providedIn: 'root' });
|
|
135
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TooltipService, [{
|
|
136
|
+
type: Injectable,
|
|
137
|
+
args: [{
|
|
138
|
+
providedIn: 'root',
|
|
139
|
+
}]
|
|
140
|
+
}], null, null); })();
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.service.js","sourceRoot":"","sources":["../../../../../projects/ng-firebase-table-kxp/src/lib/services/tooltip.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Column } from '../types/Table';\r\n\r\nexport interface TooltipState {\r\n  hoveredCell: { row: any; col: any } | null;\r\n  showTooltip: boolean;\r\n  tooltipContent: string;\r\n  tooltipPosition: { x: number; y: number };\r\n  tooltipBgColor: string;\r\n  tooltipBgStyle: { [key: string]: string } | null;\r\n  tooltipTextColor: string;\r\n  tooltipTextStyle: { [key: string]: string } | null;\r\n}\r\n\r\nexport interface TooltipConfig {\r\n  color?: string;\r\n  text?: string;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TooltipService {\r\n  private tooltipTimeout: any = null;\r\n\r\n  /**\r\n   * Cria um estado inicial para o tooltip\r\n   */\r\n  createInitialState(): TooltipState {\r\n    return {\r\n      hoveredCell: null,\r\n      showTooltip: false,\r\n      tooltipContent: '',\r\n      tooltipPosition: { x: 0, y: 0 },\r\n      tooltipBgColor: 'bg-gray-800',\r\n      tooltipBgStyle: null,\r\n      tooltipTextColor: 'text-white',\r\n      tooltipTextStyle: null,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Processa as cores do tooltip\r\n   */\r\n  processTooltipColors(config?: TooltipConfig): {\r\n    bgColor: string;\r\n    bgStyle: { [key: string]: string } | null;\r\n    textColor: string;\r\n    textStyle: { [key: string]: string } | null;\r\n  } {\r\n    const result = {\r\n      bgColor: 'bg-gray-800',\r\n      bgStyle: null as { [key: string]: string } | null,\r\n      textColor: 'text-white',\r\n      textStyle: null as { [key: string]: string } | null,\r\n    };\r\n\r\n    const tooltipBgColor = config?.color || 'bg-gray-800';\r\n    if (tooltipBgColor.startsWith('#') || tooltipBgColor.startsWith('rgb')) {\r\n      result.bgColor = '';\r\n      result.bgStyle = { 'background-color': tooltipBgColor };\r\n    } else {\r\n      result.bgColor = tooltipBgColor;\r\n      result.bgStyle = null;\r\n    }\r\n\r\n    const tooltipTextColor = config?.text || 'text-white';\r\n    if (\r\n      tooltipTextColor.startsWith('#') ||\r\n      tooltipTextColor.startsWith('rgb')\r\n    ) {\r\n      result.textColor = '';\r\n      result.textStyle = { color: tooltipTextColor };\r\n    } else {\r\n      result.textColor = tooltipTextColor;\r\n      result.textStyle = null;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Manipula o evento de mouse enter na célula\r\n   */\r\n  handleMouseEnter(\r\n    event: MouseEvent,\r\n    row: any,\r\n    col: Column,\r\n    getDisplayValue: (col: Column, row: any, withinLimit: boolean) => string,\r\n    onShow: (state: Partial<TooltipState>) => void\r\n  ): void {\r\n    // Só mostrar tooltip se a coluna tiver charLimit definido\r\n    if (!col.charLimit) {\r\n      return;\r\n    }\r\n\r\n    const fullValue = getDisplayValue(col, row, true);\r\n\r\n    // Só mostrar tooltip se o valor completo for maior que o limite\r\n    if (fullValue.length <= col.charLimit) {\r\n      return;\r\n    }\r\n\r\n    const colors = this.processTooltipColors(col.tooltip);\r\n\r\n    const state: Partial<TooltipState> = {\r\n      hoveredCell: { row, col },\r\n      tooltipContent: fullValue,\r\n      tooltipBgColor: colors.bgColor,\r\n      tooltipBgStyle: colors.bgStyle,\r\n      tooltipTextColor: colors.textColor,\r\n      tooltipTextStyle: colors.textStyle,\r\n      tooltipPosition: {\r\n        x: event.clientX + 10,\r\n        y: event.clientY - 10,\r\n      },\r\n    };\r\n\r\n    onShow(state);\r\n\r\n    // Limpar timeout anterior se existir\r\n    if (this.tooltipTimeout) {\r\n      clearTimeout(this.tooltipTimeout);\r\n    }\r\n\r\n    // Timeout para mostrar o tooltip\r\n    this.tooltipTimeout = setTimeout(() => {\r\n      onShow({ showTooltip: true });\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   * Manipula o evento de mouse leave na célula\r\n   */\r\n  handleMouseLeave(onHide: (state: TooltipState) => void): void {\r\n    if (this.tooltipTimeout) {\r\n      clearTimeout(this.tooltipTimeout);\r\n      this.tooltipTimeout = null;\r\n    }\r\n\r\n    onHide(this.createInitialState());\r\n  }\r\n\r\n  /**\r\n   * Manipula o movimento do mouse\r\n   */\r\n  handleMouseMove(\r\n    event: MouseEvent,\r\n    showTooltip: boolean,\r\n    onMove: (position: { x: number; y: number }) => void\r\n  ): void {\r\n    if (showTooltip) {\r\n      onMove({\r\n        x: event.clientX + 10,\r\n        y: event.clientY - 10,\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Combina estilos do tooltip para aplicação\r\n   */\r\n  getTooltipStyles(state: TooltipState): { [key: string]: string } {\r\n    const styles: { [key: string]: string } = {};\r\n    if (state.tooltipBgStyle) {\r\n      Object.assign(styles, state.tooltipBgStyle);\r\n    }\r\n    if (state.tooltipTextStyle) {\r\n      Object.assign(styles, state.tooltipTextStyle);\r\n    }\r\n    return styles;\r\n  }\r\n\r\n  /**\r\n   * Limpa recursos ao destruir\r\n   */\r\n  destroy(): void {\r\n    if (this.tooltipTimeout) {\r\n      clearTimeout(this.tooltipTimeout);\r\n      this.tooltipTimeout = null;\r\n    }\r\n  }\r\n}\r\n\r\n\r\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export const TABLE_DEFAULTS = {
|
|
2
|
+
SORT_FIELD: 'createdAt',
|
|
3
|
+
SORT_ORDER: 'desc',
|
|
4
|
+
PAGE_SIZE: 25,
|
|
5
|
+
DEBOUNCE_TIME_MS: 500,
|
|
6
|
+
DEFAULT_BG_COLOR: '#1976d2',
|
|
7
|
+
DEFAULT_TEXT_COLOR: '#ffffff',
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1maXJlYmFzZS10YWJsZS1reHAvc3JjL2xpYi90eXBlcy9UYWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVQSxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7SUFDNUIsVUFBVSxFQUFFLFdBQVc7SUFDdkIsVUFBVSxFQUFFLE1BQWU7SUFDM0IsU0FBUyxFQUFFLEVBQUU7SUFDYixnQkFBZ0IsRUFBRSxHQUFHO0lBQ3JCLGdCQUFnQixFQUFFLFNBQVM7SUFDM0Isa0JBQWtCLEVBQUUsU0FBUztDQUM5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb2xsZWN0aW9uUmVmZXJlbmNlLFxyXG4gIERvY3VtZW50UmVmZXJlbmNlLFxyXG4gIFF1ZXJ5RG9jdW1lbnRTbmFwc2hvdCxcclxufSBmcm9tICdAYW5ndWxhci9maXJlL2NvbXBhdC9maXJlc3RvcmUnO1xyXG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCBmaXJlYmFzZSBmcm9tICdmaXJlYmFzZS9jb21wYXQnO1xyXG5pbXBvcnQgV2hlcmVGaWx0ZXJPcCA9IGZpcmViYXNlLmZpcmVzdG9yZS5XaGVyZUZpbHRlck9wO1xyXG5pbXBvcnQgeyBPcmRlckJ5RGlyZWN0aW9uIH0gZnJvbSAnZmlyZWJhc2UvZmlyZXN0b3JlJztcclxuXHJcbmV4cG9ydCBjb25zdCBUQUJMRV9ERUZBVUxUUyA9IHtcclxuICBTT1JUX0ZJRUxEOiAnY3JlYXRlZEF0JyxcclxuICBTT1JUX09SREVSOiAnZGVzYycgYXMgY29uc3QsXHJcbiAgUEFHRV9TSVpFOiAyNSxcclxuICBERUJPVU5DRV9USU1FX01TOiA1MDAsXHJcbiAgREVGQVVMVF9CR19DT0xPUjogJyMxOTc2ZDInLFxyXG4gIERFRkFVTFRfVEVYVF9DT0xPUjogJyNmZmZmZmYnLFxyXG59O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUYWJsZURhdGEge1xyXG4gIGRpc3BsYXllZENvbHVtbnM6IENvbHVtbltdO1xyXG4gIGZpbHRlcmFibGVPcHRpb25zPzogRmlsdGVyYWJsZU9wdGlvbltdO1xyXG4gIGNvbGxlY3Rpb25SZWY6IENvbGxlY3Rpb25SZWZlcmVuY2U8dW5rbm93bj47XHJcbiAgY29sbGVjdGlvbjogc3RyaW5nO1xyXG4gIG5hbWU6IHN0cmluZztcclxuICB0b3RhbFJlZj86IHsgcmVmOiBEb2N1bWVudFJlZmVyZW5jZTx1bmtub3duPjsgZmllbGQ6IHN0cmluZyB9W107XHJcbiAgZG93bmxvYWQ6IGJvb2xlYW47XHJcbiAgcGFnaW5hdGlvbjogYm9vbGVhbjtcclxuICBpc05vdENsaWNrYWJsZT86IGJvb2xlYW47XHJcbiAgdXJsPzogc3RyaW5nO1xyXG4gIHNvcnRCeT86IHsgZmllbGQ6IHN0cmluZzsgb3JkZXI6IE9yZGVyQnlEaXJlY3Rpb24gfTtcclxuICBjb25kaXRpb25zPzoge1xyXG4gICAgb3BlcmF0b3I6IFdoZXJlRmlsdGVyT3A7XHJcbiAgICBmaXJlc3RvcmVQcm9wZXJ0eTogc3RyaW5nO1xyXG4gICAgZGFzaFByb3BlcnR5OiBzdHJpbmcgfCBzdHJpbmdbXTtcclxuICB9W107XHJcbiAgZmlsdGVyRm4/OiAoaXRlbTogYW55KSA9PiBib29sZWFuO1xyXG4gIGNvbG9yPzogeyBiZzogc3RyaW5nOyB0ZXh0OiBzdHJpbmcgfTtcclxuICBzaG93U2ltcGxlU2VhcmNoPzogYm9vbGVhbjsgLy8gRmxhZyBwYXJhIG1vc3RyYXIvb2N1bHRhciBjYW1wbyBkZSBidXNjYSBzaW1wbGVzIChwYWRyw6NvOiB0cnVlKVxyXG4gIGFjdGlvbkJ1dHRvbj86IHtcclxuICAgIGxhYmVsOiBzdHJpbmc7XHJcbiAgICByb3V0ZXJMaW5rOiBzdHJpbmc7XHJcbiAgICBpY29uPzogc3RyaW5nO1xyXG4gICAgY29sb3JDbGFzcz86IHN0cmluZztcclxuICAgIG1ldGhvZD86IChyb3c6IGFueSwgZXZlbnQ/OiBhbnkpID0+IGFueTtcclxuICAgIGNvbmRpdGlvbj86IChyb3c/OiBhbnkpID0+IGJvb2xlYW47XHJcbiAgfTtcclxuICB0YWJzPzogVGFiO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRhYiB7XHJcbiAgbWV0aG9kOiAodGFiOiBhbnksIGV2ZW50PzogYW55KSA9PiBhbnk7XHJcbiAgdGFic0RhdGE6IFRhYkRhdGFbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUYWJEYXRhIHtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIGNvdW50ZXI/OiBudW1iZXI7XHJcbiAgY291bnRlckNsYXNzPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbHVtbiB7XHJcbiAgcHJvcGVydHk6IHN0cmluZztcclxuICB0aXRsZT86IHN0cmluZztcclxuICBjaGFyTGltaXQ/OiBudW1iZXI7XHJcbiAgcGlwZT86IFBpcGVUcmFuc2Zvcm07XHJcbiAgaWNvbkNsYXNzPzoge1xyXG4gICAgdGV4dD86IHN0cmluZztcclxuICAgIGNsYXNzPzogc3RyaW5nO1xyXG4gICAgY29uZGl0aW9uPzogKHJvdzogYW55KSA9PiBhbnk7XHJcbiAgICBidXR0b25NZXRob2Q/OiAocm93OiBhbnksIGV2ZW50PzogYW55KSA9PiBhbnk7XHJcbiAgfVtdO1xyXG4gIGlzU29ydGFibGU/OiBib29sZWFuO1xyXG4gIGlzRmlsdGVyYWJsZT86IGJvb2xlYW47XHJcbiAgaXNGaWx0ZXJhYmxlQnlEYXRlPzogYm9vbGVhbjtcclxuICBoYXNMaW5rPzogYm9vbGVhbiB8IHN0cmluZztcclxuICBoYXNEb3dubG9hZD86IGJvb2xlYW4gfCBzdHJpbmc7XHJcbiAgcmVsYXRpb24/OiB7XHJcbiAgICB0YXJnZXRlZENvbGxlY3Rpb246IHN0cmluZzsgLy91c2VycyAoY29sbGVjdGlvbiB0YXJnZXRlZCBkbyBqb2luKVxyXG4gICAgc291cmNlUHJvcGVydHk6IHN0cmluZzsgLy8gdXNlcklkIDw8IGRhIGNvbGxlY3Rpb24gYXR1YWwgYG9yZGVyc2BcclxuICAgIHRhcmdldGVkUHJvcGVydHk6IHN0cmluZzsgLy8gbmFtZSA/PyAocHJvcHJpZWRhZGUgcXVlIHF1ZXJvIHB1eGFyIGRhIHRhYmVsYSB1c2VycylcclxuICB9O1xyXG4gIHF1ZXJ5TGVuZ3RoPzoge1xyXG4gICAgY29sbGVjdGlvbjogc3RyaW5nO1xyXG4gICAgcHJvcGVydHk6IHN0cmluZztcclxuICAgIG9wZXJhdG9yOiBXaGVyZUZpbHRlck9wO1xyXG4gICAgdmFsdWU6IHN0cmluZztcclxuICB9O1xyXG4gIGltYWdlPzogSW1hZ2U7XHJcbiAgbWV0aG9kPzogKHJvdzogYW55LCBldmVudD86IGFueSkgPT4gYW55O1xyXG4gIGZpbHRlclByZWRpY2F0ZXM/OiBzdHJpbmdbXTtcclxuICBjYWxjdWxhdGVWYWx1ZT86IChyb3c6IGFueSkgPT4gYW55O1xyXG4gIGFycmF5RmllbGQ/OiBzdHJpbmc7XHJcbiAgdG9vbHRpcD86IHsgY29sb3I6IHN0cmluZzsgdGV4dDogc3RyaW5nIH07XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2Uge1xyXG4gIGNsYXNzOiBzdHJpbmc7XHJcbiAgcGF0aD86IHN0cmluZztcclxuICB1cmw/OiBib29sZWFuO1xyXG4gIGRlZmF1bHQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyYWJsZU9wdGlvbiB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBpdGVtczoge1xyXG4gICAgcHJvcGVydHk6IHN0cmluZztcclxuICAgIHZhbHVlOiBzdHJpbmcgfCBib29sZWFuO1xyXG4gICAgbGFiZWw6IHN0cmluZztcclxuICB9W107XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUGFnaW5hdGlvbiB7XHJcbiAgYmF0Y2hTaXplOiBudW1iZXI7XHJcbiAgY29sbGVjdGlvbjogc3RyaW5nO1xyXG4gIGRvYz86IHtcclxuICAgIGZpcnN0RG9jOiBRdWVyeURvY3VtZW50U25hcHNob3Q8YW55PiB8IG51bGw7XHJcbiAgICBsYXN0RG9jOiBRdWVyeURvY3VtZW50U25hcHNob3Q8YW55PiB8IG51bGw7XHJcbiAgfTtcclxuICBuYXZpZ2F0aW9uOiAncmVsb2FkJyB8ICdmb3J3YXJkJyB8ICdiYWNrd2FyZCc7XHJcbiAgYXJyYW5nZTogQXJyYW5nZTtcclxuICBjb25kaXRpb25zPzogQ29uZGl0aW9uW107XHJcbiAgZmlsdGVyRm4/OiAoaXRlbTogYW55KSA9PiBib29sZWFuO1xyXG4gIHNpemU/OiBudW1iZXI7XHJcbiAgY2xpZW50UGFnZUluZGV4PzogbnVtYmVyO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbmRpdGlvbiB7XHJcbiAgb3BlcmF0b3I6IFdoZXJlRmlsdGVyT3A7XHJcbiAgZmlyZXN0b3JlUHJvcGVydHk6IHN0cmluZztcclxuICBkYXNoUHJvcGVydHk6IHN0cmluZyB8IHN0cmluZ1tdO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFycmFuZ2Uge1xyXG4gIGZpbHRlcnM6IHtcclxuICAgIGFycmFuZ2U6XHJcbiAgICAgIHwgJ2FzY2VuZGluZydcclxuICAgICAgfCAnZGVzY2VuZGluZydcclxuICAgICAgfCAnZmlsdGVyJ1xyXG4gICAgICB8ICdmaWx0ZXJCeURhdGUnXHJcbiAgICAgIHwgJ2VxdWFscydcclxuICAgICAgfCAnJztcclxuICAgIGZpbHRlcj86IHsgcHJvcGVydHk6IHN0cmluZzsgZmlsdGVyaW5nOiBzdHJpbmcgfSB8IG51bGw7XHJcbiAgICBkYXRlRmlsdGVyPzoge1xyXG4gICAgICBpbml0aWFsOiBEYXRlO1xyXG4gICAgICBmaW5hbDogRGF0ZTtcclxuICAgIH07XHJcbiAgfVtdO1xyXG4gIHNvcnRCeTogeyBmaWVsZDogc3RyaW5nOyBvcmRlcjogT3JkZXJCeURpcmVjdGlvbiB9O1xyXG4gIGVsZW1lbnRJZD86IHsgcHJvcGVydHk6IHN0cmluZzsgdmFsdWU6IHN0cmluZyB9O1xyXG59XHJcblxyXG4vLyBUaXBvIHBhcmEgaXRlbnMgZG8gZHJvcGRvd24gZGUgZmlsdHJvcyBlIG9yZGVuYcOnw6NvXHJcbmV4cG9ydCB0eXBlIERyb3Bkb3duSXRlbSA9IENvbHVtbiAmIHtcclxuICBhcnJhbmdlOiAnZmlsdGVyJyB8ICdmaWx0ZXJCeURhdGUnIHwgJ2VxdWFscycgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJztcclxuICB0aXRsZTogc3RyaW5nO1xyXG4gIGljb24/OiBzdHJpbmc7XHJcbn07XHJcblxyXG4vLyBUaXBvIHBhcmEgaXRlbnMgc2VsZWNpb25hZG9zIGVtIGZpbHRyb3NcclxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJTZWxlY3RJdGVtIHtcclxuICBwcm9wZXJ0eTogc3RyaW5nO1xyXG4gIHZhbHVlOiBzdHJpbmcgfCBib29sZWFuO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Obtém o valor aninhado de um objeto dado um caminho (ex: 'user.address.city')
|
|
3
|
+
*/
|
|
4
|
+
export function getNestedValue(obj, path) {
|
|
5
|
+
if (!path)
|
|
6
|
+
return undefined;
|
|
7
|
+
const properties = path.split('.');
|
|
8
|
+
return properties.reduce((acc, currentPart) => acc && acc[currentPart], obj);
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Formata um array de objetos em uma string com valores separados por vírgula
|
|
12
|
+
*/
|
|
13
|
+
export function formatArrayValue(array, field) {
|
|
14
|
+
if (!Array.isArray(array) || array.length === 0) {
|
|
15
|
+
return '';
|
|
16
|
+
}
|
|
17
|
+
const values = array
|
|
18
|
+
.map((item) => {
|
|
19
|
+
if (typeof item === 'object' && item !== null) {
|
|
20
|
+
return item[field] || '';
|
|
21
|
+
}
|
|
22
|
+
return String(item);
|
|
23
|
+
})
|
|
24
|
+
.filter((value) => value !== '' && value !== null && value !== undefined);
|
|
25
|
+
return values.join(', ');
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Obtém o valor de exibição para uma célula da tabela
|
|
29
|
+
*/
|
|
30
|
+
export function getDisplayValue(col, row, withinLimit = false) {
|
|
31
|
+
let value;
|
|
32
|
+
if (col.calculateValue) {
|
|
33
|
+
value = col.calculateValue(row);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
value = getNestedValue(row, col.property);
|
|
37
|
+
}
|
|
38
|
+
if (Array.isArray(value) && col.arrayField) {
|
|
39
|
+
value = formatArrayValue(value, col.arrayField);
|
|
40
|
+
}
|
|
41
|
+
if (col.queryLength && row[col.property]) {
|
|
42
|
+
value = row[col.property];
|
|
43
|
+
}
|
|
44
|
+
value = col.pipe ? col.pipe.transform(value) : value;
|
|
45
|
+
if (value === null || value === undefined) {
|
|
46
|
+
value = '';
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
value = String(value);
|
|
50
|
+
}
|
|
51
|
+
if (withinLimit || !col.charLimit || value.length <= col.charLimit) {
|
|
52
|
+
return value;
|
|
53
|
+
}
|
|
54
|
+
return value.substring(0, col.charLimit) + '...';
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Verifica se um valor é string
|
|
58
|
+
*/
|
|
59
|
+
export function isString(value) {
|
|
60
|
+
return typeof value === 'string';
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* TrackBy function para colunas
|
|
64
|
+
*/
|
|
65
|
+
export function trackByProperty(_index, col) {
|
|
66
|
+
return col.property;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Gera uma chave única para identificar uma imagem em carregamento
|
|
70
|
+
*/
|
|
71
|
+
export function getImageKey(row, col) {
|
|
72
|
+
const rowId = row.id || row._id || JSON.stringify(row);
|
|
73
|
+
return `${rowId}-${col.property}`;
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1maXJlYmFzZS10YWJsZS1reHAvc3JjL2xpYi91dGlscy90YWJsZS51dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTs7R0FFRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQUMsR0FBUSxFQUFFLElBQVk7SUFDbkQsSUFBSSxDQUFDLElBQUk7UUFBRSxPQUFPLFNBQVMsQ0FBQztJQUM1QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25DLE9BQU8sVUFBVSxDQUFDLE1BQU0sQ0FDdEIsQ0FBQyxHQUFHLEVBQUUsV0FBVyxFQUFFLEVBQUUsQ0FBQyxHQUFHLElBQUksR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUM3QyxHQUFHLENBQ0osQ0FBQztBQUNKLENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxLQUFZLEVBQUUsS0FBYTtJQUMxRCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUMvQyxPQUFPLEVBQUUsQ0FBQztLQUNYO0lBRUQsTUFBTSxNQUFNLEdBQUcsS0FBSztTQUNqQixHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtRQUNaLElBQUksT0FBTyxJQUFJLEtBQUssUUFBUSxJQUFJLElBQUksS0FBSyxJQUFJLEVBQUU7WUFDN0MsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO1NBQzFCO1FBQ0QsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEIsQ0FBQyxDQUFDO1NBQ0QsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssRUFBRSxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsQ0FBQyxDQUFDO0lBRTVFLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZUFBZSxDQUM3QixHQUFXLEVBQ1gsR0FBUSxFQUNSLGNBQXVCLEtBQUs7SUFFNUIsSUFBSSxLQUFVLENBQUM7SUFFZixJQUFJLEdBQUcsQ0FBQyxjQUFjLEVBQUU7UUFDdEIsS0FBSyxHQUFHLEdBQUcsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUM7S0FDakM7U0FBTTtRQUNMLEtBQUssR0FBRyxjQUFjLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztLQUMzQztJQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLENBQUMsVUFBVSxFQUFFO1FBQzFDLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBQ2pEO0lBRUQsSUFBSSxHQUFHLENBQUMsV0FBVyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUU7UUFDeEMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7S0FDM0I7SUFFRCxLQUFLLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUVyRCxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtRQUN6QyxLQUFLLEdBQUcsRUFBRSxDQUFDO0tBQ1o7U0FBTTtRQUNMLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDdkI7SUFFRCxJQUFJLFdBQVcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxHQUFHLENBQUMsU0FBUyxFQUFFO1FBQ2xFLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFDRCxPQUFPLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsR0FBRyxLQUFLLENBQUM7QUFDbkQsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLFFBQVEsQ0FBQyxLQUFVO0lBQ2pDLE9BQU8sT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDO0FBQ25DLENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQUMsTUFBYyxFQUFFLEdBQVc7SUFDekQsT0FBTyxHQUFHLENBQUMsUUFBUSxDQUFDO0FBQ3RCLENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsR0FBUSxFQUFFLEdBQVc7SUFDL0MsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLEVBQUUsSUFBSSxHQUFHLENBQUMsR0FBRyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdkQsT0FBTyxHQUFHLEtBQUssSUFBSSxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUM7QUFDcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbHVtbiB9IGZyb20gJy4uL3R5cGVzL1RhYmxlJztcclxuXHJcbi8qKlxyXG4gKiBPYnTDqW0gbyB2YWxvciBhbmluaGFkbyBkZSB1bSBvYmpldG8gZGFkbyB1bSBjYW1pbmhvIChleDogJ3VzZXIuYWRkcmVzcy5jaXR5JylcclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXROZXN0ZWRWYWx1ZShvYmo6IGFueSwgcGF0aDogc3RyaW5nKTogYW55IHtcclxuICBpZiAoIXBhdGgpIHJldHVybiB1bmRlZmluZWQ7XHJcbiAgY29uc3QgcHJvcGVydGllcyA9IHBhdGguc3BsaXQoJy4nKTtcclxuICByZXR1cm4gcHJvcGVydGllcy5yZWR1Y2UoXHJcbiAgICAoYWNjLCBjdXJyZW50UGFydCkgPT4gYWNjICYmIGFjY1tjdXJyZW50UGFydF0sXHJcbiAgICBvYmpcclxuICApO1xyXG59XHJcblxyXG4vKipcclxuICogRm9ybWF0YSB1bSBhcnJheSBkZSBvYmpldG9zIGVtIHVtYSBzdHJpbmcgY29tIHZhbG9yZXMgc2VwYXJhZG9zIHBvciB2w61yZ3VsYVxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdEFycmF5VmFsdWUoYXJyYXk6IGFueVtdLCBmaWVsZDogc3RyaW5nKTogc3RyaW5nIHtcclxuICBpZiAoIUFycmF5LmlzQXJyYXkoYXJyYXkpIHx8IGFycmF5Lmxlbmd0aCA9PT0gMCkge1xyXG4gICAgcmV0dXJuICcnO1xyXG4gIH1cclxuXHJcbiAgY29uc3QgdmFsdWVzID0gYXJyYXlcclxuICAgIC5tYXAoKGl0ZW0pID0+IHtcclxuICAgICAgaWYgKHR5cGVvZiBpdGVtID09PSAnb2JqZWN0JyAmJiBpdGVtICE9PSBudWxsKSB7XHJcbiAgICAgICAgcmV0dXJuIGl0ZW1bZmllbGRdIHx8ICcnO1xyXG4gICAgICB9XHJcbiAgICAgIHJldHVybiBTdHJpbmcoaXRlbSk7XHJcbiAgICB9KVxyXG4gICAgLmZpbHRlcigodmFsdWUpID0+IHZhbHVlICE9PSAnJyAmJiB2YWx1ZSAhPT0gbnVsbCAmJiB2YWx1ZSAhPT0gdW5kZWZpbmVkKTtcclxuXHJcbiAgcmV0dXJuIHZhbHVlcy5qb2luKCcsICcpO1xyXG59XHJcblxyXG4vKipcclxuICogT2J0w6ltIG8gdmFsb3IgZGUgZXhpYmnDp8OjbyBwYXJhIHVtYSBjw6lsdWxhIGRhIHRhYmVsYVxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGdldERpc3BsYXlWYWx1ZShcclxuICBjb2w6IENvbHVtbixcclxuICByb3c6IGFueSxcclxuICB3aXRoaW5MaW1pdDogYm9vbGVhbiA9IGZhbHNlXHJcbik6IHN0cmluZyB7XHJcbiAgbGV0IHZhbHVlOiBhbnk7XHJcblxyXG4gIGlmIChjb2wuY2FsY3VsYXRlVmFsdWUpIHtcclxuICAgIHZhbHVlID0gY29sLmNhbGN1bGF0ZVZhbHVlKHJvdyk7XHJcbiAgfSBlbHNlIHtcclxuICAgIHZhbHVlID0gZ2V0TmVzdGVkVmFsdWUocm93LCBjb2wucHJvcGVydHkpO1xyXG4gIH1cclxuXHJcbiAgaWYgKEFycmF5LmlzQXJyYXkodmFsdWUpICYmIGNvbC5hcnJheUZpZWxkKSB7XHJcbiAgICB2YWx1ZSA9IGZvcm1hdEFycmF5VmFsdWUodmFsdWUsIGNvbC5hcnJheUZpZWxkKTtcclxuICB9XHJcblxyXG4gIGlmIChjb2wucXVlcnlMZW5ndGggJiYgcm93W2NvbC5wcm9wZXJ0eV0pIHtcclxuICAgIHZhbHVlID0gcm93W2NvbC5wcm9wZXJ0eV07XHJcbiAgfVxyXG5cclxuICB2YWx1ZSA9IGNvbC5waXBlID8gY29sLnBpcGUudHJhbnNmb3JtKHZhbHVlKSA6IHZhbHVlO1xyXG5cclxuICBpZiAodmFsdWUgPT09IG51bGwgfHwgdmFsdWUgPT09IHVuZGVmaW5lZCkge1xyXG4gICAgdmFsdWUgPSAnJztcclxuICB9IGVsc2Uge1xyXG4gICAgdmFsdWUgPSBTdHJpbmcodmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgaWYgKHdpdGhpbkxpbWl0IHx8ICFjb2wuY2hhckxpbWl0IHx8IHZhbHVlLmxlbmd0aCA8PSBjb2wuY2hhckxpbWl0KSB7XHJcbiAgICByZXR1cm4gdmFsdWU7XHJcbiAgfVxyXG4gIHJldHVybiB2YWx1ZS5zdWJzdHJpbmcoMCwgY29sLmNoYXJMaW1pdCkgKyAnLi4uJztcclxufVxyXG5cclxuLyoqXHJcbiAqIFZlcmlmaWNhIHNlIHVtIHZhbG9yIMOpIHN0cmluZ1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGlzU3RyaW5nKHZhbHVlOiBhbnkpOiBib29sZWFuIHtcclxuICByZXR1cm4gdHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJztcclxufVxyXG5cclxuLyoqXHJcbiAqIFRyYWNrQnkgZnVuY3Rpb24gcGFyYSBjb2x1bmFzXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gdHJhY2tCeVByb3BlcnR5KF9pbmRleDogbnVtYmVyLCBjb2w6IENvbHVtbik6IHN0cmluZyB7XHJcbiAgcmV0dXJuIGNvbC5wcm9wZXJ0eTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEdlcmEgdW1hIGNoYXZlIMO6bmljYSBwYXJhIGlkZW50aWZpY2FyIHVtYSBpbWFnZW0gZW0gY2FycmVnYW1lbnRvXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gZ2V0SW1hZ2VLZXkocm93OiBhbnksIGNvbDogQ29sdW1uKTogc3RyaW5nIHtcclxuICBjb25zdCByb3dJZCA9IHJvdy5pZCB8fCByb3cuX2lkIHx8IEpTT04uc3RyaW5naWZ5KHJvdyk7XHJcbiAgcmV0dXJuIGAke3Jvd0lkfS0ke2NvbC5wcm9wZXJ0eX1gO1xyXG59XHJcblxyXG5cclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctZmlyZWJhc2UtdGFibGUta3hwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmctZmlyZWJhc2UtdGFibGUta3hwL3NyYy9uZy1maXJlYmFzZS10YWJsZS1reHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of ng-firebase-table-kxp
|
|
3
|
+
*/
|
|
4
|
+
// Main module
|
|
5
|
+
export * from './lib/ng-firebase-table-kxp.module';
|
|
6
|
+
// Legacy components (se existirem)
|
|
7
|
+
export * from './lib/ng-firebase-table-kxp.service';
|
|
8
|
+
export * from './lib/ng-firebase-table-kxp.component';
|
|
9
|
+
// Components
|
|
10
|
+
export * from './lib/components/table/table.component';
|
|
11
|
+
export * from './lib/components/table-tabs/table-tabs.component';
|
|
12
|
+
export * from './lib/components/table-tooltip/table-tooltip.component';
|
|
13
|
+
// Services
|
|
14
|
+
export * from './lib/services/table.service';
|
|
15
|
+
export * from './lib/services/filter.service';
|
|
16
|
+
export * from './lib/services/tooltip.service';
|
|
17
|
+
export * from './lib/services/pagination.service';
|
|
18
|
+
// Types
|
|
19
|
+
export * from './lib/types/Table';
|
|
20
|
+
// Utils
|
|
21
|
+
export * from './lib/utils/table.utils';
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLWZpcmViYXNlLXRhYmxlLWt4cC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWM7QUFDZCxjQUFjLG9DQUFvQyxDQUFDO0FBRW5ELG1DQUFtQztBQUNuQyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsYUFBYTtBQUNiLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHdEQUF3RCxDQUFDO0FBRXZFLFdBQVc7QUFDWCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG1DQUFtQyxDQUFDO0FBRWxELFFBQVE7QUFDUixjQUFjLG1CQUFtQixDQUFDO0FBRWxDLFFBQVE7QUFDUixjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5nLWZpcmViYXNlLXRhYmxlLWt4cFxyXG4gKi9cclxuXHJcbi8vIE1haW4gbW9kdWxlXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL25nLWZpcmViYXNlLXRhYmxlLWt4cC5tb2R1bGUnO1xyXG5cclxuLy8gTGVnYWN5IGNvbXBvbmVudHMgKHNlIGV4aXN0aXJlbSlcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmctZmlyZWJhc2UtdGFibGUta3hwLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZy1maXJlYmFzZS10YWJsZS1reHAuY29tcG9uZW50JztcclxuXHJcbi8vIENvbXBvbmVudHNcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90YWJsZS90YWJsZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxlLXRhYnMvdGFibGUtdGFicy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxlLXRvb2x0aXAvdGFibGUtdG9vbHRpcC5jb21wb25lbnQnO1xyXG5cclxuLy8gU2VydmljZXNcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvdGFibGUuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL2ZpbHRlci5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvdG9vbHRpcC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvcGFnaW5hdGlvbi5zZXJ2aWNlJztcclxuXHJcbi8vIFR5cGVzXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzL1RhYmxlJztcclxuXHJcbi8vIFV0aWxzXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3RhYmxlLnV0aWxzJztcclxuIl19
|