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
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
import { REVISION_RULES, } from './ValidationRules.js';
|
|
2
|
+
import { RevisionValidator } from './RevisionValidator.js';
|
|
3
|
+
export class RevisionAutoFixer {
|
|
4
|
+
static fix(doc, options) {
|
|
5
|
+
const actions = [];
|
|
6
|
+
const errors = [];
|
|
7
|
+
const revisionManager = doc.getRevisionManager();
|
|
8
|
+
if (!revisionManager) {
|
|
9
|
+
return {
|
|
10
|
+
allFixed: true,
|
|
11
|
+
issuesFixed: 0,
|
|
12
|
+
issuesRemaining: 0,
|
|
13
|
+
actions: [],
|
|
14
|
+
errors: [],
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
const revisions = revisionManager.getAllRevisions();
|
|
18
|
+
const skipRules = new Set(options?.skipRules || []);
|
|
19
|
+
const onlyRules = options?.onlyRules ? new Set(options.onlyRules) : null;
|
|
20
|
+
const shouldProcess = (ruleCode) => {
|
|
21
|
+
if (skipRules.has(ruleCode))
|
|
22
|
+
return false;
|
|
23
|
+
if (onlyRules && !onlyRules.has(ruleCode))
|
|
24
|
+
return false;
|
|
25
|
+
return true;
|
|
26
|
+
};
|
|
27
|
+
try {
|
|
28
|
+
if (shouldProcess('REV001')) {
|
|
29
|
+
actions.push(...this.fixDuplicateIds(revisions, options?.dryRun));
|
|
30
|
+
}
|
|
31
|
+
if (shouldProcess('REV002')) {
|
|
32
|
+
const defaultAuthor = options?.defaultAuthor || 'Unknown Author';
|
|
33
|
+
actions.push(...this.fixMissingAuthors(revisions, defaultAuthor, options?.dryRun));
|
|
34
|
+
}
|
|
35
|
+
if (shouldProcess('REV003') || shouldProcess('REV004')) {
|
|
36
|
+
actions.push(...this.fixOrphanedMoveMarkers(revisionManager, revisions, options?.dryRun));
|
|
37
|
+
}
|
|
38
|
+
if (shouldProcess('REV101')) {
|
|
39
|
+
actions.push(...this.fixMissingDates(revisions, options?.dryRun));
|
|
40
|
+
}
|
|
41
|
+
if (shouldProcess('REV102')) {
|
|
42
|
+
actions.push(...this.fixInvalidDates(revisions, options?.dryRun));
|
|
43
|
+
}
|
|
44
|
+
if (shouldProcess('REV103')) {
|
|
45
|
+
actions.push(...this.fixEmptyRevisions(revisionManager, revisions, options?.dryRun));
|
|
46
|
+
}
|
|
47
|
+
if (shouldProcess('REV104')) {
|
|
48
|
+
actions.push(...this.fixNonSequentialIds(revisions, options?.dryRun));
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
errors.push(`Fix error: ${error instanceof Error ? error.message : String(error)}`);
|
|
53
|
+
}
|
|
54
|
+
const postValidation = RevisionValidator.validate(doc);
|
|
55
|
+
if (options?.verbose) {
|
|
56
|
+
for (const action of actions) {
|
|
57
|
+
console.log(`[AutoFix] ${action.action}: ${action.issue.code}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return {
|
|
61
|
+
allFixed: postValidation.valid,
|
|
62
|
+
issuesFixed: actions.filter((a) => a.success).length,
|
|
63
|
+
issuesRemaining: postValidation.summary.errorCount + postValidation.summary.warningCount,
|
|
64
|
+
actions,
|
|
65
|
+
errors,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
static fixDuplicateIds(revisions, dryRun) {
|
|
69
|
+
const actions = [];
|
|
70
|
+
const usedIds = new Set();
|
|
71
|
+
let nextId = Math.max(...revisions.map((r) => r.getId()), 0) + 1;
|
|
72
|
+
for (const rev of revisions) {
|
|
73
|
+
const id = rev.getId();
|
|
74
|
+
if (usedIds.has(id)) {
|
|
75
|
+
const newId = nextId++;
|
|
76
|
+
const issue = {
|
|
77
|
+
code: REVISION_RULES.DUPLICATE_ID.code,
|
|
78
|
+
severity: 'error',
|
|
79
|
+
message: `Duplicate ID ${id}`,
|
|
80
|
+
location: { revisionId: id },
|
|
81
|
+
autoFixable: true,
|
|
82
|
+
};
|
|
83
|
+
actions.push({
|
|
84
|
+
issue,
|
|
85
|
+
action: `Reassigned duplicate ID ${id} to ${newId}`,
|
|
86
|
+
before: id,
|
|
87
|
+
after: newId,
|
|
88
|
+
success: true,
|
|
89
|
+
});
|
|
90
|
+
if (!dryRun) {
|
|
91
|
+
rev.setId(newId);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
usedIds.add(rev.getId());
|
|
95
|
+
}
|
|
96
|
+
return actions;
|
|
97
|
+
}
|
|
98
|
+
static fixMissingAuthors(revisions, defaultAuthor, dryRun) {
|
|
99
|
+
const actions = [];
|
|
100
|
+
for (const rev of revisions) {
|
|
101
|
+
const author = rev.getAuthor();
|
|
102
|
+
if (!author || author.trim() === '') {
|
|
103
|
+
const issue = {
|
|
104
|
+
code: REVISION_RULES.MISSING_AUTHOR.code,
|
|
105
|
+
severity: 'error',
|
|
106
|
+
message: `Missing author for revision ${rev.getId()}`,
|
|
107
|
+
location: { revisionId: rev.getId() },
|
|
108
|
+
autoFixable: true,
|
|
109
|
+
};
|
|
110
|
+
actions.push({
|
|
111
|
+
issue,
|
|
112
|
+
action: `Set author to "${defaultAuthor}" for revision ${rev.getId()}`,
|
|
113
|
+
before: author,
|
|
114
|
+
after: defaultAuthor,
|
|
115
|
+
success: true,
|
|
116
|
+
});
|
|
117
|
+
if (!dryRun) {
|
|
118
|
+
rev.setAuthor(defaultAuthor);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return actions;
|
|
123
|
+
}
|
|
124
|
+
static fixMissingDates(revisions, dryRun) {
|
|
125
|
+
const actions = [];
|
|
126
|
+
const now = new Date();
|
|
127
|
+
for (const rev of revisions) {
|
|
128
|
+
const date = rev.getDate();
|
|
129
|
+
if (!date) {
|
|
130
|
+
const issue = {
|
|
131
|
+
code: REVISION_RULES.MISSING_DATE.code,
|
|
132
|
+
severity: 'warning',
|
|
133
|
+
message: `Missing date for revision ${rev.getId()}`,
|
|
134
|
+
location: { revisionId: rev.getId() },
|
|
135
|
+
autoFixable: true,
|
|
136
|
+
};
|
|
137
|
+
actions.push({
|
|
138
|
+
issue,
|
|
139
|
+
action: `Set date to ${now.toISOString()} for revision ${rev.getId()}`,
|
|
140
|
+
before: null,
|
|
141
|
+
after: now,
|
|
142
|
+
success: true,
|
|
143
|
+
});
|
|
144
|
+
if (!dryRun) {
|
|
145
|
+
rev.setDate(now);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return actions;
|
|
150
|
+
}
|
|
151
|
+
static fixInvalidDates(revisions, dryRun) {
|
|
152
|
+
const actions = [];
|
|
153
|
+
const now = new Date();
|
|
154
|
+
for (const rev of revisions) {
|
|
155
|
+
const date = rev.getDate();
|
|
156
|
+
if (date && isNaN(date.getTime())) {
|
|
157
|
+
const issue = {
|
|
158
|
+
code: REVISION_RULES.INVALID_DATE_FORMAT.code,
|
|
159
|
+
severity: 'warning',
|
|
160
|
+
message: `Invalid date for revision ${rev.getId()}`,
|
|
161
|
+
location: { revisionId: rev.getId() },
|
|
162
|
+
autoFixable: true,
|
|
163
|
+
};
|
|
164
|
+
actions.push({
|
|
165
|
+
issue,
|
|
166
|
+
action: `Replaced invalid date with ${now.toISOString()} for revision ${rev.getId()}`,
|
|
167
|
+
before: date,
|
|
168
|
+
after: now,
|
|
169
|
+
success: true,
|
|
170
|
+
});
|
|
171
|
+
if (!dryRun) {
|
|
172
|
+
rev.setDate(now);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
return actions;
|
|
177
|
+
}
|
|
178
|
+
static fixOrphanedMoveMarkers(revisionManager, revisions, dryRun) {
|
|
179
|
+
const actions = [];
|
|
180
|
+
const moveFromIds = new Map();
|
|
181
|
+
const moveToIds = new Map();
|
|
182
|
+
for (const rev of revisions) {
|
|
183
|
+
const moveId = rev.getMoveId();
|
|
184
|
+
if (!moveId)
|
|
185
|
+
continue;
|
|
186
|
+
if (rev.getType() === 'moveFrom') {
|
|
187
|
+
moveFromIds.set(moveId, rev);
|
|
188
|
+
}
|
|
189
|
+
else if (rev.getType() === 'moveTo') {
|
|
190
|
+
moveToIds.set(moveId, rev);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
for (const [moveId, rev] of moveFromIds) {
|
|
194
|
+
if (!moveToIds.has(moveId)) {
|
|
195
|
+
const issue = {
|
|
196
|
+
code: REVISION_RULES.ORPHANED_MOVE_FROM.code,
|
|
197
|
+
severity: 'error',
|
|
198
|
+
message: `Orphaned moveFrom with moveId="${moveId}"`,
|
|
199
|
+
location: { revisionId: rev.getId() },
|
|
200
|
+
autoFixable: true,
|
|
201
|
+
};
|
|
202
|
+
actions.push({
|
|
203
|
+
issue,
|
|
204
|
+
action: `Removed orphaned moveFrom (ID: ${rev.getId()}, moveId: ${moveId})`,
|
|
205
|
+
before: { type: 'moveFrom', moveId },
|
|
206
|
+
after: null,
|
|
207
|
+
success: true,
|
|
208
|
+
});
|
|
209
|
+
if (!dryRun) {
|
|
210
|
+
revisionManager.removeById(rev.getId());
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
for (const [moveId, rev] of moveToIds) {
|
|
215
|
+
if (!moveFromIds.has(moveId)) {
|
|
216
|
+
const issue = {
|
|
217
|
+
code: REVISION_RULES.ORPHANED_MOVE_TO.code,
|
|
218
|
+
severity: 'error',
|
|
219
|
+
message: `Orphaned moveTo with moveId="${moveId}"`,
|
|
220
|
+
location: { revisionId: rev.getId() },
|
|
221
|
+
autoFixable: true,
|
|
222
|
+
};
|
|
223
|
+
actions.push({
|
|
224
|
+
issue,
|
|
225
|
+
action: `Removed orphaned moveTo (ID: ${rev.getId()}, moveId: ${moveId})`,
|
|
226
|
+
before: { type: 'moveTo', moveId },
|
|
227
|
+
after: null,
|
|
228
|
+
success: true,
|
|
229
|
+
});
|
|
230
|
+
if (!dryRun) {
|
|
231
|
+
revisionManager.removeById(rev.getId());
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return actions;
|
|
236
|
+
}
|
|
237
|
+
static fixEmptyRevisions(revisionManager, revisions, dryRun) {
|
|
238
|
+
const actions = [];
|
|
239
|
+
const propertyChangeTypes = [
|
|
240
|
+
'runPropertiesChange',
|
|
241
|
+
'paragraphPropertiesChange',
|
|
242
|
+
'tablePropertiesChange',
|
|
243
|
+
'tableExceptionPropertiesChange',
|
|
244
|
+
'tableRowPropertiesChange',
|
|
245
|
+
'tableCellPropertiesChange',
|
|
246
|
+
'sectionPropertiesChange',
|
|
247
|
+
'numberingChange',
|
|
248
|
+
];
|
|
249
|
+
for (const rev of revisions) {
|
|
250
|
+
const type = rev.getType();
|
|
251
|
+
if (propertyChangeTypes.includes(type)) {
|
|
252
|
+
continue;
|
|
253
|
+
}
|
|
254
|
+
const runs = rev.getRuns();
|
|
255
|
+
const hasContent = runs.length > 0 && runs.some((r) => r.getText().length > 0);
|
|
256
|
+
if (!hasContent) {
|
|
257
|
+
const issue = {
|
|
258
|
+
code: REVISION_RULES.EMPTY_REVISION.code,
|
|
259
|
+
severity: 'warning',
|
|
260
|
+
message: `Empty revision ${rev.getId()} (type: ${type})`,
|
|
261
|
+
location: { revisionId: rev.getId() },
|
|
262
|
+
autoFixable: true,
|
|
263
|
+
};
|
|
264
|
+
actions.push({
|
|
265
|
+
issue,
|
|
266
|
+
action: `Removed empty revision (ID: ${rev.getId()}, type: ${type})`,
|
|
267
|
+
before: { id: rev.getId(), type },
|
|
268
|
+
after: null,
|
|
269
|
+
success: true,
|
|
270
|
+
});
|
|
271
|
+
if (!dryRun) {
|
|
272
|
+
revisionManager.removeById(rev.getId());
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
return actions;
|
|
277
|
+
}
|
|
278
|
+
static fixNonSequentialIds(revisions, dryRun) {
|
|
279
|
+
const actions = [];
|
|
280
|
+
if (revisions.length === 0)
|
|
281
|
+
return actions;
|
|
282
|
+
const ids = revisions.map((r) => r.getId()).sort((a, b) => a - b);
|
|
283
|
+
let isSequential = true;
|
|
284
|
+
for (let i = 1; i < ids.length; i++) {
|
|
285
|
+
const currentId = ids[i];
|
|
286
|
+
const prevId = ids[i - 1];
|
|
287
|
+
if (currentId !== prevId + 1) {
|
|
288
|
+
isSequential = false;
|
|
289
|
+
break;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
if (!isSequential) {
|
|
293
|
+
const issue = {
|
|
294
|
+
code: REVISION_RULES.NON_SEQUENTIAL_IDS.code,
|
|
295
|
+
severity: 'warning',
|
|
296
|
+
message: 'Revision IDs are not sequential',
|
|
297
|
+
autoFixable: true,
|
|
298
|
+
};
|
|
299
|
+
const oldIds = revisions.map((r) => r.getId());
|
|
300
|
+
const newIds = [];
|
|
301
|
+
revisions.forEach((rev, index) => {
|
|
302
|
+
newIds.push(index);
|
|
303
|
+
if (!dryRun) {
|
|
304
|
+
rev.setId(index);
|
|
305
|
+
}
|
|
306
|
+
});
|
|
307
|
+
actions.push({
|
|
308
|
+
issue,
|
|
309
|
+
action: `Reassigned ${revisions.length} revision IDs to be sequential (0 to ${revisions.length - 1})`,
|
|
310
|
+
before: oldIds,
|
|
311
|
+
after: newIds,
|
|
312
|
+
success: true,
|
|
313
|
+
});
|
|
314
|
+
}
|
|
315
|
+
return actions;
|
|
316
|
+
}
|
|
317
|
+
static preview(doc, options) {
|
|
318
|
+
return this.fix(doc, { ...options, dryRun: true });
|
|
319
|
+
}
|
|
320
|
+
static formatResult(result) {
|
|
321
|
+
const lines = [];
|
|
322
|
+
lines.push(`Auto-Fix ${result.allFixed ? 'COMPLETE' : 'PARTIAL'}`);
|
|
323
|
+
lines.push(`Fixed: ${result.issuesFixed}, Remaining: ${result.issuesRemaining}`);
|
|
324
|
+
if (result.actions.length > 0) {
|
|
325
|
+
lines.push('\nActions taken:');
|
|
326
|
+
for (const action of result.actions) {
|
|
327
|
+
const status = action.success ? 'OK' : 'FAILED';
|
|
328
|
+
lines.push(` [${status}] ${action.action}`);
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
if (result.errors.length > 0) {
|
|
332
|
+
lines.push('\nErrors:');
|
|
333
|
+
for (const error of result.errors) {
|
|
334
|
+
lines.push(` - ${error}`);
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
return lines.join('\n');
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
//# sourceMappingURL=RevisionAutoFixer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RevisionAutoFixer.js","sourceRoot":"","sources":["../../../src/validation/RevisionAutoFixer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RevisionAutoFixer - Automatically fixes revision validation issues\n *\n * Provides auto-fix capabilities for common revision compliance issues,\n * helping to prevent document corruption while preserving user intent.\n *\n * @module RevisionAutoFixer\n */\n\nimport type { Document } from '../core/Document.js';\nimport type { Revision } from '../elements/Revision.js';\nimport type { RevisionManager } from '../elements/RevisionManager.js';\nimport {\n REVISION_RULES,\n AutoFixOptions,\n AutoFixResult,\n FixAction,\n ValidationIssue,\n} from './ValidationRules.js';\nimport { RevisionValidator } from './RevisionValidator.js';\n\n/**\n * Automatically fixes revision validation issues.\n *\n * @example\n * ```typescript\n * // Auto-fix all issues\n * const result = RevisionAutoFixer.fix(doc);\n * console.log(`Fixed ${result.issuesFixed} issues`);\n *\n * // Dry run (preview fixes without applying)\n * const preview = RevisionAutoFixer.fix(doc, { dryRun: true });\n * for (const action of preview.actions) {\n * console.log(`Would fix: ${action.action}`);\n * }\n * ```\n */\nexport class RevisionAutoFixer {\n /**\n * Auto-fix all fixable issues in a document.\n *\n * @param doc - Document to fix\n * @param options - Fix options\n * @returns Result with details of all fixes applied\n */\n static fix(doc: Document, options?: AutoFixOptions): AutoFixResult {\n const actions: FixAction[] = [];\n const errors: string[] = [];\n const revisionManager = doc.getRevisionManager();\n\n if (!revisionManager) {\n return {\n allFixed: true,\n issuesFixed: 0,\n issuesRemaining: 0,\n actions: [],\n errors: [],\n };\n }\n\n const revisions = revisionManager.getAllRevisions();\n const skipRules = new Set(options?.skipRules || []);\n const onlyRules = options?.onlyRules ? new Set(options.onlyRules) : null;\n\n // Helper to check if a rule should be processed\n const shouldProcess = (ruleCode: string) => {\n if (skipRules.has(ruleCode)) return false;\n if (onlyRules && !onlyRules.has(ruleCode)) return false;\n return true;\n };\n\n try {\n // Fix duplicate IDs (REV001)\n if (shouldProcess('REV001')) {\n actions.push(...this.fixDuplicateIds(revisions, options?.dryRun));\n }\n\n // Fix missing authors (REV002)\n if (shouldProcess('REV002')) {\n const defaultAuthor = options?.defaultAuthor || 'Unknown Author';\n actions.push(...this.fixMissingAuthors(revisions, defaultAuthor, options?.dryRun));\n }\n\n // Fix orphaned move markers (REV003, REV004)\n if (shouldProcess('REV003') || shouldProcess('REV004')) {\n actions.push(...this.fixOrphanedMoveMarkers(revisionManager, revisions, options?.dryRun));\n }\n\n // Fix missing dates (REV101)\n if (shouldProcess('REV101')) {\n actions.push(...this.fixMissingDates(revisions, options?.dryRun));\n }\n\n // Fix invalid dates (REV102)\n if (shouldProcess('REV102')) {\n actions.push(...this.fixInvalidDates(revisions, options?.dryRun));\n }\n\n // Fix empty revisions (REV103)\n if (shouldProcess('REV103')) {\n actions.push(...this.fixEmptyRevisions(revisionManager, revisions, options?.dryRun));\n }\n\n // Fix non-sequential IDs (REV104)\n if (shouldProcess('REV104')) {\n actions.push(...this.fixNonSequentialIds(revisions, options?.dryRun));\n }\n } catch (error: unknown) {\n errors.push(`Fix error: ${error instanceof Error ? error.message : String(error)}`);\n }\n\n // Validate after fixes\n const postValidation = RevisionValidator.validate(doc);\n\n // Log actions if verbose\n if (options?.verbose) {\n for (const action of actions) {\n console.log(`[AutoFix] ${action.action}: ${action.issue.code}`);\n }\n }\n\n return {\n allFixed: postValidation.valid,\n issuesFixed: actions.filter((a) => a.success).length,\n issuesRemaining: postValidation.summary.errorCount + postValidation.summary.warningCount,\n actions,\n errors,\n };\n }\n\n /**\n * Fix duplicate revision IDs by reassigning.\n *\n * Assigns new unique IDs to revisions with duplicate IDs.\n *\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixDuplicateIds(revisions: Revision[], dryRun?: boolean): FixAction[] {\n const actions: FixAction[] = [];\n const usedIds = new Set<number>();\n let nextId = Math.max(...revisions.map((r) => r.getId()), 0) + 1;\n\n for (const rev of revisions) {\n const id = rev.getId();\n\n if (usedIds.has(id)) {\n const newId = nextId++;\n const issue: ValidationIssue = {\n code: REVISION_RULES.DUPLICATE_ID.code,\n severity: 'error',\n message: `Duplicate ID ${id}`,\n location: { revisionId: id },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Reassigned duplicate ID ${id} to ${newId}`,\n before: id,\n after: newId,\n success: true,\n });\n\n if (!dryRun) {\n rev.setId(newId);\n }\n }\n usedIds.add(rev.getId());\n }\n\n return actions;\n }\n\n /**\n * Fix missing authors by setting a default value.\n *\n * @param revisions - Array of revisions\n * @param defaultAuthor - Default author name to use\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixMissingAuthors(\n revisions: Revision[],\n defaultAuthor: string,\n dryRun?: boolean\n ): FixAction[] {\n const actions: FixAction[] = [];\n\n for (const rev of revisions) {\n const author = rev.getAuthor();\n\n if (!author || author.trim() === '') {\n const issue: ValidationIssue = {\n code: REVISION_RULES.MISSING_AUTHOR.code,\n severity: 'error',\n message: `Missing author for revision ${rev.getId()}`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Set author to \"${defaultAuthor}\" for revision ${rev.getId()}`,\n before: author,\n after: defaultAuthor,\n success: true,\n });\n\n if (!dryRun) {\n rev.setAuthor(defaultAuthor);\n }\n }\n }\n\n return actions;\n }\n\n /**\n * Fix missing dates by setting current date.\n *\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixMissingDates(revisions: Revision[], dryRun?: boolean): FixAction[] {\n const actions: FixAction[] = [];\n const now = new Date();\n\n for (const rev of revisions) {\n const date = rev.getDate();\n\n if (!date) {\n const issue: ValidationIssue = {\n code: REVISION_RULES.MISSING_DATE.code,\n severity: 'warning',\n message: `Missing date for revision ${rev.getId()}`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Set date to ${now.toISOString()} for revision ${rev.getId()}`,\n before: null,\n after: now,\n success: true,\n });\n\n if (!dryRun) {\n rev.setDate(now);\n }\n }\n }\n\n return actions;\n }\n\n /**\n * Fix invalid dates by replacing with current date.\n *\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixInvalidDates(revisions: Revision[], dryRun?: boolean): FixAction[] {\n const actions: FixAction[] = [];\n const now = new Date();\n\n for (const rev of revisions) {\n const date = rev.getDate();\n\n if (date && isNaN(date.getTime())) {\n const issue: ValidationIssue = {\n code: REVISION_RULES.INVALID_DATE_FORMAT.code,\n severity: 'warning',\n message: `Invalid date for revision ${rev.getId()}`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Replaced invalid date with ${now.toISOString()} for revision ${rev.getId()}`,\n before: date,\n after: now,\n success: true,\n });\n\n if (!dryRun) {\n rev.setDate(now);\n }\n }\n }\n\n return actions;\n }\n\n /**\n * Fix orphaned move markers by removing them.\n *\n * @param revisionManager - RevisionManager instance\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixOrphanedMoveMarkers(\n revisionManager: { removeById(id: number): boolean },\n revisions: Revision[],\n dryRun?: boolean\n ): FixAction[] {\n const actions: FixAction[] = [];\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 // Remove orphaned moveFrom\n for (const [moveId, rev] of moveFromIds) {\n if (!moveToIds.has(moveId)) {\n const issue: ValidationIssue = {\n code: REVISION_RULES.ORPHANED_MOVE_FROM.code,\n severity: 'error',\n message: `Orphaned moveFrom with moveId=\"${moveId}\"`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Removed orphaned moveFrom (ID: ${rev.getId()}, moveId: ${moveId})`,\n before: { type: 'moveFrom', moveId },\n after: null,\n success: true,\n });\n\n if (!dryRun) {\n revisionManager.removeById(rev.getId());\n }\n }\n }\n\n // Remove orphaned moveTo\n for (const [moveId, rev] of moveToIds) {\n if (!moveFromIds.has(moveId)) {\n const issue: ValidationIssue = {\n code: REVISION_RULES.ORPHANED_MOVE_TO.code,\n severity: 'error',\n message: `Orphaned moveTo with moveId=\"${moveId}\"`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Removed orphaned moveTo (ID: ${rev.getId()}, moveId: ${moveId})`,\n before: { type: 'moveTo', moveId },\n after: null,\n success: true,\n });\n\n if (!dryRun) {\n revisionManager.removeById(rev.getId());\n }\n }\n }\n\n return actions;\n }\n\n /**\n * Fix empty revisions by removing them.\n *\n * @param revisionManager - RevisionManager instance\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixEmptyRevisions(\n revisionManager: RevisionManager,\n revisions: Revision[],\n dryRun?: boolean\n ): FixAction[] {\n const actions: FixAction[] = [];\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 // Skip property changes\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 const issue: ValidationIssue = {\n code: REVISION_RULES.EMPTY_REVISION.code,\n severity: 'warning',\n message: `Empty revision ${rev.getId()} (type: ${type})`,\n location: { revisionId: rev.getId() },\n autoFixable: true,\n };\n\n actions.push({\n issue,\n action: `Removed empty revision (ID: ${rev.getId()}, type: ${type})`,\n before: { id: rev.getId(), type },\n after: null,\n success: true,\n });\n\n if (!dryRun) {\n revisionManager.removeById(rev.getId());\n }\n }\n }\n\n return actions;\n }\n\n /**\n * Fix non-sequential IDs by reassigning.\n *\n * @param revisions - Array of revisions\n * @param dryRun - If true, only report changes without applying\n * @returns Array of fix actions\n */\n static fixNonSequentialIds(revisions: Revision[], dryRun?: boolean): FixAction[] {\n const actions: FixAction[] = [];\n\n if (revisions.length === 0) return actions;\n\n // Check if IDs are already sequential\n const ids = revisions.map((r) => r.getId()).sort((a, b) => a - b);\n let isSequential = true;\n\n for (let i = 1; i < ids.length; i++) {\n const currentId = ids[i]!;\n const prevId = ids[i - 1]!;\n if (currentId !== prevId + 1) {\n isSequential = false;\n break;\n }\n }\n\n if (!isSequential) {\n const issue: ValidationIssue = {\n code: REVISION_RULES.NON_SEQUENTIAL_IDS.code,\n severity: 'warning',\n message: 'Revision IDs are not sequential',\n autoFixable: true,\n };\n\n const oldIds = revisions.map((r) => r.getId());\n const newIds: number[] = [];\n\n revisions.forEach((rev, index) => {\n newIds.push(index);\n if (!dryRun) {\n rev.setId(index);\n }\n });\n\n actions.push({\n issue,\n action: `Reassigned ${revisions.length} revision IDs to be sequential (0 to ${revisions.length - 1})`,\n before: oldIds,\n after: newIds,\n success: true,\n });\n }\n\n return actions;\n }\n\n /**\n * Preview fixes without applying them.\n *\n * Convenience method that calls fix() with dryRun: true.\n *\n * @param doc - Document to preview fixes for\n * @param options - Fix options (dryRun is forced to true)\n * @returns Result showing what would be fixed\n */\n static preview(doc: Document, options?: Omit<AutoFixOptions, 'dryRun'>): AutoFixResult {\n return this.fix(doc, { ...options, dryRun: true });\n }\n\n /**\n * Format fix result as a human-readable string.\n *\n * @param result - AutoFixResult to format\n * @returns Formatted string\n */\n static formatResult(result: AutoFixResult): string {\n const lines: string[] = [];\n\n lines.push(`Auto-Fix ${result.allFixed ? 'COMPLETE' : 'PARTIAL'}`);\n lines.push(`Fixed: ${result.issuesFixed}, Remaining: ${result.issuesRemaining}`);\n\n if (result.actions.length > 0) {\n lines.push('\\nActions taken:');\n for (const action of result.actions) {\n const status = action.success ? 'OK' : 'FAILED';\n lines.push(` [${status}] ${action.action}`);\n }\n }\n\n if (result.errors.length > 0) {\n lines.push('\\nErrors:');\n for (const error of result.errors) {\n lines.push(` - ${error}`);\n }\n }\n\n return lines.join('\\n');\n }\n}\n"]}
|
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
import { REVISION_RULES, createIssueFromRule, } from './ValidationRules.js';
|
|
2
|
+
import { ValidationRuleRegistry } from './ValidationRuleRegistry.js';
|
|
3
|
+
export class RevisionValidator {
|
|
4
|
+
static validate(doc, options) {
|
|
5
|
+
const revisionManager = doc.getRevisionManager();
|
|
6
|
+
const allIssues = [];
|
|
7
|
+
allIssues.push(...this.runCustomRules(doc));
|
|
8
|
+
if (!revisionManager) {
|
|
9
|
+
return this.finalize(allIssues, options);
|
|
10
|
+
}
|
|
11
|
+
const revisions = revisionManager.getAllRevisions();
|
|
12
|
+
const skipRules = new Set(options?.skipRules || []);
|
|
13
|
+
if (options?.level === 'lenient') {
|
|
14
|
+
skipRules.add('REV201');
|
|
15
|
+
skipRules.add('REV202');
|
|
16
|
+
}
|
|
17
|
+
if (!skipRules.has('REV001')) {
|
|
18
|
+
allIssues.push(...this.validateRevisionIds(revisions));
|
|
19
|
+
}
|
|
20
|
+
if (!skipRules.has('REV003') && !skipRules.has('REV004')) {
|
|
21
|
+
allIssues.push(...this.validateMovePairs(revisions));
|
|
22
|
+
}
|
|
23
|
+
if (!skipRules.has('REV002')) {
|
|
24
|
+
allIssues.push(...this.validateAuthors(revisions));
|
|
25
|
+
}
|
|
26
|
+
if (!skipRules.has('REV101') && !skipRules.has('REV102')) {
|
|
27
|
+
allIssues.push(...this.validateDates(revisions));
|
|
28
|
+
}
|
|
29
|
+
if (!skipRules.has('REV103')) {
|
|
30
|
+
allIssues.push(...this.validateContent(revisions));
|
|
31
|
+
}
|
|
32
|
+
if (!skipRules.has('REV104') && options?.level === 'strict') {
|
|
33
|
+
allIssues.push(...this.validateSequentialIds(revisions));
|
|
34
|
+
}
|
|
35
|
+
if (!skipRules.has('REV201')) {
|
|
36
|
+
allIssues.push(...this.validateRevisionCount(revisions));
|
|
37
|
+
}
|
|
38
|
+
if (!skipRules.has('REV202')) {
|
|
39
|
+
allIssues.push(...this.validateRevisionDates(revisions));
|
|
40
|
+
}
|
|
41
|
+
return this.finalize(allIssues, options);
|
|
42
|
+
}
|
|
43
|
+
static runCustomRules(doc) {
|
|
44
|
+
const customIssues = ValidationRuleRegistry.runAll(doc);
|
|
45
|
+
return customIssues.map((c) => ({
|
|
46
|
+
code: c.ruleCode,
|
|
47
|
+
severity: c.severity,
|
|
48
|
+
message: c.message,
|
|
49
|
+
location: c.location ? { element: c.location } : undefined,
|
|
50
|
+
autoFixable: false,
|
|
51
|
+
}));
|
|
52
|
+
}
|
|
53
|
+
static finalize(allIssues, options) {
|
|
54
|
+
const limitedIssues = options?.maxIssues ? allIssues.slice(0, options.maxIssues) : allIssues;
|
|
55
|
+
let errors = limitedIssues.filter((i) => i.severity === 'error');
|
|
56
|
+
let warnings = limitedIssues.filter((i) => i.severity === 'warning');
|
|
57
|
+
const infos = limitedIssues.filter((i) => i.severity === 'info');
|
|
58
|
+
const autoFixable = limitedIssues.filter((i) => i.autoFixable);
|
|
59
|
+
if (options?.warningsAsErrors) {
|
|
60
|
+
errors = [...errors, ...warnings];
|
|
61
|
+
warnings = [];
|
|
62
|
+
}
|
|
63
|
+
return {
|
|
64
|
+
valid: errors.length === 0,
|
|
65
|
+
errors,
|
|
66
|
+
warnings,
|
|
67
|
+
infos,
|
|
68
|
+
autoFixable,
|
|
69
|
+
summary: {
|
|
70
|
+
totalIssues: limitedIssues.length,
|
|
71
|
+
errorCount: errors.length,
|
|
72
|
+
warningCount: warnings.length,
|
|
73
|
+
infoCount: infos.length,
|
|
74
|
+
autoFixableCount: autoFixable.length,
|
|
75
|
+
},
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
static validateRevisionIds(revisions) {
|
|
79
|
+
const issues = [];
|
|
80
|
+
const seenIds = new Map();
|
|
81
|
+
revisions.forEach((rev, index) => {
|
|
82
|
+
const id = rev.getId();
|
|
83
|
+
if (!seenIds.has(id)) {
|
|
84
|
+
seenIds.set(id, []);
|
|
85
|
+
}
|
|
86
|
+
seenIds.get(id).push(index);
|
|
87
|
+
});
|
|
88
|
+
for (const [id, indices] of seenIds) {
|
|
89
|
+
if (indices.length > 1) {
|
|
90
|
+
const rule = REVISION_RULES.DUPLICATE_ID;
|
|
91
|
+
if (rule) {
|
|
92
|
+
issues.push(createIssueFromRule(rule, { revisionId: id }, `Duplicate revision ID ${id} found at ${indices.length} locations (indices: ${indices.join(', ')})`));
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return issues;
|
|
97
|
+
}
|
|
98
|
+
static validateMovePairs(revisions) {
|
|
99
|
+
const issues = [];
|
|
100
|
+
const moveFromIds = new Map();
|
|
101
|
+
const moveToIds = new Map();
|
|
102
|
+
for (const rev of revisions) {
|
|
103
|
+
const moveId = rev.getMoveId();
|
|
104
|
+
if (!moveId)
|
|
105
|
+
continue;
|
|
106
|
+
if (rev.getType() === 'moveFrom') {
|
|
107
|
+
moveFromIds.set(moveId, rev);
|
|
108
|
+
}
|
|
109
|
+
else if (rev.getType() === 'moveTo') {
|
|
110
|
+
moveToIds.set(moveId, rev);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
for (const [moveId, rev] of moveFromIds) {
|
|
114
|
+
if (!moveToIds.has(moveId)) {
|
|
115
|
+
issues.push(createIssueFromRule(REVISION_RULES.ORPHANED_MOVE_FROM, { revisionId: rev.getId() }, `moveFrom with moveId="${moveId}" has no matching moveTo`));
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
for (const [moveId, rev] of moveToIds) {
|
|
119
|
+
if (!moveFromIds.has(moveId)) {
|
|
120
|
+
issues.push(createIssueFromRule(REVISION_RULES.ORPHANED_MOVE_TO, { revisionId: rev.getId() }, `moveTo with moveId="${moveId}" has no matching moveFrom`));
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return issues;
|
|
124
|
+
}
|
|
125
|
+
static validateAuthors(revisions) {
|
|
126
|
+
const issues = [];
|
|
127
|
+
for (const rev of revisions) {
|
|
128
|
+
const author = rev.getAuthor();
|
|
129
|
+
if (!author || author.trim() === '') {
|
|
130
|
+
issues.push(createIssueFromRule(REVISION_RULES.MISSING_AUTHOR, { revisionId: rev.getId() }));
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return issues;
|
|
134
|
+
}
|
|
135
|
+
static validateDates(revisions) {
|
|
136
|
+
const issues = [];
|
|
137
|
+
for (const rev of revisions) {
|
|
138
|
+
const date = rev.getDate();
|
|
139
|
+
if (!date) {
|
|
140
|
+
issues.push(createIssueFromRule(REVISION_RULES.MISSING_DATE, { revisionId: rev.getId() }));
|
|
141
|
+
}
|
|
142
|
+
else if (isNaN(date.getTime())) {
|
|
143
|
+
issues.push(createIssueFromRule(REVISION_RULES.INVALID_DATE_FORMAT, { revisionId: rev.getId() }, `Revision ${rev.getId()} has an invalid date`));
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
return issues;
|
|
147
|
+
}
|
|
148
|
+
static validateContent(revisions) {
|
|
149
|
+
const issues = [];
|
|
150
|
+
const propertyChangeTypes = [
|
|
151
|
+
'runPropertiesChange',
|
|
152
|
+
'paragraphPropertiesChange',
|
|
153
|
+
'tablePropertiesChange',
|
|
154
|
+
'tableExceptionPropertiesChange',
|
|
155
|
+
'tableRowPropertiesChange',
|
|
156
|
+
'tableCellPropertiesChange',
|
|
157
|
+
'sectionPropertiesChange',
|
|
158
|
+
'numberingChange',
|
|
159
|
+
];
|
|
160
|
+
for (const rev of revisions) {
|
|
161
|
+
const type = rev.getType();
|
|
162
|
+
if (propertyChangeTypes.includes(type)) {
|
|
163
|
+
continue;
|
|
164
|
+
}
|
|
165
|
+
const runs = rev.getRuns();
|
|
166
|
+
const hasContent = runs.length > 0 && runs.some((r) => r.getText().length > 0);
|
|
167
|
+
if (!hasContent) {
|
|
168
|
+
issues.push(createIssueFromRule(REVISION_RULES.EMPTY_REVISION, { revisionId: rev.getId() }, `Revision ${rev.getId()} (type: ${type}) has no content`));
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
return issues;
|
|
172
|
+
}
|
|
173
|
+
static validateSequentialIds(revisions) {
|
|
174
|
+
const issues = [];
|
|
175
|
+
if (revisions.length === 0)
|
|
176
|
+
return issues;
|
|
177
|
+
const idSet = new Set(revisions.map((r) => r.getId()));
|
|
178
|
+
const ids = Array.from(idSet);
|
|
179
|
+
if (ids.length === 0)
|
|
180
|
+
return issues;
|
|
181
|
+
const minId = Math.min(...ids);
|
|
182
|
+
const maxId = Math.max(...ids);
|
|
183
|
+
const missingIds = [];
|
|
184
|
+
for (let i = minId; i <= maxId; i++) {
|
|
185
|
+
if (!idSet.has(i)) {
|
|
186
|
+
missingIds.push(i);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
if (missingIds.length > 0) {
|
|
190
|
+
issues.push(createIssueFromRule(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)` : ''}`));
|
|
191
|
+
}
|
|
192
|
+
return issues;
|
|
193
|
+
}
|
|
194
|
+
static validateRevisionCount(revisions) {
|
|
195
|
+
const issues = [];
|
|
196
|
+
if (revisions.length > 1000) {
|
|
197
|
+
issues.push(createIssueFromRule(REVISION_RULES.LARGE_REVISION_COUNT, undefined, `Document has ${revisions.length} revisions (>1000). Consider accepting or rejecting some.`));
|
|
198
|
+
}
|
|
199
|
+
return issues;
|
|
200
|
+
}
|
|
201
|
+
static validateRevisionDates(revisions) {
|
|
202
|
+
const issues = [];
|
|
203
|
+
const oneYearAgo = new Date();
|
|
204
|
+
oneYearAgo.setFullYear(oneYearAgo.getFullYear() - 1);
|
|
205
|
+
let oldCount = 0;
|
|
206
|
+
for (const rev of revisions) {
|
|
207
|
+
const date = rev.getDate();
|
|
208
|
+
if (date && date < oneYearAgo) {
|
|
209
|
+
oldCount++;
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
if (oldCount > 0) {
|
|
213
|
+
issues.push(createIssueFromRule(REVISION_RULES.OLD_REVISION_DATE, undefined, `${oldCount} revision(s) are older than 1 year. Consider reviewing and accepting.`));
|
|
214
|
+
}
|
|
215
|
+
return issues;
|
|
216
|
+
}
|
|
217
|
+
static isValid(doc) {
|
|
218
|
+
const result = this.validate(doc, { level: 'normal' });
|
|
219
|
+
return result.valid;
|
|
220
|
+
}
|
|
221
|
+
static formatSummary(result) {
|
|
222
|
+
const lines = [];
|
|
223
|
+
lines.push(`Validation ${result.valid ? 'PASSED' : 'FAILED'}`);
|
|
224
|
+
lines.push(`Total issues: ${result.summary.totalIssues}`);
|
|
225
|
+
if (result.summary.errorCount > 0) {
|
|
226
|
+
lines.push(` Errors: ${result.summary.errorCount}`);
|
|
227
|
+
}
|
|
228
|
+
if (result.summary.warningCount > 0) {
|
|
229
|
+
lines.push(` Warnings: ${result.summary.warningCount}`);
|
|
230
|
+
}
|
|
231
|
+
if (result.summary.infoCount > 0) {
|
|
232
|
+
lines.push(` Info: ${result.summary.infoCount}`);
|
|
233
|
+
}
|
|
234
|
+
if (result.summary.autoFixableCount > 0) {
|
|
235
|
+
lines.push(` Auto-fixable: ${result.summary.autoFixableCount}`);
|
|
236
|
+
}
|
|
237
|
+
return lines.join('\n');
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
//# sourceMappingURL=RevisionValidator.js.map
|