@cj-tech-master/excelts 4.0.0 → 4.0.1-canary.20260104072032.0453bbe

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.
Files changed (633) hide show
  1. package/README.md +2 -2
  2. package/README_zh.md +2 -2
  3. package/dist/browser/index.browser.d.ts +25 -0
  4. package/dist/browser/index.browser.js +40 -0
  5. package/dist/browser/index.d.ts +23 -0
  6. package/dist/browser/index.js +35 -0
  7. package/dist/browser/modules/archive/byte-queue.d.ts +18 -0
  8. package/dist/browser/modules/archive/byte-queue.js +125 -0
  9. package/dist/browser/modules/archive/compress.base.d.ts +98 -0
  10. package/dist/browser/modules/archive/compress.base.js +173 -0
  11. package/dist/browser/modules/archive/compress.browser.d.ts +57 -0
  12. package/dist/browser/modules/archive/compress.browser.js +93 -0
  13. package/dist/browser/modules/archive/compress.d.ts +44 -0
  14. package/dist/browser/modules/archive/compress.js +86 -0
  15. package/dist/browser/modules/archive/crc32.base.d.ts +25 -0
  16. package/dist/browser/modules/archive/crc32.base.js +51 -0
  17. package/dist/browser/modules/archive/crc32.browser.d.ts +30 -0
  18. package/dist/browser/modules/archive/crc32.browser.js +32 -0
  19. package/dist/browser/modules/archive/crc32.d.ts +59 -0
  20. package/dist/browser/modules/archive/crc32.js +97 -0
  21. package/dist/browser/modules/archive/defaults.d.ts +4 -0
  22. package/dist/browser/modules/archive/defaults.js +3 -0
  23. package/dist/browser/modules/archive/deflate-fallback.d.ts +39 -0
  24. package/dist/browser/modules/archive/deflate-fallback.js +564 -0
  25. package/dist/browser/modules/archive/extract.d.ts +94 -0
  26. package/dist/browser/modules/archive/extract.js +106 -0
  27. package/dist/browser/modules/archive/index.base.d.ts +11 -0
  28. package/dist/browser/modules/archive/index.base.js +13 -0
  29. package/dist/browser/modules/archive/index.browser.d.ts +11 -0
  30. package/dist/browser/modules/archive/index.browser.js +17 -0
  31. package/dist/browser/modules/archive/index.d.ts +11 -0
  32. package/dist/browser/modules/archive/index.js +15 -0
  33. package/dist/browser/modules/archive/parse.base.d.ts +198 -0
  34. package/dist/browser/modules/archive/parse.base.js +610 -0
  35. package/dist/browser/modules/archive/parse.browser.d.ts +22 -0
  36. package/dist/browser/modules/archive/parse.browser.js +564 -0
  37. package/dist/browser/modules/archive/parse.d.ts +16 -0
  38. package/dist/browser/modules/archive/parse.js +94 -0
  39. package/dist/browser/modules/archive/streaming-compress.base.d.ts +36 -0
  40. package/dist/browser/modules/archive/streaming-compress.base.js +9 -0
  41. package/dist/browser/modules/archive/streaming-compress.browser.d.ts +26 -0
  42. package/dist/browser/modules/archive/streaming-compress.browser.js +296 -0
  43. package/dist/browser/modules/archive/streaming-compress.d.ts +22 -0
  44. package/dist/browser/modules/archive/streaming-compress.js +68 -0
  45. package/dist/browser/modules/archive/streaming-zip.d.ts +120 -0
  46. package/dist/browser/modules/archive/streaming-zip.js +407 -0
  47. package/dist/browser/modules/archive/utils/binary.d.ts +24 -0
  48. package/dist/browser/modules/archive/utils/binary.js +69 -0
  49. package/dist/browser/modules/archive/utils/bytes.d.ts +7 -0
  50. package/dist/browser/modules/archive/utils/bytes.js +101 -0
  51. package/dist/browser/modules/archive/utils/parse-buffer.d.ts +18 -0
  52. package/dist/browser/modules/archive/utils/parse-buffer.js +55 -0
  53. package/dist/browser/modules/archive/utils/text.d.ts +20 -0
  54. package/dist/browser/modules/archive/utils/text.js +33 -0
  55. package/dist/browser/modules/archive/utils/timestamps.d.ts +28 -0
  56. package/dist/browser/modules/archive/utils/timestamps.js +48 -0
  57. package/dist/browser/modules/archive/utils/zip-extra-fields.d.ts +19 -0
  58. package/dist/browser/modules/archive/utils/zip-extra-fields.js +72 -0
  59. package/dist/browser/modules/archive/utils/zip-extra.d.ts +18 -0
  60. package/dist/browser/modules/archive/utils/zip-extra.js +68 -0
  61. package/dist/browser/modules/archive/zip-builder.d.ts +117 -0
  62. package/dist/browser/modules/archive/zip-builder.js +292 -0
  63. package/dist/browser/modules/archive/zip-constants.d.ts +18 -0
  64. package/dist/browser/modules/archive/zip-constants.js +23 -0
  65. package/dist/browser/modules/archive/zip-entry-info.d.ts +29 -0
  66. package/dist/browser/modules/archive/zip-entry-info.js +6 -0
  67. package/dist/browser/modules/archive/zip-entry-metadata.d.ts +23 -0
  68. package/dist/browser/modules/archive/zip-entry-metadata.js +24 -0
  69. package/dist/browser/modules/archive/zip-parser.d.ts +62 -0
  70. package/dist/browser/modules/archive/zip-parser.js +332 -0
  71. package/dist/browser/modules/archive/zip-records.d.ts +43 -0
  72. package/dist/browser/modules/archive/zip-records.js +84 -0
  73. package/dist/browser/modules/csv/csv-core.d.ts +215 -0
  74. package/dist/browser/modules/csv/csv-core.js +723 -0
  75. package/dist/browser/modules/csv/csv-number.d.ts +3 -0
  76. package/dist/browser/modules/csv/csv-number.js +20 -0
  77. package/dist/browser/modules/csv/csv-stream.d.ts +121 -0
  78. package/dist/browser/modules/csv/csv-stream.js +703 -0
  79. package/dist/browser/modules/csv/csv.browser.d.ts +60 -0
  80. package/dist/browser/modules/csv/csv.browser.js +265 -0
  81. package/dist/browser/modules/csv/csv.d.ts +14 -0
  82. package/dist/browser/modules/csv/csv.js +29 -0
  83. package/dist/browser/modules/excel/anchor.d.ts +33 -0
  84. package/dist/browser/modules/excel/anchor.js +97 -0
  85. package/dist/browser/modules/excel/cell.d.ts +138 -0
  86. package/dist/browser/modules/excel/cell.js +946 -0
  87. package/dist/browser/modules/excel/column.d.ts +122 -0
  88. package/dist/browser/modules/excel/column.js +358 -0
  89. package/dist/browser/modules/excel/data-validations.d.ts +11 -0
  90. package/dist/browser/modules/excel/data-validations.js +43 -0
  91. package/dist/browser/modules/excel/defined-names.d.ts +37 -0
  92. package/dist/browser/modules/excel/defined-names.js +214 -0
  93. package/dist/browser/modules/excel/enums.d.ts +62 -0
  94. package/dist/browser/modules/excel/enums.js +58 -0
  95. package/dist/browser/modules/excel/image.d.ts +64 -0
  96. package/dist/browser/modules/excel/image.js +60 -0
  97. package/dist/browser/modules/excel/note.d.ts +29 -0
  98. package/dist/browser/modules/excel/note.js +61 -0
  99. package/dist/browser/modules/excel/pivot-table.d.ts +152 -0
  100. package/dist/browser/modules/excel/pivot-table.js +237 -0
  101. package/dist/browser/modules/excel/range.d.ts +62 -0
  102. package/dist/browser/modules/excel/range.js +280 -0
  103. package/dist/browser/modules/excel/row.d.ts +127 -0
  104. package/dist/browser/modules/excel/row.js +441 -0
  105. package/dist/browser/modules/excel/stream/hyperlink-reader.d.ts +33 -0
  106. package/dist/browser/modules/excel/stream/hyperlink-reader.js +84 -0
  107. package/dist/browser/modules/excel/stream/sheet-comments-writer.d.ts +26 -0
  108. package/dist/browser/modules/excel/stream/sheet-comments-writer.js +101 -0
  109. package/dist/browser/modules/excel/stream/sheet-rels-writer.d.ts +45 -0
  110. package/dist/browser/modules/excel/stream/sheet-rels-writer.js +91 -0
  111. package/dist/browser/modules/excel/stream/workbook-reader.browser.d.ts +169 -0
  112. package/dist/browser/modules/excel/stream/workbook-reader.browser.js +443 -0
  113. package/dist/browser/modules/excel/stream/workbook-reader.d.ts +24 -0
  114. package/dist/browser/modules/excel/stream/workbook-reader.js +50 -0
  115. package/dist/browser/modules/excel/stream/workbook-writer.browser.d.ts +147 -0
  116. package/dist/browser/modules/excel/stream/workbook-writer.browser.js +356 -0
  117. package/dist/browser/modules/excel/stream/workbook-writer.d.ts +31 -0
  118. package/dist/browser/modules/excel/stream/workbook-writer.js +52 -0
  119. package/dist/browser/modules/excel/stream/worksheet-reader.d.ts +61 -0
  120. package/dist/browser/modules/excel/stream/worksheet-reader.js +367 -0
  121. package/dist/browser/modules/excel/stream/worksheet-writer.d.ts +140 -0
  122. package/dist/browser/modules/excel/stream/worksheet-writer.js +613 -0
  123. package/dist/browser/modules/excel/table.d.ts +81 -0
  124. package/dist/browser/modules/excel/table.js +412 -0
  125. package/dist/browser/modules/excel/types.d.ts +518 -0
  126. package/dist/browser/modules/excel/types.js +22 -0
  127. package/dist/browser/modules/excel/utils/cell-format.d.ts +32 -0
  128. package/dist/browser/modules/excel/utils/cell-format.js +814 -0
  129. package/dist/browser/modules/excel/utils/cell-matrix.d.ts +37 -0
  130. package/dist/browser/modules/excel/utils/cell-matrix.js +180 -0
  131. package/dist/browser/modules/excel/utils/col-cache.d.ts +36 -0
  132. package/dist/browser/modules/excel/utils/col-cache.js +278 -0
  133. package/dist/browser/modules/excel/utils/copy-style.d.ts +5 -0
  134. package/dist/browser/modules/excel/utils/copy-style.js +43 -0
  135. package/dist/browser/modules/excel/utils/encryptor.browser.d.ts +19 -0
  136. package/dist/browser/modules/excel/utils/encryptor.browser.js +46 -0
  137. package/dist/browser/modules/excel/utils/encryptor.d.ts +9 -0
  138. package/dist/browser/modules/excel/utils/encryptor.js +35 -0
  139. package/dist/browser/modules/excel/utils/iterate-stream.d.ts +14 -0
  140. package/dist/browser/modules/excel/utils/iterate-stream.js +55 -0
  141. package/dist/browser/modules/excel/utils/ooxml-paths.d.ts +64 -0
  142. package/dist/browser/modules/excel/utils/ooxml-paths.js +209 -0
  143. package/dist/browser/modules/excel/utils/parse-sax.d.ts +113 -0
  144. package/dist/browser/modules/excel/utils/parse-sax.js +1206 -0
  145. package/dist/browser/modules/excel/utils/shared-formula.d.ts +2 -0
  146. package/dist/browser/modules/excel/utils/shared-formula.js +36 -0
  147. package/dist/browser/modules/excel/utils/shared-strings.d.ts +12 -0
  148. package/dist/browser/modules/excel/utils/shared-strings.js +29 -0
  149. package/dist/browser/modules/excel/utils/sheet-utils.d.ts +190 -0
  150. package/dist/browser/modules/excel/utils/sheet-utils.js +674 -0
  151. package/dist/browser/modules/excel/utils/stream-buf.d.ts +126 -0
  152. package/dist/browser/modules/excel/utils/stream-buf.js +452 -0
  153. package/dist/browser/modules/excel/utils/string-buf.d.ts +29 -0
  154. package/dist/browser/modules/excel/utils/string-buf.js +75 -0
  155. package/dist/browser/modules/excel/utils/under-dash.d.ts +7 -0
  156. package/dist/browser/modules/excel/utils/under-dash.js +166 -0
  157. package/dist/browser/modules/excel/utils/xml-stream.d.ts +34 -0
  158. package/dist/browser/modules/excel/utils/xml-stream.js +179 -0
  159. package/dist/browser/modules/excel/workbook.d.ts +195 -0
  160. package/dist/browser/modules/excel/workbook.js +314 -0
  161. package/dist/browser/modules/excel/worksheet.d.ts +333 -0
  162. package/dist/browser/modules/excel/worksheet.js +924 -0
  163. package/dist/browser/modules/excel/xlsx/defaultnumformats.d.ts +12 -0
  164. package/dist/browser/modules/excel/xlsx/defaultnumformats.js +149 -0
  165. package/dist/browser/modules/excel/xlsx/rel-type.d.ts +19 -0
  166. package/dist/browser/modules/excel/xlsx/rel-type.js +19 -0
  167. package/dist/browser/modules/excel/xlsx/xform/base-xform.d.ts +33 -0
  168. package/dist/browser/modules/excel/xlsx/xform/base-xform.js +135 -0
  169. package/dist/browser/modules/excel/xlsx/xform/book/defined-name-xform.d.ts +17 -0
  170. package/dist/browser/modules/excel/xlsx/xform/book/defined-name-xform.js +124 -0
  171. package/dist/browser/modules/excel/xlsx/xform/book/sheet-xform.d.ts +14 -0
  172. package/dist/browser/modules/excel/xlsx/xform/book/sheet-xform.js +30 -0
  173. package/dist/browser/modules/excel/xlsx/xform/book/workbook-calc-properties-xform.d.ts +11 -0
  174. package/dist/browser/modules/excel/xlsx/xform/book/workbook-calc-properties-xform.js +21 -0
  175. package/dist/browser/modules/excel/xlsx/xform/book/workbook-pivot-cache-xform.d.ts +12 -0
  176. package/dist/browser/modules/excel/xlsx/xform/book/workbook-pivot-cache-xform.js +24 -0
  177. package/dist/browser/modules/excel/xlsx/xform/book/workbook-properties-xform.d.ts +11 -0
  178. package/dist/browser/modules/excel/xlsx/xform/book/workbook-properties-xform.js +24 -0
  179. package/dist/browser/modules/excel/xlsx/xform/book/workbook-view-xform.d.ts +17 -0
  180. package/dist/browser/modules/excel/xlsx/xform/book/workbook-view-xform.js +46 -0
  181. package/dist/browser/modules/excel/xlsx/xform/book/workbook-xform.d.ts +23 -0
  182. package/dist/browser/modules/excel/xlsx/xform/book/workbook-xform.js +234 -0
  183. package/dist/browser/modules/excel/xlsx/xform/comment/comment-xform.d.ts +28 -0
  184. package/dist/browser/modules/excel/xlsx/xform/comment/comment-xform.js +76 -0
  185. package/dist/browser/modules/excel/xlsx/xform/comment/comments-xform.d.ts +21 -0
  186. package/dist/browser/modules/excel/xlsx/xform/comment/comments-xform.js +72 -0
  187. package/dist/browser/modules/excel/xlsx/xform/comment/style/vml-position-xform.d.ts +16 -0
  188. package/dist/browser/modules/excel/xlsx/xform/comment/style/vml-position-xform.js +34 -0
  189. package/dist/browser/modules/excel/xlsx/xform/comment/style/vml-protection-xform.d.ts +14 -0
  190. package/dist/browser/modules/excel/xlsx/xform/comment/style/vml-protection-xform.js +30 -0
  191. package/dist/browser/modules/excel/xlsx/xform/comment/vml-anchor-xform.d.ts +27 -0
  192. package/dist/browser/modules/excel/xlsx/xform/comment/vml-anchor-xform.js +55 -0
  193. package/dist/browser/modules/excel/xlsx/xform/comment/vml-client-data-xform.d.ts +35 -0
  194. package/dist/browser/modules/excel/xlsx/xform/comment/vml-client-data-xform.js +82 -0
  195. package/dist/browser/modules/excel/xlsx/xform/comment/vml-notes-xform.d.ts +24 -0
  196. package/dist/browser/modules/excel/xlsx/xform/comment/vml-notes-xform.js +96 -0
  197. package/dist/browser/modules/excel/xlsx/xform/comment/vml-shape-xform.d.ts +25 -0
  198. package/dist/browser/modules/excel/xlsx/xform/comment/vml-shape-xform.js +83 -0
  199. package/dist/browser/modules/excel/xlsx/xform/comment/vml-textbox-xform.d.ts +23 -0
  200. package/dist/browser/modules/excel/xlsx/xform/comment/vml-textbox-xform.js +60 -0
  201. package/dist/browser/modules/excel/xlsx/xform/composite-xform.d.ts +11 -0
  202. package/dist/browser/modules/excel/xlsx/xform/composite-xform.js +48 -0
  203. package/dist/browser/modules/excel/xlsx/xform/core/app-heading-pairs-xform.d.ts +8 -0
  204. package/dist/browser/modules/excel/xlsx/xform/core/app-heading-pairs-xform.js +24 -0
  205. package/dist/browser/modules/excel/xlsx/xform/core/app-titles-of-parts-xform.d.ts +8 -0
  206. package/dist/browser/modules/excel/xlsx/xform/core/app-titles-of-parts-xform.js +21 -0
  207. package/dist/browser/modules/excel/xlsx/xform/core/app-xform.d.ts +26 -0
  208. package/dist/browser/modules/excel/xlsx/xform/core/app-xform.js +83 -0
  209. package/dist/browser/modules/excel/xlsx/xform/core/content-types-xform.d.ts +11 -0
  210. package/dist/browser/modules/excel/xlsx/xform/core/content-types-xform.js +122 -0
  211. package/dist/browser/modules/excel/xlsx/xform/core/core-xform.d.ts +42 -0
  212. package/dist/browser/modules/excel/xlsx/xform/core/core-xform.js +124 -0
  213. package/dist/browser/modules/excel/xlsx/xform/core/relationship-xform.d.ts +14 -0
  214. package/dist/browser/modules/excel/xlsx/xform/core/relationship-xform.js +20 -0
  215. package/dist/browser/modules/excel/xlsx/xform/core/relationships-xform.d.ts +14 -0
  216. package/dist/browser/modules/excel/xlsx/xform/core/relationships-xform.js +62 -0
  217. package/dist/browser/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.d.ts +13 -0
  218. package/dist/browser/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.js +44 -0
  219. package/dist/browser/modules/excel/xlsx/xform/drawing/blip-fill-xform.d.ts +16 -0
  220. package/dist/browser/modules/excel/xlsx/xform/drawing/blip-fill-xform.js +57 -0
  221. package/dist/browser/modules/excel/xlsx/xform/drawing/blip-xform.d.ts +14 -0
  222. package/dist/browser/modules/excel/xlsx/xform/drawing/blip-xform.js +40 -0
  223. package/dist/browser/modules/excel/xlsx/xform/drawing/c-nv-pic-pr-xform.d.ts +9 -0
  224. package/dist/browser/modules/excel/xlsx/xform/drawing/c-nv-pic-pr-xform.js +32 -0
  225. package/dist/browser/modules/excel/xlsx/xform/drawing/c-nv-pr-xform.d.ts +18 -0
  226. package/dist/browser/modules/excel/xlsx/xform/drawing/c-nv-pr-xform.js +59 -0
  227. package/dist/browser/modules/excel/xlsx/xform/drawing/cell-position-xform.d.ts +24 -0
  228. package/dist/browser/modules/excel/xlsx/xform/drawing/cell-position-xform.js +68 -0
  229. package/dist/browser/modules/excel/xlsx/xform/drawing/drawing-xform.d.ts +24 -0
  230. package/dist/browser/modules/excel/xlsx/xform/drawing/drawing-xform.js +96 -0
  231. package/dist/browser/modules/excel/xlsx/xform/drawing/ext-lst-xform.d.ts +9 -0
  232. package/dist/browser/modules/excel/xlsx/xform/drawing/ext-lst-xform.js +37 -0
  233. package/dist/browser/modules/excel/xlsx/xform/drawing/ext-xform.d.ts +20 -0
  234. package/dist/browser/modules/excel/xlsx/xform/drawing/ext-xform.js +34 -0
  235. package/dist/browser/modules/excel/xlsx/xform/drawing/hlink-click-xform.d.ts +11 -0
  236. package/dist/browser/modules/excel/xlsx/xform/drawing/hlink-click-xform.js +39 -0
  237. package/dist/browser/modules/excel/xlsx/xform/drawing/nv-pic-pr-xform.d.ts +15 -0
  238. package/dist/browser/modules/excel/xlsx/xform/drawing/nv-pic-pr-xform.js +56 -0
  239. package/dist/browser/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.d.ts +20 -0
  240. package/dist/browser/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.js +52 -0
  241. package/dist/browser/modules/excel/xlsx/xform/drawing/pic-xform.d.ts +22 -0
  242. package/dist/browser/modules/excel/xlsx/xform/drawing/pic-xform.js +64 -0
  243. package/dist/browser/modules/excel/xlsx/xform/drawing/sp-pr.d.ts +32 -0
  244. package/dist/browser/modules/excel/xlsx/xform/drawing/sp-pr.js +17 -0
  245. package/dist/browser/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.d.ts +20 -0
  246. package/dist/browser/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.js +51 -0
  247. package/dist/browser/modules/excel/xlsx/xform/list-xform.d.ts +32 -0
  248. package/dist/browser/modules/excel/xlsx/xform/list-xform.js +89 -0
  249. package/dist/browser/modules/excel/xlsx/xform/pivot-table/cache-field-xform.d.ts +42 -0
  250. package/dist/browser/modules/excel/xlsx/xform/pivot-table/cache-field-xform.js +128 -0
  251. package/dist/browser/modules/excel/xlsx/xform/pivot-table/cache-field.d.ts +15 -0
  252. package/dist/browser/modules/excel/xlsx/xform/pivot-table/cache-field.js +78 -0
  253. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-cache-definition-xform.d.ts +60 -0
  254. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +179 -0
  255. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-cache-records-xform.d.ts +73 -0
  256. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-cache-records-xform.js +234 -0
  257. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +119 -0
  258. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +624 -0
  259. package/dist/browser/modules/excel/xlsx/xform/sheet/auto-filter-xform.d.ts +8 -0
  260. package/dist/browser/modules/excel/xlsx/xform/sheet/auto-filter-xform.js +34 -0
  261. package/dist/browser/modules/excel/xlsx/xform/sheet/cell-xform.d.ts +17 -0
  262. package/dist/browser/modules/excel/xlsx/xform/sheet/cell-xform.js +460 -0
  263. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/cf-rule-xform.d.ts +41 -0
  264. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/cf-rule-xform.js +259 -0
  265. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/cfvo-xform.d.ts +8 -0
  266. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/cfvo-xform.js +22 -0
  267. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/color-scale-xform.d.ts +13 -0
  268. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/color-scale-xform.js +35 -0
  269. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/conditional-formatting-xform.d.ts +9 -0
  270. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/conditional-formatting-xform.js +37 -0
  271. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/conditional-formattings-xform.d.ts +16 -0
  272. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/conditional-formattings-xform.js +74 -0
  273. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/databar-xform.d.ts +13 -0
  274. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/databar-xform.js +39 -0
  275. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/ext-lst-ref-xform.d.ts +9 -0
  276. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +67 -0
  277. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/formula-xform.d.ts +9 -0
  278. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/formula-xform.js +19 -0
  279. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/icon-set-xform.d.ts +11 -0
  280. package/dist/browser/modules/excel/xlsx/xform/sheet/cf/icon-set-xform.js +37 -0
  281. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.d.ts +10 -0
  282. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +22 -0
  283. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.d.ts +23 -0
  284. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +80 -0
  285. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.d.ts +13 -0
  286. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +35 -0
  287. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.d.ts +16 -0
  288. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +48 -0
  289. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.d.ts +13 -0
  290. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +40 -0
  291. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/databar-ext-xform.d.ts +29 -0
  292. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +69 -0
  293. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/f-ext-xform.d.ts +9 -0
  294. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/f-ext-xform.js +19 -0
  295. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.d.ts +20 -0
  296. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +60 -0
  297. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/sqref-ext-xform.d.ts +9 -0
  298. package/dist/browser/modules/excel/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +19 -0
  299. package/dist/browser/modules/excel/xlsx/xform/sheet/col-breaks-xform.d.ts +16 -0
  300. package/dist/browser/modules/excel/xlsx/xform/sheet/col-breaks-xform.js +35 -0
  301. package/dist/browser/modules/excel/xlsx/xform/sheet/col-xform.d.ts +22 -0
  302. package/dist/browser/modules/excel/xlsx/xform/sheet/col-xform.js +75 -0
  303. package/dist/browser/modules/excel/xlsx/xform/sheet/data-validations-xform.d.ts +12 -0
  304. package/dist/browser/modules/excel/xlsx/xform/sheet/data-validations-xform.js +269 -0
  305. package/dist/browser/modules/excel/xlsx/xform/sheet/dimension-xform.d.ts +10 -0
  306. package/dist/browser/modules/excel/xlsx/xform/sheet/dimension-xform.js +23 -0
  307. package/dist/browser/modules/excel/xlsx/xform/sheet/drawing-xform.d.ts +12 -0
  308. package/dist/browser/modules/excel/xlsx/xform/sheet/drawing-xform.js +27 -0
  309. package/dist/browser/modules/excel/xlsx/xform/sheet/ext-lst-xform.d.ts +16 -0
  310. package/dist/browser/modules/excel/xlsx/xform/sheet/ext-lst-xform.js +66 -0
  311. package/dist/browser/modules/excel/xlsx/xform/sheet/header-footer-xform.d.ts +20 -0
  312. package/dist/browser/modules/excel/xlsx/xform/sheet/header-footer-xform.js +124 -0
  313. package/dist/browser/modules/excel/xlsx/xform/sheet/hyperlink-xform.d.ts +16 -0
  314. package/dist/browser/modules/excel/xlsx/xform/sheet/hyperlink-xform.js +47 -0
  315. package/dist/browser/modules/excel/xlsx/xform/sheet/merge-cell-xform.d.ts +9 -0
  316. package/dist/browser/modules/excel/xlsx/xform/sheet/merge-cell-xform.js +21 -0
  317. package/dist/browser/modules/excel/xlsx/xform/sheet/merges.d.ts +14 -0
  318. package/dist/browser/modules/excel/xlsx/xform/sheet/merges.js +50 -0
  319. package/dist/browser/modules/excel/xlsx/xform/sheet/outline-properties-xform.d.ts +13 -0
  320. package/dist/browser/modules/excel/xlsx/xform/sheet/outline-properties-xform.js +36 -0
  321. package/dist/browser/modules/excel/xlsx/xform/sheet/page-breaks-xform.d.ts +14 -0
  322. package/dist/browser/modules/excel/xlsx/xform/sheet/page-breaks-xform.js +33 -0
  323. package/dist/browser/modules/excel/xlsx/xform/sheet/page-margins-xform.d.ts +17 -0
  324. package/dist/browser/modules/excel/xlsx/xform/sheet/page-margins-xform.js +42 -0
  325. package/dist/browser/modules/excel/xlsx/xform/sheet/page-setup-properties-xform.d.ts +12 -0
  326. package/dist/browser/modules/excel/xlsx/xform/sheet/page-setup-properties-xform.js +29 -0
  327. package/dist/browser/modules/excel/xlsx/xform/sheet/page-setup-xform.d.ts +27 -0
  328. package/dist/browser/modules/excel/xlsx/xform/sheet/page-setup-xform.js +96 -0
  329. package/dist/browser/modules/excel/xlsx/xform/sheet/picture-xform.d.ts +12 -0
  330. package/dist/browser/modules/excel/xlsx/xform/sheet/picture-xform.js +27 -0
  331. package/dist/browser/modules/excel/xlsx/xform/sheet/print-options-xform.d.ts +15 -0
  332. package/dist/browser/modules/excel/xlsx/xform/sheet/print-options-xform.js +41 -0
  333. package/dist/browser/modules/excel/xlsx/xform/sheet/row-breaks-xform.d.ts +10 -0
  334. package/dist/browser/modules/excel/xlsx/xform/sheet/row-breaks-xform.js +29 -0
  335. package/dist/browser/modules/excel/xlsx/xform/sheet/row-xform.d.ts +37 -0
  336. package/dist/browser/modules/excel/xlsx/xform/sheet/row-xform.js +152 -0
  337. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.d.ts +16 -0
  338. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.js +49 -0
  339. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-properties-xform.d.ts +19 -0
  340. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-properties-xform.js +82 -0
  341. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-protection-xform.d.ts +31 -0
  342. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-protection-xform.js +80 -0
  343. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-view-xform.d.ts +32 -0
  344. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-view-xform.js +193 -0
  345. package/dist/browser/modules/excel/xlsx/xform/sheet/table-part-xform.d.ts +12 -0
  346. package/dist/browser/modules/excel/xlsx/xform/sheet/table-part-xform.js +27 -0
  347. package/dist/browser/modules/excel/xlsx/xform/sheet/worksheet-xform.d.ts +21 -0
  348. package/dist/browser/modules/excel/xlsx/xform/sheet/worksheet-xform.js +518 -0
  349. package/dist/browser/modules/excel/xlsx/xform/simple/boolean-xform.d.ts +15 -0
  350. package/dist/browser/modules/excel/xlsx/xform/simple/boolean-xform.js +24 -0
  351. package/dist/browser/modules/excel/xlsx/xform/simple/date-xform.d.ts +22 -0
  352. package/dist/browser/modules/excel/xlsx/xform/simple/date-xform.js +65 -0
  353. package/dist/browser/modules/excel/xlsx/xform/simple/float-xform.d.ts +18 -0
  354. package/dist/browser/modules/excel/xlsx/xform/simple/float-xform.js +47 -0
  355. package/dist/browser/modules/excel/xlsx/xform/simple/integer-xform.d.ts +20 -0
  356. package/dist/browser/modules/excel/xlsx/xform/simple/integer-xform.js +52 -0
  357. package/dist/browser/modules/excel/xlsx/xform/simple/string-xform.d.ts +18 -0
  358. package/dist/browser/modules/excel/xlsx/xform/simple/string-xform.js +47 -0
  359. package/dist/browser/modules/excel/xlsx/xform/static-xform.d.ts +17 -0
  360. package/dist/browser/modules/excel/xlsx/xform/static-xform.js +55 -0
  361. package/dist/browser/modules/excel/xlsx/xform/strings/phonetic-text-xform.d.ts +20 -0
  362. package/dist/browser/modules/excel/xlsx/xform/strings/phonetic-text-xform.js +86 -0
  363. package/dist/browser/modules/excel/xlsx/xform/strings/rich-text-xform.d.ts +25 -0
  364. package/dist/browser/modules/excel/xlsx/xform/strings/rich-text-xform.js +77 -0
  365. package/dist/browser/modules/excel/xlsx/xform/strings/shared-string-xform.d.ts +17 -0
  366. package/dist/browser/modules/excel/xlsx/xform/strings/shared-string-xform.js +90 -0
  367. package/dist/browser/modules/excel/xlsx/xform/strings/shared-strings-xform.d.ts +27 -0
  368. package/dist/browser/modules/excel/xlsx/xform/strings/shared-strings-xform.js +109 -0
  369. package/dist/browser/modules/excel/xlsx/xform/strings/text-xform.d.ts +10 -0
  370. package/dist/browser/modules/excel/xlsx/xform/strings/text-xform.js +36 -0
  371. package/dist/browser/modules/excel/xlsx/xform/style/alignment-xform.d.ts +18 -0
  372. package/dist/browser/modules/excel/xlsx/xform/style/alignment-xform.js +152 -0
  373. package/dist/browser/modules/excel/xlsx/xform/style/border-xform.d.ts +49 -0
  374. package/dist/browser/modules/excel/xlsx/xform/style/border-xform.js +188 -0
  375. package/dist/browser/modules/excel/xlsx/xform/style/color-xform.d.ts +17 -0
  376. package/dist/browser/modules/excel/xlsx/xform/style/color-xform.js +61 -0
  377. package/dist/browser/modules/excel/xlsx/xform/style/dxf-xform.d.ts +23 -0
  378. package/dist/browser/modules/excel/xlsx/xform/style/dxf-xform.js +92 -0
  379. package/dist/browser/modules/excel/xlsx/xform/style/fill-xform.d.ts +85 -0
  380. package/dist/browser/modules/excel/xlsx/xform/style/fill-xform.js +312 -0
  381. package/dist/browser/modules/excel/xlsx/xform/style/font-xform.d.ts +35 -0
  382. package/dist/browser/modules/excel/xlsx/xform/style/font-xform.js +100 -0
  383. package/dist/browser/modules/excel/xlsx/xform/style/numfmt-xform.d.ts +18 -0
  384. package/dist/browser/modules/excel/xlsx/xform/style/numfmt-xform.js +50 -0
  385. package/dist/browser/modules/excel/xlsx/xform/style/protection-xform.d.ts +13 -0
  386. package/dist/browser/modules/excel/xlsx/xform/style/protection-xform.js +49 -0
  387. package/dist/browser/modules/excel/xlsx/xform/style/style-xform.d.ts +30 -0
  388. package/dist/browser/modules/excel/xlsx/xform/style/style-xform.js +108 -0
  389. package/dist/browser/modules/excel/xlsx/xform/style/styles-xform.d.ts +46 -0
  390. package/dist/browser/modules/excel/xlsx/xform/style/styles-xform.js +484 -0
  391. package/dist/browser/modules/excel/xlsx/xform/style/underline-xform.d.ts +14 -0
  392. package/dist/browser/modules/excel/xlsx/xform/style/underline-xform.js +38 -0
  393. package/dist/browser/modules/excel/xlsx/xform/table/auto-filter-xform.d.ts +21 -0
  394. package/dist/browser/modules/excel/xlsx/xform/table/auto-filter-xform.js +70 -0
  395. package/dist/browser/modules/excel/xlsx/xform/table/custom-filter-xform.d.ts +15 -0
  396. package/dist/browser/modules/excel/xlsx/xform/table/custom-filter-xform.js +31 -0
  397. package/dist/browser/modules/excel/xlsx/xform/table/filter-column-xform.d.ts +24 -0
  398. package/dist/browser/modules/excel/xlsx/xform/table/filter-column-xform.js +87 -0
  399. package/dist/browser/modules/excel/xlsx/xform/table/filter-xform.d.ts +14 -0
  400. package/dist/browser/modules/excel/xlsx/xform/table/filter-xform.js +29 -0
  401. package/dist/browser/modules/excel/xlsx/xform/table/table-column-xform.d.ts +21 -0
  402. package/dist/browser/modules/excel/xlsx/xform/table/table-column-xform.js +41 -0
  403. package/dist/browser/modules/excel/xlsx/xform/table/table-style-info-xform.d.ts +18 -0
  404. package/dist/browser/modules/excel/xlsx/xform/table/table-style-info-xform.js +44 -0
  405. package/dist/browser/modules/excel/xlsx/xform/table/table-xform.d.ts +33 -0
  406. package/dist/browser/modules/excel/xlsx/xform/table/table-xform.js +126 -0
  407. package/dist/browser/modules/excel/xlsx/xlsx.browser.d.ts +208 -0
  408. package/dist/browser/modules/excel/xlsx/xlsx.browser.js +1152 -0
  409. package/dist/browser/modules/excel/xlsx/xlsx.d.ts +24 -0
  410. package/dist/browser/modules/excel/xlsx/xlsx.js +239 -0
  411. package/dist/browser/modules/excel/xlsx/xml/theme1.d.ts +1 -0
  412. package/dist/browser/modules/excel/xlsx/xml/theme1.js +1 -0
  413. package/dist/browser/modules/stream/base-transform.d.ts +68 -0
  414. package/dist/browser/modules/stream/base-transform.js +160 -0
  415. package/dist/browser/modules/stream/buffered-stream.d.ts +94 -0
  416. package/dist/browser/modules/stream/buffered-stream.js +277 -0
  417. package/dist/browser/modules/stream/chunked-builder.d.ts +97 -0
  418. package/dist/browser/modules/stream/chunked-builder.js +165 -0
  419. package/dist/browser/modules/stream/event-emitter.d.ts +30 -0
  420. package/dist/browser/modules/stream/event-emitter.js +239 -0
  421. package/dist/browser/modules/stream/index.browser.d.ts +22 -0
  422. package/dist/browser/modules/stream/index.browser.js +25 -0
  423. package/dist/browser/modules/stream/index.d.ts +49 -0
  424. package/dist/browser/modules/stream/index.js +52 -0
  425. package/dist/browser/modules/stream/pull-stream.d.ts +67 -0
  426. package/dist/browser/modules/stream/pull-stream.js +204 -0
  427. package/dist/browser/modules/stream/shared.d.ts +54 -0
  428. package/dist/browser/modules/stream/shared.js +156 -0
  429. package/dist/browser/modules/stream/streams.browser.d.ts +936 -0
  430. package/dist/browser/modules/stream/streams.browser.js +3297 -0
  431. package/dist/browser/modules/stream/streams.d.ts +282 -0
  432. package/dist/browser/modules/stream/streams.js +940 -0
  433. package/dist/browser/modules/stream/types.d.ts +238 -0
  434. package/dist/browser/modules/stream/types.js +7 -0
  435. package/dist/browser/modules/stream/utils.d.ts +24 -0
  436. package/dist/browser/modules/stream/utils.js +85 -0
  437. package/dist/browser/utils/browser.d.ts +9 -0
  438. package/dist/browser/utils/browser.js +49 -0
  439. package/dist/browser/utils/datetime.d.ts +56 -0
  440. package/dist/browser/utils/datetime.js +493 -0
  441. package/dist/browser/utils/env.d.ts +14 -0
  442. package/dist/browser/utils/env.js +18 -0
  443. package/dist/browser/utils/utils.base.d.ts +49 -0
  444. package/dist/browser/utils/utils.base.js +275 -0
  445. package/dist/browser/utils/utils.browser.d.ts +6 -0
  446. package/dist/browser/utils/utils.browser.js +12 -0
  447. package/dist/browser/utils/utils.d.ts +6 -0
  448. package/dist/browser/utils/utils.js +19 -0
  449. package/dist/browser/utils/uuid.d.ts +11 -0
  450. package/dist/browser/utils/uuid.js +55 -0
  451. package/dist/cjs/modules/excel/table.js +8 -1
  452. package/dist/esm/modules/excel/table.js +8 -1
  453. package/dist/{browser → iife}/excelts.iife.js +6 -2
  454. package/dist/iife/excelts.iife.js.map +1 -0
  455. package/dist/{browser → iife}/excelts.iife.min.js +2 -2
  456. package/dist/types/index.browser.d.ts +20 -20
  457. package/dist/types/index.d.ts +23 -23
  458. package/dist/types/modules/archive/compress.browser.d.ts +1 -1
  459. package/dist/types/modules/archive/compress.d.ts +2 -2
  460. package/dist/types/modules/archive/crc32.browser.d.ts +1 -1
  461. package/dist/types/modules/archive/crc32.d.ts +1 -1
  462. package/dist/types/modules/archive/defaults.d.ts +1 -1
  463. package/dist/types/modules/archive/extract.d.ts +2 -2
  464. package/dist/types/modules/archive/index.base.d.ts +4 -4
  465. package/dist/types/modules/archive/index.browser.d.ts +5 -5
  466. package/dist/types/modules/archive/index.d.ts +5 -5
  467. package/dist/types/modules/archive/parse.base.d.ts +3 -3
  468. package/dist/types/modules/archive/parse.browser.d.ts +2 -2
  469. package/dist/types/modules/archive/parse.d.ts +3 -3
  470. package/dist/types/modules/archive/streaming-compress.browser.d.ts +2 -2
  471. package/dist/types/modules/archive/streaming-compress.d.ts +2 -2
  472. package/dist/types/modules/archive/streaming-zip.d.ts +2 -2
  473. package/dist/types/modules/archive/zip-builder.d.ts +2 -2
  474. package/dist/types/modules/archive/zip-entry-metadata.d.ts +1 -1
  475. package/dist/types/modules/archive/zip-parser.d.ts +1 -1
  476. package/dist/types/modules/csv/csv-stream.d.ts +3 -3
  477. package/dist/types/modules/csv/csv.browser.d.ts +9 -9
  478. package/dist/types/modules/csv/csv.d.ts +4 -4
  479. package/dist/types/modules/excel/anchor.d.ts +1 -1
  480. package/dist/types/modules/excel/cell.d.ts +7 -7
  481. package/dist/types/modules/excel/column.d.ts +3 -3
  482. package/dist/types/modules/excel/defined-names.d.ts +4 -4
  483. package/dist/types/modules/excel/image.d.ts +2 -2
  484. package/dist/types/modules/excel/pivot-table.d.ts +1 -1
  485. package/dist/types/modules/excel/range.d.ts +1 -1
  486. package/dist/types/modules/excel/row.d.ts +3 -3
  487. package/dist/types/modules/excel/stream/hyperlink-reader.d.ts +2 -2
  488. package/dist/types/modules/excel/stream/workbook-reader.browser.d.ts +6 -6
  489. package/dist/types/modules/excel/stream/workbook-reader.d.ts +5 -5
  490. package/dist/types/modules/excel/stream/workbook-writer.browser.d.ts +8 -8
  491. package/dist/types/modules/excel/stream/workbook-writer.d.ts +2 -2
  492. package/dist/types/modules/excel/stream/worksheet-reader.d.ts +6 -6
  493. package/dist/types/modules/excel/stream/worksheet-writer.d.ts +9 -9
  494. package/dist/types/modules/excel/table.d.ts +2 -2
  495. package/dist/types/modules/excel/utils/col-cache.d.ts +1 -1
  496. package/dist/types/modules/excel/utils/sheet-utils.d.ts +3 -3
  497. package/dist/types/modules/excel/utils/stream-buf.d.ts +2 -2
  498. package/dist/types/modules/excel/workbook.d.ts +9 -9
  499. package/dist/types/modules/excel/worksheet.d.ts +10 -10
  500. package/dist/types/modules/excel/xlsx/xform/base-xform.d.ts +1 -1
  501. package/dist/types/modules/excel/xlsx/xform/book/defined-name-xform.d.ts +1 -1
  502. package/dist/types/modules/excel/xlsx/xform/book/sheet-xform.d.ts +1 -1
  503. package/dist/types/modules/excel/xlsx/xform/book/workbook-calc-properties-xform.d.ts +1 -1
  504. package/dist/types/modules/excel/xlsx/xform/book/workbook-pivot-cache-xform.d.ts +1 -1
  505. package/dist/types/modules/excel/xlsx/xform/book/workbook-properties-xform.d.ts +1 -1
  506. package/dist/types/modules/excel/xlsx/xform/book/workbook-view-xform.d.ts +1 -1
  507. package/dist/types/modules/excel/xlsx/xform/book/workbook-xform.d.ts +2 -2
  508. package/dist/types/modules/excel/xlsx/xform/comment/comment-xform.d.ts +2 -2
  509. package/dist/types/modules/excel/xlsx/xform/comment/comments-xform.d.ts +2 -2
  510. package/dist/types/modules/excel/xlsx/xform/comment/style/vml-position-xform.d.ts +1 -1
  511. package/dist/types/modules/excel/xlsx/xform/comment/style/vml-protection-xform.d.ts +1 -1
  512. package/dist/types/modules/excel/xlsx/xform/comment/vml-anchor-xform.d.ts +1 -1
  513. package/dist/types/modules/excel/xlsx/xform/comment/vml-client-data-xform.d.ts +1 -1
  514. package/dist/types/modules/excel/xlsx/xform/comment/vml-notes-xform.d.ts +1 -1
  515. package/dist/types/modules/excel/xlsx/xform/comment/vml-shape-xform.d.ts +1 -1
  516. package/dist/types/modules/excel/xlsx/xform/comment/vml-textbox-xform.d.ts +1 -1
  517. package/dist/types/modules/excel/xlsx/xform/composite-xform.d.ts +1 -1
  518. package/dist/types/modules/excel/xlsx/xform/core/app-heading-pairs-xform.d.ts +1 -1
  519. package/dist/types/modules/excel/xlsx/xform/core/app-titles-of-parts-xform.d.ts +1 -1
  520. package/dist/types/modules/excel/xlsx/xform/core/app-xform.d.ts +1 -1
  521. package/dist/types/modules/excel/xlsx/xform/core/content-types-xform.d.ts +1 -1
  522. package/dist/types/modules/excel/xlsx/xform/core/core-xform.d.ts +1 -1
  523. package/dist/types/modules/excel/xlsx/xform/core/relationship-xform.d.ts +1 -1
  524. package/dist/types/modules/excel/xlsx/xform/core/relationships-xform.d.ts +1 -1
  525. package/dist/types/modules/excel/xlsx/xform/drawing/base-cell-anchor-xform.d.ts +1 -1
  526. package/dist/types/modules/excel/xlsx/xform/drawing/blip-fill-xform.d.ts +2 -2
  527. package/dist/types/modules/excel/xlsx/xform/drawing/blip-xform.d.ts +1 -1
  528. package/dist/types/modules/excel/xlsx/xform/drawing/c-nv-pic-pr-xform.d.ts +1 -1
  529. package/dist/types/modules/excel/xlsx/xform/drawing/c-nv-pr-xform.d.ts +1 -1
  530. package/dist/types/modules/excel/xlsx/xform/drawing/cell-position-xform.d.ts +2 -2
  531. package/dist/types/modules/excel/xlsx/xform/drawing/drawing-xform.d.ts +1 -1
  532. package/dist/types/modules/excel/xlsx/xform/drawing/ext-lst-xform.d.ts +1 -1
  533. package/dist/types/modules/excel/xlsx/xform/drawing/ext-xform.d.ts +1 -1
  534. package/dist/types/modules/excel/xlsx/xform/drawing/hlink-click-xform.d.ts +1 -1
  535. package/dist/types/modules/excel/xlsx/xform/drawing/nv-pic-pr-xform.d.ts +1 -1
  536. package/dist/types/modules/excel/xlsx/xform/drawing/one-cell-anchor-xform.d.ts +1 -1
  537. package/dist/types/modules/excel/xlsx/xform/drawing/pic-xform.d.ts +1 -1
  538. package/dist/types/modules/excel/xlsx/xform/drawing/two-cell-anchor-xform.d.ts +1 -1
  539. package/dist/types/modules/excel/xlsx/xform/list-xform.d.ts +1 -1
  540. package/dist/types/modules/excel/xlsx/xform/pivot-table/cache-field-xform.d.ts +1 -1
  541. package/dist/types/modules/excel/xlsx/xform/pivot-table/pivot-cache-definition-xform.d.ts +3 -3
  542. package/dist/types/modules/excel/xlsx/xform/pivot-table/pivot-cache-records-xform.d.ts +2 -2
  543. package/dist/types/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +1 -1
  544. package/dist/types/modules/excel/xlsx/xform/sheet/auto-filter-xform.d.ts +1 -1
  545. package/dist/types/modules/excel/xlsx/xform/sheet/cell-xform.d.ts +1 -1
  546. package/dist/types/modules/excel/xlsx/xform/sheet/cf/cf-rule-xform.d.ts +6 -6
  547. package/dist/types/modules/excel/xlsx/xform/sheet/cf/cfvo-xform.d.ts +1 -1
  548. package/dist/types/modules/excel/xlsx/xform/sheet/cf/color-scale-xform.d.ts +3 -3
  549. package/dist/types/modules/excel/xlsx/xform/sheet/cf/conditional-formatting-xform.d.ts +1 -1
  550. package/dist/types/modules/excel/xlsx/xform/sheet/cf/conditional-formattings-xform.d.ts +2 -2
  551. package/dist/types/modules/excel/xlsx/xform/sheet/cf/databar-xform.d.ts +3 -3
  552. package/dist/types/modules/excel/xlsx/xform/sheet/cf/ext-lst-ref-xform.d.ts +1 -1
  553. package/dist/types/modules/excel/xlsx/xform/sheet/cf/formula-xform.d.ts +1 -1
  554. package/dist/types/modules/excel/xlsx/xform/sheet/cf/icon-set-xform.d.ts +2 -2
  555. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.d.ts +1 -1
  556. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.d.ts +3 -3
  557. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.d.ts +2 -2
  558. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.d.ts +3 -3
  559. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.d.ts +2 -2
  560. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/databar-ext-xform.d.ts +3 -3
  561. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/f-ext-xform.d.ts +1 -1
  562. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.d.ts +3 -3
  563. package/dist/types/modules/excel/xlsx/xform/sheet/cf-ext/sqref-ext-xform.d.ts +1 -1
  564. package/dist/types/modules/excel/xlsx/xform/sheet/col-breaks-xform.d.ts +1 -1
  565. package/dist/types/modules/excel/xlsx/xform/sheet/col-xform.d.ts +1 -1
  566. package/dist/types/modules/excel/xlsx/xform/sheet/data-validations-xform.d.ts +1 -1
  567. package/dist/types/modules/excel/xlsx/xform/sheet/dimension-xform.d.ts +1 -1
  568. package/dist/types/modules/excel/xlsx/xform/sheet/drawing-xform.d.ts +1 -1
  569. package/dist/types/modules/excel/xlsx/xform/sheet/ext-lst-xform.d.ts +1 -1
  570. package/dist/types/modules/excel/xlsx/xform/sheet/header-footer-xform.d.ts +1 -1
  571. package/dist/types/modules/excel/xlsx/xform/sheet/hyperlink-xform.d.ts +1 -1
  572. package/dist/types/modules/excel/xlsx/xform/sheet/merge-cell-xform.d.ts +1 -1
  573. package/dist/types/modules/excel/xlsx/xform/sheet/outline-properties-xform.d.ts +1 -1
  574. package/dist/types/modules/excel/xlsx/xform/sheet/page-breaks-xform.d.ts +1 -1
  575. package/dist/types/modules/excel/xlsx/xform/sheet/page-margins-xform.d.ts +1 -1
  576. package/dist/types/modules/excel/xlsx/xform/sheet/page-setup-properties-xform.d.ts +1 -1
  577. package/dist/types/modules/excel/xlsx/xform/sheet/page-setup-xform.d.ts +1 -1
  578. package/dist/types/modules/excel/xlsx/xform/sheet/picture-xform.d.ts +1 -1
  579. package/dist/types/modules/excel/xlsx/xform/sheet/print-options-xform.d.ts +1 -1
  580. package/dist/types/modules/excel/xlsx/xform/sheet/row-breaks-xform.d.ts +1 -1
  581. package/dist/types/modules/excel/xlsx/xform/sheet/row-xform.d.ts +1 -1
  582. package/dist/types/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.d.ts +1 -1
  583. package/dist/types/modules/excel/xlsx/xform/sheet/sheet-properties-xform.d.ts +1 -1
  584. package/dist/types/modules/excel/xlsx/xform/sheet/sheet-protection-xform.d.ts +1 -1
  585. package/dist/types/modules/excel/xlsx/xform/sheet/sheet-view-xform.d.ts +1 -1
  586. package/dist/types/modules/excel/xlsx/xform/sheet/table-part-xform.d.ts +1 -1
  587. package/dist/types/modules/excel/xlsx/xform/sheet/worksheet-xform.d.ts +1 -1
  588. package/dist/types/modules/excel/xlsx/xform/simple/boolean-xform.d.ts +1 -1
  589. package/dist/types/modules/excel/xlsx/xform/simple/date-xform.d.ts +1 -1
  590. package/dist/types/modules/excel/xlsx/xform/simple/float-xform.d.ts +1 -1
  591. package/dist/types/modules/excel/xlsx/xform/simple/integer-xform.d.ts +1 -1
  592. package/dist/types/modules/excel/xlsx/xform/simple/string-xform.d.ts +1 -1
  593. package/dist/types/modules/excel/xlsx/xform/static-xform.d.ts +1 -1
  594. package/dist/types/modules/excel/xlsx/xform/strings/phonetic-text-xform.d.ts +1 -1
  595. package/dist/types/modules/excel/xlsx/xform/strings/rich-text-xform.d.ts +3 -3
  596. package/dist/types/modules/excel/xlsx/xform/strings/shared-string-xform.d.ts +1 -1
  597. package/dist/types/modules/excel/xlsx/xform/strings/shared-strings-xform.d.ts +2 -2
  598. package/dist/types/modules/excel/xlsx/xform/strings/text-xform.d.ts +1 -1
  599. package/dist/types/modules/excel/xlsx/xform/style/alignment-xform.d.ts +1 -1
  600. package/dist/types/modules/excel/xlsx/xform/style/border-xform.d.ts +2 -2
  601. package/dist/types/modules/excel/xlsx/xform/style/color-xform.d.ts +1 -1
  602. package/dist/types/modules/excel/xlsx/xform/style/dxf-xform.d.ts +1 -1
  603. package/dist/types/modules/excel/xlsx/xform/style/fill-xform.d.ts +2 -2
  604. package/dist/types/modules/excel/xlsx/xform/style/font-xform.d.ts +1 -1
  605. package/dist/types/modules/excel/xlsx/xform/style/numfmt-xform.d.ts +1 -1
  606. package/dist/types/modules/excel/xlsx/xform/style/protection-xform.d.ts +1 -1
  607. package/dist/types/modules/excel/xlsx/xform/style/style-xform.d.ts +3 -3
  608. package/dist/types/modules/excel/xlsx/xform/style/styles-xform.d.ts +2 -2
  609. package/dist/types/modules/excel/xlsx/xform/style/underline-xform.d.ts +1 -1
  610. package/dist/types/modules/excel/xlsx/xform/table/auto-filter-xform.d.ts +2 -2
  611. package/dist/types/modules/excel/xlsx/xform/table/custom-filter-xform.d.ts +1 -1
  612. package/dist/types/modules/excel/xlsx/xform/table/filter-column-xform.d.ts +2 -2
  613. package/dist/types/modules/excel/xlsx/xform/table/filter-xform.d.ts +1 -1
  614. package/dist/types/modules/excel/xlsx/xform/table/table-column-xform.d.ts +1 -1
  615. package/dist/types/modules/excel/xlsx/xform/table/table-style-info-xform.d.ts +1 -1
  616. package/dist/types/modules/excel/xlsx/xform/table/table-xform.d.ts +1 -1
  617. package/dist/types/modules/excel/xlsx/xlsx.browser.d.ts +3 -3
  618. package/dist/types/modules/excel/xlsx/xlsx.d.ts +1 -1
  619. package/dist/types/modules/stream/base-transform.d.ts +1 -1
  620. package/dist/types/modules/stream/buffered-stream.d.ts +1 -1
  621. package/dist/types/modules/stream/index.browser.d.ts +8 -8
  622. package/dist/types/modules/stream/index.d.ts +8 -8
  623. package/dist/types/modules/stream/pull-stream.d.ts +1 -1
  624. package/dist/types/modules/stream/streams.browser.d.ts +4 -4
  625. package/dist/types/modules/stream/streams.d.ts +3 -3
  626. package/dist/types/modules/stream/utils.d.ts +1 -1
  627. package/dist/types/utils/utils.browser.d.ts +1 -1
  628. package/dist/types/utils/utils.d.ts +1 -1
  629. package/package.json +10 -6
  630. package/dist/browser/excelts.esm.js +0 -24621
  631. package/dist/browser/excelts.esm.js.map +0 -1
  632. package/dist/browser/excelts.esm.min.js +0 -148
  633. package/dist/browser/excelts.iife.js.map +0 -1
