@beyondwork/docx-react-component 1.0.0 → 1.0.2

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 (560) hide show
  1. package/README.md +44 -104
  2. package/package.json +66 -15
  3. package/src/api/public-types.ts +1 -1
  4. package/src/compare/diff-engine.ts +530 -0
  5. package/src/compare/export-redlines.ts +162 -0
  6. package/src/compare/snapshot.ts +37 -0
  7. package/src/core/commands/index.ts +1 -1
  8. package/src/core/state/editor-state.ts +2 -2
  9. package/src/index.ts +45 -0
  10. package/src/legal/bookmarks.ts +196 -0
  11. package/src/legal/cross-references.ts +356 -0
  12. package/src/legal/defined-terms.ts +203 -0
  13. package/src/runtime/document-runtime.ts +3 -5
  14. package/src/runtime/table-commands.ts +4 -1
  15. package/src/runtime/table-schema.ts +17 -2
  16. package/src/runtime/virtualized-rendering.ts +258 -0
  17. package/src/ui/WordReviewEditor.tsx +256 -35
  18. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +2 -2
  19. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +16 -2
  20. package/.codex/config.toml +0 -5
  21. package/.corepack/v1/pnpm/10.30.3/.corepack +0 -1
  22. package/.corepack/v1/pnpm/10.30.3/LICENSE +0 -22
  23. package/.corepack/v1/pnpm/10.30.3/README.md +0 -240
  24. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp +0 -6
  25. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp.cmd +0 -5
  26. package/.corepack/v1/pnpm/10.30.3/dist/pnpm.cjs +0 -195400
  27. package/.corepack/v1/pnpm/10.30.3/dist/pnpmrc +0 -2
  28. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-arm64-2HJ4WGO6.node +0 -0
  29. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-x64-3G3H6IW4.node +0 -0
  30. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-arm64-msvc-Q6BARPPB.node +0 -0
  31. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-x64-msvc-J2TZHRQI.node +0 -0
  32. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.bash +0 -31
  33. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.fish +0 -22
  34. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.ps1 +0 -193
  35. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.zsh +0 -27
  36. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
  37. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
  38. package/.corepack/v1/pnpm/10.30.3/dist/worker.js +0 -10119
  39. package/.corepack/v1/pnpm/10.30.3/package.json +0 -192
  40. package/.cursor/mcp.json +0 -7
  41. package/.github/workflows/ci.yml +0 -35
  42. package/.mcp.json +0 -7
  43. package/.openclaw/workspace-state.json +0 -4
  44. package/.pnpmrc.json +0 -1
  45. package/.wave-launch.sh +0 -7
  46. package/.workspace-marker +0 -1
  47. package/AGENTS.md +0 -78
  48. package/CHANGELOG.md +0 -177
  49. package/DESIGN.md +0 -929
  50. package/HEARTBEAT.md +0 -7
  51. package/IDENTITY.md +0 -23
  52. package/SOUL.md +0 -36
  53. package/TOOLS.md +0 -40
  54. package/USER.md +0 -17
  55. package/docs/README.md +0 -107
  56. package/docs/agents/wave-cont-eval-role.md +0 -36
  57. package/docs/agents/wave-cont-qa-role.md +0 -52
  58. package/docs/agents/wave-deploy-verifier-role.md +0 -34
  59. package/docs/agents/wave-design-role.md +0 -47
  60. package/docs/agents/wave-documentation-role.md +0 -34
  61. package/docs/agents/wave-infra-role.md +0 -34
  62. package/docs/agents/wave-integration-role.md +0 -37
  63. package/docs/agents/wave-launcher-role.md +0 -41
  64. package/docs/agents/wave-orchestrator-role.md +0 -52
  65. package/docs/agents/wave-planner-role.md +0 -39
  66. package/docs/agents/wave-security-role.md +0 -40
  67. package/docs/architecture/docx/README.md +0 -10
  68. package/docs/architecture/future/README.md +0 -8
  69. package/docs/architecture/ooxml-upgrade-analysis.md +0 -134
  70. package/docs/architecture/platform/shared-openxml-editor-platform.md +0 -153
  71. package/docs/architecture/xlsx/canonical-workbook-model-and-commands.md +0 -187
  72. package/docs/architecture/xlsx/spreadsheet-editor-frontend-architecture.md +0 -150
  73. package/docs/comment-redline-overview.md +0 -350
  74. package/docs/concepts/context7-vs-skills.md +0 -118
  75. package/docs/concepts/operating-modes.md +0 -91
  76. package/docs/concepts/runtime-agnostic-orchestration.md +0 -111
  77. package/docs/concepts/what-is-a-wave.md +0 -217
  78. package/docs/context7/bundles.json +0 -222
  79. package/docs/context7/planner-agent/README.md +0 -28
  80. package/docs/context7/planner-agent/manifest.json +0 -83
  81. package/docs/context7/planner-agent/papers/cooperbench-why-coding-agents-cannot-be-your-teammates-yet.md +0 -3283
  82. package/docs/context7/planner-agent/papers/dova-deliberation-first-multi-agent-orchestration-for-autonomous-research-automation.md +0 -1699
  83. package/docs/context7/planner-agent/papers/dpbench-large-language-models-struggle-with-simultaneous-coordination.md +0 -2251
  84. package/docs/context7/planner-agent/papers/incremental-planning-to-control-a-blackboard-based-problem-solver.md +0 -1729
  85. package/docs/context7/planner-agent/papers/silo-bench-a-scalable-environment-for-evaluating-distributed-coordination-in-multi-agent-llm-systems.md +0 -3747
  86. package/docs/context7/planner-agent/papers/todoevolve-learning-to-architect-agent-planning-systems.md +0 -1675
  87. package/docs/context7/planner-agent/papers/verified-multi-agent-orchestration-a-plan-execute-verify-replan-framework-for-complex-query-resolution.md +0 -1173
  88. package/docs/context7/planner-agent/papers/why-do-multi-agent-llm-systems-fail.md +0 -5211
  89. package/docs/context7/planner-agent/topics/planning-and-orchestration.md +0 -24
  90. package/docs/evals/arm-templates/README.md +0 -13
  91. package/docs/evals/arm-templates/full-wave.json +0 -15
  92. package/docs/evals/arm-templates/single-agent.json +0 -15
  93. package/docs/evals/benchmark-catalog.json +0 -670
  94. package/docs/evals/cases/README.md +0 -47
  95. package/docs/evals/cases/wave-blackboard-inbox-targeting.json +0 -73
  96. package/docs/evals/cases/wave-contradiction-conflict.json +0 -104
  97. package/docs/evals/cases/wave-expert-routing-preservation.json +0 -69
  98. package/docs/evals/cases/wave-hidden-profile-private-evidence.json +0 -81
  99. package/docs/evals/cases/wave-premature-closure-guard.json +0 -71
  100. package/docs/evals/cases/wave-silo-cross-agent-state.json +0 -77
  101. package/docs/evals/cases/wave-simultaneous-lockstep.json +0 -92
  102. package/docs/evals/external-benchmarks.json +0 -85
  103. package/docs/evals/external-command-config.sample.json +0 -9
  104. package/docs/evals/external-command-config.swe-bench-pro.json +0 -8
  105. package/docs/evals/pilots/README.md +0 -47
  106. package/docs/evals/pilots/swe-bench-pro-public-full-wave-review-10.json +0 -64
  107. package/docs/evals/pilots/swe-bench-pro-public-pilot.json +0 -111
  108. package/docs/evals/wave-benchmark-program.md +0 -302
  109. package/docs/guides/planner.md +0 -220
  110. package/docs/guides/recommendations-0.8.9.md +0 -133
  111. package/docs/guides/signal-wrappers.md +0 -165
  112. package/docs/guides/terminal-surfaces.md +0 -96
  113. package/docs/image copy.png +0 -0
  114. package/docs/image.png +0 -0
  115. package/docs/images/image.png +0 -0
  116. package/docs/legal-feedback-architecture.md +0 -498
  117. package/docs/plans/component-cutover-matrix.json +0 -1072
  118. package/docs/plans/component-cutover-matrix.md +0 -307
  119. package/docs/plans/context7-wave-orchestrator.md +0 -155
  120. package/docs/plans/current-state.md +0 -198
  121. package/docs/plans/docx/README.md +0 -9
  122. package/docs/plans/examples/wave-benchmark-improvement.md +0 -108
  123. package/docs/plans/examples/wave-example-live-proof.md +0 -435
  124. package/docs/plans/master-plan.md +0 -224
  125. package/docs/plans/migration.md +0 -538
  126. package/docs/plans/operations/README.md +0 -7
  127. package/docs/plans/operations/wave-10-word-certification.md +0 -87
  128. package/docs/plans/operations/wave-8-railway-staging.md +0 -153
  129. package/docs/plans/operations/wave-9-manual-certification.md +0 -73
  130. package/docs/plans/platform/README.md +0 -9
  131. package/docs/plans/reference/legal-checklist-coverage.md +0 -258
  132. package/docs/plans/wave-orchestrator.md +0 -423
  133. package/docs/plans/waves/README.md +0 -75
  134. package/docs/plans/waves/completed/wave-0.md +0 -195
  135. package/docs/plans/waves/completed/wave-1.md +0 -379
  136. package/docs/plans/waves/completed/wave-10.md +0 -670
  137. package/docs/plans/waves/completed/wave-11.md +0 -335
  138. package/docs/plans/waves/completed/wave-12.md +0 -417
  139. package/docs/plans/waves/completed/wave-13.md +0 -316
  140. package/docs/plans/waves/completed/wave-14.md +0 -319
  141. package/docs/plans/waves/completed/wave-15.md +0 -321
  142. package/docs/plans/waves/completed/wave-16.md +0 -316
  143. package/docs/plans/waves/completed/wave-17.md +0 -331
  144. package/docs/plans/waves/completed/wave-18.md +0 -328
  145. package/docs/plans/waves/completed/wave-2.md +0 -438
  146. package/docs/plans/waves/completed/wave-3.md +0 -435
  147. package/docs/plans/waves/completed/wave-4.md +0 -430
  148. package/docs/plans/waves/completed/wave-5.md +0 -430
  149. package/docs/plans/waves/completed/wave-6.md +0 -430
  150. package/docs/plans/waves/completed/wave-7.md +0 -526
  151. package/docs/plans/waves/completed/wave-8.md +0 -596
  152. package/docs/plans/waves/completed/wave-9.md +0 -552
  153. package/docs/plans/waves/deferred/README.md +0 -14
  154. package/docs/plans/waves/deferred/encrypted-intake-contracts.md +0 -282
  155. package/docs/plans/waves/deferred/legal-feedback-wave-expansion.md +0 -308
  156. package/docs/plans/waves/deferred/wave-encrypted-intake.md +0 -451
  157. package/docs/plans/waves/design/README.md +0 -5
  158. package/docs/plans/waves/design/wave-1-a1.md +0 -309
  159. package/docs/plans/waves/reviews/README.md +0 -5
  160. package/docs/plans/waves/reviews/wave-0-cont-qa.md +0 -151
  161. package/docs/plans/waves/reviews/wave-1-cont-qa.md +0 -46
  162. package/docs/plans/waves/reviews/wave-10-accessibility-and-design.md +0 -51
  163. package/docs/plans/waves/reviews/wave-10-cont-qa.md +0 -24
  164. package/docs/plans/waves/reviews/wave-10-dashboard-proof.md +0 -46
  165. package/docs/plans/waves/reviews/wave-10-performance-signoff.md +0 -55
  166. package/docs/plans/waves/reviews/wave-10-regression-proof.md +0 -23
  167. package/docs/plans/waves/reviews/wave-10-release-audit.md +0 -31
  168. package/docs/plans/waves/reviews/wave-10-service-proof.md +0 -83
  169. package/docs/plans/waves/reviews/wave-10-word-certification.md +0 -31
  170. package/docs/plans/waves/reviews/wave-18-ai-contract-closure.md +0 -277
  171. package/docs/plans/waves/reviews/wave-18-cont-qa.md +0 -255
  172. package/docs/plans/waves/reviews/wave-18-parity-proof.md +0 -271
  173. package/docs/plans/waves/reviews/wave-19-cont-qa.md +0 -59
  174. package/docs/plans/waves/reviews/wave-2-cont-qa.md +0 -72
  175. package/docs/plans/waves/reviews/wave-20-cont-qa.md +0 -60
  176. package/docs/plans/waves/reviews/wave-25-cont-qa.md +0 -48
  177. package/docs/plans/waves/reviews/wave-28-cont-qa.md +0 -46
  178. package/docs/plans/waves/reviews/wave-29-cont-qa.md +0 -53
  179. package/docs/plans/waves/reviews/wave-3-cont-qa.md +0 -53
  180. package/docs/plans/waves/reviews/wave-3-core-proof.md +0 -77
  181. package/docs/plans/waves/reviews/wave-3-validator-proof.md +0 -73
  182. package/docs/plans/waves/reviews/wave-32-cont-qa.md +0 -43
  183. package/docs/plans/waves/reviews/wave-33-cont-qa.md +0 -526
  184. package/docs/plans/waves/reviews/wave-34-cont-qa.md +0 -100
  185. package/docs/plans/waves/reviews/wave-35-cont-qa.md +0 -145
  186. package/docs/plans/waves/reviews/wave-4-cont-qa.md +0 -47
  187. package/docs/plans/waves/reviews/wave-4-structure-proof.md +0 -69
  188. package/docs/plans/waves/reviews/wave-5-comment-proof.md +0 -158
  189. package/docs/plans/waves/reviews/wave-5-cont-qa.md +0 -68
  190. package/docs/plans/waves/reviews/wave-6-cont-qa.md +0 -416
  191. package/docs/plans/waves/reviews/wave-6-redline-proof.md +0 -130
  192. package/docs/plans/waves/reviews/wave-7-cont-qa.md +0 -82
  193. package/docs/plans/waves/reviews/wave-7-ooxml-compliance.md +0 -85
  194. package/docs/plans/waves/reviews/wave-7-preservation-proof.md +0 -119
  195. package/docs/plans/waves/reviews/wave-7-trust-ux.md +0 -87
  196. package/docs/plans/waves/reviews/wave-8-accessibility-and-design.md +0 -128
  197. package/docs/plans/waves/reviews/wave-8-cont-qa.md +0 -92
  198. package/docs/plans/waves/reviews/wave-8-live-proof.md +0 -140
  199. package/docs/plans/waves/reviews/wave-8-security.md +0 -47
  200. package/docs/plans/waves/reviews/wave-9-editor-embedding.md +0 -39
  201. package/docs/plans/waves/reviews/wave-9-fixture-runner.md +0 -56
  202. package/docs/plans/waves/reviews/wave-9-live-proof.md +0 -105
  203. package/docs/plans/waves/reviews/wave-9-usability-and-performance.md +0 -152
  204. package/docs/plans/waves/specs/README.md +0 -5
  205. package/docs/plans/waves/specs/wave-1-component-boundaries.md +0 -322
  206. package/docs/plans/waves/specs/wave-1-ooxml-contracts.md +0 -323
  207. package/docs/plans/waves/specs/wave-1-review-and-ui-contracts.md +0 -339
  208. package/docs/plans/waves/specs/wave-1-runtime-contracts.md +0 -509
  209. package/docs/plans/waves/wave-19.md +0 -341
  210. package/docs/plans/waves/wave-20.md +0 -308
  211. package/docs/plans/waves/wave-21.md +0 -289
  212. package/docs/plans/waves/wave-22.md +0 -221
  213. package/docs/plans/waves/wave-23.md +0 -295
  214. package/docs/plans/waves/wave-24.md +0 -286
  215. package/docs/plans/waves/wave-25.md +0 -313
  216. package/docs/plans/waves/wave-26.md +0 -300
  217. package/docs/plans/waves/wave-27.md +0 -299
  218. package/docs/plans/waves/wave-28.md +0 -368
  219. package/docs/plans/waves/wave-29.md +0 -303
  220. package/docs/plans/waves/wave-30.md +0 -307
  221. package/docs/plans/waves/wave-31.md +0 -231
  222. package/docs/plans/waves/wave-32.md +0 -152
  223. package/docs/plans/waves/wave-33.md +0 -147
  224. package/docs/plans/waves/wave-34.md +0 -148
  225. package/docs/plans/waves/wave-35.md +0 -141
  226. package/docs/plans/waves/wave-36.md +0 -146
  227. package/docs/plans/xlsx/README.md +0 -14
  228. package/docs/plans/xlsx/xlsx-fixture-corpus-and-certification-plan.md +0 -126
  229. package/docs/reference/cli-reference.md +0 -600
  230. package/docs/reference/coordination-and-closure.md +0 -487
  231. package/docs/reference/deep-research-report (15).md +0 -25
  232. package/docs/reference/docx/README.md +0 -10
  233. package/docs/reference/legal-checklist.md +0 -445
  234. package/docs/reference/live-proof-waves.md +0 -199
  235. package/docs/reference/ooxml-compliance.md +0 -129
  236. package/docs/reference/ooxml-feature-parity-matrix.md +0 -172
  237. package/docs/reference/platform/shared-ooxml-platform-guidance.md +0 -77
  238. package/docs/reference/prototype-agent-prompt-legal-fidelity.md +0 -155
  239. package/docs/reference/public-api.md +0 -456
  240. package/docs/reference/repository-guidance.md +0 -58
  241. package/docs/reference/runtime-config/README.md +0 -182
  242. package/docs/reference/runtime-config/claude.md +0 -110
  243. package/docs/reference/runtime-config/codex.md +0 -82
  244. package/docs/reference/runtime-config/opencode.md +0 -93
  245. package/docs/reference/sample-waves.md +0 -105
  246. package/docs/reference/skills.md +0 -237
  247. package/docs/reference/templates/AGENTS.md +0 -78
  248. package/docs/reference/templates/HEARTBEAT.md +0 -7
  249. package/docs/reference/templates/IDENTITY.md +0 -23
  250. package/docs/reference/templates/SOUL.md +0 -36
  251. package/docs/reference/templates/TOOLS.md +0 -40
  252. package/docs/reference/templates/USER.md +0 -17
  253. package/docs/reference/wave-control.md +0 -184
  254. package/docs/reference/wave-planning-lessons.md +0 -167
  255. package/docs/reference/word-review-editor-frontend-architecture.md +0 -479
  256. package/docs/reference/word-review-editor-ux-guide.md +0 -253
  257. package/docs/reference/xlsx/xlsx-ooxml-compliance.md +0 -137
  258. package/docs/research/agent-context-sources.md +0 -178
  259. package/docs/research/coordination-failure-review.md +0 -290
  260. package/docs/research/docx-react-component/Canonical Document Schema Specification for a React-based Word-compatible Editor.md +0 -2317
  261. package/docs/research/docx-react-component/Feature Compatibility Matrix for a React Word Compatible Legal Editor v1.md +0 -219
  262. package/docs/research/docx-react-component/React Component Architecture and Front-End Structure Specification for a Word-Compatible Legal Review Editor.md +0 -1112
  263. package/docs/research/docx-react-component/document_compatibility_and_testing_spec.md +0 -751
  264. package/docs/research/xlsx/raw/README.md +0 -13
  265. package/docs/roadmap.md +0 -174
  266. package/docs/superpowers/plans/2026-03-28-harness-control-bar.md +0 -677
  267. package/docs/superpowers/specs/2026-03-28-harness-control-bar-design.md +0 -274
  268. package/docs/xlsx-react/README.md +0 -38
  269. package/docs/xlsx-react/agent-llm-interaction-layer-docx-xlsx.md +0 -621
  270. package/docs/xlsx-react/canonical-workbook-model-and-commands.md +0 -948
  271. package/docs/xlsx-react/shared-openxml-editor-platform-docx-xlsx.md +0 -228
  272. package/docs/xlsx-react/spreadsheet-editor-component-architecture.md +0 -809
  273. package/docs/xlsx-react/spreadsheet-editor-frontend-architecture.md +0 -537
  274. package/docs/xlsx-react/spreadsheet-editor-ux-guide.md +0 -520
  275. package/docs/xlsx-react/xlsx-editor-research-pack.md +0 -871
  276. package/docs/xlsx-react/xlsx-fixture-corpus-and-certification-plan.md +0 -436
  277. package/docs/xlsx-react/xlsx-ooxml-compliance.md +0 -320
  278. package/examples/README.md +0 -16
  279. package/memory/MEMORY.md +0 -24
  280. package/pnpm-workspace.yaml +0 -4
  281. package/scripts/check-no-authored-js.sh +0 -13
  282. package/scripts/context7-api-check.sh +0 -65
  283. package/scripts/context7-export-env.sh +0 -42
  284. package/scripts/run-context7-mcp.sh +0 -8
  285. package/scripts/run-workspace-tests.sh +0 -15
  286. package/scripts/start-wave-10-local.sh +0 -189
  287. package/scripts/wave-agent-attach.sh +0 -47
  288. package/scripts/wave-auto-answer.sh +0 -118
  289. package/scripts/wave-dashboard-attach.sh +0 -13
  290. package/scripts/wave-launch.sh +0 -273
  291. package/scripts/wave-overnight-supervisor.sh +0 -145
  292. package/scripts/wave-status.sh +0 -379
  293. package/scripts/wave-watch.sh +0 -231
  294. package/services/README.md +0 -17
  295. package/services/openxml-validator/Dockerfile +0 -29
  296. package/services/openxml-validator/OpenXmlValidator.Api.csproj +0 -12
  297. package/services/openxml-validator/Program.cs +0 -436
  298. package/services/openxml-validator/README.md +0 -152
  299. package/services/openxml-validator/railway.json +0 -16
  300. package/services/react-word-editor/.tmp-a4/src/api/public-types.ts +0 -318
  301. package/services/react-word-editor/.tmp-a4/src/ui/WordReviewEditor.tsx +0 -1302
  302. package/services/react-word-editor/.tmp-a4/src/ui/editor-surface/editor-surface.tsx +0 -546
  303. package/services/react-word-editor/.tmp-a4/test/ui/word-review-editor.test.tsx +0 -146
  304. package/services/react-word-editor/.tmp-a4-build/src/api/public-types.js +0 -2
  305. package/services/react-word-editor/.tmp-a4-build/src/ui/WordReviewEditor.js +0 -818
  306. package/services/react-word-editor/.tmp-a4-build/src/ui/editor-surface/editor-surface.js +0 -229
  307. package/services/react-word-editor/.tmp-a4-build/test/ui/word-review-editor.test.js +0 -121
  308. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.json +0 -21
  309. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.tsbuildinfo +0 -1
  310. package/services/react-word-editor/Dockerfile +0 -26
  311. package/services/react-word-editor/README.md +0 -254
  312. package/services/react-word-editor/app/api/certification/route.ts +0 -79
  313. package/services/react-word-editor/app/api/demo-sessions/route.ts +0 -109
  314. package/services/react-word-editor/app/api/deploy-health/route.ts +0 -23
  315. package/services/react-word-editor/app/api/exports/[exportId]/route.ts +0 -34
  316. package/services/react-word-editor/app/api/exports/route.ts +0 -81
  317. package/services/react-word-editor/app/api/fixtures/[fixtureId]/run/route.ts +0 -100
  318. package/services/react-word-editor/app/api/health/route.ts +0 -70
  319. package/services/react-word-editor/app/api/runs/[runId]/route.ts +0 -36
  320. package/services/react-word-editor/app/api/scenarios/[scenarioId]/run/route.ts +0 -85
  321. package/services/react-word-editor/app/api/sessions/[sessionId]/route.ts +0 -199
  322. package/services/react-word-editor/app/api/sessions/[sessionId]/source/route.ts +0 -45
  323. package/services/react-word-editor/app/api/uploads/route.ts +0 -70
  324. package/services/react-word-editor/app/api/validate/route.ts +0 -310
  325. package/services/react-word-editor/app/certification/[runId]/page.tsx +0 -14
  326. package/services/react-word-editor/app/certification/page.tsx +0 -32
  327. package/services/react-word-editor/app/dashboard/page.tsx +0 -7
  328. package/services/react-word-editor/app/demo/page.tsx +0 -30
  329. package/services/react-word-editor/app/demo/prototype-client.tsx +0 -1080
  330. package/services/react-word-editor/app/editor/[sessionId]/page.tsx +0 -33
  331. package/services/react-word-editor/app/fixtures/page.tsx +0 -7
  332. package/services/react-word-editor/app/globals.css +0 -121
  333. package/services/react-word-editor/app/layout.tsx +0 -32
  334. package/services/react-word-editor/app/page.tsx +0 -30
  335. package/services/react-word-editor/app/runs/[runId]/page.tsx +0 -34
  336. package/services/react-word-editor/app/wave-10-word-review/page.tsx +0 -7
  337. package/services/react-word-editor/components/harness-control-bar.tsx +0 -289
  338. package/services/react-word-editor/components/harness-editor-session-client.tsx +0 -1214
  339. package/services/react-word-editor/components/harness-workspace-page.tsx +0 -715
  340. package/services/react-word-editor/components/reduced-motion-toggle.tsx +0 -79
  341. package/services/react-word-editor/components/workspace-certification-panel.tsx +0 -307
  342. package/services/react-word-editor/lib/certification-bundle.ts +0 -796
  343. package/services/react-word-editor/lib/certification-store.ts +0 -661
  344. package/services/react-word-editor/lib/demo-fixtures.test.mjs +0 -195
  345. package/services/react-word-editor/lib/demo-fixtures.ts +0 -1519
  346. package/services/react-word-editor/lib/editor-session-summary.test.mjs +0 -68
  347. package/services/react-word-editor/lib/editor-session-summary.ts +0 -14
  348. package/services/react-word-editor/lib/editor-session.ts +0 -228
  349. package/services/react-word-editor/lib/exports-route.test.mjs +0 -32
  350. package/services/react-word-editor/lib/harness-client.ts +0 -347
  351. package/services/react-word-editor/lib/harness-config.json +0 -30
  352. package/services/react-word-editor/lib/harness-config.test.mjs +0 -31
  353. package/services/react-word-editor/lib/harness-config.ts +0 -21
  354. package/services/react-word-editor/lib/harness-editor-datastore.test.mjs +0 -220
  355. package/services/react-word-editor/lib/harness-editor-datastore.ts +0 -161
  356. package/services/react-word-editor/lib/private-mode.test.mjs +0 -42
  357. package/services/react-word-editor/lib/private-mode.ts +0 -61
  358. package/services/react-word-editor/lib/regression-report.test.mjs +0 -352
  359. package/services/react-word-editor/lib/regression-report.ts +0 -896
  360. package/services/react-word-editor/lib/run-artifacts.ts +0 -934
  361. package/services/react-word-editor/lib/run-history.ts +0 -755
  362. package/services/react-word-editor/lib/scenario-artifacts.test.mjs +0 -41
  363. package/services/react-word-editor/lib/scenario-artifacts.ts +0 -44
  364. package/services/react-word-editor/lib/storage.ts +0 -953
  365. package/services/react-word-editor/lib/validator-client.test.mjs +0 -54
  366. package/services/react-word-editor/lib/validator-client.ts +0 -95
  367. package/services/react-word-editor/lib/workspace-navigation.ts +0 -79
  368. package/services/react-word-editor/middleware.ts +0 -35
  369. package/services/react-word-editor/next-env.d.ts +0 -6
  370. package/services/react-word-editor/next.config.mjs +0 -15
  371. package/services/react-word-editor/package.json +0 -38
  372. package/services/react-word-editor/postcss.config.mjs +0 -8
  373. package/services/react-word-editor/railway.json +0 -21
  374. package/services/react-word-editor/scripts/wave-10-certification.mjs +0 -101
  375. package/services/react-word-editor/scripts/wave-9-live-usability-pilot.mjs +0 -911
  376. package/services/react-word-editor/tsconfig.json +0 -39
  377. package/services/react-word-editor/tsconfig.tsbuildinfo +0 -1
  378. package/skills/README.md +0 -48
  379. package/skills/domain-docx-compatibility/SKILL.md +0 -44
  380. package/skills/domain-docx-compatibility/skill.json +0 -19
  381. package/skills/domain-editor-architecture/SKILL.md +0 -49
  382. package/skills/domain-editor-architecture/skill.json +0 -19
  383. package/skills/domain-legal-review/SKILL.md +0 -39
  384. package/skills/domain-legal-review/skill.json +0 -19
  385. package/skills/provider-aws/SKILL.md +0 -117
  386. package/skills/provider-aws/adapters/claude.md +0 -1
  387. package/skills/provider-aws/adapters/codex.md +0 -1
  388. package/skills/provider-aws/references/service-verification.md +0 -39
  389. package/skills/provider-aws/skill.json +0 -54
  390. package/skills/provider-custom-deploy/SKILL.md +0 -64
  391. package/skills/provider-custom-deploy/skill.json +0 -50
  392. package/skills/provider-docker-compose/SKILL.md +0 -96
  393. package/skills/provider-docker-compose/adapters/local.md +0 -1
  394. package/skills/provider-docker-compose/skill.json +0 -53
  395. package/skills/provider-github-release/SKILL.md +0 -121
  396. package/skills/provider-github-release/adapters/claude.md +0 -1
  397. package/skills/provider-github-release/adapters/codex.md +0 -1
  398. package/skills/provider-github-release/skill.json +0 -55
  399. package/skills/provider-kubernetes/SKILL.md +0 -143
  400. package/skills/provider-kubernetes/adapters/claude.md +0 -1
  401. package/skills/provider-kubernetes/adapters/codex.md +0 -1
  402. package/skills/provider-kubernetes/references/kubectl-patterns.md +0 -58
  403. package/skills/provider-kubernetes/skill.json +0 -52
  404. package/skills/provider-railway/SKILL.md +0 -123
  405. package/skills/provider-railway/adapters/claude.md +0 -1
  406. package/skills/provider-railway/adapters/codex.md +0 -1
  407. package/skills/provider-railway/adapters/local.md +0 -1
  408. package/skills/provider-railway/adapters/opencode.md +0 -1
  409. package/skills/provider-railway/references/verification-commands.md +0 -39
  410. package/skills/provider-railway/skill.json +0 -71
  411. package/skills/provider-ssh-manual/SKILL.md +0 -97
  412. package/skills/provider-ssh-manual/skill.json +0 -54
  413. package/skills/repo-coding-rules/SKILL.md +0 -55
  414. package/skills/repo-coding-rules/skill.json +0 -34
  415. package/skills/role-cont-eval/SKILL.md +0 -91
  416. package/skills/role-cont-eval/adapters/codex.md +0 -1
  417. package/skills/role-cont-eval/skill.json +0 -36
  418. package/skills/role-cont-qa/SKILL.md +0 -100
  419. package/skills/role-cont-qa/adapters/claude.md +0 -1
  420. package/skills/role-cont-qa/skill.json +0 -36
  421. package/skills/role-deploy/SKILL.md +0 -97
  422. package/skills/role-deploy/skill.json +0 -36
  423. package/skills/role-design/SKILL.md +0 -50
  424. package/skills/role-design/skill.json +0 -36
  425. package/skills/role-documentation/SKILL.md +0 -76
  426. package/skills/role-documentation/skill.json +0 -36
  427. package/skills/role-implementation/SKILL.md +0 -45
  428. package/skills/role-implementation/skill.json +0 -36
  429. package/skills/role-infra/SKILL.md +0 -81
  430. package/skills/role-infra/skill.json +0 -36
  431. package/skills/role-integration/SKILL.md +0 -91
  432. package/skills/role-integration/skill.json +0 -36
  433. package/skills/role-planner/SKILL.md +0 -39
  434. package/skills/role-planner/skill.json +0 -21
  435. package/skills/role-research/SKILL.md +0 -65
  436. package/skills/role-research/skill.json +0 -36
  437. package/skills/role-security/SKILL.md +0 -60
  438. package/skills/role-security/skill.json +0 -36
  439. package/skills/runtime-claude/SKILL.md +0 -66
  440. package/skills/runtime-claude/skill.json +0 -36
  441. package/skills/runtime-codex/SKILL.md +0 -58
  442. package/skills/runtime-codex/skill.json +0 -36
  443. package/skills/runtime-local/SKILL.md +0 -46
  444. package/skills/runtime-local/skill.json +0 -36
  445. package/skills/runtime-opencode/SKILL.md +0 -58
  446. package/skills/runtime-opencode/skill.json +0 -36
  447. package/skills/signal-hygiene/SKILL.md +0 -51
  448. package/skills/signal-hygiene/skill.json +0 -20
  449. package/skills/tui-design/SKILL.md +0 -77
  450. package/skills/tui-design/references/tui-design.md +0 -259
  451. package/skills/tui-design/skill.json +0 -36
  452. package/skills/wave-core/SKILL.md +0 -141
  453. package/skills/wave-core/references/marker-syntax.md +0 -70
  454. package/skills/wave-core/skill.json +0 -35
  455. package/test/README.md +0 -16
  456. package/test/core/formatting-commands.test.ts +0 -285
  457. package/test/core/image-commands.test.ts +0 -298
  458. package/test/core/mapping.test.ts +0 -186
  459. package/test/core/text-commands.test.ts +0 -176
  460. package/test/fixtures/docx/F01-basic-contract.docx +0 -0
  461. package/test/fixtures/docx/F01-basic-contract.md +0 -33
  462. package/test/fixtures/docx/F02-headings-styles.docx +0 -0
  463. package/test/fixtures/docx/F02-headings-styles.md +0 -33
  464. package/test/fixtures/docx/F03-legal-outline-numbering.docx +0 -0
  465. package/test/fixtures/docx/F03-legal-outline-numbering.md +0 -34
  466. package/test/fixtures/docx/F04-restart-numbering-schedules.docx +0 -0
  467. package/test/fixtures/docx/F04-restart-numbering-schedules.md +0 -33
  468. package/test/fixtures/docx/F05-table-heavy-agreement.docx +0 -0
  469. package/test/fixtures/docx/F05-table-heavy-agreement.md +0 -34
  470. package/test/fixtures/docx/F06-merged-cells-signature-table.docx +0 -0
  471. package/test/fixtures/docx/F06-merged-cells-signature-table.md +0 -34
  472. package/test/fixtures/docx/F07-inline-images-exhibit.docx +0 -0
  473. package/test/fixtures/docx/F07-inline-images-exhibit.md +0 -34
  474. package/test/fixtures/docx/F08-hyperlinks.docx +0 -0
  475. package/test/fixtures/docx/F08-hyperlinks.md +0 -33
  476. package/test/fixtures/docx/F09-comments-single-paragraph.docx +0 -0
  477. package/test/fixtures/docx/F09-comments-single-paragraph.md +0 -33
  478. package/test/fixtures/docx/F10-threaded-comments-resolve.docx +0 -0
  479. package/test/fixtures/docx/F10-threaded-comments-resolve.md +0 -33
  480. package/test/fixtures/docx/F11-redlines-basic.docx +0 -0
  481. package/test/fixtures/docx/F11-redlines-basic.md +0 -33
  482. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.docx +0 -0
  483. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.md +0 -33
  484. package/test/fixtures/docx/F13-comments-on-deleted-text.docx +0 -0
  485. package/test/fixtures/docx/F13-comments-on-deleted-text.md +0 -33
  486. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.docx +0 -0
  487. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.md +0 -33
  488. package/test/fixtures/docx/F15-sections-headers-footers.docx +0 -0
  489. package/test/fixtures/docx/F15-sections-headers-footers.md +0 -33
  490. package/test/fixtures/docx/F16-footnotes-endnotes.docx +0 -0
  491. package/test/fixtures/docx/F16-footnotes-endnotes.md +0 -33
  492. package/test/fixtures/docx/F17-fields-and-toc.docx +0 -0
  493. package/test/fixtures/docx/F17-fields-and-toc.md +0 -33
  494. package/test/fixtures/docx/F18-content-controls-template.docx +0 -0
  495. package/test/fixtures/docx/F18-content-controls-template.md +0 -33
  496. package/test/fixtures/docx/F19-custom-xml-doc-assembly.docx +0 -0
  497. package/test/fixtures/docx/F19-custom-xml-doc-assembly.md +0 -35
  498. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.docx +0 -0
  499. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.md +0 -33
  500. package/test/fixtures/docx/F21-malformed-broken-docx.docx +0 -0
  501. package/test/fixtures/docx/F21-malformed-broken-docx.md +0 -33
  502. package/test/fixtures/docx/README.md +0 -74
  503. package/test/fixtures/docx/certification-manifest.json +0 -104
  504. package/test/fixtures/docx/fixtures.manifest.json +0 -196
  505. package/test/fixtures/encrypted-docx/README.md +0 -27
  506. package/test/fixtures/encrypted-docx/certification-manifest.json +0 -9
  507. package/test/fixtures/encrypted-docx/fixtures.manifest.json +0 -47
  508. package/test/fixtures/scenarios/docx/README.md +0 -25
  509. package/test/fixtures/scenarios/docx/S01-sow-template.docx +0 -0
  510. package/test/fixtures/scenarios/docx/S01-sow-template.md +0 -30
  511. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.docx +0 -0
  512. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.md +0 -32
  513. package/test/fixtures/scenarios/docx/scenario-manifest.json +0 -53
  514. package/test/formats/xlsx/io/xlsx-import.test.ts +0 -766
  515. package/test/formats/xlsx/model/workbook.test.ts +0 -669
  516. package/test/helpers/dom-setup.ts +0 -124
  517. package/test/io/comment-roundtrip.test.ts +0 -272
  518. package/test/io/complex-content-roundtrip.test.ts +0 -632
  519. package/test/io/docx-compatibility-regression.test.ts +0 -199
  520. package/test/io/docx-session.test.ts +0 -1495
  521. package/test/io/footnotes-roundtrip.test.ts +0 -318
  522. package/test/io/headers-footers-roundtrip.test.ts +0 -547
  523. package/test/io/numbering-roundtrip.test.ts +0 -234
  524. package/test/io/package-reader.test.ts +0 -199
  525. package/test/io/paragraph-properties-roundtrip.test.ts +0 -129
  526. package/test/io/preserved-package-roundtrip.test.ts +0 -365
  527. package/test/io/property-completeness.test.ts +0 -292
  528. package/test/io/revision-roundtrip.test.ts +0 -347
  529. package/test/io/structural-blocks.test.ts +0 -202
  530. package/test/io/table-media-roundtrip.test.ts +0 -448
  531. package/test/io/table-properties-roundtrip.test.ts +0 -569
  532. package/test/io/table-roundtrip.test.ts +0 -302
  533. package/test/io/text-roundtrip.test.ts +0 -344
  534. package/test/model/canonical-document.test.ts +0 -285
  535. package/test/preservation/opaque-fragment-store.test.ts +0 -121
  536. package/test/preservation/package-preservation.test.ts +0 -395
  537. package/test/preservation/store.test.ts +0 -84
  538. package/test/review/comment-remapping.test.ts +0 -220
  539. package/test/review/comment-store.test.ts +0 -180
  540. package/test/review/move-revisions.test.ts +0 -143
  541. package/test/review/property-change-revisions.test.ts +0 -225
  542. package/test/review/revision-actions.test.ts +0 -330
  543. package/test/review/revision-store.test.ts +0 -193
  544. package/test/runtime/session-capabilities.test.ts +0 -260
  545. package/test/runtime/table-commands.test.ts +0 -356
  546. package/test/runtime/table-schema.test.ts +0 -221
  547. package/test/runtime/tracked-changes-toggle.test.ts +0 -107
  548. package/test/ui/comment-review-surface.test.tsx +0 -114
  549. package/test/ui/reduced-motion-toggle.test.tsx +0 -137
  550. package/test/ui/word-review-editor.imported-scenarios.test.tsx +0 -169
  551. package/test/ui/word-review-editor.interaction.test.tsx +0 -1198
  552. package/test/ui/word-review-editor.test.js +0 -188
  553. package/test/ui/word-review-editor.test.tsx +0 -280
  554. package/test/ui-tailwind/search-plugin.test.ts +0 -286
  555. package/test/validation/compatibility-engine.test.ts +0 -336
  556. package/test/validation/compatibility-report.test.ts +0 -189
  557. package/test/validation/low-priority-word-surfaces.test.ts +0 -282
  558. package/test/validation/malformed-doc.test.ts +0 -113
  559. package/test-results/.last-run.json +0 -4
  560. package/wave.config.json +0 -406
