@beyondwork/docx-react-component 1.0.0 → 1.0.1

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 (704) hide show
  1. package/dist/chunk-32W6IVQE.js +7725 -0
  2. package/dist/chunk-32W6IVQE.js.map +1 -0
  3. package/dist/index.cjs +23722 -0
  4. package/dist/index.cjs.map +1 -0
  5. package/dist/index.d.cts +7 -0
  6. package/dist/index.d.ts +7 -0
  7. package/dist/index.js +16011 -0
  8. package/dist/index.js.map +1 -0
  9. package/dist/public-types-DqCURAz8.d.cts +1152 -0
  10. package/dist/public-types-DqCURAz8.d.ts +1152 -0
  11. package/dist/tailwind.cjs +8295 -0
  12. package/dist/tailwind.cjs.map +1 -0
  13. package/dist/tailwind.d.cts +323 -0
  14. package/dist/tailwind.d.ts +323 -0
  15. package/dist/tailwind.js +553 -0
  16. package/dist/tailwind.js.map +1 -0
  17. package/package.json +52 -31
  18. package/.codex/config.toml +0 -5
  19. package/.corepack/v1/pnpm/10.30.3/.corepack +0 -1
  20. package/.corepack/v1/pnpm/10.30.3/LICENSE +0 -22
  21. package/.corepack/v1/pnpm/10.30.3/README.md +0 -240
  22. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp +0 -6
  23. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp.cmd +0 -5
  24. package/.corepack/v1/pnpm/10.30.3/dist/pnpm.cjs +0 -195400
  25. package/.corepack/v1/pnpm/10.30.3/dist/pnpmrc +0 -2
  26. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-arm64-2HJ4WGO6.node +0 -0
  27. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-x64-3G3H6IW4.node +0 -0
  28. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-arm64-msvc-Q6BARPPB.node +0 -0
  29. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-x64-msvc-J2TZHRQI.node +0 -0
  30. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.bash +0 -31
  31. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.fish +0 -22
  32. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.ps1 +0 -193
  33. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.zsh +0 -27
  34. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
  35. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
  36. package/.corepack/v1/pnpm/10.30.3/dist/worker.js +0 -10119
  37. package/.corepack/v1/pnpm/10.30.3/package.json +0 -192
  38. package/.cursor/mcp.json +0 -7
  39. package/.github/workflows/ci.yml +0 -35
  40. package/.mcp.json +0 -7
  41. package/.openclaw/workspace-state.json +0 -4
  42. package/.pnpmrc.json +0 -1
  43. package/.wave-launch.sh +0 -7
  44. package/.workspace-marker +0 -1
  45. package/AGENTS.md +0 -78
  46. package/CHANGELOG.md +0 -177
  47. package/DESIGN.md +0 -929
  48. package/HEARTBEAT.md +0 -7
  49. package/IDENTITY.md +0 -23
  50. package/SOUL.md +0 -36
  51. package/TOOLS.md +0 -40
  52. package/USER.md +0 -17
  53. package/docs/README.md +0 -107
  54. package/docs/agents/wave-cont-eval-role.md +0 -36
  55. package/docs/agents/wave-cont-qa-role.md +0 -52
  56. package/docs/agents/wave-deploy-verifier-role.md +0 -34
  57. package/docs/agents/wave-design-role.md +0 -47
  58. package/docs/agents/wave-documentation-role.md +0 -34
  59. package/docs/agents/wave-infra-role.md +0 -34
  60. package/docs/agents/wave-integration-role.md +0 -37
  61. package/docs/agents/wave-launcher-role.md +0 -41
  62. package/docs/agents/wave-orchestrator-role.md +0 -52
  63. package/docs/agents/wave-planner-role.md +0 -39
  64. package/docs/agents/wave-security-role.md +0 -40
  65. package/docs/architecture/docx/README.md +0 -10
  66. package/docs/architecture/future/README.md +0 -8
  67. package/docs/architecture/ooxml-upgrade-analysis.md +0 -134
  68. package/docs/architecture/platform/shared-openxml-editor-platform.md +0 -153
  69. package/docs/architecture/xlsx/canonical-workbook-model-and-commands.md +0 -187
  70. package/docs/architecture/xlsx/spreadsheet-editor-frontend-architecture.md +0 -150
  71. package/docs/comment-redline-overview.md +0 -350
  72. package/docs/concepts/context7-vs-skills.md +0 -118
  73. package/docs/concepts/operating-modes.md +0 -91
  74. package/docs/concepts/runtime-agnostic-orchestration.md +0 -111
  75. package/docs/concepts/what-is-a-wave.md +0 -217
  76. package/docs/context7/bundles.json +0 -222
  77. package/docs/context7/planner-agent/README.md +0 -28
  78. package/docs/context7/planner-agent/manifest.json +0 -83
  79. package/docs/context7/planner-agent/papers/cooperbench-why-coding-agents-cannot-be-your-teammates-yet.md +0 -3283
  80. package/docs/context7/planner-agent/papers/dova-deliberation-first-multi-agent-orchestration-for-autonomous-research-automation.md +0 -1699
  81. package/docs/context7/planner-agent/papers/dpbench-large-language-models-struggle-with-simultaneous-coordination.md +0 -2251
  82. package/docs/context7/planner-agent/papers/incremental-planning-to-control-a-blackboard-based-problem-solver.md +0 -1729
  83. package/docs/context7/planner-agent/papers/silo-bench-a-scalable-environment-for-evaluating-distributed-coordination-in-multi-agent-llm-systems.md +0 -3747
  84. package/docs/context7/planner-agent/papers/todoevolve-learning-to-architect-agent-planning-systems.md +0 -1675
  85. package/docs/context7/planner-agent/papers/verified-multi-agent-orchestration-a-plan-execute-verify-replan-framework-for-complex-query-resolution.md +0 -1173
  86. package/docs/context7/planner-agent/papers/why-do-multi-agent-llm-systems-fail.md +0 -5211
  87. package/docs/context7/planner-agent/topics/planning-and-orchestration.md +0 -24
  88. package/docs/evals/arm-templates/README.md +0 -13
  89. package/docs/evals/arm-templates/full-wave.json +0 -15
  90. package/docs/evals/arm-templates/single-agent.json +0 -15
  91. package/docs/evals/benchmark-catalog.json +0 -670
  92. package/docs/evals/cases/README.md +0 -47
  93. package/docs/evals/cases/wave-blackboard-inbox-targeting.json +0 -73
  94. package/docs/evals/cases/wave-contradiction-conflict.json +0 -104
  95. package/docs/evals/cases/wave-expert-routing-preservation.json +0 -69
  96. package/docs/evals/cases/wave-hidden-profile-private-evidence.json +0 -81
  97. package/docs/evals/cases/wave-premature-closure-guard.json +0 -71
  98. package/docs/evals/cases/wave-silo-cross-agent-state.json +0 -77
  99. package/docs/evals/cases/wave-simultaneous-lockstep.json +0 -92
  100. package/docs/evals/external-benchmarks.json +0 -85
  101. package/docs/evals/external-command-config.sample.json +0 -9
  102. package/docs/evals/external-command-config.swe-bench-pro.json +0 -8
  103. package/docs/evals/pilots/README.md +0 -47
  104. package/docs/evals/pilots/swe-bench-pro-public-full-wave-review-10.json +0 -64
  105. package/docs/evals/pilots/swe-bench-pro-public-pilot.json +0 -111
  106. package/docs/evals/wave-benchmark-program.md +0 -302
  107. package/docs/guides/planner.md +0 -220
  108. package/docs/guides/recommendations-0.8.9.md +0 -133
  109. package/docs/guides/signal-wrappers.md +0 -165
  110. package/docs/guides/terminal-surfaces.md +0 -96
  111. package/docs/image copy.png +0 -0
  112. package/docs/image.png +0 -0
  113. package/docs/images/image.png +0 -0
  114. package/docs/legal-feedback-architecture.md +0 -498
  115. package/docs/plans/component-cutover-matrix.json +0 -1072
  116. package/docs/plans/component-cutover-matrix.md +0 -307
  117. package/docs/plans/context7-wave-orchestrator.md +0 -155
  118. package/docs/plans/current-state.md +0 -198
  119. package/docs/plans/docx/README.md +0 -9
  120. package/docs/plans/examples/wave-benchmark-improvement.md +0 -108
  121. package/docs/plans/examples/wave-example-live-proof.md +0 -435
  122. package/docs/plans/master-plan.md +0 -224
  123. package/docs/plans/migration.md +0 -538
  124. package/docs/plans/operations/README.md +0 -7
  125. package/docs/plans/operations/wave-10-word-certification.md +0 -87
  126. package/docs/plans/operations/wave-8-railway-staging.md +0 -153
  127. package/docs/plans/operations/wave-9-manual-certification.md +0 -73
  128. package/docs/plans/platform/README.md +0 -9
  129. package/docs/plans/reference/legal-checklist-coverage.md +0 -258
  130. package/docs/plans/wave-orchestrator.md +0 -423
  131. package/docs/plans/waves/README.md +0 -75
  132. package/docs/plans/waves/completed/wave-0.md +0 -195
  133. package/docs/plans/waves/completed/wave-1.md +0 -379
  134. package/docs/plans/waves/completed/wave-10.md +0 -670
  135. package/docs/plans/waves/completed/wave-11.md +0 -335
  136. package/docs/plans/waves/completed/wave-12.md +0 -417
  137. package/docs/plans/waves/completed/wave-13.md +0 -316
  138. package/docs/plans/waves/completed/wave-14.md +0 -319
  139. package/docs/plans/waves/completed/wave-15.md +0 -321
  140. package/docs/plans/waves/completed/wave-16.md +0 -316
  141. package/docs/plans/waves/completed/wave-17.md +0 -331
  142. package/docs/plans/waves/completed/wave-18.md +0 -328
  143. package/docs/plans/waves/completed/wave-2.md +0 -438
  144. package/docs/plans/waves/completed/wave-3.md +0 -435
  145. package/docs/plans/waves/completed/wave-4.md +0 -430
  146. package/docs/plans/waves/completed/wave-5.md +0 -430
  147. package/docs/plans/waves/completed/wave-6.md +0 -430
  148. package/docs/plans/waves/completed/wave-7.md +0 -526
  149. package/docs/plans/waves/completed/wave-8.md +0 -596
  150. package/docs/plans/waves/completed/wave-9.md +0 -552
  151. package/docs/plans/waves/deferred/README.md +0 -14
  152. package/docs/plans/waves/deferred/encrypted-intake-contracts.md +0 -282
  153. package/docs/plans/waves/deferred/legal-feedback-wave-expansion.md +0 -308
  154. package/docs/plans/waves/deferred/wave-encrypted-intake.md +0 -451
  155. package/docs/plans/waves/design/README.md +0 -5
  156. package/docs/plans/waves/design/wave-1-a1.md +0 -309
  157. package/docs/plans/waves/reviews/README.md +0 -5
  158. package/docs/plans/waves/reviews/wave-0-cont-qa.md +0 -151
  159. package/docs/plans/waves/reviews/wave-1-cont-qa.md +0 -46
  160. package/docs/plans/waves/reviews/wave-10-accessibility-and-design.md +0 -51
  161. package/docs/plans/waves/reviews/wave-10-cont-qa.md +0 -24
  162. package/docs/plans/waves/reviews/wave-10-dashboard-proof.md +0 -46
  163. package/docs/plans/waves/reviews/wave-10-performance-signoff.md +0 -55
  164. package/docs/plans/waves/reviews/wave-10-regression-proof.md +0 -23
  165. package/docs/plans/waves/reviews/wave-10-release-audit.md +0 -31
  166. package/docs/plans/waves/reviews/wave-10-service-proof.md +0 -83
  167. package/docs/plans/waves/reviews/wave-10-word-certification.md +0 -31
  168. package/docs/plans/waves/reviews/wave-18-ai-contract-closure.md +0 -277
  169. package/docs/plans/waves/reviews/wave-18-cont-qa.md +0 -255
  170. package/docs/plans/waves/reviews/wave-18-parity-proof.md +0 -271
  171. package/docs/plans/waves/reviews/wave-19-cont-qa.md +0 -59
  172. package/docs/plans/waves/reviews/wave-2-cont-qa.md +0 -72
  173. package/docs/plans/waves/reviews/wave-20-cont-qa.md +0 -60
  174. package/docs/plans/waves/reviews/wave-25-cont-qa.md +0 -48
  175. package/docs/plans/waves/reviews/wave-28-cont-qa.md +0 -46
  176. package/docs/plans/waves/reviews/wave-29-cont-qa.md +0 -53
  177. package/docs/plans/waves/reviews/wave-3-cont-qa.md +0 -53
  178. package/docs/plans/waves/reviews/wave-3-core-proof.md +0 -77
  179. package/docs/plans/waves/reviews/wave-3-validator-proof.md +0 -73
  180. package/docs/plans/waves/reviews/wave-32-cont-qa.md +0 -43
  181. package/docs/plans/waves/reviews/wave-33-cont-qa.md +0 -526
  182. package/docs/plans/waves/reviews/wave-34-cont-qa.md +0 -100
  183. package/docs/plans/waves/reviews/wave-35-cont-qa.md +0 -145
  184. package/docs/plans/waves/reviews/wave-4-cont-qa.md +0 -47
  185. package/docs/plans/waves/reviews/wave-4-structure-proof.md +0 -69
  186. package/docs/plans/waves/reviews/wave-5-comment-proof.md +0 -158
  187. package/docs/plans/waves/reviews/wave-5-cont-qa.md +0 -68
  188. package/docs/plans/waves/reviews/wave-6-cont-qa.md +0 -416
  189. package/docs/plans/waves/reviews/wave-6-redline-proof.md +0 -130
  190. package/docs/plans/waves/reviews/wave-7-cont-qa.md +0 -82
  191. package/docs/plans/waves/reviews/wave-7-ooxml-compliance.md +0 -85
  192. package/docs/plans/waves/reviews/wave-7-preservation-proof.md +0 -119
  193. package/docs/plans/waves/reviews/wave-7-trust-ux.md +0 -87
  194. package/docs/plans/waves/reviews/wave-8-accessibility-and-design.md +0 -128
  195. package/docs/plans/waves/reviews/wave-8-cont-qa.md +0 -92
  196. package/docs/plans/waves/reviews/wave-8-live-proof.md +0 -140
  197. package/docs/plans/waves/reviews/wave-8-security.md +0 -47
  198. package/docs/plans/waves/reviews/wave-9-editor-embedding.md +0 -39
  199. package/docs/plans/waves/reviews/wave-9-fixture-runner.md +0 -56
  200. package/docs/plans/waves/reviews/wave-9-live-proof.md +0 -105
  201. package/docs/plans/waves/reviews/wave-9-usability-and-performance.md +0 -152
  202. package/docs/plans/waves/specs/README.md +0 -5
  203. package/docs/plans/waves/specs/wave-1-component-boundaries.md +0 -322
  204. package/docs/plans/waves/specs/wave-1-ooxml-contracts.md +0 -323
  205. package/docs/plans/waves/specs/wave-1-review-and-ui-contracts.md +0 -339
  206. package/docs/plans/waves/specs/wave-1-runtime-contracts.md +0 -509
  207. package/docs/plans/waves/wave-19.md +0 -341
  208. package/docs/plans/waves/wave-20.md +0 -308
  209. package/docs/plans/waves/wave-21.md +0 -289
  210. package/docs/plans/waves/wave-22.md +0 -221
  211. package/docs/plans/waves/wave-23.md +0 -295
  212. package/docs/plans/waves/wave-24.md +0 -286
  213. package/docs/plans/waves/wave-25.md +0 -313
  214. package/docs/plans/waves/wave-26.md +0 -300
  215. package/docs/plans/waves/wave-27.md +0 -299
  216. package/docs/plans/waves/wave-28.md +0 -368
  217. package/docs/plans/waves/wave-29.md +0 -303
  218. package/docs/plans/waves/wave-30.md +0 -307
  219. package/docs/plans/waves/wave-31.md +0 -231
  220. package/docs/plans/waves/wave-32.md +0 -152
  221. package/docs/plans/waves/wave-33.md +0 -147
  222. package/docs/plans/waves/wave-34.md +0 -148
  223. package/docs/plans/waves/wave-35.md +0 -141
  224. package/docs/plans/waves/wave-36.md +0 -146
  225. package/docs/plans/xlsx/README.md +0 -14
  226. package/docs/plans/xlsx/xlsx-fixture-corpus-and-certification-plan.md +0 -126
  227. package/docs/reference/cli-reference.md +0 -600
  228. package/docs/reference/coordination-and-closure.md +0 -487
  229. package/docs/reference/deep-research-report (15).md +0 -25
  230. package/docs/reference/docx/README.md +0 -10
  231. package/docs/reference/legal-checklist.md +0 -445
  232. package/docs/reference/live-proof-waves.md +0 -199
  233. package/docs/reference/ooxml-compliance.md +0 -129
  234. package/docs/reference/ooxml-feature-parity-matrix.md +0 -172
  235. package/docs/reference/platform/shared-ooxml-platform-guidance.md +0 -77
  236. package/docs/reference/prototype-agent-prompt-legal-fidelity.md +0 -155
  237. package/docs/reference/public-api.md +0 -456
  238. package/docs/reference/repository-guidance.md +0 -58
  239. package/docs/reference/runtime-config/README.md +0 -182
  240. package/docs/reference/runtime-config/claude.md +0 -110
  241. package/docs/reference/runtime-config/codex.md +0 -82
  242. package/docs/reference/runtime-config/opencode.md +0 -93
  243. package/docs/reference/sample-waves.md +0 -105
  244. package/docs/reference/skills.md +0 -237
  245. package/docs/reference/templates/AGENTS.md +0 -78
  246. package/docs/reference/templates/HEARTBEAT.md +0 -7
  247. package/docs/reference/templates/IDENTITY.md +0 -23
  248. package/docs/reference/templates/SOUL.md +0 -36
  249. package/docs/reference/templates/TOOLS.md +0 -40
  250. package/docs/reference/templates/USER.md +0 -17
  251. package/docs/reference/wave-control.md +0 -184
  252. package/docs/reference/wave-planning-lessons.md +0 -167
  253. package/docs/reference/word-review-editor-frontend-architecture.md +0 -479
  254. package/docs/reference/word-review-editor-ux-guide.md +0 -253
  255. package/docs/reference/xlsx/xlsx-ooxml-compliance.md +0 -137
  256. package/docs/research/agent-context-sources.md +0 -178
  257. package/docs/research/coordination-failure-review.md +0 -290
  258. package/docs/research/docx-react-component/Canonical Document Schema Specification for a React-based Word-compatible Editor.md +0 -2317
  259. package/docs/research/docx-react-component/Feature Compatibility Matrix for a React Word Compatible Legal Editor v1.md +0 -219
  260. package/docs/research/docx-react-component/React Component Architecture and Front-End Structure Specification for a Word-Compatible Legal Review Editor.md +0 -1112
  261. package/docs/research/docx-react-component/document_compatibility_and_testing_spec.md +0 -751
  262. package/docs/research/xlsx/raw/README.md +0 -13
  263. package/docs/roadmap.md +0 -174
  264. package/docs/superpowers/plans/2026-03-28-harness-control-bar.md +0 -677
  265. package/docs/superpowers/specs/2026-03-28-harness-control-bar-design.md +0 -274
  266. package/docs/xlsx-react/README.md +0 -38
  267. package/docs/xlsx-react/agent-llm-interaction-layer-docx-xlsx.md +0 -621
  268. package/docs/xlsx-react/canonical-workbook-model-and-commands.md +0 -948
  269. package/docs/xlsx-react/shared-openxml-editor-platform-docx-xlsx.md +0 -228
  270. package/docs/xlsx-react/spreadsheet-editor-component-architecture.md +0 -809
  271. package/docs/xlsx-react/spreadsheet-editor-frontend-architecture.md +0 -537
  272. package/docs/xlsx-react/spreadsheet-editor-ux-guide.md +0 -520
  273. package/docs/xlsx-react/xlsx-editor-research-pack.md +0 -871
  274. package/docs/xlsx-react/xlsx-fixture-corpus-and-certification-plan.md +0 -436
  275. package/docs/xlsx-react/xlsx-ooxml-compliance.md +0 -320
  276. package/examples/README.md +0 -16
  277. package/memory/MEMORY.md +0 -24
  278. package/pnpm-workspace.yaml +0 -4
  279. package/scripts/check-no-authored-js.sh +0 -13
  280. package/scripts/context7-api-check.sh +0 -65
  281. package/scripts/context7-export-env.sh +0 -42
  282. package/scripts/run-context7-mcp.sh +0 -8
  283. package/scripts/run-workspace-tests.sh +0 -15
  284. package/scripts/start-wave-10-local.sh +0 -189
  285. package/scripts/wave-agent-attach.sh +0 -47
  286. package/scripts/wave-auto-answer.sh +0 -118
  287. package/scripts/wave-dashboard-attach.sh +0 -13
  288. package/scripts/wave-launch.sh +0 -273
  289. package/scripts/wave-overnight-supervisor.sh +0 -145
  290. package/scripts/wave-status.sh +0 -379
  291. package/scripts/wave-watch.sh +0 -231
  292. package/services/README.md +0 -17
  293. package/services/openxml-validator/Dockerfile +0 -29
  294. package/services/openxml-validator/OpenXmlValidator.Api.csproj +0 -12
  295. package/services/openxml-validator/Program.cs +0 -436
  296. package/services/openxml-validator/README.md +0 -152
  297. package/services/openxml-validator/railway.json +0 -16
  298. package/services/react-word-editor/.tmp-a4/src/api/public-types.ts +0 -318
  299. package/services/react-word-editor/.tmp-a4/src/ui/WordReviewEditor.tsx +0 -1302
  300. package/services/react-word-editor/.tmp-a4/src/ui/editor-surface/editor-surface.tsx +0 -546
  301. package/services/react-word-editor/.tmp-a4/test/ui/word-review-editor.test.tsx +0 -146
  302. package/services/react-word-editor/.tmp-a4-build/src/api/public-types.js +0 -2
  303. package/services/react-word-editor/.tmp-a4-build/src/ui/WordReviewEditor.js +0 -818
  304. package/services/react-word-editor/.tmp-a4-build/src/ui/editor-surface/editor-surface.js +0 -229
  305. package/services/react-word-editor/.tmp-a4-build/test/ui/word-review-editor.test.js +0 -121
  306. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.json +0 -21
  307. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.tsbuildinfo +0 -1
  308. package/services/react-word-editor/Dockerfile +0 -26
  309. package/services/react-word-editor/README.md +0 -254
  310. package/services/react-word-editor/app/api/certification/route.ts +0 -79
  311. package/services/react-word-editor/app/api/demo-sessions/route.ts +0 -109
  312. package/services/react-word-editor/app/api/deploy-health/route.ts +0 -23
  313. package/services/react-word-editor/app/api/exports/[exportId]/route.ts +0 -34
  314. package/services/react-word-editor/app/api/exports/route.ts +0 -81
  315. package/services/react-word-editor/app/api/fixtures/[fixtureId]/run/route.ts +0 -100
  316. package/services/react-word-editor/app/api/health/route.ts +0 -70
  317. package/services/react-word-editor/app/api/runs/[runId]/route.ts +0 -36
  318. package/services/react-word-editor/app/api/scenarios/[scenarioId]/run/route.ts +0 -85
  319. package/services/react-word-editor/app/api/sessions/[sessionId]/route.ts +0 -199
  320. package/services/react-word-editor/app/api/sessions/[sessionId]/source/route.ts +0 -45
  321. package/services/react-word-editor/app/api/uploads/route.ts +0 -70
  322. package/services/react-word-editor/app/api/validate/route.ts +0 -310
  323. package/services/react-word-editor/app/certification/[runId]/page.tsx +0 -14
  324. package/services/react-word-editor/app/certification/page.tsx +0 -32
  325. package/services/react-word-editor/app/dashboard/page.tsx +0 -7
  326. package/services/react-word-editor/app/demo/page.tsx +0 -30
  327. package/services/react-word-editor/app/demo/prototype-client.tsx +0 -1080
  328. package/services/react-word-editor/app/editor/[sessionId]/page.tsx +0 -33
  329. package/services/react-word-editor/app/fixtures/page.tsx +0 -7
  330. package/services/react-word-editor/app/globals.css +0 -121
  331. package/services/react-word-editor/app/layout.tsx +0 -32
  332. package/services/react-word-editor/app/page.tsx +0 -30
  333. package/services/react-word-editor/app/runs/[runId]/page.tsx +0 -34
  334. package/services/react-word-editor/app/wave-10-word-review/page.tsx +0 -7
  335. package/services/react-word-editor/components/harness-control-bar.tsx +0 -289
  336. package/services/react-word-editor/components/harness-editor-session-client.tsx +0 -1214
  337. package/services/react-word-editor/components/harness-workspace-page.tsx +0 -715
  338. package/services/react-word-editor/components/reduced-motion-toggle.tsx +0 -79
  339. package/services/react-word-editor/components/workspace-certification-panel.tsx +0 -307
  340. package/services/react-word-editor/lib/certification-bundle.ts +0 -796
  341. package/services/react-word-editor/lib/certification-store.ts +0 -661
  342. package/services/react-word-editor/lib/demo-fixtures.test.mjs +0 -195
  343. package/services/react-word-editor/lib/demo-fixtures.ts +0 -1519
  344. package/services/react-word-editor/lib/editor-session-summary.test.mjs +0 -68
  345. package/services/react-word-editor/lib/editor-session-summary.ts +0 -14
  346. package/services/react-word-editor/lib/editor-session.ts +0 -228
  347. package/services/react-word-editor/lib/exports-route.test.mjs +0 -32
  348. package/services/react-word-editor/lib/harness-client.ts +0 -347
  349. package/services/react-word-editor/lib/harness-config.json +0 -30
  350. package/services/react-word-editor/lib/harness-config.test.mjs +0 -31
  351. package/services/react-word-editor/lib/harness-config.ts +0 -21
  352. package/services/react-word-editor/lib/harness-editor-datastore.test.mjs +0 -220
  353. package/services/react-word-editor/lib/harness-editor-datastore.ts +0 -161
  354. package/services/react-word-editor/lib/private-mode.test.mjs +0 -42
  355. package/services/react-word-editor/lib/private-mode.ts +0 -61
  356. package/services/react-word-editor/lib/regression-report.test.mjs +0 -352
  357. package/services/react-word-editor/lib/regression-report.ts +0 -896
  358. package/services/react-word-editor/lib/run-artifacts.ts +0 -934
  359. package/services/react-word-editor/lib/run-history.ts +0 -755
  360. package/services/react-word-editor/lib/scenario-artifacts.test.mjs +0 -41
  361. package/services/react-word-editor/lib/scenario-artifacts.ts +0 -44
  362. package/services/react-word-editor/lib/storage.ts +0 -953
  363. package/services/react-word-editor/lib/validator-client.test.mjs +0 -54
  364. package/services/react-word-editor/lib/validator-client.ts +0 -95
  365. package/services/react-word-editor/lib/workspace-navigation.ts +0 -79
  366. package/services/react-word-editor/middleware.ts +0 -35
  367. package/services/react-word-editor/next-env.d.ts +0 -6
  368. package/services/react-word-editor/next.config.mjs +0 -15
  369. package/services/react-word-editor/package.json +0 -38
  370. package/services/react-word-editor/postcss.config.mjs +0 -8
  371. package/services/react-word-editor/railway.json +0 -21
  372. package/services/react-word-editor/scripts/wave-10-certification.mjs +0 -101
  373. package/services/react-word-editor/scripts/wave-9-live-usability-pilot.mjs +0 -911
  374. package/services/react-word-editor/tsconfig.json +0 -39
  375. package/services/react-word-editor/tsconfig.tsbuildinfo +0 -1
  376. package/skills/README.md +0 -48
  377. package/skills/domain-docx-compatibility/SKILL.md +0 -44
  378. package/skills/domain-docx-compatibility/skill.json +0 -19
  379. package/skills/domain-editor-architecture/SKILL.md +0 -49
  380. package/skills/domain-editor-architecture/skill.json +0 -19
  381. package/skills/domain-legal-review/SKILL.md +0 -39
  382. package/skills/domain-legal-review/skill.json +0 -19
  383. package/skills/provider-aws/SKILL.md +0 -117
  384. package/skills/provider-aws/adapters/claude.md +0 -1
  385. package/skills/provider-aws/adapters/codex.md +0 -1
  386. package/skills/provider-aws/references/service-verification.md +0 -39
  387. package/skills/provider-aws/skill.json +0 -54
  388. package/skills/provider-custom-deploy/SKILL.md +0 -64
  389. package/skills/provider-custom-deploy/skill.json +0 -50
  390. package/skills/provider-docker-compose/SKILL.md +0 -96
  391. package/skills/provider-docker-compose/adapters/local.md +0 -1
  392. package/skills/provider-docker-compose/skill.json +0 -53
  393. package/skills/provider-github-release/SKILL.md +0 -121
  394. package/skills/provider-github-release/adapters/claude.md +0 -1
  395. package/skills/provider-github-release/adapters/codex.md +0 -1
  396. package/skills/provider-github-release/skill.json +0 -55
  397. package/skills/provider-kubernetes/SKILL.md +0 -143
  398. package/skills/provider-kubernetes/adapters/claude.md +0 -1
  399. package/skills/provider-kubernetes/adapters/codex.md +0 -1
  400. package/skills/provider-kubernetes/references/kubectl-patterns.md +0 -58
  401. package/skills/provider-kubernetes/skill.json +0 -52
  402. package/skills/provider-railway/SKILL.md +0 -123
  403. package/skills/provider-railway/adapters/claude.md +0 -1
  404. package/skills/provider-railway/adapters/codex.md +0 -1
  405. package/skills/provider-railway/adapters/local.md +0 -1
  406. package/skills/provider-railway/adapters/opencode.md +0 -1
  407. package/skills/provider-railway/references/verification-commands.md +0 -39
  408. package/skills/provider-railway/skill.json +0 -71
  409. package/skills/provider-ssh-manual/SKILL.md +0 -97
  410. package/skills/provider-ssh-manual/skill.json +0 -54
  411. package/skills/repo-coding-rules/SKILL.md +0 -55
  412. package/skills/repo-coding-rules/skill.json +0 -34
  413. package/skills/role-cont-eval/SKILL.md +0 -91
  414. package/skills/role-cont-eval/adapters/codex.md +0 -1
  415. package/skills/role-cont-eval/skill.json +0 -36
  416. package/skills/role-cont-qa/SKILL.md +0 -100
  417. package/skills/role-cont-qa/adapters/claude.md +0 -1
  418. package/skills/role-cont-qa/skill.json +0 -36
  419. package/skills/role-deploy/SKILL.md +0 -97
  420. package/skills/role-deploy/skill.json +0 -36
  421. package/skills/role-design/SKILL.md +0 -50
  422. package/skills/role-design/skill.json +0 -36
  423. package/skills/role-documentation/SKILL.md +0 -76
  424. package/skills/role-documentation/skill.json +0 -36
  425. package/skills/role-implementation/SKILL.md +0 -45
  426. package/skills/role-implementation/skill.json +0 -36
  427. package/skills/role-infra/SKILL.md +0 -81
  428. package/skills/role-infra/skill.json +0 -36
  429. package/skills/role-integration/SKILL.md +0 -91
  430. package/skills/role-integration/skill.json +0 -36
  431. package/skills/role-planner/SKILL.md +0 -39
  432. package/skills/role-planner/skill.json +0 -21
  433. package/skills/role-research/SKILL.md +0 -65
  434. package/skills/role-research/skill.json +0 -36
  435. package/skills/role-security/SKILL.md +0 -60
  436. package/skills/role-security/skill.json +0 -36
  437. package/skills/runtime-claude/SKILL.md +0 -66
  438. package/skills/runtime-claude/skill.json +0 -36
  439. package/skills/runtime-codex/SKILL.md +0 -58
  440. package/skills/runtime-codex/skill.json +0 -36
  441. package/skills/runtime-local/SKILL.md +0 -46
  442. package/skills/runtime-local/skill.json +0 -36
  443. package/skills/runtime-opencode/SKILL.md +0 -58
  444. package/skills/runtime-opencode/skill.json +0 -36
  445. package/skills/signal-hygiene/SKILL.md +0 -51
  446. package/skills/signal-hygiene/skill.json +0 -20
  447. package/skills/tui-design/SKILL.md +0 -77
  448. package/skills/tui-design/references/tui-design.md +0 -259
  449. package/skills/tui-design/skill.json +0 -36
  450. package/skills/wave-core/SKILL.md +0 -141
  451. package/skills/wave-core/references/marker-syntax.md +0 -70
  452. package/skills/wave-core/skill.json +0 -35
  453. package/src/README.md +0 -85
  454. package/src/api/README.md +0 -22
  455. package/src/api/public-types.ts +0 -525
  456. package/src/component-inventory.md +0 -99
  457. package/src/core/README.md +0 -10
  458. package/src/core/commands/README.md +0 -3
  459. package/src/core/commands/formatting-commands.ts +0 -161
  460. package/src/core/commands/image-commands.ts +0 -144
  461. package/src/core/commands/index.ts +0 -1013
  462. package/src/core/commands/list-commands.ts +0 -370
  463. package/src/core/commands/review-commands.ts +0 -108
  464. package/src/core/commands/text-commands.ts +0 -119
  465. package/src/core/schema/README.md +0 -3
  466. package/src/core/schema/text-schema.ts +0 -512
  467. package/src/core/selection/README.md +0 -3
  468. package/src/core/selection/mapping.ts +0 -238
  469. package/src/core/selection/review-anchors.ts +0 -94
  470. package/src/core/state/README.md +0 -3
  471. package/src/core/state/editor-state.ts +0 -580
  472. package/src/core/state/text-transaction.ts +0 -276
  473. package/src/formats/xlsx/io/parse-shared-strings.ts +0 -41
  474. package/src/formats/xlsx/io/parse-sheet.ts +0 -289
  475. package/src/formats/xlsx/io/parse-styles.ts +0 -57
  476. package/src/formats/xlsx/io/parse-workbook.ts +0 -75
  477. package/src/formats/xlsx/io/xlsx-session.ts +0 -306
  478. package/src/formats/xlsx/model/cell.ts +0 -189
  479. package/src/formats/xlsx/model/sheet.ts +0 -244
  480. package/src/formats/xlsx/model/styles.ts +0 -118
  481. package/src/formats/xlsx/model/workbook.ts +0 -449
  482. package/src/io/README.md +0 -10
  483. package/src/io/docx-session.ts +0 -1763
  484. package/src/io/export/README.md +0 -3
  485. package/src/io/export/export-session.ts +0 -165
  486. package/src/io/export/minimal-docx.ts +0 -115
  487. package/src/io/export/reattach-preserved-parts.ts +0 -54
  488. package/src/io/export/serialize-comments.ts +0 -876
  489. package/src/io/export/serialize-footnotes.ts +0 -217
  490. package/src/io/export/serialize-headers-footers.ts +0 -200
  491. package/src/io/export/serialize-main-document.ts +0 -982
  492. package/src/io/export/serialize-numbering.ts +0 -97
  493. package/src/io/export/serialize-revisions.ts +0 -389
  494. package/src/io/export/serialize-runtime-revisions.ts +0 -265
  495. package/src/io/export/serialize-tables.ts +0 -147
  496. package/src/io/export/split-review-boundaries.ts +0 -194
  497. package/src/io/normalize/README.md +0 -3
  498. package/src/io/normalize/normalize-text.ts +0 -437
  499. package/src/io/ooxml/README.md +0 -3
  500. package/src/io/ooxml/parse-comments.ts +0 -779
  501. package/src/io/ooxml/parse-complex-content.ts +0 -287
  502. package/src/io/ooxml/parse-fields.ts +0 -438
  503. package/src/io/ooxml/parse-footnotes.ts +0 -403
  504. package/src/io/ooxml/parse-headers-footers.ts +0 -483
  505. package/src/io/ooxml/parse-inline-media.ts +0 -431
  506. package/src/io/ooxml/parse-main-document.ts +0 -1846
  507. package/src/io/ooxml/parse-numbering.ts +0 -425
  508. package/src/io/ooxml/parse-revisions.ts +0 -658
  509. package/src/io/ooxml/parse-shapes.ts +0 -271
  510. package/src/io/ooxml/parse-tables.ts +0 -568
  511. package/src/io/ooxml/parse-theme.ts +0 -314
  512. package/src/io/ooxml/part-manifest.ts +0 -136
  513. package/src/io/ooxml/revision-boundaries.ts +0 -351
  514. package/src/io/opc/README.md +0 -3
  515. package/src/io/opc/corrupt-package.ts +0 -166
  516. package/src/io/opc/docx-package.ts +0 -74
  517. package/src/io/opc/package-reader.ts +0 -320
  518. package/src/io/opc/package-writer.ts +0 -273
  519. package/src/model/README.md +0 -3
  520. package/src/model/canonical-document.ts +0 -1911
  521. package/src/model/cds-1.0.0.ts +0 -196
  522. package/src/model/snapshot.ts +0 -393
  523. package/src/preservation/README.md +0 -3
  524. package/src/preservation/markup-compatibility.ts +0 -48
  525. package/src/preservation/opaque-fragment-store.ts +0 -89
  526. package/src/preservation/opaque-region.ts +0 -233
  527. package/src/preservation/package-preservation.ts +0 -120
  528. package/src/preservation/preserved-part-manifest.ts +0 -56
  529. package/src/preservation/relationship-retention.ts +0 -57
  530. package/src/preservation/store.ts +0 -185
  531. package/src/review/README.md +0 -16
  532. package/src/review/store/README.md +0 -3
  533. package/src/review/store/comment-anchors.ts +0 -70
  534. package/src/review/store/comment-remapping.ts +0 -154
  535. package/src/review/store/comment-store.ts +0 -331
  536. package/src/review/store/comment-thread.ts +0 -109
  537. package/src/review/store/revision-actions.ts +0 -394
  538. package/src/review/store/revision-store.ts +0 -303
  539. package/src/review/store/revision-types.ts +0 -168
  540. package/src/review/store/runtime-comment-store.ts +0 -43
  541. package/src/runtime/README.md +0 -3
  542. package/src/runtime/ai-action-policy.ts +0 -764
  543. package/src/runtime/document-runtime.ts +0 -969
  544. package/src/runtime/read-only-diagnostics-runtime.ts +0 -232
  545. package/src/runtime/review-runtime.ts +0 -44
  546. package/src/runtime/revision-runtime.ts +0 -107
  547. package/src/runtime/session-capabilities.ts +0 -138
  548. package/src/runtime/surface-projection.ts +0 -570
  549. package/src/runtime/table-commands.ts +0 -84
  550. package/src/runtime/table-schema.ts +0 -125
  551. package/src/ui/README.md +0 -30
  552. package/src/ui/WordReviewEditor.tsx +0 -1283
  553. package/src/ui/comments/README.md +0 -3
  554. package/src/ui/compatibility/README.md +0 -3
  555. package/src/ui/editor-surface/README.md +0 -3
  556. package/src/ui/headless/comment-decoration-model.ts +0 -124
  557. package/src/ui/headless/revision-decoration-model.ts +0 -128
  558. package/src/ui/headless/selection-helpers.ts +0 -34
  559. package/src/ui/headless/use-editor-keyboard.ts +0 -98
  560. package/src/ui/review/README.md +0 -3
  561. package/src/ui/shared/revision-filters.ts +0 -31
  562. package/src/ui/status/README.md +0 -3
  563. package/src/ui/theme/README.md +0 -3
  564. package/src/ui/toolbar/README.md +0 -3
  565. package/src/ui-tailwind/chrome/tw-alert-banner.tsx +0 -48
  566. package/src/ui-tailwind/chrome/tw-selection-toolbar.tsx +0 -44
  567. package/src/ui-tailwind/chrome/tw-unsaved-modal.tsx +0 -58
  568. package/src/ui-tailwind/chrome/use-before-unload.ts +0 -20
  569. package/src/ui-tailwind/editor-surface/pm-command-bridge.ts +0 -139
  570. package/src/ui-tailwind/editor-surface/pm-decorations.ts +0 -98
  571. package/src/ui-tailwind/editor-surface/pm-position-map.ts +0 -123
  572. package/src/ui-tailwind/editor-surface/pm-schema.ts +0 -452
  573. package/src/ui-tailwind/editor-surface/pm-state-from-snapshot.ts +0 -327
  574. package/src/ui-tailwind/editor-surface/search-plugin.ts +0 -157
  575. package/src/ui-tailwind/editor-surface/tw-caret.tsx +0 -12
  576. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +0 -150
  577. package/src/ui-tailwind/editor-surface/tw-inline-token.tsx +0 -118
  578. package/src/ui-tailwind/editor-surface/tw-opaque-block.tsx +0 -52
  579. package/src/ui-tailwind/editor-surface/tw-paragraph-block.tsx +0 -151
  580. package/src/ui-tailwind/editor-surface/tw-prosemirror-surface.tsx +0 -215
  581. package/src/ui-tailwind/editor-surface/tw-segment-view.tsx +0 -111
  582. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +0 -108
  583. package/src/ui-tailwind/index.ts +0 -61
  584. package/src/ui-tailwind/review/tw-comment-sidebar.tsx +0 -276
  585. package/src/ui-tailwind/review/tw-health-panel.tsx +0 -120
  586. package/src/ui-tailwind/review/tw-review-rail.tsx +0 -120
  587. package/src/ui-tailwind/review/tw-revision-sidebar.tsx +0 -164
  588. package/src/ui-tailwind/status/tw-status-bar.tsx +0 -58
  589. package/src/ui-tailwind/theme/editor-theme.css +0 -190
  590. package/src/ui-tailwind/toolbar/tw-toolbar-icon-button.tsx +0 -48
  591. package/src/ui-tailwind/toolbar/tw-toolbar.tsx +0 -231
  592. package/src/ui-tailwind/tw-review-workspace.tsx +0 -140
  593. package/src/validation/README.md +0 -3
  594. package/src/validation/compatibility-engine.ts +0 -317
  595. package/src/validation/compatibility-report.ts +0 -160
  596. package/src/validation/diagnostics.ts +0 -203
  597. package/src/validation/import-diagnostics.ts +0 -128
  598. package/src/validation/low-priority-word-surfaces.ts +0 -373
  599. package/test/README.md +0 -16
  600. package/test/core/formatting-commands.test.ts +0 -285
  601. package/test/core/image-commands.test.ts +0 -298
  602. package/test/core/mapping.test.ts +0 -186
  603. package/test/core/text-commands.test.ts +0 -176
  604. package/test/fixtures/docx/F01-basic-contract.docx +0 -0
  605. package/test/fixtures/docx/F01-basic-contract.md +0 -33
  606. package/test/fixtures/docx/F02-headings-styles.docx +0 -0
  607. package/test/fixtures/docx/F02-headings-styles.md +0 -33
  608. package/test/fixtures/docx/F03-legal-outline-numbering.docx +0 -0
  609. package/test/fixtures/docx/F03-legal-outline-numbering.md +0 -34
  610. package/test/fixtures/docx/F04-restart-numbering-schedules.docx +0 -0
  611. package/test/fixtures/docx/F04-restart-numbering-schedules.md +0 -33
  612. package/test/fixtures/docx/F05-table-heavy-agreement.docx +0 -0
  613. package/test/fixtures/docx/F05-table-heavy-agreement.md +0 -34
  614. package/test/fixtures/docx/F06-merged-cells-signature-table.docx +0 -0
  615. package/test/fixtures/docx/F06-merged-cells-signature-table.md +0 -34
  616. package/test/fixtures/docx/F07-inline-images-exhibit.docx +0 -0
  617. package/test/fixtures/docx/F07-inline-images-exhibit.md +0 -34
  618. package/test/fixtures/docx/F08-hyperlinks.docx +0 -0
  619. package/test/fixtures/docx/F08-hyperlinks.md +0 -33
  620. package/test/fixtures/docx/F09-comments-single-paragraph.docx +0 -0
  621. package/test/fixtures/docx/F09-comments-single-paragraph.md +0 -33
  622. package/test/fixtures/docx/F10-threaded-comments-resolve.docx +0 -0
  623. package/test/fixtures/docx/F10-threaded-comments-resolve.md +0 -33
  624. package/test/fixtures/docx/F11-redlines-basic.docx +0 -0
  625. package/test/fixtures/docx/F11-redlines-basic.md +0 -33
  626. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.docx +0 -0
  627. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.md +0 -33
  628. package/test/fixtures/docx/F13-comments-on-deleted-text.docx +0 -0
  629. package/test/fixtures/docx/F13-comments-on-deleted-text.md +0 -33
  630. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.docx +0 -0
  631. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.md +0 -33
  632. package/test/fixtures/docx/F15-sections-headers-footers.docx +0 -0
  633. package/test/fixtures/docx/F15-sections-headers-footers.md +0 -33
  634. package/test/fixtures/docx/F16-footnotes-endnotes.docx +0 -0
  635. package/test/fixtures/docx/F16-footnotes-endnotes.md +0 -33
  636. package/test/fixtures/docx/F17-fields-and-toc.docx +0 -0
  637. package/test/fixtures/docx/F17-fields-and-toc.md +0 -33
  638. package/test/fixtures/docx/F18-content-controls-template.docx +0 -0
  639. package/test/fixtures/docx/F18-content-controls-template.md +0 -33
  640. package/test/fixtures/docx/F19-custom-xml-doc-assembly.docx +0 -0
  641. package/test/fixtures/docx/F19-custom-xml-doc-assembly.md +0 -35
  642. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.docx +0 -0
  643. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.md +0 -33
  644. package/test/fixtures/docx/F21-malformed-broken-docx.docx +0 -0
  645. package/test/fixtures/docx/F21-malformed-broken-docx.md +0 -33
  646. package/test/fixtures/docx/README.md +0 -74
  647. package/test/fixtures/docx/certification-manifest.json +0 -104
  648. package/test/fixtures/docx/fixtures.manifest.json +0 -196
  649. package/test/fixtures/encrypted-docx/README.md +0 -27
  650. package/test/fixtures/encrypted-docx/certification-manifest.json +0 -9
  651. package/test/fixtures/encrypted-docx/fixtures.manifest.json +0 -47
  652. package/test/fixtures/scenarios/docx/README.md +0 -25
  653. package/test/fixtures/scenarios/docx/S01-sow-template.docx +0 -0
  654. package/test/fixtures/scenarios/docx/S01-sow-template.md +0 -30
  655. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.docx +0 -0
  656. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.md +0 -32
  657. package/test/fixtures/scenarios/docx/scenario-manifest.json +0 -53
  658. package/test/formats/xlsx/io/xlsx-import.test.ts +0 -766
  659. package/test/formats/xlsx/model/workbook.test.ts +0 -669
  660. package/test/helpers/dom-setup.ts +0 -124
  661. package/test/io/comment-roundtrip.test.ts +0 -272
  662. package/test/io/complex-content-roundtrip.test.ts +0 -632
  663. package/test/io/docx-compatibility-regression.test.ts +0 -199
  664. package/test/io/docx-session.test.ts +0 -1495
  665. package/test/io/footnotes-roundtrip.test.ts +0 -318
  666. package/test/io/headers-footers-roundtrip.test.ts +0 -547
  667. package/test/io/numbering-roundtrip.test.ts +0 -234
  668. package/test/io/package-reader.test.ts +0 -199
  669. package/test/io/paragraph-properties-roundtrip.test.ts +0 -129
  670. package/test/io/preserved-package-roundtrip.test.ts +0 -365
  671. package/test/io/property-completeness.test.ts +0 -292
  672. package/test/io/revision-roundtrip.test.ts +0 -347
  673. package/test/io/structural-blocks.test.ts +0 -202
  674. package/test/io/table-media-roundtrip.test.ts +0 -448
  675. package/test/io/table-properties-roundtrip.test.ts +0 -569
  676. package/test/io/table-roundtrip.test.ts +0 -302
  677. package/test/io/text-roundtrip.test.ts +0 -344
  678. package/test/model/canonical-document.test.ts +0 -285
  679. package/test/preservation/opaque-fragment-store.test.ts +0 -121
  680. package/test/preservation/package-preservation.test.ts +0 -395
  681. package/test/preservation/store.test.ts +0 -84
  682. package/test/review/comment-remapping.test.ts +0 -220
  683. package/test/review/comment-store.test.ts +0 -180
  684. package/test/review/move-revisions.test.ts +0 -143
  685. package/test/review/property-change-revisions.test.ts +0 -225
  686. package/test/review/revision-actions.test.ts +0 -330
  687. package/test/review/revision-store.test.ts +0 -193
  688. package/test/runtime/session-capabilities.test.ts +0 -260
  689. package/test/runtime/table-commands.test.ts +0 -356
  690. package/test/runtime/table-schema.test.ts +0 -221
  691. package/test/runtime/tracked-changes-toggle.test.ts +0 -107
  692. package/test/ui/comment-review-surface.test.tsx +0 -114
  693. package/test/ui/reduced-motion-toggle.test.tsx +0 -137
  694. package/test/ui/word-review-editor.imported-scenarios.test.tsx +0 -169
  695. package/test/ui/word-review-editor.interaction.test.tsx +0 -1198
  696. package/test/ui/word-review-editor.test.js +0 -188
  697. package/test/ui/word-review-editor.test.tsx +0 -280
  698. package/test/ui-tailwind/search-plugin.test.ts +0 -286
  699. package/test/validation/compatibility-engine.test.ts +0 -336
  700. package/test/validation/compatibility-report.test.ts +0 -189
  701. package/test/validation/low-priority-word-surfaces.test.ts +0 -282
  702. package/test/validation/malformed-doc.test.ts +0 -113
  703. package/test-results/.last-run.json +0 -4
  704. package/wave.config.json +0 -406
