@sqlrooms/pivot 0.29.0-rc.2
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 +3 -0
- package/dist/PivotCellContent.d.ts +10 -0
- package/dist/PivotCellContent.d.ts.map +1 -0
- package/dist/PivotCellContent.js +37 -0
- package/dist/PivotCellContent.js.map +1 -0
- package/dist/PivotCoreSlice.d.ts +73 -0
- package/dist/PivotCoreSlice.d.ts.map +1 -0
- package/dist/PivotCoreSlice.js +175 -0
- package/dist/PivotCoreSlice.js.map +1 -0
- package/dist/PivotEditor.d.ts +66 -0
- package/dist/PivotEditor.d.ts.map +1 -0
- package/dist/PivotEditor.js +341 -0
- package/dist/PivotEditor.js.map +1 -0
- package/dist/PivotResults.d.ts +15 -0
- package/dist/PivotResults.d.ts.map +1 -0
- package/dist/PivotResults.js +102 -0
- package/dist/PivotResults.js.map +1 -0
- package/dist/PivotSlice.d.ts +7 -0
- package/dist/PivotSlice.d.ts.map +1 -0
- package/dist/PivotSlice.js +353 -0
- package/dist/PivotSlice.js.map +1 -0
- package/dist/PivotView.d.ts +3 -0
- package/dist/PivotView.d.ts.map +1 -0
- package/dist/PivotView.js +39 -0
- package/dist/PivotView.js.map +1 -0
- package/dist/TableRenderer.d.ts +14 -0
- package/dist/TableRenderer.d.ts.map +1 -0
- package/dist/TableRenderer.js +100 -0
- package/dist/TableRenderer.js.map +1 -0
- package/dist/TsvRenderer.d.ts +7 -0
- package/dist/TsvRenderer.d.ts.map +1 -0
- package/dist/TsvRenderer.js +26 -0
- package/dist/TsvRenderer.js.map +1 -0
- package/dist/aggregators.d.ts +24 -0
- package/dist/aggregators.d.ts.map +1 -0
- package/dist/aggregators.js +232 -0
- package/dist/aggregators.js.map +1 -0
- package/dist/helpers.d.ts +85 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/helpers.js +348 -0
- package/dist/helpers.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -0
- package/dist/pivotCellRegistryEntry.d.ts +4 -0
- package/dist/pivotCellRegistryEntry.d.ts.map +1 -0
- package/dist/pivotCellRegistryEntry.js +137 -0
- package/dist/pivotCellRegistryEntry.js.map +1 -0
- package/dist/pivotCellTypes.d.ts +23 -0
- package/dist/pivotCellTypes.d.ts.map +1 -0
- package/dist/pivotCellTypes.js +14 -0
- package/dist/pivotCellTypes.js.map +1 -0
- package/dist/pivotExecution.d.ts +16 -0
- package/dist/pivotExecution.d.ts.map +1 -0
- package/dist/pivotExecution.js +49 -0
- package/dist/pivotExecution.js.map +1 -0
- package/dist/sql.d.ts +17 -0
- package/dist/sql.d.ts.map +1 -0
- package/dist/sql.js +278 -0
- package/dist/sql.js.map +1 -0
- package/dist/types.d.ts +513 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +107 -0
- package/dist/types.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PivotResults.js","sourceRoot":"","sources":["../src/PivotResults.tsx"],"names":[],"mappings":"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","sourcesContent":["import {useSql} from '@sqlrooms/duckdb';\nimport {ErrorPane, SpinnerPane} from '@sqlrooms/ui';\nimport {VegaLiteChart} from '@sqlrooms/vega';\nimport React, {useMemo} from 'react';\nimport {getDefaultValuesForAggregator} from './aggregators';\nimport {\n buildChartSpec,\n getUniqueStringColumnValues,\n type HeatmapMode,\n} from './helpers';\nimport {\n buildCellsQuery,\n buildColTotalsQuery,\n buildGrandTotalQuery,\n buildPivotExportQuery,\n buildRowTotalsQuery,\n createPivotQuerySourceFromTable,\n} from './sql';\nimport {TableRenderer} from './TableRenderer';\nimport {TsvRenderer} from './TsvRenderer';\nimport {\n type PivotConfig,\n type PivotQuerySource,\n type PivotRelationViews,\n} from './types';\n\ntype PivotResultsProps = {\n config: PivotConfig;\n source?: PivotQuerySource;\n table?: Parameters<typeof createPivotQuerySourceFromTable>[0];\n relations?: PivotRelationViews;\n runState?: 'idle' | 'running' | 'success' | 'cancel' | 'error';\n stale?: boolean;\n lastError?: string;\n};\n\ntype PivotRow = Record<string, unknown>;\n\nexport const PivotResults: React.FC<PivotResultsProps> = ({\n config,\n source,\n table,\n relations,\n runState,\n stale,\n lastError,\n}) => {\n const querySource = useMemo(\n () =>\n source ?? (table ? createPivotQuerySourceFromTable(table) : undefined),\n [source, table],\n );\n const resolvedConfig = useMemo(() => {\n const nextVals = getDefaultValuesForAggregator({\n aggregatorName: config.aggregatorName,\n fields: (querySource?.columns ?? []).filter(\n (column) => !config.hiddenFromAggregators.includes(column.name),\n ),\n currentValues: config.vals,\n });\n\n if (JSON.stringify(nextVals) === JSON.stringify(config.vals)) {\n return config;\n }\n\n return {\n ...config,\n vals: nextVals,\n };\n }, [config, querySource?.columns]);\n\n const directCellsQuery = useMemo(\n () => (querySource ? buildCellsQuery(resolvedConfig, querySource) : ''),\n [querySource, resolvedConfig],\n );\n const directRowTotalsQuery = useMemo(\n () => (querySource ? buildRowTotalsQuery(resolvedConfig, querySource) : ''),\n [querySource, resolvedConfig],\n );\n const directColTotalsQuery = useMemo(\n () => (querySource ? buildColTotalsQuery(resolvedConfig, querySource) : ''),\n [querySource, resolvedConfig],\n );\n const directGrandTotalQuery = useMemo(\n () =>\n querySource ? buildGrandTotalQuery(resolvedConfig, querySource) : '',\n [querySource, resolvedConfig],\n );\n\n const materializedRelations = useMemo(\n () =>\n !querySource && runState === 'success' && !stale ? relations : undefined,\n [querySource, relations, runState, stale],\n );\n\n const matCells = materializedRelations?.cells;\n const matRowTotals = materializedRelations?.rowTotals;\n const matColTotals = materializedRelations?.colTotals;\n const matGrandTotal = materializedRelations?.grandTotal;\n const matExport = materializedRelations?.export;\n\n const cellsQuery = useMemo(\n () => (matCells ? `SELECT * FROM ${matCells}` : directCellsQuery),\n [directCellsQuery, matCells],\n );\n const rowTotalsQuery = useMemo(\n () =>\n matRowTotals ? `SELECT * FROM ${matRowTotals}` : directRowTotalsQuery,\n [directRowTotalsQuery, matRowTotals],\n );\n const colTotalsQuery = useMemo(\n () =>\n matColTotals ? `SELECT * FROM ${matColTotals}` : directColTotalsQuery,\n [directColTotalsQuery, matColTotals],\n );\n const grandTotalQuery = useMemo(\n () =>\n matGrandTotal ? `SELECT * FROM ${matGrandTotal}` : directGrandTotalQuery,\n [directGrandTotalQuery, matGrandTotal],\n );\n\n const enabled = Boolean(\n matCells || matRowTotals || matColTotals || matGrandTotal || querySource,\n );\n const cellsResult = useSql<PivotRow>({query: cellsQuery, enabled});\n const rowTotalsResult = useSql<PivotRow>({query: rowTotalsQuery, enabled});\n const colTotalsResult = useSql<PivotRow>({query: colTotalsQuery, enabled});\n const grandTotalResult = useSql<PivotRow>({query: grandTotalQuery, enabled});\n\n const grandTotal = useMemo(() => {\n return grandTotalResult.data?.arrowTable?.getChild('value')?.get(0) ?? null;\n }, [grandTotalResult.data?.arrowTable]);\n\n const chartRenderer = resolvedConfig.rendererName.includes('Chart');\n const numericOutput = !['List Unique Values', 'First', 'Last'].includes(\n resolvedConfig.aggregatorName,\n );\n const chartSpec = useMemo(\n () => buildChartSpec(resolvedConfig, resolvedConfig.rendererName),\n [resolvedConfig],\n );\n const cellsArrowTable = cellsResult.data?.arrowTable;\n const chartExportQuery = useMemo(() => {\n const colLabels = getUniqueStringColumnValues(cellsArrowTable, 'col_label');\n if (matExport) {\n return `SELECT * FROM ${matExport}`;\n }\n return querySource\n ? buildPivotExportQuery(resolvedConfig, querySource, colLabels)\n : '';\n }, [cellsArrowTable, matExport, querySource, resolvedConfig]);\n\n if (!enabled) {\n return (\n <div className=\"text-muted-foreground flex h-full items-center justify-center p-6 text-sm\">\n Select a pivot source to preview results.\n </div>\n );\n }\n\n if (runState === 'error' && lastError) {\n return <ErrorPane error={new Error(lastError)} />;\n }\n\n if (\n cellsResult.error ||\n rowTotalsResult.error ||\n colTotalsResult.error ||\n grandTotalResult.error\n ) {\n return (\n <ErrorPane\n error={\n cellsResult.error ||\n rowTotalsResult.error ||\n colTotalsResult.error ||\n grandTotalResult.error ||\n new Error('Unknown pivot error')\n }\n />\n );\n }\n\n if (\n cellsResult.isLoading ||\n rowTotalsResult.isLoading ||\n colTotalsResult.isLoading ||\n grandTotalResult.isLoading\n ) {\n return <SpinnerPane className=\"h-80\" />;\n }\n\n if (resolvedConfig.rendererName === 'Exportable TSV') {\n return <TsvRenderer query={chartExportQuery} />;\n }\n\n if (chartRenderer) {\n if (!numericOutput) {\n return (\n <ErrorPane\n error={\n new Error('The selected renderer requires a numeric aggregation.')\n }\n />\n );\n }\n\n return (\n <div className=\"bg-background rounded-md border p-4\">\n <VegaLiteChart.ArrowChart\n aspectRatio={16 / 8}\n arrowTable={cellsResult.data?.arrowTable}\n spec={chartSpec}\n />\n </div>\n );\n }\n\n const heatmapMode: HeatmapMode =\n resolvedConfig.rendererName === 'Table Heatmap'\n ? 'full'\n : resolvedConfig.rendererName === 'Table Row Heatmap'\n ? 'row'\n : resolvedConfig.rendererName === 'Table Col Heatmap'\n ? 'col'\n : undefined;\n\n return (\n <TableRenderer\n config={resolvedConfig}\n cellRows={cellsResult.data?.arrowTable}\n rowTotals={rowTotalsResult.data?.arrowTable}\n colTotals={colTotalsResult.data?.arrowTable}\n grandTotal={grandTotal}\n heatmapMode={heatmapMode}\n />\n );\n};\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type PivotConfig, PivotSliceState } from './types';
|
|
2
|
+
export declare function createPivotSlice(props?: {
|
|
3
|
+
config?: Partial<PivotConfig & {
|
|
4
|
+
tableName?: string;
|
|
5
|
+
}>;
|
|
6
|
+
}): import("zustand").StateCreator<PivotSliceState>;
|
|
7
|
+
//# sourceMappingURL=PivotSlice.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PivotSlice.d.ts","sourceRoot":"","sources":["../src/PivotSlice.ts"],"names":[],"mappings":"AAyBA,OAAO,EACL,KAAK,WAAW,EAKhB,eAAe,EAChB,MAAM,SAAS,CAAC;AAyCjB,wBAAgB,gBAAgB,CAAC,KAAK,CAAC,EAAE;IACvC,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,GAAG;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAC,CAAC,CAAC;CACtD,mDAqbA"}
|
|
@@ -0,0 +1,353 @@
|
|
|
1
|
+
import { createSlice } from '@sqlrooms/room-store';
|
|
2
|
+
import { generateUniqueName } from '@sqlrooms/utils';
|
|
3
|
+
import { produce } from 'immer';
|
|
4
|
+
import { createId } from '@paralleldrive/cuid2';
|
|
5
|
+
import { addAttributeFilterValuesInConfig, clearAttributeFilterInConfig, createDefaultPivotConfig, moveFieldInConfig, nextSortOrder, normalizePivotConfig, removeAttributeFilterValuesInConfig, setAttributeFilterValuesInConfig, } from './PivotCoreSlice';
|
|
6
|
+
import { createPivotQuerySourceFromTable } from './sql';
|
|
7
|
+
import { createOrReplacePivotRelations, dropPivotRelations, } from './pivotExecution';
|
|
8
|
+
import { PivotSliceConfig, } from './types';
|
|
9
|
+
import { createStore } from 'zustand/vanilla';
|
|
10
|
+
function createInitialPivotSliceConfig(props) {
|
|
11
|
+
if (!props?.config) {
|
|
12
|
+
return PivotSliceConfig.parse({
|
|
13
|
+
pivots: {},
|
|
14
|
+
pivotOrder: [],
|
|
15
|
+
currentPivotId: undefined,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
const id = createId();
|
|
19
|
+
const source = props?.config?.tableName
|
|
20
|
+
? { kind: 'table', tableName: props.config.tableName }
|
|
21
|
+
: undefined;
|
|
22
|
+
const config = createDefaultPivotConfig(props?.config);
|
|
23
|
+
return PivotSliceConfig.parse({
|
|
24
|
+
pivots: {
|
|
25
|
+
[id]: {
|
|
26
|
+
id,
|
|
27
|
+
title: 'Pivot 1',
|
|
28
|
+
source,
|
|
29
|
+
config,
|
|
30
|
+
status: { state: 'idle', stale: false },
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
pivotOrder: [id],
|
|
34
|
+
currentPivotId: id,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
function resetPivotRuntimeStatus(status) {
|
|
38
|
+
return {
|
|
39
|
+
state: 'idle',
|
|
40
|
+
stale: true,
|
|
41
|
+
lastRunTime: status.lastRunTime,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export function createPivotSlice(props) {
|
|
45
|
+
const pivotStores = new Map();
|
|
46
|
+
return createSlice((set, get, store) => {
|
|
47
|
+
/**
|
|
48
|
+
* Shared helper: mutate a pivot's config and reset its runtime status.
|
|
49
|
+
* `updater` receives the current config and returns the new one.
|
|
50
|
+
*/
|
|
51
|
+
const updatePivotConfig = (pivotId, updater) => {
|
|
52
|
+
set((state) => produce(state, (draft) => {
|
|
53
|
+
const pivot = draft.pivot.config.pivots[pivotId];
|
|
54
|
+
if (!pivot)
|
|
55
|
+
return;
|
|
56
|
+
pivot.config = updater(pivot.config);
|
|
57
|
+
pivot.status = resetPivotRuntimeStatus(pivot.status);
|
|
58
|
+
}));
|
|
59
|
+
};
|
|
60
|
+
return {
|
|
61
|
+
pivot: {
|
|
62
|
+
config: createInitialPivotSliceConfig(props),
|
|
63
|
+
async initialize() {
|
|
64
|
+
const tables = get().db.tables;
|
|
65
|
+
if (tables.length === 0) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
set((state) => produce(state, (draft) => {
|
|
69
|
+
if (!draft.pivot.config.currentPivotId &&
|
|
70
|
+
draft.pivot.config.pivotOrder.length > 0) {
|
|
71
|
+
draft.pivot.config.currentPivotId =
|
|
72
|
+
draft.pivot.config.pivotOrder[0];
|
|
73
|
+
}
|
|
74
|
+
for (const pivotId of draft.pivot.config.pivotOrder) {
|
|
75
|
+
const pivot = draft.pivot.config.pivots[pivotId];
|
|
76
|
+
if (!pivot)
|
|
77
|
+
continue;
|
|
78
|
+
if (pivot.source?.kind === 'table') {
|
|
79
|
+
const tableName = pivot.source.tableName;
|
|
80
|
+
const table = tables.find((candidate) => candidate.tableName === tableName) ?? tables[0];
|
|
81
|
+
if (table) {
|
|
82
|
+
pivot.source = { kind: 'table', tableName: table.tableName };
|
|
83
|
+
pivot.config = normalizePivotConfig(pivot.config, table.columns);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
pivot.status = resetPivotRuntimeStatus(pivot.status);
|
|
87
|
+
}
|
|
88
|
+
}));
|
|
89
|
+
},
|
|
90
|
+
getPivotStore(pivotId) {
|
|
91
|
+
const existing = pivotStores.get(pivotId);
|
|
92
|
+
if (existing)
|
|
93
|
+
return existing;
|
|
94
|
+
function getSnapshot() {
|
|
95
|
+
const rootState = get();
|
|
96
|
+
const pivot = rootState.pivot.config.pivots[pivotId];
|
|
97
|
+
const availableTables = rootState.db.tables.map((t) => t.tableName);
|
|
98
|
+
if (!pivot) {
|
|
99
|
+
return {
|
|
100
|
+
source: undefined,
|
|
101
|
+
config: createDefaultPivotConfig(),
|
|
102
|
+
status: { state: 'idle', stale: false },
|
|
103
|
+
querySource: undefined,
|
|
104
|
+
fields: [],
|
|
105
|
+
availableTables,
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
const tableSource = pivot.source?.kind === 'table' ? pivot.source : undefined;
|
|
109
|
+
const table = tableSource
|
|
110
|
+
? rootState.db.tables.find((t) => t.tableName === tableSource.tableName)
|
|
111
|
+
: undefined;
|
|
112
|
+
const querySource = table
|
|
113
|
+
? createPivotQuerySourceFromTable(table)
|
|
114
|
+
: undefined;
|
|
115
|
+
return {
|
|
116
|
+
source: pivot.source,
|
|
117
|
+
config: pivot.config,
|
|
118
|
+
status: pivot.status,
|
|
119
|
+
querySource,
|
|
120
|
+
fields: querySource?.columns ?? [],
|
|
121
|
+
availableTables,
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
let currentSnapshot = getSnapshot();
|
|
125
|
+
const adapterStore = createStore((adapterSet) => ({
|
|
126
|
+
...currentSnapshot,
|
|
127
|
+
ui: { sectionOpenState: {} },
|
|
128
|
+
setSource: (source) => get().pivot.setSource(pivotId, source),
|
|
129
|
+
setConfig: (config) => get().pivot.setConfig(pivotId, config),
|
|
130
|
+
patchConfig: (partial) => get().pivot.patchConfig(pivotId, partial),
|
|
131
|
+
setRendererName: (v) => get().pivot.setRendererName(pivotId, v),
|
|
132
|
+
setAggregatorName: (v) => get().pivot.setAggregatorName(pivotId, v),
|
|
133
|
+
setVals: (v) => get().pivot.setVals(pivotId, v),
|
|
134
|
+
moveField: (field, dest, idx) => get().pivot.moveField(pivotId, field, dest, idx),
|
|
135
|
+
cycleRowOrder: () => get().pivot.cycleRowOrder(pivotId),
|
|
136
|
+
cycleColOrder: () => get().pivot.cycleColOrder(pivotId),
|
|
137
|
+
setAttributeFilterValues: (a, v) => get().pivot.setAttributeFilterValues(pivotId, a, v),
|
|
138
|
+
addAttributeFilterValues: (a, v) => get().pivot.addAttributeFilterValues(pivotId, a, v),
|
|
139
|
+
removeAttributeFilterValues: (a, v) => get().pivot.removeAttributeFilterValues(pivotId, a, v),
|
|
140
|
+
clearAttributeFilter: (a) => get().pivot.clearAttributeFilter(pivotId, a),
|
|
141
|
+
setSectionOpen: (section, isOpen) => adapterSet((state) => ({
|
|
142
|
+
ui: {
|
|
143
|
+
...state.ui,
|
|
144
|
+
sectionOpenState: {
|
|
145
|
+
...state.ui.sectionOpenState,
|
|
146
|
+
[section]: isOpen,
|
|
147
|
+
},
|
|
148
|
+
},
|
|
149
|
+
})),
|
|
150
|
+
run: () => get().pivot.runPivot(pivotId),
|
|
151
|
+
}));
|
|
152
|
+
const unsubscribe = store.subscribe(() => {
|
|
153
|
+
const nextSnapshot = getSnapshot();
|
|
154
|
+
const prev = currentSnapshot;
|
|
155
|
+
if (JSON.stringify(prev.source) ===
|
|
156
|
+
JSON.stringify(nextSnapshot.source) &&
|
|
157
|
+
JSON.stringify(prev.config) ===
|
|
158
|
+
JSON.stringify(nextSnapshot.config) &&
|
|
159
|
+
JSON.stringify(prev.status) ===
|
|
160
|
+
JSON.stringify(nextSnapshot.status) &&
|
|
161
|
+
JSON.stringify(prev.querySource) ===
|
|
162
|
+
JSON.stringify(nextSnapshot.querySource) &&
|
|
163
|
+
prev.fields.length === nextSnapshot.fields.length &&
|
|
164
|
+
prev.fields.every((f, i) => f.name === nextSnapshot.fields[i]?.name &&
|
|
165
|
+
f.type === nextSnapshot.fields[i]?.type) &&
|
|
166
|
+
prev.availableTables.length ===
|
|
167
|
+
nextSnapshot.availableTables.length &&
|
|
168
|
+
prev.availableTables.every((t, i) => t === nextSnapshot.availableTables[i])) {
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
currentSnapshot = nextSnapshot;
|
|
172
|
+
adapterStore.setState(nextSnapshot);
|
|
173
|
+
});
|
|
174
|
+
const instanceStore = Object.assign(adapterStore, {
|
|
175
|
+
destroy: () => {
|
|
176
|
+
unsubscribe();
|
|
177
|
+
pivotStores.delete(pivotId);
|
|
178
|
+
},
|
|
179
|
+
});
|
|
180
|
+
pivotStores.set(pivotId, instanceStore);
|
|
181
|
+
return instanceStore;
|
|
182
|
+
},
|
|
183
|
+
addPivot(pivotProps) {
|
|
184
|
+
const id = createId();
|
|
185
|
+
const title = generateUniqueName(pivotProps?.title ?? 'Pivot 1', Object.values(get().pivot.config.pivots).map((pivot) => pivot.title), ' ');
|
|
186
|
+
const nextPivot = {
|
|
187
|
+
id,
|
|
188
|
+
title,
|
|
189
|
+
source: pivotProps?.source,
|
|
190
|
+
config: createDefaultPivotConfig(pivotProps?.config),
|
|
191
|
+
status: { state: 'idle', stale: false },
|
|
192
|
+
};
|
|
193
|
+
set((state) => produce(state, (draft) => {
|
|
194
|
+
draft.pivot.config.pivots[id] = nextPivot;
|
|
195
|
+
draft.pivot.config.pivotOrder.push(id);
|
|
196
|
+
draft.pivot.config.currentPivotId = id;
|
|
197
|
+
}));
|
|
198
|
+
return id;
|
|
199
|
+
},
|
|
200
|
+
removePivot(pivotId) {
|
|
201
|
+
pivotStores.get(pivotId)?.destroy();
|
|
202
|
+
pivotStores.delete(pivotId);
|
|
203
|
+
const relations = get().pivot.config.pivots[pivotId]?.status.relations;
|
|
204
|
+
void (async () => {
|
|
205
|
+
if (!relations)
|
|
206
|
+
return;
|
|
207
|
+
const connector = await get().db.getConnector();
|
|
208
|
+
await dropPivotRelations({ connector, relations });
|
|
209
|
+
void get().db.refreshTableSchemas();
|
|
210
|
+
})();
|
|
211
|
+
set((state) => produce(state, (draft) => {
|
|
212
|
+
delete draft.pivot.config.pivots[pivotId];
|
|
213
|
+
draft.pivot.config.pivotOrder =
|
|
214
|
+
draft.pivot.config.pivotOrder.filter((id) => id !== pivotId);
|
|
215
|
+
if (draft.pivot.config.currentPivotId === pivotId) {
|
|
216
|
+
draft.pivot.config.currentPivotId =
|
|
217
|
+
draft.pivot.config.pivotOrder[0];
|
|
218
|
+
}
|
|
219
|
+
}));
|
|
220
|
+
},
|
|
221
|
+
setCurrentPivot(pivotId) {
|
|
222
|
+
set((state) => produce(state, (draft) => {
|
|
223
|
+
draft.pivot.config.currentPivotId = pivotId;
|
|
224
|
+
}));
|
|
225
|
+
},
|
|
226
|
+
renamePivot(pivotId, title) {
|
|
227
|
+
set((state) => produce(state, (draft) => {
|
|
228
|
+
const pivot = draft.pivot.config.pivots[pivotId];
|
|
229
|
+
if (pivot) {
|
|
230
|
+
pivot.title = title;
|
|
231
|
+
}
|
|
232
|
+
}));
|
|
233
|
+
},
|
|
234
|
+
setSource(pivotId, source) {
|
|
235
|
+
set((state) => produce(state, (draft) => {
|
|
236
|
+
const pivot = draft.pivot.config.pivots[pivotId];
|
|
237
|
+
if (!pivot)
|
|
238
|
+
return;
|
|
239
|
+
pivot.source = source;
|
|
240
|
+
pivot.config = createDefaultPivotConfig();
|
|
241
|
+
pivot.status = resetPivotRuntimeStatus(pivot.status);
|
|
242
|
+
}));
|
|
243
|
+
},
|
|
244
|
+
setStatus(pivotId, status) {
|
|
245
|
+
set((state) => produce(state, (draft) => {
|
|
246
|
+
const pivot = draft.pivot.config.pivots[pivotId];
|
|
247
|
+
if (!pivot)
|
|
248
|
+
return;
|
|
249
|
+
pivot.status = { ...pivot.status, ...status };
|
|
250
|
+
}));
|
|
251
|
+
},
|
|
252
|
+
setConfig(pivotId, config) {
|
|
253
|
+
const tableSource = get().pivot.config.pivots[pivotId]?.source?.kind === 'table'
|
|
254
|
+
? get().pivot.config.pivots[pivotId].source
|
|
255
|
+
: undefined;
|
|
256
|
+
const columns = tableSource?.kind === 'table'
|
|
257
|
+
? (get().db.tables.find((t) => t.tableName === tableSource.tableName)?.columns ?? [])
|
|
258
|
+
: [];
|
|
259
|
+
updatePivotConfig(pivotId, () => normalizePivotConfig(config, columns));
|
|
260
|
+
},
|
|
261
|
+
patchConfig(pivotId, config) {
|
|
262
|
+
const tableSource = get().pivot.config.pivots[pivotId]?.source?.kind === 'table'
|
|
263
|
+
? get().pivot.config.pivots[pivotId].source
|
|
264
|
+
: undefined;
|
|
265
|
+
const columns = tableSource?.kind === 'table'
|
|
266
|
+
? (get().db.tables.find((t) => t.tableName === tableSource.tableName)?.columns ?? [])
|
|
267
|
+
: [];
|
|
268
|
+
updatePivotConfig(pivotId, (c) => normalizePivotConfig({ ...c, ...config }, columns));
|
|
269
|
+
},
|
|
270
|
+
setRendererName: (pivotId, rendererName) => updatePivotConfig(pivotId, (c) => ({ ...c, rendererName })),
|
|
271
|
+
setAggregatorName: (pivotId, aggregatorName) => updatePivotConfig(pivotId, (c) => ({ ...c, aggregatorName })),
|
|
272
|
+
setRows: (pivotId, rows) => updatePivotConfig(pivotId, (c) => ({ ...c, rows })),
|
|
273
|
+
setCols: (pivotId, cols) => updatePivotConfig(pivotId, (c) => ({ ...c, cols })),
|
|
274
|
+
setVals: (pivotId, vals) => updatePivotConfig(pivotId, (c) => ({ ...c, vals })),
|
|
275
|
+
setUnusedOrder: (pivotId, unusedOrder) => updatePivotConfig(pivotId, (c) => ({ ...c, unusedOrder })),
|
|
276
|
+
moveField: (pivotId, field, destination, index) => updatePivotConfig(pivotId, (c) => moveFieldInConfig(c, field, destination, index)),
|
|
277
|
+
cycleRowOrder: (pivotId) => updatePivotConfig(pivotId, (c) => ({
|
|
278
|
+
...c,
|
|
279
|
+
rowOrder: nextSortOrder(c.rowOrder),
|
|
280
|
+
})),
|
|
281
|
+
cycleColOrder: (pivotId) => updatePivotConfig(pivotId, (c) => ({
|
|
282
|
+
...c,
|
|
283
|
+
colOrder: nextSortOrder(c.colOrder),
|
|
284
|
+
})),
|
|
285
|
+
setAttributeFilterValues: (pivotId, attribute, values) => updatePivotConfig(pivotId, (c) => setAttributeFilterValuesInConfig(c, attribute, values)),
|
|
286
|
+
addAttributeFilterValues: (pivotId, attribute, values) => updatePivotConfig(pivotId, (c) => addAttributeFilterValuesInConfig(c, attribute, values)),
|
|
287
|
+
removeAttributeFilterValues: (pivotId, attribute, values) => updatePivotConfig(pivotId, (c) => removeAttributeFilterValuesInConfig(c, attribute, values)),
|
|
288
|
+
clearAttributeFilter: (pivotId, attribute) => updatePivotConfig(pivotId, (c) => clearAttributeFilterInConfig(c, attribute)),
|
|
289
|
+
async runPivot(pivotId, opts) {
|
|
290
|
+
const state = get();
|
|
291
|
+
const pivot = state.pivot.config.pivots[pivotId];
|
|
292
|
+
if (!pivot)
|
|
293
|
+
return;
|
|
294
|
+
const schemaName = opts?.schemaName ?? '__sqlrooms_pivot';
|
|
295
|
+
let querySource = opts?.querySource;
|
|
296
|
+
if (!querySource) {
|
|
297
|
+
const tableSource = pivot.source?.kind === 'table' ? pivot.source : undefined;
|
|
298
|
+
if (!tableSource)
|
|
299
|
+
return;
|
|
300
|
+
const table = state.db.tables.find((t) => t.tableName === tableSource.tableName);
|
|
301
|
+
if (!table)
|
|
302
|
+
return;
|
|
303
|
+
querySource = createPivotQuerySourceFromTable(table);
|
|
304
|
+
}
|
|
305
|
+
set((current) => produce(current, (draft) => {
|
|
306
|
+
const p = draft.pivot.config.pivots[pivotId];
|
|
307
|
+
if (!p)
|
|
308
|
+
return;
|
|
309
|
+
p.status = { ...p.status, state: 'running' };
|
|
310
|
+
}));
|
|
311
|
+
try {
|
|
312
|
+
const connector = await state.db.getConnector();
|
|
313
|
+
const normalizedConfig = normalizePivotConfig(pivot.config, querySource.columns);
|
|
314
|
+
const relations = await createOrReplacePivotRelations({
|
|
315
|
+
connector,
|
|
316
|
+
source: querySource,
|
|
317
|
+
config: normalizedConfig,
|
|
318
|
+
relationBaseName: `pivot_${pivotId}`,
|
|
319
|
+
schemaName,
|
|
320
|
+
});
|
|
321
|
+
set((current) => produce(current, (draft) => {
|
|
322
|
+
const p = draft.pivot.config.pivots[pivotId];
|
|
323
|
+
if (!p)
|
|
324
|
+
return;
|
|
325
|
+
p.config = normalizedConfig;
|
|
326
|
+
p.status = {
|
|
327
|
+
state: 'success',
|
|
328
|
+
stale: false,
|
|
329
|
+
lastRunTime: Date.now(),
|
|
330
|
+
relations,
|
|
331
|
+
sourceRelation: querySource.tableRef,
|
|
332
|
+
};
|
|
333
|
+
}));
|
|
334
|
+
void get().db.refreshTableSchemas();
|
|
335
|
+
}
|
|
336
|
+
catch (error) {
|
|
337
|
+
set((current) => produce(current, (draft) => {
|
|
338
|
+
const p = draft.pivot.config.pivots[pivotId];
|
|
339
|
+
if (!p)
|
|
340
|
+
return;
|
|
341
|
+
p.status = {
|
|
342
|
+
...p.status,
|
|
343
|
+
state: 'error',
|
|
344
|
+
lastError: error instanceof Error ? error.message : String(error),
|
|
345
|
+
};
|
|
346
|
+
}));
|
|
347
|
+
}
|
|
348
|
+
},
|
|
349
|
+
},
|
|
350
|
+
};
|
|
351
|
+
});
|
|
352
|
+
}
|
|
353
|
+
//# sourceMappingURL=PivotSlice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PivotSlice.js","sourceRoot":"","sources":["../src/PivotSlice.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,WAAW,EAAC,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAC,kBAAkB,EAAC,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAC,OAAO,EAAC,MAAM,OAAO,CAAC;AAC9B,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EACL,gCAAgC,EAChC,4BAA4B,EAC5B,wBAAwB,EACxB,iBAAiB,EACjB,aAAa,EACb,oBAAoB,EACpB,mCAAmC,EACnC,gCAAgC,GACjC,MAAM,kBAAkB,CAAC;AAM1B,OAAO,EAAC,+BAA+B,EAAC,MAAM,OAAO,CAAC;AACtD,OAAO,EACL,6BAA6B,EAC7B,kBAAkB,GACnB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAKL,gBAAgB,GAEjB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAC,WAAW,EAAC,MAAM,iBAAiB,CAAC;AAE5C,SAAS,6BAA6B,CAAC,KAEtC;IACC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC;QACnB,OAAO,gBAAgB,CAAC,KAAK,CAAC;YAC5B,MAAM,EAAE,EAAE;YACV,UAAU,EAAE,EAAE;YACd,cAAc,EAAE,SAAS;SAC1B,CAAC,CAAC;IACL,CAAC;IACD,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;IACtB,MAAM,MAAM,GAAG,KAAK,EAAE,MAAM,EAAE,SAAS;QACrC,CAAC,CAAE,EAAC,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,SAAS,EAAiB;QACrE,CAAC,CAAC,SAAS,CAAC;IACd,MAAM,MAAM,GAAG,wBAAwB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACvD,OAAO,gBAAgB,CAAC,KAAK,CAAC;QAC5B,MAAM,EAAE;YACN,CAAC,EAAE,CAAC,EAAE;gBACJ,EAAE;gBACF,KAAK,EAAE,SAAS;gBAChB,MAAM;gBACN,MAAM;gBACN,MAAM,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAC;aACtC;SACF;QACD,UAAU,EAAE,CAAC,EAAE,CAAC;QAChB,cAAc,EAAE,EAAE;KACnB,CAAC,CAAC;AACL,CAAC;AAED,SAAS,uBAAuB,CAAC,MAAmB;IAClD,OAAO;QACL,KAAK,EAAE,MAAM;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,MAAM,CAAC,WAAW;KAChC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAEhC;IAEC,MAAM,WAAW,GAAG,IAAI,GAAG,EAA8B,CAAC;IAE1D,OAAO,WAAW,CAA6B,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE;QACjE;;;WAGG;QACH,MAAM,iBAAiB,GAAG,CACxB,OAAe,EACf,OAA6C,EAC7C,EAAE;YACF,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACvB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACjD,IAAI,CAAC,KAAK;oBAAE,OAAO;gBACnB,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBACrC,KAAK,CAAC,MAAM,GAAG,uBAAuB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACvD,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC;QAEF,OAAO;YACL,KAAK,EAAE;gBACL,MAAM,EAAE,6BAA6B,CAAC,KAAK,CAAC;gBAE5C,KAAK,CAAC,UAAU;oBACd,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC;oBAC/B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBACxB,OAAO;oBACT,CAAC;oBACD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,IACE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc;4BAClC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EACxC,CAAC;4BACD,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc;gCAC/B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;wBACrC,CAAC;wBAED,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;4BACpD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;4BACjD,IAAI,CAAC,KAAK;gCAAE,SAAS;4BACrB,IAAI,KAAK,CAAC,MAAM,EAAE,IAAI,KAAK,OAAO,EAAE,CAAC;gCACnC,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC;gCACzC,MAAM,KAAK,GACT,MAAM,CAAC,IAAI,CACT,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,KAAK,SAAS,CACjD,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;gCACjB,IAAI,KAAK,EAAE,CAAC;oCACV,KAAK,CAAC,MAAM,GAAG,EAAC,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAC,CAAC;oCAC3D,KAAK,CAAC,MAAM,GAAG,oBAAoB,CACjC,KAAK,CAAC,MAAM,EACZ,KAAK,CAAC,OAAO,CACd,CAAC;gCACJ,CAAC;4BACH,CAAC;4BACD,KAAK,CAAC,MAAM,GAAG,uBAAuB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;wBACvD,CAAC;oBACH,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,aAAa,CAAC,OAAO;oBACnB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBAC1C,IAAI,QAAQ;wBAAE,OAAO,QAAQ,CAAC;oBAE9B,SAAS,WAAW;wBAClB,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC;wBACxB,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBACrD,MAAM,eAAe,GAAG,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;wBACpE,IAAI,CAAC,KAAK,EAAE,CAAC;4BACX,OAAO;gCACL,MAAM,EAAE,SAAS;gCACjB,MAAM,EAAE,wBAAwB,EAAE;gCAClC,MAAM,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAC;gCACrC,WAAW,EAAE,SAAS;gCACtB,MAAM,EAAE,EAAE;gCACV,eAAe;6BAChB,CAAC;wBACJ,CAAC;wBACD,MAAM,WAAW,GACf,KAAK,CAAC,MAAM,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;wBAC5D,MAAM,KAAK,GAAG,WAAW;4BACvB,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CACtB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,WAAW,CAAC,SAAS,CAC7C;4BACH,CAAC,CAAC,SAAS,CAAC;wBACd,MAAM,WAAW,GAAG,KAAK;4BACvB,CAAC,CAAC,+BAA+B,CAAC,KAAK,CAAC;4BACxC,CAAC,CAAC,SAAS,CAAC;wBACd,OAAO;4BACL,MAAM,EAAE,KAAK,CAAC,MAAM;4BACpB,MAAM,EAAE,KAAK,CAAC,MAAM;4BACpB,MAAM,EAAE,KAAK,CAAC,MAAM;4BACpB,WAAW;4BACX,MAAM,EAAE,WAAW,EAAE,OAAO,IAAI,EAAE;4BAClC,eAAe;yBAChB,CAAC;oBACJ,CAAC;oBAED,IAAI,eAAe,GAAG,WAAW,EAAE,CAAC;oBAEpC,MAAM,YAAY,GAAG,WAAW,CAC9B,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;wBACf,GAAG,eAAe;wBAClB,EAAE,EAAE,EAAC,gBAAgB,EAAE,EAAE,EAAC;wBAC1B,SAAS,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;wBAC7D,SAAS,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;wBAC7D,WAAW,EAAE,CAAC,OAAO,EAAE,EAAE,CACvB,GAAG,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC;wBAC3C,eAAe,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC/D,iBAAiB,EAAE,CAAC,CAAC,EAAE,EAAE,CACvB,GAAG,EAAE,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC3C,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC/C,SAAS,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,CAC9B,GAAG,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC;wBAClD,aAAa,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC;wBACvD,aAAa,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC;wBACvD,wBAAwB,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACjC,GAAG,EAAE,CAAC,KAAK,CAAC,wBAAwB,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;wBACrD,wBAAwB,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACjC,GAAG,EAAE,CAAC,KAAK,CAAC,wBAAwB,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;wBACrD,2BAA2B,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACpC,GAAG,EAAE,CAAC,KAAK,CAAC,2BAA2B,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;wBACxD,oBAAoB,EAAE,CAAC,CAAC,EAAE,EAAE,CAC1B,GAAG,EAAE,CAAC,KAAK,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC9C,cAAc,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CAClC,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;4BACrB,EAAE,EAAE;gCACF,GAAG,KAAK,CAAC,EAAE;gCACX,gBAAgB,EAAE;oCAChB,GAAG,KAAK,CAAC,EAAE,CAAC,gBAAgB;oCAC5B,CAAC,OAAO,CAAC,EAAE,MAAM;iCAClB;6BACF;yBACF,CAAC,CAAC;wBACL,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;qBACzC,CAAC,CACH,CAAC;oBAEF,MAAM,WAAW,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;wBACvC,MAAM,YAAY,GAAG,WAAW,EAAE,CAAC;wBACnC,MAAM,IAAI,GAAG,eAAe,CAAC;wBAC7B,IACE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;4BACzB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC;4BACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gCACzB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC;4BACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gCACzB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC;4BACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC;gCAC9B,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,WAAW,CAAC;4BAC1C,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,YAAY,CAAC,MAAM,CAAC,MAAM;4BACjD,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACP,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI;gCACvC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAC1C;4BACD,IAAI,CAAC,eAAe,CAAC,MAAM;gCACzB,YAAY,CAAC,eAAe,CAAC,MAAM;4BACrC,IAAI,CAAC,eAAe,CAAC,KAAK,CACxB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,eAAe,CAAC,CAAC,CAAC,CAChD,EACD,CAAC;4BACD,OAAO;wBACT,CAAC;wBACD,eAAe,GAAG,YAAY,CAAC;wBAC/B,YAAY,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;oBACtC,CAAC,CAAC,CAAC;oBAEH,MAAM,aAAa,GAAuB,MAAM,CAAC,MAAM,CACrD,YAAY,EACZ;wBACE,OAAO,EAAE,GAAG,EAAE;4BACZ,WAAW,EAAE,CAAC;4BACd,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBAC9B,CAAC;qBACF,CACF,CAAC;oBACF,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;oBACxC,OAAO,aAAa,CAAC;gBACvB,CAAC;gBAED,QAAQ,CAAC,UAAU;oBACjB,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;oBACtB,MAAM,KAAK,GAAG,kBAAkB,CAC9B,UAAU,EAAE,KAAK,IAAI,SAAS,EAC9B,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAC1C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CACvB,EACD,GAAG,CACJ,CAAC;oBACF,MAAM,SAAS,GAAG;wBAChB,EAAE;wBACF,KAAK;wBACL,MAAM,EAAE,UAAU,EAAE,MAAM;wBAC1B,MAAM,EAAE,wBAAwB,CAAC,UAAU,EAAE,MAAM,CAAC;wBACpD,MAAM,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAuB;qBAC5D,CAAC;oBACF,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC;wBAC1C,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;wBACvC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,GAAG,EAAE,CAAC;oBACzC,CAAC,CAAC,CACH,CAAC;oBACF,OAAO,EAAE,CAAC;gBACZ,CAAC;gBAED,WAAW,CAAC,OAAO;oBACjB,WAAW,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;oBACpC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBAC5B,MAAM,SAAS,GACb,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC;oBACvD,KAAK,CAAC,KAAK,IAAI,EAAE;wBACf,IAAI,CAAC,SAAS;4BAAE,OAAO;wBACvB,MAAM,SAAS,GAAG,MAAM,GAAG,EAAE,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;wBAChD,MAAM,kBAAkB,CAAC,EAAC,SAAS,EAAE,SAAS,EAAC,CAAC,CAAC;wBACjD,KAAK,GAAG,EAAE,CAAC,EAAE,CAAC,mBAAmB,EAAE,CAAC;oBACtC,CAAC,CAAC,EAAE,CAAC;oBACL,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBAC1C,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU;4BAC3B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;wBAC/D,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,KAAK,OAAO,EAAE,CAAC;4BAClD,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc;gCAC/B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;wBACrC,CAAC;oBACH,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,eAAe,CAAC,OAAO;oBACrB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,GAAG,OAAO,CAAC;oBAC9C,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,WAAW,CAAC,OAAO,EAAE,KAAK;oBACxB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBACjD,IAAI,KAAK,EAAE,CAAC;4BACV,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;wBACtB,CAAC;oBACH,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,SAAS,CAAC,OAAO,EAAE,MAAM;oBACvB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBACjD,IAAI,CAAC,KAAK;4BAAE,OAAO;wBACnB,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;wBACtB,KAAK,CAAC,MAAM,GAAG,wBAAwB,EAAE,CAAC;wBAC1C,KAAK,CAAC,MAAM,GAAG,uBAAuB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;oBACvD,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,SAAS,CAAC,OAAO,EAAE,MAAM;oBACvB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,OAAO,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;wBACvB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBACjD,IAAI,CAAC,KAAK;4BAAE,OAAO;wBACnB,KAAK,CAAC,MAAM,GAAG,EAAC,GAAG,KAAK,CAAC,MAAM,EAAE,GAAG,MAAM,EAAC,CAAC;oBAC9C,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,SAAS,CAAC,OAAO,EAAE,MAAM;oBACvB,MAAM,WAAW,GACf,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,KAAK,OAAO;wBAC1D,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAE,CAAC,MAAM;wBAC5C,CAAC,CAAC,SAAS,CAAC;oBAChB,MAAM,OAAO,GACX,WAAW,EAAE,IAAI,KAAK,OAAO;wBAC3B,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CACnB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,WAAW,CAAC,SAAS,CAC7C,EAAE,OAAO,IAAI,EAAE,CAAC;wBACnB,CAAC,CAAC,EAAE,CAAC;oBACT,iBAAiB,CAAC,OAAO,EAAE,GAAG,EAAE,CAC9B,oBAAoB,CAAC,MAAM,EAAE,OAAO,CAAC,CACtC,CAAC;gBACJ,CAAC;gBAED,WAAW,CAAC,OAAO,EAAE,MAAM;oBACzB,MAAM,WAAW,GACf,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,KAAK,OAAO;wBAC1D,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAE,CAAC,MAAM;wBAC5C,CAAC,CAAC,SAAS,CAAC;oBAChB,MAAM,OAAO,GACX,WAAW,EAAE,IAAI,KAAK,OAAO;wBAC3B,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CACnB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,WAAW,CAAC,SAAS,CAC7C,EAAE,OAAO,IAAI,EAAE,CAAC;wBACnB,CAAC,CAAC,EAAE,CAAC;oBACT,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,oBAAoB,CAAC,EAAC,GAAG,CAAC,EAAE,GAAG,MAAM,EAAC,EAAE,OAAO,CAAC,CACjD,CAAC;gBACJ,CAAC;gBAED,eAAe,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,EAAE,CACzC,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,YAAY,EAAC,CAAC,CAAC;gBAE3D,iBAAiB,EAAE,CAAC,OAAO,EAAE,cAAc,EAAE,EAAE,CAC7C,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,cAAc,EAAC,CAAC,CAAC;gBAE7D,OAAO,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CACzB,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,IAAI,EAAC,CAAC,CAAC;gBAEnD,OAAO,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CACzB,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,IAAI,EAAC,CAAC,CAAC;gBAEnD,OAAO,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CACzB,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,IAAI,EAAC,CAAC,CAAC;gBAEnD,cAAc,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,EAAE,CACvC,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAE,WAAW,EAAC,CAAC,CAAC;gBAE1D,SAAS,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,CAChD,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,iBAAiB,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC,CAChD;gBAEH,aAAa,EAAE,CAAC,OAAO,EAAE,EAAE,CACzB,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;oBACjC,GAAG,CAAC;oBACJ,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC;iBACpC,CAAC,CAAC;gBAEL,aAAa,EAAE,CAAC,OAAO,EAAE,EAAE,CACzB,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;oBACjC,GAAG,CAAC;oBACJ,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC;iBACpC,CAAC,CAAC;gBAEL,wBAAwB,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,CACvD,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,gCAAgC,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,CACvD;gBAEH,wBAAwB,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,CACvD,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,gCAAgC,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,CACvD;gBAEH,2BAA2B,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,CAC1D,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,mCAAmC,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,CAC1D;gBAEH,oBAAoB,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,EAAE,CAC3C,iBAAiB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAC/B,4BAA4B,CAAC,CAAC,EAAE,SAAS,CAAC,CAC3C;gBAEH,KAAK,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI;oBAC1B,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC;oBACpB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACjD,IAAI,CAAC,KAAK;wBAAE,OAAO;oBAEnB,MAAM,UAAU,GAAG,IAAI,EAAE,UAAU,IAAI,kBAAkB,CAAC;oBAE1D,IAAI,WAAW,GAAG,IAAI,EAAE,WAAW,CAAC;oBACpC,IAAI,CAAC,WAAW,EAAE,CAAC;wBACjB,MAAM,WAAW,GACf,KAAK,CAAC,MAAM,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;wBAC5D,IAAI,CAAC,WAAW;4BAAE,OAAO;wBACzB,MAAM,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAChC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,WAAW,CAAC,SAAS,CAC7C,CAAC;wBACF,IAAI,CAAC,KAAK;4BAAE,OAAO;wBACnB,WAAW,GAAG,+BAA+B,CAAC,KAAK,CAAC,CAAC;oBACvD,CAAC;oBAED,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;wBACzB,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBAC7C,IAAI,CAAC,CAAC;4BAAE,OAAO;wBACf,CAAC,CAAC,MAAM,GAAG,EAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAC,CAAC;oBAC7C,CAAC,CAAC,CACH,CAAC;oBAEF,IAAI,CAAC;wBACH,MAAM,SAAS,GAAG,MAAM,KAAK,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;wBAChD,MAAM,gBAAgB,GAAG,oBAAoB,CAC3C,KAAK,CAAC,MAAM,EACZ,WAAW,CAAC,OAAO,CACpB,CAAC;wBACF,MAAM,SAAS,GAAG,MAAM,6BAA6B,CAAC;4BACpD,SAAS;4BACT,MAAM,EAAE,WAAW;4BACnB,MAAM,EAAE,gBAAgB;4BACxB,gBAAgB,EAAE,SAAS,OAAO,EAAE;4BACpC,UAAU;yBACX,CAAC,CAAC;wBACH,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;4BACzB,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;4BAC7C,IAAI,CAAC,CAAC;gCAAE,OAAO;4BACf,CAAC,CAAC,MAAM,GAAG,gBAAgB,CAAC;4BAC5B,CAAC,CAAC,MAAM,GAAG;gCACT,KAAK,EAAE,SAAS;gCAChB,KAAK,EAAE,KAAK;gCACZ,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE;gCACvB,SAAS;gCACT,cAAc,EAAE,WAAY,CAAC,QAAQ;6BACtC,CAAC;wBACJ,CAAC,CAAC,CACH,CAAC;wBACF,KAAK,GAAG,EAAE,CAAC,EAAE,CAAC,mBAAmB,EAAE,CAAC;oBACtC,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;4BACzB,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;4BAC7C,IAAI,CAAC,CAAC;gCAAE,OAAO;4BACf,CAAC,CAAC,MAAM,GAAG;gCACT,GAAG,CAAC,CAAC,MAAM;gCACX,KAAK,EAAE,OAAO;gCACd,SAAS,EACP,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;6BACzD,CAAC;wBACJ,CAAC,CAAC,CACH,CAAC;oBACJ,CAAC;gBACH,CAAC;aACF;SACF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["import {DuckDbSliceState} from '@sqlrooms/duckdb';\nimport {BaseRoomStoreState, createSlice} from '@sqlrooms/room-store';\nimport {generateUniqueName} from '@sqlrooms/utils';\nimport {produce} from 'immer';\nimport {createId} from '@paralleldrive/cuid2';\nimport {\n addAttributeFilterValuesInConfig,\n clearAttributeFilterInConfig,\n createDefaultPivotConfig,\n moveFieldInConfig,\n nextSortOrder,\n normalizePivotConfig,\n removeAttributeFilterValuesInConfig,\n setAttributeFilterValuesInConfig,\n} from './PivotCoreSlice';\nimport type {\n PivotInstanceSnapshot,\n PivotInstanceState,\n PivotInstanceStore,\n} from './PivotCoreSlice';\nimport {createPivotQuerySourceFromTable} from './sql';\nimport {\n createOrReplacePivotRelations,\n dropPivotRelations,\n} from './pivotExecution';\nimport {\n type PivotConfig,\n type PivotSliceConfig as PivotSlicePersistedConfig,\n type PivotSource,\n type PivotStatus,\n PivotSliceConfig,\n PivotSliceState,\n} from './types';\nimport {createStore} from 'zustand/vanilla';\n\nfunction createInitialPivotSliceConfig(props?: {\n config?: Partial<PivotConfig & {tableName?: string}>;\n}): PivotSlicePersistedConfig {\n if (!props?.config) {\n return PivotSliceConfig.parse({\n pivots: {},\n pivotOrder: [],\n currentPivotId: undefined,\n });\n }\n const id = createId();\n const source = props?.config?.tableName\n ? ({kind: 'table', tableName: props.config.tableName} as PivotSource)\n : undefined;\n const config = createDefaultPivotConfig(props?.config);\n return PivotSliceConfig.parse({\n pivots: {\n [id]: {\n id,\n title: 'Pivot 1',\n source,\n config,\n status: {state: 'idle', stale: false},\n },\n },\n pivotOrder: [id],\n currentPivotId: id,\n });\n}\n\nfunction resetPivotRuntimeStatus(status: PivotStatus): PivotStatus {\n return {\n state: 'idle',\n stale: true,\n lastRunTime: status.lastRunTime,\n };\n}\n\nexport function createPivotSlice(props?: {\n config?: Partial<PivotConfig & {tableName?: string}>;\n}) {\n type RootState = BaseRoomStoreState & DuckDbSliceState & PivotSliceState;\n const pivotStores = new Map<string, PivotInstanceStore>();\n\n return createSlice<PivotSliceState, RootState>((set, get, store) => {\n /**\n * Shared helper: mutate a pivot's config and reset its runtime status.\n * `updater` receives the current config and returns the new one.\n */\n const updatePivotConfig = (\n pivotId: string,\n updater: (config: PivotConfig) => PivotConfig,\n ) => {\n set((state) =>\n produce(state, (draft) => {\n const pivot = draft.pivot.config.pivots[pivotId];\n if (!pivot) return;\n pivot.config = updater(pivot.config);\n pivot.status = resetPivotRuntimeStatus(pivot.status);\n }),\n );\n };\n\n return {\n pivot: {\n config: createInitialPivotSliceConfig(props),\n\n async initialize() {\n const tables = get().db.tables;\n if (tables.length === 0) {\n return;\n }\n set((state) =>\n produce(state, (draft) => {\n if (\n !draft.pivot.config.currentPivotId &&\n draft.pivot.config.pivotOrder.length > 0\n ) {\n draft.pivot.config.currentPivotId =\n draft.pivot.config.pivotOrder[0];\n }\n\n for (const pivotId of draft.pivot.config.pivotOrder) {\n const pivot = draft.pivot.config.pivots[pivotId];\n if (!pivot) continue;\n if (pivot.source?.kind === 'table') {\n const tableName = pivot.source.tableName;\n const table =\n tables.find(\n (candidate) => candidate.tableName === tableName,\n ) ?? tables[0];\n if (table) {\n pivot.source = {kind: 'table', tableName: table.tableName};\n pivot.config = normalizePivotConfig(\n pivot.config,\n table.columns,\n );\n }\n }\n pivot.status = resetPivotRuntimeStatus(pivot.status);\n }\n }),\n );\n },\n\n getPivotStore(pivotId) {\n const existing = pivotStores.get(pivotId);\n if (existing) return existing;\n\n function getSnapshot(): PivotInstanceSnapshot {\n const rootState = get();\n const pivot = rootState.pivot.config.pivots[pivotId];\n const availableTables = rootState.db.tables.map((t) => t.tableName);\n if (!pivot) {\n return {\n source: undefined,\n config: createDefaultPivotConfig(),\n status: {state: 'idle', stale: false},\n querySource: undefined,\n fields: [],\n availableTables,\n };\n }\n const tableSource =\n pivot.source?.kind === 'table' ? pivot.source : undefined;\n const table = tableSource\n ? rootState.db.tables.find(\n (t) => t.tableName === tableSource.tableName,\n )\n : undefined;\n const querySource = table\n ? createPivotQuerySourceFromTable(table)\n : undefined;\n return {\n source: pivot.source,\n config: pivot.config,\n status: pivot.status,\n querySource,\n fields: querySource?.columns ?? [],\n availableTables,\n };\n }\n\n let currentSnapshot = getSnapshot();\n\n const adapterStore = createStore<PivotInstanceState>(\n (adapterSet) => ({\n ...currentSnapshot,\n ui: {sectionOpenState: {}},\n setSource: (source) => get().pivot.setSource(pivotId, source),\n setConfig: (config) => get().pivot.setConfig(pivotId, config),\n patchConfig: (partial) =>\n get().pivot.patchConfig(pivotId, partial),\n setRendererName: (v) => get().pivot.setRendererName(pivotId, v),\n setAggregatorName: (v) =>\n get().pivot.setAggregatorName(pivotId, v),\n setVals: (v) => get().pivot.setVals(pivotId, v),\n moveField: (field, dest, idx) =>\n get().pivot.moveField(pivotId, field, dest, idx),\n cycleRowOrder: () => get().pivot.cycleRowOrder(pivotId),\n cycleColOrder: () => get().pivot.cycleColOrder(pivotId),\n setAttributeFilterValues: (a, v) =>\n get().pivot.setAttributeFilterValues(pivotId, a, v),\n addAttributeFilterValues: (a, v) =>\n get().pivot.addAttributeFilterValues(pivotId, a, v),\n removeAttributeFilterValues: (a, v) =>\n get().pivot.removeAttributeFilterValues(pivotId, a, v),\n clearAttributeFilter: (a) =>\n get().pivot.clearAttributeFilter(pivotId, a),\n setSectionOpen: (section, isOpen) =>\n adapterSet((state) => ({\n ui: {\n ...state.ui,\n sectionOpenState: {\n ...state.ui.sectionOpenState,\n [section]: isOpen,\n },\n },\n })),\n run: () => get().pivot.runPivot(pivotId),\n }),\n );\n\n const unsubscribe = store.subscribe(() => {\n const nextSnapshot = getSnapshot();\n const prev = currentSnapshot;\n if (\n JSON.stringify(prev.source) ===\n JSON.stringify(nextSnapshot.source) &&\n JSON.stringify(prev.config) ===\n JSON.stringify(nextSnapshot.config) &&\n JSON.stringify(prev.status) ===\n JSON.stringify(nextSnapshot.status) &&\n JSON.stringify(prev.querySource) ===\n JSON.stringify(nextSnapshot.querySource) &&\n prev.fields.length === nextSnapshot.fields.length &&\n prev.fields.every(\n (f, i) =>\n f.name === nextSnapshot.fields[i]?.name &&\n f.type === nextSnapshot.fields[i]?.type,\n ) &&\n prev.availableTables.length ===\n nextSnapshot.availableTables.length &&\n prev.availableTables.every(\n (t, i) => t === nextSnapshot.availableTables[i],\n )\n ) {\n return;\n }\n currentSnapshot = nextSnapshot;\n adapterStore.setState(nextSnapshot);\n });\n\n const instanceStore: PivotInstanceStore = Object.assign(\n adapterStore,\n {\n destroy: () => {\n unsubscribe();\n pivotStores.delete(pivotId);\n },\n },\n );\n pivotStores.set(pivotId, instanceStore);\n return instanceStore;\n },\n\n addPivot(pivotProps) {\n const id = createId();\n const title = generateUniqueName(\n pivotProps?.title ?? 'Pivot 1',\n Object.values(get().pivot.config.pivots).map(\n (pivot) => pivot.title,\n ),\n ' ',\n );\n const nextPivot = {\n id,\n title,\n source: pivotProps?.source,\n config: createDefaultPivotConfig(pivotProps?.config),\n status: {state: 'idle', stale: false} satisfies PivotStatus,\n };\n set((state) =>\n produce(state, (draft) => {\n draft.pivot.config.pivots[id] = nextPivot;\n draft.pivot.config.pivotOrder.push(id);\n draft.pivot.config.currentPivotId = id;\n }),\n );\n return id;\n },\n\n removePivot(pivotId) {\n pivotStores.get(pivotId)?.destroy();\n pivotStores.delete(pivotId);\n const relations =\n get().pivot.config.pivots[pivotId]?.status.relations;\n void (async () => {\n if (!relations) return;\n const connector = await get().db.getConnector();\n await dropPivotRelations({connector, relations});\n void get().db.refreshTableSchemas();\n })();\n set((state) =>\n produce(state, (draft) => {\n delete draft.pivot.config.pivots[pivotId];\n draft.pivot.config.pivotOrder =\n draft.pivot.config.pivotOrder.filter((id) => id !== pivotId);\n if (draft.pivot.config.currentPivotId === pivotId) {\n draft.pivot.config.currentPivotId =\n draft.pivot.config.pivotOrder[0];\n }\n }),\n );\n },\n\n setCurrentPivot(pivotId) {\n set((state) =>\n produce(state, (draft) => {\n draft.pivot.config.currentPivotId = pivotId;\n }),\n );\n },\n\n renamePivot(pivotId, title) {\n set((state) =>\n produce(state, (draft) => {\n const pivot = draft.pivot.config.pivots[pivotId];\n if (pivot) {\n pivot.title = title;\n }\n }),\n );\n },\n\n setSource(pivotId, source) {\n set((state) =>\n produce(state, (draft) => {\n const pivot = draft.pivot.config.pivots[pivotId];\n if (!pivot) return;\n pivot.source = source;\n pivot.config = createDefaultPivotConfig();\n pivot.status = resetPivotRuntimeStatus(pivot.status);\n }),\n );\n },\n\n setStatus(pivotId, status) {\n set((state) =>\n produce(state, (draft) => {\n const pivot = draft.pivot.config.pivots[pivotId];\n if (!pivot) return;\n pivot.status = {...pivot.status, ...status};\n }),\n );\n },\n\n setConfig(pivotId, config) {\n const tableSource =\n get().pivot.config.pivots[pivotId]?.source?.kind === 'table'\n ? get().pivot.config.pivots[pivotId]!.source\n : undefined;\n const columns =\n tableSource?.kind === 'table'\n ? (get().db.tables.find(\n (t) => t.tableName === tableSource.tableName,\n )?.columns ?? [])\n : [];\n updatePivotConfig(pivotId, () =>\n normalizePivotConfig(config, columns),\n );\n },\n\n patchConfig(pivotId, config) {\n const tableSource =\n get().pivot.config.pivots[pivotId]?.source?.kind === 'table'\n ? get().pivot.config.pivots[pivotId]!.source\n : undefined;\n const columns =\n tableSource?.kind === 'table'\n ? (get().db.tables.find(\n (t) => t.tableName === tableSource.tableName,\n )?.columns ?? [])\n : [];\n updatePivotConfig(pivotId, (c) =>\n normalizePivotConfig({...c, ...config}, columns),\n );\n },\n\n setRendererName: (pivotId, rendererName) =>\n updatePivotConfig(pivotId, (c) => ({...c, rendererName})),\n\n setAggregatorName: (pivotId, aggregatorName) =>\n updatePivotConfig(pivotId, (c) => ({...c, aggregatorName})),\n\n setRows: (pivotId, rows) =>\n updatePivotConfig(pivotId, (c) => ({...c, rows})),\n\n setCols: (pivotId, cols) =>\n updatePivotConfig(pivotId, (c) => ({...c, cols})),\n\n setVals: (pivotId, vals) =>\n updatePivotConfig(pivotId, (c) => ({...c, vals})),\n\n setUnusedOrder: (pivotId, unusedOrder) =>\n updatePivotConfig(pivotId, (c) => ({...c, unusedOrder})),\n\n moveField: (pivotId, field, destination, index) =>\n updatePivotConfig(pivotId, (c) =>\n moveFieldInConfig(c, field, destination, index),\n ),\n\n cycleRowOrder: (pivotId) =>\n updatePivotConfig(pivotId, (c) => ({\n ...c,\n rowOrder: nextSortOrder(c.rowOrder),\n })),\n\n cycleColOrder: (pivotId) =>\n updatePivotConfig(pivotId, (c) => ({\n ...c,\n colOrder: nextSortOrder(c.colOrder),\n })),\n\n setAttributeFilterValues: (pivotId, attribute, values) =>\n updatePivotConfig(pivotId, (c) =>\n setAttributeFilterValuesInConfig(c, attribute, values),\n ),\n\n addAttributeFilterValues: (pivotId, attribute, values) =>\n updatePivotConfig(pivotId, (c) =>\n addAttributeFilterValuesInConfig(c, attribute, values),\n ),\n\n removeAttributeFilterValues: (pivotId, attribute, values) =>\n updatePivotConfig(pivotId, (c) =>\n removeAttributeFilterValuesInConfig(c, attribute, values),\n ),\n\n clearAttributeFilter: (pivotId, attribute) =>\n updatePivotConfig(pivotId, (c) =>\n clearAttributeFilterInConfig(c, attribute),\n ),\n\n async runPivot(pivotId, opts) {\n const state = get();\n const pivot = state.pivot.config.pivots[pivotId];\n if (!pivot) return;\n\n const schemaName = opts?.schemaName ?? '__sqlrooms_pivot';\n\n let querySource = opts?.querySource;\n if (!querySource) {\n const tableSource =\n pivot.source?.kind === 'table' ? pivot.source : undefined;\n if (!tableSource) return;\n const table = state.db.tables.find(\n (t) => t.tableName === tableSource.tableName,\n );\n if (!table) return;\n querySource = createPivotQuerySourceFromTable(table);\n }\n\n set((current) =>\n produce(current, (draft) => {\n const p = draft.pivot.config.pivots[pivotId];\n if (!p) return;\n p.status = {...p.status, state: 'running'};\n }),\n );\n\n try {\n const connector = await state.db.getConnector();\n const normalizedConfig = normalizePivotConfig(\n pivot.config,\n querySource.columns,\n );\n const relations = await createOrReplacePivotRelations({\n connector,\n source: querySource,\n config: normalizedConfig,\n relationBaseName: `pivot_${pivotId}`,\n schemaName,\n });\n set((current) =>\n produce(current, (draft) => {\n const p = draft.pivot.config.pivots[pivotId];\n if (!p) return;\n p.config = normalizedConfig;\n p.status = {\n state: 'success',\n stale: false,\n lastRunTime: Date.now(),\n relations,\n sourceRelation: querySource!.tableRef,\n };\n }),\n );\n void get().db.refreshTableSchemas();\n } catch (error) {\n set((current) =>\n produce(current, (draft) => {\n const p = draft.pivot.config.pivots[pivotId];\n if (!p) return;\n p.status = {\n ...p.status,\n state: 'error',\n lastError:\n error instanceof Error ? error.message : String(error),\n };\n }),\n );\n }\n },\n },\n };\n });\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PivotView.d.ts","sourceRoot":"","sources":["../src/PivotView.tsx"],"names":[],"mappings":"AAGA,OAAO,KAA2B,MAAM,OAAO,CAAC;AAuBhD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAwC7B,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useBaseRoomStore } from '@sqlrooms/room-store';
|
|
3
|
+
import { useEffect, useMemo } from 'react';
|
|
4
|
+
import { PivotEditor } from './PivotEditor';
|
|
5
|
+
const PivotViewContent = ({ pivotId }) => {
|
|
6
|
+
const getPivotStore = useBaseRoomStore((state) => state.pivot.getPivotStore);
|
|
7
|
+
const pivotStore = useMemo(() => getPivotStore(pivotId), [getPivotStore, pivotId]);
|
|
8
|
+
return _jsx(PivotEditor, { store: pivotStore, autoRun: true });
|
|
9
|
+
};
|
|
10
|
+
export const PivotView = () => {
|
|
11
|
+
const tables = useBaseRoomStore((state) => state.db.tables);
|
|
12
|
+
const pivotConfig = useBaseRoomStore((state) => state.pivot.config);
|
|
13
|
+
const currentPivotId = pivotConfig.currentPivotId;
|
|
14
|
+
const currentPivot = currentPivotId
|
|
15
|
+
? pivotConfig.pivots[currentPivotId]
|
|
16
|
+
: undefined;
|
|
17
|
+
const setSource = useBaseRoomStore((state) => state.pivot.setSource);
|
|
18
|
+
const selectedTable = useMemo(() => {
|
|
19
|
+
if (currentPivot?.source?.kind !== 'table') {
|
|
20
|
+
return tables[0];
|
|
21
|
+
}
|
|
22
|
+
const tableName = currentPivot.source.tableName;
|
|
23
|
+
return tables.find((table) => table.tableName === tableName) ?? tables[0];
|
|
24
|
+
}, [currentPivot?.source, tables]);
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
if (currentPivot && !currentPivot.source && selectedTable) {
|
|
27
|
+
setSource(currentPivot.id, {
|
|
28
|
+
kind: 'table',
|
|
29
|
+
tableName: selectedTable.tableName,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}, [currentPivot, selectedTable, setSource]);
|
|
33
|
+
const tableSource = currentPivot?.source?.kind === 'table' ? currentPivot.source : undefined;
|
|
34
|
+
if (!currentPivot || !selectedTable || !tableSource) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return _jsx(PivotViewContent, { pivotId: currentPivot.id });
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=PivotView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PivotView.js","sourceRoot":"","sources":["../src/PivotView.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAc,EAAC,SAAS,EAAE,OAAO,EAAC,MAAM,OAAO,CAAC;AAChD,OAAO,EAAC,WAAW,EAAC,MAAM,eAAe,CAAC;AAU1C,MAAM,gBAAgB,GAAgC,CAAC,EAAC,OAAO,EAAC,EAAE,EAAE;IAClE,MAAM,aAAa,GAAG,gBAAgB,CACpC,CAAC,KAAqB,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,aAAa,CACrD,CAAC;IACF,MAAM,UAAU,GAAG,OAAO,CACxB,GAAG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,EAC5B,CAAC,aAAa,EAAE,OAAO,CAAC,CACzB,CAAC;IAEF,OAAO,KAAC,WAAW,IAAC,KAAK,EAAE,UAAU,EAAE,OAAO,SAAG,CAAC;AACpD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAa,GAAG,EAAE;IACtC,MAAM,MAAM,GAAG,gBAAgB,CAC7B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAC3B,CAAC;IACF,MAAM,WAAW,GAAG,gBAAgB,CAClC,CAAC,KAAqB,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAC9C,CAAC;IACF,MAAM,cAAc,GAAG,WAAW,CAAC,cAAc,CAAC;IAClD,MAAM,YAAY,GAAG,cAAc;QACjC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,cAAc,CAAC;QACpC,CAAC,CAAC,SAAS,CAAC;IACd,MAAM,SAAS,GAAG,gBAAgB,CAChC,CAAC,KAAqB,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CACjD,CAAC;IAEF,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,EAAE;QACjC,IAAI,YAAY,EAAE,MAAM,EAAE,IAAI,KAAK,OAAO,EAAE,CAAC;YAC3C,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC;QACD,MAAM,SAAS,GAAG,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC;QAChD,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,SAAS,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IAC5E,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IAEnC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,YAAY,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,aAAa,EAAE,CAAC;YAC1D,SAAS,CAAC,YAAY,CAAC,EAAE,EAAE;gBACzB,IAAI,EAAE,OAAO;gBACb,SAAS,EAAE,aAAa,CAAC,SAAS;aACnC,CAAC,CAAC;QACL,CAAC;IACH,CAAC,EAAE,CAAC,YAAY,EAAE,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC;IAE7C,MAAM,WAAW,GACf,YAAY,EAAE,MAAM,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;IAE3E,IAAI,CAAC,YAAY,IAAI,CAAC,aAAa,IAAI,CAAC,WAAW,EAAE,CAAC;QACpD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,KAAC,gBAAgB,IAAC,OAAO,EAAE,YAAY,CAAC,EAAE,GAAI,CAAC;AACxD,CAAC,CAAC","sourcesContent":["import {DataTable} from '@sqlrooms/duckdb';\nimport type {BaseRoomStoreState} from '@sqlrooms/room-store';\nimport {useBaseRoomStore} from '@sqlrooms/room-store';\nimport React, {useEffect, useMemo} from 'react';\nimport {PivotEditor} from './PivotEditor';\nimport {PivotSliceState} from './types';\n\ntype PivotRootState = BaseRoomStoreState &\n PivotSliceState & {\n db: {\n tables: DataTable[];\n };\n };\n\nconst PivotViewContent: React.FC<{pivotId: string}> = ({pivotId}) => {\n const getPivotStore = useBaseRoomStore(\n (state: PivotRootState) => state.pivot.getPivotStore,\n );\n const pivotStore = useMemo(\n () => getPivotStore(pivotId),\n [getPivotStore, pivotId],\n );\n\n return <PivotEditor store={pivotStore} autoRun />;\n};\n\nexport const PivotView: React.FC = () => {\n const tables = useBaseRoomStore<PivotRootState, DataTable[]>(\n (state) => state.db.tables,\n );\n const pivotConfig = useBaseRoomStore(\n (state: PivotRootState) => state.pivot.config,\n );\n const currentPivotId = pivotConfig.currentPivotId;\n const currentPivot = currentPivotId\n ? pivotConfig.pivots[currentPivotId]\n : undefined;\n const setSource = useBaseRoomStore(\n (state: PivotRootState) => state.pivot.setSource,\n );\n\n const selectedTable = useMemo(() => {\n if (currentPivot?.source?.kind !== 'table') {\n return tables[0];\n }\n const tableName = currentPivot.source.tableName;\n return tables.find((table) => table.tableName === tableName) ?? tables[0];\n }, [currentPivot?.source, tables]);\n\n useEffect(() => {\n if (currentPivot && !currentPivot.source && selectedTable) {\n setSource(currentPivot.id, {\n kind: 'table',\n tableName: selectedTable.tableName,\n });\n }\n }, [currentPivot, selectedTable, setSource]);\n\n const tableSource =\n currentPivot?.source?.kind === 'table' ? currentPivot.source : undefined;\n\n if (!currentPivot || !selectedTable || !tableSource) {\n return null;\n }\n\n return <PivotViewContent pivotId={currentPivot.id} />;\n};\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type HeatmapMode, type PivotArrowTable, type PivotCellValue } from './helpers';
|
|
2
|
+
import { PivotConfig } from './types';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
type TableRendererProps = {
|
|
5
|
+
config: PivotConfig;
|
|
6
|
+
cellRows: PivotArrowTable;
|
|
7
|
+
rowTotals: PivotArrowTable;
|
|
8
|
+
colTotals: PivotArrowTable;
|
|
9
|
+
grandTotal: PivotCellValue;
|
|
10
|
+
heatmapMode?: HeatmapMode;
|
|
11
|
+
};
|
|
12
|
+
export declare const TableRenderer: React.FC<TableRendererProps>;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=TableRenderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TableRenderer.d.ts","sourceRoot":"","sources":["../src/TableRenderer.tsx"],"names":[],"mappings":"AACA,OAAO,EAKL,KAAK,WAAW,EAGhB,KAAK,eAAe,EACpB,KAAK,cAAc,EAGpB,MAAM,WAAW,CAAC;AAEnB,OAAO,EAAC,WAAW,EAAC,MAAM,SAAS,CAAC;AACpC,OAAO,KAAgB,MAAM,OAAO,CAAC;AAErC,KAAK,kBAAkB,GAAG;IACxB,MAAM,EAAE,WAAW,CAAC;IACpB,QAAQ,EAAE,eAAe,CAAC;IAC1B,SAAS,EAAE,eAAe,CAAC;IAC3B,SAAS,EAAE,eAAe,CAAC;IAC3B,UAAU,EAAE,cAAc,CAAC;IAC3B,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CA+PtD,CAAC"}
|