@beyondwork/docx-react-component 1.0.29 → 1.0.30

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 (381) 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/review-queue-bar.tsx +97 -0
  180. package/src/ui-tailwind/chrome/tw-alert-banner.tsx +64 -0
  181. package/src/ui-tailwind/chrome/tw-context-analytics-summary.tsx +122 -0
  182. package/src/ui-tailwind/chrome/tw-image-context-toolbar.tsx +121 -0
  183. package/src/ui-tailwind/chrome/tw-layout-panel.tsx +114 -0
  184. package/src/ui-tailwind/chrome/tw-object-context-toolbar.tsx +30 -0
  185. package/src/ui-tailwind/chrome/tw-page-ruler.tsx +365 -0
  186. package/src/ui-tailwind/chrome/tw-selection-tool-blocked.tsx +23 -0
  187. package/src/ui-tailwind/chrome/tw-selection-tool-comment.tsx +35 -0
  188. package/src/ui-tailwind/chrome/tw-selection-tool-formatting.tsx +37 -0
  189. package/src/ui-tailwind/chrome/tw-selection-tool-host.tsx +298 -0
  190. package/src/ui-tailwind/chrome/tw-selection-tool-structure.tsx +116 -0
  191. package/src/ui-tailwind/chrome/tw-selection-tool-suggestion.tsx +29 -0
  192. package/src/ui-tailwind/chrome/tw-selection-tool-workflow.tsx +27 -0
  193. package/src/ui-tailwind/chrome/tw-selection-toolbar.tsx +186 -0
  194. package/src/ui-tailwind/chrome/tw-suggestion-card.tsx +139 -0
  195. package/src/ui-tailwind/chrome/tw-table-context-toolbar.tsx +200 -0
  196. package/src/ui-tailwind/chrome/tw-unsaved-modal.tsx +58 -0
  197. package/src/ui-tailwind/chrome/use-before-unload.ts +20 -0
  198. package/src/ui-tailwind/editor-surface/perf-probe.ts +179 -0
  199. package/src/ui-tailwind/editor-surface/pm-command-bridge.ts +189 -0
  200. package/src/ui-tailwind/editor-surface/pm-contextual-ui.ts +31 -0
  201. package/src/ui-tailwind/editor-surface/pm-decorations.ts +411 -0
  202. package/src/ui-tailwind/editor-surface/pm-position-map.ts +123 -0
  203. package/src/ui-tailwind/editor-surface/pm-schema.ts +927 -0
  204. package/src/ui-tailwind/editor-surface/pm-state-from-snapshot.ts +567 -0
  205. package/src/ui-tailwind/editor-surface/search-plugin.ts +168 -0
  206. package/src/ui-tailwind/editor-surface/surface-build-keys.ts +65 -0
  207. package/src/ui-tailwind/editor-surface/tw-caret.tsx +12 -0
  208. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +150 -0
  209. package/src/ui-tailwind/editor-surface/tw-inline-token.tsx +129 -0
  210. package/src/ui-tailwind/editor-surface/tw-opaque-block.tsx +58 -0
  211. package/src/ui-tailwind/editor-surface/tw-paragraph-block.tsx +151 -0
  212. package/src/ui-tailwind/editor-surface/tw-prosemirror-surface.tsx +1047 -0
  213. package/src/ui-tailwind/editor-surface/tw-segment-view.tsx +111 -0
  214. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +503 -0
  215. package/src/ui-tailwind/index.ts +62 -0
  216. package/src/ui-tailwind/page-chrome-model.ts +27 -0
  217. package/src/ui-tailwind/review/tw-comment-sidebar.tsx +406 -0
  218. package/src/ui-tailwind/review/tw-health-panel.tsx +149 -0
  219. package/src/ui-tailwind/review/tw-review-rail.tsx +122 -0
  220. package/src/ui-tailwind/review/tw-revision-sidebar.tsx +164 -0
  221. package/src/ui-tailwind/status/tw-status-bar.tsx +65 -0
  222. package/{dist → src}/ui-tailwind/theme/editor-theme.css +58 -40
  223. package/src/ui-tailwind/toolbar/tw-toolbar-icon-button.tsx +52 -0
  224. package/src/ui-tailwind/toolbar/tw-toolbar.tsx +1133 -0
  225. package/src/ui-tailwind/tw-review-workspace.tsx +1460 -0
  226. package/src/validation/README.md +3 -0
  227. package/src/validation/compatibility-engine.ts +878 -0
  228. package/src/validation/compatibility-report.ts +161 -0
  229. package/src/validation/diagnostics.ts +204 -0
  230. package/src/validation/docx-comment-proof.ts +720 -0
  231. package/src/validation/import-diagnostics.ts +128 -0
  232. package/src/validation/low-priority-word-surfaces.ts +373 -0
  233. package/dist/canonical-document-BLEbzL2J.d.cts +0 -844
  234. package/dist/canonical-document-BLEbzL2J.d.ts +0 -844
  235. package/dist/chunk-2FJS5GZM.js +0 -763
  236. package/dist/chunk-2FJS5GZM.js.map +0 -1
  237. package/dist/chunk-2OQBZS3F.js +0 -446
  238. package/dist/chunk-2OQBZS3F.js.map +0 -1
  239. package/dist/chunk-2S7W4KFO.js +0 -127
  240. package/dist/chunk-2S7W4KFO.js.map +0 -1
  241. package/dist/chunk-2TG72QSW.js +0 -3874
  242. package/dist/chunk-2TG72QSW.js.map +0 -1
  243. package/dist/chunk-36QNIZBO.js +0 -532
  244. package/dist/chunk-36QNIZBO.js.map +0 -1
  245. package/dist/chunk-4AQOYAW4.js +0 -3069
  246. package/dist/chunk-4AQOYAW4.js.map +0 -1
  247. package/dist/chunk-4D5EWJ3P.js +0 -77
  248. package/dist/chunk-4D5EWJ3P.js.map +0 -1
  249. package/dist/chunk-5FN54NDH.js +0 -2257
  250. package/dist/chunk-5FN54NDH.js.map +0 -1
  251. package/dist/chunk-BOYGQYRQ.js +0 -7306
  252. package/dist/chunk-BOYGQYRQ.js.map +0 -1
  253. package/dist/chunk-CN3XMECL.js +0 -212
  254. package/dist/chunk-CN3XMECL.js.map +0 -1
  255. package/dist/chunk-EBI3BX6U.js +0 -164
  256. package/dist/chunk-EBI3BX6U.js.map +0 -1
  257. package/dist/chunk-EILUG3VB.js +0 -1275
  258. package/dist/chunk-EILUG3VB.js.map +0 -1
  259. package/dist/chunk-FUDY333O.js +0 -70
  260. package/dist/chunk-FUDY333O.js.map +0 -1
  261. package/dist/chunk-GBVOWFIK.js +0 -1237
  262. package/dist/chunk-GBVOWFIK.js.map +0 -1
  263. package/dist/chunk-H4TQ3H3Y.js +0 -262
  264. package/dist/chunk-H4TQ3H3Y.js.map +0 -1
  265. package/dist/chunk-JGB3IXZO.js +0 -189
  266. package/dist/chunk-JGB3IXZO.js.map +0 -1
  267. package/dist/chunk-KD2QRQPY.js +0 -4342
  268. package/dist/chunk-KD2QRQPY.js.map +0 -1
  269. package/dist/chunk-KLMXQVYK.js +0 -369
  270. package/dist/chunk-KLMXQVYK.js.map +0 -1
  271. package/dist/chunk-KZUG5KFQ.js +0 -214
  272. package/dist/chunk-KZUG5KFQ.js.map +0 -1
  273. package/dist/chunk-QDAQ4CJU.js +0 -345
  274. package/dist/chunk-QDAQ4CJU.js.map +0 -1
  275. package/dist/chunk-RMH72RZI.js.map +0 -1
  276. package/dist/chunk-SWKWQZXM.js +0 -117
  277. package/dist/chunk-SWKWQZXM.js.map +0 -1
  278. package/dist/chunk-TJBP2K4T.js.map +0 -1
  279. package/dist/chunk-TLCEAQDQ.js +0 -542
  280. package/dist/chunk-TLCEAQDQ.js.map +0 -1
  281. package/dist/chunk-UZXBISGO.js.map +0 -1
  282. package/dist/chunk-WGBAKP3Q.js +0 -3220
  283. package/dist/chunk-WGBAKP3Q.js.map +0 -1
  284. package/dist/compare/index.cjs +0 -5475
  285. package/dist/compare/index.cjs.map +0 -1
  286. package/dist/compare/index.d.cts +0 -114
  287. package/dist/compare/index.d.ts +0 -114
  288. package/dist/compare/index.js +0 -731
  289. package/dist/compare/index.js.map +0 -1
  290. package/dist/core/commands/formatting-commands.cjs +0 -828
  291. package/dist/core/commands/formatting-commands.cjs.map +0 -1
  292. package/dist/core/commands/formatting-commands.d.cts +0 -63
  293. package/dist/core/commands/formatting-commands.d.ts +0 -63
  294. package/dist/core/commands/formatting-commands.js +0 -37
  295. package/dist/core/commands/formatting-commands.js.map +0 -1
  296. package/dist/core/commands/image-commands.cjs +0 -2023
  297. package/dist/core/commands/image-commands.cjs.map +0 -1
  298. package/dist/core/commands/image-commands.d.cts +0 -58
  299. package/dist/core/commands/image-commands.d.ts +0 -58
  300. package/dist/core/commands/image-commands.js +0 -18
  301. package/dist/core/commands/image-commands.js.map +0 -1
  302. package/dist/core/commands/section-layout-commands.cjs.map +0 -1
  303. package/dist/core/commands/section-layout-commands.d.cts +0 -62
  304. package/dist/core/commands/section-layout-commands.d.ts +0 -62
  305. package/dist/core/commands/section-layout-commands.js +0 -21
  306. package/dist/core/commands/section-layout-commands.js.map +0 -1
  307. package/dist/core/commands/style-commands.cjs.map +0 -1
  308. package/dist/core/commands/style-commands.d.cts +0 -13
  309. package/dist/core/commands/style-commands.d.ts +0 -13
  310. package/dist/core/commands/style-commands.js +0 -9
  311. package/dist/core/commands/style-commands.js.map +0 -1
  312. package/dist/core/commands/table-structure-commands.cjs +0 -1883
  313. package/dist/core/commands/table-structure-commands.cjs.map +0 -1
  314. package/dist/core/commands/table-structure-commands.d.cts +0 -59
  315. package/dist/core/commands/table-structure-commands.d.ts +0 -59
  316. package/dist/core/commands/table-structure-commands.js +0 -12
  317. package/dist/core/commands/table-structure-commands.js.map +0 -1
  318. package/dist/core/commands/text-commands.cjs +0 -2391
  319. package/dist/core/commands/text-commands.cjs.map +0 -1
  320. package/dist/core/commands/text-commands.d.cts +0 -24
  321. package/dist/core/commands/text-commands.d.ts +0 -24
  322. package/dist/core/commands/text-commands.js +0 -28
  323. package/dist/core/commands/text-commands.js.map +0 -1
  324. package/dist/core/selection/mapping.cjs +0 -200
  325. package/dist/core/selection/mapping.cjs.map +0 -1
  326. package/dist/core/selection/mapping.d.cts +0 -2
  327. package/dist/core/selection/mapping.d.ts +0 -2
  328. package/dist/core/selection/mapping.js +0 -31
  329. package/dist/core/selection/mapping.js.map +0 -1
  330. package/dist/core/state/editor-state.cjs +0 -2278
  331. package/dist/core/state/editor-state.cjs.map +0 -1
  332. package/dist/core/state/editor-state.d.cts +0 -2
  333. package/dist/core/state/editor-state.d.ts +0 -2
  334. package/dist/core/state/editor-state.js +0 -26
  335. package/dist/core/state/editor-state.js.map +0 -1
  336. package/dist/index.cjs +0 -38553
  337. package/dist/index.cjs.map +0 -1
  338. package/dist/index.d.cts +0 -15
  339. package/dist/index.d.ts +0 -15
  340. package/dist/index.js +0 -7856
  341. package/dist/index.js.map +0 -1
  342. package/dist/io/docx-session.cjs +0 -16236
  343. package/dist/io/docx-session.cjs.map +0 -1
  344. package/dist/io/docx-session.d.cts +0 -21
  345. package/dist/io/docx-session.d.ts +0 -21
  346. package/dist/io/docx-session.js +0 -18
  347. package/dist/io/docx-session.js.map +0 -1
  348. package/dist/legal/index.cjs +0 -3900
  349. package/dist/legal/index.cjs.map +0 -1
  350. package/dist/legal/index.d.cts +0 -86
  351. package/dist/legal/index.d.ts +0 -86
  352. package/dist/legal/index.js +0 -616
  353. package/dist/legal/index.js.map +0 -1
  354. package/dist/public-types-7ZL_94cz.d.ts +0 -1573
  355. package/dist/public-types-CeMaDueh.d.cts +0 -1573
  356. package/dist/public-types.cjs +0 -19
  357. package/dist/public-types.cjs.map +0 -1
  358. package/dist/public-types.d.cts +0 -2
  359. package/dist/public-types.d.ts +0 -2
  360. package/dist/public-types.js +0 -1
  361. package/dist/public-types.js.map +0 -1
  362. package/dist/runtime/document-runtime.cjs +0 -11140
  363. package/dist/runtime/document-runtime.cjs.map +0 -1
  364. package/dist/runtime/document-runtime.d.cts +0 -231
  365. package/dist/runtime/document-runtime.d.ts +0 -231
  366. package/dist/runtime/document-runtime.js +0 -21
  367. package/dist/runtime/document-runtime.js.map +0 -1
  368. package/dist/structural-helpers-CilgOVhh.d.cts +0 -10
  369. package/dist/structural-helpers-q0Gd-eBN.d.ts +0 -10
  370. package/dist/ui-tailwind/editor-surface/search-plugin.cjs +0 -313
  371. package/dist/ui-tailwind/editor-surface/search-plugin.cjs.map +0 -1
  372. package/dist/ui-tailwind/editor-surface/search-plugin.d.cts +0 -67
  373. package/dist/ui-tailwind/editor-surface/search-plugin.d.ts +0 -67
  374. package/dist/ui-tailwind/editor-surface/search-plugin.js +0 -23
  375. package/dist/ui-tailwind/editor-surface/search-plugin.js.map +0 -1
  376. package/dist/ui-tailwind/index.cjs +0 -4833
  377. package/dist/ui-tailwind/index.cjs.map +0 -1
  378. package/dist/ui-tailwind/index.d.cts +0 -617
  379. package/dist/ui-tailwind/index.d.ts +0 -617
  380. package/dist/ui-tailwind/index.js +0 -575
  381. package/dist/ui-tailwind/index.js.map +0 -1
