@dxos/plugin-sheet 0.6.11-staging.e6894a4 → 0.6.11
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-4XOKHKKZ.mjs → SheetContainer-U4H5D34A.mjs} +30 -28
- package/dist/lib/browser/SheetContainer-U4H5D34A.mjs.map +7 -0
- package/dist/lib/browser/{chunk-FWGRE3EG.mjs → chunk-APHOLYUB.mjs} +2 -2
- package/dist/lib/browser/{chunk-P7SSL3EG.mjs → chunk-D5AGLXJP.mjs} +9 -9
- package/dist/lib/browser/chunk-D5AGLXJP.mjs.map +7 -0
- package/dist/lib/browser/chunk-NU4PBN33.mjs +8 -0
- package/dist/lib/browser/index.mjs +18 -16
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing.mjs +2 -2
- package/dist/lib/node/{SheetContainer-IQT6TR4Z.cjs → SheetContainer-AXQV3ZT5.cjs} +45 -43
- package/dist/lib/node/SheetContainer-AXQV3ZT5.cjs.map +7 -0
- package/dist/lib/node/{chunk-SVAIIXWQ.cjs → chunk-5KKJ4NPP.cjs} +12 -12
- package/dist/lib/node/chunk-5KKJ4NPP.cjs.map +7 -0
- package/dist/lib/node/{chunk-727C6YNP.cjs → chunk-CN3RPESU.cjs} +9 -9
- package/dist/lib/node/{chunk-5EPCDAZC.cjs → chunk-PYXHNAAK.cjs} +5 -5
- package/dist/lib/node/index.cjs +25 -23
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/testing.cjs +4 -4
- package/dist/types/src/SheetPlugin.d.ts.map +1 -1
- package/dist/types/src/components/Sheet/Sheet.d.ts.map +1 -1
- package/dist/types/src/components/Sheet/Sheet.stories.d.ts.map +1 -1
- package/dist/types/src/components/SheetContainer.d.ts +1 -1
- package/dist/types/src/components/SheetContainer.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/model/model.d.ts.map +1 -1
- package/package.json +28 -28
- package/src/SheetPlugin.tsx +18 -12
- package/src/components/Sheet/Sheet.stories.tsx +6 -8
- package/src/components/Sheet/Sheet.tsx +13 -22
- package/src/components/SheetContainer.tsx +1 -3
- package/src/components/Toolbar/Toolbar.stories.tsx +5 -10
- package/src/model/model.ts +2 -3
- package/dist/lib/browser/SheetContainer-4XOKHKKZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-P7SSL3EG.mjs.map +0 -7
- package/dist/lib/browser/chunk-YPU3R7FA.mjs +0 -8
- package/dist/lib/node/SheetContainer-IQT6TR4Z.cjs.map +0 -7
- package/dist/lib/node/chunk-SVAIIXWQ.cjs.map +0 -7
- /package/dist/lib/browser/{chunk-FWGRE3EG.mjs.map → chunk-APHOLYUB.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-YPU3R7FA.mjs.map → chunk-NU4PBN33.mjs.map} +0 -0
- /package/dist/lib/node/{chunk-727C6YNP.cjs.map → chunk-CN3RPESU.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-5EPCDAZC.cjs.map → chunk-PYXHNAAK.cjs.map} +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
useComputeGraph
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-APHOLYUB.mjs";
|
|
4
4
|
import {
|
|
5
5
|
SheetModel,
|
|
6
6
|
addressFromA1Notation,
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
inRange,
|
|
11
11
|
posEquals,
|
|
12
12
|
rangeToA1Notation
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-D5AGLXJP.mjs";
|
|
14
14
|
import {
|
|
15
15
|
ValueTypeEnum
|
|
16
16
|
} from "./chunk-FUAGSXA4.mjs";
|
|
@@ -32,7 +32,7 @@ import { useResizeDetector } from "react-resize-detector";
|
|
|
32
32
|
import { debounce } from "@dxos/async";
|
|
33
33
|
import { fullyQualifiedId as fullyQualifiedId2, createDocAccessor } from "@dxos/client/echo";
|
|
34
34
|
import { log } from "@dxos/log";
|
|
35
|
-
import { createAttendableAttributes } from "@dxos/react-ui-attention";
|
|
35
|
+
import { createAttendableAttributes, useHasAttention } from "@dxos/react-ui-attention";
|
|
36
36
|
import { mx as mx2 } from "@dxos/react-ui-theme";
|
|
37
37
|
|
|
38
38
|
// packages/plugins/plugin-sheet/src/components/Sheet/grid.ts
|
|
@@ -373,6 +373,9 @@ var FormattingModel = class {
|
|
|
373
373
|
]
|
|
374
374
|
};
|
|
375
375
|
}
|
|
376
|
+
//
|
|
377
|
+
// Numbers.
|
|
378
|
+
//
|
|
376
379
|
case ValueTypeEnum.Number: {
|
|
377
380
|
return {
|
|
378
381
|
value: value.toLocaleString(locales),
|
|
@@ -405,6 +408,9 @@ var FormattingModel = class {
|
|
|
405
408
|
]
|
|
406
409
|
};
|
|
407
410
|
}
|
|
411
|
+
//
|
|
412
|
+
// Dates.
|
|
413
|
+
//
|
|
408
414
|
case ValueTypeEnum.DateTime: {
|
|
409
415
|
const date = this.model.toLocalDate(value);
|
|
410
416
|
return {
|
|
@@ -888,8 +894,7 @@ var fragments = {
|
|
|
888
894
|
axis: "bg-axisSurface text-axisText text-xs select-none",
|
|
889
895
|
axisSelected: "bg-attention text-baseText",
|
|
890
896
|
cell: "bg-gridCell",
|
|
891
|
-
cellSelected: "bg-gridCellSelected text-baseText border !border-accentSurface"
|
|
892
|
-
border: "border-gridLine"
|
|
897
|
+
cellSelected: "bg-gridCellSelected text-baseText border !border-accentSurface"
|
|
893
898
|
};
|
|
894
899
|
var SheetRoot = ({ children, ...props }) => {
|
|
895
900
|
return /* @__PURE__ */ React3.createElement(SheetContextProvider, props, children);
|
|
@@ -1009,7 +1014,7 @@ var SheetMain = /* @__PURE__ */ forwardRef(({ classNames, numRows, numColumns },
|
|
|
1009
1014
|
};
|
|
1010
1015
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1011
1016
|
role: "none",
|
|
1012
|
-
className: mx2("grid grid-cols-[calc(var(--rail-size)-2px)_1fr] grid-rows-[32px_1fr_32px] bs-full is-full overflow-hidden",
|
|
1017
|
+
className: mx2("grid grid-cols-[calc(var(--rail-size)-2px)_1fr] grid-rows-[32px_1fr_32px] bs-full is-full overflow-hidden", classNames)
|
|
1013
1018
|
}, /* @__PURE__ */ React3.createElement(GridCorner, {
|
|
1014
1019
|
onClick: () => {
|
|
1015
1020
|
setCursor(void 0);
|
|
@@ -1144,7 +1149,7 @@ var SheetRows = /* @__PURE__ */ forwardRef(({ rows, sizes, selected, onSelect, o
|
|
|
1144
1149
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1145
1150
|
className: "relative flex grow overflow-hidden"
|
|
1146
1151
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
1147
|
-
className: mx2("z-20 absolute inset-0 border-y pointer-events-none"
|
|
1152
|
+
className: mx2("z-20 absolute inset-0 border-y border-gridLine pointer-events-none"),
|
|
1148
1153
|
style: {
|
|
1149
1154
|
width: axisWidth
|
|
1150
1155
|
}
|
|
@@ -1232,7 +1237,7 @@ var GridRowCell = ({ idx, index, label, size, resize, selected, onSelect, onResi
|
|
|
1232
1237
|
ref: setNodeRef,
|
|
1233
1238
|
...attributes,
|
|
1234
1239
|
...listeners,
|
|
1235
|
-
className: mx2("flex h-full items-center justify-center cursor-pointer", "border-t focus-visible:outline-none", fragments.
|
|
1240
|
+
className: mx2("flex h-full items-center justify-center cursor-pointer", "border-t border-gridLine focus-visible:outline-none", fragments.axis, selected && fragments.axisSelected, isDragging && fragments.axisSelected),
|
|
1236
1241
|
onClick: () => onSelect?.(index)
|
|
1237
1242
|
}, /* @__PURE__ */ React3.createElement("span", {
|
|
1238
1243
|
className: "flex w-full justify-center"
|
|
@@ -1278,7 +1283,7 @@ var SheetColumns = /* @__PURE__ */ forwardRef(({ columns, sizes, selected, onSel
|
|
|
1278
1283
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1279
1284
|
className: "relative flex grow overflow-hidden"
|
|
1280
1285
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
1281
|
-
className: mx2("z-20 absolute inset-0 border-x pointer-events-none"
|
|
1286
|
+
className: mx2("z-20 absolute inset-0 border-x border-gridLine pointer-events-none"),
|
|
1282
1287
|
style: {
|
|
1283
1288
|
height: axisHeight
|
|
1284
1289
|
}
|
|
@@ -1369,7 +1374,7 @@ var GridColumnCell = ({ idx, index, label, size, resize, selected, onSelect, onR
|
|
|
1369
1374
|
ref: setNodeRef,
|
|
1370
1375
|
...attributes,
|
|
1371
1376
|
...listeners,
|
|
1372
|
-
className: mx2("flex h-full items-center justify-center cursor-pointer", "border-l focus-visible:outline-none", fragments.
|
|
1377
|
+
className: mx2("flex h-full items-center justify-center cursor-pointer", "border-l border-gridLine focus-visible:outline-none", fragments.axis, selected && fragments.axisSelected, isDragging && fragments.axisSelected),
|
|
1373
1378
|
onClick: () => onSelect?.(index)
|
|
1374
1379
|
}, /* @__PURE__ */ React3.createElement("span", {
|
|
1375
1380
|
className: "flex w-full justify-center"
|
|
@@ -1395,7 +1400,7 @@ var SheetGrid = /* @__PURE__ */ forwardRef(({ size, rows, columns, rowSizes, col
|
|
|
1395
1400
|
id: model.id
|
|
1396
1401
|
}, {
|
|
1397
1402
|
F: __dxlog_file2,
|
|
1398
|
-
L:
|
|
1403
|
+
L: 730,
|
|
1399
1404
|
S: void 0,
|
|
1400
1405
|
C: (f, a) => f(...a)
|
|
1401
1406
|
});
|
|
@@ -1512,18 +1517,18 @@ var SheetGrid = /* @__PURE__ */ forwardRef(({ size, rows, columns, rowSizes, col
|
|
|
1512
1517
|
rowSizes,
|
|
1513
1518
|
columnSizes
|
|
1514
1519
|
});
|
|
1515
|
-
const
|
|
1516
|
-
const attendableAttrs = createAttendableAttributes(
|
|
1517
|
-
const
|
|
1520
|
+
const id = fullyQualifiedId2(model.sheet);
|
|
1521
|
+
const attendableAttrs = createAttendableAttributes(id);
|
|
1522
|
+
const hasAttention = useHasAttention(id);
|
|
1518
1523
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1519
1524
|
ref: containerRef,
|
|
1520
1525
|
role: "grid",
|
|
1521
1526
|
className: "relative flex grow overflow-hidden"
|
|
1522
1527
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
1523
|
-
className: mx2("z-20 absolute inset-0 border pointer-events-none"
|
|
1528
|
+
className: mx2("z-20 absolute inset-0 border border-gridLine pointer-events-none")
|
|
1524
1529
|
}), /* @__PURE__ */ React3.createElement("div", {
|
|
1525
1530
|
ref: scrollerRef,
|
|
1526
|
-
className: mx2("grow",
|
|
1531
|
+
className: mx2("grow", hasAttention && "overflow-auto scrollbar-thin")
|
|
1527
1532
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
1528
1533
|
className: "relative select-none",
|
|
1529
1534
|
style: {
|
|
@@ -1547,7 +1552,7 @@ var SheetGrid = /* @__PURE__ */ forwardRef(({ size, rows, columns, rowSizes, col
|
|
|
1547
1552
|
row,
|
|
1548
1553
|
column
|
|
1549
1554
|
};
|
|
1550
|
-
const
|
|
1555
|
+
const id2 = addressToA1Notation(cell);
|
|
1551
1556
|
const idx = model.addressToIndex(cell);
|
|
1552
1557
|
const active = posEquals(cursor, cell);
|
|
1553
1558
|
if (active && editing) {
|
|
@@ -1590,8 +1595,8 @@ var SheetGrid = /* @__PURE__ */ forwardRef(({ size, rows, columns, rowSizes, col
|
|
|
1590
1595
|
});
|
|
1591
1596
|
}
|
|
1592
1597
|
return /* @__PURE__ */ React3.createElement(SheetCell, {
|
|
1593
|
-
key:
|
|
1594
|
-
id,
|
|
1598
|
+
key: id2,
|
|
1599
|
+
id: id2,
|
|
1595
1600
|
cell,
|
|
1596
1601
|
active,
|
|
1597
1602
|
style,
|
|
@@ -1635,7 +1640,7 @@ var SheetCell = ({ id, cell, style, active, onSelect }) => {
|
|
|
1635
1640
|
[`data-${CELL_DATA_KEY}`]: id,
|
|
1636
1641
|
role: "cell",
|
|
1637
1642
|
style,
|
|
1638
|
-
className: mx2("flex w-full h-full truncate items-center border cursor-pointer",
|
|
1643
|
+
className: mx2("flex w-full h-full px-2 py-1 truncate items-center border border-gridLine cursor-pointer", fragments.cell, active && [
|
|
1639
1644
|
"z-20",
|
|
1640
1645
|
fragments.cellSelected
|
|
1641
1646
|
], classNames),
|
|
@@ -1698,7 +1703,7 @@ var SheetStatusBar = () => {
|
|
|
1698
1703
|
}
|
|
1699
1704
|
}
|
|
1700
1705
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1701
|
-
className: mx2("flex shrink-0 justify-between items-center px-4 py-1 text-sm border-x
|
|
1706
|
+
className: mx2("flex shrink-0 justify-between items-center px-4 py-1 text-sm border-x border-gridLine")
|
|
1702
1707
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
1703
1708
|
className: "flex gap-4 items-center"
|
|
1704
1709
|
}, /* @__PURE__ */ React3.createElement("div", {
|
|
@@ -1726,7 +1731,7 @@ var SheetDebug = () => {
|
|
|
1726
1731
|
model
|
|
1727
1732
|
]);
|
|
1728
1733
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1729
|
-
className: mx2("z-20 absolute right-0 top-20 bottom-20 w-[30rem] overflow-auto scrollbar-thin", "border text-xs bg-neutral-50 dark:bg-black text-cyan-500 font-mono p-1 opacity-80"
|
|
1734
|
+
className: mx2("z-20 absolute right-0 top-20 bottom-20 w-[30rem] overflow-auto scrollbar-thin", "border border-gridLine text-xs bg-neutral-50 dark:bg-black text-cyan-500 font-mono p-1 opacity-80")
|
|
1730
1735
|
}, /* @__PURE__ */ React3.createElement("pre", {
|
|
1731
1736
|
className: "whitespace-pre-wrap"
|
|
1732
1737
|
}, JSON.stringify({
|
|
@@ -1750,13 +1755,10 @@ var Sheet = {
|
|
|
1750
1755
|
};
|
|
1751
1756
|
|
|
1752
1757
|
// packages/plugins/plugin-sheet/src/components/SheetContainer.tsx
|
|
1753
|
-
var SheetContainer = ({ sheet, space, role,
|
|
1754
|
-
part: "main",
|
|
1755
|
-
entryId: ""
|
|
1756
|
-
}, remoteFunctionUrl }) => {
|
|
1758
|
+
var SheetContainer = ({ sheet, space, role, remoteFunctionUrl }) => {
|
|
1757
1759
|
return /* @__PURE__ */ React4.createElement("div", {
|
|
1758
1760
|
role: "none",
|
|
1759
|
-
className: mx3("flex", role === "article" && "row-span-2", role === "section" && "aspect-square border-y border-is border-separator"
|
|
1761
|
+
className: mx3("flex", role === "article" && "row-span-2", role === "section" && "aspect-square border-y border-is border-separator")
|
|
1760
1762
|
}, /* @__PURE__ */ React4.createElement(Sheet.Root, {
|
|
1761
1763
|
sheet,
|
|
1762
1764
|
space,
|
|
@@ -1767,4 +1769,4 @@ var SheetContainer_default = SheetContainer;
|
|
|
1767
1769
|
export {
|
|
1768
1770
|
SheetContainer_default as default
|
|
1769
1771
|
};
|
|
1770
|
-
//# sourceMappingURL=SheetContainer-
|
|
1772
|
+
//# sourceMappingURL=SheetContainer-U4H5D34A.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/SheetContainer.tsx", "../../../src/components/Sheet/Sheet.tsx", "../../../src/components/Sheet/grid.ts", "../../../src/components/Sheet/nav.ts", "../../../src/components/Sheet/sheet-context.tsx", "../../../src/components/Sheet/formatting.ts", "../../../src/components/Sheet/util.ts", "../../../src/components/CellEditor/CellEditor.tsx", "../../../src/components/CellEditor/extension.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type LayoutCoordinate } from '@dxos/app-framework';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { Sheet, type SheetRootProps } from './Sheet';\n\nconst SheetContainer = ({\n sheet,\n space,\n role,\n remoteFunctionUrl,\n}: SheetRootProps & { role?: string; coordinate?: LayoutCoordinate }) => {\n return (\n <div\n role='none'\n className={mx(\n 'flex',\n role === 'article' && 'row-span-2',\n role === 'section' && 'aspect-square border-y border-is border-separator',\n )}\n >\n <Sheet.Root sheet={sheet} space={space} remoteFunctionUrl={remoteFunctionUrl}>\n <Sheet.Main />\n </Sheet.Root>\n </div>\n );\n};\n\nexport default SheetContainer;\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport {\n type Active,\n DndContext,\n type DragEndEvent,\n DragOverlay,\n type DragStartEvent,\n KeyboardSensor,\n type Modifier,\n MouseSensor,\n type PointerActivationConstraint,\n TouchSensor,\n useDraggable,\n useDroppable,\n useSensor,\n useSensors,\n} from '@dnd-kit/core';\nimport { restrictToHorizontalAxis, restrictToVerticalAxis } from '@dnd-kit/modifiers';\nimport { getEventCoordinates, useCombinedRefs } from '@dnd-kit/utilities';\nimport { Function as FunctionIcon } from '@phosphor-icons/react';\nimport { Resizable, type ResizeCallback, type ResizeStartCallback } from 're-resizable';\nimport React, {\n type CSSProperties,\n type DOMAttributes,\n type PropsWithChildren,\n forwardRef,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { createPortal } from 'react-dom';\nimport { useResizeDetector } from 'react-resize-detector';\n\nimport { debounce } from '@dxos/async';\nimport { fullyQualifiedId, createDocAccessor } from '@dxos/client/echo';\nimport { log } from '@dxos/log';\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { createAttendableAttributes, useHasAttention } from '@dxos/react-ui-attention';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport {\n type GridLayoutProps,\n type SizeMap,\n CELL_DATA_KEY,\n axisHeight,\n axisWidth,\n defaultHeight,\n defaultWidth,\n maxWidth,\n maxHeight,\n minWidth,\n minHeight,\n getCellElement,\n useGridLayout,\n} from './grid';\nimport { type GridSize, handleArrowNav, handleNav, useRangeSelect } from './nav';\nimport { type SheetContextProps, SheetContextProvider, useSheetContext } from './sheet-context';\nimport { getRectUnion, getRelativeClientRect, scrollIntoView } from './util';\nimport {\n type CellIndex,\n type CellAddress,\n addressToA1Notation,\n columnLetter,\n posEquals,\n rangeToA1Notation,\n} from '../../model';\nimport {\n CellEditor,\n type CellRangeNotifier,\n type EditorKeysProps,\n editorKeys,\n rangeExtension,\n sheetExtension,\n} from '../CellEditor';\n\n// TODO(burdon): Virtualization bug.\n// TODO(burdon): Toolbar styles and formatting.\n// TODO(burdon): Insert/delete rows/columns (menu).\n// TODO(burdon): Scroll to position if off screen.\n// TODO(burdon): Don't render until sizes were updated (otherwise, flickers).\n\n// TODO(burdon): Model multiple sheets (e.g., documents). And cross sheet references.\n// TODO(burdon): Factor out react-ui-sheet.\n// TODO(burdon): Comments (josiah).\n// TODO(burdon): Realtime long text.\n// TODO(burdon): Search.\n\n// TODO(burdon): Virtualization:\n// https://github.com/TanStack/virtual/blob/main/examples/react/dynamic/src/main.tsx#L171\n// https://tanstack.com/virtual/v3/docs/framework/react/examples/variable\n// https://canvas-grid-demo.vercel.app\n// https://sheet.brianhung.me\n// https://github.com/BrianHung\n// https://daybrush.com/moveable\n\n/**\n * Features:\n * - Move rows/columns.\n * - Insert/delete rows/columns.\n * - Copy/paste.\n * - Undo/redo.\n * - Comments.\n * - Real time collaborative editing of large text cells.\n * - Select range.\n * - Format cells.\n * - Formulae.\n * - Update formula ranges by selection.\n */\n\nconst fragments = {\n axis: 'bg-axisSurface text-axisText text-xs select-none',\n axisSelected: 'bg-attention text-baseText',\n cell: 'bg-gridCell',\n cellSelected: 'bg-gridCellSelected text-baseText border !border-accentSurface',\n};\n\n//\n// Root\n//\n\ntype SheetRootProps = SheetContextProps;\n\nconst SheetRoot = ({ children, ...props }: PropsWithChildren<SheetContextProps>) => {\n return <SheetContextProvider {...props}>{children}</SheetContextProvider>;\n};\n\n//\n// Main\n//\n\ntype SheetMainProps = ThemedClassName<Partial<GridSize>>;\n\nconst SheetMain = forwardRef<HTMLDivElement, SheetMainProps>(({ classNames, numRows, numColumns }, forwardRef) => {\n const { model, cursor, setCursor, setRange, setEditing } = useSheetContext();\n\n // Scrolling.\n const { rowsRef, columnsRef, contentRef } = useScrollHandlers();\n\n //\n // Order of Row/columns.\n //\n const [rows, setRows] = useState([...model.sheet.rows]);\n const [columns, setColumns] = useState([...model.sheet.columns]);\n useEffect(() => {\n const rowsAccessor = createDocAccessor(model.sheet, ['rows']);\n const columnsAccessor = createDocAccessor(model.sheet, ['columns']);\n const handleUpdate = debounce(() => {\n setRows([...model.sheet.rows]);\n setColumns([...model.sheet.columns]);\n }, 100);\n\n rowsAccessor.handle.addListener('change', handleUpdate);\n columnsAccessor.handle.addListener('change', handleUpdate);\n handleUpdate();\n return () => {\n rowsAccessor.handle.removeListener('change', handleUpdate);\n columnsAccessor.handle.removeListener('change', handleUpdate);\n };\n }, [model]);\n\n // Refresh the model.\n // TODO(burdon): Breaks undo.\n useEffect(() => {\n model.reset();\n }, [rows, columns]);\n\n const handleMoveRows: SheetRowsProps['onMove'] = (from, to, num = 1) => {\n const cursorIdx = cursor ? model.addressToIndex(cursor) : undefined;\n const [rows] = model.sheet.rows.splice(from, num);\n model.sheet.rows.splice(to, 0, rows);\n if (cursorIdx) {\n setCursor(model.addressFromIndex(cursorIdx));\n }\n setRows([...model.sheet.rows]);\n };\n\n const handleMoveColumns: SheetColumnsProps['onMove'] = (from, to, num = 1) => {\n const cursorIdx = cursor ? model.addressToIndex(cursor) : undefined;\n const columns = model.sheet.columns.splice(from, num);\n model.sheet.columns.splice(to, 0, ...columns);\n if (cursorIdx) {\n setCursor(model.addressFromIndex(cursorIdx));\n }\n setColumns([...model.sheet.columns]);\n };\n\n //\n // Row/column sizes.\n //\n const [rowSizes, setRowSizes] = useState<SizeMap>();\n const [columnSizes, setColumnSizes] = useState<SizeMap>();\n useEffect(() => {\n const rowAccessor = createDocAccessor(model.sheet, ['rowMeta']);\n const columnAccessor = createDocAccessor(model.sheet, ['columnMeta']);\n const handleUpdate = debounce(() => {\n const mapSizes = (values: [string, { size?: number | undefined }][]) =>\n values.reduce<SizeMap>((map, [idx, meta]) => {\n if (meta.size) {\n map[idx] = meta.size;\n }\n return map;\n }, {});\n\n setRowSizes(mapSizes(Object.entries(model.sheet.rowMeta)));\n setColumnSizes(mapSizes(Object.entries(model.sheet.columnMeta)));\n }, 100);\n\n rowAccessor.handle.addListener('change', handleUpdate);\n columnAccessor.handle.addListener('change', handleUpdate);\n handleUpdate();\n return () => {\n rowAccessor.handle.removeListener('change', handleUpdate);\n columnAccessor.handle.removeListener('change', handleUpdate);\n };\n }, [model]);\n\n const handleResizeRow: SheetRowsProps['onResize'] = (idx, size, save) => {\n if (save) {\n model.sheet.rowMeta[idx] ??= {};\n model.sheet.rowMeta[idx].size = size;\n } else {\n setRowSizes((sizes) => ({ ...sizes, [idx]: size }));\n }\n };\n\n const handleResizeColumn: SheetColumnsProps['onResize'] = (idx, size, save) => {\n if (save) {\n model.sheet.columnMeta[idx] ??= {};\n model.sheet.columnMeta[idx].size = size;\n } else {\n setColumnSizes((sizes) => ({ ...sizes, [idx]: size }));\n }\n };\n\n return (\n <div\n role='none'\n className={mx(\n 'grid grid-cols-[calc(var(--rail-size)-2px)_1fr] grid-rows-[32px_1fr_32px] bs-full is-full overflow-hidden',\n classNames,\n )}\n >\n <GridCorner\n onClick={() => {\n setCursor(undefined);\n setRange(undefined);\n setEditing(false);\n }}\n />\n <SheetColumns\n ref={columnsRef}\n columns={columns}\n sizes={columnSizes}\n selected={cursor?.column}\n onSelect={(column) => setCursor(cursor?.column === column ? undefined : { row: -1, column })}\n onResize={handleResizeColumn}\n onMove={handleMoveColumns}\n />\n\n <SheetRows\n ref={rowsRef}\n rows={rows}\n sizes={rowSizes}\n selected={cursor?.row}\n onSelect={(row) => setCursor(cursor?.row === row ? undefined : { row, column: -1 })}\n onResize={handleResizeRow}\n onMove={handleMoveRows}\n />\n <SheetGrid\n ref={contentRef}\n size={{ numRows: numRows ?? rows.length, numColumns: numColumns ?? columns.length }}\n rows={rows}\n columns={columns}\n rowSizes={rowSizes}\n columnSizes={columnSizes}\n />\n\n <GridCorner />\n <SheetStatusBar />\n </div>\n );\n});\n\n/**\n * Coordinate scrolling across components.\n */\nconst useScrollHandlers = () => {\n const rowsRef = useRef<HTMLDivElement>(null);\n const columnsRef = useRef<HTMLDivElement>(null);\n const contentRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const handleRowsScroll = (ev: Event) => {\n const { scrollTop } = ev.target as HTMLDivElement;\n if (!rowsRef.current!.dataset.locked) {\n contentRef.current!.scrollTop = scrollTop;\n }\n };\n\n const handleColumnsScroll = (ev: Event) => {\n const { scrollLeft } = ev.target as HTMLDivElement;\n if (!columnsRef.current!.dataset.locked) {\n contentRef.current!.scrollLeft = scrollLeft;\n }\n };\n\n const handleContentScroll = (ev: Event) => {\n const { scrollTop, scrollLeft } = ev.target as HTMLDivElement;\n rowsRef.current!.scrollTop = scrollTop;\n columnsRef.current!.scrollLeft = scrollLeft;\n };\n\n const rows = rowsRef.current!;\n const columns = columnsRef.current!;\n const content = contentRef.current!;\n\n rows.addEventListener('scroll', handleRowsScroll);\n columns.addEventListener('scroll', handleColumnsScroll);\n content.addEventListener('scroll', handleContentScroll);\n return () => {\n rows.removeEventListener('scroll', handleRowsScroll);\n columns.removeEventListener('scroll', handleColumnsScroll);\n content.removeEventListener('scroll', handleContentScroll);\n };\n }, []);\n\n return { rowsRef, columnsRef, contentRef };\n};\n\n//\n// Row/Column\n//\n\nconst GridCorner = (props: { className?: string } & Pick<DOMAttributes<HTMLDivElement>, 'onClick'>) => {\n return <div className={fragments.axis} {...props} />;\n};\n\nconst MovingOverlay = ({ label }: { label: string }) => {\n return (\n <div className='flex w-full h-full justify-center items-center text-sm p-1 bg-gridOverlay cursor-pointer'>\n {label}\n </div>\n );\n};\n\n// https://docs.dndkit.com/api-documentation/sensors/pointer#activation-constraints\nconst mouseConstraints: PointerActivationConstraint = { distance: 10 };\nconst touchConstraints: PointerActivationConstraint = { delay: 250, tolerance: 5 };\n\ntype ResizeProps = {\n sizes?: SizeMap;\n onResize?: (idx: CellIndex, size: number, save?: boolean) => void;\n};\n\ntype MoveProps = {\n onMove?: (from: number, to: number) => void;\n};\n\ntype RowColumnSelection = {\n selected?: number;\n onSelect?: (selected: number) => void;\n};\n\ntype RowColumnProps = {\n idx: CellIndex;\n index: number;\n label: string;\n size: number;\n resize: boolean;\n selected: boolean;\n} & Pick<ResizeProps, 'onResize'> &\n Pick<RowColumnSelection, 'onSelect'>;\n\n//\n// Rows\n//\n\ntype SheetRowsProps = { rows: CellIndex[] } & RowColumnSelection & ResizeProps & MoveProps;\n\nconst SheetRows = forwardRef<HTMLDivElement, SheetRowsProps>(\n ({ rows, sizes, selected, onSelect, onResize, onMove }, forwardRef) => {\n const mouseSensor = useSensor(MouseSensor, { activationConstraint: mouseConstraints });\n const touchSensor = useSensor(TouchSensor, { activationConstraint: touchConstraints });\n const keyboardSensor = useSensor(KeyboardSensor, {});\n const sensors = useSensors(mouseSensor, touchSensor, keyboardSensor);\n\n const [active, setActive] = useState<Active | null>(null);\n const handleDragStart = ({ active }: DragStartEvent) => {\n setActive(active);\n };\n\n const handleDragEnd = ({ over, active }: DragEndEvent) => {\n if (over && over.id !== active.id) {\n setActive(null);\n onMove?.(active.data.current!.index, over.data.current!.index);\n }\n };\n\n const snapToCenter: Modifier = ({ activatorEvent, draggingNodeRect, transform }) => {\n if (draggingNodeRect && activatorEvent) {\n const activatorCoordinates = getEventCoordinates(activatorEvent);\n if (!activatorCoordinates) {\n return transform;\n }\n\n const offset = activatorCoordinates.y - draggingNodeRect.top;\n return {\n ...transform,\n y: transform.y + offset - draggingNodeRect.height / 2,\n };\n }\n\n return transform;\n };\n\n return (\n <div className='relative flex grow overflow-hidden'>\n {/* Fixed border. */}\n <div\n className={mx('z-20 absolute inset-0 border-y border-gridLine pointer-events-none')}\n style={{ width: axisWidth }}\n />\n\n {/* Scrollbar. */}\n <div ref={forwardRef} role='rowheader' className='grow overflow-y-auto scrollbar-none'>\n <DndContext\n sensors={sensors}\n modifiers={[restrictToVerticalAxis, snapToCenter]}\n onDragStart={handleDragStart}\n onDragEnd={handleDragEnd}\n >\n <div className='flex flex-col' style={{ width: axisWidth }}>\n {rows.map((idx, index) => (\n <GridRowCell\n key={idx}\n idx={idx}\n index={index}\n label={String(index + 1)}\n size={sizes?.[idx] ?? defaultHeight}\n resize={index < rows.length - 1}\n selected={selected === index}\n onResize={onResize}\n onSelect={onSelect}\n />\n ))}\n </div>\n\n {createPortal(\n <DragOverlay>{active && <MovingOverlay label={String(active.data.current!.index + 1)} />}</DragOverlay>,\n document.body,\n )}\n </DndContext>\n </div>\n </div>\n );\n },\n);\n\nconst GridRowCell = ({ idx, index, label, size, resize, selected, onSelect, onResize }: RowColumnProps) => {\n const { setNodeRef: setDroppableNodeRef } = useDroppable({ id: idx, data: { index } });\n const {\n setNodeRef: setDraggableNodeRef,\n attributes,\n listeners,\n isDragging,\n over,\n } = useDraggable({ id: idx, data: { index } });\n const setNodeRef = useCombinedRefs(setDroppableNodeRef, setDraggableNodeRef);\n const [initialSize, setInitialSize] = useState(size);\n const [resizing, setResizing] = useState(false);\n\n // Lock scroll container while resizing (fixes scroll bug).\n // https://github.com/bokuweb/re-resizable/issues/727\n const scrollHandler = useRef<any>();\n const handleResizeStart: ResizeStartCallback = (_ev, _dir, elementRef) => {\n const scrollContainer = elementRef.closest<HTMLDivElement>('[role=\"rowheader\"]')!;\n const scrollTop = scrollContainer.scrollTop;\n scrollHandler.current = (ev: Event) => ((ev.target as HTMLElement).scrollTop = scrollTop);\n scrollContainer.addEventListener('scroll', scrollHandler.current);\n scrollContainer.dataset.locked = 'true';\n setResizing(true);\n };\n\n const handleResize: ResizeCallback = (_ev, _dir, _elementRef, { height }) => {\n onResize?.(idx, initialSize + height);\n };\n\n const handleResizeStop: ResizeCallback = (_ev, _dir, elementRef, { height }) => {\n const scrollContainer = elementRef.closest<HTMLDivElement>('[role=\"rowheader\"]')!;\n scrollContainer.removeEventListener('scroll', scrollHandler.current!);\n delete scrollContainer.dataset.locked;\n scrollHandler.current = undefined;\n setInitialSize(initialSize + height);\n onResize?.(idx, initialSize + height, true);\n setResizing(false);\n };\n\n // Row.\n return (\n <Resizable\n enable={{ bottom: resize }}\n size={{ height: size - 1 }}\n minHeight={minHeight - 1}\n maxHeight={maxHeight}\n onResizeStart={handleResizeStart}\n onResize={handleResize}\n onResizeStop={handleResizeStop}\n >\n <div\n ref={setNodeRef}\n {...attributes}\n {...listeners}\n className={mx(\n 'flex h-full items-center justify-center cursor-pointer',\n 'border-t border-gridLine focus-visible:outline-none',\n fragments.axis,\n selected && fragments.axisSelected,\n isDragging && fragments.axisSelected,\n )}\n onClick={() => onSelect?.(index)}\n >\n <span className='flex w-full justify-center'>{label}</span>\n\n {/* Drop indicator. */}\n {over?.id === idx && !isDragging && (\n <div className='z-20 absolute top-0 w-full min-h-[4px] border-b-4 border-accentSurface' />\n )}\n\n {/* Resize indicator. */}\n {resizing && <div className='z-20 absolute bottom-0 w-full min-h-[4px] border-b-4 border-accentSurface' />}\n </div>\n </Resizable>\n );\n};\n\n//\n// Columns\n//\n\ntype SheetColumnsProps = { columns: CellIndex[] } & RowColumnSelection & ResizeProps & MoveProps;\n\nconst SheetColumns = forwardRef<HTMLDivElement, SheetColumnsProps>(\n ({ columns, sizes, selected, onSelect, onResize, onMove }, forwardRef) => {\n const mouseSensor = useSensor(MouseSensor, { activationConstraint: mouseConstraints });\n const touchSensor = useSensor(TouchSensor, { activationConstraint: touchConstraints });\n const keyboardSensor = useSensor(KeyboardSensor, {});\n const sensors = useSensors(mouseSensor, touchSensor, keyboardSensor);\n\n const [active, setActive] = useState<Active | null>(null);\n const handleDragStart = ({ active }: DragStartEvent) => {\n setActive(active);\n };\n\n const handleDragEnd = ({ active, over }: DragEndEvent) => {\n if (over && over.id !== active.id) {\n setActive(null);\n onMove?.(active.data.current!.index, over.data.current!.index);\n }\n };\n\n const snapToCenter: Modifier = ({ activatorEvent, draggingNodeRect, transform }) => {\n if (draggingNodeRect && activatorEvent) {\n const activatorCoordinates = getEventCoordinates(activatorEvent);\n if (!activatorCoordinates) {\n return transform;\n }\n\n const offset = activatorCoordinates.x - draggingNodeRect.left;\n return {\n ...transform,\n x: transform.x + offset - draggingNodeRect.width / 2,\n };\n }\n\n return transform;\n };\n\n return (\n <div className='relative flex grow overflow-hidden'>\n {/* Fixed border. */}\n <div\n className={mx('z-20 absolute inset-0 border-x border-gridLine pointer-events-none')}\n style={{ height: axisHeight }}\n />\n\n {/* Scrollbar. */}\n <div ref={forwardRef} role='columnheader' className='grow overflow-x-auto scrollbar-none'>\n <DndContext\n autoScroll={{ enabled: true }}\n sensors={sensors}\n modifiers={[restrictToHorizontalAxis, snapToCenter]}\n onDragStart={handleDragStart}\n onDragEnd={handleDragEnd}\n >\n <div className='flex h-full' style={{ height: axisHeight }}>\n {columns.map((idx, index) => (\n <GridColumnCell\n key={idx}\n idx={idx}\n index={index}\n label={columnLetter(index)}\n size={sizes?.[idx] ?? defaultWidth}\n resize={index < columns.length - 1}\n selected={selected === index}\n onResize={onResize}\n onSelect={onSelect}\n />\n ))}\n </div>\n\n {createPortal(\n <DragOverlay>{active && <MovingOverlay label={columnLetter(active.data.current!.index)} />}</DragOverlay>,\n document.body,\n )}\n </DndContext>\n </div>\n </div>\n );\n },\n);\n\nconst GridColumnCell = ({ idx, index, label, size, resize, selected, onSelect, onResize }: RowColumnProps) => {\n const { setNodeRef: setDroppableNodeRef } = useDroppable({ id: idx, data: { index } });\n const {\n setNodeRef: setDraggableNodeRef,\n attributes,\n listeners,\n over,\n isDragging,\n } = useDraggable({ id: idx, data: { index } });\n const setNodeRef = useCombinedRefs(setDroppableNodeRef, setDraggableNodeRef);\n const [initialSize, setInitialSize] = useState(size);\n const [resizing, setResizing] = useState(false);\n\n // Lock scroll container while resizing (fixes scroll bug).\n // https://github.com/bokuweb/re-resizable/issues/727\n const scrollHandler = useRef<any>();\n const handleResizeStart: ResizeStartCallback = (_ev, _dir, elementRef) => {\n const scrollContainer = elementRef.closest<HTMLDivElement>('[role=\"columnheader\"]')!;\n const scrollLeft = scrollContainer.scrollLeft;\n scrollHandler.current = (ev: Event) => ((ev.target as HTMLElement).scrollLeft = scrollLeft);\n scrollContainer.addEventListener('scroll', scrollHandler.current);\n scrollContainer.dataset.locked = 'true';\n setResizing(true);\n };\n\n const handleResize: ResizeCallback = (_ev, _dir, _elementRef, { width }) => {\n onResize?.(idx, initialSize + width);\n };\n\n const handleResizeStop: ResizeCallback = (_ev, _dir, elementRef, { width }) => {\n const scrollContainer = elementRef.closest<HTMLDivElement>('[role=\"columnheader\"]')!;\n scrollContainer.removeEventListener('scroll', scrollHandler.current!);\n delete scrollContainer.dataset.locked;\n scrollHandler.current = undefined;\n setInitialSize(initialSize + width);\n onResize?.(idx, initialSize + width, true);\n setResizing(false);\n };\n\n // Column.\n return (\n <Resizable\n enable={{ right: resize }}\n size={{ width: size - 1 }}\n minWidth={minWidth - 1}\n maxWidth={maxWidth}\n onResizeStart={handleResizeStart}\n onResize={handleResize}\n onResizeStop={handleResizeStop}\n >\n <div\n ref={setNodeRef}\n {...attributes}\n {...listeners}\n className={mx(\n 'flex h-full items-center justify-center cursor-pointer',\n 'border-l border-gridLine focus-visible:outline-none',\n fragments.axis,\n selected && fragments.axisSelected,\n isDragging && fragments.axisSelected,\n )}\n onClick={() => onSelect?.(index)}\n >\n <span className='flex w-full justify-center'>{label}</span>\n\n {/* Drop indicator. */}\n {over?.id === idx && !isDragging && (\n <div className='z-20 absolute left-0 h-full min-w-[4px] border-l-4 border-accentSurface' />\n )}\n\n {/* Resize indicator. */}\n {resizing && <div className='z-20 absolute right-0 h-full min-h-[4px] border-l-4 border-accentSurface' />}\n </div>\n </Resizable>\n );\n};\n\n//\n// Content\n//\n\ntype SheetGridProps = GridLayoutProps & {\n size: GridSize;\n};\n\nconst SheetGrid = forwardRef<HTMLDivElement, SheetGridProps>(\n ({ size, rows, columns, rowSizes, columnSizes }, forwardRef) => {\n const {\n ref: containerRef,\n width: containerWidth = 0,\n height: containerHeight = 0,\n } = useResizeDetector({ refreshRate: 200 });\n const scrollerRef = useRef<HTMLDivElement>(null);\n useImperativeHandle(forwardRef, () => scrollerRef.current!);\n\n const { model, cursor, range, editing, setCursor, setRange, setEditing, onInfo } = useSheetContext();\n const initialText = useRef<string>();\n const quickEdit = useRef(false);\n\n // Listen for async calculation updates.\n const [, forceUpdate] = useState({});\n useEffect(() => {\n const unsubscribe = model.update.on(() => {\n log('updated', { id: model.id });\n forceUpdate({});\n });\n\n return () => {\n unsubscribe();\n };\n }, [model]);\n\n //\n // Event handling.\n //\n\n const inputRef = useRef<HTMLInputElement>(null);\n const handleKeyDown: DOMAttributes<HTMLInputElement>['onKeyDown'] = (ev) => {\n // Cut-and-paste.\n const isMacOS = /Mac|iPhone|iPod|iPad/.test(navigator.userAgent);\n if (cursor && ((isMacOS && ev.metaKey) || ev.ctrlKey)) {\n switch (ev.key) {\n case 'x': {\n model.cut(range ?? { from: cursor });\n return;\n }\n case 'c': {\n model.copy(range ?? { from: cursor });\n return;\n }\n case 'v': {\n model.paste(cursor);\n return;\n }\n case 'z': {\n if (ev.shiftKey) {\n model.redo();\n } else {\n model.undo();\n }\n return;\n }\n }\n }\n\n switch (ev.key) {\n case 'ArrowUp':\n case 'ArrowDown':\n case 'ArrowLeft':\n case 'ArrowRight':\n case 'Home':\n case 'End': {\n const next = handleNav(ev, cursor, range, size);\n setRange(next.range);\n if (next.cursor) {\n setCursor(next.cursor);\n const element = getCellElement(scrollerRef.current!, next.cursor);\n if (element) {\n scrollIntoView(scrollerRef.current!, element);\n }\n }\n break;\n }\n\n case 'Backspace': {\n if (cursor) {\n if (range) {\n model.clear(range);\n } else {\n model.setValue(cursor, null);\n }\n }\n break;\n }\n\n case 'Escape': {\n setRange(undefined);\n break;\n }\n\n case 'Enter': {\n ev.stopPropagation();\n if (cursor) {\n setEditing(true);\n }\n break;\n }\n\n case '?': {\n onInfo?.();\n break;\n }\n\n default: {\n if (ev.key.length === 1) {\n initialText.current = ev.key;\n quickEdit.current = true;\n setEditing(true);\n }\n }\n }\n };\n\n // Mouse handlers for selection.\n const { handlers } = useRangeSelect((event, range) => {\n switch (event) {\n case 'start': {\n // if (!editing) {\n // setCursor(range?.from);\n // }\n setRange(undefined);\n break;\n }\n\n default: {\n setRange(range);\n }\n }\n });\n\n // Calculate visible grid.\n const { width, height, rowRange, columnRange } = useGridLayout({\n scroller: scrollerRef.current,\n size: { width: containerWidth, height: containerHeight },\n rows,\n columns,\n rowSizes,\n columnSizes,\n });\n\n // TODO(burdon): Prevent scroll if not attended.\n const id = fullyQualifiedId(model.sheet);\n const attendableAttrs = createAttendableAttributes(id);\n const hasAttention = useHasAttention(id);\n\n return (\n <div ref={containerRef} role='grid' className='relative flex grow overflow-hidden'>\n {/* Fixed border. */}\n <div className={mx('z-20 absolute inset-0 border border-gridLine pointer-events-none')} />\n\n {/* Grid scroll container. */}\n <div ref={scrollerRef} className={mx('grow', hasAttention && 'overflow-auto scrollbar-thin')}>\n {/* Scroll content. */}\n <div\n className='relative select-none'\n style={{ width, height }}\n onClick={() => inputRef.current?.focus()}\n {...handlers}\n >\n {/* Selection. */}\n {scrollerRef.current && <SelectionOverlay root={scrollerRef.current} />}\n\n {/* Grid cells. */}\n {rowRange.map(({ row, top, height }) => {\n return columnRange.map(({ column, left, width }) => {\n const style: CSSProperties = { position: 'absolute', top, left, width, height };\n const cell = { row, column };\n const id = addressToA1Notation(cell);\n const idx = model.addressToIndex(cell);\n const active = posEquals(cursor, cell);\n if (active && editing) {\n const value = initialText.current ?? model.getCellText(cell) ?? '';\n\n // TODO(burdon): Validate formula before closing: hf.validateFormula();\n const handleClose: GridCellEditorProps['onClose'] = (value) => {\n initialText.current = undefined;\n quickEdit.current = false;\n if (value !== undefined) {\n model.setValue(cell, value);\n // Auto-advance to next cell.\n const next = handleArrowNav({ key: 'ArrowDown', metaKey: false }, cursor, size);\n if (next) {\n setCursor(next);\n }\n }\n inputRef.current?.focus();\n setEditing(false);\n };\n\n // Quick entry mode: i.e., typing to enter cell.\n const handleNav: GridCellEditorProps['onNav'] = (value, { key }) => {\n initialText.current = undefined;\n model.setValue(cell, value ?? null);\n const next = handleArrowNav({ key, metaKey: false }, cursor, size);\n if (next) {\n setCursor(next);\n }\n inputRef.current?.focus();\n setEditing(false);\n };\n\n return (\n <GridCellEditor\n key={idx}\n value={value}\n style={style}\n onNav={quickEdit.current ? handleNav : undefined}\n onClose={handleClose}\n />\n );\n }\n\n return (\n <SheetCell\n key={id}\n id={id}\n cell={cell}\n active={active}\n style={style}\n onSelect={(cell, edit) => {\n setEditing(edit);\n setCursor(cell);\n }}\n />\n );\n });\n })}\n </div>\n </div>\n\n {/* Hidden input for key navigation. */}\n {createPortal(\n <input\n ref={inputRef}\n autoFocus\n className='absolute w-[1px] h-[1px] bg-transparent outline-none border-none caret-transparent'\n onKeyDown={handleKeyDown}\n {...attendableAttrs}\n />,\n document.body,\n )}\n </div>\n );\n },\n);\n\n//\n// Selection\n//\n\nconst SelectionOverlay = ({ root }: { root: HTMLDivElement }) => {\n const { range } = useSheetContext();\n if (!range) {\n return null;\n }\n\n const c1 = getCellElement(root, range.from);\n const c2 = range.to ? getCellElement(root, range.to)! : c1;\n if (!c1 || !c2) {\n return null;\n }\n\n // TODO(burdon): Instead of measuring cells, get from grid layout?\n const b1 = getRelativeClientRect(root, c1);\n const b2 = getRelativeClientRect(root, c2);\n const bounds = getRectUnion(b1, b2);\n\n return (\n <div\n role='none'\n style={bounds}\n className='z-10 absolute pointer-events-none bg-gridSelectionOverlay border border-gridOverlay'\n />\n );\n};\n\n//\n// Cell\n//\n\ntype SheetCellProps = {\n id: string; // TODO(burdon): Should this be the index?\n cell: CellAddress;\n style: CSSProperties;\n active: boolean;\n onSelect?: (selected: CellAddress, edit: boolean) => void;\n};\n\nconst SheetCell = ({ id, cell, style, active, onSelect }: SheetCellProps) => {\n const { formatting, editing, setRange } = useSheetContext();\n const { value, classNames } = formatting.getFormatting(cell);\n\n return (\n <div\n {...{ [`data-${CELL_DATA_KEY}`]: id }}\n role='cell'\n style={style}\n className={mx(\n 'flex w-full h-full px-2 py-1 truncate items-center border border-gridLine cursor-pointer',\n fragments.cell,\n active && ['z-20', fragments.cellSelected],\n classNames,\n )}\n onClick={() => {\n if (editing) {\n setRange?.({ from: cell });\n } else {\n onSelect?.(cell, false);\n }\n }}\n onDoubleClick={() => onSelect?.(cell, true)}\n >\n {value}\n </div>\n );\n};\n\ntype GridCellEditorProps = {\n style: CSSProperties;\n value: string;\n} & EditorKeysProps;\n\nconst GridCellEditor = ({ style, value, onNav, onClose }: GridCellEditorProps) => {\n const { model, range } = useSheetContext();\n const notifier = useRef<CellRangeNotifier>();\n useEffect(() => {\n if (range) {\n // Update range selection in formula.\n notifier.current?.(rangeToA1Notation(range));\n }\n }, [range]);\n const extension = useMemo(\n () => [\n editorKeys({ onNav, onClose }),\n sheetExtension({ functions: model.functions }),\n rangeExtension((fn) => (notifier.current = fn)),\n ],\n [model],\n );\n\n return (\n <div\n role='cell'\n style={style}\n className={mx('z-20 flex', fragments.cellSelected)}\n onClick={(ev) => ev.stopPropagation()}\n >\n <CellEditor autoFocus value={value} extension={extension} />\n </div>\n );\n};\n\n//\n// StatusBar\n//\n\nconst SheetStatusBar = () => {\n const { model, cursor, range } = useSheetContext();\n let value;\n let isFormula = false;\n if (cursor) {\n value = model.getCellValue(cursor);\n if (typeof value === 'string' && value.charAt(0) === '=') {\n value = model.mapFormulaBindingFromId(model.mapFormulaIndicesToRefs(value));\n isFormula = true;\n } else if (value != null) {\n value = String(value);\n }\n }\n\n return (\n <div className={mx('flex shrink-0 justify-between items-center px-4 py-1 text-sm border-x border-gridLine')}>\n <div className='flex gap-4 items-center'>\n <div className='flex w-16 items-center font-mono'>\n {(range && rangeToA1Notation(range)) || (cursor && addressToA1Notation(cursor))}\n </div>\n <div className='flex gap-2 items-center'>\n <FunctionIcon className={mx('text-greenText', isFormula ? 'visible' : 'invisible')} />\n <span className='font-mono'>{value}</span>\n </div>\n </div>\n </div>\n );\n};\n\n//\n// Debug\n//\n\nconst SheetDebug = () => {\n const { model, cursor, range } = useSheetContext();\n const [, forceUpdate] = useState({});\n useEffect(() => {\n // TODO(burdon): This is called without registering a listener.\n const accessor = createDocAccessor(model.sheet, []);\n const handleUpdate = () => forceUpdate({});\n accessor.handle.addListener('change', handleUpdate);\n handleUpdate();\n return () => {\n accessor.handle.removeListener('change', handleUpdate);\n };\n }, [model]);\n\n return (\n <div\n className={mx(\n 'z-20 absolute right-0 top-20 bottom-20 w-[30rem] overflow-auto scrollbar-thin',\n 'border border-gridLine text-xs bg-neutral-50 dark:bg-black text-cyan-500 font-mono p-1 opacity-80',\n )}\n >\n <pre className='whitespace-pre-wrap'>\n {JSON.stringify(\n {\n cursor,\n range,\n cells: model.sheet.cells,\n rowMeta: model.sheet.rowMeta,\n columnMeta: model.sheet.columnMeta,\n formatting: model.sheet.formatting,\n },\n undefined,\n 2,\n )}\n </pre>\n </div>\n );\n};\n\n//\n// Grid\n//\n\nexport const Sheet = {\n Root: SheetRoot,\n Main: SheetMain,\n Rows: SheetRows,\n Columns: SheetColumns,\n Grid: SheetGrid,\n Cell: SheetCell,\n StatusBar: SheetStatusBar,\n Debug: SheetDebug,\n};\n\nexport type { SheetRootProps, SheetMainProps, SheetRowsProps, SheetColumnsProps, SheetGridProps, SheetCellProps };\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type MouseEvent, useEffect, useState } from 'react';\n\nimport { type CellAddress, type CellIndex, addressFromA1Notation, addressToA1Notation } from '../../model';\n\n// export type Bounds = Pick<DOMRect, 'left' | 'top' | 'width' | 'height'>;\n// export type Dimension = Pick<DOMRect, 'width' | 'height'>;\n\nexport type SizeMap = Record<string, number>;\n\nexport type RowPosition = { row: number } & Pick<DOMRect, 'top' | 'height'>;\nexport type ColumnPosition = { column: number } & Pick<DOMRect, 'left' | 'width'>;\n\nexport const axisWidth = 'calc(var(--rail-size)-2px)';\nexport const axisHeight = 34;\n\nexport const minWidth = 40;\nexport const maxWidth = 800;\n\nexport const minHeight = axisHeight;\nexport const maxHeight = 400;\n\nexport const defaultWidth = 200;\nexport const defaultHeight = minHeight;\n\n/**\n * Cell nodes are identified by their A1 notation.\n */\nexport const CELL_DATA_KEY = 'cell';\n\nexport type GridLayoutProps = {\n rows: CellIndex[];\n columns: CellIndex[];\n rowSizes?: SizeMap;\n columnSizes?: SizeMap;\n};\n\nexport type GridLayout = {\n width: number;\n height: number;\n rowRange: RowPosition[];\n columnRange: ColumnPosition[];\n};\n\n/**\n * Calculates the grid geometry for the current viewport.\n */\nexport const useGridLayout = ({\n scroller,\n size,\n rows,\n columns,\n rowSizes,\n columnSizes,\n}: GridLayoutProps & {\n scroller: HTMLDivElement | null;\n size: { width: number; height: number };\n}): GridLayout => {\n const [rowPositions, setRowPositions] = useState<RowPosition[]>([]);\n useEffect(() => {\n if (!rowSizes) {\n return;\n }\n\n let y = 0;\n setRowPositions(\n rows.map((idx, i) => {\n const height = rowSizes?.[idx] ?? defaultHeight;\n const top = y;\n y += height - 1;\n return { row: i, top, height };\n }),\n );\n }, [rows, rowSizes]);\n\n const [columnPositions, setColumnPositions] = useState<ColumnPosition[]>([]);\n useEffect(() => {\n if (!columns) {\n return;\n }\n\n let x = 0;\n setColumnPositions(\n columns.map((idx, i) => {\n const width = columnSizes?.[idx] ?? defaultWidth;\n const left = x;\n x += width - 1;\n return { column: i, left, width };\n }),\n );\n }, [columns, columnSizes]);\n\n const height = rowPositions.length\n ? rowPositions[rowPositions.length - 1].top + rowPositions[rowPositions.length - 1].height\n : 0;\n\n const width = columnPositions.length\n ? columnPositions[columnPositions.length - 1].left + columnPositions[columnPositions.length - 1].width\n : 0;\n\n //\n // Virtual window.\n // TODO(burdon): Preserve edit state, selection.\n // TODO(burdon): BUG: Doesn't scroll to cursor if jump to end.\n //\n\n const [{ rowRange, columnRange }, setWindow] = useState<{\n rowRange: RowPosition[];\n columnRange: ColumnPosition[];\n }>({ rowRange: [], columnRange: [] });\n useEffect(() => {\n const handleScroll = () => {\n if (!scroller) {\n return;\n }\n\n const { scrollLeft: left, scrollTop: top, clientWidth: width, clientHeight: height } = scroller;\n\n let rowStart = 0;\n let rowEnd = 0;\n for (let i = 0; i < rowPositions.length; i++) {\n const row = rowPositions[i];\n if (row.top <= top) {\n rowStart = i;\n }\n if (row.top + row.height >= top + height) {\n rowEnd = i;\n break;\n }\n }\n\n let columnStart = 0;\n let columnEnd = 0;\n for (let i = 0; i < columnPositions.length; i++) {\n const column = columnPositions[i];\n if (column.left <= left) {\n columnStart = i;\n }\n if (column.left + column.width >= left + width) {\n columnEnd = i;\n break;\n }\n }\n\n const overscan = 5;\n setWindow({\n rowRange: rowPositions.slice(\n Math.max(0, rowStart - overscan),\n Math.min(rowPositions.length, rowEnd + overscan),\n ),\n columnRange: columnPositions.slice(\n Math.max(0, columnStart - overscan),\n Math.min(columnPositions.length, columnEnd + overscan),\n ),\n });\n };\n\n scroller?.addEventListener('scroll', handleScroll);\n handleScroll();\n return () => {\n scroller?.removeEventListener('scroll', handleScroll);\n };\n }, [size.width, size.height, rowPositions, columnPositions]);\n\n return { width, height, rowRange, columnRange };\n};\n\n/**\n * Find child node at mouse pointer.\n */\nexport const getCellAtPointer = (event: MouseEvent): CellAddress | undefined => {\n const element = document.elementFromPoint(event.clientX, event.clientY);\n const root = element?.closest<HTMLDivElement>(`[data-${CELL_DATA_KEY}]`);\n if (root) {\n const value = root.dataset[CELL_DATA_KEY];\n if (value) {\n return addressFromA1Notation(value);\n }\n }\n};\n\n/**\n * Get element.\n */\nexport const getCellElement = (root: HTMLElement, cell: CellAddress): HTMLElement | null => {\n const pos = addressToA1Notation(cell);\n return root.querySelector(`[data-${CELL_DATA_KEY}=\"${pos}\"]`);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type KeyboardEvent, type MouseEventHandler, useState } from 'react';\n\nimport { getCellAtPointer } from './grid';\nimport { type CellAddress, type CellRange, posEquals } from '../../model';\n\nexport type GridSize = {\n numRows: number;\n numColumns: number;\n};\n\n/**\n * Calculate next range based on arrow keys.\n */\nexport const handleNav = (\n ev: KeyboardEvent<HTMLInputElement>,\n cursor: CellAddress | undefined,\n range: CellRange | undefined,\n size: GridSize,\n): { cursor?: CellAddress; range?: CellRange } => {\n if (cursor && ev.shiftKey) {\n // Navigate from the furthest point.\n const opposite = range?.to ?? { ...cursor };\n switch (ev.key) {\n case 'ArrowUp': {\n if (opposite.row > 0) {\n opposite.row -= 1;\n }\n break;\n }\n case 'ArrowDown': {\n if (opposite.row < size.numRows - 1) {\n opposite.row += 1;\n }\n break;\n }\n case 'ArrowLeft': {\n if (opposite.column > 0) {\n opposite.column -= 1;\n }\n break;\n }\n case 'ArrowRight': {\n if (opposite.column < size.numColumns - 1) {\n opposite.column += 1;\n }\n break;\n }\n }\n\n return { cursor, range: { from: cursor, to: opposite } };\n }\n\n const next = handleArrowNav(ev, cursor, size);\n return { cursor: next };\n};\n\n/**\n * Calculate next cell based on arrow keys.\n */\nexport const handleArrowNav = (\n ev: Pick<KeyboardEvent<HTMLInputElement>, 'key' | 'metaKey'>,\n cursor: CellAddress | undefined,\n { numRows, numColumns }: GridSize,\n): CellAddress | undefined => {\n switch (ev.key) {\n case 'ArrowUp':\n if (cursor === undefined) {\n return { row: 0, column: 0 };\n } else if (cursor.row > 0) {\n return { row: ev.metaKey ? 0 : cursor.row - 1, column: cursor.column };\n }\n break;\n case 'ArrowDown':\n if (cursor === undefined) {\n return { row: 0, column: 0 };\n } else if (cursor.row < numRows - 1) {\n return { row: ev.metaKey ? numRows - 1 : cursor.row + 1, column: cursor.column };\n }\n break;\n case 'ArrowLeft':\n if (cursor === undefined) {\n return { row: 0, column: 0 };\n } else if (cursor.column > 0) {\n return { row: cursor.row, column: ev.metaKey ? 0 : cursor.column - 1 };\n }\n break;\n case 'ArrowRight':\n if (cursor === undefined) {\n return { row: 0, column: 0 };\n } else if (cursor.column < numColumns - 1) {\n return { row: cursor.row, column: ev.metaKey ? numColumns - 1 : cursor.column + 1 };\n }\n break;\n case 'Home':\n return { row: 0, column: 0 };\n case 'End':\n return { row: numRows - 1, column: numColumns - 1 };\n }\n};\n\n/**\n * Hook to manage range drag handlers.\n */\n// TODO(burdon): Memoize callbacks?\nexport const useRangeSelect = (\n cb: (event: 'start' | 'move' | 'end', range: CellRange | undefined) => void,\n): {\n range: CellRange | undefined;\n handlers: {\n onMouseDown: MouseEventHandler<HTMLDivElement>;\n onMouseMove: MouseEventHandler<HTMLDivElement>;\n onMouseUp: MouseEventHandler<HTMLDivElement>;\n };\n} => {\n const [from, setFrom] = useState<CellAddress | undefined>();\n const [to, setTo] = useState<CellAddress | undefined>();\n\n const onMouseDown: MouseEventHandler<HTMLDivElement> = (ev) => {\n const current = getCellAtPointer(ev);\n setFrom(current);\n if (current) {\n setTimeout(() => cb('start', { from: current }));\n }\n };\n\n const onMouseMove: MouseEventHandler<HTMLDivElement> = (ev) => {\n if (from) {\n let current = getCellAtPointer(ev);\n if (posEquals(current, from)) {\n current = undefined;\n }\n setTo(current);\n setTimeout(() => cb('move', { from, to: current }));\n }\n };\n\n const onMouseUp: MouseEventHandler<HTMLDivElement> = (ev) => {\n if (from) {\n let current = getCellAtPointer(ev);\n if (posEquals(current, from)) {\n current = undefined;\n }\n setFrom(undefined);\n setTo(undefined);\n setTimeout(() => cb('end', current ? { from, to: current } : undefined));\n }\n };\n\n return {\n range: from ? { from, to } : undefined,\n handlers: { onMouseDown, onMouseMove, onMouseUp },\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren, createContext, useContext, useState, useEffect } from 'react';\n\nimport { invariant } from '@dxos/invariant';\nimport { type FunctionType } from '@dxos/plugin-script';\nimport { fullyQualifiedId, type Space } from '@dxos/react-client/echo';\n\nimport { FormattingModel } from './formatting';\nimport { type CellAddress, type CellRange, defaultFunctions, SheetModel } from '../../model';\nimport { type SheetType } from '../../types';\nimport { type FunctionContextOptions } from '../ComputeGraph';\n// TODO(wittjosiah): Refactor. This is not exported from ./components due to depending on ECHO.\nimport { useComputeGraph } from '../ComputeGraph/graph-context';\n\n// TODO(wittjosiah): Factor out.\nconst OBJECT_ID_LENGTH = 60; // 33 (space id) + 26 (object id) + 1 (separator).\n\nexport type SheetContextType = {\n model: SheetModel;\n formatting: FormattingModel;\n\n // Cursor state.\n // TODO(burdon): Cursor and range should use indices.\n cursor?: CellAddress;\n setCursor: (cell: CellAddress | undefined) => void;\n range?: CellRange;\n setRange: (range: CellRange | undefined) => void;\n\n // Editing state (undefined if not editing).\n editing: boolean;\n setEditing: (editing: boolean) => void;\n\n // Events.\n // TODO(burdon): Generalize.\n onInfo?: () => void;\n};\n\nconst SheetContext = createContext<SheetContextType | null>(null);\n\nexport const useSheetContext = (): SheetContextType => {\n const context = useContext(SheetContext);\n invariant(context);\n return context;\n};\n\nexport type SheetContextProps = {\n sheet: SheetType;\n space: Space;\n readonly?: boolean;\n} & Pick<SheetContextType, 'onInfo'> &\n Partial<FunctionContextOptions>;\n\n/**\n * Map from binding to fully qualified ECHO ID.\n */\nconst mapFormulaBindingToId =\n (functions: FunctionType[]) =>\n (formula: string): string => {\n return formula.replace(/([a-zA-Z0-9]+)\\((.*)\\)/g, (match, binding, args) => {\n if (defaultFunctions.find((fn) => fn.name === binding) || binding === 'EDGE') {\n return match;\n }\n\n const fn = functions.find((fn) => fn.binding === binding);\n if (fn) {\n return `${fullyQualifiedId(fn)}(${args})`;\n } else {\n return match;\n }\n });\n };\n\n/**\n * Map from fully qualified ECHO ID to binding.\n */\nconst mapFormulaBindingFromId =\n (functions: FunctionType[]) =>\n (formula: string): string => {\n return formula.replace(/([a-zA-Z0-9]+):([a-zA-Z0-9]+)\\((.*)\\)/g, (match, spaceId, objectId, args) => {\n const id = `${spaceId}:${objectId}`;\n if (id.length !== OBJECT_ID_LENGTH) {\n return match;\n }\n\n const fn = functions.find((fn) => fullyQualifiedId(fn) === id);\n if (fn?.binding) {\n return `${fn.binding}(${args})`;\n } else {\n return match;\n }\n });\n };\n\nexport const SheetContextProvider = ({\n children,\n sheet,\n space,\n readonly,\n onInfo,\n ...options\n}: PropsWithChildren<SheetContextProps>) => {\n const graph = useComputeGraph(space, options);\n\n const [cursor, setCursor] = useState<CellAddress>();\n const [range, setRange] = useState<CellRange>();\n const [editing, setEditing] = useState<boolean>(false);\n\n const [[model, formatting] = [], setModels] = useState<[SheetModel, FormattingModel] | undefined>(undefined);\n useEffect(() => {\n let model: SheetModel | undefined;\n let formatting;\n const t = setTimeout(async () => {\n model = new SheetModel(graph, sheet, space, { readonly, mapFormulaBindingToId, mapFormulaBindingFromId });\n await model.initialize();\n formatting = new FormattingModel(model);\n setModels([model, formatting]);\n });\n\n return () => {\n clearTimeout(t);\n void model?.destroy();\n };\n }, [graph, readonly]);\n\n if (!model || !formatting) {\n return null;\n }\n\n return (\n <SheetContext.Provider\n value={{\n model,\n formatting,\n cursor,\n setCursor,\n range,\n setRange,\n editing,\n setEditing,\n // TODO(burdon): Change to event.\n onInfo,\n }}\n >\n {children}\n </SheetContext.Provider>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type ClassNameValue } from '@dxos/react-ui-types';\n\nimport { type SheetModel, type CellAddress, inRange } from '../../model';\nimport { ValueTypeEnum } from '../../types';\n\nexport class FormattingModel {\n constructor(private readonly model: SheetModel) {}\n\n /**\n * Get formatted string value and className for cell.\n */\n getFormatting(cell: CellAddress): { value?: string; classNames?: ClassNameValue } {\n const value = this.model.getValue(cell);\n if (value === undefined || value === null) {\n return {};\n }\n\n // TODO(burdon): Locale.\n const locales = undefined;\n\n // Cell-specific formatting.\n const idx = this.model.addressToIndex(cell);\n let formatting = this.model.sheet.formatting?.[idx] ?? {};\n const classNames = [...(formatting?.classNames ?? [])];\n\n // Range formatting.\n // TODO(burdon): NOTE: D0 means the D column.\n // TODO(burdon): Cache model formatting (e.g., for ranges). Create class out of this function.\n for (const [idx, _formatting] of Object.entries(this.model.sheet.formatting)) {\n const range = this.model.rangeFromIndex(idx);\n if (inRange(range, cell)) {\n if (_formatting.classNames) {\n classNames.push(..._formatting.classNames);\n }\n\n // TODO(burdon): Last wins.\n if (_formatting.type) {\n formatting = _formatting;\n }\n }\n }\n\n const defaultNumber = 'justify-end font-mono';\n\n const type = formatting?.type ?? this.model.getValueType(cell);\n switch (type) {\n case ValueTypeEnum.Boolean: {\n return {\n value: (value as boolean).toLocaleString().toUpperCase(),\n classNames: [...classNames, value ? '!text-greenText' : '!text-orangeText'],\n };\n }\n\n //\n // Numbers.\n //\n\n case ValueTypeEnum.Number: {\n return { value: value.toLocaleString(locales), classNames: [...classNames, defaultNumber] };\n }\n\n case ValueTypeEnum.Percent: {\n return { value: (value as number) * 100 + '%', classNames: [...classNames, defaultNumber] };\n }\n\n case ValueTypeEnum.Currency: {\n return {\n value: (value as number).toLocaleString(locales, {\n style: 'currency',\n currency: 'USD',\n minimumFractionDigits: 2,\n maximumFractionDigits: 2,\n }),\n classNames: [...classNames, defaultNumber],\n };\n }\n\n //\n // Dates.\n //\n\n case ValueTypeEnum.DateTime: {\n const date = this.model.toLocalDate(value as number);\n return { value: date.toLocaleString(locales), classNames };\n }\n\n case ValueTypeEnum.Date: {\n const date = this.model.toLocalDate(value as number);\n return { value: date.toLocaleDateString(locales), classNames };\n }\n\n case ValueTypeEnum.Time: {\n const date = this.model.toLocalDate(value as number);\n return { value: date.toLocaleTimeString(locales), classNames };\n }\n\n default: {\n return { value: String(value), classNames };\n }\n }\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Gets the relative client rect of an element within a parent container.\n * NOTE: This is stable even when the parent is scrolling.\n * https://developer.mozilla.org/en-US/docs/Web/API/Element/getBoundingClientRect\n * @param root Parent container (e.g., scrollable container).\n * @param element\n */\nexport const getRelativeClientRect = (root: HTMLElement, element: HTMLElement): DOMRect => {\n const rootRect = root.getBoundingClientRect();\n const elementRect = element.getBoundingClientRect();\n return new DOMRect(\n elementRect.left - rootRect.left + root.scrollLeft,\n elementRect.top - rootRect.top + root.scrollTop,\n elementRect.width,\n elementRect.height,\n );\n};\n\n/**\n * Union of two rectangles.\n */\nexport const getRectUnion = (b1: DOMRect, b2: DOMRect): Pick<DOMRect, 'left' | 'top' | 'width' | 'height'> => {\n return {\n left: Math.min(b1.left, b2.left),\n top: Math.min(b1.top, b2.top),\n width: Math.abs(b1.left - b2.left) + (b1.left > b2.left ? b1.width : b2.width),\n height: Math.abs(b1.top - b2.top) + (b1.height > b2.height ? b1.height : b2.height),\n };\n};\n\n/**\n * Scroll to cell.\n * We need to correct for the DOM `scrollIntoView` function which doesn't show the border.\n */\nexport const scrollIntoView = (scrollContainer: HTMLElement, el: HTMLElement) => {\n el.scrollIntoView({ block: 'nearest', inline: 'nearest' });\n\n const cellBounds = el.getBoundingClientRect();\n const scrollerBounds = scrollContainer.getBoundingClientRect();\n\n if (cellBounds.top < scrollerBounds.top) {\n scrollContainer.scrollTop -= scrollerBounds.top - cellBounds.top;\n } else if (cellBounds.bottom >= scrollerBounds.bottom - 1) {\n scrollContainer.scrollTop += 2 + scrollerBounds.bottom - cellBounds.bottom;\n }\n\n if (cellBounds.left < scrollerBounds.left) {\n scrollContainer.scrollLeft -= scrollerBounds.left - cellBounds.left;\n } else if (cellBounds.right >= scrollerBounds.right) {\n scrollContainer.scrollLeft += 2 + scrollerBounds.right - cellBounds.right;\n }\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Extension } from '@codemirror/state';\nimport { EditorView, keymap } from '@codemirror/view';\nimport React, { type DOMAttributes, type KeyboardEvent } from 'react';\n\nimport { useThemeContext } from '@dxos/react-ui';\nimport {\n type UseTextEditorProps,\n createBasicExtensions,\n createThemeExtensions,\n preventNewline,\n useTextEditor,\n} from '@dxos/react-ui-editor';\n\nexport type EditorKeysProps = {\n onClose: (value: string | undefined) => void;\n onNav?: (value: string | undefined, ev: Pick<KeyboardEvent<HTMLInputElement>, 'key'>) => void;\n};\n\nexport const editorKeys = ({ onNav, onClose }: EditorKeysProps): Extension => {\n return keymap.of([\n {\n key: 'ArrowUp',\n run: (editor) => {\n const value = editor.state.doc.toString();\n onNav?.(value, { key: 'ArrowUp' });\n return !!onNav;\n },\n },\n {\n key: 'ArrowDown',\n run: (editor) => {\n const value = editor.state.doc.toString();\n onNav?.(value, { key: 'ArrowDown' });\n return !!onNav;\n },\n },\n {\n key: 'ArrowLeft',\n run: (editor) => {\n const value = editor.state.doc.toString();\n onNav?.(value, { key: 'ArrowLeft' });\n return !!onNav;\n },\n },\n {\n key: 'ArrowRight',\n run: (editor) => {\n const value = editor.state.doc.toString();\n onNav?.(value, { key: 'ArrowRight' });\n return !!onNav;\n },\n },\n {\n key: 'Enter',\n run: (editor) => {\n onClose(editor.state.doc.toString());\n return true;\n },\n },\n {\n key: 'Escape',\n run: () => {\n onClose(undefined);\n return true;\n },\n },\n ]);\n};\n\nexport type CellEditorProps = {\n value?: string;\n extension?: Extension;\n} & Pick<UseTextEditorProps, 'autoFocus'> &\n Pick<DOMAttributes<HTMLInputElement>, 'onBlur' | 'onKeyDown'>;\n\nexport const CellEditor = ({ value, extension, autoFocus, onBlur }: CellEditorProps) => {\n const { themeMode } = useThemeContext();\n const { parentRef } = useTextEditor(() => {\n return {\n autoFocus,\n initialValue: value,\n selection: { anchor: value?.length ?? 0 },\n extensions: [\n extension ?? [],\n preventNewline,\n EditorView.focusChangeEffect.of((_, focusing) => {\n if (!focusing) {\n onBlur?.({ type: 'blur' } as any);\n }\n return null;\n }),\n createBasicExtensions({ lineWrapping: false }),\n createThemeExtensions({\n themeMode,\n slots: {\n editor: {\n className: 'flex w-full [&>.cm-scroller]:scrollbar-none',\n },\n content: {\n className: '!px-2 !py-1',\n },\n },\n }),\n ],\n };\n }, [extension]);\n\n return <div ref={parentRef} className='flex w-full' />;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport {\n type Completion,\n type CompletionContext,\n type CompletionResult,\n acceptCompletion,\n autocompletion,\n completionStatus,\n startCompletion,\n} from '@codemirror/autocomplete';\nimport { HighlightStyle, type Language, syntaxHighlighting } from '@codemirror/language';\nimport { type Extension, Facet } from '@codemirror/state';\nimport { type EditorView, ViewPlugin, type ViewUpdate, keymap } from '@codemirror/view';\nimport { type SyntaxNode } from '@lezer/common';\nimport { tags } from '@lezer/highlight';\nimport { spreadsheet } from 'codemirror-lang-spreadsheet';\n\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { type FunctionDefinition } from '../../model';\n\n/**\n * https://codemirror.net/examples/styling\n * https://lezer.codemirror.net/docs/ref/#highlight\n * https://github.com/luizzappa/codemirror-lang-spreadsheet/blob/main/src/index.ts#L28 (mapping)\n */\n// TODO(burdon): Define light/dark.\nconst highlightStyles = HighlightStyle.define([\n // Function.\n {\n tag: tags.name,\n class: 'text-accentText',\n },\n // Range.\n {\n tag: tags.tagName,\n class: 'text-pinkText',\n },\n // Values.\n {\n tag: tags.number,\n class: 'text-tealText',\n },\n {\n tag: tags.bool,\n class: 'text-tealText',\n },\n {\n tag: tags.string,\n class: 'text-tealText',\n },\n // Error.\n {\n tag: tags.invalid,\n class: 'text-unAccent',\n },\n]);\n\nconst languageFacet = Facet.define<Language>();\n\nexport type SheetExtensionOptions = {\n functions?: FunctionDefinition[];\n};\n\n/**\n * Spreadsheet formula extension and parser.\n * https://github.com/luizzappa/codemirror-lang-spreadsheet\n * https://github.com/luizzappa/codemirror-app-spreadsheet/blob/master/src/editor.ts\n * https://github.com/codemirror/lang-example\n * https://hyperformula.handsontable.com/guide/key-concepts.html#grammar\n */\nexport const sheetExtension = ({ functions = [] }: SheetExtensionOptions): Extension => {\n const { extension, language } = spreadsheet({ idiom: 'en-US', decimalSeparator: '.' });\n\n const createCompletion = (name: string) => {\n const { section = 'Custom', description, syntax } = functions.find((value) => value.name === name) ?? {};\n\n return {\n section,\n label: name,\n info: () => {\n if (!description && !syntax) {\n return null;\n }\n\n // TODO(burdon): Standardize color styles.\n const root = document.createElement('div');\n root.className = 'flex flex-col gap-2 text-sm';\n\n const title = document.createElement('h2');\n title.innerText = name;\n title.className = 'text-lg font-mono text-accentText';\n root.appendChild(title);\n\n if (description) {\n const info = document.createElement('p');\n info.innerText = description;\n info.className = 'text-subdued';\n root.appendChild(info);\n }\n\n if (syntax) {\n const detail = document.createElement('pre');\n detail.innerText = syntax;\n detail.className = 'whitespace-pre-wrap text-greenText';\n root.appendChild(detail);\n }\n\n return root;\n },\n apply: (view, completion, from, to) => {\n const insertParens = to === view.state.doc.toString().length;\n view.dispatch(\n view.state.update({\n changes: {\n from,\n to,\n insert: completion.label + (insertParens ? '()' : ''),\n },\n selection: {\n anchor: from + completion.label.length + 1,\n },\n }),\n );\n },\n } satisfies Completion;\n };\n\n return [\n extension,\n languageFacet.of(language),\n language.data.of({\n autocomplete: (context: CompletionContext): CompletionResult | null => {\n if (context.state.doc.toString()[0] !== '=') {\n return null;\n }\n const match = context.matchBefore(/\\w*/);\n if (!match || match.from === match.to) {\n return null;\n }\n\n const text = match.text.toUpperCase();\n if (!context.explicit && match.text.length < 2) {\n return null;\n }\n\n return {\n from: match.from,\n options:\n functions?.filter(({ name }) => name.startsWith(text)).map(({ name }) => createCompletion(name)) ?? [],\n };\n },\n }),\n\n syntaxHighlighting(highlightStyles),\n autocompletion({\n aboveCursor: false,\n defaultKeymap: true,\n activateOnTyping: true,\n // NOTE: Useful for debugging.\n closeOnBlur: false,\n icons: false,\n tooltipClass: () =>\n mx(\n // TODO(burdon): Factor out fragments.\n // TODO(burdon): Size to make width same as column.\n '!-left-[1px] !top-[33px] !-m-0 border !border-t-0 [&>ul]:!min-w-[198px]',\n '[&>ul>li[aria-selected]]:!bg-accentSurface',\n 'border-separator',\n ),\n }),\n keymap.of([\n {\n key: 'Tab',\n run: (view) => {\n return completionStatus(view.state) === 'active' ? acceptCompletion(view) : startCompletion(view);\n },\n },\n ]),\n\n // Parsing.\n // StateField.define({\n // create: (state) => {},\n // update: (value, tr) => {\n // log.info('update');\n // syntaxTree(tr.state).iterate({\n // enter: ({ type, from, to }) => {\n // log.info('node', { type: type.name, from, to });\n // },\n // });\n // },\n // }),\n ];\n};\n\nexport type CellRangeNotifier = (range: string) => void;\n\ntype Range = { from: number; to: number };\n\n/**\n * Tracks the currently active cell within a formula and provides a callback to modify it.\n */\nexport const rangeExtension = (onInit: (notifier: CellRangeNotifier) => void): Extension => {\n let view: EditorView;\n let activeRange: Range | undefined;\n const provider: CellRangeNotifier = (range: string) => {\n if (activeRange) {\n view.dispatch(\n view.state.update({\n changes: { ...activeRange, insert: range.toString() },\n selection: { anchor: activeRange.from + range.length },\n }),\n );\n }\n\n view.focus();\n };\n\n return ViewPlugin.fromClass(\n class {\n constructor(_view: EditorView) {\n view = _view;\n onInit(provider);\n }\n\n update(view: ViewUpdate) {\n const { anchor } = view.state.selection.ranges[0];\n\n // Find first Range or cell at cursor.\n activeRange = undefined;\n const [language] = view.state.facet(languageFacet);\n const { topNode } = language.parser.parse(view.state.doc.toString());\n visitTree(topNode, ({ type, from, to }) => {\n if (from <= anchor && to >= anchor) {\n switch (type.name) {\n case 'Function': {\n // Mark but keep looking.\n activeRange = { from: to, to };\n break;\n }\n\n case 'CloseParen': {\n // Mark but keep looking.\n activeRange = { from, to: from };\n break;\n }\n\n case 'RangeToken':\n case 'CellToken':\n activeRange = { from, to };\n return true;\n }\n }\n\n return false;\n });\n\n // Allow start of formula.\n if (!activeRange && view.state.doc.toString()[0] === '=') {\n activeRange = { from: 1, to: view.state.doc.toString().length };\n }\n }\n },\n );\n};\n\n/**\n * Lezer parse result visitor.\n */\nconst visitTree = (node: SyntaxNode, callback: (node: SyntaxNode) => boolean): boolean => {\n if (callback(node)) {\n return true;\n }\n\n for (let child = node.firstChild; child !== null; child = child.nextSibling) {\n if (visitTree(child, callback)) {\n return true;\n }\n }\n\n return false;\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "mx", "DndContext", "DragOverlay", "KeyboardSensor", "MouseSensor", "TouchSensor", "useDraggable", "useDroppable", "useSensor", "useSensors", "restrictToHorizontalAxis", "restrictToVerticalAxis", "getEventCoordinates", "useCombinedRefs", "Function", "FunctionIcon", "Resizable", "React", "forwardRef", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useState", "createPortal", "useResizeDetector", "debounce", "fullyQualifiedId", "createDocAccessor", "log", "createAttendableAttributes", "useHasAttention", "mx", "useEffect", "useState", "axisWidth", "axisHeight", "minWidth", "maxWidth", "minHeight", "maxHeight", "defaultWidth", "defaultHeight", "CELL_DATA_KEY", "useGridLayout", "scroller", "size", "rows", "columns", "rowSizes", "columnSizes", "rowPositions", "setRowPositions", "useState", "useEffect", "y", "map", "idx", "i", "height", "top", "row", "columnPositions", "setColumnPositions", "x", "width", "left", "column", "length", "rowRange", "columnRange", "setWindow", "handleScroll", "scrollLeft", "scrollTop", "clientWidth", "clientHeight", "rowStart", "rowEnd", "columnStart", "columnEnd", "overscan", "slice", "Math", "max", "min", "addEventListener", "removeEventListener", "getCellAtPointer", "event", "element", "document", "elementFromPoint", "clientX", "clientY", "root", "closest", "value", "dataset", "addressFromA1Notation", "getCellElement", "cell", "pos", "addressToA1Notation", "querySelector", "useState", "handleNav", "ev", "cursor", "range", "size", "shiftKey", "opposite", "to", "key", "row", "numRows", "column", "numColumns", "from", "next", "handleArrowNav", "undefined", "metaKey", "useRangeSelect", "cb", "setFrom", "useState", "setTo", "onMouseDown", "current", "getCellAtPointer", "setTimeout", "onMouseMove", "posEquals", "onMouseUp", "handlers", "React", "createContext", "useContext", "useState", "useEffect", "invariant", "fullyQualifiedId", "FormattingModel", "constructor", "model", "getFormatting", "cell", "value", "getValue", "undefined", "locales", "idx", "addressToIndex", "formatting", "sheet", "classNames", "_formatting", "Object", "entries", "range", "rangeFromIndex", "inRange", "push", "type", "defaultNumber", "getValueType", "ValueTypeEnum", "Boolean", "toLocaleString", "toUpperCase", "Number", "Percent", "Currency", "style", "currency", "minimumFractionDigits", "maximumFractionDigits", "DateTime", "date", "toLocalDate", "Date", "toLocaleDateString", "Time", "toLocaleTimeString", "String", "OBJECT_ID_LENGTH", "SheetContext", "createContext", "useSheetContext", "context", "useContext", "invariant", "mapFormulaBindingToId", "functions", "formula", "replace", "match", "binding", "args", "defaultFunctions", "find", "fn", "name", "fullyQualifiedId", "mapFormulaBindingFromId", "spaceId", "objectId", "id", "length", "SheetContextProvider", "children", "sheet", "space", "readonly", "onInfo", "options", "graph", "useComputeGraph", "cursor", "setCursor", "useState", "range", "setRange", "editing", "setEditing", "model", "formatting", "setModels", "undefined", "useEffect", "t", "setTimeout", "SheetModel", "initialize", "FormattingModel", "clearTimeout", "destroy", "Provider", "value", "getRelativeClientRect", "root", "element", "rootRect", "getBoundingClientRect", "elementRect", "DOMRect", "left", "scrollLeft", "top", "scrollTop", "width", "height", "getRectUnion", "b1", "b2", "Math", "min", "abs", "scrollIntoView", "scrollContainer", "el", "block", "inline", "cellBounds", "scrollerBounds", "bottom", "right", "EditorView", "keymap", "React", "useThemeContext", "createBasicExtensions", "createThemeExtensions", "preventNewline", "useTextEditor", "editorKeys", "onNav", "onClose", "keymap", "of", "key", "run", "editor", "value", "state", "doc", "toString", "undefined", "CellEditor", "extension", "autoFocus", "onBlur", "themeMode", "useThemeContext", "parentRef", "useTextEditor", "initialValue", "selection", "anchor", "length", "extensions", "preventNewline", "EditorView", "focusChangeEffect", "_", "focusing", "type", "createBasicExtensions", "lineWrapping", "createThemeExtensions", "slots", "className", "content", "React", "div", "ref", "acceptCompletion", "autocompletion", "completionStatus", "startCompletion", "HighlightStyle", "syntaxHighlighting", "Facet", "ViewPlugin", "keymap", "tags", "spreadsheet", "mx", "highlightStyles", "HighlightStyle", "define", "tag", "tags", "name", "class", "tagName", "number", "bool", "string", "invalid", "languageFacet", "Facet", "sheetExtension", "functions", "extension", "language", "spreadsheet", "idiom", "decimalSeparator", "createCompletion", "section", "description", "syntax", "find", "value", "label", "info", "root", "document", "createElement", "className", "title", "innerText", "appendChild", "detail", "apply", "view", "completion", "from", "to", "insertParens", "state", "doc", "toString", "length", "dispatch", "update", "changes", "insert", "selection", "anchor", "of", "data", "autocomplete", "context", "match", "matchBefore", "text", "toUpperCase", "explicit", "options", "filter", "startsWith", "map", "syntaxHighlighting", "autocompletion", "aboveCursor", "defaultKeymap", "activateOnTyping", "closeOnBlur", "icons", "tooltipClass", "mx", "keymap", "key", "run", "completionStatus", "acceptCompletion", "startCompletion", "rangeExtension", "onInit", "activeRange", "provider", "range", "focus", "ViewPlugin", "fromClass", "constructor", "_view", "ranges", "undefined", "facet", "topNode", "parser", "parse", "visitTree", "type", "node", "callback", "child", "firstChild", "nextSibling", "fragments", "axis", "axisSelected", "cell", "cellSelected", "SheetRoot", "children", "props", "React", "SheetContextProvider", "SheetMain", "forwardRef", "classNames", "numRows", "numColumns", "model", "cursor", "setCursor", "setRange", "setEditing", "useSheetContext", "rowsRef", "columnsRef", "contentRef", "useScrollHandlers", "rows", "setRows", "useState", "sheet", "columns", "setColumns", "useEffect", "rowsAccessor", "createDocAccessor", "columnsAccessor", "handleUpdate", "debounce", "handle", "addListener", "removeListener", "reset", "handleMoveRows", "from", "to", "num", "cursorIdx", "addressToIndex", "undefined", "splice", "addressFromIndex", "handleMoveColumns", "rowSizes", "setRowSizes", "columnSizes", "setColumnSizes", "rowAccessor", "columnAccessor", "mapSizes", "values", "reduce", "map", "idx", "meta", "size", "Object", "entries", "rowMeta", "columnMeta", "handleResizeRow", "save", "sizes", "handleResizeColumn", "div", "role", "className", "mx", "GridCorner", "onClick", "SheetColumns", "ref", "selected", "column", "onSelect", "row", "onResize", "onMove", "SheetRows", "SheetGrid", "length", "SheetStatusBar", "useRef", "handleRowsScroll", "ev", "scrollTop", "target", "current", "dataset", "locked", "handleColumnsScroll", "scrollLeft", "handleContentScroll", "content", "addEventListener", "removeEventListener", "MovingOverlay", "label", "mouseConstraints", "distance", "touchConstraints", "delay", "tolerance", "mouseSensor", "useSensor", "MouseSensor", "activationConstraint", "touchSensor", "TouchSensor", "keyboardSensor", "KeyboardSensor", "sensors", "useSensors", "active", "setActive", "handleDragStart", "handleDragEnd", "over", "id", "data", "index", "snapToCenter", "activatorEvent", "draggingNodeRect", "transform", "activatorCoordinates", "getEventCoordinates", "offset", "y", "top", "height", "style", "width", "axisWidth", "DndContext", "modifiers", "restrictToVerticalAxis", "onDragStart", "onDragEnd", "GridRowCell", "key", "String", "defaultHeight", "resize", "createPortal", "DragOverlay", "document", "body", "setNodeRef", "setDroppableNodeRef", "useDroppable", "setDraggableNodeRef", "attributes", "listeners", "isDragging", "useDraggable", "useCombinedRefs", "initialSize", "setInitialSize", "resizing", "setResizing", "scrollHandler", "handleResizeStart", "_ev", "_dir", "elementRef", "scrollContainer", "closest", "handleResize", "_elementRef", "handleResizeStop", "Resizable", "enable", "bottom", "minHeight", "maxHeight", "onResizeStart", "onResizeStop", "span", "x", "left", "axisHeight", "autoScroll", "enabled", "restrictToHorizontalAxis", "GridColumnCell", "columnLetter", "defaultWidth", "right", "minWidth", "maxWidth", "containerRef", "containerWidth", "containerHeight", "useResizeDetector", "refreshRate", "scrollerRef", "useImperativeHandle", "range", "editing", "onInfo", "initialText", "quickEdit", "forceUpdate", "unsubscribe", "update", "on", "log", "inputRef", "handleKeyDown", "isMacOS", "test", "navigator", "userAgent", "metaKey", "ctrlKey", "cut", "copy", "paste", "shiftKey", "redo", "undo", "next", "handleNav", "element", "getCellElement", "scrollIntoView", "clear", "setValue", "stopPropagation", "handlers", "useRangeSelect", "event", "rowRange", "columnRange", "useGridLayout", "scroller", "fullyQualifiedId", "attendableAttrs", "createAttendableAttributes", "hasAttention", "useHasAttention", "focus", "SelectionOverlay", "root", "position", "addressToA1Notation", "posEquals", "value", "getCellText", "handleClose", "handleArrowNav", "GridCellEditor", "onNav", "onClose", "SheetCell", "edit", "input", "autoFocus", "onKeyDown", "c1", "c2", "b1", "getRelativeClientRect", "b2", "bounds", "getRectUnion", "formatting", "getFormatting", "CELL_DATA_KEY", "onDoubleClick", "notifier", "rangeToA1Notation", "extension", "useMemo", "editorKeys", "sheetExtension", "functions", "rangeExtension", "fn", "CellEditor", "isFormula", "getCellValue", "charAt", "mapFormulaBindingFromId", "mapFormulaIndicesToRefs", "FunctionIcon", "SheetDebug", "accessor", "pre", "JSON", "stringify", "cells", "Sheet", "Root", "Main", "Rows", "Columns", "Grid", "Cell", "StatusBar", "Debug", "SheetContainer", "sheet", "space", "role", "remoteFunctionUrl", "React", "div", "className", "mx", "Sheet", "Root", "Main"]
|
|
7
|
+
}
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
CustomPluginTranslations,
|
|
4
4
|
FunctionPluginAsync,
|
|
5
5
|
createComputeGraph
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-D5AGLXJP.mjs";
|
|
7
7
|
|
|
8
8
|
// packages/plugins/plugin-sheet/src/components/ComputeGraph/edge-function.ts
|
|
9
9
|
import { effect } from "@preact/signals-core";
|
|
@@ -172,4 +172,4 @@ export {
|
|
|
172
172
|
ComputeGraphContextProvider,
|
|
173
173
|
useComputeGraph
|
|
174
174
|
};
|
|
175
|
-
//# sourceMappingURL=chunk-
|
|
175
|
+
//# sourceMappingURL=chunk-APHOLYUB.mjs.map
|
|
@@ -2647,8 +2647,8 @@ var createIndices = (length) => Array.from({
|
|
|
2647
2647
|
|
|
2648
2648
|
// packages/plugins/plugin-sheet/src/model/model.ts
|
|
2649
2649
|
var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/model/model.ts";
|
|
2650
|
-
var DEFAULT_ROWS =
|
|
2651
|
-
var DEFAULT_COLUMNS = 26
|
|
2650
|
+
var DEFAULT_ROWS = 100;
|
|
2651
|
+
var DEFAULT_COLUMNS = 26;
|
|
2652
2652
|
var typeMap = {
|
|
2653
2653
|
BOOLEAN: ValueTypeEnum.Boolean,
|
|
2654
2654
|
NUMBER_RAW: ValueTypeEnum.Number,
|
|
@@ -2738,13 +2738,13 @@ var SheetModel = class {
|
|
|
2738
2738
|
id: this.id
|
|
2739
2739
|
}, {
|
|
2740
2740
|
F: __dxlog_file4,
|
|
2741
|
-
L:
|
|
2741
|
+
L: 142,
|
|
2742
2742
|
S: this,
|
|
2743
2743
|
C: (f, a) => f(...a)
|
|
2744
2744
|
});
|
|
2745
2745
|
invariant2(!this.initialized, "Already initialized.", {
|
|
2746
2746
|
F: __dxlog_file4,
|
|
2747
|
-
L:
|
|
2747
|
+
L: 143,
|
|
2748
2748
|
S: this,
|
|
2749
2749
|
A: [
|
|
2750
2750
|
"!this.initialized",
|
|
@@ -2753,7 +2753,7 @@ var SheetModel = class {
|
|
|
2753
2753
|
});
|
|
2754
2754
|
this._ctx = new Context(void 0, {
|
|
2755
2755
|
F: __dxlog_file4,
|
|
2756
|
-
L:
|
|
2756
|
+
L: 144
|
|
2757
2757
|
});
|
|
2758
2758
|
if (!this._sheet.rows.length) {
|
|
2759
2759
|
this._insertIndices(this._sheet.rows, 0, this._options.rows, DEFAULT_ROWS);
|
|
@@ -2781,7 +2781,7 @@ var SheetModel = class {
|
|
|
2781
2781
|
id: this.id
|
|
2782
2782
|
}, {
|
|
2783
2783
|
F: __dxlog_file4,
|
|
2784
|
-
L:
|
|
2784
|
+
L: 174,
|
|
2785
2785
|
S: this,
|
|
2786
2786
|
C: (f, a) => f(...a)
|
|
2787
2787
|
});
|
|
@@ -3106,7 +3106,7 @@ var SheetModel = class {
|
|
|
3106
3106
|
mapFormulaRefsToIndices(formula) {
|
|
3107
3107
|
invariant2(formula.charAt(0) === "=", void 0, {
|
|
3108
3108
|
F: __dxlog_file4,
|
|
3109
|
-
L:
|
|
3109
|
+
L: 509,
|
|
3110
3110
|
S: this,
|
|
3111
3111
|
A: [
|
|
3112
3112
|
"formula.charAt(0) === '='",
|
|
@@ -3123,7 +3123,7 @@ var SheetModel = class {
|
|
|
3123
3123
|
mapFormulaIndicesToRefs(formula) {
|
|
3124
3124
|
invariant2(formula.charAt(0) === "=", void 0, {
|
|
3125
3125
|
F: __dxlog_file4,
|
|
3126
|
-
L:
|
|
3126
|
+
L: 519,
|
|
3127
3127
|
S: this,
|
|
3128
3128
|
A: [
|
|
3129
3129
|
"formula.charAt(0) === '='",
|
|
@@ -3232,4 +3232,4 @@ export {
|
|
|
3232
3232
|
inRange,
|
|
3233
3233
|
SheetModel
|
|
3234
3234
|
};
|
|
3235
|
-
//# sourceMappingURL=chunk-
|
|
3235
|
+
//# sourceMappingURL=chunk-D5AGLXJP.mjs.map
|