@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,218 @@
1
+ import type { NumberingCatalog, ParagraphNode } from "../../model/canonical-document.ts";
2
+ import {
3
+ isSyntheticDocxNullAbstractDefinition,
4
+ isSyntheticDocxNullNumberingInstance,
5
+ } from "../ooxml/numbering-sentinels.ts";
6
+
7
+ export const WORD_NUMBERING_CONTENT_TYPE =
8
+ "application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml";
9
+
10
+ export function serializeNumberingXml(catalog: NumberingCatalog): string {
11
+ const abstractDefinitions = Object.values(catalog.abstractDefinitions)
12
+ .filter((definition) => !isSyntheticDocxNullAbstractDefinition(definition))
13
+ .sort((left, right) =>
14
+ compareSerializedIds(left.abstractNumberingId, right.abstractNumberingId),
15
+ );
16
+ const instances = Object.values(catalog.instances)
17
+ .filter((instance) => !isSyntheticDocxNullNumberingInstance(instance))
18
+ .sort((left, right) =>
19
+ compareSerializedIds(left.numberingInstanceId, right.numberingInstanceId),
20
+ );
21
+
22
+ const body = [
23
+ ...abstractDefinitions.map((definition) => serializeAbstractDefinition(definition)),
24
+ ...instances.map((instance) => serializeInstance(instance)),
25
+ ].join("");
26
+
27
+ return [
28
+ `<?xml version="1.0" encoding="UTF-8" standalone="yes"?>`,
29
+ `<w:numbering xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main">${body}</w:numbering>`,
30
+ ].join("\n");
31
+ }
32
+
33
+ export function hasSerializableNumberingEntries(catalog: NumberingCatalog): boolean {
34
+ return (
35
+ Object.values(catalog.abstractDefinitions).some(
36
+ (definition) => !isSyntheticDocxNullAbstractDefinition(definition),
37
+ ) ||
38
+ Object.values(catalog.instances).some(
39
+ (instance) => !isSyntheticDocxNullNumberingInstance(instance),
40
+ )
41
+ );
42
+ }
43
+
44
+ export function serializeParagraphNumberingProperties(
45
+ numbering: ParagraphNode["numbering"],
46
+ ): string {
47
+ if (!numbering) {
48
+ return "";
49
+ }
50
+
51
+ return `<w:numPr><w:ilvl w:val="${numbering.level}"/><w:numId w:val="${escapeAttribute(
52
+ stripCanonicalPrefix(numbering.numberingInstanceId, "num:"),
53
+ )}"/></w:numPr>`;
54
+ }
55
+
56
+ function serializeAbstractDefinition(definition: NumberingCatalog["abstractDefinitions"][string]): string {
57
+ const abstractNumId = escapeAttribute(
58
+ stripCanonicalPrefix(definition.abstractNumberingId, "abstract-num:"),
59
+ );
60
+ const levels = [...definition.levels]
61
+ .sort((left, right) => left.level - right.level)
62
+ .map((level) => serializeLevel(level))
63
+ .join("");
64
+
65
+ return `<w:abstractNum w:abstractNumId="${abstractNumId}">${levels}</w:abstractNum>`;
66
+ }
67
+
68
+ function serializeLevel(
69
+ level: NumberingCatalog["abstractDefinitions"][string]["levels"][number],
70
+ serializedLevel = level.level,
71
+ ): string {
72
+ const start = level.startAt !== undefined ? `<w:start w:val="${level.startAt}"/>` : "";
73
+ const paragraphStyle = level.paragraphStyleId
74
+ ? `<w:pStyle w:val="${escapeAttribute(level.paragraphStyleId)}"/>`
75
+ : "";
76
+ const isLegal = level.isLegalNumbering ? "<w:isLgl/>" : "";
77
+ const suffix = level.suffix ? `<w:suff w:val="${escapeAttribute(level.suffix)}"/>` : "";
78
+ const justification = level.paragraphGeometry?.justification
79
+ ? `<w:lvlJc w:val="${escapeAttribute(level.paragraphGeometry.justification)}"/>`
80
+ : "";
81
+ const paragraphProperties = serializeLevelParagraphGeometry(level.paragraphGeometry);
82
+
83
+ return `<w:lvl w:ilvl="${serializedLevel}">${start}<w:numFmt w:val="${escapeAttribute(
84
+ level.format,
85
+ )}"/><w:lvlText w:val="${escapeAttribute(level.text)}"/>${paragraphStyle}${isLegal}${suffix}${justification}${paragraphProperties}</w:lvl>`;
86
+ }
87
+
88
+ function serializeLevelOverride(
89
+ level: NumberingCatalog["instances"][string]["overrides"][number]["levelDefinition"],
90
+ serializedLevel: number,
91
+ ): string {
92
+ if (!level) {
93
+ return "";
94
+ }
95
+
96
+ const start = level.startAt !== undefined ? `<w:start w:val="${level.startAt}"/>` : "";
97
+ const format = level.format ? `<w:numFmt w:val="${escapeAttribute(level.format)}"/>` : "";
98
+ const text = level.text !== undefined
99
+ ? `<w:lvlText w:val="${escapeAttribute(level.text)}"/>`
100
+ : "";
101
+ const paragraphStyle = level.paragraphStyleId
102
+ ? `<w:pStyle w:val="${escapeAttribute(level.paragraphStyleId)}"/>`
103
+ : "";
104
+ const isLegal =
105
+ level.isLegalNumbering === undefined
106
+ ? ""
107
+ : level.isLegalNumbering
108
+ ? "<w:isLgl/>"
109
+ : `<w:isLgl w:val="0"/>`;
110
+ const suffix = level.suffix ? `<w:suff w:val="${escapeAttribute(level.suffix)}"/>` : "";
111
+ const justification = level.paragraphGeometry?.justification
112
+ ? `<w:lvlJc w:val="${escapeAttribute(level.paragraphGeometry.justification)}"/>`
113
+ : "";
114
+ const paragraphProperties = serializeLevelParagraphGeometry(level.paragraphGeometry);
115
+ const body = `${start}${format}${text}${paragraphStyle}${isLegal}${suffix}${justification}${paragraphProperties}`;
116
+
117
+ return body.length > 0 ? `<w:lvl w:ilvl="${serializedLevel}">${body}</w:lvl>` : "";
118
+ }
119
+
120
+ function serializeInstance(instance: NumberingCatalog["instances"][string]): string {
121
+ const numId = escapeAttribute(stripCanonicalPrefix(instance.numberingInstanceId, "num:"));
122
+ const abstractNumId = escapeAttribute(
123
+ stripCanonicalPrefix(instance.abstractNumberingId, "abstract-num:"),
124
+ );
125
+ const overrides = [...instance.overrides]
126
+ .sort((left, right) => left.level - right.level)
127
+ .map((override) => serializeOverride(override))
128
+ .join("");
129
+
130
+ return `<w:num w:numId="${numId}"><w:abstractNumId w:val="${abstractNumId}"/>${overrides}</w:num>`;
131
+ }
132
+
133
+ function serializeOverride(override: NumberingCatalog["instances"][string]["overrides"][number]): string {
134
+ const startOverride =
135
+ override.startAt !== undefined ? `<w:startOverride w:val="${override.startAt}"/>` : "";
136
+ const levelDefinition = override.levelDefinition
137
+ ? serializeLevelOverride(override.levelDefinition, override.level)
138
+ : "";
139
+ return `<w:lvlOverride w:ilvl="${override.level}">${startOverride}${levelDefinition}</w:lvlOverride>`;
140
+ }
141
+
142
+ function serializeLevelParagraphGeometry(
143
+ paragraphGeometry: NumberingCatalog["abstractDefinitions"][string]["levels"][number]["paragraphGeometry"],
144
+ ): string {
145
+ if (!paragraphGeometry) {
146
+ return "";
147
+ }
148
+
149
+ const children: string[] = [];
150
+ if (paragraphGeometry.spacing) {
151
+ const attrs: string[] = [];
152
+ if (paragraphGeometry.spacing.before !== undefined) {
153
+ attrs.push(`w:before="${paragraphGeometry.spacing.before}"`);
154
+ }
155
+ if (paragraphGeometry.spacing.after !== undefined) {
156
+ attrs.push(`w:after="${paragraphGeometry.spacing.after}"`);
157
+ }
158
+ if (paragraphGeometry.spacing.line !== undefined) {
159
+ attrs.push(`w:line="${paragraphGeometry.spacing.line}"`);
160
+ }
161
+ if (paragraphGeometry.spacing.lineRule !== undefined) {
162
+ attrs.push(`w:lineRule="${paragraphGeometry.spacing.lineRule}"`);
163
+ }
164
+ if (attrs.length > 0) {
165
+ children.push(`<w:spacing ${attrs.join(" ")}/>`);
166
+ }
167
+ }
168
+
169
+ if (paragraphGeometry.indentation) {
170
+ const attrs: string[] = [];
171
+ if (paragraphGeometry.indentation.left !== undefined) {
172
+ attrs.push(`w:left="${paragraphGeometry.indentation.left}"`);
173
+ }
174
+ if (paragraphGeometry.indentation.right !== undefined) {
175
+ attrs.push(`w:right="${paragraphGeometry.indentation.right}"`);
176
+ }
177
+ if (paragraphGeometry.indentation.firstLine !== undefined) {
178
+ attrs.push(`w:firstLine="${paragraphGeometry.indentation.firstLine}"`);
179
+ }
180
+ if (paragraphGeometry.indentation.hanging !== undefined) {
181
+ attrs.push(`w:hanging="${paragraphGeometry.indentation.hanging}"`);
182
+ }
183
+ if (attrs.length > 0) {
184
+ children.push(`<w:ind ${attrs.join(" ")}/>`);
185
+ }
186
+ }
187
+
188
+ if (paragraphGeometry.tabStops && paragraphGeometry.tabStops.length > 0) {
189
+ const tabsXml = paragraphGeometry.tabStops.map((tab) => {
190
+ const leader = tab.leader === "middleDot" ? "middledot" : tab.leader;
191
+ const leaderAttr = leader ? ` w:leader="${leader}"` : "";
192
+ return `<w:tab w:val="${tab.align}" w:pos="${tab.position}"${leaderAttr}/>`;
193
+ }).join("");
194
+ children.push(`<w:tabs>${tabsXml}</w:tabs>`);
195
+ }
196
+
197
+ return children.length > 0 ? `<w:pPr>${children.join("")}</w:pPr>` : "";
198
+ }
199
+
200
+ function compareSerializedIds(left: string, right: string): number {
201
+ return stripKnownPrefix(left).localeCompare(stripKnownPrefix(right), "en", { numeric: true });
202
+ }
203
+
204
+ function stripKnownPrefix(value: string): string {
205
+ return value.replace(/^abstract-num:|^num:/, "");
206
+ }
207
+
208
+ function stripCanonicalPrefix(value: string, prefix: "abstract-num:" | "num:"): string {
209
+ return value.startsWith(prefix) ? value.slice(prefix.length) : value;
210
+ }
211
+
212
+ function escapeAttribute(value: string): string {
213
+ return value
214
+ .replace(/&/g, "&amp;")
215
+ .replace(/"/g, "&quot;")
216
+ .replace(/</g, "&lt;")
217
+ .replace(/>/g, "&gt;");
218
+ }
@@ -0,0 +1,389 @@
1
+ import type { RevisionRecord } from "../../review/store/revision-types.ts";
2
+ import type {
3
+ ParsedRevisionsResult,
4
+ PreservedRevisionMarkup,
5
+ } from "../ooxml/parse-revisions.ts";
6
+ import {
7
+ mapRevisionBoundaries,
8
+ type RevisionParagraphBoundary,
9
+ } from "../ooxml/revision-boundaries.ts";
10
+
11
+ export interface SerializeRevisionsOptions {
12
+ revisions: readonly RevisionRecord[];
13
+ preservedMarkup: readonly PreservedRevisionMarkup[];
14
+ boundaries?: readonly RevisionParagraphBoundary[];
15
+ }
16
+
17
+ interface XmlReplacement {
18
+ start: number;
19
+ end: number;
20
+ replacement: string;
21
+ }
22
+
23
+ interface ParagraphMarkupDecision {
24
+ revisionId: string;
25
+ paragraphIndex: number;
26
+ rawMarkup: string;
27
+ mergeFromParagraphIndex?: number;
28
+ mergeToParagraphIndex?: number;
29
+ }
30
+
31
+ export function serializeRevisionsIntoDocumentXml(
32
+ documentXml: string,
33
+ options: SerializeRevisionsOptions | ParsedRevisionsResult,
34
+ ): string {
35
+ const revisions = options.revisions;
36
+ const preservedMarkup = options.preservedMarkup
37
+ .slice()
38
+ .sort((left, right) => left.xmlStart - right.xmlStart);
39
+ const revisionById = new Map(revisions.map((revision) => [revision.revisionId, revision]));
40
+ const boundaries = options.boundaries ?? mapRevisionBoundaries(documentXml);
41
+ const replacements: XmlReplacement[] = [];
42
+ const consumedRevisionIds = new Set<string>();
43
+ const paragraphDecisions = collectParagraphMarkupDecisions(
44
+ preservedMarkup,
45
+ revisionById,
46
+ boundaries,
47
+ );
48
+
49
+ replacements.push(
50
+ ...createParagraphStructuralReplacements(
51
+ documentXml,
52
+ boundaries,
53
+ paragraphDecisions,
54
+ consumedRevisionIds,
55
+ ),
56
+ );
57
+
58
+ for (const markup of preservedMarkup) {
59
+ if (consumedRevisionIds.has(markup.revisionId)) {
60
+ continue;
61
+ }
62
+
63
+ const revision = revisionById.get(markup.revisionId);
64
+
65
+ if (
66
+ revision?.kind === "property-change" &&
67
+ revision.status === "rejected" &&
68
+ markup.containerXmlStart !== undefined &&
69
+ markup.containerXmlEnd !== undefined &&
70
+ markup.beforeContainerXml !== undefined
71
+ ) {
72
+ replacements.push({
73
+ start: markup.containerXmlStart,
74
+ end: markup.containerXmlEnd,
75
+ replacement: markup.beforeContainerXml,
76
+ });
77
+ continue;
78
+ }
79
+
80
+ replacements.push({
81
+ start: markup.xmlStart,
82
+ end: markup.xmlEnd,
83
+ replacement: serializeMarkup(markup, revision),
84
+ });
85
+ }
86
+
87
+ return applyReplacements(documentXml, replacements);
88
+ }
89
+
90
+ function serializeMarkup(
91
+ markup: PreservedRevisionMarkup,
92
+ revision: RevisionRecord | undefined,
93
+ ): string {
94
+ if (!revision) {
95
+ return markup.rawXml;
96
+ }
97
+
98
+ switch (revision.kind) {
99
+ case "move":
100
+ case "formatting":
101
+ return markup.rawXml;
102
+ case "property-change":
103
+ return serializePropertyChangeMarkup(markup.rawXml, revision.status);
104
+ case "insertion":
105
+ return serializeInsertionMarkup(markup.rawXml, revision.status);
106
+ case "deletion":
107
+ return serializeDeletionMarkup(markup.rawXml, revision.status);
108
+ }
109
+ }
110
+
111
+ function collectParagraphMarkupDecisions(
112
+ preservedMarkup: readonly PreservedRevisionMarkup[],
113
+ revisionById: ReadonlyMap<string, RevisionRecord>,
114
+ boundaries: readonly RevisionParagraphBoundary[],
115
+ ): ParagraphMarkupDecision[] {
116
+ const decisions: ParagraphMarkupDecision[] = [];
117
+
118
+ for (const markup of preservedMarkup) {
119
+ if (!markup.originalRevisionType.startsWith("paragraph-")) {
120
+ continue;
121
+ }
122
+
123
+ const revision = revisionById.get(markup.revisionId);
124
+ const paragraphIndex = markup.paragraphIndex;
125
+ if (!revision || paragraphIndex === undefined) {
126
+ continue;
127
+ }
128
+
129
+ if (revision.status === "active" || revision.status === "detached") {
130
+ continue;
131
+ }
132
+
133
+ if (markup.originalRevisionType === "paragraph-del") {
134
+ decisions.push({
135
+ revisionId: markup.revisionId,
136
+ paragraphIndex,
137
+ rawMarkup: markup.rawXml,
138
+ ...(revision.status === "accepted" && boundaries[paragraphIndex + 1]
139
+ ? { mergeFromParagraphIndex: paragraphIndex, mergeToParagraphIndex: paragraphIndex + 1 }
140
+ : {}),
141
+ });
142
+ continue;
143
+ }
144
+
145
+ if (markup.originalRevisionType === "paragraph-ins") {
146
+ decisions.push({
147
+ revisionId: markup.revisionId,
148
+ paragraphIndex,
149
+ rawMarkup: markup.rawXml,
150
+ ...(revision.status === "rejected" && boundaries[paragraphIndex - 1]
151
+ ? { mergeFromParagraphIndex: paragraphIndex - 1, mergeToParagraphIndex: paragraphIndex }
152
+ : {}),
153
+ });
154
+ }
155
+ }
156
+
157
+ return decisions;
158
+ }
159
+
160
+ function createParagraphStructuralReplacements(
161
+ documentXml: string,
162
+ boundaries: readonly RevisionParagraphBoundary[],
163
+ decisions: readonly ParagraphMarkupDecision[],
164
+ consumedRevisionIds: Set<string>,
165
+ ): XmlReplacement[] {
166
+ const replacements: XmlReplacement[] = [];
167
+ const removedMarkupByParagraph = new Map<number, string[]>();
168
+ const mergeEdgeStarts = new Set<number>();
169
+
170
+ for (const decision of decisions) {
171
+ consumedRevisionIds.add(decision.revisionId);
172
+ const existing = removedMarkupByParagraph.get(decision.paragraphIndex) ?? [];
173
+ existing.push(decision.rawMarkup);
174
+ removedMarkupByParagraph.set(decision.paragraphIndex, existing);
175
+
176
+ if (
177
+ decision.mergeFromParagraphIndex !== undefined &&
178
+ decision.mergeToParagraphIndex !== undefined
179
+ ) {
180
+ mergeEdgeStarts.add(decision.mergeFromParagraphIndex);
181
+ }
182
+ }
183
+
184
+ const mergedParagraphIndices = new Set<number>();
185
+
186
+ for (let paragraphIndex = 0; paragraphIndex < boundaries.length; paragraphIndex += 1) {
187
+ if (mergedParagraphIndices.has(paragraphIndex) || !mergeEdgeStarts.has(paragraphIndex)) {
188
+ continue;
189
+ }
190
+
191
+ let groupEnd = paragraphIndex;
192
+ while (mergeEdgeStarts.has(groupEnd)) {
193
+ groupEnd += 1;
194
+ }
195
+
196
+ const startBoundary = boundaries[paragraphIndex];
197
+ const endBoundary = boundaries[groupEnd];
198
+ if (!startBoundary || !endBoundary) {
199
+ continue;
200
+ }
201
+
202
+ let targetInnerXml = removeParagraphRevisionMarkup(
203
+ getParagraphInnerXml(documentXml, startBoundary),
204
+ removedMarkupByParagraph.get(paragraphIndex) ?? [],
205
+ );
206
+ let appendedStoryXml = "";
207
+
208
+ for (let sourceIndex = paragraphIndex + 1; sourceIndex <= groupEnd; sourceIndex += 1) {
209
+ const sourceBoundary = boundaries[sourceIndex];
210
+ if (!sourceBoundary) {
211
+ continue;
212
+ }
213
+
214
+ appendedStoryXml += getParagraphStoryXml(documentXml, sourceBoundary);
215
+ mergedParagraphIndices.add(sourceIndex);
216
+ }
217
+
218
+ replacements.push({
219
+ start: startBoundary.paragraphStart,
220
+ end: endBoundary.paragraphEnd,
221
+ replacement: serializeMergedParagraph(
222
+ documentXml,
223
+ startBoundary,
224
+ targetInnerXml,
225
+ appendedStoryXml,
226
+ ),
227
+ });
228
+ mergedParagraphIndices.add(paragraphIndex);
229
+ }
230
+
231
+ for (const [paragraphIndex, rawMarkup] of removedMarkupByParagraph.entries()) {
232
+ if (mergedParagraphIndices.has(paragraphIndex)) {
233
+ continue;
234
+ }
235
+
236
+ const boundary = boundaries[paragraphIndex];
237
+ if (!boundary) {
238
+ continue;
239
+ }
240
+
241
+ replacements.push({
242
+ start: boundary.paragraphStart,
243
+ end: boundary.paragraphEnd,
244
+ replacement: serializeMergedParagraph(
245
+ documentXml,
246
+ boundary,
247
+ removeParagraphRevisionMarkup(getParagraphInnerXml(documentXml, boundary), rawMarkup),
248
+ "",
249
+ ),
250
+ });
251
+ }
252
+
253
+ return replacements;
254
+ }
255
+
256
+ function serializeMergedParagraph(
257
+ documentXml: string,
258
+ targetBoundary: RevisionParagraphBoundary,
259
+ targetInnerXml: string,
260
+ appendedStoryXml: string,
261
+ ): string {
262
+ return [
263
+ documentXml.slice(targetBoundary.paragraphStart, targetBoundary.paragraphStartTagEnd),
264
+ targetInnerXml,
265
+ appendedStoryXml,
266
+ documentXml.slice(targetBoundary.paragraphEndTagStart, targetBoundary.paragraphEnd),
267
+ ].join("");
268
+ }
269
+
270
+ function getParagraphInnerXml(
271
+ documentXml: string,
272
+ boundary: RevisionParagraphBoundary,
273
+ ): string {
274
+ return documentXml.slice(boundary.paragraphStartTagEnd, boundary.paragraphEndTagStart);
275
+ }
276
+
277
+ function getParagraphStoryXml(
278
+ documentXml: string,
279
+ boundary: RevisionParagraphBoundary,
280
+ ): string {
281
+ const innerXml = getParagraphInnerXml(documentXml, boundary);
282
+ if (
283
+ boundary.paragraphPropertiesStart === undefined ||
284
+ boundary.paragraphPropertiesEnd === undefined
285
+ ) {
286
+ return innerXml;
287
+ }
288
+
289
+ const relativeStart = boundary.paragraphPropertiesStart - boundary.paragraphStartTagEnd;
290
+ const relativeEnd = boundary.paragraphPropertiesEnd - boundary.paragraphStartTagEnd;
291
+
292
+ return innerXml.slice(0, relativeStart) + innerXml.slice(relativeEnd);
293
+ }
294
+
295
+ function removeParagraphRevisionMarkup(
296
+ innerXml: string,
297
+ rawMarkup: string | readonly string[],
298
+ ): string {
299
+ const markups = Array.isArray(rawMarkup) ? rawMarkup : [rawMarkup];
300
+ return cleanupEmptyParagraphPropertyContainers(
301
+ markups.reduce((result, markup) => result.replace(markup, ""), innerXml),
302
+ );
303
+ }
304
+
305
+ function cleanupEmptyParagraphPropertyContainers(xml: string): string {
306
+ let next = xml;
307
+ let previous = "";
308
+
309
+ while (next !== previous) {
310
+ previous = next;
311
+ next = next
312
+ .replace(/<w:rPr>\s*<\/w:rPr>/g, "")
313
+ .replace(/<w:pPr>\s*<\/w:pPr>/g, "");
314
+ }
315
+
316
+ return next;
317
+ }
318
+
319
+ function applyReplacements(documentXml: string, replacements: XmlReplacement[]): string {
320
+ const sorted = replacements
321
+ .slice()
322
+ .sort((left, right) => right.start - left.start || right.end - left.end);
323
+ let output = documentXml;
324
+
325
+ for (const replacement of sorted) {
326
+ output =
327
+ output.slice(0, replacement.start) +
328
+ replacement.replacement +
329
+ output.slice(replacement.end);
330
+ }
331
+
332
+ return output;
333
+ }
334
+
335
+ function serializePropertyChangeMarkup(
336
+ rawXml: string,
337
+ status: RevisionRecord["status"],
338
+ ): string {
339
+ switch (status) {
340
+ case "accepted":
341
+ return "";
342
+ case "rejected":
343
+ case "active":
344
+ case "detached":
345
+ return rawXml;
346
+ }
347
+ }
348
+
349
+ function serializeInsertionMarkup(
350
+ rawXml: string,
351
+ status: RevisionRecord["status"],
352
+ ): string {
353
+ switch (status) {
354
+ case "accepted":
355
+ return unwrapRevisionContainer(rawXml);
356
+ case "rejected":
357
+ return "";
358
+ case "active":
359
+ case "detached":
360
+ return rawXml;
361
+ }
362
+ }
363
+
364
+ function serializeDeletionMarkup(
365
+ rawXml: string,
366
+ status: RevisionRecord["status"],
367
+ ): string {
368
+ switch (status) {
369
+ case "accepted":
370
+ return "";
371
+ case "rejected":
372
+ return convertDeletedContentToRuns(unwrapRevisionContainer(rawXml));
373
+ case "active":
374
+ case "detached":
375
+ return rawXml;
376
+ }
377
+ }
378
+
379
+ function unwrapRevisionContainer(rawXml: string): string {
380
+ return rawXml
381
+ .replace(/^<[^>]+>/, "")
382
+ .replace(/<\/[^>]+>\s*$/, "");
383
+ }
384
+
385
+ function convertDeletedContentToRuns(xml: string): string {
386
+ return xml
387
+ .replace(/<(\/?)w:delText\b/g, "<$1w:t")
388
+ .replace(/<(\/?)w:delInstrText\b/g, "<$1w:instrText");
389
+ }