@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
@@ -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