@beyondwork/docx-react-component 1.0.29 → 1.0.31

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 (383) hide show
  1. package/package.json +65 -96
  2. package/src/README.md +85 -0
  3. package/src/api/README.md +26 -0
  4. package/src/api/public-types.ts +1952 -0
  5. package/src/api/session-state.ts +62 -0
  6. package/src/compare/diff-engine.ts +623 -0
  7. package/src/compare/export-redlines.ts +280 -0
  8. package/src/compare/index.ts +25 -0
  9. package/src/compare/snapshot.ts +97 -0
  10. package/src/component-inventory.md +99 -0
  11. package/src/core/README.md +10 -0
  12. package/src/core/commands/README.md +3 -0
  13. package/{dist/chunk-TJBP2K4T.js → src/core/commands/formatting-commands.ts} +536 -196
  14. package/src/core/commands/image-commands.ts +373 -0
  15. package/src/core/commands/index.ts +1879 -0
  16. package/src/core/commands/list-commands.ts +565 -0
  17. package/src/core/commands/paragraph-layout-commands.ts +339 -0
  18. package/src/core/commands/review-commands.ts +108 -0
  19. package/{dist/core/commands/section-layout-commands.cjs → src/core/commands/section-layout-commands.ts} +340 -137
  20. package/src/core/commands/structural-helpers.ts +309 -0
  21. package/{dist/core/commands/style-commands.cjs → src/core/commands/style-commands.ts} +113 -65
  22. package/src/core/commands/table-structure-commands.ts +854 -0
  23. package/{dist/chunk-UZXBISGO.js → src/core/commands/text-commands.ts} +142 -86
  24. package/src/core/schema/README.md +3 -0
  25. package/src/core/schema/text-schema.ts +516 -0
  26. package/src/core/search/search-text.ts +357 -0
  27. package/src/core/selection/README.md +3 -0
  28. package/src/core/selection/mapping.ts +289 -0
  29. package/src/core/selection/review-anchors.ts +183 -0
  30. package/src/core/state/README.md +3 -0
  31. package/src/core/state/editor-state.ts +892 -0
  32. package/src/core/state/text-transaction.ts +869 -0
  33. package/src/formats/xlsx/io/parse-shared-strings.ts +41 -0
  34. package/src/formats/xlsx/io/parse-sheet.ts +459 -0
  35. package/src/formats/xlsx/io/parse-styles.ts +59 -0
  36. package/src/formats/xlsx/io/parse-workbook.ts +75 -0
  37. package/src/formats/xlsx/io/serialize-shared-strings.ts +72 -0
  38. package/src/formats/xlsx/io/serialize-sheet.ts +333 -0
  39. package/src/formats/xlsx/io/serialize-styles.ts +98 -0
  40. package/src/formats/xlsx/io/serialize-workbook.ts +429 -0
  41. package/src/formats/xlsx/io/xlsx-session.ts +314 -0
  42. package/src/formats/xlsx/model/cell.ts +189 -0
  43. package/src/formats/xlsx/model/sheet.ts +326 -0
  44. package/src/formats/xlsx/model/styles.ts +118 -0
  45. package/src/formats/xlsx/model/workbook.ts +453 -0
  46. package/src/formats/xlsx/runtime/cell-commands.ts +567 -0
  47. package/src/formats/xlsx/runtime/sheet-commands.ts +206 -0
  48. package/src/formats/xlsx/runtime/workbook-runtime.ts +177 -0
  49. package/src/formats/xlsx/runtime/workbook-transaction.ts +822 -0
  50. package/src/index.ts +142 -0
  51. package/src/io/README.md +10 -0
  52. package/src/io/docx-session.ts +3175 -0
  53. package/src/io/export/README.md +3 -0
  54. package/src/io/export/export-session.ts +220 -0
  55. package/src/io/export/minimal-docx.ts +115 -0
  56. package/src/io/export/reattach-preserved-parts.ts +54 -0
  57. package/src/io/export/serialize-comments.ts +947 -0
  58. package/src/io/export/serialize-footnotes.ts +394 -0
  59. package/src/io/export/serialize-headers-footers.ts +368 -0
  60. package/src/io/export/serialize-main-document.ts +1342 -0
  61. package/src/io/export/serialize-numbering.ts +218 -0
  62. package/src/io/export/serialize-revisions.ts +389 -0
  63. package/src/io/export/serialize-runtime-revisions.ts +463 -0
  64. package/src/io/export/serialize-tables.ts +174 -0
  65. package/src/io/export/split-review-boundaries.ts +356 -0
  66. package/src/io/export/split-story-blocks-for-runtime-revisions.ts +252 -0
  67. package/src/io/export/table-properties-xml.ts +318 -0
  68. package/src/io/normalize/README.md +3 -0
  69. package/src/io/normalize/normalize-text.ts +670 -0
  70. package/src/io/ooxml/README.md +3 -0
  71. package/src/io/ooxml/highlight-colors.ts +39 -0
  72. package/src/io/ooxml/numbering-sentinels.ts +44 -0
  73. package/src/io/ooxml/parse-comments.ts +852 -0
  74. package/src/io/ooxml/parse-complex-content.ts +287 -0
  75. package/src/io/ooxml/parse-fields.ts +834 -0
  76. package/src/io/ooxml/parse-footnotes.ts +952 -0
  77. package/src/io/ooxml/parse-headers-footers.ts +1212 -0
  78. package/src/io/ooxml/parse-inline-media.ts +461 -0
  79. package/src/io/ooxml/parse-main-document.ts +2947 -0
  80. package/src/io/ooxml/parse-numbering.ts +747 -0
  81. package/src/io/ooxml/parse-revisions.ts +1045 -0
  82. package/src/io/ooxml/parse-settings.ts +184 -0
  83. package/src/io/ooxml/parse-shapes.ts +296 -0
  84. package/src/io/ooxml/parse-styles.ts +639 -0
  85. package/src/io/ooxml/parse-tables.ts +627 -0
  86. package/src/io/ooxml/parse-theme.ts +346 -0
  87. package/src/io/ooxml/part-manifest.ts +136 -0
  88. package/src/io/ooxml/revision-boundaries.ts +475 -0
  89. package/src/io/ooxml/workflow-payload.ts +544 -0
  90. package/src/io/opc/README.md +3 -0
  91. package/src/io/opc/corrupt-package.ts +166 -0
  92. package/src/io/opc/docx-package.ts +74 -0
  93. package/src/io/opc/package-reader.ts +325 -0
  94. package/src/io/opc/package-writer.ts +273 -0
  95. package/src/io/source-package-provenance.ts +241 -0
  96. package/{dist/chunk-RMH72RZI.js → src/legal/bookmarks.ts} +130 -44
  97. package/src/legal/cross-references.ts +414 -0
  98. package/src/legal/defined-terms.ts +203 -0
  99. package/src/legal/index.ts +32 -0
  100. package/src/legal/signature-blocks.ts +259 -0
  101. package/src/model/README.md +3 -0
  102. package/src/model/canonical-document.ts +2722 -0
  103. package/src/model/cds-1.0.0.ts +212 -0
  104. package/src/model/snapshot.ts +760 -0
  105. package/src/preservation/README.md +3 -0
  106. package/src/preservation/markup-compatibility.ts +48 -0
  107. package/src/preservation/opaque-fragment-store.ts +89 -0
  108. package/src/preservation/opaque-region.ts +233 -0
  109. package/src/preservation/package-preservation.ts +113 -0
  110. package/src/preservation/preserved-part-manifest.ts +56 -0
  111. package/src/preservation/relationship-retention.ts +57 -0
  112. package/src/preservation/store.ts +255 -0
  113. package/src/review/README.md +16 -0
  114. package/src/review/store/README.md +3 -0
  115. package/src/review/store/comment-anchors.ts +70 -0
  116. package/src/review/store/comment-remapping.ts +154 -0
  117. package/src/review/store/comment-store.ts +349 -0
  118. package/src/review/store/comment-thread.ts +109 -0
  119. package/src/review/store/revision-actions.ts +423 -0
  120. package/src/review/store/revision-store.ts +323 -0
  121. package/src/review/store/revision-types.ts +182 -0
  122. package/src/review/store/runtime-comment-store.ts +43 -0
  123. package/src/runtime/README.md +3 -0
  124. package/src/runtime/ai-action-policy.ts +764 -0
  125. package/src/runtime/context-analytics.ts +824 -0
  126. package/src/runtime/document-layout.ts +332 -0
  127. package/src/runtime/document-locations.ts +521 -0
  128. package/src/runtime/document-navigation.ts +616 -0
  129. package/src/runtime/document-outline.ts +440 -0
  130. package/src/runtime/document-runtime.ts +4055 -0
  131. package/src/runtime/document-search.ts +145 -0
  132. package/src/runtime/event-refresh-hints.ts +137 -0
  133. package/src/runtime/numbering-prefix.ts +244 -0
  134. package/src/runtime/page-layout-estimation.ts +305 -0
  135. package/src/runtime/read-only-diagnostics-runtime.ts +241 -0
  136. package/src/runtime/resolved-numbering-geometry.ts +293 -0
  137. package/src/runtime/review-runtime.ts +44 -0
  138. package/src/runtime/revision-runtime.ts +107 -0
  139. package/src/runtime/session-capabilities.ts +192 -0
  140. package/src/runtime/story-context.ts +164 -0
  141. package/src/runtime/story-targeting.ts +162 -0
  142. package/src/runtime/suggestions-snapshot.ts +137 -0
  143. package/src/runtime/surface-projection.ts +1553 -0
  144. package/src/runtime/table-commands.ts +173 -0
  145. package/src/runtime/table-schema.ts +309 -0
  146. package/src/runtime/table-style-resolver.ts +409 -0
  147. package/src/runtime/view-state.ts +493 -0
  148. package/src/runtime/virtualized-rendering.ts +258 -0
  149. package/src/runtime/workflow-markup.ts +393 -0
  150. package/src/ui/README.md +30 -0
  151. package/src/ui/WordReviewEditor.tsx +5268 -0
  152. package/src/ui/browser-export.ts +52 -0
  153. package/src/ui/comments/README.md +3 -0
  154. package/src/ui/compatibility/README.md +3 -0
  155. package/src/ui/editor-command-bag.ts +127 -0
  156. package/src/ui/editor-runtime-boundary.ts +1558 -0
  157. package/src/ui/editor-shell-view.tsx +144 -0
  158. package/src/ui/editor-surface/README.md +3 -0
  159. package/src/ui/editor-surface-controller.tsx +66 -0
  160. package/src/ui/headless/comment-decoration-model.ts +124 -0
  161. package/src/ui/headless/preserve-editor-selection.ts +5 -0
  162. package/src/ui/headless/revision-decoration-model.ts +128 -0
  163. package/src/ui/headless/selection-helpers.ts +54 -0
  164. package/src/ui/headless/selection-tool-context.ts +19 -0
  165. package/src/ui/headless/selection-tool-resolver.ts +752 -0
  166. package/src/ui/headless/selection-tool-types.ts +129 -0
  167. package/src/ui/headless/selection-toolbar-model.ts +11 -0
  168. package/src/ui/headless/use-editor-keyboard.ts +103 -0
  169. package/src/ui/review/README.md +3 -0
  170. package/src/ui/runtime-shortcut-dispatch.ts +365 -0
  171. package/src/ui/runtime-snapshot-selectors.ts +197 -0
  172. package/src/ui/shared/revision-filters.ts +31 -0
  173. package/src/ui/status/README.md +3 -0
  174. package/src/ui/theme/README.md +3 -0
  175. package/src/ui/toolbar/README.md +3 -0
  176. package/src/ui/workflow-surface-blocked-rails.ts +94 -0
  177. package/src/ui-tailwind/chrome/chrome-preset-model.ts +107 -0
  178. package/src/ui-tailwind/chrome/chrome-preset-toolbar.tsx +15 -0
  179. package/src/ui-tailwind/chrome/responsive-chrome.ts +46 -0
  180. package/src/ui-tailwind/chrome/review-queue-bar.tsx +97 -0
  181. package/src/ui-tailwind/chrome/tw-alert-banner.tsx +64 -0
  182. package/src/ui-tailwind/chrome/tw-context-analytics-summary.tsx +122 -0
  183. package/src/ui-tailwind/chrome/tw-image-context-toolbar.tsx +121 -0
  184. package/src/ui-tailwind/chrome/tw-layout-panel.tsx +114 -0
  185. package/src/ui-tailwind/chrome/tw-object-context-toolbar.tsx +30 -0
  186. package/src/ui-tailwind/chrome/tw-page-ruler.tsx +365 -0
  187. package/src/ui-tailwind/chrome/tw-selection-tool-blocked.tsx +23 -0
  188. package/src/ui-tailwind/chrome/tw-selection-tool-comment.tsx +35 -0
  189. package/src/ui-tailwind/chrome/tw-selection-tool-formatting.tsx +37 -0
  190. package/src/ui-tailwind/chrome/tw-selection-tool-host.tsx +303 -0
  191. package/src/ui-tailwind/chrome/tw-selection-tool-structure.tsx +116 -0
  192. package/src/ui-tailwind/chrome/tw-selection-tool-suggestion.tsx +29 -0
  193. package/src/ui-tailwind/chrome/tw-selection-tool-workflow.tsx +27 -0
  194. package/src/ui-tailwind/chrome/tw-selection-toolbar.tsx +186 -0
  195. package/src/ui-tailwind/chrome/tw-suggestion-card.tsx +139 -0
  196. package/src/ui-tailwind/chrome/tw-table-context-toolbar.tsx +250 -0
  197. package/src/ui-tailwind/chrome/tw-unsaved-modal.tsx +58 -0
  198. package/src/ui-tailwind/chrome/use-before-unload.ts +20 -0
  199. package/src/ui-tailwind/editor-surface/perf-probe.ts +179 -0
  200. package/src/ui-tailwind/editor-surface/pm-command-bridge.ts +189 -0
  201. package/src/ui-tailwind/editor-surface/pm-contextual-ui.ts +31 -0
  202. package/src/ui-tailwind/editor-surface/pm-decorations.ts +411 -0
  203. package/src/ui-tailwind/editor-surface/pm-position-map.ts +123 -0
  204. package/src/ui-tailwind/editor-surface/pm-schema.ts +927 -0
  205. package/src/ui-tailwind/editor-surface/pm-state-from-snapshot.ts +567 -0
  206. package/src/ui-tailwind/editor-surface/search-plugin.ts +168 -0
  207. package/src/ui-tailwind/editor-surface/surface-build-keys.ts +63 -0
  208. package/src/ui-tailwind/editor-surface/tw-caret.tsx +12 -0
  209. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +150 -0
  210. package/src/ui-tailwind/editor-surface/tw-inline-token.tsx +129 -0
  211. package/src/ui-tailwind/editor-surface/tw-opaque-block.tsx +58 -0
  212. package/src/ui-tailwind/editor-surface/tw-paragraph-block.tsx +151 -0
  213. package/src/ui-tailwind/editor-surface/tw-prosemirror-surface.tsx +1047 -0
  214. package/src/ui-tailwind/editor-surface/tw-segment-view.tsx +111 -0
  215. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +503 -0
  216. package/src/ui-tailwind/index.ts +62 -0
  217. package/src/ui-tailwind/page-chrome-model.ts +27 -0
  218. package/src/ui-tailwind/review/tw-comment-sidebar.tsx +406 -0
  219. package/src/ui-tailwind/review/tw-health-panel.tsx +149 -0
  220. package/src/ui-tailwind/review/tw-review-rail.tsx +130 -0
  221. package/src/ui-tailwind/review/tw-revision-sidebar.tsx +164 -0
  222. package/src/ui-tailwind/status/tw-status-bar.tsx +65 -0
  223. package/{dist → src}/ui-tailwind/theme/editor-theme.css +58 -40
  224. package/src/ui-tailwind/toolbar/toolbar-layout.ts +47 -0
  225. package/src/ui-tailwind/toolbar/tw-toolbar-icon-button.tsx +52 -0
  226. package/src/ui-tailwind/toolbar/tw-toolbar.tsx +1478 -0
  227. package/src/ui-tailwind/tw-review-workspace.tsx +1587 -0
  228. package/src/validation/README.md +3 -0
  229. package/src/validation/compatibility-engine.ts +878 -0
  230. package/src/validation/compatibility-report.ts +161 -0
  231. package/src/validation/diagnostics.ts +204 -0
  232. package/src/validation/docx-comment-proof.ts +720 -0
  233. package/src/validation/import-diagnostics.ts +128 -0
  234. package/src/validation/low-priority-word-surfaces.ts +373 -0
  235. package/dist/canonical-document-BLEbzL2J.d.cts +0 -844
  236. package/dist/canonical-document-BLEbzL2J.d.ts +0 -844
  237. package/dist/chunk-2FJS5GZM.js +0 -763
  238. package/dist/chunk-2FJS5GZM.js.map +0 -1
  239. package/dist/chunk-2OQBZS3F.js +0 -446
  240. package/dist/chunk-2OQBZS3F.js.map +0 -1
  241. package/dist/chunk-2S7W4KFO.js +0 -127
  242. package/dist/chunk-2S7W4KFO.js.map +0 -1
  243. package/dist/chunk-2TG72QSW.js +0 -3874
  244. package/dist/chunk-2TG72QSW.js.map +0 -1
  245. package/dist/chunk-36QNIZBO.js +0 -532
  246. package/dist/chunk-36QNIZBO.js.map +0 -1
  247. package/dist/chunk-4AQOYAW4.js +0 -3069
  248. package/dist/chunk-4AQOYAW4.js.map +0 -1
  249. package/dist/chunk-4D5EWJ3P.js +0 -77
  250. package/dist/chunk-4D5EWJ3P.js.map +0 -1
  251. package/dist/chunk-5FN54NDH.js +0 -2257
  252. package/dist/chunk-5FN54NDH.js.map +0 -1
  253. package/dist/chunk-BOYGQYRQ.js +0 -7306
  254. package/dist/chunk-BOYGQYRQ.js.map +0 -1
  255. package/dist/chunk-CN3XMECL.js +0 -212
  256. package/dist/chunk-CN3XMECL.js.map +0 -1
  257. package/dist/chunk-EBI3BX6U.js +0 -164
  258. package/dist/chunk-EBI3BX6U.js.map +0 -1
  259. package/dist/chunk-EILUG3VB.js +0 -1275
  260. package/dist/chunk-EILUG3VB.js.map +0 -1
  261. package/dist/chunk-FUDY333O.js +0 -70
  262. package/dist/chunk-FUDY333O.js.map +0 -1
  263. package/dist/chunk-GBVOWFIK.js +0 -1237
  264. package/dist/chunk-GBVOWFIK.js.map +0 -1
  265. package/dist/chunk-H4TQ3H3Y.js +0 -262
  266. package/dist/chunk-H4TQ3H3Y.js.map +0 -1
  267. package/dist/chunk-JGB3IXZO.js +0 -189
  268. package/dist/chunk-JGB3IXZO.js.map +0 -1
  269. package/dist/chunk-KD2QRQPY.js +0 -4342
  270. package/dist/chunk-KD2QRQPY.js.map +0 -1
  271. package/dist/chunk-KLMXQVYK.js +0 -369
  272. package/dist/chunk-KLMXQVYK.js.map +0 -1
  273. package/dist/chunk-KZUG5KFQ.js +0 -214
  274. package/dist/chunk-KZUG5KFQ.js.map +0 -1
  275. package/dist/chunk-QDAQ4CJU.js +0 -345
  276. package/dist/chunk-QDAQ4CJU.js.map +0 -1
  277. package/dist/chunk-RMH72RZI.js.map +0 -1
  278. package/dist/chunk-SWKWQZXM.js +0 -117
  279. package/dist/chunk-SWKWQZXM.js.map +0 -1
  280. package/dist/chunk-TJBP2K4T.js.map +0 -1
  281. package/dist/chunk-TLCEAQDQ.js +0 -542
  282. package/dist/chunk-TLCEAQDQ.js.map +0 -1
  283. package/dist/chunk-UZXBISGO.js.map +0 -1
  284. package/dist/chunk-WGBAKP3Q.js +0 -3220
  285. package/dist/chunk-WGBAKP3Q.js.map +0 -1
  286. package/dist/compare/index.cjs +0 -5475
  287. package/dist/compare/index.cjs.map +0 -1
  288. package/dist/compare/index.d.cts +0 -114
  289. package/dist/compare/index.d.ts +0 -114
  290. package/dist/compare/index.js +0 -731
  291. package/dist/compare/index.js.map +0 -1
  292. package/dist/core/commands/formatting-commands.cjs +0 -828
  293. package/dist/core/commands/formatting-commands.cjs.map +0 -1
  294. package/dist/core/commands/formatting-commands.d.cts +0 -63
  295. package/dist/core/commands/formatting-commands.d.ts +0 -63
  296. package/dist/core/commands/formatting-commands.js +0 -37
  297. package/dist/core/commands/formatting-commands.js.map +0 -1
  298. package/dist/core/commands/image-commands.cjs +0 -2023
  299. package/dist/core/commands/image-commands.cjs.map +0 -1
  300. package/dist/core/commands/image-commands.d.cts +0 -58
  301. package/dist/core/commands/image-commands.d.ts +0 -58
  302. package/dist/core/commands/image-commands.js +0 -18
  303. package/dist/core/commands/image-commands.js.map +0 -1
  304. package/dist/core/commands/section-layout-commands.cjs.map +0 -1
  305. package/dist/core/commands/section-layout-commands.d.cts +0 -62
  306. package/dist/core/commands/section-layout-commands.d.ts +0 -62
  307. package/dist/core/commands/section-layout-commands.js +0 -21
  308. package/dist/core/commands/section-layout-commands.js.map +0 -1
  309. package/dist/core/commands/style-commands.cjs.map +0 -1
  310. package/dist/core/commands/style-commands.d.cts +0 -13
  311. package/dist/core/commands/style-commands.d.ts +0 -13
  312. package/dist/core/commands/style-commands.js +0 -9
  313. package/dist/core/commands/style-commands.js.map +0 -1
  314. package/dist/core/commands/table-structure-commands.cjs +0 -1883
  315. package/dist/core/commands/table-structure-commands.cjs.map +0 -1
  316. package/dist/core/commands/table-structure-commands.d.cts +0 -59
  317. package/dist/core/commands/table-structure-commands.d.ts +0 -59
  318. package/dist/core/commands/table-structure-commands.js +0 -12
  319. package/dist/core/commands/table-structure-commands.js.map +0 -1
  320. package/dist/core/commands/text-commands.cjs +0 -2391
  321. package/dist/core/commands/text-commands.cjs.map +0 -1
  322. package/dist/core/commands/text-commands.d.cts +0 -24
  323. package/dist/core/commands/text-commands.d.ts +0 -24
  324. package/dist/core/commands/text-commands.js +0 -28
  325. package/dist/core/commands/text-commands.js.map +0 -1
  326. package/dist/core/selection/mapping.cjs +0 -200
  327. package/dist/core/selection/mapping.cjs.map +0 -1
  328. package/dist/core/selection/mapping.d.cts +0 -2
  329. package/dist/core/selection/mapping.d.ts +0 -2
  330. package/dist/core/selection/mapping.js +0 -31
  331. package/dist/core/selection/mapping.js.map +0 -1
  332. package/dist/core/state/editor-state.cjs +0 -2278
  333. package/dist/core/state/editor-state.cjs.map +0 -1
  334. package/dist/core/state/editor-state.d.cts +0 -2
  335. package/dist/core/state/editor-state.d.ts +0 -2
  336. package/dist/core/state/editor-state.js +0 -26
  337. package/dist/core/state/editor-state.js.map +0 -1
  338. package/dist/index.cjs +0 -38553
  339. package/dist/index.cjs.map +0 -1
  340. package/dist/index.d.cts +0 -15
  341. package/dist/index.d.ts +0 -15
  342. package/dist/index.js +0 -7856
  343. package/dist/index.js.map +0 -1
  344. package/dist/io/docx-session.cjs +0 -16236
  345. package/dist/io/docx-session.cjs.map +0 -1
  346. package/dist/io/docx-session.d.cts +0 -21
  347. package/dist/io/docx-session.d.ts +0 -21
  348. package/dist/io/docx-session.js +0 -18
  349. package/dist/io/docx-session.js.map +0 -1
  350. package/dist/legal/index.cjs +0 -3900
  351. package/dist/legal/index.cjs.map +0 -1
  352. package/dist/legal/index.d.cts +0 -86
  353. package/dist/legal/index.d.ts +0 -86
  354. package/dist/legal/index.js +0 -616
  355. package/dist/legal/index.js.map +0 -1
  356. package/dist/public-types-7ZL_94cz.d.ts +0 -1573
  357. package/dist/public-types-CeMaDueh.d.cts +0 -1573
  358. package/dist/public-types.cjs +0 -19
  359. package/dist/public-types.cjs.map +0 -1
  360. package/dist/public-types.d.cts +0 -2
  361. package/dist/public-types.d.ts +0 -2
  362. package/dist/public-types.js +0 -1
  363. package/dist/public-types.js.map +0 -1
  364. package/dist/runtime/document-runtime.cjs +0 -11140
  365. package/dist/runtime/document-runtime.cjs.map +0 -1
  366. package/dist/runtime/document-runtime.d.cts +0 -231
  367. package/dist/runtime/document-runtime.d.ts +0 -231
  368. package/dist/runtime/document-runtime.js +0 -21
  369. package/dist/runtime/document-runtime.js.map +0 -1
  370. package/dist/structural-helpers-CilgOVhh.d.cts +0 -10
  371. package/dist/structural-helpers-q0Gd-eBN.d.ts +0 -10
  372. package/dist/ui-tailwind/editor-surface/search-plugin.cjs +0 -313
  373. package/dist/ui-tailwind/editor-surface/search-plugin.cjs.map +0 -1
  374. package/dist/ui-tailwind/editor-surface/search-plugin.d.cts +0 -67
  375. package/dist/ui-tailwind/editor-surface/search-plugin.d.ts +0 -67
  376. package/dist/ui-tailwind/editor-surface/search-plugin.js +0 -23
  377. package/dist/ui-tailwind/editor-surface/search-plugin.js.map +0 -1
  378. package/dist/ui-tailwind/index.cjs +0 -4833
  379. package/dist/ui-tailwind/index.cjs.map +0 -1
  380. package/dist/ui-tailwind/index.d.cts +0 -617
  381. package/dist/ui-tailwind/index.d.ts +0 -617
  382. package/dist/ui-tailwind/index.js +0 -575
  383. package/dist/ui-tailwind/index.js.map +0 -1
