@dxos/plugin-sheet 0.6.13-main.ed424a1 → 0.6.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/SheetContainer-U4H5D34A.mjs +1772 -0
- package/dist/lib/browser/SheetContainer-U4H5D34A.mjs.map +7 -0
- package/dist/lib/browser/chunk-APHOLYUB.mjs +175 -0
- package/dist/lib/browser/chunk-APHOLYUB.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-5WPZCXNS.mjs → browser/chunk-D5AGLXJP.mjs} +678 -411
- package/dist/lib/browser/chunk-D5AGLXJP.mjs.map +7 -0
- package/dist/lib/browser/chunk-FUAGSXA4.mjs +82 -0
- package/dist/lib/browser/chunk-FUAGSXA4.mjs.map +7 -0
- package/dist/lib/browser/chunk-JRL5LGCE.mjs +18 -0
- package/dist/lib/browser/chunk-JRL5LGCE.mjs.map +7 -0
- package/dist/lib/browser/chunk-NU4PBN33.mjs +8 -0
- package/dist/lib/browser/chunk-NU4PBN33.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +62 -93
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/meta.mjs +1 -1
- package/dist/lib/browser/testing.mjs +92 -0
- package/dist/lib/browser/testing.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +12 -6
- package/dist/lib/node/SheetContainer-AXQV3ZT5.cjs +1765 -0
- package/dist/lib/node/SheetContainer-AXQV3ZT5.cjs.map +7 -0
- package/dist/lib/node/{chunk-5XPK2V4A.cjs → chunk-5KKJ4NPP.cjs} +678 -418
- package/dist/lib/node/chunk-5KKJ4NPP.cjs.map +7 -0
- package/dist/lib/node/chunk-BJ6ZD7MN.cjs +51 -0
- package/dist/lib/node/chunk-BJ6ZD7MN.cjs.map +7 -0
- package/dist/lib/node/chunk-CN3RPESU.cjs +202 -0
- package/dist/lib/node/chunk-CN3RPESU.cjs.map +7 -0
- package/dist/lib/node/{chunk-NZARD7UP.cjs → chunk-DSYKOI4E.cjs} +51 -40
- package/dist/lib/node/chunk-DSYKOI4E.cjs.map +7 -0
- package/dist/lib/node/chunk-PYXHNAAK.cjs +40 -0
- package/dist/lib/node/chunk-PYXHNAAK.cjs.map +7 -0
- package/dist/lib/node/index.cjs +69 -105
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/meta.cjs +3 -3
- package/dist/lib/node/meta.cjs.map +1 -1
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/testing.cjs +111 -0
- package/dist/lib/node/testing.cjs.map +7 -0
- package/dist/lib/node/types.cjs +15 -9
- package/dist/lib/node/types.cjs.map +2 -2
- package/dist/types/src/SheetPlugin.d.ts.map +1 -1
- package/dist/types/src/components/CellEditor/CellEditor.d.ts +14 -0
- package/dist/types/src/components/CellEditor/CellEditor.d.ts.map +1 -0
- package/dist/types/src/components/{GridSheet/SheetCellEditor.stories.d.ts → CellEditor/CellEditor.stories.d.ts} +4 -4
- package/dist/types/src/components/CellEditor/CellEditor.stories.d.ts.map +1 -0
- package/dist/types/src/{extensions/editor → components/CellEditor}/extension.d.ts +1 -1
- package/dist/types/src/components/CellEditor/extension.d.ts.map +1 -0
- package/dist/types/src/components/CellEditor/extension.test.d.ts.map +1 -0
- package/dist/types/src/components/CellEditor/index.d.ts +3 -0
- package/dist/types/src/components/CellEditor/index.d.ts.map +1 -0
- package/dist/types/src/{graph/functions → components/ComputeGraph}/async-function.d.ts +5 -14
- package/dist/types/src/components/ComputeGraph/async-function.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/custom.d.ts +21 -0
- package/dist/types/src/components/ComputeGraph/custom.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/edge-function.d.ts +20 -0
- package/dist/types/src/components/ComputeGraph/edge-function.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/graph-context.d.ts +12 -0
- package/dist/types/src/components/ComputeGraph/graph-context.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/graph.browser.test.d.ts +2 -0
- package/dist/types/src/components/ComputeGraph/graph.browser.test.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/graph.d.ts +26 -0
- package/dist/types/src/components/ComputeGraph/graph.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/index.d.ts +3 -1
- package/dist/types/src/components/ComputeGraph/index.d.ts.map +1 -1
- package/dist/types/src/components/Sheet/Sheet.d.ts +55 -0
- package/dist/types/src/components/Sheet/Sheet.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/Sheet.stories.d.ts +54 -0
- package/dist/types/src/components/Sheet/Sheet.stories.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/formatting.d.ts +14 -0
- package/dist/types/src/components/Sheet/formatting.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/grid.d.ts +52 -0
- package/dist/types/src/components/Sheet/grid.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/index.d.ts +2 -0
- package/dist/types/src/components/Sheet/index.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/nav.d.ts +29 -0
- package/dist/types/src/components/Sheet/nav.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/sheet-context.d.ts +25 -0
- package/dist/types/src/components/Sheet/sheet-context.d.ts.map +1 -0
- package/dist/types/src/components/Sheet/util.d.ts +18 -0
- package/dist/types/src/components/Sheet/util.d.ts.map +1 -0
- package/dist/types/src/components/SheetContainer.d.ts +9 -0
- package/dist/types/src/components/SheetContainer.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +9 -33
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts +15 -19
- package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/common.d.ts +20 -0
- package/dist/types/src/components/Toolbar/common.d.ts.map +1 -0
- package/dist/types/src/components/index.d.ts +2 -3
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +9 -3
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/{graph/functions/function-defs.d.ts → model/functions.d.ts} +1 -1
- package/dist/types/src/model/functions.d.ts.map +1 -0
- package/dist/types/src/model/index.d.ts +3 -2
- package/dist/types/src/model/index.d.ts.map +1 -1
- package/dist/types/src/model/model.browser.test.d.ts +2 -0
- package/dist/types/src/model/model.browser.test.d.ts.map +1 -0
- package/dist/types/src/model/{sheet-model.d.ts → model.d.ts} +67 -13
- package/dist/types/src/model/model.d.ts.map +1 -0
- package/dist/types/src/{defs → model}/types.d.ts +3 -8
- package/dist/types/src/model/types.d.ts.map +1 -0
- package/dist/types/src/model/types.test.d.ts.map +1 -0
- package/dist/types/src/model/util.d.ts +15 -0
- package/dist/types/src/model/util.d.ts.map +1 -0
- package/dist/types/src/testing.d.ts +9 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +12 -17
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +40 -125
- package/dist/types/src/types.d.ts.map +1 -1
- package/package.json +52 -58
- package/src/SheetPlugin.tsx +74 -52
- package/src/components/{GridSheet/SheetCellEditor.stories.tsx → CellEditor/CellEditor.stories.tsx} +8 -8
- package/src/components/CellEditor/CellEditor.tsx +113 -0
- package/src/{extensions/editor → components/CellEditor}/extension.test.ts +6 -4
- package/src/{extensions/editor → components/CellEditor}/extension.ts +6 -5
- package/src/{extensions/editor → components/CellEditor}/index.ts +1 -0
- package/src/{graph/functions → components/ComputeGraph}/async-function.ts +15 -25
- package/src/{graph/testing/test-plugin.ts → components/ComputeGraph/custom.ts} +14 -44
- package/src/{graph/functions → components/ComputeGraph}/edge-function.ts +14 -16
- package/src/components/ComputeGraph/graph-context.tsx +50 -0
- package/src/components/ComputeGraph/graph.browser.test.ts +50 -0
- package/src/components/ComputeGraph/graph.ts +62 -0
- package/src/components/ComputeGraph/index.ts +3 -1
- package/src/components/Sheet/Sheet.stories.tsx +287 -0
- package/src/components/Sheet/Sheet.tsx +1160 -0
- package/src/components/Sheet/formatting.ts +106 -0
- package/src/components/Sheet/grid.ts +191 -0
- package/src/{testing → components/Sheet}/index.ts +1 -1
- package/src/components/Sheet/nav.ts +157 -0
- package/src/components/Sheet/sheet-context.tsx +150 -0
- package/src/components/Sheet/util.ts +56 -0
- package/src/components/SheetContainer.tsx +34 -0
- package/src/components/Toolbar/Toolbar.tsx +112 -242
- package/src/components/Toolbar/common.tsx +72 -0
- package/src/components/index.ts +0 -2
- package/src/meta.tsx +18 -0
- package/src/model/index.ts +3 -2
- package/src/model/model.browser.test.ts +100 -0
- package/src/model/model.ts +550 -0
- package/src/{defs → model}/types.test.ts +9 -8
- package/src/{defs → model}/types.ts +14 -24
- package/src/model/util.ts +36 -0
- package/src/testing.ts +50 -0
- package/src/translations.ts +1 -6
- package/src/types.ts +47 -40
- package/dist/lib/browser/SheetContainer-RVRACGCZ.mjs +0 -290
- package/dist/lib/browser/SheetContainer-RVRACGCZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-BWN5DZWZ.mjs +0 -74
- package/dist/lib/browser/chunk-BWN5DZWZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-D3QTX46O.mjs +0 -14
- package/dist/lib/browser/chunk-D3QTX46O.mjs.map +0 -7
- package/dist/lib/browser/chunk-GSV5QNLD.mjs +0 -2966
- package/dist/lib/browser/chunk-GSV5QNLD.mjs.map +0 -7
- package/dist/lib/browser/chunk-HOG37RYS.mjs +0 -1528
- package/dist/lib/browser/chunk-HOG37RYS.mjs.map +0 -7
- package/dist/lib/browser/graph-M4IQ76QX.mjs +0 -33
- package/dist/lib/browser/graph-M4IQ76QX.mjs.map +0 -7
- package/dist/lib/node/SheetContainer-J7XROAMN.cjs +0 -300
- package/dist/lib/node/SheetContainer-J7XROAMN.cjs.map +0 -7
- package/dist/lib/node/chunk-5XPK2V4A.cjs.map +0 -7
- package/dist/lib/node/chunk-AXQZA2YS.cjs +0 -1527
- package/dist/lib/node/chunk-AXQZA2YS.cjs.map +0 -7
- package/dist/lib/node/chunk-NZARD7UP.cjs.map +0 -7
- package/dist/lib/node/chunk-QIFIGEKV.cjs +0 -37
- package/dist/lib/node/chunk-QIFIGEKV.cjs.map +0 -7
- package/dist/lib/node/graph-Q3N2X26H.cjs +0 -55
- package/dist/lib/node/graph-Q3N2X26H.cjs.map +0 -7
- package/dist/lib/node-esm/SheetContainer-YWQVKHQB.mjs +0 -291
- package/dist/lib/node-esm/SheetContainer-YWQVKHQB.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5WPZCXNS.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-BPXXIAOQ.mjs +0 -1529
- package/dist/lib/node-esm/chunk-BPXXIAOQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-VCYJWE3O.mjs +0 -16
- package/dist/lib/node-esm/chunk-VCYJWE3O.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WFDTY3IC.mjs +0 -75
- package/dist/lib/node-esm/chunk-WFDTY3IC.mjs.map +0 -7
- package/dist/lib/node-esm/graph-SMPUMOV2.mjs +0 -34
- package/dist/lib/node-esm/graph-SMPUMOV2.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -280
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/meta.mjs +0 -10
- package/dist/lib/node-esm/meta.mjs.map +0 -7
- package/dist/lib/node-esm/types.mjs +0 -17
- package/dist/lib/node-esm/types.mjs.map +0 -7
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts +0 -11
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts.map +0 -1
- package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts +0 -3
- package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts.map +0 -1
- package/dist/types/src/components/FunctionEditor/index.d.ts +0 -2
- package/dist/types/src/components/FunctionEditor/index.d.ts.map +0 -1
- package/dist/types/src/components/GridSheet/GridSheet.d.ts +0 -3
- package/dist/types/src/components/GridSheet/GridSheet.d.ts.map +0 -1
- package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts +0 -9
- package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts.map +0 -1
- package/dist/types/src/components/GridSheet/SheetCellEditor.stories.d.ts.map +0 -1
- package/dist/types/src/components/GridSheet/index.d.ts +0 -2
- package/dist/types/src/components/GridSheet/index.d.ts.map +0 -1
- package/dist/types/src/components/GridSheet/util.d.ts +0 -16
- package/dist/types/src/components/GridSheet/util.d.ts.map +0 -1
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts +0 -6
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts.map +0 -1
- package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts +0 -11
- package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/SheetContainer/index.d.ts +0 -3
- package/dist/types/src/components/SheetContainer/index.d.ts.map +0 -1
- package/dist/types/src/components/SheetContext/SheetContext.d.ts +0 -26
- package/dist/types/src/components/SheetContext/SheetContext.d.ts.map +0 -1
- package/dist/types/src/components/SheetContext/index.d.ts +0 -2
- package/dist/types/src/components/SheetContext/index.d.ts.map +0 -1
- package/dist/types/src/defs/index.d.ts +0 -4
- package/dist/types/src/defs/index.d.ts.map +0 -1
- package/dist/types/src/defs/sheet-range-types.d.ts +0 -13
- package/dist/types/src/defs/sheet-range-types.d.ts.map +0 -1
- package/dist/types/src/defs/types.d.ts.map +0 -1
- package/dist/types/src/defs/types.test.d.ts.map +0 -1
- package/dist/types/src/defs/util.d.ts +0 -43
- package/dist/types/src/defs/util.d.ts.map +0 -1
- package/dist/types/src/extensions/compute.d.ts +0 -6
- package/dist/types/src/extensions/compute.d.ts.map +0 -1
- package/dist/types/src/extensions/compute.stories.d.ts +0 -26
- package/dist/types/src/extensions/compute.stories.d.ts.map +0 -1
- package/dist/types/src/extensions/editor/extension.d.ts.map +0 -1
- package/dist/types/src/extensions/editor/extension.test.d.ts.map +0 -1
- package/dist/types/src/extensions/editor/index.d.ts +0 -2
- package/dist/types/src/extensions/editor/index.d.ts.map +0 -1
- package/dist/types/src/extensions/index.d.ts +0 -3
- package/dist/types/src/extensions/index.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph-registry.d.ts +0 -34
- package/dist/types/src/graph/compute-graph-registry.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.d.ts +0 -64
- package/dist/types/src/graph/compute-graph.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.stories.d.ts +0 -10
- package/dist/types/src/graph/compute-graph.stories.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.test.d.ts +0 -2
- package/dist/types/src/graph/compute-graph.test.d.ts.map +0 -1
- package/dist/types/src/graph/compute-node.d.ts +0 -26
- package/dist/types/src/graph/compute-node.d.ts.map +0 -1
- package/dist/types/src/graph/functions/async-function.d.ts.map +0 -1
- package/dist/types/src/graph/functions/edge-function.d.ts +0 -21
- package/dist/types/src/graph/functions/edge-function.d.ts.map +0 -1
- package/dist/types/src/graph/functions/function-defs.d.ts.map +0 -1
- package/dist/types/src/graph/functions/index.d.ts +0 -4
- package/dist/types/src/graph/functions/index.d.ts.map +0 -1
- package/dist/types/src/graph/hyperformula.test.d.ts +0 -2
- package/dist/types/src/graph/hyperformula.test.d.ts.map +0 -1
- package/dist/types/src/graph/index.d.ts +0 -5
- package/dist/types/src/graph/index.d.ts.map +0 -1
- package/dist/types/src/graph/testing/index.d.ts +0 -3
- package/dist/types/src/graph/testing/index.d.ts.map +0 -1
- package/dist/types/src/graph/testing/test-builder.d.ts +0 -15
- package/dist/types/src/graph/testing/test-builder.d.ts.map +0 -1
- package/dist/types/src/graph/testing/test-plugin.d.ts +0 -36
- package/dist/types/src/graph/testing/test-plugin.d.ts.map +0 -1
- package/dist/types/src/graph/util.d.ts +0 -2
- package/dist/types/src/graph/util.d.ts.map +0 -1
- package/dist/types/src/hooks/hooks.stories.d.ts +0 -11
- package/dist/types/src/hooks/hooks.stories.d.ts.map +0 -1
- package/dist/types/src/hooks/index.d.ts +0 -4
- package/dist/types/src/hooks/index.d.ts.map +0 -1
- package/dist/types/src/hooks/threads.d.ts +0 -8
- package/dist/types/src/hooks/threads.d.ts.map +0 -1
- package/dist/types/src/hooks/useComputeGraph.d.ts +0 -7
- package/dist/types/src/hooks/useComputeGraph.d.ts.map +0 -1
- package/dist/types/src/hooks/useSheetModel.d.ts +0 -8
- package/dist/types/src/hooks/useSheetModel.d.ts.map +0 -1
- package/dist/types/src/model/decorations.d.ts +0 -25
- package/dist/types/src/model/decorations.d.ts.map +0 -1
- package/dist/types/src/model/sheet-model.d.ts.map +0 -1
- package/dist/types/src/model/sheet-model.test.d.ts +0 -2
- package/dist/types/src/model/sheet-model.test.d.ts.map +0 -1
- package/dist/types/src/sanity.test.d.ts +0 -2
- package/dist/types/src/sanity.test.d.ts.map +0 -1
- package/dist/types/src/testing/index.d.ts +0 -2
- package/dist/types/src/testing/index.d.ts.map +0 -1
- package/dist/types/src/testing/testing.d.ts +0 -8
- package/dist/types/src/testing/testing.d.ts.map +0 -1
- package/dist/vendor/hyperformula.mjs +0 -37145
- package/src/components/ComputeGraph/ComputeGraphContextProvider.tsx +0 -20
- package/src/components/FunctionEditor/FunctionEditor.tsx +0 -45
- package/src/components/FunctionEditor/index.ts +0 -5
- package/src/components/GridSheet/GridSheet.stories.tsx +0 -41
- package/src/components/GridSheet/GridSheet.tsx +0 -163
- package/src/components/GridSheet/index.ts +0 -5
- package/src/components/GridSheet/util.ts +0 -158
- package/src/components/SheetContainer/SheetContainer.stories.tsx +0 -40
- package/src/components/SheetContainer/SheetContainer.tsx +0 -27
- package/src/components/SheetContainer/index.ts +0 -7
- package/src/components/SheetContext/SheetContext.tsx +0 -104
- package/src/components/SheetContext/index.ts +0 -5
- package/src/defs/index.ts +0 -7
- package/src/defs/sheet-range-types.ts +0 -46
- package/src/defs/util.ts +0 -151
- package/src/extensions/compute.stories.tsx +0 -151
- package/src/extensions/compute.ts +0 -147
- package/src/extensions/index.ts +0 -6
- package/src/graph/compute-graph-registry.ts +0 -90
- package/src/graph/compute-graph.stories.tsx +0 -93
- package/src/graph/compute-graph.test.ts +0 -87
- package/src/graph/compute-graph.ts +0 -242
- package/src/graph/compute-node.ts +0 -63
- package/src/graph/functions/index.ts +0 -7
- package/src/graph/hyperformula.test.ts +0 -14
- package/src/graph/index.ts +0 -8
- package/src/graph/testing/index.ts +0 -6
- package/src/graph/testing/test-builder.ts +0 -54
- package/src/graph/util.ts +0 -8
- package/src/hooks/hooks.stories.tsx +0 -50
- package/src/hooks/index.ts +0 -7
- package/src/hooks/threads.ts +0 -147
- package/src/hooks/useComputeGraph.ts +0 -28
- package/src/hooks/useSheetModel.ts +0 -40
- package/src/meta.ts +0 -14
- package/src/model/decorations.ts +0 -64
- package/src/model/sheet-model.test.ts +0 -57
- package/src/model/sheet-model.ts +0 -418
- package/src/sanity.test.ts +0 -40
- package/src/testing/testing.tsx +0 -68
- /package/dist/types/src/{extensions/editor → components/CellEditor}/extension.test.d.ts +0 -0
- /package/dist/types/src/{defs → model}/types.test.d.ts +0 -0
- /package/src/{graph/functions/function-defs.ts → model/functions.ts} +0 -0
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type CellValue } from 'hyperformula';
|
|
6
|
-
import { afterEach, beforeEach, describe, expect, test } from 'vitest';
|
|
7
|
-
|
|
8
|
-
import { Trigger } from '@dxos/async';
|
|
9
|
-
import { create, fullyQualifiedId } from '@dxos/client/echo';
|
|
10
|
-
import { FunctionType } from '@dxos/plugin-script/types';
|
|
11
|
-
|
|
12
|
-
import { DetailedCellError } from '#hyperformula';
|
|
13
|
-
import { TestBuilder } from './testing';
|
|
14
|
-
|
|
15
|
-
describe('ComputeGraph', () => {
|
|
16
|
-
let testBuilder: TestBuilder;
|
|
17
|
-
beforeEach(async () => {
|
|
18
|
-
testBuilder = new TestBuilder({ types: [FunctionType] });
|
|
19
|
-
await testBuilder.open();
|
|
20
|
-
});
|
|
21
|
-
afterEach(async () => {
|
|
22
|
-
await testBuilder.close();
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test('map functions', async () => {
|
|
26
|
-
const space = await testBuilder.client.spaces.create();
|
|
27
|
-
const graph = testBuilder.registry.createGraph(space);
|
|
28
|
-
await graph.open();
|
|
29
|
-
|
|
30
|
-
// Create script.
|
|
31
|
-
const trigger = new Trigger();
|
|
32
|
-
graph.update.once(() => trigger.wake());
|
|
33
|
-
const functionObject = space.db.add(create(FunctionType, { version: 1, binding: 'TEST' }));
|
|
34
|
-
await trigger.wait();
|
|
35
|
-
const functions = graph.getFunctions({ echo: true });
|
|
36
|
-
expect(functions).to.toHaveLength(1);
|
|
37
|
-
|
|
38
|
-
const id = graph.mapFunctionBindingToId('TEST()');
|
|
39
|
-
expect(id).to.eq(`${fullyQualifiedId(functionObject)}()`);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
test('cross-node references', async () => {
|
|
43
|
-
const space = await testBuilder.client.spaces.create();
|
|
44
|
-
const graph = testBuilder.registry.createGraph(space);
|
|
45
|
-
|
|
46
|
-
// Create nodes.
|
|
47
|
-
const node1 = await graph.getOrCreateNode('node-1').open();
|
|
48
|
-
const node2 = await graph.getOrCreateNode('node-2').open();
|
|
49
|
-
expect(graph.hf.getSheetNames()).to.toHaveLength(2);
|
|
50
|
-
|
|
51
|
-
{
|
|
52
|
-
node1.graph.hf.setCellContents({ sheet: node1.sheetId, row: 0, col: 0 }, [[100, 200, 300, '=SUM(A1:C1)']]);
|
|
53
|
-
node2.graph.hf.setCellContents({ sheet: node2.sheetId, row: 0, col: 0 }, "='node-1'!D1");
|
|
54
|
-
const value1 = node1.graph.hf.getCellValue({ sheet: node1.sheetId, col: 3, row: 0 });
|
|
55
|
-
const value2 = node2.graph.hf.getCellValue({ sheet: node2.sheetId, col: 0, row: 0 });
|
|
56
|
-
expect(value1).to.eq(value2);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
// Get updated event.
|
|
60
|
-
const trigger = new Trigger<CellValue>();
|
|
61
|
-
node2.update.on(({ change }) => {
|
|
62
|
-
const value = node2.graph.hf.getCellValue({ sheet: node2.sheetId, col: 0, row: 0 });
|
|
63
|
-
expect(value).to.eq(change?.newValue);
|
|
64
|
-
trigger.wake(value);
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
{
|
|
68
|
-
node1.graph.hf.setCellContents({ sheet: node1.sheetId, row: 0, col: 0 }, 400);
|
|
69
|
-
const value1 = node1.graph.hf.getCellValue({ sheet: node1.sheetId, col: 3, row: 0 });
|
|
70
|
-
const value2 = await trigger.wait();
|
|
71
|
-
expect(value1).to.eq(value2);
|
|
72
|
-
}
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
// TODO(burdon): Dynamically load node/model based on dependencies.
|
|
76
|
-
// - Create dependency then close model.
|
|
77
|
-
test('dynamic loading', async () => {
|
|
78
|
-
const space = await testBuilder.client.spaces.create();
|
|
79
|
-
const graph = testBuilder.registry.createGraph(space);
|
|
80
|
-
|
|
81
|
-
const node1 = await graph.getOrCreateNode('node-1').open();
|
|
82
|
-
node1.graph.hf.setCellContents({ sheet: node1.sheetId, row: 0, col: 0 }, "='node-2'!A1");
|
|
83
|
-
const value1 = node1.graph.hf.getCellValue({ sheet: node1.sheetId, col: 0, row: 0 });
|
|
84
|
-
expect(value1).to.be.instanceof(DetailedCellError);
|
|
85
|
-
expect((value1 as DetailedCellError).type).to.eq('REF');
|
|
86
|
-
});
|
|
87
|
-
});
|
|
@@ -1,242 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Listeners } from 'hyperformula/typings/Emitter';
|
|
6
|
-
|
|
7
|
-
import { Event } from '@dxos/async';
|
|
8
|
-
import { type Space, Filter, fullyQualifiedId } from '@dxos/client/echo';
|
|
9
|
-
import { Resource } from '@dxos/context';
|
|
10
|
-
import { getTypename } from '@dxos/echo-schema';
|
|
11
|
-
import { invariant } from '@dxos/invariant';
|
|
12
|
-
import { PublicKey } from '@dxos/keys';
|
|
13
|
-
import { log } from '@dxos/log';
|
|
14
|
-
import { FunctionType } from '@dxos/plugin-script/types';
|
|
15
|
-
import { nonNullable } from '@dxos/util';
|
|
16
|
-
|
|
17
|
-
import { ExportedCellChange, type HyperFormula } from '#hyperformula';
|
|
18
|
-
import { ComputeNode } from './compute-node';
|
|
19
|
-
import {
|
|
20
|
-
defaultFunctions,
|
|
21
|
-
FunctionContext,
|
|
22
|
-
type FunctionContextOptions,
|
|
23
|
-
type FunctionDefinition,
|
|
24
|
-
EDGE_FUNCTION_NAME,
|
|
25
|
-
} from './functions';
|
|
26
|
-
|
|
27
|
-
// TODO(wittjosiah): Factor out.
|
|
28
|
-
const OBJECT_ID_LENGTH = 60; // 33 (space id) + 1 (separator) + 26 (object id).
|
|
29
|
-
|
|
30
|
-
// TODO(burdon): Factory.
|
|
31
|
-
// export type ComputeNodeGenerator = <T>(obj: T) => ComputeNode;
|
|
32
|
-
|
|
33
|
-
type ObjectRef = { type: string; id: string };
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Marker for sheets that are managed by an ECHO object.
|
|
37
|
-
* Sheet ID: `dxos.org/type/SheetType@1234`
|
|
38
|
-
*/
|
|
39
|
-
export const createSheetName = ({ type, id }: ObjectRef) => `${type}@${id}`;
|
|
40
|
-
export const parseSheetName = (name: string): Partial<ObjectRef> => {
|
|
41
|
-
const [type, id] = name.split('@');
|
|
42
|
-
return id ? { type, id } : { id: type };
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
export type ComputeGraphEvent = 'functionsUpdated';
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Per-space compute and dependency graph.
|
|
49
|
-
* Consists of multiple ComputeNode (corresponding to a HyperFormula sheet).
|
|
50
|
-
* Manages the set of custom functions.
|
|
51
|
-
* HyperFormula manages the dependency graph.
|
|
52
|
-
*/
|
|
53
|
-
export class ComputeGraph extends Resource {
|
|
54
|
-
public readonly id = `graph-${PublicKey.random().truncate()}`;
|
|
55
|
-
|
|
56
|
-
// Map of nodes indexed by sheet number.
|
|
57
|
-
private readonly _nodes = new Map<number, ComputeNode>();
|
|
58
|
-
|
|
59
|
-
// Cached function objects.
|
|
60
|
-
private _remoteFunctions: FunctionType[] = [];
|
|
61
|
-
|
|
62
|
-
public readonly update = new Event<{ type: ComputeGraphEvent }>();
|
|
63
|
-
|
|
64
|
-
// The context is passed to all functions.
|
|
65
|
-
public readonly context = new FunctionContext(this._hf, this._space, this._options);
|
|
66
|
-
|
|
67
|
-
constructor(
|
|
68
|
-
private readonly _hf: HyperFormula,
|
|
69
|
-
private readonly _space?: Space,
|
|
70
|
-
private readonly _options?: Partial<FunctionContextOptions>,
|
|
71
|
-
) {
|
|
72
|
-
super();
|
|
73
|
-
this._hf.updateConfig({ context: this.context });
|
|
74
|
-
// TODO(burdon): If debounce then aggregate changes.
|
|
75
|
-
const onValuesUpdate: Listeners['valuesUpdated'] = (changes) => {
|
|
76
|
-
for (const change of changes) {
|
|
77
|
-
if (change instanceof ExportedCellChange) {
|
|
78
|
-
const { sheet } = change;
|
|
79
|
-
const node = this._nodes.get(sheet);
|
|
80
|
-
if (node) {
|
|
81
|
-
node.update.emit({ type: 'valuesUpdated', change });
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
this._hf.on('valuesUpdated', onValuesUpdate);
|
|
88
|
-
this._ctx.onDispose(() => this._hf.off('valuesUpdated', onValuesUpdate));
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
get hf() {
|
|
92
|
-
return this._hf;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
getFunctions(
|
|
96
|
-
{ standard, echo }: { standard?: boolean; echo?: boolean } = { standard: true, echo: true },
|
|
97
|
-
): FunctionDefinition[] {
|
|
98
|
-
return [
|
|
99
|
-
...(standard
|
|
100
|
-
? this._hf
|
|
101
|
-
.getRegisteredFunctionNames()
|
|
102
|
-
.map((name) => defaultFunctions.find((fn) => fn.name === name) ?? { name })
|
|
103
|
-
: []),
|
|
104
|
-
...(echo ? this._remoteFunctions.map((fn) => ({ name: fn.binding! })) : []),
|
|
105
|
-
];
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Get or create cell representing a sheet.
|
|
110
|
-
*/
|
|
111
|
-
// TODO(burdon): Async (open node).
|
|
112
|
-
// The graph should be an extensible factory that plugins extend with model constructors.
|
|
113
|
-
// This would enable on-the-fly instantiation of new models when then are referenced.
|
|
114
|
-
// E.g., Cross-object reference would be stored as "ObjectId!A1"
|
|
115
|
-
// The graph would then load the object and create a ComputeNode (model) of the appropriate type.
|
|
116
|
-
getOrCreateNode(name: string): ComputeNode {
|
|
117
|
-
invariant(name.length);
|
|
118
|
-
if (!this._hf.doesSheetExist(name)) {
|
|
119
|
-
log.info('created node', { space: this._space?.id, sheet: name });
|
|
120
|
-
this._hf.addSheet(name);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
const sheetId = this._hf.getSheetId(name);
|
|
124
|
-
invariant(sheetId !== undefined);
|
|
125
|
-
|
|
126
|
-
const node = new ComputeNode(this, sheetId);
|
|
127
|
-
this._nodes.set(sheetId, node);
|
|
128
|
-
return node;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* Map bound value to custom function invocation.
|
|
133
|
-
* E.g., "HELLO(...args)" => "EDGE("HELLO", ...args)".
|
|
134
|
-
*/
|
|
135
|
-
mapFormulaToNative(formula: string): string {
|
|
136
|
-
return (
|
|
137
|
-
formula
|
|
138
|
-
//
|
|
139
|
-
// Map cross-sheet references by name onto sheet stored by ECHO object/model.
|
|
140
|
-
// Example: "Test Sheet"!A0 => "dxos.org/type/SheetType@1234"!A0
|
|
141
|
-
// https://hyperformula.handsontable.com/guide/cell-references.html#cell-references
|
|
142
|
-
//
|
|
143
|
-
.replace(/['"]?([ \w]+)['"]?!/, (_match, name) => {
|
|
144
|
-
if (name) {
|
|
145
|
-
// TODO(burdon): Cache map.
|
|
146
|
-
const objects = this._hf
|
|
147
|
-
.getSheetNames()
|
|
148
|
-
.map((name) => {
|
|
149
|
-
const { type, id } = parseSheetName(name);
|
|
150
|
-
return type && id ? this._space?.db.getObjectById(id) : undefined;
|
|
151
|
-
})
|
|
152
|
-
.filter(nonNullable);
|
|
153
|
-
|
|
154
|
-
for (const obj of objects) {
|
|
155
|
-
if (obj.name === name) {
|
|
156
|
-
const type = getTypename(obj)!;
|
|
157
|
-
// NOTE: Names must be single quoted.
|
|
158
|
-
return `'${createSheetName({ type, id: obj.id })}'!`;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
return `${name}!`;
|
|
164
|
-
})
|
|
165
|
-
|
|
166
|
-
//
|
|
167
|
-
// Map remote function references (i.e., to remote DX function invocation).
|
|
168
|
-
//
|
|
169
|
-
.replace(/(\w+)\((.*)\)/g, (match, binding, args) => {
|
|
170
|
-
const fn = this._remoteFunctions.find((fn) => fn.binding === binding);
|
|
171
|
-
if (!fn) {
|
|
172
|
-
return match;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
if (args.trim() === '') {
|
|
176
|
-
return `${EDGE_FUNCTION_NAME}("${binding}")`;
|
|
177
|
-
} else {
|
|
178
|
-
return `${EDGE_FUNCTION_NAME}("${binding}", ${args})`;
|
|
179
|
-
}
|
|
180
|
-
})
|
|
181
|
-
);
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* Map from binding to fully qualified ECHO ID (to store).
|
|
186
|
-
* E.g., HELLO() => spaceId:objectId()
|
|
187
|
-
*/
|
|
188
|
-
mapFunctionBindingToId(formula: string) {
|
|
189
|
-
return formula.replace(/(\w+)\((.*)\)/g, (match, binding, args) => {
|
|
190
|
-
if (binding === EDGE_FUNCTION_NAME || defaultFunctions.find((fn) => fn.name === binding)) {
|
|
191
|
-
return match;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
const fn = this._remoteFunctions.find((fn) => fn.binding === binding);
|
|
195
|
-
if (fn) {
|
|
196
|
-
const id = fullyQualifiedId(fn);
|
|
197
|
-
return `${id}(${args})`;
|
|
198
|
-
} else {
|
|
199
|
-
return match;
|
|
200
|
-
}
|
|
201
|
-
});
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
/**
|
|
205
|
-
* Map from fully qualified ECHO ID to binding (from store).
|
|
206
|
-
* E.g., spaceId:objectId() => HELLO()
|
|
207
|
-
*/
|
|
208
|
-
mapFunctionBindingFromId(formula: string) {
|
|
209
|
-
return formula.replace(/(\w+):([a-zA-Z0-9]+)\((.*)\)/g, (match, spaceId, objectId, args) => {
|
|
210
|
-
const id = `${spaceId}:${objectId}`;
|
|
211
|
-
if (id.length !== OBJECT_ID_LENGTH) {
|
|
212
|
-
return match;
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
const fn = this._remoteFunctions.find((fn) => fullyQualifiedId(fn) === id);
|
|
216
|
-
if (fn?.binding) {
|
|
217
|
-
return `${fn.binding}(${args})`;
|
|
218
|
-
} else {
|
|
219
|
-
return match;
|
|
220
|
-
}
|
|
221
|
-
});
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
protected override async _open() {
|
|
225
|
-
if (this._space) {
|
|
226
|
-
// Subscribe to remote function definitions.
|
|
227
|
-
const query = this._space.db.query(Filter.schema(FunctionType));
|
|
228
|
-
const unsubscribe = query.subscribe(({ objects }) => {
|
|
229
|
-
this._remoteFunctions = objects.filter(({ binding }) => binding);
|
|
230
|
-
this.update.emit({ type: 'functionsUpdated' });
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
this._ctx.onDispose(unsubscribe);
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
protected override async _close() {
|
|
238
|
-
for (const node of this._nodes.values()) {
|
|
239
|
-
await node.close();
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
}
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Listeners } from 'hyperformula/typings/Emitter';
|
|
6
|
-
import { type ExportedCellChange } from 'hyperformula/typings/Exporter';
|
|
7
|
-
|
|
8
|
-
import { Event } from '@dxos/async';
|
|
9
|
-
import { Resource } from '@dxos/context';
|
|
10
|
-
|
|
11
|
-
import { DetailedCellError } from '#hyperformula';
|
|
12
|
-
import { type ComputeGraph } from './compute-graph';
|
|
13
|
-
import { type CellAddress } from '../defs';
|
|
14
|
-
import { type CellScalarValue } from '../types';
|
|
15
|
-
|
|
16
|
-
export type ComputeNodeEvent = {
|
|
17
|
-
type: keyof Listeners;
|
|
18
|
-
change?: ExportedCellChange;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Individual "sheet" (typically corresponds to an ECHO object).
|
|
23
|
-
*/
|
|
24
|
-
// TODO(burdon): Factor out common HF wrapper from from SheetModel.
|
|
25
|
-
export class ComputeNode extends Resource {
|
|
26
|
-
public readonly update = new Event<ComputeNodeEvent>();
|
|
27
|
-
|
|
28
|
-
constructor(
|
|
29
|
-
private readonly _graph: ComputeGraph,
|
|
30
|
-
public readonly sheetId: number,
|
|
31
|
-
) {
|
|
32
|
-
super();
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
get graph() {
|
|
36
|
-
return this._graph;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
clear() {
|
|
40
|
-
this._graph.hf.clearSheet(this.sheetId);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
getValue(cell: CellAddress): CellScalarValue {
|
|
44
|
-
const value = this._graph.hf.getCellValue({ sheet: this.sheetId, row: cell.row, col: cell.col });
|
|
45
|
-
if (value instanceof DetailedCellError) {
|
|
46
|
-
return null;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return value;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
setValue(cell: CellAddress, value: CellScalarValue) {
|
|
53
|
-
const mappedValue =
|
|
54
|
-
typeof value === 'string' && value.charAt(0) === '=' ? this._graph.mapFormulaToNative(value) : value;
|
|
55
|
-
this._graph.hf.setCellContents({ sheet: this.sheetId, row: cell.row, col: cell.col }, [[mappedValue]]);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// TODO(burdon): Load data into sheet.
|
|
59
|
-
protected override async _open() {
|
|
60
|
-
// const unsubscribe = this._graph.update.on(this.update.emit);
|
|
61
|
-
// this._ctx.onDispose(unsubscribe);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { describe, test, expect } from 'vitest';
|
|
6
|
-
|
|
7
|
-
import { HyperFormula } from '#hyperformula';
|
|
8
|
-
|
|
9
|
-
describe('hyperformula', () => {
|
|
10
|
-
test('sanity test', async () => {
|
|
11
|
-
const hf = HyperFormula.buildEmpty({ licenseKey: 'gpl-v3' });
|
|
12
|
-
expect(hf).to.exist;
|
|
13
|
-
});
|
|
14
|
-
});
|
package/src/graph/index.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Client, type ClientOptions } from '@dxos/client';
|
|
6
|
-
import { type Context, Resource } from '@dxos/context';
|
|
7
|
-
import { invariant } from '@dxos/invariant';
|
|
8
|
-
|
|
9
|
-
import { type ComputeGraphOptions, ComputeGraphRegistry } from '../compute-graph-registry';
|
|
10
|
-
|
|
11
|
-
export type TestBuilderOptions = ClientOptions & ComputeGraphOptions;
|
|
12
|
-
|
|
13
|
-
// TODO(burdon): Reconcile with @dxos/client/testing.
|
|
14
|
-
export class TestBuilder extends Resource {
|
|
15
|
-
private _client?: Client;
|
|
16
|
-
private _registry?: ComputeGraphRegistry;
|
|
17
|
-
|
|
18
|
-
constructor(private readonly _options: TestBuilderOptions = {}) {
|
|
19
|
-
super();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
get ctx(): Context {
|
|
23
|
-
return this._ctx;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
get client(): Client {
|
|
27
|
-
invariant(this._client);
|
|
28
|
-
return this._client;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
get registry(): ComputeGraphRegistry {
|
|
32
|
-
invariant(this._registry);
|
|
33
|
-
return this._registry;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
override async _open() {
|
|
37
|
-
const client = new Client(this._options);
|
|
38
|
-
await client.initialize();
|
|
39
|
-
await client.halo.createIdentity();
|
|
40
|
-
this._client = client;
|
|
41
|
-
this._ctx.onDispose(async () => {
|
|
42
|
-
await client.destroy();
|
|
43
|
-
this._client = undefined;
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
const registry = new ComputeGraphRegistry(this._options);
|
|
47
|
-
await registry.open();
|
|
48
|
-
this._registry = registry;
|
|
49
|
-
this._ctx.onDispose(async () => {
|
|
50
|
-
await registry.close();
|
|
51
|
-
this._registry = undefined;
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
}
|
package/src/graph/util.ts
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import '@dxos-theme';
|
|
6
|
-
|
|
7
|
-
import React, { useEffect, useState } from 'react';
|
|
8
|
-
|
|
9
|
-
import { useSpace } from '@dxos/react-client/echo';
|
|
10
|
-
import { withClientProvider } from '@dxos/react-client/testing';
|
|
11
|
-
import { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';
|
|
12
|
-
import { withTheme } from '@dxos/storybook-utils';
|
|
13
|
-
|
|
14
|
-
import { ComputeGraphContextProvider } from '../components';
|
|
15
|
-
import { createSheet } from '../defs';
|
|
16
|
-
import { useComputeGraph, useSheetModel } from '../hooks';
|
|
17
|
-
import { withComputeGraphDecorator } from '../testing';
|
|
18
|
-
import { SheetType } from '../types';
|
|
19
|
-
|
|
20
|
-
const Story = () => {
|
|
21
|
-
const space = useSpace();
|
|
22
|
-
const graph = useComputeGraph(space);
|
|
23
|
-
const [sheet, setSheet] = useState<SheetType>();
|
|
24
|
-
const model = useSheetModel(graph, sheet);
|
|
25
|
-
useEffect(() => {
|
|
26
|
-
if (space) {
|
|
27
|
-
const sheet = space.db.add(createSheet());
|
|
28
|
-
setSheet(sheet);
|
|
29
|
-
}
|
|
30
|
-
}, [space]);
|
|
31
|
-
|
|
32
|
-
return (
|
|
33
|
-
<SyntaxHighlighter language='json'>
|
|
34
|
-
{JSON.stringify({ space: space?.id, graph: graph?.id, sheet: sheet?.id, model: model?.id }, null, 2)}
|
|
35
|
-
</SyntaxHighlighter>
|
|
36
|
-
);
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
export default {
|
|
40
|
-
title: 'plugin-sheet/hooks',
|
|
41
|
-
component: ComputeGraphContextProvider,
|
|
42
|
-
decorators: [
|
|
43
|
-
withClientProvider({ types: [SheetType], createIdentity: true, createSpace: true }),
|
|
44
|
-
withComputeGraphDecorator(),
|
|
45
|
-
withTheme,
|
|
46
|
-
],
|
|
47
|
-
render: (args: any) => <Story {...args} />,
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
export const Default = {};
|