@beyondwork/docx-react-component 1.0.28 → 1.0.29
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/dist/canonical-document-BLEbzL2J.d.cts +844 -0
- package/dist/canonical-document-BLEbzL2J.d.ts +844 -0
- package/dist/chunk-2FJS5GZM.js +763 -0
- package/dist/chunk-2FJS5GZM.js.map +1 -0
- package/{src/core/commands/section-layout-commands.ts → dist/chunk-2OQBZS3F.js} +106 -340
- package/dist/chunk-2OQBZS3F.js.map +1 -0
- package/dist/chunk-2S7W4KFO.js +127 -0
- package/dist/chunk-2S7W4KFO.js.map +1 -0
- package/dist/chunk-2TG72QSW.js +3874 -0
- package/dist/chunk-2TG72QSW.js.map +1 -0
- package/{src/core/commands/table-structure-commands.ts → dist/chunk-36QNIZBO.js} +126 -315
- package/dist/chunk-36QNIZBO.js.map +1 -0
- package/dist/chunk-4AQOYAW4.js +3069 -0
- package/dist/chunk-4AQOYAW4.js.map +1 -0
- package/dist/chunk-4D5EWJ3P.js +77 -0
- package/dist/chunk-4D5EWJ3P.js.map +1 -0
- package/dist/chunk-5FN54NDH.js +2257 -0
- package/dist/chunk-5FN54NDH.js.map +1 -0
- package/dist/chunk-BOYGQYRQ.js +7306 -0
- package/dist/chunk-BOYGQYRQ.js.map +1 -0
- package/dist/chunk-CN3XMECL.js +212 -0
- package/dist/chunk-CN3XMECL.js.map +1 -0
- package/dist/chunk-EBI3BX6U.js +164 -0
- package/dist/chunk-EBI3BX6U.js.map +1 -0
- package/dist/chunk-EILUG3VB.js +1275 -0
- package/dist/chunk-EILUG3VB.js.map +1 -0
- package/dist/chunk-FUDY333O.js +70 -0
- package/dist/chunk-FUDY333O.js.map +1 -0
- package/dist/chunk-GBVOWFIK.js +1237 -0
- package/dist/chunk-GBVOWFIK.js.map +1 -0
- package/dist/chunk-H4TQ3H3Y.js +262 -0
- package/dist/chunk-H4TQ3H3Y.js.map +1 -0
- package/{src/core/commands/style-commands.ts → dist/chunk-JGB3IXZO.js} +40 -113
- package/dist/chunk-JGB3IXZO.js.map +1 -0
- package/dist/chunk-KD2QRQPY.js +4342 -0
- package/dist/chunk-KD2QRQPY.js.map +1 -0
- package/dist/chunk-KLMXQVYK.js +369 -0
- package/dist/chunk-KLMXQVYK.js.map +1 -0
- package/dist/chunk-KZUG5KFQ.js +214 -0
- package/dist/chunk-KZUG5KFQ.js.map +1 -0
- package/{src/core/state/text-transaction.ts → dist/chunk-QDAQ4CJU.js} +79 -236
- package/dist/chunk-QDAQ4CJU.js.map +1 -0
- package/{src/legal/bookmarks.ts → dist/chunk-RMH72RZI.js} +44 -130
- package/dist/chunk-RMH72RZI.js.map +1 -0
- package/dist/chunk-SWKWQZXM.js +117 -0
- package/dist/chunk-SWKWQZXM.js.map +1 -0
- package/{src/core/commands/formatting-commands.ts → dist/chunk-TJBP2K4T.js} +196 -536
- package/dist/chunk-TJBP2K4T.js.map +1 -0
- package/dist/chunk-TLCEAQDQ.js +542 -0
- package/dist/chunk-TLCEAQDQ.js.map +1 -0
- package/{src/core/commands/text-commands.ts → dist/chunk-UZXBISGO.js} +86 -142
- package/dist/chunk-UZXBISGO.js.map +1 -0
- package/dist/chunk-WGBAKP3Q.js +3220 -0
- package/dist/chunk-WGBAKP3Q.js.map +1 -0
- package/dist/compare/index.cjs +5475 -0
- package/dist/compare/index.cjs.map +1 -0
- package/dist/compare/index.d.cts +114 -0
- package/dist/compare/index.d.ts +114 -0
- package/dist/compare/index.js +731 -0
- package/dist/compare/index.js.map +1 -0
- package/dist/core/commands/formatting-commands.cjs +828 -0
- package/dist/core/commands/formatting-commands.cjs.map +1 -0
- package/dist/core/commands/formatting-commands.d.cts +63 -0
- package/dist/core/commands/formatting-commands.d.ts +63 -0
- package/dist/core/commands/formatting-commands.js +37 -0
- package/dist/core/commands/formatting-commands.js.map +1 -0
- package/dist/core/commands/image-commands.cjs +2023 -0
- package/dist/core/commands/image-commands.cjs.map +1 -0
- package/dist/core/commands/image-commands.d.cts +58 -0
- package/dist/core/commands/image-commands.d.ts +58 -0
- package/dist/core/commands/image-commands.js +18 -0
- package/dist/core/commands/image-commands.js.map +1 -0
- package/dist/core/commands/section-layout-commands.cjs +477 -0
- package/dist/core/commands/section-layout-commands.cjs.map +1 -0
- package/dist/core/commands/section-layout-commands.d.cts +62 -0
- package/dist/core/commands/section-layout-commands.d.ts +62 -0
- package/dist/core/commands/section-layout-commands.js +21 -0
- package/dist/core/commands/section-layout-commands.js.map +1 -0
- package/dist/core/commands/style-commands.cjs +214 -0
- package/dist/core/commands/style-commands.cjs.map +1 -0
- package/dist/core/commands/style-commands.d.cts +13 -0
- package/dist/core/commands/style-commands.d.ts +13 -0
- package/dist/core/commands/style-commands.js +9 -0
- package/dist/core/commands/style-commands.js.map +1 -0
- package/dist/core/commands/table-structure-commands.cjs +1883 -0
- package/dist/core/commands/table-structure-commands.cjs.map +1 -0
- package/dist/core/commands/table-structure-commands.d.cts +59 -0
- package/dist/core/commands/table-structure-commands.d.ts +59 -0
- package/dist/core/commands/table-structure-commands.js +12 -0
- package/dist/core/commands/table-structure-commands.js.map +1 -0
- package/dist/core/commands/text-commands.cjs +2391 -0
- package/dist/core/commands/text-commands.cjs.map +1 -0
- package/dist/core/commands/text-commands.d.cts +24 -0
- package/dist/core/commands/text-commands.d.ts +24 -0
- package/dist/core/commands/text-commands.js +28 -0
- package/dist/core/commands/text-commands.js.map +1 -0
- package/dist/core/selection/mapping.cjs +200 -0
- package/dist/core/selection/mapping.cjs.map +1 -0
- package/dist/core/selection/mapping.d.cts +2 -0
- package/dist/core/selection/mapping.d.ts +2 -0
- package/dist/core/selection/mapping.js +31 -0
- package/dist/core/selection/mapping.js.map +1 -0
- package/dist/core/state/editor-state.cjs +2278 -0
- package/dist/core/state/editor-state.cjs.map +1 -0
- package/dist/core/state/editor-state.d.cts +2 -0
- package/dist/core/state/editor-state.d.ts +2 -0
- package/dist/core/state/editor-state.js +26 -0
- package/dist/core/state/editor-state.js.map +1 -0
- package/dist/index.cjs +38553 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +15 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.js +7856 -0
- package/dist/index.js.map +1 -0
- package/dist/io/docx-session.cjs +16236 -0
- package/dist/io/docx-session.cjs.map +1 -0
- package/dist/io/docx-session.d.cts +21 -0
- package/dist/io/docx-session.d.ts +21 -0
- package/dist/io/docx-session.js +18 -0
- package/dist/io/docx-session.js.map +1 -0
- package/dist/legal/index.cjs +3900 -0
- package/dist/legal/index.cjs.map +1 -0
- package/dist/legal/index.d.cts +86 -0
- package/dist/legal/index.d.ts +86 -0
- package/dist/legal/index.js +616 -0
- package/dist/legal/index.js.map +1 -0
- package/dist/public-types-7ZL_94cz.d.ts +1573 -0
- package/dist/public-types-CeMaDueh.d.cts +1573 -0
- package/dist/public-types.cjs +19 -0
- package/dist/public-types.cjs.map +1 -0
- package/dist/public-types.d.cts +2 -0
- package/dist/public-types.d.ts +2 -0
- package/dist/public-types.js +1 -0
- package/dist/public-types.js.map +1 -0
- package/dist/runtime/document-runtime.cjs +11140 -0
- package/dist/runtime/document-runtime.cjs.map +1 -0
- package/dist/runtime/document-runtime.d.cts +231 -0
- package/dist/runtime/document-runtime.d.ts +231 -0
- package/dist/runtime/document-runtime.js +21 -0
- package/dist/runtime/document-runtime.js.map +1 -0
- package/dist/structural-helpers-CilgOVhh.d.cts +10 -0
- package/dist/structural-helpers-q0Gd-eBN.d.ts +10 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.cjs +313 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.cjs.map +1 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.d.cts +67 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.d.ts +67 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.js +23 -0
- package/dist/ui-tailwind/editor-surface/search-plugin.js.map +1 -0
- package/dist/ui-tailwind/index.cjs +4833 -0
- package/dist/ui-tailwind/index.cjs.map +1 -0
- package/dist/ui-tailwind/index.d.cts +617 -0
- package/dist/ui-tailwind/index.d.ts +617 -0
- package/dist/ui-tailwind/index.js +575 -0
- package/dist/ui-tailwind/index.js.map +1 -0
- package/package.json +61 -41
- package/src/README.md +0 -85
- package/src/api/README.md +0 -26
- package/src/api/public-types.ts +0 -1421
- package/src/api/session-state.ts +0 -60
- package/src/compare/diff-engine.ts +0 -623
- package/src/compare/export-redlines.ts +0 -280
- package/src/compare/index.ts +0 -25
- package/src/compare/snapshot.ts +0 -97
- package/src/component-inventory.md +0 -99
- package/src/core/README.md +0 -10
- package/src/core/commands/README.md +0 -3
- package/src/core/commands/image-commands.ts +0 -373
- package/src/core/commands/index.ts +0 -1757
- package/src/core/commands/list-commands.ts +0 -565
- package/src/core/commands/paragraph-layout-commands.ts +0 -339
- package/src/core/commands/review-commands.ts +0 -108
- package/src/core/commands/structural-helpers.ts +0 -309
- package/src/core/schema/README.md +0 -3
- package/src/core/schema/text-schema.ts +0 -516
- package/src/core/search/search-text.ts +0 -357
- package/src/core/selection/README.md +0 -3
- package/src/core/selection/mapping.ts +0 -289
- package/src/core/selection/review-anchors.ts +0 -183
- package/src/core/state/README.md +0 -3
- package/src/core/state/editor-state.ts +0 -892
- package/src/formats/xlsx/io/parse-shared-strings.ts +0 -41
- package/src/formats/xlsx/io/parse-sheet.ts +0 -459
- package/src/formats/xlsx/io/parse-styles.ts +0 -59
- package/src/formats/xlsx/io/parse-workbook.ts +0 -75
- package/src/formats/xlsx/io/serialize-shared-strings.ts +0 -72
- package/src/formats/xlsx/io/serialize-sheet.ts +0 -333
- package/src/formats/xlsx/io/serialize-styles.ts +0 -98
- package/src/formats/xlsx/io/serialize-workbook.ts +0 -429
- package/src/formats/xlsx/io/xlsx-session.ts +0 -314
- package/src/formats/xlsx/model/cell.ts +0 -189
- package/src/formats/xlsx/model/sheet.ts +0 -326
- package/src/formats/xlsx/model/styles.ts +0 -118
- package/src/formats/xlsx/model/workbook.ts +0 -453
- package/src/formats/xlsx/runtime/cell-commands.ts +0 -567
- package/src/formats/xlsx/runtime/sheet-commands.ts +0 -206
- package/src/formats/xlsx/runtime/workbook-runtime.ts +0 -177
- package/src/formats/xlsx/runtime/workbook-transaction.ts +0 -822
- package/src/index.ts +0 -101
- package/src/io/README.md +0 -10
- package/src/io/docx-session.ts +0 -2882
- package/src/io/export/README.md +0 -3
- package/src/io/export/export-session.ts +0 -220
- package/src/io/export/minimal-docx.ts +0 -115
- package/src/io/export/reattach-preserved-parts.ts +0 -54
- package/src/io/export/serialize-comments.ts +0 -947
- package/src/io/export/serialize-footnotes.ts +0 -399
- package/src/io/export/serialize-headers-footers.ts +0 -372
- package/src/io/export/serialize-main-document.ts +0 -1376
- package/src/io/export/serialize-numbering.ts +0 -118
- package/src/io/export/serialize-revisions.ts +0 -389
- package/src/io/export/serialize-runtime-revisions.ts +0 -269
- package/src/io/export/serialize-tables.ts +0 -174
- package/src/io/export/split-review-boundaries.ts +0 -356
- package/src/io/normalize/README.md +0 -3
- package/src/io/normalize/normalize-text.ts +0 -639
- package/src/io/ooxml/README.md +0 -3
- package/src/io/ooxml/highlight-colors.ts +0 -39
- package/src/io/ooxml/numbering-sentinels.ts +0 -44
- package/src/io/ooxml/parse-comments.ts +0 -846
- package/src/io/ooxml/parse-complex-content.ts +0 -287
- package/src/io/ooxml/parse-fields.ts +0 -834
- package/src/io/ooxml/parse-footnotes.ts +0 -896
- package/src/io/ooxml/parse-headers-footers.ts +0 -1169
- package/src/io/ooxml/parse-inline-media.ts +0 -461
- package/src/io/ooxml/parse-main-document.ts +0 -2877
- package/src/io/ooxml/parse-numbering.ts +0 -432
- package/src/io/ooxml/parse-revisions.ts +0 -931
- package/src/io/ooxml/parse-settings.ts +0 -184
- package/src/io/ooxml/parse-shapes.ts +0 -296
- package/src/io/ooxml/parse-styles.ts +0 -463
- package/src/io/ooxml/parse-tables.ts +0 -618
- package/src/io/ooxml/parse-theme.ts +0 -346
- package/src/io/ooxml/part-manifest.ts +0 -136
- package/src/io/ooxml/revision-boundaries.ts +0 -351
- package/src/io/opc/README.md +0 -3
- package/src/io/opc/corrupt-package.ts +0 -166
- package/src/io/opc/docx-package.ts +0 -74
- package/src/io/opc/package-reader.ts +0 -325
- package/src/io/opc/package-writer.ts +0 -273
- package/src/io/source-package-provenance.ts +0 -241
- package/src/legal/cross-references.ts +0 -414
- package/src/legal/defined-terms.ts +0 -203
- package/src/legal/index.ts +0 -32
- package/src/legal/signature-blocks.ts +0 -259
- package/src/model/README.md +0 -3
- package/src/model/canonical-document.ts +0 -2632
- package/src/model/cds-1.0.0.ts +0 -212
- package/src/model/snapshot.ts +0 -649
- package/src/preservation/README.md +0 -3
- package/src/preservation/markup-compatibility.ts +0 -48
- package/src/preservation/opaque-fragment-store.ts +0 -89
- package/src/preservation/opaque-region.ts +0 -233
- package/src/preservation/package-preservation.ts +0 -113
- package/src/preservation/preserved-part-manifest.ts +0 -56
- package/src/preservation/relationship-retention.ts +0 -57
- package/src/preservation/store.ts +0 -185
- package/src/review/README.md +0 -16
- package/src/review/store/README.md +0 -3
- package/src/review/store/comment-anchors.ts +0 -70
- package/src/review/store/comment-remapping.ts +0 -154
- package/src/review/store/comment-store.ts +0 -331
- package/src/review/store/comment-thread.ts +0 -109
- package/src/review/store/revision-actions.ts +0 -394
- package/src/review/store/revision-store.ts +0 -312
- package/src/review/store/revision-types.ts +0 -171
- package/src/review/store/runtime-comment-store.ts +0 -43
- package/src/runtime/README.md +0 -3
- package/src/runtime/ai-action-policy.ts +0 -764
- package/src/runtime/document-layout.ts +0 -332
- package/src/runtime/document-navigation.ts +0 -603
- package/src/runtime/document-runtime.ts +0 -3159
- package/src/runtime/document-search.ts +0 -145
- package/src/runtime/numbering-prefix.ts +0 -216
- package/src/runtime/page-layout-estimation.ts +0 -212
- package/src/runtime/read-only-diagnostics-runtime.ts +0 -241
- package/src/runtime/review-runtime.ts +0 -44
- package/src/runtime/revision-runtime.ts +0 -107
- package/src/runtime/session-capabilities.ts +0 -192
- package/src/runtime/story-context.ts +0 -164
- package/src/runtime/story-targeting.ts +0 -162
- package/src/runtime/surface-projection.ts +0 -1357
- package/src/runtime/table-commands.ts +0 -173
- package/src/runtime/table-schema.ts +0 -309
- package/src/runtime/view-state.ts +0 -477
- package/src/runtime/virtualized-rendering.ts +0 -258
- package/src/runtime/workflow-markup.ts +0 -353
- package/src/ui/README.md +0 -30
- package/src/ui/WordReviewEditor.tsx +0 -4086
- package/src/ui/browser-export.ts +0 -52
- package/src/ui/comments/README.md +0 -3
- package/src/ui/compatibility/README.md +0 -3
- package/src/ui/editor-command-bag.ts +0 -120
- package/src/ui/editor-runtime-boundary.ts +0 -1457
- package/src/ui/editor-shell-view.tsx +0 -142
- package/src/ui/editor-surface/README.md +0 -3
- package/src/ui/editor-surface-controller.tsx +0 -61
- package/src/ui/headless/comment-decoration-model.ts +0 -124
- package/src/ui/headless/preserve-editor-selection.ts +0 -5
- package/src/ui/headless/revision-decoration-model.ts +0 -128
- package/src/ui/headless/selection-helpers.ts +0 -54
- package/src/ui/headless/selection-toolbar-model.ts +0 -34
- package/src/ui/headless/use-editor-keyboard.ts +0 -103
- package/src/ui/review/README.md +0 -3
- package/src/ui/runtime-snapshot-selectors.ts +0 -197
- package/src/ui/shared/revision-filters.ts +0 -31
- package/src/ui/status/README.md +0 -3
- package/src/ui/theme/README.md +0 -3
- package/src/ui/toolbar/README.md +0 -3
- package/src/ui/workflow-surface-blocked-rails.ts +0 -94
- package/src/ui-tailwind/chrome/tw-alert-banner.tsx +0 -64
- package/src/ui-tailwind/chrome/tw-image-context-toolbar.tsx +0 -129
- package/src/ui-tailwind/chrome/tw-layout-panel.tsx +0 -114
- package/src/ui-tailwind/chrome/tw-object-context-toolbar.tsx +0 -34
- package/src/ui-tailwind/chrome/tw-page-ruler.tsx +0 -386
- package/src/ui-tailwind/chrome/tw-selection-toolbar.tsx +0 -186
- package/src/ui-tailwind/chrome/tw-suggestion-card.tsx +0 -139
- package/src/ui-tailwind/chrome/tw-table-context-toolbar.tsx +0 -128
- package/src/ui-tailwind/chrome/tw-unsaved-modal.tsx +0 -58
- package/src/ui-tailwind/chrome/use-before-unload.ts +0 -20
- package/src/ui-tailwind/editor-surface/perf-probe.ts +0 -179
- package/src/ui-tailwind/editor-surface/pm-command-bridge.ts +0 -184
- package/src/ui-tailwind/editor-surface/pm-contextual-ui.ts +0 -31
- package/src/ui-tailwind/editor-surface/pm-decorations.ts +0 -427
- package/src/ui-tailwind/editor-surface/pm-position-map.ts +0 -123
- package/src/ui-tailwind/editor-surface/pm-schema.ts +0 -876
- package/src/ui-tailwind/editor-surface/pm-state-from-snapshot.ts +0 -504
- package/src/ui-tailwind/editor-surface/search-plugin.ts +0 -168
- package/src/ui-tailwind/editor-surface/surface-build-keys.ts +0 -61
- package/src/ui-tailwind/editor-surface/tw-caret.tsx +0 -12
- package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +0 -150
- package/src/ui-tailwind/editor-surface/tw-inline-token.tsx +0 -129
- package/src/ui-tailwind/editor-surface/tw-opaque-block.tsx +0 -58
- package/src/ui-tailwind/editor-surface/tw-paragraph-block.tsx +0 -151
- package/src/ui-tailwind/editor-surface/tw-prosemirror-surface.tsx +0 -944
- package/src/ui-tailwind/editor-surface/tw-segment-view.tsx +0 -111
- package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +0 -436
- package/src/ui-tailwind/index.ts +0 -62
- package/src/ui-tailwind/page-chrome-model.ts +0 -27
- package/src/ui-tailwind/review/tw-comment-sidebar.tsx +0 -406
- package/src/ui-tailwind/review/tw-health-panel.tsx +0 -149
- package/src/ui-tailwind/review/tw-review-rail.tsx +0 -120
- package/src/ui-tailwind/review/tw-revision-sidebar.tsx +0 -164
- package/src/ui-tailwind/status/tw-status-bar.tsx +0 -61
- package/src/ui-tailwind/toolbar/tw-toolbar-icon-button.tsx +0 -52
- package/src/ui-tailwind/toolbar/tw-toolbar.tsx +0 -1064
- package/src/ui-tailwind/tw-review-workspace.tsx +0 -1417
- package/src/validation/README.md +0 -3
- package/src/validation/compatibility-engine.ts +0 -634
- package/src/validation/compatibility-report.ts +0 -161
- package/src/validation/diagnostics.ts +0 -204
- package/src/validation/docx-comment-proof.ts +0 -707
- package/src/validation/import-diagnostics.ts +0 -128
- package/src/validation/low-priority-word-surfaces.ts +0 -373
- /package/{src → dist}/ui-tailwind/theme/editor-theme.css +0 -0
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
DocRange,
|
|
3
|
-
OpaqueFragmentRecord,
|
|
4
|
-
PreservationStore,
|
|
5
|
-
} from "../model/canonical-document.ts";
|
|
6
|
-
import {
|
|
7
|
-
describeOpaqueFragment,
|
|
8
|
-
findOpaqueFragmentsIntersectingRange,
|
|
9
|
-
getOpaqueFragment,
|
|
10
|
-
listOpaqueFragments,
|
|
11
|
-
} from "./store.ts";
|
|
12
|
-
|
|
13
|
-
export interface LockedOpaqueFragment {
|
|
14
|
-
fragmentId: string;
|
|
15
|
-
warningId: string;
|
|
16
|
-
featureClass: "preserve-only";
|
|
17
|
-
range: DocRange;
|
|
18
|
-
label: string;
|
|
19
|
-
detail: string;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export interface OpaqueFragmentDeletionIntent {
|
|
23
|
-
fragmentId: string;
|
|
24
|
-
warningId: string;
|
|
25
|
-
featureClass: "preserve-only";
|
|
26
|
-
destructive: true;
|
|
27
|
-
confirmationLabel: "Delete preserved content";
|
|
28
|
-
confirmationDetail: string;
|
|
29
|
-
range: DocRange;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export function getLockedOpaqueFragment(
|
|
33
|
-
store: PreservationStore,
|
|
34
|
-
fragmentId: string,
|
|
35
|
-
): LockedOpaqueFragment | undefined {
|
|
36
|
-
const fragment = getOpaqueFragment(store, fragmentId);
|
|
37
|
-
return fragment ? toLockedOpaqueFragment(fragment) : undefined;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
export function listLockedOpaqueFragments(
|
|
41
|
-
store: PreservationStore,
|
|
42
|
-
): LockedOpaqueFragment[] {
|
|
43
|
-
return listOpaqueFragments(store).map(toLockedOpaqueFragment);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
export function listLockedOpaqueFragmentsIntersectingRange(
|
|
47
|
-
store: PreservationStore,
|
|
48
|
-
range: DocRange,
|
|
49
|
-
): LockedOpaqueFragment[] {
|
|
50
|
-
return findOpaqueFragmentsIntersectingRange(store, range).map(
|
|
51
|
-
toLockedOpaqueFragment,
|
|
52
|
-
);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export function createOpaqueFragmentDeletionIntent(
|
|
56
|
-
store: PreservationStore,
|
|
57
|
-
fragmentId: string,
|
|
58
|
-
): OpaqueFragmentDeletionIntent | undefined {
|
|
59
|
-
const lockedFragment = getLockedOpaqueFragment(store, fragmentId);
|
|
60
|
-
if (!lockedFragment) {
|
|
61
|
-
return undefined;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return {
|
|
65
|
-
fragmentId: lockedFragment.fragmentId,
|
|
66
|
-
warningId: lockedFragment.warningId,
|
|
67
|
-
featureClass: lockedFragment.featureClass,
|
|
68
|
-
destructive: true,
|
|
69
|
-
confirmationLabel: "Delete preserved content",
|
|
70
|
-
confirmationDetail:
|
|
71
|
-
`${lockedFragment.label} is preserved as an atomic region. ` +
|
|
72
|
-
"Deleting it removes the preserved payload and may prevent exact OOXML reattachment.",
|
|
73
|
-
range: lockedFragment.range,
|
|
74
|
-
};
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
function toLockedOpaqueFragment(
|
|
78
|
-
fragment: OpaqueFragmentRecord,
|
|
79
|
-
): LockedOpaqueFragment {
|
|
80
|
-
const descriptor = describeOpaqueFragment(fragment);
|
|
81
|
-
return {
|
|
82
|
-
fragmentId: fragment.fragmentId,
|
|
83
|
-
warningId: fragment.warningId,
|
|
84
|
-
featureClass: fragment.featureClass,
|
|
85
|
-
range: fragment.lastKnownRange,
|
|
86
|
-
label: descriptor.label,
|
|
87
|
-
detail: descriptor.detail,
|
|
88
|
-
};
|
|
89
|
-
}
|
|
@@ -1,233 +0,0 @@
|
|
|
1
|
-
import type { CompatibilityFeatureEntry } from "../api/public-types";
|
|
2
|
-
import type { SurfaceBlockSnapshot } from "../api/public-types";
|
|
3
|
-
import type {
|
|
4
|
-
DocRange,
|
|
5
|
-
OpaqueFragmentRecord,
|
|
6
|
-
PreservationStore,
|
|
7
|
-
} from "../model/canonical-document.ts";
|
|
8
|
-
import {
|
|
9
|
-
createOpaqueFragmentDeletionIntent,
|
|
10
|
-
getLockedOpaqueFragment,
|
|
11
|
-
listLockedOpaqueFragments,
|
|
12
|
-
listLockedOpaqueFragmentsIntersectingRange,
|
|
13
|
-
type LockedOpaqueFragment,
|
|
14
|
-
type OpaqueFragmentDeletionIntent,
|
|
15
|
-
} from "./opaque-fragment-store.ts";
|
|
16
|
-
import { describeOpaqueFragment, getOpaqueFragment } from "./store.ts";
|
|
17
|
-
|
|
18
|
-
export interface OpaqueRegionSurfaceModel {
|
|
19
|
-
fragmentId: string;
|
|
20
|
-
warningId: string;
|
|
21
|
-
featureKey: string;
|
|
22
|
-
state: "locked-preserve-only";
|
|
23
|
-
label: string;
|
|
24
|
-
detail: string;
|
|
25
|
-
range: DocRange;
|
|
26
|
-
wholeUnitLabel: string;
|
|
27
|
-
selectionLabel: string;
|
|
28
|
-
destructiveAction: OpaqueFragmentDeletionIntent;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export interface OpaqueRegionTrustMessage {
|
|
32
|
-
eyebrow: string;
|
|
33
|
-
title: string;
|
|
34
|
-
body: string;
|
|
35
|
-
exportState: "ready" | "blocked";
|
|
36
|
-
exportLabel: string;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export interface OpaqueRegionTrustMessageOptions {
|
|
40
|
-
blockExport?: boolean;
|
|
41
|
-
blockExportReason?: string;
|
|
42
|
-
blockingFeature?: Pick<CompatibilityFeatureEntry, "featureKey" | "featureClass" | "message">;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export function getOpaqueRegionSurfaceModel(
|
|
46
|
-
store: PreservationStore,
|
|
47
|
-
fragmentId: string,
|
|
48
|
-
): OpaqueRegionSurfaceModel | undefined {
|
|
49
|
-
const locked = getLockedOpaqueFragment(store, fragmentId);
|
|
50
|
-
if (!locked) {
|
|
51
|
-
return undefined;
|
|
52
|
-
}
|
|
53
|
-
const fragment = getOpaqueFragment(store, fragmentId);
|
|
54
|
-
if (!fragment) {
|
|
55
|
-
return undefined;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return toOpaqueRegionSurfaceModel(
|
|
59
|
-
fragment,
|
|
60
|
-
locked,
|
|
61
|
-
createOpaqueFragmentDeletionIntent(store, fragmentId),
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
export function listOpaqueRegionSurfaceModels(
|
|
66
|
-
store: PreservationStore,
|
|
67
|
-
): OpaqueRegionSurfaceModel[] {
|
|
68
|
-
return listLockedOpaqueFragments(store).flatMap((locked) => {
|
|
69
|
-
const fragment = getOpaqueFragment(store, locked.fragmentId);
|
|
70
|
-
if (!fragment) {
|
|
71
|
-
return [];
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
return [
|
|
75
|
-
toOpaqueRegionSurfaceModel(
|
|
76
|
-
fragment,
|
|
77
|
-
locked,
|
|
78
|
-
createOpaqueFragmentDeletionIntent(store, locked.fragmentId),
|
|
79
|
-
),
|
|
80
|
-
];
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
export function listOpaqueRegionSurfaceModelsIntersectingRange(
|
|
85
|
-
store: PreservationStore,
|
|
86
|
-
range: DocRange,
|
|
87
|
-
): OpaqueRegionSurfaceModel[] {
|
|
88
|
-
return listLockedOpaqueFragmentsIntersectingRange(store, range).flatMap((locked) => {
|
|
89
|
-
const fragment = getOpaqueFragment(store, locked.fragmentId);
|
|
90
|
-
if (!fragment) {
|
|
91
|
-
return [];
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
return [
|
|
95
|
-
toOpaqueRegionSurfaceModel(
|
|
96
|
-
fragment,
|
|
97
|
-
locked,
|
|
98
|
-
createOpaqueFragmentDeletionIntent(store, locked.fragmentId),
|
|
99
|
-
),
|
|
100
|
-
];
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
export function createOpaqueRegionSurfaceModel(
|
|
105
|
-
fragment: OpaqueFragmentRecord,
|
|
106
|
-
): OpaqueRegionSurfaceModel {
|
|
107
|
-
const store: PreservationStore = {
|
|
108
|
-
opaqueFragments: {
|
|
109
|
-
[fragment.fragmentId]: fragment,
|
|
110
|
-
},
|
|
111
|
-
packageParts: {},
|
|
112
|
-
};
|
|
113
|
-
const region = getOpaqueRegionSurfaceModel(store, fragment.fragmentId);
|
|
114
|
-
if (!region) {
|
|
115
|
-
throw new Error(`Opaque region ${fragment.fragmentId} could not be projected.`);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
return region;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
export function createOpaqueRegionSurfaceModelFromSurfaceBlock(
|
|
122
|
-
block: Extract<SurfaceBlockSnapshot, { kind: "opaque_block" }>,
|
|
123
|
-
): OpaqueRegionSurfaceModel {
|
|
124
|
-
return {
|
|
125
|
-
fragmentId: block.fragmentId,
|
|
126
|
-
warningId: block.warningId,
|
|
127
|
-
featureKey: "preserve-only-region",
|
|
128
|
-
state: "locked-preserve-only",
|
|
129
|
-
label: block.label,
|
|
130
|
-
detail: block.detail,
|
|
131
|
-
range: {
|
|
132
|
-
from: block.from,
|
|
133
|
-
to: block.to,
|
|
134
|
-
},
|
|
135
|
-
wholeUnitLabel: "Whole-unit only",
|
|
136
|
-
selectionLabel: `Select preserved region ${block.from}-${block.to}`,
|
|
137
|
-
destructiveAction: {
|
|
138
|
-
fragmentId: block.fragmentId,
|
|
139
|
-
warningId: block.warningId,
|
|
140
|
-
featureClass: "preserve-only",
|
|
141
|
-
destructive: true,
|
|
142
|
-
confirmationLabel: "Delete preserved content",
|
|
143
|
-
confirmationDetail:
|
|
144
|
-
`${block.label} is preserved as an atomic region. ` +
|
|
145
|
-
"Deleting it removes the preserved payload and may prevent exact OOXML reattachment.",
|
|
146
|
-
range: {
|
|
147
|
-
from: block.from,
|
|
148
|
-
to: block.to,
|
|
149
|
-
},
|
|
150
|
-
},
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
export function createOpaqueRegionTrustMessage(
|
|
155
|
-
region: OpaqueRegionSurfaceModel,
|
|
156
|
-
options: OpaqueRegionTrustMessageOptions = {},
|
|
157
|
-
): OpaqueRegionTrustMessage {
|
|
158
|
-
const blockingFeature = normalizeBlockingFeature(
|
|
159
|
-
region,
|
|
160
|
-
options.blockExportReason,
|
|
161
|
-
options.blockingFeature,
|
|
162
|
-
);
|
|
163
|
-
const exportState = options.blockExport ? "blocked" : "ready";
|
|
164
|
-
const title = options.blockExport
|
|
165
|
-
? "Export needs another fix before this snapshot can leave the editor"
|
|
166
|
-
: "Export remains available while this preserved region stays intact";
|
|
167
|
-
const baseSentence =
|
|
168
|
-
`${region.label} stays visible but locked as one preserved unit so Word-specific OOXML can round-trip safely.`;
|
|
169
|
-
const body = options.blockExport
|
|
170
|
-
? blockingFeature
|
|
171
|
-
? `${baseSentence} Export is blocked by ${blockingFeature}, not by this preserve-only region alone.`
|
|
172
|
-
: `${baseSentence} Export is blocked because this snapshot also contains unsupported issues that cannot be preserved as-is.`
|
|
173
|
-
: `${baseSentence} Internal editing is disabled here, but the document can still export if no unsupported-fatal issues are present.`;
|
|
174
|
-
|
|
175
|
-
return {
|
|
176
|
-
eyebrow: "Preserve-only region",
|
|
177
|
-
title,
|
|
178
|
-
body,
|
|
179
|
-
exportState,
|
|
180
|
-
exportLabel: exportState === "blocked" ? "export blocked elsewhere" : "export remains available",
|
|
181
|
-
};
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
function toOpaqueRegionSurfaceModel(
|
|
185
|
-
fragment: OpaqueFragmentRecord,
|
|
186
|
-
locked: LockedOpaqueFragment,
|
|
187
|
-
deletionIntent: OpaqueFragmentDeletionIntent | undefined,
|
|
188
|
-
): OpaqueRegionSurfaceModel {
|
|
189
|
-
if (!deletionIntent) {
|
|
190
|
-
throw new Error(`Missing deletion intent for preserved region ${locked.fragmentId}.`);
|
|
191
|
-
}
|
|
192
|
-
const descriptor = describeOpaqueFragment(fragment);
|
|
193
|
-
|
|
194
|
-
return {
|
|
195
|
-
fragmentId: locked.fragmentId,
|
|
196
|
-
warningId: locked.warningId,
|
|
197
|
-
featureKey: descriptor.featureKey,
|
|
198
|
-
state: "locked-preserve-only",
|
|
199
|
-
label: locked.label,
|
|
200
|
-
detail: locked.detail,
|
|
201
|
-
range: locked.range,
|
|
202
|
-
wholeUnitLabel: "Whole-unit only",
|
|
203
|
-
selectionLabel: `Select preserved region ${locked.range.from}-${locked.range.to}`,
|
|
204
|
-
destructiveAction: deletionIntent,
|
|
205
|
-
};
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
function normalizeBlockingFeature(
|
|
209
|
-
region: OpaqueRegionSurfaceModel,
|
|
210
|
-
blockExportReason?: string,
|
|
211
|
-
blockingFeature?: Pick<CompatibilityFeatureEntry, "featureKey" | "featureClass" | "message">,
|
|
212
|
-
): string | undefined {
|
|
213
|
-
if (typeof blockExportReason === "string" && blockExportReason.trim().length > 0) {
|
|
214
|
-
const trimmedReason = blockExportReason.trim();
|
|
215
|
-
return trimmedReason.charAt(0).toLowerCase() + trimmedReason.slice(1);
|
|
216
|
-
}
|
|
217
|
-
if (!blockingFeature) {
|
|
218
|
-
return undefined;
|
|
219
|
-
}
|
|
220
|
-
if (
|
|
221
|
-
blockingFeature.featureClass === "preserve-only" &&
|
|
222
|
-
blockingFeature.featureKey === region.featureKey
|
|
223
|
-
) {
|
|
224
|
-
return undefined;
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
const trimmedMessage = blockingFeature.message.trim();
|
|
228
|
-
if (trimmedMessage.length > 0) {
|
|
229
|
-
return trimmedMessage.charAt(0).toLowerCase() + trimmedMessage.slice(1);
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
return blockingFeature.featureKey.replace(/[-_]+/gu, " ");
|
|
233
|
-
}
|
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import type { PreservedPackagePart } from "../model/canonical-document.ts";
|
|
2
|
-
import { resolveRelationshipTarget } from "../io/ooxml/part-manifest.ts";
|
|
3
|
-
import type { OpcPackage } from "../io/opc/package-reader.ts";
|
|
4
|
-
|
|
5
|
-
const CORE_NON_PRESERVED_PART_PATHS = new Set([
|
|
6
|
-
"/docProps/app.xml",
|
|
7
|
-
"/docProps/core.xml",
|
|
8
|
-
"/word/numbering.xml",
|
|
9
|
-
]);
|
|
10
|
-
|
|
11
|
-
export function collectPreservedPackageParts(
|
|
12
|
-
sourcePackage: OpcPackage,
|
|
13
|
-
commentsPartPath?: string,
|
|
14
|
-
): Record<string, PreservedPackagePart> {
|
|
15
|
-
return Object.fromEntries(
|
|
16
|
-
[...sourcePackage.parts.values()]
|
|
17
|
-
.filter((part) => shouldPreservePackagePart(part.path, part.surfaceKind, commentsPartPath))
|
|
18
|
-
.map((part) => [
|
|
19
|
-
part.path,
|
|
20
|
-
{
|
|
21
|
-
packagePartName: part.path,
|
|
22
|
-
contentType: part.contentType ?? "application/octet-stream",
|
|
23
|
-
relationshipIds: findRelationshipIdsTargetingPart(sourcePackage, part.path),
|
|
24
|
-
} satisfies PreservedPackagePart,
|
|
25
|
-
]),
|
|
26
|
-
);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function collectBrokenInternalRelationshipTargets(
|
|
30
|
-
sourcePackage: OpcPackage,
|
|
31
|
-
): string[] {
|
|
32
|
-
const brokenTargets: string[] = [];
|
|
33
|
-
|
|
34
|
-
for (const relationship of sourcePackage.manifest.packageRelationships) {
|
|
35
|
-
if (relationship.targetMode !== "internal") {
|
|
36
|
-
continue;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const target = resolveRelationshipTarget(null, relationship);
|
|
40
|
-
if (!sourcePackage.parts.has(target)) {
|
|
41
|
-
brokenTargets.push(target);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
for (const part of sourcePackage.parts.values()) {
|
|
46
|
-
for (const relationship of part.relationships) {
|
|
47
|
-
if (relationship.targetMode !== "internal") {
|
|
48
|
-
continue;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const target = resolveRelationshipTarget(part.path, relationship);
|
|
52
|
-
if (!sourcePackage.parts.has(target)) {
|
|
53
|
-
brokenTargets.push(target);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return [...new Set(brokenTargets)].sort();
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export function shouldPreservePackagePart(
|
|
62
|
-
partPath: string,
|
|
63
|
-
surfaceKind: OpcPackage["parts"] extends Map<string, infer T>
|
|
64
|
-
? T extends { surfaceKind: infer U }
|
|
65
|
-
? U
|
|
66
|
-
: never
|
|
67
|
-
: never,
|
|
68
|
-
commentsPartPath?: string,
|
|
69
|
-
): boolean {
|
|
70
|
-
if (surfaceKind !== "content") {
|
|
71
|
-
return false;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
if (
|
|
75
|
-
partPath === "/word/document.xml" ||
|
|
76
|
-
partPath === commentsPartPath ||
|
|
77
|
-
partPath.startsWith("/word/media/") ||
|
|
78
|
-
CORE_NON_PRESERVED_PART_PATHS.has(partPath)
|
|
79
|
-
) {
|
|
80
|
-
return false;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
return true;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
export function findRelationshipIdsTargetingPart(
|
|
87
|
-
sourcePackage: OpcPackage,
|
|
88
|
-
targetPartPath: string,
|
|
89
|
-
): string[] {
|
|
90
|
-
const ids = new Set<string>();
|
|
91
|
-
|
|
92
|
-
for (const relationship of sourcePackage.manifest.packageRelationships) {
|
|
93
|
-
if (
|
|
94
|
-
relationship.targetMode === "internal" &&
|
|
95
|
-
resolveRelationshipTarget(null, relationship) === targetPartPath
|
|
96
|
-
) {
|
|
97
|
-
ids.add(relationship.id);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
for (const part of sourcePackage.parts.values()) {
|
|
102
|
-
for (const relationship of part.relationships) {
|
|
103
|
-
if (
|
|
104
|
-
relationship.targetMode === "internal" &&
|
|
105
|
-
resolveRelationshipTarget(part.path, relationship) === targetPartPath
|
|
106
|
-
) {
|
|
107
|
-
ids.add(relationship.id);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
return [...ids].sort();
|
|
113
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
PreservationStore,
|
|
3
|
-
PreservedPackagePart,
|
|
4
|
-
} from "../model/canonical-document.ts";
|
|
5
|
-
import { listPreservedPackageParts } from "./store.ts";
|
|
6
|
-
|
|
7
|
-
export interface PreservedPartManifestEntry {
|
|
8
|
-
packagePartName: string;
|
|
9
|
-
contentType: string;
|
|
10
|
-
relationshipIds: string[];
|
|
11
|
-
label: string;
|
|
12
|
-
detail: string;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function listPreservedPartManifestEntries(
|
|
16
|
-
store: PreservationStore,
|
|
17
|
-
): PreservedPartManifestEntry[] {
|
|
18
|
-
return listPreservedPackageParts(store).map(toManifestEntry);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export function getPreservedPartManifestEntry(
|
|
22
|
-
store: PreservationStore,
|
|
23
|
-
packagePartName: string,
|
|
24
|
-
): PreservedPartManifestEntry | undefined {
|
|
25
|
-
const part = store.packageParts[packagePartName];
|
|
26
|
-
return part ? toManifestEntry(part) : undefined;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function findPreservedPartsReferencingRelationship(
|
|
30
|
-
store: PreservationStore,
|
|
31
|
-
relationshipId: string,
|
|
32
|
-
): PreservedPartManifestEntry[] {
|
|
33
|
-
return listPreservedPackageParts(store)
|
|
34
|
-
.filter((part) => part.relationshipIds.includes(relationshipId))
|
|
35
|
-
.map(toManifestEntry);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function toManifestEntry(
|
|
39
|
-
part: PreservedPackagePart,
|
|
40
|
-
): PreservedPartManifestEntry {
|
|
41
|
-
const relationshipCount = part.relationshipIds.length;
|
|
42
|
-
const relationshipDetail =
|
|
43
|
-
relationshipCount === 0
|
|
44
|
-
? "No explicit preserved relationships recorded."
|
|
45
|
-
: relationshipCount === 1
|
|
46
|
-
? `Tracks relationship ${part.relationshipIds[0]}.`
|
|
47
|
-
: `Tracks ${relationshipCount} preserved relationships.`;
|
|
48
|
-
|
|
49
|
-
return {
|
|
50
|
-
packagePartName: part.packagePartName,
|
|
51
|
-
contentType: part.contentType,
|
|
52
|
-
relationshipIds: [...part.relationshipIds],
|
|
53
|
-
label: `Preserved package part ${part.packagePartName}`,
|
|
54
|
-
detail: `${part.contentType}. ${relationshipDetail}`,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import type { OpaqueFragmentRecord, PreservationStore } from "../model/canonical-document.ts";
|
|
2
|
-
import type { OpcRelationship } from "../io/ooxml/part-manifest.ts";
|
|
3
|
-
|
|
4
|
-
export function retainRelationshipsForFragment(
|
|
5
|
-
fragment: OpaqueFragmentRecord | undefined,
|
|
6
|
-
relationships: OpcRelationship[],
|
|
7
|
-
existingRelationshipMap: Map<string, OpcRelationship>,
|
|
8
|
-
retainedRelationshipIds: Set<string>,
|
|
9
|
-
): void {
|
|
10
|
-
if (!fragment || fragment.payloadKind !== "xml-subtree") {
|
|
11
|
-
return;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
for (const relationshipId of extractReferencedRelationshipIds(fragment.payloadReference)) {
|
|
15
|
-
if (retainedRelationshipIds.has(relationshipId)) {
|
|
16
|
-
continue;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const relationship = existingRelationshipMap.get(relationshipId);
|
|
20
|
-
if (!relationship) {
|
|
21
|
-
continue;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
relationships.push({ ...relationship });
|
|
25
|
-
retainedRelationshipIds.add(relationshipId);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function retainRelationshipsForStore(
|
|
30
|
-
store: PreservationStore,
|
|
31
|
-
relationships: OpcRelationship[],
|
|
32
|
-
existingRelationshipMap: Map<string, OpcRelationship>,
|
|
33
|
-
retainedRelationshipIds: Set<string>,
|
|
34
|
-
): void {
|
|
35
|
-
for (const fragment of Object.values(store.opaqueFragments)) {
|
|
36
|
-
retainRelationshipsForFragment(
|
|
37
|
-
fragment,
|
|
38
|
-
relationships,
|
|
39
|
-
existingRelationshipMap,
|
|
40
|
-
retainedRelationshipIds,
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export function extractReferencedRelationshipIds(xml: string): Set<string> {
|
|
46
|
-
const relationshipIds = new Set<string>();
|
|
47
|
-
const relationshipPattern = /\br:id=(["'])([^"']+)\1/gu;
|
|
48
|
-
|
|
49
|
-
for (const match of xml.matchAll(relationshipPattern)) {
|
|
50
|
-
const relationshipId = match[2];
|
|
51
|
-
if (relationshipId) {
|
|
52
|
-
relationshipIds.add(relationshipId);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return relationshipIds;
|
|
57
|
-
}
|