@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
|
@@ -0,0 +1,616 @@
|
|
|
1
|
+
import {
|
|
2
|
+
parseMainDocumentXml
|
|
3
|
+
} from "../chunk-4AQOYAW4.js";
|
|
4
|
+
import "../chunk-FUDY333O.js";
|
|
5
|
+
import {
|
|
6
|
+
assessBookmarkIntegrity,
|
|
7
|
+
collectBookmarksFromCanonicalDocument,
|
|
8
|
+
isHiddenBookmarkName,
|
|
9
|
+
parseBookmarksFromDocumentXml
|
|
10
|
+
} from "../chunk-RMH72RZI.js";
|
|
11
|
+
import {
|
|
12
|
+
extractComplexFieldsFromBodyXml,
|
|
13
|
+
parseFieldsFromParagraphXml
|
|
14
|
+
} from "../chunk-TLCEAQDQ.js";
|
|
15
|
+
|
|
16
|
+
// src/legal/cross-references.ts
|
|
17
|
+
var CROSS_REFERENCE_PATTERN = /\b(Section|Clause|Article|Schedule|Exhibit|Appendix)\s+(\d+(?:\.\d+)*|[A-Z]-\d+|[A-Z])(?=[^A-Za-z0-9]|$)/g;
|
|
18
|
+
var W_REF_PATTERN = /<w:ref\b([^>]*)\/?>/g;
|
|
19
|
+
var ATTRIBUTE_PATTERN = /(?:^|\s)(?:w:)?([A-Za-z][\w-]*)="([^"]*)"/g;
|
|
20
|
+
var COMPLEX_FIELD_PATTERN = /<w:instrText\b[^>]*>([\s\S]*?)<\/w:instrText>[\s\S]*?<w:fldChar\b[^>]*w:fldCharType="separate"[^>]*\/>[\s\S]*?<w:t\b[^>]*>([\s\S]*?)<\/w:t>[\s\S]*?<w:fldChar\b[^>]*w:fldCharType="end"[^>]*\/>/g;
|
|
21
|
+
function parseCrossReferencesFromDocumentXml(xml) {
|
|
22
|
+
const parsed = parseMainDocumentXml(xml);
|
|
23
|
+
const results = [];
|
|
24
|
+
parsed.blocks.forEach((block, paragraphIndex) => {
|
|
25
|
+
if (block.type !== "paragraph") {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
for (const child of block.children) {
|
|
29
|
+
if (child.type === "hyperlink" && child.href.startsWith("#")) {
|
|
30
|
+
results.push({
|
|
31
|
+
source: "hyperlink",
|
|
32
|
+
kind: "bookmark",
|
|
33
|
+
target: child.href.slice(1),
|
|
34
|
+
label: flattenInlineText(child.children).trim() || child.href.slice(1),
|
|
35
|
+
paragraphIndex,
|
|
36
|
+
confidence: "high"
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
const { simpleFields } = parseFieldsFromParagraphXml(block.rawXml);
|
|
41
|
+
for (const field of simpleFields) {
|
|
42
|
+
const reference = parseFieldReferenceInstruction(field.instruction);
|
|
43
|
+
if (!reference) {
|
|
44
|
+
continue;
|
|
45
|
+
}
|
|
46
|
+
results.push({
|
|
47
|
+
source: "field",
|
|
48
|
+
kind: "bookmark",
|
|
49
|
+
target: reference.target,
|
|
50
|
+
instruction: reference.instruction,
|
|
51
|
+
label: stripXml(field.contentXml) || reference.target,
|
|
52
|
+
paragraphIndex,
|
|
53
|
+
confidence: "high"
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
for (const pattern of detectCrossReferencePatterns(flattenParagraphText(block))) {
|
|
57
|
+
results.push({
|
|
58
|
+
source: "text-pattern",
|
|
59
|
+
kind: pattern.kind,
|
|
60
|
+
target: pattern.targetHint,
|
|
61
|
+
label: pattern.label,
|
|
62
|
+
paragraphIndex,
|
|
63
|
+
confidence: "medium"
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
for (const field of extractComplexFieldsFromBodyXml(xml)) {
|
|
68
|
+
const reference = parseFieldReferenceInstruction(field.instruction);
|
|
69
|
+
if (!reference) {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
results.push({
|
|
73
|
+
source: "field",
|
|
74
|
+
kind: "bookmark",
|
|
75
|
+
target: reference.target,
|
|
76
|
+
instruction: reference.instruction,
|
|
77
|
+
label: stripXml(field.contentXml) || reference.target,
|
|
78
|
+
confidence: "high"
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
for (const field of extractComplexFieldsWithRegex(xml)) {
|
|
82
|
+
const reference = parseFieldReferenceInstruction(field.instruction);
|
|
83
|
+
if (!reference) {
|
|
84
|
+
continue;
|
|
85
|
+
}
|
|
86
|
+
results.push({
|
|
87
|
+
source: "field",
|
|
88
|
+
kind: "bookmark",
|
|
89
|
+
target: reference.target,
|
|
90
|
+
instruction: reference.instruction,
|
|
91
|
+
label: field.label || reference.target,
|
|
92
|
+
confidence: "high"
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
for (const element of extractWRefElements(xml)) {
|
|
96
|
+
results.push({
|
|
97
|
+
source: "w:ref",
|
|
98
|
+
kind: "bookmark",
|
|
99
|
+
target: element.target,
|
|
100
|
+
label: element.label || element.target || "w:ref",
|
|
101
|
+
confidence: element.target ? "high" : "medium"
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
return dedupeCrossReferences(results);
|
|
105
|
+
}
|
|
106
|
+
function collectCrossReferencesFromCanonicalDocument(document) {
|
|
107
|
+
const root = "content" in document ? document.content : document;
|
|
108
|
+
const results = [];
|
|
109
|
+
let paragraphIndex = -1;
|
|
110
|
+
walkDocument(root, (node) => {
|
|
111
|
+
if (node.type === "paragraph") {
|
|
112
|
+
paragraphIndex += 1;
|
|
113
|
+
for (const child of node.children) {
|
|
114
|
+
if (child.type === "hyperlink" && child.href.startsWith("#")) {
|
|
115
|
+
results.push({
|
|
116
|
+
source: "hyperlink",
|
|
117
|
+
kind: "bookmark",
|
|
118
|
+
target: child.href.slice(1),
|
|
119
|
+
label: flattenInlineText(child.children).trim() || child.href.slice(1),
|
|
120
|
+
paragraphIndex,
|
|
121
|
+
confidence: "high"
|
|
122
|
+
});
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
125
|
+
if (child.type === "field") {
|
|
126
|
+
const reference = parseFieldReferenceInstruction(child.instruction);
|
|
127
|
+
if (!reference) {
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
results.push({
|
|
131
|
+
source: "field",
|
|
132
|
+
kind: "bookmark",
|
|
133
|
+
target: reference.target,
|
|
134
|
+
instruction: reference.instruction,
|
|
135
|
+
label: flattenInlineText(child.children).trim() || reference.target,
|
|
136
|
+
paragraphIndex,
|
|
137
|
+
confidence: "high"
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
for (const pattern of detectCrossReferencePatterns(flattenParagraphText(node))) {
|
|
142
|
+
results.push({
|
|
143
|
+
source: "text-pattern",
|
|
144
|
+
kind: pattern.kind,
|
|
145
|
+
target: pattern.targetHint,
|
|
146
|
+
label: pattern.label,
|
|
147
|
+
paragraphIndex,
|
|
148
|
+
confidence: "medium"
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
return dedupeCrossReferences(results);
|
|
154
|
+
}
|
|
155
|
+
function detectCrossReferencePatterns(text) {
|
|
156
|
+
const matches = [];
|
|
157
|
+
for (const match of text.matchAll(CROSS_REFERENCE_PATTERN)) {
|
|
158
|
+
const referenceType = match[1]?.toLowerCase();
|
|
159
|
+
const target = match[2];
|
|
160
|
+
const label = `${match[1]} ${target}`.trim();
|
|
161
|
+
if (!referenceType || !target) {
|
|
162
|
+
continue;
|
|
163
|
+
}
|
|
164
|
+
matches.push({
|
|
165
|
+
kind: referenceType,
|
|
166
|
+
label,
|
|
167
|
+
targetHint: target
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
return matches;
|
|
171
|
+
}
|
|
172
|
+
function parseFieldReferenceInstruction(instruction) {
|
|
173
|
+
const trimmedInstruction = instruction.trim().replace(/\s+/g, " ");
|
|
174
|
+
const match = /^(REF|PAGEREF|NOTEREF)\s+(?:"([^"]+)"|([^\s\\]+))/i.exec(trimmedInstruction);
|
|
175
|
+
if (!match) {
|
|
176
|
+
return void 0;
|
|
177
|
+
}
|
|
178
|
+
return {
|
|
179
|
+
kind: match[1].toUpperCase(),
|
|
180
|
+
target: (match[2] ?? match[3] ?? "").trim(),
|
|
181
|
+
instruction: trimmedInstruction
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
function extractWRefElements(xml) {
|
|
185
|
+
const matches = [];
|
|
186
|
+
for (const match of xml.matchAll(W_REF_PATTERN)) {
|
|
187
|
+
const attributes = readAttributes(match[1] ?? "");
|
|
188
|
+
matches.push({
|
|
189
|
+
target: attributes.anchor ?? attributes.name ?? attributes.id,
|
|
190
|
+
label: attributes.displayText ?? attributes.text
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
return matches;
|
|
194
|
+
}
|
|
195
|
+
function extractComplexFieldsWithRegex(xml) {
|
|
196
|
+
const matches = [];
|
|
197
|
+
for (const match of xml.matchAll(COMPLEX_FIELD_PATTERN)) {
|
|
198
|
+
const instruction = stripXml(match[1] ?? "");
|
|
199
|
+
const label = stripXml(match[2] ?? "");
|
|
200
|
+
if (!instruction) {
|
|
201
|
+
continue;
|
|
202
|
+
}
|
|
203
|
+
matches.push({ instruction, label });
|
|
204
|
+
}
|
|
205
|
+
return matches;
|
|
206
|
+
}
|
|
207
|
+
function readAttributes(source) {
|
|
208
|
+
const attributes = {};
|
|
209
|
+
for (const match of source.matchAll(ATTRIBUTE_PATTERN)) {
|
|
210
|
+
const [, key, value] = match;
|
|
211
|
+
attributes[key] = value;
|
|
212
|
+
}
|
|
213
|
+
return attributes;
|
|
214
|
+
}
|
|
215
|
+
function stripXml(xml) {
|
|
216
|
+
return xml.replace(/<[^>]+>/g, "").replace(/\s+/g, " ").trim();
|
|
217
|
+
}
|
|
218
|
+
function flattenParagraphText(paragraph) {
|
|
219
|
+
return paragraph.children.map((child) => {
|
|
220
|
+
switch (child.type) {
|
|
221
|
+
case "text":
|
|
222
|
+
return child.text;
|
|
223
|
+
case "hyperlink":
|
|
224
|
+
return flattenInlineText(child.children);
|
|
225
|
+
case "field":
|
|
226
|
+
return child.children ? flattenInlineText(child.children) : "";
|
|
227
|
+
case "tab":
|
|
228
|
+
return " ";
|
|
229
|
+
case "hard_break":
|
|
230
|
+
case "column_break":
|
|
231
|
+
return "\n";
|
|
232
|
+
default:
|
|
233
|
+
return "";
|
|
234
|
+
}
|
|
235
|
+
}).join("");
|
|
236
|
+
}
|
|
237
|
+
function flattenInlineText(children) {
|
|
238
|
+
return children.map((child) => {
|
|
239
|
+
if (child.type === "text") {
|
|
240
|
+
return child.text;
|
|
241
|
+
}
|
|
242
|
+
if (child.type === "tab") {
|
|
243
|
+
return " ";
|
|
244
|
+
}
|
|
245
|
+
if (child.type === "hard_break" || child.type === "column_break") {
|
|
246
|
+
return "\n";
|
|
247
|
+
}
|
|
248
|
+
return "";
|
|
249
|
+
}).join("");
|
|
250
|
+
}
|
|
251
|
+
function dedupeCrossReferences(references) {
|
|
252
|
+
const seen = /* @__PURE__ */ new Set();
|
|
253
|
+
const deduped = [];
|
|
254
|
+
for (const reference of references) {
|
|
255
|
+
const key = [
|
|
256
|
+
reference.source,
|
|
257
|
+
reference.kind,
|
|
258
|
+
reference.target ?? "",
|
|
259
|
+
reference.label,
|
|
260
|
+
String(reference.paragraphIndex ?? -1)
|
|
261
|
+
].join("|");
|
|
262
|
+
if (seen.has(key)) {
|
|
263
|
+
continue;
|
|
264
|
+
}
|
|
265
|
+
seen.add(key);
|
|
266
|
+
deduped.push(reference);
|
|
267
|
+
}
|
|
268
|
+
return deduped;
|
|
269
|
+
}
|
|
270
|
+
function walkDocument(node, visit) {
|
|
271
|
+
visit(node);
|
|
272
|
+
if ("children" in node && Array.isArray(node.children)) {
|
|
273
|
+
for (const child of node.children) {
|
|
274
|
+
walkDocument(child, visit);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
if (node.type === "table") {
|
|
278
|
+
for (const row of node.rows) {
|
|
279
|
+
walkDocument(row, visit);
|
|
280
|
+
}
|
|
281
|
+
} else if (node.type === "table_row") {
|
|
282
|
+
for (const cell of node.cells) {
|
|
283
|
+
walkDocument(cell, visit);
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
// src/legal/defined-terms.ts
|
|
289
|
+
var QUOTED_DEFINITION_PATTERN = /["“]([A-Z][A-Za-z0-9]*(?:[ -][A-Z][A-Za-z0-9]*){0,5})["”]\s+(?:means|has the meaning(?: set forth)?|shall mean|refers to)\b/g;
|
|
290
|
+
var BARE_DEFINITION_PATTERN = /\b([A-Z][A-Za-z0-9]*(?:\s+[A-Z][A-Za-z0-9]*){0,5})\s+(?:means|has the meaning(?: set forth)?|shall mean|refers to)\b/g;
|
|
291
|
+
var BLOCKED_BARE_TERMS = /* @__PURE__ */ new Set([
|
|
292
|
+
"This Agreement",
|
|
293
|
+
"Such Term",
|
|
294
|
+
"The Company",
|
|
295
|
+
"This Section",
|
|
296
|
+
"This Clause"
|
|
297
|
+
]);
|
|
298
|
+
function collectDefinedTermsFromDocumentXml(xml) {
|
|
299
|
+
const parsed = parseMainDocumentXml(xml);
|
|
300
|
+
const paragraphs = parsed.blocks.filter((block) => block.type === "paragraph").map((block) => flattenParagraphText2(block));
|
|
301
|
+
return buildDefinedTermCatalog(paragraphs);
|
|
302
|
+
}
|
|
303
|
+
function collectDefinedTermsFromCanonicalDocument(document) {
|
|
304
|
+
const root = "content" in document ? document.content : document;
|
|
305
|
+
const paragraphs = [];
|
|
306
|
+
walkDocument2(root, (node) => {
|
|
307
|
+
if (node.type === "paragraph") {
|
|
308
|
+
paragraphs.push(flattenParagraphText2(node));
|
|
309
|
+
}
|
|
310
|
+
});
|
|
311
|
+
return buildDefinedTermCatalog(paragraphs);
|
|
312
|
+
}
|
|
313
|
+
function buildDefinedTermCatalog(paragraphs) {
|
|
314
|
+
const terms = /* @__PURE__ */ new Map();
|
|
315
|
+
paragraphs.forEach((paragraph, paragraphIndex) => {
|
|
316
|
+
for (const candidate of extractDefinitionCandidates(paragraph)) {
|
|
317
|
+
const normalized = normalizeTerm(candidate.term);
|
|
318
|
+
const existing = terms.get(normalized) ?? {
|
|
319
|
+
term: candidate.term,
|
|
320
|
+
normalizedTerm: normalized,
|
|
321
|
+
definitionStyle: candidate.definitionStyle,
|
|
322
|
+
definitions: [],
|
|
323
|
+
references: []
|
|
324
|
+
};
|
|
325
|
+
if (!terms.has(normalized)) {
|
|
326
|
+
terms.set(normalized, existing);
|
|
327
|
+
}
|
|
328
|
+
existing.definitions.push({
|
|
329
|
+
paragraphIndex,
|
|
330
|
+
label: candidate.term,
|
|
331
|
+
kind: "definition"
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
});
|
|
335
|
+
paragraphs.forEach((paragraph, paragraphIndex) => {
|
|
336
|
+
for (const term of terms.values()) {
|
|
337
|
+
const references = findTermReferences(paragraph, term.term);
|
|
338
|
+
if (references === 0) {
|
|
339
|
+
continue;
|
|
340
|
+
}
|
|
341
|
+
const hasDefinitionInParagraph = term.definitions.some(
|
|
342
|
+
(definition) => definition.paragraphIndex === paragraphIndex
|
|
343
|
+
);
|
|
344
|
+
const referenceCount = hasDefinitionInParagraph ? 0 : references;
|
|
345
|
+
for (let count = 0; count < referenceCount; count += 1) {
|
|
346
|
+
term.references.push({
|
|
347
|
+
paragraphIndex,
|
|
348
|
+
label: term.term,
|
|
349
|
+
kind: "reference"
|
|
350
|
+
});
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
});
|
|
354
|
+
return Array.from(terms.values()).sort((left, right) => left.term.localeCompare(right.term));
|
|
355
|
+
}
|
|
356
|
+
function extractDefinitionCandidates(paragraph) {
|
|
357
|
+
const candidates = [];
|
|
358
|
+
for (const match of paragraph.matchAll(QUOTED_DEFINITION_PATTERN)) {
|
|
359
|
+
const term = match[1]?.trim();
|
|
360
|
+
if (!term) {
|
|
361
|
+
continue;
|
|
362
|
+
}
|
|
363
|
+
candidates.push({
|
|
364
|
+
term,
|
|
365
|
+
definitionStyle: "quoted"
|
|
366
|
+
});
|
|
367
|
+
}
|
|
368
|
+
for (const match of paragraph.matchAll(BARE_DEFINITION_PATTERN)) {
|
|
369
|
+
const term = match[1]?.trim();
|
|
370
|
+
if (!term || BLOCKED_BARE_TERMS.has(term) || isQuotedTerm(term, paragraph)) {
|
|
371
|
+
continue;
|
|
372
|
+
}
|
|
373
|
+
candidates.push({
|
|
374
|
+
term,
|
|
375
|
+
definitionStyle: "bare"
|
|
376
|
+
});
|
|
377
|
+
}
|
|
378
|
+
return candidates;
|
|
379
|
+
}
|
|
380
|
+
function normalizeTerm(term) {
|
|
381
|
+
return term.trim().replace(/\s+/g, " ").toLowerCase();
|
|
382
|
+
}
|
|
383
|
+
function isQuotedTerm(term, paragraph) {
|
|
384
|
+
return paragraph.includes(`"${term}"`) || paragraph.includes(`\u201C${term}\u201D`);
|
|
385
|
+
}
|
|
386
|
+
function findTermReferences(paragraph, term) {
|
|
387
|
+
const escapedTerm = escapeRegExp(term);
|
|
388
|
+
const pattern = new RegExp(`(?:^|[^A-Za-z0-9])(?:"|\u201C)?(${escapedTerm})(?:"|\u201D)?(?=[^A-Za-z0-9]|$)`, "g");
|
|
389
|
+
return Array.from(paragraph.matchAll(pattern)).length;
|
|
390
|
+
}
|
|
391
|
+
function escapeRegExp(value) {
|
|
392
|
+
return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
393
|
+
}
|
|
394
|
+
function flattenParagraphText2(paragraph) {
|
|
395
|
+
return paragraph.children.map((child) => {
|
|
396
|
+
switch (child.type) {
|
|
397
|
+
case "text":
|
|
398
|
+
return child.text;
|
|
399
|
+
case "hyperlink":
|
|
400
|
+
case "field":
|
|
401
|
+
return child.children.map((nested) => nested.type === "text" ? nested.text : nested.type === "tab" ? " " : "").join("");
|
|
402
|
+
case "tab":
|
|
403
|
+
return " ";
|
|
404
|
+
case "hard_break":
|
|
405
|
+
case "column_break":
|
|
406
|
+
return "\n";
|
|
407
|
+
default:
|
|
408
|
+
return "";
|
|
409
|
+
}
|
|
410
|
+
}).join("");
|
|
411
|
+
}
|
|
412
|
+
function walkDocument2(node, visit) {
|
|
413
|
+
visit(node);
|
|
414
|
+
if ("children" in node && Array.isArray(node.children)) {
|
|
415
|
+
for (const child of node.children) {
|
|
416
|
+
walkDocument2(child, visit);
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
if (node.type === "table") {
|
|
420
|
+
for (const row of node.rows) {
|
|
421
|
+
walkDocument2(row, visit);
|
|
422
|
+
}
|
|
423
|
+
} else if (node.type === "table_row") {
|
|
424
|
+
for (const cell of node.cells) {
|
|
425
|
+
walkDocument2(cell, visit);
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
// src/legal/signature-blocks.ts
|
|
431
|
+
var EXECUTION_TRIGGER_PATTERN = /\b(?:IN WITNESS WHEREOF|EXECUTED|AGREED AND ACCEPTED|SIGNATURES FOLLOW)\b/i;
|
|
432
|
+
var ROLE_LINE_PATTERN = /^\s*(?:By|Name|Title|Date|Witness|Authorized Signatory|Signature)\s*[:\-]?\s*/i;
|
|
433
|
+
var PARTY_LABEL_PATTERN = /^(?:(?:The |)[A-Z][A-Za-z0-9 ,.'&()-]{2,60})\s*$/;
|
|
434
|
+
var WITNESS_PATTERN = /\bWITNESS(?:ED|ES)?\b/i;
|
|
435
|
+
var NOTARY_PATTERN = /\bNOTARY\s+PUBLIC\b/i;
|
|
436
|
+
var UNDERLINE_PLACEHOLDER_PATTERN = /_{4,}|\.{4,}/;
|
|
437
|
+
function detectSignatureBlocksFromCanonicalDocument(document) {
|
|
438
|
+
const root = "content" in document ? document.content : document;
|
|
439
|
+
const paragraphs = [];
|
|
440
|
+
const warnings = [];
|
|
441
|
+
walkBlocks(root, (node) => {
|
|
442
|
+
if (node.type === "paragraph") {
|
|
443
|
+
paragraphs.push({ text: flattenParagraphText3(node), node });
|
|
444
|
+
}
|
|
445
|
+
});
|
|
446
|
+
const candidates = findSignatureBlockCandidates(paragraphs);
|
|
447
|
+
const hasPreservation = "preservation" in document && document.preservation !== void 0;
|
|
448
|
+
const preservationSafe = hasPreservation ? !hasOpaqueFragmentsInSignatureRanges(
|
|
449
|
+
document,
|
|
450
|
+
candidates
|
|
451
|
+
) : true;
|
|
452
|
+
if (!preservationSafe) {
|
|
453
|
+
warnings.push(
|
|
454
|
+
"One or more signature block regions overlap with preserve-only opaque fragments. Export fidelity may be degraded."
|
|
455
|
+
);
|
|
456
|
+
}
|
|
457
|
+
return {
|
|
458
|
+
reportVersion: "signature-block-report/1",
|
|
459
|
+
candidates,
|
|
460
|
+
preservationSafe,
|
|
461
|
+
warnings
|
|
462
|
+
};
|
|
463
|
+
}
|
|
464
|
+
function findSignatureBlockCandidates(paragraphs) {
|
|
465
|
+
const candidates = [];
|
|
466
|
+
let index = 0;
|
|
467
|
+
while (index < paragraphs.length) {
|
|
468
|
+
const text = paragraphs[index].text;
|
|
469
|
+
if (EXECUTION_TRIGGER_PATTERN.test(text)) {
|
|
470
|
+
const block = scanSignatureBlock(paragraphs, index);
|
|
471
|
+
if (block) {
|
|
472
|
+
candidates.push(block);
|
|
473
|
+
index = block.endIndex + 1;
|
|
474
|
+
continue;
|
|
475
|
+
}
|
|
476
|
+
}
|
|
477
|
+
index += 1;
|
|
478
|
+
}
|
|
479
|
+
return candidates;
|
|
480
|
+
}
|
|
481
|
+
function scanSignatureBlock(paragraphs, triggerIndex) {
|
|
482
|
+
const parties = [];
|
|
483
|
+
let endIndex = triggerIndex;
|
|
484
|
+
let kind = "execution-block";
|
|
485
|
+
let hasSignatureContent = false;
|
|
486
|
+
for (let index = triggerIndex + 1; index < paragraphs.length && index <= triggerIndex + 40; index += 1) {
|
|
487
|
+
const text = paragraphs[index].text.trim();
|
|
488
|
+
if (text.length === 0) {
|
|
489
|
+
endIndex = index;
|
|
490
|
+
continue;
|
|
491
|
+
}
|
|
492
|
+
if (WITNESS_PATTERN.test(text)) {
|
|
493
|
+
kind = "witness-block";
|
|
494
|
+
}
|
|
495
|
+
if (NOTARY_PATTERN.test(text)) {
|
|
496
|
+
kind = "notary-block";
|
|
497
|
+
}
|
|
498
|
+
if (ROLE_LINE_PATTERN.test(text)) {
|
|
499
|
+
hasSignatureContent = true;
|
|
500
|
+
endIndex = index;
|
|
501
|
+
continue;
|
|
502
|
+
}
|
|
503
|
+
if (UNDERLINE_PLACEHOLDER_PATTERN.test(text)) {
|
|
504
|
+
hasSignatureContent = true;
|
|
505
|
+
endIndex = index;
|
|
506
|
+
continue;
|
|
507
|
+
}
|
|
508
|
+
if (PARTY_LABEL_PATTERN.test(text) && !isBodyParagraph(text)) {
|
|
509
|
+
parties.push({
|
|
510
|
+
roleLabel: text.trim(),
|
|
511
|
+
paragraphIndex: index
|
|
512
|
+
});
|
|
513
|
+
hasSignatureContent = true;
|
|
514
|
+
endIndex = index;
|
|
515
|
+
continue;
|
|
516
|
+
}
|
|
517
|
+
if (hasSignatureContent && isBodyParagraph(text)) {
|
|
518
|
+
break;
|
|
519
|
+
}
|
|
520
|
+
endIndex = index;
|
|
521
|
+
}
|
|
522
|
+
if (!hasSignatureContent) {
|
|
523
|
+
return void 0;
|
|
524
|
+
}
|
|
525
|
+
return {
|
|
526
|
+
startIndex: triggerIndex,
|
|
527
|
+
endIndex,
|
|
528
|
+
kind,
|
|
529
|
+
parties,
|
|
530
|
+
confidence: parties.length > 0 ? "high" : "medium"
|
|
531
|
+
};
|
|
532
|
+
}
|
|
533
|
+
function isBodyParagraph(text) {
|
|
534
|
+
return text.length > 120 && /[.;]/.test(text);
|
|
535
|
+
}
|
|
536
|
+
function hasOpaqueFragmentsInSignatureRanges(document, candidates) {
|
|
537
|
+
if (candidates.length === 0) {
|
|
538
|
+
return false;
|
|
539
|
+
}
|
|
540
|
+
const opaqueCount = Object.keys(document.preservation.opaqueFragments).length;
|
|
541
|
+
if (opaqueCount === 0) {
|
|
542
|
+
return false;
|
|
543
|
+
}
|
|
544
|
+
let paragraphIndex = 0;
|
|
545
|
+
const opaqueIndices = /* @__PURE__ */ new Set();
|
|
546
|
+
for (const block of document.content.children) {
|
|
547
|
+
if (block.type === "paragraph") {
|
|
548
|
+
paragraphIndex += 1;
|
|
549
|
+
continue;
|
|
550
|
+
}
|
|
551
|
+
if (block.type === "opaque_block") {
|
|
552
|
+
opaqueIndices.add(paragraphIndex);
|
|
553
|
+
}
|
|
554
|
+
paragraphIndex += 1;
|
|
555
|
+
}
|
|
556
|
+
return candidates.some((candidate) => {
|
|
557
|
+
for (let index = candidate.startIndex; index <= candidate.endIndex; index += 1) {
|
|
558
|
+
if (opaqueIndices.has(index)) {
|
|
559
|
+
return true;
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
return false;
|
|
563
|
+
});
|
|
564
|
+
}
|
|
565
|
+
function flattenParagraphText3(paragraph) {
|
|
566
|
+
return paragraph.children.map((child) => {
|
|
567
|
+
switch (child.type) {
|
|
568
|
+
case "text":
|
|
569
|
+
return child.text;
|
|
570
|
+
case "hyperlink":
|
|
571
|
+
case "field":
|
|
572
|
+
return child.children.map(
|
|
573
|
+
(nested) => nested.type === "text" ? nested.text : nested.type === "tab" ? " " : ""
|
|
574
|
+
).join("");
|
|
575
|
+
case "tab":
|
|
576
|
+
return " ";
|
|
577
|
+
case "hard_break":
|
|
578
|
+
case "column_break":
|
|
579
|
+
return "\n";
|
|
580
|
+
default:
|
|
581
|
+
return "";
|
|
582
|
+
}
|
|
583
|
+
}).join("");
|
|
584
|
+
}
|
|
585
|
+
function walkBlocks(node, visit) {
|
|
586
|
+
visit(node);
|
|
587
|
+
if ("children" in node && Array.isArray(node.children)) {
|
|
588
|
+
for (const child of node.children) {
|
|
589
|
+
walkBlocks(child, visit);
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
if (node.type === "table") {
|
|
593
|
+
for (const row of node.rows) {
|
|
594
|
+
walkBlocks(row, visit);
|
|
595
|
+
}
|
|
596
|
+
} else if (node.type === "table_row") {
|
|
597
|
+
for (const cell of node.cells) {
|
|
598
|
+
walkBlocks(cell, visit);
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
}
|
|
602
|
+
export {
|
|
603
|
+
assessBookmarkIntegrity,
|
|
604
|
+
buildDefinedTermCatalog,
|
|
605
|
+
collectBookmarksFromCanonicalDocument,
|
|
606
|
+
collectCrossReferencesFromCanonicalDocument,
|
|
607
|
+
collectDefinedTermsFromCanonicalDocument,
|
|
608
|
+
collectDefinedTermsFromDocumentXml,
|
|
609
|
+
detectCrossReferencePatterns,
|
|
610
|
+
detectSignatureBlocksFromCanonicalDocument,
|
|
611
|
+
isHiddenBookmarkName,
|
|
612
|
+
parseBookmarksFromDocumentXml,
|
|
613
|
+
parseCrossReferencesFromDocumentXml,
|
|
614
|
+
parseFieldReferenceInstruction
|
|
615
|
+
};
|
|
616
|
+
//# sourceMappingURL=index.js.map
|