@dxos/plugin-sheet 0.8.4-main.ae835ea → 0.8.4-main.bcb3aa67d6

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.
Files changed (287) hide show
  1. package/dist/lib/browser/chunk-CBNIKBPQ.mjs +278 -0
  2. package/dist/lib/browser/chunk-CBNIKBPQ.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-GZ2EV64I.mjs +118 -0
  4. package/dist/lib/browser/chunk-GZ2EV64I.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  6. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  7. package/dist/lib/browser/drop-axis-PB7F3LBV.mjs +23 -0
  8. package/dist/lib/browser/drop-axis-PB7F3LBV.mjs.map +7 -0
  9. package/dist/lib/browser/index.mjs +122 -114
  10. package/dist/lib/browser/index.mjs.map +4 -4
  11. package/dist/lib/browser/insert-axis-DH5CO4AY.mjs +16 -0
  12. package/dist/lib/browser/insert-axis-DH5CO4AY.mjs.map +7 -0
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/operations/index.mjs +13 -0
  15. package/dist/lib/browser/operations/index.mjs.map +7 -0
  16. package/dist/lib/browser/restore-axis-Y5H5IOC6.mjs +16 -0
  17. package/dist/lib/browser/restore-axis-Y5H5IOC6.mjs.map +7 -0
  18. package/dist/lib/browser/scroll-to-anchor-MN36E3X7.mjs +65 -0
  19. package/dist/lib/browser/scroll-to-anchor-MN36E3X7.mjs.map +7 -0
  20. package/dist/lib/browser/types/index.mjs +4 -2
  21. package/dist/lib/node-esm/chunk-3ZYLQWHC.mjs +279 -0
  22. package/dist/lib/node-esm/chunk-3ZYLQWHC.mjs.map +7 -0
  23. package/dist/lib/node-esm/chunk-74MOADQ7.mjs +119 -0
  24. package/dist/lib/node-esm/chunk-74MOADQ7.mjs.map +7 -0
  25. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  26. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  27. package/dist/lib/node-esm/drop-axis-UBBQCU6D.mjs +24 -0
  28. package/dist/lib/node-esm/drop-axis-UBBQCU6D.mjs.map +7 -0
  29. package/dist/lib/node-esm/index.mjs +122 -114
  30. package/dist/lib/node-esm/index.mjs.map +4 -4
  31. package/dist/lib/node-esm/insert-axis-S7BR2RSJ.mjs +17 -0
  32. package/dist/lib/node-esm/insert-axis-S7BR2RSJ.mjs.map +7 -0
  33. package/dist/lib/node-esm/meta.json +1 -1
  34. package/dist/lib/node-esm/operations/index.mjs +14 -0
  35. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  36. package/dist/lib/node-esm/restore-axis-6B25SOHX.mjs +17 -0
  37. package/dist/lib/node-esm/restore-axis-6B25SOHX.mjs.map +7 -0
  38. package/dist/lib/node-esm/scroll-to-anchor-YLB4MYGF.mjs +66 -0
  39. package/dist/lib/node-esm/scroll-to-anchor-YLB4MYGF.mjs.map +7 -0
  40. package/dist/lib/node-esm/types/index.mjs +4 -2
  41. package/dist/types/src/SheetPlugin.d.ts +2 -1
  42. package/dist/types/src/SheetPlugin.d.ts.map +1 -1
  43. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  44. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  45. package/dist/types/src/capabilities/compute-graph-registry.d.ts +3 -2
  46. package/dist/types/src/capabilities/compute-graph-registry.d.ts.map +1 -1
  47. package/dist/types/src/capabilities/index.d.ts +9 -9
  48. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  49. package/dist/types/src/capabilities/markdown.d.ts +3 -2
  50. package/dist/types/src/capabilities/markdown.d.ts.map +1 -1
  51. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  52. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  53. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  54. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  55. package/dist/types/src/capabilities/state.d.ts +6 -0
  56. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  57. package/dist/types/src/capabilities/undo-mappings.d.ts +5 -0
  58. package/dist/types/src/capabilities/undo-mappings.d.ts.map +1 -0
  59. package/dist/types/src/components/ComputeGraph/compute-graph.stories.d.ts.map +1 -1
  60. package/dist/types/src/components/Sheet/Sheet.d.ts +29 -0
  61. package/dist/types/src/components/Sheet/Sheet.d.ts.map +1 -0
  62. package/dist/types/src/components/Sheet/index.d.ts +2 -0
  63. package/dist/types/src/components/Sheet/index.d.ts.map +1 -0
  64. package/dist/types/src/components/{GridSheet → SheetContent}/SheetCellEditor.stories.d.ts +1 -1
  65. package/dist/types/src/components/SheetContent/SheetCellEditor.stories.d.ts.map +1 -0
  66. package/dist/types/src/components/SheetContent/SheetContent.d.ts +10 -0
  67. package/dist/types/src/components/SheetContent/SheetContent.d.ts.map +1 -0
  68. package/dist/types/src/components/SheetContent/SheetContent.stories.d.ts +63 -0
  69. package/dist/types/src/components/SheetContent/SheetContent.stories.d.ts.map +1 -0
  70. package/dist/types/src/components/SheetContent/index.d.ts +2 -0
  71. package/dist/types/src/components/SheetContent/index.d.ts.map +1 -0
  72. package/dist/types/src/components/SheetContent/util.d.ts.map +1 -0
  73. package/dist/types/src/components/{SheetContext/SheetContext.d.ts → SheetRoot/SheetRoot.d.ts} +7 -5
  74. package/dist/types/src/components/SheetRoot/SheetRoot.d.ts.map +1 -0
  75. package/dist/types/src/components/SheetRoot/index.d.ts +2 -0
  76. package/dist/types/src/components/SheetRoot/index.d.ts.map +1 -0
  77. package/dist/types/src/components/SheetStatusbar/SheetStatusbar.d.ts +10 -0
  78. package/dist/types/src/components/SheetStatusbar/SheetStatusbar.d.ts.map +1 -0
  79. package/dist/types/src/components/SheetStatusbar/index.d.ts +2 -0
  80. package/dist/types/src/components/SheetStatusbar/index.d.ts.map +1 -0
  81. package/dist/types/src/components/SheetToolbar/SheetToolbar.d.ts +9 -5
  82. package/dist/types/src/components/SheetToolbar/SheetToolbar.d.ts.map +1 -1
  83. package/dist/types/src/components/SheetToolbar/SheetToolbar.stories.d.ts +72 -66
  84. package/dist/types/src/components/SheetToolbar/SheetToolbar.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/SheetToolbar/align.d.ts +13 -20
  86. package/dist/types/src/components/SheetToolbar/align.d.ts.map +1 -1
  87. package/dist/types/src/components/SheetToolbar/style.d.ts +13 -19
  88. package/dist/types/src/components/SheetToolbar/style.d.ts.map +1 -1
  89. package/dist/types/src/components/SheetToolbar/useToolbarState.d.ts +14 -1
  90. package/dist/types/src/components/SheetToolbar/useToolbarState.d.ts.map +1 -1
  91. package/dist/types/src/components/index.d.ts +1 -4
  92. package/dist/types/src/components/index.d.ts.map +1 -1
  93. package/dist/types/src/{components → containers}/RangeList/RangeList.d.ts +1 -1
  94. package/dist/types/src/{components → containers}/RangeList/RangeList.d.ts.map +1 -1
  95. package/dist/types/src/containers/RangeList/index.d.ts +3 -0
  96. package/dist/types/src/containers/RangeList/index.d.ts.map +1 -0
  97. package/dist/types/src/containers/SheetContainer/SheetContainer.d.ts +12 -0
  98. package/dist/types/src/containers/SheetContainer/SheetContainer.d.ts.map +1 -0
  99. package/dist/types/src/containers/SheetContainer/SheetContainer.stories.d.ts +58 -0
  100. package/dist/types/src/containers/SheetContainer/SheetContainer.stories.d.ts.map +1 -0
  101. package/dist/types/src/{components → containers}/SheetContainer/index.d.ts.map +1 -1
  102. package/dist/types/src/containers/index.d.ts +4 -0
  103. package/dist/types/src/containers/index.d.ts.map +1 -0
  104. package/dist/types/src/extensions/compute.stories.d.ts.map +1 -1
  105. package/dist/types/src/extensions/editor/sheet-extension.d.ts.map +1 -1
  106. package/dist/types/src/index.d.ts +1 -1
  107. package/dist/types/src/index.d.ts.map +1 -1
  108. package/dist/types/src/integrations/thread-ranges.d.ts +0 -2
  109. package/dist/types/src/integrations/thread-ranges.d.ts.map +1 -1
  110. package/dist/types/src/meta.d.ts +2 -2
  111. package/dist/types/src/meta.d.ts.map +1 -1
  112. package/dist/types/src/model/sheet-model.d.ts +3 -3
  113. package/dist/types/src/model/sheet-model.d.ts.map +1 -1
  114. package/dist/types/src/model/testing.d.ts +1 -1
  115. package/dist/types/src/model/testing.d.ts.map +1 -1
  116. package/dist/types/src/model/useSheetModel.d.ts +1 -1
  117. package/dist/types/src/model/useSheetModel.d.ts.map +1 -1
  118. package/dist/types/src/operations/definitions.d.ts +45 -0
  119. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  120. package/dist/types/src/operations/drop-axis.d.ts +5 -0
  121. package/dist/types/src/operations/drop-axis.d.ts.map +1 -0
  122. package/dist/types/src/operations/index.d.ts +4 -0
  123. package/dist/types/src/operations/index.d.ts.map +1 -0
  124. package/dist/types/src/operations/insert-axis.d.ts +5 -0
  125. package/dist/types/src/operations/insert-axis.d.ts.map +1 -0
  126. package/dist/types/src/operations/restore-axis.d.ts +5 -0
  127. package/dist/types/src/operations/restore-axis.d.ts.map +1 -0
  128. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  129. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  130. package/dist/types/src/serializer.d.ts +1 -1
  131. package/dist/types/src/serializer.d.ts.map +1 -1
  132. package/dist/types/src/testing/data.d.ts +1 -1
  133. package/dist/types/src/testing/data.d.ts.map +1 -1
  134. package/dist/types/src/testing/testing.d.ts +16 -16
  135. package/dist/types/src/testing/testing.d.ts.map +1 -1
  136. package/dist/types/src/translations.d.ts +38 -35
  137. package/dist/types/src/translations.d.ts.map +1 -1
  138. package/dist/types/src/types/Sheet.d.ts +41 -35
  139. package/dist/types/src/types/Sheet.d.ts.map +1 -1
  140. package/dist/types/src/types/capabilities.d.ts +18 -0
  141. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  142. package/dist/types/src/types/index.d.ts +1 -0
  143. package/dist/types/src/types/index.d.ts.map +1 -1
  144. package/dist/types/src/types/types.d.ts +2 -68
  145. package/dist/types/src/types/types.d.ts.map +1 -1
  146. package/dist/types/src/types/util.d.ts +2 -1
  147. package/dist/types/src/types/util.d.ts.map +1 -1
  148. package/dist/types/tsconfig.tsbuildinfo +1 -1
  149. package/package.json +93 -68
  150. package/src/SheetPlugin.tsx +63 -67
  151. package/src/capabilities/anchor-sort.ts +20 -15
  152. package/src/capabilities/compute-graph-registry.ts +18 -14
  153. package/src/capabilities/index.ts +12 -8
  154. package/src/capabilities/markdown.ts +20 -13
  155. package/src/capabilities/operation-handler.ts +16 -0
  156. package/src/capabilities/react-surface.tsx +38 -29
  157. package/src/capabilities/state.ts +29 -0
  158. package/src/capabilities/undo-mappings.ts +30 -0
  159. package/src/components/ComputeGraph/compute-graph.stories.tsx +13 -8
  160. package/src/components/Sheet/Sheet.tsx +20 -0
  161. package/src/components/Sheet/index.ts +5 -0
  162. package/src/components/{GridSheet → SheetContent}/SheetCellEditor.stories.tsx +10 -7
  163. package/src/components/{GridSheet/GridSheet.stories.tsx → SheetContent/SheetContent.stories.tsx} +16 -15
  164. package/src/components/{GridSheet/GridSheet.tsx → SheetContent/SheetContent.tsx} +80 -50
  165. package/src/components/{RangeList → SheetContent}/index.ts +1 -1
  166. package/src/components/{GridSheet → SheetContent}/util.ts +15 -9
  167. package/src/components/{SheetContext/SheetContext.tsx → SheetRoot/SheetRoot.tsx} +48 -41
  168. package/src/components/{GridSheet → SheetRoot}/index.ts +1 -1
  169. package/src/components/{FunctionEditor/FunctionEditor.tsx → SheetStatusbar/SheetStatusbar.tsx} +18 -6
  170. package/src/components/{FunctionEditor → SheetStatusbar}/index.ts +1 -1
  171. package/src/components/SheetToolbar/SheetToolbar.stories.tsx +4 -4
  172. package/src/components/SheetToolbar/SheetToolbar.tsx +50 -39
  173. package/src/components/SheetToolbar/align.ts +48 -23
  174. package/src/components/SheetToolbar/style.ts +51 -21
  175. package/src/components/SheetToolbar/useToolbarState.ts +22 -5
  176. package/src/components/index.ts +1 -7
  177. package/src/{components → containers}/RangeList/RangeList.tsx +18 -14
  178. package/src/containers/RangeList/index.ts +7 -0
  179. package/src/containers/SheetContainer/SheetContainer.stories.tsx +109 -0
  180. package/src/containers/SheetContainer/SheetContainer.tsx +57 -0
  181. package/src/{components → containers}/SheetContainer/index.ts +1 -1
  182. package/src/containers/index.ts +8 -0
  183. package/src/extensions/compute.stories.tsx +25 -15
  184. package/src/extensions/compute.ts +1 -1
  185. package/src/extensions/editor/sheet-extension.ts +16 -13
  186. package/src/index.ts +1 -1
  187. package/src/integrations/thread-ranges.ts +17 -60
  188. package/src/meta.ts +3 -3
  189. package/src/model/sheet-model.test.ts +3 -3
  190. package/src/model/sheet-model.ts +79 -47
  191. package/src/model/testing.ts +1 -1
  192. package/src/model/useSheetModel.ts +1 -1
  193. package/src/operations/definitions.ts +73 -0
  194. package/src/operations/drop-axis.ts +26 -0
  195. package/src/operations/index.ts +14 -0
  196. package/src/operations/insert-axis.ts +19 -0
  197. package/src/operations/restore-axis.ts +19 -0
  198. package/src/operations/scroll-to-anchor.ts +31 -0
  199. package/src/playwright/playwright.config.ts +1 -1
  200. package/src/playwright/sheet.spec.ts +2 -1
  201. package/src/sanity.test.ts +6 -3
  202. package/src/serializer.ts +2 -2
  203. package/src/testing/data.ts +1 -1
  204. package/src/testing/testing.tsx +2 -2
  205. package/src/translations.ts +38 -35
  206. package/src/types/Sheet.ts +31 -31
  207. package/src/types/capabilities.ts +26 -0
  208. package/src/types/index.ts +1 -0
  209. package/src/types/sheet-range-types.ts +3 -3
  210. package/src/types/types.ts +4 -40
  211. package/src/types/util.ts +2 -1
  212. package/dist/lib/browser/SheetContainer-GTINUSNB.mjs +0 -349
  213. package/dist/lib/browser/SheetContainer-GTINUSNB.mjs.map +0 -7
  214. package/dist/lib/browser/anchor-sort-R5CB37J7.mjs +0 -24
  215. package/dist/lib/browser/anchor-sort-R5CB37J7.mjs.map +0 -7
  216. package/dist/lib/browser/chunk-73AV3NH6.mjs +0 -15
  217. package/dist/lib/browser/chunk-73AV3NH6.mjs.map +0 -7
  218. package/dist/lib/browser/chunk-7VEWYJJN.mjs +0 -234
  219. package/dist/lib/browser/chunk-7VEWYJJN.mjs.map +0 -7
  220. package/dist/lib/browser/chunk-DVJ3QW3F.mjs +0 -907
  221. package/dist/lib/browser/chunk-DVJ3QW3F.mjs.map +0 -7
  222. package/dist/lib/browser/chunk-FWFAAGXL.mjs +0 -28
  223. package/dist/lib/browser/chunk-FWFAAGXL.mjs.map +0 -7
  224. package/dist/lib/browser/chunk-LS6D4GG7.mjs +0 -850
  225. package/dist/lib/browser/chunk-LS6D4GG7.mjs.map +0 -7
  226. package/dist/lib/browser/compute-graph-registry-AP5RA7W3.mjs +0 -21
  227. package/dist/lib/browser/compute-graph-registry-AP5RA7W3.mjs.map +0 -7
  228. package/dist/lib/browser/intent-resolver-66OAYVQF.mjs +0 -56
  229. package/dist/lib/browser/intent-resolver-66OAYVQF.mjs.map +0 -7
  230. package/dist/lib/browser/markdown-B6VKYY2S.mjs +0 -26
  231. package/dist/lib/browser/markdown-B6VKYY2S.mjs.map +0 -7
  232. package/dist/lib/browser/react-surface-F3VQPGDV.mjs +0 -53
  233. package/dist/lib/browser/react-surface-F3VQPGDV.mjs.map +0 -7
  234. package/dist/lib/node-esm/SheetContainer-PW4KNZME.mjs +0 -350
  235. package/dist/lib/node-esm/SheetContainer-PW4KNZME.mjs.map +0 -7
  236. package/dist/lib/node-esm/anchor-sort-HEND452H.mjs +0 -25
  237. package/dist/lib/node-esm/anchor-sort-HEND452H.mjs.map +0 -7
  238. package/dist/lib/node-esm/chunk-44YTKTMP.mjs +0 -16
  239. package/dist/lib/node-esm/chunk-44YTKTMP.mjs.map +0 -7
  240. package/dist/lib/node-esm/chunk-4H2EHVWE.mjs +0 -908
  241. package/dist/lib/node-esm/chunk-4H2EHVWE.mjs.map +0 -7
  242. package/dist/lib/node-esm/chunk-4QV4AGWK.mjs +0 -236
  243. package/dist/lib/node-esm/chunk-4QV4AGWK.mjs.map +0 -7
  244. package/dist/lib/node-esm/chunk-HILDMVPL.mjs +0 -29
  245. package/dist/lib/node-esm/chunk-HILDMVPL.mjs.map +0 -7
  246. package/dist/lib/node-esm/chunk-LYUIM3QG.mjs +0 -851
  247. package/dist/lib/node-esm/chunk-LYUIM3QG.mjs.map +0 -7
  248. package/dist/lib/node-esm/compute-graph-registry-UMQ5UYCL.mjs +0 -22
  249. package/dist/lib/node-esm/compute-graph-registry-UMQ5UYCL.mjs.map +0 -7
  250. package/dist/lib/node-esm/intent-resolver-VNKIMQQT.mjs +0 -57
  251. package/dist/lib/node-esm/intent-resolver-VNKIMQQT.mjs.map +0 -7
  252. package/dist/lib/node-esm/markdown-VKY7HXU2.mjs +0 -27
  253. package/dist/lib/node-esm/markdown-VKY7HXU2.mjs.map +0 -7
  254. package/dist/lib/node-esm/react-surface-GGX76V2Y.mjs +0 -54
  255. package/dist/lib/node-esm/react-surface-GGX76V2Y.mjs.map +0 -7
  256. package/dist/types/src/capabilities/capabilities.d.ts +0 -5
  257. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  258. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  259. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  260. package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts +0 -3
  261. package/dist/types/src/components/FunctionEditor/FunctionEditor.d.ts.map +0 -1
  262. package/dist/types/src/components/FunctionEditor/index.d.ts +0 -2
  263. package/dist/types/src/components/FunctionEditor/index.d.ts.map +0 -1
  264. package/dist/types/src/components/GridSheet/GridSheet.d.ts +0 -3
  265. package/dist/types/src/components/GridSheet/GridSheet.d.ts.map +0 -1
  266. package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts +0 -54
  267. package/dist/types/src/components/GridSheet/GridSheet.stories.d.ts.map +0 -1
  268. package/dist/types/src/components/GridSheet/SheetCellEditor.stories.d.ts.map +0 -1
  269. package/dist/types/src/components/GridSheet/index.d.ts +0 -2
  270. package/dist/types/src/components/GridSheet/index.d.ts.map +0 -1
  271. package/dist/types/src/components/GridSheet/util.d.ts.map +0 -1
  272. package/dist/types/src/components/RangeList/index.d.ts +0 -2
  273. package/dist/types/src/components/RangeList/index.d.ts.map +0 -1
  274. package/dist/types/src/components/SheetContainer/SheetContainer.d.ts +0 -11
  275. package/dist/types/src/components/SheetContainer/SheetContainer.d.ts.map +0 -1
  276. package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts +0 -55
  277. package/dist/types/src/components/SheetContainer/SheetContainer.stories.d.ts.map +0 -1
  278. package/dist/types/src/components/SheetContext/SheetContext.d.ts.map +0 -1
  279. package/dist/types/src/components/SheetContext/index.d.ts +0 -2
  280. package/dist/types/src/components/SheetContext/index.d.ts.map +0 -1
  281. package/src/capabilities/capabilities.ts +0 -14
  282. package/src/capabilities/intent-resolver.ts +0 -38
  283. package/src/components/SheetContainer/SheetContainer.stories.tsx +0 -90
  284. package/src/components/SheetContainer/SheetContainer.tsx +0 -40
  285. package/src/components/SheetContext/index.ts +0 -5
  286. /package/dist/types/src/components/{GridSheet → SheetContent}/util.d.ts +0 -0
  287. /package/dist/types/src/{components → containers}/SheetContainer/index.d.ts +0 -0
