@dxos/plugin-sheet 0.6.12 → 0.6.13-main.548ca8d
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-NDNIS44E.mjs +265 -0
- package/dist/lib/browser/SheetContainer-NDNIS44E.mjs.map +7 -0
- package/dist/lib/browser/chunk-AQSGDA4X.mjs +1614 -0
- package/dist/lib/browser/chunk-AQSGDA4X.mjs.map +7 -0
- package/dist/lib/browser/chunk-D3QTX46O.mjs +14 -0
- package/dist/lib/browser/chunk-D3QTX46O.mjs.map +7 -0
- package/dist/lib/browser/chunk-GKI67SEF.mjs +69 -0
- package/dist/lib/browser/chunk-GKI67SEF.mjs.map +7 -0
- package/dist/lib/browser/chunk-GSV5QNLD.mjs +2966 -0
- package/dist/lib/browser/chunk-GSV5QNLD.mjs.map +7 -0
- package/dist/lib/browser/graph-M4IQ76QX.mjs +33 -0
- package/dist/lib/browser/graph-M4IQ76QX.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +93 -62
- 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/types.mjs +4 -10
- package/dist/lib/node/SheetContainer-YSQGJD7K.cjs +276 -0
- package/dist/lib/node/SheetContainer-YSQGJD7K.cjs.map +7 -0
- package/dist/lib/node/{chunk-5KKJ4NPP.cjs → chunk-5XPK2V4A.cjs} +418 -678
- package/dist/lib/node/chunk-5XPK2V4A.cjs.map +7 -0
- package/dist/lib/node/chunk-6F43RV45.cjs +1610 -0
- package/dist/lib/node/chunk-6F43RV45.cjs.map +7 -0
- package/dist/lib/node/{chunk-DSYKOI4E.cjs → chunk-ER3PM7GD.cjs} +29 -45
- package/dist/lib/node/chunk-ER3PM7GD.cjs.map +7 -0
- package/dist/lib/node/chunk-QIFIGEKV.cjs +37 -0
- package/dist/lib/node/chunk-QIFIGEKV.cjs.map +7 -0
- package/dist/lib/node/graph-Q3N2X26H.cjs +55 -0
- package/dist/lib/node/graph-Q3N2X26H.cjs.map +7 -0
- package/dist/lib/node/index.cjs +105 -69
- 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/types.cjs +8 -14
- package/dist/lib/node/types.cjs.map +2 -2
- package/dist/lib/node-esm/SheetContainer-M7WRMZDU.mjs +266 -0
- package/dist/lib/node-esm/SheetContainer-M7WRMZDU.mjs.map +7 -0
- package/dist/lib/{browser/chunk-D5AGLXJP.mjs → node-esm/chunk-5WPZCXNS.mjs} +411 -678
- package/dist/lib/node-esm/chunk-5WPZCXNS.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-ELTFPX5B.mjs +1615 -0
- package/dist/lib/node-esm/chunk-ELTFPX5B.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-VCYJWE3O.mjs +16 -0
- package/dist/lib/node-esm/chunk-VCYJWE3O.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-ZVLLQ2PJ.mjs +70 -0
- package/dist/lib/node-esm/chunk-ZVLLQ2PJ.mjs.map +7 -0
- package/dist/lib/node-esm/graph-SMPUMOV2.mjs +34 -0
- package/dist/lib/node-esm/graph-SMPUMOV2.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +280 -0
- package/dist/lib/node-esm/index.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -0
- package/dist/lib/node-esm/meta.mjs +10 -0
- package/dist/lib/node-esm/meta.mjs.map +7 -0
- package/dist/lib/node-esm/types.mjs +17 -0
- package/dist/lib/node-esm/types.mjs.map +7 -0
- package/dist/types/src/SheetPlugin.d.ts.map +1 -1
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts +11 -0
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts.map +1 -0
- package/dist/types/src/components/ComputeGraph/index.d.ts +1 -3
- package/dist/types/src/components/ComputeGraph/index.d.ts.map +1 -1
- package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts +3 -0
- package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts.map +1 -0
- package/dist/types/src/components/FunctionEditor/index.d.ts +2 -0
- package/dist/types/src/components/FunctionEditor/index.d.ts.map +1 -0
- package/dist/types/src/components/GridSheet/GridSheet.d.ts +3 -0
- package/dist/types/src/components/GridSheet/GridSheet.d.ts.map +1 -0
- package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts +9 -0
- package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts.map +1 -0
- package/dist/types/src/components/{CellEditor/CellEditor.stories.d.ts → GridSheet/SheetCellEditor.stories.d.ts} +4 -4
- package/dist/types/src/components/GridSheet/SheetCellEditor.stories.d.ts.map +1 -0
- package/dist/types/src/components/GridSheet/index.d.ts +2 -0
- package/dist/types/src/components/GridSheet/index.d.ts.map +1 -0
- package/dist/types/src/components/GridSheet/util.d.ts +16 -0
- package/dist/types/src/components/GridSheet/util.d.ts.map +1 -0
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts +6 -0
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts.map +1 -0
- package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts +11 -0
- package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts.map +1 -0
- package/dist/types/src/components/SheetContainer/index.d.ts +3 -0
- package/dist/types/src/components/SheetContainer/index.d.ts.map +1 -0
- package/dist/types/src/components/SheetContext/SheetContext.d.ts +27 -0
- package/dist/types/src/components/SheetContext/SheetContext.d.ts.map +1 -0
- package/dist/types/src/components/SheetContext/index.d.ts +2 -0
- package/dist/types/src/components/SheetContext/index.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +36 -6
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts +19 -14
- package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +3 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/defs/index.d.ts +3 -0
- package/dist/types/src/defs/index.d.ts.map +1 -0
- package/dist/types/src/{model → defs}/types.d.ts +8 -3
- package/dist/types/src/defs/types.d.ts.map +1 -0
- package/dist/types/src/defs/types.test.d.ts.map +1 -0
- package/dist/types/src/defs/util.d.ts +43 -0
- package/dist/types/src/defs/util.d.ts.map +1 -0
- package/dist/types/src/extensions/compute.d.ts +6 -0
- package/dist/types/src/extensions/compute.d.ts.map +1 -0
- package/dist/types/src/extensions/compute.stories.d.ts +26 -0
- package/dist/types/src/extensions/compute.stories.d.ts.map +1 -0
- package/dist/types/src/{components/CellEditor → extensions/editor}/extension.d.ts +1 -1
- package/dist/types/src/extensions/editor/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/editor/extension.test.d.ts.map +1 -0
- package/dist/types/src/extensions/editor/index.d.ts +2 -0
- package/dist/types/src/extensions/editor/index.d.ts.map +1 -0
- package/dist/types/src/extensions/index.d.ts +3 -0
- package/dist/types/src/extensions/index.d.ts.map +1 -0
- package/dist/types/src/graph/compute-graph-registry.d.ts +34 -0
- package/dist/types/src/graph/compute-graph-registry.d.ts.map +1 -0
- package/dist/types/src/graph/compute-graph.d.ts +64 -0
- package/dist/types/src/graph/compute-graph.d.ts.map +1 -0
- package/dist/types/src/graph/compute-graph.stories.d.ts +10 -0
- package/dist/types/src/graph/compute-graph.stories.d.ts.map +1 -0
- package/dist/types/src/graph/compute-graph.test.d.ts +2 -0
- package/dist/types/src/graph/compute-graph.test.d.ts.map +1 -0
- package/dist/types/src/graph/compute-node.d.ts +26 -0
- package/dist/types/src/graph/compute-node.d.ts.map +1 -0
- package/dist/types/src/{components/ComputeGraph → graph/functions}/async-function.d.ts +14 -5
- package/dist/types/src/graph/functions/async-function.d.ts.map +1 -0
- package/dist/types/src/graph/functions/edge-function.d.ts +21 -0
- package/dist/types/src/graph/functions/edge-function.d.ts.map +1 -0
- package/dist/types/src/{model/functions.d.ts → graph/functions/function-defs.d.ts} +1 -1
- package/dist/types/src/graph/functions/function-defs.d.ts.map +1 -0
- package/dist/types/src/graph/functions/index.d.ts +4 -0
- package/dist/types/src/graph/functions/index.d.ts.map +1 -0
- package/dist/types/src/graph/hyperformula.test.d.ts +2 -0
- package/dist/types/src/graph/hyperformula.test.d.ts.map +1 -0
- package/dist/types/src/graph/index.d.ts +5 -0
- package/dist/types/src/graph/index.d.ts.map +1 -0
- package/dist/types/src/graph/testing/index.d.ts +3 -0
- package/dist/types/src/graph/testing/index.d.ts.map +1 -0
- package/dist/types/src/graph/testing/test-builder.d.ts +15 -0
- package/dist/types/src/graph/testing/test-builder.d.ts.map +1 -0
- package/dist/types/src/graph/testing/test-plugin.d.ts +36 -0
- package/dist/types/src/graph/testing/test-plugin.d.ts.map +1 -0
- package/dist/types/src/graph/util.d.ts +2 -0
- package/dist/types/src/graph/util.d.ts.map +1 -0
- package/dist/types/src/hooks/hooks.stories.d.ts +11 -0
- package/dist/types/src/hooks/hooks.stories.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +5 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -0
- package/dist/types/src/hooks/threads.d.ts +8 -0
- package/dist/types/src/hooks/threads.d.ts.map +1 -0
- package/dist/types/src/hooks/useComputeGraph.d.ts +7 -0
- package/dist/types/src/hooks/useComputeGraph.d.ts.map +1 -0
- package/dist/types/src/hooks/useFormattingModel.d.ts +3 -0
- package/dist/types/src/hooks/useFormattingModel.d.ts.map +1 -0
- package/dist/types/src/hooks/useSheetModel.d.ts +8 -0
- package/dist/types/src/hooks/useSheetModel.d.ts.map +1 -0
- package/dist/types/src/meta.d.ts +3 -9
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/model/decorations.d.ts +25 -0
- package/dist/types/src/model/decorations.d.ts.map +1 -0
- package/dist/types/src/model/formatting-model.d.ts +19 -0
- package/dist/types/src/model/formatting-model.d.ts.map +1 -0
- package/dist/types/src/model/index.d.ts +3 -3
- package/dist/types/src/model/index.d.ts.map +1 -1
- package/dist/types/src/model/{model.d.ts → sheet-model.d.ts} +13 -67
- package/dist/types/src/model/sheet-model.d.ts.map +1 -0
- package/dist/types/src/model/sheet-model.test.d.ts +2 -0
- package/dist/types/src/model/sheet-model.test.d.ts.map +1 -0
- package/dist/types/src/sanity.test.d.ts +2 -0
- package/dist/types/src/sanity.test.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +2 -0
- package/dist/types/src/testing/index.d.ts.map +1 -0
- package/dist/types/src/testing/testing.d.ts +8 -0
- package/dist/types/src/testing/testing.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +17 -12
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +98 -32
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/vendor/hyperformula.mjs +37145 -0
- package/package.json +57 -52
- package/src/SheetPlugin.tsx +52 -74
- package/src/components/ComputeGraph/ComputeGraphContextProvider.tsx +20 -0
- package/src/components/ComputeGraph/index.ts +1 -3
- package/src/components/FunctionEditor/FunctionEditor.tsx +45 -0
- package/src/components/FunctionEditor/index.ts +5 -0
- package/src/components/GridSheet/GridSheet.stories.tsx +41 -0
- package/src/components/GridSheet/GridSheet.tsx +161 -0
- package/src/components/{CellEditor/CellEditor.stories.tsx → GridSheet/SheetCellEditor.stories.tsx} +8 -8
- package/src/components/GridSheet/index.ts +5 -0
- package/src/components/GridSheet/util.ts +144 -0
- package/src/components/SheetContainer/SheetContainer.stories.tsx +40 -0
- package/src/components/SheetContainer/SheetContainer.tsx +52 -0
- package/src/components/SheetContainer/index.ts +7 -0
- package/src/components/SheetContext/SheetContext.tsx +108 -0
- package/src/components/SheetContext/index.ts +5 -0
- package/src/components/Toolbar/Toolbar.tsx +167 -85
- package/src/components/index.ts +2 -0
- package/src/defs/index.ts +6 -0
- package/src/{model → defs}/types.test.ts +8 -9
- package/src/{model → defs}/types.ts +24 -14
- package/src/defs/util.ts +151 -0
- package/src/extensions/compute.stories.tsx +151 -0
- package/src/extensions/compute.ts +147 -0
- package/src/{components/CellEditor → extensions/editor}/extension.test.ts +4 -6
- package/src/{components/CellEditor → extensions/editor}/extension.ts +5 -6
- package/src/{components/CellEditor → extensions/editor}/index.ts +0 -1
- package/src/extensions/index.ts +6 -0
- package/src/graph/compute-graph-registry.ts +90 -0
- package/src/graph/compute-graph.stories.tsx +93 -0
- package/src/graph/compute-graph.test.ts +87 -0
- package/src/graph/compute-graph.ts +242 -0
- package/src/graph/compute-node.ts +63 -0
- package/src/{components/ComputeGraph → graph/functions}/async-function.ts +25 -15
- package/src/{components/ComputeGraph → graph/functions}/edge-function.ts +16 -14
- package/src/graph/functions/index.ts +7 -0
- package/src/graph/hyperformula.test.ts +14 -0
- package/src/graph/index.ts +8 -0
- package/src/graph/testing/index.ts +6 -0
- package/src/graph/testing/test-builder.ts +54 -0
- package/src/{components/ComputeGraph/custom.ts → graph/testing/test-plugin.ts} +44 -14
- package/src/graph/util.ts +8 -0
- package/src/hooks/hooks.stories.tsx +50 -0
- package/src/hooks/index.ts +8 -0
- package/src/hooks/threads.ts +147 -0
- package/src/hooks/useComputeGraph.ts +28 -0
- package/src/hooks/useFormattingModel.ts +11 -0
- package/src/hooks/useSheetModel.ts +40 -0
- package/src/meta.ts +14 -0
- package/src/model/decorations.ts +64 -0
- package/src/{components/Sheet/formatting.ts → model/formatting-model.ts} +30 -20
- package/src/model/index.ts +3 -3
- package/src/model/sheet-model.test.ts +57 -0
- package/src/model/sheet-model.ts +418 -0
- package/src/sanity.test.ts +40 -0
- package/src/{components/Sheet → testing}/index.ts +1 -1
- package/src/testing/testing.tsx +68 -0
- package/src/translations.ts +6 -1
- package/src/types.ts +40 -41
- package/dist/lib/browser/SheetContainer-U4H5D34A.mjs +0 -1772
- package/dist/lib/browser/SheetContainer-U4H5D34A.mjs.map +0 -7
- package/dist/lib/browser/chunk-APHOLYUB.mjs +0 -175
- package/dist/lib/browser/chunk-APHOLYUB.mjs.map +0 -7
- package/dist/lib/browser/chunk-D5AGLXJP.mjs.map +0 -7
- package/dist/lib/browser/chunk-FUAGSXA4.mjs +0 -82
- package/dist/lib/browser/chunk-FUAGSXA4.mjs.map +0 -7
- package/dist/lib/browser/chunk-JRL5LGCE.mjs +0 -18
- package/dist/lib/browser/chunk-JRL5LGCE.mjs.map +0 -7
- package/dist/lib/browser/chunk-NU4PBN33.mjs +0 -8
- package/dist/lib/browser/chunk-NU4PBN33.mjs.map +0 -7
- package/dist/lib/browser/testing.mjs +0 -92
- package/dist/lib/browser/testing.mjs.map +0 -7
- package/dist/lib/node/SheetContainer-AXQV3ZT5.cjs +0 -1765
- package/dist/lib/node/SheetContainer-AXQV3ZT5.cjs.map +0 -7
- package/dist/lib/node/chunk-5KKJ4NPP.cjs.map +0 -7
- package/dist/lib/node/chunk-BJ6ZD7MN.cjs +0 -51
- package/dist/lib/node/chunk-BJ6ZD7MN.cjs.map +0 -7
- package/dist/lib/node/chunk-CN3RPESU.cjs +0 -202
- package/dist/lib/node/chunk-CN3RPESU.cjs.map +0 -7
- package/dist/lib/node/chunk-DSYKOI4E.cjs.map +0 -7
- package/dist/lib/node/chunk-PYXHNAAK.cjs +0 -40
- package/dist/lib/node/chunk-PYXHNAAK.cjs.map +0 -7
- package/dist/lib/node/testing.cjs +0 -111
- package/dist/lib/node/testing.cjs.map +0 -7
- package/dist/types/src/components/CellEditor/CellEditor.d.ts +0 -14
- package/dist/types/src/components/CellEditor/CellEditor.d.ts.map +0 -1
- package/dist/types/src/components/CellEditor/CellEditor.stories.d.ts.map +0 -1
- package/dist/types/src/components/CellEditor/extension.d.ts.map +0 -1
- package/dist/types/src/components/CellEditor/extension.test.d.ts.map +0 -1
- package/dist/types/src/components/CellEditor/index.d.ts +0 -3
- package/dist/types/src/components/CellEditor/index.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/async-function.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/custom.d.ts +0 -21
- package/dist/types/src/components/ComputeGraph/custom.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/edge-function.d.ts +0 -20
- package/dist/types/src/components/ComputeGraph/edge-function.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/graph-context.d.ts +0 -12
- package/dist/types/src/components/ComputeGraph/graph-context.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/graph.browser.test.d.ts +0 -2
- package/dist/types/src/components/ComputeGraph/graph.browser.test.d.ts.map +0 -1
- package/dist/types/src/components/ComputeGraph/graph.d.ts +0 -26
- package/dist/types/src/components/ComputeGraph/graph.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/Sheet.d.ts +0 -55
- package/dist/types/src/components/Sheet/Sheet.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/Sheet.stories.d.ts +0 -54
- package/dist/types/src/components/Sheet/Sheet.stories.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/formatting.d.ts +0 -14
- package/dist/types/src/components/Sheet/formatting.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/grid.d.ts +0 -52
- package/dist/types/src/components/Sheet/grid.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/index.d.ts +0 -2
- package/dist/types/src/components/Sheet/index.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/nav.d.ts +0 -29
- package/dist/types/src/components/Sheet/nav.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/sheet-context.d.ts +0 -25
- package/dist/types/src/components/Sheet/sheet-context.d.ts.map +0 -1
- package/dist/types/src/components/Sheet/util.d.ts +0 -18
- package/dist/types/src/components/Sheet/util.d.ts.map +0 -1
- package/dist/types/src/components/SheetContainer.d.ts +0 -9
- package/dist/types/src/components/SheetContainer.d.ts.map +0 -1
- package/dist/types/src/components/Toolbar/common.d.ts +0 -20
- package/dist/types/src/components/Toolbar/common.d.ts.map +0 -1
- package/dist/types/src/model/functions.d.ts.map +0 -1
- package/dist/types/src/model/model.browser.test.d.ts +0 -2
- package/dist/types/src/model/model.browser.test.d.ts.map +0 -1
- package/dist/types/src/model/model.d.ts.map +0 -1
- package/dist/types/src/model/types.d.ts.map +0 -1
- package/dist/types/src/model/types.test.d.ts.map +0 -1
- package/dist/types/src/model/util.d.ts +0 -15
- package/dist/types/src/model/util.d.ts.map +0 -1
- package/dist/types/src/testing.d.ts +0 -9
- package/dist/types/src/testing.d.ts.map +0 -1
- package/src/components/CellEditor/CellEditor.tsx +0 -113
- package/src/components/ComputeGraph/graph-context.tsx +0 -50
- package/src/components/ComputeGraph/graph.browser.test.ts +0 -50
- package/src/components/ComputeGraph/graph.ts +0 -62
- package/src/components/Sheet/Sheet.stories.tsx +0 -287
- package/src/components/Sheet/Sheet.tsx +0 -1160
- package/src/components/Sheet/grid.ts +0 -191
- package/src/components/Sheet/nav.ts +0 -157
- package/src/components/Sheet/sheet-context.tsx +0 -150
- package/src/components/Sheet/util.ts +0 -56
- package/src/components/SheetContainer.tsx +0 -34
- package/src/components/Toolbar/common.tsx +0 -72
- package/src/meta.tsx +0 -18
- package/src/model/model.browser.test.ts +0 -100
- package/src/model/model.ts +0 -550
- package/src/model/util.ts +0 -36
- package/src/testing.ts +0 -50
- /package/dist/types/src/{model → defs}/types.test.d.ts +0 -0
- /package/dist/types/src/{components/CellEditor → extensions/editor}/extension.test.d.ts +0 -0
- /package/src/{model/functions.ts → graph/functions/function-defs.ts} +0 -0
|
@@ -26,45 +26,97 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
26
|
mod
|
|
27
27
|
));
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var
|
|
30
|
-
__export(
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
29
|
+
var chunk_5XPK2V4A_exports = {};
|
|
30
|
+
__export(chunk_5XPK2V4A_exports, {
|
|
31
|
+
AsyncFunctionPlugin: () => AsyncFunctionPlugin,
|
|
32
|
+
ComputeGraph: () => ComputeGraph,
|
|
33
|
+
ComputeGraphRegistry: () => ComputeGraphRegistry,
|
|
34
|
+
ComputeNode: () => ComputeNode,
|
|
35
|
+
EDGE_FUNCTION_NAME: () => EDGE_FUNCTION_NAME,
|
|
36
|
+
EdgeFunctionPlugin: () => EdgeFunctionPlugin,
|
|
37
|
+
EdgeFunctionPluginTranslations: () => EdgeFunctionPluginTranslations,
|
|
38
|
+
FunctionContext: () => FunctionContext,
|
|
39
|
+
createSheetName: () => createSheetName,
|
|
40
|
+
defaultFunctionContextOptions: () => defaultFunctionContextOptions,
|
|
39
41
|
defaultFunctions: () => defaultFunctions,
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
defaultOptions: () => defaultOptions,
|
|
43
|
+
defaultPlugins: () => defaultPlugins,
|
|
44
|
+
parseSheetName: () => parseSheetName
|
|
43
45
|
});
|
|
44
|
-
module.exports = __toCommonJS(
|
|
45
|
-
var import_chunk_DSYKOI4E = require("./chunk-DSYKOI4E.cjs");
|
|
46
|
-
var import_hyperformula = require("hyperformula");
|
|
46
|
+
module.exports = __toCommonJS(chunk_5XPK2V4A_exports);
|
|
47
47
|
var import_async = require("@dxos/async");
|
|
48
|
+
var import_echo = require("@dxos/client/echo");
|
|
49
|
+
var import_context = require("@dxos/context");
|
|
50
|
+
var import_echo_schema = require("@dxos/echo-schema");
|
|
51
|
+
var import_invariant = require("@dxos/invariant");
|
|
48
52
|
var import_keys = require("@dxos/keys");
|
|
49
53
|
var import_log = require("@dxos/log");
|
|
50
|
-
var
|
|
51
|
-
var
|
|
54
|
+
var import_types = require("@dxos/plugin-script/types");
|
|
55
|
+
var import_util = require("@dxos/util");
|
|
56
|
+
var import_hyperformula = require("#hyperformula");
|
|
52
57
|
var import_async2 = require("@dxos/async");
|
|
53
|
-
var
|
|
54
|
-
var
|
|
58
|
+
var import_context2 = require("@dxos/context");
|
|
59
|
+
var import_hyperformula2 = require("#hyperformula");
|
|
60
|
+
var import_lodash = __toESM(require("lodash.defaultsdeep"));
|
|
55
61
|
var import_async3 = require("@dxos/async");
|
|
56
|
-
var
|
|
57
|
-
var
|
|
58
|
-
var
|
|
62
|
+
var import_log2 = require("@dxos/log");
|
|
63
|
+
var import_hyperformula3 = require("#hyperformula");
|
|
64
|
+
var import_signals_core = require("@preact/signals-core");
|
|
65
|
+
var import_echo2 = require("@dxos/client/echo");
|
|
59
66
|
var import_log3 = require("@dxos/log");
|
|
67
|
+
var import_edge = require("@dxos/plugin-script/edge");
|
|
68
|
+
var import_types2 = require("@dxos/plugin-script/types");
|
|
69
|
+
var import_util2 = require("@dxos/util");
|
|
70
|
+
var import_hyperformula4 = require("#hyperformula");
|
|
71
|
+
var import_lodash2 = __toESM(require("lodash.defaultsdeep"));
|
|
72
|
+
var import_context3 = require("@dxos/context");
|
|
60
73
|
var import_invariant2 = require("@dxos/invariant");
|
|
61
|
-
var
|
|
62
|
-
var
|
|
63
|
-
var
|
|
64
|
-
|
|
74
|
+
var import_log4 = require("@dxos/log");
|
|
75
|
+
var import_hyperformula5 = require("#hyperformula");
|
|
76
|
+
var ComputeNode = class extends import_context2.Resource {
|
|
77
|
+
constructor(_graph, sheetId) {
|
|
78
|
+
super();
|
|
79
|
+
this._graph = _graph;
|
|
80
|
+
this.sheetId = sheetId;
|
|
81
|
+
this.update = new import_async2.Event();
|
|
82
|
+
}
|
|
83
|
+
get graph() {
|
|
84
|
+
return this._graph;
|
|
85
|
+
}
|
|
86
|
+
clear() {
|
|
87
|
+
this._graph.hf.clearSheet(this.sheetId);
|
|
88
|
+
}
|
|
89
|
+
getValue(cell) {
|
|
90
|
+
const value = this._graph.hf.getCellValue({
|
|
91
|
+
sheet: this.sheetId,
|
|
92
|
+
row: cell.row,
|
|
93
|
+
col: cell.col
|
|
94
|
+
});
|
|
95
|
+
if (value instanceof import_hyperformula2.DetailedCellError) {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
return value;
|
|
99
|
+
}
|
|
100
|
+
setValue(cell, value) {
|
|
101
|
+
const mappedValue = typeof value === "string" && value.charAt(0) === "=" ? this._graph.mapFormulaToNative(value) : value;
|
|
102
|
+
this._graph.hf.setCellContents({
|
|
103
|
+
sheet: this.sheetId,
|
|
104
|
+
row: cell.row,
|
|
105
|
+
col: cell.col
|
|
106
|
+
}, [
|
|
107
|
+
[
|
|
108
|
+
mappedValue
|
|
109
|
+
]
|
|
110
|
+
]);
|
|
111
|
+
}
|
|
112
|
+
// TODO(burdon): Load data into sheet.
|
|
113
|
+
async _open() {
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/graph/functions/async-function.ts";
|
|
65
117
|
var defaultFunctionContextOptions = {
|
|
66
118
|
defaultTtl: 5e3,
|
|
67
|
-
|
|
119
|
+
debounceDelay: 200,
|
|
68
120
|
remoteFunctionUrl: "https://edge.dxos.workers.dev/functions"
|
|
69
121
|
};
|
|
70
122
|
var FunctionContext = class _FunctionContext {
|
|
@@ -75,7 +127,7 @@ var FunctionContext = class _FunctionContext {
|
|
|
75
127
|
...args
|
|
76
128
|
});
|
|
77
129
|
}
|
|
78
|
-
constructor(_hf, _space,
|
|
130
|
+
constructor(_hf, _space, _options) {
|
|
79
131
|
this._hf = _hf;
|
|
80
132
|
this._space = _space;
|
|
81
133
|
this._cache = /* @__PURE__ */ new Map();
|
|
@@ -83,10 +135,10 @@ var FunctionContext = class _FunctionContext {
|
|
|
83
135
|
this._subscriptions = /* @__PURE__ */ new Map();
|
|
84
136
|
this._invocations = {};
|
|
85
137
|
this._options = (0, import_lodash.default)(_options ?? {}, defaultFunctionContextOptions);
|
|
86
|
-
this._onUpdate = (0,
|
|
138
|
+
this._onUpdate = (0, import_async3.debounce)((update) => {
|
|
87
139
|
this._hf.resumeEvaluation();
|
|
88
|
-
onUpdate(
|
|
89
|
-
}, this._options.
|
|
140
|
+
this._options.onUpdate?.(update);
|
|
141
|
+
}, this._options.debounceDelay);
|
|
90
142
|
}
|
|
91
143
|
get space() {
|
|
92
144
|
return this._space;
|
|
@@ -136,23 +188,26 @@ var FunctionContext = class _FunctionContext {
|
|
|
136
188
|
value: value2
|
|
137
189
|
}, {
|
|
138
190
|
F: __dxlog_file,
|
|
139
|
-
L:
|
|
191
|
+
L: 143,
|
|
140
192
|
S: this,
|
|
141
193
|
C: (f, a) => f(...a)
|
|
142
194
|
});
|
|
143
|
-
this._onUpdate(
|
|
195
|
+
this._onUpdate({
|
|
196
|
+
name,
|
|
197
|
+
cell
|
|
198
|
+
});
|
|
144
199
|
} catch (err) {
|
|
145
200
|
import_log2.log.warn("failed", {
|
|
146
201
|
cell,
|
|
147
202
|
err
|
|
148
203
|
}, {
|
|
149
204
|
F: __dxlog_file,
|
|
150
|
-
L:
|
|
205
|
+
L: 147,
|
|
151
206
|
S: this,
|
|
152
207
|
C: (f, a) => f(...a)
|
|
153
208
|
});
|
|
154
209
|
this._cache.set(invocationKey, {
|
|
155
|
-
value: new
|
|
210
|
+
value: new import_hyperformula3.CellError(import_hyperformula3.ErrorType.ERROR, "Function failed."),
|
|
156
211
|
ts: Date.now()
|
|
157
212
|
});
|
|
158
213
|
} finally {
|
|
@@ -167,59 +222,137 @@ var FunctionContext = class _FunctionContext {
|
|
|
167
222
|
cache: value
|
|
168
223
|
}, {
|
|
169
224
|
F: __dxlog_file,
|
|
170
|
-
L:
|
|
225
|
+
L: 155,
|
|
171
226
|
S: this,
|
|
172
227
|
C: (f, a) => f(...a)
|
|
173
228
|
});
|
|
174
229
|
return value;
|
|
175
230
|
}
|
|
176
231
|
};
|
|
177
|
-
var
|
|
232
|
+
var AsyncFunctionPlugin = class extends import_hyperformula3.FunctionPlugin {
|
|
178
233
|
get context() {
|
|
179
234
|
return this.config.context;
|
|
180
235
|
}
|
|
236
|
+
/**
|
|
237
|
+
* Immediately returns cached value then runs the async function.
|
|
238
|
+
*/
|
|
181
239
|
runAsyncFunction(ast, state, cb, options) {
|
|
182
240
|
const { procedureName } = ast;
|
|
183
241
|
const metadata = this.metadata(procedureName);
|
|
184
242
|
return this.runFunction(ast.args, state, metadata, (...args) => {
|
|
185
|
-
return this.context.invokeFunction(procedureName, state, args, cb, options) ??
|
|
243
|
+
return this.context.invokeFunction(procedureName, state, args, cb, options) ?? import_hyperformula3.EmptyValue;
|
|
186
244
|
});
|
|
187
245
|
}
|
|
188
246
|
};
|
|
189
|
-
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/
|
|
190
|
-
var
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
247
|
+
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/graph/functions/edge-function.ts";
|
|
248
|
+
var EDGE_FUNCTION_NAME = "DX";
|
|
249
|
+
var FUNCTION_TTL = 1e4;
|
|
250
|
+
var EdgeFunctionPlugin = class extends AsyncFunctionPlugin {
|
|
251
|
+
dx(ast, state) {
|
|
252
|
+
const handler = (subscribe = false) => async (binding, ...args) => {
|
|
253
|
+
const space = this.context.space;
|
|
254
|
+
if (!space) {
|
|
255
|
+
return new import_hyperformula4.CellError(import_hyperformula4.ErrorType.REF, "Missing space");
|
|
256
|
+
}
|
|
257
|
+
const { objects: [fn] } = await space.db.query(import_echo2.Filter.schema(import_types2.FunctionType, {
|
|
258
|
+
binding
|
|
259
|
+
})).run();
|
|
260
|
+
if (!fn) {
|
|
261
|
+
import_log3.log.info("Function not found", {
|
|
262
|
+
binding
|
|
263
|
+
}, {
|
|
264
|
+
F: __dxlog_file2,
|
|
265
|
+
L: 41,
|
|
266
|
+
S: this,
|
|
267
|
+
C: (f, a) => f(...a)
|
|
268
|
+
});
|
|
269
|
+
return new import_hyperformula4.CellError(import_hyperformula4.ErrorType.REF, "Function not found");
|
|
270
|
+
}
|
|
271
|
+
if (subscribe) {
|
|
272
|
+
const unsubscribe = (0, import_signals_core.effect)(() => {
|
|
273
|
+
import_log3.log.info("function changed", {
|
|
274
|
+
fn
|
|
275
|
+
}, {
|
|
276
|
+
F: __dxlog_file2,
|
|
277
|
+
L: 47,
|
|
278
|
+
S: this,
|
|
279
|
+
C: (f, a) => f(...a)
|
|
280
|
+
});
|
|
281
|
+
const _ = fn?.version;
|
|
282
|
+
this.runAsyncFunction(ast, state, handler(false), {
|
|
283
|
+
ttl: FUNCTION_TTL
|
|
284
|
+
});
|
|
285
|
+
});
|
|
286
|
+
this.context.createSubscription(ast.procedureName, unsubscribe);
|
|
287
|
+
}
|
|
288
|
+
const path = (0, import_edge.getUserFunctionUrlInMetadata)((0, import_echo2.getMeta)(fn));
|
|
289
|
+
const result = await fetch(`${this.context.remoteFunctionUrl}${path}`, {
|
|
290
|
+
method: "POST",
|
|
291
|
+
headers: {
|
|
292
|
+
"Content-Type": "application/json"
|
|
293
|
+
},
|
|
294
|
+
body: JSON.stringify({
|
|
295
|
+
args: args.filter(import_util2.nonNullable)
|
|
296
|
+
})
|
|
297
|
+
});
|
|
298
|
+
return await result.text();
|
|
299
|
+
};
|
|
300
|
+
return this.runAsyncFunction(ast, state, handler(true), {
|
|
301
|
+
ttl: FUNCTION_TTL
|
|
211
302
|
});
|
|
212
303
|
}
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
304
|
+
};
|
|
305
|
+
EdgeFunctionPlugin.implementedFunctions = {
|
|
306
|
+
[EDGE_FUNCTION_NAME]: {
|
|
307
|
+
method: "dx",
|
|
308
|
+
parameters: [
|
|
309
|
+
// Binding
|
|
310
|
+
{
|
|
311
|
+
argumentType: import_hyperformula4.FunctionArgumentType.STRING
|
|
312
|
+
},
|
|
313
|
+
// Remote function arguments (currently supporting up to 8).
|
|
314
|
+
{
|
|
315
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
316
|
+
optionalArg: true
|
|
317
|
+
},
|
|
318
|
+
{
|
|
319
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
320
|
+
optionalArg: true
|
|
321
|
+
},
|
|
322
|
+
{
|
|
323
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
324
|
+
optionalArg: true
|
|
325
|
+
},
|
|
326
|
+
{
|
|
327
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
328
|
+
optionalArg: true
|
|
329
|
+
},
|
|
330
|
+
{
|
|
331
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
332
|
+
optionalArg: true
|
|
333
|
+
},
|
|
334
|
+
{
|
|
335
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
336
|
+
optionalArg: true
|
|
337
|
+
},
|
|
338
|
+
{
|
|
339
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
340
|
+
optionalArg: true
|
|
341
|
+
},
|
|
342
|
+
{
|
|
343
|
+
argumentType: import_hyperformula4.FunctionArgumentType.ANY,
|
|
344
|
+
optionalArg: true
|
|
345
|
+
}
|
|
346
|
+
],
|
|
347
|
+
isVolatile: true
|
|
348
|
+
}
|
|
349
|
+
};
|
|
350
|
+
var EdgeFunctionPluginTranslations = {
|
|
351
|
+
enGB: {
|
|
352
|
+
[EDGE_FUNCTION_NAME]: "Remote function"
|
|
353
|
+
},
|
|
354
|
+
enUS: {
|
|
355
|
+
[EDGE_FUNCTION_NAME]: "Remote function"
|
|
223
356
|
}
|
|
224
357
|
};
|
|
225
358
|
var defaultFunctions = [
|
|
@@ -2594,666 +2727,273 @@ var defaultFunctions = [
|
|
|
2594
2727
|
section: "Text"
|
|
2595
2728
|
}
|
|
2596
2729
|
];
|
|
2597
|
-
var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/
|
|
2598
|
-
var
|
|
2599
|
-
var
|
|
2600
|
-
|
|
2601
|
-
|
|
2602
|
-
|
|
2603
|
-
|
|
2604
|
-
|
|
2605
|
-
|
|
2606
|
-
|
|
2607
|
-
A: [
|
|
2608
|
-
"column < MAX_COLUMNS",
|
|
2609
|
-
"`Invalid column: ${column}`"
|
|
2610
|
-
]
|
|
2611
|
-
});
|
|
2612
|
-
return (column >= 26 ? String.fromCharCode("A".charCodeAt(0) + Math.floor(column / 26) - 1) : "") + String.fromCharCode("A".charCodeAt(0) + column % 26);
|
|
2613
|
-
};
|
|
2614
|
-
var addressToA1Notation = ({ column, row }) => {
|
|
2615
|
-
return `${columnLetter(column)}${row + 1}`;
|
|
2616
|
-
};
|
|
2617
|
-
var addressFromA1Notation = (ref) => {
|
|
2618
|
-
const match = ref.match(/([A-Z]+)(\d+)/);
|
|
2619
|
-
(0, import_invariant2.invariant)(match, `Invalid notation: ${ref}`, {
|
|
2620
|
-
F: __dxlog_file3,
|
|
2621
|
-
L: 30,
|
|
2622
|
-
S: void 0,
|
|
2623
|
-
A: [
|
|
2624
|
-
"match",
|
|
2625
|
-
"`Invalid notation: ${ref}`"
|
|
2626
|
-
]
|
|
2627
|
-
});
|
|
2628
|
-
return {
|
|
2629
|
-
row: parseInt(match[2], 10) - 1,
|
|
2630
|
-
column: match[1].split("").reduce((acc, c) => acc * 26 + c.charCodeAt(0) - "A".charCodeAt(0) + 1, 0) - 1
|
|
2730
|
+
var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/graph/compute-graph.ts";
|
|
2731
|
+
var OBJECT_ID_LENGTH = 60;
|
|
2732
|
+
var createSheetName = ({ type, id }) => `${type}@${id}`;
|
|
2733
|
+
var parseSheetName = (name) => {
|
|
2734
|
+
const [type, id] = name.split("@");
|
|
2735
|
+
return id ? {
|
|
2736
|
+
type,
|
|
2737
|
+
id
|
|
2738
|
+
} : {
|
|
2739
|
+
id: type
|
|
2631
2740
|
};
|
|
2632
2741
|
};
|
|
2633
|
-
var
|
|
2634
|
-
|
|
2635
|
-
range?.from && addressToA1Notation(range?.from),
|
|
2636
|
-
range?.to && addressToA1Notation(range?.to)
|
|
2637
|
-
].filter(Boolean).join(":");
|
|
2638
|
-
};
|
|
2639
|
-
var inRange = (range, cell) => {
|
|
2640
|
-
if (!range) {
|
|
2641
|
-
return false;
|
|
2642
|
-
}
|
|
2643
|
-
const { from, to } = range;
|
|
2644
|
-
if (from && posEquals(from, cell) || to && posEquals(to, cell)) {
|
|
2645
|
-
return true;
|
|
2646
|
-
}
|
|
2647
|
-
if (!from || !to) {
|
|
2648
|
-
return false;
|
|
2649
|
-
}
|
|
2650
|
-
const { column: c1, row: r1 } = from;
|
|
2651
|
-
const { column: c2, row: r2 } = to;
|
|
2652
|
-
const cMin = Math.min(c1, c2);
|
|
2653
|
-
const cMax = Math.max(c1, c2);
|
|
2654
|
-
const rMin = Math.min(r1, r2);
|
|
2655
|
-
const rMax = Math.max(r1, r2);
|
|
2656
|
-
const { column, row } = cell;
|
|
2657
|
-
return column >= cMin && column <= cMax && row >= rMin && row <= rMax;
|
|
2658
|
-
};
|
|
2659
|
-
var ApiError = class extends Error {
|
|
2660
|
-
};
|
|
2661
|
-
var ReadonlyException = class extends ApiError {
|
|
2662
|
-
};
|
|
2663
|
-
var RangeException = class extends ApiError {
|
|
2664
|
-
constructor(n) {
|
|
2742
|
+
var ComputeGraph = class extends import_context.Resource {
|
|
2743
|
+
constructor(_hf, _space, _options) {
|
|
2665
2744
|
super();
|
|
2666
|
-
|
|
2667
|
-
};
|
|
2668
|
-
var createIndex = (length = 8) => {
|
|
2669
|
-
const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
|
2670
|
-
const charactersLength = characters.length;
|
|
2671
|
-
const randomBuffer = (0, import_crypto.randomBytes)(length);
|
|
2672
|
-
return Array.from(randomBuffer, (byte) => characters[byte % charactersLength]).join("");
|
|
2673
|
-
};
|
|
2674
|
-
var createIndices = (length) => Array.from({
|
|
2675
|
-
length
|
|
2676
|
-
}).map(() => createIndex());
|
|
2677
|
-
var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/model/model.ts";
|
|
2678
|
-
var DEFAULT_ROWS = 100;
|
|
2679
|
-
var DEFAULT_COLUMNS = 26;
|
|
2680
|
-
var typeMap = {
|
|
2681
|
-
BOOLEAN: import_chunk_DSYKOI4E.ValueTypeEnum.Boolean,
|
|
2682
|
-
NUMBER_RAW: import_chunk_DSYKOI4E.ValueTypeEnum.Number,
|
|
2683
|
-
NUMBER_PERCENT: import_chunk_DSYKOI4E.ValueTypeEnum.Percent,
|
|
2684
|
-
NUMBER_CURRENCY: import_chunk_DSYKOI4E.ValueTypeEnum.Currency,
|
|
2685
|
-
NUMBER_DATETIME: import_chunk_DSYKOI4E.ValueTypeEnum.DateTime,
|
|
2686
|
-
NUMBER_DATE: import_chunk_DSYKOI4E.ValueTypeEnum.Date,
|
|
2687
|
-
NUMBER_TIME: import_chunk_DSYKOI4E.ValueTypeEnum.Time
|
|
2688
|
-
};
|
|
2689
|
-
var defaultOptions = {
|
|
2690
|
-
rows: 50,
|
|
2691
|
-
columns: 26,
|
|
2692
|
-
mapFormulaBindingFromId: () => (formula) => formula,
|
|
2693
|
-
mapFormulaBindingToId: () => (formula) => formula
|
|
2694
|
-
};
|
|
2695
|
-
var getTopLeft = (range) => {
|
|
2696
|
-
const to = range.to ?? range.from;
|
|
2697
|
-
return {
|
|
2698
|
-
row: Math.min(range.from.row, to.row),
|
|
2699
|
-
column: Math.min(range.from.column, to.column)
|
|
2700
|
-
};
|
|
2701
|
-
};
|
|
2702
|
-
var toSimpleCellAddress = (sheet, cell) => ({
|
|
2703
|
-
sheet,
|
|
2704
|
-
row: cell.row,
|
|
2705
|
-
col: cell.column
|
|
2706
|
-
});
|
|
2707
|
-
var toModelRange = (sheet, range) => ({
|
|
2708
|
-
start: toSimpleCellAddress(sheet, range.from),
|
|
2709
|
-
end: toSimpleCellAddress(sheet, range.to ?? range.from)
|
|
2710
|
-
});
|
|
2711
|
-
var SheetModel = class {
|
|
2712
|
-
constructor(_graph, _sheet, _space, options = {}) {
|
|
2713
|
-
this._graph = _graph;
|
|
2714
|
-
this._sheet = _sheet;
|
|
2745
|
+
this._hf = _hf;
|
|
2715
2746
|
this._space = _space;
|
|
2716
|
-
this.
|
|
2717
|
-
this.
|
|
2718
|
-
this.
|
|
2719
|
-
this.
|
|
2720
|
-
|
|
2721
|
-
|
|
2722
|
-
|
|
2723
|
-
|
|
2724
|
-
|
|
2725
|
-
|
|
2726
|
-
|
|
2727
|
-
|
|
2747
|
+
this._options = _options;
|
|
2748
|
+
this.id = `graph-${import_keys.PublicKey.random().truncate()}`;
|
|
2749
|
+
this._nodes = /* @__PURE__ */ new Map();
|
|
2750
|
+
this._remoteFunctions = [];
|
|
2751
|
+
this.update = new import_async.Event();
|
|
2752
|
+
this.context = new FunctionContext(this._hf, this._space, this._options);
|
|
2753
|
+
this._hf.updateConfig({
|
|
2754
|
+
context: this.context
|
|
2755
|
+
});
|
|
2756
|
+
const onValuesUpdate = (changes) => {
|
|
2757
|
+
for (const change of changes) {
|
|
2758
|
+
if (change instanceof import_hyperformula.ExportedCellChange) {
|
|
2759
|
+
const { sheet } = change;
|
|
2760
|
+
const node = this._nodes.get(sheet);
|
|
2761
|
+
if (node) {
|
|
2762
|
+
node.update.emit({
|
|
2763
|
+
type: "valuesUpdated",
|
|
2764
|
+
change
|
|
2765
|
+
});
|
|
2766
|
+
}
|
|
2767
|
+
}
|
|
2768
|
+
}
|
|
2728
2769
|
};
|
|
2729
|
-
this.
|
|
2730
|
-
|
|
2731
|
-
get graph() {
|
|
2732
|
-
return this._graph;
|
|
2733
|
-
}
|
|
2734
|
-
get sheet() {
|
|
2735
|
-
return this._sheet;
|
|
2770
|
+
this._hf.on("valuesUpdated", onValuesUpdate);
|
|
2771
|
+
this._ctx.onDispose(() => this._hf.off("valuesUpdated", onValuesUpdate));
|
|
2736
2772
|
}
|
|
2737
|
-
get
|
|
2738
|
-
return this.
|
|
2773
|
+
get hf() {
|
|
2774
|
+
return this._hf;
|
|
2739
2775
|
}
|
|
2740
|
-
|
|
2741
|
-
|
|
2742
|
-
|
|
2743
|
-
|
|
2744
|
-
};
|
|
2745
|
-
}
|
|
2746
|
-
get functions() {
|
|
2747
|
-
const hfFunctions = this._graph.hf.getRegisteredFunctionNames().map((name) => defaultFunctions.find((fn) => fn.name === name) ?? {
|
|
2748
|
-
name
|
|
2749
|
-
});
|
|
2750
|
-
const echoFunctions = this._functions.map((fn) => ({
|
|
2751
|
-
name: fn.binding
|
|
2752
|
-
}));
|
|
2776
|
+
getFunctions({ standard, echo } = {
|
|
2777
|
+
standard: true,
|
|
2778
|
+
echo: true
|
|
2779
|
+
}) {
|
|
2753
2780
|
return [
|
|
2754
|
-
...
|
|
2755
|
-
|
|
2781
|
+
...standard ? this._hf.getRegisteredFunctionNames().map((name) => defaultFunctions.find((fn) => fn.name === name) ?? {
|
|
2782
|
+
name
|
|
2783
|
+
}) : [],
|
|
2784
|
+
...echo ? this._remoteFunctions.map((fn) => ({
|
|
2785
|
+
name: fn.binding
|
|
2786
|
+
})) : []
|
|
2756
2787
|
];
|
|
2757
2788
|
}
|
|
2758
|
-
get initialized() {
|
|
2759
|
-
return !!this._ctx;
|
|
2760
|
-
}
|
|
2761
2789
|
/**
|
|
2762
|
-
*
|
|
2790
|
+
* Get or create cell representing a sheet.
|
|
2763
2791
|
*/
|
|
2764
|
-
|
|
2765
|
-
|
|
2766
|
-
|
|
2767
|
-
|
|
2768
|
-
|
|
2769
|
-
|
|
2770
|
-
|
|
2771
|
-
|
|
2772
|
-
|
|
2773
|
-
(0, import_invariant.invariant)(!this.initialized, "Already initialized.", {
|
|
2774
|
-
F: __dxlog_file4,
|
|
2775
|
-
L: 143,
|
|
2792
|
+
// TODO(burdon): Async (open node).
|
|
2793
|
+
// The graph should be an extensible factory that plugins extend with model constructors.
|
|
2794
|
+
// This would enable on-the-fly instantiation of new models when then are referenced.
|
|
2795
|
+
// E.g., Cross-object reference would be stored as "ObjectId!A1"
|
|
2796
|
+
// The graph would then load the object and create a ComputeNode (model) of the appropriate type.
|
|
2797
|
+
getOrCreateNode(name) {
|
|
2798
|
+
(0, import_invariant.invariant)(name.length, void 0, {
|
|
2799
|
+
F: __dxlog_file3,
|
|
2800
|
+
L: 117,
|
|
2776
2801
|
S: this,
|
|
2777
2802
|
A: [
|
|
2778
|
-
"
|
|
2779
|
-
"
|
|
2803
|
+
"name.length",
|
|
2804
|
+
""
|
|
2780
2805
|
]
|
|
2781
2806
|
});
|
|
2782
|
-
this.
|
|
2783
|
-
|
|
2784
|
-
|
|
2785
|
-
|
|
2786
|
-
|
|
2787
|
-
|
|
2788
|
-
|
|
2789
|
-
|
|
2790
|
-
|
|
2791
|
-
}
|
|
2792
|
-
this.reset();
|
|
2793
|
-
const unsubscribe = this._graph.update.on(() => this.update.emit());
|
|
2794
|
-
this._ctx.onDispose(unsubscribe);
|
|
2795
|
-
if (this._space) {
|
|
2796
|
-
const { Filter } = await import("@dxos/client/echo");
|
|
2797
|
-
const { FunctionType } = await import("@dxos/plugin-script/types");
|
|
2798
|
-
const query = this._space?.db.query(Filter.schema(FunctionType));
|
|
2799
|
-
const unsubscribe2 = query.subscribe(({ objects }) => {
|
|
2800
|
-
this._functions = objects.filter((fn) => fn.binding);
|
|
2801
|
-
this.update.emit();
|
|
2807
|
+
if (!this._hf.doesSheetExist(name)) {
|
|
2808
|
+
import_log.log.info("created node", {
|
|
2809
|
+
space: this._space?.id,
|
|
2810
|
+
sheet: name
|
|
2811
|
+
}, {
|
|
2812
|
+
F: __dxlog_file3,
|
|
2813
|
+
L: 119,
|
|
2814
|
+
S: this,
|
|
2815
|
+
C: (f, a) => f(...a)
|
|
2802
2816
|
});
|
|
2803
|
-
this.
|
|
2817
|
+
this._hf.addSheet(name);
|
|
2804
2818
|
}
|
|
2805
|
-
|
|
2806
|
-
|
|
2807
|
-
|
|
2808
|
-
|
|
2809
|
-
id: this.id
|
|
2810
|
-
}, {
|
|
2811
|
-
F: __dxlog_file4,
|
|
2812
|
-
L: 174,
|
|
2819
|
+
const sheetId = this._hf.getSheetId(name);
|
|
2820
|
+
(0, import_invariant.invariant)(sheetId !== void 0, void 0, {
|
|
2821
|
+
F: __dxlog_file3,
|
|
2822
|
+
L: 124,
|
|
2813
2823
|
S: this,
|
|
2814
|
-
|
|
2815
|
-
|
|
2816
|
-
|
|
2817
|
-
await this._ctx.dispose();
|
|
2818
|
-
this._ctx = void 0;
|
|
2819
|
-
}
|
|
2820
|
-
}
|
|
2821
|
-
/**
|
|
2822
|
-
* Update engine.
|
|
2823
|
-
* NOTE: This resets the undo history.
|
|
2824
|
-
* @deprecated
|
|
2825
|
-
*/
|
|
2826
|
-
reset() {
|
|
2827
|
-
this._graph.hf.clearSheet(this._sheetId);
|
|
2828
|
-
Object.entries(this._sheet.cells).forEach(([key, { value }]) => {
|
|
2829
|
-
const { column, row } = this.addressFromIndex(key);
|
|
2830
|
-
if (typeof value === "string" && value.charAt(0) === "=") {
|
|
2831
|
-
value = this.mapFormulaBindingToFormula(this.mapFormulaBindingFromId(this.mapFormulaIndicesToRefs(value)));
|
|
2832
|
-
}
|
|
2833
|
-
this._graph.hf.setCellContents({
|
|
2834
|
-
sheet: this._sheetId,
|
|
2835
|
-
row,
|
|
2836
|
-
col: column
|
|
2837
|
-
}, value);
|
|
2838
|
-
});
|
|
2839
|
-
}
|
|
2840
|
-
/**
|
|
2841
|
-
* Recalculate formulas.
|
|
2842
|
-
* NOTE: This resets the undo history.
|
|
2843
|
-
* https://hyperformula.handsontable.com/guide/volatile-functions.html#volatile-actions
|
|
2844
|
-
* @deprecated
|
|
2845
|
-
*/
|
|
2846
|
-
// TODO(burdon): Remove.
|
|
2847
|
-
recalculate() {
|
|
2848
|
-
this._graph.hf.rebuildAndRecalculate();
|
|
2849
|
-
}
|
|
2850
|
-
insertRows(i, n = 1) {
|
|
2851
|
-
this._insertIndices(this._sheet.rows, i, n, DEFAULT_ROWS);
|
|
2852
|
-
this.reset();
|
|
2853
|
-
}
|
|
2854
|
-
insertColumns(i, n = 1) {
|
|
2855
|
-
this._insertIndices(this._sheet.columns, i, n, DEFAULT_COLUMNS);
|
|
2856
|
-
this.reset();
|
|
2857
|
-
}
|
|
2858
|
-
//
|
|
2859
|
-
// Undoable actions.
|
|
2860
|
-
// TODO(burdon): Group undoable methods; consistently update hf/sheet.
|
|
2861
|
-
//
|
|
2862
|
-
/**
|
|
2863
|
-
* Clear range of values.
|
|
2864
|
-
*/
|
|
2865
|
-
clear(range) {
|
|
2866
|
-
const topLeft = getTopLeft(range);
|
|
2867
|
-
const values = this._iterRange(range, () => null);
|
|
2868
|
-
this._graph.hf.setCellContents(toSimpleCellAddress(this._sheetId, topLeft), values);
|
|
2869
|
-
this._iterRange(range, (cell) => {
|
|
2870
|
-
const idx = this.addressToIndex(cell);
|
|
2871
|
-
delete this._sheet.cells[idx];
|
|
2872
|
-
});
|
|
2873
|
-
}
|
|
2874
|
-
cut(range) {
|
|
2875
|
-
this._graph.hf.cut(toModelRange(this._sheetId, range));
|
|
2876
|
-
this._iterRange(range, (cell) => {
|
|
2877
|
-
const idx = this.addressToIndex(cell);
|
|
2878
|
-
delete this._sheet.cells[idx];
|
|
2879
|
-
});
|
|
2880
|
-
}
|
|
2881
|
-
copy(range) {
|
|
2882
|
-
this._graph.hf.copy(toModelRange(this._sheetId, range));
|
|
2883
|
-
}
|
|
2884
|
-
paste(cell) {
|
|
2885
|
-
if (!this._graph.hf.isClipboardEmpty()) {
|
|
2886
|
-
const changes = this._graph.hf.paste(toSimpleCellAddress(this._sheetId, cell));
|
|
2887
|
-
for (const change of changes) {
|
|
2888
|
-
if (change instanceof import_hyperformula3.ExportedCellChange) {
|
|
2889
|
-
const { address, newValue } = change;
|
|
2890
|
-
const idx = this.addressToIndex({
|
|
2891
|
-
row: address.row,
|
|
2892
|
-
column: address.col
|
|
2893
|
-
});
|
|
2894
|
-
this._sheet.cells[idx] = {
|
|
2895
|
-
value: newValue
|
|
2896
|
-
};
|
|
2897
|
-
}
|
|
2898
|
-
}
|
|
2899
|
-
}
|
|
2900
|
-
}
|
|
2901
|
-
// TODO(burdon): Display undo/redo state.
|
|
2902
|
-
undo() {
|
|
2903
|
-
if (this._graph.hf.isThereSomethingToUndo()) {
|
|
2904
|
-
this._graph.hf.undo();
|
|
2905
|
-
this.update.emit();
|
|
2906
|
-
}
|
|
2907
|
-
}
|
|
2908
|
-
redo() {
|
|
2909
|
-
if (this._graph.hf.isThereSomethingToRedo()) {
|
|
2910
|
-
this._graph.hf.redo();
|
|
2911
|
-
this.update.emit();
|
|
2912
|
-
}
|
|
2913
|
-
}
|
|
2914
|
-
/**
|
|
2915
|
-
* Get value from sheet.
|
|
2916
|
-
*/
|
|
2917
|
-
getCellValue(cell) {
|
|
2918
|
-
const idx = this.addressToIndex(cell);
|
|
2919
|
-
return this._sheet.cells[idx]?.value ?? null;
|
|
2920
|
-
}
|
|
2921
|
-
/**
|
|
2922
|
-
* Get value as a string for editing.
|
|
2923
|
-
*/
|
|
2924
|
-
getCellText(cell) {
|
|
2925
|
-
const value = this.getCellValue(cell);
|
|
2926
|
-
if (value == null) {
|
|
2927
|
-
return void 0;
|
|
2928
|
-
}
|
|
2929
|
-
if (typeof value === "string" && value.charAt(0) === "=") {
|
|
2930
|
-
return this.mapFormulaBindingFromId(this.mapFormulaIndicesToRefs(value));
|
|
2931
|
-
} else {
|
|
2932
|
-
return String(value);
|
|
2933
|
-
}
|
|
2934
|
-
}
|
|
2935
|
-
/**
|
|
2936
|
-
* Get array of raw values from sheet.
|
|
2937
|
-
*/
|
|
2938
|
-
getCellValues(range) {
|
|
2939
|
-
return this._iterRange(range, (cell) => this.getCellValue(cell));
|
|
2940
|
-
}
|
|
2941
|
-
/**
|
|
2942
|
-
* Gets the regular or computed value from the engine.
|
|
2943
|
-
*/
|
|
2944
|
-
getValue(cell) {
|
|
2945
|
-
const value = this._graph.hf.getCellValue(toSimpleCellAddress(this._sheetId, cell));
|
|
2946
|
-
if (value instanceof import_hyperformula3.DetailedCellError) {
|
|
2947
|
-
return value.toString();
|
|
2948
|
-
}
|
|
2949
|
-
return value;
|
|
2950
|
-
}
|
|
2951
|
-
/**
|
|
2952
|
-
* Get value type.
|
|
2953
|
-
*/
|
|
2954
|
-
getValueType(cell) {
|
|
2955
|
-
const addr = toSimpleCellAddress(this._sheetId, cell);
|
|
2956
|
-
const type = this._graph.hf.getCellValueDetailedType(addr);
|
|
2957
|
-
return typeMap[type];
|
|
2958
|
-
}
|
|
2959
|
-
/**
|
|
2960
|
-
* Sets the value, updating the sheet and engine.
|
|
2961
|
-
*/
|
|
2962
|
-
setValue(cell, value) {
|
|
2963
|
-
if (this._options.readonly) {
|
|
2964
|
-
throw new ReadonlyException();
|
|
2965
|
-
}
|
|
2966
|
-
let refresh = false;
|
|
2967
|
-
if (cell.row >= this._sheet.rows.length) {
|
|
2968
|
-
this._insertIndices(this._sheet.rows, cell.row, 1, DEFAULT_ROWS);
|
|
2969
|
-
refresh = true;
|
|
2970
|
-
}
|
|
2971
|
-
if (cell.column >= this._sheet.columns.length) {
|
|
2972
|
-
this._insertIndices(this._sheet.columns, cell.column, 1, DEFAULT_COLUMNS);
|
|
2973
|
-
refresh = true;
|
|
2974
|
-
}
|
|
2975
|
-
if (refresh) {
|
|
2976
|
-
this.reset();
|
|
2977
|
-
}
|
|
2978
|
-
this._graph.hf.setCellContents({
|
|
2979
|
-
sheet: this._sheetId,
|
|
2980
|
-
row: cell.row,
|
|
2981
|
-
col: cell.column
|
|
2982
|
-
}, [
|
|
2983
|
-
[
|
|
2984
|
-
typeof value === "string" && value.charAt(0) === "=" ? this.mapFormulaBindingToFormula(value) : value
|
|
2824
|
+
A: [
|
|
2825
|
+
"sheetId !== undefined",
|
|
2826
|
+
""
|
|
2985
2827
|
]
|
|
2986
|
-
]);
|
|
2987
|
-
const idx = this.addressToIndex(cell);
|
|
2988
|
-
if (value === void 0 || value === null) {
|
|
2989
|
-
delete this._sheet.cells[idx];
|
|
2990
|
-
} else {
|
|
2991
|
-
if (typeof value === "string" && value.charAt(0) === "=") {
|
|
2992
|
-
value = this.mapFormulaBindingToId(this.mapFormulaRefsToIndices(value));
|
|
2993
|
-
}
|
|
2994
|
-
this._sheet.cells[idx] = {
|
|
2995
|
-
value
|
|
2996
|
-
};
|
|
2997
|
-
}
|
|
2998
|
-
}
|
|
2999
|
-
/**
|
|
3000
|
-
* Sets values from a simple map.
|
|
3001
|
-
*/
|
|
3002
|
-
setValues(values) {
|
|
3003
|
-
Object.entries(values).forEach(([key, { value }]) => {
|
|
3004
|
-
this.setValue(addressFromA1Notation(key), value);
|
|
3005
2828
|
});
|
|
2829
|
+
const node = new ComputeNode(this, sheetId);
|
|
2830
|
+
this._nodes.set(sheetId, node);
|
|
2831
|
+
return node;
|
|
3006
2832
|
}
|
|
3007
2833
|
/**
|
|
3008
|
-
*
|
|
2834
|
+
* Map bound value to custom function invocation.
|
|
2835
|
+
* E.g., "HELLO(...args)" => "EDGE("HELLO", ...args)".
|
|
3009
2836
|
*/
|
|
3010
|
-
|
|
3011
|
-
|
|
3012
|
-
|
|
3013
|
-
|
|
3014
|
-
|
|
3015
|
-
|
|
3016
|
-
|
|
3017
|
-
|
|
3018
|
-
|
|
3019
|
-
|
|
3020
|
-
|
|
3021
|
-
|
|
3022
|
-
|
|
3023
|
-
|
|
3024
|
-
|
|
3025
|
-
row,
|
|
3026
|
-
column
|
|
3027
|
-
});
|
|
3028
|
-
if (value !== void 0) {
|
|
3029
|
-
rowCells.push(value);
|
|
2837
|
+
mapFormulaToNative(formula) {
|
|
2838
|
+
return formula.replace(/['"]?([ \w]+)['"]?!/, (_match, name) => {
|
|
2839
|
+
if (name) {
|
|
2840
|
+
const objects = this._hf.getSheetNames().map((name2) => {
|
|
2841
|
+
const { type, id } = parseSheetName(name2);
|
|
2842
|
+
return type && id ? this._space?.db.getObjectById(id) : void 0;
|
|
2843
|
+
}).filter(import_util.nonNullable);
|
|
2844
|
+
for (const obj of objects) {
|
|
2845
|
+
if (obj.name === name) {
|
|
2846
|
+
const type = (0, import_echo_schema.getTypename)(obj);
|
|
2847
|
+
return `'${createSheetName({
|
|
2848
|
+
type,
|
|
2849
|
+
id: obj.id
|
|
2850
|
+
})}'!`;
|
|
2851
|
+
}
|
|
3030
2852
|
}
|
|
3031
2853
|
}
|
|
3032
|
-
|
|
3033
|
-
}
|
|
3034
|
-
|
|
3035
|
-
}
|
|
3036
|
-
/**
|
|
3037
|
-
*
|
|
3038
|
-
*/
|
|
3039
|
-
// TODO(burdon): Insert indices into sheet.
|
|
3040
|
-
_insertIndices(indices, i, n, max) {
|
|
3041
|
-
if (i + n > max) {
|
|
3042
|
-
throw new RangeException(i + n);
|
|
3043
|
-
}
|
|
3044
|
-
const idx = createIndices(n);
|
|
3045
|
-
indices.splice(i, 0, ...idx);
|
|
3046
|
-
}
|
|
3047
|
-
// TODO(burdon): Delete index.
|
|
3048
|
-
_deleteIndices(indices, i, n) {
|
|
3049
|
-
throw new Error("Not implemented");
|
|
3050
|
-
}
|
|
3051
|
-
// TODO(burdon): Move. Cannot use fractional without changing. Switch back to using unique IDs?
|
|
3052
|
-
_moveIndices(indices, i, j, n) {
|
|
3053
|
-
throw new Error("Not implemented");
|
|
3054
|
-
}
|
|
3055
|
-
//
|
|
3056
|
-
// Indices.
|
|
3057
|
-
//
|
|
3058
|
-
/**
|
|
3059
|
-
* E.g., "A1" => "x1@y1".
|
|
3060
|
-
*/
|
|
3061
|
-
addressToIndex(cell) {
|
|
3062
|
-
return `${this._sheet.columns[cell.column]}@${this._sheet.rows[cell.row]}`;
|
|
3063
|
-
}
|
|
3064
|
-
/**
|
|
3065
|
-
* E.g., "x1@y1" => "A1".
|
|
3066
|
-
*/
|
|
3067
|
-
addressFromIndex(idx) {
|
|
3068
|
-
const [column, row] = idx.split("@");
|
|
3069
|
-
return {
|
|
3070
|
-
column: this._sheet.columns.indexOf(column),
|
|
3071
|
-
row: this._sheet.rows.indexOf(row)
|
|
3072
|
-
};
|
|
3073
|
-
}
|
|
3074
|
-
/**
|
|
3075
|
-
* E.g., "A1:B2" => "x1@y1:x2@y2".
|
|
3076
|
-
*/
|
|
3077
|
-
rangeToIndex(range) {
|
|
3078
|
-
return [
|
|
3079
|
-
range.from,
|
|
3080
|
-
range.to ?? range.from
|
|
3081
|
-
].map((cell) => this.addressToIndex(cell)).join(":");
|
|
3082
|
-
}
|
|
3083
|
-
/**
|
|
3084
|
-
* E.g., "x1@y1:x2@y2" => "A1:B2".
|
|
3085
|
-
*/
|
|
3086
|
-
rangeFromIndex(idx) {
|
|
3087
|
-
const [from, to] = idx.split(":").map((idx2) => this.addressFromIndex(idx2));
|
|
3088
|
-
return {
|
|
3089
|
-
from,
|
|
3090
|
-
to
|
|
3091
|
-
};
|
|
3092
|
-
}
|
|
3093
|
-
/**
|
|
3094
|
-
* E.g., "HELLO()" => "EDGE("HELLO")".
|
|
3095
|
-
*/
|
|
3096
|
-
mapFormulaBindingToFormula(formula) {
|
|
3097
|
-
return formula.replace(/([a-zA-Z0-9]+)\((.*)\)/g, (match, binding, args) => {
|
|
3098
|
-
const fn = this._functions.find((fn2) => fn2.binding === binding);
|
|
2854
|
+
return `${name}!`;
|
|
2855
|
+
}).replace(/(\w+)\((.*)\)/g, (match, binding, args) => {
|
|
2856
|
+
const fn = this._remoteFunctions.find((fn2) => fn2.binding === binding);
|
|
3099
2857
|
if (!fn) {
|
|
3100
2858
|
return match;
|
|
3101
2859
|
}
|
|
3102
2860
|
if (args.trim() === "") {
|
|
3103
|
-
return
|
|
2861
|
+
return `${EDGE_FUNCTION_NAME}("${binding}")`;
|
|
2862
|
+
} else {
|
|
2863
|
+
return `${EDGE_FUNCTION_NAME}("${binding}", ${args})`;
|
|
3104
2864
|
}
|
|
3105
|
-
return `EDGE("${binding}", ${args})`;
|
|
3106
2865
|
});
|
|
3107
2866
|
}
|
|
3108
2867
|
/**
|
|
3109
|
-
*
|
|
2868
|
+
* Map from binding to fully qualified ECHO ID (to store).
|
|
2869
|
+
* E.g., HELLO() => spaceId:objectId()
|
|
3110
2870
|
*/
|
|
3111
|
-
|
|
3112
|
-
return formula.replace(/
|
|
3113
|
-
if (
|
|
3114
|
-
return
|
|
2871
|
+
mapFunctionBindingToId(formula) {
|
|
2872
|
+
return formula.replace(/(\w+)\((.*)\)/g, (match, binding, args) => {
|
|
2873
|
+
if (binding === EDGE_FUNCTION_NAME || defaultFunctions.find((fn2) => fn2.name === binding)) {
|
|
2874
|
+
return match;
|
|
2875
|
+
}
|
|
2876
|
+
const fn = this._remoteFunctions.find((fn2) => fn2.binding === binding);
|
|
2877
|
+
if (fn) {
|
|
2878
|
+
const id = (0, import_echo.fullyQualifiedId)(fn);
|
|
2879
|
+
return `${id}(${args})`;
|
|
2880
|
+
} else {
|
|
2881
|
+
return match;
|
|
3115
2882
|
}
|
|
3116
|
-
return `${binding}(${args.slice(2)})`;
|
|
3117
|
-
});
|
|
3118
|
-
}
|
|
3119
|
-
/**
|
|
3120
|
-
* Map from binding to fully qualified ECHO ID.
|
|
3121
|
-
*/
|
|
3122
|
-
mapFormulaBindingToId(formula) {
|
|
3123
|
-
return this._options.mapFormulaBindingToId(this._functions)(formula);
|
|
3124
|
-
}
|
|
3125
|
-
/**
|
|
3126
|
-
* Map from fully qualified ECHO ID to binding.
|
|
3127
|
-
*/
|
|
3128
|
-
mapFormulaBindingFromId(formula) {
|
|
3129
|
-
return this._options.mapFormulaBindingFromId(this._functions)(formula);
|
|
3130
|
-
}
|
|
3131
|
-
/**
|
|
3132
|
-
* Map from A1 notation to indices.
|
|
3133
|
-
*/
|
|
3134
|
-
mapFormulaRefsToIndices(formula) {
|
|
3135
|
-
(0, import_invariant.invariant)(formula.charAt(0) === "=", void 0, {
|
|
3136
|
-
F: __dxlog_file4,
|
|
3137
|
-
L: 509,
|
|
3138
|
-
S: this,
|
|
3139
|
-
A: [
|
|
3140
|
-
"formula.charAt(0) === '='",
|
|
3141
|
-
""
|
|
3142
|
-
]
|
|
3143
|
-
});
|
|
3144
|
-
return formula.replace(/([a-zA-Z]+)([0-9]+)/g, (match) => {
|
|
3145
|
-
return this.addressToIndex(addressFromA1Notation(match));
|
|
3146
2883
|
});
|
|
3147
2884
|
}
|
|
3148
2885
|
/**
|
|
3149
|
-
* Map from
|
|
2886
|
+
* Map from fully qualified ECHO ID to binding (from store).
|
|
2887
|
+
* E.g., spaceId:objectId() => HELLO()
|
|
3150
2888
|
*/
|
|
3151
|
-
|
|
3152
|
-
|
|
3153
|
-
|
|
3154
|
-
|
|
3155
|
-
|
|
3156
|
-
|
|
3157
|
-
|
|
3158
|
-
|
|
3159
|
-
|
|
3160
|
-
|
|
3161
|
-
|
|
3162
|
-
|
|
2889
|
+
mapFunctionBindingFromId(formula) {
|
|
2890
|
+
return formula.replace(/(\w+):([a-zA-Z0-9]+)\((.*)\)/g, (match, spaceId, objectId, args) => {
|
|
2891
|
+
const id = `${spaceId}:${objectId}`;
|
|
2892
|
+
if (id.length !== OBJECT_ID_LENGTH) {
|
|
2893
|
+
return match;
|
|
2894
|
+
}
|
|
2895
|
+
const fn = this._remoteFunctions.find((fn2) => (0, import_echo.fullyQualifiedId)(fn2) === id);
|
|
2896
|
+
if (fn?.binding) {
|
|
2897
|
+
return `${fn.binding}(${args})`;
|
|
2898
|
+
} else {
|
|
2899
|
+
return match;
|
|
2900
|
+
}
|
|
3163
2901
|
});
|
|
3164
2902
|
}
|
|
3165
|
-
|
|
3166
|
-
|
|
3167
|
-
|
|
3168
|
-
|
|
3169
|
-
|
|
3170
|
-
|
|
3171
|
-
|
|
3172
|
-
|
|
3173
|
-
|
|
3174
|
-
|
|
3175
|
-
|
|
3176
|
-
}
|
|
3177
|
-
toDateTime(num) {
|
|
3178
|
-
return this._graph.hf.numberToDateTime(num);
|
|
3179
|
-
}
|
|
3180
|
-
toDate(num) {
|
|
3181
|
-
return this._graph.hf.numberToDate(num);
|
|
2903
|
+
async _open() {
|
|
2904
|
+
if (this._space) {
|
|
2905
|
+
const query = this._space.db.query(import_echo.Filter.schema(import_types.FunctionType));
|
|
2906
|
+
const unsubscribe = query.subscribe(({ objects }) => {
|
|
2907
|
+
this._remoteFunctions = objects.filter(({ binding }) => binding);
|
|
2908
|
+
this.update.emit({
|
|
2909
|
+
type: "functionsUpdated"
|
|
2910
|
+
});
|
|
2911
|
+
});
|
|
2912
|
+
this._ctx.onDispose(unsubscribe);
|
|
2913
|
+
}
|
|
3182
2914
|
}
|
|
3183
|
-
|
|
3184
|
-
|
|
2915
|
+
async _close() {
|
|
2916
|
+
for (const node of this._nodes.values()) {
|
|
2917
|
+
await node.close();
|
|
2918
|
+
}
|
|
3185
2919
|
}
|
|
3186
2920
|
};
|
|
3187
|
-
var
|
|
3188
|
-
|
|
2921
|
+
var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/graph/compute-graph-registry.ts";
|
|
2922
|
+
var defaultOptions = {
|
|
2923
|
+
licenseKey: "gpl-v3"
|
|
3189
2924
|
};
|
|
3190
|
-
var
|
|
3191
|
-
|
|
3192
|
-
|
|
3193
|
-
|
|
3194
|
-
};
|
|
3195
|
-
return this.runAsyncFunction(ast, state, handler);
|
|
2925
|
+
var defaultPlugins = [
|
|
2926
|
+
{
|
|
2927
|
+
plugin: EdgeFunctionPlugin,
|
|
2928
|
+
translations: EdgeFunctionPluginTranslations
|
|
3196
2929
|
}
|
|
3197
|
-
|
|
3198
|
-
|
|
3199
|
-
|
|
3200
|
-
|
|
3201
|
-
|
|
3202
|
-
|
|
3203
|
-
|
|
3204
|
-
|
|
3205
|
-
|
|
3206
|
-
|
|
3207
|
-
if (!rate) {
|
|
3208
|
-
return NaN;
|
|
3209
|
-
}
|
|
3210
|
-
return parseNumberString(rate);
|
|
3211
|
-
};
|
|
3212
|
-
return this.runAsyncFunction(ast, state, handler, {
|
|
3213
|
-
ttl: 1e4
|
|
2930
|
+
];
|
|
2931
|
+
var ComputeGraphRegistry = class extends import_context3.Resource {
|
|
2932
|
+
constructor(options = {
|
|
2933
|
+
plugins: defaultPlugins
|
|
2934
|
+
}) {
|
|
2935
|
+
super();
|
|
2936
|
+
this._graphs = /* @__PURE__ */ new Map();
|
|
2937
|
+
this._options = (0, import_lodash2.default)({}, options, defaultOptions);
|
|
2938
|
+
this._options.plugins?.forEach(({ plugin, translations }) => {
|
|
2939
|
+
import_hyperformula5.HyperFormula.registerFunctionPlugin(plugin, translations);
|
|
3214
2940
|
});
|
|
3215
2941
|
}
|
|
3216
|
-
|
|
3217
|
-
|
|
3218
|
-
|
|
3219
|
-
|
|
3220
|
-
|
|
3221
|
-
|
|
3222
|
-
|
|
3223
|
-
|
|
3224
|
-
|
|
3225
|
-
|
|
3226
|
-
|
|
3227
|
-
|
|
3228
|
-
|
|
3229
|
-
}
|
|
3230
|
-
|
|
3231
|
-
|
|
2942
|
+
getGraph(spaceId) {
|
|
2943
|
+
return this._graphs.get(spaceId);
|
|
2944
|
+
}
|
|
2945
|
+
getOrCreateGraph(space) {
|
|
2946
|
+
let graph = this._graphs.get(space.id);
|
|
2947
|
+
if (!graph) {
|
|
2948
|
+
(0, import_log4.log)("create graph", {
|
|
2949
|
+
space: space.id
|
|
2950
|
+
}, {
|
|
2951
|
+
F: __dxlog_file4,
|
|
2952
|
+
L: 69,
|
|
2953
|
+
S: this,
|
|
2954
|
+
C: (f, a) => f(...a)
|
|
2955
|
+
});
|
|
2956
|
+
graph = this.createGraph(space);
|
|
2957
|
+
}
|
|
2958
|
+
return graph;
|
|
3232
2959
|
}
|
|
3233
|
-
|
|
3234
|
-
|
|
3235
|
-
|
|
3236
|
-
|
|
3237
|
-
|
|
3238
|
-
|
|
3239
|
-
|
|
3240
|
-
|
|
3241
|
-
|
|
2960
|
+
createGraph(space) {
|
|
2961
|
+
(0, import_invariant2.invariant)(!this._graphs.has(space.id), `ComputeGraph already exists for space: ${space.id}`, {
|
|
2962
|
+
F: __dxlog_file4,
|
|
2963
|
+
L: 77,
|
|
2964
|
+
S: this,
|
|
2965
|
+
A: [
|
|
2966
|
+
"!this._graphs.has(space.id)",
|
|
2967
|
+
"`ComputeGraph already exists for space: ${space.id}`"
|
|
2968
|
+
]
|
|
2969
|
+
});
|
|
2970
|
+
const hf = import_hyperformula5.HyperFormula.buildEmpty(this._options);
|
|
2971
|
+
const graph = new ComputeGraph(hf, space, this._options);
|
|
2972
|
+
this._graphs.set(space.id, graph);
|
|
2973
|
+
return graph;
|
|
2974
|
+
}
|
|
2975
|
+
async _close() {
|
|
2976
|
+
for (const graph of this._graphs.values()) {
|
|
2977
|
+
await graph.close();
|
|
2978
|
+
}
|
|
2979
|
+
this._graphs.clear();
|
|
3242
2980
|
}
|
|
3243
2981
|
};
|
|
3244
2982
|
// Annotate the CommonJS export names for ESM import in node:
|
|
3245
2983
|
0 && (module.exports = {
|
|
3246
|
-
|
|
3247
|
-
|
|
3248
|
-
|
|
3249
|
-
|
|
3250
|
-
|
|
3251
|
-
|
|
3252
|
-
|
|
3253
|
-
|
|
2984
|
+
AsyncFunctionPlugin,
|
|
2985
|
+
ComputeGraph,
|
|
2986
|
+
ComputeGraphRegistry,
|
|
2987
|
+
ComputeNode,
|
|
2988
|
+
EDGE_FUNCTION_NAME,
|
|
2989
|
+
EdgeFunctionPlugin,
|
|
2990
|
+
EdgeFunctionPluginTranslations,
|
|
2991
|
+
FunctionContext,
|
|
2992
|
+
createSheetName,
|
|
2993
|
+
defaultFunctionContextOptions,
|
|
3254
2994
|
defaultFunctions,
|
|
3255
|
-
|
|
3256
|
-
|
|
3257
|
-
|
|
2995
|
+
defaultOptions,
|
|
2996
|
+
defaultPlugins,
|
|
2997
|
+
parseSheetName
|
|
3258
2998
|
});
|
|
3259
|
-
//# sourceMappingURL=chunk-
|
|
2999
|
+
//# sourceMappingURL=chunk-5XPK2V4A.cjs.map
|