@@ -1,818 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.WordReviewEditor = void 0;
4
- exports.__unstable_createWordReviewEditorRuntime = __unstable_createWordReviewEditorRuntime;
5
- const jsx_runtime_1 = require("react/jsx-runtime");
6
- const react_1 = require("react");
7
- const editor_surface_1 = require("./editor-surface/editor-surface");
8
- let runtimeInstanceCounter = 0;
9
- let commentCounter = 0;
10
- function createNowIsoString() {
11
- return new Date().toISOString();
12
- }
13
- function createSessionId(documentId) {
14
- runtimeInstanceCounter += 1;
15
- return `wre-${documentId}-${runtimeInstanceCounter}`;
16
- }
17
- function toUint8Array(bytes) {
18
- return bytes instanceof Uint8Array ? bytes : new Uint8Array(bytes);
19
- }
20
- function createEmptyAnchorProjection() {
21
- return {
22
- kind: "range",
23
- from: 0,
24
- to: 0,
25
- assoc: { start: 1, end: 1 },
26
- };
27
- }
28
- function createEmptySelectionSnapshot() {
29
- return {
30
- anchor: 0,
31
- head: 0,
32
- isCollapsed: true,
33
- activeRange: createEmptyAnchorProjection(),
34
- };
35
- }
36
- function createCompatibilityReport(overrides) {
37
- return {
38
- reportVersion: "compatibility-report/1",
39
- generatedAt: createNowIsoString(),
40
- blockExport: false,
41
- featureEntries: [],
42
- warnings: [],
43
- errors: [],
44
- ...overrides,
45
- };
46
- }
47
- function createEmptyCanonicalDocument(documentId) {
48
- return {
49
- schemaVersion: "cds/1.0.0",
50
- docId: `doc-${documentId}`,
51
- metadata: {},
52
- styles: {},
53
- numbering: {},
54
- media: {},
55
- content: [],
56
- review: {
57
- comments: {},
58
- revisions: {},
59
- },
60
- preservation: {},
61
- diagnostics: {},
62
- };
63
- }
64
- function createPersistedSnapshot(documentId, compatibility) {
65
- const now = createNowIsoString();
66
- return {
67
- snapshotVersion: "persisted-editor-snapshot/1",
68
- schemaVersion: "cds/1.0.0",
69
- documentId,
70
- docId: `doc-${documentId}`,
71
- createdAt: now,
72
- updatedAt: now,
73
- savedAt: now,
74
- editorBuild: "wave-2-shell",
75
- canonicalDocument: createEmptyCanonicalDocument(documentId),
76
- compatibility,
77
- warningLog: compatibility.warnings,
78
- };
79
- }
80
- function createRuntimeError(code, message, source, isFatal, details) {
81
- return {
82
- errorId: `${code}-${Math.random().toString(36).slice(2, 10)}`,
83
- code,
84
- message,
85
- isFatal,
86
- source,
87
- details,
88
- };
89
- }
90
- function buildDocumentStats(source, commentCount, changeCount) {
91
- if (!source) {
92
- return {
93
- wordCount: 0,
94
- paragraphCount: 0,
95
- commentCount,
96
- changeCount,
97
- };
98
- }
99
- if (source.kind === "snapshot") {
100
- const content = source.snapshot.canonicalDocument.content;
101
- const paragraphCount = Array.isArray(content) ? content.length : 0;
102
- return {
103
- wordCount: Math.max(32, source.snapshot.warningLog.length * 8),
104
- paragraphCount: Math.max(1, paragraphCount),
105
- commentCount,
106
- changeCount,
107
- };
108
- }
109
- const byteLength = toUint8Array(source.bytes).byteLength;
110
- return {
111
- wordCount: Math.max(32, Math.floor(byteLength / 6)),
112
- paragraphCount: Math.max(1, Math.floor(byteLength / 320)),
113
- commentCount,
114
- changeCount,
115
- };
116
- }
117
- function buildCompatibilityPanelSnapshot(report) {
118
- return {
119
- report,
120
- blockExport: report.blockExport,
121
- preserveOnlyCount: report.featureEntries.filter((entry) => entry.featureClass === "preserve-only").length,
122
- fatalCount: report.featureEntries.filter((entry) => entry.featureClass === "unsupported-fatal").length,
123
- };
124
- }
125
- function createBaseRenderSnapshot(documentId, readOnly) {
126
- const compatibility = createCompatibilityReport();
127
- return {
128
- documentId,
129
- sessionId: createSessionId(documentId),
130
- revisionToken: "initial",
131
- isReady: false,
132
- isDirty: false,
133
- readOnly,
134
- selection: createEmptySelectionSnapshot(),
135
- documentStats: {
136
- wordCount: 0,
137
- paragraphCount: 0,
138
- commentCount: 0,
139
- changeCount: 0,
140
- },
141
- comments: {
142
- commentIdsInOrder: [],
143
- threads: {},
144
- },
145
- trackedChanges: {
146
- changeIdsInOrder: [],
147
- changes: {},
148
- },
149
- compatibility: buildCompatibilityPanelSnapshot(compatibility),
150
- warnings: [],
151
- commandState: {
152
- canUndo: false,
153
- canRedo: false,
154
- canAddComment: !readOnly,
155
- canAcceptAllChanges: false,
156
- canRejectAllChanges: false,
157
- canExport: true,
158
- canSaveSnapshot: false,
159
- },
160
- };
161
- }
162
- function resolveInitialExplicitSource(props) {
163
- if (props.initialSnapshot) {
164
- return {
165
- kind: "snapshot",
166
- snapshot: props.initialSnapshot,
167
- sourceLabel: props.initialSourceLabel,
168
- };
169
- }
170
- if (props.initialDocx) {
171
- return {
172
- kind: "docx",
173
- bytes: props.initialDocx,
174
- sourceLabel: props.initialSourceLabel,
175
- };
176
- }
177
- return undefined;
178
- }
179
- function buildEditorSurfaceModel(snapshot, reviewMode, markupDisplay) {
180
- const features = snapshot.compatibility.report.featureEntries.map((entry) => ({
181
- featureEntryId: entry.featureEntryId,
182
- featureClass: entry.featureClass,
183
- message: entry.message,
184
- }));
185
- const comments = snapshot.comments.commentIdsInOrder.map((commentId) => {
186
- const thread = snapshot.comments.threads[commentId];
187
- return {
188
- commentId,
189
- preview: thread.body.slice(0, 72) || "Untitled comment",
190
- status: thread.status,
191
- isActive: snapshot.comments.openCommentId === commentId,
192
- };
193
- });
194
- const trackedChanges = snapshot.trackedChanges.changeIdsInOrder.map((changeId) => {
195
- const change = snapshot.trackedChanges.changes[changeId];
196
- return {
197
- changeId,
198
- label: `${change.kind} ${changeId}`,
199
- status: change.status,
200
- };
201
- });
202
- const warningSummary = snapshot.warnings.length === 0
203
- ? "No active runtime warnings"
204
- : `${snapshot.warnings.length} active warning${snapshot.warnings.length === 1 ? "" : "s"}`;
205
- const compatibilitySummary = snapshot.compatibility.blockExport
206
- ? "Export is blocked pending compatibility remediation"
207
- : snapshot.compatibility.report.featureEntries.length === 0
208
- ? "No compatibility findings in the current snapshot"
209
- : `${snapshot.compatibility.report.featureEntries.length} compatibility entr${snapshot.compatibility.report.featureEntries.length === 1 ? "y" : "ies"} tracked`;
210
- const activeRange = snapshot.selection.activeRange;
211
- const selectionLabel = activeRange.kind === "range"
212
- ? `${activeRange.from} → ${activeRange.to}`
213
- : activeRange.kind === "node"
214
- ? `Node at ${activeRange.at}`
215
- : `Detached (${activeRange.reason})`;
216
- return {
217
- documentId: snapshot.documentId,
218
- sessionId: snapshot.sessionId,
219
- sourceLabel: snapshot.sourceLabel,
220
- isReady: snapshot.isReady,
221
- isDirty: snapshot.isDirty,
222
- readOnly: snapshot.readOnly,
223
- reviewMode,
224
- markupDisplay,
225
- documentStats: snapshot.documentStats,
226
- selectionLabel,
227
- warningSummary,
228
- compatibilitySummary,
229
- warnings: snapshot.warnings.map((warning) => ({
230
- warningId: warning.warningId,
231
- severity: warning.severity,
232
- code: warning.code,
233
- message: warning.message,
234
- })),
235
- comments,
236
- trackedChanges,
237
- features,
238
- };
239
- }
240
- function __unstable_createWordReviewEditorRuntime(options) {
241
- let listeners = new Set();
242
- let viewportDelegate = null;
243
- let renderSnapshot = createBaseRenderSnapshot(options.documentId, options.readOnly);
244
- let persistedSnapshot = createPersistedSnapshot(options.documentId, renderSnapshot.compatibility.report);
245
- let lastExport = new Uint8Array();
246
- let destroyed = false;
247
- const notify = () => {
248
- if (destroyed) {
249
- return;
250
- }
251
- listeners.forEach((listener) => listener());
252
- };
253
- const emitEvent = (event) => {
254
- options.onEvent?.(event);
255
- options.datastore?.logEvent?.({
256
- type: event.type,
257
- documentId: event.documentId,
258
- });
259
- };
260
- const emitError = (error) => {
261
- options.onError?.(error);
262
- emitEvent({
263
- type: "error",
264
- documentId: renderSnapshot.documentId,
265
- error,
266
- });
267
- };
268
- const setDirty = (isDirty) => {
269
- if (renderSnapshot.isDirty === isDirty) {
270
- return;
271
- }
272
- renderSnapshot = {
273
- ...renderSnapshot,
274
- isDirty,
275
- };
276
- emitEvent({
277
- type: "dirty_changed",
278
- documentId: renderSnapshot.documentId,
279
- isDirty,
280
- });
281
- };
282
- const setRenderSnapshot = (nextSnapshot) => {
283
- renderSnapshot =
284
- typeof nextSnapshot === "function" ? nextSnapshot(renderSnapshot) : nextSnapshot;
285
- persistedSnapshot = {
286
- ...persistedSnapshot,
287
- documentId: renderSnapshot.documentId,
288
- updatedAt: createNowIsoString(),
289
- warningLog: renderSnapshot.warnings,
290
- compatibility: renderSnapshot.compatibility.report,
291
- };
292
- notify();
293
- };
294
- const applySource = (descriptor, revisionToken) => {
295
- const source = descriptor?.source;
296
- const sourceLabel = source?.sourceLabel ?? options.initialSourceLabel;
297
- const compatibility = source?.kind === "snapshot"
298
- ? source.snapshot.compatibility
299
- : createCompatibilityReport();
300
- const warnings = source?.kind === "snapshot" ? source.snapshot.warningLog : compatibility.warnings;
301
- const comments = {
302
- commentIdsInOrder: [],
303
- threads: {},
304
- };
305
- const trackedChanges = {
306
- changeIdsInOrder: [],
307
- changes: {},
308
- };
309
- const nextSnapshot = {
310
- ...renderSnapshot,
311
- documentId: options.documentId,
312
- sessionId: createSessionId(options.documentId),
313
- sourceLabel,
314
- revisionToken,
315
- isReady: true,
316
- isDirty: false,
317
- readOnly: options.readOnly,
318
- documentStats: buildDocumentStats(source, 0, 0),
319
- comments,
320
- trackedChanges,
321
- compatibility: buildCompatibilityPanelSnapshot(compatibility),
322
- warnings,
323
- fatalError: undefined,
324
- commandState: {
325
- canUndo: false,
326
- canRedo: false,
327
- canAddComment: !options.readOnly,
328
- canAcceptAllChanges: false,
329
- canRejectAllChanges: false,
330
- canExport: !compatibility.blockExport,
331
- canSaveSnapshot: Boolean(options.datastore),
332
- },
333
- };
334
- persistedSnapshot =
335
- source?.kind === "snapshot"
336
- ? {
337
- ...source.snapshot,
338
- documentId: options.documentId,
339
- }
340
- : createPersistedSnapshot(options.documentId, compatibility);
341
- if (source?.kind === "docx") {
342
- lastExport = toUint8Array(source.bytes);
343
- }
344
- else {
345
- lastExport = new Uint8Array();
346
- }
347
- setRenderSnapshot(nextSnapshot);
348
- warnings.forEach((warning) => options.onWarning?.(warning));
349
- emitEvent({
350
- type: "ready",
351
- documentId: options.documentId,
352
- sessionId: nextSnapshot.sessionId,
353
- source: descriptor?.sourceKind ?? "datastore",
354
- stats: nextSnapshot.documentStats,
355
- compatibility: nextSnapshot.compatibility.report,
356
- });
357
- };
358
- const handleLoadFailure = (message, details) => {
359
- const error = createRuntimeError("datastore_failed", message, "datastore", true, details);
360
- setRenderSnapshot((current) => ({
361
- ...current,
362
- isReady: true,
363
- fatalError: error,
364
- commandState: {
365
- ...current.commandState,
366
- canAddComment: false,
367
- canExport: false,
368
- canSaveSnapshot: false,
369
- },
370
- }));
371
- emitError(error);
372
- };
373
- return {
374
- subscribe(listener) {
375
- listeners.add(listener);
376
- return () => {
377
- listeners.delete(listener);
378
- };
379
- },
380
- getRenderSnapshot() {
381
- return renderSnapshot;
382
- },
383
- async initialize(runtimeOptions) {
384
- if (destroyed) {
385
- return;
386
- }
387
- if (runtimeOptions.initialSource &&
388
- options.datastore &&
389
- options.datastore.logEvent) {
390
- options.datastore.logEvent({
391
- type: "runtime_initialized",
392
- documentId: runtimeOptions.documentId,
393
- });
394
- }
395
- if (runtimeOptions.initialSource) {
396
- applySource({
397
- source: runtimeOptions.initialSource,
398
- sourceKind: runtimeOptions.initialSource.kind,
399
- }, "initial-load");
400
- return;
401
- }
402
- if (!runtimeOptions.datastore) {
403
- applySource(undefined, "empty-load");
404
- return;
405
- }
406
- setRenderSnapshot((current) => ({
407
- ...current,
408
- isReady: false,
409
- }));
410
- try {
411
- const loaded = await runtimeOptions.datastore.load({
412
- documentId: runtimeOptions.documentId,
413
- });
414
- applySource(loaded.source
415
- ? {
416
- source: loaded.source,
417
- sourceKind: "datastore",
418
- }
419
- : undefined, "datastore-load");
420
- }
421
- catch (error) {
422
- handleLoadFailure("Datastore load failed.", {
423
- cause: error instanceof Error ? error.message : String(error),
424
- });
425
- }
426
- },
427
- async replaceExternalSource(revisionToken, source) {
428
- applySource({
429
- source,
430
- sourceKind: source.kind,
431
- }, revisionToken);
432
- },
433
- focus() {
434
- viewportDelegate?.focus();
435
- },
436
- blur() {
437
- viewportDelegate?.blur();
438
- },
439
- undo() { },
440
- redo() { },
441
- addComment(params) {
442
- commentCounter += 1;
443
- const commentId = `comment-${commentCounter}`;
444
- const nextThreads = {
445
- ...renderSnapshot.comments.threads,
446
- [commentId]: {
447
- commentId,
448
- body: params.body,
449
- status: "open",
450
- anchor: params.anchor,
451
- },
452
- };
453
- const nextCommentIds = [...renderSnapshot.comments.commentIdsInOrder, commentId];
454
- const nextStats = {
455
- ...renderSnapshot.documentStats,
456
- commentCount: nextCommentIds.length,
457
- };
458
- setRenderSnapshot((current) => ({
459
- ...current,
460
- comments: {
461
- commentIdsInOrder: nextCommentIds,
462
- threads: nextThreads,
463
- openCommentId: commentId,
464
- },
465
- documentStats: nextStats,
466
- }));
467
- setDirty(true);
468
- emitEvent({
469
- type: "comment_added",
470
- documentId: renderSnapshot.documentId,
471
- commentId,
472
- anchor: params.anchor,
473
- });
474
- return commentId;
475
- },
476
- openComment(commentId) {
477
- if (!renderSnapshot.comments.threads[commentId]) {
478
- return;
479
- }
480
- setRenderSnapshot((current) => ({
481
- ...current,
482
- comments: {
483
- ...current.comments,
484
- openCommentId: commentId,
485
- },
486
- }));
487
- },
488
- resolveComment(commentId) {
489
- const thread = renderSnapshot.comments.threads[commentId];
490
- if (!thread) {
491
- return;
492
- }
493
- setRenderSnapshot((current) => ({
494
- ...current,
495
- comments: {
496
- ...current.comments,
497
- threads: {
498
- ...current.comments.threads,
499
- [commentId]: {
500
- ...thread,
501
- status: "resolved",
502
- },
503
- },
504
- },
505
- }));
506
- setDirty(true);
507
- emitEvent({
508
- type: "comment_resolved",
509
- documentId: renderSnapshot.documentId,
510
- commentId,
511
- });
512
- },
513
- acceptChange(changeId) {
514
- const change = renderSnapshot.trackedChanges.changes[changeId];
515
- if (!change) {
516
- return;
517
- }
518
- setRenderSnapshot((current) => ({
519
- ...current,
520
- trackedChanges: {
521
- ...current.trackedChanges,
522
- changes: {
523
- ...current.trackedChanges.changes,
524
- [changeId]: {
525
- ...change,
526
- status: "accepted",
527
- },
528
- },
529
- },
530
- }));
531
- setDirty(true);
532
- emitEvent({
533
- type: "change_accepted",
534
- documentId: renderSnapshot.documentId,
535
- changeId,
536
- });
537
- },
538
- rejectChange(changeId) {
539
- const change = renderSnapshot.trackedChanges.changes[changeId];
540
- if (!change) {
541
- return;
542
- }
543
- setRenderSnapshot((current) => ({
544
- ...current,
545
- trackedChanges: {
546
- ...current.trackedChanges,
547
- changes: {
548
- ...current.trackedChanges.changes,
549
- [changeId]: {
550
- ...change,
551
- status: "rejected",
552
- },
553
- },
554
- },
555
- }));
556
- setDirty(true);
557
- emitEvent({
558
- type: "change_rejected",
559
- documentId: renderSnapshot.documentId,
560
- changeId,
561
- });
562
- },
563
- acceptAllChanges() {
564
- const nextChanges = {};
565
- for (const [changeId, change] of Object.entries(renderSnapshot.trackedChanges.changes)) {
566
- nextChanges[changeId] = { ...change, status: "accepted" };
567
- }
568
- setRenderSnapshot((current) => ({
569
- ...current,
570
- trackedChanges: {
571
- ...current.trackedChanges,
572
- changes: nextChanges,
573
- },
574
- }));
575
- setDirty(true);
576
- },
577
- rejectAllChanges() {
578
- const nextChanges = {};
579
- for (const [changeId, change] of Object.entries(renderSnapshot.trackedChanges.changes)) {
580
- nextChanges[changeId] = { ...change, status: "rejected" };
581
- }
582
- setRenderSnapshot((current) => ({
583
- ...current,
584
- trackedChanges: {
585
- ...current.trackedChanges,
586
- changes: nextChanges,
587
- },
588
- }));
589
- setDirty(true);
590
- },
591
- async saveSnapshot(isAutosave) {
592
- const snapshot = {
593
- ...persistedSnapshot,
594
- updatedAt: createNowIsoString(),
595
- savedAt: createNowIsoString(),
596
- warningLog: renderSnapshot.warnings,
597
- compatibility: renderSnapshot.compatibility.report,
598
- };
599
- persistedSnapshot = snapshot;
600
- if (options.datastore) {
601
- try {
602
- await options.datastore.saveSnapshot({
603
- documentId: renderSnapshot.documentId,
604
- snapshot,
605
- isAutosave,
606
- });
607
- }
608
- catch (error) {
609
- emitError(createRuntimeError("datastore_failed", "Snapshot save failed.", "datastore", false, {
610
- cause: error instanceof Error ? error.message : String(error),
611
- }));
612
- }
613
- }
614
- emitEvent({
615
- type: "snapshot_saved",
616
- documentId: renderSnapshot.documentId,
617
- snapshot,
618
- isAutosave,
619
- });
620
- setDirty(false);
621
- return snapshot;
622
- },
623
- getPersistedSnapshot() {
624
- return persistedSnapshot;
625
- },
626
- getCompatibilityReport() {
627
- return renderSnapshot.compatibility.report;
628
- },
629
- getWarnings() {
630
- return renderSnapshot.warnings;
631
- },
632
- async exportDocx(_options) {
633
- const result = {
634
- docx: lastExport,
635
- compatibilityReport: renderSnapshot.compatibility.report,
636
- warnings: renderSnapshot.warnings,
637
- };
638
- if (options.datastore) {
639
- try {
640
- await options.datastore.saveExport({
641
- documentId: renderSnapshot.documentId,
642
- docx: result.docx,
643
- compatibilityReport: result.compatibilityReport,
644
- });
645
- }
646
- catch (error) {
647
- emitError(createRuntimeError("datastore_failed", "Export persistence failed.", "datastore", false, {
648
- cause: error instanceof Error ? error.message : String(error),
649
- }));
650
- }
651
- }
652
- emitEvent({
653
- type: "export_completed",
654
- documentId: renderSnapshot.documentId,
655
- result,
656
- });
657
- return result;
658
- },
659
- attachViewport(delegate) {
660
- viewportDelegate = delegate;
661
- },
662
- destroy() {
663
- destroyed = true;
664
- listeners.clear();
665
- viewportDelegate = null;
666
- },
667
- };
668
- }
669
- function ToolbarButton({ label, disabled, onClick, }) {
670
- return ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: onClick, disabled: disabled, style: {
671
- padding: "8px 12px",
672
- borderRadius: "12px",
673
- border: "1px solid rgba(23, 31, 38, 0.08)",
674
- background: disabled ? "rgba(241, 238, 229, 0.7)" : "rgba(255, 255, 255, 0.9)",
675
- color: disabled ? "#8b949b" : "#18212a",
676
- fontSize: "13px",
677
- cursor: disabled ? "not-allowed" : "pointer",
678
- }, children: label }));
679
- }
680
- exports.WordReviewEditor = (0, react_1.forwardRef)(function WordReviewEditor({ documentId, currentUser, initialDocx, initialSnapshot, initialSourceLabel, externalDocumentRevision, externalDocSource, readOnly = false, reviewMode = "review", markupDisplay = "all", datastore, autosave, onEvent, onWarning, onError, }, ref) {
681
- const initialSourceStateRef = (0, react_1.useRef)({
682
- initialized: false,
683
- value: undefined,
684
- });
685
- const runtimeRef = (0, react_1.useRef)(null);
686
- const canvasRef = (0, react_1.useRef)(null);
687
- const previousRevisionRef = (0, react_1.useRef)(externalDocumentRevision);
688
- if (!initialSourceStateRef.current.initialized) {
689
- initialSourceStateRef.current = {
690
- initialized: true,
691
- value: resolveInitialExplicitSource({
692
- initialDocx,
693
- initialSnapshot,
694
- initialSourceLabel,
695
- }),
696
- };
697
- }
698
- const initialSource = initialSourceStateRef.current.value;
699
- if (!runtimeRef.current) {
700
- runtimeRef.current = __unstable_createWordReviewEditorRuntime({
701
- documentId,
702
- readOnly,
703
- initialSource,
704
- initialSourceLabel,
705
- datastore,
706
- onEvent,
707
- onWarning,
708
- onError,
709
- });
710
- }
711
- const runtime = runtimeRef.current;
712
- const snapshot = (0, react_1.useSyncExternalStore)(runtime.subscribe, runtime.getRenderSnapshot, runtime.getRenderSnapshot);
713
- (0, react_1.useEffect)(() => {
714
- void runtime.initialize({
715
- documentId,
716
- initialSource,
717
- datastore,
718
- });
719
- return () => {
720
- runtime.destroy();
721
- };
722
- }, [runtime]);
723
- (0, react_1.useEffect)(() => {
724
- runtime.attachViewport({
725
- focus() {
726
- canvasRef.current?.focus();
727
- },
728
- blur() {
729
- canvasRef.current?.blur();
730
- },
731
- });
732
- return () => {
733
- runtime.attachViewport(null);
734
- };
735
- }, [runtime]);
736
- (0, react_1.useEffect)(() => {
737
- if (externalDocumentRevision &&
738
- externalDocSource &&
739
- previousRevisionRef.current !== externalDocumentRevision) {
740
- previousRevisionRef.current = externalDocumentRevision;
741
- void runtime.replaceExternalSource(externalDocumentRevision, externalDocSource);
742
- }
743
- }, [externalDocumentRevision, externalDocSource, runtime]);
744
- (0, react_1.useEffect)(() => {
745
- if (!autosave?.enabled || !snapshot.isDirty) {
746
- return;
747
- }
748
- const timeoutId = window.setTimeout(() => {
749
- void runtime.saveSnapshot(true);
750
- }, autosave.debounceMs);
751
- return () => {
752
- window.clearTimeout(timeoutId);
753
- };
754
- }, [autosave, runtime, snapshot.isDirty]);
755
- (0, react_1.useImperativeHandle)(ref, () => ({
756
- focus: () => runtime.focus(),
757
- blur: () => runtime.blur(),
758
- undo: () => runtime.undo(),
759
- redo: () => runtime.redo(),
760
- addComment: (params) => runtime.addComment(params),
761
- openComment: (commentId) => runtime.openComment(commentId),
762
- resolveComment: (commentId) => runtime.resolveComment(commentId),
763
- acceptChange: (changeId) => runtime.acceptChange(changeId),
764
- rejectChange: (changeId) => runtime.rejectChange(changeId),
765
- acceptAllChanges: () => runtime.acceptAllChanges(),
766
- rejectAllChanges: () => runtime.rejectAllChanges(),
767
- exportDocx: (options) => runtime.exportDocx(options),
768
- getSnapshot: () => runtime.getPersistedSnapshot(),
769
- getCompatibilityReport: () => runtime.getCompatibilityReport(),
770
- getWarnings: () => runtime.getWarnings(),
771
- }), [runtime]);
772
- const surfaceModel = buildEditorSurfaceModel(snapshot, reviewMode, markupDisplay);
773
- return ((0, jsx_runtime_1.jsx)("section", { "aria-label": "Word Review Editor", "data-document-id": documentId, "data-session-id": snapshot.sessionId, style: {
774
- minHeight: "100%",
775
- background: "radial-gradient(circle at top left, rgba(227, 232, 225, 0.8), transparent 34%), linear-gradient(180deg, #eef1ea 0%, #e4e8df 100%)",
776
- color: "#18212a",
777
- padding: "24px",
778
- borderRadius: "28px",
779
- }, children: (0, jsx_runtime_1.jsxs)("div", { style: {
780
- display: "grid",
781
- gap: "18px",
782
- }, children: [(0, jsx_runtime_1.jsxs)("header", { style: {
783
- display: "flex",
784
- flexWrap: "wrap",
785
- justifyContent: "space-between",
786
- gap: "14px",
787
- alignItems: "center",
788
- padding: "12px 14px",
789
- borderRadius: "18px",
790
- border: "1px solid rgba(23, 31, 38, 0.07)",
791
- background: "rgba(250, 249, 246, 0.82)",
792
- backdropFilter: "blur(10px)",
793
- }, children: [(0, jsx_runtime_1.jsxs)("div", { style: { display: "flex", gap: "8px", flexWrap: "wrap" }, children: [(0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Undo", disabled: !snapshot.commandState.canUndo, onClick: () => runtime.undo() }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Redo", disabled: !snapshot.commandState.canRedo, onClick: () => runtime.redo() }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Add comment", disabled: !snapshot.commandState.canAddComment, onClick: () => runtime.addComment({
794
- anchor: snapshot.selection.activeRange,
795
- body: `Comment from ${currentUser.displayName}`,
796
- }) }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Accept all", disabled: !snapshot.commandState.canAcceptAllChanges, onClick: () => runtime.acceptAllChanges() }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Reject all", disabled: !snapshot.commandState.canRejectAllChanges, onClick: () => runtime.rejectAllChanges() })] }), (0, jsx_runtime_1.jsxs)("div", { style: { display: "flex", gap: "8px", flexWrap: "wrap" }, children: [(0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Save snapshot", disabled: !snapshot.commandState.canSaveSnapshot, onClick: () => {
797
- void runtime.saveSnapshot(false);
798
- } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Export docx", disabled: !snapshot.commandState.canExport, onClick: () => {
799
- void runtime.exportDocx({
800
- includeCompatibilityReport: true,
801
- });
802
- } })] })] }), snapshot.fatalError ? ((0, jsx_runtime_1.jsx)("div", { role: "alert", style: {
803
- padding: "16px 18px",
804
- borderRadius: "18px",
805
- background: "rgba(242, 223, 223, 0.92)",
806
- border: "1px solid rgba(142, 59, 59, 0.25)",
807
- color: "#5f2626",
808
- }, children: snapshot.fatalError.message })) : null, (0, jsx_runtime_1.jsx)(editor_surface_1.EditorSurface, { canvasRef: canvasRef, model: surfaceModel, onOpenComment: (commentId) => runtime.openComment(commentId) }), (0, jsx_runtime_1.jsxs)("footer", { style: {
809
- display: "flex",
810
- flexWrap: "wrap",
811
- justifyContent: "space-between",
812
- gap: "12px",
813
- color: "#58646f",
814
- fontSize: "13px",
815
- padding: "0 4px",
816
- }, children: [(0, jsx_runtime_1.jsxs)("span", { children: [snapshot.isReady ? "Ready" : "Loading", " \u2022", " ", snapshot.isDirty ? "Unsaved changes" : "Clean", " \u2022 session", " ", snapshot.sessionId] }), (0, jsx_runtime_1.jsxs)("span", { children: [reviewMode, " review \u2022 ", markupDisplay, " markup \u2022", " ", snapshot.compatibility.blockExport ? "export blocked" : "export allowed"] })] })] }) }));
817
- });
818
- exports.default = exports.WordReviewEditor;