@@ -0,0 +1,357 @@
1
+ import type {
2
+ EditorStoryTarget,
3
+ SearchOptions as PublicSearchOptions,
4
+ SecondaryStorySurface,
5
+ SurfaceBlockSnapshot,
6
+ WorkflowCandidateRange,
7
+ } from "../../api/public-types";
8
+
9
+ export interface SearchTextOptions extends PublicSearchOptions {
10
+ caseSensitive?: boolean;
11
+ regex?: boolean;
12
+ }
13
+
14
+ export interface SearchResult {
15
+ from: number;
16
+ to: number;
17
+ text: string;
18
+ index: number;
19
+ }
20
+
21
+ export interface SurfaceSearchResult extends SearchResult {
22
+ excerpt: string;
23
+ }
24
+
25
+ export interface SecondaryStorySearchResult extends SurfaceSearchResult {
26
+ storyTarget: EditorStoryTarget;
27
+ }
28
+
29
+ interface ProjectedSurfaceText {
30
+ text: string;
31
+ offsetMap: Array<number | null>;
32
+ }
33
+
34
+ interface SurfaceProjectionBuilder {
35
+ text: string[];
36
+ offsetMap: Array<number | null>;
37
+ nextRuntimeOffset: number;
38
+ }
39
+
40
+ export function buildSearchPattern(
41
+ query: string,
42
+ options: SearchTextOptions = {},
43
+ ): RegExp | null {
44
+ if (!query) {
45
+ return null;
46
+ }
47
+
48
+ const caseSensitive = options.matchCase ?? options.caseSensitive ?? false;
49
+ const regex = options.regex ?? false;
50
+ const wholeWord = options.wholeWord ?? false;
51
+
52
+ try {
53
+ const source = regex
54
+ ? query
55
+ : query.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
56
+ const wrapped = wholeWord ? `\\b${source}\\b` : source;
57
+ return new RegExp(wrapped, caseSensitive ? "g" : "gi");
58
+ } catch {
59
+ return null;
60
+ }
61
+ }
62
+
63
+ export function findSearchMatches(
64
+ text: string,
65
+ query: string,
66
+ options: SearchTextOptions = {},
67
+ ): SearchResult[] {
68
+ const pattern = buildSearchPattern(query, options);
69
+ if (!pattern) return [];
70
+
71
+ const results: SearchResult[] = [];
72
+ let match: RegExpExecArray | null;
73
+ pattern.lastIndex = 0;
74
+ while ((match = pattern.exec(text)) !== null) {
75
+ results.push({
76
+ from: match.index,
77
+ to: match.index + match[0].length,
78
+ text: match[0],
79
+ index: results.length,
80
+ });
81
+
82
+ if (match[0].length === 0) {
83
+ pattern.lastIndex += 1;
84
+ }
85
+ }
86
+
87
+ return results;
88
+ }
89
+
90
+ export function createSearchExcerpt(
91
+ text: string,
92
+ from: number,
93
+ to: number,
94
+ radius = 24,
95
+ ): string {
96
+ const safeFrom = Math.max(0, Math.min(from, text.length));
97
+ const safeTo = Math.max(safeFrom, Math.min(to, text.length));
98
+ const start = Math.max(0, safeFrom - radius);
99
+ const end = Math.min(text.length, safeTo + radius);
100
+ const prefix = start > 0 ? "…" : "";
101
+ const suffix = end < text.length ? "…" : "";
102
+ const excerpt = text
103
+ .slice(start, end)
104
+ .replace(/[\uFFF9\uFFFA]/gu, "")
105
+ .replace(/\s{2,}/gu, " ")
106
+ .trim();
107
+ return `${prefix}${excerpt}${suffix}`;
108
+ }
109
+
110
+ export function searchSurfaceBlocks(
111
+ blocks: readonly SurfaceBlockSnapshot[],
112
+ query: string,
113
+ options: SearchTextOptions = {},
114
+ ): SurfaceSearchResult[] {
115
+ const projection = projectSurfaceText(blocks);
116
+ return findSearchMatches(projection.text, query, options)
117
+ .map((match) => {
118
+ const range = resolveProjectedRuntimeRange(
119
+ projection.offsetMap,
120
+ match.from,
121
+ match.to,
122
+ );
123
+ if (!range) {
124
+ return null;
125
+ }
126
+
127
+ return {
128
+ ...match,
129
+ from: range.from,
130
+ to: range.to,
131
+ excerpt: createSearchExcerpt(projection.text, match.from, match.to),
132
+ };
133
+ })
134
+ .filter((match): match is SurfaceSearchResult => Boolean(match));
135
+ }
136
+
137
+ export function searchSecondaryStories(
138
+ stories: readonly SecondaryStorySurface[],
139
+ query: string,
140
+ options: SearchTextOptions = {},
141
+ ): SecondaryStorySearchResult[] {
142
+ const results: SecondaryStorySearchResult[] = [];
143
+
144
+ for (const story of stories) {
145
+ for (const match of searchSurfaceBlocks(story.blocks, query, options)) {
146
+ results.push({
147
+ storyTarget: story.target,
148
+ from: match.from,
149
+ to: match.to,
150
+ text: match.text,
151
+ index: results.length,
152
+ excerpt: match.excerpt,
153
+ });
154
+ }
155
+ }
156
+
157
+ return results;
158
+ }
159
+
160
+ /**
161
+ * Derive workflow candidate ranges from search results.
162
+ *
163
+ * Maps search hits into `WorkflowCandidateRange` values suitable for
164
+ * inclusion in a host-fed `WorkflowOverlay`. The runtime search results
165
+ * supply runtime-mapped `from`/`to` positions that align with the
166
+ * canonical document model.
167
+ */
168
+ export function deriveCandidateRangesFromSearch(
169
+ results: readonly SurfaceSearchResult[],
170
+ storyTarget?: EditorStoryTarget,
171
+ source: WorkflowCandidateRange["source"] = "search",
172
+ ): WorkflowCandidateRange[] {
173
+ return results.map((result, index) => ({
174
+ candidateId: `search-candidate-${index}`,
175
+ storyTarget,
176
+ anchor: {
177
+ kind: "range" as const,
178
+ from: result.from,
179
+ to: result.to,
180
+ assoc: { start: 1 as const, end: -1 as const },
181
+ },
182
+ label: result.excerpt,
183
+ source,
184
+ }));
185
+ }
186
+
187
+ export function projectSurfaceText(
188
+ blocks: readonly SurfaceBlockSnapshot[],
189
+ ): ProjectedSurfaceText {
190
+ const builder: SurfaceProjectionBuilder = {
191
+ text: [],
192
+ offsetMap: [],
193
+ nextRuntimeOffset: 0,
194
+ };
195
+
196
+ appendSurfaceBlocks(builder, blocks);
197
+
198
+ return {
199
+ text: builder.text.join(""),
200
+ offsetMap: builder.offsetMap,
201
+ };
202
+ }
203
+
204
+ function appendSurfaceBlocks(
205
+ builder: SurfaceProjectionBuilder,
206
+ blocks: readonly SurfaceBlockSnapshot[],
207
+ ): void {
208
+ for (const block of blocks) {
209
+ if (block.kind === "opaque_block") {
210
+ if (block.fragmentId.startsWith("preview:")) {
211
+ continue;
212
+ }
213
+ appendAtomicSpan(builder, block.from, block.to, "\uFFFA");
214
+ continue;
215
+ }
216
+
217
+ if (block.kind === "table") {
218
+ appendRuntimeGap(builder, block.from);
219
+ for (const [rowIndex, row] of block.rows.entries()) {
220
+ if (rowIndex > 0) {
221
+ appendSyntheticSeparator(builder, "\n");
222
+ }
223
+ for (const [cellIndex, cell] of row.cells.entries()) {
224
+ if (cellIndex > 0) {
225
+ appendSyntheticSeparator(builder, "\t");
226
+ }
227
+ appendSurfaceBlocks(builder, cell.content);
228
+ }
229
+ }
230
+ appendRuntimeGap(builder, block.to);
231
+ continue;
232
+ }
233
+
234
+ if (block.kind === "sdt_block") {
235
+ appendRuntimeGap(builder, block.from);
236
+ appendSurfaceBlocks(builder, block.children);
237
+ appendRuntimeGap(builder, block.to);
238
+ continue;
239
+ }
240
+
241
+ for (const segment of block.segments) {
242
+ switch (segment.kind) {
243
+ case "text":
244
+ appendTextSpan(builder, segment.text, segment.from);
245
+ break;
246
+ case "tab":
247
+ appendAtomicSpan(builder, segment.from, segment.to, "\t");
248
+ break;
249
+ case "hard_break":
250
+ appendAtomicSpan(builder, segment.from, segment.to, "\n");
251
+ break;
252
+ case "image":
253
+ appendAtomicSpan(builder, segment.from, segment.to, "\uFFFC");
254
+ break;
255
+ case "opaque_inline":
256
+ appendAtomicSpan(builder, segment.from, segment.to, "\uFFF9");
257
+ break;
258
+ case "note_ref":
259
+ appendAtomicSpan(builder, segment.from, segment.to, "\uFFFA");
260
+ break;
261
+ }
262
+ }
263
+
264
+ appendRuntimeGap(builder, block.to);
265
+ }
266
+ }
267
+
268
+ function appendTextSpan(
269
+ builder: SurfaceProjectionBuilder,
270
+ text: string,
271
+ startOffset: number,
272
+ ): void {
273
+ appendRuntimeGap(builder, startOffset);
274
+
275
+ for (let index = 0; index < text.length; index += 1) {
276
+ builder.text.push(text[index]!);
277
+ builder.offsetMap.push(startOffset + index);
278
+ }
279
+
280
+ builder.nextRuntimeOffset = Math.max(
281
+ builder.nextRuntimeOffset,
282
+ startOffset + text.length,
283
+ );
284
+ }
285
+
286
+ function appendAtomicSpan(
287
+ builder: SurfaceProjectionBuilder,
288
+ from: number,
289
+ to: number,
290
+ char: string,
291
+ ): void {
292
+ appendRuntimeGap(builder, from);
293
+ const width = Math.max(1, to - from);
294
+
295
+ for (let index = 0; index < width; index += 1) {
296
+ builder.text.push(char);
297
+ builder.offsetMap.push(from + index);
298
+ }
299
+
300
+ builder.nextRuntimeOffset = Math.max(builder.nextRuntimeOffset, to);
301
+ }
302
+
303
+ function appendRuntimeGap(
304
+ builder: SurfaceProjectionBuilder,
305
+ nextFrom: number,
306
+ ): void {
307
+ for (
308
+ let offset = builder.nextRuntimeOffset;
309
+ offset < nextFrom;
310
+ offset += 1
311
+ ) {
312
+ builder.text.push("\n");
313
+ builder.offsetMap.push(offset);
314
+ }
315
+
316
+ builder.nextRuntimeOffset = Math.max(builder.nextRuntimeOffset, nextFrom);
317
+ }
318
+
319
+ function appendSyntheticSeparator(
320
+ builder: SurfaceProjectionBuilder,
321
+ value: string,
322
+ ): void {
323
+ for (const char of value) {
324
+ builder.text.push(char);
325
+ builder.offsetMap.push(null);
326
+ }
327
+ }
328
+
329
+ function resolveProjectedRuntimeRange(
330
+ offsetMap: ReadonlyArray<number | null>,
331
+ from: number,
332
+ to: number,
333
+ ): { from: number; to: number } | null {
334
+ let runtimeFrom: number | undefined;
335
+ for (let index = from; index < to; index += 1) {
336
+ const offset = offsetMap[index];
337
+ if (offset !== null && offset !== undefined) {
338
+ runtimeFrom = offset;
339
+ break;
340
+ }
341
+ }
342
+
343
+ let runtimeTo: number | undefined;
344
+ for (let index = to - 1; index >= from; index -= 1) {
345
+ const offset = offsetMap[index];
346
+ if (offset !== null && offset !== undefined) {
347
+ runtimeTo = offset + 1;
348
+ break;
349
+ }
350
+ }
351
+
352
+ if (runtimeFrom === undefined || runtimeTo === undefined) {
353
+ return null;
354
+ }
355
+
356
+ return { from: runtimeFrom, to: runtimeTo };
357
+ }
@@ -0,0 +1,3 @@
1
+ # Core Selection
2
+
3
+ Selections, ranges, position mapping, and anchor remapping helpers belong here.
@@ -0,0 +1,289 @@
1
+ import type { EditorStoryTarget } from "../../api/public-types";
2
+
3
+ export type Position = number;
4
+ export type Assoc = -1 | 1;
5
+
6
+ export interface DocRange {
7
+ from: Position;
8
+ to: Position;
9
+ }
10
+
11
+ export interface BoundaryAssoc {
12
+ start: Assoc;
13
+ end: Assoc;
14
+ }
15
+
16
+ export interface RangeAnchor {
17
+ kind: "range";
18
+ range: DocRange;
19
+ assoc: BoundaryAssoc;
20
+ }
21
+
22
+ export interface NodeAnchor {
23
+ kind: "node";
24
+ at: Position;
25
+ assoc: Assoc;
26
+ }
27
+
28
+ export interface DetachedAnchor {
29
+ kind: "detached";
30
+ lastKnownRange: DocRange;
31
+ reason: "deleted" | "invalidatedByStructureChange" | "importAmbiguity";
32
+ }
33
+
34
+ export type EditorAnchorProjection = RangeAnchor | NodeAnchor | DetachedAnchor;
35
+
36
+ export interface MappingStep {
37
+ from: Position;
38
+ to: Position;
39
+ insertSize: number;
40
+ }
41
+
42
+ export interface MappingResult {
43
+ position: Position;
44
+ deleted: boolean;
45
+ }
46
+
47
+ export interface TransactionMapping {
48
+ steps: MappingStep[];
49
+ metadata?: {
50
+ invalidatesStructures?: boolean;
51
+ affectsComments?: boolean;
52
+ affectsRevisions?: boolean;
53
+ affectsOpaqueFragments?: boolean;
54
+ [key: string]: unknown;
55
+ };
56
+ }
57
+
58
+ export const DEFAULT_BOUNDARY_ASSOC: BoundaryAssoc = {
59
+ start: 1,
60
+ end: -1,
61
+ };
62
+
63
+ export function createRangeAnchor(
64
+ from: Position,
65
+ to = from,
66
+ assoc: BoundaryAssoc = DEFAULT_BOUNDARY_ASSOC,
67
+ ): RangeAnchor {
68
+ return {
69
+ kind: "range",
70
+ range: normalizeRange({ from, to }),
71
+ assoc,
72
+ };
73
+ }
74
+
75
+ export function createNodeAnchor(at: Position, assoc: Assoc = 1): NodeAnchor {
76
+ return {
77
+ kind: "node",
78
+ at,
79
+ assoc,
80
+ };
81
+ }
82
+
83
+ export function createDetachedAnchor(
84
+ lastKnownRange: DocRange,
85
+ reason: DetachedAnchor["reason"],
86
+ ): DetachedAnchor {
87
+ return {
88
+ kind: "detached",
89
+ lastKnownRange: normalizeRange(lastKnownRange),
90
+ reason,
91
+ };
92
+ }
93
+
94
+ export function createEmptyMapping(): TransactionMapping {
95
+ return {
96
+ steps: [],
97
+ };
98
+ }
99
+
100
+ export function normalizeRange(range: DocRange): DocRange {
101
+ return range.from <= range.to
102
+ ? { from: range.from, to: range.to }
103
+ : { from: range.to, to: range.from };
104
+ }
105
+
106
+ export function getEffectiveRange(anchor: EditorAnchorProjection): DocRange {
107
+ if (anchor.kind === "range") {
108
+ return anchor.range;
109
+ }
110
+ if (anchor.kind === "node") {
111
+ return { from: anchor.at, to: anchor.at };
112
+ }
113
+ return anchor.lastKnownRange;
114
+ }
115
+
116
+ export function mapPosition(
117
+ position: Position,
118
+ assoc: Assoc,
119
+ mapping: TransactionMapping,
120
+ ): MappingResult {
121
+ let mappedPosition = position;
122
+ let deleted = false;
123
+
124
+ for (const step of mapping.steps) {
125
+ const next = mapPositionThroughStep(mappedPosition, assoc, step);
126
+ mappedPosition = next.position;
127
+ deleted = deleted || next.deleted;
128
+ }
129
+
130
+ return {
131
+ position: mappedPosition,
132
+ deleted,
133
+ };
134
+ }
135
+
136
+ export function mapAnchor(
137
+ anchor: EditorAnchorProjection,
138
+ mapping: TransactionMapping,
139
+ ): EditorAnchorProjection {
140
+ if (anchor.kind === "detached") {
141
+ return anchor;
142
+ }
143
+
144
+ if (anchor.kind === "node") {
145
+ const mapped = mapPosition(anchor.at, anchor.assoc, mapping);
146
+
147
+ if (mapped.deleted) {
148
+ return createDetachedAnchor(
149
+ { from: anchor.at, to: anchor.at + 1 },
150
+ mapping.metadata?.invalidatesStructures
151
+ ? "invalidatedByStructureChange"
152
+ : "deleted",
153
+ );
154
+ }
155
+
156
+ return createNodeAnchor(mapped.position, anchor.assoc);
157
+ }
158
+
159
+ const from = mapPosition(anchor.range.from, anchor.assoc.start, mapping);
160
+ const to = mapPosition(anchor.range.to, anchor.assoc.end, mapping);
161
+ const mappedRange = normalizeRange({ from: from.position, to: to.position });
162
+
163
+ if (from.deleted && to.deleted && mappedRange.from === mappedRange.to) {
164
+ return createDetachedAnchor(
165
+ anchor.range,
166
+ mapping.metadata?.invalidatesStructures
167
+ ? "invalidatedByStructureChange"
168
+ : "deleted",
169
+ );
170
+ }
171
+
172
+ return createRangeAnchor(mappedRange.from, mappedRange.to, anchor.assoc);
173
+ }
174
+
175
+ export function mapRange(
176
+ range: DocRange,
177
+ assoc: BoundaryAssoc,
178
+ mapping: TransactionMapping,
179
+ ): RangeAnchor | DetachedAnchor {
180
+ const mapped = mapAnchor(createRangeAnchor(range.from, range.to, assoc), mapping);
181
+ return mapped.kind === "node" ? createRangeAnchor(mapped.at, mapped.at, assoc) : mapped;
182
+ }
183
+
184
+ export function areAnchorsEqual(
185
+ left: EditorAnchorProjection,
186
+ right: EditorAnchorProjection,
187
+ ): boolean {
188
+ if (left.kind !== right.kind) {
189
+ return false;
190
+ }
191
+
192
+ if (left.kind === "detached" && right.kind === "detached") {
193
+ return (
194
+ left.reason === right.reason &&
195
+ left.lastKnownRange.from === right.lastKnownRange.from &&
196
+ left.lastKnownRange.to === right.lastKnownRange.to
197
+ );
198
+ }
199
+
200
+ if (left.kind === "node" && right.kind === "node") {
201
+ return left.at === right.at && left.assoc === right.assoc;
202
+ }
203
+
204
+ if (left.kind === "range" && right.kind === "range") {
205
+ return (
206
+ left.range.from === right.range.from &&
207
+ left.range.to === right.range.to &&
208
+ left.assoc.start === right.assoc.start &&
209
+ left.assoc.end === right.assoc.end
210
+ );
211
+ }
212
+
213
+ return false;
214
+ }
215
+
216
+ export function storyTargetsEqual(
217
+ left: EditorStoryTarget | undefined,
218
+ right: EditorStoryTarget | undefined,
219
+ ): boolean {
220
+ if (left === right) return true;
221
+ if (!left || !right) return left === right;
222
+ if (left.kind !== right.kind) return false;
223
+ if (left.kind === "main") return true;
224
+ if (left.kind === "header" && right.kind === "header") {
225
+ return (
226
+ left.relationshipId === right.relationshipId &&
227
+ left.variant === right.variant &&
228
+ (left.sectionIndex === undefined ||
229
+ right.sectionIndex === undefined
230
+ ? true
231
+ : left.sectionIndex === right.sectionIndex)
232
+ );
233
+ }
234
+ if (left.kind === "footer" && right.kind === "footer") {
235
+ return (
236
+ left.relationshipId === right.relationshipId &&
237
+ left.variant === right.variant &&
238
+ (left.sectionIndex === undefined ||
239
+ right.sectionIndex === undefined
240
+ ? true
241
+ : left.sectionIndex === right.sectionIndex)
242
+ );
243
+ }
244
+ if (left.kind === "footnote" && right.kind === "footnote") {
245
+ return left.noteId === right.noteId;
246
+ }
247
+ if (left.kind === "endnote" && right.kind === "endnote") {
248
+ return left.noteId === right.noteId;
249
+ }
250
+ return false;
251
+ }
252
+
253
+ export const MAIN_STORY_TARGET: EditorStoryTarget = { kind: "main" };
254
+
255
+ function mapPositionThroughStep(
256
+ position: Position,
257
+ assoc: Assoc,
258
+ step: MappingStep,
259
+ ): MappingResult {
260
+ if (position < step.from) {
261
+ return { position, deleted: false };
262
+ }
263
+
264
+ if (position > step.to) {
265
+ return {
266
+ position: position + step.insertSize - (step.to - step.from),
267
+ deleted: false,
268
+ };
269
+ }
270
+
271
+ if (position === step.from) {
272
+ return {
273
+ position: assoc < 0 ? step.from : step.from + step.insertSize,
274
+ deleted: false,
275
+ };
276
+ }
277
+
278
+ if (position === step.to) {
279
+ return {
280
+ position: assoc < 0 ? step.from : step.from + step.insertSize,
281
+ deleted: false,
282
+ };
283
+ }
284
+
285
+ return {
286
+ position: assoc < 0 ? step.from : step.from + step.insertSize,
287
+ deleted: true,
288
+ };
289
+ }