@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.
- package/README.md +44 -104
- package/package.json +66 -15
- package/src/api/public-types.ts +1 -1
- package/src/compare/diff-engine.ts +530 -0
- package/src/compare/export-redlines.ts +162 -0
- package/src/compare/snapshot.ts +37 -0
- package/src/core/commands/index.ts +1 -1
- package/src/core/state/editor-state.ts +2 -2
- package/src/index.ts +45 -0
- package/src/legal/bookmarks.ts +196 -0
- package/src/legal/cross-references.ts +356 -0
- package/src/legal/defined-terms.ts +203 -0
- package/src/runtime/document-runtime.ts +3 -5
- package/src/runtime/table-commands.ts +4 -1
- package/src/runtime/table-schema.ts +17 -2
- package/src/runtime/virtualized-rendering.ts +258 -0
- package/src/ui/WordReviewEditor.tsx +256 -35
- package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +2 -2
- package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +16 -2
- package/.codex/config.toml +0 -5
- package/.corepack/v1/pnpm/10.30.3/.corepack +0 -1
- package/.corepack/v1/pnpm/10.30.3/LICENSE +0 -22
- package/.corepack/v1/pnpm/10.30.3/README.md +0 -240
- package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp +0 -6
- package/.corepack/v1/pnpm/10.30.3/dist/node-gyp-bin/node-gyp.cmd +0 -5
- package/.corepack/v1/pnpm/10.30.3/dist/pnpm.cjs +0 -195400
- package/.corepack/v1/pnpm/10.30.3/dist/pnpmrc +0 -2
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-arm64-2HJ4WGO6.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.darwin-x64-3G3H6IW4.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-arm64-msvc-Q6BARPPB.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/reflink.win32-x64-msvc-J2TZHRQI.node +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.bash +0 -31
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.fish +0 -22
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.ps1 +0 -193
- package/.corepack/v1/pnpm/10.30.3/dist/templates/completion.zsh +0 -27
- package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
- package/.corepack/v1/pnpm/10.30.3/dist/worker.js +0 -10119
- package/.corepack/v1/pnpm/10.30.3/package.json +0 -192
- package/.cursor/mcp.json +0 -7
- package/.github/workflows/ci.yml +0 -35
- package/.mcp.json +0 -7
- package/.openclaw/workspace-state.json +0 -4
- package/.pnpmrc.json +0 -1
- package/.wave-launch.sh +0 -7
- package/.workspace-marker +0 -1
- package/AGENTS.md +0 -78
- package/CHANGELOG.md +0 -177
- package/DESIGN.md +0 -929
- package/HEARTBEAT.md +0 -7
- package/IDENTITY.md +0 -23
- package/SOUL.md +0 -36
- package/TOOLS.md +0 -40
- package/USER.md +0 -17
- package/docs/README.md +0 -107
- package/docs/agents/wave-cont-eval-role.md +0 -36
- package/docs/agents/wave-cont-qa-role.md +0 -52
- package/docs/agents/wave-deploy-verifier-role.md +0 -34
- package/docs/agents/wave-design-role.md +0 -47
- package/docs/agents/wave-documentation-role.md +0 -34
- package/docs/agents/wave-infra-role.md +0 -34
- package/docs/agents/wave-integration-role.md +0 -37
- package/docs/agents/wave-launcher-role.md +0 -41
- package/docs/agents/wave-orchestrator-role.md +0 -52
- package/docs/agents/wave-planner-role.md +0 -39
- package/docs/agents/wave-security-role.md +0 -40
- package/docs/architecture/docx/README.md +0 -10
- package/docs/architecture/future/README.md +0 -8
- package/docs/architecture/ooxml-upgrade-analysis.md +0 -134
- package/docs/architecture/platform/shared-openxml-editor-platform.md +0 -153
- package/docs/architecture/xlsx/canonical-workbook-model-and-commands.md +0 -187
- package/docs/architecture/xlsx/spreadsheet-editor-frontend-architecture.md +0 -150
- package/docs/comment-redline-overview.md +0 -350
- package/docs/concepts/context7-vs-skills.md +0 -118
- package/docs/concepts/operating-modes.md +0 -91
- package/docs/concepts/runtime-agnostic-orchestration.md +0 -111
- package/docs/concepts/what-is-a-wave.md +0 -217
- package/docs/context7/bundles.json +0 -222
- package/docs/context7/planner-agent/README.md +0 -28
- package/docs/context7/planner-agent/manifest.json +0 -83
- package/docs/context7/planner-agent/papers/cooperbench-why-coding-agents-cannot-be-your-teammates-yet.md +0 -3283
- package/docs/context7/planner-agent/papers/dova-deliberation-first-multi-agent-orchestration-for-autonomous-research-automation.md +0 -1699
- package/docs/context7/planner-agent/papers/dpbench-large-language-models-struggle-with-simultaneous-coordination.md +0 -2251
- package/docs/context7/planner-agent/papers/incremental-planning-to-control-a-blackboard-based-problem-solver.md +0 -1729
- package/docs/context7/planner-agent/papers/silo-bench-a-scalable-environment-for-evaluating-distributed-coordination-in-multi-agent-llm-systems.md +0 -3747
- package/docs/context7/planner-agent/papers/todoevolve-learning-to-architect-agent-planning-systems.md +0 -1675
- package/docs/context7/planner-agent/papers/verified-multi-agent-orchestration-a-plan-execute-verify-replan-framework-for-complex-query-resolution.md +0 -1173
- package/docs/context7/planner-agent/papers/why-do-multi-agent-llm-systems-fail.md +0 -5211
- package/docs/context7/planner-agent/topics/planning-and-orchestration.md +0 -24
- package/docs/evals/arm-templates/README.md +0 -13
- package/docs/evals/arm-templates/full-wave.json +0 -15
- package/docs/evals/arm-templates/single-agent.json +0 -15
- package/docs/evals/benchmark-catalog.json +0 -670
- package/docs/evals/cases/README.md +0 -47
- package/docs/evals/cases/wave-blackboard-inbox-targeting.json +0 -73
- package/docs/evals/cases/wave-contradiction-conflict.json +0 -104
- package/docs/evals/cases/wave-expert-routing-preservation.json +0 -69
- package/docs/evals/cases/wave-hidden-profile-private-evidence.json +0 -81
- package/docs/evals/cases/wave-premature-closure-guard.json +0 -71
- package/docs/evals/cases/wave-silo-cross-agent-state.json +0 -77
- package/docs/evals/cases/wave-simultaneous-lockstep.json +0 -92
- package/docs/evals/external-benchmarks.json +0 -85
- package/docs/evals/external-command-config.sample.json +0 -9
- package/docs/evals/external-command-config.swe-bench-pro.json +0 -8
- package/docs/evals/pilots/README.md +0 -47
- package/docs/evals/pilots/swe-bench-pro-public-full-wave-review-10.json +0 -64
- package/docs/evals/pilots/swe-bench-pro-public-pilot.json +0 -111
- package/docs/evals/wave-benchmark-program.md +0 -302
- package/docs/guides/planner.md +0 -220
- package/docs/guides/recommendations-0.8.9.md +0 -133
- package/docs/guides/signal-wrappers.md +0 -165
- package/docs/guides/terminal-surfaces.md +0 -96
- package/docs/image copy.png +0 -0
- package/docs/image.png +0 -0
- package/docs/images/image.png +0 -0
- package/docs/legal-feedback-architecture.md +0 -498
- package/docs/plans/component-cutover-matrix.json +0 -1072
- package/docs/plans/component-cutover-matrix.md +0 -307
- package/docs/plans/context7-wave-orchestrator.md +0 -155
- package/docs/plans/current-state.md +0 -198
- package/docs/plans/docx/README.md +0 -9
- package/docs/plans/examples/wave-benchmark-improvement.md +0 -108
- package/docs/plans/examples/wave-example-live-proof.md +0 -435
- package/docs/plans/master-plan.md +0 -224
- package/docs/plans/migration.md +0 -538
- package/docs/plans/operations/README.md +0 -7
- package/docs/plans/operations/wave-10-word-certification.md +0 -87
- package/docs/plans/operations/wave-8-railway-staging.md +0 -153
- package/docs/plans/operations/wave-9-manual-certification.md +0 -73
- package/docs/plans/platform/README.md +0 -9
- package/docs/plans/reference/legal-checklist-coverage.md +0 -258
- package/docs/plans/wave-orchestrator.md +0 -423
- package/docs/plans/waves/README.md +0 -75
- package/docs/plans/waves/completed/wave-0.md +0 -195
- package/docs/plans/waves/completed/wave-1.md +0 -379
- package/docs/plans/waves/completed/wave-10.md +0 -670
- package/docs/plans/waves/completed/wave-11.md +0 -335
- package/docs/plans/waves/completed/wave-12.md +0 -417
- package/docs/plans/waves/completed/wave-13.md +0 -316
- package/docs/plans/waves/completed/wave-14.md +0 -319
- package/docs/plans/waves/completed/wave-15.md +0 -321
- package/docs/plans/waves/completed/wave-16.md +0 -316
- package/docs/plans/waves/completed/wave-17.md +0 -331
- package/docs/plans/waves/completed/wave-18.md +0 -328
- package/docs/plans/waves/completed/wave-2.md +0 -438
- package/docs/plans/waves/completed/wave-3.md +0 -435
- package/docs/plans/waves/completed/wave-4.md +0 -430
- package/docs/plans/waves/completed/wave-5.md +0 -430
- package/docs/plans/waves/completed/wave-6.md +0 -430
- package/docs/plans/waves/completed/wave-7.md +0 -526
- package/docs/plans/waves/completed/wave-8.md +0 -596
- package/docs/plans/waves/completed/wave-9.md +0 -552
- package/docs/plans/waves/deferred/README.md +0 -14
- package/docs/plans/waves/deferred/encrypted-intake-contracts.md +0 -282
- package/docs/plans/waves/deferred/legal-feedback-wave-expansion.md +0 -308
- package/docs/plans/waves/deferred/wave-encrypted-intake.md +0 -451
- package/docs/plans/waves/design/README.md +0 -5
- package/docs/plans/waves/design/wave-1-a1.md +0 -309
- package/docs/plans/waves/reviews/README.md +0 -5
- package/docs/plans/waves/reviews/wave-0-cont-qa.md +0 -151
- package/docs/plans/waves/reviews/wave-1-cont-qa.md +0 -46
- package/docs/plans/waves/reviews/wave-10-accessibility-and-design.md +0 -51
- package/docs/plans/waves/reviews/wave-10-cont-qa.md +0 -24
- package/docs/plans/waves/reviews/wave-10-dashboard-proof.md +0 -46
- package/docs/plans/waves/reviews/wave-10-performance-signoff.md +0 -55
- package/docs/plans/waves/reviews/wave-10-regression-proof.md +0 -23
- package/docs/plans/waves/reviews/wave-10-release-audit.md +0 -31
- package/docs/plans/waves/reviews/wave-10-service-proof.md +0 -83
- package/docs/plans/waves/reviews/wave-10-word-certification.md +0 -31
- package/docs/plans/waves/reviews/wave-18-ai-contract-closure.md +0 -277
- package/docs/plans/waves/reviews/wave-18-cont-qa.md +0 -255
- package/docs/plans/waves/reviews/wave-18-parity-proof.md +0 -271
- package/docs/plans/waves/reviews/wave-19-cont-qa.md +0 -59
- package/docs/plans/waves/reviews/wave-2-cont-qa.md +0 -72
- package/docs/plans/waves/reviews/wave-20-cont-qa.md +0 -60
- package/docs/plans/waves/reviews/wave-25-cont-qa.md +0 -48
- package/docs/plans/waves/reviews/wave-28-cont-qa.md +0 -46
- package/docs/plans/waves/reviews/wave-29-cont-qa.md +0 -53
- package/docs/plans/waves/reviews/wave-3-cont-qa.md +0 -53
- package/docs/plans/waves/reviews/wave-3-core-proof.md +0 -77
- package/docs/plans/waves/reviews/wave-3-validator-proof.md +0 -73
- package/docs/plans/waves/reviews/wave-32-cont-qa.md +0 -43
- package/docs/plans/waves/reviews/wave-33-cont-qa.md +0 -526
- package/docs/plans/waves/reviews/wave-34-cont-qa.md +0 -100
- package/docs/plans/waves/reviews/wave-35-cont-qa.md +0 -145
- package/docs/plans/waves/reviews/wave-4-cont-qa.md +0 -47
- package/docs/plans/waves/reviews/wave-4-structure-proof.md +0 -69
- package/docs/plans/waves/reviews/wave-5-comment-proof.md +0 -158
- package/docs/plans/waves/reviews/wave-5-cont-qa.md +0 -68
- package/docs/plans/waves/reviews/wave-6-cont-qa.md +0 -416
- package/docs/plans/waves/reviews/wave-6-redline-proof.md +0 -130
- package/docs/plans/waves/reviews/wave-7-cont-qa.md +0 -82
- package/docs/plans/waves/reviews/wave-7-ooxml-compliance.md +0 -85
- package/docs/plans/waves/reviews/wave-7-preservation-proof.md +0 -119
- package/docs/plans/waves/reviews/wave-7-trust-ux.md +0 -87
- package/docs/plans/waves/reviews/wave-8-accessibility-and-design.md +0 -128
- package/docs/plans/waves/reviews/wave-8-cont-qa.md +0 -92
- package/docs/plans/waves/reviews/wave-8-live-proof.md +0 -140
- package/docs/plans/waves/reviews/wave-8-security.md +0 -47
- package/docs/plans/waves/reviews/wave-9-editor-embedding.md +0 -39
- package/docs/plans/waves/reviews/wave-9-fixture-runner.md +0 -56
- package/docs/plans/waves/reviews/wave-9-live-proof.md +0 -105
- package/docs/plans/waves/reviews/wave-9-usability-and-performance.md +0 -152
- package/docs/plans/waves/specs/README.md +0 -5
- package/docs/plans/waves/specs/wave-1-component-boundaries.md +0 -322
- package/docs/plans/waves/specs/wave-1-ooxml-contracts.md +0 -323
- package/docs/plans/waves/specs/wave-1-review-and-ui-contracts.md +0 -339
- package/docs/plans/waves/specs/wave-1-runtime-contracts.md +0 -509
- package/docs/plans/waves/wave-19.md +0 -341
- package/docs/plans/waves/wave-20.md +0 -308
- package/docs/plans/waves/wave-21.md +0 -289
- package/docs/plans/waves/wave-22.md +0 -221
- package/docs/plans/waves/wave-23.md +0 -295
- package/docs/plans/waves/wave-24.md +0 -286
- package/docs/plans/waves/wave-25.md +0 -313
- package/docs/plans/waves/wave-26.md +0 -300
- package/docs/plans/waves/wave-27.md +0 -299
- package/docs/plans/waves/wave-28.md +0 -368
- package/docs/plans/waves/wave-29.md +0 -303
- package/docs/plans/waves/wave-30.md +0 -307
- package/docs/plans/waves/wave-31.md +0 -231
- package/docs/plans/waves/wave-32.md +0 -152
- package/docs/plans/waves/wave-33.md +0 -147
- package/docs/plans/waves/wave-34.md +0 -148
- package/docs/plans/waves/wave-35.md +0 -141
- package/docs/plans/waves/wave-36.md +0 -146
- package/docs/plans/xlsx/README.md +0 -14
- package/docs/plans/xlsx/xlsx-fixture-corpus-and-certification-plan.md +0 -126
- package/docs/reference/cli-reference.md +0 -600
- package/docs/reference/coordination-and-closure.md +0 -487
- package/docs/reference/deep-research-report (15).md +0 -25
- package/docs/reference/docx/README.md +0 -10
- package/docs/reference/legal-checklist.md +0 -445
- package/docs/reference/live-proof-waves.md +0 -199
- package/docs/reference/ooxml-compliance.md +0 -129
- package/docs/reference/ooxml-feature-parity-matrix.md +0 -172
- package/docs/reference/platform/shared-ooxml-platform-guidance.md +0 -77
- package/docs/reference/prototype-agent-prompt-legal-fidelity.md +0 -155
- package/docs/reference/public-api.md +0 -456
- package/docs/reference/repository-guidance.md +0 -58
- package/docs/reference/runtime-config/README.md +0 -182
- package/docs/reference/runtime-config/claude.md +0 -110
- package/docs/reference/runtime-config/codex.md +0 -82
- package/docs/reference/runtime-config/opencode.md +0 -93
- package/docs/reference/sample-waves.md +0 -105
- package/docs/reference/skills.md +0 -237
- package/docs/reference/templates/AGENTS.md +0 -78
- package/docs/reference/templates/HEARTBEAT.md +0 -7
- package/docs/reference/templates/IDENTITY.md +0 -23
- package/docs/reference/templates/SOUL.md +0 -36
- package/docs/reference/templates/TOOLS.md +0 -40
- package/docs/reference/templates/USER.md +0 -17
- package/docs/reference/wave-control.md +0 -184
- package/docs/reference/wave-planning-lessons.md +0 -167
- package/docs/reference/word-review-editor-frontend-architecture.md +0 -479
- package/docs/reference/word-review-editor-ux-guide.md +0 -253
- package/docs/reference/xlsx/xlsx-ooxml-compliance.md +0 -137
- package/docs/research/agent-context-sources.md +0 -178
- package/docs/research/coordination-failure-review.md +0 -290
- package/docs/research/docx-react-component/Canonical Document Schema Specification for a React-based Word-compatible Editor.md +0 -2317
- package/docs/research/docx-react-component/Feature Compatibility Matrix for a React Word Compatible Legal Editor v1.md +0 -219
- package/docs/research/docx-react-component/React Component Architecture and Front-End Structure Specification for a Word-Compatible Legal Review Editor.md +0 -1112
- package/docs/research/docx-react-component/document_compatibility_and_testing_spec.md +0 -751
- package/docs/research/xlsx/raw/README.md +0 -13
- package/docs/roadmap.md +0 -174
- package/docs/superpowers/plans/2026-03-28-harness-control-bar.md +0 -677
- package/docs/superpowers/specs/2026-03-28-harness-control-bar-design.md +0 -274
- package/docs/xlsx-react/README.md +0 -38
- package/docs/xlsx-react/agent-llm-interaction-layer-docx-xlsx.md +0 -621
- package/docs/xlsx-react/canonical-workbook-model-and-commands.md +0 -948
- package/docs/xlsx-react/shared-openxml-editor-platform-docx-xlsx.md +0 -228
- package/docs/xlsx-react/spreadsheet-editor-component-architecture.md +0 -809
- package/docs/xlsx-react/spreadsheet-editor-frontend-architecture.md +0 -537
- package/docs/xlsx-react/spreadsheet-editor-ux-guide.md +0 -520
- package/docs/xlsx-react/xlsx-editor-research-pack.md +0 -871
- package/docs/xlsx-react/xlsx-fixture-corpus-and-certification-plan.md +0 -436
- package/docs/xlsx-react/xlsx-ooxml-compliance.md +0 -320
- package/examples/README.md +0 -16
- package/memory/MEMORY.md +0 -24
- package/pnpm-workspace.yaml +0 -4
- package/scripts/check-no-authored-js.sh +0 -13
- package/scripts/context7-api-check.sh +0 -65
- package/scripts/context7-export-env.sh +0 -42
- package/scripts/run-context7-mcp.sh +0 -8
- package/scripts/run-workspace-tests.sh +0 -15
- package/scripts/start-wave-10-local.sh +0 -189
- package/scripts/wave-agent-attach.sh +0 -47
- package/scripts/wave-auto-answer.sh +0 -118
- package/scripts/wave-dashboard-attach.sh +0 -13
- package/scripts/wave-launch.sh +0 -273
- package/scripts/wave-overnight-supervisor.sh +0 -145
- package/scripts/wave-status.sh +0 -379
- package/scripts/wave-watch.sh +0 -231
- package/services/README.md +0 -17
- package/services/openxml-validator/Dockerfile +0 -29
- package/services/openxml-validator/OpenXmlValidator.Api.csproj +0 -12
- package/services/openxml-validator/Program.cs +0 -436
- package/services/openxml-validator/README.md +0 -152
- package/services/openxml-validator/railway.json +0 -16
- package/services/react-word-editor/.tmp-a4/src/api/public-types.ts +0 -318
- package/services/react-word-editor/.tmp-a4/src/ui/WordReviewEditor.tsx +0 -1302
- package/services/react-word-editor/.tmp-a4/src/ui/editor-surface/editor-surface.tsx +0 -546
- package/services/react-word-editor/.tmp-a4/test/ui/word-review-editor.test.tsx +0 -146
- package/services/react-word-editor/.tmp-a4-build/src/api/public-types.js +0 -2
- package/services/react-word-editor/.tmp-a4-build/src/ui/WordReviewEditor.js +0 -818
- package/services/react-word-editor/.tmp-a4-build/src/ui/editor-surface/editor-surface.js +0 -229
- package/services/react-word-editor/.tmp-a4-build/test/ui/word-review-editor.test.js +0 -121
- package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.json +0 -21
- package/services/react-word-editor/.tmp-wave-4-a3-tsconfig.tsbuildinfo +0 -1
- package/services/react-word-editor/Dockerfile +0 -26
- package/services/react-word-editor/README.md +0 -254
- package/services/react-word-editor/app/api/certification/route.ts +0 -79
- package/services/react-word-editor/app/api/demo-sessions/route.ts +0 -109
- package/services/react-word-editor/app/api/deploy-health/route.ts +0 -23
- package/services/react-word-editor/app/api/exports/[exportId]/route.ts +0 -34
- package/services/react-word-editor/app/api/exports/route.ts +0 -81
- package/services/react-word-editor/app/api/fixtures/[fixtureId]/run/route.ts +0 -100
- package/services/react-word-editor/app/api/health/route.ts +0 -70
- package/services/react-word-editor/app/api/runs/[runId]/route.ts +0 -36
- package/services/react-word-editor/app/api/scenarios/[scenarioId]/run/route.ts +0 -85
- package/services/react-word-editor/app/api/sessions/[sessionId]/route.ts +0 -199
- package/services/react-word-editor/app/api/sessions/[sessionId]/source/route.ts +0 -45
- package/services/react-word-editor/app/api/uploads/route.ts +0 -70
- package/services/react-word-editor/app/api/validate/route.ts +0 -310
- package/services/react-word-editor/app/certification/[runId]/page.tsx +0 -14
- package/services/react-word-editor/app/certification/page.tsx +0 -32
- package/services/react-word-editor/app/dashboard/page.tsx +0 -7
- package/services/react-word-editor/app/demo/page.tsx +0 -30
- package/services/react-word-editor/app/demo/prototype-client.tsx +0 -1080
- package/services/react-word-editor/app/editor/[sessionId]/page.tsx +0 -33
- package/services/react-word-editor/app/fixtures/page.tsx +0 -7
- package/services/react-word-editor/app/globals.css +0 -121
- package/services/react-word-editor/app/layout.tsx +0 -32
- package/services/react-word-editor/app/page.tsx +0 -30
- package/services/react-word-editor/app/runs/[runId]/page.tsx +0 -34
- package/services/react-word-editor/app/wave-10-word-review/page.tsx +0 -7
- package/services/react-word-editor/components/harness-control-bar.tsx +0 -289
- package/services/react-word-editor/components/harness-editor-session-client.tsx +0 -1214
- package/services/react-word-editor/components/harness-workspace-page.tsx +0 -715
- package/services/react-word-editor/components/reduced-motion-toggle.tsx +0 -79
- package/services/react-word-editor/components/workspace-certification-panel.tsx +0 -307
- package/services/react-word-editor/lib/certification-bundle.ts +0 -796
- package/services/react-word-editor/lib/certification-store.ts +0 -661
- package/services/react-word-editor/lib/demo-fixtures.test.mjs +0 -195
- package/services/react-word-editor/lib/demo-fixtures.ts +0 -1519
- package/services/react-word-editor/lib/editor-session-summary.test.mjs +0 -68
- package/services/react-word-editor/lib/editor-session-summary.ts +0 -14
- package/services/react-word-editor/lib/editor-session.ts +0 -228
- package/services/react-word-editor/lib/exports-route.test.mjs +0 -32
- package/services/react-word-editor/lib/harness-client.ts +0 -347
- package/services/react-word-editor/lib/harness-config.json +0 -30
- package/services/react-word-editor/lib/harness-config.test.mjs +0 -31
- package/services/react-word-editor/lib/harness-config.ts +0 -21
- package/services/react-word-editor/lib/harness-editor-datastore.test.mjs +0 -220
- package/services/react-word-editor/lib/harness-editor-datastore.ts +0 -161
- package/services/react-word-editor/lib/private-mode.test.mjs +0 -42
- package/services/react-word-editor/lib/private-mode.ts +0 -61
- package/services/react-word-editor/lib/regression-report.test.mjs +0 -352
- package/services/react-word-editor/lib/regression-report.ts +0 -896
- package/services/react-word-editor/lib/run-artifacts.ts +0 -934
- package/services/react-word-editor/lib/run-history.ts +0 -755
- package/services/react-word-editor/lib/scenario-artifacts.test.mjs +0 -41
- package/services/react-word-editor/lib/scenario-artifacts.ts +0 -44
- package/services/react-word-editor/lib/storage.ts +0 -953
- package/services/react-word-editor/lib/validator-client.test.mjs +0 -54
- package/services/react-word-editor/lib/validator-client.ts +0 -95
- package/services/react-word-editor/lib/workspace-navigation.ts +0 -79
- package/services/react-word-editor/middleware.ts +0 -35
- package/services/react-word-editor/next-env.d.ts +0 -6
- package/services/react-word-editor/next.config.mjs +0 -15
- package/services/react-word-editor/package.json +0 -38
- package/services/react-word-editor/postcss.config.mjs +0 -8
- package/services/react-word-editor/railway.json +0 -21
- package/services/react-word-editor/scripts/wave-10-certification.mjs +0 -101
- package/services/react-word-editor/scripts/wave-9-live-usability-pilot.mjs +0 -911
- package/services/react-word-editor/tsconfig.json +0 -39
- package/services/react-word-editor/tsconfig.tsbuildinfo +0 -1
- package/skills/README.md +0 -48
- package/skills/domain-docx-compatibility/SKILL.md +0 -44
- package/skills/domain-docx-compatibility/skill.json +0 -19
- package/skills/domain-editor-architecture/SKILL.md +0 -49
- package/skills/domain-editor-architecture/skill.json +0 -19
- package/skills/domain-legal-review/SKILL.md +0 -39
- package/skills/domain-legal-review/skill.json +0 -19
- package/skills/provider-aws/SKILL.md +0 -117
- package/skills/provider-aws/adapters/claude.md +0 -1
- package/skills/provider-aws/adapters/codex.md +0 -1
- package/skills/provider-aws/references/service-verification.md +0 -39
- package/skills/provider-aws/skill.json +0 -54
- package/skills/provider-custom-deploy/SKILL.md +0 -64
- package/skills/provider-custom-deploy/skill.json +0 -50
- package/skills/provider-docker-compose/SKILL.md +0 -96
- package/skills/provider-docker-compose/adapters/local.md +0 -1
- package/skills/provider-docker-compose/skill.json +0 -53
- package/skills/provider-github-release/SKILL.md +0 -121
- package/skills/provider-github-release/adapters/claude.md +0 -1
- package/skills/provider-github-release/adapters/codex.md +0 -1
- package/skills/provider-github-release/skill.json +0 -55
- package/skills/provider-kubernetes/SKILL.md +0 -143
- package/skills/provider-kubernetes/adapters/claude.md +0 -1
- package/skills/provider-kubernetes/adapters/codex.md +0 -1
- package/skills/provider-kubernetes/references/kubectl-patterns.md +0 -58
- package/skills/provider-kubernetes/skill.json +0 -52
- package/skills/provider-railway/SKILL.md +0 -123
- package/skills/provider-railway/adapters/claude.md +0 -1
- package/skills/provider-railway/adapters/codex.md +0 -1
- package/skills/provider-railway/adapters/local.md +0 -1
- package/skills/provider-railway/adapters/opencode.md +0 -1
- package/skills/provider-railway/references/verification-commands.md +0 -39
- package/skills/provider-railway/skill.json +0 -71
- package/skills/provider-ssh-manual/SKILL.md +0 -97
- package/skills/provider-ssh-manual/skill.json +0 -54
- package/skills/repo-coding-rules/SKILL.md +0 -55
- package/skills/repo-coding-rules/skill.json +0 -34
- package/skills/role-cont-eval/SKILL.md +0 -91
- package/skills/role-cont-eval/adapters/codex.md +0 -1
- package/skills/role-cont-eval/skill.json +0 -36
- package/skills/role-cont-qa/SKILL.md +0 -100
- package/skills/role-cont-qa/adapters/claude.md +0 -1
- package/skills/role-cont-qa/skill.json +0 -36
- package/skills/role-deploy/SKILL.md +0 -97
- package/skills/role-deploy/skill.json +0 -36
- package/skills/role-design/SKILL.md +0 -50
- package/skills/role-design/skill.json +0 -36
- package/skills/role-documentation/SKILL.md +0 -76
- package/skills/role-documentation/skill.json +0 -36
- package/skills/role-implementation/SKILL.md +0 -45
- package/skills/role-implementation/skill.json +0 -36
- package/skills/role-infra/SKILL.md +0 -81
- package/skills/role-infra/skill.json +0 -36
- package/skills/role-integration/SKILL.md +0 -91
- package/skills/role-integration/skill.json +0 -36
- package/skills/role-planner/SKILL.md +0 -39
- package/skills/role-planner/skill.json +0 -21
- package/skills/role-research/SKILL.md +0 -65
- package/skills/role-research/skill.json +0 -36
- package/skills/role-security/SKILL.md +0 -60
- package/skills/role-security/skill.json +0 -36
- package/skills/runtime-claude/SKILL.md +0 -66
- package/skills/runtime-claude/skill.json +0 -36
- package/skills/runtime-codex/SKILL.md +0 -58
- package/skills/runtime-codex/skill.json +0 -36
- package/skills/runtime-local/SKILL.md +0 -46
- package/skills/runtime-local/skill.json +0 -36
- package/skills/runtime-opencode/SKILL.md +0 -58
- package/skills/runtime-opencode/skill.json +0 -36
- package/skills/signal-hygiene/SKILL.md +0 -51
- package/skills/signal-hygiene/skill.json +0 -20
- package/skills/tui-design/SKILL.md +0 -77
- package/skills/tui-design/references/tui-design.md +0 -259
- package/skills/tui-design/skill.json +0 -36
- package/skills/wave-core/SKILL.md +0 -141
- package/skills/wave-core/references/marker-syntax.md +0 -70
- package/skills/wave-core/skill.json +0 -35
- package/test/README.md +0 -16
- package/test/core/formatting-commands.test.ts +0 -285
- package/test/core/image-commands.test.ts +0 -298
- package/test/core/mapping.test.ts +0 -186
- package/test/core/text-commands.test.ts +0 -176
- package/test/fixtures/docx/F01-basic-contract.docx +0 -0
- package/test/fixtures/docx/F01-basic-contract.md +0 -33
- package/test/fixtures/docx/F02-headings-styles.docx +0 -0
- package/test/fixtures/docx/F02-headings-styles.md +0 -33
- package/test/fixtures/docx/F03-legal-outline-numbering.docx +0 -0
- package/test/fixtures/docx/F03-legal-outline-numbering.md +0 -34
- package/test/fixtures/docx/F04-restart-numbering-schedules.docx +0 -0
- package/test/fixtures/docx/F04-restart-numbering-schedules.md +0 -33
- package/test/fixtures/docx/F05-table-heavy-agreement.docx +0 -0
- package/test/fixtures/docx/F05-table-heavy-agreement.md +0 -34
- package/test/fixtures/docx/F06-merged-cells-signature-table.docx +0 -0
- package/test/fixtures/docx/F06-merged-cells-signature-table.md +0 -34
- package/test/fixtures/docx/F07-inline-images-exhibit.docx +0 -0
- package/test/fixtures/docx/F07-inline-images-exhibit.md +0 -34
- package/test/fixtures/docx/F08-hyperlinks.docx +0 -0
- package/test/fixtures/docx/F08-hyperlinks.md +0 -33
- package/test/fixtures/docx/F09-comments-single-paragraph.docx +0 -0
- package/test/fixtures/docx/F09-comments-single-paragraph.md +0 -33
- package/test/fixtures/docx/F10-threaded-comments-resolve.docx +0 -0
- package/test/fixtures/docx/F10-threaded-comments-resolve.md +0 -33
- package/test/fixtures/docx/F11-redlines-basic.docx +0 -0
- package/test/fixtures/docx/F11-redlines-basic.md +0 -33
- package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.docx +0 -0
- package/test/fixtures/docx/F12-redlines-paragraph-joins-splits.md +0 -33
- package/test/fixtures/docx/F13-comments-on-deleted-text.docx +0 -0
- package/test/fixtures/docx/F13-comments-on-deleted-text.md +0 -33
- package/test/fixtures/docx/F14-revisions-in-tables-and-lists.docx +0 -0
- package/test/fixtures/docx/F14-revisions-in-tables-and-lists.md +0 -33
- package/test/fixtures/docx/F15-sections-headers-footers.docx +0 -0
- package/test/fixtures/docx/F15-sections-headers-footers.md +0 -33
- package/test/fixtures/docx/F16-footnotes-endnotes.docx +0 -0
- package/test/fixtures/docx/F16-footnotes-endnotes.md +0 -33
- package/test/fixtures/docx/F17-fields-and-toc.docx +0 -0
- package/test/fixtures/docx/F17-fields-and-toc.md +0 -33
- package/test/fixtures/docx/F18-content-controls-template.docx +0 -0
- package/test/fixtures/docx/F18-content-controls-template.md +0 -33
- package/test/fixtures/docx/F19-custom-xml-doc-assembly.docx +0 -0
- package/test/fixtures/docx/F19-custom-xml-doc-assembly.md +0 -35
- package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.docx +0 -0
- package/test/fixtures/docx/F20-unknown-ooxml-and-alternatecontent.md +0 -33
- package/test/fixtures/docx/F21-malformed-broken-docx.docx +0 -0
- package/test/fixtures/docx/F21-malformed-broken-docx.md +0 -33
- package/test/fixtures/docx/README.md +0 -74
- package/test/fixtures/docx/certification-manifest.json +0 -104
- package/test/fixtures/docx/fixtures.manifest.json +0 -196
- package/test/fixtures/encrypted-docx/README.md +0 -27
- package/test/fixtures/encrypted-docx/certification-manifest.json +0 -9
- package/test/fixtures/encrypted-docx/fixtures.manifest.json +0 -47
- package/test/fixtures/scenarios/docx/README.md +0 -25
- package/test/fixtures/scenarios/docx/S01-sow-template.docx +0 -0
- package/test/fixtures/scenarios/docx/S01-sow-template.md +0 -30
- package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.docx +0 -0
- package/test/fixtures/scenarios/docx/S02-bw-partner-user-licence-agreement-redlines.md +0 -32
- package/test/fixtures/scenarios/docx/scenario-manifest.json +0 -53
- package/test/formats/xlsx/io/xlsx-import.test.ts +0 -766
- package/test/formats/xlsx/model/workbook.test.ts +0 -669
- package/test/helpers/dom-setup.ts +0 -124
- package/test/io/comment-roundtrip.test.ts +0 -272
- package/test/io/complex-content-roundtrip.test.ts +0 -632
- package/test/io/docx-compatibility-regression.test.ts +0 -199
- package/test/io/docx-session.test.ts +0 -1495
- package/test/io/footnotes-roundtrip.test.ts +0 -318
- package/test/io/headers-footers-roundtrip.test.ts +0 -547
- package/test/io/numbering-roundtrip.test.ts +0 -234
- package/test/io/package-reader.test.ts +0 -199
- package/test/io/paragraph-properties-roundtrip.test.ts +0 -129
- package/test/io/preserved-package-roundtrip.test.ts +0 -365
- package/test/io/property-completeness.test.ts +0 -292
- package/test/io/revision-roundtrip.test.ts +0 -347
- package/test/io/structural-blocks.test.ts +0 -202
- package/test/io/table-media-roundtrip.test.ts +0 -448
- package/test/io/table-properties-roundtrip.test.ts +0 -569
- package/test/io/table-roundtrip.test.ts +0 -302
- package/test/io/text-roundtrip.test.ts +0 -344
- package/test/model/canonical-document.test.ts +0 -285
- package/test/preservation/opaque-fragment-store.test.ts +0 -121
- package/test/preservation/package-preservation.test.ts +0 -395
- package/test/preservation/store.test.ts +0 -84
- package/test/review/comment-remapping.test.ts +0 -220
- package/test/review/comment-store.test.ts +0 -180
- package/test/review/move-revisions.test.ts +0 -143
- package/test/review/property-change-revisions.test.ts +0 -225
- package/test/review/revision-actions.test.ts +0 -330
- package/test/review/revision-store.test.ts +0 -193
- package/test/runtime/session-capabilities.test.ts +0 -260
- package/test/runtime/table-commands.test.ts +0 -356
- package/test/runtime/table-schema.test.ts +0 -221
- package/test/runtime/tracked-changes-toggle.test.ts +0 -107
- package/test/ui/comment-review-surface.test.tsx +0 -114
- package/test/ui/reduced-motion-toggle.test.tsx +0 -137
- package/test/ui/word-review-editor.imported-scenarios.test.tsx +0 -169
- package/test/ui/word-review-editor.interaction.test.tsx +0 -1198
- package/test/ui/word-review-editor.test.js +0 -188
- package/test/ui/word-review-editor.test.tsx +0 -280
- package/test/ui-tailwind/search-plugin.test.ts +0 -286
- package/test/validation/compatibility-engine.test.ts +0 -336
- package/test/validation/compatibility-report.test.ts +0 -189
- package/test/validation/low-priority-word-surfaces.test.ts +0 -282
- package/test/validation/malformed-doc.test.ts +0 -113
- package/test-results/.last-run.json +0 -4
- package/wave.config.json +0 -406
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
import assert from "node:assert/strict";
|
|
2
|
-
import test from "node:test";
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
createDetachedAnchor,
|
|
6
|
-
createRangeAnchor,
|
|
7
|
-
mapAnchor,
|
|
8
|
-
mapPosition,
|
|
9
|
-
type TransactionMapping,
|
|
10
|
-
} from "../../src/core/selection/mapping.ts";
|
|
11
|
-
import {
|
|
12
|
-
createDefaultCanonicalDocument,
|
|
13
|
-
type CanonicalDocumentEnvelope,
|
|
14
|
-
} from "../../src/core/state/editor-state.ts";
|
|
15
|
-
import { createDocumentRuntime } from "../../src/runtime/document-runtime.ts";
|
|
16
|
-
|
|
17
|
-
test("mapPosition shifts positions after an insertion", () => {
|
|
18
|
-
const mapping: TransactionMapping = {
|
|
19
|
-
steps: [
|
|
20
|
-
{
|
|
21
|
-
from: 5,
|
|
22
|
-
to: 5,
|
|
23
|
-
insertSize: 3,
|
|
24
|
-
},
|
|
25
|
-
],
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
assert.deepEqual(mapPosition(9, 1, mapping), {
|
|
29
|
-
position: 12,
|
|
30
|
-
deleted: false,
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
test("mapAnchor detaches a fully deleted range", () => {
|
|
35
|
-
const mapping: TransactionMapping = {
|
|
36
|
-
steps: [
|
|
37
|
-
{
|
|
38
|
-
from: 2,
|
|
39
|
-
to: 6,
|
|
40
|
-
insertSize: 0,
|
|
41
|
-
},
|
|
42
|
-
],
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
const anchor = createRangeAnchor(3, 5);
|
|
46
|
-
const mapped = mapAnchor(anchor, mapping);
|
|
47
|
-
|
|
48
|
-
assert.deepEqual(mapped, createDetachedAnchor({ from: 3, to: 5 }, "deleted"));
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
test("mapAnchor preserves structural invalidation reason when flagged", () => {
|
|
52
|
-
const mapping: TransactionMapping = {
|
|
53
|
-
steps: [
|
|
54
|
-
{
|
|
55
|
-
from: 2,
|
|
56
|
-
to: 4,
|
|
57
|
-
insertSize: 0,
|
|
58
|
-
},
|
|
59
|
-
],
|
|
60
|
-
metadata: {
|
|
61
|
-
invalidatesStructures: true,
|
|
62
|
-
},
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
const mapped = mapAnchor(createRangeAnchor(3, 3), mapping);
|
|
66
|
-
|
|
67
|
-
assert.deepEqual(
|
|
68
|
-
mapped,
|
|
69
|
-
createDetachedAnchor({ from: 3, to: 3 }, "invalidatedByStructureChange"),
|
|
70
|
-
);
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
test("document runtime routes mutations through dispatch and tracks undo redo", () => {
|
|
74
|
-
const eventTypes: string[] = [];
|
|
75
|
-
const runtime = createDocumentRuntime({
|
|
76
|
-
documentId: "doc-1",
|
|
77
|
-
initialCanonicalDocument: createDefaultCanonicalDocument(
|
|
78
|
-
"doc-1",
|
|
79
|
-
"2026-03-26T00:00:00.000Z",
|
|
80
|
-
),
|
|
81
|
-
clock: () => "2026-03-26T00:00:00.000Z",
|
|
82
|
-
onEvent(event) {
|
|
83
|
-
eventTypes.push(event.type);
|
|
84
|
-
},
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
runtime.dispatch({
|
|
88
|
-
type: "selection.set",
|
|
89
|
-
selection: {
|
|
90
|
-
anchor: 1,
|
|
91
|
-
head: 4,
|
|
92
|
-
isCollapsed: false,
|
|
93
|
-
activeRange: createRangeAnchor(1, 4),
|
|
94
|
-
},
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
const commentId = runtime.addComment({
|
|
98
|
-
body: "Needs review",
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
assert.equal(runtime.getRenderSnapshot().selection.anchor, 1);
|
|
102
|
-
assert.equal(runtime.getRenderSnapshot().comments.openCommentIds.length, 1);
|
|
103
|
-
assert.ok(commentId.startsWith("comment-"));
|
|
104
|
-
|
|
105
|
-
runtime.undo();
|
|
106
|
-
assert.equal(runtime.getRenderSnapshot().comments.openCommentIds.length, 0);
|
|
107
|
-
|
|
108
|
-
runtime.redo();
|
|
109
|
-
assert.equal(runtime.getRenderSnapshot().comments.openCommentIds.length, 1);
|
|
110
|
-
assert.ok(eventTypes.includes("selection_changed"));
|
|
111
|
-
assert.ok(eventTypes.includes("comment_added"));
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
test("persisted snapshots remain separate from render snapshots", () => {
|
|
115
|
-
const runtime = createDocumentRuntime({
|
|
116
|
-
documentId: "doc-2",
|
|
117
|
-
initialCanonicalDocument: createDefaultCanonicalDocument(
|
|
118
|
-
"doc-2",
|
|
119
|
-
"2026-03-26T00:00:00.000Z",
|
|
120
|
-
),
|
|
121
|
-
clock: () => "2026-03-26T00:00:00.000Z",
|
|
122
|
-
editorBuild: "test-build",
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
const persisted = runtime.getPersistedSnapshot();
|
|
126
|
-
const renderSnapshot = runtime.getRenderSnapshot();
|
|
127
|
-
|
|
128
|
-
assert.equal(persisted.snapshotVersion, "persisted-editor-snapshot/1");
|
|
129
|
-
assert.equal(persisted.editorBuild, "test-build");
|
|
130
|
-
assert.equal(typeof persisted.canonicalDocument.docId, "string");
|
|
131
|
-
assert.ok(persisted.canonicalDocument.docId.length > 0);
|
|
132
|
-
assert.ok("documentStats" in renderSnapshot);
|
|
133
|
-
assert.ok(!("documentStats" in persisted));
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
test("document replacement remaps stored comment anchors", () => {
|
|
137
|
-
const runtime = createDocumentRuntime({
|
|
138
|
-
documentId: "doc-3",
|
|
139
|
-
initialCanonicalDocument: createDefaultCanonicalDocument(
|
|
140
|
-
"doc-3",
|
|
141
|
-
"2026-03-26T00:00:00.000Z",
|
|
142
|
-
),
|
|
143
|
-
clock: () => "2026-03-26T00:00:00.000Z",
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
runtime.dispatch({
|
|
147
|
-
type: "selection.set",
|
|
148
|
-
selection: {
|
|
149
|
-
anchor: 2,
|
|
150
|
-
head: 4,
|
|
151
|
-
isCollapsed: false,
|
|
152
|
-
activeRange: createRangeAnchor(2, 4),
|
|
153
|
-
},
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
const commentId = runtime.addComment({ body: "Shift me" });
|
|
157
|
-
const nextDocument =
|
|
158
|
-
runtime.getPersistedSnapshot().canonicalDocument as unknown as CanonicalDocumentEnvelope;
|
|
159
|
-
|
|
160
|
-
runtime.dispatch({
|
|
161
|
-
type: "document.replace",
|
|
162
|
-
document: nextDocument,
|
|
163
|
-
mapping: {
|
|
164
|
-
steps: [
|
|
165
|
-
{
|
|
166
|
-
from: 0,
|
|
167
|
-
to: 0,
|
|
168
|
-
insertSize: 3,
|
|
169
|
-
},
|
|
170
|
-
],
|
|
171
|
-
metadata: {
|
|
172
|
-
affectsComments: true,
|
|
173
|
-
},
|
|
174
|
-
},
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
const comment = (
|
|
178
|
-
runtime.getPersistedSnapshot().canonicalDocument as unknown as CanonicalDocumentEnvelope
|
|
179
|
-
).review.comments[commentId];
|
|
180
|
-
|
|
181
|
-
assert.equal(comment.anchor.kind, "range");
|
|
182
|
-
if (comment.anchor.kind === "range") {
|
|
183
|
-
assert.equal(comment.anchor.range.from, 5);
|
|
184
|
-
assert.equal(comment.anchor.range.to, 7);
|
|
185
|
-
}
|
|
186
|
-
});
|
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
import assert from "node:assert/strict";
|
|
2
|
-
import test from "node:test";
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
deleteSelectionOrBackward,
|
|
6
|
-
insertHardBreak,
|
|
7
|
-
insertTab,
|
|
8
|
-
insertText,
|
|
9
|
-
splitParagraph,
|
|
10
|
-
} from "../../src/core/commands/text-commands.ts";
|
|
11
|
-
import { createRangeAnchor, mapAnchor } from "../../src/core/selection/mapping.ts";
|
|
12
|
-
import {
|
|
13
|
-
createSelectionSnapshot,
|
|
14
|
-
type CanonicalDocumentEnvelope,
|
|
15
|
-
} from "../../src/core/state/editor-state.ts";
|
|
16
|
-
import { TextTransactionError } from "../../src/core/state/text-transaction.ts";
|
|
17
|
-
import { createPlainText, parseTextStory } from "../../src/core/schema/text-schema.ts";
|
|
18
|
-
|
|
19
|
-
const TIMESTAMP = "2026-03-26T09:00:00.000Z";
|
|
20
|
-
|
|
21
|
-
function createDocument(
|
|
22
|
-
blocks: Array<
|
|
23
|
-
| { type: "paragraph"; children: Array<Record<string, unknown>> }
|
|
24
|
-
| { type: "opaque_block"; fragmentId: string; warningId: string }
|
|
25
|
-
>,
|
|
26
|
-
): CanonicalDocumentEnvelope {
|
|
27
|
-
return {
|
|
28
|
-
schemaVersion: "cds/1.0.0",
|
|
29
|
-
docId: "doc-1",
|
|
30
|
-
createdAt: TIMESTAMP,
|
|
31
|
-
updatedAt: TIMESTAMP,
|
|
32
|
-
metadata: {},
|
|
33
|
-
styles: {},
|
|
34
|
-
numbering: {},
|
|
35
|
-
media: {},
|
|
36
|
-
content: {
|
|
37
|
-
type: "doc",
|
|
38
|
-
children: blocks,
|
|
39
|
-
},
|
|
40
|
-
review: {
|
|
41
|
-
comments: {},
|
|
42
|
-
revisions: {},
|
|
43
|
-
},
|
|
44
|
-
preservation: {},
|
|
45
|
-
diagnostics: {},
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
test("insertText retains consecutive whitespace and emits a stable mapping step", () => {
|
|
50
|
-
const document = createDocument([{ type: "paragraph", children: [{ type: "text", text: "AlphaBeta" }] }]);
|
|
51
|
-
const selection = createSelectionSnapshot(5, 5);
|
|
52
|
-
|
|
53
|
-
const result = insertText(document, selection, " ", {
|
|
54
|
-
timestamp: TIMESTAMP,
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
assert.equal(result.storyText, "Alpha Beta");
|
|
58
|
-
assert.deepEqual(result.mapping.steps, [{ from: 5, to: 5, insertSize: 2 }]);
|
|
59
|
-
assert.equal(result.selection.anchor, 7);
|
|
60
|
-
assert.equal(createPlainText(parseTextStory(result.document.content)), "Alpha Beta");
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test("insertTab and insertHardBreak create the expected inline units", () => {
|
|
64
|
-
const document = createDocument([{ type: "paragraph", children: [{ type: "text", text: "Hello" }] }]);
|
|
65
|
-
|
|
66
|
-
const withTab = insertTab(document, createSelectionSnapshot(5, 5), {
|
|
67
|
-
timestamp: TIMESTAMP,
|
|
68
|
-
});
|
|
69
|
-
assert.equal(withTab.storyText, "Hello\t");
|
|
70
|
-
|
|
71
|
-
const withBreak = insertHardBreak(withTab.document, createSelectionSnapshot(6, 6), {
|
|
72
|
-
timestamp: TIMESTAMP,
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
assert.equal(withBreak.storyText, "Hello\t\n");
|
|
76
|
-
|
|
77
|
-
const story = parseTextStory(withBreak.document.content);
|
|
78
|
-
assert.equal(story.units[5]?.kind, "tab");
|
|
79
|
-
assert.equal(story.units[6]?.kind, "hard_break");
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
test("splitParagraph preserves story order and marks structure invalidation in mapping metadata", () => {
|
|
83
|
-
const document = createDocument([{ type: "paragraph", children: [{ type: "text", text: "AlphaBeta" }] }]);
|
|
84
|
-
|
|
85
|
-
const result = splitParagraph(document, createSelectionSnapshot(5, 5), {
|
|
86
|
-
timestamp: TIMESTAMP,
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
assert.equal(result.storyText, "Alpha\nBeta");
|
|
90
|
-
assert.equal(result.mapping.metadata?.invalidatesStructures, true);
|
|
91
|
-
assert.deepEqual(result.mapping.steps, [{ from: 5, to: 5, insertSize: 1 }]);
|
|
92
|
-
|
|
93
|
-
const story = parseTextStory(result.document.content);
|
|
94
|
-
assert.equal(story.units[5]?.kind, "paragraph_break");
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
test("backward delete across a paragraph boundary merges paragraphs and remaps anchors deterministically", () => {
|
|
98
|
-
const document = createDocument([
|
|
99
|
-
{ type: "paragraph", children: [{ type: "text", text: "Alpha" }] },
|
|
100
|
-
{ type: "paragraph", children: [{ type: "text", text: "Beta" }] },
|
|
101
|
-
]);
|
|
102
|
-
|
|
103
|
-
const result = deleteSelectionOrBackward(document, createSelectionSnapshot(6, 6), {
|
|
104
|
-
timestamp: TIMESTAMP,
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
assert.equal(result.storyText, "AlphaBeta");
|
|
108
|
-
assert.equal(result.mapping.metadata?.invalidatesStructures, true);
|
|
109
|
-
|
|
110
|
-
const mappedAnchor = mapAnchor(createRangeAnchor(6, 10), result.mapping);
|
|
111
|
-
assert.equal(mappedAnchor.kind, "range");
|
|
112
|
-
if (mappedAnchor.kind === "range") {
|
|
113
|
-
assert.equal(mappedAnchor.range.from, 5);
|
|
114
|
-
assert.equal(mappedAnchor.range.to, 9);
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
test("range deletion removes selected content and collapses the resulting selection", () => {
|
|
119
|
-
const document = createDocument([{ type: "paragraph", children: [{ type: "text", text: "AlphaBeta" }] }]);
|
|
120
|
-
|
|
121
|
-
const result = deleteSelectionOrBackward(document, createSelectionSnapshot(2, 7), {
|
|
122
|
-
timestamp: TIMESTAMP,
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
assert.equal(result.storyText, "Alta");
|
|
126
|
-
assert.equal(result.selection.anchor, 2);
|
|
127
|
-
assert.deepEqual(result.mapping.steps, [{ from: 2, to: 7, insertSize: 0 }]);
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
test("transactions reject deletions that would silently discard protected opaque content", () => {
|
|
131
|
-
const document = createDocument([
|
|
132
|
-
{
|
|
133
|
-
type: "paragraph",
|
|
134
|
-
children: [
|
|
135
|
-
{ type: "text", text: "A" },
|
|
136
|
-
{ type: "opaque_inline", fragmentId: "fragment-1", warningId: "warning-1" },
|
|
137
|
-
{ type: "text", text: "B" },
|
|
138
|
-
],
|
|
139
|
-
},
|
|
140
|
-
]);
|
|
141
|
-
|
|
142
|
-
assert.throws(
|
|
143
|
-
() =>
|
|
144
|
-
deleteSelectionOrBackward(document, createSelectionSnapshot(1, 2), {
|
|
145
|
-
timestamp: TIMESTAMP,
|
|
146
|
-
}),
|
|
147
|
-
(error: unknown) =>
|
|
148
|
-
error instanceof TextTransactionError && error.code === "unsupported_content",
|
|
149
|
-
);
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
test("insertText preserves top-level opaque blocks and trailing paragraph structure", () => {
|
|
153
|
-
const document = createDocument([
|
|
154
|
-
{ type: "paragraph", children: [{ type: "text", text: "Alpha" }] },
|
|
155
|
-
{ type: "opaque_block", fragmentId: "fragment:block-1", warningId: "warning:block-1" },
|
|
156
|
-
{
|
|
157
|
-
type: "paragraph",
|
|
158
|
-
children: [{ type: "text", text: "Beta" }],
|
|
159
|
-
},
|
|
160
|
-
]);
|
|
161
|
-
|
|
162
|
-
const result = insertText(document, createSelectionSnapshot(6, 6), "!", {
|
|
163
|
-
timestamp: TIMESTAMP,
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
assert.equal(result.storyText, "Alpha\uFFFA!Beta");
|
|
167
|
-
assert.deepEqual(result.mapping.steps, [{ from: 6, to: 6, insertSize: 1 }]);
|
|
168
|
-
assert.deepEqual(result.document.content, {
|
|
169
|
-
type: "doc",
|
|
170
|
-
children: [
|
|
171
|
-
{ type: "paragraph", children: [{ type: "text", text: "Alpha" }] },
|
|
172
|
-
{ type: "opaque_block", fragmentId: "fragment:block-1", warningId: "warning:block-1" },
|
|
173
|
-
{ type: "paragraph", children: [{ type: "text", text: "!Beta" }] },
|
|
174
|
-
],
|
|
175
|
-
});
|
|
176
|
-
});
|
|
Binary file
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
# F01 Basic contract skeleton
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F01-basic-contract.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: baseline paragraphs, runs, whitespace, tabs, hard breaks, and paragraph split or merge behavior
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- the session should load into editable canonical paragraphs and runs
|
|
13
|
-
- whitespace, tabs, and hard breaks should normalize into runtime-owned text content without flattening semantic boundaries
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- normal text edits, paragraph splits, and paragraph merges remain supported
|
|
18
|
-
- no preserve-only fallback should be required for the main text story in this fixture
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should regenerate the owned main-document story content from canonical state
|
|
23
|
-
- roundtripped paragraph and run boundaries should remain stable enough for reload and Word reopen
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported edits
|
|
28
|
-
- the source and supported edited exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
|
|
30
|
-
## Word expectation
|
|
31
|
-
|
|
32
|
-
- Word should reopen the edited package without repair prompts
|
|
33
|
-
- baseline paragraph structure and whitespace behavior should remain intact after export
|
|
Binary file
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
# F02 Headings and styles contract
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F02-headings-styles.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: heading paragraphs, paragraph style references, and outline-level preservation through the main story
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- heading paragraphs should import into canonical paragraph content with style bindings intact
|
|
13
|
-
- style-backed outline semantics should remain attached to the relevant paragraphs instead of being flattened to plain text
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- normal text edits inside styled paragraphs remain supported
|
|
18
|
-
- heading paragraphs should keep their style identity through supported edits unless the runtime explicitly changes that style binding
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve paragraph style references and heading ordering
|
|
23
|
-
- reimported output should still identify the same heading paragraphs through their style-backed metadata
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported edits
|
|
28
|
-
- the source and supported edited exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
|
|
30
|
-
## Word expectation
|
|
31
|
-
|
|
32
|
-
- Word should reopen the edited package without repair prompts
|
|
33
|
-
- heading styling and outline behavior should remain intact after export
|
|
Binary file
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
# F03 Legal outline numbering
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F03-legal-outline-numbering.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: nested numbered and bulleted legal-outline content with numbering bindings carried through `word/numbering.xml`
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- numbered and bulleted paragraphs should import into canonical list-aware paragraph content
|
|
13
|
-
- numbering bindings should remain runtime-owned metadata rather than being flattened into plain paragraph text
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- normal text edits inside list items remain supported
|
|
18
|
-
- supported list edits should preserve nesting and numbering bindings instead of dropping the list structure
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve numbering definitions and paragraph numbering bindings
|
|
23
|
-
- reimported output should continue to identify the same nested list structure
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported edits
|
|
28
|
-
- the source and supported edited exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
- this fixture is part of the supported-roundtrip numbering slice for Wave 5 and Wave 10
|
|
30
|
-
|
|
31
|
-
## Word expectation
|
|
32
|
-
|
|
33
|
-
- Word should reopen the edited package without repair prompts
|
|
34
|
-
- numbering, indentation, and nested legal-outline structure should remain intact after export
|
|
Binary file
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
# F04 Restart numbering schedules
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- `word/document.xml` contains one primary numbered sequence and one restarted sequence.
|
|
6
|
-
- `word/numbering.xml` defines one abstract numbering definition plus two numbering instances.
|
|
7
|
-
- `numId=2` carries a level-0 `<w:startOverride w:val="1"/>` restart override.
|
|
8
|
-
|
|
9
|
-
## Import expectation
|
|
10
|
-
|
|
11
|
-
- the session should load as editable canonical paragraphs with numbering bindings intact
|
|
12
|
-
- canonical numbering state should include both numbering instances and the restart override on `num:2`
|
|
13
|
-
|
|
14
|
-
## Edit expectation
|
|
15
|
-
|
|
16
|
-
- normal text edits inside numbered paragraphs remain supported
|
|
17
|
-
- restart semantics remain owned by numbering state, not flattened into plain paragraphs
|
|
18
|
-
|
|
19
|
-
## Export expectation
|
|
20
|
-
|
|
21
|
-
- export should preserve paragraph numbering bindings for both sequences
|
|
22
|
-
- `word/numbering.xml` should retain the restart override for the restarted schedule
|
|
23
|
-
- reimported output should still report the restart override on `num:2`
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported text edits
|
|
28
|
-
- the fixture is part of the `supported-roundtrip` numbering slice for Wave 5 and Wave 10
|
|
29
|
-
|
|
30
|
-
## Word expectation
|
|
31
|
-
|
|
32
|
-
- Word should reopen the edited package without repair prompts
|
|
33
|
-
- the restarted schedule should still begin at `1` after export
|
|
Binary file
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
# F05 Table-heavy agreement
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F05-table-heavy-agreement.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: body-level table markup, `w:tblGrid`, and package-backed cell-content survival
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- surrounding non-table story content may import into canonical editable text
|
|
13
|
-
- body-level table content should import as locked preserve-only package-backed content rather than first-class canonical table state
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- supported edits may occur around the preserved table region
|
|
18
|
-
- the table surface itself must remain atomic and non-editable on the current live path
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve the original table subtree and package-backed table content without semantic rewriting
|
|
23
|
-
- `w:tbl`, `w:tblGrid`, and related table structure should survive roundtrip intact
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported surrounding edits
|
|
28
|
-
- the source and preserve-only roundtrip exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
- this fixture proves preserve-only table survival, not first-class table editing
|
|
30
|
-
|
|
31
|
-
## Word expectation
|
|
32
|
-
|
|
33
|
-
- Word should reopen the edited package without repair prompts
|
|
34
|
-
- the table layout and cell content should remain intact after export
|
|
Binary file
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
# F06 Merged-cells signature table
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F06-merged-cells-signature-table.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: body-level table markup with horizontal and vertical merged-cell behavior
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- surrounding non-table story content may import into canonical editable text
|
|
13
|
-
- merged-cell table markup should import as locked preserve-only package-backed content rather than canonical table state
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- supported edits may occur around the preserved table region
|
|
18
|
-
- merged-cell structure must remain atomic and non-editable on the current live path
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve the original merged-cell table subtree without semantic rewriting
|
|
23
|
-
- `w:gridSpan`, `w:vMerge`, and related table structure should survive roundtrip intact
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported surrounding edits
|
|
28
|
-
- the source and preserve-only roundtrip exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
- this fixture proves preserve-only merged-cell survival, not first-class table editing
|
|
30
|
-
|
|
31
|
-
## Word expectation
|
|
32
|
-
|
|
33
|
-
- Word should reopen the edited package without repair prompts
|
|
34
|
-
- merged-cell layout and signature-table structure should remain intact after export
|
|
Binary file
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
# F07 Inline images exhibit
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F07-inline-images-exhibit.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: inline drawing markup, image part retention, and document-to-media relationship integrity
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- inline images should import into the supported story surface without dropping their media backing
|
|
13
|
-
- media parts and image relationships should remain tracked as package-backed assets through the runtime session
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- normal text edits around existing inline images remain supported
|
|
18
|
-
- this fixture does not claim arbitrary image replacement or resizing; the requirement is non-destructive inline-image survival on the owned path
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve image parts, content types, and document relationship targets required for inline rendering
|
|
23
|
-
- reimported output should still surface the inline images in the same story locations
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported edits
|
|
28
|
-
- the source and supported edited exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
- relationship integrity is part of the supported-roundtrip proof for this fixture
|
|
30
|
-
|
|
31
|
-
## Word expectation
|
|
32
|
-
|
|
33
|
-
- Word should reopen the edited package without repair prompts
|
|
34
|
-
- inline images should still render in place after export
|
|
Binary file
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
# F08 Hyperlinks exhibit list
|
|
2
|
-
|
|
3
|
-
## Source shape
|
|
4
|
-
|
|
5
|
-
- file: `F08-hyperlinks.docx`
|
|
6
|
-
- source package findings: `0`
|
|
7
|
-
- source SDK findings: `0`
|
|
8
|
-
- observed focus: external hyperlink relationships in body content and hyperlink-bearing content inside preserved table regions
|
|
9
|
-
|
|
10
|
-
## Import expectation
|
|
11
|
-
|
|
12
|
-
- body-level hyperlinks should import into canonical text content with their targets preserved
|
|
13
|
-
- hyperlinks that live inside preserve-only regions should stay attached to those opaque preserved regions
|
|
14
|
-
|
|
15
|
-
## Edit expectation
|
|
16
|
-
|
|
17
|
-
- normal text edits around supported body hyperlinks remain supported
|
|
18
|
-
- preserve-only regions containing hyperlinks must remain atomic and non-editable on the live path
|
|
19
|
-
|
|
20
|
-
## Export expectation
|
|
21
|
-
|
|
22
|
-
- export should preserve external hyperlink relationships required by supported body hyperlinks
|
|
23
|
-
- hyperlink targets and relationship integrity should survive roundtrip for both canonical and preserved surfaces
|
|
24
|
-
|
|
25
|
-
## Validation expectation
|
|
26
|
-
|
|
27
|
-
- package integrity should remain valid after supported edits
|
|
28
|
-
- the source and supported edited exports should remain at `0` package findings and `0` SDK findings
|
|
29
|
-
|
|
30
|
-
## Word expectation
|
|
31
|
-
|
|
32
|
-
- Word should reopen the edited package without repair prompts
|
|
33
|
-
- hyperlink text and target behavior should remain intact after export
|
|
Binary file
|