@@ -1,1519 +0,0 @@
1
- /**
2
- * Demo fixtures aligned to the real product type system.
3
- *
4
- * These types mirror src/api/public-types.ts structurally so the prototype
5
- * renders from the same shapes the real RuntimeRenderSnapshot uses.
6
- * Prototype-only extensions are tagged with `_prototypeOnly: true`.
7
- * Comment and revision visibility is modeled as decoration arrays
8
- * over text segments, matching how the real editor applies them.
9
- */
10
-
11
- // ─── Structural mirrors of src/api/public-types.ts ───
12
- // These are defined locally so the Next.js tsconfig doesn't need to reach
13
- // outside the harness directory. They are structurally identical to the
14
- // canonical types in src/api/public-types.ts.
15
-
16
- export type CompatibilityFeatureClass =
17
- | "supported-roundtrip"
18
- | "preserve-only"
19
- | "unsupported-fatal";
20
-
21
- export interface CompatibilityFeatureEntry {
22
- featureEntryId: string;
23
- featureKey: string;
24
- featureClass: CompatibilityFeatureClass;
25
- message: string;
26
- affectedAnchor?: EditorAnchorProjection;
27
- details?: Record<string, unknown>;
28
- }
29
-
30
- export type EditorAnchorProjection =
31
- | { kind: "range"; from: number; to: number; assoc: { start: -1 | 1; end: -1 | 1 } }
32
- | { kind: "node"; at: number; assoc: -1 | 1 }
33
- | { kind: "detached"; lastKnownRange: { from: number; to: number }; reason: string };
34
-
35
- export interface SelectionSnapshot {
36
- anchor: number;
37
- head: number;
38
- isCollapsed: boolean;
39
- activeRange: EditorAnchorProjection;
40
- }
41
-
42
- export interface DocumentStats {
43
- storyLength: number;
44
- commentCount: number;
45
- revisionCount: number;
46
- opaqueFragmentCount: number;
47
- }
48
-
49
- export interface CommandStateSnapshot {
50
- canUndo: boolean;
51
- canRedo: boolean;
52
- readOnly: boolean;
53
- }
54
-
55
- export interface CommentSidebarThreadSnapshot {
56
- commentId: string;
57
- status: "open" | "resolved" | "detached";
58
- anchor: EditorAnchorProjection;
59
- excerpt: string;
60
- entryCount: number;
61
- createdAt: string;
62
- createdBy: string;
63
- warningCount: number;
64
- anchorLabel: string;
65
- isActive: boolean;
66
- resolvedAt?: string;
67
- resolvedBy?: string;
68
- }
69
-
70
- export interface TrackedChangeEntrySnapshot {
71
- revisionId: string;
72
- kind: "insertion" | "deletion" | "formatting" | "move";
73
- label: string;
74
- status: "active" | "accepted" | "rejected" | "detached";
75
- actionability: "actionable" | "preserve-only";
76
- importedRevisionForm?: string;
77
- anchor: EditorAnchorProjection;
78
- anchorLabel: string;
79
- createdAt: string;
80
- authorId: string;
81
- warningCount: number;
82
- canAccept: boolean;
83
- canReject: boolean;
84
- preserveOnlyReason?: string;
85
- }
86
-
87
- export type SurfaceTextMark = "bold" | "italic" | "underline" | "strikethrough";
88
-
89
- export type SurfaceInlineSegment =
90
- | { segmentId: string; kind: "text"; from: number; to: number; text: string; marks?: SurfaceTextMark[]; hyperlinkHref?: string }
91
- | { segmentId: string; kind: "tab" | "hard_break"; from: number; to: number; hyperlinkHref?: string }
92
- | { segmentId: string; kind: "image"; from: number; to: number; mediaId: string; altText?: string; state: "editable" | "missing"; detail?: string }
93
- | { segmentId: string; kind: "opaque_inline"; from: number; to: number; fragmentId: string; warningId: string; label: string; detail: string; state: "locked-preserve-only" };
94
-
95
- export type SurfaceBlockSnapshot =
96
- | { blockId: string; kind: "paragraph"; from: number; to: number; styleId?: string; numbering?: { numberingInstanceId: string; level: number }; segments: SurfaceInlineSegment[] }
97
- | { blockId: string; kind: "opaque_block"; from: number; to: number; fragmentId: string; warningId: string; label: string; detail: string; state: "locked-preserve-only" };
98
-
99
- export interface EditorError {
100
- errorId: string;
101
- code: string;
102
- message: string;
103
- isFatal: boolean;
104
- source: string;
105
- details?: Record<string, unknown>;
106
- }
107
-
108
- export interface EditorWarning {
109
- warningId: string;
110
- code: string;
111
- severity: "info" | "warning";
112
- message: string;
113
- source: string;
114
- affectedAnchor?: EditorAnchorProjection;
115
- featureEntryId?: string;
116
- details?: Record<string, unknown>;
117
- }
118
-
119
- // ─── Prototype-only block extensions ───
120
- // Table shape mirrors proposed canonical TableNode > TableRowNode > TableCellNode
121
- // from docs/legal-feedback-architecture.md
122
-
123
- export interface PrototypeTableBlock {
124
- blockId: string;
125
- kind: "table";
126
- _prototypeOnly: true;
127
- tableId: string;
128
- caption?: string;
129
- note?: string;
130
- headerRowCount: number;
131
- rows: PrototypeTableRow[];
132
- }
133
-
134
- export interface PrototypeTableRow {
135
- rowId: string;
136
- isHeader: boolean;
137
- cells: PrototypeTableCell[];
138
- }
139
-
140
- export interface PrototypeTableCell {
141
- cellId: string;
142
- colSpan: number;
143
- rowSpan: number;
144
- segments: SurfaceInlineSegment[];
145
- preserveOnly?: boolean;
146
- preserveOnlyReason?: string;
147
- }
148
-
149
- export interface PrototypeCalloutBlock {
150
- blockId: string;
151
- kind: "callout";
152
- _prototypeOnly: true;
153
- tone: string;
154
- title: string;
155
- body: string;
156
- }
157
-
158
- export type PrototypeSurfaceBlock =
159
- | SurfaceBlockSnapshot
160
- | PrototypeTableBlock
161
- | PrototypeCalloutBlock;
162
-
163
- // ─── Prototype-only extensions on real types ───
164
-
165
- export interface PrototypeCommentThread extends CommentSidebarThreadSnapshot {
166
- /** Prototype-only: full thread body text (real sidebar may not expose this) */
167
- body: string;
168
- /** Prototype-only: nested reply previews */
169
- responses: { author: string; timestamp: string; body: string }[];
170
- }
171
-
172
- export interface PrototypeRevisionEntry extends TrackedChangeEntrySnapshot {
173
- /** Prototype-only: visible text excerpt */
174
- excerpt: string;
175
- /** Prototype-only: explanation text */
176
- detail: string;
177
- }
178
-
179
- export interface PrototypeFeatureEntry extends CompatibilityFeatureEntry {
180
- /** Prototype-only: short summary line */
181
- summary: string;
182
- }
183
-
184
- // ─── Decoration layers ───
185
-
186
- export interface PrototypeCommentDecoration {
187
- commentId: string;
188
- segmentIds: string[];
189
- }
190
-
191
- export interface PrototypeRevisionDecoration {
192
- revisionId: string;
193
- kind: "insertion" | "deletion";
194
- segmentIds: string[];
195
- }
196
-
197
- // ─── Mock snapshot (structurally mirrors RuntimeRenderSnapshot with prototype extensions) ───
198
-
199
- export interface MockRuntimeRenderSnapshot {
200
- // Fields from RuntimeRenderSnapshot
201
- documentId: string;
202
- sessionId: string;
203
- sourceLabel?: string;
204
- revisionToken: string;
205
- isReady: boolean;
206
- isDirty: boolean;
207
- readOnly: boolean;
208
- selection: SelectionSnapshot;
209
- documentStats: DocumentStats;
210
- warnings: EditorWarning[];
211
- fatalError?: EditorError;
212
- commandState: CommandStateSnapshot;
213
-
214
- // Extended with prototype types
215
- surface: {
216
- storySize: number;
217
- plainText: string;
218
- blocks: PrototypeSurfaceBlock[];
219
- lockedFragmentIds: string[];
220
- };
221
- comments: {
222
- activeCommentId?: string;
223
- openCommentIds: string[];
224
- resolvedCommentIds: string[];
225
- detachedCommentIds: string[];
226
- totalCount: number;
227
- threads: PrototypeCommentThread[];
228
- };
229
- trackedChanges: {
230
- pendingChangeIds: string[];
231
- acceptedChangeIds: string[];
232
- rejectedChangeIds: string[];
233
- detachedChangeIds: string[];
234
- actionableChangeIds: string[];
235
- preserveOnlyChangeIds: string[];
236
- totalCount: number;
237
- revisions: PrototypeRevisionEntry[];
238
- };
239
- compatibility: {
240
- blockExport: boolean;
241
- blockExportReasons: string[];
242
- warningCount: number;
243
- errorCount: number;
244
- featureEntries: PrototypeFeatureEntry[];
245
- };
246
- }
247
-
248
- // ─── Demo session wrapper ───
249
-
250
- export type DemoMarkupDisplay = "clean" | "simple" | "all";
251
- export type DemoViewMode = "canvas" | "page";
252
- export type DemoRailTab = "comments" | "changes" | "health";
253
-
254
- export interface DemoSession {
255
- id: string;
256
- title: string;
257
- sourceKind: "fixture" | "scenario" | "upload";
258
- defaultMarkupDisplay: DemoMarkupDisplay;
259
- defaultViewMode: DemoViewMode;
260
- defaultRailTab: DemoRailTab;
261
- defaultTrackChangesEnabled: boolean;
262
- snapshot: MockRuntimeRenderSnapshot;
263
- commentDecorations: PrototypeCommentDecoration[];
264
- revisionDecorations: PrototypeRevisionDecoration[];
265
- }
266
-
267
- export interface DemoCatalogResponse {
268
- sessions: DemoSession[];
269
- }
270
-
271
- // ─── Helpers ───
272
-
273
- function rangeAnchor(from: number, to: number): EditorAnchorProjection {
274
- return { kind: "range", from, to, assoc: { start: -1, end: 1 } };
275
- }
276
-
277
- function detachedAnchor(from: number, to: number): EditorAnchorProjection {
278
- return {
279
- kind: "detached",
280
- lastKnownRange: { from, to },
281
- reason: "importAmbiguity",
282
- };
283
- }
284
-
285
- function collapsedSelection(pos: number): SelectionSnapshot {
286
- return {
287
- anchor: pos,
288
- head: pos,
289
- isCollapsed: true,
290
- activeRange: rangeAnchor(pos, pos),
291
- };
292
- }
293
-
294
- let _pos = 0;
295
- function resetPos() {
296
- _pos = 0;
297
- }
298
- function text(
299
- id: string,
300
- content: string,
301
- opts?: { marks?: SurfaceInlineSegment extends { marks?: infer M } ? M : never; hyperlinkHref?: string },
302
- ): Extract<SurfaceInlineSegment, { kind: "text" }> {
303
- const from = _pos;
304
- _pos += content.length;
305
- return {
306
- segmentId: id,
307
- kind: "text",
308
- from,
309
- to: _pos,
310
- text: content,
311
- ...(opts?.marks ? { marks: opts.marks } : {}),
312
- ...(opts?.hyperlinkHref ? { hyperlinkHref: opts.hyperlinkHref } : {}),
313
- };
314
- }
315
-
316
- function tab(id: string): SurfaceInlineSegment {
317
- const from = _pos;
318
- _pos += 1;
319
- return { segmentId: id, kind: "tab" as const, from, to: _pos };
320
- }
321
-
322
- function hardBreak(id: string): SurfaceInlineSegment {
323
- const from = _pos;
324
- _pos += 1;
325
- return { segmentId: id, kind: "hard_break" as const, from, to: _pos };
326
- }
327
-
328
- function image(
329
- id: string,
330
- mediaId: string,
331
- opts?: { altText?: string; state?: "editable" | "missing"; detail?: string },
332
- ): SurfaceInlineSegment {
333
- const from = _pos;
334
- _pos += 1;
335
- return {
336
- segmentId: id,
337
- kind: "image" as const,
338
- from,
339
- to: _pos,
340
- mediaId,
341
- altText: opts?.altText,
342
- state: opts?.state ?? "editable",
343
- detail: opts?.detail,
344
- };
345
- }
346
-
347
- function opaqueInline(
348
- id: string,
349
- label: string,
350
- detail: string,
351
- ): SurfaceInlineSegment {
352
- const from = _pos;
353
- _pos += 1;
354
- return {
355
- segmentId: id,
356
- kind: "opaque_inline" as const,
357
- from,
358
- to: _pos,
359
- fragmentId: `frag-${id}`,
360
- warningId: `warn-${id}`,
361
- label,
362
- detail,
363
- state: "locked-preserve-only" as const,
364
- };
365
- }
366
-
367
- function para(
368
- id: string,
369
- styleId: string | undefined,
370
- segments: SurfaceInlineSegment[],
371
- numbering?: { numberingInstanceId: string; level: number },
372
- ): Extract<SurfaceBlockSnapshot, { kind: "paragraph" }> {
373
- const from = segments.length > 0 ? (segments[0] as any).from : _pos;
374
- const to = segments.length > 0 ? (segments[segments.length - 1] as any).to : _pos;
375
- return {
376
- blockId: id,
377
- kind: "paragraph",
378
- from,
379
- to,
380
- ...(styleId ? { styleId } : {}),
381
- ...(numbering ? { numbering } : {}),
382
- segments,
383
- };
384
- }
385
-
386
- function opaque(
387
- id: string,
388
- label: string,
389
- detail: string,
390
- ): Extract<SurfaceBlockSnapshot, { kind: "opaque_block" }> {
391
- const from = _pos;
392
- _pos += 1;
393
- return {
394
- blockId: id,
395
- kind: "opaque_block",
396
- from,
397
- to: _pos,
398
- fragmentId: `frag-${id}`,
399
- warningId: `warn-${id}`,
400
- label,
401
- detail,
402
- state: "locked-preserve-only",
403
- };
404
- }
405
-
406
- function protoTable(
407
- id: string,
408
- tableId: string,
409
- opts: {
410
- caption?: string;
411
- note?: string;
412
- headerRowCount?: number;
413
- rows: PrototypeTableRow[];
414
- },
415
- ): PrototypeTableBlock {
416
- return {
417
- blockId: id,
418
- kind: "table",
419
- _prototypeOnly: true,
420
- tableId,
421
- caption: opts.caption,
422
- note: opts.note,
423
- headerRowCount: opts.headerRowCount ?? 1,
424
- rows: opts.rows,
425
- };
426
- }
427
-
428
- function protoCallout(
429
- id: string,
430
- tone: string,
431
- title: string,
432
- body: string,
433
- ): PrototypeCalloutBlock {
434
- return {
435
- blockId: id,
436
- kind: "callout",
437
- _prototypeOnly: true,
438
- tone,
439
- title,
440
- body,
441
- };
442
- }
443
-
444
- // ─── Session builders ───
445
-
446
- function buildCleanContractReview(): DemoSession {
447
- resetPos();
448
-
449
- const c1: PrototypeCommentThread = {
450
- commentId: "clean-c1",
451
- status: "open",
452
- anchor: rangeAnchor(25, 55),
453
- excerpt: "commercially reasonable efforts",
454
- entryCount: 2,
455
- createdAt: "Today · 10:12",
456
- createdBy: "Avery Chen",
457
- warningCount: 0,
458
- anchorLabel: "Clause 2.1",
459
- isActive: false,
460
- body: "Keep the softer obligation language here. The current phrasing still gives Legal room without inviting a measurable SLA.",
461
- responses: [
462
- { author: "Jordan Mills", timestamp: "Today · 10:18", body: "Agreed. Leave this as a comment-only note in the baseline prototype flow." },
463
- ],
464
- };
465
-
466
- const c2: PrototypeCommentThread = {
467
- commentId: "clean-c2",
468
- status: "resolved",
469
- anchor: rangeAnchor(150, 170),
470
- excerpt: "electronic signature",
471
- entryCount: 1,
472
- createdAt: "Yesterday · 17:40",
473
- createdBy: "Nia Patel",
474
- warningCount: 0,
475
- anchorLabel: "Signature block",
476
- isActive: false,
477
- resolvedAt: "Yesterday · 18:00",
478
- resolvedBy: "Nia Patel",
479
- body: "Resolution confirms the signature language is acceptable as drafted and no longer needs active review focus.",
480
- responses: [],
481
- };
482
-
483
- const r1: PrototypeRevisionEntry = {
484
- revisionId: "clean-r1",
485
- kind: "insertion",
486
- label: "Insertion",
487
- status: "active",
488
- actionability: "actionable",
489
- anchor: rangeAnchor(100, 119),
490
- anchorLabel: "Clause 2.3",
491
- createdAt: "Today · 09:58",
492
- authorId: "avery-chen",
493
- warningCount: 0,
494
- canAccept: true,
495
- canReject: true,
496
- excerpt: "with written notice",
497
- detail: "A small insertion showing the simple-markup baseline.",
498
- };
499
-
500
- const h1Segs = [text("clean-h1-s1", "Statement of Work Addendum")];
501
- const h1 = para("clean-h1", "Heading1", h1Segs);
502
-
503
- const p1Segs = [
504
- text("clean-p1-s1", "Supplier will provide "),
505
- text("clean-p1-s2", "commercially reasonable efforts"),
506
- text("clean-p1-s3", " to deliver the implementation services listed in Schedule A."),
507
- ];
508
- const p1 = para("clean-p1", undefined, p1Segs);
509
-
510
- const p2Segs = [
511
- text("clean-p2-s1", "Either party may terminate this addendum "),
512
- text("clean-p2-s2", "with written notice"),
513
- text("clean-p2-s3", " if the other materially breaches the agreement."),
514
- ];
515
- const p2 = para("clean-p2", undefined, p2Segs);
516
-
517
- const p3Segs = [
518
- text("clean-p3-s1", "Related policy: "),
519
- text("clean-p3-s2", "Information Security Standards", { hyperlinkHref: "https://example.com/policy" }),
520
- text("clean-p3-s3", "."),
521
- ];
522
- const p3 = para("clean-p3", undefined, p3Segs);
523
-
524
- const p4Segs = [
525
- text("clean-p4-s1", "Exhibit A"),
526
- tab("clean-p4-tab"),
527
- text("clean-p4-s2", "Scope of services"),
528
- hardBreak("clean-p4-br"),
529
- text("clean-p4-s3", "See attached: "),
530
- image("clean-p4-img", "media:schedule-a-diagram", { altText: "Schedule A diagram", state: "editable" }),
531
- ];
532
- const p4 = para("clean-p4", undefined, p4Segs);
533
-
534
- const cleanTable = protoTable("clean-table", "tbl-clean-1", {
535
- caption: "Schedule A — Clause summary",
536
- headerRowCount: 1,
537
- rows: [
538
- {
539
- rowId: "ct-h",
540
- isHeader: true,
541
- cells: [
542
- { cellId: "ct-h-1", colSpan: 1, rowSpan: 1, segments: [text("ct-h-1-s1", "Clause")] },
543
- { cellId: "ct-h-2", colSpan: 1, rowSpan: 1, segments: [text("ct-h-2-s1", "Obligation")] },
544
- { cellId: "ct-h-3", colSpan: 1, rowSpan: 1, segments: [text("ct-h-3-s1", "Status")] },
545
- ],
546
- },
547
- {
548
- rowId: "ct-1",
549
- isHeader: false,
550
- cells: [
551
- { cellId: "ct-1-1", colSpan: 1, rowSpan: 1, segments: [text("ct-1-1-s1", "2.1")] },
552
- { cellId: "ct-1-2", colSpan: 1, rowSpan: 1, segments: [text("ct-1-2-s1", "Deliver implementation services per Schedule A")] },
553
- { cellId: "ct-1-3", colSpan: 1, rowSpan: 1, segments: [text("ct-1-3-s1", "Active")] },
554
- ],
555
- },
556
- {
557
- rowId: "ct-2",
558
- isHeader: false,
559
- cells: [
560
- { cellId: "ct-2-1", colSpan: 1, rowSpan: 1, segments: [text("ct-2-1-s1", "2.3")] },
561
- { cellId: "ct-2-2", colSpan: 1, rowSpan: 1, segments: [text("ct-2-2-s1", "Termination with written notice on material breach")] },
562
- { cellId: "ct-2-3", colSpan: 1, rowSpan: 1, segments: [text("ct-2-3-s1", "Under review")] },
563
- ],
564
- },
565
- ],
566
- });
567
-
568
- return {
569
- id: "clean-contract-review",
570
- title: "Clean Contract Review",
571
- sourceKind: "fixture",
572
- defaultMarkupDisplay: "simple",
573
- defaultViewMode: "canvas",
574
- defaultRailTab: "comments",
575
- defaultTrackChangesEnabled: true,
576
- snapshot: {
577
- documentId: "doc-clean",
578
- sessionId: "session-cr-101",
579
- sourceLabel: "F01/F03 baseline contract",
580
- revisionToken: "rev-clean-001",
581
- isReady: true,
582
- isDirty: false,
583
- readOnly: false,
584
- selection: collapsedSelection(0),
585
- documentStats: { storyLength: _pos, commentCount: 2, revisionCount: 1, opaqueFragmentCount: 0 },
586
- comments: {
587
- openCommentIds: ["clean-c1"],
588
- resolvedCommentIds: ["clean-c2"],
589
- detachedCommentIds: [],
590
- totalCount: 2,
591
- threads: [c1, c2],
592
- },
593
- trackedChanges: {
594
- pendingChangeIds: ["clean-r1"],
595
- acceptedChangeIds: [],
596
- rejectedChangeIds: [],
597
- detachedChangeIds: [],
598
- actionableChangeIds: ["clean-r1"],
599
- preserveOnlyChangeIds: [],
600
- totalCount: 1,
601
- revisions: [r1],
602
- },
603
- compatibility: {
604
- blockExport: false,
605
- blockExportReasons: [],
606
- warningCount: 0,
607
- errorCount: 0,
608
- featureEntries: [
609
- {
610
- featureEntryId: "clean-f1",
611
- featureKey: "supported-review",
612
- featureClass: "supported-roundtrip",
613
- message: "Supported review path",
614
- summary: "Paragraph styles, comments, hyperlinks, and light redlines stay in the supported slice.",
615
- },
616
- {
617
- featureEntryId: "clean-f2",
618
- featureKey: "canvas-layout",
619
- featureClass: "supported-roundtrip",
620
- message: "Canvas-first hierarchy",
621
- summary: "Document surface stays central and the review rail stays secondary.",
622
- },
623
- ],
624
- },
625
- warnings: [
626
- {
627
- warningId: "warn-font-sub-1",
628
- code: "font_substitution",
629
- severity: "info" as const,
630
- message: "Source font \"Times New Roman\" approximated as curated legal serif in browser rendering",
631
- source: "import",
632
- },
633
- ],
634
- commandState: { canUndo: false, canRedo: false, readOnly: false },
635
- surface: {
636
- storySize: _pos,
637
- plainText: "",
638
- blocks: [h1, p1, p2, p3, p4, cleanTable],
639
- lockedFragmentIds: [],
640
- },
641
- },
642
- commentDecorations: [
643
- { commentId: "clean-c1", segmentIds: ["clean-p1-s2"] },
644
- ],
645
- revisionDecorations: [
646
- { revisionId: "clean-r1", kind: "insertion", segmentIds: ["clean-p2-s2"] },
647
- ],
648
- };
649
- }
650
-
651
- function buildCommentNegotiation(): DemoSession {
652
- resetPos();
653
-
654
- const c1: PrototypeCommentThread = {
655
- commentId: "comments-c1",
656
- status: "open",
657
- anchor: rangeAnchor(11, 29),
658
- excerpt: "strategic alliance",
659
- entryCount: 2,
660
- createdAt: "Today · 08:44",
661
- createdBy: "Priya Gomez",
662
- warningCount: 0,
663
- anchorLabel: "Recital A",
664
- isActive: false,
665
- body: "This recital reads more like marketing than a contract. Consider replacing it with concrete deal framing or move the language to a cover note.",
666
- responses: [
667
- { author: "Noah Price", timestamp: "Today · 08:56", body: "Good call. I want the prototype to show how a longer comment still stays readable in the rail." },
668
- ],
669
- };
670
-
671
- const c2: PrototypeCommentThread = {
672
- commentId: "comments-c2",
673
- status: "open",
674
- anchor: rangeAnchor(80, 95),
675
- excerpt: "promptly notify",
676
- entryCount: 1,
677
- createdAt: "Today · 09:10",
678
- createdBy: "Noah Price",
679
- warningCount: 0,
680
- anchorLabel: "Clause 4.2",
681
- isActive: false,
682
- body: "We should confirm whether 'promptly' is acceptable or whether the fallback should specify a concrete business-day window.",
683
- responses: [],
684
- };
685
-
686
- const c3: PrototypeCommentThread = {
687
- commentId: "comments-c3",
688
- status: "resolved",
689
- anchor: rangeAnchor(140, 158),
690
- excerpt: "notice@company.com",
691
- entryCount: 1,
692
- createdAt: "Yesterday · 18:02",
693
- createdBy: "Priya Gomez",
694
- warningCount: 0,
695
- anchorLabel: "Notice details",
696
- isActive: false,
697
- resolvedAt: "Yesterday · 18:30",
698
- resolvedBy: "Priya Gomez",
699
- body: "Resolved after confirming the notice alias is the same one already used in the master agreement.",
700
- responses: [],
701
- };
702
-
703
- const h1Segs = [text("comments-h1-s1", "Term Sheet")];
704
- const h1 = para("comments-h1", "Heading1", h1Segs);
705
-
706
- const p1Segs = [
707
- text("comments-p1-s1", "The parties intend to form a "),
708
- text("comments-p1-s2", "strategic alliance"),
709
- text("comments-p1-s3", " for delivery of implementation and support services."),
710
- ];
711
- const p1 = para("comments-p1", undefined, p1Segs);
712
-
713
- const p2Segs = [
714
- text("comments-p2-s1", "Customer must "),
715
- text("comments-p2-s2", "promptly notify"),
716
- text("comments-p2-s3", " Supplier of a material delay in data delivery."),
717
- ];
718
- const p2 = para("comments-p2", undefined, p2Segs);
719
-
720
- const p3Segs = [
721
- text("comments-p3-s1", "All notices under this term sheet will be sent to "),
722
- text("comments-p3-s2", "notice@company.com"),
723
- text("comments-p3-s3", "."),
724
- ];
725
- const p3 = para("comments-p3", undefined, p3Segs);
726
-
727
- return {
728
- id: "comment-negotiation",
729
- title: "Comment Negotiation",
730
- sourceKind: "fixture",
731
- defaultMarkupDisplay: "simple",
732
- defaultViewMode: "canvas",
733
- defaultRailTab: "comments",
734
- defaultTrackChangesEnabled: false,
735
- snapshot: {
736
- documentId: "doc-comments",
737
- sessionId: "session-cn-204",
738
- sourceLabel: "F09/F10 thread-heavy markup",
739
- revisionToken: "rev-comments-001",
740
- isReady: true,
741
- isDirty: false,
742
- readOnly: false,
743
- selection: collapsedSelection(0),
744
- documentStats: { storyLength: _pos, commentCount: 3, revisionCount: 0, opaqueFragmentCount: 0 },
745
- comments: {
746
- openCommentIds: ["comments-c1", "comments-c2"],
747
- resolvedCommentIds: ["comments-c3"],
748
- detachedCommentIds: [],
749
- totalCount: 3,
750
- threads: [c1, c2, c3],
751
- },
752
- trackedChanges: {
753
- pendingChangeIds: [],
754
- acceptedChangeIds: [],
755
- rejectedChangeIds: [],
756
- detachedChangeIds: [],
757
- actionableChangeIds: [],
758
- preserveOnlyChangeIds: [],
759
- totalCount: 0,
760
- revisions: [],
761
- },
762
- compatibility: {
763
- blockExport: false,
764
- blockExportReasons: [],
765
- warningCount: 0,
766
- errorCount: 0,
767
- featureEntries: [
768
- {
769
- featureEntryId: "comments-f1",
770
- featureKey: "comment-anchors",
771
- featureClass: "supported-roundtrip",
772
- message: "Supported comment anchor mapping",
773
- summary: "Single-paragraph comment anchors remain in the supported-roundtrip slice.",
774
- },
775
- ],
776
- },
777
- warnings: [],
778
- commandState: { canUndo: false, canRedo: false, readOnly: false },
779
- surface: {
780
- storySize: _pos,
781
- plainText: "",
782
- blocks: [h1, p1, p2, p3],
783
- lockedFragmentIds: [],
784
- },
785
- },
786
- commentDecorations: [
787
- { commentId: "comments-c1", segmentIds: ["comments-p1-s2"] },
788
- { commentId: "comments-c2", segmentIds: ["comments-p2-s2"] },
789
- { commentId: "comments-c3", segmentIds: ["comments-p3-s2"] },
790
- ],
791
- revisionDecorations: [],
792
- };
793
- }
794
-
795
- function buildRedlineNegotiation(): DemoSession {
796
- resetPos();
797
-
798
- const c1: PrototypeCommentThread = {
799
- commentId: "redline-c1",
800
- status: "open",
801
- anchor: rangeAnchor(30, 48),
802
- excerpt: "reasonable efforts",
803
- entryCount: 1,
804
- createdAt: "Today · 11:02",
805
- createdBy: "Riley Shah",
806
- warningCount: 0,
807
- anchorLabel: "Clause 5.1",
808
- isActive: false,
809
- body: "If the deletion stands, the remaining phrase needs a stronger limitation elsewhere in the section.",
810
- responses: [],
811
- };
812
-
813
- const r1: PrototypeRevisionEntry = {
814
- revisionId: "redline-r1",
815
- kind: "deletion",
816
- label: "Deletion",
817
- status: "active",
818
- actionability: "actionable",
819
- anchor: rangeAnchor(50, 72),
820
- anchorLabel: "Clause 5.1",
821
- createdAt: "Today · 10:41",
822
- authorId: "riley-shah",
823
- warningCount: 0,
824
- canAccept: true,
825
- canReject: true,
826
- excerpt: "commercially reasonable",
827
- detail: "The deletion is intentionally short so the full-markup styling can stay readable.",
828
- };
829
-
830
- const r2: PrototypeRevisionEntry = {
831
- revisionId: "redline-r2",
832
- kind: "insertion",
833
- label: "Insertion",
834
- status: "active",
835
- actionability: "actionable",
836
- anchor: rangeAnchor(80, 112),
837
- anchorLabel: "Clause 5.1",
838
- createdAt: "Today · 10:44",
839
- authorId: "riley-shah",
840
- warningCount: 0,
841
- canAccept: true,
842
- canReject: true,
843
- excerpt: "using senior implementation staff",
844
- detail: "The insertion shows how a new obligation can remain obvious without using loud diff colors.",
845
- };
846
-
847
- const r3: PrototypeRevisionEntry = {
848
- revisionId: "redline-r3",
849
- kind: "insertion",
850
- label: "Preserve-only structural change",
851
- status: "detached",
852
- actionability: "preserve-only",
853
- anchor: detachedAnchor(0, 0),
854
- anchorLabel: "Table row merge",
855
- createdAt: "Source metadata",
856
- authorId: "imported-source",
857
- warningCount: 1,
858
- canAccept: false,
859
- canReject: false,
860
- preserveOnlyReason: "Structural revision outside supported slice",
861
- excerpt: "structural revision outside supported slice",
862
- detail: "This is preserved review state, not a normal actionable change.",
863
- };
864
-
865
- const h1Segs = [text("redline-h1-s1", "Clause 5. Delivery Standard")];
866
- const h1 = para("redline-h1", "Heading1", h1Segs);
867
-
868
- const p1Segs = [
869
- text("redline-p1-s1", "Supplier will use "),
870
- text("redline-p1-s2", "commercially reasonable"),
871
- text("redline-p1-s3", " efforts "),
872
- text("redline-p1-s4", "using senior implementation staff"),
873
- text("redline-p1-s5", " to meet the implementation plan milestones."),
874
- ];
875
- const p1 = para("redline-p1", undefined, p1Segs);
876
-
877
- const p2Segs = [
878
- text("redline-p2-s1", "Related comment: "),
879
- text("redline-p2-s2", "reasonable efforts"),
880
- text("redline-p2-s3", "."),
881
- ];
882
- const p2 = para("redline-p2", undefined, p2Segs);
883
-
884
- // Additional paragraphs for demonstrating mode differences
885
- const h2Segs = [
886
- text("redline-h2-s1", "5.2 "),
887
- text("redline-h2-s2", "Performance Benchmarks"),
888
- text("redline-h2-s3", " and Reporting"),
889
- ];
890
- const h2 = para("redline-h2", "Heading2", h2Segs);
891
-
892
- const p3Segs = [
893
- text("redline-p3-s1", "Supplier shall "),
894
- text("redline-p3-s2", "deliver quarterly reports"),
895
- text("redline-p3-s3", " to Customer covering all active workstreams. Reports must include "),
896
- text("redline-p3-s4", "measurable completion criteria"),
897
- text("redline-p3-s5", " and "),
898
- text("redline-p3-s6", "variance analysis against the agreed schedule"),
899
- text("redline-p3-s7", "."),
900
- ];
901
- const p3 = para("redline-p3", undefined, p3Segs);
902
-
903
- const p4Segs = [
904
- text("redline-p4-s1", "Customer may "),
905
- text("redline-p4-s2", "withhold payment for"),
906
- text("redline-p4-s3", " "),
907
- text("redline-p4-s4", "request a cure period of"),
908
- text("redline-p4-s5", " any milestone that fails to meet the agreed performance threshold."),
909
- ];
910
- const p4 = para("redline-p4", undefined, p4Segs);
911
-
912
- const r4: PrototypeRevisionEntry = {
913
- revisionId: "redline-r4",
914
- kind: "insertion",
915
- label: "Insertion",
916
- status: "active",
917
- actionability: "actionable",
918
- anchor: rangeAnchor(200, 228),
919
- anchorLabel: "Clause 5.2",
920
- createdAt: "Today · 10:52",
921
- authorId: "riley-shah",
922
- warningCount: 0,
923
- canAccept: true,
924
- canReject: true,
925
- excerpt: "measurable completion criteria",
926
- detail: "Strengthened the reporting obligation language.",
927
- };
928
-
929
- const r5: PrototypeRevisionEntry = {
930
- revisionId: "redline-r5",
931
- kind: "deletion",
932
- label: "Deletion",
933
- status: "active",
934
- actionability: "actionable",
935
- anchor: rangeAnchor(280, 300),
936
- anchorLabel: "Clause 5.2",
937
- createdAt: "Today · 10:55",
938
- authorId: "riley-shah",
939
- warningCount: 0,
940
- canAccept: true,
941
- canReject: true,
942
- excerpt: "withhold payment for",
943
- detail: "Replaced punitive remedy with cure period.",
944
- };
945
-
946
- const r6: PrototypeRevisionEntry = {
947
- revisionId: "redline-r6",
948
- kind: "insertion",
949
- label: "Insertion",
950
- status: "active",
951
- actionability: "actionable",
952
- anchor: rangeAnchor(301, 325),
953
- anchorLabel: "Clause 5.2",
954
- createdAt: "Today · 10:55",
955
- authorId: "riley-shah",
956
- warningCount: 0,
957
- canAccept: true,
958
- canReject: true,
959
- excerpt: "request a cure period of",
960
- detail: "Replacement for the deleted payment-withholding clause.",
961
- };
962
-
963
- const c2: PrototypeCommentThread = {
964
- commentId: "redline-c2",
965
- status: "open",
966
- anchor: rangeAnchor(200, 246),
967
- excerpt: "variance analysis against the agreed schedule",
968
- entryCount: 1,
969
- createdAt: "Today · 11:10",
970
- createdBy: "Riley Shah",
971
- warningCount: 0,
972
- anchorLabel: "Clause 5.2 reporting",
973
- isActive: false,
974
- body: "Confirm that variance analysis includes both schedule and budget dimensions, or whether schedule-only is sufficient for v1.",
975
- responses: [],
976
- };
977
-
978
- const callout = protoCallout(
979
- "redline-c1-block",
980
- "warning",
981
- "Preserve-only structural revision",
982
- "Imported table/list revisions stay visible in health and change surfaces but are not presented as editable actions.",
983
- );
984
-
985
- return {
986
- id: "redline-negotiation",
987
- title: "Redline Negotiation",
988
- sourceKind: "fixture",
989
- defaultMarkupDisplay: "all",
990
- defaultViewMode: "canvas",
991
- defaultRailTab: "changes",
992
- defaultTrackChangesEnabled: true,
993
- snapshot: {
994
- documentId: "doc-redline",
995
- sessionId: "session-rn-309",
996
- sourceLabel: "F11/F12 redline package",
997
- revisionToken: "rev-redline-001",
998
- isReady: true,
999
- isDirty: false,
1000
- readOnly: false,
1001
- selection: collapsedSelection(0),
1002
- documentStats: { storyLength: _pos, commentCount: 2, revisionCount: 6, opaqueFragmentCount: 0 },
1003
- comments: {
1004
- openCommentIds: ["redline-c1", "redline-c2"],
1005
- resolvedCommentIds: [],
1006
- detachedCommentIds: [],
1007
- totalCount: 2,
1008
- threads: [c1, c2],
1009
- },
1010
- trackedChanges: {
1011
- pendingChangeIds: ["redline-r1", "redline-r2", "redline-r4", "redline-r5", "redline-r6"],
1012
- acceptedChangeIds: [],
1013
- rejectedChangeIds: [],
1014
- detachedChangeIds: ["redline-r3"],
1015
- actionableChangeIds: ["redline-r1", "redline-r2", "redline-r4", "redline-r5", "redline-r6"],
1016
- preserveOnlyChangeIds: ["redline-r3"],
1017
- totalCount: 6,
1018
- revisions: [r1, r2, r3, r4, r5, r6],
1019
- },
1020
- compatibility: {
1021
- blockExport: false,
1022
- blockExportReasons: [],
1023
- warningCount: 1,
1024
- errorCount: 0,
1025
- featureEntries: [
1026
- {
1027
- featureEntryId: "redline-f1",
1028
- featureKey: "supported-revisions",
1029
- featureClass: "supported-roundtrip",
1030
- message: "Supported revision loop",
1031
- summary: "Run-level insertions and deletions are actionable and export-safe.",
1032
- },
1033
- {
1034
- featureEntryId: "redline-f2",
1035
- featureKey: "structural-revisions",
1036
- featureClass: "preserve-only",
1037
- message: "Structural revisions remain honest",
1038
- summary: "Complex imported structural revisions stay preserve-only.",
1039
- },
1040
- ],
1041
- },
1042
- warnings: [],
1043
- commandState: { canUndo: false, canRedo: false, readOnly: false },
1044
- surface: {
1045
- storySize: _pos,
1046
- plainText: "",
1047
- blocks: [h1, p1, p2, h2, p3, p4, callout],
1048
- lockedFragmentIds: [],
1049
- },
1050
- },
1051
- commentDecorations: [
1052
- { commentId: "redline-c1", segmentIds: ["redline-p2-s2"] },
1053
- { commentId: "redline-c2", segmentIds: ["redline-p3-s6"] },
1054
- ],
1055
- revisionDecorations: [
1056
- { revisionId: "redline-r1", kind: "deletion", segmentIds: ["redline-p1-s2"] },
1057
- { revisionId: "redline-r2", kind: "insertion", segmentIds: ["redline-p1-s4"] },
1058
- { revisionId: "redline-r4", kind: "insertion", segmentIds: ["redline-p3-s4"] },
1059
- { revisionId: "redline-r5", kind: "deletion", segmentIds: ["redline-p4-s2"] },
1060
- { revisionId: "redline-r6", kind: "insertion", segmentIds: ["redline-p4-s4"] },
1061
- ],
1062
- };
1063
- }
1064
-
1065
- function buildPreserveOnlyPackage(): DemoSession {
1066
- resetPos();
1067
-
1068
- const c1: PrototypeCommentThread = {
1069
- commentId: "preserve-c1",
1070
- status: "detached",
1071
- anchor: detachedAnchor(0, 0),
1072
- excerpt: "preserved comment markup inside locked content",
1073
- entryCount: 1,
1074
- createdAt: "Source metadata",
1075
- createdBy: "Imported source",
1076
- warningCount: 1,
1077
- anchorLabel: "Header note",
1078
- isActive: false,
1079
- body: "This comment survives as preserved review metadata, but its anchor lives inside a locked region the runtime does not safely own.",
1080
- responses: [],
1081
- };
1082
-
1083
- const r1: PrototypeRevisionEntry = {
1084
- revisionId: "preserve-r1",
1085
- kind: "insertion",
1086
- label: "Imported preserve-only change",
1087
- status: "detached",
1088
- actionability: "preserve-only",
1089
- anchor: detachedAnchor(0, 0),
1090
- anchorLabel: "Header field run",
1091
- createdAt: "Source metadata",
1092
- authorId: "imported-source",
1093
- warningCount: 1,
1094
- canAccept: false,
1095
- canReject: false,
1096
- preserveOnlyReason: "Anchor inside locked region",
1097
- excerpt: "field-rich revision retained without rewrite",
1098
- detail: "Preserved review state, not a normal actionable change.",
1099
- };
1100
-
1101
- const h1Segs = [text("preserve-h1-s1", "Exhibit C - Manufacturing Controls")];
1102
- const h1 = para("preserve-h1", "Heading1", h1Segs);
1103
-
1104
- const p1Segs = [
1105
- text("preserve-p1-s1", "The controlled workflow remains editable in the supported slice, while "),
1106
- text("preserve-p1-s2", "preserved markup in header and note content"),
1107
- text("preserve-p1-s3", " is surfaced through health and warning views."),
1108
- ];
1109
- const p1 = para("preserve-p1", undefined, p1Segs);
1110
-
1111
- const p2Segs = [
1112
- text("preserve-p2-s1", "Embedded content: "),
1113
- image("preserve-p2-img", "media:exhibit-photo", { altText: "Exhibit photo", state: "missing", detail: "Media part not found in package" }),
1114
- text("preserve-p2-s2", " and preserved field: "),
1115
- opaqueInline("preserve-p2-opaque", "TOC field", "Table of contents field preserved as opaque inline"),
1116
- text("preserve-p2-s3", "."),
1117
- ];
1118
- const p2 = para("preserve-p2", undefined, p2Segs);
1119
-
1120
- const locked = opaque(
1121
- "preserve-locked-1",
1122
- "Locked preserve-only package region",
1123
- "Header/footer fields, footnotes, and custom XML wrappers stay attached during export but are not exposed as normal editable content.",
1124
- );
1125
-
1126
- const table = protoTable("preserve-table", "tbl-preserve-1", {
1127
- caption: "Obligation compliance matrix",
1128
- note: "Table structure remains preserve-only on the live path. The prototype keeps future cell-level review affordances visible without claiming runtime-backed in-cell editing.",
1129
- headerRowCount: 1,
1130
- rows: [
1131
- {
1132
- rowId: "ptr-h",
1133
- isHeader: true,
1134
- cells: [
1135
- { cellId: "ptr-h-1", colSpan: 1, rowSpan: 1, segments: [text("ptr-h-1-s1", "Workstream")] },
1136
- { cellId: "ptr-h-2", colSpan: 1, rowSpan: 1, segments: [text("ptr-h-2-s1", "Owner")] },
1137
- { cellId: "ptr-h-3", colSpan: 1, rowSpan: 1, segments: [text("ptr-h-3-s1", "Status")] },
1138
- ],
1139
- },
1140
- {
1141
- rowId: "ptr-1",
1142
- isHeader: false,
1143
- cells: [
1144
- { cellId: "ptr-1-1", colSpan: 1, rowSpan: 1, segments: [text("ptr-1-1-s1", "Quality gates")] },
1145
- { cellId: "ptr-1-2", colSpan: 1, rowSpan: 1, segments: [text("ptr-1-2-s1", "Supplier")] },
1146
- { cellId: "ptr-1-3", colSpan: 1, rowSpan: 1, segments: [text("ptr-1-3-s1", "Future runtime-backed table path")] },
1147
- ],
1148
- },
1149
- {
1150
- rowId: "ptr-2",
1151
- isHeader: false,
1152
- cells: [
1153
- { cellId: "ptr-2-1", colSpan: 1, rowSpan: 1, segments: [text("ptr-2-1-s1", "Header field runs")] },
1154
- { cellId: "ptr-2-2", colSpan: 1, rowSpan: 1, segments: [text("ptr-2-2-s1", "Preserved package part")], preserveOnly: true, preserveOnlyReason: "Content inside locked region" },
1155
- { cellId: "ptr-2-3", colSpan: 1, rowSpan: 1, segments: [text("ptr-2-3-s1", "Locked")], preserveOnly: true, preserveOnlyReason: "Content inside locked region" },
1156
- ],
1157
- },
1158
- {
1159
- rowId: "ptr-3",
1160
- isHeader: false,
1161
- cells: [
1162
- { cellId: "ptr-3-1", colSpan: 1, rowSpan: 1, segments: [text("ptr-3-1-s1", "Custom XML wrappers")] },
1163
- { cellId: "ptr-3-2", colSpan: 1, rowSpan: 1, segments: [text("ptr-3-2-s1", "Preserved package part")], preserveOnly: true, preserveOnlyReason: "Opaque package content" },
1164
- { cellId: "ptr-3-3", colSpan: 1, rowSpan: 1, segments: [text("ptr-3-3-s1", "Locked")], preserveOnly: true, preserveOnlyReason: "Opaque package content" },
1165
- ],
1166
- },
1167
- ],
1168
- });
1169
-
1170
- return {
1171
- id: "preserve-only-package",
1172
- title: "Preserve-Only Package",
1173
- sourceKind: "fixture",
1174
- defaultMarkupDisplay: "simple",
1175
- defaultViewMode: "page",
1176
- defaultRailTab: "health",
1177
- defaultTrackChangesEnabled: true,
1178
- snapshot: {
1179
- documentId: "doc-preserve",
1180
- sessionId: "session-pp-412",
1181
- sourceLabel: "F15-F20 preservation sample",
1182
- revisionToken: "rev-preserve-001",
1183
- isReady: true,
1184
- isDirty: false,
1185
- readOnly: false,
1186
- selection: collapsedSelection(0),
1187
- documentStats: { storyLength: _pos, commentCount: 1, revisionCount: 1, opaqueFragmentCount: 1 },
1188
- comments: {
1189
- openCommentIds: [],
1190
- resolvedCommentIds: [],
1191
- detachedCommentIds: ["preserve-c1"],
1192
- totalCount: 1,
1193
- threads: [c1],
1194
- },
1195
- trackedChanges: {
1196
- pendingChangeIds: [],
1197
- acceptedChangeIds: [],
1198
- rejectedChangeIds: [],
1199
- detachedChangeIds: ["preserve-r1"],
1200
- actionableChangeIds: [],
1201
- preserveOnlyChangeIds: ["preserve-r1"],
1202
- totalCount: 1,
1203
- revisions: [r1],
1204
- },
1205
- compatibility: {
1206
- blockExport: false,
1207
- blockExportReasons: [],
1208
- warningCount: 2,
1209
- errorCount: 0,
1210
- featureEntries: [
1211
- {
1212
- featureEntryId: "preserve-f1",
1213
- featureKey: "sections-notes-fields",
1214
- featureClass: "preserve-only",
1215
- message: "Sections, notes, and fields preserved",
1216
- summary: "Out-of-band content survives package round-trips but remains locked.",
1217
- },
1218
- {
1219
- featureEntryId: "preserve-f2",
1220
- featureKey: "custom-xml-unknown",
1221
- featureClass: "preserve-only",
1222
- message: "Custom XML and unknown OOXML retained",
1223
- summary: "Opaque package content is preserved with relationship and content-type fidelity.",
1224
- },
1225
- ],
1226
- },
1227
- warnings: [
1228
- {
1229
- warningId: "warn-preserve-font-1",
1230
- code: "font_substitution",
1231
- severity: "warning" as const,
1232
- message: "Embedded font \"Calibri Light\" not available in browser — using curated legal sans approximation",
1233
- source: "import",
1234
- },
1235
- {
1236
- warningId: "warn-preserve-ooxml-1",
1237
- code: "unsupported_ooxml_preserved",
1238
- severity: "warning" as const,
1239
- message: "Custom XML data bindings preserved as opaque package content",
1240
- source: "preservation",
1241
- },
1242
- ],
1243
- commandState: { canUndo: false, canRedo: false, readOnly: false },
1244
- surface: {
1245
- storySize: _pos,
1246
- plainText: "",
1247
- blocks: [h1, p1, p2, locked, table],
1248
- lockedFragmentIds: ["frag-preserve-locked-1"],
1249
- },
1250
- },
1251
- commentDecorations: [
1252
- { commentId: "preserve-c1", segmentIds: ["preserve-p1-s2"] },
1253
- ],
1254
- revisionDecorations: [],
1255
- };
1256
- }
1257
-
1258
- function buildMalformedBlocked(): DemoSession {
1259
- resetPos();
1260
-
1261
- const fatalError: EditorError = {
1262
- errorId: "fatal-err-1",
1263
- code: "package_corrupt",
1264
- message: "The editor cannot safely reopen or rewrite this package without violating the trust contract.",
1265
- isFatal: true,
1266
- source: "import",
1267
- };
1268
-
1269
- const callout = protoCallout(
1270
- "fatal-callout",
1271
- "danger",
1272
- "Export blocked",
1273
- "The package import failed closed because required relationships or parts were malformed. The session remains readable for diagnosis only.",
1274
- );
1275
-
1276
- const locked = opaque(
1277
- "fatal-locked",
1278
- "Read-only diagnostics surface",
1279
- "Blocked sessions remain controlled and legible instead of crashing into a raw error dump.",
1280
- );
1281
-
1282
- return {
1283
- id: "malformed-blocked",
1284
- title: "Malformed / Blocked",
1285
- sourceKind: "fixture",
1286
- defaultMarkupDisplay: "clean",
1287
- defaultViewMode: "page",
1288
- defaultRailTab: "health",
1289
- defaultTrackChangesEnabled: false,
1290
- snapshot: {
1291
- documentId: "doc-malformed",
1292
- sessionId: "session-mb-021",
1293
- sourceLabel: "F21 malformed package",
1294
- revisionToken: "rev-malformed-001",
1295
- isReady: true,
1296
- isDirty: false,
1297
- readOnly: true,
1298
- selection: collapsedSelection(0),
1299
- documentStats: { storyLength: _pos, commentCount: 0, revisionCount: 0, opaqueFragmentCount: 1 },
1300
- comments: {
1301
- openCommentIds: [],
1302
- resolvedCommentIds: [],
1303
- detachedCommentIds: [],
1304
- totalCount: 0,
1305
- threads: [],
1306
- },
1307
- trackedChanges: {
1308
- pendingChangeIds: [],
1309
- acceptedChangeIds: [],
1310
- rejectedChangeIds: [],
1311
- detachedChangeIds: [],
1312
- actionableChangeIds: [],
1313
- preserveOnlyChangeIds: [],
1314
- totalCount: 0,
1315
- revisions: [],
1316
- },
1317
- compatibility: {
1318
- blockExport: true,
1319
- blockExportReasons: ["Package relationship integrity failed"],
1320
- warningCount: 0,
1321
- errorCount: 1,
1322
- featureEntries: [
1323
- {
1324
- featureEntryId: "fatal-f1",
1325
- featureKey: "package-integrity",
1326
- featureClass: "unsupported-fatal",
1327
- message: "Package relationship integrity failed",
1328
- summary: "Export remains blocked until the source document is replaced with a valid OPC package.",
1329
- },
1330
- ],
1331
- },
1332
- warnings: [],
1333
- fatalError,
1334
- commandState: { canUndo: false, canRedo: false, readOnly: true },
1335
- surface: {
1336
- storySize: _pos,
1337
- plainText: "",
1338
- blocks: [callout, locked],
1339
- lockedFragmentIds: ["frag-fatal-locked"],
1340
- },
1341
- },
1342
- commentDecorations: [],
1343
- revisionDecorations: [],
1344
- };
1345
- }
1346
-
1347
- function buildPilotS02(): DemoSession {
1348
- resetPos();
1349
-
1350
- const c1: PrototypeCommentThread = {
1351
- commentId: "pilot-c1",
1352
- status: "open",
1353
- anchor: rangeAnchor(70, 96),
1354
- excerpt: "commercial deployment freeze",
1355
- entryCount: 2,
1356
- createdAt: "Today · 14:08",
1357
- createdBy: "Mina Cole",
1358
- warningCount: 0,
1359
- anchorLabel: "Clause 7.4",
1360
- isActive: false,
1361
- body: "This comment is intentionally long enough to test the rail card layout and the relationship between summary text and full thread detail.",
1362
- responses: [
1363
- { author: "Owen Reed", timestamp: "Today · 14:14", body: "Use this thread to judge whether the rail remains readable during longer pilot tasks." },
1364
- ],
1365
- };
1366
-
1367
- const r1: PrototypeRevisionEntry = {
1368
- revisionId: "pilot-r1",
1369
- kind: "deletion",
1370
- label: "Deletion",
1371
- status: "active",
1372
- actionability: "actionable",
1373
- anchor: rangeAnchor(25, 51),
1374
- anchorLabel: "Clause 7.4",
1375
- createdAt: "Today · 13:55",
1376
- authorId: "mina-cole",
1377
- warningCount: 0,
1378
- canAccept: true,
1379
- canReject: true,
1380
- excerpt: "exclusive deployment freeze",
1381
- detail: "Supported inline revision, stays actionable.",
1382
- };
1383
-
1384
- const r2: PrototypeRevisionEntry = {
1385
- revisionId: "pilot-r2",
1386
- kind: "insertion",
1387
- label: "Imported preserve-only note",
1388
- status: "detached",
1389
- actionability: "preserve-only",
1390
- anchor: detachedAnchor(0, 0),
1391
- anchorLabel: "Footnote note",
1392
- createdAt: "Source metadata",
1393
- authorId: "imported-source",
1394
- warningCount: 1,
1395
- canAccept: false,
1396
- canReject: false,
1397
- preserveOnlyReason: "Imported descendant outside supported slice",
1398
- excerpt: "preserved imported review descendant",
1399
- detail: "A preserved imported descendant remains visible in the rail but never masquerades as a normal action.",
1400
- };
1401
-
1402
- const h1Segs = [text("pilot-h1-s1", "Clause 7. Operational Freeze")];
1403
- const h1 = para("pilot-h1", "Heading1", h1Segs);
1404
-
1405
- const p1Segs = [
1406
- text("pilot-p1-s1", "Customer may request a "),
1407
- text("pilot-p1-s2", "exclusive deployment freeze"),
1408
- text("pilot-p1-s3", " during a critical release period, subject to a "),
1409
- text("pilot-p1-s4", "commercial deployment freeze"),
1410
- text("pilot-p1-s5", " approval workflow."),
1411
- ];
1412
- const p1 = para("pilot-p1", undefined, p1Segs);
1413
-
1414
- const callout = protoCallout(
1415
- "pilot-callout",
1416
- "warning",
1417
- "Imported preserve-only review descendant",
1418
- "Some source review markup remains visible only as preserved evidence and warning-backed health metadata.",
1419
- );
1420
-
1421
- const locked = opaque(
1422
- "pilot-locked",
1423
- "Locked scenario note region",
1424
- "Preserved note content that must survive export without becoming normal editable document content.",
1425
- );
1426
-
1427
- return {
1428
- id: "pilot-s02",
1429
- title: "Pilot Scenario · S02",
1430
- sourceKind: "scenario",
1431
- defaultMarkupDisplay: "simple",
1432
- defaultViewMode: "canvas",
1433
- defaultRailTab: "changes",
1434
- defaultTrackChangesEnabled: true,
1435
- snapshot: {
1436
- documentId: "doc-pilot",
1437
- sessionId: "session-s02-901",
1438
- sourceLabel: "S02 partner licence redlines",
1439
- revisionToken: "rev-pilot-001",
1440
- isReady: true,
1441
- isDirty: false,
1442
- readOnly: false,
1443
- selection: collapsedSelection(0),
1444
- documentStats: { storyLength: _pos, commentCount: 1, revisionCount: 2, opaqueFragmentCount: 1 },
1445
- comments: {
1446
- openCommentIds: ["pilot-c1"],
1447
- resolvedCommentIds: [],
1448
- detachedCommentIds: [],
1449
- totalCount: 1,
1450
- threads: [c1],
1451
- },
1452
- trackedChanges: {
1453
- pendingChangeIds: ["pilot-r1"],
1454
- acceptedChangeIds: [],
1455
- rejectedChangeIds: [],
1456
- detachedChangeIds: ["pilot-r2"],
1457
- actionableChangeIds: ["pilot-r1"],
1458
- preserveOnlyChangeIds: ["pilot-r2"],
1459
- totalCount: 2,
1460
- revisions: [r1, r2],
1461
- },
1462
- compatibility: {
1463
- blockExport: false,
1464
- blockExportReasons: [],
1465
- warningCount: 1,
1466
- errorCount: 0,
1467
- featureEntries: [
1468
- {
1469
- featureEntryId: "pilot-f1",
1470
- featureKey: "mixed-markup",
1471
- featureClass: "preserve-only",
1472
- message: "Supported and preserve-only markup coexist",
1473
- summary: "Inline revisions stay actionable while some imported descendants remain preserved and locked.",
1474
- },
1475
- {
1476
- featureEntryId: "pilot-f2",
1477
- featureKey: "scenario-evidence",
1478
- featureClass: "supported-roundtrip",
1479
- message: "Scenario evidence stays separate from release-gate fixtures",
1480
- summary: "Representative scenarios inform pilot work without rewriting the frozen fixture registry.",
1481
- },
1482
- ],
1483
- },
1484
- warnings: [],
1485
- commandState: { canUndo: false, canRedo: false, readOnly: false },
1486
- surface: {
1487
- storySize: _pos,
1488
- plainText: "",
1489
- blocks: [h1, p1, callout, locked],
1490
- lockedFragmentIds: ["frag-pilot-locked"],
1491
- },
1492
- },
1493
- commentDecorations: [
1494
- { commentId: "pilot-c1", segmentIds: ["pilot-p1-s4"] },
1495
- ],
1496
- revisionDecorations: [
1497
- { revisionId: "pilot-r1", kind: "deletion", segmentIds: ["pilot-p1-s2"] },
1498
- ],
1499
- };
1500
- }
1501
-
1502
- // ─── Catalog ───
1503
-
1504
- const demoSessions: DemoSession[] = [
1505
- buildCleanContractReview(),
1506
- buildCommentNegotiation(),
1507
- buildRedlineNegotiation(),
1508
- buildPreserveOnlyPackage(),
1509
- buildMalformedBlocked(),
1510
- buildPilotS02(),
1511
- ];
1512
-
1513
- export function getDemoCatalogResponse(): DemoCatalogResponse {
1514
- return { sessions: demoSessions };
1515
- }
1516
-
1517
- export function getDemoSessionById(id: string): DemoSession | undefined {
1518
- return demoSessions.find((session) => session.id === id);
1519
- }