@@ -0,0 +1,674 @@
1
+ /**
2
+ * Utility functions for ExcelTS
3
+ * Provides convenient helper functions for common spreadsheet operations
4
+ */
5
+ import { Workbook } from "../workbook.js";
6
+ import { colCache } from "./col-cache.js";
7
+ import { format as cellFormat } from "./cell-format.js";
8
+ import { dateToExcel } from "../../../utils/utils.base.js";
9
+ /**
10
+ * Check if format is a pure time format (no date components like y, m for month, d)
11
+ * Time formats only contain: h, m (minutes in time context), s, AM/PM
12
+ * Excludes elapsed time formats like [h]:mm:ss which should keep full serial number
13
+ */
14
+ function isTimeOnlyFormat(fmt) {
15
+ // Remove quoted strings first
16
+ const cleaned = fmt.replace(/"[^"]*"/g, "");
17
+ // Elapsed time formats [h], [m], [s] should NOT be treated as time-only
18
+ // They need the full serial number to calculate total hours/minutes/seconds
19
+ if (/\[[hms]\]/i.test(cleaned)) {
20
+ return false;
21
+ }
22
+ // Remove color codes and conditions (but we already checked for [h], [m], [s])
23
+ const withoutBrackets = cleaned.replace(/\[[^\]]*\]/g, "");
24
+ // Check if it has time components (h, s, or AM/PM)
25
+ const hasTimeComponents = /[hs]/i.test(withoutBrackets) || /AM\/PM|A\/P/i.test(withoutBrackets);
26
+ // Check if it has date components (y, d, or m not adjacent to h/s which would make it minutes)
27
+ // In Excel: "m" after "h" or before "s" is minutes, otherwise it's month
28
+ const hasDateComponents = /[yd]/i.test(withoutBrackets);
29
+ // If it has time but no date components, it's a time-only format
30
+ // Also check for standalone 'm' that's not minutes (not near h or s)
31
+ if (hasDateComponents) {
32
+ return false;
33
+ }
34
+ // Check for month 'm' - if 'm' exists but not in h:m or m:s context, it's a date format
35
+ if (/m/i.test(withoutBrackets) && !hasTimeComponents) {
36
+ return false;
37
+ }
38
+ return hasTimeComponents;
39
+ }
40
+ /**
41
+ * Check if format is a date format (contains y, d, or month-m)
42
+ * Used to determine if dateFormat override should be applied
43
+ */
44
+ function isDateFormat(fmt) {
45
+ // Remove quoted strings first
46
+ const cleaned = fmt.replace(/"[^"]*"/g, "");
47
+ // Elapsed time formats [h], [m], [s] are NOT date formats
48
+ if (/\[[hms]\]/i.test(cleaned)) {
49
+ return false;
50
+ }
51
+ // Remove color codes and conditions
52
+ const withoutBrackets = cleaned.replace(/\[[^\]]*\]/g, "");
53
+ // Check for year or day components
54
+ if (/[yd]/i.test(withoutBrackets)) {
55
+ return true;
56
+ }
57
+ // Check for month 'm' - only if it's NOT in time context (not near h or s)
58
+ // In Excel: "m" after "h" or before "s" is minutes, otherwise it's month
59
+ if (/m/i.test(withoutBrackets)) {
60
+ const hasTimeComponents = /[hs]/i.test(withoutBrackets) || /AM\/PM|A\/P/i.test(withoutBrackets);
61
+ // If no time components, 'm' is month
62
+ if (!hasTimeComponents) {
63
+ return true;
64
+ }
65
+ // If has time components, need to check if 'm' is month or minutes
66
+ // Simplified: if format has both date-like and time-like patterns, consider it a date format
67
+ // e.g., "m/d/yy h:mm" - has 'm' as month and 'mm' as minutes
68
+ }
69
+ return false;
70
+ }
71
+ /**
72
+ * Format a value (Date, number, boolean, string) according to the given format
73
+ * Handles timezone-independent conversion for Date objects
74
+ * @param value - The value to format
75
+ * @param fmt - The format string to use
76
+ * @param dateFormat - Optional override format for date values (not applied to time or elapsed time formats)
77
+ */
78
+ function formatValue(value, fmt, dateFormat) {
79
+ // Date object - convert back to Excel serial number
80
+ if (value instanceof Date) {
81
+ let serial = dateToExcel(value);
82
+ // For time-only formats, use only the fractional part (time portion)
83
+ if (isTimeOnlyFormat(fmt)) {
84
+ serial = serial % 1;
85
+ if (serial < 0) {
86
+ serial += 1;
87
+ }
88
+ return cellFormat(fmt, serial);
89
+ }
90
+ // Only apply dateFormat override to actual date formats
91
+ // (not elapsed time formats like [h]:mm:ss)
92
+ const actualFmt = dateFormat && isDateFormat(fmt) ? dateFormat : fmt;
93
+ return cellFormat(actualFmt, serial);
94
+ }
95
+ // Number/Boolean/String - let cellFormat handle it
96
+ return cellFormat(fmt, value);
97
+ }
98
+ /**
99
+ * Get formatted display text for a cell value
100
+ * Returns the value formatted according to the cell's numFmt
101
+ * This matches Excel's display exactly (timezone-independent)
102
+ * @param cell - The cell to get display text for
103
+ * @param dateFormat - Optional override format for date values
104
+ */
105
+ function getCellDisplayText(cell, dateFormat) {
106
+ const value = cell.value;
107
+ const numFmt = cell.numFmt;
108
+ // Extract format code string from numFmt (which can be string or NumFmt object)
109
+ const fmt = typeof numFmt === "string" ? numFmt : (numFmt?.formatCode ?? "General");
110
+ // Null/undefined
111
+ if (value == null) {
112
+ return "";
113
+ }
114
+ // Date/Number/Boolean/String - format directly
115
+ if (value instanceof Date ||
116
+ typeof value === "number" ||
117
+ typeof value === "boolean" ||
118
+ typeof value === "string") {
119
+ return formatValue(value, fmt, dateFormat);
120
+ }
121
+ // Formula type - use the result value
122
+ if (typeof value === "object" && "formula" in value) {
123
+ const result = value.result;
124
+ if (result == null) {
125
+ return "";
126
+ }
127
+ if (result instanceof Date ||
128
+ typeof result === "number" ||
129
+ typeof result === "boolean" ||
130
+ typeof result === "string") {
131
+ return formatValue(result, fmt, dateFormat);
132
+ }
133
+ }
134
+ // Fallback to cell.text for other types (rich text, hyperlink, error, etc.)
135
+ return cell.text;
136
+ }
137
+ // =============================================================================
138
+ // Cell Address Encoding/Decoding
139
+ // =============================================================================
140
+ /**
141
+ * Decode column string to 0-indexed number
142
+ * @example decodeCol("A") => 0, decodeCol("Z") => 25, decodeCol("AA") => 26
143
+ */
144
+ export function decodeCol(colstr) {
145
+ return colCache.l2n(colstr.toUpperCase()) - 1;
146
+ }
147
+ /**
148
+ * Encode 0-indexed column number to string
149
+ * @example encodeCol(0) => "A", encodeCol(25) => "Z", encodeCol(26) => "AA"
150
+ */
151
+ export function encodeCol(col) {
152
+ return colCache.n2l(col + 1);
153
+ }
154
+ /**
155
+ * Decode row string to 0-indexed number
156
+ * @example decodeRow("1") => 0, decodeRow("10") => 9
157
+ */
158
+ export function decodeRow(rowstr) {
159
+ return parseInt(rowstr, 10) - 1;
160
+ }
161
+ /**
162
+ * Encode 0-indexed row number to string
163
+ * @example encodeRow(0) => "1", encodeRow(9) => "10"
164
+ */
165
+ export function encodeRow(row) {
166
+ return String(row + 1);
167
+ }
168
+ /**
169
+ * Decode cell address string to CellAddress object
170
+ * @example decodeCell("A1") => {c: 0, r: 0}, decodeCell("B2") => {c: 1, r: 1}
171
+ */
172
+ export function decodeCell(cstr) {
173
+ const addr = colCache.decodeAddress(cstr.toUpperCase());
174
+ return { c: addr.col - 1, r: addr.row - 1 };
175
+ }
176
+ /**
177
+ * Encode CellAddress object to cell address string
178
+ * @example encodeCell({c: 0, r: 0}) => "A1", encodeCell({c: 1, r: 1}) => "B2"
179
+ */
180
+ export function encodeCell(cell) {
181
+ return colCache.encodeAddress(cell.r + 1, cell.c + 1);
182
+ }
183
+ /**
184
+ * Decode range string to Range object
185
+ * @example decodeRange("A1:B2") => {s: {c: 0, r: 0}, e: {c: 1, r: 1}}
186
+ */
187
+ export function decodeRange(range) {
188
+ const idx = range.indexOf(":");
189
+ if (idx === -1) {
190
+ const cell = decodeCell(range);
191
+ return { s: cell, e: { ...cell } };
192
+ }
193
+ return {
194
+ s: decodeCell(range.slice(0, idx)),
195
+ e: decodeCell(range.slice(idx + 1))
196
+ };
197
+ }
198
+ export function encodeRange(startOrRange, end) {
199
+ if (end === undefined) {
200
+ const range = startOrRange;
201
+ return encodeRange(range.s, range.e);
202
+ }
203
+ const start = startOrRange;
204
+ const startStr = encodeCell(start);
205
+ const endStr = encodeCell(end);
206
+ return startStr === endStr ? startStr : `${startStr}:${endStr}`;
207
+ }
208
+ /**
209
+ * Create a worksheet from an array of objects (xlsx compatible)
210
+ * @example
211
+ * const ws = jsonToSheet([{name: "Alice", age: 30}, {name: "Bob", age: 25}])
212
+ */
213
+ export function jsonToSheet(data, opts) {
214
+ const o = opts || {};
215
+ // Create a temporary workbook to get a worksheet
216
+ const tempWb = new Workbook();
217
+ const worksheet = tempWb.addWorksheet("Sheet1");
218
+ if (data.length === 0) {
219
+ return worksheet;
220
+ }
221
+ // Determine headers - use provided header or Object.keys from first object
222
+ const allKeys = new Set();
223
+ data.forEach(row => Object.keys(row).forEach(k => allKeys.add(k)));
224
+ const headers = o.header ? [...o.header] : [...allKeys];
225
+ // Add any missing keys from data that weren't in header
226
+ if (o.header) {
227
+ allKeys.forEach(k => {
228
+ if (!headers.includes(k)) {
229
+ headers.push(k);
230
+ }
231
+ });
232
+ }
233
+ let rowNum = 1;
234
+ // Write header row
235
+ if (!o.skipHeader) {
236
+ headers.forEach((h, colIdx) => {
237
+ worksheet.getCell(rowNum, colIdx + 1).value = h;
238
+ });
239
+ rowNum++;
240
+ }
241
+ // Write data rows
242
+ for (const row of data) {
243
+ headers.forEach((key, colIdx) => {
244
+ const val = row[key];
245
+ if (val === null && o.nullError) {
246
+ worksheet.getCell(rowNum, colIdx + 1).value = { error: "#NULL!" };
247
+ }
248
+ else if (val !== undefined && val !== null) {
249
+ worksheet.getCell(rowNum, colIdx + 1).value = val;
250
+ }
251
+ });
252
+ rowNum++;
253
+ }
254
+ return worksheet;
255
+ }
256
+ /**
257
+ * Add data from an array of objects to an existing worksheet (xlsx compatible)
258
+ */
259
+ export function sheetAddJson(worksheet, data, opts) {
260
+ const o = opts || {};
261
+ if (data.length === 0) {
262
+ return worksheet;
263
+ }
264
+ // Determine starting position
265
+ let startRow = 1;
266
+ let startCol = 1;
267
+ if (o.origin !== undefined) {
268
+ if (typeof o.origin === "string") {
269
+ const addr = decodeCell(o.origin);
270
+ startRow = addr.r + 1;
271
+ startCol = addr.c + 1;
272
+ }
273
+ else if (typeof o.origin === "number") {
274
+ if (o.origin === -1) {
275
+ // Append to bottom
276
+ startRow = worksheet.rowCount + 1;
277
+ }
278
+ else {
279
+ startRow = o.origin + 1; // 0-indexed row
280
+ }
281
+ }
282
+ else {
283
+ startRow = o.origin.r + 1;
284
+ startCol = o.origin.c + 1;
285
+ }
286
+ }
287
+ // Determine headers
288
+ const allKeys = new Set();
289
+ data.forEach(row => Object.keys(row).forEach(k => allKeys.add(k)));
290
+ const headers = o.header ? [...o.header] : [...allKeys];
291
+ if (o.header) {
292
+ allKeys.forEach(k => {
293
+ if (!headers.includes(k)) {
294
+ headers.push(k);
295
+ }
296
+ });
297
+ }
298
+ let rowNum = startRow;
299
+ // Write header row
300
+ if (!o.skipHeader) {
301
+ headers.forEach((h, colIdx) => {
302
+ worksheet.getCell(rowNum, startCol + colIdx).value = h;
303
+ });
304
+ rowNum++;
305
+ }
306
+ // Write data rows
307
+ for (const row of data) {
308
+ headers.forEach((key, colIdx) => {
309
+ const val = row[key];
310
+ if (val === null && o.nullError) {
311
+ worksheet.getCell(rowNum, startCol + colIdx).value = { error: "#NULL!" };
312
+ }
313
+ else if (val !== undefined && val !== null) {
314
+ worksheet.getCell(rowNum, startCol + colIdx).value = val;
315
+ }
316
+ });
317
+ rowNum++;
318
+ }
319
+ return worksheet;
320
+ }
321
+ /**
322
+ * Convert worksheet to JSON array (xlsx compatible)
323
+ * @example
324
+ * // Default: array of objects with first row as headers
325
+ * const data = sheetToJson(worksheet)
326
+ * // => [{name: "Alice", age: 30}, {name: "Bob", age: 25}]
327
+ *
328
+ * // Array of arrays
329
+ * const aoa = sheetToJson(worksheet, { header: 1 })
330
+ * // => [["name", "age"], ["Alice", 30], ["Bob", 25]]
331
+ *
332
+ * // Column letters as keys
333
+ * const cols = sheetToJson(worksheet, { header: "A" })
334
+ * // => [{A: "name", B: "age"}, {A: "Alice", B: 30}]
335
+ */
336
+ export function sheetToJson(worksheet, opts) {
337
+ const o = opts || {};
338
+ // Determine range
339
+ let startRow = 1;
340
+ let endRow = worksheet.rowCount;
341
+ let startCol = 1;
342
+ let endCol = worksheet.columnCount;
343
+ if (o.range !== undefined) {
344
+ if (typeof o.range === "number") {
345
+ startRow = o.range + 1; // 0-indexed to 1-indexed
346
+ }
347
+ else if (typeof o.range === "string") {
348
+ const r = decodeRange(o.range);
349
+ startRow = r.s.r + 1;
350
+ endRow = r.e.r + 1;
351
+ startCol = r.s.c + 1;
352
+ endCol = r.e.c + 1;
353
+ }
354
+ }
355
+ if (endRow < startRow || endCol < startCol) {
356
+ return [];
357
+ }
358
+ // Handle header option
359
+ const headerOpt = o.header;
360
+ // header: 1 - return array of arrays
361
+ if (headerOpt === 1) {
362
+ const result = [];
363
+ // Default for header:1 is to include blank rows
364
+ const includeBlank = o.blankrows !== false;
365
+ for (let row = startRow; row <= endRow; row++) {
366
+ const rowData = [];
367
+ let isEmpty = true;
368
+ for (let col = startCol; col <= endCol; col++) {
369
+ const cell = worksheet.getCell(row, col);
370
+ const val = o.raw === false ? getCellDisplayText(cell, o.dateFormat).trim() : cell.value;
371
+ if (val != null && val !== "") {
372
+ rowData[col - startCol] = val;
373
+ isEmpty = false;
374
+ }
375
+ else if (o.defval !== undefined) {
376
+ rowData[col - startCol] = o.defval;
377
+ }
378
+ else {
379
+ rowData[col - startCol] = null;
380
+ }
381
+ }
382
+ if (!isEmpty || includeBlank) {
383
+ result.push(rowData);
384
+ }
385
+ }
386
+ return result;
387
+ }
388
+ // header: "A" - use column letters as keys
389
+ if (headerOpt === "A") {
390
+ const result = [];
391
+ // Default for header:"A" is to skip blank rows
392
+ const includeBlank = o.blankrows === true;
393
+ for (let row = startRow; row <= endRow; row++) {
394
+ const rowData = {};
395
+ let isEmpty = true;
396
+ for (let col = startCol; col <= endCol; col++) {
397
+ const cell = worksheet.getCell(row, col);
398
+ const val = o.raw === false ? getCellDisplayText(cell, o.dateFormat).trim() : cell.value;
399
+ const key = encodeCol(col - 1); // 0-indexed for encodeCol
400
+ if (val != null && val !== "") {
401
+ rowData[key] = val;
402
+ isEmpty = false;
403
+ }
404
+ else if (o.defval !== undefined) {
405
+ rowData[key] = o.defval;
406
+ }
407
+ }
408
+ if (!isEmpty || includeBlank) {
409
+ result.push(rowData);
410
+ }
411
+ }
412
+ return result;
413
+ }
414
+ // header: string[] - use provided array as keys
415
+ if (Array.isArray(headerOpt)) {
416
+ const result = [];
417
+ const includeBlank = o.blankrows === true;
418
+ for (let row = startRow; row <= endRow; row++) {
419
+ const rowData = {};
420
+ let isEmpty = true;
421
+ for (let col = startCol; col <= endCol; col++) {
422
+ const colIdx = col - startCol;
423
+ const key = headerOpt[colIdx] ?? `__EMPTY_${colIdx}`;
424
+ const cell = worksheet.getCell(row, col);
425
+ const val = o.raw === false ? getCellDisplayText(cell, o.dateFormat).trim() : cell.value;
426
+ if (val != null && val !== "") {
427
+ rowData[key] = val;
428
+ isEmpty = false;
429
+ }
430
+ else if (o.defval !== undefined) {
431
+ rowData[key] = o.defval;
432
+ }
433
+ }
434
+ if (!isEmpty || includeBlank) {
435
+ result.push(rowData);
436
+ }
437
+ }
438
+ return result;
439
+ }
440
+ // Default: first row as header, disambiguate duplicates
441
+ const headers = [];
442
+ const headerCounts = {};
443
+ for (let col = startCol; col <= endCol; col++) {
444
+ const cell = worksheet.getCell(startRow, col);
445
+ const val = cell.value;
446
+ let header = val != null ? String(val) : `__EMPTY_${col - startCol}`;
447
+ // Disambiguate duplicate headers
448
+ if (headerCounts[header] !== undefined) {
449
+ headerCounts[header]++;
450
+ header = `${header}_${headerCounts[header]}`;
451
+ }
452
+ else {
453
+ headerCounts[header] = 0;
454
+ }
455
+ headers.push(header);
456
+ }
457
+ // Read data rows (skip header row)
458
+ const result = [];
459
+ const dataStartRow = startRow + 1;
460
+ // Default for objects is to skip blank rows
461
+ const includeBlank = o.blankrows === true;
462
+ for (let row = dataStartRow; row <= endRow; row++) {
463
+ const rowData = {};
464
+ let isEmpty = true;
465
+ for (let col = startCol; col <= endCol; col++) {
466
+ const cell = worksheet.getCell(row, col);
467
+ const val = o.raw === false ? getCellDisplayText(cell, o.dateFormat).trim() : cell.value;
468
+ const key = headers[col - startCol];
469
+ if (val != null && val !== "") {
470
+ rowData[key] = val;
471
+ isEmpty = false;
472
+ }
473
+ else if (o.defval !== undefined) {
474
+ rowData[key] = o.defval;
475
+ }
476
+ }
477
+ if (!isEmpty || includeBlank) {
478
+ result.push(rowData);
479
+ }
480
+ }
481
+ return result;
482
+ }
483
+ /**
484
+ * Convert worksheet to CSV string
485
+ */
486
+ export function sheetToCsv(worksheet, opts) {
487
+ const o = opts || {};
488
+ const FS = o.FS ?? ",";
489
+ const RS = o.RS ?? "\n";
490
+ const rows = [];
491
+ worksheet.eachRow({ includeEmpty: o.blankrows !== false }, (row, rowNumber) => {
492
+ const cells = [];
493
+ let isEmpty = true;
494
+ row.eachCell({ includeEmpty: true }, (cell, colNumber) => {
495
+ let val = "";
496
+ if (cell.value != null) {
497
+ if (cell.value instanceof Date) {
498
+ val = cell.value.toISOString();
499
+ }
500
+ else if (typeof cell.value === "object") {
501
+ // Handle rich text, formula results, etc.
502
+ if ("result" in cell.value) {
503
+ val = String(cell.value.result ?? "");
504
+ }
505
+ else if ("text" in cell.value) {
506
+ val = String(cell.value.text ?? "");
507
+ }
508
+ else if ("richText" in cell.value) {
509
+ val = cell.value.richText.map(r => r.text).join("");
510
+ }
511
+ else {
512
+ val = String(cell.value);
513
+ }
514
+ }
515
+ else {
516
+ val = String(cell.value);
517
+ }
518
+ isEmpty = false;
519
+ }
520
+ // Quote if necessary
521
+ const needsQuote = o.forceQuotes ||
522
+ val.includes(FS) ||
523
+ val.includes('"') ||
524
+ val.includes("\n") ||
525
+ val.includes("\r");
526
+ if (needsQuote) {
527
+ val = `"${val.replace(/"/g, '""')}"`;
528
+ }
529
+ cells.push(val);
530
+ });
531
+ // Pad cells to match column count
532
+ while (cells.length < worksheet.columnCount) {
533
+ cells.push("");
534
+ }
535
+ if (!isEmpty || o.blankrows !== false) {
536
+ rows.push(cells.join(FS));
537
+ }
538
+ });
539
+ return rows.join(RS);
540
+ }
541
+ // =============================================================================
542
+ // Workbook Functions
543
+ // =============================================================================
544
+ /**
545
+ * Create a new workbook
546
+ */
547
+ export function bookNew() {
548
+ return new Workbook();
549
+ }
550
+ /**
551
+ * Append worksheet to workbook (xlsx compatible)
552
+ * @example
553
+ * const wb = bookNew();
554
+ * const ws = jsonToSheet([{a: 1, b: 2}]);
555
+ * bookAppendSheet(wb, ws, "Sheet1");
556
+ */
557
+ export function bookAppendSheet(workbook, worksheet, name) {
558
+ // Copy the worksheet data to a new sheet in the workbook
559
+ const newWs = workbook.addWorksheet(name);
560
+ // Copy all cells from source worksheet
561
+ worksheet.eachRow({ includeEmpty: true }, (row, rowNumber) => {
562
+ row.eachCell({ includeEmpty: true }, (cell, colNumber) => {
563
+ const newCell = newWs.getCell(rowNumber, colNumber);
564
+ newCell.value = cell.value;
565
+ if (cell.style) {
566
+ newCell.style = cell.style;
567
+ }
568
+ });
569
+ });
570
+ // Copy column properties
571
+ worksheet.columns?.forEach((col, idx) => {
572
+ if (col && newWs.columns[idx]) {
573
+ if (col.width) {
574
+ newWs.getColumn(idx + 1).width = col.width;
575
+ }
576
+ }
577
+ });
578
+ }
579
+ /**
580
+ * Create a worksheet from an array of arrays (xlsx compatible)
581
+ * @example
582
+ * const ws = aoaToSheet([["Name", "Age"], ["Alice", 30], ["Bob", 25]])
583
+ */
584
+ export function aoaToSheet(data, opts) {
585
+ const tempWb = new Workbook();
586
+ const worksheet = tempWb.addWorksheet("Sheet1");
587
+ if (data.length === 0) {
588
+ return worksheet;
589
+ }
590
+ // Determine starting position
591
+ let startRow = 1;
592
+ let startCol = 1;
593
+ if (opts?.origin !== undefined) {
594
+ if (typeof opts.origin === "string") {
595
+ const addr = decodeCell(opts.origin);
596
+ startRow = addr.r + 1;
597
+ startCol = addr.c + 1;
598
+ }
599
+ else if (typeof opts.origin === "number") {
600
+ startRow = opts.origin + 1; // 0-indexed row
601
+ }
602
+ else {
603
+ startRow = opts.origin.r + 1;
604
+ startCol = opts.origin.c + 1;
605
+ }
606
+ }
607
+ data.forEach((row, rowIdx) => {
608
+ if (!row) {
609
+ return;
610
+ }
611
+ row.forEach((val, colIdx) => {
612
+ if (val !== undefined && val !== null) {
613
+ worksheet.getCell(startRow + rowIdx, startCol + colIdx).value = val;
614
+ }
615
+ });
616
+ });
617
+ return worksheet;
618
+ }
619
+ /**
620
+ * Add data from an array of arrays to an existing worksheet (xlsx compatible)
621
+ */
622
+ export function sheetAddAoa(worksheet, data, opts) {
623
+ if (data.length === 0) {
624
+ return worksheet;
625
+ }
626
+ // Determine starting position
627
+ let startRow = 1;
628
+ let startCol = 1;
629
+ if (opts?.origin !== undefined) {
630
+ if (typeof opts.origin === "string") {
631
+ const addr = decodeCell(opts.origin);
632
+ startRow = addr.r + 1;
633
+ startCol = addr.c + 1;
634
+ }
635
+ else if (typeof opts.origin === "number") {
636
+ if (opts.origin === -1) {
637
+ // Append to bottom
638
+ startRow = worksheet.rowCount + 1;
639
+ }
640
+ else {
641
+ startRow = opts.origin + 1; // 0-indexed row
642
+ }
643
+ }
644
+ else {
645
+ startRow = opts.origin.r + 1;
646
+ startCol = opts.origin.c + 1;
647
+ }
648
+ }
649
+ data.forEach((row, rowIdx) => {
650
+ if (!row) {
651
+ return;
652
+ }
653
+ row.forEach((val, colIdx) => {
654
+ if (val !== undefined && val !== null) {
655
+ worksheet.getCell(startRow + rowIdx, startCol + colIdx).value = val;
656
+ }
657
+ });
658
+ });
659
+ return worksheet;
660
+ }
661
+ /**
662
+ * Convert worksheet to array of arrays
663
+ */
664
+ export function sheetToAoa(worksheet) {
665
+ const result = [];
666
+ worksheet.eachRow({ includeEmpty: true }, (row, rowNumber) => {
667
+ const rowData = [];
668
+ row.eachCell({ includeEmpty: true }, (cell, colNumber) => {
669
+ rowData[colNumber - 1] = cell.value;
670
+ });
671
+ result[rowNumber - 1] = rowData;
672
+ });
673
+ return result;
674
+ }