@@ -2,11 +2,5 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from 'react';
6
-
7
5
  export * from './ComputeGraph';
8
- export * from './GridSheet';
9
- export * from './RangeList';
10
- export * from './SheetContext';
11
-
12
- export const SheetContainer = lazy(() => import('./SheetContainer'));
6
+ export * from './Sheet';
@@ -6,13 +6,13 @@ import * as Schema from 'effect/Schema';
6
6
  import React, { useCallback } from 'react';
7
7
 
8
8
  import { rangeToA1Notation } from '@dxos/compute';
9
- import { Callout, useTranslation } from '@dxos/react-ui';
9
+ import { Obj } from '@dxos/echo';
10
+ import { Input, Message, useTranslation } from '@dxos/react-ui';
10
11
  import { List } from '@dxos/react-ui-list';
11
- import { ghostHover } from '@dxos/react-ui-theme';
12
12
 
13
- import { meta } from '../../meta';
14
- import { rangeFromIndex } from '../../types';
15
- import { Sheet } from '../../types';
13
+ import { meta } from '#meta';
14
+ import { rangeFromIndex } from '#types';
15
+ import { Sheet } from '#types';
16
16
 
17
17
  export type RangeListProps = {
18
18
  sheet: Sheet.Sheet;
@@ -25,28 +25,32 @@ export const RangeList = ({ sheet }: RangeListProps) => {
25
25
  const handleDeleteRange = useCallback(
26
26
  (range: Sheet.Range) => {
27
27
  const index = sheet.ranges.findIndex((sheetRange) => sheetRange === range);
28
- sheet.ranges.splice(index, 1);
28
+ Obj.change(sheet, (obj) => {
29
+ obj.ranges.splice(index, 1);
30
+ });
29
31
  },
30
32
  [sheet],
31
33
  );
32
34
  return (
33
35
  <>
34
- <h2 className='mbs-cardSpacingBlock mbe-labelSpacingBlock text-sm font-semibold'>{t('range list heading')}</h2>
36
+ <Input.Root>
37
+ <Input.Label>{t('range-list.heading')}</Input.Label>
38
+ </Input.Root>
35
39
  {sheet.ranges.length < 1 ? (
36
- <Callout.Root>
37
- <Callout.Title>{t('no ranges message')}</Callout.Title>
38
- </Callout.Root>
40
+ <Message.Root>
41
+ <Message.Title>{t('no-ranges.message')}</Message.Title>
42
+ </Message.Root>
39
43
  ) : (
40
44
  <List.Root<Sheet.Range> items={sheet.ranges} isItem={Schema.is(Sheet.Range)}>
41
45
  {({ items: ranges }) =>
42
46
  ranges.map((range, i) => (
43
- <List.Item key={i} item={range} classNames={['p-2', ghostHover]}>
47
+ <List.Item key={i} item={range}>
44
48
  <List.ItemDragHandle />
45
49
  <List.ItemTitle onClick={() => handleSelectRange(range)}>
46
- {t('range title', {
50
+ {t('range.title', {
47
51
  position: rangeToA1Notation(rangeFromIndex(sheet, range.range)),
48
- key: t(`range key ${range.key} label`),
49
- value: t(`range value ${range.value} label`),
52
+ key: t(`range-key-${range.key}.label`),
53
+ value: t(`range-value-${range.value}.label`),
50
54
  })}
51
55
  </List.ItemTitle>
52
56
  <List.ItemDeleteButton onClick={() => handleDeleteRange(range)} />
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import { RangeList } from './RangeList';
6
+
7
+ export default RangeList;
@@ -0,0 +1,109 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import { type Meta } from '@storybook/react-vite';
6
+ import * as Effect from 'effect/Effect';
7
+ import React, { useContext } from 'react';
8
+
9
+ import { Capabilities, Capability } from '@dxos/app-framework';
10
+ import { withPluginManager } from '@dxos/app-framework/testing';
11
+ import { Obj } from '@dxos/echo';
12
+ import { Operation, OperationHandlerSet } from '@dxos/operation';
13
+ import { corePlugins } from '@dxos/plugin-testing';
14
+ import { useSpace } from '@dxos/react-client/echo';
15
+ import { withClientProvider } from '@dxos/react-client/testing';
16
+ import { withLayout } from '@dxos/react-ui/testing';
17
+ import { AttendableContainer } from '@dxos/react-ui-attention';
18
+
19
+ import { ComputeGraphContext, useComputeGraph } from '#components';
20
+ import { createTestCells, useTestSheet, withComputeGraphDecorator } from '#testing';
21
+ import { translations } from '../../translations';
22
+ import { Sheet } from '#types';
23
+ import { SheetOperation } from '#operations';
24
+ import RangeList from '../RangeList';
25
+
26
+ import { SheetContainer } from './SheetContainer';
27
+
28
+ const meta = {
29
+ title: 'plugins/plugin-sheet/containers/SheetContainer',
30
+ component: SheetContainer,
31
+ decorators: [
32
+ withLayout({ layout: 'fullscreen' }),
33
+ withClientProvider({ types: [Sheet.Sheet], createSpace: true }),
34
+ withComputeGraphDecorator(),
35
+ withPluginManager({
36
+ plugins: [...corePlugins()],
37
+ capabilities: [
38
+ Capability.contributes(
39
+ Capabilities.OperationHandler,
40
+ OperationHandlerSet.make(
41
+ Operation.withHandler(SheetOperation.DropAxis, ({ model, axis, axisIndex }) =>
42
+ Effect.sync(() => {
43
+ model[axis === 'col' ? 'dropColumn' : 'dropRow'](axisIndex);
44
+ return { axis, axisIndex, index: 0, axisMeta: null, values: [] };
45
+ }),
46
+ ),
47
+ ),
48
+ ),
49
+ ],
50
+ }),
51
+ ],
52
+ parameters: {
53
+ layout: 'fullscreen',
54
+ translations,
55
+ },
56
+ } satisfies Meta<typeof SheetContainer>;
57
+
58
+ export default meta;
59
+
60
+ export const Default = () => {
61
+ const space = useSpace();
62
+ const graph = useComputeGraph(space);
63
+ const { registry } = useContext(ComputeGraphContext) ?? {};
64
+ const sheet = useTestSheet(space, graph, { cells: createTestCells() });
65
+ if (!sheet || !space || !registry) {
66
+ return null;
67
+ }
68
+
69
+ return (
70
+ <AttendableContainer id={Obj.getDXN(sheet).toString()} classNames='contents'>
71
+ <SheetContainer
72
+ role='article'
73
+ space={space}
74
+ subject={sheet}
75
+ attendableId='test'
76
+ registry={registry}
77
+ ignoreAttention
78
+ />
79
+ </AttendableContainer>
80
+ );
81
+ };
82
+
83
+ export const Spec = () => {
84
+ const space = useSpace();
85
+ const graph = useComputeGraph(space);
86
+ const { registry } = useContext(ComputeGraphContext) ?? {};
87
+ const sheet = useTestSheet(space, graph, { cells: { A1: { value: 'Ready' } } });
88
+ if (!sheet || !space || !registry) {
89
+ return null;
90
+ }
91
+
92
+ return (
93
+ <AttendableContainer id={Obj.getDXN(sheet).toString()} classNames='contents'>
94
+ <div role='none' className='w-full grid grid-cols-[1fr_20rem]'>
95
+ <SheetContainer
96
+ role='article'
97
+ space={space}
98
+ subject={sheet}
99
+ attendableId='test'
100
+ registry={registry}
101
+ ignoreAttention
102
+ />
103
+ <div role='none' data-testid='grid.range-list'>
104
+ <RangeList sheet={sheet} />
105
+ </div>
106
+ </div>
107
+ </AttendableContainer>
108
+ );
109
+ };
@@ -0,0 +1,57 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { type ObjectSurfaceProps } from '@dxos/app-toolkit/ui';
8
+ import { type ComputeGraphRegistry } from '@dxos/compute';
9
+ import { type Space } from '@dxos/react-client/echo';
10
+ import { Panel } from '@dxos/react-ui';
11
+
12
+ import { ComputeGraphContextProvider, Sheet, useComputeGraph } from '#components';
13
+ import { type Sheet as SheetType } from '#types';
14
+
15
+ export type SheetContainerProps = ObjectSurfaceProps<
16
+ SheetType.Sheet,
17
+ {
18
+ space: Space;
19
+ registry: ComputeGraphRegistry;
20
+ ignoreAttention?: boolean;
21
+ }
22
+ >;
23
+
24
+ export const SheetContainer = ({ registry, ...props }: SheetContainerProps) => (
25
+ <ComputeGraphContextProvider registry={registry}>
26
+ <SheetContainerInner {...props} />
27
+ </ComputeGraphContextProvider>
28
+ );
29
+
30
+ const SheetContainerInner = ({
31
+ role,
32
+ subject: sheet,
33
+ attendableId,
34
+ space,
35
+ ignoreAttention,
36
+ }: Omit<SheetContainerProps, 'registry'>) => {
37
+ const graph = useComputeGraph(space);
38
+ if (!graph) {
39
+ return null;
40
+ }
41
+
42
+ return (
43
+ <Sheet.Root graph={graph} sheet={sheet} attendableId={attendableId!} ignoreAttention={ignoreAttention}>
44
+ <Panel.Root classNames={role === 'section' && 'aspect-aquare'}>
45
+ <Panel.Toolbar asChild>
46
+ <Sheet.Toolbar />
47
+ </Panel.Toolbar>
48
+ <Panel.Content asChild>
49
+ <Sheet.Content />
50
+ </Panel.Content>
51
+ <Panel.Statusbar asChild>
52
+ <Sheet.Statusbar />
53
+ </Panel.Statusbar>
54
+ </Panel.Root>
55
+ </Sheet.Root>
56
+ );
57
+ };
@@ -1,5 +1,5 @@
1
1
  //
2
- // Copyright 2024 DXOS.org
2
+ // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
5
  import { SheetContainer } from './SheetContainer';
@@ -0,0 +1,8 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type ComponentType, lazy } from 'react';
6
+
7
+ export const RangeList: ComponentType<any> = lazy(() => import('./RangeList'));
8
+ export const SheetContainer: ComponentType<any> = lazy(() => import('./SheetContainer'));
@@ -5,27 +5,27 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useEffect, useMemo } from 'react';
7
7
 
8
- import { IntentPlugin } from '@dxos/app-framework';
8
+ import { OperationPlugin, RuntimePlugin } from '@dxos/app-framework';
9
9
  import { withPluginManager } from '@dxos/app-framework/testing';
10
10
  import { PublicKey } from '@dxos/keys';
11
11
  import { useSpace } from '@dxos/react-client/echo';
12
12
  import { withClientProvider } from '@dxos/react-client/testing';
13
13
  import { useThemeContext } from '@dxos/react-ui';
14
- import { withTheme } from '@dxos/react-ui/testing';
14
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
15
+ import { useTextEditor } from '@dxos/react-ui-editor';
15
16
  import {
16
17
  createBasicExtensions,
17
18
  createMarkdownExtensions,
18
19
  createThemeExtensions,
19
20
  decorateMarkdown,
20
21
  documentId,
21
- useTextEditor,
22
- } from '@dxos/react-ui-editor';
22
+ } from '@dxos/ui-editor';
23
23
  import { isNonNullable } from '@dxos/util';
24
24
 
25
- import { GridSheet, SheetProvider, useComputeGraph } from '../components';
25
+ import { Sheet, useComputeGraph } from '#components';
26
26
  import { useSheetModel } from '../model';
27
- import { useTestSheet, withComputeGraphDecorator } from '../testing';
28
- import { Sheet } from '../types';
27
+ import { useTestSheet, withComputeGraphDecorator } from '#testing';
28
+ import { Sheet as SheetType } from '#types';
29
29
 
30
30
  import { compute, computeGraphFacet } from './compute';
31
31
 
@@ -73,7 +73,12 @@ const Grid = () => {
73
73
  const model = useSheetModel(graph, sheet);
74
74
  useEffect(() => {
75
75
  if (model) {
76
- model.setValues({ A1: { value: 100 }, A2: { value: 200 }, A3: { value: 300 }, A5: { value: '=SUM(A1:A3)' } });
76
+ model.setValues({
77
+ A1: { value: 100 },
78
+ A2: { value: 200 },
79
+ A3: { value: 300 },
80
+ A5: { value: '=SUM(A1:A3)' },
81
+ });
77
82
  }
78
83
  }, [model]);
79
84
 
@@ -83,9 +88,9 @@ const Grid = () => {
83
88
 
84
89
  return (
85
90
  <div className='flex w-[40rem] overflow-hidden'>
86
- <SheetProvider graph={graph} sheet={sheet}>
87
- <GridSheet />
88
- </SheetProvider>
91
+ <Sheet.Root graph={graph} sheet={sheet} attendableId='test'>
92
+ <Sheet.Content />
93
+ </Sheet.Root>
89
94
  </div>
90
95
  );
91
96
  };
@@ -100,12 +105,17 @@ const GraphStory = (props: EditorProps) => {
100
105
  };
101
106
 
102
107
  const meta = {
103
- title: 'plugins/plugin-sheet/extensions',
108
+ title: 'plugins/plugin-sheet/extensions/compute',
104
109
  decorators: [
105
- withTheme,
106
- withClientProvider({ types: [Sheet.Sheet], createIdentity: true, createSpace: true }),
110
+ withTheme(),
111
+ withLayout({ layout: 'fullscreen' }),
112
+ withClientProvider({
113
+ types: [SheetType.Sheet],
114
+ createIdentity: true,
115
+ createSpace: true,
116
+ }),
107
117
  // TODO(wittjosiah): Try to write story which does not depend on plugin manager.
108
- withPluginManager({ plugins: [IntentPlugin()] }),
118
+ withPluginManager({ plugins: [OperationPlugin(), RuntimePlugin()] }),
109
119
  withComputeGraphDecorator(),
110
120
  ],
111
121
  parameters: {
@@ -23,7 +23,7 @@ import {
23
23
  createSheetName,
24
24
  } from '@dxos/compute';
25
25
  import { invariant } from '@dxos/invariant';
26
- import { documentId, singleValueFacet } from '@dxos/react-ui-editor';
26
+ import { documentId, singleValueFacet } from '@dxos/ui-editor';
27
27
 
28
28
  const LANGUAGE_TAG = 'dx';
29
29
 
@@ -20,8 +20,8 @@ import { spreadsheet } from 'codemirror-lang-spreadsheet';
20
20
 
21
21
  import { type FunctionDefinition } from '@dxos/compute';
22
22
  import { RANGE_NOTATION } from '@dxos/compute';
23
- import { singleValueFacet } from '@dxos/react-ui-editor';
24
- import { mx } from '@dxos/react-ui-theme';
23
+ import { singleValueFacet } from '@dxos/ui-editor';
24
+ import { mx } from '@dxos/ui-theme';
25
25
 
26
26
  /**
27
27
  * https://codemirror.net/examples/styling
@@ -33,30 +33,30 @@ const highlightStyles = HighlightStyle.define([
33
33
  // Function.
34
34
  {
35
35
  tag: tags.name,
36
- class: 'text-accentText',
36
+ class: 'text-accent-text',
37
37
  },
38
38
  // Range.
39
39
  {
40
40
  tag: tags.tagName,
41
- class: 'text-pinkText',
41
+ class: 'text-pink-text',
42
42
  },
43
43
  // Values.
44
44
  {
45
45
  tag: tags.number,
46
- class: 'text-tealText',
46
+ class: 'text-teal-text',
47
47
  },
48
48
  {
49
49
  tag: tags.bool,
50
- class: 'text-tealText',
50
+ class: 'text-teal-text',
51
51
  },
52
52
  {
53
53
  tag: tags.string,
54
- class: 'text-tealText',
54
+ class: 'text-teal-text',
55
55
  },
56
56
  // Error.
57
57
  {
58
58
  tag: tags.invalid,
59
- class: 'text-unAccent',
59
+ class: 'text-un-accent',
60
60
  },
61
61
  ]);
62
62
 
@@ -75,7 +75,10 @@ export type SheetExtensionOptions = {
75
75
  * https://hyperformula.handsontable.com/guide/key-concepts.html#grammar
76
76
  */
77
77
  export const sheetExtension = ({ debug, functions = [] }: SheetExtensionOptions): Extension => {
78
- const { extension, language } = spreadsheet({ idiom: 'en-US', decimalSeparator: '.' });
78
+ const { extension, language } = spreadsheet({
79
+ idiom: 'en-US',
80
+ decimalSeparator: '.',
81
+ });
79
82
 
80
83
  const createCompletion = (name: string) => {
81
84
  const { section = 'Custom', description, syntax } = functions.find((value) => value.name === name) ?? {};
@@ -94,7 +97,7 @@ export const sheetExtension = ({ debug, functions = [] }: SheetExtensionOptions)
94
97
 
95
98
  const title = document.createElement('h2');
96
99
  title.innerText = name;
97
- title.className = 'text-lg font-mono text-accentText';
100
+ title.className = 'text-lg font-mono text-accent-text';
98
101
  root.appendChild(title);
99
102
 
100
103
  if (description) {
@@ -107,7 +110,7 @@ export const sheetExtension = ({ debug, functions = [] }: SheetExtensionOptions)
107
110
  if (syntax) {
108
111
  const detail = document.createElement('pre');
109
112
  detail.innerText = syntax;
110
- detail.className = 'whitespace-pre-wrap text-greenText';
113
+ detail.className = 'whitespace-pre-wrap text-green-text';
111
114
  root.appendChild(detail);
112
115
  }
113
116
 
@@ -166,8 +169,8 @@ export const sheetExtension = ({ debug, functions = [] }: SheetExtensionOptions)
166
169
  icons: false,
167
170
  tooltipClass: () =>
168
171
  mx(
169
- '!-left-[1px] !top-[33px] !-m-0 border !border-t-0 [&>ul]:!min-w-[198px]',
170
- '[&>ul>li[aria-selected]]:!bg-accentSurface',
172
+ '!-left-[1px] !top-[33px] !-m-0 border border-h-0! [&>ul]:!min-w-[198px]',
173
+ '[&>ul>li[aria-selected]]:!bg-accent-surface',
171
174
  'border-separator',
172
175
  ),
173
176
  }),
package/src/index.ts CHANGED
@@ -2,6 +2,6 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- export { SheetCapabilities } from './capabilities';
5
+ export { SheetCapabilities } from './types';
6
6
  export * from './meta';
7
7
  export * from './SheetPlugin';
@@ -2,29 +2,19 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- import * as Function from 'effect/Function';
6
- import * as Schema from 'effect/Schema';
7
5
  import { useCallback, useEffect, useMemo } from 'react';
8
6
 
9
- import {
10
- LayoutAction,
11
- chain,
12
- createIntent,
13
- createResolver,
14
- useIntentDispatcher,
15
- useIntentResolver,
16
- } from '@dxos/app-framework';
7
+ import { useOperationInvoker } from '@dxos/app-framework/ui';
8
+ import { linkedSegment } from '@dxos/react-ui-attention';
17
9
  import { debounce } from '@dxos/async';
18
10
  import { type CellAddress, type CompleteCellRange, inRange } from '@dxos/compute';
19
11
  import { Obj, Relation } from '@dxos/echo';
20
- import { ATTENDABLE_PATH_SEPARATOR, DeckAction } from '@dxos/plugin-deck/types';
21
- import { Thread, ThreadAction } from '@dxos/plugin-thread/types';
22
- import { Filter, Query, fullyQualifiedId, getSpace, useQuery } from '@dxos/react-client/echo';
23
- import { type DxGridElement, type GridContentProps } from '@dxos/react-ui-grid';
24
- import { AnchoredTo } from '@dxos/schema';
12
+ import { DeckOperation } from '@dxos/plugin-deck/operations';
13
+ import { ThreadOperation } from '@dxos/plugin-thread/operations';
14
+ import { Filter, Query, useQuery } from '@dxos/react-client/echo';
15
+ import { AnchoredTo, Thread } from '@dxos/types';
25
16
 
26
- import { useSheetContext } from '../components';
27
- import { meta } from '../meta';
17
+ import { useSheetContext } from '#components';
28
18
 
29
19
  export const completeCellRangeToThreadCursor = (range: CompleteCellRange): string => {
30
20
  return `${range.from.col},${range.from.row},${range.to.col},${range.to.row}`;
@@ -43,45 +33,12 @@ export const parseThreadAnchorAsCellRange = (cursor: string): CompleteCellRange
43
33
  }
44
34
  };
45
35
 
46
- export const useUpdateFocusedCellOnThreadSelection = (grid: DxGridElement | null) => {
47
- const { model, setActiveRefs } = useSheetContext();
48
- const scrollIntoViewResolver = useMemo(
49
- () =>
50
- createResolver({
51
- intent: LayoutAction.ScrollIntoView,
52
- position: 'hoist',
53
- filter: (
54
- data,
55
- ): data is {
56
- part: 'current';
57
- subject: string;
58
- options: { cursor: string; ref: GridContentProps['activeRefs'] };
59
- } => {
60
- if (!Schema.is(LayoutAction.ScrollIntoView.fields.input)(data)) {
61
- return false;
62
- }
63
-
64
- return data.subject === fullyQualifiedId(model.sheet) && !!data.options?.cursor;
65
- },
66
- resolve: ({ options: { cursor, ref } }) => {
67
- setActiveRefs(ref);
68
- // TODO(Zan): Everywhere we refer to the cursor in a thread context should change to `anchor`.
69
- const range = parseThreadAnchorAsCellRange(cursor!);
70
- range && grid?.setFocus({ ...range.to, plane: 'grid' }, true);
71
- },
72
- }),
73
- [model.sheet, setActiveRefs],
74
- );
75
-
76
- useIntentResolver(meta.id, scrollIntoViewResolver);
77
- };
78
-
79
36
  export const useSelectThreadOnCellFocus = () => {
80
37
  const { model, cursor } = useSheetContext();
81
- const { dispatchPromise: dispatch } = useIntentDispatcher();
38
+ const { invokePromise } = useOperationInvoker();
82
39
 
83
- const space = getSpace(model.sheet);
84
- const anchors = useQuery(space, Query.select(Filter.ids(model.sheet.id)).targetOf(AnchoredTo));
40
+ const db = Obj.getDatabase(model.sheet);
41
+ const anchors = useQuery(db, Query.select(Filter.id(model.sheet.id)).targetOf(AnchoredTo.AnchoredTo));
85
42
 
86
43
  const selectClosestThread = useCallback(
87
44
  (cellAddress: CellAddress) => {
@@ -100,15 +57,15 @@ export const useSelectThreadOnCellFocus = () => {
100
57
  });
101
58
 
102
59
  if (closestThread) {
103
- const primary = fullyQualifiedId(model.sheet);
104
- const intent = Function.pipe(
105
- createIntent(ThreadAction.Select, { current: fullyQualifiedId(closestThread) }),
106
- chain(DeckAction.ChangeCompanion, { primary, companion: `${primary}${ATTENDABLE_PATH_SEPARATOR}comments` }),
107
- );
108
- void dispatch(intent);
60
+ void (async () => {
61
+ await invokePromise(ThreadOperation.Select, { current: Relation.getDXN(closestThread).toString() });
62
+ await invokePromise(DeckOperation.ChangeCompanion, {
63
+ companion: linkedSegment('comments'),
64
+ });
65
+ })();
109
66
  }
110
67
  },
111
- [dispatch, anchors],
68
+ [invokePromise, anchors],
112
69
  );
113
70
 
114
71
  const debounced = useMemo(() => {
package/src/meta.ts CHANGED
@@ -2,11 +2,11 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { type PluginMeta } from '@dxos/app-framework';
5
+ import { type Plugin } from '@dxos/app-framework';
6
6
  import { trim } from '@dxos/util';
7
7
 
8
- export const meta: PluginMeta = {
9
- id: 'dxos.org/plugin/sheet',
8
+ export const meta: Plugin.Meta = {
9
+ id: 'org.dxos.plugin.sheet',
10
10
  name: 'Sheet',
11
11
  description: trim`
12
12
  Full-featured spreadsheet application with over 400 built-in formulas for calculations and data analysis.
@@ -7,10 +7,10 @@ import { afterEach, beforeEach, describe, expect, onTestFinished, test } from 'v
7
7
  import { Trigger } from '@dxos/async';
8
8
  import { type CellScalarValue, addressFromA1Notation, isFormula } from '@dxos/compute';
9
9
  import { TestBuilder, testFunctionPlugins } from '@dxos/compute/testing';
10
- import { Function } from '@dxos/functions';
11
10
  import { log } from '@dxos/log';
11
+ import { Operation } from '@dxos/operation';
12
12
 
13
- import { Sheet, mapFormulaIndicesToRefs, mapFormulaRefsToIndices } from '../types';
13
+ import { Sheet, mapFormulaIndicesToRefs, mapFormulaRefsToIndices } from '#types';
14
14
 
15
15
  import { SheetModel } from './sheet-model';
16
16
  import { createTestGrid } from './testing';
@@ -18,7 +18,7 @@ import { createTestGrid } from './testing';
18
18
  describe('SheetModel', () => {
19
19
  let testBuilder: TestBuilder;
20
20
  beforeEach(async () => {
21
- testBuilder = new TestBuilder({ types: [Function.Function], plugins: testFunctionPlugins });
21
+ testBuilder = new TestBuilder({ types: [Operation.PersistentOperation], plugins: testFunctionPlugins });
22
22
  await testBuilder.open();
23
23
  });
24
24
  afterEach(async () => {