@cj-tech-master/excelts 9.4.2 → 9.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.browser.d.ts +8 -5
- package/dist/browser/index.browser.js +19 -1
- package/dist/browser/index.d.ts +4 -2
- package/dist/browser/index.js +9 -1
- package/dist/browser/modules/excel/chart/cache-populator.d.ts +49 -0
- package/dist/browser/modules/excel/chart/cache-populator.js +1171 -0
- package/dist/browser/modules/excel/chart/chart-api.d.ts +92 -0
- package/dist/browser/modules/excel/chart/chart-api.js +364 -0
- package/dist/browser/modules/excel/chart/chart-builder.d.ts +48 -0
- package/dist/browser/modules/excel/chart/chart-builder.js +2432 -0
- package/dist/browser/modules/excel/chart/chart-ex-builder.d.ts +36 -0
- package/dist/browser/modules/excel/chart/chart-ex-builder.js +903 -0
- package/dist/browser/modules/excel/chart/chart-ex-parser.d.ts +8 -0
- package/dist/browser/modules/excel/chart/chart-ex-parser.js +1205 -0
- package/dist/browser/modules/excel/chart/chart-ex-renderer.d.ts +187 -0
- package/dist/browser/modules/excel/chart/chart-ex-renderer.js +5352 -0
- package/dist/browser/modules/excel/chart/chart-ex-types.d.ts +531 -0
- package/dist/browser/modules/excel/chart/chart-ex-types.js +11 -0
- package/dist/browser/modules/excel/chart/chart-images.d.ts +78 -0
- package/dist/browser/modules/excel/chart/chart-images.js +363 -0
- package/dist/browser/modules/excel/chart/chart-presets.d.ts +392 -0
- package/dist/browser/modules/excel/chart/chart-presets.js +179 -0
- package/dist/browser/modules/excel/chart/chart-renderer.d.ts +550 -0
- package/dist/browser/modules/excel/chart/chart-renderer.js +6440 -0
- package/dist/browser/modules/excel/chart/chart-sidecar.d.ts +21 -0
- package/dist/browser/modules/excel/chart/chart-sidecar.js +427 -0
- package/dist/browser/modules/excel/chart/chart-utils.d.ts +306 -0
- package/dist/browser/modules/excel/chart/chart-utils.js +821 -0
- package/dist/browser/modules/excel/chart/chart.d.ts +504 -0
- package/dist/browser/modules/excel/chart/chart.js +1320 -0
- package/dist/browser/modules/excel/chart/glyph-rasterizer.d.ts +62 -0
- package/dist/browser/modules/excel/chart/glyph-rasterizer.js +658 -0
- package/dist/browser/modules/excel/chart/index.d.ts +54 -0
- package/dist/browser/modules/excel/chart/index.js +46 -0
- package/dist/browser/modules/excel/chart/install.d.ts +44 -0
- package/dist/browser/modules/excel/chart/install.js +91 -0
- package/dist/browser/modules/excel/chart/shape-properties.d.ts +156 -0
- package/dist/browser/modules/excel/chart/shape-properties.js +1557 -0
- package/dist/browser/modules/excel/chart/stroke-font.d.ts +36 -0
- package/dist/browser/modules/excel/chart/stroke-font.js +1556 -0
- package/dist/browser/modules/excel/chart/topojson.d.ts +98 -0
- package/dist/browser/modules/excel/chart/topojson.js +236 -0
- package/dist/browser/modules/excel/chart/types.d.ts +2559 -0
- package/dist/browser/modules/excel/chart/types.js +8 -0
- package/dist/browser/modules/excel/chart-host-registry.d.ts +157 -0
- package/dist/browser/modules/excel/chart-host-registry.js +90 -0
- package/dist/browser/modules/excel/chartsheet.d.ts +102 -0
- package/dist/browser/modules/excel/chartsheet.js +196 -0
- package/dist/browser/modules/excel/defined-names.d.ts +35 -0
- package/dist/browser/modules/excel/defined-names.js +44 -4
- package/dist/browser/modules/excel/errors.d.ts +6 -0
- package/dist/browser/modules/excel/errors.js +9 -0
- package/dist/browser/modules/excel/form-control.d.ts +6 -0
- package/dist/browser/modules/excel/form-control.js +17 -0
- package/dist/browser/modules/excel/image.js +12 -2
- package/dist/browser/modules/excel/pivot-chart.d.ts +7 -0
- package/dist/browser/modules/excel/pivot-chart.js +53 -0
- package/dist/browser/modules/excel/pivot-table.d.ts +55 -0
- package/dist/browser/modules/excel/pivot-table.js +35 -0
- package/dist/browser/modules/excel/range.js +5 -1
- package/dist/browser/modules/excel/sparkline/index.d.ts +7 -0
- package/dist/browser/modules/excel/sparkline/index.js +7 -0
- package/dist/browser/modules/excel/sparkline/sparkline.d.ts +206 -0
- package/dist/browser/modules/excel/sparkline/sparkline.js +750 -0
- package/dist/browser/modules/excel/stream/worksheet-writer.js +3 -2
- package/dist/browser/modules/excel/table.js +42 -6
- package/dist/browser/modules/excel/types.d.ts +72 -0
- package/dist/browser/modules/excel/utils/address.d.ts +18 -0
- package/dist/browser/modules/excel/utils/address.js +28 -0
- package/dist/browser/modules/excel/utils/drawing-utils.js +11 -6
- package/dist/browser/modules/excel/utils/guid.d.ts +15 -0
- package/dist/browser/modules/excel/utils/guid.js +35 -0
- package/dist/browser/modules/excel/utils/ooxml-paths.d.ts +74 -0
- package/dist/browser/modules/excel/utils/ooxml-paths.js +206 -9
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chart-sidecar.d.ts +35 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chart-sidecar.js +101 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chart.d.ts +32 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chart.js +2125 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chartsheet.d.ts +9 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-chartsheet.js +26 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-content-types.d.ts +16 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-content-types.js +181 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-drawing.d.ts +34 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-drawing.js +267 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-pivot.d.ts +14 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-pivot.js +104 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-relationships.d.ts +18 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-relationships.js +184 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-structure.d.ts +21 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-structure.js +56 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-styles.d.ts +15 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-styles.js +89 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-table.d.ts +31 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-table.js +177 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-workbook.d.ts +19 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-workbook.js +163 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-worksheet.d.ts +25 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/check-worksheet.js +569 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/context.d.ts +85 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/context.js +191 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/index.d.ts +31 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/index.js +102 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/path-utils.d.ts +67 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/path-utils.js +156 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/reporter.d.ts +41 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/reporter.js +61 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/types.d.ts +109 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/types.js +12 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/xml-utils.d.ts +38 -0
- package/dist/browser/modules/excel/utils/ooxml-validator/xml-utils.js +100 -0
- package/dist/browser/modules/excel/workbook.browser.d.ts +248 -30
- package/dist/browser/modules/excel/workbook.browser.js +966 -31
- package/dist/browser/modules/excel/workbook.d.ts +43 -0
- package/dist/browser/modules/excel/workbook.js +48 -0
- package/dist/browser/modules/excel/worksheet.d.ts +157 -3
- package/dist/browser/modules/excel/worksheet.js +394 -35
- package/dist/browser/modules/excel/xlsx/rel-type.d.ts +40 -0
- package/dist/browser/modules/excel/xlsx/rel-type.js +41 -1
- package/dist/browser/modules/excel/xlsx/xform/book/defined-name-xform.d.ts +1 -0
- package/dist/browser/modules/excel/xlsx/xform/book/defined-name-xform.js +11 -2
- package/dist/browser/modules/excel/xlsx/xform/book/external-link-xform.js +12 -10
- package/dist/browser/modules/excel/xlsx/xform/book/workbook-xform.js +96 -22
- package/dist/browser/modules/excel/xlsx/xform/chart/chart-space-xform.d.ts +353 -0
- package/dist/browser/modules/excel/xlsx/xform/chart/chart-space-xform.js +6000 -0
- package/dist/browser/modules/excel/xlsx/xform/comment/threaded-comments-xform.d.ts +60 -0
- package/dist/browser/modules/excel/xlsx/xform/comment/threaded-comments-xform.js +213 -0
- package/dist/browser/modules/excel/xlsx/xform/core/content-types-xform.js +150 -11
- package/dist/browser/modules/excel/xlsx/xform/drawing/absolute-anchor-xform.js +20 -1
- package/dist/browser/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.js +1 -1
- package/dist/browser/modules/excel/xlsx/xform/drawing/drawing-xform.d.ts +30 -0
- package/dist/browser/modules/excel/xlsx/xform/drawing/drawing-xform.js +109 -5
- package/dist/browser/modules/excel/xlsx/xform/drawing/graphic-frame-xform.d.ts +54 -0
- package/dist/browser/modules/excel/xlsx/xform/drawing/graphic-frame-xform.js +225 -0
- package/dist/browser/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.d.ts +3 -1
- package/dist/browser/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.js +18 -3
- package/dist/browser/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.d.ts +46 -0
- package/dist/browser/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.js +294 -12
- package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +13 -2
- package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +32 -6
- package/dist/browser/modules/excel/xlsx/xform/sheet/chartsheet-xform.d.ts +185 -0
- package/dist/browser/modules/excel/xlsx/xform/sheet/chartsheet-xform.js +441 -0
- package/dist/browser/modules/excel/xlsx/xform/sheet/ext-lst-xform.d.ts +1 -0
- package/dist/browser/modules/excel/xlsx/xform/sheet/ext-lst-xform.js +51 -2
- package/dist/browser/modules/excel/xlsx/xform/sheet/worksheet-xform.js +196 -20
- package/dist/browser/modules/excel/xlsx/xform/table/auto-filter-xform.js +16 -1
- package/dist/browser/modules/excel/xlsx/xform/table/table-column-xform.js +17 -2
- package/dist/browser/modules/excel/xlsx/xform/xsd-values.d.ts +63 -0
- package/dist/browser/modules/excel/xlsx/xform/xsd-values.js +101 -0
- package/dist/browser/modules/excel/xlsx/xlsx.browser.d.ts +115 -21
- package/dist/browser/modules/excel/xlsx/xlsx.browser.js +4422 -78
- package/dist/browser/modules/pdf/builder/document-builder.d.ts +74 -0
- package/dist/browser/modules/pdf/builder/document-builder.js +507 -2
- package/dist/browser/modules/pdf/builder/pdf-editor.js +48 -3
- package/dist/browser/modules/pdf/excel-bridge.d.ts +69 -0
- package/dist/browser/modules/pdf/excel-bridge.js +683 -12
- package/dist/browser/modules/pdf/font/font-manager.d.ts +25 -0
- package/dist/browser/modules/pdf/font/font-manager.js +39 -0
- package/dist/browser/modules/pdf/index.d.ts +5 -2
- package/dist/browser/modules/pdf/index.js +3 -1
- package/dist/browser/modules/pdf/render/chart-surface.d.ts +33 -0
- package/dist/browser/modules/pdf/render/chart-surface.js +200 -0
- package/dist/browser/modules/pdf/render/layout-engine.d.ts +22 -1
- package/dist/browser/modules/pdf/render/layout-engine.js +436 -56
- package/dist/browser/modules/pdf/render/page-renderer.js +169 -28
- package/dist/browser/modules/pdf/render/pdf-exporter.js +117 -7
- package/dist/browser/modules/pdf/types.d.ts +227 -23
- package/dist/browser/modules/pdf/types.js +4 -0
- package/dist/browser/modules/pdf/word-bridge.d.ts +47 -0
- package/dist/browser/modules/pdf/word-bridge.js +304 -0
- package/dist/browser/modules/word/constants.d.ts +179 -0
- package/dist/browser/modules/word/constants.js +231 -0
- package/dist/browser/modules/word/content-types.d.ts +27 -0
- package/dist/browser/modules/word/content-types.js +53 -0
- package/dist/browser/modules/word/digital-signatures.d.ts +87 -0
- package/dist/browser/modules/word/digital-signatures.js +134 -0
- package/dist/browser/modules/word/document.d.ts +728 -0
- package/dist/browser/modules/word/document.js +1795 -0
- package/dist/browser/modules/word/docx-packager.d.ts +14 -0
- package/dist/browser/modules/word/docx-packager.js +822 -0
- package/dist/browser/modules/word/docx-reader.d.ts +11 -0
- package/dist/browser/modules/word/docx-reader.js +4929 -0
- package/dist/browser/modules/word/encryption.d.ts +102 -0
- package/dist/browser/modules/word/encryption.js +274 -0
- package/dist/browser/modules/word/errors.d.ts +49 -0
- package/dist/browser/modules/word/errors.js +68 -0
- package/dist/browser/modules/word/font-obfuscation.d.ts +31 -0
- package/dist/browser/modules/word/font-obfuscation.js +83 -0
- package/dist/browser/modules/word/html-renderer.d.ts +38 -0
- package/dist/browser/modules/word/html-renderer.js +782 -0
- package/dist/browser/modules/word/index.base.d.ts +19 -0
- package/dist/browser/modules/word/index.base.js +51 -0
- package/dist/browser/modules/word/index.browser.d.ts +4 -0
- package/dist/browser/modules/word/index.browser.js +4 -0
- package/dist/browser/modules/word/index.d.ts +4 -0
- package/dist/browser/modules/word/index.js +4 -0
- package/dist/browser/modules/word/internal-utils.d.ts +23 -0
- package/dist/browser/modules/word/internal-utils.js +54 -0
- package/dist/browser/modules/word/relationships.d.ts +31 -0
- package/dist/browser/modules/word/relationships.js +56 -0
- package/dist/browser/modules/word/types.d.ts +2325 -0
- package/dist/browser/modules/word/types.js +10 -0
- package/dist/browser/modules/word/units.d.ts +49 -0
- package/dist/browser/modules/word/units.js +111 -0
- package/dist/browser/modules/word/writers/chart-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/chart-writer.js +385 -0
- package/dist/browser/modules/word/writers/checkbox-writer.d.ts +9 -0
- package/dist/browser/modules/word/writers/checkbox-writer.js +42 -0
- package/dist/browser/modules/word/writers/comment-writer.d.ts +15 -0
- package/dist/browser/modules/word/writers/comment-writer.js +70 -0
- package/dist/browser/modules/word/writers/document-writer.d.ts +16 -0
- package/dist/browser/modules/word/writers/document-writer.js +461 -0
- package/dist/browser/modules/word/writers/footnote-writer.d.ts +11 -0
- package/dist/browser/modules/word/writers/footnote-writer.js +72 -0
- package/dist/browser/modules/word/writers/header-footer-writer.d.ts +13 -0
- package/dist/browser/modules/word/writers/header-footer-writer.js +129 -0
- package/dist/browser/modules/word/writers/image-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/image-writer.js +185 -0
- package/dist/browser/modules/word/writers/math-writer.d.ts +9 -0
- package/dist/browser/modules/word/writers/math-writer.js +428 -0
- package/dist/browser/modules/word/writers/numbering-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/numbering-writer.js +125 -0
- package/dist/browser/modules/word/writers/paragraph-writer.d.ts +13 -0
- package/dist/browser/modules/word/writers/paragraph-writer.js +516 -0
- package/dist/browser/modules/word/writers/parts-writer.d.ts +26 -0
- package/dist/browser/modules/word/writers/parts-writer.js +660 -0
- package/dist/browser/modules/word/writers/run-writer.d.ts +15 -0
- package/dist/browser/modules/word/writers/run-writer.js +649 -0
- package/dist/browser/modules/word/writers/section-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/section-writer.js +238 -0
- package/dist/browser/modules/word/writers/styles-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/styles-writer.js +242 -0
- package/dist/browser/modules/word/writers/table-writer.d.ts +10 -0
- package/dist/browser/modules/word/writers/table-writer.js +503 -0
- package/dist/browser/modules/word/writers/textbox-writer.d.ts +9 -0
- package/dist/browser/modules/word/writers/textbox-writer.js +53 -0
- package/dist/browser/modules/word/writers/toc-writer.d.ts +9 -0
- package/dist/browser/modules/word/writers/toc-writer.js +79 -0
- package/dist/browser/modules/xml/encode.d.ts +56 -7
- package/dist/browser/modules/xml/encode.js +157 -11
- package/dist/cjs/index.js +13 -2
- package/dist/cjs/modules/excel/chart/cache-populator.js +1178 -0
- package/dist/cjs/modules/excel/chart/chart-api.js +371 -0
- package/dist/cjs/modules/excel/chart/chart-builder.js +2440 -0
- package/dist/cjs/modules/excel/chart/chart-ex-builder.js +907 -0
- package/dist/cjs/modules/excel/chart/chart-ex-parser.js +1208 -0
- package/dist/cjs/modules/excel/chart/chart-ex-renderer.js +5364 -0
- package/dist/cjs/modules/excel/chart/chart-ex-types.js +12 -0
- package/dist/cjs/modules/excel/chart/chart-images.js +366 -0
- package/dist/cjs/modules/excel/chart/chart-presets.js +184 -0
- package/dist/cjs/modules/excel/chart/chart-renderer.js +6450 -0
- package/dist/cjs/modules/excel/chart/chart-sidecar.js +433 -0
- package/dist/cjs/modules/excel/chart/chart-utils.js +845 -0
- package/dist/cjs/modules/excel/chart/chart.js +1324 -0
- package/dist/cjs/modules/excel/chart/glyph-rasterizer.js +664 -0
- package/dist/cjs/modules/excel/chart/index.js +101 -0
- package/dist/cjs/modules/excel/chart/install.js +95 -0
- package/dist/cjs/modules/excel/chart/shape-properties.js +1577 -0
- package/dist/cjs/modules/excel/chart/stroke-font.js +1559 -0
- package/dist/cjs/modules/excel/chart/topojson.js +239 -0
- package/dist/cjs/modules/excel/chart/types.js +9 -0
- package/dist/cjs/modules/excel/chart-host-registry.js +96 -0
- package/dist/cjs/modules/excel/chartsheet.js +199 -0
- package/dist/cjs/modules/excel/defined-names.js +44 -4
- package/dist/cjs/modules/excel/errors.js +11 -1
- package/dist/cjs/modules/excel/form-control.js +17 -0
- package/dist/cjs/modules/excel/image.js +12 -2
- package/dist/cjs/modules/excel/pivot-chart.js +56 -0
- package/dist/cjs/modules/excel/pivot-table.js +35 -0
- package/dist/cjs/modules/excel/range.js +5 -1
- package/dist/cjs/modules/excel/sparkline/index.js +23 -0
- package/dist/cjs/modules/excel/sparkline/sparkline.js +756 -0
- package/dist/cjs/modules/excel/stream/worksheet-writer.js +3 -2
- package/dist/cjs/modules/excel/table.js +42 -6
- package/dist/cjs/modules/excel/utils/address.js +29 -0
- package/dist/cjs/modules/excel/utils/drawing-utils.js +11 -6
- package/dist/cjs/modules/excel/utils/guid.js +38 -0
- package/dist/cjs/modules/excel/utils/ooxml-paths.js +246 -9
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-chart-sidecar.js +103 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-chart.js +2128 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-chartsheet.js +29 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-content-types.js +184 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-drawing.js +270 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-pivot.js +107 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-relationships.js +188 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-structure.js +60 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-styles.js +92 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-table.js +180 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-workbook.js +166 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/check-worksheet.js +572 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/context.js +196 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/index.js +105 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/path-utils.js +168 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/reporter.js +66 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/types.js +13 -0
- package/dist/cjs/modules/excel/utils/ooxml-validator/xml-utils.js +110 -0
- package/dist/cjs/modules/excel/workbook.browser.js +973 -38
- package/dist/cjs/modules/excel/workbook.js +48 -0
- package/dist/cjs/modules/excel/worksheet.js +393 -34
- package/dist/cjs/modules/excel/xlsx/rel-type.js +41 -1
- package/dist/cjs/modules/excel/xlsx/xform/book/defined-name-xform.js +11 -2
- package/dist/cjs/modules/excel/xlsx/xform/book/external-link-xform.js +12 -10
- package/dist/cjs/modules/excel/xlsx/xform/book/workbook-xform.js +96 -22
- package/dist/cjs/modules/excel/xlsx/xform/chart/chart-space-xform.js +6003 -0
- package/dist/cjs/modules/excel/xlsx/xform/comment/threaded-comments-xform.js +219 -0
- package/dist/cjs/modules/excel/xlsx/xform/core/content-types-xform.js +149 -10
- package/dist/cjs/modules/excel/xlsx/xform/drawing/absolute-anchor-xform.js +20 -1
- package/dist/cjs/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.js +1 -1
- package/dist/cjs/modules/excel/xlsx/xform/drawing/drawing-xform.js +109 -5
- package/dist/cjs/modules/excel/xlsx/xform/drawing/graphic-frame-xform.js +228 -0
- package/dist/cjs/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.js +18 -3
- package/dist/cjs/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.js +294 -12
- package/dist/cjs/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +32 -6
- package/dist/cjs/modules/excel/xlsx/xform/sheet/chartsheet-xform.js +444 -0
- package/dist/cjs/modules/excel/xlsx/xform/sheet/ext-lst-xform.js +51 -2
- package/dist/cjs/modules/excel/xlsx/xform/sheet/worksheet-xform.js +195 -19
- package/dist/cjs/modules/excel/xlsx/xform/table/auto-filter-xform.js +16 -1
- package/dist/cjs/modules/excel/xlsx/xform/table/table-column-xform.js +17 -2
- package/dist/cjs/modules/excel/xlsx/xform/xsd-values.js +106 -0
- package/dist/cjs/modules/excel/xlsx/xlsx.browser.js +4420 -76
- package/dist/cjs/modules/pdf/builder/document-builder.js +506 -1
- package/dist/cjs/modules/pdf/builder/pdf-editor.js +48 -3
- package/dist/cjs/modules/pdf/excel-bridge.js +684 -12
- package/dist/cjs/modules/pdf/font/font-manager.js +39 -0
- package/dist/cjs/modules/pdf/index.js +5 -1
- package/dist/cjs/modules/pdf/render/chart-surface.js +203 -0
- package/dist/cjs/modules/pdf/render/layout-engine.js +437 -56
- package/dist/cjs/modules/pdf/render/page-renderer.js +169 -28
- package/dist/cjs/modules/pdf/render/pdf-exporter.js +115 -5
- package/dist/cjs/modules/pdf/types.js +5 -0
- package/dist/cjs/modules/pdf/word-bridge.js +307 -0
- package/dist/cjs/modules/word/constants.js +234 -0
- package/dist/cjs/modules/word/content-types.js +57 -0
- package/dist/cjs/modules/word/digital-signatures.js +140 -0
- package/dist/cjs/modules/word/document.js +1909 -0
- package/dist/cjs/modules/word/docx-packager.js +825 -0
- package/dist/cjs/modules/word/docx-reader.js +4932 -0
- package/dist/cjs/modules/word/encryption.js +282 -0
- package/dist/cjs/modules/word/errors.js +88 -0
- package/dist/cjs/modules/word/font-obfuscation.js +88 -0
- package/dist/cjs/modules/word/html-renderer.js +785 -0
- package/dist/cjs/modules/word/index.base.js +199 -0
- package/dist/cjs/modules/word/index.browser.js +20 -0
- package/dist/cjs/modules/word/index.js +20 -0
- package/dist/cjs/modules/word/internal-utils.js +59 -0
- package/dist/cjs/modules/word/relationships.js +60 -0
- package/dist/cjs/modules/word/types.js +11 -0
- package/dist/cjs/modules/word/units.js +135 -0
- package/dist/cjs/modules/word/writers/chart-writer.js +388 -0
- package/dist/cjs/modules/word/writers/checkbox-writer.js +45 -0
- package/dist/cjs/modules/word/writers/comment-writer.js +74 -0
- package/dist/cjs/modules/word/writers/document-writer.js +465 -0
- package/dist/cjs/modules/word/writers/footnote-writer.js +76 -0
- package/dist/cjs/modules/word/writers/header-footer-writer.js +134 -0
- package/dist/cjs/modules/word/writers/image-writer.js +188 -0
- package/dist/cjs/modules/word/writers/math-writer.js +431 -0
- package/dist/cjs/modules/word/writers/numbering-writer.js +128 -0
- package/dist/cjs/modules/word/writers/paragraph-writer.js +521 -0
- package/dist/cjs/modules/word/writers/parts-writer.js +671 -0
- package/dist/cjs/modules/word/writers/run-writer.js +655 -0
- package/dist/cjs/modules/word/writers/section-writer.js +241 -0
- package/dist/cjs/modules/word/writers/styles-writer.js +245 -0
- package/dist/cjs/modules/word/writers/table-writer.js +506 -0
- package/dist/cjs/modules/word/writers/textbox-writer.js +56 -0
- package/dist/cjs/modules/word/writers/toc-writer.js +82 -0
- package/dist/cjs/modules/xml/encode.js +158 -11
- package/dist/esm/index.browser.js +20 -2
- package/dist/esm/index.js +9 -1
- package/dist/esm/modules/excel/chart/cache-populator.js +1171 -0
- package/dist/esm/modules/excel/chart/chart-api.js +364 -0
- package/dist/esm/modules/excel/chart/chart-builder.js +2432 -0
- package/dist/esm/modules/excel/chart/chart-ex-builder.js +903 -0
- package/dist/esm/modules/excel/chart/chart-ex-parser.js +1205 -0
- package/dist/esm/modules/excel/chart/chart-ex-renderer.js +5352 -0
- package/dist/esm/modules/excel/chart/chart-ex-types.js +11 -0
- package/dist/esm/modules/excel/chart/chart-images.js +363 -0
- package/dist/esm/modules/excel/chart/chart-presets.js +179 -0
- package/dist/esm/modules/excel/chart/chart-renderer.js +6440 -0
- package/dist/esm/modules/excel/chart/chart-sidecar.js +427 -0
- package/dist/esm/modules/excel/chart/chart-utils.js +821 -0
- package/dist/esm/modules/excel/chart/chart.js +1320 -0
- package/dist/esm/modules/excel/chart/glyph-rasterizer.js +658 -0
- package/dist/esm/modules/excel/chart/index.js +46 -0
- package/dist/esm/modules/excel/chart/install.js +91 -0
- package/dist/esm/modules/excel/chart/shape-properties.js +1557 -0
- package/dist/esm/modules/excel/chart/stroke-font.js +1556 -0
- package/dist/esm/modules/excel/chart/topojson.js +236 -0
- package/dist/esm/modules/excel/chart/types.js +8 -0
- package/dist/esm/modules/excel/chart-host-registry.js +90 -0
- package/dist/esm/modules/excel/chartsheet.js +196 -0
- package/dist/esm/modules/excel/defined-names.js +44 -4
- package/dist/esm/modules/excel/errors.js +9 -0
- package/dist/esm/modules/excel/form-control.js +17 -0
- package/dist/esm/modules/excel/image.js +12 -2
- package/dist/esm/modules/excel/pivot-chart.js +53 -0
- package/dist/esm/modules/excel/pivot-table.js +35 -0
- package/dist/esm/modules/excel/range.js +5 -1
- package/dist/esm/modules/excel/sparkline/index.js +7 -0
- package/dist/esm/modules/excel/sparkline/sparkline.js +750 -0
- package/dist/esm/modules/excel/stream/worksheet-writer.js +3 -2
- package/dist/esm/modules/excel/table.js +42 -6
- package/dist/esm/modules/excel/utils/address.js +28 -0
- package/dist/esm/modules/excel/utils/drawing-utils.js +11 -6
- package/dist/esm/modules/excel/utils/guid.js +35 -0
- package/dist/esm/modules/excel/utils/ooxml-paths.js +206 -9
- package/dist/esm/modules/excel/utils/ooxml-validator/check-chart-sidecar.js +101 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-chart.js +2125 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-chartsheet.js +26 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-content-types.js +181 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-drawing.js +267 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-pivot.js +104 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-relationships.js +184 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-structure.js +56 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-styles.js +89 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-table.js +177 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-workbook.js +163 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/check-worksheet.js +569 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/context.js +191 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/index.js +102 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/path-utils.js +156 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/reporter.js +61 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/types.js +12 -0
- package/dist/esm/modules/excel/utils/ooxml-validator/xml-utils.js +100 -0
- package/dist/esm/modules/excel/workbook.browser.js +969 -34
- package/dist/esm/modules/excel/workbook.js +48 -0
- package/dist/esm/modules/excel/worksheet.js +394 -35
- package/dist/esm/modules/excel/xlsx/rel-type.js +41 -1
- package/dist/esm/modules/excel/xlsx/xform/book/defined-name-xform.js +11 -2
- package/dist/esm/modules/excel/xlsx/xform/book/external-link-xform.js +12 -10
- package/dist/esm/modules/excel/xlsx/xform/book/workbook-xform.js +96 -22
- package/dist/esm/modules/excel/xlsx/xform/chart/chart-space-xform.js +6000 -0
- package/dist/esm/modules/excel/xlsx/xform/comment/threaded-comments-xform.js +213 -0
- package/dist/esm/modules/excel/xlsx/xform/core/content-types-xform.js +150 -11
- package/dist/esm/modules/excel/xlsx/xform/drawing/absolute-anchor-xform.js +20 -1
- package/dist/esm/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.js +1 -1
- package/dist/esm/modules/excel/xlsx/xform/drawing/drawing-xform.js +109 -5
- package/dist/esm/modules/excel/xlsx/xform/drawing/graphic-frame-xform.js +225 -0
- package/dist/esm/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.js +18 -3
- package/dist/esm/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.js +294 -12
- package/dist/esm/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +32 -6
- package/dist/esm/modules/excel/xlsx/xform/sheet/chartsheet-xform.js +441 -0
- package/dist/esm/modules/excel/xlsx/xform/sheet/ext-lst-xform.js +51 -2
- package/dist/esm/modules/excel/xlsx/xform/sheet/worksheet-xform.js +196 -20
- package/dist/esm/modules/excel/xlsx/xform/table/auto-filter-xform.js +16 -1
- package/dist/esm/modules/excel/xlsx/xform/table/table-column-xform.js +17 -2
- package/dist/esm/modules/excel/xlsx/xform/xsd-values.js +101 -0
- package/dist/esm/modules/excel/xlsx/xlsx.browser.js +4422 -78
- package/dist/esm/modules/pdf/builder/document-builder.js +507 -2
- package/dist/esm/modules/pdf/builder/pdf-editor.js +48 -3
- package/dist/esm/modules/pdf/excel-bridge.js +683 -12
- package/dist/esm/modules/pdf/font/font-manager.js +39 -0
- package/dist/esm/modules/pdf/index.js +3 -1
- package/dist/esm/modules/pdf/render/chart-surface.js +200 -0
- package/dist/esm/modules/pdf/render/layout-engine.js +436 -56
- package/dist/esm/modules/pdf/render/page-renderer.js +169 -28
- package/dist/esm/modules/pdf/render/pdf-exporter.js +117 -7
- package/dist/esm/modules/pdf/types.js +4 -0
- package/dist/esm/modules/pdf/word-bridge.js +304 -0
- package/dist/esm/modules/word/constants.js +231 -0
- package/dist/esm/modules/word/content-types.js +53 -0
- package/dist/esm/modules/word/digital-signatures.js +134 -0
- package/dist/esm/modules/word/document.js +1795 -0
- package/dist/esm/modules/word/docx-packager.js +822 -0
- package/dist/esm/modules/word/docx-reader.js +4929 -0
- package/dist/esm/modules/word/encryption.js +274 -0
- package/dist/esm/modules/word/errors.js +68 -0
- package/dist/esm/modules/word/font-obfuscation.js +83 -0
- package/dist/esm/modules/word/html-renderer.js +782 -0
- package/dist/esm/modules/word/index.base.js +51 -0
- package/dist/esm/modules/word/index.browser.js +4 -0
- package/dist/esm/modules/word/index.js +4 -0
- package/dist/esm/modules/word/internal-utils.js +54 -0
- package/dist/esm/modules/word/relationships.js +56 -0
- package/dist/esm/modules/word/types.js +10 -0
- package/dist/esm/modules/word/units.js +111 -0
- package/dist/esm/modules/word/writers/chart-writer.js +385 -0
- package/dist/esm/modules/word/writers/checkbox-writer.js +42 -0
- package/dist/esm/modules/word/writers/comment-writer.js +70 -0
- package/dist/esm/modules/word/writers/document-writer.js +461 -0
- package/dist/esm/modules/word/writers/footnote-writer.js +72 -0
- package/dist/esm/modules/word/writers/header-footer-writer.js +129 -0
- package/dist/esm/modules/word/writers/image-writer.js +185 -0
- package/dist/esm/modules/word/writers/math-writer.js +428 -0
- package/dist/esm/modules/word/writers/numbering-writer.js +125 -0
- package/dist/esm/modules/word/writers/paragraph-writer.js +516 -0
- package/dist/esm/modules/word/writers/parts-writer.js +660 -0
- package/dist/esm/modules/word/writers/run-writer.js +649 -0
- package/dist/esm/modules/word/writers/section-writer.js +238 -0
- package/dist/esm/modules/word/writers/styles-writer.js +242 -0
- package/dist/esm/modules/word/writers/table-writer.js +503 -0
- package/dist/esm/modules/word/writers/textbox-writer.js +53 -0
- package/dist/esm/modules/word/writers/toc-writer.js +79 -0
- package/dist/esm/modules/xml/encode.js +157 -11
- package/dist/iife/excelts.iife.js +11789 -687
- package/dist/iife/excelts.iife.js.map +1 -1
- package/dist/iife/excelts.iife.min.js +52 -44
- package/dist/types/index.browser.d.ts +8 -5
- package/dist/types/index.d.ts +4 -2
- package/dist/types/modules/excel/chart/cache-populator.d.ts +49 -0
- package/dist/types/modules/excel/chart/chart-api.d.ts +92 -0
- package/dist/types/modules/excel/chart/chart-builder.d.ts +48 -0
- package/dist/types/modules/excel/chart/chart-ex-builder.d.ts +36 -0
- package/dist/types/modules/excel/chart/chart-ex-parser.d.ts +8 -0
- package/dist/types/modules/excel/chart/chart-ex-renderer.d.ts +187 -0
- package/dist/types/modules/excel/chart/chart-ex-types.d.ts +531 -0
- package/dist/types/modules/excel/chart/chart-images.d.ts +78 -0
- package/dist/types/modules/excel/chart/chart-presets.d.ts +392 -0
- package/dist/types/modules/excel/chart/chart-renderer.d.ts +550 -0
- package/dist/types/modules/excel/chart/chart-sidecar.d.ts +21 -0
- package/dist/types/modules/excel/chart/chart-utils.d.ts +306 -0
- package/dist/types/modules/excel/chart/chart.d.ts +504 -0
- package/dist/types/modules/excel/chart/glyph-rasterizer.d.ts +62 -0
- package/dist/types/modules/excel/chart/index.d.ts +54 -0
- package/dist/types/modules/excel/chart/install.d.ts +44 -0
- package/dist/types/modules/excel/chart/shape-properties.d.ts +156 -0
- package/dist/types/modules/excel/chart/stroke-font.d.ts +36 -0
- package/dist/types/modules/excel/chart/topojson.d.ts +98 -0
- package/dist/types/modules/excel/chart/types.d.ts +2559 -0
- package/dist/types/modules/excel/chart-host-registry.d.ts +157 -0
- package/dist/types/modules/excel/chartsheet.d.ts +102 -0
- package/dist/types/modules/excel/defined-names.d.ts +35 -0
- package/dist/types/modules/excel/errors.d.ts +6 -0
- package/dist/types/modules/excel/form-control.d.ts +6 -0
- package/dist/types/modules/excel/pivot-chart.d.ts +7 -0
- package/dist/types/modules/excel/pivot-table.d.ts +55 -0
- package/dist/types/modules/excel/sparkline/index.d.ts +7 -0
- package/dist/types/modules/excel/sparkline/sparkline.d.ts +206 -0
- package/dist/types/modules/excel/types.d.ts +72 -0
- package/dist/types/modules/excel/utils/address.d.ts +18 -0
- package/dist/types/modules/excel/utils/guid.d.ts +15 -0
- package/dist/types/modules/excel/utils/ooxml-paths.d.ts +74 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-chart-sidecar.d.ts +35 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-chart.d.ts +32 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-chartsheet.d.ts +9 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-content-types.d.ts +16 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-drawing.d.ts +34 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-pivot.d.ts +14 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-relationships.d.ts +18 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-structure.d.ts +21 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-styles.d.ts +15 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-table.d.ts +31 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-workbook.d.ts +19 -0
- package/dist/types/modules/excel/utils/ooxml-validator/check-worksheet.d.ts +25 -0
- package/dist/types/modules/excel/utils/ooxml-validator/context.d.ts +85 -0
- package/dist/types/modules/excel/utils/ooxml-validator/index.d.ts +31 -0
- package/dist/types/modules/excel/utils/ooxml-validator/path-utils.d.ts +67 -0
- package/dist/types/modules/excel/utils/ooxml-validator/reporter.d.ts +41 -0
- package/dist/types/modules/excel/utils/ooxml-validator/types.d.ts +109 -0
- package/dist/types/modules/excel/utils/ooxml-validator/xml-utils.d.ts +38 -0
- package/dist/types/modules/excel/workbook.browser.d.ts +248 -30
- package/dist/types/modules/excel/workbook.d.ts +43 -0
- package/dist/types/modules/excel/worksheet.d.ts +157 -3
- package/dist/types/modules/excel/xlsx/rel-type.d.ts +40 -0
- package/dist/types/modules/excel/xlsx/xform/book/defined-name-xform.d.ts +1 -0
- package/dist/types/modules/excel/xlsx/xform/chart/chart-space-xform.d.ts +353 -0
- package/dist/types/modules/excel/xlsx/xform/comment/threaded-comments-xform.d.ts +60 -0
- package/dist/types/modules/excel/xlsx/xform/drawing/drawing-xform.d.ts +30 -0
- package/dist/types/modules/excel/xlsx/xform/drawing/graphic-frame-xform.d.ts +54 -0
- package/dist/types/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.d.ts +3 -1
- package/dist/types/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.d.ts +46 -0
- package/dist/types/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +13 -2
- package/dist/types/modules/excel/xlsx/xform/sheet/chartsheet-xform.d.ts +185 -0
- package/dist/types/modules/excel/xlsx/xform/sheet/ext-lst-xform.d.ts +1 -0
- package/dist/types/modules/excel/xlsx/xform/xsd-values.d.ts +63 -0
- package/dist/types/modules/excel/xlsx/xlsx.browser.d.ts +115 -21
- package/dist/types/modules/pdf/builder/document-builder.d.ts +74 -0
- package/dist/types/modules/pdf/excel-bridge.d.ts +69 -0
- package/dist/types/modules/pdf/font/font-manager.d.ts +25 -0
- package/dist/types/modules/pdf/index.d.ts +5 -2
- package/dist/types/modules/pdf/render/chart-surface.d.ts +33 -0
- package/dist/types/modules/pdf/render/layout-engine.d.ts +22 -1
- package/dist/types/modules/pdf/types.d.ts +227 -23
- package/dist/types/modules/pdf/word-bridge.d.ts +47 -0
- package/dist/types/modules/word/constants.d.ts +179 -0
- package/dist/types/modules/word/content-types.d.ts +27 -0
- package/dist/types/modules/word/digital-signatures.d.ts +87 -0
- package/dist/types/modules/word/document.d.ts +728 -0
- package/dist/types/modules/word/docx-packager.d.ts +14 -0
- package/dist/types/modules/word/docx-reader.d.ts +11 -0
- package/dist/types/modules/word/encryption.d.ts +102 -0
- package/dist/types/modules/word/errors.d.ts +49 -0
- package/dist/types/modules/word/font-obfuscation.d.ts +31 -0
- package/dist/types/modules/word/html-renderer.d.ts +38 -0
- package/dist/types/modules/word/index.base.d.ts +19 -0
- package/dist/types/modules/word/index.browser.d.ts +4 -0
- package/dist/types/modules/word/index.d.ts +4 -0
- package/dist/types/modules/word/internal-utils.d.ts +23 -0
- package/dist/types/modules/word/relationships.d.ts +31 -0
- package/dist/types/modules/word/types.d.ts +2325 -0
- package/dist/types/modules/word/units.d.ts +49 -0
- package/dist/types/modules/word/writers/chart-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/checkbox-writer.d.ts +9 -0
- package/dist/types/modules/word/writers/comment-writer.d.ts +15 -0
- package/dist/types/modules/word/writers/document-writer.d.ts +16 -0
- package/dist/types/modules/word/writers/footnote-writer.d.ts +11 -0
- package/dist/types/modules/word/writers/header-footer-writer.d.ts +13 -0
- package/dist/types/modules/word/writers/image-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/math-writer.d.ts +9 -0
- package/dist/types/modules/word/writers/numbering-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/paragraph-writer.d.ts +13 -0
- package/dist/types/modules/word/writers/parts-writer.d.ts +26 -0
- package/dist/types/modules/word/writers/run-writer.d.ts +15 -0
- package/dist/types/modules/word/writers/section-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/styles-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/table-writer.d.ts +10 -0
- package/dist/types/modules/word/writers/textbox-writer.d.ts +9 -0
- package/dist/types/modules/word/writers/toc-writer.d.ts +9 -0
- package/dist/types/modules/xml/encode.d.ts +56 -7
- package/package.json +29 -11
- package/dist/browser/modules/excel/utils/ooxml-validator.d.ts +0 -48
- package/dist/browser/modules/excel/utils/ooxml-validator.js +0 -493
- package/dist/browser/modules/excel/utils/passthrough-manager.d.ts +0 -77
- package/dist/browser/modules/excel/utils/passthrough-manager.js +0 -129
- package/dist/cjs/modules/excel/utils/ooxml-validator.js +0 -499
- package/dist/cjs/modules/excel/utils/passthrough-manager.js +0 -133
- package/dist/esm/modules/excel/utils/ooxml-validator.js +0 -493
- package/dist/esm/modules/excel/utils/passthrough-manager.js +0 -129
- package/dist/types/modules/excel/utils/ooxml-validator.d.ts +0 -48
- package/dist/types/modules/excel/utils/passthrough-manager.d.ts +0 -77
|
@@ -0,0 +1,572 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Worksheet check — the largest and most important part of the validator.
|
|
4
|
+
*
|
|
5
|
+
* Covers four new structural checks beyond the original wiring check:
|
|
6
|
+
* 1. **Child element ordering** — `<worksheet>` children must appear in
|
|
7
|
+
* the ECMA-376 canonical order. Excel is known to reject files with
|
|
8
|
+
* out-of-order children; this is a top cause of "Excel needs to
|
|
9
|
+
* repair" prompts.
|
|
10
|
+
* 2. **Cell `r="A1"` consistency** — every `<c r="…"/>` inside a
|
|
11
|
+
* `<row r="N"/>` must decode to row `N` and to a column in
|
|
12
|
+
* `[1, 16384]` (Excel's max column limit, XFD).
|
|
13
|
+
* 3. **Merge region overlap** — every `<mergeCell ref="A1:B2"/>` must
|
|
14
|
+
* parse and no two merged ranges may overlap.
|
|
15
|
+
* 4. **Style / SST index bounds** — every `<c s="N"/>` must reference a
|
|
16
|
+
* valid `cellXfs` index, and every `<c t="s"><v>N</v></c>` must
|
|
17
|
+
* reference an existing `sharedStrings` index.
|
|
18
|
+
*
|
|
19
|
+
* Plus the legacy r:id wiring checks (controls, drawing, comments,
|
|
20
|
+
* hyperlink, tablePart, legacyDrawing) and the "controls without
|
|
21
|
+
* drawing" repair signal. The old "legacyDrawing-after-controls" kind is
|
|
22
|
+
* kept for backward compatibility — it is emitted in parallel with the
|
|
23
|
+
* generic `sheet-child-out-of-order` kind.
|
|
24
|
+
*/
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.checkWorksheets = checkWorksheets;
|
|
27
|
+
const address_1 = require("../address");
|
|
28
|
+
const path_utils_1 = require("./path-utils");
|
|
29
|
+
const xml_utils_1 = require("./xml-utils");
|
|
30
|
+
// -----------------------------------------------------------------------------
|
|
31
|
+
// ECMA-376 worksheet child order.
|
|
32
|
+
// -----------------------------------------------------------------------------
|
|
33
|
+
/**
|
|
34
|
+
* Canonical order of `<worksheet>` direct children. The index of each
|
|
35
|
+
* child name within this array is its "rank"; any child with a smaller
|
|
36
|
+
* rank seen after a child with a larger rank is out of order.
|
|
37
|
+
*
|
|
38
|
+
* Names are local names (no namespace prefix). Elements allowed to
|
|
39
|
+
* repeat (like `cols`, `conditionalFormatting`) are still subject to
|
|
40
|
+
* the same rank — two consecutive `cols` blocks is fine, but a `cols`
|
|
41
|
+
* after `sheetData` is not.
|
|
42
|
+
*/
|
|
43
|
+
const WORKSHEET_CHILD_ORDER = [
|
|
44
|
+
"sheetPr",
|
|
45
|
+
"dimension",
|
|
46
|
+
"sheetViews",
|
|
47
|
+
"sheetFormatPr",
|
|
48
|
+
"cols",
|
|
49
|
+
"sheetData",
|
|
50
|
+
"sheetCalcPr",
|
|
51
|
+
"sheetProtection",
|
|
52
|
+
"protectedRanges",
|
|
53
|
+
"scenarios",
|
|
54
|
+
"autoFilter",
|
|
55
|
+
"sortState",
|
|
56
|
+
"dataConsolidate",
|
|
57
|
+
"customSheetViews",
|
|
58
|
+
"mergeCells",
|
|
59
|
+
"phoneticPr",
|
|
60
|
+
"conditionalFormatting",
|
|
61
|
+
"dataValidations",
|
|
62
|
+
"hyperlinks",
|
|
63
|
+
"printOptions",
|
|
64
|
+
"pageMargins",
|
|
65
|
+
"pageSetup",
|
|
66
|
+
"headerFooter",
|
|
67
|
+
"rowBreaks",
|
|
68
|
+
"colBreaks",
|
|
69
|
+
"customProperties",
|
|
70
|
+
"cellWatches",
|
|
71
|
+
"ignoredErrors",
|
|
72
|
+
"smartTags",
|
|
73
|
+
"drawing",
|
|
74
|
+
"legacyDrawing",
|
|
75
|
+
"legacyDrawingHF",
|
|
76
|
+
"drawingHF",
|
|
77
|
+
"picture",
|
|
78
|
+
"oleObjects",
|
|
79
|
+
"controls",
|
|
80
|
+
"webPublishItems",
|
|
81
|
+
"tableParts",
|
|
82
|
+
"extLst"
|
|
83
|
+
];
|
|
84
|
+
const WORKSHEET_CHILD_RANK = new Map(WORKSHEET_CHILD_ORDER.map((name, idx) => [name, idx]));
|
|
85
|
+
// Excel 2007+ limits.
|
|
86
|
+
const EXCEL_MAX_ROW = 1048576;
|
|
87
|
+
const EXCEL_MAX_COL = 16384; // XFD
|
|
88
|
+
function readCellXfsCount(ctx) {
|
|
89
|
+
const dom = ctx.readDom("xl/styles.xml");
|
|
90
|
+
if (!dom) {
|
|
91
|
+
return undefined;
|
|
92
|
+
}
|
|
93
|
+
const cellXfs = (0, xml_utils_1.findChildLocal)(dom.root, "cellXfs");
|
|
94
|
+
if (!cellXfs) {
|
|
95
|
+
return 0;
|
|
96
|
+
}
|
|
97
|
+
const count = (0, xml_utils_1.attrByLocalName)(cellXfs, "count");
|
|
98
|
+
const n = count !== undefined ? parseInt(count, 10) : NaN;
|
|
99
|
+
if (Number.isFinite(n) && n >= 0) {
|
|
100
|
+
return n;
|
|
101
|
+
}
|
|
102
|
+
return (0, xml_utils_1.findChildrenLocal)(cellXfs, "xf").length;
|
|
103
|
+
}
|
|
104
|
+
function readSstSize(ctx) {
|
|
105
|
+
const dom = ctx.readDom("xl/sharedStrings.xml");
|
|
106
|
+
if (!dom) {
|
|
107
|
+
return undefined;
|
|
108
|
+
}
|
|
109
|
+
const uniqueCount = (0, xml_utils_1.attrByLocalName)(dom.root, "uniqueCount");
|
|
110
|
+
const n = uniqueCount !== undefined ? parseInt(uniqueCount, 10) : NaN;
|
|
111
|
+
if (Number.isFinite(n) && n >= 0) {
|
|
112
|
+
return n;
|
|
113
|
+
}
|
|
114
|
+
return (0, xml_utils_1.findChildrenLocal)(dom.root, "si").length;
|
|
115
|
+
}
|
|
116
|
+
function loadIndexCounts(ctx) {
|
|
117
|
+
return {
|
|
118
|
+
cellXfs: readCellXfsCount(ctx),
|
|
119
|
+
sstSize: readSstSize(ctx)
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
// -----------------------------------------------------------------------------
|
|
123
|
+
// Cell address helpers — safe wrappers around `address.ts`.
|
|
124
|
+
// -----------------------------------------------------------------------------
|
|
125
|
+
/**
|
|
126
|
+
* Parse an A1-style reference into `{ col, row }` (1-based) or
|
|
127
|
+
* `undefined` when the string is not a legal cell reference. Accepts
|
|
128
|
+
* absolute-address `$`-markers produced by some serialisers.
|
|
129
|
+
*/
|
|
130
|
+
function parseCellRef(ref) {
|
|
131
|
+
// Match optional `$`, letters, optional `$`, digits.
|
|
132
|
+
const m = /^\$?([A-Za-z]+)\$?(\d+)$/.exec(ref);
|
|
133
|
+
if (!m) {
|
|
134
|
+
return undefined;
|
|
135
|
+
}
|
|
136
|
+
try {
|
|
137
|
+
const col = (0, address_1.decodeCol)(m[1]) + 1;
|
|
138
|
+
const row = (0, address_1.decodeRow)(m[2]) + 1;
|
|
139
|
+
if (!Number.isFinite(col) || !Number.isFinite(row)) {
|
|
140
|
+
return undefined;
|
|
141
|
+
}
|
|
142
|
+
return { col, row };
|
|
143
|
+
}
|
|
144
|
+
catch {
|
|
145
|
+
return undefined;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
function parseMergeRef(ref) {
|
|
149
|
+
const idx = ref.indexOf(":");
|
|
150
|
+
if (idx === -1) {
|
|
151
|
+
const p = parseCellRef(ref);
|
|
152
|
+
return p ? { t: p.row, l: p.col, b: p.row, r: p.col, ref } : undefined;
|
|
153
|
+
}
|
|
154
|
+
const a = parseCellRef(ref.slice(0, idx));
|
|
155
|
+
const b = parseCellRef(ref.slice(idx + 1));
|
|
156
|
+
if (!a || !b) {
|
|
157
|
+
return undefined;
|
|
158
|
+
}
|
|
159
|
+
return {
|
|
160
|
+
t: Math.min(a.row, b.row),
|
|
161
|
+
b: Math.max(a.row, b.row),
|
|
162
|
+
l: Math.min(a.col, b.col),
|
|
163
|
+
r: Math.max(a.col, b.col),
|
|
164
|
+
ref
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
function rectsOverlap(a, b) {
|
|
168
|
+
return a.l <= b.r && b.l <= a.r && a.t <= b.b && b.t <= a.b;
|
|
169
|
+
}
|
|
170
|
+
// -----------------------------------------------------------------------------
|
|
171
|
+
// Public checker
|
|
172
|
+
// -----------------------------------------------------------------------------
|
|
173
|
+
function checkWorksheets(ctx) {
|
|
174
|
+
let counts;
|
|
175
|
+
for (const [path, entry] of ctx.files()) {
|
|
176
|
+
if (ctx.reporter.capped) {
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
if (entry.type === "directory" ||
|
|
180
|
+
!path.startsWith("xl/worksheets/sheet") ||
|
|
181
|
+
!path.endsWith(".xml")) {
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
counts ?? (counts = loadIndexCounts(ctx));
|
|
185
|
+
checkSingleWorksheet(ctx, path, counts);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
function checkSingleWorksheet(ctx, path, counts) {
|
|
189
|
+
const dom = ctx.readDom(path, err => {
|
|
190
|
+
ctx.reporter.error("xml-malformed", `Malformed XML: ${err.message}`, path);
|
|
191
|
+
});
|
|
192
|
+
if (!dom) {
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
const root = dom.root;
|
|
196
|
+
// 1) Child element ordering.
|
|
197
|
+
checkChildOrdering(ctx, path, root);
|
|
198
|
+
// 2) Cell ref consistency + style/SST index bounds + sharedFormula masters.
|
|
199
|
+
const sheetData = (0, xml_utils_1.findChildLocal)(root, "sheetData");
|
|
200
|
+
if (sheetData) {
|
|
201
|
+
checkSheetData(ctx, path, sheetData, counts);
|
|
202
|
+
}
|
|
203
|
+
// 3) Merge cell overlap.
|
|
204
|
+
const mergeCells = (0, xml_utils_1.findChildLocal)(root, "mergeCells");
|
|
205
|
+
if (mergeCells) {
|
|
206
|
+
checkMergeCells(ctx, path, mergeCells);
|
|
207
|
+
}
|
|
208
|
+
// 4) Legacy wiring + controls-without-drawing + legacyDrawing ordering.
|
|
209
|
+
checkSheetWiring(ctx, path, root);
|
|
210
|
+
}
|
|
211
|
+
// -----------------------------------------------------------------------------
|
|
212
|
+
// Ordering
|
|
213
|
+
// -----------------------------------------------------------------------------
|
|
214
|
+
function checkChildOrdering(ctx, path, root) {
|
|
215
|
+
let maxRank = -1;
|
|
216
|
+
let sawControls = false;
|
|
217
|
+
let sawLegacyDrawingAfterControls = false;
|
|
218
|
+
for (const child of iterateWorksheetChildren(root)) {
|
|
219
|
+
if (child.type !== "element") {
|
|
220
|
+
continue;
|
|
221
|
+
}
|
|
222
|
+
const local = child.name.includes(":")
|
|
223
|
+
? child.name.slice(child.name.lastIndexOf(":") + 1)
|
|
224
|
+
: child.name;
|
|
225
|
+
const rank = WORKSHEET_CHILD_RANK.get(local);
|
|
226
|
+
if (rank === undefined) {
|
|
227
|
+
// Unknown element — don't flag, someone might have added an extension.
|
|
228
|
+
continue;
|
|
229
|
+
}
|
|
230
|
+
if (rank < maxRank) {
|
|
231
|
+
const expectedAfter = WORKSHEET_CHILD_ORDER[maxRank] ?? "?";
|
|
232
|
+
ctx.reporter.error("sheet-child-out-of-order", `Worksheet child <${local}> appears after <${expectedAfter}>; expected order violated`, path);
|
|
233
|
+
if (local === "legacyDrawing" && sawControls) {
|
|
234
|
+
sawLegacyDrawingAfterControls = true;
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
if (rank > maxRank) {
|
|
238
|
+
maxRank = rank;
|
|
239
|
+
}
|
|
240
|
+
if (local === "controls") {
|
|
241
|
+
sawControls = true;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
// Backwards-compat: emit the legacy-specific kind too so existing
|
|
245
|
+
// regression tests that grep for it still match.
|
|
246
|
+
if (sawLegacyDrawingAfterControls) {
|
|
247
|
+
ctx.reporter.error("sheet-legacyDrawing-after-controls", "Worksheet has <legacyDrawing> after <controls>; Excel may repair or reject this sheet", path);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Yield every direct child of the worksheet — but transparently unwrap
|
|
252
|
+
* `<mc:AlternateContent><mc:Choice>…</mc:Choice></mc:AlternateContent>`.
|
|
253
|
+
* The MCE alternate-content wrapper is a schema-level feature that lets
|
|
254
|
+
* writers express a primary serialisation and a fallback; for ordering
|
|
255
|
+
* purposes the Choice's children are logically in the worksheet itself.
|
|
256
|
+
* Without this flattening, checkers miss the inner `<controls>` element
|
|
257
|
+
* because it hides inside a namespace-prefixed envelope.
|
|
258
|
+
*/
|
|
259
|
+
function* iterateWorksheetChildren(root) {
|
|
260
|
+
for (const child of root.children) {
|
|
261
|
+
if (child.type !== "element") {
|
|
262
|
+
continue;
|
|
263
|
+
}
|
|
264
|
+
const local = child.name.includes(":")
|
|
265
|
+
? child.name.slice(child.name.lastIndexOf(":") + 1)
|
|
266
|
+
: child.name;
|
|
267
|
+
if (local === "AlternateContent") {
|
|
268
|
+
// Use Choice's children (fallback is the degenerate substitute).
|
|
269
|
+
for (const c of child.children) {
|
|
270
|
+
if (c.type !== "element") {
|
|
271
|
+
continue;
|
|
272
|
+
}
|
|
273
|
+
const cLocal = c.name.includes(":") ? c.name.slice(c.name.lastIndexOf(":") + 1) : c.name;
|
|
274
|
+
if (cLocal === "Choice") {
|
|
275
|
+
for (const inner of c.children) {
|
|
276
|
+
if (inner.type === "element") {
|
|
277
|
+
yield inner;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
continue;
|
|
283
|
+
}
|
|
284
|
+
yield child;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
// -----------------------------------------------------------------------------
|
|
288
|
+
// sheetData (cell refs / style idx / SST idx / sharedFormula)
|
|
289
|
+
// -----------------------------------------------------------------------------
|
|
290
|
+
function checkSheetData(ctx, path, sheetData, counts) {
|
|
291
|
+
// Track shared-formula si masters: si -> how many masters have been seen.
|
|
292
|
+
const masterSiCounts = new Map();
|
|
293
|
+
// si values referenced by followers that had no master yet.
|
|
294
|
+
const followerSi = new Set();
|
|
295
|
+
for (const row of sheetData.children) {
|
|
296
|
+
if (ctx.reporter.capped) {
|
|
297
|
+
return;
|
|
298
|
+
}
|
|
299
|
+
if (row.type !== "element" || !(0, xml_utils_1.matchesLocal)(row.name, "row")) {
|
|
300
|
+
continue;
|
|
301
|
+
}
|
|
302
|
+
const rowAttr = (0, xml_utils_1.attrByLocalName)(row, "r");
|
|
303
|
+
const rowIndex = rowAttr !== undefined ? parseInt(rowAttr, 10) : NaN;
|
|
304
|
+
if (Number.isFinite(rowIndex)) {
|
|
305
|
+
if (rowIndex < 1 || rowIndex > EXCEL_MAX_ROW) {
|
|
306
|
+
ctx.reporter.error("sheet-row-index-out-of-bounds", `Row r="${rowAttr}" is outside Excel's limit 1..${EXCEL_MAX_ROW}`, path);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
for (const cell of row.children) {
|
|
310
|
+
if (ctx.reporter.capped) {
|
|
311
|
+
return;
|
|
312
|
+
}
|
|
313
|
+
if (cell.type !== "element" || !(0, xml_utils_1.matchesLocal)(cell.name, "c")) {
|
|
314
|
+
continue;
|
|
315
|
+
}
|
|
316
|
+
checkCell(ctx, path, cell, Number.isFinite(rowIndex) ? rowIndex : undefined, counts);
|
|
317
|
+
checkSharedFormula(cell, masterSiCounts, followerSi);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
// Shared-formula: every follower si must have a master, every si must
|
|
321
|
+
// have exactly one master.
|
|
322
|
+
for (const [si, n] of masterSiCounts) {
|
|
323
|
+
if (n > 1) {
|
|
324
|
+
ctx.reporter.error("sheet-sharedFormula-duplicate-master", `Shared formula si="${si}" has ${n} master entries (should be exactly one)`, path);
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
for (const si of followerSi) {
|
|
328
|
+
if (!masterSiCounts.has(si)) {
|
|
329
|
+
ctx.reporter.error("sheet-sharedFormula-master-missing", `Shared formula si="${si}" has no master entry`, path);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
function checkCell(ctx, path, cell, rowIndex, counts) {
|
|
334
|
+
const ref = (0, xml_utils_1.attrByLocalName)(cell, "r");
|
|
335
|
+
if (ref === undefined) {
|
|
336
|
+
ctx.reporter.error("sheet-cell-ref-missing", `Cell missing r="" attribute`, path);
|
|
337
|
+
return;
|
|
338
|
+
}
|
|
339
|
+
const parsed = parseCellRef(ref);
|
|
340
|
+
if (!parsed) {
|
|
341
|
+
ctx.reporter.error("sheet-cell-ref-invalid", `Cell has invalid r="${ref}"`, path);
|
|
342
|
+
return;
|
|
343
|
+
}
|
|
344
|
+
if (parsed.col < 1 ||
|
|
345
|
+
parsed.col > EXCEL_MAX_COL ||
|
|
346
|
+
parsed.row < 1 ||
|
|
347
|
+
parsed.row > EXCEL_MAX_ROW) {
|
|
348
|
+
ctx.reporter.error("sheet-cell-ref-out-of-bounds", `Cell r="${ref}" is outside Excel's sheet bounds (max XFD1048576)`, path);
|
|
349
|
+
}
|
|
350
|
+
if (rowIndex !== undefined && parsed.row !== rowIndex) {
|
|
351
|
+
ctx.reporter.error("sheet-cell-ref-row-mismatch", `Cell r="${ref}" has row ${parsed.row} but is inside <row r="${rowIndex}">`, path);
|
|
352
|
+
}
|
|
353
|
+
// Style index.
|
|
354
|
+
const styleAttr = (0, xml_utils_1.attrByLocalName)(cell, "s");
|
|
355
|
+
if (styleAttr !== undefined && counts.cellXfs !== undefined) {
|
|
356
|
+
const s = parseInt(styleAttr, 10);
|
|
357
|
+
if (!Number.isFinite(s) || s < 0 || s >= counts.cellXfs) {
|
|
358
|
+
ctx.reporter.error("sheet-cell-style-index-oob", `Cell r="${ref}" s="${styleAttr}" is outside cellXfs range [0, ${counts.cellXfs})`, path);
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
// Shared-strings index (t="s" means cell value is an index into sharedStrings).
|
|
362
|
+
const typeAttr = (0, xml_utils_1.attrByLocalName)(cell, "t");
|
|
363
|
+
if (typeAttr === "s" && counts.sstSize !== undefined) {
|
|
364
|
+
const v = (0, xml_utils_1.findChildLocal)(cell, "v");
|
|
365
|
+
if (v) {
|
|
366
|
+
const text = collectText(v).trim();
|
|
367
|
+
const n = parseInt(text, 10);
|
|
368
|
+
if (!Number.isFinite(n) || n < 0 || n >= counts.sstSize) {
|
|
369
|
+
ctx.reporter.error("sheet-cell-sst-index-oob", `Cell r="${ref}" references sharedStrings index ${text} but SST has ${counts.sstSize} entries`, path);
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
function checkSharedFormula(cell, masterSiCounts, followerSi) {
|
|
375
|
+
const f = (0, xml_utils_1.findChildLocal)(cell, "f");
|
|
376
|
+
if (!f) {
|
|
377
|
+
return;
|
|
378
|
+
}
|
|
379
|
+
const t = (0, xml_utils_1.attrByLocalName)(f, "t");
|
|
380
|
+
if (t !== "shared") {
|
|
381
|
+
return;
|
|
382
|
+
}
|
|
383
|
+
const si = (0, xml_utils_1.attrByLocalName)(f, "si");
|
|
384
|
+
if (si === undefined) {
|
|
385
|
+
return;
|
|
386
|
+
}
|
|
387
|
+
const hasRef = (0, xml_utils_1.attrByLocalName)(f, "ref") !== undefined;
|
|
388
|
+
const hasBody = collectText(f).trim().length > 0;
|
|
389
|
+
// A master is identified by having a `ref` attribute (range); a follower
|
|
390
|
+
// has just `si` with an empty body. Some producers also emit a body on
|
|
391
|
+
// masters, which is fine.
|
|
392
|
+
if (hasRef || hasBody) {
|
|
393
|
+
masterSiCounts.set(si, (masterSiCounts.get(si) ?? 0) + 1);
|
|
394
|
+
}
|
|
395
|
+
else {
|
|
396
|
+
followerSi.add(si);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
function collectText(el) {
|
|
400
|
+
let out = "";
|
|
401
|
+
for (const child of el.children) {
|
|
402
|
+
if (child.type === "text" || child.type === "cdata") {
|
|
403
|
+
out += child.value;
|
|
404
|
+
}
|
|
405
|
+
else if (child.type === "element") {
|
|
406
|
+
out += collectText(child);
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
return out;
|
|
410
|
+
}
|
|
411
|
+
// -----------------------------------------------------------------------------
|
|
412
|
+
// mergeCells
|
|
413
|
+
// -----------------------------------------------------------------------------
|
|
414
|
+
function checkMergeCells(ctx, path, mergeCells) {
|
|
415
|
+
const rects = [];
|
|
416
|
+
for (const mc of (0, xml_utils_1.findChildrenLocal)(mergeCells, "mergeCell")) {
|
|
417
|
+
if (ctx.reporter.capped) {
|
|
418
|
+
return;
|
|
419
|
+
}
|
|
420
|
+
const ref = (0, xml_utils_1.attrByLocalName)(mc, "ref");
|
|
421
|
+
if (!ref) {
|
|
422
|
+
ctx.reporter.error("sheet-merge-invalid-range", `<mergeCell> missing ref attribute`, path);
|
|
423
|
+
continue;
|
|
424
|
+
}
|
|
425
|
+
const rect = parseMergeRef(ref);
|
|
426
|
+
if (!rect) {
|
|
427
|
+
ctx.reporter.error("sheet-merge-invalid-range", `<mergeCell ref="${ref}"> does not parse as a range`, path);
|
|
428
|
+
continue;
|
|
429
|
+
}
|
|
430
|
+
for (const prior of rects) {
|
|
431
|
+
if (rectsOverlap(prior, rect)) {
|
|
432
|
+
ctx.reporter.error("sheet-merge-overlap", `Merge ${ref} overlaps with earlier merge ${prior.ref}`, path);
|
|
433
|
+
break;
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
rects.push(rect);
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
function checkSheetWiring(ctx, path, root) {
|
|
440
|
+
const relsPath = `xl/worksheets/_rels/${(0, path_utils_1.posixBasename)(path)}.rels`;
|
|
441
|
+
// Resolve the effective worksheet children, flattening AlternateContent/Choice.
|
|
442
|
+
const effectiveChildren = [];
|
|
443
|
+
for (const child of iterateWorksheetChildren(root)) {
|
|
444
|
+
effectiveChildren.push(child);
|
|
445
|
+
}
|
|
446
|
+
const firstLocal = (el) => el.name.includes(":") ? el.name.slice(el.name.lastIndexOf(":") + 1) : el.name;
|
|
447
|
+
const uses = [];
|
|
448
|
+
const controls = effectiveChildren.find(el => firstLocal(el) === "controls");
|
|
449
|
+
if (controls) {
|
|
450
|
+
// `<control>` elements may be wrapped in inner
|
|
451
|
+
// `<mc:AlternateContent><mc:Choice>…` blocks (one per control). Use
|
|
452
|
+
// a recursive descent so we pick them up regardless of nesting.
|
|
453
|
+
for (const c of (0, xml_utils_1.collectDescendantsLocal)(controls, "control")) {
|
|
454
|
+
const rid = (0, xml_utils_1.attrByLocalName)(c, "id");
|
|
455
|
+
if (rid) {
|
|
456
|
+
uses.push({
|
|
457
|
+
rid,
|
|
458
|
+
kind: "control",
|
|
459
|
+
typeIncludes: "/relationships/ctrlProp",
|
|
460
|
+
missingKind: "sheet-control-missing-rel",
|
|
461
|
+
wrongKind: "sheet-control-wrong-rel-type",
|
|
462
|
+
label: "<control>"
|
|
463
|
+
});
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
const legacyDrawing = effectiveChildren.find(el => firstLocal(el) === "legacyDrawing");
|
|
468
|
+
if (legacyDrawing) {
|
|
469
|
+
const rid = (0, xml_utils_1.attrByLocalName)(legacyDrawing, "id");
|
|
470
|
+
if (rid) {
|
|
471
|
+
uses.push({
|
|
472
|
+
rid,
|
|
473
|
+
kind: "legacyDrawing",
|
|
474
|
+
typeIncludes: "/relationships/vmlDrawing",
|
|
475
|
+
missingKind: "sheet-legacyDrawing-missing-rel",
|
|
476
|
+
wrongKind: "sheet-legacyDrawing-wrong-rel-type",
|
|
477
|
+
label: "<legacyDrawing>"
|
|
478
|
+
});
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
const drawing = effectiveChildren.find(el => firstLocal(el) === "drawing");
|
|
482
|
+
if (drawing) {
|
|
483
|
+
const rid = (0, xml_utils_1.attrByLocalName)(drawing, "id");
|
|
484
|
+
if (rid) {
|
|
485
|
+
uses.push({
|
|
486
|
+
rid,
|
|
487
|
+
kind: "drawing",
|
|
488
|
+
typeIncludes: "/relationships/drawing",
|
|
489
|
+
missingKind: "sheet-drawing-missing-rel",
|
|
490
|
+
wrongKind: "sheet-drawing-wrong-rel-type",
|
|
491
|
+
label: "<drawing>"
|
|
492
|
+
});
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
const hyperlinks = effectiveChildren.find(el => firstLocal(el) === "hyperlinks");
|
|
496
|
+
if (hyperlinks) {
|
|
497
|
+
for (const hl of (0, xml_utils_1.findChildrenLocal)(hyperlinks, "hyperlink")) {
|
|
498
|
+
const rid = (0, xml_utils_1.attrByLocalName)(hl, "id");
|
|
499
|
+
if (rid) {
|
|
500
|
+
uses.push({
|
|
501
|
+
rid,
|
|
502
|
+
kind: "hyperlink",
|
|
503
|
+
typeIncludes: "/relationships/hyperlink",
|
|
504
|
+
missingKind: "sheet-hyperlink-missing-rel",
|
|
505
|
+
wrongKind: "sheet-hyperlink-wrong-rel-type",
|
|
506
|
+
label: "<hyperlink>"
|
|
507
|
+
});
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
}
|
|
511
|
+
const tableParts = effectiveChildren.find(el => firstLocal(el) === "tableParts");
|
|
512
|
+
if (tableParts) {
|
|
513
|
+
for (const tp of (0, xml_utils_1.findChildrenLocal)(tableParts, "tablePart")) {
|
|
514
|
+
const rid = (0, xml_utils_1.attrByLocalName)(tp, "id");
|
|
515
|
+
if (rid) {
|
|
516
|
+
uses.push({
|
|
517
|
+
rid,
|
|
518
|
+
kind: "tablePart",
|
|
519
|
+
typeIncludes: "/relationships/table",
|
|
520
|
+
missingKind: "sheet-tablePart-missing-rel",
|
|
521
|
+
wrongKind: "sheet-tablePart-wrong-rel-type",
|
|
522
|
+
label: "<tablePart>"
|
|
523
|
+
});
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
// `<comments r:id="..."/>` is not actually a standard worksheet child — the
|
|
528
|
+
// comments relationship is normally declared without a `<comments>` element
|
|
529
|
+
// in the sheet. But the original validator matched this pattern, so keep
|
|
530
|
+
// the behaviour for any serialiser that emits it.
|
|
531
|
+
for (const c of effectiveChildren.filter(el => firstLocal(el) === "comments")) {
|
|
532
|
+
const rid = (0, xml_utils_1.attrByLocalName)(c, "id");
|
|
533
|
+
if (rid) {
|
|
534
|
+
uses.push({
|
|
535
|
+
rid,
|
|
536
|
+
kind: "comments",
|
|
537
|
+
typeIncludes: "/relationships/comments",
|
|
538
|
+
missingKind: "sheet-comments-missing-rel",
|
|
539
|
+
wrongKind: "sheet-comments-wrong-rel-type",
|
|
540
|
+
label: "<comments>"
|
|
541
|
+
});
|
|
542
|
+
}
|
|
543
|
+
}
|
|
544
|
+
// controls without drawing -> repair signal.
|
|
545
|
+
const hasControl = uses.some(u => u.kind === "control");
|
|
546
|
+
const hasDrawing = uses.some(u => u.kind === "drawing");
|
|
547
|
+
if (hasControl && !hasDrawing) {
|
|
548
|
+
ctx.reporter.error("sheet-controls-missing-drawing", "Worksheet has legacy <controls> but no <drawing>; Excel may repair/reject legacy form controls", path);
|
|
549
|
+
}
|
|
550
|
+
// If there are any r:ids in use, rels file must exist.
|
|
551
|
+
if (uses.length > 0 && !ctx.has(relsPath)) {
|
|
552
|
+
ctx.reporter.error("sheet-missing-rels", `Worksheet has controls/legacyDrawing/drawing/hyperlinks/tableParts but missing rels part: ${relsPath}`, path);
|
|
553
|
+
return;
|
|
554
|
+
}
|
|
555
|
+
if (!ctx.has(relsPath)) {
|
|
556
|
+
return;
|
|
557
|
+
}
|
|
558
|
+
const rels = ctx.readRels(relsPath);
|
|
559
|
+
for (const use of uses) {
|
|
560
|
+
if (ctx.reporter.capped) {
|
|
561
|
+
return;
|
|
562
|
+
}
|
|
563
|
+
const rel = rels.byId.get(use.rid);
|
|
564
|
+
if (!rel) {
|
|
565
|
+
ctx.reporter.error(use.missingKind, `Sheet ${use.label} references missing relationship: ${use.rid} (in ${relsPath})`, path);
|
|
566
|
+
continue;
|
|
567
|
+
}
|
|
568
|
+
if (!rel.type.includes(use.typeIncludes)) {
|
|
569
|
+
ctx.reporter.error(use.wrongKind, `Sheet ${use.label} ${use.rid} relationship is not ${use.typeIncludes}: ${rel.type}`, path);
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
}
|