@dxos/plugin-sheet 0.6.10 → 0.6.11-staging.a542fc9
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-ISY6DUVE.mjs → SheetContainer-4XOKHKKZ.mjs} +40 -30
- package/dist/lib/browser/SheetContainer-4XOKHKKZ.mjs.map +7 -0
- package/dist/lib/browser/{chunk-D3PUKBH6.mjs → chunk-FUAGSXA4.mjs} +1 -1
- package/dist/lib/browser/{chunk-D3PUKBH6.mjs.map → chunk-FUAGSXA4.mjs.map} +2 -2
- package/dist/lib/browser/chunk-FWGRE3EG.mjs +175 -0
- package/dist/lib/browser/chunk-FWGRE3EG.mjs.map +7 -0
- package/dist/lib/browser/{chunk-CBRBNG3R.mjs → chunk-P7SSL3EG.mjs} +115 -194
- package/dist/lib/browser/chunk-P7SSL3EG.mjs.map +7 -0
- package/dist/lib/browser/chunk-YPU3R7FA.mjs +8 -0
- package/dist/lib/browser/chunk-YPU3R7FA.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +23 -68
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing.mjs +92 -0
- package/dist/lib/browser/testing.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +1 -1
- package/dist/lib/node/{SheetContainer-ESRTE7A5.cjs → SheetContainer-IQT6TR4Z.cjs} +61 -52
- package/dist/lib/node/SheetContainer-IQT6TR4Z.cjs.map +7 -0
- package/dist/lib/node/chunk-5EPCDAZC.cjs +40 -0
- package/dist/lib/node/chunk-5EPCDAZC.cjs.map +7 -0
- package/dist/lib/node/chunk-727C6YNP.cjs +202 -0
- package/dist/lib/node/chunk-727C6YNP.cjs.map +7 -0
- package/dist/lib/node/{chunk-3R3J7IZR.cjs → chunk-DSYKOI4E.cjs} +4 -4
- package/dist/lib/node/{chunk-3R3J7IZR.cjs.map → chunk-DSYKOI4E.cjs.map} +2 -2
- package/dist/lib/node/{chunk-4EGEA3KL.cjs → chunk-SVAIIXWQ.cjs} +127 -206
- package/dist/lib/node/chunk-SVAIIXWQ.cjs.map +7 -0
- package/dist/lib/node/index.cjs +24 -67
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/testing.cjs +111 -0
- package/dist/lib/node/testing.cjs.map +7 -0
- package/dist/lib/node/types.cjs +9 -9
- package/dist/lib/node/types.cjs.map +1 -1
- package/dist/types/src/SheetPlugin.d.ts.map +1 -1
- package/dist/types/src/components/CellEditor/extension.d.ts.map +1 -1
- package/dist/types/src/components/ComputeGraph/edge-function.d.ts.map +1 -1
- package/dist/types/src/components/ComputeGraph/graph-context.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/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/testing.d.ts +9 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/types.d.ts.map +1 -1
- package/package.json +38 -28
- package/src/SheetPlugin.tsx +18 -4
- package/src/components/CellEditor/extension.ts +16 -10
- package/src/components/ComputeGraph/edge-function.ts +6 -2
- package/src/components/ComputeGraph/graph-context.tsx +10 -1
- package/src/components/Sheet/Sheet.stories.tsx +3 -39
- package/src/components/Sheet/Sheet.tsx +12 -12
- package/src/components/Sheet/formatting.ts +1 -1
- package/src/components/SheetContainer.tsx +2 -1
- package/src/testing.ts +50 -0
- package/src/types.ts +2 -0
- package/dist/lib/browser/SheetContainer-ISY6DUVE.mjs.map +0 -7
- package/dist/lib/browser/chunk-CBRBNG3R.mjs.map +0 -7
- package/dist/lib/node/SheetContainer-ESRTE7A5.cjs.map +0 -7
- package/dist/lib/node/chunk-4EGEA3KL.cjs.map +0 -7
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useComputeGraph
|
|
3
|
+
} from "./chunk-FWGRE3EG.mjs";
|
|
1
4
|
import {
|
|
2
5
|
SheetModel,
|
|
3
6
|
addressFromA1Notation,
|
|
@@ -6,12 +9,11 @@ import {
|
|
|
6
9
|
defaultFunctions,
|
|
7
10
|
inRange,
|
|
8
11
|
posEquals,
|
|
9
|
-
rangeToA1Notation
|
|
10
|
-
|
|
11
|
-
} from "./chunk-CBRBNG3R.mjs";
|
|
12
|
+
rangeToA1Notation
|
|
13
|
+
} from "./chunk-P7SSL3EG.mjs";
|
|
12
14
|
import {
|
|
13
15
|
ValueTypeEnum
|
|
14
|
-
} from "./chunk-
|
|
16
|
+
} from "./chunk-FUAGSXA4.mjs";
|
|
15
17
|
import "./chunk-JRL5LGCE.mjs";
|
|
16
18
|
|
|
17
19
|
// packages/plugins/plugin-sheet/src/components/SheetContainer.tsx
|
|
@@ -367,7 +369,7 @@ var FormattingModel = class {
|
|
|
367
369
|
value: value.toLocaleString().toUpperCase(),
|
|
368
370
|
classNames: [
|
|
369
371
|
...classNames,
|
|
370
|
-
value ? "!text-
|
|
372
|
+
value ? "!text-greenText" : "!text-orangeText"
|
|
371
373
|
]
|
|
372
374
|
};
|
|
373
375
|
}
|
|
@@ -680,30 +682,30 @@ var highlightStyles = HighlightStyle.define([
|
|
|
680
682
|
// Function.
|
|
681
683
|
{
|
|
682
684
|
tag: tags.name,
|
|
683
|
-
class: "text-
|
|
685
|
+
class: "text-accentText"
|
|
684
686
|
},
|
|
685
687
|
// Range.
|
|
686
688
|
{
|
|
687
689
|
tag: tags.tagName,
|
|
688
|
-
class: "text-
|
|
690
|
+
class: "text-pinkText"
|
|
689
691
|
},
|
|
690
692
|
// Values.
|
|
691
693
|
{
|
|
692
694
|
tag: tags.number,
|
|
693
|
-
class: "text-
|
|
695
|
+
class: "text-tealText"
|
|
694
696
|
},
|
|
695
697
|
{
|
|
696
698
|
tag: tags.bool,
|
|
697
|
-
class: "text-
|
|
699
|
+
class: "text-tealText"
|
|
698
700
|
},
|
|
699
701
|
{
|
|
700
702
|
tag: tags.string,
|
|
701
|
-
class: "text-
|
|
703
|
+
class: "text-tealText"
|
|
702
704
|
},
|
|
703
705
|
// Error.
|
|
704
706
|
{
|
|
705
707
|
tag: tags.invalid,
|
|
706
|
-
class: "text-
|
|
708
|
+
class: "text-unAccent"
|
|
707
709
|
}
|
|
708
710
|
]);
|
|
709
711
|
var languageFacet = Facet.define();
|
|
@@ -725,7 +727,7 @@ var sheetExtension = ({ functions = [] }) => {
|
|
|
725
727
|
root.className = "flex flex-col gap-2 text-sm";
|
|
726
728
|
const title = document.createElement("h2");
|
|
727
729
|
title.innerText = name;
|
|
728
|
-
title.className = "text-lg font-mono text-
|
|
730
|
+
title.className = "text-lg font-mono text-accentText";
|
|
729
731
|
root.appendChild(title);
|
|
730
732
|
if (description) {
|
|
731
733
|
const info = document.createElement("p");
|
|
@@ -736,7 +738,7 @@ var sheetExtension = ({ functions = [] }) => {
|
|
|
736
738
|
if (syntax) {
|
|
737
739
|
const detail = document.createElement("pre");
|
|
738
740
|
detail.innerText = syntax;
|
|
739
|
-
detail.className = "whitespace-pre-wrap text-
|
|
741
|
+
detail.className = "whitespace-pre-wrap text-greenText";
|
|
740
742
|
root.appendChild(detail);
|
|
741
743
|
}
|
|
742
744
|
return root;
|
|
@@ -790,8 +792,8 @@ var sheetExtension = ({ functions = [] }) => {
|
|
|
790
792
|
// TODO(burdon): Factor out fragments.
|
|
791
793
|
// TODO(burdon): Size to make width same as column.
|
|
792
794
|
"!-left-[1px] !top-[33px] !-m-0 border !border-t-0 [&>ul]:!min-w-[198px]",
|
|
793
|
-
"[&>ul>li[aria-selected]]:!bg-
|
|
794
|
-
"border-
|
|
795
|
+
"[&>ul>li[aria-selected]]:!bg-accentSurface",
|
|
796
|
+
"border-separator"
|
|
795
797
|
)
|
|
796
798
|
}),
|
|
797
799
|
keymap2.of([
|
|
@@ -841,6 +843,13 @@ var rangeExtension = (onInit) => {
|
|
|
841
843
|
};
|
|
842
844
|
break;
|
|
843
845
|
}
|
|
846
|
+
case "CloseParen": {
|
|
847
|
+
activeRange = {
|
|
848
|
+
from,
|
|
849
|
+
to: from
|
|
850
|
+
};
|
|
851
|
+
break;
|
|
852
|
+
}
|
|
844
853
|
case "RangeToken":
|
|
845
854
|
case "CellToken":
|
|
846
855
|
activeRange = {
|
|
@@ -876,11 +885,11 @@ var visitTree = (node, callback) => {
|
|
|
876
885
|
// packages/plugins/plugin-sheet/src/components/Sheet/Sheet.tsx
|
|
877
886
|
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-sheet/src/components/Sheet/Sheet.tsx";
|
|
878
887
|
var fragments = {
|
|
879
|
-
axis: "bg-
|
|
880
|
-
axisSelected: "bg-
|
|
881
|
-
cell: "
|
|
882
|
-
cellSelected: "bg-
|
|
883
|
-
border: "border-
|
|
888
|
+
axis: "bg-axisSurface text-axisText text-xs select-none",
|
|
889
|
+
axisSelected: "bg-attention text-baseText",
|
|
890
|
+
cell: "bg-gridCell",
|
|
891
|
+
cellSelected: "bg-gridCellSelected text-baseText border !border-accentSurface",
|
|
892
|
+
border: "border-gridLine"
|
|
884
893
|
};
|
|
885
894
|
var SheetRoot = ({ children, ...props }) => {
|
|
886
895
|
return /* @__PURE__ */ React3.createElement(SheetContextProvider, props, children);
|
|
@@ -1089,7 +1098,7 @@ var GridCorner = (props) => {
|
|
|
1089
1098
|
};
|
|
1090
1099
|
var MovingOverlay = ({ label }) => {
|
|
1091
1100
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1092
|
-
className: "flex w-full h-full justify-center items-center text-sm p-1 bg-
|
|
1101
|
+
className: "flex w-full h-full justify-center items-center text-sm p-1 bg-gridOverlay cursor-pointer"
|
|
1093
1102
|
}, label);
|
|
1094
1103
|
};
|
|
1095
1104
|
var mouseConstraints = {
|
|
@@ -1228,9 +1237,9 @@ var GridRowCell = ({ idx, index, label, size, resize, selected, onSelect, onResi
|
|
|
1228
1237
|
}, /* @__PURE__ */ React3.createElement("span", {
|
|
1229
1238
|
className: "flex w-full justify-center"
|
|
1230
1239
|
}, label), over?.id === idx && !isDragging && /* @__PURE__ */ React3.createElement("div", {
|
|
1231
|
-
className: "z-20 absolute top-0 w-full min-h-[4px] border-b-4 border-
|
|
1240
|
+
className: "z-20 absolute top-0 w-full min-h-[4px] border-b-4 border-accentSurface"
|
|
1232
1241
|
}), resizing && /* @__PURE__ */ React3.createElement("div", {
|
|
1233
|
-
className: "z-20 absolute bottom-0 w-full min-h-[4px] border-b-4 border-
|
|
1242
|
+
className: "z-20 absolute bottom-0 w-full min-h-[4px] border-b-4 border-accentSurface"
|
|
1234
1243
|
})));
|
|
1235
1244
|
};
|
|
1236
1245
|
var SheetColumns = /* @__PURE__ */ forwardRef(({ columns, sizes, selected, onSelect, onResize, onMove }, forwardRef2) => {
|
|
@@ -1365,9 +1374,9 @@ var GridColumnCell = ({ idx, index, label, size, resize, selected, onSelect, onR
|
|
|
1365
1374
|
}, /* @__PURE__ */ React3.createElement("span", {
|
|
1366
1375
|
className: "flex w-full justify-center"
|
|
1367
1376
|
}, label), over?.id === idx && !isDragging && /* @__PURE__ */ React3.createElement("div", {
|
|
1368
|
-
className: "z-20 absolute left-0 h-full min-w-[4px] border-l-4 border-
|
|
1377
|
+
className: "z-20 absolute left-0 h-full min-w-[4px] border-l-4 border-accentSurface"
|
|
1369
1378
|
}), resizing && /* @__PURE__ */ React3.createElement("div", {
|
|
1370
|
-
className: "z-20 absolute right-0 h-full min-h-[4px] border-l-4 border-
|
|
1379
|
+
className: "z-20 absolute right-0 h-full min-h-[4px] border-l-4 border-accentSurface"
|
|
1371
1380
|
})));
|
|
1372
1381
|
};
|
|
1373
1382
|
var SheetGrid = /* @__PURE__ */ forwardRef(({ size, rows, columns, rowSizes, columnSizes }, forwardRef2) => {
|
|
@@ -1616,7 +1625,7 @@ var SelectionOverlay = ({ root }) => {
|
|
|
1616
1625
|
return /* @__PURE__ */ React3.createElement("div", {
|
|
1617
1626
|
role: "none",
|
|
1618
1627
|
style: bounds,
|
|
1619
|
-
className: "z-10 absolute pointer-events-none bg-
|
|
1628
|
+
className: "z-10 absolute pointer-events-none bg-gridSelectionOverlay border border-gridOverlay"
|
|
1620
1629
|
});
|
|
1621
1630
|
};
|
|
1622
1631
|
var SheetCell = ({ id, cell, style, active, onSelect }) => {
|
|
@@ -1697,7 +1706,7 @@ var SheetStatusBar = () => {
|
|
|
1697
1706
|
}, range && rangeToA1Notation(range) || cursor && addressToA1Notation(cursor)), /* @__PURE__ */ React3.createElement("div", {
|
|
1698
1707
|
className: "flex gap-2 items-center"
|
|
1699
1708
|
}, /* @__PURE__ */ React3.createElement(FunctionIcon, {
|
|
1700
|
-
className: mx2("text-
|
|
1709
|
+
className: mx2("text-greenText", isFormula ? "visible" : "invisible")
|
|
1701
1710
|
}), /* @__PURE__ */ React3.createElement("span", {
|
|
1702
1711
|
className: "font-mono"
|
|
1703
1712
|
}, value))));
|
|
@@ -1744,17 +1753,18 @@ var Sheet = {
|
|
|
1744
1753
|
var SheetContainer = ({ sheet, space, role, coordinate = {
|
|
1745
1754
|
part: "main",
|
|
1746
1755
|
entryId: ""
|
|
1747
|
-
} }) => {
|
|
1756
|
+
}, remoteFunctionUrl }) => {
|
|
1748
1757
|
return /* @__PURE__ */ React4.createElement("div", {
|
|
1749
1758
|
role: "none",
|
|
1750
1759
|
className: mx3("flex", role === "article" && "row-span-2", role === "section" && "aspect-square border-y border-is border-separator", coordinate.part !== "solo" && "border-is border-separator")
|
|
1751
1760
|
}, /* @__PURE__ */ React4.createElement(Sheet.Root, {
|
|
1752
1761
|
sheet,
|
|
1753
|
-
space
|
|
1762
|
+
space,
|
|
1763
|
+
remoteFunctionUrl
|
|
1754
1764
|
}, /* @__PURE__ */ React4.createElement(Sheet.Main, null)));
|
|
1755
1765
|
};
|
|
1756
1766
|
var SheetContainer_default = SheetContainer;
|
|
1757
1767
|
export {
|
|
1758
1768
|
SheetContainer_default as default
|
|
1759
1769
|
};
|
|
1760
|
-
//# sourceMappingURL=SheetContainer-
|
|
1770
|
+
//# sourceMappingURL=SheetContainer-4XOKHKKZ.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 coordinate = { part: 'main', entryId: '' },\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', // TODO(burdon): Container with toolbar.\n role === 'section' && 'aspect-square border-y border-is border-separator',\n coordinate.part !== 'solo' && '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 } 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\n// TODO(burdon): Factor out fragments.\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 border: 'border-gridLine',\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 fragments.border,\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 pointer-events-none', fragments.border)}\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 focus-visible:outline-none',\n fragments.border,\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 pointer-events-none', fragments.border)}\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 focus-visible:outline-none',\n fragments.border,\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 qualifiedSubjectId = fullyQualifiedId(model.sheet);\n const attendableAttrs = createAttendableAttributes(qualifiedSubjectId);\n // const attended = useHasAttention(qualifiedSubjectId);\n const attended = true;\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 pointer-events-none', fragments.border)} />\n\n {/* Grid scroll container. */}\n <div ref={scrollerRef} className={mx('grow', attended && '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 truncate items-center border cursor-pointer',\n 'px-2 py-1',\n fragments.cell,\n fragments.border,\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', fragments.border)}>\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 text-xs bg-neutral-50 dark:bg-black text-cyan-500 font-mono p-1 opacity-80',\n fragments.border,\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", "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", "border", "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", "qualifiedSubjectId", "fullyQualifiedId", "attendableAttrs", "createAttendableAttributes", "attended", "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", "coordinate", "part", "entryId", "remoteFunctionUrl", "React", "div", "className", "mx", "Sheet", "Root", "Main"]
|
|
7
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport type {\n GraphBuilderProvides,\n IntentResolverProvides,\n MetadataRecordsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { create, S, TypedObject } from '@dxos/echo-schema';\nimport { type SchemaProvides } from '@dxos/plugin-client';\nimport { type StackProvides } from '@dxos/plugin-stack';\n\nimport { SHEET_PLUGIN } from './meta';\n\nconst SHEET_ACTION = `${SHEET_PLUGIN}/action`;\n\nexport enum SheetAction {\n CREATE = `${SHEET_ACTION}/create`,\n}\n\nexport type SheetPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n GraphBuilderProvides &\n MetadataRecordsProvides &\n TranslationsProvides &\n SchemaProvides &\n StackProvides;\n\nexport type CellScalarValue = number | string | boolean | null;\n\nexport const CellValue = S.Struct({\n // TODO(burdon): How to store dates (datetime, date, time), percentages, etc.\n // Consider import/export; natural access for other plugins. Special handling for currency (precision).\n // TODO(burdon): Automerge (long string) or short string or number.\n // TODO(burdon): Arrays?\n value: S.Any,\n});\n\nexport type CellValue = S.Schema.Type<typeof CellValue>;\n\n/**\n * https://www.tutorialsteacher.com/typescript/typescript-number\n */\n// TODO(burdon): Format vs. value.\nexport enum ValueTypeEnum {\n Null = 0,\n Number = 1,\n Boolean = 2,\n String = 3,\n\n // Special numbers.\n Percent = 10,\n Currency = 11,\n\n // Dates.\n DateTime = 20,\n Date = 21,\n Time = 22,\n\n // Validated string types.\n // TODO(burdon): Define effect types.\n URL = 30,\n DID = 31,\n}\n\nexport const ValueType = S.Enums(ValueTypeEnum);\n\nexport const Formatting = S.Struct({\n type: S.optional(ValueType),\n format: S.optional(S.String),\n precision: S.optional(S.Number),\n classNames: S.optional(S.Array(S.String)),\n});\n\nexport type Formatting = S.Schema.Type<typeof Formatting>;\n\n// TODO(burdon): Visibility, locked, frozen, etc.\nexport const RowColumnMeta = S.Struct({\n size: S.optional(S.Number),\n});\n\n// TODO(burdon): Index to all updates when rows/columns are inserted/deleted.\nexport class SheetType extends TypedObject({ typename: 'dxos.org/type/SheetType', version: '0.1.0' })({\n title: S.optional(S.String),\n\n // Sparse map of cells referenced by index.\n cells: S.mutable(S.Record(S.String, S.mutable(CellValue))),\n\n // Ordered row indices.\n rows: S.mutable(S.Array(S.String)),\n\n // Ordered column indices.\n columns: S.mutable(S.Array(S.String)),\n\n // Row metadata referenced by index.\n rowMeta: S.mutable(S.Record(S.String, S.mutable(RowColumnMeta))),\n\n // Column metadata referenced by index.\n columnMeta: S.mutable(S.Record(S.String, S.mutable(RowColumnMeta))),\n\n // Cell formatting referenced by indexed range.\n formatting: S.mutable(S.Record(S.String, S.mutable(Formatting))),\n}) {}\n\n// TODO(burdon): Fix defaults.\nexport const createSheet = (title?: string): SheetType =>\n create(SheetType, { title, cells: {}, rows: [], columns: [], rowMeta: {}, columnMeta: {}, formatting: {} });\n"],
|
|
5
|
-
"mappings": ";;;;;AAWA,SAASA,QAAQC,GAAGC,mBAAmB;AAMvC,IAAMC,eAAe,GAAGC,YAAAA;;UAEZC,cAAAA;wCACD,GAAGF,YAAAA,SAAqB,IAAA;GADvBE,gBAAAA,cAAAA,CAAAA,EAAAA;AAcL,IAAMC,YAAYC,EAAEC,OAAO;;;;;EAKhCC,OAAOF,EAAEG;AACX,CAAA;;UAQYC,gBAAAA;;;;;;;;;;;;GAAAA,kBAAAA,gBAAAA,CAAAA,EAAAA;AAqBL,IAAMC,YAAYL,EAAEM,MAAMF,aAAAA;AAE1B,IAAMG,aAAaP,EAAEC,OAAO;EACjCO,MAAMR,EAAES,SAASJ,SAAAA;EACjBK,QAAQV,EAAES,SAAST,EAAEW,MAAM;EAC3BC,WAAWZ,EAAES,SAAST,EAAEa,MAAM;EAC9BC,YAAYd,EAAES,SAAST,EAAEe,MAAMf,EAAEW,MAAM,CAAA;AACzC,CAAA;AAKO,IAAMK,gBAAgBhB,EAAEC,OAAO;EACpCgB,MAAMjB,EAAES,SAAST,EAAEa,MAAM;AAC3B,CAAA;
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport type {\n GraphBuilderProvides,\n IntentResolverProvides,\n MetadataRecordsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { create, S, TypedObject } from '@dxos/echo-schema';\nimport { type SchemaProvides } from '@dxos/plugin-client';\nimport { type StackProvides } from '@dxos/plugin-stack';\n\nimport { SHEET_PLUGIN } from './meta';\n\nconst SHEET_ACTION = `${SHEET_PLUGIN}/action`;\n\nexport enum SheetAction {\n CREATE = `${SHEET_ACTION}/create`,\n}\n\nexport type SheetPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n GraphBuilderProvides &\n MetadataRecordsProvides &\n TranslationsProvides &\n SchemaProvides &\n StackProvides;\n\nexport type CellScalarValue = number | string | boolean | null;\n\nexport const CellValue = S.Struct({\n // TODO(burdon): How to store dates (datetime, date, time), percentages, etc.\n // Consider import/export; natural access for other plugins. Special handling for currency (precision).\n // TODO(burdon): Automerge (long string) or short string or number.\n // TODO(burdon): Arrays?\n value: S.Any,\n});\n\nexport type CellValue = S.Schema.Type<typeof CellValue>;\n\n/**\n * https://www.tutorialsteacher.com/typescript/typescript-number\n */\n// TODO(burdon): Format vs. value.\nexport enum ValueTypeEnum {\n Null = 0,\n Number = 1,\n Boolean = 2,\n String = 3,\n\n // Special numbers.\n Percent = 10,\n Currency = 11,\n\n // Dates.\n DateTime = 20,\n Date = 21,\n Time = 22,\n\n // Validated string types.\n // TODO(burdon): Define effect types.\n URL = 30,\n DID = 31,\n}\n\nexport const ValueType = S.Enums(ValueTypeEnum);\n\nexport const Formatting = S.Struct({\n type: S.optional(ValueType),\n format: S.optional(S.String),\n precision: S.optional(S.Number),\n classNames: S.optional(S.Array(S.String)),\n});\n\nexport type Formatting = S.Schema.Type<typeof Formatting>;\n\n// TODO(burdon): Visibility, locked, frozen, etc.\nexport const RowColumnMeta = S.Struct({\n size: S.optional(S.Number),\n});\n\n// TODO(burdon): Index to all updates when rows/columns are inserted/deleted.\n// TODO(wittjosiah): Migrate typename to remove `Type` suffix.\n// TODO(wittjosiah): Rename title to name to align with other schemas.\nexport class SheetType extends TypedObject({ typename: 'dxos.org/type/SheetType', version: '0.1.0' })({\n title: S.optional(S.String),\n\n // Sparse map of cells referenced by index.\n cells: S.mutable(S.Record(S.String, S.mutable(CellValue))),\n\n // Ordered row indices.\n rows: S.mutable(S.Array(S.String)),\n\n // Ordered column indices.\n columns: S.mutable(S.Array(S.String)),\n\n // Row metadata referenced by index.\n rowMeta: S.mutable(S.Record(S.String, S.mutable(RowColumnMeta))),\n\n // Column metadata referenced by index.\n columnMeta: S.mutable(S.Record(S.String, S.mutable(RowColumnMeta))),\n\n // Cell formatting referenced by indexed range.\n formatting: S.mutable(S.Record(S.String, S.mutable(Formatting))),\n}) {}\n\n// TODO(burdon): Fix defaults.\nexport const createSheet = (title?: string): SheetType =>\n create(SheetType, { title, cells: {}, rows: [], columns: [], rowMeta: {}, columnMeta: {}, formatting: {} });\n"],
|
|
5
|
+
"mappings": ";;;;;AAWA,SAASA,QAAQC,GAAGC,mBAAmB;AAMvC,IAAMC,eAAe,GAAGC,YAAAA;;UAEZC,cAAAA;wCACD,GAAGF,YAAAA,SAAqB,IAAA;GADvBE,gBAAAA,cAAAA,CAAAA,EAAAA;AAcL,IAAMC,YAAYC,EAAEC,OAAO;;;;;EAKhCC,OAAOF,EAAEG;AACX,CAAA;;UAQYC,gBAAAA;;;;;;;;;;;;GAAAA,kBAAAA,gBAAAA,CAAAA,EAAAA;AAqBL,IAAMC,YAAYL,EAAEM,MAAMF,aAAAA;AAE1B,IAAMG,aAAaP,EAAEC,OAAO;EACjCO,MAAMR,EAAES,SAASJ,SAAAA;EACjBK,QAAQV,EAAES,SAAST,EAAEW,MAAM;EAC3BC,WAAWZ,EAAES,SAAST,EAAEa,MAAM;EAC9BC,YAAYd,EAAES,SAAST,EAAEe,MAAMf,EAAEW,MAAM,CAAA;AACzC,CAAA;AAKO,IAAMK,gBAAgBhB,EAAEC,OAAO;EACpCgB,MAAMjB,EAAES,SAAST,EAAEa,MAAM;AAC3B,CAAA;AAKO,IAAMK,YAAN,cAAwBC,YAAY;EAAEC,UAAU;EAA2BC,SAAS;AAAQ,CAAA,EAAG;EACpGC,OAAOtB,EAAES,SAAST,EAAEW,MAAM;;EAG1BY,OAAOvB,EAAEwB,QAAQxB,EAAEyB,OAAOzB,EAAEW,QAAQX,EAAEwB,QAAQzB,SAAAA,CAAAA,CAAAA;;EAG9C2B,MAAM1B,EAAEwB,QAAQxB,EAAEe,MAAMf,EAAEW,MAAM,CAAA;;EAGhCgB,SAAS3B,EAAEwB,QAAQxB,EAAEe,MAAMf,EAAEW,MAAM,CAAA;;EAGnCiB,SAAS5B,EAAEwB,QAAQxB,EAAEyB,OAAOzB,EAAEW,QAAQX,EAAEwB,QAAQR,aAAAA,CAAAA,CAAAA;;EAGhDa,YAAY7B,EAAEwB,QAAQxB,EAAEyB,OAAOzB,EAAEW,QAAQX,EAAEwB,QAAQR,aAAAA,CAAAA,CAAAA;;EAGnDc,YAAY9B,EAAEwB,QAAQxB,EAAEyB,OAAOzB,EAAEW,QAAQX,EAAEwB,QAAQjB,UAAAA,CAAAA,CAAAA;AACrD,CAAA,EAAA;AAAI;AAGG,IAAMwB,cAAc,CAACT,UAC1BU,OAAOd,WAAW;EAAEI;EAAOC,OAAO,CAAC;EAAGG,MAAM,CAAA;EAAIC,SAAS,CAAA;EAAIC,SAAS,CAAC;EAAGC,YAAY,CAAC;EAAGC,YAAY,CAAC;AAAE,CAAA;",
|
|
6
6
|
"names": ["create", "S", "TypedObject", "SHEET_ACTION", "SHEET_PLUGIN", "SheetAction", "CellValue", "S", "Struct", "value", "Any", "ValueTypeEnum", "ValueType", "Enums", "Formatting", "type", "optional", "format", "String", "precision", "Number", "classNames", "Array", "RowColumnMeta", "size", "SheetType", "TypedObject", "typename", "version", "title", "cells", "mutable", "Record", "rows", "columns", "rowMeta", "columnMeta", "formatting", "createSheet", "create"]
|
|
7
7
|
}
|