@cj-tech-master/excelts 1.6.3-canary.20251224124621.73c5d94 → 1.6.3
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 +18 -31
- package/README_zh.md +19 -31
- package/dist/browser/excelts.iife.js +40910 -7518
- package/dist/browser/excelts.iife.js.map +1 -1
- package/dist/browser/excelts.iife.min.js +105 -25
- package/dist/cjs/csv/csv.js +162 -226
- package/dist/cjs/doc/anchor.js +2 -2
- package/dist/cjs/doc/cell.js +22 -22
- package/dist/cjs/doc/column.js +7 -7
- package/dist/cjs/doc/data-validations.js +3 -3
- package/dist/cjs/doc/defined-names.js +13 -13
- package/dist/cjs/doc/image.js +7 -7
- package/dist/cjs/doc/modelcontainer.js +2 -2
- package/dist/cjs/doc/note.js +2 -2
- package/dist/cjs/doc/pivot-table.js +5 -5
- package/dist/cjs/doc/range.js +11 -11
- package/dist/cjs/doc/row.js +16 -16
- package/dist/cjs/doc/table.js +5 -5
- package/dist/cjs/doc/workbook.js +179 -68
- package/dist/cjs/doc/worksheet.js +41 -41
- package/dist/cjs/index.js +32 -49
- package/dist/cjs/stream/xlsx/hyperlink-reader.js +6 -6
- package/dist/cjs/stream/xlsx/sheet-comments-writer.js +12 -12
- package/dist/cjs/stream/xlsx/sheet-rels-writer.js +4 -4
- package/dist/cjs/stream/xlsx/workbook-reader.js +22 -22
- package/dist/cjs/stream/xlsx/workbook-writer.js +34 -34
- package/dist/cjs/stream/xlsx/worksheet-reader.js +17 -17
- package/dist/cjs/stream/xlsx/worksheet-writer.js +60 -60
- package/dist/cjs/utils/cell-format.js +2 -2
- package/dist/cjs/utils/cell-matrix.js +5 -5
- package/dist/cjs/utils/parse-sax.js +2 -2
- package/dist/cjs/utils/shared-formula.js +5 -5
- package/dist/cjs/utils/sheet-utils.js +13 -13
- package/dist/cjs/utils/stream-buf.js +5 -5
- package/dist/cjs/utils/unzip/extract.js +11 -11
- package/dist/cjs/utils/unzip/index.js +21 -21
- package/dist/cjs/utils/unzip/parse-extra-field.js +3 -3
- package/dist/cjs/utils/unzip/parse.js +16 -16
- package/dist/cjs/utils/unzip/zip-parser.js +3 -3
- package/dist/cjs/utils/utils.js +154 -46
- package/dist/cjs/utils/xml-stream.js +3 -3
- package/dist/cjs/utils/zip/compress.js +198 -18
- package/dist/cjs/utils/zip/index.js +17 -17
- package/dist/cjs/utils/zip/zip-builder.js +10 -10
- package/dist/cjs/utils/zip-stream.js +4 -4
- package/dist/cjs/xlsx/xform/base-xform.js +4 -4
- package/dist/cjs/xlsx/xform/book/defined-name-xform.js +4 -4
- package/dist/cjs/xlsx/xform/book/sheet-xform.js +4 -4
- package/dist/cjs/xlsx/xform/book/workbook-calc-properties-xform.js +2 -2
- package/dist/cjs/xlsx/xform/book/workbook-pivot-cache-xform.js +2 -2
- package/dist/cjs/xlsx/xform/book/workbook-properties-xform.js +2 -2
- package/dist/cjs/xlsx/xform/book/workbook-view-xform.js +2 -2
- package/dist/cjs/xlsx/xform/book/workbook-xform.js +24 -24
- package/dist/cjs/xlsx/xform/comment/comment-xform.js +4 -4
- package/dist/cjs/xlsx/xform/comment/comments-xform.js +6 -6
- package/dist/cjs/xlsx/xform/comment/style/vml-position-xform.js +2 -2
- package/dist/cjs/xlsx/xform/comment/style/vml-protection-xform.js +2 -2
- package/dist/cjs/xlsx/xform/comment/vml-anchor-xform.js +2 -2
- package/dist/cjs/xlsx/xform/comment/vml-client-data-xform.js +10 -10
- package/dist/cjs/xlsx/xform/comment/vml-notes-xform.js +6 -6
- package/dist/cjs/xlsx/xform/comment/vml-shape-xform.js +6 -6
- package/dist/cjs/xlsx/xform/comment/vml-textbox-xform.js +2 -2
- package/dist/cjs/xlsx/xform/composite-xform.js +2 -2
- package/dist/cjs/xlsx/xform/core/app-heading-pairs-xform.js +2 -2
- package/dist/cjs/xlsx/xform/core/app-titles-of-parts-xform.js +2 -2
- package/dist/cjs/xlsx/xform/core/app-xform.js +11 -11
- package/dist/cjs/xlsx/xform/core/content-types-xform.js +4 -4
- package/dist/cjs/xlsx/xform/core/core-xform.js +23 -23
- package/dist/cjs/xlsx/xform/core/relationship-xform.js +2 -2
- package/dist/cjs/xlsx/xform/core/relationships-xform.js +6 -6
- package/dist/cjs/xlsx/xform/drawing/base-cell-anchor-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/blip-fill-xform.js +4 -4
- package/dist/cjs/xlsx/xform/drawing/blip-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/c-nv-pic-pr-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/c-nv-pr-xform.js +6 -6
- package/dist/cjs/xlsx/xform/drawing/cell-position-xform.js +7 -7
- package/dist/cjs/xlsx/xform/drawing/drawing-xform.js +10 -10
- package/dist/cjs/xlsx/xform/drawing/ext-lst-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/ext-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/hlink-click-xform.js +2 -2
- package/dist/cjs/xlsx/xform/drawing/nv-pic-pr-xform.js +6 -6
- package/dist/cjs/xlsx/xform/drawing/one-cell-anchor-xform.js +10 -10
- package/dist/cjs/xlsx/xform/drawing/pic-xform.js +9 -9
- package/dist/cjs/xlsx/xform/drawing/two-cell-anchor-xform.js +9 -9
- package/dist/cjs/xlsx/xform/list-xform.js +2 -2
- package/dist/cjs/xlsx/xform/pivot-table/cache-field-xform.js +5 -5
- package/dist/cjs/xlsx/xform/pivot-table/cache-field.js +3 -3
- package/dist/cjs/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +10 -10
- package/dist/cjs/xlsx/xform/pivot-table/pivot-cache-records-xform.js +9 -9
- package/dist/cjs/xlsx/xform/pivot-table/pivot-table-xform.js +11 -10
- package/dist/cjs/xlsx/xform/sheet/auto-filter-xform.js +4 -4
- package/dist/cjs/xlsx/xform/sheet/cell-xform.js +65 -65
- package/dist/cjs/xlsx/xform/sheet/cf/cf-rule-xform.js +27 -27
- package/dist/cjs/xlsx/xform/sheet/cf/cfvo-xform.js +3 -3
- package/dist/cjs/xlsx/xform/sheet/cf/color-scale-xform.js +6 -6
- package/dist/cjs/xlsx/xform/sheet/cf/conditional-formatting-xform.js +6 -6
- package/dist/cjs/xlsx/xform/sheet/cf/conditional-formattings-xform.js +4 -4
- package/dist/cjs/xlsx/xform/sheet/cf/databar-xform.js +6 -6
- package/dist/cjs/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +5 -5
- package/dist/cjs/xlsx/xform/sheet/cf/formula-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/cf/icon-set-xform.js +11 -11
- package/dist/cjs/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +3 -3
- package/dist/cjs/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +12 -11
- package/dist/cjs/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +4 -4
- package/dist/cjs/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +8 -8
- package/dist/cjs/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +6 -6
- package/dist/cjs/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +26 -26
- package/dist/cjs/xlsx/xform/sheet/cf-ext/f-ext-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +14 -14
- package/dist/cjs/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/col-xform.js +6 -6
- package/dist/cjs/xlsx/xform/sheet/data-validations-xform.js +18 -18
- package/dist/cjs/xlsx/xform/sheet/dimension-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/drawing-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/ext-lst-xform.js +5 -5
- package/dist/cjs/xlsx/xform/sheet/header-footer-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/hyperlink-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/merge-cell-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/merges.js +8 -8
- package/dist/cjs/xlsx/xform/sheet/outline-properties-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/page-breaks-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/page-margins-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/page-setup-properties-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/page-setup-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/picture-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/print-options-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/row-breaks-xform.js +4 -4
- package/dist/cjs/xlsx/xform/sheet/row-xform.js +11 -11
- package/dist/cjs/xlsx/xform/sheet/sheet-format-properties-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/sheet-properties-xform.js +8 -8
- package/dist/cjs/xlsx/xform/sheet/sheet-protection-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/sheet-view-xform.js +4 -4
- package/dist/cjs/xlsx/xform/sheet/table-part-xform.js +2 -2
- package/dist/cjs/xlsx/xform/sheet/worksheet-xform.js +68 -68
- package/dist/cjs/xlsx/xform/simple/boolean-xform.js +2 -2
- package/dist/cjs/xlsx/xform/simple/date-xform.js +2 -2
- package/dist/cjs/xlsx/xform/simple/float-xform.js +2 -2
- package/dist/cjs/xlsx/xform/simple/integer-xform.js +2 -2
- package/dist/cjs/xlsx/xform/simple/string-xform.js +2 -2
- package/dist/cjs/xlsx/xform/static-xform.js +4 -4
- package/dist/cjs/xlsx/xform/strings/phonetic-text-xform.js +6 -6
- package/dist/cjs/xlsx/xform/strings/rich-text-xform.js +6 -6
- package/dist/cjs/xlsx/xform/strings/shared-string-xform.js +8 -8
- package/dist/cjs/xlsx/xform/strings/shared-strings-xform.js +6 -6
- package/dist/cjs/xlsx/xform/strings/text-xform.js +2 -2
- package/dist/cjs/xlsx/xform/style/alignment-xform.js +8 -8
- package/dist/cjs/xlsx/xform/style/border-xform.js +8 -8
- package/dist/cjs/xlsx/xform/style/color-xform.js +2 -2
- package/dist/cjs/xlsx/xform/style/dxf-xform.js +14 -14
- package/dist/cjs/xlsx/xform/style/fill-xform.js +9 -9
- package/dist/cjs/xlsx/xform/style/font-xform.js +22 -22
- package/dist/cjs/xlsx/xform/style/numfmt-xform.js +5 -5
- package/dist/cjs/xlsx/xform/style/protection-xform.js +2 -2
- package/dist/cjs/xlsx/xform/style/style-xform.js +6 -6
- package/dist/cjs/xlsx/xform/style/styles-xform.js +39 -39
- package/dist/cjs/xlsx/xform/style/underline-xform.js +2 -2
- package/dist/cjs/xlsx/xform/table/auto-filter-xform.js +4 -4
- package/dist/cjs/xlsx/xform/table/custom-filter-xform.js +2 -2
- package/dist/cjs/xlsx/xform/table/filter-column-xform.js +9 -9
- package/dist/cjs/xlsx/xform/table/filter-xform.js +2 -2
- package/dist/cjs/xlsx/xform/table/table-column-xform.js +2 -2
- package/dist/cjs/xlsx/xform/table/table-style-info-xform.js +2 -2
- package/dist/cjs/xlsx/xform/table/table-xform.js +12 -12
- package/dist/cjs/xlsx/xlsx.js +833 -91
- package/dist/esm/csv/csv.js +159 -189
- package/dist/esm/doc/workbook.js +175 -64
- package/dist/esm/index.browser.js +1 -33
- package/dist/esm/index.js +8 -23
- package/dist/esm/local.js +1 -0
- package/dist/esm/utils/utils.js +123 -15
- package/dist/esm/utils/zip/compress.js +164 -16
- package/dist/esm/xlsx/xform/pivot-table/pivot-table-xform.js +3 -2
- package/dist/esm/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +3 -2
- package/dist/esm/xlsx/xlsx.js +829 -87
- package/dist/types/csv/csv.d.ts +71 -97
- package/dist/types/doc/anchor.d.ts +1 -1
- package/dist/types/doc/cell.d.ts +7 -7
- package/dist/types/doc/column.d.ts +3 -3
- package/dist/types/doc/defined-names.d.ts +4 -4
- package/dist/types/doc/image.d.ts +2 -2
- package/dist/types/doc/modelcontainer.d.ts +1 -1
- package/dist/types/doc/pivot-table.d.ts +1 -1
- package/dist/types/doc/range.d.ts +1 -1
- package/dist/types/doc/row.d.ts +3 -3
- package/dist/types/doc/table.d.ts +2 -2
- package/dist/types/doc/workbook.d.ts +92 -62
- package/dist/types/doc/worksheet.d.ts +10 -10
- package/dist/types/index.browser.d.ts +5 -19
- package/dist/types/index.d.ts +23 -24
- package/dist/types/local.d.ts +1 -0
- package/dist/types/stream/xlsx/hyperlink-reader.d.ts +1 -1
- package/dist/types/stream/xlsx/workbook-reader.d.ts +4 -4
- package/dist/types/stream/xlsx/workbook-writer.d.ts +6 -6
- package/dist/types/stream/xlsx/worksheet-reader.d.ts +5 -5
- package/dist/types/stream/xlsx/worksheet-writer.d.ts +9 -9
- package/dist/types/utils/col-cache.d.ts +1 -1
- package/dist/types/utils/sheet-utils.d.ts +3 -3
- package/dist/types/utils/unzip/extract.d.ts +6 -6
- package/dist/types/utils/unzip/index.d.ts +8 -8
- package/dist/types/utils/unzip/parse.d.ts +3 -3
- package/dist/types/utils/utils.d.ts +25 -6
- package/dist/types/utils/zip/compress.d.ts +45 -13
- package/dist/types/utils/zip/index.d.ts +5 -5
- package/dist/types/utils/zip/zip-builder.d.ts +1 -1
- package/dist/types/xlsx/xform/base-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/defined-name-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/sheet-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/workbook-calc-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/workbook-pivot-cache-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/workbook-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/workbook-view-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/book/workbook-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/comment/comment-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/comment/comments-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/comment/style/vml-position-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/style/vml-protection-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/vml-anchor-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/vml-client-data-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/vml-notes-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/vml-shape-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/comment/vml-textbox-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/composite-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/app-heading-pairs-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/app-titles-of-parts-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/app-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/content-types-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/core-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/relationship-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/core/relationships-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/base-cell-anchor-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/blip-fill-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/drawing/blip-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/c-nv-pic-pr-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/c-nv-pr-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/cell-position-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/drawing/drawing-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/ext-lst-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/ext-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/hlink-click-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/nv-pic-pr-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/one-cell-anchor-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/pic-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/drawing/two-cell-anchor-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/list-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/pivot-table/cache-field-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/pivot-table/pivot-cache-definition-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/pivot-table/pivot-cache-records-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/pivot-table/pivot-table-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/auto-filter-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cell-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf/cf-rule-xform.d.ts +6 -6
- package/dist/types/xlsx/xform/sheet/cf/cfvo-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf/color-scale-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf/conditional-formatting-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf/conditional-formattings-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/sheet/cf/databar-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf/ext-lst-ref-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf/formula-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf/icon-set-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/sheet/cf-ext/databar-ext-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf-ext/f-ext-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/sheet/cf-ext/sqref-ext-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/col-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/data-validations-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/dimension-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/drawing-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/ext-lst-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/header-footer-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/hyperlink-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/merge-cell-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/outline-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/page-breaks-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/page-margins-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/page-setup-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/page-setup-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/picture-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/print-options-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/row-breaks-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/row-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/sheet-format-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/sheet-properties-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/sheet-protection-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/sheet-view-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/table-part-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/sheet/worksheet-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/simple/boolean-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/simple/date-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/simple/float-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/simple/integer-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/simple/string-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/static-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/strings/phonetic-text-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/strings/rich-text-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/strings/shared-string-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/strings/shared-strings-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/strings/text-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/alignment-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/border-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/style/color-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/dxf-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/fill-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/style/font-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/numfmt-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/protection-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/style/style-xform.d.ts +3 -3
- package/dist/types/xlsx/xform/style/styles-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/style/underline-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/table/auto-filter-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/table/custom-filter-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/table/filter-column-xform.d.ts +2 -2
- package/dist/types/xlsx/xform/table/filter-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/table/table-column-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/table/table-style-info-xform.d.ts +1 -1
- package/dist/types/xlsx/xform/table/table-xform.d.ts +1 -1
- package/dist/types/xlsx/xlsx.d.ts +80 -20
- package/package.json +15 -13
- package/dist/browser/excelts.esm.js +0 -19115
- package/dist/browser/excelts.esm.js.map +0 -1
- package/dist/browser/excelts.esm.min.js +0 -127
- package/dist/cjs/csv/csv-core.js +0 -701
- package/dist/cjs/csv/csv-stream.js +0 -646
- package/dist/cjs/csv/csv.base.js +0 -154
- package/dist/cjs/csv/csv.browser.js +0 -68
- package/dist/cjs/doc/workbook.base.js +0 -211
- package/dist/cjs/doc/workbook.browser.js +0 -62
- package/dist/cjs/utils/browser-buffer.js +0 -75
- package/dist/cjs/utils/encryptor.browser.js +0 -240
- package/dist/cjs/utils/stream-buf.browser.js +0 -355
- package/dist/cjs/utils/utils.base.js +0 -161
- package/dist/cjs/utils/utils.browser.js +0 -89
- package/dist/cjs/utils/zip/compress.base.js +0 -85
- package/dist/cjs/utils/zip/compress.browser.js +0 -83
- package/dist/cjs/utils/zip/crc32.browser.js +0 -88
- package/dist/cjs/utils/zip-stream.browser.js +0 -135
- package/dist/cjs/xlsx/xlsx.base.js +0 -742
- package/dist/cjs/xlsx/xlsx.browser.js +0 -205
- package/dist/esm/csv/csv-core.js +0 -694
- package/dist/esm/csv/csv-stream.js +0 -638
- package/dist/esm/csv/csv.base.js +0 -141
- package/dist/esm/csv/csv.browser.js +0 -65
- package/dist/esm/doc/workbook.base.js +0 -207
- package/dist/esm/doc/workbook.browser.js +0 -59
- package/dist/esm/utils/browser-buffer.js +0 -67
- package/dist/esm/utils/encryptor.browser.js +0 -237
- package/dist/esm/utils/stream-buf.browser.js +0 -352
- package/dist/esm/utils/utils.base.js +0 -142
- package/dist/esm/utils/utils.browser.js +0 -68
- package/dist/esm/utils/zip/compress.base.js +0 -80
- package/dist/esm/utils/zip/compress.browser.js +0 -76
- package/dist/esm/utils/zip/crc32.browser.js +0 -82
- package/dist/esm/utils/zip-stream.browser.js +0 -132
- package/dist/esm/xlsx/xlsx.base.js +0 -739
- package/dist/esm/xlsx/xlsx.browser.js +0 -202
- package/dist/types/csv/csv-core.d.ts +0 -207
- package/dist/types/csv/csv-stream.d.ts +0 -114
- package/dist/types/csv/csv.base.d.ts +0 -61
- package/dist/types/csv/csv.browser.d.ts +0 -33
- package/dist/types/doc/workbook.base.d.ts +0 -111
- package/dist/types/doc/workbook.browser.d.ts +0 -38
- package/dist/types/utils/browser-buffer.d.ts +0 -28
- package/dist/types/utils/encryptor.browser.d.ts +0 -28
- package/dist/types/utils/stream-buf.browser.d.ts +0 -41
- package/dist/types/utils/utils.base.d.ts +0 -29
- package/dist/types/utils/utils.browser.d.ts +0 -29
- package/dist/types/utils/zip/compress.base.d.ts +0 -42
- package/dist/types/utils/zip/compress.browser.d.ts +0 -54
- package/dist/types/utils/zip/crc32.browser.d.ts +0 -52
- package/dist/types/utils/zip-stream.browser.d.ts +0 -39
- package/dist/types/xlsx/xlsx.base.d.ts +0 -134
- package/dist/types/xlsx/xlsx.browser.d.ts +0 -31
|
@@ -1,237 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Browser-compatible Encryptor with pure JS SHA implementations
|
|
3
|
-
* This provides synchronous hash functions for browser compatibility
|
|
4
|
-
*/
|
|
5
|
-
import { BrowserBuffer, base64ToUint8Array, uint8ArrayToBase64, stringToUtf16Le, concatUint8Arrays } from "./browser-buffer.js";
|
|
6
|
-
// Helper to convert number to little-endian Uint8Array
|
|
7
|
-
function uint32ToLe(num) {
|
|
8
|
-
const bytes = new Uint8Array(4);
|
|
9
|
-
bytes[0] = num & 0xff;
|
|
10
|
-
bytes[1] = (num >> 8) & 0xff;
|
|
11
|
-
bytes[2] = (num >> 16) & 0xff;
|
|
12
|
-
bytes[3] = (num >> 24) & 0xff;
|
|
13
|
-
return bytes;
|
|
14
|
-
}
|
|
15
|
-
// ============================================================================
|
|
16
|
-
// Pure JavaScript SHA-512 implementation
|
|
17
|
-
// ============================================================================
|
|
18
|
-
// SHA-512 constants (first 80 primes 2..409)
|
|
19
|
-
const K = new BigUint64Array([
|
|
20
|
-
0x428a2f98d728ae22n,
|
|
21
|
-
0x7137449123ef65cdn,
|
|
22
|
-
0xb5c0fbcfec4d3b2fn,
|
|
23
|
-
0xe9b5dba58189dbb4n,
|
|
24
|
-
0x3956c25bf348b538n,
|
|
25
|
-
0x59f111f1b605d019n,
|
|
26
|
-
0x923f82a4af194f9bn,
|
|
27
|
-
0xab1c5ed5da6d8118n,
|
|
28
|
-
0xd807aa98a3030242n,
|
|
29
|
-
0x12835b0145706fben,
|
|
30
|
-
0x243185be4ee4b28cn,
|
|
31
|
-
0x550c7dc3d5ffb4e2n,
|
|
32
|
-
0x72be5d74f27b896fn,
|
|
33
|
-
0x80deb1fe3b1696b1n,
|
|
34
|
-
0x9bdc06a725c71235n,
|
|
35
|
-
0xc19bf174cf692694n,
|
|
36
|
-
0xe49b69c19ef14ad2n,
|
|
37
|
-
0xefbe4786384f25e3n,
|
|
38
|
-
0x0fc19dc68b8cd5b5n,
|
|
39
|
-
0x240ca1cc77ac9c65n,
|
|
40
|
-
0x2de92c6f592b0275n,
|
|
41
|
-
0x4a7484aa6ea6e483n,
|
|
42
|
-
0x5cb0a9dcbd41fbd4n,
|
|
43
|
-
0x76f988da831153b5n,
|
|
44
|
-
0x983e5152ee66dfabn,
|
|
45
|
-
0xa831c66d2db43210n,
|
|
46
|
-
0xb00327c898fb213fn,
|
|
47
|
-
0xbf597fc7beef0ee4n,
|
|
48
|
-
0xc6e00bf33da88fc2n,
|
|
49
|
-
0xd5a79147930aa725n,
|
|
50
|
-
0x06ca6351e003826fn,
|
|
51
|
-
0x142929670a0e6e70n,
|
|
52
|
-
0x27b70a8546d22ffcn,
|
|
53
|
-
0x2e1b21385c26c926n,
|
|
54
|
-
0x4d2c6dfc5ac42aedn,
|
|
55
|
-
0x53380d139d95b3dfn,
|
|
56
|
-
0x650a73548baf63den,
|
|
57
|
-
0x766a0abb3c77b2a8n,
|
|
58
|
-
0x81c2c92e47edaee6n,
|
|
59
|
-
0x92722c851482353bn,
|
|
60
|
-
0xa2bfe8a14cf10364n,
|
|
61
|
-
0xa81a664bbc423001n,
|
|
62
|
-
0xc24b8b70d0f89791n,
|
|
63
|
-
0xc76c51a30654be30n,
|
|
64
|
-
0xd192e819d6ef5218n,
|
|
65
|
-
0xd69906245565a910n,
|
|
66
|
-
0xf40e35855771202an,
|
|
67
|
-
0x106aa07032bbd1b8n,
|
|
68
|
-
0x19a4c116b8d2d0c8n,
|
|
69
|
-
0x1e376c085141ab53n,
|
|
70
|
-
0x2748774cdf8eeb99n,
|
|
71
|
-
0x34b0bcb5e19b48a8n,
|
|
72
|
-
0x391c0cb3c5c95a63n,
|
|
73
|
-
0x4ed8aa4ae3418acbn,
|
|
74
|
-
0x5b9cca4f7763e373n,
|
|
75
|
-
0x682e6ff3d6b2b8a3n,
|
|
76
|
-
0x748f82ee5defb2fcn,
|
|
77
|
-
0x78a5636f43172f60n,
|
|
78
|
-
0x84c87814a1f0ab72n,
|
|
79
|
-
0x8cc702081a6439ecn,
|
|
80
|
-
0x90befffa23631e28n,
|
|
81
|
-
0xa4506cebde82bde9n,
|
|
82
|
-
0xbef9a3f7b2c67915n,
|
|
83
|
-
0xc67178f2e372532bn,
|
|
84
|
-
0xca273eceea26619cn,
|
|
85
|
-
0xd186b8c721c0c207n,
|
|
86
|
-
0xeada7dd6cde0eb1en,
|
|
87
|
-
0xf57d4f7fee6ed178n,
|
|
88
|
-
0x06f067aa72176fban,
|
|
89
|
-
0x0a637dc5a2c898a6n,
|
|
90
|
-
0x113f9804bef90daen,
|
|
91
|
-
0x1b710b35131c471bn,
|
|
92
|
-
0x28db77f523047d84n,
|
|
93
|
-
0x32caab7b40c72493n,
|
|
94
|
-
0x3c9ebe0a15c9bebcn,
|
|
95
|
-
0x431d67c49c100d4cn,
|
|
96
|
-
0x4cc5d4becb3e42b6n,
|
|
97
|
-
0x597f299cfc657e2an,
|
|
98
|
-
0x5fcb6fab3ad6faecn,
|
|
99
|
-
0x6c44198c4a475817n
|
|
100
|
-
]);
|
|
101
|
-
// Initial hash values for SHA-512
|
|
102
|
-
const H0 = new BigUint64Array([
|
|
103
|
-
0x6a09e667f3bcc908n,
|
|
104
|
-
0xbb67ae8584caa73bn,
|
|
105
|
-
0x3c6ef372fe94f82bn,
|
|
106
|
-
0xa54ff53a5f1d36f1n,
|
|
107
|
-
0x510e527fade682d1n,
|
|
108
|
-
0x9b05688c2b3e6c1fn,
|
|
109
|
-
0x1f83d9abfb41bd6bn,
|
|
110
|
-
0x5be0cd19137e2179n
|
|
111
|
-
]);
|
|
112
|
-
function rotr64(x, n) {
|
|
113
|
-
return ((x >> BigInt(n)) | (x << BigInt(64 - n))) & 0xffffffffffffffffn;
|
|
114
|
-
}
|
|
115
|
-
function sha512(message) {
|
|
116
|
-
// Pre-processing: adding padding bits
|
|
117
|
-
const msgLen = message.length;
|
|
118
|
-
const msgBitLen = BigInt(msgLen * 8);
|
|
119
|
-
// Calculate padding length (message + 1 + padding + 16 bytes for length) should be multiple of 128
|
|
120
|
-
const padLen = (128 - ((msgLen + 17) % 128)) % 128;
|
|
121
|
-
const paddedLen = msgLen + 1 + padLen + 16;
|
|
122
|
-
const padded = new Uint8Array(paddedLen);
|
|
123
|
-
padded.set(message);
|
|
124
|
-
padded[msgLen] = 0x80;
|
|
125
|
-
// Append original length in bits as 128-bit big-endian (we only use lower 64 bits)
|
|
126
|
-
const view = new DataView(padded.buffer);
|
|
127
|
-
// Upper 64 bits (always 0 for messages < 2^64 bits)
|
|
128
|
-
view.setBigUint64(paddedLen - 16, 0n, false);
|
|
129
|
-
// Lower 64 bits
|
|
130
|
-
view.setBigUint64(paddedLen - 8, msgBitLen, false);
|
|
131
|
-
// Initialize hash values
|
|
132
|
-
const H = new BigUint64Array(H0);
|
|
133
|
-
// Process message in 1024-bit (128-byte) chunks
|
|
134
|
-
const W = new BigUint64Array(80);
|
|
135
|
-
for (let chunkStart = 0; chunkStart < paddedLen; chunkStart += 128) {
|
|
136
|
-
const chunkView = new DataView(padded.buffer, chunkStart, 128);
|
|
137
|
-
// Copy chunk into first 16 words W[0..15]
|
|
138
|
-
for (let i = 0; i < 16; i++) {
|
|
139
|
-
W[i] = chunkView.getBigUint64(i * 8, false);
|
|
140
|
-
}
|
|
141
|
-
// Extend the first 16 words into the remaining 64 words W[16..79]
|
|
142
|
-
for (let i = 16; i < 80; i++) {
|
|
143
|
-
const s0 = rotr64(W[i - 15], 1) ^ rotr64(W[i - 15], 8) ^ (W[i - 15] >> 7n);
|
|
144
|
-
const s1 = rotr64(W[i - 2], 19) ^ rotr64(W[i - 2], 61) ^ (W[i - 2] >> 6n);
|
|
145
|
-
W[i] = (W[i - 16] + s0 + W[i - 7] + s1) & 0xffffffffffffffffn;
|
|
146
|
-
}
|
|
147
|
-
// Initialize working variables
|
|
148
|
-
let a = H[0], b = H[1], c = H[2], d = H[3];
|
|
149
|
-
let e = H[4], f = H[5], g = H[6], h = H[7];
|
|
150
|
-
// Main loop
|
|
151
|
-
for (let i = 0; i < 80; i++) {
|
|
152
|
-
const S1 = rotr64(e, 14) ^ rotr64(e, 18) ^ rotr64(e, 41);
|
|
153
|
-
const ch = (e & f) ^ (~e & g);
|
|
154
|
-
const temp1 = (h + S1 + ch + K[i] + W[i]) & 0xffffffffffffffffn;
|
|
155
|
-
const S0 = rotr64(a, 28) ^ rotr64(a, 34) ^ rotr64(a, 39);
|
|
156
|
-
const maj = (a & b) ^ (a & c) ^ (b & c);
|
|
157
|
-
const temp2 = (S0 + maj) & 0xffffffffffffffffn;
|
|
158
|
-
h = g;
|
|
159
|
-
g = f;
|
|
160
|
-
f = e;
|
|
161
|
-
e = (d + temp1) & 0xffffffffffffffffn;
|
|
162
|
-
d = c;
|
|
163
|
-
c = b;
|
|
164
|
-
b = a;
|
|
165
|
-
a = (temp1 + temp2) & 0xffffffffffffffffn;
|
|
166
|
-
}
|
|
167
|
-
// Add compressed chunk to current hash value
|
|
168
|
-
H[0] = (H[0] + a) & 0xffffffffffffffffn;
|
|
169
|
-
H[1] = (H[1] + b) & 0xffffffffffffffffn;
|
|
170
|
-
H[2] = (H[2] + c) & 0xffffffffffffffffn;
|
|
171
|
-
H[3] = (H[3] + d) & 0xffffffffffffffffn;
|
|
172
|
-
H[4] = (H[4] + e) & 0xffffffffffffffffn;
|
|
173
|
-
H[5] = (H[5] + f) & 0xffffffffffffffffn;
|
|
174
|
-
H[6] = (H[6] + g) & 0xffffffffffffffffn;
|
|
175
|
-
H[7] = (H[7] + h) & 0xffffffffffffffffn;
|
|
176
|
-
}
|
|
177
|
-
// Produce the final hash value (big-endian)
|
|
178
|
-
const result = new Uint8Array(64);
|
|
179
|
-
const resultView = new DataView(result.buffer);
|
|
180
|
-
for (let i = 0; i < 8; i++) {
|
|
181
|
-
resultView.setBigUint64(i * 8, H[i], false);
|
|
182
|
-
}
|
|
183
|
-
return result;
|
|
184
|
-
}
|
|
185
|
-
// ============================================================================
|
|
186
|
-
// Encryptor implementation
|
|
187
|
-
// ============================================================================
|
|
188
|
-
const Encryptor = {
|
|
189
|
-
/**
|
|
190
|
-
* Calculate a hash of the concatenated buffers with the given algorithm.
|
|
191
|
-
* @param algorithm - The hash algorithm.
|
|
192
|
-
* @returns The hash as Uint8Array
|
|
193
|
-
*/
|
|
194
|
-
hash(algorithm, ...buffers) {
|
|
195
|
-
const data = concatUint8Arrays(...buffers);
|
|
196
|
-
const algo = algorithm.toLowerCase().replace("-", "");
|
|
197
|
-
if (algo === "sha512") {
|
|
198
|
-
return sha512(data);
|
|
199
|
-
}
|
|
200
|
-
throw new Error(`Hash algorithm '${algorithm}' not supported in browser sync mode!`);
|
|
201
|
-
},
|
|
202
|
-
/**
|
|
203
|
-
* Convert a password into an encryption key
|
|
204
|
-
* @param password - The password
|
|
205
|
-
* @param hashAlgorithm - The hash algorithm
|
|
206
|
-
* @param saltValue - The salt value (base64 encoded)
|
|
207
|
-
* @param spinCount - The spin count
|
|
208
|
-
* @returns The encryption key (base64 encoded)
|
|
209
|
-
*/
|
|
210
|
-
convertPasswordToHash(password, hashAlgorithm, saltValue, spinCount) {
|
|
211
|
-
const algo = hashAlgorithm.toLowerCase().replace("-", "");
|
|
212
|
-
if (algo !== "sha512") {
|
|
213
|
-
throw new Error(`Hash algorithm '${hashAlgorithm}' not supported in browser!`);
|
|
214
|
-
}
|
|
215
|
-
// Password must be in unicode buffer (UTF-16LE)
|
|
216
|
-
const passwordBuffer = stringToUtf16Le(password);
|
|
217
|
-
// Generate the initial hash
|
|
218
|
-
const saltBuffer = base64ToUint8Array(saltValue);
|
|
219
|
-
let key = this.hash(hashAlgorithm, saltBuffer, passwordBuffer);
|
|
220
|
-
// Now regenerate until spin count
|
|
221
|
-
for (let i = 0; i < spinCount; i++) {
|
|
222
|
-
const iterator = uint32ToLe(i);
|
|
223
|
-
key = this.hash(hashAlgorithm, key, iterator);
|
|
224
|
-
}
|
|
225
|
-
return uint8ArrayToBase64(key);
|
|
226
|
-
},
|
|
227
|
-
/**
|
|
228
|
-
* Generates cryptographically strong pseudo-random data.
|
|
229
|
-
* @param size The size argument is a number indicating the number of bytes to generate.
|
|
230
|
-
*/
|
|
231
|
-
randomBytes(size) {
|
|
232
|
-
const bytes = new BrowserBuffer(size);
|
|
233
|
-
crypto.getRandomValues(bytes);
|
|
234
|
-
return bytes;
|
|
235
|
-
}
|
|
236
|
-
};
|
|
237
|
-
export { Encryptor };
|
|
@@ -1,352 +0,0 @@
|
|
|
1
|
-
import { StringBuf } from "./string-buf.js";
|
|
2
|
-
// =============================================================================
|
|
3
|
-
// Data chunks - encapsulating incoming data
|
|
4
|
-
class StringChunk {
|
|
5
|
-
constructor(data, encoding) {
|
|
6
|
-
this._data = data;
|
|
7
|
-
this._encoding = encoding;
|
|
8
|
-
}
|
|
9
|
-
get length() {
|
|
10
|
-
return this.toBuffer().length;
|
|
11
|
-
}
|
|
12
|
-
copy(target, targetOffset, offset, length) {
|
|
13
|
-
const buf = this.toBuffer();
|
|
14
|
-
const bytesToCopy = Math.min(length, buf.length - offset);
|
|
15
|
-
target.set(buf.subarray(offset, offset + bytesToCopy), targetOffset);
|
|
16
|
-
return bytesToCopy;
|
|
17
|
-
}
|
|
18
|
-
toBuffer() {
|
|
19
|
-
if (!this._buffer) {
|
|
20
|
-
this._buffer = new TextEncoder().encode(this._data);
|
|
21
|
-
}
|
|
22
|
-
return this._buffer;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
class StringBufChunk {
|
|
26
|
-
constructor(data) {
|
|
27
|
-
this._data = data;
|
|
28
|
-
}
|
|
29
|
-
get length() {
|
|
30
|
-
return this._data.length;
|
|
31
|
-
}
|
|
32
|
-
copy(target, targetOffset, offset, length) {
|
|
33
|
-
const buf = this.toBuffer();
|
|
34
|
-
const bytesToCopy = Math.min(length, buf.length - offset);
|
|
35
|
-
target.set(buf.subarray(offset, offset + bytesToCopy), targetOffset);
|
|
36
|
-
return bytesToCopy;
|
|
37
|
-
}
|
|
38
|
-
toBuffer() {
|
|
39
|
-
return this._data.toBuffer();
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
class BufferChunk {
|
|
43
|
-
constructor(data) {
|
|
44
|
-
this._data = data;
|
|
45
|
-
}
|
|
46
|
-
get length() {
|
|
47
|
-
return this._data.length;
|
|
48
|
-
}
|
|
49
|
-
copy(target, targetOffset, offset, length) {
|
|
50
|
-
const bytesToCopy = Math.min(length, this._data.length - offset);
|
|
51
|
-
target.set(this._data.subarray(offset, offset + bytesToCopy), targetOffset);
|
|
52
|
-
}
|
|
53
|
-
toBuffer() {
|
|
54
|
-
return this._data;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
// =============================================================================
|
|
58
|
-
// ReadWriteBuf - a single buffer supporting simple read-write
|
|
59
|
-
class ReadWriteBuf {
|
|
60
|
-
constructor(size) {
|
|
61
|
-
this.size = size;
|
|
62
|
-
this.buffer = new Uint8Array(size);
|
|
63
|
-
this.iRead = 0;
|
|
64
|
-
this.iWrite = 0;
|
|
65
|
-
}
|
|
66
|
-
toBuffer() {
|
|
67
|
-
if (this.iRead === 0 && this.iWrite === this.size) {
|
|
68
|
-
return this.buffer;
|
|
69
|
-
}
|
|
70
|
-
return this.buffer.slice(this.iRead, this.iWrite);
|
|
71
|
-
}
|
|
72
|
-
get length() {
|
|
73
|
-
return this.iWrite - this.iRead;
|
|
74
|
-
}
|
|
75
|
-
get eod() {
|
|
76
|
-
return this.iRead === this.iWrite;
|
|
77
|
-
}
|
|
78
|
-
get full() {
|
|
79
|
-
return this.iWrite === this.size;
|
|
80
|
-
}
|
|
81
|
-
read(size) {
|
|
82
|
-
if (size === 0) {
|
|
83
|
-
return null;
|
|
84
|
-
}
|
|
85
|
-
if (size === undefined || size >= this.length) {
|
|
86
|
-
const buf = this.toBuffer();
|
|
87
|
-
this.iRead = this.iWrite;
|
|
88
|
-
return buf;
|
|
89
|
-
}
|
|
90
|
-
const buf = this.buffer.slice(this.iRead, this.iRead + size);
|
|
91
|
-
this.iRead += size;
|
|
92
|
-
return buf;
|
|
93
|
-
}
|
|
94
|
-
write(chunk, offset, length) {
|
|
95
|
-
const size = Math.min(length, this.size - this.iWrite);
|
|
96
|
-
chunk.copy(this.buffer, this.iWrite, offset, offset + size);
|
|
97
|
-
this.iWrite += size;
|
|
98
|
-
return size;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
// =============================================================================
|
|
102
|
-
// StreamBuf - Browser version without Node.js stream dependency
|
|
103
|
-
// A simple buffer manager that mimics stream behavior for xlsx writing
|
|
104
|
-
class StreamBuf {
|
|
105
|
-
constructor(options) {
|
|
106
|
-
options = options || {};
|
|
107
|
-
this.bufSize = options.bufSize || 1024 * 1024;
|
|
108
|
-
this.buffers = [];
|
|
109
|
-
this.batch = options.batch || false;
|
|
110
|
-
this.corked = false;
|
|
111
|
-
this.paused = false;
|
|
112
|
-
this.encoding = null;
|
|
113
|
-
this.pipes = [];
|
|
114
|
-
this.events = new Map();
|
|
115
|
-
}
|
|
116
|
-
// Event emitter methods
|
|
117
|
-
on(event, callback) {
|
|
118
|
-
const callbacks = this.events.get(event) || [];
|
|
119
|
-
callbacks.push(callback);
|
|
120
|
-
this.events.set(event, callbacks);
|
|
121
|
-
return this;
|
|
122
|
-
}
|
|
123
|
-
once(event, callback) {
|
|
124
|
-
const onceCallback = (...args) => {
|
|
125
|
-
this.off(event, onceCallback);
|
|
126
|
-
callback(...args);
|
|
127
|
-
};
|
|
128
|
-
return this.on(event, onceCallback);
|
|
129
|
-
}
|
|
130
|
-
off(event, callback) {
|
|
131
|
-
const callbacks = this.events.get(event) || [];
|
|
132
|
-
const index = callbacks.indexOf(callback);
|
|
133
|
-
if (index !== -1) {
|
|
134
|
-
callbacks.splice(index, 1);
|
|
135
|
-
}
|
|
136
|
-
return this;
|
|
137
|
-
}
|
|
138
|
-
emit(event, ...args) {
|
|
139
|
-
const callbacks = this.events.get(event) || [];
|
|
140
|
-
callbacks.forEach(cb => cb(...args));
|
|
141
|
-
return callbacks.length > 0;
|
|
142
|
-
}
|
|
143
|
-
removeListener(event, callback) {
|
|
144
|
-
return this.off(event, callback);
|
|
145
|
-
}
|
|
146
|
-
toBuffer() {
|
|
147
|
-
switch (this.buffers.length) {
|
|
148
|
-
case 0:
|
|
149
|
-
return null;
|
|
150
|
-
case 1:
|
|
151
|
-
return this.buffers[0].toBuffer();
|
|
152
|
-
default: {
|
|
153
|
-
const totalLength = this.buffers.reduce((acc, buf) => acc + buf.length, 0);
|
|
154
|
-
const result = new Uint8Array(totalLength);
|
|
155
|
-
let offset = 0;
|
|
156
|
-
for (const rwBuf of this.buffers) {
|
|
157
|
-
const buf = rwBuf.toBuffer();
|
|
158
|
-
result.set(buf, offset);
|
|
159
|
-
offset += buf.length;
|
|
160
|
-
}
|
|
161
|
-
return result;
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
_getWritableBuffer() {
|
|
166
|
-
if (this.buffers.length) {
|
|
167
|
-
const last = this.buffers[this.buffers.length - 1];
|
|
168
|
-
if (!last.full) {
|
|
169
|
-
return last;
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
const buf = new ReadWriteBuf(this.bufSize);
|
|
173
|
-
this.buffers.push(buf);
|
|
174
|
-
return buf;
|
|
175
|
-
}
|
|
176
|
-
async _pipe(chunk) {
|
|
177
|
-
const write = (pipe) => {
|
|
178
|
-
return new Promise(resolve => {
|
|
179
|
-
pipe.write(chunk.toBuffer(), () => {
|
|
180
|
-
resolve();
|
|
181
|
-
});
|
|
182
|
-
});
|
|
183
|
-
};
|
|
184
|
-
await Promise.all(this.pipes.map(write));
|
|
185
|
-
}
|
|
186
|
-
_writeToBuffers(chunk) {
|
|
187
|
-
let inPos = 0;
|
|
188
|
-
const inLen = chunk.length;
|
|
189
|
-
while (inPos < inLen) {
|
|
190
|
-
const buffer = this._getWritableBuffer();
|
|
191
|
-
inPos += buffer.write(chunk, inPos, inLen - inPos);
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
async write(data, encoding, callback) {
|
|
195
|
-
const nop = () => { };
|
|
196
|
-
if (encoding instanceof Function) {
|
|
197
|
-
callback = encoding;
|
|
198
|
-
encoding = "utf8";
|
|
199
|
-
}
|
|
200
|
-
callback = callback || nop;
|
|
201
|
-
let chunk;
|
|
202
|
-
if (data instanceof StringBuf || (data && data.constructor?.name === "StringBuf")) {
|
|
203
|
-
chunk = new StringBufChunk(data);
|
|
204
|
-
}
|
|
205
|
-
else if (data instanceof Uint8Array) {
|
|
206
|
-
chunk = new BufferChunk(data);
|
|
207
|
-
}
|
|
208
|
-
else if (ArrayBuffer.isView(data)) {
|
|
209
|
-
chunk = new BufferChunk(new Uint8Array(data.buffer, data.byteOffset, data.byteLength));
|
|
210
|
-
}
|
|
211
|
-
else if (data instanceof ArrayBuffer) {
|
|
212
|
-
chunk = new BufferChunk(new Uint8Array(data));
|
|
213
|
-
}
|
|
214
|
-
else if (typeof data === "string" || data instanceof String) {
|
|
215
|
-
chunk = new StringChunk(String(data), encoding);
|
|
216
|
-
}
|
|
217
|
-
else {
|
|
218
|
-
throw new Error("Chunk must be one of type String, Uint8Array, ArrayBuffer or StringBuf.");
|
|
219
|
-
}
|
|
220
|
-
if (this.pipes.length) {
|
|
221
|
-
if (this.batch) {
|
|
222
|
-
this._writeToBuffers(chunk);
|
|
223
|
-
while (!this.corked && this.buffers.length > 1) {
|
|
224
|
-
await this._pipe(new BufferChunk(this.buffers.shift().toBuffer()));
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
else if (!this.corked) {
|
|
228
|
-
await this._pipe(chunk);
|
|
229
|
-
callback();
|
|
230
|
-
}
|
|
231
|
-
else {
|
|
232
|
-
this._writeToBuffers(chunk);
|
|
233
|
-
queueMicrotask(() => callback());
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
else {
|
|
237
|
-
if (!this.paused) {
|
|
238
|
-
this.emit("data", chunk.toBuffer());
|
|
239
|
-
}
|
|
240
|
-
this._writeToBuffers(chunk);
|
|
241
|
-
this.emit("readable");
|
|
242
|
-
}
|
|
243
|
-
return true;
|
|
244
|
-
}
|
|
245
|
-
cork() {
|
|
246
|
-
this.corked = true;
|
|
247
|
-
}
|
|
248
|
-
_flush() {
|
|
249
|
-
if (this.pipes.length) {
|
|
250
|
-
while (this.buffers.length) {
|
|
251
|
-
this._pipe(new BufferChunk(this.buffers.shift().toBuffer()));
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
uncork() {
|
|
256
|
-
this.corked = false;
|
|
257
|
-
this._flush();
|
|
258
|
-
}
|
|
259
|
-
end(chunk, encoding, callback) {
|
|
260
|
-
const writeComplete = (error) => {
|
|
261
|
-
if (error) {
|
|
262
|
-
callback?.(error);
|
|
263
|
-
}
|
|
264
|
-
else {
|
|
265
|
-
this._flush();
|
|
266
|
-
this.pipes.forEach((pipe) => {
|
|
267
|
-
pipe.end();
|
|
268
|
-
});
|
|
269
|
-
this.emit("finish");
|
|
270
|
-
}
|
|
271
|
-
};
|
|
272
|
-
if (chunk) {
|
|
273
|
-
this.write(chunk, encoding, writeComplete);
|
|
274
|
-
}
|
|
275
|
-
else {
|
|
276
|
-
writeComplete();
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
read(size) {
|
|
280
|
-
let buffers;
|
|
281
|
-
if (size) {
|
|
282
|
-
buffers = [];
|
|
283
|
-
while (size && this.buffers.length && !this.buffers[0].eod) {
|
|
284
|
-
const first = this.buffers[0];
|
|
285
|
-
const buffer = first.read(size);
|
|
286
|
-
if (buffer) {
|
|
287
|
-
size -= buffer.length;
|
|
288
|
-
buffers.push(buffer);
|
|
289
|
-
}
|
|
290
|
-
if (first.eod && first.full) {
|
|
291
|
-
this.buffers.shift();
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
return concatUint8Arrays(buffers);
|
|
295
|
-
}
|
|
296
|
-
buffers = this.buffers.map(buf => buf.toBuffer()).filter(Boolean);
|
|
297
|
-
this.buffers = [];
|
|
298
|
-
return concatUint8Arrays(buffers);
|
|
299
|
-
}
|
|
300
|
-
setEncoding(encoding) {
|
|
301
|
-
this.encoding = encoding;
|
|
302
|
-
}
|
|
303
|
-
pause() {
|
|
304
|
-
this.paused = true;
|
|
305
|
-
}
|
|
306
|
-
resume() {
|
|
307
|
-
this.paused = false;
|
|
308
|
-
}
|
|
309
|
-
isPaused() {
|
|
310
|
-
return this.paused;
|
|
311
|
-
}
|
|
312
|
-
pipe(destination) {
|
|
313
|
-
this.pipes.push(destination);
|
|
314
|
-
if (!this.paused && this.buffers.length) {
|
|
315
|
-
this.end();
|
|
316
|
-
}
|
|
317
|
-
return destination;
|
|
318
|
-
}
|
|
319
|
-
unpipe(destination) {
|
|
320
|
-
this.pipes = this.pipes.filter((pipe) => pipe !== destination);
|
|
321
|
-
}
|
|
322
|
-
unshift() {
|
|
323
|
-
throw new Error("Not Implemented");
|
|
324
|
-
}
|
|
325
|
-
wrap() {
|
|
326
|
-
throw new Error("Not Implemented");
|
|
327
|
-
}
|
|
328
|
-
push(chunk) {
|
|
329
|
-
if (chunk !== null) {
|
|
330
|
-
this.write(chunk);
|
|
331
|
-
}
|
|
332
|
-
return true;
|
|
333
|
-
}
|
|
334
|
-
}
|
|
335
|
-
// Helper function to concatenate Uint8Arrays
|
|
336
|
-
function concatUint8Arrays(arrays) {
|
|
337
|
-
if (arrays.length === 0) {
|
|
338
|
-
return new Uint8Array(0);
|
|
339
|
-
}
|
|
340
|
-
if (arrays.length === 1) {
|
|
341
|
-
return arrays[0];
|
|
342
|
-
}
|
|
343
|
-
const totalLength = arrays.reduce((acc, arr) => acc + arr.length, 0);
|
|
344
|
-
const result = new Uint8Array(totalLength);
|
|
345
|
-
let offset = 0;
|
|
346
|
-
for (const arr of arrays) {
|
|
347
|
-
result.set(arr, offset);
|
|
348
|
-
offset += arr.length;
|
|
349
|
-
}
|
|
350
|
-
return result;
|
|
351
|
-
}
|
|
352
|
-
export { StreamBuf };
|