@dxos/plugin-sheet 0.6.14-main.7bd9c89 → 0.6.14-main.8b352a0
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-AKWROARP.mjs → SheetContainer-R65IDJHN.mjs} +54 -58
- package/dist/lib/browser/SheetContainer-R65IDJHN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-BWN5DZWZ.mjs → chunk-5KVQ5IPW.mjs} +3 -12
- package/dist/lib/browser/chunk-5KVQ5IPW.mjs.map +7 -0
- package/dist/lib/browser/{chunk-FGMFOW6U.mjs → chunk-I2DKJ72A.mjs} +570 -669
- package/dist/lib/browser/chunk-I2DKJ72A.mjs.map +7 -0
- package/dist/lib/browser/{chunk-GSV5QNLD.mjs → chunk-KCYJSOFB.mjs} +252 -33
- package/dist/lib/browser/chunk-KCYJSOFB.mjs.map +7 -0
- package/dist/lib/browser/{graph-M4IQ76QX.mjs → compute-graph-SJT67236.mjs} +4 -2
- package/dist/lib/browser/index.mjs +62 -20
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/types.mjs +1 -1
- package/dist/lib/node/{SheetContainer-N5IQGEFL.cjs → SheetContainer-6BO4C5X2.cjs} +52 -62
- package/dist/lib/node/SheetContainer-6BO4C5X2.cjs.map +7 -0
- package/dist/lib/node/{chunk-NZARD7UP.cjs → chunk-2XJ5I4UF.cjs} +6 -15
- package/dist/lib/node/chunk-2XJ5I4UF.cjs.map +7 -0
- package/dist/lib/node/{chunk-53BMSUIK.cjs → chunk-DEPJHN47.cjs} +534 -646
- package/dist/lib/node/chunk-DEPJHN47.cjs.map +7 -0
- package/dist/lib/node/{chunk-5XPK2V4A.cjs → chunk-JF5XNTF3.cjs} +257 -28
- package/dist/lib/node/chunk-JF5XNTF3.cjs.map +7 -0
- package/dist/lib/node/{graph-Q3N2X26H.cjs → compute-graph-AQBDL7HO.cjs} +21 -19
- package/dist/lib/node/compute-graph-AQBDL7HO.cjs.map +7 -0
- package/dist/lib/node/index.cjs +70 -31
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/types.cjs +6 -6
- package/dist/lib/node/types.cjs.map +1 -1
- package/dist/lib/node-esm/{SheetContainer-46PBMF2E.mjs → SheetContainer-MJXC5E3P.mjs} +54 -58
- package/dist/lib/node-esm/SheetContainer-MJXC5E3P.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-T3PRH7QS.mjs → chunk-25V7WY4R.mjs} +570 -669
- package/dist/lib/node-esm/chunk-25V7WY4R.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-WFDTY3IC.mjs → chunk-5TXLF6PL.mjs} +3 -12
- package/dist/lib/node-esm/chunk-5TXLF6PL.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-5WPZCXNS.mjs → chunk-XBEHKYO7.mjs} +251 -33
- package/dist/lib/node-esm/chunk-XBEHKYO7.mjs.map +7 -0
- package/dist/lib/node-esm/{graph-SMPUMOV2.mjs → compute-graph-FRCKXEYK.mjs} +4 -2
- package/dist/lib/node-esm/index.mjs +62 -20
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/types.mjs +1 -1
- package/dist/types/src/SheetPlugin.d.ts.map +1 -1
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts +3 -1
- package/dist/types/src/components/ComputeGraph/ComputeGraphContextProvider.d.ts.map +1 -1
- package/dist/types/src/components/GridSheet/GridSheet.d.ts.map +1 -1
- package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts.map +1 -1
- package/dist/types/src/components/GridSheet/util.d.ts +1 -2
- package/dist/types/src/components/GridSheet/util.d.ts.map +1 -1
- package/dist/types/src/components/RangeList/RangeList.d.ts +7 -0
- package/dist/types/src/components/RangeList/RangeList.d.ts.map +1 -0
- package/dist/types/src/components/RangeList/index.d.ts +2 -0
- package/dist/types/src/components/RangeList/index.d.ts.map +1 -0
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts +6 -3
- package/dist/types/src/components/SheetContainer/SheetContainer.d.ts.map +1 -1
- package/dist/types/src/components/SheetContext/SheetContext.d.ts +7 -5
- package/dist/types/src/components/SheetContext/SheetContext.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +5 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/compute-graph/compute-graph-registry.d.ts.map +1 -0
- package/dist/types/src/{graph → compute-graph}/compute-graph.d.ts +1 -1
- package/dist/types/src/compute-graph/compute-graph.d.ts.map +1 -0
- package/dist/types/src/compute-graph/compute-graph.stories.d.ts.map +1 -0
- package/dist/types/src/compute-graph/compute-graph.test.d.ts.map +1 -0
- package/dist/types/src/compute-graph/compute-node.d.ts.map +1 -0
- package/dist/types/src/compute-graph/functions/async-function.d.ts.map +1 -0
- package/dist/types/src/compute-graph/functions/edge-function.d.ts.map +1 -0
- package/dist/types/src/compute-graph/functions/function-defs.d.ts.map +1 -0
- package/dist/types/src/compute-graph/functions/index.d.ts.map +1 -0
- package/dist/types/src/compute-graph/hyperformula.test.d.ts.map +1 -0
- package/dist/types/src/compute-graph/index.d.ts.map +1 -0
- package/dist/types/src/compute-graph/testing/index.d.ts.map +1 -0
- package/dist/types/src/compute-graph/testing/test-builder.d.ts.map +1 -0
- package/dist/types/src/compute-graph/testing/test-plugin.d.ts.map +1 -0
- package/dist/types/src/compute-graph/util.d.ts.map +1 -0
- package/dist/types/src/defs/index.d.ts +1 -1
- package/dist/types/src/defs/index.d.ts.map +1 -1
- package/dist/types/src/defs/sheet-range-types.d.ts +1 -1
- package/dist/types/src/defs/sheet-range-types.d.ts.map +1 -1
- package/dist/types/src/defs/types.d.ts +6 -0
- package/dist/types/src/defs/types.d.ts.map +1 -1
- package/dist/types/src/defs/util.d.ts +2 -6
- package/dist/types/src/defs/util.d.ts.map +1 -1
- package/dist/types/src/extensions/compute.d.ts +1 -1
- package/dist/types/src/extensions/compute.d.ts.map +1 -1
- package/dist/types/src/extensions/editor/extension.d.ts +23 -3
- package/dist/types/src/extensions/editor/extension.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/integrations/index.d.ts +2 -0
- package/dist/types/src/integrations/index.d.ts.map +1 -0
- package/dist/types/src/integrations/thread-ranges.d.ts +7 -0
- package/dist/types/src/integrations/thread-ranges.d.ts.map +1 -0
- package/dist/types/src/model/index.d.ts +1 -1
- package/dist/types/src/model/index.d.ts.map +1 -1
- package/dist/types/src/model/sheet-model.d.ts +1 -1
- package/dist/types/src/model/sheet-model.d.ts.map +1 -1
- package/dist/types/src/{hooks → model}/useSheetModel.d.ts +1 -1
- package/dist/types/src/model/useSheetModel.d.ts.map +1 -0
- package/dist/types/src/serializer.d.ts +4 -0
- package/dist/types/src/serializer.d.ts.map +1 -0
- package/dist/types/src/testing/testing.d.ts +1 -1
- package/dist/types/src/testing/testing.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +13 -3
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +4 -30
- package/dist/types/src/types.d.ts.map +1 -1
- package/package.json +43 -50
- package/src/SheetPlugin.tsx +25 -12
- package/src/components/ComputeGraph/ComputeGraphContextProvider.tsx +19 -2
- package/src/components/FunctionEditor/FunctionEditor.tsx +5 -5
- package/src/components/GridSheet/GridSheet.stories.tsx +3 -1
- package/src/components/GridSheet/GridSheet.tsx +118 -22
- package/src/components/GridSheet/SheetCellEditor.stories.tsx +1 -1
- package/src/components/GridSheet/util.ts +24 -14
- package/src/components/RangeList/RangeList.tsx +53 -0
- package/src/components/RangeList/index.ts +5 -0
- package/src/components/SheetContainer/SheetContainer.stories.tsx +3 -3
- package/src/components/SheetContainer/SheetContainer.tsx +10 -4
- package/src/components/SheetContext/SheetContext.tsx +43 -20
- package/src/components/Toolbar/Toolbar.tsx +44 -41
- package/src/components/index.ts +1 -0
- package/src/{graph → compute-graph}/compute-graph.stories.tsx +2 -1
- package/src/{graph → compute-graph}/compute-graph.ts +5 -2
- package/src/{graph → compute-graph}/compute-node.ts +2 -3
- package/src/defs/index.ts +1 -1
- package/src/defs/sheet-range-types.ts +5 -4
- package/src/defs/types.ts +6 -1
- package/src/defs/util.ts +3 -19
- package/src/extensions/compute.stories.tsx +2 -2
- package/src/extensions/compute.ts +2 -2
- package/src/extensions/editor/extension.test.ts +1 -1
- package/src/extensions/editor/extension.ts +48 -23
- package/src/index.ts +2 -2
- package/src/integrations/index.ts +5 -0
- package/src/integrations/thread-ranges.ts +101 -0
- package/src/model/index.ts +1 -1
- package/src/model/sheet-model.test.ts +1 -1
- package/src/model/sheet-model.ts +13 -8
- package/src/{hooks → model}/useSheetModel.ts +1 -1
- package/src/serializer.ts +27 -0
- package/src/testing/testing.tsx +1 -1
- package/src/translations.ts +13 -3
- package/src/types.ts +4 -2
- package/dist/lib/browser/SheetContainer-AKWROARP.mjs.map +0 -7
- package/dist/lib/browser/chunk-BWN5DZWZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-FGMFOW6U.mjs.map +0 -7
- package/dist/lib/browser/chunk-GSV5QNLD.mjs.map +0 -7
- package/dist/lib/node/SheetContainer-N5IQGEFL.cjs.map +0 -7
- package/dist/lib/node/chunk-53BMSUIK.cjs.map +0 -7
- package/dist/lib/node/chunk-5XPK2V4A.cjs.map +0 -7
- package/dist/lib/node/chunk-NZARD7UP.cjs.map +0 -7
- package/dist/lib/node/graph-Q3N2X26H.cjs.map +0 -7
- package/dist/lib/node-esm/SheetContainer-46PBMF2E.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5WPZCXNS.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-T3PRH7QS.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WFDTY3IC.mjs.map +0 -7
- package/dist/types/src/graph/compute-graph-registry.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.stories.d.ts.map +0 -1
- package/dist/types/src/graph/compute-graph.test.d.ts.map +0 -1
- 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.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.map +0 -1
- package/dist/types/src/graph/hyperformula.test.d.ts.map +0 -1
- package/dist/types/src/graph/index.d.ts.map +0 -1
- package/dist/types/src/graph/testing/index.d.ts.map +0 -1
- package/dist/types/src/graph/testing/test-builder.d.ts.map +0 -1
- package/dist/types/src/graph/testing/test-plugin.d.ts.map +0 -1
- package/dist/types/src/graph/util.d.ts.map +0 -1
- package/dist/types/src/hooks/hooks.stories.d.ts +0 -6
- 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.map +0 -1
- package/dist/types/src/model/decorations.d.ts +0 -26
- package/dist/types/src/model/decorations.d.ts.map +0 -1
- package/src/hooks/hooks.stories.tsx +0 -53
- package/src/hooks/index.ts +0 -7
- package/src/hooks/threads.ts +0 -147
- package/src/hooks/useComputeGraph.ts +0 -28
- package/src/model/decorations.ts +0 -66
- /package/dist/lib/browser/{graph-M4IQ76QX.mjs.map → compute-graph-SJT67236.mjs.map} +0 -0
- /package/dist/lib/node-esm/{graph-SMPUMOV2.mjs.map → compute-graph-FRCKXEYK.mjs.map} +0 -0
- /package/dist/types/src/{graph → compute-graph}/compute-graph-registry.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/compute-graph.stories.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/compute-graph.test.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/compute-node.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/functions/async-function.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/functions/edge-function.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/functions/function-defs.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/functions/index.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/hyperformula.test.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/index.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/testing/index.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/testing/test-builder.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/testing/test-plugin.d.ts +0 -0
- /package/dist/types/src/{graph → compute-graph}/util.d.ts +0 -0
- /package/src/{graph → compute-graph}/compute-graph-registry.ts +0 -0
- /package/src/{graph → compute-graph}/compute-graph.test.ts +0 -0
- /package/src/{graph → compute-graph}/functions/async-function.ts +0 -0
- /package/src/{graph → compute-graph}/functions/edge-function.ts +0 -0
- /package/src/{graph → compute-graph}/functions/function-defs.ts +0 -0
- /package/src/{graph → compute-graph}/functions/index.ts +0 -0
- /package/src/{graph → compute-graph}/hyperformula.test.ts +0 -0
- /package/src/{graph → compute-graph}/index.ts +0 -0
- /package/src/{graph → compute-graph}/testing/index.ts +0 -0
- /package/src/{graph → compute-graph}/testing/test-builder.ts +0 -0
- /package/src/{graph → compute-graph}/testing/test-plugin.ts +0 -0
- /package/src/{graph → compute-graph}/util.ts +0 -0
|
@@ -1,15 +1,34 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
|
|
2
|
+
DEFAULT_COLUMNS,
|
|
3
|
+
DEFAULT_ROWS,
|
|
4
|
+
MAX_COLUMNS,
|
|
5
|
+
MAX_ROWS,
|
|
6
|
+
RANGE_NOTATION,
|
|
7
|
+
ReadonlyException,
|
|
8
|
+
addressFromA1Notation,
|
|
9
|
+
addressFromIndex,
|
|
10
|
+
addressToA1Notation,
|
|
11
|
+
addressToIndex,
|
|
12
|
+
cellClassNameForRange,
|
|
13
|
+
createSheetName,
|
|
14
|
+
inRange,
|
|
15
|
+
initialize,
|
|
16
|
+
insertIndices,
|
|
17
|
+
isFormula,
|
|
18
|
+
rangeFromIndex,
|
|
19
|
+
rangeToA1Notation
|
|
20
|
+
} from "./chunk-KCYJSOFB.mjs";
|
|
21
|
+
import {
|
|
22
|
+
Range
|
|
23
|
+
} from "./chunk-5KVQ5IPW.mjs";
|
|
4
24
|
import {
|
|
5
25
|
SHEET_PLUGIN
|
|
6
26
|
} from "./chunk-D3QTX46O.mjs";
|
|
7
|
-
import {
|
|
8
|
-
createSheetName
|
|
9
|
-
} from "./chunk-GSV5QNLD.mjs";
|
|
10
27
|
|
|
11
28
|
// packages/plugins/plugin-sheet/src/components/ComputeGraph/ComputeGraphContextProvider.tsx
|
|
12
|
-
import React, { createContext } from "react";
|
|
29
|
+
import React, { createContext, useContext } from "react";
|
|
30
|
+
import { raise } from "@dxos/debug";
|
|
31
|
+
import { useAsyncState } from "@dxos/react-hooks";
|
|
13
32
|
var ComputeGraphContext = /* @__PURE__ */ createContext(void 0);
|
|
14
33
|
var ComputeGraphContextProvider = ({ registry, children }) => {
|
|
15
34
|
return /* @__PURE__ */ React.createElement(ComputeGraphContext.Provider, {
|
|
@@ -18,192 +37,19 @@ var ComputeGraphContextProvider = ({ registry, children }) => {
|
|
|
18
37
|
}
|
|
19
38
|
}, children);
|
|
20
39
|
};
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/defs/types.ts";
|
|
29
|
-
var DEFAULT_ROWS = 50;
|
|
30
|
-
var DEFAULT_COLUMNS = 26;
|
|
31
|
-
var MAX_ROWS = 500;
|
|
32
|
-
var MAX_COLUMNS = 26 * 2;
|
|
33
|
-
var posEquals = (a, b) => {
|
|
34
|
-
return a?.col === b?.col && a?.row === b?.row;
|
|
35
|
-
};
|
|
36
|
-
var columnLetter = (col) => {
|
|
37
|
-
invariant(col < MAX_COLUMNS, `Invalid column: ${col}`, {
|
|
38
|
-
F: __dxlog_file,
|
|
39
|
-
L: 26,
|
|
40
|
-
S: void 0,
|
|
41
|
-
A: [
|
|
42
|
-
"col < MAX_COLUMNS",
|
|
43
|
-
"`Invalid column: ${col}`"
|
|
44
|
-
]
|
|
45
|
-
});
|
|
46
|
-
return (col >= 26 ? String.fromCharCode("A".charCodeAt(0) + Math.floor(col / 26) - 1) : "") + String.fromCharCode("A".charCodeAt(0) + col % 26);
|
|
47
|
-
};
|
|
48
|
-
var addressToA1Notation = ({ col, row }) => {
|
|
49
|
-
return `${columnLetter(col)}${row + 1}`;
|
|
50
|
-
};
|
|
51
|
-
var addressFromA1Notation = (ref) => {
|
|
52
|
-
const match = ref.match(/([A-Z]+)(\d+)/);
|
|
53
|
-
invariant(match, `Invalid notation: ${ref}`, {
|
|
54
|
-
F: __dxlog_file,
|
|
55
|
-
L: 40,
|
|
56
|
-
S: void 0,
|
|
57
|
-
A: [
|
|
58
|
-
"match",
|
|
59
|
-
"`Invalid notation: ${ref}`"
|
|
60
|
-
]
|
|
61
|
-
});
|
|
62
|
-
return {
|
|
63
|
-
row: parseInt(match[2], 10) - 1,
|
|
64
|
-
col: match[1].split("").reduce((acc, c) => acc * 26 + c.charCodeAt(0) - "A".charCodeAt(0) + 1, 0) - 1
|
|
65
|
-
};
|
|
66
|
-
};
|
|
67
|
-
var rangeToA1Notation = (range) => {
|
|
68
|
-
return [
|
|
69
|
-
range?.from && addressToA1Notation(range?.from),
|
|
70
|
-
range?.to && addressToA1Notation(range?.to)
|
|
71
|
-
].filter(Boolean).join(":");
|
|
72
|
-
};
|
|
73
|
-
var inRange = (range, cell) => {
|
|
74
|
-
if (!range) {
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
const { from, to } = range;
|
|
78
|
-
if (from && posEquals(from, cell) || to && posEquals(to, cell)) {
|
|
79
|
-
return true;
|
|
80
|
-
}
|
|
81
|
-
if (!from || !to) {
|
|
82
|
-
return false;
|
|
83
|
-
}
|
|
84
|
-
const { col: c1, row: r1 } = from;
|
|
85
|
-
const { col: c2, row: r2 } = to;
|
|
86
|
-
const cMin = Math.min(c1, c2);
|
|
87
|
-
const cMax = Math.max(c1, c2);
|
|
88
|
-
const rMin = Math.min(r1, r2);
|
|
89
|
-
const rMax = Math.max(r1, r2);
|
|
90
|
-
const { col, row } = cell;
|
|
91
|
-
return col >= cMin && col <= cMax && row >= rMin && row <= rMax;
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
// packages/plugins/plugin-sheet/src/defs/util.ts
|
|
95
|
-
var ApiError = class extends Error {
|
|
96
|
-
};
|
|
97
|
-
var ReadonlyException = class extends ApiError {
|
|
98
|
-
};
|
|
99
|
-
var RangeException = class extends ApiError {
|
|
100
|
-
constructor(n) {
|
|
101
|
-
super();
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
var createIndex = (length = 8) => {
|
|
105
|
-
const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
|
106
|
-
const charactersLength = characters.length;
|
|
107
|
-
const randomBuffer = randomBytes(length);
|
|
108
|
-
return Array.from(randomBuffer, (byte) => characters[byte % charactersLength]).join("");
|
|
109
|
-
};
|
|
110
|
-
var createIndices = (length) => Array.from({
|
|
111
|
-
length
|
|
112
|
-
}).map(() => createIndex());
|
|
113
|
-
var insertIndices = (indices, i, n, max) => {
|
|
114
|
-
if (i + n > max) {
|
|
115
|
-
throw new RangeException(i + n);
|
|
116
|
-
}
|
|
117
|
-
const idx = createIndices(n);
|
|
118
|
-
indices.splice(i, 0, ...idx);
|
|
119
|
-
};
|
|
120
|
-
var initialize = (sheet, { rows = DEFAULT_ROWS, columns = DEFAULT_COLUMNS } = {}) => {
|
|
121
|
-
if (!sheet.rows.length) {
|
|
122
|
-
insertIndices(sheet.rows, 0, rows, MAX_ROWS);
|
|
123
|
-
}
|
|
124
|
-
if (!sheet.columns.length) {
|
|
125
|
-
insertIndices(sheet.columns, 0, columns, MAX_COLUMNS);
|
|
126
|
-
}
|
|
127
|
-
};
|
|
128
|
-
var createSheet = ({ name, cells, ...size } = {}) => {
|
|
129
|
-
const sheet = create(SheetType, {
|
|
130
|
-
name,
|
|
131
|
-
cells: {},
|
|
132
|
-
rows: [],
|
|
133
|
-
columns: [],
|
|
134
|
-
rowMeta: {},
|
|
135
|
-
columnMeta: {},
|
|
136
|
-
ranges: []
|
|
137
|
-
});
|
|
138
|
-
initialize(sheet, size);
|
|
139
|
-
if (cells) {
|
|
140
|
-
Object.entries(cells).forEach(([key, { value }]) => {
|
|
141
|
-
const idx = addressToIndex(sheet, addressFromA1Notation(key));
|
|
142
|
-
sheet.cells[idx] = {
|
|
143
|
-
value
|
|
144
|
-
};
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
return sheet;
|
|
148
|
-
};
|
|
149
|
-
var addressToIndex = (sheet, cell) => {
|
|
150
|
-
return `${sheet.columns[cell.col]}@${sheet.rows[cell.row]}`;
|
|
151
|
-
};
|
|
152
|
-
var addressFromIndex = (sheet, idx) => {
|
|
153
|
-
const [column, row] = idx.split("@");
|
|
154
|
-
return {
|
|
155
|
-
col: sheet.columns.indexOf(column),
|
|
156
|
-
row: sheet.rows.indexOf(row)
|
|
157
|
-
};
|
|
158
|
-
};
|
|
159
|
-
var closest = (cursor, cells) => {
|
|
160
|
-
let closestCell2;
|
|
161
|
-
let closestDistance = Number.MAX_SAFE_INTEGER;
|
|
162
|
-
for (const cell of cells) {
|
|
163
|
-
const distance = Math.abs(cell.row - cursor.row) + Math.abs(cell.col - cursor.col);
|
|
164
|
-
if (distance < closestDistance) {
|
|
165
|
-
closestCell2 = cell;
|
|
166
|
-
closestDistance = distance;
|
|
40
|
+
var useComputeGraph = (space) => {
|
|
41
|
+
const { registry } = useContext(ComputeGraphContext) ?? raise(new Error("Missing ComputeGraphContext"));
|
|
42
|
+
const [graph] = useAsyncState(async () => {
|
|
43
|
+
if (space) {
|
|
44
|
+
const graph2 = registry.getOrCreateGraph(space);
|
|
45
|
+
await graph2.open();
|
|
46
|
+
return graph2;
|
|
167
47
|
}
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
const { row: rowB, col: columnB } = addressFromIndex(sheet, indexB);
|
|
174
|
-
if (rowA !== rowB) {
|
|
175
|
-
return rowA - rowB;
|
|
176
|
-
} else {
|
|
177
|
-
return columnA - columnB;
|
|
178
|
-
}
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
// packages/plugins/plugin-sheet/src/defs/sheet-range-types.ts
|
|
182
|
-
var cellClassNameForRange = ({ key, value }) => {
|
|
183
|
-
switch (key) {
|
|
184
|
-
case "align":
|
|
185
|
-
switch (value) {
|
|
186
|
-
case "start":
|
|
187
|
-
return "text-start";
|
|
188
|
-
case "center":
|
|
189
|
-
return "text-center";
|
|
190
|
-
case "end":
|
|
191
|
-
return "text-end";
|
|
192
|
-
default:
|
|
193
|
-
return void 0;
|
|
194
|
-
}
|
|
195
|
-
case "comment":
|
|
196
|
-
return "bg-gridComment";
|
|
197
|
-
case "style":
|
|
198
|
-
switch (value) {
|
|
199
|
-
case "highlight":
|
|
200
|
-
return "bg-gridHighlight";
|
|
201
|
-
default:
|
|
202
|
-
return void 0;
|
|
203
|
-
}
|
|
204
|
-
default:
|
|
205
|
-
return void 0;
|
|
206
|
-
}
|
|
48
|
+
}, [
|
|
49
|
+
space,
|
|
50
|
+
registry
|
|
51
|
+
]);
|
|
52
|
+
return graph;
|
|
207
53
|
};
|
|
208
54
|
|
|
209
55
|
// packages/plugins/plugin-sheet/src/extensions/compute.ts
|
|
@@ -211,8 +57,8 @@ import { syntaxTree } from "@codemirror/language";
|
|
|
211
57
|
import { RangeSetBuilder, StateEffect, StateField } from "@codemirror/state";
|
|
212
58
|
import { Decoration, EditorView, ViewPlugin, WidgetType } from "@codemirror/view";
|
|
213
59
|
import { debounce } from "@dxos/async";
|
|
214
|
-
import { invariant
|
|
215
|
-
import { documentId, singleValueFacet } from "@dxos/react-ui-editor
|
|
60
|
+
import { invariant } from "@dxos/invariant";
|
|
61
|
+
import { documentId, singleValueFacet } from "@dxos/react-ui-editor";
|
|
216
62
|
var updateAllDecorations = StateEffect.define();
|
|
217
63
|
var computeGraphFacet = singleValueFacet();
|
|
218
64
|
|
|
@@ -222,7 +68,7 @@ import { HighlightStyle, syntaxHighlighting } from "@codemirror/language";
|
|
|
222
68
|
import { ViewPlugin as ViewPlugin2, keymap } from "@codemirror/view";
|
|
223
69
|
import { tags } from "@lezer/highlight";
|
|
224
70
|
import { spreadsheet } from "codemirror-lang-spreadsheet";
|
|
225
|
-
import { singleValueFacet as singleValueFacet2 } from "@dxos/react-ui-editor
|
|
71
|
+
import { singleValueFacet as singleValueFacet2 } from "@dxos/react-ui-editor";
|
|
226
72
|
import { mx } from "@dxos/react-ui-theme";
|
|
227
73
|
var highlightStyles = HighlightStyle.define([
|
|
228
74
|
// Function.
|
|
@@ -346,27 +192,29 @@ var sheetExtension = ({ functions = [] }) => {
|
|
|
346
192
|
])
|
|
347
193
|
];
|
|
348
194
|
};
|
|
349
|
-
var rangeExtension = (onInit) => {
|
|
195
|
+
var rangeExtension = ({ onInit, onStateChange }) => {
|
|
350
196
|
let view;
|
|
351
197
|
let activeRange;
|
|
352
|
-
const
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
198
|
+
const notifier = {
|
|
199
|
+
setRange: (range) => {
|
|
200
|
+
if (activeRange) {
|
|
201
|
+
view.dispatch(view.state.update({
|
|
202
|
+
changes: {
|
|
203
|
+
...activeRange,
|
|
204
|
+
insert: range.toString()
|
|
205
|
+
},
|
|
206
|
+
selection: {
|
|
207
|
+
anchor: activeRange.from + range.length
|
|
208
|
+
}
|
|
209
|
+
}));
|
|
210
|
+
}
|
|
211
|
+
view.focus();
|
|
363
212
|
}
|
|
364
|
-
view.focus();
|
|
365
213
|
};
|
|
366
214
|
return ViewPlugin2.fromClass(class {
|
|
367
215
|
constructor(_view) {
|
|
368
216
|
view = _view;
|
|
369
|
-
onInit(
|
|
217
|
+
onInit?.(notifier);
|
|
370
218
|
}
|
|
371
219
|
update(view2) {
|
|
372
220
|
const { anchor } = view2.state.selection.ranges[0];
|
|
@@ -376,20 +224,18 @@ var rangeExtension = (onInit) => {
|
|
|
376
224
|
visitTree(topNode, ({ type, from, to }) => {
|
|
377
225
|
if (from <= anchor && to >= anchor) {
|
|
378
226
|
switch (type.name) {
|
|
379
|
-
case "Function":
|
|
227
|
+
case "Function":
|
|
380
228
|
activeRange = {
|
|
381
229
|
from: to,
|
|
382
230
|
to
|
|
383
231
|
};
|
|
384
232
|
break;
|
|
385
|
-
|
|
386
|
-
case "CloseParen": {
|
|
233
|
+
case "CloseParen":
|
|
387
234
|
activeRange = {
|
|
388
235
|
from,
|
|
389
236
|
to: from
|
|
390
237
|
};
|
|
391
238
|
break;
|
|
392
|
-
}
|
|
393
239
|
case "RangeToken":
|
|
394
240
|
case "CellToken":
|
|
395
241
|
activeRange = {
|
|
@@ -402,11 +248,17 @@ var rangeExtension = (onInit) => {
|
|
|
402
248
|
return false;
|
|
403
249
|
});
|
|
404
250
|
if (!activeRange && view2.state.doc.toString()[0] === "=") {
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
251
|
+
const str = view2.state.doc.sliceString(1);
|
|
252
|
+
if (RANGE_NOTATION.test(str)) {
|
|
253
|
+
activeRange = {
|
|
254
|
+
from: 1,
|
|
255
|
+
to: str.length + 1
|
|
256
|
+
};
|
|
257
|
+
}
|
|
409
258
|
}
|
|
259
|
+
onStateChange?.({
|
|
260
|
+
activeRange: activeRange ? view2.state.doc.sliceString(activeRange.from, activeRange.to) : void 0
|
|
261
|
+
});
|
|
410
262
|
}
|
|
411
263
|
});
|
|
412
264
|
};
|
|
@@ -422,228 +274,22 @@ var visitTree = (node, callback) => {
|
|
|
422
274
|
return false;
|
|
423
275
|
};
|
|
424
276
|
|
|
425
|
-
// packages/plugins/plugin-sheet/src/
|
|
426
|
-
import { useContext as useContext2 } from "react";
|
|
427
|
-
import {
|
|
428
|
-
import {
|
|
429
|
-
|
|
430
|
-
// packages/plugins/plugin-sheet/src/components/index.ts
|
|
431
|
-
import { lazy } from "react";
|
|
432
|
-
|
|
433
|
-
// packages/plugins/plugin-sheet/src/components/GridSheet/GridSheet.tsx
|
|
434
|
-
import React3, { useCallback as useCallback2, useMemo as useMemo3, useRef } from "react";
|
|
435
|
-
import { useAttention } from "@dxos/react-ui-attention";
|
|
436
|
-
import { Grid as Grid2, editorKeys, GridCellEditor, closestCell } from "@dxos/react-ui-grid";
|
|
437
|
-
|
|
438
|
-
// packages/plugins/plugin-sheet/src/components/GridSheet/util.ts
|
|
439
|
-
import { useEffect, useLayoutEffect, useState } from "react";
|
|
440
|
-
import { createDocAccessor } from "@dxos/react-client/echo";
|
|
441
|
-
import { parseValue, cellClassesForFieldType } from "@dxos/react-ui-data";
|
|
442
|
-
import { colToA1Notation, rowToA1Notation } from "@dxos/react-ui-grid";
|
|
443
|
-
import { mx as mx2 } from "@dxos/react-ui-theme";
|
|
444
|
-
var dxGridCellIndexToSheetCellAddress = (index) => {
|
|
445
|
-
const [colStr, rowStr] = index.split(",");
|
|
446
|
-
return {
|
|
447
|
-
col: parseInt(colStr),
|
|
448
|
-
row: parseInt(rowStr)
|
|
449
|
-
};
|
|
450
|
-
};
|
|
451
|
-
var createDxGridColumns = (model) => {
|
|
452
|
-
return model.sheet.columns.reduce((acc, columnId, numericIndex) => {
|
|
453
|
-
if (model.sheet.columnMeta[columnId] && model.sheet.columnMeta[columnId].size) {
|
|
454
|
-
acc.grid[numericIndex] = {
|
|
455
|
-
size: model.sheet.columnMeta[columnId].size,
|
|
456
|
-
resizeable: true
|
|
457
|
-
};
|
|
458
|
-
}
|
|
459
|
-
return acc;
|
|
460
|
-
}, {
|
|
461
|
-
grid: {}
|
|
462
|
-
});
|
|
463
|
-
};
|
|
464
|
-
var createDxGridRows = (model) => {
|
|
465
|
-
return model.sheet.rows.reduce((acc, rowId, numericIndex) => {
|
|
466
|
-
if (model.sheet.rowMeta[rowId] && model.sheet.rowMeta[rowId].size) {
|
|
467
|
-
acc.grid[numericIndex] = {
|
|
468
|
-
size: model.sheet.rowMeta[rowId].size,
|
|
469
|
-
resizeable: true
|
|
470
|
-
};
|
|
471
|
-
}
|
|
472
|
-
return acc;
|
|
473
|
-
}, {
|
|
474
|
-
grid: {}
|
|
475
|
-
});
|
|
476
|
-
};
|
|
477
|
-
var projectCellProps = (model, col, row) => {
|
|
478
|
-
const address = {
|
|
479
|
-
col,
|
|
480
|
-
row
|
|
481
|
-
};
|
|
482
|
-
const rawValue = model.getValue(address);
|
|
483
|
-
if (rawValue === void 0 || rawValue === null) {
|
|
484
|
-
return {
|
|
485
|
-
value: ""
|
|
486
|
-
};
|
|
487
|
-
}
|
|
488
|
-
const ranges = model.sheet.ranges?.filter(({ range }) => inRange(range, address));
|
|
489
|
-
const type = model.getValueType(address);
|
|
490
|
-
const classNames = ranges?.map(cellClassNameForRange).reverse();
|
|
491
|
-
return {
|
|
492
|
-
value: parseValue(type, rawValue),
|
|
493
|
-
className: mx2(cellClassesForFieldType(type), classNames)
|
|
494
|
-
};
|
|
495
|
-
};
|
|
496
|
-
var gridCellGetter = (model) => {
|
|
497
|
-
const cachedGridCells = {};
|
|
498
|
-
return (nextBounds) => {
|
|
499
|
-
[
|
|
500
|
-
...Array(nextBounds.end.col - nextBounds.start.col)
|
|
501
|
-
].forEach((_, c0) => {
|
|
502
|
-
return [
|
|
503
|
-
...Array(nextBounds.end.row - nextBounds.start.row)
|
|
504
|
-
].forEach((_2, r0) => {
|
|
505
|
-
const col = nextBounds.start.col + c0;
|
|
506
|
-
const row = nextBounds.start.row + r0;
|
|
507
|
-
cachedGridCells[`${col},${row}`] = projectCellProps(model, col, row);
|
|
508
|
-
});
|
|
509
|
-
});
|
|
510
|
-
return cachedGridCells;
|
|
511
|
-
};
|
|
512
|
-
};
|
|
513
|
-
var rowLabelCell = (row) => ({
|
|
514
|
-
value: rowToA1Notation(row),
|
|
515
|
-
className: "text-end !pie-1",
|
|
516
|
-
resizeHandle: "row"
|
|
517
|
-
});
|
|
518
|
-
var colLabelCell = (col) => ({
|
|
519
|
-
value: colToA1Notation(col),
|
|
520
|
-
resizeHandle: "col"
|
|
521
|
-
});
|
|
522
|
-
var cellGetter = (model) => {
|
|
523
|
-
const getGridCells = gridCellGetter(model);
|
|
524
|
-
return (nextBounds, plane) => {
|
|
525
|
-
switch (plane) {
|
|
526
|
-
case "grid":
|
|
527
|
-
return getGridCells(nextBounds);
|
|
528
|
-
case "frozenColsStart":
|
|
529
|
-
return [
|
|
530
|
-
...Array(nextBounds.end.row - nextBounds.start.row)
|
|
531
|
-
].reduce((acc, _, r0) => {
|
|
532
|
-
const r = nextBounds.start.row + r0;
|
|
533
|
-
acc[`0,${r}`] = rowLabelCell(r);
|
|
534
|
-
return acc;
|
|
535
|
-
}, {});
|
|
536
|
-
case "frozenRowsStart":
|
|
537
|
-
return [
|
|
538
|
-
...Array(nextBounds.end.col - nextBounds.start.col)
|
|
539
|
-
].reduce((acc, _, c0) => {
|
|
540
|
-
const c = nextBounds.start.col + c0;
|
|
541
|
-
acc[`${c},0`] = colLabelCell(c);
|
|
542
|
-
return acc;
|
|
543
|
-
}, {});
|
|
544
|
-
default:
|
|
545
|
-
return {};
|
|
546
|
-
}
|
|
547
|
-
};
|
|
548
|
-
};
|
|
549
|
-
var useSheetModelDxGridProps = (dxGridRef, model) => {
|
|
550
|
-
const [columns, setColumns] = useState(createDxGridColumns(model));
|
|
551
|
-
const [rows, setRows] = useState(createDxGridColumns(model));
|
|
552
|
-
useLayoutEffect(() => {
|
|
553
|
-
const cellsAccessor = createDocAccessor(model.sheet, [
|
|
554
|
-
"cells"
|
|
555
|
-
]);
|
|
556
|
-
if (dxGridRef.current) {
|
|
557
|
-
dxGridRef.current.getCells = cellGetter(model);
|
|
558
|
-
}
|
|
559
|
-
const handleCellsUpdate = () => {
|
|
560
|
-
dxGridRef.current?.requestUpdate("initialCells");
|
|
561
|
-
};
|
|
562
|
-
cellsAccessor.handle.addListener("change", handleCellsUpdate);
|
|
563
|
-
return () => cellsAccessor.handle.removeListener("change", handleCellsUpdate);
|
|
564
|
-
}, [
|
|
565
|
-
model
|
|
566
|
-
]);
|
|
567
|
-
useEffect(() => {
|
|
568
|
-
const columnMetaAccessor = createDocAccessor(model.sheet, [
|
|
569
|
-
"columnMeta"
|
|
570
|
-
]);
|
|
571
|
-
const rowMetaAccessor = createDocAccessor(model.sheet, [
|
|
572
|
-
"rowMeta"
|
|
573
|
-
]);
|
|
574
|
-
const handleColumnMetaUpdate = () => {
|
|
575
|
-
setColumns(createDxGridColumns(model));
|
|
576
|
-
};
|
|
577
|
-
const handleRowMetaUpdate = () => {
|
|
578
|
-
setRows(createDxGridRows(model));
|
|
579
|
-
};
|
|
580
|
-
columnMetaAccessor.handle.addListener("change", handleColumnMetaUpdate);
|
|
581
|
-
rowMetaAccessor.handle.addListener("change", handleRowMetaUpdate);
|
|
582
|
-
return () => {
|
|
583
|
-
columnMetaAccessor.handle.removeListener("change", handleColumnMetaUpdate);
|
|
584
|
-
rowMetaAccessor.handle.removeListener("change", handleRowMetaUpdate);
|
|
585
|
-
};
|
|
586
|
-
}, [
|
|
587
|
-
model
|
|
588
|
-
]);
|
|
589
|
-
return {
|
|
590
|
-
columns,
|
|
591
|
-
rows
|
|
592
|
-
};
|
|
593
|
-
};
|
|
594
|
-
|
|
595
|
-
// packages/plugins/plugin-sheet/src/hooks/useSheetModel.ts
|
|
596
|
-
import { useEffect as useEffect2, useState as useState2 } from "react";
|
|
597
|
-
|
|
598
|
-
// packages/plugins/plugin-sheet/src/model/decorations.ts
|
|
599
|
-
import { create as create2 } from "@dxos/echo-schema";
|
|
600
|
-
var createDecorations = () => {
|
|
601
|
-
const { decorations } = create2({
|
|
602
|
-
decorations: {}
|
|
603
|
-
});
|
|
604
|
-
const addDecoration = (cellIndex, decorator) => {
|
|
605
|
-
decorations[cellIndex] = [
|
|
606
|
-
...decorations[cellIndex] || [],
|
|
607
|
-
decorator
|
|
608
|
-
];
|
|
609
|
-
};
|
|
610
|
-
const removeDecoration = (cellIndex, type) => {
|
|
611
|
-
if (type) {
|
|
612
|
-
decorations[cellIndex] = (decorations[cellIndex] || []).filter((d) => d.type !== type);
|
|
613
|
-
} else {
|
|
614
|
-
delete decorations[cellIndex];
|
|
615
|
-
}
|
|
616
|
-
};
|
|
617
|
-
const getDecorationsForCell = (cellIndex) => {
|
|
618
|
-
return decorations[cellIndex];
|
|
619
|
-
};
|
|
620
|
-
const getAllDecorations = () => {
|
|
621
|
-
const result = [];
|
|
622
|
-
for (const decoratorArray of Object.values(decorations)) {
|
|
623
|
-
for (const decorator of decoratorArray) {
|
|
624
|
-
result.push(decorator);
|
|
625
|
-
}
|
|
626
|
-
}
|
|
627
|
-
return result;
|
|
628
|
-
};
|
|
629
|
-
return {
|
|
630
|
-
addDecoration,
|
|
631
|
-
removeDecoration,
|
|
632
|
-
getDecorationsForCell,
|
|
633
|
-
getAllDecorations
|
|
634
|
-
};
|
|
635
|
-
};
|
|
277
|
+
// packages/plugins/plugin-sheet/src/components/SheetContext/SheetContext.tsx
|
|
278
|
+
import React2, { createContext as createContext2, useCallback, useContext as useContext2, useState as useState2 } from "react";
|
|
279
|
+
import { invariant as invariant3 } from "@dxos/invariant";
|
|
280
|
+
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
281
|
+
import { Grid, useGridContext } from "@dxos/react-ui-grid";
|
|
636
282
|
|
|
637
283
|
// packages/plugins/plugin-sheet/src/model/sheet-model.ts
|
|
638
284
|
import { Event } from "@dxos/async";
|
|
639
285
|
import { Resource } from "@dxos/context";
|
|
640
286
|
import { getTypename } from "@dxos/echo-schema";
|
|
641
|
-
import { invariant as
|
|
287
|
+
import { invariant as invariant2 } from "@dxos/invariant";
|
|
642
288
|
import { PublicKey } from "@dxos/keys";
|
|
643
289
|
import { log } from "@dxos/log";
|
|
644
290
|
import { FieldValueType } from "@dxos/schema";
|
|
645
291
|
import { DetailedCellError, ExportedCellChange } from "#hyperformula";
|
|
646
|
-
var
|
|
292
|
+
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/model/sheet-model.ts";
|
|
647
293
|
var typeMap = {
|
|
648
294
|
BOOLEAN: FieldValueType.Boolean,
|
|
649
295
|
NUMBER_RAW: FieldValueType.Number,
|
|
@@ -700,8 +346,8 @@ var SheetModel = class extends Resource {
|
|
|
700
346
|
log("initialize", {
|
|
701
347
|
id: this.id
|
|
702
348
|
}, {
|
|
703
|
-
F:
|
|
704
|
-
L:
|
|
349
|
+
F: __dxlog_file,
|
|
350
|
+
L: 111,
|
|
705
351
|
S: this,
|
|
706
352
|
C: (f, a) => f(...a)
|
|
707
353
|
});
|
|
@@ -721,9 +367,9 @@ var SheetModel = class extends Resource {
|
|
|
721
367
|
* @deprecated
|
|
722
368
|
*/
|
|
723
369
|
reset() {
|
|
724
|
-
|
|
725
|
-
F:
|
|
726
|
-
L:
|
|
370
|
+
invariant2(this._node, void 0, {
|
|
371
|
+
F: __dxlog_file,
|
|
372
|
+
L: 131,
|
|
727
373
|
S: this,
|
|
728
374
|
A: [
|
|
729
375
|
"this._node",
|
|
@@ -732,9 +378,9 @@ var SheetModel = class extends Resource {
|
|
|
732
378
|
});
|
|
733
379
|
this._node.graph.hf.clearSheet(this._node.sheetId);
|
|
734
380
|
Object.entries(this._sheet.cells).forEach(([key, { value }]) => {
|
|
735
|
-
|
|
736
|
-
F:
|
|
737
|
-
L:
|
|
381
|
+
invariant2(this._node, void 0, {
|
|
382
|
+
F: __dxlog_file,
|
|
383
|
+
L: 134,
|
|
738
384
|
S: this,
|
|
739
385
|
A: [
|
|
740
386
|
"this._node",
|
|
@@ -742,7 +388,7 @@ var SheetModel = class extends Resource {
|
|
|
742
388
|
]
|
|
743
389
|
});
|
|
744
390
|
const { col, row } = addressFromIndex(this._sheet, key);
|
|
745
|
-
if (
|
|
391
|
+
if (isFormula(value)) {
|
|
746
392
|
value = this._graph.mapFormulaToNative(this._graph.mapFunctionBindingFromId(this.mapFormulaIndicesToRefs(value)));
|
|
747
393
|
}
|
|
748
394
|
this._node.graph.hf.setCellContents({
|
|
@@ -778,9 +424,9 @@ var SheetModel = class extends Resource {
|
|
|
778
424
|
* Clear range of values.
|
|
779
425
|
*/
|
|
780
426
|
clear(range) {
|
|
781
|
-
|
|
782
|
-
F:
|
|
783
|
-
L:
|
|
427
|
+
invariant2(this._node, void 0, {
|
|
428
|
+
F: __dxlog_file,
|
|
429
|
+
L: 176,
|
|
784
430
|
S: this,
|
|
785
431
|
A: [
|
|
786
432
|
"this._node",
|
|
@@ -796,9 +442,9 @@ var SheetModel = class extends Resource {
|
|
|
796
442
|
});
|
|
797
443
|
}
|
|
798
444
|
cut(range) {
|
|
799
|
-
|
|
800
|
-
F:
|
|
801
|
-
L:
|
|
445
|
+
invariant2(this._node, void 0, {
|
|
446
|
+
F: __dxlog_file,
|
|
447
|
+
L: 187,
|
|
802
448
|
S: this,
|
|
803
449
|
A: [
|
|
804
450
|
"this._node",
|
|
@@ -812,9 +458,9 @@ var SheetModel = class extends Resource {
|
|
|
812
458
|
});
|
|
813
459
|
}
|
|
814
460
|
copy(range) {
|
|
815
|
-
|
|
816
|
-
F:
|
|
817
|
-
L:
|
|
461
|
+
invariant2(this._node, void 0, {
|
|
462
|
+
F: __dxlog_file,
|
|
463
|
+
L: 196,
|
|
818
464
|
S: this,
|
|
819
465
|
A: [
|
|
820
466
|
"this._node",
|
|
@@ -824,9 +470,9 @@ var SheetModel = class extends Resource {
|
|
|
824
470
|
this._node.graph.hf.copy(toModelRange(this._node.sheetId, range));
|
|
825
471
|
}
|
|
826
472
|
paste(cell) {
|
|
827
|
-
|
|
828
|
-
F:
|
|
829
|
-
L:
|
|
473
|
+
invariant2(this._node, void 0, {
|
|
474
|
+
F: __dxlog_file,
|
|
475
|
+
L: 201,
|
|
830
476
|
S: this,
|
|
831
477
|
A: [
|
|
832
478
|
"this._node",
|
|
@@ -851,9 +497,9 @@ var SheetModel = class extends Resource {
|
|
|
851
497
|
}
|
|
852
498
|
// TODO(burdon): Display undo/redo state.
|
|
853
499
|
undo() {
|
|
854
|
-
|
|
855
|
-
F:
|
|
856
|
-
L:
|
|
500
|
+
invariant2(this._node, void 0, {
|
|
501
|
+
F: __dxlog_file,
|
|
502
|
+
L: 216,
|
|
857
503
|
S: this,
|
|
858
504
|
A: [
|
|
859
505
|
"this._node",
|
|
@@ -865,9 +511,9 @@ var SheetModel = class extends Resource {
|
|
|
865
511
|
}
|
|
866
512
|
}
|
|
867
513
|
redo() {
|
|
868
|
-
|
|
869
|
-
F:
|
|
870
|
-
L:
|
|
514
|
+
invariant2(this._node, void 0, {
|
|
515
|
+
F: __dxlog_file,
|
|
516
|
+
L: 224,
|
|
871
517
|
S: this,
|
|
872
518
|
A: [
|
|
873
519
|
"this._node",
|
|
@@ -893,7 +539,7 @@ var SheetModel = class extends Resource {
|
|
|
893
539
|
if (value == null) {
|
|
894
540
|
return void 0;
|
|
895
541
|
}
|
|
896
|
-
if (
|
|
542
|
+
if (isFormula(value)) {
|
|
897
543
|
return this._graph.mapFunctionBindingFromId(this.mapFormulaIndicesToRefs(value));
|
|
898
544
|
} else {
|
|
899
545
|
return String(value);
|
|
@@ -909,9 +555,9 @@ var SheetModel = class extends Resource {
|
|
|
909
555
|
* Gets the regular or computed value from the engine.
|
|
910
556
|
*/
|
|
911
557
|
getValue(cell) {
|
|
912
|
-
|
|
913
|
-
F:
|
|
914
|
-
L:
|
|
558
|
+
invariant2(this._node, void 0, {
|
|
559
|
+
F: __dxlog_file,
|
|
560
|
+
L: 267,
|
|
915
561
|
S: this,
|
|
916
562
|
A: [
|
|
917
563
|
"this._node",
|
|
@@ -928,9 +574,9 @@ var SheetModel = class extends Resource {
|
|
|
928
574
|
* Get value type.
|
|
929
575
|
*/
|
|
930
576
|
getValueType(cell) {
|
|
931
|
-
|
|
932
|
-
F:
|
|
933
|
-
L:
|
|
577
|
+
invariant2(this._node, void 0, {
|
|
578
|
+
F: __dxlog_file,
|
|
579
|
+
L: 280,
|
|
934
580
|
S: this,
|
|
935
581
|
A: [
|
|
936
582
|
"this._node",
|
|
@@ -945,9 +591,9 @@ var SheetModel = class extends Resource {
|
|
|
945
591
|
* Sets the value, updating the sheet and engine.
|
|
946
592
|
*/
|
|
947
593
|
setValue(cell, value) {
|
|
948
|
-
|
|
949
|
-
F:
|
|
950
|
-
L:
|
|
594
|
+
invariant2(this._node, void 0, {
|
|
595
|
+
F: __dxlog_file,
|
|
596
|
+
L: 290,
|
|
951
597
|
S: this,
|
|
952
598
|
A: [
|
|
953
599
|
"this._node",
|
|
@@ -975,14 +621,14 @@ var SheetModel = class extends Resource {
|
|
|
975
621
|
col: cell.col
|
|
976
622
|
}, [
|
|
977
623
|
[
|
|
978
|
-
|
|
624
|
+
isFormula(value) ? this._graph.mapFormulaToNative(value) : value
|
|
979
625
|
]
|
|
980
626
|
]);
|
|
981
627
|
const idx = addressToIndex(this._sheet, cell);
|
|
982
628
|
if (value === void 0 || value === null) {
|
|
983
629
|
delete this._sheet.cells[idx];
|
|
984
630
|
} else {
|
|
985
|
-
if (
|
|
631
|
+
if (isFormula(value)) {
|
|
986
632
|
value = this._graph.mapFunctionBindingToId(this.mapFormulaRefsToIndices(value));
|
|
987
633
|
}
|
|
988
634
|
this._sheet.cells[idx] = {
|
|
@@ -1042,12 +688,12 @@ var SheetModel = class extends Resource {
|
|
|
1042
688
|
* Map from A1 notation to indices.
|
|
1043
689
|
*/
|
|
1044
690
|
mapFormulaRefsToIndices(formula) {
|
|
1045
|
-
|
|
1046
|
-
F:
|
|
1047
|
-
L:
|
|
691
|
+
invariant2(isFormula(formula), void 0, {
|
|
692
|
+
F: __dxlog_file,
|
|
693
|
+
L: 379,
|
|
1048
694
|
S: this,
|
|
1049
695
|
A: [
|
|
1050
|
-
"formula
|
|
696
|
+
"isFormula(formula)",
|
|
1051
697
|
""
|
|
1052
698
|
]
|
|
1053
699
|
});
|
|
@@ -1059,12 +705,12 @@ var SheetModel = class extends Resource {
|
|
|
1059
705
|
* Map from indices to A1 notation.
|
|
1060
706
|
*/
|
|
1061
707
|
mapFormulaIndicesToRefs(formula) {
|
|
1062
|
-
|
|
1063
|
-
F:
|
|
1064
|
-
L:
|
|
708
|
+
invariant2(isFormula(formula), void 0, {
|
|
709
|
+
F: __dxlog_file,
|
|
710
|
+
L: 389,
|
|
1065
711
|
S: this,
|
|
1066
712
|
A: [
|
|
1067
|
-
"formula
|
|
713
|
+
"isFormula(formula)",
|
|
1068
714
|
""
|
|
1069
715
|
]
|
|
1070
716
|
});
|
|
@@ -1085,9 +731,9 @@ var SheetModel = class extends Resource {
|
|
|
1085
731
|
return new Date(year, month - 1, day, hours, minutes, seconds);
|
|
1086
732
|
}
|
|
1087
733
|
toDateTime(num) {
|
|
1088
|
-
|
|
1089
|
-
F:
|
|
1090
|
-
L:
|
|
734
|
+
invariant2(this._node, void 0, {
|
|
735
|
+
F: __dxlog_file,
|
|
736
|
+
L: 410,
|
|
1091
737
|
S: this,
|
|
1092
738
|
A: [
|
|
1093
739
|
"this._node",
|
|
@@ -1097,9 +743,9 @@ var SheetModel = class extends Resource {
|
|
|
1097
743
|
return this._node.graph.hf.numberToDateTime(num);
|
|
1098
744
|
}
|
|
1099
745
|
toDate(num) {
|
|
1100
|
-
|
|
1101
|
-
F:
|
|
1102
|
-
L:
|
|
746
|
+
invariant2(this._node, void 0, {
|
|
747
|
+
F: __dxlog_file,
|
|
748
|
+
L: 415,
|
|
1103
749
|
S: this,
|
|
1104
750
|
A: [
|
|
1105
751
|
"this._node",
|
|
@@ -1109,9 +755,9 @@ var SheetModel = class extends Resource {
|
|
|
1109
755
|
return this._node.graph.hf.numberToDate(num);
|
|
1110
756
|
}
|
|
1111
757
|
toTime(num) {
|
|
1112
|
-
|
|
1113
|
-
F:
|
|
1114
|
-
L:
|
|
758
|
+
invariant2(this._node, void 0, {
|
|
759
|
+
F: __dxlog_file,
|
|
760
|
+
L: 420,
|
|
1115
761
|
S: this,
|
|
1116
762
|
A: [
|
|
1117
763
|
"this._node",
|
|
@@ -1122,10 +768,11 @@ var SheetModel = class extends Resource {
|
|
|
1122
768
|
}
|
|
1123
769
|
};
|
|
1124
770
|
|
|
1125
|
-
// packages/plugins/plugin-sheet/src/
|
|
771
|
+
// packages/plugins/plugin-sheet/src/model/useSheetModel.ts
|
|
772
|
+
import { useEffect, useState } from "react";
|
|
1126
773
|
var useSheetModel = (graph, sheet, { readonly } = {}) => {
|
|
1127
|
-
const [model, setModel] =
|
|
1128
|
-
|
|
774
|
+
const [model, setModel] = useState();
|
|
775
|
+
useEffect(() => {
|
|
1129
776
|
if (!graph || !sheet) {
|
|
1130
777
|
return;
|
|
1131
778
|
}
|
|
@@ -1149,182 +796,392 @@ var useSheetModel = (graph, sheet, { readonly } = {}) => {
|
|
|
1149
796
|
return model;
|
|
1150
797
|
};
|
|
1151
798
|
|
|
1152
|
-
// packages/plugins/plugin-sheet/src/
|
|
1153
|
-
|
|
1154
|
-
|
|
799
|
+
// packages/plugins/plugin-sheet/src/components/SheetContext/SheetContext.tsx
|
|
800
|
+
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/components/SheetContext/SheetContext.tsx";
|
|
801
|
+
var SheetContext = /* @__PURE__ */ createContext2(void 0);
|
|
802
|
+
var useSheetContext = () => {
|
|
803
|
+
const context = useContext2(SheetContext);
|
|
804
|
+
invariant3(context, void 0, {
|
|
805
|
+
F: __dxlog_file2,
|
|
806
|
+
L: 52,
|
|
807
|
+
S: void 0,
|
|
808
|
+
A: [
|
|
809
|
+
"context",
|
|
810
|
+
""
|
|
811
|
+
]
|
|
812
|
+
});
|
|
813
|
+
return context;
|
|
814
|
+
};
|
|
815
|
+
var SheetProviderImpl = ({ model, onInfo, children, __gridScope }) => {
|
|
816
|
+
const { id, editing, setEditing } = useGridContext("SheetProvider", __gridScope);
|
|
817
|
+
const [cursor, setCursorInternal] = useState2();
|
|
818
|
+
const [range, setRangeInternal] = useState2();
|
|
819
|
+
const [cursorFallbackRange, setCursorFallbackRange] = useState2();
|
|
820
|
+
const [activeRefs, setActiveRefs] = useState2("");
|
|
821
|
+
const setCursor = useCallback((nextCursor) => {
|
|
822
|
+
setCursorInternal(nextCursor);
|
|
823
|
+
setCursorFallbackRange(range?.to ? range : nextCursor ? {
|
|
824
|
+
from: nextCursor,
|
|
825
|
+
to: nextCursor
|
|
826
|
+
} : void 0);
|
|
827
|
+
}, [
|
|
828
|
+
range
|
|
829
|
+
]);
|
|
830
|
+
const setRange = useCallback((nextRange) => {
|
|
831
|
+
setRangeInternal(nextRange);
|
|
832
|
+
setCursorFallbackRange(nextRange?.to ? nextRange : cursor ? {
|
|
833
|
+
from: cursor,
|
|
834
|
+
to: cursor
|
|
835
|
+
} : void 0);
|
|
836
|
+
}, [
|
|
837
|
+
cursor
|
|
838
|
+
]);
|
|
839
|
+
return /* @__PURE__ */ React2.createElement(SheetContext.Provider, {
|
|
840
|
+
value: {
|
|
841
|
+
id,
|
|
842
|
+
model,
|
|
843
|
+
editing,
|
|
844
|
+
setEditing,
|
|
845
|
+
cursor,
|
|
846
|
+
setCursor,
|
|
847
|
+
range,
|
|
848
|
+
setRange,
|
|
849
|
+
cursorFallbackRange,
|
|
850
|
+
activeRefs,
|
|
851
|
+
setActiveRefs,
|
|
852
|
+
// TODO(burdon): Change to event.
|
|
853
|
+
onInfo
|
|
854
|
+
}
|
|
855
|
+
}, children);
|
|
856
|
+
};
|
|
857
|
+
var SheetProvider = ({ children, graph, sheet, readonly, onInfo }) => {
|
|
858
|
+
const model = useSheetModel(graph, sheet, {
|
|
859
|
+
readonly
|
|
860
|
+
});
|
|
861
|
+
return !model ? null : /* @__PURE__ */ React2.createElement(Grid.Root, {
|
|
862
|
+
id: fullyQualifiedId(sheet)
|
|
863
|
+
}, /* @__PURE__ */ React2.createElement(SheetProviderImpl, {
|
|
864
|
+
model,
|
|
865
|
+
onInfo
|
|
866
|
+
}, children));
|
|
867
|
+
};
|
|
868
|
+
|
|
869
|
+
// packages/plugins/plugin-sheet/src/components/GridSheet/GridSheet.tsx
|
|
870
|
+
import React4, { useCallback as useCallback4, useMemo as useMemo2, useRef, useState as useState4 } from "react";
|
|
871
|
+
import { DropdownMenu, Icon, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
872
|
+
import { useAttention } from "@dxos/react-ui-attention";
|
|
873
|
+
import { closestCell, editorKeys, Grid as Grid2, GridCellEditor } from "@dxos/react-ui-grid";
|
|
874
|
+
|
|
875
|
+
// packages/plugins/plugin-sheet/src/components/GridSheet/util.ts
|
|
876
|
+
import { useEffect as useEffect3, useState as useState3 } from "react";
|
|
877
|
+
import { createDocAccessor, fullyQualifiedId as fullyQualifiedId3 } from "@dxos/react-client/echo";
|
|
878
|
+
import { parseValue, cellClassesForFieldType } from "@dxos/react-ui-data";
|
|
879
|
+
import { colToA1Notation, rowToA1Notation, commentedClassName } from "@dxos/react-ui-grid";
|
|
880
|
+
import { mx as mx2 } from "@dxos/react-ui-theme";
|
|
881
|
+
|
|
882
|
+
// packages/plugins/plugin-sheet/src/integrations/thread-ranges.ts
|
|
883
|
+
import { useCallback as useCallback3, useEffect as useEffect2, useMemo } from "react";
|
|
1155
884
|
import { LayoutAction, useIntentDispatcher, useIntentResolver } from "@dxos/app-framework";
|
|
1156
885
|
import { debounce as debounce2 } from "@dxos/async";
|
|
1157
|
-
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
1158
|
-
|
|
1159
|
-
|
|
886
|
+
import { fullyQualifiedId as fullyQualifiedId2 } from "@dxos/react-client/echo";
|
|
887
|
+
|
|
888
|
+
// packages/plugins/plugin-sheet/src/components/index.ts
|
|
889
|
+
import { lazy } from "react";
|
|
890
|
+
|
|
891
|
+
// packages/plugins/plugin-sheet/src/components/RangeList/RangeList.tsx
|
|
892
|
+
import React3, { useCallback as useCallback2 } from "react";
|
|
893
|
+
import { S } from "@dxos/echo-schema";
|
|
894
|
+
import { useTranslation } from "@dxos/react-ui";
|
|
895
|
+
import { List } from "@dxos/react-ui-list";
|
|
896
|
+
import { ghostHover } from "@dxos/react-ui-theme";
|
|
897
|
+
var RangeList = ({ sheet }) => {
|
|
898
|
+
const { t } = useTranslation(SHEET_PLUGIN);
|
|
899
|
+
const handleSelectRange = (range) => {
|
|
900
|
+
};
|
|
901
|
+
const handleDeleteRange = useCallback2((range) => {
|
|
902
|
+
const index = sheet.ranges.findIndex((sheetRange) => sheetRange === range);
|
|
903
|
+
sheet.ranges.splice(index, 1);
|
|
904
|
+
}, [
|
|
905
|
+
sheet
|
|
906
|
+
]);
|
|
907
|
+
return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ React3.createElement("h2", {
|
|
908
|
+
className: "p-2 text-sm font-semibold"
|
|
909
|
+
}, t("range list heading")), /* @__PURE__ */ React3.createElement(List.Root, {
|
|
910
|
+
items: sheet.ranges,
|
|
911
|
+
isItem: S.is(Range)
|
|
912
|
+
}, ({ items: ranges }) => ranges.map((range, i) => /* @__PURE__ */ React3.createElement(List.Item, {
|
|
913
|
+
key: i,
|
|
914
|
+
item: range,
|
|
915
|
+
classNames: [
|
|
916
|
+
"p-2",
|
|
917
|
+
ghostHover
|
|
918
|
+
]
|
|
919
|
+
}, /* @__PURE__ */ React3.createElement(List.ItemDragHandle, null), /* @__PURE__ */ React3.createElement(List.ItemTitle, {
|
|
920
|
+
onClick: () => handleSelectRange(range)
|
|
921
|
+
}, t("range title", {
|
|
922
|
+
position: rangeToA1Notation(rangeFromIndex(sheet, range.range)),
|
|
923
|
+
key: t(`range key ${range.key} label`),
|
|
924
|
+
value: t(`range value ${range.value} label`)
|
|
925
|
+
})), /* @__PURE__ */ React3.createElement(List.ItemDeleteButton, {
|
|
926
|
+
onClick: () => handleDeleteRange(range)
|
|
927
|
+
})))));
|
|
928
|
+
};
|
|
929
|
+
|
|
930
|
+
// packages/plugins/plugin-sheet/src/components/index.ts
|
|
931
|
+
var SheetContainer = lazy(() => import("./SheetContainer-R65IDJHN.mjs"));
|
|
932
|
+
|
|
933
|
+
// packages/plugins/plugin-sheet/src/integrations/thread-ranges.ts
|
|
934
|
+
var completeCellRangeToThreadCursor = (range) => {
|
|
935
|
+
return `${range.from.col},${range.from.row},${range.to.col},${range.to.row}`;
|
|
936
|
+
};
|
|
937
|
+
var parseThreadAnchorAsCellRange = (cursor) => {
|
|
938
|
+
const coords = cursor.split(",");
|
|
939
|
+
if (coords.length !== 4) {
|
|
940
|
+
return null;
|
|
941
|
+
} else {
|
|
942
|
+
const [fromCol, fromRow, toCol, toRow] = coords;
|
|
943
|
+
return {
|
|
944
|
+
from: {
|
|
945
|
+
col: parseInt(fromCol),
|
|
946
|
+
row: parseInt(fromRow)
|
|
947
|
+
},
|
|
948
|
+
to: {
|
|
949
|
+
col: parseInt(toCol),
|
|
950
|
+
row: parseInt(toRow)
|
|
951
|
+
}
|
|
952
|
+
};
|
|
953
|
+
}
|
|
954
|
+
};
|
|
955
|
+
var useUpdateFocusedCellOnThreadSelection = (grid) => {
|
|
956
|
+
const { model, setActiveRefs } = useSheetContext();
|
|
957
|
+
const handleScrollIntoView = useCallback3(({ action, data }) => {
|
|
1160
958
|
switch (action) {
|
|
1161
959
|
case LayoutAction.SCROLL_INTO_VIEW: {
|
|
1162
|
-
if (!data?.id || data?.cursor === void 0 || data?.id !==
|
|
960
|
+
if (!data?.id || data?.cursor === void 0 || data?.id !== fullyQualifiedId2(model.sheet)) {
|
|
1163
961
|
return;
|
|
1164
962
|
}
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
963
|
+
setActiveRefs(data.thread);
|
|
964
|
+
const range = parseThreadAnchorAsCellRange(data.cursor);
|
|
965
|
+
range && grid?.setFocus({
|
|
966
|
+
...range.to,
|
|
1168
967
|
plane: "grid"
|
|
1169
968
|
}, true);
|
|
1170
969
|
}
|
|
1171
970
|
}
|
|
1172
971
|
}, [
|
|
1173
|
-
model.sheet
|
|
972
|
+
model.sheet,
|
|
973
|
+
setActiveRefs
|
|
1174
974
|
]);
|
|
1175
975
|
useIntentResolver(SHEET_PLUGIN, handleScrollIntoView);
|
|
1176
976
|
};
|
|
1177
|
-
var useSelectThreadOnCellFocus = (
|
|
977
|
+
var useSelectThreadOnCellFocus = () => {
|
|
978
|
+
const { model, cursor } = useSheetContext();
|
|
1178
979
|
const dispatch = useIntentDispatcher();
|
|
1179
|
-
const
|
|
980
|
+
const threads = useMemo(() => model.sheet.threads?.filter((thread) => !!thread) ?? [], [
|
|
1180
981
|
// TODO(thure): Surely we can find a better dependency for this…
|
|
1181
982
|
JSON.stringify(model.sheet.threads)
|
|
1182
983
|
]);
|
|
1183
|
-
const
|
|
1184
|
-
|
|
1185
|
-
model.sheet
|
|
1186
|
-
]);
|
|
1187
|
-
const selectClosestThread = useCallback((cellAddress) => {
|
|
1188
|
-
if (!cellAddress || !activeThreads) {
|
|
984
|
+
const selectClosestThread = useCallback3((cellAddress) => {
|
|
985
|
+
if (!cellAddress || !threads) {
|
|
1189
986
|
return;
|
|
1190
987
|
}
|
|
1191
|
-
const
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
action: "dxos.org/plugin/thread/action/select",
|
|
1198
|
-
data: {
|
|
1199
|
-
current: fullyQualifiedId(closestThread)
|
|
1200
|
-
}
|
|
1201
|
-
}
|
|
1202
|
-
]);
|
|
988
|
+
const closestThread = threads?.find(({ anchor }) => {
|
|
989
|
+
if (anchor) {
|
|
990
|
+
const range = parseThreadAnchorAsCellRange(anchor);
|
|
991
|
+
return range ? inRange(range, cellAddress) : false;
|
|
992
|
+
} else {
|
|
993
|
+
return false;
|
|
1203
994
|
}
|
|
995
|
+
});
|
|
996
|
+
if (closestThread) {
|
|
997
|
+
void dispatch([
|
|
998
|
+
{
|
|
999
|
+
action: "dxos.org/plugin/thread/action/select",
|
|
1000
|
+
data: {
|
|
1001
|
+
current: fullyQualifiedId2(closestThread)
|
|
1002
|
+
}
|
|
1003
|
+
}
|
|
1004
|
+
]);
|
|
1204
1005
|
}
|
|
1205
1006
|
}, [
|
|
1206
1007
|
dispatch,
|
|
1207
|
-
|
|
1208
|
-
activeThreadAddresses,
|
|
1209
|
-
model.sheet
|
|
1008
|
+
threads
|
|
1210
1009
|
]);
|
|
1211
1010
|
const debounced = useMemo(() => {
|
|
1212
1011
|
return debounce2((cellCoords) => requestAnimationFrame(() => selectClosestThread(cellCoords)), 50);
|
|
1213
1012
|
}, [
|
|
1214
1013
|
selectClosestThread
|
|
1215
1014
|
]);
|
|
1216
|
-
|
|
1015
|
+
useEffect2(() => {
|
|
1217
1016
|
if (!cursor) {
|
|
1218
1017
|
return;
|
|
1219
1018
|
}
|
|
1220
1019
|
debounced(cursor);
|
|
1221
1020
|
}, [
|
|
1222
1021
|
cursor,
|
|
1223
|
-
|
|
1022
|
+
debounced
|
|
1224
1023
|
]);
|
|
1225
1024
|
};
|
|
1226
|
-
|
|
1025
|
+
|
|
1026
|
+
// packages/plugins/plugin-sheet/src/components/GridSheet/util.ts
|
|
1027
|
+
var dxGridCellIndexToSheetCellAddress = (index) => {
|
|
1028
|
+
const [colStr, rowStr] = index.split(",");
|
|
1227
1029
|
return {
|
|
1228
|
-
|
|
1229
|
-
|
|
1230
|
-
"bg-greenFill"
|
|
1231
|
-
],
|
|
1232
|
-
cellIndex
|
|
1030
|
+
col: parseInt(colStr),
|
|
1031
|
+
row: parseInt(rowStr)
|
|
1233
1032
|
};
|
|
1234
1033
|
};
|
|
1235
|
-
var
|
|
1236
|
-
|
|
1237
|
-
model.sheet
|
|
1238
|
-
|
|
1239
|
-
|
|
1240
|
-
|
|
1241
|
-
|
|
1242
|
-
|
|
1243
|
-
|
|
1244
|
-
|
|
1245
|
-
|
|
1246
|
-
return;
|
|
1247
|
-
}
|
|
1248
|
-
for (const thread of sheet.threads) {
|
|
1249
|
-
if (!thread || thread.anchor === void 0 || thread.status === "resolved") {
|
|
1250
|
-
continue;
|
|
1251
|
-
}
|
|
1252
|
-
activeThreadAnchors.add(thread.anchor);
|
|
1253
|
-
const index = thread.anchor;
|
|
1254
|
-
const existingDecorations = decorations.getDecorationsForCell(index);
|
|
1255
|
-
if (!existingDecorations || !existingDecorations.some((d) => d.type === "comment")) {
|
|
1256
|
-
decorations.addDecoration(index, createThreadDecoration(index, thread.id, sheetId));
|
|
1257
|
-
}
|
|
1258
|
-
}
|
|
1259
|
-
for (const decoration of decorations.getAllDecorations()) {
|
|
1260
|
-
if (decoration.type !== "comment") {
|
|
1261
|
-
continue;
|
|
1262
|
-
}
|
|
1263
|
-
if (!activeThreadAnchors.has(decoration.cellIndex)) {
|
|
1264
|
-
decorations.removeDecoration(decoration.cellIndex, "comment");
|
|
1265
|
-
}
|
|
1266
|
-
}
|
|
1267
|
-
});
|
|
1268
|
-
return () => unsubscribe();
|
|
1034
|
+
var createDxGridColumns = (model) => {
|
|
1035
|
+
return model.sheet.columns.reduce((acc, columnId, numericIndex) => {
|
|
1036
|
+
if (model.sheet.columnMeta[columnId] && model.sheet.columnMeta[columnId].size) {
|
|
1037
|
+
acc.grid[numericIndex] = {
|
|
1038
|
+
size: model.sheet.columnMeta[columnId].size,
|
|
1039
|
+
resizeable: true
|
|
1040
|
+
};
|
|
1041
|
+
}
|
|
1042
|
+
return acc;
|
|
1043
|
+
}, {
|
|
1044
|
+
grid: {}
|
|
1269
1045
|
});
|
|
1270
1046
|
};
|
|
1271
|
-
|
|
1272
|
-
|
|
1273
|
-
|
|
1274
|
-
|
|
1275
|
-
|
|
1276
|
-
|
|
1277
|
-
|
|
1278
|
-
|
|
1279
|
-
|
|
1280
|
-
|
|
1281
|
-
|
|
1282
|
-
F: __dxlog_file3,
|
|
1283
|
-
L: 45,
|
|
1284
|
-
S: void 0,
|
|
1285
|
-
A: [
|
|
1286
|
-
"context",
|
|
1287
|
-
""
|
|
1288
|
-
]
|
|
1047
|
+
var createDxGridRows = (model) => {
|
|
1048
|
+
return model.sheet.rows.reduce((acc, rowId, numericIndex) => {
|
|
1049
|
+
if (model.sheet.rowMeta[rowId] && model.sheet.rowMeta[rowId].size) {
|
|
1050
|
+
acc.grid[numericIndex] = {
|
|
1051
|
+
size: model.sheet.rowMeta[rowId].size,
|
|
1052
|
+
resizeable: true
|
|
1053
|
+
};
|
|
1054
|
+
}
|
|
1055
|
+
return acc;
|
|
1056
|
+
}, {
|
|
1057
|
+
grid: {}
|
|
1289
1058
|
});
|
|
1290
|
-
return context;
|
|
1291
1059
|
};
|
|
1292
|
-
var
|
|
1293
|
-
const
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1060
|
+
var projectCellProps = (model, col, row) => {
|
|
1061
|
+
const address = {
|
|
1062
|
+
col,
|
|
1063
|
+
row
|
|
1064
|
+
};
|
|
1065
|
+
const rawValue = model.getValue(address);
|
|
1066
|
+
const ranges = model.sheet.ranges?.filter(({ range }) => inRange(rangeFromIndex(model.sheet, range), address));
|
|
1067
|
+
const threadRefs = model.sheet.threads?.filter((thread) => {
|
|
1068
|
+
const range = thread?.anchor && parseThreadAnchorAsCellRange(thread.anchor);
|
|
1069
|
+
return thread && range ? inRange(range, address) : false;
|
|
1070
|
+
}).map((thread) => fullyQualifiedId3(thread)).join(" ");
|
|
1071
|
+
const type = model.getValueType(address);
|
|
1072
|
+
const classNames = ranges?.map(cellClassNameForRange).reverse();
|
|
1073
|
+
return {
|
|
1074
|
+
value: parseValue(type, rawValue),
|
|
1075
|
+
className: mx2(cellClassesForFieldType(type), threadRefs && commentedClassName, classNames),
|
|
1076
|
+
dataRefs: threadRefs
|
|
1077
|
+
};
|
|
1078
|
+
};
|
|
1079
|
+
var gridCellGetter = (model) => {
|
|
1080
|
+
const cachedGridCells = {};
|
|
1081
|
+
return (nextBounds) => {
|
|
1082
|
+
[
|
|
1083
|
+
...Array(nextBounds.end.col - nextBounds.start.col)
|
|
1084
|
+
].forEach((_, c0) => {
|
|
1085
|
+
return [
|
|
1086
|
+
...Array(nextBounds.end.row - nextBounds.start.row)
|
|
1087
|
+
].forEach((_2, r0) => {
|
|
1088
|
+
const col = nextBounds.start.col + c0;
|
|
1089
|
+
const row = nextBounds.start.row + r0;
|
|
1090
|
+
cachedGridCells[`${col},${row}`] = projectCellProps(model, col, row);
|
|
1091
|
+
});
|
|
1092
|
+
});
|
|
1093
|
+
return cachedGridCells;
|
|
1094
|
+
};
|
|
1095
|
+
};
|
|
1096
|
+
var rowLabelCell = (row) => ({
|
|
1097
|
+
value: rowToA1Notation(row),
|
|
1098
|
+
className: "text-end !pie-1",
|
|
1099
|
+
resizeHandle: "row"
|
|
1100
|
+
});
|
|
1101
|
+
var colLabelCell = (col) => ({
|
|
1102
|
+
value: colToA1Notation(col),
|
|
1103
|
+
resizeHandle: "col"
|
|
1104
|
+
});
|
|
1105
|
+
var cellGetter = (model) => {
|
|
1106
|
+
const getGridCells = gridCellGetter(model);
|
|
1107
|
+
return (nextBounds, plane) => {
|
|
1108
|
+
switch (plane) {
|
|
1109
|
+
case "grid":
|
|
1110
|
+
return getGridCells(nextBounds);
|
|
1111
|
+
case "frozenColsStart":
|
|
1112
|
+
return [
|
|
1113
|
+
...Array(nextBounds.end.row - nextBounds.start.row)
|
|
1114
|
+
].reduce((acc, _, r0) => {
|
|
1115
|
+
const r = nextBounds.start.row + r0;
|
|
1116
|
+
acc[`0,${r}`] = rowLabelCell(r);
|
|
1117
|
+
return acc;
|
|
1118
|
+
}, {});
|
|
1119
|
+
case "frozenRowsStart":
|
|
1120
|
+
return [
|
|
1121
|
+
...Array(nextBounds.end.col - nextBounds.start.col)
|
|
1122
|
+
].reduce((acc, _, c0) => {
|
|
1123
|
+
const c = nextBounds.start.col + c0;
|
|
1124
|
+
acc[`${c},0`] = colLabelCell(c);
|
|
1125
|
+
return acc;
|
|
1126
|
+
}, {});
|
|
1127
|
+
default:
|
|
1128
|
+
return {};
|
|
1312
1129
|
}
|
|
1313
|
-
}
|
|
1130
|
+
};
|
|
1314
1131
|
};
|
|
1315
|
-
var
|
|
1316
|
-
const
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1132
|
+
var useSheetModelDxGridProps = (dxGrid, model) => {
|
|
1133
|
+
const [columns, setColumns] = useState3(createDxGridColumns(model));
|
|
1134
|
+
const [rows, setRows] = useState3(createDxGridColumns(model));
|
|
1135
|
+
useEffect3(() => {
|
|
1136
|
+
const cellsAccessor = createDocAccessor(model.sheet, [
|
|
1137
|
+
"cells"
|
|
1138
|
+
]);
|
|
1139
|
+
if (dxGrid) {
|
|
1140
|
+
dxGrid.getCells = cellGetter(model);
|
|
1141
|
+
}
|
|
1142
|
+
const handleCellsUpdate = () => {
|
|
1143
|
+
dxGrid?.requestUpdate("initialCells");
|
|
1144
|
+
};
|
|
1145
|
+
cellsAccessor.handle.addListener("change", handleCellsUpdate);
|
|
1146
|
+
return () => cellsAccessor.handle.removeListener("change", handleCellsUpdate);
|
|
1147
|
+
}, [
|
|
1322
1148
|
model,
|
|
1323
|
-
|
|
1324
|
-
|
|
1149
|
+
dxGrid
|
|
1150
|
+
]);
|
|
1151
|
+
useEffect3(() => {
|
|
1152
|
+
const columnMetaAccessor = createDocAccessor(model.sheet, [
|
|
1153
|
+
"columnMeta"
|
|
1154
|
+
]);
|
|
1155
|
+
const rowMetaAccessor = createDocAccessor(model.sheet, [
|
|
1156
|
+
"rowMeta"
|
|
1157
|
+
]);
|
|
1158
|
+
const handleColumnMetaUpdate = () => {
|
|
1159
|
+
setColumns(createDxGridColumns(model));
|
|
1160
|
+
};
|
|
1161
|
+
const handleRowMetaUpdate = () => {
|
|
1162
|
+
setRows(createDxGridRows(model));
|
|
1163
|
+
};
|
|
1164
|
+
columnMetaAccessor.handle.addListener("change", handleColumnMetaUpdate);
|
|
1165
|
+
rowMetaAccessor.handle.addListener("change", handleRowMetaUpdate);
|
|
1166
|
+
return () => {
|
|
1167
|
+
columnMetaAccessor.handle.removeListener("change", handleColumnMetaUpdate);
|
|
1168
|
+
rowMetaAccessor.handle.removeListener("change", handleRowMetaUpdate);
|
|
1169
|
+
};
|
|
1170
|
+
}, [
|
|
1171
|
+
model
|
|
1172
|
+
]);
|
|
1173
|
+
return {
|
|
1174
|
+
columns,
|
|
1175
|
+
rows
|
|
1176
|
+
};
|
|
1325
1177
|
};
|
|
1326
1178
|
|
|
1327
1179
|
// packages/plugins/plugin-sheet/src/components/GridSheet/GridSheet.tsx
|
|
1180
|
+
var inertPosition = {
|
|
1181
|
+
plane: "grid",
|
|
1182
|
+
col: 0,
|
|
1183
|
+
row: 0
|
|
1184
|
+
};
|
|
1328
1185
|
var initialCells = {
|
|
1329
1186
|
grid: {},
|
|
1330
1187
|
frozenColsStart: [
|
|
@@ -1365,11 +1222,12 @@ var sheetColDefault = {
|
|
|
1365
1222
|
}
|
|
1366
1223
|
};
|
|
1367
1224
|
var GridSheet = () => {
|
|
1368
|
-
const {
|
|
1369
|
-
const
|
|
1370
|
-
const
|
|
1225
|
+
const { t } = useTranslation2(SHEET_PLUGIN);
|
|
1226
|
+
const { id, model, editing, setEditing, setCursor, setRange, cursor, cursorFallbackRange, activeRefs } = useSheetContext();
|
|
1227
|
+
const [dxGrid, setDxGrid] = useState4(null);
|
|
1228
|
+
const rangeController = useRef();
|
|
1371
1229
|
const { hasAttention } = useAttention(id);
|
|
1372
|
-
const handleFocus =
|
|
1230
|
+
const handleFocus = useCallback4((event) => {
|
|
1373
1231
|
if (!editing) {
|
|
1374
1232
|
const cell = closestCell(event.target);
|
|
1375
1233
|
if (cell && cell.plane === "grid") {
|
|
@@ -1382,7 +1240,7 @@ var GridSheet = () => {
|
|
|
1382
1240
|
}, [
|
|
1383
1241
|
editing
|
|
1384
1242
|
]);
|
|
1385
|
-
const handleClose =
|
|
1243
|
+
const handleClose = useCallback4((value, { key, shift }) => {
|
|
1386
1244
|
if (value !== void 0) {
|
|
1387
1245
|
model.setValue(dxGridCellIndexToSheetCellAddress(editing.index), value);
|
|
1388
1246
|
}
|
|
@@ -1400,13 +1258,22 @@ var GridSheet = () => {
|
|
|
1400
1258
|
"ArrowUp",
|
|
1401
1259
|
"ArrowLeft"
|
|
1402
1260
|
].includes(key) ? -1 : 1 : shift ? -1 : 1;
|
|
1403
|
-
dxGrid
|
|
1261
|
+
dxGrid?.refocus(axis, delta);
|
|
1404
1262
|
}, [
|
|
1405
1263
|
model,
|
|
1406
1264
|
editing,
|
|
1407
|
-
|
|
1265
|
+
dxGrid
|
|
1266
|
+
]);
|
|
1267
|
+
const handleBlur = useCallback4((value) => {
|
|
1268
|
+
if (value !== void 0) {
|
|
1269
|
+
model.setValue(dxGridCellIndexToSheetCellAddress(editing.index), value);
|
|
1270
|
+
}
|
|
1271
|
+
setEditing(null);
|
|
1272
|
+
}, [
|
|
1273
|
+
model,
|
|
1274
|
+
editing
|
|
1408
1275
|
]);
|
|
1409
|
-
const handleAxisResize =
|
|
1276
|
+
const handleAxisResize = useCallback4(({ axis, size, index: numericIndex }) => {
|
|
1410
1277
|
if (axis === "row") {
|
|
1411
1278
|
const rowId = model.sheet.rows[parseInt(numericIndex)];
|
|
1412
1279
|
model.sheet.rowMeta[rowId] ??= {};
|
|
@@ -1419,39 +1286,35 @@ var GridSheet = () => {
|
|
|
1419
1286
|
}, [
|
|
1420
1287
|
model
|
|
1421
1288
|
]);
|
|
1422
|
-
const handleSelect =
|
|
1423
|
-
const
|
|
1289
|
+
const handleSelect = useCallback4(({ minCol, maxCol, minRow, maxRow }) => {
|
|
1290
|
+
const range = {
|
|
1424
1291
|
from: {
|
|
1425
1292
|
col: minCol,
|
|
1426
1293
|
row: minRow
|
|
1427
1294
|
}
|
|
1428
1295
|
};
|
|
1429
1296
|
if (minCol !== maxCol || minRow !== maxRow) {
|
|
1430
|
-
|
|
1297
|
+
range.to = {
|
|
1431
1298
|
col: maxCol,
|
|
1432
1299
|
row: maxRow
|
|
1433
1300
|
};
|
|
1434
1301
|
}
|
|
1435
1302
|
if (editing) {
|
|
1436
|
-
|
|
1303
|
+
rangeController.current?.setRange(rangeToA1Notation(range));
|
|
1437
1304
|
} else {
|
|
1438
|
-
setRange(
|
|
1305
|
+
setRange(range.to ? range : void 0);
|
|
1439
1306
|
}
|
|
1440
1307
|
}, [
|
|
1441
1308
|
editing
|
|
1442
1309
|
]);
|
|
1443
|
-
const handleWheel =
|
|
1310
|
+
const handleWheel = useCallback4((event) => {
|
|
1444
1311
|
if (!hasAttention) {
|
|
1445
1312
|
event.stopPropagation();
|
|
1446
1313
|
}
|
|
1447
1314
|
}, [
|
|
1448
1315
|
hasAttention
|
|
1449
1316
|
]);
|
|
1450
|
-
const handleKeyDown =
|
|
1451
|
-
const cursorFallbackRange = range ?? cursor ? {
|
|
1452
|
-
from: cursor,
|
|
1453
|
-
to: cursor
|
|
1454
|
-
} : null;
|
|
1317
|
+
const handleKeyDown = useCallback4((event) => {
|
|
1455
1318
|
switch (event.key) {
|
|
1456
1319
|
case "Backspace":
|
|
1457
1320
|
case "Delete":
|
|
@@ -1482,12 +1345,36 @@ var GridSheet = () => {
|
|
|
1482
1345
|
}
|
|
1483
1346
|
}
|
|
1484
1347
|
}, [
|
|
1485
|
-
|
|
1348
|
+
cursorFallbackRange,
|
|
1486
1349
|
model,
|
|
1487
1350
|
cursor
|
|
1488
1351
|
]);
|
|
1352
|
+
const contextMenuAnchorRef = useRef(null);
|
|
1353
|
+
const [contextMenuOpen, setContextMenuOpen] = useState4(null);
|
|
1354
|
+
const contextMenuAxis = contextMenuOpen?.plane.startsWith("frozenRows") ? "col" : "row";
|
|
1355
|
+
const handleContextMenu = useCallback4((event) => {
|
|
1356
|
+
const cell = closestCell(event.target);
|
|
1357
|
+
if (cell && cell.plane.startsWith("frozen")) {
|
|
1358
|
+
event.preventDefault();
|
|
1359
|
+
contextMenuAnchorRef.current = event.target;
|
|
1360
|
+
setContextMenuOpen(cell);
|
|
1361
|
+
}
|
|
1362
|
+
}, []);
|
|
1363
|
+
const handleAxisMenuAction = useCallback4((operation) => {
|
|
1364
|
+
switch (operation) {
|
|
1365
|
+
case "add-before":
|
|
1366
|
+
case "add-after":
|
|
1367
|
+
model[contextMenuAxis === "col" ? "insertColumns" : "insertRows"](contextMenuOpen[contextMenuAxis] + (operation === "add-before" ? 0 : 1), 1);
|
|
1368
|
+
break;
|
|
1369
|
+
case "remove":
|
|
1370
|
+
}
|
|
1371
|
+
}, [
|
|
1372
|
+
contextMenuAxis,
|
|
1373
|
+
contextMenuOpen,
|
|
1374
|
+
model
|
|
1375
|
+
]);
|
|
1489
1376
|
const { columns, rows } = useSheetModelDxGridProps(dxGrid, model);
|
|
1490
|
-
const extension =
|
|
1377
|
+
const extension = useMemo2(() => [
|
|
1491
1378
|
editorKeys({
|
|
1492
1379
|
onClose: handleClose,
|
|
1493
1380
|
...editing?.initialContent && {
|
|
@@ -1497,23 +1384,32 @@ var GridSheet = () => {
|
|
|
1497
1384
|
sheetExtension({
|
|
1498
1385
|
functions: model.graph.getFunctions()
|
|
1499
1386
|
}),
|
|
1500
|
-
rangeExtension(
|
|
1387
|
+
rangeExtension({
|
|
1388
|
+
onInit: (fn) => rangeController.current = fn,
|
|
1389
|
+
onStateChange: (state) => {
|
|
1390
|
+
if (dxGrid) {
|
|
1391
|
+
dxGrid.mode = typeof state.activeRange === "undefined" ? "edit" : "edit-select";
|
|
1392
|
+
}
|
|
1393
|
+
}
|
|
1394
|
+
})
|
|
1501
1395
|
], [
|
|
1502
1396
|
model,
|
|
1503
1397
|
handleClose,
|
|
1504
1398
|
editing
|
|
1505
1399
|
]);
|
|
1506
|
-
const getCellContent =
|
|
1400
|
+
const getCellContent = useCallback4((index) => {
|
|
1507
1401
|
const cell = dxGridCellIndexToSheetCellAddress(index);
|
|
1508
1402
|
return model.getCellText(cell);
|
|
1509
1403
|
}, [
|
|
1510
1404
|
model
|
|
1511
1405
|
]);
|
|
1512
|
-
useUpdateFocusedCellOnThreadSelection(
|
|
1513
|
-
|
|
1406
|
+
useUpdateFocusedCellOnThreadSelection(dxGrid);
|
|
1407
|
+
useSelectThreadOnCellFocus();
|
|
1408
|
+
return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(GridCellEditor, {
|
|
1514
1409
|
getCellContent,
|
|
1515
|
-
extension
|
|
1516
|
-
|
|
1410
|
+
extension,
|
|
1411
|
+
onBlur: handleBlur
|
|
1412
|
+
}), /* @__PURE__ */ React4.createElement(Grid2.Content, {
|
|
1517
1413
|
initialCells,
|
|
1518
1414
|
limitColumns: DEFAULT_COLUMNS,
|
|
1519
1415
|
limitRows: DEFAULT_ROWS,
|
|
@@ -1527,44 +1423,49 @@ var GridSheet = () => {
|
|
|
1527
1423
|
onFocus: handleFocus,
|
|
1528
1424
|
onWheelCapture: handleWheel,
|
|
1529
1425
|
onKeyDown: handleKeyDown,
|
|
1426
|
+
onContextMenu: handleContextMenu,
|
|
1530
1427
|
overscroll: "inline",
|
|
1531
1428
|
className: "[--dx-grid-base:var(--surface-bg)]",
|
|
1532
|
-
|
|
1533
|
-
|
|
1534
|
-
}
|
|
1535
|
-
|
|
1536
|
-
|
|
1537
|
-
|
|
1538
|
-
|
|
1539
|
-
|
|
1540
|
-
|
|
1541
|
-
|
|
1542
|
-
|
|
1543
|
-
|
|
1544
|
-
|
|
1545
|
-
|
|
1546
|
-
|
|
1547
|
-
|
|
1548
|
-
|
|
1549
|
-
|
|
1550
|
-
|
|
1551
|
-
|
|
1552
|
-
|
|
1429
|
+
activeRefs,
|
|
1430
|
+
ref: setDxGrid
|
|
1431
|
+
}), /* @__PURE__ */ React4.createElement(DropdownMenu.Root, {
|
|
1432
|
+
modal: false,
|
|
1433
|
+
open: !!contextMenuOpen,
|
|
1434
|
+
onOpenChange: (nextOpen) => setContextMenuOpen(nextOpen ? inertPosition : null)
|
|
1435
|
+
}, /* @__PURE__ */ React4.createElement(DropdownMenu.VirtualTrigger, {
|
|
1436
|
+
virtualRef: contextMenuAnchorRef
|
|
1437
|
+
}), /* @__PURE__ */ React4.createElement(DropdownMenu.Content, {
|
|
1438
|
+
side: contextMenuAxis === "col" ? "bottom" : "right",
|
|
1439
|
+
sideOffset: 4,
|
|
1440
|
+
collisionPadding: 8
|
|
1441
|
+
}, /* @__PURE__ */ React4.createElement(DropdownMenu.Viewport, null, /* @__PURE__ */ React4.createElement(DropdownMenu.Item, {
|
|
1442
|
+
onClick: () => handleAxisMenuAction("add-before")
|
|
1443
|
+
}, /* @__PURE__ */ React4.createElement(Icon, {
|
|
1444
|
+
size: 5,
|
|
1445
|
+
icon: contextMenuAxis === "col" ? "ph--columns-plus-left--regular" : "ph--rows-plus-top--regular"
|
|
1446
|
+
}), /* @__PURE__ */ React4.createElement("span", null, t(`add ${contextMenuAxis} before label`))), /* @__PURE__ */ React4.createElement(DropdownMenu.Item, {
|
|
1447
|
+
onClick: () => handleAxisMenuAction("add-after")
|
|
1448
|
+
}, /* @__PURE__ */ React4.createElement(Icon, {
|
|
1449
|
+
size: 5,
|
|
1450
|
+
icon: contextMenuAxis === "col" ? "ph--columns-plus-right--regular" : "ph--rows-plus-bottom--regular"
|
|
1451
|
+
}), /* @__PURE__ */ React4.createElement("span", null, t(`add ${contextMenuAxis} after label`))), /* @__PURE__ */ React4.createElement(DropdownMenu.Item, {
|
|
1452
|
+
disabled: true,
|
|
1453
|
+
onClick: () => handleAxisMenuAction("remove")
|
|
1454
|
+
}, /* @__PURE__ */ React4.createElement(Icon, {
|
|
1455
|
+
size: 5,
|
|
1456
|
+
icon: "ph--backspace--regular"
|
|
1457
|
+
}), /* @__PURE__ */ React4.createElement("span", null, t(`delete ${contextMenuAxis} label`)))), /* @__PURE__ */ React4.createElement(DropdownMenu.Arrow, null))));
|
|
1553
1458
|
};
|
|
1554
1459
|
|
|
1555
1460
|
export {
|
|
1556
1461
|
ComputeGraphContextProvider,
|
|
1557
|
-
addressToA1Notation,
|
|
1558
|
-
rangeToA1Notation,
|
|
1559
|
-
inRange,
|
|
1560
|
-
createSheet,
|
|
1561
|
-
addressToIndex,
|
|
1562
|
-
compareIndexPositions,
|
|
1563
|
-
computeGraphFacet,
|
|
1564
1462
|
useComputeGraph,
|
|
1463
|
+
completeCellRangeToThreadCursor,
|
|
1464
|
+
computeGraphFacet,
|
|
1565
1465
|
useSheetContext,
|
|
1566
1466
|
SheetProvider,
|
|
1567
1467
|
GridSheet,
|
|
1468
|
+
RangeList,
|
|
1568
1469
|
SheetContainer
|
|
1569
1470
|
};
|
|
1570
|
-
//# sourceMappingURL=chunk-
|
|
1471
|
+
//# sourceMappingURL=chunk-I2DKJ72A.mjs.map
|