docxmlater 10.4.0 → 11.0.4
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 +3 -3
- package/dist/constants/legacyCompatFlags.d.ts +1 -1
- package/dist/constants/legacyCompatFlags.d.ts.map +1 -1
- package/dist/constants/legacyCompatFlags.js.map +1 -1
- package/dist/core/Document.d.ts +75 -67
- package/dist/core/Document.d.ts.map +1 -1
- package/dist/core/Document.js +618 -414
- package/dist/core/Document.js.map +1 -1
- package/dist/core/DocumentContent.d.ts +11 -10
- package/dist/core/DocumentContent.d.ts.map +1 -1
- package/dist/core/DocumentContent.js +19 -19
- package/dist/core/DocumentContent.js.map +1 -1
- package/dist/core/DocumentEvents.d.ts +39 -0
- package/dist/core/DocumentEvents.d.ts.map +1 -0
- package/dist/core/DocumentEvents.js +51 -0
- package/dist/core/DocumentEvents.js.map +1 -0
- package/dist/core/DocumentGenerator.d.ts +11 -11
- package/dist/core/DocumentGenerator.d.ts.map +1 -1
- package/dist/core/DocumentGenerator.js +72 -52
- package/dist/core/DocumentGenerator.js.map +1 -1
- package/dist/core/DocumentParser.d.ts +15 -15
- package/dist/core/DocumentParser.d.ts.map +1 -1
- package/dist/core/DocumentParser.js +2100 -1076
- package/dist/core/DocumentParser.js.map +1 -1
- package/dist/core/DocumentValidator.d.ts +3 -3
- package/dist/core/DocumentValidator.d.ts.map +1 -1
- package/dist/core/DocumentValidator.js +31 -31
- package/dist/core/DocumentValidator.js.map +1 -1
- package/dist/core/ElementRegistry.d.ts +22 -0
- package/dist/core/ElementRegistry.d.ts.map +1 -0
- package/dist/core/ElementRegistry.js +27 -0
- package/dist/core/ElementRegistry.js.map +1 -0
- package/dist/core/Relationship.js +4 -4
- package/dist/core/Relationship.js.map +1 -1
- package/dist/core/RelationshipManager.d.ts +1 -1
- package/dist/core/RelationshipManager.d.ts.map +1 -1
- package/dist/core/RelationshipManager.js +32 -32
- package/dist/core/RelationshipManager.js.map +1 -1
- package/dist/elements/AlternateContent.d.ts +1 -1
- package/dist/elements/AlternateContent.d.ts.map +1 -1
- package/dist/elements/AlternateContent.js.map +1 -1
- package/dist/elements/Bookmark.d.ts +6 -1
- package/dist/elements/Bookmark.d.ts.map +1 -1
- package/dist/elements/Bookmark.js +19 -3
- package/dist/elements/Bookmark.js.map +1 -1
- package/dist/elements/BookmarkManager.d.ts +1 -1
- package/dist/elements/BookmarkManager.d.ts.map +1 -1
- package/dist/elements/BookmarkManager.js +7 -7
- package/dist/elements/BookmarkManager.js.map +1 -1
- package/dist/elements/Comment.d.ts +2 -2
- package/dist/elements/Comment.d.ts.map +1 -1
- package/dist/elements/Comment.js +4 -4
- package/dist/elements/Comment.js.map +1 -1
- package/dist/elements/CommentManager.d.ts +2 -2
- package/dist/elements/CommentManager.d.ts.map +1 -1
- package/dist/elements/CommentManager.js +9 -9
- package/dist/elements/CommentManager.js.map +1 -1
- package/dist/elements/CommonTypes.d.ts +9 -4
- package/dist/elements/CommonTypes.d.ts.map +1 -1
- package/dist/elements/CommonTypes.js +1 -0
- package/dist/elements/CommonTypes.js.map +1 -1
- package/dist/elements/CustomXml.d.ts +1 -1
- package/dist/elements/CustomXml.d.ts.map +1 -1
- package/dist/elements/CustomXml.js.map +1 -1
- package/dist/elements/Endnote.d.ts +2 -2
- package/dist/elements/Endnote.d.ts.map +1 -1
- package/dist/elements/Endnote.js +9 -9
- package/dist/elements/Endnote.js.map +1 -1
- package/dist/elements/EndnoteManager.d.ts +1 -1
- package/dist/elements/EndnoteManager.d.ts.map +1 -1
- package/dist/elements/EndnoteManager.js +11 -11
- package/dist/elements/EndnoteManager.js.map +1 -1
- package/dist/elements/Field.d.ts +9 -5
- package/dist/elements/Field.d.ts.map +1 -1
- package/dist/elements/Field.js +21 -9
- package/dist/elements/Field.js.map +1 -1
- package/dist/elements/FieldHelpers.d.ts +1 -1
- package/dist/elements/FieldHelpers.d.ts.map +1 -1
- package/dist/elements/FieldHelpers.js +10 -10
- package/dist/elements/FieldHelpers.js.map +1 -1
- package/dist/elements/Footer.d.ts +3 -3
- package/dist/elements/Footer.d.ts.map +1 -1
- package/dist/elements/Footer.js +5 -5
- package/dist/elements/Footer.js.map +1 -1
- package/dist/elements/Footnote.d.ts +2 -2
- package/dist/elements/Footnote.d.ts.map +1 -1
- package/dist/elements/Footnote.js +9 -9
- package/dist/elements/Footnote.js.map +1 -1
- package/dist/elements/FootnoteManager.d.ts +1 -1
- package/dist/elements/FootnoteManager.d.ts.map +1 -1
- package/dist/elements/FootnoteManager.js +11 -11
- package/dist/elements/FootnoteManager.js.map +1 -1
- package/dist/elements/Header.d.ts +3 -3
- package/dist/elements/Header.d.ts.map +1 -1
- package/dist/elements/Header.js +5 -5
- package/dist/elements/Header.js.map +1 -1
- package/dist/elements/HeaderFooterManager.d.ts +2 -2
- package/dist/elements/HeaderFooterManager.d.ts.map +1 -1
- package/dist/elements/HeaderFooterManager.js.map +1 -1
- package/dist/elements/Hyperlink.d.ts +5 -5
- package/dist/elements/Hyperlink.d.ts.map +1 -1
- package/dist/elements/Hyperlink.js +29 -29
- package/dist/elements/Hyperlink.js.map +1 -1
- package/dist/elements/Image.d.ts +1 -1
- package/dist/elements/Image.d.ts.map +1 -1
- package/dist/elements/Image.js +67 -67
- package/dist/elements/Image.js.map +1 -1
- package/dist/elements/ImageManager.d.ts +1 -1
- package/dist/elements/ImageManager.d.ts.map +1 -1
- package/dist/elements/ImageManager.js +4 -4
- package/dist/elements/ImageManager.js.map +1 -1
- package/dist/elements/ImageRun.d.ts +3 -3
- package/dist/elements/ImageRun.d.ts.map +1 -1
- package/dist/elements/ImageRun.js +2 -2
- package/dist/elements/ImageRun.js.map +1 -1
- package/dist/elements/MathElement.d.ts +1 -1
- package/dist/elements/MathElement.d.ts.map +1 -1
- package/dist/elements/MathElement.js.map +1 -1
- package/dist/elements/Paragraph.d.ts +34 -19
- package/dist/elements/Paragraph.d.ts.map +1 -1
- package/dist/elements/Paragraph.js +286 -231
- package/dist/elements/Paragraph.js.map +1 -1
- package/dist/elements/PreservedElement.d.ts +1 -1
- package/dist/elements/PreservedElement.d.ts.map +1 -1
- package/dist/elements/PreservedElement.js.map +1 -1
- package/dist/elements/PropertyChangeTypes.d.ts +2 -2
- package/dist/elements/PropertyChangeTypes.d.ts.map +1 -1
- package/dist/elements/PropertyChangeTypes.js.map +1 -1
- package/dist/elements/RangeMarker.d.ts +14 -1
- package/dist/elements/RangeMarker.d.ts.map +1 -1
- package/dist/elements/RangeMarker.js +46 -8
- package/dist/elements/RangeMarker.js.map +1 -1
- package/dist/elements/RegisteredBodyElement.d.ts +15 -0
- package/dist/elements/RegisteredBodyElement.d.ts.map +1 -0
- package/dist/elements/RegisteredBodyElement.js +44 -0
- package/dist/elements/RegisteredBodyElement.js.map +1 -0
- package/dist/elements/Revision.d.ts +8 -8
- package/dist/elements/Revision.d.ts.map +1 -1
- package/dist/elements/Revision.js +12 -12
- package/dist/elements/Revision.js.map +1 -1
- package/dist/elements/RevisionContent.d.ts +3 -3
- package/dist/elements/RevisionContent.d.ts.map +1 -1
- package/dist/elements/RevisionContent.js.map +1 -1
- package/dist/elements/RevisionManager.d.ts +2 -2
- package/dist/elements/RevisionManager.d.ts.map +1 -1
- package/dist/elements/RevisionManager.js +2 -2
- package/dist/elements/RevisionManager.js.map +1 -1
- package/dist/elements/Run.d.ts +16 -10
- package/dist/elements/Run.d.ts.map +1 -1
- package/dist/elements/Run.js +199 -173
- package/dist/elements/Run.js.map +1 -1
- package/dist/elements/Section.d.ts +4 -2
- package/dist/elements/Section.d.ts.map +1 -1
- package/dist/elements/Section.js +152 -145
- package/dist/elements/Section.js.map +1 -1
- package/dist/elements/Shape.d.ts +3 -3
- package/dist/elements/Shape.d.ts.map +1 -1
- package/dist/elements/Shape.js +12 -12
- package/dist/elements/Shape.js.map +1 -1
- package/dist/elements/StructuredDocumentTag.d.ts +3 -3
- package/dist/elements/StructuredDocumentTag.d.ts.map +1 -1
- package/dist/elements/StructuredDocumentTag.js +39 -39
- package/dist/elements/StructuredDocumentTag.js.map +1 -1
- package/dist/elements/Table.d.ts +16 -10
- package/dist/elements/Table.d.ts.map +1 -1
- package/dist/elements/Table.js +118 -89
- package/dist/elements/Table.js.map +1 -1
- package/dist/elements/TableCell.d.ts +11 -11
- package/dist/elements/TableCell.d.ts.map +1 -1
- package/dist/elements/TableCell.js +108 -78
- package/dist/elements/TableCell.js.map +1 -1
- package/dist/elements/TableGridChange.d.ts +1 -1
- package/dist/elements/TableGridChange.d.ts.map +1 -1
- package/dist/elements/TableGridChange.js +3 -3
- package/dist/elements/TableGridChange.js.map +1 -1
- package/dist/elements/TableOfContents.d.ts +1 -1
- package/dist/elements/TableOfContents.d.ts.map +1 -1
- package/dist/elements/TableOfContents.js +2 -2
- package/dist/elements/TableOfContents.js.map +1 -1
- package/dist/elements/TableOfContentsElement.d.ts +2 -2
- package/dist/elements/TableOfContentsElement.d.ts.map +1 -1
- package/dist/elements/TableOfContentsElement.js +5 -5
- package/dist/elements/TableOfContentsElement.js.map +1 -1
- package/dist/elements/TableRow.d.ts +18 -7
- package/dist/elements/TableRow.d.ts.map +1 -1
- package/dist/elements/TableRow.js +127 -74
- package/dist/elements/TableRow.js.map +1 -1
- package/dist/elements/TextBox.d.ts +4 -4
- package/dist/elements/TextBox.d.ts.map +1 -1
- package/dist/elements/TextBox.js +6 -6
- package/dist/elements/TextBox.js.map +1 -1
- package/dist/esm/constants/legacyCompatFlags.js +97 -0
- package/dist/esm/constants/legacyCompatFlags.js.map +1 -0
- package/dist/esm/constants/limits.js +36 -0
- package/dist/esm/constants/limits.js.map +1 -0
- package/dist/esm/core/Document.js +8498 -0
- package/dist/esm/core/Document.js.map +1 -0
- package/dist/esm/core/DocumentContent.js +190 -0
- package/dist/esm/core/DocumentContent.js.map +1 -0
- package/dist/esm/core/DocumentEvents.js +47 -0
- package/dist/esm/core/DocumentEvents.js.map +1 -0
- package/dist/esm/core/DocumentGenerator.js +764 -0
- package/dist/esm/core/DocumentGenerator.js.map +1 -0
- package/dist/esm/core/DocumentIdManager.js +67 -0
- package/dist/esm/core/DocumentIdManager.js.map +1 -0
- package/dist/esm/core/DocumentParser.js +8760 -0
- package/dist/esm/core/DocumentParser.js.map +1 -0
- package/dist/esm/core/DocumentValidator.js +222 -0
- package/dist/esm/core/DocumentValidator.js.map +1 -0
- package/dist/esm/core/ElementRegistry.js +24 -0
- package/dist/esm/core/ElementRegistry.js.map +1 -0
- package/dist/esm/core/Relationship.js +177 -0
- package/dist/esm/core/Relationship.js.map +1 -0
- package/dist/esm/core/RelationshipManager.js +202 -0
- package/dist/esm/core/RelationshipManager.js.map +1 -0
- package/dist/esm/elements/AlternateContent.js +19 -0
- package/dist/esm/elements/AlternateContent.js.map +1 -0
- package/dist/esm/elements/Bookmark.js +115 -0
- package/dist/esm/elements/Bookmark.js.map +1 -0
- package/dist/esm/elements/BookmarkManager.js +99 -0
- package/dist/esm/elements/BookmarkManager.js.map +1 -0
- package/dist/esm/elements/Comment.js +181 -0
- package/dist/esm/elements/Comment.js.map +1 -0
- package/dist/esm/elements/CommentManager.js +233 -0
- package/dist/esm/elements/CommentManager.js.map +1 -0
- package/dist/esm/elements/CommonTypes.js +106 -0
- package/dist/esm/elements/CommonTypes.js.map +1 -0
- package/dist/esm/elements/CustomXml.js +19 -0
- package/dist/esm/elements/CustomXml.js.map +1 -0
- package/dist/esm/elements/Endnote.js +107 -0
- package/dist/esm/elements/Endnote.js.map +1 -0
- package/dist/esm/elements/EndnoteManager.js +119 -0
- package/dist/esm/elements/EndnoteManager.js.map +1 -0
- package/dist/esm/elements/Field.js +856 -0
- package/dist/esm/elements/Field.js.map +1 -0
- package/dist/esm/elements/FieldHelpers.js +134 -0
- package/dist/esm/elements/FieldHelpers.js.map +1 -0
- package/dist/esm/elements/FontManager.js +158 -0
- package/dist/esm/elements/FontManager.js.map +1 -0
- package/dist/esm/elements/Footer.js +141 -0
- package/dist/esm/elements/Footer.js.map +1 -0
- package/dist/esm/elements/Footnote.js +107 -0
- package/dist/esm/elements/Footnote.js.map +1 -0
- package/dist/esm/elements/FootnoteManager.js +119 -0
- package/dist/esm/elements/FootnoteManager.js.map +1 -0
- package/dist/esm/elements/Header.js +141 -0
- package/dist/esm/elements/Header.js.map +1 -0
- package/dist/esm/elements/HeaderFooterManager.js +87 -0
- package/dist/esm/elements/HeaderFooterManager.js.map +1 -0
- package/dist/esm/elements/Hyperlink.js +586 -0
- package/dist/esm/elements/Hyperlink.js.map +1 -0
- package/dist/esm/elements/Image.js +1288 -0
- package/dist/esm/elements/Image.js.map +1 -0
- package/dist/esm/elements/ImageManager.js +223 -0
- package/dist/esm/elements/ImageManager.js.map +1 -0
- package/dist/esm/elements/ImageRun.js +29 -0
- package/dist/esm/elements/ImageRun.js.map +1 -0
- package/dist/esm/elements/MathElement.js +37 -0
- package/dist/esm/elements/MathElement.js.map +1 -0
- package/dist/esm/elements/Paragraph.js +2308 -0
- package/dist/esm/elements/Paragraph.js.map +1 -0
- package/dist/esm/elements/PreservedElement.js +29 -0
- package/dist/esm/elements/PreservedElement.js.map +1 -0
- package/dist/esm/elements/PropertyChangeTypes.js +53 -0
- package/dist/esm/elements/PropertyChangeTypes.js.map +1 -0
- package/dist/esm/elements/RangeMarker.js +219 -0
- package/dist/esm/elements/RangeMarker.js.map +1 -0
- package/dist/esm/elements/RegisteredBodyElement.js +40 -0
- package/dist/esm/elements/RegisteredBodyElement.js.map +1 -0
- package/dist/esm/elements/Revision.js +498 -0
- package/dist/esm/elements/Revision.js.map +1 -0
- package/dist/esm/elements/RevisionContent.js +18 -0
- package/dist/esm/elements/RevisionContent.js.map +1 -0
- package/dist/esm/elements/RevisionManager.js +486 -0
- package/dist/esm/elements/RevisionManager.js.map +1 -0
- package/dist/esm/elements/Run.js +1465 -0
- package/dist/esm/elements/Run.js.map +1 -0
- package/dist/esm/elements/Section.js +978 -0
- package/dist/esm/elements/Section.js.map +1 -0
- package/dist/esm/elements/Shape.js +493 -0
- package/dist/esm/elements/Shape.js.map +1 -0
- package/dist/esm/elements/StructuredDocumentTag.js +471 -0
- package/dist/esm/elements/StructuredDocumentTag.js.map +1 -0
- package/dist/esm/elements/Table.js +1456 -0
- package/dist/esm/elements/Table.js.map +1 -0
- package/dist/esm/elements/TableCell.js +835 -0
- package/dist/esm/elements/TableCell.js.map +1 -0
- package/dist/esm/elements/TableGridChange.js +52 -0
- package/dist/esm/elements/TableGridChange.js.map +1 -0
- package/dist/esm/elements/TableOfContents.js +389 -0
- package/dist/esm/elements/TableOfContents.js.map +1 -0
- package/dist/esm/elements/TableOfContentsElement.js +29 -0
- package/dist/esm/elements/TableOfContentsElement.js.map +1 -0
- package/dist/esm/elements/TableRow.js +555 -0
- package/dist/esm/elements/TableRow.js.map +1 -0
- package/dist/esm/elements/TextBox.js +459 -0
- package/dist/esm/elements/TextBox.js.map +1 -0
- package/dist/esm/formatting/AbstractNumbering.js +325 -0
- package/dist/esm/formatting/AbstractNumbering.js.map +1 -0
- package/dist/esm/formatting/NumberingInstance.js +150 -0
- package/dist/esm/formatting/NumberingInstance.js.map +1 -0
- package/dist/esm/formatting/NumberingLevel.js +608 -0
- package/dist/esm/formatting/NumberingLevel.js.map +1 -0
- package/dist/esm/formatting/NumberingManager.js +423 -0
- package/dist/esm/formatting/NumberingManager.js.map +1 -0
- package/dist/esm/formatting/Style.js +1151 -0
- package/dist/esm/formatting/Style.js.map +1 -0
- package/dist/esm/formatting/StylesManager.js +557 -0
- package/dist/esm/formatting/StylesManager.js.map +1 -0
- package/dist/esm/helpers/CleanupHelper.js +350 -0
- package/dist/esm/helpers/CleanupHelper.js.map +1 -0
- package/dist/esm/images/ImageOptimizer.js +161 -0
- package/dist/esm/images/ImageOptimizer.js.map +1 -0
- package/dist/esm/index.js +75 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/internal.js +16 -0
- package/dist/esm/internal.js.map +1 -0
- package/dist/esm/managers/DrawingManager.js +163 -0
- package/dist/esm/managers/DrawingManager.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/processors/ChangelogGenerator.js +970 -0
- package/dist/esm/processors/ChangelogGenerator.js.map +1 -0
- package/dist/esm/processors/CompatibilityUpgrader.js +130 -0
- package/dist/esm/processors/CompatibilityUpgrader.js.map +1 -0
- package/dist/esm/processors/InMemoryRevisionAcceptor.js +530 -0
- package/dist/esm/processors/InMemoryRevisionAcceptor.js.map +1 -0
- package/dist/esm/processors/MoveOperationHelper.js +57 -0
- package/dist/esm/processors/MoveOperationHelper.js.map +1 -0
- package/dist/esm/processors/RevisionAwareProcessor.js +232 -0
- package/dist/esm/processors/RevisionAwareProcessor.js.map +1 -0
- package/dist/esm/processors/RevisionWalker.js +278 -0
- package/dist/esm/processors/RevisionWalker.js.map +1 -0
- package/dist/{utils → esm/processors}/SelectiveRevisionAcceptor.js +81 -42
- package/dist/esm/processors/SelectiveRevisionAcceptor.js.map +1 -0
- package/dist/esm/processors/ShadingResolver.js +66 -0
- package/dist/esm/processors/ShadingResolver.js.map +1 -0
- package/dist/esm/processors/acceptRevisions.js +416 -0
- package/dist/esm/processors/acceptRevisions.js.map +1 -0
- package/dist/esm/processors/cnfStyleDecoder.js +89 -0
- package/dist/esm/processors/cnfStyleDecoder.js.map +1 -0
- package/dist/esm/processors/stripTrackedChanges.js +201 -0
- package/dist/esm/processors/stripTrackedChanges.js.map +1 -0
- package/dist/esm/tracking/DocumentTrackingContext.js +531 -0
- package/dist/esm/tracking/DocumentTrackingContext.js.map +1 -0
- package/dist/esm/tracking/TrackingContext.js +2 -0
- package/dist/esm/tracking/TrackingContext.js.map +1 -0
- package/dist/esm/types/compatibility-types.js +8 -0
- package/dist/esm/types/compatibility-types.js.map +1 -0
- package/dist/esm/types/document-types.js +2 -0
- package/dist/esm/types/document-types.js.map +1 -0
- package/dist/esm/types/formatting.js +2 -0
- package/dist/esm/types/formatting.js.map +1 -0
- package/dist/esm/types/list-types.js +2 -0
- package/dist/esm/types/list-types.js.map +1 -0
- package/dist/esm/types/settings-types.js +2 -0
- package/dist/esm/types/settings-types.js.map +1 -0
- package/dist/esm/types/styleConfig.js +2 -0
- package/dist/esm/types/styleConfig.js.map +1 -0
- package/dist/esm/utils/KeyedRegistry.js +32 -0
- package/dist/esm/utils/KeyedRegistry.js.map +1 -0
- package/dist/esm/utils/corruptionDetection.js +155 -0
- package/dist/esm/utils/corruptionDetection.js.map +1 -0
- package/dist/esm/utils/dateFormatting.js +4 -0
- package/dist/esm/utils/dateFormatting.js.map +1 -0
- package/dist/esm/utils/deepClone.js +40 -0
- package/dist/esm/utils/deepClone.js.map +1 -0
- package/dist/esm/utils/deepEqual.js +47 -0
- package/dist/esm/utils/deepEqual.js.map +1 -0
- package/dist/esm/utils/diagnostics.js +69 -0
- package/dist/esm/utils/diagnostics.js.map +1 -0
- package/dist/esm/utils/errorHandling.js +36 -0
- package/dist/esm/utils/errorHandling.js.map +1 -0
- package/dist/esm/utils/formatting.js +93 -0
- package/dist/esm/utils/formatting.js.map +1 -0
- package/dist/esm/utils/list-detection.js +148 -0
- package/dist/esm/utils/list-detection.js.map +1 -0
- package/dist/esm/utils/logger.js +205 -0
- package/dist/esm/utils/logger.js.map +1 -0
- package/dist/esm/utils/parsingHelpers.js +56 -0
- package/dist/esm/utils/parsingHelpers.js.map +1 -0
- package/dist/esm/utils/textDiff.js +42 -0
- package/dist/esm/utils/textDiff.js.map +1 -0
- package/dist/esm/utils/units.js +152 -0
- package/dist/esm/utils/units.js.map +1 -0
- package/dist/esm/utils/validation.js +285 -0
- package/dist/esm/utils/validation.js.map +1 -0
- package/dist/esm/utils/xmlSanitization.js +54 -0
- package/dist/esm/utils/xmlSanitization.js.map +1 -0
- package/dist/esm/validation/RevisionAutoFixer.js +340 -0
- package/dist/esm/validation/RevisionAutoFixer.js.map +1 -0
- package/dist/esm/validation/RevisionValidator.js +240 -0
- package/dist/esm/validation/RevisionValidator.js.map +1 -0
- package/dist/esm/validation/ValidationRuleRegistry.js +40 -0
- package/dist/esm/validation/ValidationRuleRegistry.js.map +1 -0
- package/dist/esm/validation/ValidationRules.js +92 -0
- package/dist/esm/validation/ValidationRules.js.map +1 -0
- package/dist/esm/validation/index.js +4 -0
- package/dist/esm/validation/index.js.map +1 -0
- package/dist/esm/xml/XMLBuilder.js +434 -0
- package/dist/esm/xml/XMLBuilder.js.map +1 -0
- package/dist/esm/xml/XMLParser.js +486 -0
- package/dist/esm/xml/XMLParser.js.map +1 -0
- package/dist/esm/zip/ZipHandler.js +298 -0
- package/dist/esm/zip/ZipHandler.js.map +1 -0
- package/dist/esm/zip/ZipReader.js +147 -0
- package/dist/esm/zip/ZipReader.js.map +1 -0
- package/dist/esm/zip/ZipWriter.js +199 -0
- package/dist/esm/zip/ZipWriter.js.map +1 -0
- package/dist/esm/zip/errors.js +43 -0
- package/dist/esm/zip/errors.js.map +1 -0
- package/dist/esm/zip/types.js +31 -0
- package/dist/esm/zip/types.js.map +1 -0
- package/dist/formatting/AbstractNumbering.d.ts +2 -2
- package/dist/formatting/AbstractNumbering.d.ts.map +1 -1
- package/dist/formatting/AbstractNumbering.js +33 -33
- package/dist/formatting/AbstractNumbering.js.map +1 -1
- package/dist/formatting/NumberingInstance.d.ts +2 -2
- package/dist/formatting/NumberingInstance.d.ts.map +1 -1
- package/dist/formatting/NumberingInstance.js +7 -7
- package/dist/formatting/NumberingInstance.js.map +1 -1
- package/dist/formatting/NumberingLevel.d.ts +11 -2
- package/dist/formatting/NumberingLevel.d.ts.map +1 -1
- package/dist/formatting/NumberingLevel.js +111 -25
- package/dist/formatting/NumberingLevel.js.map +1 -1
- package/dist/formatting/NumberingManager.d.ts +4 -4
- package/dist/formatting/NumberingManager.d.ts.map +1 -1
- package/dist/formatting/NumberingManager.js +28 -28
- package/dist/formatting/NumberingManager.js.map +1 -1
- package/dist/formatting/Style.d.ts +14 -7
- package/dist/formatting/Style.d.ts.map +1 -1
- package/dist/formatting/Style.js +309 -112
- package/dist/formatting/Style.js.map +1 -1
- package/dist/formatting/StylesManager.d.ts +2 -2
- package/dist/formatting/StylesManager.d.ts.map +1 -1
- package/dist/formatting/StylesManager.js +52 -52
- package/dist/formatting/StylesManager.js.map +1 -1
- package/dist/helpers/CleanupHelper.d.ts +1 -1
- package/dist/helpers/CleanupHelper.d.ts.map +1 -1
- package/dist/helpers/CleanupHelper.js +15 -15
- package/dist/helpers/CleanupHelper.js.map +1 -1
- package/dist/index.d.ts +81 -90
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +286 -317
- package/dist/index.js.map +1 -1
- package/dist/internal.d.ts +16 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +42 -0
- package/dist/internal.js.map +1 -0
- package/dist/managers/DrawingManager.d.ts +3 -3
- package/dist/managers/DrawingManager.d.ts.map +1 -1
- package/dist/managers/DrawingManager.js +12 -12
- package/dist/managers/DrawingManager.js.map +1 -1
- package/dist/{utils → processors}/ChangelogGenerator.d.ts +2 -2
- package/dist/processors/ChangelogGenerator.d.ts.map +1 -0
- package/dist/{utils → processors}/ChangelogGenerator.js +2 -2
- package/dist/processors/ChangelogGenerator.js.map +1 -0
- package/dist/processors/CompatibilityUpgrader.d.ts.map +1 -0
- package/dist/{utils → processors}/CompatibilityUpgrader.js +10 -10
- package/dist/processors/CompatibilityUpgrader.js.map +1 -0
- package/dist/{utils → processors}/InMemoryRevisionAcceptor.d.ts +3 -3
- package/dist/processors/InMemoryRevisionAcceptor.d.ts.map +1 -0
- package/dist/{utils → processors}/InMemoryRevisionAcceptor.js +84 -27
- package/dist/processors/InMemoryRevisionAcceptor.js.map +1 -0
- package/dist/{utils → processors}/MoveOperationHelper.d.ts +4 -4
- package/dist/processors/MoveOperationHelper.d.ts.map +1 -0
- package/dist/{utils → processors}/MoveOperationHelper.js +10 -10
- package/dist/processors/MoveOperationHelper.js.map +1 -0
- package/dist/{utils → processors}/RevisionAwareProcessor.d.ts +3 -3
- package/dist/processors/RevisionAwareProcessor.d.ts.map +1 -0
- package/dist/{utils → processors}/RevisionAwareProcessor.js +2 -2
- package/dist/processors/RevisionAwareProcessor.js.map +1 -0
- package/dist/{utils → processors}/RevisionWalker.d.ts +2 -1
- package/dist/processors/RevisionWalker.d.ts.map +1 -0
- package/dist/{utils → processors}/RevisionWalker.js +28 -0
- package/dist/processors/RevisionWalker.js.map +1 -0
- package/dist/{utils → processors}/SelectiveRevisionAcceptor.d.ts +4 -3
- package/dist/processors/SelectiveRevisionAcceptor.d.ts.map +1 -0
- package/dist/processors/SelectiveRevisionAcceptor.js +402 -0
- package/dist/processors/SelectiveRevisionAcceptor.js.map +1 -0
- package/dist/processors/ShadingResolver.d.ts +6 -0
- package/dist/processors/ShadingResolver.d.ts.map +1 -0
- package/dist/{utils → processors}/ShadingResolver.js +2 -2
- package/dist/processors/ShadingResolver.js.map +1 -0
- package/dist/{utils → processors}/acceptRevisions.d.ts +1 -1
- package/dist/processors/acceptRevisions.d.ts.map +1 -0
- package/dist/{utils → processors}/acceptRevisions.js +24 -4
- package/dist/processors/acceptRevisions.js.map +1 -0
- package/dist/{utils → processors}/cnfStyleDecoder.d.ts +1 -1
- package/dist/processors/cnfStyleDecoder.d.ts.map +1 -0
- package/dist/processors/cnfStyleDecoder.js.map +1 -0
- package/dist/processors/stripTrackedChanges.d.ts +3 -0
- package/dist/processors/stripTrackedChanges.d.ts.map +1 -0
- package/dist/{utils → processors}/stripTrackedChanges.js +16 -6
- package/dist/processors/stripTrackedChanges.js.map +1 -0
- package/dist/tracking/DocumentTrackingContext.d.ts +4 -4
- package/dist/tracking/DocumentTrackingContext.d.ts.map +1 -1
- package/dist/tracking/DocumentTrackingContext.js +38 -43
- package/dist/tracking/DocumentTrackingContext.js.map +1 -1
- package/dist/tracking/TrackingContext.d.ts +8 -8
- package/dist/tracking/TrackingContext.d.ts.map +1 -1
- package/dist/tracking/TrackingContext.js.map +1 -1
- package/dist/types/document-types.d.ts +28 -0
- package/dist/types/document-types.d.ts.map +1 -0
- package/dist/types/document-types.js +3 -0
- package/dist/types/document-types.js.map +1 -0
- package/dist/types/formatting.d.ts +4 -4
- package/dist/types/formatting.d.ts.map +1 -1
- package/dist/types/formatting.js.map +1 -1
- package/dist/types/settings-types.d.ts +6 -0
- package/dist/types/settings-types.d.ts.map +1 -1
- package/dist/types/settings-types.js.map +1 -1
- package/dist/utils/KeyedRegistry.d.ts +13 -0
- package/dist/utils/KeyedRegistry.d.ts.map +1 -0
- package/dist/utils/KeyedRegistry.js +36 -0
- package/dist/utils/KeyedRegistry.js.map +1 -0
- package/dist/utils/corruptionDetection.d.ts +1 -1
- package/dist/utils/corruptionDetection.d.ts.map +1 -1
- package/dist/utils/corruptionDetection.js +4 -4
- package/dist/utils/corruptionDetection.js.map +1 -1
- package/dist/utils/deepEqual.d.ts +2 -0
- package/dist/utils/deepEqual.d.ts.map +1 -0
- package/dist/utils/deepEqual.js +50 -0
- package/dist/utils/deepEqual.js.map +1 -0
- package/dist/utils/list-detection.d.ts +2 -2
- package/dist/utils/list-detection.d.ts.map +1 -1
- package/dist/utils/list-detection.js.map +1 -1
- package/dist/utils/parsingHelpers.d.ts +1 -1
- package/dist/utils/parsingHelpers.d.ts.map +1 -1
- package/dist/utils/parsingHelpers.js +2 -2
- package/dist/utils/parsingHelpers.js.map +1 -1
- package/dist/utils/validation.js +7 -7
- package/dist/utils/validation.js.map +1 -1
- package/dist/utils/xmlSanitization.js +2 -2
- package/dist/utils/xmlSanitization.js.map +1 -1
- package/dist/validation/RevisionAutoFixer.d.ts +4 -4
- package/dist/validation/RevisionAutoFixer.d.ts.map +1 -1
- package/dist/validation/RevisionAutoFixer.js +11 -11
- package/dist/validation/RevisionAutoFixer.js.map +1 -1
- package/dist/validation/RevisionValidator.d.ts +5 -4
- package/dist/validation/RevisionValidator.d.ts.map +1 -1
- package/dist/validation/RevisionValidator.js +29 -30
- package/dist/validation/RevisionValidator.js.map +1 -1
- package/dist/validation/ValidationRuleRegistry.d.ts +27 -0
- package/dist/validation/ValidationRuleRegistry.d.ts.map +1 -0
- package/dist/validation/ValidationRuleRegistry.js +43 -0
- package/dist/validation/ValidationRuleRegistry.js.map +1 -0
- package/dist/validation/index.d.ts +3 -3
- package/dist/validation/index.d.ts.map +1 -1
- package/dist/validation/index.js +10 -10
- package/dist/validation/index.js.map +1 -1
- package/dist/xml/XMLBuilder.d.ts +6 -1
- package/dist/xml/XMLBuilder.d.ts.map +1 -1
- package/dist/xml/XMLBuilder.js +11 -6
- package/dist/xml/XMLBuilder.js.map +1 -1
- package/dist/xml/XMLParser.js +6 -6
- package/dist/xml/XMLParser.js.map +1 -1
- package/dist/zip/ZipHandler.d.ts +1 -1
- package/dist/zip/ZipHandler.d.ts.map +1 -1
- package/dist/zip/ZipHandler.js +8 -8
- package/dist/zip/ZipHandler.js.map +1 -1
- package/dist/zip/ZipReader.d.ts +1 -1
- package/dist/zip/ZipReader.d.ts.map +1 -1
- package/dist/zip/ZipReader.js +14 -14
- package/dist/zip/ZipReader.js.map +1 -1
- package/dist/zip/ZipWriter.d.ts +1 -1
- package/dist/zip/ZipWriter.d.ts.map +1 -1
- package/dist/zip/ZipWriter.js +10 -10
- package/dist/zip/ZipWriter.js.map +1 -1
- package/package.json +20 -4
- package/src/constants/legacyCompatFlags.ts +1 -1
- package/src/core/Document.ts +478 -167
- package/src/core/DocumentContent.ts +14 -11
- package/src/core/DocumentEvents.ts +90 -0
- package/src/core/DocumentGenerator.ts +49 -22
- package/src/core/DocumentParser.ts +2235 -620
- package/src/core/DocumentValidator.ts +7 -7
- package/src/core/ElementRegistry.ts +69 -0
- package/src/core/Relationship.ts +1 -1
- package/src/core/RelationshipManager.ts +4 -4
- package/src/elements/AlternateContent.ts +1 -1
- package/src/elements/Bookmark.ts +52 -4
- package/src/elements/BookmarkManager.ts +2 -2
- package/src/elements/Comment.ts +3 -3
- package/src/elements/CommentManager.ts +4 -4
- package/src/elements/CommonTypes.ts +45 -7
- package/src/elements/CustomXml.ts +1 -1
- package/src/elements/Endnote.ts +2 -2
- package/src/elements/EndnoteManager.ts +3 -3
- package/src/elements/Field.ts +44 -10
- package/src/elements/FieldHelpers.ts +2 -2
- package/src/elements/Footer.ts +4 -4
- package/src/elements/Footnote.ts +2 -2
- package/src/elements/FootnoteManager.ts +3 -3
- package/src/elements/Header.ts +4 -4
- package/src/elements/HeaderFooterManager.ts +2 -2
- package/src/elements/Hyperlink.ts +16 -12
- package/src/elements/Image.ts +3 -3
- package/src/elements/ImageManager.ts +2 -2
- package/src/elements/ImageRun.ts +3 -3
- package/src/elements/MathElement.ts +1 -1
- package/src/elements/Paragraph.ts +221 -88
- package/src/elements/PreservedElement.ts +1 -1
- package/src/elements/PropertyChangeTypes.ts +2 -2
- package/src/elements/RangeMarker.ts +153 -12
- package/src/elements/RegisteredBodyElement.ts +52 -0
- package/src/elements/Revision.ts +14 -14
- package/src/elements/RevisionContent.ts +3 -3
- package/src/elements/RevisionManager.ts +3 -3
- package/src/elements/Run.ts +221 -94
- package/src/elements/Section.ts +136 -69
- package/src/elements/Shape.ts +4 -4
- package/src/elements/StructuredDocumentTag.ts +3 -3
- package/src/elements/Table.ts +91 -27
- package/src/elements/TableCell.ts +62 -34
- package/src/elements/TableGridChange.ts +1 -1
- package/src/elements/TableOfContents.ts +1 -1
- package/src/elements/TableOfContentsElement.ts +2 -2
- package/src/elements/TableRow.ts +192 -48
- package/src/elements/TextBox.ts +5 -5
- package/src/formatting/AbstractNumbering.ts +3 -3
- package/src/formatting/NumberingInstance.ts +2 -2
- package/src/formatting/NumberingLevel.ts +201 -10
- package/src/formatting/NumberingManager.ts +5 -5
- package/src/formatting/Style.ts +382 -86
- package/src/formatting/StylesManager.ts +4 -4
- package/src/helpers/CleanupHelper.ts +6 -6
- package/src/index.ts +118 -127
- package/src/internal.ts +79 -0
- package/src/managers/DrawingManager.ts +3 -3
- package/src/{utils → processors}/ChangelogGenerator.ts +3 -3
- package/src/{utils → processors}/CompatibilityUpgrader.ts +2 -2
- package/src/{utils → processors}/InMemoryRevisionAcceptor.ts +100 -12
- package/src/{utils → processors}/MoveOperationHelper.ts +5 -5
- package/src/{utils → processors}/RevisionAwareProcessor.ts +3 -3
- package/src/{utils → processors}/RevisionWalker.ts +42 -1
- package/src/{utils → processors}/SelectiveRevisionAcceptor.ts +98 -39
- package/src/{utils → processors}/ShadingResolver.ts +5 -5
- package/src/{utils → processors}/acceptRevisions.ts +77 -9
- package/src/{utils → processors}/cnfStyleDecoder.ts +1 -1
- package/src/{utils → processors}/stripTrackedChanges.ts +35 -10
- package/src/tracking/DocumentTrackingContext.ts +12 -14
- package/src/tracking/TrackingContext.ts +8 -8
- package/src/types/document-types.ts +53 -0
- package/src/types/formatting.ts +4 -4
- package/src/types/settings-types.ts +32 -0
- package/src/utils/KeyedRegistry.ts +41 -0
- package/src/utils/corruptionDetection.ts +2 -2
- package/src/utils/deepEqual.ts +58 -0
- package/src/utils/list-detection.ts +2 -2
- package/src/utils/parsingHelpers.ts +11 -3
- package/src/utils/validation.ts +3 -3
- package/src/utils/xmlSanitization.ts +1 -1
- package/src/validation/RevisionAutoFixer.ts +5 -5
- package/src/validation/RevisionValidator.ts +39 -28
- package/src/validation/ValidationRuleRegistry.ts +86 -0
- package/src/validation/index.ts +3 -3
- package/src/xml/XMLBuilder.ts +13 -3
- package/src/xml/XMLParser.ts +2 -2
- package/src/zip/ZipHandler.ts +4 -4
- package/src/zip/ZipReader.ts +3 -3
- package/src/zip/ZipWriter.ts +3 -3
- package/dist/utils/ChangelogGenerator.d.ts.map +0 -1
- package/dist/utils/ChangelogGenerator.js.map +0 -1
- package/dist/utils/CompatibilityUpgrader.d.ts.map +0 -1
- package/dist/utils/CompatibilityUpgrader.js.map +0 -1
- package/dist/utils/InMemoryRevisionAcceptor.d.ts.map +0 -1
- package/dist/utils/InMemoryRevisionAcceptor.js.map +0 -1
- package/dist/utils/MoveOperationHelper.d.ts.map +0 -1
- package/dist/utils/MoveOperationHelper.js.map +0 -1
- package/dist/utils/RevisionAwareProcessor.d.ts.map +0 -1
- package/dist/utils/RevisionAwareProcessor.js.map +0 -1
- package/dist/utils/RevisionWalker.d.ts.map +0 -1
- package/dist/utils/RevisionWalker.js.map +0 -1
- package/dist/utils/SelectiveRevisionAcceptor.d.ts.map +0 -1
- package/dist/utils/SelectiveRevisionAcceptor.js.map +0 -1
- package/dist/utils/ShadingResolver.d.ts +0 -6
- package/dist/utils/ShadingResolver.d.ts.map +0 -1
- package/dist/utils/ShadingResolver.js.map +0 -1
- package/dist/utils/acceptRevisions.d.ts.map +0 -1
- package/dist/utils/acceptRevisions.js.map +0 -1
- package/dist/utils/cnfStyleDecoder.d.ts.map +0 -1
- package/dist/utils/cnfStyleDecoder.js.map +0 -1
- package/dist/utils/stripTrackedChanges.d.ts +0 -3
- package/dist/utils/stripTrackedChanges.d.ts.map +0 -1
- package/dist/utils/stripTrackedChanges.js.map +0 -1
- package/src/__tests__/helper-methods.test.ts +0 -512
- package/src/constants/CLAUDE.md +0 -28
- package/src/core/CLAUDE.md +0 -113
- package/src/elements/CLAUDE.md +0 -142
- package/src/formatting/CLAUDE.md +0 -78
- package/src/managers/CLAUDE.md +0 -47
- package/src/tracking/CLAUDE.md +0 -30
- package/src/types/CLAUDE.md +0 -39
- package/src/utils/CLAUDE.md +0 -168
- package/src/validation/CLAUDE.md +0 -40
- package/src/xml/CLAUDE.md +0 -65
- package/src/zip/CLAUDE.md +0 -55
- /package/dist/{utils → processors}/CompatibilityUpgrader.d.ts +0 -0
- /package/dist/{utils → processors}/cnfStyleDecoder.js +0 -0
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.RevisionValidator = void 0;
|
|
4
|
-
const
|
|
4
|
+
const ValidationRules_js_1 = require("./ValidationRules.js");
|
|
5
|
+
const ValidationRuleRegistry_js_1 = require("./ValidationRuleRegistry.js");
|
|
5
6
|
class RevisionValidator {
|
|
6
7
|
static validate(doc, options) {
|
|
7
8
|
const revisionManager = doc.getRevisionManager();
|
|
9
|
+
const allIssues = [];
|
|
10
|
+
allIssues.push(...this.runCustomRules(doc));
|
|
8
11
|
if (!revisionManager) {
|
|
9
|
-
return this.
|
|
12
|
+
return this.finalize(allIssues, options);
|
|
10
13
|
}
|
|
11
14
|
const revisions = revisionManager.getAllRevisions();
|
|
12
|
-
const allIssues = [];
|
|
13
15
|
const skipRules = new Set(options?.skipRules || []);
|
|
14
16
|
if (options?.level === 'lenient') {
|
|
15
17
|
skipRules.add('REV201');
|
|
@@ -39,6 +41,19 @@ class RevisionValidator {
|
|
|
39
41
|
if (!skipRules.has('REV202')) {
|
|
40
42
|
allIssues.push(...this.validateRevisionDates(revisions));
|
|
41
43
|
}
|
|
44
|
+
return this.finalize(allIssues, options);
|
|
45
|
+
}
|
|
46
|
+
static runCustomRules(doc) {
|
|
47
|
+
const customIssues = ValidationRuleRegistry_js_1.ValidationRuleRegistry.runAll(doc);
|
|
48
|
+
return customIssues.map((c) => ({
|
|
49
|
+
code: c.ruleCode,
|
|
50
|
+
severity: c.severity,
|
|
51
|
+
message: c.message,
|
|
52
|
+
location: c.location ? { element: c.location } : undefined,
|
|
53
|
+
autoFixable: false,
|
|
54
|
+
}));
|
|
55
|
+
}
|
|
56
|
+
static finalize(allIssues, options) {
|
|
42
57
|
const limitedIssues = options?.maxIssues ? allIssues.slice(0, options.maxIssues) : allIssues;
|
|
43
58
|
let errors = limitedIssues.filter((i) => i.severity === 'error');
|
|
44
59
|
let warnings = limitedIssues.filter((i) => i.severity === 'warning');
|
|
@@ -63,22 +78,6 @@ class RevisionValidator {
|
|
|
63
78
|
},
|
|
64
79
|
};
|
|
65
80
|
}
|
|
66
|
-
static createEmptyResult() {
|
|
67
|
-
return {
|
|
68
|
-
valid: true,
|
|
69
|
-
errors: [],
|
|
70
|
-
warnings: [],
|
|
71
|
-
infos: [],
|
|
72
|
-
autoFixable: [],
|
|
73
|
-
summary: {
|
|
74
|
-
totalIssues: 0,
|
|
75
|
-
errorCount: 0,
|
|
76
|
-
warningCount: 0,
|
|
77
|
-
infoCount: 0,
|
|
78
|
-
autoFixableCount: 0,
|
|
79
|
-
},
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
81
|
static validateRevisionIds(revisions) {
|
|
83
82
|
const issues = [];
|
|
84
83
|
const seenIds = new Map();
|
|
@@ -91,9 +90,9 @@ class RevisionValidator {
|
|
|
91
90
|
});
|
|
92
91
|
for (const [id, indices] of seenIds) {
|
|
93
92
|
if (indices.length > 1) {
|
|
94
|
-
const rule =
|
|
93
|
+
const rule = ValidationRules_js_1.REVISION_RULES.DUPLICATE_ID;
|
|
95
94
|
if (rule) {
|
|
96
|
-
issues.push((0,
|
|
95
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(rule, { revisionId: id }, `Duplicate revision ID ${id} found at ${indices.length} locations (indices: ${indices.join(', ')})`));
|
|
97
96
|
}
|
|
98
97
|
}
|
|
99
98
|
}
|
|
@@ -116,12 +115,12 @@ class RevisionValidator {
|
|
|
116
115
|
}
|
|
117
116
|
for (const [moveId, rev] of moveFromIds) {
|
|
118
117
|
if (!moveToIds.has(moveId)) {
|
|
119
|
-
issues.push((0,
|
|
118
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.ORPHANED_MOVE_FROM, { revisionId: rev.getId() }, `moveFrom with moveId="${moveId}" has no matching moveTo`));
|
|
120
119
|
}
|
|
121
120
|
}
|
|
122
121
|
for (const [moveId, rev] of moveToIds) {
|
|
123
122
|
if (!moveFromIds.has(moveId)) {
|
|
124
|
-
issues.push((0,
|
|
123
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.ORPHANED_MOVE_TO, { revisionId: rev.getId() }, `moveTo with moveId="${moveId}" has no matching moveFrom`));
|
|
125
124
|
}
|
|
126
125
|
}
|
|
127
126
|
return issues;
|
|
@@ -131,7 +130,7 @@ class RevisionValidator {
|
|
|
131
130
|
for (const rev of revisions) {
|
|
132
131
|
const author = rev.getAuthor();
|
|
133
132
|
if (!author || author.trim() === '') {
|
|
134
|
-
issues.push((0,
|
|
133
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.MISSING_AUTHOR, { revisionId: rev.getId() }));
|
|
135
134
|
}
|
|
136
135
|
}
|
|
137
136
|
return issues;
|
|
@@ -141,10 +140,10 @@ class RevisionValidator {
|
|
|
141
140
|
for (const rev of revisions) {
|
|
142
141
|
const date = rev.getDate();
|
|
143
142
|
if (!date) {
|
|
144
|
-
issues.push((0,
|
|
143
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.MISSING_DATE, { revisionId: rev.getId() }));
|
|
145
144
|
}
|
|
146
145
|
else if (isNaN(date.getTime())) {
|
|
147
|
-
issues.push((0,
|
|
146
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.INVALID_DATE_FORMAT, { revisionId: rev.getId() }, `Revision ${rev.getId()} has an invalid date`));
|
|
148
147
|
}
|
|
149
148
|
}
|
|
150
149
|
return issues;
|
|
@@ -169,7 +168,7 @@ class RevisionValidator {
|
|
|
169
168
|
const runs = rev.getRuns();
|
|
170
169
|
const hasContent = runs.length > 0 && runs.some((r) => r.getText().length > 0);
|
|
171
170
|
if (!hasContent) {
|
|
172
|
-
issues.push((0,
|
|
171
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.EMPTY_REVISION, { revisionId: rev.getId() }, `Revision ${rev.getId()} (type: ${type}) has no content`));
|
|
173
172
|
}
|
|
174
173
|
}
|
|
175
174
|
return issues;
|
|
@@ -191,14 +190,14 @@ class RevisionValidator {
|
|
|
191
190
|
}
|
|
192
191
|
}
|
|
193
192
|
if (missingIds.length > 0) {
|
|
194
|
-
issues.push((0,
|
|
193
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.NON_SEQUENTIAL_IDS, undefined, `Revision IDs are not sequential. Missing IDs: ${missingIds.slice(0, 10).join(', ')}${missingIds.length > 10 ? ` (and ${missingIds.length - 10} more)` : ''}`));
|
|
195
194
|
}
|
|
196
195
|
return issues;
|
|
197
196
|
}
|
|
198
197
|
static validateRevisionCount(revisions) {
|
|
199
198
|
const issues = [];
|
|
200
199
|
if (revisions.length > 1000) {
|
|
201
|
-
issues.push((0,
|
|
200
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.LARGE_REVISION_COUNT, undefined, `Document has ${revisions.length} revisions (>1000). Consider accepting or rejecting some.`));
|
|
202
201
|
}
|
|
203
202
|
return issues;
|
|
204
203
|
}
|
|
@@ -214,7 +213,7 @@ class RevisionValidator {
|
|
|
214
213
|
}
|
|
215
214
|
}
|
|
216
215
|
if (oldCount > 0) {
|
|
217
|
-
issues.push((0,
|
|
216
|
+
issues.push((0, ValidationRules_js_1.createIssueFromRule)(ValidationRules_js_1.REVISION_RULES.OLD_REVISION_DATE, undefined, `${oldCount} revision(s) are older than 1 year. Consider reviewing and accepting.`));
|
|
218
217
|
}
|
|
219
218
|
return issues;
|
|
220
219
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RevisionValidator.js","sourceRoot":"","sources":["../../src/validation/RevisionValidator.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RevisionValidator - Validates document revisions for ECMA-376 compliance\n *\n * Checks tracked changes against OOXML specifications to prevent\n * document corruption and ensure compatibility with Microsoft Word.\n *\n * @module RevisionValidator\n */\n\nimport type { Document } from '../core/Document';\nimport type { Revision } from '../elements/Revision';\nimport {\n REVISION_RULES,\n ValidationIssue,\n ValidationOptions,\n ValidationResult,\n createIssueFromRule,\n} from './ValidationRules';\n\n/**\n * Validates document revisions for ECMA-376 compliance.\n *\n * @example\n * ```typescript\n * const result = RevisionValidator.validate(doc);\n * if (!result.valid) {\n * console.error(`Found ${result.errors.length} errors`);\n * for (const error of result.errors) {\n * console.error(` ${error.code}: ${error.message}`);\n * }\n * }\n * ```\n */\nexport class RevisionValidator {\n /**\n * Validates all revisions in a document.\n *\n * @param doc - Document to validate\n * @param options - Validation options\n * @returns Validation result with all issues found\n */\n static validate(doc: Document, options?: ValidationOptions): ValidationResult {\n const revisionManager = doc.getRevisionManager();\n if (!revisionManager) {\n return this.createEmptyResult();\n }\n\n const revisions = revisionManager.getAllRevisions();\n const allIssues: ValidationIssue[] = [];\n\n // Skip certain rules if lenient mode\n const skipRules = new Set(options?.skipRules || []);\n if (options?.level === 'lenient') {\n // In lenient mode, skip info rules\n skipRules.add('REV201');\n skipRules.add('REV202');\n }\n\n // Run all validations\n if (!skipRules.has('REV001')) {\n allIssues.push(...this.validateRevisionIds(revisions));\n }\n if (!skipRules.has('REV003') && !skipRules.has('REV004')) {\n allIssues.push(...this.validateMovePairs(revisions));\n }\n if (!skipRules.has('REV002')) {\n allIssues.push(...this.validateAuthors(revisions));\n }\n if (!skipRules.has('REV101') && !skipRules.has('REV102')) {\n allIssues.push(...this.validateDates(revisions));\n }\n if (!skipRules.has('REV103')) {\n allIssues.push(...this.validateContent(revisions));\n }\n if (!skipRules.has('REV104') && options?.level === 'strict') {\n allIssues.push(...this.validateSequentialIds(revisions));\n }\n if (!skipRules.has('REV201')) {\n allIssues.push(...this.validateRevisionCount(revisions));\n }\n if (!skipRules.has('REV202')) {\n allIssues.push(...this.validateRevisionDates(revisions));\n }\n\n // Apply max issues limit\n const limitedIssues = options?.maxIssues ? allIssues.slice(0, options.maxIssues) : allIssues;\n\n // Separate by severity\n let errors = limitedIssues.filter((i) => i.severity === 'error');\n let warnings = limitedIssues.filter((i) => i.severity === 'warning');\n const infos = limitedIssues.filter((i) => i.severity === 'info');\n const autoFixable = limitedIssues.filter((i) => i.autoFixable);\n\n // Handle warningsAsErrors option\n if (options?.warningsAsErrors) {\n errors = [...errors, ...warnings];\n warnings = [];\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n infos,\n autoFixable,\n summary: {\n totalIssues: limitedIssues.length,\n errorCount: errors.length,\n warningCount: warnings.length,\n infoCount: infos.length,\n autoFixableCount: autoFixable.length,\n },\n };\n }\n\n /**\n * Creates an empty validation result (for documents with no revisions).\n */\n private static createEmptyResult(): ValidationResult {\n return {\n valid: true,\n errors: [],\n warnings: [],\n infos: [],\n autoFixable: [],\n summary: {\n totalIssues: 0,\n errorCount: 0,\n warningCount: 0,\n infoCount: 0,\n autoFixableCount: 0,\n },\n };\n }\n\n /**\n * Validates revision ID uniqueness.\n *\n * Per ECMA-376, revision IDs must be unique within a document.\n * Duplicate IDs can cause Word to reject the document.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for duplicate IDs\n */\n static validateRevisionIds(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n const seenIds = new Map<number, number[]>(); // id -> indices\n\n revisions.forEach((rev, index) => {\n const id = rev.getId();\n if (!seenIds.has(id)) {\n seenIds.set(id, []);\n }\n seenIds.get(id)!.push(index);\n });\n\n for (const [id, indices] of seenIds) {\n if (indices.length > 1) {\n const rule = REVISION_RULES.DUPLICATE_ID;\n if (rule) {\n issues.push(\n createIssueFromRule(\n rule,\n { revisionId: id },\n `Duplicate revision ID ${id} found at ${indices.length} locations (indices: ${indices.join(', ')})`\n )\n );\n }\n }\n }\n\n return issues;\n }\n\n /**\n * Validates move operation pairs.\n *\n * Each moveFrom must have a matching moveTo with the same moveId,\n * and vice versa. Orphaned move markers can cause document corruption.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for orphaned move operations\n */\n static validateMovePairs(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n const moveFromIds = new Map<string, Revision>();\n const moveToIds = new Map<string, Revision>();\n\n for (const rev of revisions) {\n const moveId = rev.getMoveId();\n if (!moveId) continue;\n\n if (rev.getType() === 'moveFrom') {\n moveFromIds.set(moveId, rev);\n } else if (rev.getType() === 'moveTo') {\n moveToIds.set(moveId, rev);\n }\n }\n\n // Check for orphaned moveFrom\n for (const [moveId, rev] of moveFromIds) {\n if (!moveToIds.has(moveId)) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.ORPHANED_MOVE_FROM,\n { revisionId: rev.getId() },\n `moveFrom with moveId=\"${moveId}\" has no matching moveTo`\n )\n );\n }\n }\n\n // Check for orphaned moveTo\n for (const [moveId, rev] of moveToIds) {\n if (!moveFromIds.has(moveId)) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.ORPHANED_MOVE_TO,\n { revisionId: rev.getId() },\n `moveTo with moveId=\"${moveId}\" has no matching moveFrom`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates author presence.\n *\n * Per ECMA-376, the author attribute is required for revisions.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for missing authors\n */\n static validateAuthors(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n for (const rev of revisions) {\n const author = rev.getAuthor();\n if (!author || author.trim() === '') {\n issues.push(\n createIssueFromRule(REVISION_RULES.MISSING_AUTHOR, { revisionId: rev.getId() })\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates date presence and format.\n *\n * Per ECMA-376, revision dates should be in ISO 8601 format.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for date problems\n */\n static validateDates(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n for (const rev of revisions) {\n const date = rev.getDate();\n\n if (!date) {\n issues.push(createIssueFromRule(REVISION_RULES.MISSING_DATE, { revisionId: rev.getId() }));\n } else if (isNaN(date.getTime())) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.INVALID_DATE_FORMAT,\n { revisionId: rev.getId() },\n `Revision ${rev.getId()} has an invalid date`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates revision content.\n *\n * Revisions (except property changes) should have content.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for empty revisions\n */\n static validateContent(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n const propertyChangeTypes = [\n 'runPropertiesChange',\n 'paragraphPropertiesChange',\n 'tablePropertiesChange',\n 'tableExceptionPropertiesChange',\n 'tableRowPropertiesChange',\n 'tableCellPropertiesChange',\n 'sectionPropertiesChange',\n 'numberingChange',\n ];\n\n for (const rev of revisions) {\n const type = rev.getType();\n\n // Property changes don't need text content\n if (propertyChangeTypes.includes(type)) {\n continue;\n }\n\n const runs = rev.getRuns();\n const hasContent = runs.length > 0 && runs.some((r) => r.getText().length > 0);\n\n if (!hasContent) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.EMPTY_REVISION,\n { revisionId: rev.getId() },\n `Revision ${rev.getId()} (type: ${type}) has no content`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates that revision IDs are sequential.\n *\n * While not strictly required, sequential IDs are best practice.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for non-sequential IDs\n */\n static validateSequentialIds(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n if (revisions.length === 0) return issues;\n\n // Use Set for O(n) lookup instead of sorting\n const idSet = new Set(revisions.map((r) => r.getId()));\n const ids = Array.from(idSet);\n\n if (ids.length === 0) return issues;\n\n const minId = Math.min(...ids);\n const maxId = Math.max(...ids);\n\n // Find actual missing IDs in the range\n const missingIds: number[] = [];\n for (let i = minId; i <= maxId; i++) {\n if (!idSet.has(i)) {\n missingIds.push(i);\n }\n }\n\n if (missingIds.length > 0) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.NON_SEQUENTIAL_IDS,\n undefined,\n `Revision IDs are not sequential. Missing IDs: ${missingIds.slice(0, 10).join(', ')}${missingIds.length > 10 ? ` (and ${missingIds.length - 10} more)` : ''}`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Validates revision count (info-level).\n *\n * Large numbers of revisions can slow down Word.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for large revision counts\n */\n static validateRevisionCount(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n if (revisions.length > 1000) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.LARGE_REVISION_COUNT,\n undefined,\n `Document has ${revisions.length} revisions (>1000). Consider accepting or rejecting some.`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Validates revision dates for staleness (info-level).\n *\n * Very old revisions may indicate stale tracked changes.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for old revisions\n */\n static validateRevisionDates(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n const oneYearAgo = new Date();\n oneYearAgo.setFullYear(oneYearAgo.getFullYear() - 1);\n\n let oldCount = 0;\n for (const rev of revisions) {\n const date = rev.getDate();\n if (date && date < oneYearAgo) {\n oldCount++;\n }\n }\n\n if (oldCount > 0) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.OLD_REVISION_DATE,\n undefined,\n `${oldCount} revision(s) are older than 1 year. Consider reviewing and accepting.`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Quick check if a document has any validation errors.\n *\n * @param doc - Document to check\n * @returns True if the document has no errors\n */\n static isValid(doc: Document): boolean {\n const result = this.validate(doc, { level: 'normal' });\n return result.valid;\n }\n\n /**\n * Get a summary string of validation results.\n *\n * @param result - Validation result\n * @returns Human-readable summary string\n */\n static formatSummary(result: ValidationResult): string {\n const lines: string[] = [];\n\n lines.push(`Validation ${result.valid ? 'PASSED' : 'FAILED'}`);\n lines.push(`Total issues: ${result.summary.totalIssues}`);\n\n if (result.summary.errorCount > 0) {\n lines.push(` Errors: ${result.summary.errorCount}`);\n }\n if (result.summary.warningCount > 0) {\n lines.push(` Warnings: ${result.summary.warningCount}`);\n }\n if (result.summary.infoCount > 0) {\n lines.push(` Info: ${result.summary.infoCount}`);\n }\n\n if (result.summary.autoFixableCount > 0) {\n lines.push(` Auto-fixable: ${result.summary.autoFixableCount}`);\n }\n\n return lines.join('\\n');\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"RevisionValidator.js","sourceRoot":"","sources":["../../src/validation/RevisionValidator.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RevisionValidator - Validates document revisions for ECMA-376 compliance\n *\n * Checks tracked changes against OOXML specifications to prevent\n * document corruption and ensure compatibility with Microsoft Word.\n *\n * @module RevisionValidator\n */\n\nimport type { Document } from '../core/Document.js';\nimport type { Revision } from '../elements/Revision.js';\nimport {\n REVISION_RULES,\n ValidationIssue,\n ValidationOptions,\n ValidationResult,\n createIssueFromRule,\n} from './ValidationRules.js';\nimport { ValidationRuleRegistry } from './ValidationRuleRegistry.js';\n\n/**\n * Validates document revisions for ECMA-376 compliance.\n *\n * @example\n * ```typescript\n * const result = RevisionValidator.validate(doc);\n * if (!result.valid) {\n * console.error(`Found ${result.errors.length} errors`);\n * for (const error of result.errors) {\n * console.error(` ${error.code}: ${error.message}`);\n * }\n * }\n * ```\n */\nexport class RevisionValidator {\n /**\n * Validates all revisions in a document.\n *\n * @param doc - Document to validate\n * @param options - Validation options\n * @returns Validation result with all issues found\n */\n static validate(doc: Document, options?: ValidationOptions): ValidationResult {\n const revisionManager = doc.getRevisionManager();\n const allIssues: ValidationIssue[] = [];\n\n // Custom rules from ValidationRuleRegistry run regardless of whether\n // the document has a revision manager — they validate document-level\n // properties, not just revisions.\n allIssues.push(...this.runCustomRules(doc));\n\n if (!revisionManager) {\n return this.finalize(allIssues, options);\n }\n\n const revisions = revisionManager.getAllRevisions();\n\n // Skip certain rules if lenient mode\n const skipRules = new Set(options?.skipRules || []);\n if (options?.level === 'lenient') {\n // In lenient mode, skip info rules\n skipRules.add('REV201');\n skipRules.add('REV202');\n }\n\n // Run all validations\n if (!skipRules.has('REV001')) {\n allIssues.push(...this.validateRevisionIds(revisions));\n }\n if (!skipRules.has('REV003') && !skipRules.has('REV004')) {\n allIssues.push(...this.validateMovePairs(revisions));\n }\n if (!skipRules.has('REV002')) {\n allIssues.push(...this.validateAuthors(revisions));\n }\n if (!skipRules.has('REV101') && !skipRules.has('REV102')) {\n allIssues.push(...this.validateDates(revisions));\n }\n if (!skipRules.has('REV103')) {\n allIssues.push(...this.validateContent(revisions));\n }\n if (!skipRules.has('REV104') && options?.level === 'strict') {\n allIssues.push(...this.validateSequentialIds(revisions));\n }\n if (!skipRules.has('REV201')) {\n allIssues.push(...this.validateRevisionCount(revisions));\n }\n if (!skipRules.has('REV202')) {\n allIssues.push(...this.validateRevisionDates(revisions));\n }\n\n return this.finalize(allIssues, options);\n }\n\n /**\n * Run every rule in `ValidationRuleRegistry` against `doc` and convert\n * the produced `CustomValidationIssue`s into the built-in\n * `ValidationIssue` shape so they can be merged into the final result.\n */\n private static runCustomRules(doc: Document): ValidationIssue[] {\n const customIssues = ValidationRuleRegistry.runAll(doc);\n return customIssues.map((c) => ({\n code: c.ruleCode,\n severity: c.severity,\n message: c.message,\n location: c.location ? { element: c.location } : undefined,\n autoFixable: false,\n }));\n }\n\n /**\n * Apply maxIssues / warningsAsErrors options and bucket the issues\n * into the standard `ValidationResult` shape.\n */\n private static finalize(\n allIssues: ValidationIssue[],\n options?: ValidationOptions\n ): ValidationResult {\n const limitedIssues = options?.maxIssues ? allIssues.slice(0, options.maxIssues) : allIssues;\n\n let errors = limitedIssues.filter((i) => i.severity === 'error');\n let warnings = limitedIssues.filter((i) => i.severity === 'warning');\n const infos = limitedIssues.filter((i) => i.severity === 'info');\n const autoFixable = limitedIssues.filter((i) => i.autoFixable);\n\n if (options?.warningsAsErrors) {\n errors = [...errors, ...warnings];\n warnings = [];\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n infos,\n autoFixable,\n summary: {\n totalIssues: limitedIssues.length,\n errorCount: errors.length,\n warningCount: warnings.length,\n infoCount: infos.length,\n autoFixableCount: autoFixable.length,\n },\n };\n }\n\n /**\n * Validates revision ID uniqueness.\n *\n * Per ECMA-376, revision IDs must be unique within a document.\n * Duplicate IDs can cause Word to reject the document.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for duplicate IDs\n */\n static validateRevisionIds(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n const seenIds = new Map<number, number[]>(); // id -> indices\n\n revisions.forEach((rev, index) => {\n const id = rev.getId();\n if (!seenIds.has(id)) {\n seenIds.set(id, []);\n }\n seenIds.get(id)!.push(index);\n });\n\n for (const [id, indices] of seenIds) {\n if (indices.length > 1) {\n const rule = REVISION_RULES.DUPLICATE_ID;\n if (rule) {\n issues.push(\n createIssueFromRule(\n rule,\n { revisionId: id },\n `Duplicate revision ID ${id} found at ${indices.length} locations (indices: ${indices.join(', ')})`\n )\n );\n }\n }\n }\n\n return issues;\n }\n\n /**\n * Validates move operation pairs.\n *\n * Each moveFrom must have a matching moveTo with the same moveId,\n * and vice versa. Orphaned move markers can cause document corruption.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for orphaned move operations\n */\n static validateMovePairs(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n const moveFromIds = new Map<string, Revision>();\n const moveToIds = new Map<string, Revision>();\n\n for (const rev of revisions) {\n const moveId = rev.getMoveId();\n if (!moveId) continue;\n\n if (rev.getType() === 'moveFrom') {\n moveFromIds.set(moveId, rev);\n } else if (rev.getType() === 'moveTo') {\n moveToIds.set(moveId, rev);\n }\n }\n\n // Check for orphaned moveFrom\n for (const [moveId, rev] of moveFromIds) {\n if (!moveToIds.has(moveId)) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.ORPHANED_MOVE_FROM,\n { revisionId: rev.getId() },\n `moveFrom with moveId=\"${moveId}\" has no matching moveTo`\n )\n );\n }\n }\n\n // Check for orphaned moveTo\n for (const [moveId, rev] of moveToIds) {\n if (!moveFromIds.has(moveId)) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.ORPHANED_MOVE_TO,\n { revisionId: rev.getId() },\n `moveTo with moveId=\"${moveId}\" has no matching moveFrom`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates author presence.\n *\n * Per ECMA-376, the author attribute is required for revisions.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for missing authors\n */\n static validateAuthors(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n for (const rev of revisions) {\n const author = rev.getAuthor();\n if (!author || author.trim() === '') {\n issues.push(\n createIssueFromRule(REVISION_RULES.MISSING_AUTHOR, { revisionId: rev.getId() })\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates date presence and format.\n *\n * Per ECMA-376, revision dates should be in ISO 8601 format.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for date problems\n */\n static validateDates(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n for (const rev of revisions) {\n const date = rev.getDate();\n\n if (!date) {\n issues.push(createIssueFromRule(REVISION_RULES.MISSING_DATE, { revisionId: rev.getId() }));\n } else if (isNaN(date.getTime())) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.INVALID_DATE_FORMAT,\n { revisionId: rev.getId() },\n `Revision ${rev.getId()} has an invalid date`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates revision content.\n *\n * Revisions (except property changes) should have content.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for empty revisions\n */\n static validateContent(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n const propertyChangeTypes = [\n 'runPropertiesChange',\n 'paragraphPropertiesChange',\n 'tablePropertiesChange',\n 'tableExceptionPropertiesChange',\n 'tableRowPropertiesChange',\n 'tableCellPropertiesChange',\n 'sectionPropertiesChange',\n 'numberingChange',\n ];\n\n for (const rev of revisions) {\n const type = rev.getType();\n\n // Property changes don't need text content\n if (propertyChangeTypes.includes(type)) {\n continue;\n }\n\n const runs = rev.getRuns();\n const hasContent = runs.length > 0 && runs.some((r) => r.getText().length > 0);\n\n if (!hasContent) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.EMPTY_REVISION,\n { revisionId: rev.getId() },\n `Revision ${rev.getId()} (type: ${type}) has no content`\n )\n );\n }\n }\n\n return issues;\n }\n\n /**\n * Validates that revision IDs are sequential.\n *\n * While not strictly required, sequential IDs are best practice.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for non-sequential IDs\n */\n static validateSequentialIds(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n if (revisions.length === 0) return issues;\n\n // Use Set for O(n) lookup instead of sorting\n const idSet = new Set(revisions.map((r) => r.getId()));\n const ids = Array.from(idSet);\n\n if (ids.length === 0) return issues;\n\n const minId = Math.min(...ids);\n const maxId = Math.max(...ids);\n\n // Find actual missing IDs in the range\n const missingIds: number[] = [];\n for (let i = minId; i <= maxId; i++) {\n if (!idSet.has(i)) {\n missingIds.push(i);\n }\n }\n\n if (missingIds.length > 0) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.NON_SEQUENTIAL_IDS,\n undefined,\n `Revision IDs are not sequential. Missing IDs: ${missingIds.slice(0, 10).join(', ')}${missingIds.length > 10 ? ` (and ${missingIds.length - 10} more)` : ''}`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Validates revision count (info-level).\n *\n * Large numbers of revisions can slow down Word.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for large revision counts\n */\n static validateRevisionCount(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n\n if (revisions.length > 1000) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.LARGE_REVISION_COUNT,\n undefined,\n `Document has ${revisions.length} revisions (>1000). Consider accepting or rejecting some.`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Validates revision dates for staleness (info-level).\n *\n * Very old revisions may indicate stale tracked changes.\n *\n * @param revisions - Array of revisions to validate\n * @returns Array of validation issues for old revisions\n */\n static validateRevisionDates(revisions: Revision[]): ValidationIssue[] {\n const issues: ValidationIssue[] = [];\n const oneYearAgo = new Date();\n oneYearAgo.setFullYear(oneYearAgo.getFullYear() - 1);\n\n let oldCount = 0;\n for (const rev of revisions) {\n const date = rev.getDate();\n if (date && date < oneYearAgo) {\n oldCount++;\n }\n }\n\n if (oldCount > 0) {\n issues.push(\n createIssueFromRule(\n REVISION_RULES.OLD_REVISION_DATE,\n undefined,\n `${oldCount} revision(s) are older than 1 year. Consider reviewing and accepting.`\n )\n );\n }\n\n return issues;\n }\n\n /**\n * Quick check if a document has any validation errors.\n *\n * @param doc - Document to check\n * @returns True if the document has no errors\n */\n static isValid(doc: Document): boolean {\n const result = this.validate(doc, { level: 'normal' });\n return result.valid;\n }\n\n /**\n * Get a summary string of validation results.\n *\n * @param result - Validation result\n * @returns Human-readable summary string\n */\n static formatSummary(result: ValidationResult): string {\n const lines: string[] = [];\n\n lines.push(`Validation ${result.valid ? 'PASSED' : 'FAILED'}`);\n lines.push(`Total issues: ${result.summary.totalIssues}`);\n\n if (result.summary.errorCount > 0) {\n lines.push(` Errors: ${result.summary.errorCount}`);\n }\n if (result.summary.warningCount > 0) {\n lines.push(` Warnings: ${result.summary.warningCount}`);\n }\n if (result.summary.infoCount > 0) {\n lines.push(` Info: ${result.summary.infoCount}`);\n }\n\n if (result.summary.autoFixableCount > 0) {\n lines.push(` Auto-fixable: ${result.summary.autoFixableCount}`);\n }\n\n return lines.join('\\n');\n }\n}\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { Document } from '../core/Document.js';
|
|
2
|
+
export type CustomValidationSeverity = 'error' | 'warning' | 'info';
|
|
3
|
+
export interface CustomValidationIssue {
|
|
4
|
+
ruleCode: string;
|
|
5
|
+
severity: CustomValidationSeverity;
|
|
6
|
+
message: string;
|
|
7
|
+
location?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface CustomValidationRule {
|
|
10
|
+
code: string;
|
|
11
|
+
description: string;
|
|
12
|
+
severity: CustomValidationSeverity;
|
|
13
|
+
validate(doc: Document): CustomValidationIssue[];
|
|
14
|
+
}
|
|
15
|
+
declare class ValidationRuleRegistryImpl {
|
|
16
|
+
private readonly inner;
|
|
17
|
+
register(rule: CustomValidationRule): void;
|
|
18
|
+
unregister(code: string): boolean;
|
|
19
|
+
has(code: string): boolean;
|
|
20
|
+
get(code: string): CustomValidationRule | undefined;
|
|
21
|
+
getAll(): CustomValidationRule[];
|
|
22
|
+
runAll(doc: Document): CustomValidationIssue[];
|
|
23
|
+
clear(): void;
|
|
24
|
+
}
|
|
25
|
+
export declare const ValidationRuleRegistry: ValidationRuleRegistryImpl;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=ValidationRuleRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationRuleRegistry.d.ts","sourceRoot":"","sources":["../../src/validation/ValidationRuleRegistry.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAQpD,MAAM,MAAM,wBAAwB,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEpE,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,wBAAwB,CAAC;IACnC,OAAO,EAAE,MAAM,CAAC;IAEhB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,oBAAoB;IAEnC,IAAI,EAAE,MAAM,CAAC;IAEb,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,wBAAwB,CAAC;IAKnC,QAAQ,CAAC,GAAG,EAAE,QAAQ,GAAG,qBAAqB,EAAE,CAAC;CAClD;AAED,cAAM,0BAA0B;IAC9B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAqE;IAE3F,QAAQ,CAAC,IAAI,EAAE,oBAAoB,GAAG,IAAI;IAI1C,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAIjC,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI1B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,oBAAoB,GAAG,SAAS;IAInD,MAAM,IAAI,oBAAoB,EAAE;IAMhC,MAAM,CAAC,GAAG,EAAE,QAAQ,GAAG,qBAAqB,EAAE;IAgB9C,KAAK,IAAI,IAAI;CAGd;AAED,eAAO,MAAM,sBAAsB,4BAAmC,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidationRuleRegistry = void 0;
|
|
4
|
+
const KeyedRegistry_js_1 = require("../utils/KeyedRegistry.js");
|
|
5
|
+
class ValidationRuleRegistryImpl {
|
|
6
|
+
inner = new KeyedRegistry_js_1.KeyedRegistry('ValidationRuleRegistry');
|
|
7
|
+
register(rule) {
|
|
8
|
+
this.inner.register(rule.code, rule);
|
|
9
|
+
}
|
|
10
|
+
unregister(code) {
|
|
11
|
+
return this.inner.unregister(code);
|
|
12
|
+
}
|
|
13
|
+
has(code) {
|
|
14
|
+
return this.inner.has(code);
|
|
15
|
+
}
|
|
16
|
+
get(code) {
|
|
17
|
+
return this.inner.get(code);
|
|
18
|
+
}
|
|
19
|
+
getAll() {
|
|
20
|
+
return this.inner.values();
|
|
21
|
+
}
|
|
22
|
+
runAll(doc) {
|
|
23
|
+
const out = [];
|
|
24
|
+
for (const rule of this.inner.values()) {
|
|
25
|
+
try {
|
|
26
|
+
out.push(...rule.validate(doc));
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
out.push({
|
|
30
|
+
ruleCode: rule.code,
|
|
31
|
+
severity: 'error',
|
|
32
|
+
message: `Rule "${rule.code}" threw during validation`,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return out;
|
|
37
|
+
}
|
|
38
|
+
clear() {
|
|
39
|
+
this.inner.clear();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.ValidationRuleRegistry = new ValidationRuleRegistryImpl();
|
|
43
|
+
//# sourceMappingURL=ValidationRuleRegistry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationRuleRegistry.js","sourceRoot":"","sources":["../../src/validation/ValidationRuleRegistry.ts"],"names":[],"mappings":";;;AASA,gEAA0D;AA8B1D,MAAM,0BAA0B;IACb,KAAK,GAAG,IAAI,gCAAa,CAAuB,wBAAwB,CAAC,CAAC;IAE3F,QAAQ,CAAC,IAA0B;QACjC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;IAC7B,CAAC;IAID,MAAM,CAAC,GAAa;QAClB,MAAM,GAAG,GAA4B,EAAE,CAAC;QACxC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC;gBACH,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;YAClC,CAAC;YAAC,MAAM,CAAC;gBACP,GAAG,CAAC,IAAI,CAAC;oBACP,QAAQ,EAAE,IAAI,CAAC,IAAI;oBACnB,QAAQ,EAAE,OAAO;oBACjB,OAAO,EAAE,SAAS,IAAI,CAAC,IAAI,2BAA2B;iBACvD,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AAEY,QAAA,sBAAsB,GAAG,IAAI,0BAA0B,EAAE,CAAC","sourcesContent":["/**\n * Plugin extension point for custom validation rules. Built-in rules\n * live in `ValidationRules.ts`; this registry lets consumers add their\n * own without modifying framework code. Custom rules run alongside the\n * built-ins when `RevisionValidator.validate()` executes — the validator\n * appends `runAll()` issues to its `infos`/`warnings`/`errors` buckets\n * based on each rule's declared severity.\n */\nimport type { Document } from '../core/Document.js';\nimport { KeyedRegistry } from '../utils/KeyedRegistry.js';\n\n/**\n * Severity for custom validation rules. Distinct from the built-in\n * `ValidationSeverity` enum so the public API surface has no name\n * collision.\n */\nexport type CustomValidationSeverity = 'error' | 'warning' | 'info';\n\nexport interface CustomValidationIssue {\n ruleCode: string;\n severity: CustomValidationSeverity;\n message: string;\n /** Optional element identifier or path for navigation in tooling. */\n location?: string;\n}\n\nexport interface CustomValidationRule {\n /** Unique rule identifier — must not collide with built-in rule codes. */\n code: string;\n /** Human-readable description of what the rule checks. */\n description: string;\n severity: CustomValidationSeverity;\n /**\n * Run the rule against a document and return any issues found.\n * Synchronous — async rules should be wrapped externally.\n */\n validate(doc: Document): CustomValidationIssue[];\n}\n\nclass ValidationRuleRegistryImpl {\n private readonly inner = new KeyedRegistry<CustomValidationRule>('ValidationRuleRegistry');\n\n register(rule: CustomValidationRule): void {\n this.inner.register(rule.code, rule);\n }\n\n unregister(code: string): boolean {\n return this.inner.unregister(code);\n }\n\n has(code: string): boolean {\n return this.inner.has(code);\n }\n\n get(code: string): CustomValidationRule | undefined {\n return this.inner.get(code);\n }\n\n getAll(): CustomValidationRule[] {\n return this.inner.values();\n }\n\n /** Run every registered rule and concatenate the issues. A throwing\n * rule is captured as a synthetic 'error' issue so consumers see it. */\n runAll(doc: Document): CustomValidationIssue[] {\n const out: CustomValidationIssue[] = [];\n for (const rule of this.inner.values()) {\n try {\n out.push(...rule.validate(doc));\n } catch {\n out.push({\n ruleCode: rule.code,\n severity: 'error',\n message: `Rule \"${rule.code}\" threw during validation`,\n });\n }\n }\n return out;\n }\n\n clear(): void {\n this.inner.clear();\n }\n}\n\nexport const ValidationRuleRegistry = new ValidationRuleRegistryImpl();\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { REVISION_RULES, ValidationSeverity, ValidationIssue, ValidationRule, ValidationOptions, AutoFixOptions, ValidationResult, FixAction, AutoFixResult, createIssueFromRule, getRuleByCode, getRulesBySeverity, getAutoFixableRules, } from './ValidationRules';
|
|
2
|
-
export { RevisionValidator } from './RevisionValidator';
|
|
3
|
-
export { RevisionAutoFixer } from './RevisionAutoFixer';
|
|
1
|
+
export { REVISION_RULES, ValidationSeverity, ValidationIssue, ValidationRule, ValidationOptions, AutoFixOptions, ValidationResult, FixAction, AutoFixResult, createIssueFromRule, getRuleByCode, getRulesBySeverity, getAutoFixableRules, } from './ValidationRules.js';
|
|
2
|
+
export { RevisionValidator } from './RevisionValidator.js';
|
|
3
|
+
export { RevisionAutoFixer } from './RevisionAutoFixer.js';
|
|
4
4
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/validation/index.ts"],"names":[],"mappings":"AASA,OAAO,EACL,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,gBAAgB,EAChB,SAAS,EACT,aAAa,EACb,mBAAmB,EACnB,aAAa,EACb,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/validation/index.ts"],"names":[],"mappings":"AASA,OAAO,EACL,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,gBAAgB,EAChB,SAAS,EACT,aAAa,EACb,mBAAmB,EACnB,aAAa,EACb,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,sBAAsB,CAAC;AAG9B,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAG3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC"}
|
package/dist/validation/index.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.RevisionAutoFixer = exports.RevisionValidator = exports.getAutoFixableRules = exports.getRulesBySeverity = exports.getRuleByCode = exports.createIssueFromRule = exports.REVISION_RULES = void 0;
|
|
4
|
-
var
|
|
5
|
-
Object.defineProperty(exports, "REVISION_RULES", { enumerable: true, get: function () { return
|
|
6
|
-
Object.defineProperty(exports, "createIssueFromRule", { enumerable: true, get: function () { return
|
|
7
|
-
Object.defineProperty(exports, "getRuleByCode", { enumerable: true, get: function () { return
|
|
8
|
-
Object.defineProperty(exports, "getRulesBySeverity", { enumerable: true, get: function () { return
|
|
9
|
-
Object.defineProperty(exports, "getAutoFixableRules", { enumerable: true, get: function () { return
|
|
10
|
-
var
|
|
11
|
-
Object.defineProperty(exports, "RevisionValidator", { enumerable: true, get: function () { return
|
|
12
|
-
var
|
|
13
|
-
Object.defineProperty(exports, "RevisionAutoFixer", { enumerable: true, get: function () { return
|
|
4
|
+
var ValidationRules_js_1 = require("./ValidationRules.js");
|
|
5
|
+
Object.defineProperty(exports, "REVISION_RULES", { enumerable: true, get: function () { return ValidationRules_js_1.REVISION_RULES; } });
|
|
6
|
+
Object.defineProperty(exports, "createIssueFromRule", { enumerable: true, get: function () { return ValidationRules_js_1.createIssueFromRule; } });
|
|
7
|
+
Object.defineProperty(exports, "getRuleByCode", { enumerable: true, get: function () { return ValidationRules_js_1.getRuleByCode; } });
|
|
8
|
+
Object.defineProperty(exports, "getRulesBySeverity", { enumerable: true, get: function () { return ValidationRules_js_1.getRulesBySeverity; } });
|
|
9
|
+
Object.defineProperty(exports, "getAutoFixableRules", { enumerable: true, get: function () { return ValidationRules_js_1.getAutoFixableRules; } });
|
|
10
|
+
var RevisionValidator_js_1 = require("./RevisionValidator.js");
|
|
11
|
+
Object.defineProperty(exports, "RevisionValidator", { enumerable: true, get: function () { return RevisionValidator_js_1.RevisionValidator; } });
|
|
12
|
+
var RevisionAutoFixer_js_1 = require("./RevisionAutoFixer.js");
|
|
13
|
+
Object.defineProperty(exports, "RevisionAutoFixer", { enumerable: true, get: function () { return RevisionAutoFixer_js_1.RevisionAutoFixer; } });
|
|
14
14
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/validation/index.ts"],"names":[],"mappings":";;;AASA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/validation/index.ts"],"names":[],"mappings":";;;AASA,2DAc8B;AAb5B,oHAAA,cAAc,OAAA;AASd,yHAAA,mBAAmB,OAAA;AACnB,mHAAA,aAAa,OAAA;AACb,wHAAA,kBAAkB,OAAA;AAClB,yHAAA,mBAAmB,OAAA;AAIrB,+DAA2D;AAAlD,yHAAA,iBAAiB,OAAA;AAG1B,+DAA2D;AAAlD,yHAAA,iBAAiB,OAAA","sourcesContent":["/**\n * Validation Module\n *\n * Provides validation and auto-fix capabilities for ECMA-376 revision compliance.\n *\n * @module validation\n */\n\n// Rule definitions and types\nexport {\n REVISION_RULES,\n ValidationSeverity,\n ValidationIssue,\n ValidationRule,\n ValidationOptions,\n AutoFixOptions,\n ValidationResult,\n FixAction,\n AutoFixResult,\n createIssueFromRule,\n getRuleByCode,\n getRulesBySeverity,\n getAutoFixableRules,\n} from './ValidationRules.js';\n\n// Validator class\nexport { RevisionValidator } from './RevisionValidator.js';\n\n// Auto-fixer class\nexport { RevisionAutoFixer } from './RevisionAutoFixer.js';\n"]}
|
package/dist/xml/XMLBuilder.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { ShadingConfig } from '../elements/CommonTypes';
|
|
1
|
+
import type { ShadingConfig } from '../elements/CommonTypes.js';
|
|
2
2
|
type ParsedXmlObject = Record<string, any>;
|
|
3
3
|
export interface XMLElement {
|
|
4
4
|
name: string;
|
|
@@ -48,6 +48,11 @@ export declare class XMLBuilder {
|
|
|
48
48
|
size?: number;
|
|
49
49
|
color?: string;
|
|
50
50
|
space?: number;
|
|
51
|
+
themeColor?: string;
|
|
52
|
+
themeTint?: string;
|
|
53
|
+
themeShade?: string;
|
|
54
|
+
shadow?: boolean;
|
|
55
|
+
frame?: boolean;
|
|
51
56
|
}): XMLElement;
|
|
52
57
|
static createShading(shading: ShadingConfig): XMLElement | null;
|
|
53
58
|
static createMargins(type: string, margins: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"XMLBuilder.d.ts","sourceRoot":"","sources":["../../src/xml/XMLBuilder.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"XMLBuilder.d.ts","sourceRoot":"","sources":["../../src/xml/XMLBuilder.ts"],"names":[],"mappings":"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"}
|
package/dist/xml/XMLBuilder.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.XMLBuilder = void 0;
|
|
4
|
-
const
|
|
5
|
-
const
|
|
4
|
+
const xmlSanitization_js_1 = require("../utils/xmlSanitization.js");
|
|
5
|
+
const CommonTypes_js_1 = require("../elements/CommonTypes.js");
|
|
6
6
|
class XMLBuilder {
|
|
7
7
|
elements = [];
|
|
8
8
|
static CANNOT_SELF_CLOSE = [
|
|
@@ -105,13 +105,13 @@ class XMLBuilder {
|
|
|
105
105
|
return XMLBuilder.escapeXmlText(text);
|
|
106
106
|
}
|
|
107
107
|
static escapeXmlText(text) {
|
|
108
|
-
return (0,
|
|
108
|
+
return (0, xmlSanitization_js_1.removeInvalidXmlChars)(text)
|
|
109
109
|
.replace(/&/g, '&')
|
|
110
110
|
.replace(/</g, '<')
|
|
111
111
|
.replace(/>/g, '>');
|
|
112
112
|
}
|
|
113
113
|
static escapeXmlAttribute(value) {
|
|
114
|
-
return (0,
|
|
114
|
+
return (0, xmlSanitization_js_1.removeInvalidXmlChars)(value)
|
|
115
115
|
.replace(/&/g, '&')
|
|
116
116
|
.replace(/</g, '<')
|
|
117
117
|
.replace(/>/g, '>')
|
|
@@ -127,7 +127,7 @@ class XMLBuilder {
|
|
|
127
127
|
.replace(/&/g, '&');
|
|
128
128
|
}
|
|
129
129
|
static sanitizeXmlContent(text) {
|
|
130
|
-
return ((0,
|
|
130
|
+
return ((0, xmlSanitization_js_1.removeInvalidXmlChars)(text)
|
|
131
131
|
.replace(/\]\]>/g, ']]>')
|
|
132
132
|
.replace(/&/g, '&')
|
|
133
133
|
.replace(/</g, '<')
|
|
@@ -390,11 +390,16 @@ class XMLBuilder {
|
|
|
390
390
|
'w:sz': border.size,
|
|
391
391
|
'w:color': border.color,
|
|
392
392
|
'w:space': border.space,
|
|
393
|
+
'w:themeColor': border.themeColor,
|
|
394
|
+
'w:themeTint': border.themeTint,
|
|
395
|
+
'w:themeShade': border.themeShade,
|
|
396
|
+
'w:shadow': border.shadow === undefined ? undefined : border.shadow ? '1' : '0',
|
|
397
|
+
'w:frame': border.frame === undefined ? undefined : border.frame ? '1' : '0',
|
|
393
398
|
});
|
|
394
399
|
return XMLBuilder.wSelf(side, attrs);
|
|
395
400
|
}
|
|
396
401
|
static createShading(shading) {
|
|
397
|
-
const attrs = (0,
|
|
402
|
+
const attrs = (0, CommonTypes_js_1.buildShadingAttributes)(shading);
|
|
398
403
|
if (!attrs['w:val'] && Object.keys(attrs).length > 0) {
|
|
399
404
|
attrs['w:val'] = 'clear';
|
|
400
405
|
}
|