@ackplus/react-tanstack-data-table 1.1.12 → 1.1.13
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/README.md +143 -11
- package/dist/lib/components/droupdown/menu-dropdown.d.ts.map +1 -1
- package/dist/lib/components/droupdown/menu-dropdown.js +8 -1
- package/dist/lib/components/filters/filter-value-input.js +2 -2
- package/dist/lib/components/pagination/data-table-pagination.d.ts.map +1 -1
- package/dist/lib/components/pagination/data-table-pagination.js +10 -1
- package/dist/lib/components/toolbar/table-export-control.d.ts.map +1 -1
- package/dist/lib/components/toolbar/table-export-control.js +46 -12
- package/dist/lib/contexts/data-table-context.d.ts +7 -10
- package/dist/lib/contexts/data-table-context.d.ts.map +1 -1
- package/dist/lib/contexts/data-table-context.js +5 -1
- package/dist/lib/data-table.d.ts.map +1 -1
- package/dist/lib/data-table.js +561 -230
- package/dist/lib/features/column-filter.feature.js +38 -21
- package/dist/lib/features/selection.feature.d.ts.map +1 -1
- package/dist/lib/features/selection.feature.js +11 -3
- package/dist/lib/types/column.types.d.ts +19 -0
- package/dist/lib/types/column.types.d.ts.map +1 -1
- package/dist/lib/types/data-table-api.d.ts +24 -18
- package/dist/lib/types/data-table-api.d.ts.map +1 -1
- package/dist/lib/types/data-table.types.d.ts +36 -10
- package/dist/lib/types/data-table.types.d.ts.map +1 -1
- package/dist/lib/types/export.types.d.ts +57 -13
- package/dist/lib/types/export.types.d.ts.map +1 -1
- package/dist/lib/types/slots.types.d.ts +3 -1
- package/dist/lib/types/slots.types.d.ts.map +1 -1
- package/dist/lib/types/table.types.d.ts +1 -3
- package/dist/lib/types/table.types.d.ts.map +1 -1
- package/dist/lib/utils/debounced-fetch.utils.d.ts +8 -4
- package/dist/lib/utils/debounced-fetch.utils.d.ts.map +1 -1
- package/dist/lib/utils/debounced-fetch.utils.js +63 -14
- package/dist/lib/utils/export-utils.d.ts +14 -4
- package/dist/lib/utils/export-utils.d.ts.map +1 -1
- package/dist/lib/utils/export-utils.js +362 -66
- package/package.json +4 -2
- package/src/lib/components/droupdown/menu-dropdown.tsx +9 -3
- package/src/lib/components/filters/filter-value-input.tsx +2 -2
- package/src/lib/components/pagination/data-table-pagination.tsx +14 -2
- package/src/lib/components/toolbar/table-export-control.tsx +65 -9
- package/src/lib/contexts/data-table-context.tsx +16 -2
- package/src/lib/data-table.tsx +703 -222
- package/src/lib/features/column-filter.feature.ts +40 -19
- package/src/lib/features/selection.feature.ts +11 -5
- package/src/lib/types/column.types.ts +20 -1
- package/src/lib/types/data-table-api.ts +33 -15
- package/src/lib/types/data-table.types.ts +58 -3
- package/src/lib/types/export.types.ts +79 -10
- package/src/lib/types/slots.types.ts +3 -1
- package/src/lib/types/table.types.ts +1 -3
- package/src/lib/utils/debounced-fetch.utils.ts +90 -18
- package/src/lib/utils/export-utils.ts +496 -69
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.types.d.ts","sourceRoot":"","sources":["../../../src/lib/types/table.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAErD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAG/D;;;GAGG;AAEH;;GAEG;AAEH,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,QAAQ,CAAC;AAI3C,MAAM,WAAW,UAAU;IACvB,YAAY,EAAE,iBAAiB,CAAC;IAChC,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,UAAU,CAAC,EAAE;QACT,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,aAAa,CAAC,EAAE;QACZ,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;KACpB,CAAC;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACzC;AAED,MAAM,WAAW,YAAY;IACzB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,iBAAiB,CAAC;IAChC,OAAO,EAAE,YAAY,CAAC;IACtB,UAAU,EAAE;QACR,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,aAAa,EAAE;QACX,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;KACpB,CAAC;CACL;AAED,MAAM,WAAW,
|
|
1
|
+
{"version":3,"file":"table.types.d.ts","sourceRoot":"","sources":["../../../src/lib/types/table.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAErD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAG/D;;;GAGG;AAEH;;GAEG;AAEH,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,QAAQ,CAAC;AAI3C,MAAM,WAAW,UAAU;IACvB,YAAY,EAAE,iBAAiB,CAAC;IAChC,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,UAAU,CAAC,EAAE;QACT,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,aAAa,CAAC,EAAE;QACZ,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;KACpB,CAAC;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACzC;AAED,MAAM,WAAW,YAAY;IACzB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,iBAAiB,CAAC;IAChC,OAAO,EAAE,YAAY,CAAC;IACtB,UAAU,EAAE;QACR,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,aAAa,EAAE;QACX,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;KACpB,CAAC;CACL;AAED,MAAM,WAAW,oBAAqB,SAAQ,OAAO,CAAC,YAAY,CAAC;IAC/D,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,iBAAiB;IAC9B,OAAO,EAAE,gBAAgB,EAAE,CAAC;IAC5B,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IAEpB,cAAc,EAAE,gBAAgB,EAAE,CAAC;IACnC,YAAY,EAAE,KAAK,GAAG,IAAI,CAAC;CAC9B;AAED;;GAEG;AACH,MAAM,WAAW,uBAAuB;IACpC,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,IAAI,CAAC;CACtB"}
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DataFetchMeta, TableFilters } from '../types';
|
|
2
|
+
interface DebouncedFetchOptions {
|
|
3
|
+
debounceDelay?: number;
|
|
4
|
+
meta?: DataFetchMeta;
|
|
5
|
+
}
|
|
2
6
|
interface useDebouncedFetchReturn<T extends Record<string, any>> {
|
|
3
|
-
debouncedFetch: (filters:
|
|
7
|
+
debouncedFetch: (filters: Partial<TableFilters>, optionsOrDelay?: number | DebouncedFetchOptions) => Promise<{
|
|
4
8
|
data: T[];
|
|
5
9
|
total: number;
|
|
6
|
-
}>;
|
|
10
|
+
} | null>;
|
|
7
11
|
isLoading: boolean;
|
|
8
12
|
}
|
|
9
|
-
export declare function useDebouncedFetch<T extends Record<string, any>>(onFetchData: ((filters:
|
|
13
|
+
export declare function useDebouncedFetch<T extends Record<string, any>>(onFetchData: ((filters: Partial<TableFilters>, meta?: DataFetchMeta) => Promise<{
|
|
10
14
|
data: T[];
|
|
11
15
|
total: number;
|
|
12
16
|
}>) | undefined): useDebouncedFetchReturn<T>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"debounced-fetch.utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/debounced-fetch.utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"debounced-fetch.utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/debounced-fetch.utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAIvD,UAAU,qBAAqB;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,IAAI,CAAC,EAAE,aAAa,CAAC;CACxB;AAED,UAAU,uBAAuB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAC3D,cAAc,EAAE,CACZ,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,EAC9B,cAAc,CAAC,EAAE,MAAM,GAAG,qBAAqB,KAC9C,OAAO,CAAC;QAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC,CAAC;IAClD,SAAS,EAAE,OAAO,CAAC;CACtB;AAQD,wBAAgB,iBAAiB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC3D,WAAW,EAAE,CAAC,CACV,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,EAC9B,IAAI,CAAC,EAAE,aAAa,KACnB,OAAO,CAAC;IAAE,IAAI,EAAE,CAAC,EAAE,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC,GAAG,SAAS,GACxD,uBAAuB,CAAC,CAAC,CAAC,CAoG5B"}
|
|
@@ -6,39 +6,88 @@ const DEFAULT_DEBOUNCE_DELAY = 300;
|
|
|
6
6
|
function useDebouncedFetch(onFetchData) {
|
|
7
7
|
const [isLoading, setIsLoading] = (0, react_1.useState)(false);
|
|
8
8
|
const debounceTimer = (0, react_1.useRef)(null);
|
|
9
|
-
const
|
|
9
|
+
const pendingRequestRef = (0, react_1.useRef)(null);
|
|
10
|
+
const latestRequestIdRef = (0, react_1.useRef)(0);
|
|
11
|
+
const activeRequestCountRef = (0, react_1.useRef)(0);
|
|
12
|
+
const isMountedRef = (0, react_1.useRef)(true);
|
|
13
|
+
const resetLoadingIfIdle = (0, react_1.useCallback)(() => {
|
|
14
|
+
if (!isMountedRef.current)
|
|
15
|
+
return;
|
|
16
|
+
if (!debounceTimer.current && !pendingRequestRef.current && activeRequestCountRef.current === 0) {
|
|
17
|
+
setIsLoading(false);
|
|
18
|
+
}
|
|
19
|
+
}, []);
|
|
20
|
+
const debouncedFetch = (0, react_1.useCallback)(async (filters, optionsOrDelay = DEFAULT_DEBOUNCE_DELAY) => {
|
|
21
|
+
var _a;
|
|
10
22
|
if (!onFetchData)
|
|
11
23
|
return null;
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
24
|
+
const options = typeof optionsOrDelay === 'number'
|
|
25
|
+
? { debounceDelay: optionsOrDelay }
|
|
26
|
+
: optionsOrDelay;
|
|
27
|
+
const debounceDelay = (_a = options.debounceDelay) !== null && _a !== void 0 ? _a : DEFAULT_DEBOUNCE_DELAY;
|
|
28
|
+
const requestId = latestRequestIdRef.current + 1;
|
|
29
|
+
latestRequestIdRef.current = requestId;
|
|
30
|
+
// Clear existing timer and resolve pending debounced request.
|
|
15
31
|
if (debounceTimer.current) {
|
|
16
32
|
clearTimeout(debounceTimer.current);
|
|
33
|
+
debounceTimer.current = null;
|
|
34
|
+
}
|
|
35
|
+
if (pendingRequestRef.current) {
|
|
36
|
+
pendingRequestRef.current.resolve(null);
|
|
37
|
+
pendingRequestRef.current = null;
|
|
17
38
|
}
|
|
18
|
-
|
|
39
|
+
setIsLoading(true);
|
|
40
|
+
return new Promise((resolve, reject) => {
|
|
41
|
+
pendingRequestRef.current = {
|
|
42
|
+
id: requestId,
|
|
43
|
+
resolve,
|
|
44
|
+
reject,
|
|
45
|
+
};
|
|
19
46
|
debounceTimer.current = setTimeout(async () => {
|
|
20
|
-
|
|
47
|
+
const pendingRequest = pendingRequestRef.current;
|
|
48
|
+
if (!pendingRequest || pendingRequest.id !== requestId) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
pendingRequestRef.current = null;
|
|
52
|
+
debounceTimer.current = null;
|
|
53
|
+
activeRequestCountRef.current += 1;
|
|
21
54
|
try {
|
|
22
|
-
const result = await onFetchData(filters);
|
|
23
|
-
|
|
55
|
+
const result = await onFetchData(filters, options.meta);
|
|
56
|
+
// Ignore stale responses if a newer request was queued.
|
|
57
|
+
if (requestId === latestRequestIdRef.current) {
|
|
58
|
+
resolve(result);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
resolve(null);
|
|
62
|
+
}
|
|
24
63
|
}
|
|
25
64
|
catch (error) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
65
|
+
if (requestId === latestRequestIdRef.current) {
|
|
66
|
+
reject(error);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
resolve(null);
|
|
70
|
+
}
|
|
29
71
|
}
|
|
30
72
|
finally {
|
|
31
|
-
|
|
73
|
+
activeRequestCountRef.current = Math.max(0, activeRequestCountRef.current - 1);
|
|
74
|
+
resetLoadingIfIdle();
|
|
32
75
|
}
|
|
33
76
|
}, debounceDelay);
|
|
34
77
|
});
|
|
35
|
-
}, [onFetchData]);
|
|
78
|
+
}, [onFetchData, resetLoadingIfIdle]);
|
|
36
79
|
// Cleanup timer on unmount
|
|
37
80
|
(0, react_1.useEffect)(() => {
|
|
38
|
-
|
|
81
|
+
isMountedRef.current = true;
|
|
39
82
|
return () => {
|
|
83
|
+
isMountedRef.current = false;
|
|
40
84
|
if (debounceTimer.current) {
|
|
41
85
|
clearTimeout(debounceTimer.current);
|
|
86
|
+
debounceTimer.current = null;
|
|
87
|
+
}
|
|
88
|
+
if (pendingRequestRef.current) {
|
|
89
|
+
pendingRequestRef.current.resolve(null);
|
|
90
|
+
pendingRequestRef.current = null;
|
|
42
91
|
}
|
|
43
92
|
};
|
|
44
93
|
}, []);
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Table } from '@tanstack/react-table';
|
|
2
2
|
import { SelectionState } from '../features';
|
|
3
|
+
import { ExportPhase, ServerExportResult } from '../types/export.types';
|
|
3
4
|
export interface ExportOptions {
|
|
4
5
|
format: 'csv' | 'excel';
|
|
5
6
|
filename: string;
|
|
@@ -17,14 +18,23 @@ export interface ExportOptions {
|
|
|
17
18
|
message: string;
|
|
18
19
|
code: string;
|
|
19
20
|
}) => void;
|
|
21
|
+
onStateChange?: (state: {
|
|
22
|
+
phase: ExportPhase;
|
|
23
|
+
processedRows?: number;
|
|
24
|
+
totalRows?: number;
|
|
25
|
+
percentage?: number;
|
|
26
|
+
message?: string;
|
|
27
|
+
code?: string;
|
|
28
|
+
}) => void;
|
|
29
|
+
signal?: AbortSignal;
|
|
30
|
+
sanitizeCSV?: boolean;
|
|
20
31
|
}
|
|
21
32
|
export interface ServerExportOptions extends ExportOptions {
|
|
22
|
-
fetchData: (filters?: any, selection?: SelectionState) => Promise<
|
|
23
|
-
data: any[];
|
|
24
|
-
total: number;
|
|
25
|
-
}>;
|
|
33
|
+
fetchData: (filters?: any, selection?: SelectionState, signal?: AbortSignal) => Promise<ServerExportResult<any>>;
|
|
26
34
|
currentFilters?: any;
|
|
27
35
|
selection?: SelectionState;
|
|
36
|
+
chunkSize?: number;
|
|
37
|
+
strictTotalCheck?: boolean;
|
|
28
38
|
}
|
|
29
39
|
/**
|
|
30
40
|
* Export data for client-side tables
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"export-utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/export-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAE9C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"export-utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/export-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAE9C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAGxE,MAAM,WAAW,aAAa;IAC1B,MAAM,EAAE,KAAK,GAAG,OAAO,CAAC;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IACrG,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IACzF,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IAC7D,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE;QACpB,KAAK,EAAE,WAAW,CAAC;QACnB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,IAAI,CAAC,EAAE,MAAM,CAAC;KACjB,KAAK,IAAI,CAAC;IACX,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;CACzB;AAGD,MAAM,WAAW,mBAAoB,SAAQ,aAAa;IACtD,SAAS,EAAE,CACP,OAAO,CAAC,EAAE,GAAG,EACb,SAAS,CAAC,EAAE,cAAc,EAC1B,MAAM,CAAC,EAAE,WAAW,KACnB,OAAO,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC;IACtC,cAAc,CAAC,EAAE,GAAG,CAAC;IACrB,SAAS,CAAC,EAAE,cAAc,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAuLD;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAAC,KAAK,EACxC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,EACnB,OAAO,EAAE,aAAa,GACvB,OAAO,CAAC,IAAI,CAAC,CAkGf;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAAC,KAAK,EACxC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,EACnB,OAAO,EAAE,mBAAmB,GAC7B,OAAO,CAAC,IAAI,CAAC,CAyPf"}
|