@beyondwork/docx-react-component 1.0.0 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (560) hide show
  1. package/README.md +44 -104
  2. package/package.json +66 -15
  3. package/src/api/public-types.ts +1 -1
  4. package/src/compare/diff-engine.ts +530 -0
  5. package/src/compare/export-redlines.ts +162 -0
  6. package/src/compare/snapshot.ts +37 -0
  7. package/src/core/commands/index.ts +1 -1
  8. package/src/core/state/editor-state.ts +2 -2
  9. package/src/index.ts +45 -0
  10. package/src/legal/bookmarks.ts +196 -0
  11. package/src/legal/cross-references.ts +356 -0
  12. package/src/legal/defined-terms.ts +203 -0
  13. package/src/runtime/document-runtime.ts +3 -5
  14. package/src/runtime/table-commands.ts +4 -1
  15. package/src/runtime/table-schema.ts +17 -2
  16. package/src/runtime/virtualized-rendering.ts +258 -0
  17. package/src/ui/WordReviewEditor.tsx +256 -35
  18. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +2 -2
  19. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +16 -2
  20. package/.codex/config.toml +0 -5
  21. package/.corepack/v1/pnpm/10.30.3/.corepack +0 -1
  22. package/.corepack/v1/pnpm/10.30.3/LICENSE +0 -22
  23. package/.corepack/v1/pnpm/10.30.3/README.md +0 -240
  24. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp +0 -6
  25. package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp.cmd +0 -5
  26. package/.corepack/v1/pnpm/10.30.3/dist/pnpm.cjs +0 -195400
  27. package/.corepack/v1/pnpm/10.30.3/dist/pnpmrc +0 -2
  28. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-arm64-2HJ4WGO6.node +0 -0
  29. package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-x64-3G3H6IW4.node +0 -0
  30. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-arm64-msvc-Q6BARPPB.node +0 -0
  31. package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-x64-msvc-J2TZHRQI.node +0 -0
  32. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.bash +0 -31
  33. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.fish +0 -22
  34. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.ps1 +0 -193
  35. package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.zsh +0 -27
  36. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
  37. package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
  38. package/.corepack/v1/pnpm/10.30.3/dist/worker.js +0 -10119
  39. package/.corepack/v1/pnpm/10.30.3/package.json +0 -192
  40. package/.cursor/mcp.json +0 -7
  41. package/.github/workflows/ci.yml +0 -35
  42. package/.mcp.json +0 -7
  43. package/.openclaw/workspace-state.json +0 -4
  44. package/.pnpmrc.json +0 -1
  45. package/.wave-launch.sh +0 -7
  46. package/.workspace-marker +0 -1
  47. package/AGENTS.md +0 -78
  48. package/CHANGELOG.md +0 -177
  49. package/DESIGN.md +0 -929
  50. package/HEARTBEAT.md +0 -7
  51. package/IDENTITY.md +0 -23
  52. package/SOUL.md +0 -36
  53. package/TOOLS.md +0 -40
  54. package/USER.md +0 -17
  55. package/docs/README.md +0 -107
  56. package/docs/agents/wave-cont-eval-role.md +0 -36
  57. package/docs/agents/wave-cont-qa-role.md +0 -52
  58. package/docs/agents/wave-deploy-verifier-role.md +0 -34
  59. package/docs/agents/wave-design-role.md +0 -47
  60. package/docs/agents/wave-documentation-role.md +0 -34
  61. package/docs/agents/wave-infra-role.md +0 -34
  62. package/docs/agents/wave-integration-role.md +0 -37
  63. package/docs/agents/wave-launcher-role.md +0 -41
  64. package/docs/agents/wave-orchestrator-role.md +0 -52
  65. package/docs/agents/wave-planner-role.md +0 -39
  66. package/docs/agents/wave-security-role.md +0 -40
  67. package/docs/architecture/docx/README.md +0 -10
  68. package/docs/architecture/future/README.md +0 -8
  69. package/docs/architecture/ooxml-upgrade-analysis.md +0 -134
  70. package/docs/architecture/platform/shared-openxml-editor-platform.md +0 -153
  71. package/docs/architecture/xlsx/canonical-workbook-model-and-commands.md +0 -187
  72. package/docs/architecture/xlsx/spreadsheet-editor-frontend-architecture.md +0 -150
  73. package/docs/comment-redline-overview.md +0 -350
  74. package/docs/concepts/context7-vs-skills.md +0 -118
  75. package/docs/concepts/operating-modes.md +0 -91
  76. package/docs/concepts/runtime-agnostic-orchestration.md +0 -111
  77. package/docs/concepts/what-is-a-wave.md +0 -217
  78. package/docs/context7/bundles.json +0 -222
  79. package/docs/context7/planner-agent/README.md +0 -28
  80. package/docs/context7/planner-agent/manifest.json +0 -83
  81. package/docs/context7/planner-agent/papers/cooperbench-why-coding-agents-cannot-be-your-teammates-yet.md +0 -3283
  82. package/docs/context7/planner-agent/papers/dova-deliberation-first-multi-agent-orchestration-for-autonomous-research-automation.md +0 -1699
  83. package/docs/context7/planner-agent/papers/dpbench-large-language-models-struggle-with-simultaneous-coordination.md +0 -2251
  84. package/docs/context7/planner-agent/papers/incremental-planning-to-control-a-blackboard-based-problem-solver.md +0 -1729
  85. package/docs/context7/planner-agent/papers/silo-bench-a-scalable-environment-for-evaluating-distributed-coordination-in-multi-agent-llm-systems.md +0 -3747
  86. package/docs/context7/planner-agent/papers/todoevolve-learning-to-architect-agent-planning-systems.md +0 -1675
  87. package/docs/context7/planner-agent/papers/verified-multi-agent-orchestration-a-plan-execute-verify-replan-framework-for-complex-query-resolution.md +0 -1173
  88. package/docs/context7/planner-agent/papers/why-do-multi-agent-llm-systems-fail.md +0 -5211
  89. package/docs/context7/planner-agent/topics/planning-and-orchestration.md +0 -24
  90. package/docs/evals/arm-templates/README.md +0 -13
  91. package/docs/evals/arm-templates/full-wave.json +0 -15
  92. package/docs/evals/arm-templates/single-agent.json +0 -15
  93. package/docs/evals/benchmark-catalog.json +0 -670
  94. package/docs/evals/cases/README.md +0 -47
  95. package/docs/evals/cases/wave-blackboard-inbox-targeting.json +0 -73
  96. package/docs/evals/cases/wave-contradiction-conflict.json +0 -104
  97. package/docs/evals/cases/wave-expert-routing-preservation.json +0 -69
  98. package/docs/evals/cases/wave-hidden-profile-private-evidence.json +0 -81
  99. package/docs/evals/cases/wave-premature-closure-guard.json +0 -71
  100. package/docs/evals/cases/wave-silo-cross-agent-state.json +0 -77
  101. package/docs/evals/cases/wave-simultaneous-lockstep.json +0 -92
  102. package/docs/evals/external-benchmarks.json +0 -85
  103. package/docs/evals/external-command-config.sample.json +0 -9
  104. package/docs/evals/external-command-config.swe-bench-pro.json +0 -8
  105. package/docs/evals/pilots/README.md +0 -47
  106. package/docs/evals/pilots/swe-bench-pro-public-full-wave-review-10.json +0 -64
  107. package/docs/evals/pilots/swe-bench-pro-public-pilot.json +0 -111
  108. package/docs/evals/wave-benchmark-program.md +0 -302
  109. package/docs/guides/planner.md +0 -220
  110. package/docs/guides/recommendations-0.8.9.md +0 -133
  111. package/docs/guides/signal-wrappers.md +0 -165
  112. package/docs/guides/terminal-surfaces.md +0 -96
  113. package/docs/image copy.png +0 -0
  114. package/docs/image.png +0 -0
  115. package/docs/images/image.png +0 -0
  116. package/docs/legal-feedback-architecture.md +0 -498
  117. package/docs/plans/component-cutover-matrix.json +0 -1072
  118. package/docs/plans/component-cutover-matrix.md +0 -307
  119. package/docs/plans/context7-wave-orchestrator.md +0 -155
  120. package/docs/plans/current-state.md +0 -198
  121. package/docs/plans/docx/README.md +0 -9
  122. package/docs/plans/examples/wave-benchmark-improvement.md +0 -108
  123. package/docs/plans/examples/wave-example-live-proof.md +0 -435
  124. package/docs/plans/master-plan.md +0 -224
  125. package/docs/plans/migration.md +0 -538
  126. package/docs/plans/operations/README.md +0 -7
  127. package/docs/plans/operations/wave-10-word-certification.md +0 -87
  128. package/docs/plans/operations/wave-8-railway-staging.md +0 -153
  129. package/docs/plans/operations/wave-9-manual-certification.md +0 -73
  130. package/docs/plans/platform/README.md +0 -9
  131. package/docs/plans/reference/legal-checklist-coverage.md +0 -258
  132. package/docs/plans/wave-orchestrator.md +0 -423
  133. package/docs/plans/waves/README.md +0 -75
  134. package/docs/plans/waves/completed/wave-0.md +0 -195
  135. package/docs/plans/waves/completed/wave-1.md +0 -379
  136. package/docs/plans/waves/completed/wave-10.md +0 -670
  137. package/docs/plans/waves/completed/wave-11.md +0 -335
  138. package/docs/plans/waves/completed/wave-12.md +0 -417
  139. package/docs/plans/waves/completed/wave-13.md +0 -316
  140. package/docs/plans/waves/completed/wave-14.md +0 -319
  141. package/docs/plans/waves/completed/wave-15.md +0 -321
  142. package/docs/plans/waves/completed/wave-16.md +0 -316
  143. package/docs/plans/waves/completed/wave-17.md +0 -331
  144. package/docs/plans/waves/completed/wave-18.md +0 -328
  145. package/docs/plans/waves/completed/wave-2.md +0 -438
  146. package/docs/plans/waves/completed/wave-3.md +0 -435
  147. package/docs/plans/waves/completed/wave-4.md +0 -430
  148. package/docs/plans/waves/completed/wave-5.md +0 -430
  149. package/docs/plans/waves/completed/wave-6.md +0 -430
  150. package/docs/plans/waves/completed/wave-7.md +0 -526
  151. package/docs/plans/waves/completed/wave-8.md +0 -596
  152. package/docs/plans/waves/completed/wave-9.md +0 -552
  153. package/docs/plans/waves/deferred/README.md +0 -14
  154. package/docs/plans/waves/deferred/encrypted-intake-contracts.md +0 -282
  155. package/docs/plans/waves/deferred/legal-feedback-wave-expansion.md +0 -308
  156. package/docs/plans/waves/deferred/wave-encrypted-intake.md +0 -451
  157. package/docs/plans/waves/design/README.md +0 -5
  158. package/docs/plans/waves/design/wave-1-a1.md +0 -309
  159. package/docs/plans/waves/reviews/README.md +0 -5
  160. package/docs/plans/waves/reviews/wave-0-cont-qa.md +0 -151
  161. package/docs/plans/waves/reviews/wave-1-cont-qa.md +0 -46
  162. package/docs/plans/waves/reviews/wave-10-accessibility-and-design.md +0 -51
  163. package/docs/plans/waves/reviews/wave-10-cont-qa.md +0 -24
  164. package/docs/plans/waves/reviews/wave-10-dashboard-proof.md +0 -46
  165. package/docs/plans/waves/reviews/wave-10-performance-signoff.md +0 -55
  166. package/docs/plans/waves/reviews/wave-10-regression-proof.md +0 -23
  167. package/docs/plans/waves/reviews/wave-10-release-audit.md +0 -31
  168. package/docs/plans/waves/reviews/wave-10-service-proof.md +0 -83
  169. package/docs/plans/waves/reviews/wave-10-word-certification.md +0 -31
  170. package/docs/plans/waves/reviews/wave-18-ai-contract-closure.md +0 -277
  171. package/docs/plans/waves/reviews/wave-18-cont-qa.md +0 -255
  172. package/docs/plans/waves/reviews/wave-18-parity-proof.md +0 -271
  173. package/docs/plans/waves/reviews/wave-19-cont-qa.md +0 -59
  174. package/docs/plans/waves/reviews/wave-2-cont-qa.md +0 -72
  175. package/docs/plans/waves/reviews/wave-20-cont-qa.md +0 -60
  176. package/docs/plans/waves/reviews/wave-25-cont-qa.md +0 -48
  177. package/docs/plans/waves/reviews/wave-28-cont-qa.md +0 -46
  178. package/docs/plans/waves/reviews/wave-29-cont-qa.md +0 -53
  179. package/docs/plans/waves/reviews/wave-3-cont-qa.md +0 -53
  180. package/docs/plans/waves/reviews/wave-3-core-proof.md +0 -77
  181. package/docs/plans/waves/reviews/wave-3-validator-proof.md +0 -73
  182. package/docs/plans/waves/reviews/wave-32-cont-qa.md +0 -43
  183. package/docs/plans/waves/reviews/wave-33-cont-qa.md +0 -526
  184. package/docs/plans/waves/reviews/wave-34-cont-qa.md +0 -100
  185. package/docs/plans/waves/reviews/wave-35-cont-qa.md +0 -145
  186. package/docs/plans/waves/reviews/wave-4-cont-qa.md +0 -47
  187. package/docs/plans/waves/reviews/wave-4-structure-proof.md +0 -69
  188. package/docs/plans/waves/reviews/wave-5-comment-proof.md +0 -158
  189. package/docs/plans/waves/reviews/wave-5-cont-qa.md +0 -68
  190. package/docs/plans/waves/reviews/wave-6-cont-qa.md +0 -416
  191. package/docs/plans/waves/reviews/wave-6-redline-proof.md +0 -130
  192. package/docs/plans/waves/reviews/wave-7-cont-qa.md +0 -82
  193. package/docs/plans/waves/reviews/wave-7-ooxml-compliance.md +0 -85
  194. package/docs/plans/waves/reviews/wave-7-preservation-proof.md +0 -119
  195. package/docs/plans/waves/reviews/wave-7-trust-ux.md +0 -87
  196. package/docs/plans/waves/reviews/wave-8-accessibility-and-design.md +0 -128
  197. package/docs/plans/waves/reviews/wave-8-cont-qa.md +0 -92
  198. package/docs/plans/waves/reviews/wave-8-live-proof.md +0 -140
  199. package/docs/plans/waves/reviews/wave-8-security.md +0 -47
  200. package/docs/plans/waves/reviews/wave-9-editor-embedding.md +0 -39
  201. package/docs/plans/waves/reviews/wave-9-fixture-runner.md +0 -56
  202. package/docs/plans/waves/reviews/wave-9-live-proof.md +0 -105
  203. package/docs/plans/waves/reviews/wave-9-usability-and-performance.md +0 -152
  204. package/docs/plans/waves/specs/README.md +0 -5
  205. package/docs/plans/waves/specs/wave-1-component-boundaries.md +0 -322
  206. package/docs/plans/waves/specs/wave-1-ooxml-contracts.md +0 -323
  207. package/docs/plans/waves/specs/wave-1-review-and-ui-contracts.md +0 -339
  208. package/docs/plans/waves/specs/wave-1-runtime-contracts.md +0 -509
  209. package/docs/plans/waves/wave-19.md +0 -341
  210. package/docs/plans/waves/wave-20.md +0 -308
  211. package/docs/plans/waves/wave-21.md +0 -289
  212. package/docs/plans/waves/wave-22.md +0 -221
  213. package/docs/plans/waves/wave-23.md +0 -295
  214. package/docs/plans/waves/wave-24.md +0 -286
  215. package/docs/plans/waves/wave-25.md +0 -313
  216. package/docs/plans/waves/wave-26.md +0 -300
  217. package/docs/plans/waves/wave-27.md +0 -299
  218. package/docs/plans/waves/wave-28.md +0 -368
  219. package/docs/plans/waves/wave-29.md +0 -303
  220. package/docs/plans/waves/wave-30.md +0 -307
  221. package/docs/plans/waves/wave-31.md +0 -231
  222. package/docs/plans/waves/wave-32.md +0 -152
  223. package/docs/plans/waves/wave-33.md +0 -147
  224. package/docs/plans/waves/wave-34.md +0 -148
  225. package/docs/plans/waves/wave-35.md +0 -141
  226. package/docs/plans/waves/wave-36.md +0 -146
  227. package/docs/plans/xlsx/README.md +0 -14
  228. package/docs/plans/xlsx/xlsx-fixture-corpus-and-certification-plan.md +0 -126
  229. package/docs/reference/cli-reference.md +0 -600
  230. package/docs/reference/coordination-and-closure.md +0 -487
  231. package/docs/reference/deep-research-report (15).md +0 -25
  232. package/docs/reference/docx/README.md +0 -10
  233. package/docs/reference/legal-checklist.md +0 -445
  234. package/docs/reference/live-proof-waves.md +0 -199
  235. package/docs/reference/ooxml-compliance.md +0 -129
  236. package/docs/reference/ooxml-feature-parity-matrix.md +0 -172
  237. package/docs/reference/platform/shared-ooxml-platform-guidance.md +0 -77
  238. package/docs/reference/prototype-agent-prompt-legal-fidelity.md +0 -155
  239. package/docs/reference/public-api.md +0 -456
  240. package/docs/reference/repository-guidance.md +0 -58
  241. package/docs/reference/runtime-config/README.md +0 -182
  242. package/docs/reference/runtime-config/claude.md +0 -110
  243. package/docs/reference/runtime-config/codex.md +0 -82
  244. package/docs/reference/runtime-config/opencode.md +0 -93
  245. package/docs/reference/sample-waves.md +0 -105
  246. package/docs/reference/skills.md +0 -237
  247. package/docs/reference/templates/AGENTS.md +0 -78
  248. package/docs/reference/templates/HEARTBEAT.md +0 -7
  249. package/docs/reference/templates/IDENTITY.md +0 -23
  250. package/docs/reference/templates/SOUL.md +0 -36
  251. package/docs/reference/templates/TOOLS.md +0 -40
  252. package/docs/reference/templates/USER.md +0 -17
  253. package/docs/reference/wave-control.md +0 -184
  254. package/docs/reference/wave-planning-lessons.md +0 -167
  255. package/docs/reference/word-review-editor-frontend-architecture.md +0 -479
  256. package/docs/reference/word-review-editor-ux-guide.md +0 -253
  257. package/docs/reference/xlsx/xlsx-ooxml-compliance.md +0 -137
  258. package/docs/research/agent-context-sources.md +0 -178
  259. package/docs/research/coordination-failure-review.md +0 -290
  260. package/docs/research/docx-react-component/Canonical Document Schema Specification for a React-based Word-compatible Editor.md +0 -2317
  261. package/docs/research/docx-react-component/Feature Compatibility Matrix for a React Word Compatible Legal Editor v1.md +0 -219
  262. package/docs/research/docx-react-component/React Component Architecture and Front-End Structure Specification for a Word-Compatible Legal Review Editor.md +0 -1112
  263. package/docs/research/docx-react-component/document_compatibility_and_testing_spec.md +0 -751
  264. package/docs/research/xlsx/raw/README.md +0 -13
  265. package/docs/roadmap.md +0 -174
  266. package/docs/superpowers/plans/2026-03-28-harness-control-bar.md +0 -677
  267. package/docs/superpowers/specs/2026-03-28-harness-control-bar-design.md +0 -274
  268. package/docs/xlsx-react/README.md +0 -38
  269. package/docs/xlsx-react/agent-llm-interaction-layer-docx-xlsx.md +0 -621
  270. package/docs/xlsx-react/canonical-workbook-model-and-commands.md +0 -948
  271. package/docs/xlsx-react/shared-openxml-editor-platform-docx-xlsx.md +0 -228
  272. package/docs/xlsx-react/spreadsheet-editor-component-architecture.md +0 -809
  273. package/docs/xlsx-react/spreadsheet-editor-frontend-architecture.md +0 -537
  274. package/docs/xlsx-react/spreadsheet-editor-ux-guide.md +0 -520
  275. package/docs/xlsx-react/xlsx-editor-research-pack.md +0 -871
  276. package/docs/xlsx-react/xlsx-fixture-corpus-and-certification-plan.md +0 -436
  277. package/docs/xlsx-react/xlsx-ooxml-compliance.md +0 -320
  278. package/examples/README.md +0 -16
  279. package/memory/MEMORY.md +0 -24
  280. package/pnpm-workspace.yaml +0 -4
  281. package/scripts/check-no-authored-js.sh +0 -13
  282. package/scripts/context7-api-check.sh +0 -65
  283. package/scripts/context7-export-env.sh +0 -42
  284. package/scripts/run-context7-mcp.sh +0 -8
  285. package/scripts/run-workspace-tests.sh +0 -15
  286. package/scripts/start-wave-10-local.sh +0 -189
  287. package/scripts/wave-agent-attach.sh +0 -47
  288. package/scripts/wave-auto-answer.sh +0 -118
  289. package/scripts/wave-dashboard-attach.sh +0 -13
  290. package/scripts/wave-launch.sh +0 -273
  291. package/scripts/wave-overnight-supervisor.sh +0 -145
  292. package/scripts/wave-status.sh +0 -379
  293. package/scripts/wave-watch.sh +0 -231
  294. package/services/README.md +0 -17
  295. package/services/openxml-validator/Dockerfile +0 -29
  296. package/services/openxml-validator/OpenXmlValidator.Api.csproj +0 -12
  297. package/services/openxml-validator/Program.cs +0 -436
  298. package/services/openxml-validator/README.md +0 -152
  299. package/services/openxml-validator/railway.json +0 -16
  300. package/services/react-word-editor/.tmp-a4/src/api/public-types.ts +0 -318
  301. package/services/react-word-editor/.tmp-a4/src/ui/WordReviewEditor.tsx +0 -1302
  302. package/services/react-word-editor/.tmp-a4/src/ui/editor-surface/editor-surface.tsx +0 -546
  303. package/services/react-word-editor/.tmp-a4/test/ui/word-review-editor.test.tsx +0 -146
  304. package/services/react-word-editor/.tmp-a4-build/src/api/public-types.js +0 -2
  305. package/services/react-word-editor/.tmp-a4-build/src/ui/WordReviewEditor.js +0 -818
  306. package/services/react-word-editor/.tmp-a4-build/src/ui/editor-surface/editor-surface.js +0 -229
  307. package/services/react-word-editor/.tmp-a4-build/test/ui/word-review-editor.test.js +0 -121
  308. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.json +0 -21
  309. package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.tsbuildinfo +0 -1
  310. package/services/react-word-editor/Dockerfile +0 -26
  311. package/services/react-word-editor/README.md +0 -254
  312. package/services/react-word-editor/app/api/certification/route.ts +0 -79
  313. package/services/react-word-editor/app/api/demo-sessions/route.ts +0 -109
  314. package/services/react-word-editor/app/api/deploy-health/route.ts +0 -23
  315. package/services/react-word-editor/app/api/exports/[exportId]/route.ts +0 -34
  316. package/services/react-word-editor/app/api/exports/route.ts +0 -81
  317. package/services/react-word-editor/app/api/fixtures/[fixtureId]/run/route.ts +0 -100
  318. package/services/react-word-editor/app/api/health/route.ts +0 -70
  319. package/services/react-word-editor/app/api/runs/[runId]/route.ts +0 -36
  320. package/services/react-word-editor/app/api/scenarios/[scenarioId]/run/route.ts +0 -85
  321. package/services/react-word-editor/app/api/sessions/[sessionId]/route.ts +0 -199
  322. package/services/react-word-editor/app/api/sessions/[sessionId]/source/route.ts +0 -45
  323. package/services/react-word-editor/app/api/uploads/route.ts +0 -70
  324. package/services/react-word-editor/app/api/validate/route.ts +0 -310
  325. package/services/react-word-editor/app/certification/[runId]/page.tsx +0 -14
  326. package/services/react-word-editor/app/certification/page.tsx +0 -32
  327. package/services/react-word-editor/app/dashboard/page.tsx +0 -7
  328. package/services/react-word-editor/app/demo/page.tsx +0 -30
  329. package/services/react-word-editor/app/demo/prototype-client.tsx +0 -1080
  330. package/services/react-word-editor/app/editor/[sessionId]/page.tsx +0 -33
  331. package/services/react-word-editor/app/fixtures/page.tsx +0 -7
  332. package/services/react-word-editor/app/globals.css +0 -121
  333. package/services/react-word-editor/app/layout.tsx +0 -32
  334. package/services/react-word-editor/app/page.tsx +0 -30
  335. package/services/react-word-editor/app/runs/[runId]/page.tsx +0 -34
  336. package/services/react-word-editor/app/wave-10-word-review/page.tsx +0 -7
  337. package/services/react-word-editor/components/harness-control-bar.tsx +0 -289
  338. package/services/react-word-editor/components/harness-editor-session-client.tsx +0 -1214
  339. package/services/react-word-editor/components/harness-workspace-page.tsx +0 -715
  340. package/services/react-word-editor/components/reduced-motion-toggle.tsx +0 -79
  341. package/services/react-word-editor/components/workspace-certification-panel.tsx +0 -307
  342. package/services/react-word-editor/lib/certification-bundle.ts +0 -796
  343. package/services/react-word-editor/lib/certification-store.ts +0 -661
  344. package/services/react-word-editor/lib/demo-fixtures.test.mjs +0 -195
  345. package/services/react-word-editor/lib/demo-fixtures.ts +0 -1519
  346. package/services/react-word-editor/lib/editor-session-summary.test.mjs +0 -68
  347. package/services/react-word-editor/lib/editor-session-summary.ts +0 -14
  348. package/services/react-word-editor/lib/editor-session.ts +0 -228
  349. package/services/react-word-editor/lib/exports-route.test.mjs +0 -32
  350. package/services/react-word-editor/lib/harness-client.ts +0 -347
  351. package/services/react-word-editor/lib/harness-config.json +0 -30
  352. package/services/react-word-editor/lib/harness-config.test.mjs +0 -31
  353. package/services/react-word-editor/lib/harness-config.ts +0 -21
  354. package/services/react-word-editor/lib/harness-editor-datastore.test.mjs +0 -220
  355. package/services/react-word-editor/lib/harness-editor-datastore.ts +0 -161
  356. package/services/react-word-editor/lib/private-mode.test.mjs +0 -42
  357. package/services/react-word-editor/lib/private-mode.ts +0 -61
  358. package/services/react-word-editor/lib/regression-report.test.mjs +0 -352
  359. package/services/react-word-editor/lib/regression-report.ts +0 -896
  360. package/services/react-word-editor/lib/run-artifacts.ts +0 -934
  361. package/services/react-word-editor/lib/run-history.ts +0 -755
  362. package/services/react-word-editor/lib/scenario-artifacts.test.mjs +0 -41
  363. package/services/react-word-editor/lib/scenario-artifacts.ts +0 -44
  364. package/services/react-word-editor/lib/storage.ts +0 -953
  365. package/services/react-word-editor/lib/validator-client.test.mjs +0 -54
  366. package/services/react-word-editor/lib/validator-client.ts +0 -95
  367. package/services/react-word-editor/lib/workspace-navigation.ts +0 -79
  368. package/services/react-word-editor/middleware.ts +0 -35
  369. package/services/react-word-editor/next-env.d.ts +0 -6
  370. package/services/react-word-editor/next.config.mjs +0 -15
  371. package/services/react-word-editor/package.json +0 -38
  372. package/services/react-word-editor/postcss.config.mjs +0 -8
  373. package/services/react-word-editor/railway.json +0 -21
  374. package/services/react-word-editor/scripts/wave-10-certification.mjs +0 -101
  375. package/services/react-word-editor/scripts/wave-9-live-usability-pilot.mjs +0 -911
  376. package/services/react-word-editor/tsconfig.json +0 -39
  377. package/services/react-word-editor/tsconfig.tsbuildinfo +0 -1
  378. package/skills/README.md +0 -48
  379. package/skills/domain-docx-compatibility/SKILL.md +0 -44
  380. package/skills/domain-docx-compatibility/skill.json +0 -19
  381. package/skills/domain-editor-architecture/SKILL.md +0 -49
  382. package/skills/domain-editor-architecture/skill.json +0 -19
  383. package/skills/domain-legal-review/SKILL.md +0 -39
  384. package/skills/domain-legal-review/skill.json +0 -19
  385. package/skills/provider-aws/SKILL.md +0 -117
  386. package/skills/provider-aws/adapters/claude.md +0 -1
  387. package/skills/provider-aws/adapters/codex.md +0 -1
  388. package/skills/provider-aws/references/service-verification.md +0 -39
  389. package/skills/provider-aws/skill.json +0 -54
  390. package/skills/provider-custom-deploy/SKILL.md +0 -64
  391. package/skills/provider-custom-deploy/skill.json +0 -50
  392. package/skills/provider-docker-compose/SKILL.md +0 -96
  393. package/skills/provider-docker-compose/adapters/local.md +0 -1
  394. package/skills/provider-docker-compose/skill.json +0 -53
  395. package/skills/provider-github-release/SKILL.md +0 -121
  396. package/skills/provider-github-release/adapters/claude.md +0 -1
  397. package/skills/provider-github-release/adapters/codex.md +0 -1
  398. package/skills/provider-github-release/skill.json +0 -55
  399. package/skills/provider-kubernetes/SKILL.md +0 -143
  400. package/skills/provider-kubernetes/adapters/claude.md +0 -1
  401. package/skills/provider-kubernetes/adapters/codex.md +0 -1
  402. package/skills/provider-kubernetes/references/kubectl-patterns.md +0 -58
  403. package/skills/provider-kubernetes/skill.json +0 -52
  404. package/skills/provider-railway/SKILL.md +0 -123
  405. package/skills/provider-railway/adapters/claude.md +0 -1
  406. package/skills/provider-railway/adapters/codex.md +0 -1
  407. package/skills/provider-railway/adapters/local.md +0 -1
  408. package/skills/provider-railway/adapters/opencode.md +0 -1
  409. package/skills/provider-railway/references/verification-commands.md +0 -39
  410. package/skills/provider-railway/skill.json +0 -71
  411. package/skills/provider-ssh-manual/SKILL.md +0 -97
  412. package/skills/provider-ssh-manual/skill.json +0 -54
  413. package/skills/repo-coding-rules/SKILL.md +0 -55
  414. package/skills/repo-coding-rules/skill.json +0 -34
  415. package/skills/role-cont-eval/SKILL.md +0 -91
  416. package/skills/role-cont-eval/adapters/codex.md +0 -1
  417. package/skills/role-cont-eval/skill.json +0 -36
  418. package/skills/role-cont-qa/SKILL.md +0 -100
  419. package/skills/role-cont-qa/adapters/claude.md +0 -1
  420. package/skills/role-cont-qa/skill.json +0 -36
  421. package/skills/role-deploy/SKILL.md +0 -97
  422. package/skills/role-deploy/skill.json +0 -36
  423. package/skills/role-design/SKILL.md +0 -50
  424. package/skills/role-design/skill.json +0 -36
  425. package/skills/role-documentation/SKILL.md +0 -76
  426. package/skills/role-documentation/skill.json +0 -36
  427. package/skills/role-implementation/SKILL.md +0 -45
  428. package/skills/role-implementation/skill.json +0 -36
  429. package/skills/role-infra/SKILL.md +0 -81
  430. package/skills/role-infra/skill.json +0 -36
  431. package/skills/role-integration/SKILL.md +0 -91
  432. package/skills/role-integration/skill.json +0 -36
  433. package/skills/role-planner/SKILL.md +0 -39
  434. package/skills/role-planner/skill.json +0 -21
  435. package/skills/role-research/SKILL.md +0 -65
  436. package/skills/role-research/skill.json +0 -36
  437. package/skills/role-security/SKILL.md +0 -60
  438. package/skills/role-security/skill.json +0 -36
  439. package/skills/runtime-claude/SKILL.md +0 -66
  440. package/skills/runtime-claude/skill.json +0 -36
  441. package/skills/runtime-codex/SKILL.md +0 -58
  442. package/skills/runtime-codex/skill.json +0 -36
  443. package/skills/runtime-local/SKILL.md +0 -46
  444. package/skills/runtime-local/skill.json +0 -36
  445. package/skills/runtime-opencode/SKILL.md +0 -58
  446. package/skills/runtime-opencode/skill.json +0 -36
  447. package/skills/signal-hygiene/SKILL.md +0 -51
  448. package/skills/signal-hygiene/skill.json +0 -20
  449. package/skills/tui-design/SKILL.md +0 -77
  450. package/skills/tui-design/references/tui-design.md +0 -259
  451. package/skills/tui-design/skill.json +0 -36
  452. package/skills/wave-core/SKILL.md +0 -141
  453. package/skills/wave-core/references/marker-syntax.md +0 -70
  454. package/skills/wave-core/skill.json +0 -35
  455. package/test/README.md +0 -16
  456. package/test/core/formatting-commands.test.ts +0 -285
  457. package/test/core/image-commands.test.ts +0 -298
  458. package/test/core/mapping.test.ts +0 -186
  459. package/test/core/text-commands.test.ts +0 -176
  460. package/test/fixtures/docx/F01-basic-contract.docx +0 -0
  461. package/test/fixtures/docx/F01-basic-contract.md +0 -33
  462. package/test/fixtures/docx/F02-headings-styles.docx +0 -0
  463. package/test/fixtures/docx/F02-headings-styles.md +0 -33
  464. package/test/fixtures/docx/F03-legal-outline-numbering.docx +0 -0
  465. package/test/fixtures/docx/F03-legal-outline-numbering.md +0 -34
  466. package/test/fixtures/docx/F04-restart-numbering-schedules.docx +0 -0
  467. package/test/fixtures/docx/F04-restart-numbering-schedules.md +0 -33
  468. package/test/fixtures/docx/F05-table-heavy-agreement.docx +0 -0
  469. package/test/fixtures/docx/F05-table-heavy-agreement.md +0 -34
  470. package/test/fixtures/docx/F06-merged-cells-signature-table.docx +0 -0
  471. package/test/fixtures/docx/F06-merged-cells-signature-table.md +0 -34
  472. package/test/fixtures/docx/F07-inline-images-exhibit.docx +0 -0
  473. package/test/fixtures/docx/F07-inline-images-exhibit.md +0 -34
  474. package/test/fixtures/docx/F08-hyperlinks.docx +0 -0
  475. package/test/fixtures/docx/F08-hyperlinks.md +0 -33
  476. package/test/fixtures/docx/F09-comments-single-paragraph.docx +0 -0
  477. package/test/fixtures/docx/F09-comments-single-paragraph.md +0 -33
  478. package/test/fixtures/docx/F10-threaded-comments-resolve.docx +0 -0
  479. package/test/fixtures/docx/F10-threaded-comments-resolve.md +0 -33
  480. package/test/fixtures/docx/F11-redlines-basic.docx +0 -0
  481. package/test/fixtures/docx/F11-redlines-basic.md +0 -33
  482. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.docx +0 -0
  483. package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.md +0 -33
  484. package/test/fixtures/docx/F13-comments-on-deleted-text.docx +0 -0
  485. package/test/fixtures/docx/F13-comments-on-deleted-text.md +0 -33
  486. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.docx +0 -0
  487. package/test/fixtures/docx/F14-revisions-in-tables-and-lists.md +0 -33
  488. package/test/fixtures/docx/F15-sections-headers-footers.docx +0 -0
  489. package/test/fixtures/docx/F15-sections-headers-footers.md +0 -33
  490. package/test/fixtures/docx/F16-footnotes-endnotes.docx +0 -0
  491. package/test/fixtures/docx/F16-footnotes-endnotes.md +0 -33
  492. package/test/fixtures/docx/F17-fields-and-toc.docx +0 -0
  493. package/test/fixtures/docx/F17-fields-and-toc.md +0 -33
  494. package/test/fixtures/docx/F18-content-controls-template.docx +0 -0
  495. package/test/fixtures/docx/F18-content-controls-template.md +0 -33
  496. package/test/fixtures/docx/F19-custom-xml-doc-assembly.docx +0 -0
  497. package/test/fixtures/docx/F19-custom-xml-doc-assembly.md +0 -35
  498. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.docx +0 -0
  499. package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.md +0 -33
  500. package/test/fixtures/docx/F21-malformed-broken-docx.docx +0 -0
  501. package/test/fixtures/docx/F21-malformed-broken-docx.md +0 -33
  502. package/test/fixtures/docx/README.md +0 -74
  503. package/test/fixtures/docx/certification-manifest.json +0 -104
  504. package/test/fixtures/docx/fixtures.manifest.json +0 -196
  505. package/test/fixtures/encrypted-docx/README.md +0 -27
  506. package/test/fixtures/encrypted-docx/certification-manifest.json +0 -9
  507. package/test/fixtures/encrypted-docx/fixtures.manifest.json +0 -47
  508. package/test/fixtures/scenarios/docx/README.md +0 -25
  509. package/test/fixtures/scenarios/docx/S01-sow-template.docx +0 -0
  510. package/test/fixtures/scenarios/docx/S01-sow-template.md +0 -30
  511. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.docx +0 -0
  512. package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.md +0 -32
  513. package/test/fixtures/scenarios/docx/scenario-manifest.json +0 -53
  514. package/test/formats/xlsx/io/xlsx-import.test.ts +0 -766
  515. package/test/formats/xlsx/model/workbook.test.ts +0 -669
  516. package/test/helpers/dom-setup.ts +0 -124
  517. package/test/io/comment-roundtrip.test.ts +0 -272
  518. package/test/io/complex-content-roundtrip.test.ts +0 -632
  519. package/test/io/docx-compatibility-regression.test.ts +0 -199
  520. package/test/io/docx-session.test.ts +0 -1495
  521. package/test/io/footnotes-roundtrip.test.ts +0 -318
  522. package/test/io/headers-footers-roundtrip.test.ts +0 -547
  523. package/test/io/numbering-roundtrip.test.ts +0 -234
  524. package/test/io/package-reader.test.ts +0 -199
  525. package/test/io/paragraph-properties-roundtrip.test.ts +0 -129
  526. package/test/io/preserved-package-roundtrip.test.ts +0 -365
  527. package/test/io/property-completeness.test.ts +0 -292
  528. package/test/io/revision-roundtrip.test.ts +0 -347
  529. package/test/io/structural-blocks.test.ts +0 -202
  530. package/test/io/table-media-roundtrip.test.ts +0 -448
  531. package/test/io/table-properties-roundtrip.test.ts +0 -569
  532. package/test/io/table-roundtrip.test.ts +0 -302
  533. package/test/io/text-roundtrip.test.ts +0 -344
  534. package/test/model/canonical-document.test.ts +0 -285
  535. package/test/preservation/opaque-fragment-store.test.ts +0 -121
  536. package/test/preservation/package-preservation.test.ts +0 -395
  537. package/test/preservation/store.test.ts +0 -84
  538. package/test/review/comment-remapping.test.ts +0 -220
  539. package/test/review/comment-store.test.ts +0 -180
  540. package/test/review/move-revisions.test.ts +0 -143
  541. package/test/review/property-change-revisions.test.ts +0 -225
  542. package/test/review/revision-actions.test.ts +0 -330
  543. package/test/review/revision-store.test.ts +0 -193
  544. package/test/runtime/session-capabilities.test.ts +0 -260
  545. package/test/runtime/table-commands.test.ts +0 -356
  546. package/test/runtime/table-schema.test.ts +0 -221
  547. package/test/runtime/tracked-changes-toggle.test.ts +0 -107
  548. package/test/ui/comment-review-surface.test.tsx +0 -114
  549. package/test/ui/reduced-motion-toggle.test.tsx +0 -137
  550. package/test/ui/word-review-editor.imported-scenarios.test.tsx +0 -169
  551. package/test/ui/word-review-editor.interaction.test.tsx +0 -1198
  552. package/test/ui/word-review-editor.test.js +0 -188
  553. package/test/ui/word-review-editor.test.tsx +0 -280
  554. package/test/ui-tailwind/search-plugin.test.ts +0 -286
  555. package/test/validation/compatibility-engine.test.ts +0 -336
  556. package/test/validation/compatibility-report.test.ts +0 -189
  557. package/test/validation/low-priority-word-surfaces.test.ts +0 -282
  558. package/test/validation/malformed-doc.test.ts +0 -113
  559. package/test-results/.last-run.json +0 -4
  560. package/wave.config.json +0 -406
@@ -1,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
- }