@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.
Files changed (66) hide show
  1. package/README.md +3 -0
  2. package/dist/PivotCellContent.d.ts +10 -0
  3. package/dist/PivotCellContent.d.ts.map +1 -0
  4. package/dist/PivotCellContent.js +37 -0
  5. package/dist/PivotCellContent.js.map +1 -0
  6. package/dist/PivotCoreSlice.d.ts +73 -0
  7. package/dist/PivotCoreSlice.d.ts.map +1 -0
  8. package/dist/PivotCoreSlice.js +175 -0
  9. package/dist/PivotCoreSlice.js.map +1 -0
  10. package/dist/PivotEditor.d.ts +66 -0
  11. package/dist/PivotEditor.d.ts.map +1 -0
  12. package/dist/PivotEditor.js +341 -0
  13. package/dist/PivotEditor.js.map +1 -0
  14. package/dist/PivotResults.d.ts +15 -0
  15. package/dist/PivotResults.d.ts.map +1 -0
  16. package/dist/PivotResults.js +102 -0
  17. package/dist/PivotResults.js.map +1 -0
  18. package/dist/PivotSlice.d.ts +7 -0
  19. package/dist/PivotSlice.d.ts.map +1 -0
  20. package/dist/PivotSlice.js +353 -0
  21. package/dist/PivotSlice.js.map +1 -0
  22. package/dist/PivotView.d.ts +3 -0
  23. package/dist/PivotView.d.ts.map +1 -0
  24. package/dist/PivotView.js +39 -0
  25. package/dist/PivotView.js.map +1 -0
  26. package/dist/TableRenderer.d.ts +14 -0
  27. package/dist/TableRenderer.d.ts.map +1 -0
  28. package/dist/TableRenderer.js +100 -0
  29. package/dist/TableRenderer.js.map +1 -0
  30. package/dist/TsvRenderer.d.ts +7 -0
  31. package/dist/TsvRenderer.d.ts.map +1 -0
  32. package/dist/TsvRenderer.js +26 -0
  33. package/dist/TsvRenderer.js.map +1 -0
  34. package/dist/aggregators.d.ts +24 -0
  35. package/dist/aggregators.d.ts.map +1 -0
  36. package/dist/aggregators.js +232 -0
  37. package/dist/aggregators.js.map +1 -0
  38. package/dist/helpers.d.ts +85 -0
  39. package/dist/helpers.d.ts.map +1 -0
  40. package/dist/helpers.js +348 -0
  41. package/dist/helpers.js.map +1 -0
  42. package/dist/index.d.ts +20 -0
  43. package/dist/index.d.ts.map +1 -0
  44. package/dist/index.js +17 -0
  45. package/dist/index.js.map +1 -0
  46. package/dist/pivotCellRegistryEntry.d.ts +4 -0
  47. package/dist/pivotCellRegistryEntry.d.ts.map +1 -0
  48. package/dist/pivotCellRegistryEntry.js +137 -0
  49. package/dist/pivotCellRegistryEntry.js.map +1 -0
  50. package/dist/pivotCellTypes.d.ts +23 -0
  51. package/dist/pivotCellTypes.d.ts.map +1 -0
  52. package/dist/pivotCellTypes.js +14 -0
  53. package/dist/pivotCellTypes.js.map +1 -0
  54. package/dist/pivotExecution.d.ts +16 -0
  55. package/dist/pivotExecution.d.ts.map +1 -0
  56. package/dist/pivotExecution.js +49 -0
  57. package/dist/pivotExecution.js.map +1 -0
  58. package/dist/sql.d.ts +17 -0
  59. package/dist/sql.d.ts.map +1 -0
  60. package/dist/sql.js +278 -0
  61. package/dist/sql.js.map +1 -0
  62. package/dist/types.d.ts +513 -0
  63. package/dist/types.d.ts.map +1 -0
  64. package/dist/types.js +107 -0
  65. package/dist/types.js.map +1 -0
  66. 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":"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","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,3 @@
1
+ import React from 'react';
2
+ export declare const PivotView: React.FC;
3
+ //# sourceMappingURL=PivotView.d.ts.map
@@ -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"}