@@ -1,616 +0,0 @@
1
- import {
2
- parseMainDocumentXml
3
- } from "../chunk-4AQOYAW4.js";
4
- import "../chunk-FUDY333O.js";
5
- import {
6
- assessBookmarkIntegrity,
7
- collectBookmarksFromCanonicalDocument,
8
- isHiddenBookmarkName,
9
- parseBookmarksFromDocumentXml
10
- } from "../chunk-RMH72RZI.js";
11
- import {
12
- extractComplexFieldsFromBodyXml,
13
- parseFieldsFromParagraphXml
14
- } from "../chunk-TLCEAQDQ.js";
15
-
16
- // src/legal/cross-references.ts
17
- var CROSS_REFERENCE_PATTERN = /\b(Section|Clause|Article|Schedule|Exhibit|Appendix)\s+(\d+(?:\.\d+)*|[A-Z]-\d+|[A-Z])(?=[^A-Za-z0-9]|$)/g;
18
- var W_REF_PATTERN = /<w:ref\b([^>]*)\/?>/g;
19
- var ATTRIBUTE_PATTERN = /(?:^|\s)(?:w:)?([A-Za-z][\w-]*)="([^"]*)"/g;
20
- var COMPLEX_FIELD_PATTERN = /<w:instrText\b[^>]*>([\s\S]*?)<\/w:instrText>[\s\S]*?<w:fldChar\b[^>]*w:fldCharType="separate"[^>]*\/>[\s\S]*?<w:t\b[^>]*>([\s\S]*?)<\/w:t>[\s\S]*?<w:fldChar\b[^>]*w:fldCharType="end"[^>]*\/>/g;
21
- function parseCrossReferencesFromDocumentXml(xml) {
22
- const parsed = parseMainDocumentXml(xml);
23
- const results = [];
24
- parsed.blocks.forEach((block, paragraphIndex) => {
25
- if (block.type !== "paragraph") {
26
- return;
27
- }
28
- for (const child of block.children) {
29
- if (child.type === "hyperlink" && child.href.startsWith("#")) {
30
- results.push({
31
- source: "hyperlink",
32
- kind: "bookmark",
33
- target: child.href.slice(1),
34
- label: flattenInlineText(child.children).trim() || child.href.slice(1),
35
- paragraphIndex,
36
- confidence: "high"
37
- });
38
- }
39
- }
40
- const { simpleFields } = parseFieldsFromParagraphXml(block.rawXml);
41
- for (const field of simpleFields) {
42
- const reference = parseFieldReferenceInstruction(field.instruction);
43
- if (!reference) {
44
- continue;
45
- }
46
- results.push({
47
- source: "field",
48
- kind: "bookmark",
49
- target: reference.target,
50
- instruction: reference.instruction,
51
- label: stripXml(field.contentXml) || reference.target,
52
- paragraphIndex,
53
- confidence: "high"
54
- });
55
- }
56
- for (const pattern of detectCrossReferencePatterns(flattenParagraphText(block))) {
57
- results.push({
58
- source: "text-pattern",
59
- kind: pattern.kind,
60
- target: pattern.targetHint,
61
- label: pattern.label,
62
- paragraphIndex,
63
- confidence: "medium"
64
- });
65
- }
66
- });
67
- for (const field of extractComplexFieldsFromBodyXml(xml)) {
68
- const reference = parseFieldReferenceInstruction(field.instruction);
69
- if (!reference) {
70
- continue;
71
- }
72
- results.push({
73
- source: "field",
74
- kind: "bookmark",
75
- target: reference.target,
76
- instruction: reference.instruction,
77
- label: stripXml(field.contentXml) || reference.target,
78
- confidence: "high"
79
- });
80
- }
81
- for (const field of extractComplexFieldsWithRegex(xml)) {
82
- const reference = parseFieldReferenceInstruction(field.instruction);
83
- if (!reference) {
84
- continue;
85
- }
86
- results.push({
87
- source: "field",
88
- kind: "bookmark",
89
- target: reference.target,
90
- instruction: reference.instruction,
91
- label: field.label || reference.target,
92
- confidence: "high"
93
- });
94
- }
95
- for (const element of extractWRefElements(xml)) {
96
- results.push({
97
- source: "w:ref",
98
- kind: "bookmark",
99
- target: element.target,
100
- label: element.label || element.target || "w:ref",
101
- confidence: element.target ? "high" : "medium"
102
- });
103
- }
104
- return dedupeCrossReferences(results);
105
- }
106
- function collectCrossReferencesFromCanonicalDocument(document) {
107
- const root = "content" in document ? document.content : document;
108
- const results = [];
109
- let paragraphIndex = -1;
110
- walkDocument(root, (node) => {
111
- if (node.type === "paragraph") {
112
- paragraphIndex += 1;
113
- for (const child of node.children) {
114
- if (child.type === "hyperlink" && child.href.startsWith("#")) {
115
- results.push({
116
- source: "hyperlink",
117
- kind: "bookmark",
118
- target: child.href.slice(1),
119
- label: flattenInlineText(child.children).trim() || child.href.slice(1),
120
- paragraphIndex,
121
- confidence: "high"
122
- });
123
- continue;
124
- }
125
- if (child.type === "field") {
126
- const reference = parseFieldReferenceInstruction(child.instruction);
127
- if (!reference) {
128
- continue;
129
- }
130
- results.push({
131
- source: "field",
132
- kind: "bookmark",
133
- target: reference.target,
134
- instruction: reference.instruction,
135
- label: flattenInlineText(child.children).trim() || reference.target,
136
- paragraphIndex,
137
- confidence: "high"
138
- });
139
- }
140
- }
141
- for (const pattern of detectCrossReferencePatterns(flattenParagraphText(node))) {
142
- results.push({
143
- source: "text-pattern",
144
- kind: pattern.kind,
145
- target: pattern.targetHint,
146
- label: pattern.label,
147
- paragraphIndex,
148
- confidence: "medium"
149
- });
150
- }
151
- }
152
- });
153
- return dedupeCrossReferences(results);
154
- }
155
- function detectCrossReferencePatterns(text) {
156
- const matches = [];
157
- for (const match of text.matchAll(CROSS_REFERENCE_PATTERN)) {
158
- const referenceType = match[1]?.toLowerCase();
159
- const target = match[2];
160
- const label = `${match[1]} ${target}`.trim();
161
- if (!referenceType || !target) {
162
- continue;
163
- }
164
- matches.push({
165
- kind: referenceType,
166
- label,
167
- targetHint: target
168
- });
169
- }
170
- return matches;
171
- }
172
- function parseFieldReferenceInstruction(instruction) {
173
- const trimmedInstruction = instruction.trim().replace(/\s+/g, " ");
174
- const match = /^(REF|PAGEREF|NOTEREF)\s+(?:"([^"]+)"|([^\s\\]+))/i.exec(trimmedInstruction);
175
- if (!match) {
176
- return void 0;
177
- }
178
- return {
179
- kind: match[1].toUpperCase(),
180
- target: (match[2] ?? match[3] ?? "").trim(),
181
- instruction: trimmedInstruction
182
- };
183
- }
184
- function extractWRefElements(xml) {
185
- const matches = [];
186
- for (const match of xml.matchAll(W_REF_PATTERN)) {
187
- const attributes = readAttributes(match[1] ?? "");
188
- matches.push({
189
- target: attributes.anchor ?? attributes.name ?? attributes.id,
190
- label: attributes.displayText ?? attributes.text
191
- });
192
- }
193
- return matches;
194
- }
195
- function extractComplexFieldsWithRegex(xml) {
196
- const matches = [];
197
- for (const match of xml.matchAll(COMPLEX_FIELD_PATTERN)) {
198
- const instruction = stripXml(match[1] ?? "");
199
- const label = stripXml(match[2] ?? "");
200
- if (!instruction) {
201
- continue;
202
- }
203
- matches.push({ instruction, label });
204
- }
205
- return matches;
206
- }
207
- function readAttributes(source) {
208
- const attributes = {};
209
- for (const match of source.matchAll(ATTRIBUTE_PATTERN)) {
210
- const [, key, value] = match;
211
- attributes[key] = value;
212
- }
213
- return attributes;
214
- }
215
- function stripXml(xml) {
216
- return xml.replace(/<[^>]+>/g, "").replace(/\s+/g, " ").trim();
217
- }
218
- function flattenParagraphText(paragraph) {
219
- return paragraph.children.map((child) => {
220
- switch (child.type) {
221
- case "text":
222
- return child.text;
223
- case "hyperlink":
224
- return flattenInlineText(child.children);
225
- case "field":
226
- return child.children ? flattenInlineText(child.children) : "";
227
- case "tab":
228
- return " ";
229
- case "hard_break":
230
- case "column_break":
231
- return "\n";
232
- default:
233
- return "";
234
- }
235
- }).join("");
236
- }
237
- function flattenInlineText(children) {
238
- return children.map((child) => {
239
- if (child.type === "text") {
240
- return child.text;
241
- }
242
- if (child.type === "tab") {
243
- return " ";
244
- }
245
- if (child.type === "hard_break" || child.type === "column_break") {
246
- return "\n";
247
- }
248
- return "";
249
- }).join("");
250
- }
251
- function dedupeCrossReferences(references) {
252
- const seen = /* @__PURE__ */ new Set();
253
- const deduped = [];
254
- for (const reference of references) {
255
- const key = [
256
- reference.source,
257
- reference.kind,
258
- reference.target ?? "",
259
- reference.label,
260
- String(reference.paragraphIndex ?? -1)
261
- ].join("|");
262
- if (seen.has(key)) {
263
- continue;
264
- }
265
- seen.add(key);
266
- deduped.push(reference);
267
- }
268
- return deduped;
269
- }
270
- function walkDocument(node, visit) {
271
- visit(node);
272
- if ("children" in node && Array.isArray(node.children)) {
273
- for (const child of node.children) {
274
- walkDocument(child, visit);
275
- }
276
- }
277
- if (node.type === "table") {
278
- for (const row of node.rows) {
279
- walkDocument(row, visit);
280
- }
281
- } else if (node.type === "table_row") {
282
- for (const cell of node.cells) {
283
- walkDocument(cell, visit);
284
- }
285
- }
286
- }
287
-
288
- // src/legal/defined-terms.ts
289
- var QUOTED_DEFINITION_PATTERN = /["“]([A-Z][A-Za-z0-9]*(?:[ -][A-Z][A-Za-z0-9]*){0,5})["”]\s+(?:means|has the meaning(?: set forth)?|shall mean|refers to)\b/g;
290
- var BARE_DEFINITION_PATTERN = /\b([A-Z][A-Za-z0-9]*(?:\s+[A-Z][A-Za-z0-9]*){0,5})\s+(?:means|has the meaning(?: set forth)?|shall mean|refers to)\b/g;
291
- var BLOCKED_BARE_TERMS = /* @__PURE__ */ new Set([
292
- "This Agreement",
293
- "Such Term",
294
- "The Company",
295
- "This Section",
296
- "This Clause"
297
- ]);
298
- function collectDefinedTermsFromDocumentXml(xml) {
299
- const parsed = parseMainDocumentXml(xml);
300
- const paragraphs = parsed.blocks.filter((block) => block.type === "paragraph").map((block) => flattenParagraphText2(block));
301
- return buildDefinedTermCatalog(paragraphs);
302
- }
303
- function collectDefinedTermsFromCanonicalDocument(document) {
304
- const root = "content" in document ? document.content : document;
305
- const paragraphs = [];
306
- walkDocument2(root, (node) => {
307
- if (node.type === "paragraph") {
308
- paragraphs.push(flattenParagraphText2(node));
309
- }
310
- });
311
- return buildDefinedTermCatalog(paragraphs);
312
- }
313
- function buildDefinedTermCatalog(paragraphs) {
314
- const terms = /* @__PURE__ */ new Map();
315
- paragraphs.forEach((paragraph, paragraphIndex) => {
316
- for (const candidate of extractDefinitionCandidates(paragraph)) {
317
- const normalized = normalizeTerm(candidate.term);
318
- const existing = terms.get(normalized) ?? {
319
- term: candidate.term,
320
- normalizedTerm: normalized,
321
- definitionStyle: candidate.definitionStyle,
322
- definitions: [],
323
- references: []
324
- };
325
- if (!terms.has(normalized)) {
326
- terms.set(normalized, existing);
327
- }
328
- existing.definitions.push({
329
- paragraphIndex,
330
- label: candidate.term,
331
- kind: "definition"
332
- });
333
- }
334
- });
335
- paragraphs.forEach((paragraph, paragraphIndex) => {
336
- for (const term of terms.values()) {
337
- const references = findTermReferences(paragraph, term.term);
338
- if (references === 0) {
339
- continue;
340
- }
341
- const hasDefinitionInParagraph = term.definitions.some(
342
- (definition) => definition.paragraphIndex === paragraphIndex
343
- );
344
- const referenceCount = hasDefinitionInParagraph ? 0 : references;
345
- for (let count = 0; count < referenceCount; count += 1) {
346
- term.references.push({
347
- paragraphIndex,
348
- label: term.term,
349
- kind: "reference"
350
- });
351
- }
352
- }
353
- });
354
- return Array.from(terms.values()).sort((left, right) => left.term.localeCompare(right.term));
355
- }
356
- function extractDefinitionCandidates(paragraph) {
357
- const candidates = [];
358
- for (const match of paragraph.matchAll(QUOTED_DEFINITION_PATTERN)) {
359
- const term = match[1]?.trim();
360
- if (!term) {
361
- continue;
362
- }
363
- candidates.push({
364
- term,
365
- definitionStyle: "quoted"
366
- });
367
- }
368
- for (const match of paragraph.matchAll(BARE_DEFINITION_PATTERN)) {
369
- const term = match[1]?.trim();
370
- if (!term || BLOCKED_BARE_TERMS.has(term) || isQuotedTerm(term, paragraph)) {
371
- continue;
372
- }
373
- candidates.push({
374
- term,
375
- definitionStyle: "bare"
376
- });
377
- }
378
- return candidates;
379
- }
380
- function normalizeTerm(term) {
381
- return term.trim().replace(/\s+/g, " ").toLowerCase();
382
- }
383
- function isQuotedTerm(term, paragraph) {
384
- return paragraph.includes(`"${term}"`) || paragraph.includes(`\u201C${term}\u201D`);
385
- }
386
- function findTermReferences(paragraph, term) {
387
- const escapedTerm = escapeRegExp(term);
388
- const pattern = new RegExp(`(?:^|[^A-Za-z0-9])(?:"|\u201C)?(${escapedTerm})(?:"|\u201D)?(?=[^A-Za-z0-9]|$)`, "g");
389
- return Array.from(paragraph.matchAll(pattern)).length;
390
- }
391
- function escapeRegExp(value) {
392
- return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
393
- }
394
- function flattenParagraphText2(paragraph) {
395
- return paragraph.children.map((child) => {
396
- switch (child.type) {
397
- case "text":
398
- return child.text;
399
- case "hyperlink":
400
- case "field":
401
- return child.children.map((nested) => nested.type === "text" ? nested.text : nested.type === "tab" ? " " : "").join("");
402
- case "tab":
403
- return " ";
404
- case "hard_break":
405
- case "column_break":
406
- return "\n";
407
- default:
408
- return "";
409
- }
410
- }).join("");
411
- }
412
- function walkDocument2(node, visit) {
413
- visit(node);
414
- if ("children" in node && Array.isArray(node.children)) {
415
- for (const child of node.children) {
416
- walkDocument2(child, visit);
417
- }
418
- }
419
- if (node.type === "table") {
420
- for (const row of node.rows) {
421
- walkDocument2(row, visit);
422
- }
423
- } else if (node.type === "table_row") {
424
- for (const cell of node.cells) {
425
- walkDocument2(cell, visit);
426
- }
427
- }
428
- }
429
-
430
- // src/legal/signature-blocks.ts
431
- var EXECUTION_TRIGGER_PATTERN = /\b(?:IN WITNESS WHEREOF|EXECUTED|AGREED AND ACCEPTED|SIGNATURES FOLLOW)\b/i;
432
- var ROLE_LINE_PATTERN = /^\s*(?:By|Name|Title|Date|Witness|Authorized Signatory|Signature)\s*[:\-]?\s*/i;
433
- var PARTY_LABEL_PATTERN = /^(?:(?:The |)[A-Z][A-Za-z0-9 ,.'&()-]{2,60})\s*$/;
434
- var WITNESS_PATTERN = /\bWITNESS(?:ED|ES)?\b/i;
435
- var NOTARY_PATTERN = /\bNOTARY\s+PUBLIC\b/i;
436
- var UNDERLINE_PLACEHOLDER_PATTERN = /_{4,}|\.{4,}/;
437
- function detectSignatureBlocksFromCanonicalDocument(document) {
438
- const root = "content" in document ? document.content : document;
439
- const paragraphs = [];
440
- const warnings = [];
441
- walkBlocks(root, (node) => {
442
- if (node.type === "paragraph") {
443
- paragraphs.push({ text: flattenParagraphText3(node), node });
444
- }
445
- });
446
- const candidates = findSignatureBlockCandidates(paragraphs);
447
- const hasPreservation = "preservation" in document && document.preservation !== void 0;
448
- const preservationSafe = hasPreservation ? !hasOpaqueFragmentsInSignatureRanges(
449
- document,
450
- candidates
451
- ) : true;
452
- if (!preservationSafe) {
453
- warnings.push(
454
- "One or more signature block regions overlap with preserve-only opaque fragments. Export fidelity may be degraded."
455
- );
456
- }
457
- return {
458
- reportVersion: "signature-block-report/1",
459
- candidates,
460
- preservationSafe,
461
- warnings
462
- };
463
- }
464
- function findSignatureBlockCandidates(paragraphs) {
465
- const candidates = [];
466
- let index = 0;
467
- while (index < paragraphs.length) {
468
- const text = paragraphs[index].text;
469
- if (EXECUTION_TRIGGER_PATTERN.test(text)) {
470
- const block = scanSignatureBlock(paragraphs, index);
471
- if (block) {
472
- candidates.push(block);
473
- index = block.endIndex + 1;
474
- continue;
475
- }
476
- }
477
- index += 1;
478
- }
479
- return candidates;
480
- }
481
- function scanSignatureBlock(paragraphs, triggerIndex) {
482
- const parties = [];
483
- let endIndex = triggerIndex;
484
- let kind = "execution-block";
485
- let hasSignatureContent = false;
486
- for (let index = triggerIndex + 1; index < paragraphs.length && index <= triggerIndex + 40; index += 1) {
487
- const text = paragraphs[index].text.trim();
488
- if (text.length === 0) {
489
- endIndex = index;
490
- continue;
491
- }
492
- if (WITNESS_PATTERN.test(text)) {
493
- kind = "witness-block";
494
- }
495
- if (NOTARY_PATTERN.test(text)) {
496
- kind = "notary-block";
497
- }
498
- if (ROLE_LINE_PATTERN.test(text)) {
499
- hasSignatureContent = true;
500
- endIndex = index;
501
- continue;
502
- }
503
- if (UNDERLINE_PLACEHOLDER_PATTERN.test(text)) {
504
- hasSignatureContent = true;
505
- endIndex = index;
506
- continue;
507
- }
508
- if (PARTY_LABEL_PATTERN.test(text) && !isBodyParagraph(text)) {
509
- parties.push({
510
- roleLabel: text.trim(),
511
- paragraphIndex: index
512
- });
513
- hasSignatureContent = true;
514
- endIndex = index;
515
- continue;
516
- }
517
- if (hasSignatureContent && isBodyParagraph(text)) {
518
- break;
519
- }
520
- endIndex = index;
521
- }
522
- if (!hasSignatureContent) {
523
- return void 0;
524
- }
525
- return {
526
- startIndex: triggerIndex,
527
- endIndex,
528
- kind,
529
- parties,
530
- confidence: parties.length > 0 ? "high" : "medium"
531
- };
532
- }
533
- function isBodyParagraph(text) {
534
- return text.length > 120 && /[.;]/.test(text);
535
- }
536
- function hasOpaqueFragmentsInSignatureRanges(document, candidates) {
537
- if (candidates.length === 0) {
538
- return false;
539
- }
540
- const opaqueCount = Object.keys(document.preservation.opaqueFragments).length;
541
- if (opaqueCount === 0) {
542
- return false;
543
- }
544
- let paragraphIndex = 0;
545
- const opaqueIndices = /* @__PURE__ */ new Set();
546
- for (const block of document.content.children) {
547
- if (block.type === "paragraph") {
548
- paragraphIndex += 1;
549
- continue;
550
- }
551
- if (block.type === "opaque_block") {
552
- opaqueIndices.add(paragraphIndex);
553
- }
554
- paragraphIndex += 1;
555
- }
556
- return candidates.some((candidate) => {
557
- for (let index = candidate.startIndex; index <= candidate.endIndex; index += 1) {
558
- if (opaqueIndices.has(index)) {
559
- return true;
560
- }
561
- }
562
- return false;
563
- });
564
- }
565
- function flattenParagraphText3(paragraph) {
566
- return paragraph.children.map((child) => {
567
- switch (child.type) {
568
- case "text":
569
- return child.text;
570
- case "hyperlink":
571
- case "field":
572
- return child.children.map(
573
- (nested) => nested.type === "text" ? nested.text : nested.type === "tab" ? " " : ""
574
- ).join("");
575
- case "tab":
576
- return " ";
577
- case "hard_break":
578
- case "column_break":
579
- return "\n";
580
- default:
581
- return "";
582
- }
583
- }).join("");
584
- }
585
- function walkBlocks(node, visit) {
586
- visit(node);
587
- if ("children" in node && Array.isArray(node.children)) {
588
- for (const child of node.children) {
589
- walkBlocks(child, visit);
590
- }
591
- }
592
- if (node.type === "table") {
593
- for (const row of node.rows) {
594
- walkBlocks(row, visit);
595
- }
596
- } else if (node.type === "table_row") {
597
- for (const cell of node.cells) {
598
- walkBlocks(cell, visit);
599
- }
600
- }
601
- }
602
- export {
603
- assessBookmarkIntegrity,
604
- buildDefinedTermCatalog,
605
- collectBookmarksFromCanonicalDocument,
606
- collectCrossReferencesFromCanonicalDocument,
607
- collectDefinedTermsFromCanonicalDocument,
608
- collectDefinedTermsFromDocumentXml,
609
- detectCrossReferencePatterns,
610
- detectSignatureBlocksFromCanonicalDocument,
611
- isHiddenBookmarkName,
612
- parseBookmarksFromDocumentXml,
613
- parseCrossReferencesFromDocumentXml,
614
- parseFieldReferenceInstruction
615
- };
616
- //# sourceMappingURL=index.js.map