@cj-tech-master/excelts 9.5.4 → 9.5.5

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 (767) hide show
  1. package/dist/browser/modules/archive/compression/streaming-compress.browser.js +29 -0
  2. package/dist/browser/modules/archive/compression/streaming-compress.js +9 -0
  3. package/dist/browser/modules/archive/compression/worker-pool/pool.browser.js +26 -1
  4. package/dist/browser/modules/archive/fs/archive-file.d.ts +8 -5
  5. package/dist/browser/modules/archive/fs/archive-file.js +78 -16
  6. package/dist/browser/modules/archive/unzip/stream.browser.js +43 -2
  7. package/dist/browser/modules/excel/chart/chart-ex-builder.js +7 -2
  8. package/dist/browser/modules/excel/chart/chart-ex-renderer.js +4 -9
  9. package/dist/browser/modules/excel/chart/chart-ex-types.d.ts +0 -12
  10. package/dist/browser/modules/excel/chart/chart.d.ts +1 -5
  11. package/dist/browser/modules/excel/chart/chart.js +1 -7
  12. package/dist/browser/modules/excel/chart/types.d.ts +0 -6
  13. package/dist/browser/modules/excel/stream/workbook-reader.browser.js +25 -1
  14. package/dist/browser/modules/excel/stream/workbook-reader.js +9 -0
  15. package/dist/browser/modules/excel/stream/workbook-writer.browser.d.ts +40 -0
  16. package/dist/browser/modules/excel/stream/workbook-writer.browser.js +228 -13
  17. package/dist/browser/modules/excel/utils/string-buf.d.ts +5 -26
  18. package/dist/browser/modules/excel/utils/string-buf.js +4 -81
  19. package/dist/browser/modules/excel/workbook.browser.js +135 -25
  20. package/dist/browser/modules/excel/xlsx/xform/chart/chart-space-xform.js +6 -20
  21. package/dist/browser/modules/excel/xlsx/xlsx.browser.d.ts +19 -9
  22. package/dist/browser/modules/excel/xlsx/xlsx.browser.js +32 -8
  23. package/dist/browser/modules/excel/xlsx/xlsx.d.ts +10 -2
  24. package/dist/browser/modules/excel/xlsx/xlsx.js +9 -1
  25. package/dist/browser/modules/pdf/excel-bridge.d.ts +30 -1
  26. package/dist/browser/modules/pdf/excel-bridge.js +32 -0
  27. package/dist/browser/modules/pdf/font/metrics.d.ts +3 -52
  28. package/dist/browser/modules/pdf/font/metrics.js +3 -237
  29. package/dist/browser/modules/pdf/index.d.ts +1 -1
  30. package/dist/browser/modules/pdf/index.js +1 -1
  31. package/dist/browser/modules/pdf/render-layout-to-pdf.d.ts +66 -0
  32. package/dist/browser/modules/pdf/render-layout-to-pdf.js +647 -0
  33. package/dist/browser/modules/pdf/word-bridge.d.ts +80 -12
  34. package/dist/browser/modules/pdf/word-bridge.js +122 -274
  35. package/dist/browser/modules/stream/index.base.d.ts +2 -0
  36. package/dist/browser/modules/stream/index.base.js +2 -1
  37. package/dist/browser/modules/stream/internal/sink-adapter.d.ts +65 -0
  38. package/dist/browser/modules/stream/internal/sink-adapter.js +198 -0
  39. package/dist/browser/modules/stream/pull-stream.d.ts +19 -2
  40. package/dist/browser/modules/stream/pull-stream.js +51 -5
  41. package/dist/browser/modules/stream/types.d.ts +13 -1
  42. package/dist/browser/modules/word/advanced/diff.d.ts +61 -0
  43. package/dist/browser/modules/word/advanced/diff.js +167 -0
  44. package/dist/browser/modules/word/advanced/drawing-shapes.d.ts +269 -0
  45. package/dist/browser/modules/word/advanced/drawing-shapes.js +268 -0
  46. package/dist/browser/modules/word/advanced/field-engine.d.ts +43 -0
  47. package/dist/browser/modules/word/advanced/field-engine.js +1225 -0
  48. package/dist/browser/modules/word/advanced/glossary.d.ts +86 -0
  49. package/dist/browser/modules/word/advanced/glossary.js +79 -0
  50. package/dist/browser/modules/word/advanced/math-convert.d.ts +30 -0
  51. package/dist/browser/modules/word/advanced/math-convert.js +595 -0
  52. package/dist/browser/modules/word/advanced/ole-objects.d.ts +115 -0
  53. package/dist/browser/modules/word/advanced/ole-objects.js +271 -0
  54. package/dist/browser/modules/word/advanced/style-map.d.ts +105 -0
  55. package/dist/browser/modules/word/advanced/style-map.js +322 -0
  56. package/dist/browser/modules/word/advanced/validation.d.ts +56 -0
  57. package/dist/browser/modules/word/advanced/validation.js +1065 -0
  58. package/dist/browser/modules/word/advanced/vba-project.d.ts +91 -0
  59. package/dist/browser/modules/word/advanced/vba-project.js +265 -0
  60. package/dist/browser/modules/word/bridge/excel-bridge.d.ts +127 -0
  61. package/dist/browser/modules/word/bridge/excel-bridge.js +980 -0
  62. package/dist/browser/modules/word/builder/document-handle.d.ts +151 -0
  63. package/dist/browser/modules/word/builder/document-handle.js +664 -0
  64. package/dist/browser/modules/word/builder/paragraph-builders.d.ts +61 -0
  65. package/dist/browser/modules/word/builder/paragraph-builders.js +90 -0
  66. package/dist/browser/modules/word/builder/run-builders.d.ts +374 -0
  67. package/dist/browser/modules/word/builder/run-builders.js +600 -0
  68. package/dist/browser/modules/word/builder/table-builders.d.ts +23 -0
  69. package/dist/browser/modules/word/builder/table-builders.js +45 -0
  70. package/dist/browser/modules/word/constants.d.ts +39 -1
  71. package/dist/browser/modules/word/constants.js +109 -1
  72. package/dist/browser/modules/word/convert/conversion-ir.d.ts +210 -0
  73. package/dist/browser/modules/word/convert/conversion-ir.js +31 -0
  74. package/dist/browser/modules/word/convert/docx-to-semantic.d.ts +39 -0
  75. package/dist/browser/modules/word/convert/docx-to-semantic.js +499 -0
  76. package/dist/browser/modules/word/convert/flat-opc.d.ts +44 -0
  77. package/dist/browser/modules/word/convert/flat-opc.js +385 -0
  78. package/dist/browser/modules/word/convert/html/html-import.d.ts +50 -0
  79. package/dist/browser/modules/word/convert/html/html-import.js +1907 -0
  80. package/dist/{types/modules/word → browser/modules/word/convert/html}/html-renderer.d.ts +14 -1
  81. package/dist/{esm/modules/word → browser/modules/word/convert/html}/html-renderer.js +420 -69
  82. package/dist/browser/modules/word/convert/html/html.d.ts +15 -0
  83. package/dist/browser/modules/word/convert/html/html.js +15 -0
  84. package/dist/browser/modules/word/convert/markdown/markdown-import.d.ts +68 -0
  85. package/dist/browser/modules/word/convert/markdown/markdown-import.js +1325 -0
  86. package/dist/browser/modules/word/convert/markdown/markdown-renderer.d.ts +25 -0
  87. package/dist/browser/modules/word/convert/markdown/markdown-renderer.js +634 -0
  88. package/dist/browser/modules/word/convert/markdown/markdown.d.ts +15 -0
  89. package/dist/browser/modules/word/convert/markdown/markdown.js +15 -0
  90. package/dist/browser/modules/word/convert/odt/odt.d.ts +41 -0
  91. package/dist/browser/modules/word/convert/odt/odt.js +1932 -0
  92. package/dist/browser/modules/word/{color-utils.d.ts → core/color-utils.d.ts} +8 -1
  93. package/dist/browser/modules/word/core/color-utils.js +43 -0
  94. package/dist/browser/modules/word/core/internal-utils.d.ts +90 -0
  95. package/dist/browser/modules/word/core/internal-utils.js +209 -0
  96. package/dist/browser/modules/word/core/mapper.d.ts +44 -0
  97. package/dist/browser/modules/word/core/mapper.js +427 -0
  98. package/dist/browser/modules/word/core/opc-paths.d.ts +33 -0
  99. package/dist/browser/modules/word/core/opc-paths.js +48 -0
  100. package/dist/browser/modules/word/core/text-utils.d.ts +38 -0
  101. package/dist/browser/modules/word/core/text-utils.js +202 -0
  102. package/dist/browser/modules/word/core/walker.d.ts +119 -0
  103. package/dist/browser/modules/word/core/walker.js +570 -0
  104. package/dist/browser/modules/word/crypto.d.ts +14 -9
  105. package/dist/browser/modules/word/crypto.js +13 -7
  106. package/dist/browser/modules/word/document-io.d.ts +59 -27
  107. package/dist/browser/modules/word/document-io.js +80 -197
  108. package/dist/browser/modules/word/errors.d.ts +44 -1
  109. package/dist/browser/modules/word/errors.js +54 -2
  110. package/dist/browser/modules/word/excel.d.ts +14 -0
  111. package/dist/browser/modules/word/excel.js +13 -0
  112. package/dist/browser/modules/word/font/font-embed.d.ts +112 -0
  113. package/dist/browser/modules/word/font/font-embed.js +646 -0
  114. package/dist/{esm/modules/word → browser/modules/word/font}/font-obfuscation.js +4 -9
  115. package/dist/browser/modules/word/font/hyphenation.d.ts +65 -0
  116. package/dist/browser/modules/word/font/hyphenation.js +4210 -0
  117. package/dist/browser/modules/word/font/text-shaping.d.ts +58 -0
  118. package/dist/browser/modules/word/font/text-shaping.js +635 -0
  119. package/dist/browser/modules/word/html.d.ts +7 -6
  120. package/dist/browser/modules/word/html.js +6 -5
  121. package/dist/browser/modules/word/incremental-edit.d.ts +123 -0
  122. package/dist/browser/modules/word/incremental-edit.js +361 -0
  123. package/dist/browser/modules/word/index.base.d.ts +194 -10
  124. package/dist/browser/modules/word/index.base.js +138 -29
  125. package/dist/browser/modules/word/layout/layout-constants.d.ts +17 -0
  126. package/dist/browser/modules/word/layout/layout-constants.js +17 -0
  127. package/dist/browser/modules/word/layout/layout-full.d.ts +53 -0
  128. package/dist/browser/modules/word/layout/layout-full.js +1696 -0
  129. package/dist/browser/modules/word/layout/layout-model.d.ts +344 -0
  130. package/dist/browser/modules/word/layout/layout-model.js +16 -0
  131. package/dist/browser/modules/word/layout/layout.d.ts +63 -0
  132. package/dist/browser/modules/word/layout/layout.js +1167 -0
  133. package/dist/browser/modules/word/layout/render-page.d.ts +57 -0
  134. package/dist/browser/modules/word/layout/render-page.js +1238 -0
  135. package/dist/browser/modules/word/markdown.d.ts +14 -0
  136. package/dist/browser/modules/word/markdown.js +13 -0
  137. package/dist/browser/modules/word/patcher.d.ts +62 -0
  138. package/dist/browser/modules/word/patcher.js +537 -0
  139. package/dist/browser/modules/word/query/compat.d.ts +25 -0
  140. package/dist/browser/modules/word/query/compat.js +58 -0
  141. package/dist/browser/modules/word/query/data-binding.d.ts +22 -0
  142. package/dist/browser/modules/word/query/data-binding.js +392 -0
  143. package/dist/browser/modules/word/query/form-fields.d.ts +41 -0
  144. package/dist/browser/modules/word/query/form-fields.js +268 -0
  145. package/dist/browser/modules/word/query/format-search.d.ts +99 -0
  146. package/dist/browser/modules/word/query/format-search.js +329 -0
  147. package/dist/browser/modules/word/query/mail-merge.d.ts +25 -0
  148. package/dist/browser/modules/word/query/mail-merge.js +111 -0
  149. package/dist/browser/modules/word/query/merge.d.ts +50 -0
  150. package/dist/browser/modules/word/query/merge.js +617 -0
  151. package/dist/browser/modules/word/query/replace.d.ts +47 -0
  152. package/dist/browser/modules/word/query/replace.js +301 -0
  153. package/dist/browser/modules/word/query/revisions.d.ts +67 -0
  154. package/dist/browser/modules/word/query/revisions.js +879 -0
  155. package/dist/browser/modules/word/query/search.d.ts +129 -0
  156. package/dist/browser/modules/word/query/search.js +346 -0
  157. package/dist/browser/modules/word/query/split.d.ts +44 -0
  158. package/dist/browser/modules/word/query/split.js +135 -0
  159. package/dist/browser/modules/word/query/style-resolve.d.ts +104 -0
  160. package/dist/browser/modules/word/query/style-resolve.js +368 -0
  161. package/dist/browser/modules/word/reader/chart-parser.d.ts +20 -0
  162. package/dist/browser/modules/word/reader/chart-parser.js +810 -0
  163. package/dist/browser/modules/word/reader/comments-parser.d.ts +26 -0
  164. package/dist/browser/modules/word/reader/comments-parser.js +92 -0
  165. package/dist/browser/modules/word/reader/doc-props-parsers.d.ts +15 -0
  166. package/dist/browser/modules/word/reader/doc-props-parsers.js +190 -0
  167. package/dist/browser/modules/word/reader/docx-reader.d.ts +27 -0
  168. package/dist/browser/modules/word/reader/docx-reader.js +2557 -0
  169. package/dist/browser/modules/word/reader/drawing-helpers.d.ts +27 -0
  170. package/dist/browser/modules/word/reader/drawing-helpers.js +84 -0
  171. package/dist/browser/modules/word/reader/form-field-parser.d.ts +21 -0
  172. package/dist/browser/modules/word/reader/form-field-parser.js +82 -0
  173. package/dist/browser/modules/word/reader/image-parsers.d.ts +11 -0
  174. package/dist/browser/modules/word/reader/image-parsers.js +291 -0
  175. package/dist/browser/modules/word/reader/math-parser.d.ts +12 -0
  176. package/dist/browser/modules/word/reader/math-parser.js +422 -0
  177. package/dist/browser/modules/word/reader/metadata-parsers.d.ts +17 -0
  178. package/dist/browser/modules/word/reader/metadata-parsers.js +87 -0
  179. package/dist/browser/modules/word/reader/numbering-parser.d.ts +13 -0
  180. package/dist/browser/modules/word/reader/numbering-parser.js +166 -0
  181. package/dist/browser/modules/word/reader/paragraph-section-parsers.d.ts +12 -0
  182. package/dist/browser/modules/word/reader/paragraph-section-parsers.js +503 -0
  183. package/dist/browser/modules/word/reader/parse-utils.d.ts +91 -0
  184. package/dist/browser/modules/word/reader/parse-utils.js +249 -0
  185. package/dist/browser/modules/word/reader/properties-parsers.d.ts +21 -0
  186. package/dist/browser/modules/word/reader/properties-parsers.js +332 -0
  187. package/dist/browser/modules/word/reader/reader-context.d.ts +69 -0
  188. package/dist/browser/modules/word/reader/reader-context.js +61 -0
  189. package/dist/browser/modules/word/reader/sdt-helpers.d.ts +29 -0
  190. package/dist/browser/modules/word/reader/sdt-helpers.js +111 -0
  191. package/dist/browser/modules/word/reader/settings-parser.d.ts +8 -0
  192. package/dist/browser/modules/word/reader/settings-parser.js +263 -0
  193. package/dist/browser/modules/word/reader/styles-parser.d.ts +12 -0
  194. package/dist/browser/modules/word/reader/styles-parser.js +147 -0
  195. package/dist/browser/modules/word/reader/table-properties-parsers.d.ts +12 -0
  196. package/dist/browser/modules/word/reader/table-properties-parsers.js +234 -0
  197. package/dist/browser/modules/word/reader/theme-parser.d.ts +8 -0
  198. package/dist/browser/modules/word/reader/theme-parser.js +167 -0
  199. package/dist/browser/modules/word/reader/watermark-parser.d.ts +15 -0
  200. package/dist/browser/modules/word/reader/watermark-parser.js +110 -0
  201. package/dist/browser/modules/word/security/cfb-reader.d.ts +37 -0
  202. package/dist/browser/modules/word/security/cfb-reader.js +410 -0
  203. package/dist/browser/modules/word/{digital-signatures.d.ts → security/digital-signatures.d.ts} +19 -11
  204. package/dist/browser/modules/word/{digital-signatures.js → security/digital-signatures.js} +34 -34
  205. package/dist/browser/modules/word/security/document-protection.d.ts +93 -0
  206. package/dist/browser/modules/word/security/document-protection.js +201 -0
  207. package/dist/{types/modules/word → browser/modules/word/security}/encryption.d.ts +51 -4
  208. package/dist/browser/modules/word/security/encryption.js +602 -0
  209. package/dist/browser/modules/word/security/policy.d.ts +80 -0
  210. package/dist/browser/modules/word/security/policy.js +102 -0
  211. package/dist/browser/modules/word/template/template-chart.d.ts +56 -0
  212. package/dist/browser/modules/word/template/template-chart.js +167 -0
  213. package/dist/browser/modules/word/template/template-datasource.d.ts +154 -0
  214. package/dist/browser/modules/word/template/template-datasource.js +541 -0
  215. package/dist/browser/modules/word/template/template-engine.d.ts +121 -0
  216. package/dist/browser/modules/word/template/template-engine.js +1435 -0
  217. package/dist/browser/modules/word/types.d.ts +224 -25
  218. package/dist/browser/modules/word/units.d.ts +26 -0
  219. package/dist/browser/modules/word/units.js +43 -14
  220. package/dist/browser/modules/word/{writers → writer}/chart-writer.js +164 -23
  221. package/dist/browser/modules/word/writer/checkbox-writer.d.ts +17 -0
  222. package/dist/browser/modules/word/writer/checkbox-writer.js +79 -0
  223. package/dist/{types/modules/word/writers → browser/modules/word/writer}/comment-writer.d.ts +2 -1
  224. package/dist/browser/modules/word/{writers → writer}/comment-writer.js +8 -6
  225. package/dist/browser/modules/word/writer/common-parts.d.ts +57 -0
  226. package/dist/browser/modules/word/writer/common-parts.js +101 -0
  227. package/dist/{types/modules/word → browser/modules/word/writer}/content-types.d.ts +2 -2
  228. package/dist/{esm/modules/word → browser/modules/word/writer}/content-types.js +14 -6
  229. package/dist/browser/modules/word/writer/document-writer.d.ts +24 -0
  230. package/dist/browser/modules/word/writer/document-writer.js +473 -0
  231. package/dist/browser/modules/word/writer/docx-packager.d.ts +35 -0
  232. package/dist/browser/modules/word/writer/docx-packager.js +1515 -0
  233. package/dist/{types/modules/word/writers → browser/modules/word/writer}/footnote-writer.d.ts +3 -2
  234. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/footnote-writer.js +13 -10
  235. package/dist/{types/modules/word/writers → browser/modules/word/writer}/header-footer-writer.d.ts +3 -2
  236. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/header-footer-writer.js +39 -21
  237. package/dist/{types/modules/word/writers → browser/modules/word/writer}/image-writer.d.ts +1 -1
  238. package/dist/browser/modules/word/{writers → writer}/image-writer.js +11 -7
  239. package/dist/browser/modules/word/writer/math-writer.d.ts +20 -0
  240. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/math-writer.js +21 -1
  241. package/dist/browser/modules/word/{writers → writer}/numbering-writer.d.ts +1 -1
  242. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/numbering-writer.js +11 -4
  243. package/dist/browser/modules/word/{writers → writer}/paragraph-writer.d.ts +2 -1
  244. package/dist/browser/modules/word/{writers → writer}/paragraph-writer.js +73 -38
  245. package/dist/browser/modules/word/{writers → writer}/parts-writer.d.ts +3 -3
  246. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/parts-writer.js +91 -12
  247. package/dist/browser/modules/word/writer/reference-scanners.d.ts +42 -0
  248. package/dist/browser/modules/word/writer/reference-scanners.js +111 -0
  249. package/dist/browser/modules/word/writer/relationships.d.ts +52 -0
  250. package/dist/browser/modules/word/writer/relationships.js +117 -0
  251. package/dist/browser/modules/word/writer/render-context.d.ts +124 -0
  252. package/dist/browser/modules/word/writer/render-context.js +46 -0
  253. package/dist/browser/modules/word/{writers → writer}/run-writer.d.ts +10 -1
  254. package/dist/{esm/modules/word/writers → browser/modules/word/writer}/run-writer.js +126 -24
  255. package/dist/browser/modules/word/writer/sdt-writer.d.ts +25 -0
  256. package/dist/browser/modules/word/writer/sdt-writer.js +189 -0
  257. package/dist/browser/modules/word/writer/stream-buf.d.ts +37 -0
  258. package/dist/browser/modules/word/writer/stream-buf.js +73 -0
  259. package/dist/browser/modules/word/writer/streaming-writer.d.ts +344 -0
  260. package/dist/browser/modules/word/writer/streaming-writer.js +1382 -0
  261. package/dist/browser/modules/word/writer/string-buf.d.ts +8 -0
  262. package/dist/browser/modules/word/writer/string-buf.js +7 -0
  263. package/dist/browser/modules/word/{writers → writer}/styles-writer.js +32 -1
  264. package/dist/browser/modules/word/{writers → writer}/table-writer.d.ts +2 -1
  265. package/dist/browser/modules/word/{writers → writer}/table-writer.js +94 -11
  266. package/dist/browser/modules/xml/types.d.ts +22 -0
  267. package/dist/browser/utils/crypto.browser.d.ts +3 -1
  268. package/dist/browser/utils/crypto.browser.js +3 -1
  269. package/dist/browser/utils/crypto.d.ts +4 -1
  270. package/dist/browser/utils/crypto.js +4 -1
  271. package/dist/browser/utils/font-metrics.d.ts +63 -0
  272. package/dist/browser/utils/font-metrics.js +293 -0
  273. package/dist/browser/utils/string-buf.d.ts +42 -0
  274. package/dist/browser/utils/string-buf.js +89 -0
  275. package/dist/browser/utils/theme-colors.d.ts +55 -0
  276. package/dist/browser/utils/theme-colors.js +120 -0
  277. package/dist/cjs/modules/archive/compression/streaming-compress.browser.js +29 -0
  278. package/dist/cjs/modules/archive/compression/streaming-compress.js +9 -0
  279. package/dist/cjs/modules/archive/compression/worker-pool/pool.browser.js +26 -1
  280. package/dist/cjs/modules/archive/fs/archive-file.js +78 -16
  281. package/dist/cjs/modules/archive/unzip/stream.browser.js +43 -2
  282. package/dist/cjs/modules/excel/chart/chart-ex-builder.js +7 -2
  283. package/dist/cjs/modules/excel/chart/chart-ex-renderer.js +4 -9
  284. package/dist/cjs/modules/excel/chart/chart.js +1 -7
  285. package/dist/cjs/modules/excel/stream/workbook-reader.browser.js +25 -1
  286. package/dist/cjs/modules/excel/stream/workbook-reader.js +9 -0
  287. package/dist/cjs/modules/excel/stream/workbook-writer.browser.js +228 -13
  288. package/dist/cjs/modules/excel/utils/string-buf.js +5 -81
  289. package/dist/cjs/modules/excel/workbook.browser.js +135 -25
  290. package/dist/cjs/modules/excel/xlsx/xform/chart/chart-space-xform.js +6 -20
  291. package/dist/cjs/modules/excel/xlsx/xlsx.browser.js +32 -8
  292. package/dist/cjs/modules/excel/xlsx/xlsx.js +9 -1
  293. package/dist/cjs/modules/pdf/excel-bridge.js +33 -0
  294. package/dist/cjs/modules/pdf/font/metrics.js +11 -244
  295. package/dist/cjs/modules/pdf/index.js +2 -1
  296. package/dist/cjs/modules/pdf/render-layout-to-pdf.js +651 -0
  297. package/dist/cjs/modules/pdf/word-bridge.js +155 -274
  298. package/dist/cjs/modules/stream/index.base.js +4 -2
  299. package/dist/cjs/modules/stream/internal/sink-adapter.js +202 -0
  300. package/dist/cjs/modules/stream/pull-stream.js +51 -5
  301. package/dist/cjs/modules/word/advanced/diff.js +170 -0
  302. package/dist/cjs/modules/word/advanced/drawing-shapes.js +279 -0
  303. package/dist/cjs/modules/word/advanced/field-engine.js +1229 -0
  304. package/dist/cjs/modules/word/advanced/glossary.js +87 -0
  305. package/dist/cjs/modules/word/advanced/math-convert.js +599 -0
  306. package/dist/cjs/modules/word/advanced/ole-objects.js +277 -0
  307. package/dist/cjs/modules/word/advanced/style-map.js +329 -0
  308. package/dist/cjs/modules/word/advanced/validation.js +1068 -0
  309. package/dist/cjs/modules/word/advanced/vba-project.js +274 -0
  310. package/dist/cjs/modules/word/bridge/excel-bridge.js +1020 -0
  311. package/dist/cjs/modules/word/builder/document-handle.js +667 -0
  312. package/dist/cjs/modules/word/builder/paragraph-builders.js +109 -0
  313. package/dist/cjs/modules/word/builder/run-builders.js +676 -0
  314. package/dist/cjs/modules/word/builder/table-builders.js +53 -0
  315. package/dist/cjs/modules/word/constants.js +111 -2
  316. package/dist/cjs/modules/word/convert/conversion-ir.js +34 -0
  317. package/dist/cjs/modules/word/convert/docx-to-semantic.js +502 -0
  318. package/dist/cjs/modules/word/convert/flat-opc.js +390 -0
  319. package/dist/cjs/modules/word/convert/html/html-import.js +1910 -0
  320. package/dist/cjs/modules/word/{html-renderer.js → convert/html/html-renderer.js} +420 -69
  321. package/dist/cjs/modules/word/convert/html/html.js +20 -0
  322. package/dist/cjs/modules/word/convert/markdown/markdown-import.js +1329 -0
  323. package/dist/cjs/modules/word/convert/markdown/markdown-renderer.js +637 -0
  324. package/dist/cjs/modules/word/convert/markdown/markdown.js +21 -0
  325. package/dist/cjs/modules/word/convert/odt/odt.js +1936 -0
  326. package/dist/cjs/modules/word/core/color-utils.js +47 -0
  327. package/dist/cjs/modules/word/core/internal-utils.js +219 -0
  328. package/dist/cjs/modules/word/core/mapper.js +430 -0
  329. package/dist/cjs/modules/word/core/opc-paths.js +53 -0
  330. package/dist/cjs/modules/word/core/text-utils.js +210 -0
  331. package/dist/cjs/modules/word/core/walker.js +577 -0
  332. package/dist/cjs/modules/word/crypto.js +19 -8
  333. package/dist/cjs/modules/word/document-io.js +117 -197
  334. package/dist/cjs/modules/word/errors.js +59 -13
  335. package/dist/cjs/modules/word/excel.js +22 -0
  336. package/dist/cjs/modules/word/font/font-embed.js +652 -0
  337. package/dist/cjs/modules/word/{font-obfuscation.js → font/font-obfuscation.js} +4 -9
  338. package/dist/cjs/modules/word/font/hyphenation.js +4216 -0
  339. package/dist/cjs/modules/word/font/text-shaping.js +640 -0
  340. package/dist/cjs/modules/word/html.js +9 -7
  341. package/dist/cjs/modules/word/incremental-edit.js +366 -0
  342. package/dist/cjs/modules/word/index.base.js +370 -137
  343. package/dist/cjs/modules/word/layout/layout-constants.js +20 -0
  344. package/dist/cjs/modules/word/layout/layout-full.js +1699 -0
  345. package/dist/cjs/modules/word/layout/layout-model.js +17 -0
  346. package/dist/cjs/modules/word/layout/layout.js +1170 -0
  347. package/dist/cjs/modules/word/layout/render-page.js +1243 -0
  348. package/dist/cjs/modules/word/markdown.js +19 -0
  349. package/dist/cjs/modules/word/patcher.js +539 -0
  350. package/dist/cjs/modules/word/query/compat.js +61 -0
  351. package/dist/cjs/modules/word/query/data-binding.js +395 -0
  352. package/dist/cjs/modules/word/query/form-fields.js +272 -0
  353. package/dist/cjs/modules/word/query/format-search.js +334 -0
  354. package/dist/cjs/modules/word/query/mail-merge.js +114 -0
  355. package/dist/cjs/modules/word/query/merge.js +620 -0
  356. package/dist/cjs/modules/word/query/replace.js +304 -0
  357. package/dist/cjs/modules/word/query/revisions.js +885 -0
  358. package/dist/cjs/modules/word/query/search.js +361 -0
  359. package/dist/cjs/modules/word/query/split.js +138 -0
  360. package/dist/cjs/modules/word/query/style-resolve.js +374 -0
  361. package/dist/cjs/modules/word/reader/chart-parser.js +814 -0
  362. package/dist/cjs/modules/word/reader/comments-parser.js +96 -0
  363. package/dist/cjs/modules/word/reader/doc-props-parsers.js +194 -0
  364. package/dist/cjs/modules/word/reader/docx-reader.js +2560 -0
  365. package/dist/cjs/modules/word/reader/drawing-helpers.js +90 -0
  366. package/dist/cjs/modules/word/reader/form-field-parser.js +85 -0
  367. package/dist/cjs/modules/word/reader/image-parsers.js +293 -0
  368. package/dist/cjs/modules/word/reader/math-parser.js +424 -0
  369. package/dist/cjs/modules/word/reader/metadata-parsers.js +93 -0
  370. package/dist/cjs/modules/word/reader/numbering-parser.js +168 -0
  371. package/dist/cjs/modules/word/reader/paragraph-section-parsers.js +505 -0
  372. package/dist/cjs/modules/word/reader/parse-utils.js +271 -0
  373. package/dist/cjs/modules/word/reader/properties-parsers.js +338 -0
  374. package/dist/cjs/modules/word/reader/reader-context.js +66 -0
  375. package/dist/cjs/modules/word/reader/sdt-helpers.js +114 -0
  376. package/dist/cjs/modules/word/reader/settings-parser.js +265 -0
  377. package/dist/cjs/modules/word/reader/styles-parser.js +149 -0
  378. package/dist/cjs/modules/word/reader/table-properties-parsers.js +237 -0
  379. package/dist/cjs/modules/word/reader/theme-parser.js +169 -0
  380. package/dist/cjs/modules/word/reader/watermark-parser.js +113 -0
  381. package/dist/cjs/modules/word/security/cfb-reader.js +414 -0
  382. package/dist/cjs/modules/word/{digital-signatures.js → security/digital-signatures.js} +34 -34
  383. package/dist/cjs/modules/word/security/document-protection.js +208 -0
  384. package/dist/cjs/modules/word/security/encryption.js +612 -0
  385. package/dist/cjs/modules/word/security/policy.js +106 -0
  386. package/dist/cjs/modules/word/template/template-chart.js +170 -0
  387. package/dist/cjs/modules/word/template/template-datasource.js +549 -0
  388. package/dist/cjs/modules/word/template/template-engine.js +1430 -0
  389. package/dist/cjs/modules/word/units.js +44 -14
  390. package/dist/cjs/modules/word/{writers → writer}/chart-writer.js +163 -22
  391. package/dist/cjs/modules/word/writer/checkbox-writer.js +82 -0
  392. package/dist/cjs/modules/word/{writers → writer}/comment-writer.js +8 -6
  393. package/dist/cjs/modules/word/writer/common-parts.js +104 -0
  394. package/dist/cjs/modules/word/{content-types.js → writer/content-types.js} +14 -6
  395. package/dist/cjs/modules/word/writer/document-writer.js +478 -0
  396. package/dist/cjs/modules/word/writer/docx-packager.js +1551 -0
  397. package/dist/cjs/modules/word/{writers → writer}/footnote-writer.js +13 -10
  398. package/dist/cjs/modules/word/{writers → writer}/header-footer-writer.js +38 -20
  399. package/dist/cjs/modules/word/{writers → writer}/image-writer.js +11 -7
  400. package/dist/cjs/modules/word/{writers → writer}/math-writer.js +21 -1
  401. package/dist/cjs/modules/word/{writers → writer}/numbering-writer.js +11 -4
  402. package/dist/cjs/modules/word/{writers → writer}/paragraph-writer.js +72 -37
  403. package/dist/cjs/modules/word/{writers → writer}/parts-writer.js +91 -12
  404. package/dist/cjs/modules/word/writer/reference-scanners.js +120 -0
  405. package/dist/cjs/modules/word/writer/relationships.js +124 -0
  406. package/dist/cjs/modules/word/writer/render-context.js +51 -0
  407. package/dist/cjs/modules/word/{writers → writer}/run-writer.js +127 -24
  408. package/dist/cjs/modules/word/writer/sdt-writer.js +192 -0
  409. package/dist/cjs/modules/word/writer/stream-buf.js +76 -0
  410. package/dist/cjs/modules/word/writer/streaming-writer.js +1387 -0
  411. package/dist/cjs/modules/word/writer/string-buf.js +11 -0
  412. package/dist/cjs/modules/word/{writers → writer}/styles-writer.js +32 -1
  413. package/dist/cjs/modules/word/{writers → writer}/table-writer.js +94 -11
  414. package/dist/cjs/utils/crypto.browser.js +3 -1
  415. package/dist/cjs/utils/crypto.js +4 -1
  416. package/dist/cjs/utils/font-metrics.js +303 -0
  417. package/dist/cjs/utils/string-buf.js +92 -0
  418. package/dist/cjs/utils/theme-colors.js +126 -0
  419. package/dist/esm/modules/archive/compression/streaming-compress.browser.js +29 -0
  420. package/dist/esm/modules/archive/compression/streaming-compress.js +9 -0
  421. package/dist/esm/modules/archive/compression/worker-pool/pool.browser.js +26 -1
  422. package/dist/esm/modules/archive/fs/archive-file.js +78 -16
  423. package/dist/esm/modules/archive/unzip/stream.browser.js +43 -2
  424. package/dist/esm/modules/excel/chart/chart-ex-builder.js +7 -2
  425. package/dist/esm/modules/excel/chart/chart-ex-renderer.js +4 -9
  426. package/dist/esm/modules/excel/chart/chart.js +1 -7
  427. package/dist/esm/modules/excel/stream/workbook-reader.browser.js +25 -1
  428. package/dist/esm/modules/excel/stream/workbook-reader.js +9 -0
  429. package/dist/esm/modules/excel/stream/workbook-writer.browser.js +228 -13
  430. package/dist/esm/modules/excel/utils/string-buf.js +4 -81
  431. package/dist/esm/modules/excel/workbook.browser.js +135 -25
  432. package/dist/esm/modules/excel/xlsx/xform/chart/chart-space-xform.js +6 -20
  433. package/dist/esm/modules/excel/xlsx/xlsx.browser.js +32 -8
  434. package/dist/esm/modules/excel/xlsx/xlsx.js +9 -1
  435. package/dist/esm/modules/pdf/excel-bridge.js +32 -0
  436. package/dist/esm/modules/pdf/font/metrics.js +3 -237
  437. package/dist/esm/modules/pdf/index.js +1 -1
  438. package/dist/esm/modules/pdf/render-layout-to-pdf.js +647 -0
  439. package/dist/esm/modules/pdf/word-bridge.js +122 -274
  440. package/dist/esm/modules/stream/index.base.js +2 -1
  441. package/dist/esm/modules/stream/internal/sink-adapter.js +198 -0
  442. package/dist/esm/modules/stream/pull-stream.js +51 -5
  443. package/dist/esm/modules/word/advanced/diff.js +167 -0
  444. package/dist/esm/modules/word/advanced/drawing-shapes.js +268 -0
  445. package/dist/esm/modules/word/advanced/field-engine.js +1225 -0
  446. package/dist/esm/modules/word/advanced/glossary.js +79 -0
  447. package/dist/esm/modules/word/advanced/math-convert.js +595 -0
  448. package/dist/esm/modules/word/advanced/ole-objects.js +271 -0
  449. package/dist/esm/modules/word/advanced/style-map.js +322 -0
  450. package/dist/esm/modules/word/advanced/validation.js +1065 -0
  451. package/dist/esm/modules/word/advanced/vba-project.js +265 -0
  452. package/dist/esm/modules/word/bridge/excel-bridge.js +980 -0
  453. package/dist/esm/modules/word/builder/document-handle.js +664 -0
  454. package/dist/esm/modules/word/builder/paragraph-builders.js +90 -0
  455. package/dist/esm/modules/word/builder/run-builders.js +600 -0
  456. package/dist/esm/modules/word/builder/table-builders.js +45 -0
  457. package/dist/esm/modules/word/constants.js +109 -1
  458. package/dist/esm/modules/word/convert/conversion-ir.js +31 -0
  459. package/dist/esm/modules/word/convert/docx-to-semantic.js +499 -0
  460. package/dist/esm/modules/word/convert/flat-opc.js +385 -0
  461. package/dist/esm/modules/word/convert/html/html-import.js +1907 -0
  462. package/dist/{browser/modules/word → esm/modules/word/convert/html}/html-renderer.js +420 -69
  463. package/dist/esm/modules/word/convert/html/html.js +15 -0
  464. package/dist/esm/modules/word/convert/markdown/markdown-import.js +1325 -0
  465. package/dist/esm/modules/word/convert/markdown/markdown-renderer.js +634 -0
  466. package/dist/esm/modules/word/convert/markdown/markdown.js +15 -0
  467. package/dist/esm/modules/word/convert/odt/odt.js +1932 -0
  468. package/dist/esm/modules/word/core/color-utils.js +43 -0
  469. package/dist/esm/modules/word/core/internal-utils.js +209 -0
  470. package/dist/esm/modules/word/core/mapper.js +427 -0
  471. package/dist/esm/modules/word/core/opc-paths.js +48 -0
  472. package/dist/esm/modules/word/core/text-utils.js +202 -0
  473. package/dist/esm/modules/word/core/walker.js +570 -0
  474. package/dist/esm/modules/word/crypto.js +13 -7
  475. package/dist/esm/modules/word/document-io.js +80 -197
  476. package/dist/esm/modules/word/errors.js +54 -2
  477. package/dist/esm/modules/word/excel.js +13 -0
  478. package/dist/esm/modules/word/font/font-embed.js +646 -0
  479. package/dist/{browser/modules/word → esm/modules/word/font}/font-obfuscation.js +4 -9
  480. package/dist/esm/modules/word/font/hyphenation.js +4210 -0
  481. package/dist/esm/modules/word/font/text-shaping.js +635 -0
  482. package/dist/esm/modules/word/html.js +6 -5
  483. package/dist/esm/modules/word/incremental-edit.js +361 -0
  484. package/dist/esm/modules/word/index.base.js +138 -29
  485. package/dist/esm/modules/word/layout/layout-constants.js +17 -0
  486. package/dist/esm/modules/word/layout/layout-full.js +1696 -0
  487. package/dist/esm/modules/word/layout/layout-model.js +16 -0
  488. package/dist/esm/modules/word/layout/layout.js +1167 -0
  489. package/dist/esm/modules/word/layout/render-page.js +1238 -0
  490. package/dist/esm/modules/word/markdown.js +13 -0
  491. package/dist/esm/modules/word/patcher.js +537 -0
  492. package/dist/esm/modules/word/query/compat.js +58 -0
  493. package/dist/esm/modules/word/query/data-binding.js +392 -0
  494. package/dist/esm/modules/word/query/form-fields.js +268 -0
  495. package/dist/esm/modules/word/query/format-search.js +329 -0
  496. package/dist/esm/modules/word/query/mail-merge.js +111 -0
  497. package/dist/esm/modules/word/query/merge.js +617 -0
  498. package/dist/esm/modules/word/query/replace.js +301 -0
  499. package/dist/esm/modules/word/query/revisions.js +879 -0
  500. package/dist/esm/modules/word/query/search.js +346 -0
  501. package/dist/esm/modules/word/query/split.js +135 -0
  502. package/dist/esm/modules/word/query/style-resolve.js +368 -0
  503. package/dist/esm/modules/word/reader/chart-parser.js +810 -0
  504. package/dist/esm/modules/word/reader/comments-parser.js +92 -0
  505. package/dist/esm/modules/word/reader/doc-props-parsers.js +190 -0
  506. package/dist/esm/modules/word/reader/docx-reader.js +2557 -0
  507. package/dist/esm/modules/word/reader/drawing-helpers.js +84 -0
  508. package/dist/esm/modules/word/reader/form-field-parser.js +82 -0
  509. package/dist/esm/modules/word/reader/image-parsers.js +291 -0
  510. package/dist/esm/modules/word/reader/math-parser.js +422 -0
  511. package/dist/esm/modules/word/reader/metadata-parsers.js +87 -0
  512. package/dist/esm/modules/word/reader/numbering-parser.js +166 -0
  513. package/dist/esm/modules/word/reader/paragraph-section-parsers.js +503 -0
  514. package/dist/esm/modules/word/reader/parse-utils.js +249 -0
  515. package/dist/esm/modules/word/reader/properties-parsers.js +332 -0
  516. package/dist/esm/modules/word/reader/reader-context.js +61 -0
  517. package/dist/esm/modules/word/reader/sdt-helpers.js +111 -0
  518. package/dist/esm/modules/word/reader/settings-parser.js +263 -0
  519. package/dist/esm/modules/word/reader/styles-parser.js +147 -0
  520. package/dist/esm/modules/word/reader/table-properties-parsers.js +234 -0
  521. package/dist/esm/modules/word/reader/theme-parser.js +167 -0
  522. package/dist/esm/modules/word/reader/watermark-parser.js +110 -0
  523. package/dist/esm/modules/word/security/cfb-reader.js +410 -0
  524. package/dist/esm/modules/word/{digital-signatures.js → security/digital-signatures.js} +34 -34
  525. package/dist/esm/modules/word/security/document-protection.js +201 -0
  526. package/dist/esm/modules/word/security/encryption.js +602 -0
  527. package/dist/esm/modules/word/security/policy.js +102 -0
  528. package/dist/esm/modules/word/template/template-chart.js +167 -0
  529. package/dist/esm/modules/word/template/template-datasource.js +541 -0
  530. package/dist/esm/modules/word/template/template-engine.js +1435 -0
  531. package/dist/esm/modules/word/units.js +43 -14
  532. package/dist/esm/modules/word/{writers → writer}/chart-writer.js +164 -23
  533. package/dist/esm/modules/word/writer/checkbox-writer.js +79 -0
  534. package/dist/esm/modules/word/{writers → writer}/comment-writer.js +8 -6
  535. package/dist/esm/modules/word/writer/common-parts.js +101 -0
  536. package/dist/{browser/modules/word → esm/modules/word/writer}/content-types.js +14 -6
  537. package/dist/esm/modules/word/writer/document-writer.js +473 -0
  538. package/dist/esm/modules/word/writer/docx-packager.js +1515 -0
  539. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/footnote-writer.js +13 -10
  540. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/header-footer-writer.js +39 -21
  541. package/dist/esm/modules/word/{writers → writer}/image-writer.js +11 -7
  542. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/math-writer.js +21 -1
  543. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/numbering-writer.js +11 -4
  544. package/dist/esm/modules/word/{writers → writer}/paragraph-writer.js +73 -38
  545. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/parts-writer.js +91 -12
  546. package/dist/esm/modules/word/writer/reference-scanners.js +111 -0
  547. package/dist/esm/modules/word/writer/relationships.js +117 -0
  548. package/dist/esm/modules/word/writer/render-context.js +46 -0
  549. package/dist/{browser/modules/word/writers → esm/modules/word/writer}/run-writer.js +126 -24
  550. package/dist/esm/modules/word/writer/sdt-writer.js +189 -0
  551. package/dist/esm/modules/word/writer/stream-buf.js +73 -0
  552. package/dist/esm/modules/word/writer/streaming-writer.js +1382 -0
  553. package/dist/esm/modules/word/writer/string-buf.js +7 -0
  554. package/dist/esm/modules/word/{writers → writer}/styles-writer.js +32 -1
  555. package/dist/esm/modules/word/{writers → writer}/table-writer.js +94 -11
  556. package/dist/esm/utils/crypto.browser.js +3 -1
  557. package/dist/esm/utils/crypto.js +4 -1
  558. package/dist/esm/utils/font-metrics.js +293 -0
  559. package/dist/esm/utils/string-buf.js +89 -0
  560. package/dist/esm/utils/theme-colors.js +120 -0
  561. package/dist/iife/excelts.iife.js +70692 -70337
  562. package/dist/iife/excelts.iife.js.map +1 -1
  563. package/dist/iife/excelts.iife.min.js +57 -57
  564. package/dist/types/modules/archive/fs/archive-file.d.ts +8 -5
  565. package/dist/types/modules/excel/chart/chart-ex-types.d.ts +0 -12
  566. package/dist/types/modules/excel/chart/chart.d.ts +1 -5
  567. package/dist/types/modules/excel/chart/types.d.ts +0 -6
  568. package/dist/types/modules/excel/stream/workbook-writer.browser.d.ts +40 -0
  569. package/dist/types/modules/excel/utils/string-buf.d.ts +5 -26
  570. package/dist/types/modules/excel/xlsx/xlsx.browser.d.ts +19 -9
  571. package/dist/types/modules/excel/xlsx/xlsx.d.ts +10 -2
  572. package/dist/types/modules/pdf/excel-bridge.d.ts +30 -1
  573. package/dist/types/modules/pdf/font/metrics.d.ts +3 -52
  574. package/dist/types/modules/pdf/index.d.ts +1 -1
  575. package/dist/types/modules/pdf/render-layout-to-pdf.d.ts +66 -0
  576. package/dist/types/modules/pdf/word-bridge.d.ts +80 -12
  577. package/dist/types/modules/stream/index.base.d.ts +2 -0
  578. package/dist/types/modules/stream/internal/sink-adapter.d.ts +65 -0
  579. package/dist/types/modules/stream/pull-stream.d.ts +19 -2
  580. package/dist/types/modules/stream/types.d.ts +13 -1
  581. package/dist/types/modules/word/advanced/diff.d.ts +61 -0
  582. package/dist/types/modules/word/advanced/drawing-shapes.d.ts +269 -0
  583. package/dist/types/modules/word/advanced/field-engine.d.ts +43 -0
  584. package/dist/types/modules/word/advanced/glossary.d.ts +86 -0
  585. package/dist/types/modules/word/advanced/math-convert.d.ts +30 -0
  586. package/dist/types/modules/word/advanced/ole-objects.d.ts +115 -0
  587. package/dist/types/modules/word/advanced/style-map.d.ts +105 -0
  588. package/dist/types/modules/word/advanced/validation.d.ts +56 -0
  589. package/dist/types/modules/word/advanced/vba-project.d.ts +91 -0
  590. package/dist/types/modules/word/bridge/excel-bridge.d.ts +127 -0
  591. package/dist/types/modules/word/builder/document-handle.d.ts +151 -0
  592. package/dist/types/modules/word/builder/paragraph-builders.d.ts +61 -0
  593. package/dist/types/modules/word/builder/run-builders.d.ts +374 -0
  594. package/dist/types/modules/word/builder/table-builders.d.ts +23 -0
  595. package/dist/types/modules/word/constants.d.ts +39 -1
  596. package/dist/types/modules/word/convert/conversion-ir.d.ts +210 -0
  597. package/dist/types/modules/word/convert/docx-to-semantic.d.ts +39 -0
  598. package/dist/types/modules/word/convert/flat-opc.d.ts +44 -0
  599. package/dist/types/modules/word/convert/html/html-import.d.ts +50 -0
  600. package/dist/{browser/modules/word → types/modules/word/convert/html}/html-renderer.d.ts +14 -1
  601. package/dist/types/modules/word/convert/html/html.d.ts +15 -0
  602. package/dist/types/modules/word/convert/markdown/markdown-import.d.ts +68 -0
  603. package/dist/types/modules/word/convert/markdown/markdown-renderer.d.ts +25 -0
  604. package/dist/types/modules/word/convert/markdown/markdown.d.ts +15 -0
  605. package/dist/types/modules/word/convert/odt/odt.d.ts +41 -0
  606. package/dist/types/modules/word/{color-utils.d.ts → core/color-utils.d.ts} +8 -1
  607. package/dist/types/modules/word/core/internal-utils.d.ts +90 -0
  608. package/dist/types/modules/word/core/mapper.d.ts +44 -0
  609. package/dist/types/modules/word/core/opc-paths.d.ts +33 -0
  610. package/dist/types/modules/word/core/text-utils.d.ts +38 -0
  611. package/dist/types/modules/word/core/walker.d.ts +119 -0
  612. package/dist/types/modules/word/crypto.d.ts +14 -9
  613. package/dist/types/modules/word/document-io.d.ts +59 -27
  614. package/dist/types/modules/word/errors.d.ts +44 -1
  615. package/dist/types/modules/word/excel.d.ts +14 -0
  616. package/dist/types/modules/word/font/font-embed.d.ts +112 -0
  617. package/dist/types/modules/word/font/hyphenation.d.ts +65 -0
  618. package/dist/types/modules/word/font/text-shaping.d.ts +58 -0
  619. package/dist/types/modules/word/html.d.ts +7 -6
  620. package/dist/types/modules/word/incremental-edit.d.ts +123 -0
  621. package/dist/types/modules/word/index.base.d.ts +194 -10
  622. package/dist/types/modules/word/layout/layout-constants.d.ts +17 -0
  623. package/dist/types/modules/word/layout/layout-full.d.ts +53 -0
  624. package/dist/types/modules/word/layout/layout-model.d.ts +344 -0
  625. package/dist/types/modules/word/layout/layout.d.ts +63 -0
  626. package/dist/types/modules/word/layout/render-page.d.ts +57 -0
  627. package/dist/types/modules/word/markdown.d.ts +14 -0
  628. package/dist/types/modules/word/patcher.d.ts +62 -0
  629. package/dist/types/modules/word/query/compat.d.ts +25 -0
  630. package/dist/types/modules/word/query/data-binding.d.ts +22 -0
  631. package/dist/types/modules/word/query/form-fields.d.ts +41 -0
  632. package/dist/types/modules/word/query/format-search.d.ts +99 -0
  633. package/dist/types/modules/word/query/mail-merge.d.ts +25 -0
  634. package/dist/types/modules/word/query/merge.d.ts +50 -0
  635. package/dist/types/modules/word/query/replace.d.ts +47 -0
  636. package/dist/types/modules/word/query/revisions.d.ts +67 -0
  637. package/dist/types/modules/word/query/search.d.ts +129 -0
  638. package/dist/types/modules/word/query/split.d.ts +44 -0
  639. package/dist/types/modules/word/query/style-resolve.d.ts +104 -0
  640. package/dist/types/modules/word/reader/chart-parser.d.ts +20 -0
  641. package/dist/types/modules/word/reader/comments-parser.d.ts +26 -0
  642. package/dist/types/modules/word/reader/doc-props-parsers.d.ts +15 -0
  643. package/dist/types/modules/word/reader/docx-reader.d.ts +27 -0
  644. package/dist/types/modules/word/reader/drawing-helpers.d.ts +27 -0
  645. package/dist/types/modules/word/reader/form-field-parser.d.ts +21 -0
  646. package/dist/types/modules/word/reader/image-parsers.d.ts +11 -0
  647. package/dist/types/modules/word/reader/math-parser.d.ts +12 -0
  648. package/dist/types/modules/word/reader/metadata-parsers.d.ts +17 -0
  649. package/dist/types/modules/word/reader/numbering-parser.d.ts +13 -0
  650. package/dist/types/modules/word/reader/paragraph-section-parsers.d.ts +12 -0
  651. package/dist/types/modules/word/reader/parse-utils.d.ts +91 -0
  652. package/dist/types/modules/word/reader/properties-parsers.d.ts +21 -0
  653. package/dist/types/modules/word/reader/reader-context.d.ts +69 -0
  654. package/dist/types/modules/word/reader/sdt-helpers.d.ts +29 -0
  655. package/dist/types/modules/word/reader/settings-parser.d.ts +8 -0
  656. package/dist/types/modules/word/reader/styles-parser.d.ts +12 -0
  657. package/dist/types/modules/word/reader/table-properties-parsers.d.ts +12 -0
  658. package/dist/types/modules/word/reader/theme-parser.d.ts +8 -0
  659. package/dist/types/modules/word/reader/watermark-parser.d.ts +15 -0
  660. package/dist/types/modules/word/security/cfb-reader.d.ts +37 -0
  661. package/dist/types/modules/word/{digital-signatures.d.ts → security/digital-signatures.d.ts} +19 -11
  662. package/dist/types/modules/word/security/document-protection.d.ts +93 -0
  663. package/dist/{browser/modules/word → types/modules/word/security}/encryption.d.ts +51 -4
  664. package/dist/types/modules/word/security/policy.d.ts +80 -0
  665. package/dist/types/modules/word/template/template-chart.d.ts +56 -0
  666. package/dist/types/modules/word/template/template-datasource.d.ts +154 -0
  667. package/dist/types/modules/word/template/template-engine.d.ts +121 -0
  668. package/dist/types/modules/word/types.d.ts +224 -25
  669. package/dist/types/modules/word/units.d.ts +26 -0
  670. package/dist/types/modules/word/writer/checkbox-writer.d.ts +17 -0
  671. package/dist/{browser/modules/word/writers → types/modules/word/writer}/comment-writer.d.ts +2 -1
  672. package/dist/types/modules/word/writer/common-parts.d.ts +57 -0
  673. package/dist/{browser/modules/word → types/modules/word/writer}/content-types.d.ts +2 -2
  674. package/dist/types/modules/word/writer/document-writer.d.ts +24 -0
  675. package/dist/types/modules/word/writer/docx-packager.d.ts +35 -0
  676. package/dist/{browser/modules/word/writers → types/modules/word/writer}/footnote-writer.d.ts +3 -2
  677. package/dist/{browser/modules/word/writers → types/modules/word/writer}/header-footer-writer.d.ts +3 -2
  678. package/dist/{browser/modules/word/writers → types/modules/word/writer}/image-writer.d.ts +1 -1
  679. package/dist/types/modules/word/writer/math-writer.d.ts +20 -0
  680. package/dist/types/modules/word/{writers → writer}/numbering-writer.d.ts +1 -1
  681. package/dist/types/modules/word/{writers → writer}/paragraph-writer.d.ts +2 -1
  682. package/dist/types/modules/word/{writers → writer}/parts-writer.d.ts +3 -3
  683. package/dist/types/modules/word/writer/reference-scanners.d.ts +42 -0
  684. package/dist/types/modules/word/writer/relationships.d.ts +52 -0
  685. package/dist/types/modules/word/writer/render-context.d.ts +124 -0
  686. package/dist/types/modules/word/{writers → writer}/run-writer.d.ts +10 -1
  687. package/dist/types/modules/word/writer/sdt-writer.d.ts +25 -0
  688. package/dist/types/modules/word/writer/stream-buf.d.ts +37 -0
  689. package/dist/types/modules/word/writer/streaming-writer.d.ts +344 -0
  690. package/dist/types/modules/word/writer/string-buf.d.ts +8 -0
  691. package/dist/types/modules/word/{writers → writer}/table-writer.d.ts +2 -1
  692. package/dist/types/modules/xml/types.d.ts +22 -0
  693. package/dist/types/utils/crypto.browser.d.ts +3 -1
  694. package/dist/types/utils/crypto.d.ts +4 -1
  695. package/dist/types/utils/font-metrics.d.ts +63 -0
  696. package/dist/types/utils/string-buf.d.ts +42 -0
  697. package/dist/types/utils/theme-colors.d.ts +55 -0
  698. package/package.json +121 -39
  699. package/dist/browser/modules/word/color-utils.js +0 -94
  700. package/dist/browser/modules/word/document.d.ts +0 -657
  701. package/dist/browser/modules/word/document.js +0 -1533
  702. package/dist/browser/modules/word/docx-packager.d.ts +0 -14
  703. package/dist/browser/modules/word/docx-packager.js +0 -822
  704. package/dist/browser/modules/word/docx-reader.d.ts +0 -11
  705. package/dist/browser/modules/word/docx-reader.js +0 -4929
  706. package/dist/browser/modules/word/encryption.js +0 -274
  707. package/dist/browser/modules/word/internal-utils.d.ts +0 -23
  708. package/dist/browser/modules/word/internal-utils.js +0 -54
  709. package/dist/browser/modules/word/namespaces.d.ts +0 -159
  710. package/dist/browser/modules/word/namespaces.js +0 -189
  711. package/dist/browser/modules/word/relationships.d.ts +0 -30
  712. package/dist/browser/modules/word/relationships.js +0 -48
  713. package/dist/browser/modules/word/writers/checkbox-writer.d.ts +0 -9
  714. package/dist/browser/modules/word/writers/checkbox-writer.js +0 -42
  715. package/dist/browser/modules/word/writers/document-writer.d.ts +0 -16
  716. package/dist/browser/modules/word/writers/document-writer.js +0 -461
  717. package/dist/browser/modules/word/writers/math-writer.d.ts +0 -9
  718. package/dist/cjs/modules/word/color-utils.js +0 -97
  719. package/dist/cjs/modules/word/document.js +0 -1645
  720. package/dist/cjs/modules/word/docx-packager.js +0 -825
  721. package/dist/cjs/modules/word/docx-reader.js +0 -4932
  722. package/dist/cjs/modules/word/encryption.js +0 -282
  723. package/dist/cjs/modules/word/internal-utils.js +0 -59
  724. package/dist/cjs/modules/word/namespaces.js +0 -192
  725. package/dist/cjs/modules/word/relationships.js +0 -55
  726. package/dist/cjs/modules/word/writers/checkbox-writer.js +0 -45
  727. package/dist/cjs/modules/word/writers/document-writer.js +0 -465
  728. package/dist/esm/modules/word/color-utils.js +0 -94
  729. package/dist/esm/modules/word/document.js +0 -1533
  730. package/dist/esm/modules/word/docx-packager.js +0 -822
  731. package/dist/esm/modules/word/docx-reader.js +0 -4929
  732. package/dist/esm/modules/word/encryption.js +0 -274
  733. package/dist/esm/modules/word/internal-utils.js +0 -54
  734. package/dist/esm/modules/word/namespaces.js +0 -189
  735. package/dist/esm/modules/word/relationships.js +0 -48
  736. package/dist/esm/modules/word/writers/checkbox-writer.js +0 -42
  737. package/dist/esm/modules/word/writers/document-writer.js +0 -461
  738. package/dist/types/modules/word/document.d.ts +0 -657
  739. package/dist/types/modules/word/docx-packager.d.ts +0 -14
  740. package/dist/types/modules/word/docx-reader.d.ts +0 -11
  741. package/dist/types/modules/word/internal-utils.d.ts +0 -23
  742. package/dist/types/modules/word/namespaces.d.ts +0 -159
  743. package/dist/types/modules/word/relationships.d.ts +0 -30
  744. package/dist/types/modules/word/writers/checkbox-writer.d.ts +0 -9
  745. package/dist/types/modules/word/writers/document-writer.d.ts +0 -16
  746. package/dist/types/modules/word/writers/math-writer.d.ts +0 -9
  747. /package/dist/browser/modules/word/{font-obfuscation.d.ts → font/font-obfuscation.d.ts} +0 -0
  748. /package/dist/browser/modules/word/{writers → writer}/chart-writer.d.ts +0 -0
  749. /package/dist/browser/modules/word/{writers → writer}/section-writer.d.ts +0 -0
  750. /package/dist/browser/modules/word/{writers → writer}/section-writer.js +0 -0
  751. /package/dist/browser/modules/word/{writers → writer}/styles-writer.d.ts +0 -0
  752. /package/dist/browser/modules/word/{writers → writer}/textbox-writer.d.ts +0 -0
  753. /package/dist/browser/modules/word/{writers → writer}/textbox-writer.js +0 -0
  754. /package/dist/browser/modules/word/{writers → writer}/toc-writer.d.ts +0 -0
  755. /package/dist/browser/modules/word/{writers → writer}/toc-writer.js +0 -0
  756. /package/dist/cjs/modules/word/{writers → writer}/section-writer.js +0 -0
  757. /package/dist/cjs/modules/word/{writers → writer}/textbox-writer.js +0 -0
  758. /package/dist/cjs/modules/word/{writers → writer}/toc-writer.js +0 -0
  759. /package/dist/esm/modules/word/{writers → writer}/section-writer.js +0 -0
  760. /package/dist/esm/modules/word/{writers → writer}/textbox-writer.js +0 -0
  761. /package/dist/esm/modules/word/{writers → writer}/toc-writer.js +0 -0
  762. /package/dist/types/modules/word/{font-obfuscation.d.ts → font/font-obfuscation.d.ts} +0 -0
  763. /package/dist/types/modules/word/{writers → writer}/chart-writer.d.ts +0 -0
  764. /package/dist/types/modules/word/{writers → writer}/section-writer.d.ts +0 -0
  765. /package/dist/types/modules/word/{writers → writer}/styles-writer.d.ts +0 -0
  766. /package/dist/types/modules/word/{writers → writer}/textbox-writer.d.ts +0 -0
  767. /package/dist/types/modules/word/{writers → writer}/toc-writer.d.ts +0 -0
@@ -33,11 +33,77 @@ import { stringToUint8Array } from "../../../utils/binary.js";
33
33
  import { base64ToUint8Array } from "../../../utils/utils.js";
34
34
  const EMPTY_U8 = new Uint8Array(0);
35
35
  const TEXT_DECODER = new TextDecoder();
36
+ /**
37
+ * Drain a resolver list, calling each. Mutates the array to empty.
38
+ *
39
+ * Used by the backpressure machinery: when a sink drains or errors, every
40
+ * parked `_waitForUserSinkDrain()` / pending-async waiter must be woken
41
+ * exactly once, and the array reset so the next backpressure cycle starts
42
+ * clean. Hoisted to a free function so it can be re-used across the three
43
+ * wake sites without per-site duplication of the splice/loop pattern.
44
+ */
45
+ function callAllResolvers(resolvers) {
46
+ if (resolvers.length === 0) {
47
+ return;
48
+ }
49
+ // Snapshot then clear, so a resolver that itself triggers a fresh wait
50
+ // (re-pushing into the same array) doesn't get confused with the current
51
+ // batch.
52
+ const snapshot = resolvers.splice(0);
53
+ for (const r of snapshot) {
54
+ r();
55
+ }
56
+ }
36
57
  // ============================================================================
37
58
  // Base Class
38
59
  // ============================================================================
39
60
  export class WorkbookWriterBase {
40
61
  constructor(options, WorksheetWriterClass) {
62
+ // ---------------------------------------------------------------------------
63
+ // Backpressure tracking for the user-supplied output sink.
64
+ //
65
+ // Set by `_trackBackpressure(ok)` whenever `this.stream.write(data)` returns
66
+ // false (or a Promise that resolves to false). Cleared when the sink emits
67
+ // `'drain'`. Awaited by `_waitForUserSinkDrain()` at async boundaries
68
+ // (between worksheets, before `addWorkbook`, etc) so a slow sink throttles
69
+ // the producer instead of letting bytes accumulate unboundedly inside the
70
+ // sink's internal buffer or in the zip pipeline.
71
+ //
72
+ // Important caveat: this **cannot** block a single tight synchronous
73
+ // `for (...) row.commit()` loop inside one worksheet — JavaScript has no
74
+ // sync wait, and `row.commit()` is sync void. During such a loop, every
75
+ // produced compressed chunk is pushed straight into the sink's internal
76
+ // buffer (Node `Writable` accepts writes after returning false; it just
77
+ // hints "drain"). For very-large single-worksheet workloads with a slow
78
+ // sink, the practical bound on how much can pile up is roughly the total
79
+ // compressed size of one worksheet — only the `wb.commit()` boundary
80
+ // (and any `worksheet.commit()` between sheets) gives the event loop a
81
+ // chance to park here on `_waitForUserSinkDrain()`.
82
+ //
83
+ // Multi-sheet workloads benefit fully because each `worksheet.commit()`
84
+ // hands control back to `_commitWorksheets()` which awaits drain before
85
+ // the next sheet starts.
86
+ this._needsDrain = false;
87
+ this._drainResolvers = [];
88
+ this._drainListenerAttached = false;
89
+ // Captured if the user sink fires 'error' before `_finalize()` attaches its
90
+ // own listener. Replayed by `_finalize()` so the original error is what
91
+ // rejects `commit()`, not a generic timeout.
92
+ this._sinkError = null;
93
+ /**
94
+ * Attach error/close listeners on the user sink so any parked backpressure
95
+ * waiters are released the moment the sink fails. Without this, a
96
+ * `commit()` parked on `_waitForUserSinkDrain()` would hang forever if
97
+ * the sink errored before emitting 'drain'. Idempotent and a no-op for
98
+ * sinks that don't expose `.on` (e.g. internal `StreamBuf`).
99
+ *
100
+ * Uses a non-consuming listener: if the user has their own 'error' handler
101
+ * it still fires (EventEmitter broadcasts to all listeners). The error is
102
+ * also captured into `_sinkError` so `_finalize()` can replay it — `_finalize`
103
+ * registers its own listener with `once()`, which would miss errors that
104
+ * arrived earlier in the commit pipeline.
105
+ */
106
+ this._lifecycleListenersAttached = false;
41
107
  this.WorksheetWriterClass = WorksheetWriterClass;
42
108
  this.created = options.created || new Date();
43
109
  this.modified = options.modified || this.created;
@@ -57,14 +123,26 @@ export class WorkbookWriterBase {
57
123
  this.commentRefs = [];
58
124
  this.dynamicArrayCount = 0;
59
125
  this._trueStreaming = options.trueStreaming ?? false;
60
- // Create Zip instance
126
+ // Create Zip instance.
127
+ //
128
+ // Backpressure note: when `this.stream.write(data)` returns false (the
129
+ // user-supplied sink — e.g. fs.WriteStream, PassThrough, HTTP response
130
+ // — has reached its highWaterMark), we cannot synchronously block the
131
+ // zip callback (it's invoked from inside `row.commit()`'s sync chain).
132
+ // Instead we record a `_needsDrain` flag and a Promise that resolves
133
+ // when the sink emits `'drain'`. `commit()` and `_commitWorksheets()`
134
+ // await this promise at their natural async boundaries, so the producer
135
+ // stops generating new zip data until the sink has caught up. This
136
+ // makes `WorkbookWriter` safe against slow sinks (network responses,
137
+ // throttled fs, etc) without changing the public API.
61
138
  this.zip = new Zip((err, data, final) => {
62
139
  if (err) {
63
140
  this.stream.emit("error", err);
64
141
  }
65
142
  else {
66
143
  // `streaming-zip` already emits `Uint8Array`; avoid copying per chunk.
67
- this.stream.write(data);
144
+ const ok = this.stream.write(data);
145
+ this._trackBackpressure(ok);
68
146
  if (final) {
69
147
  this.stream.end();
70
148
  }
@@ -72,6 +150,11 @@ export class WorkbookWriterBase {
72
150
  });
73
151
  // Setup output stream
74
152
  this.stream = this._createOutputStream(options);
153
+ // Eagerly attach error/close listeners on the sink so any backpressure
154
+ // waiters are released the moment the sink fails — without this, a
155
+ // `commit()` parked on `_waitForUserSinkDrain()` would hang forever if
156
+ // the sink errored before emitting 'drain'.
157
+ this._attachSinkLifecycleListeners();
75
158
  // Theme and office rels are deferred to commit() so that worksheet files
76
159
  // are added to the ZIP first. This ensures StreamingZip sets ondata on
77
160
  // the worksheet immediately, allowing pushSync to flow data through
@@ -87,6 +170,106 @@ export class WorkbookWriterBase {
87
170
  }
88
171
  return new StreamBuf();
89
172
  }
173
+ /**
174
+ * Internal: record whether the sink accepted the last write. The
175
+ * `OutputStreamLike.write` type advertises `boolean | Promise<boolean>`
176
+ * for forward compatibility, but in practice every concrete sink we
177
+ * accept (Node `Writable`, browser `Writable` from `@stream`, internal
178
+ * `StreamBuf`, fs.WriteStream, etc) returns a sync `boolean`. We
179
+ * defensively handle the Promise shape but it's never exercised.
180
+ */
181
+ _trackBackpressure(ok) {
182
+ if (ok instanceof Promise) {
183
+ // Defensive path: a hypothetical sink whose `write()` returns a
184
+ // Promise. Await its resolution and treat false as backpressure.
185
+ ok.then(result => {
186
+ if (!result) {
187
+ this._needsDrain = true;
188
+ }
189
+ }, () => {
190
+ // Errors surface via the sink's 'error' event; ignore here.
191
+ });
192
+ return;
193
+ }
194
+ if (ok === false) {
195
+ this._needsDrain = true;
196
+ }
197
+ this._ensureDrainListener();
198
+ }
199
+ _ensureDrainListener() {
200
+ if (this._drainListenerAttached) {
201
+ return;
202
+ }
203
+ if (typeof this.stream.on !== "function") {
204
+ // StreamBuf and similar sinks that don't follow the Writable contract
205
+ // never emit 'drain'; they also never return false from write(), so
206
+ // they reach this branch only spuriously. Skip listener attach.
207
+ return;
208
+ }
209
+ this._drainListenerAttached = true;
210
+ this.stream.on("drain", () => {
211
+ this._needsDrain = false;
212
+ callAllResolvers(this._drainResolvers);
213
+ });
214
+ }
215
+ _attachSinkLifecycleListeners() {
216
+ if (this._lifecycleListenersAttached) {
217
+ return;
218
+ }
219
+ if (typeof this.stream.on !== "function") {
220
+ return;
221
+ }
222
+ this._lifecycleListenersAttached = true;
223
+ // Use `.once()` for both events: we only care about the first error
224
+ // (subsequent errors are captured in `_sinkError` only if we haven't
225
+ // recorded one yet). Using `.once()` also avoids leaking the listener
226
+ // if the sink lives longer than the WorkbookWriter — the EventEmitter
227
+ // releases the closure as soon as the event fires.
228
+ if (typeof this.stream.once === "function") {
229
+ this.stream.once("error", (err) => {
230
+ if (!this._sinkError) {
231
+ this._sinkError = err;
232
+ }
233
+ this._wakeAllBackpressureWaiters();
234
+ });
235
+ this.stream.once("close", () => {
236
+ this._wakeAllBackpressureWaiters();
237
+ });
238
+ }
239
+ else {
240
+ // Fallback: sink only has .on, attach normally.
241
+ this.stream.on("error", (err) => {
242
+ if (!this._sinkError) {
243
+ this._sinkError = err;
244
+ }
245
+ this._wakeAllBackpressureWaiters();
246
+ });
247
+ }
248
+ }
249
+ _wakeAllBackpressureWaiters() {
250
+ this._needsDrain = false;
251
+ callAllResolvers(this._drainResolvers);
252
+ }
253
+ /**
254
+ * Park here until any async writes have settled and the user sink has
255
+ * drained below its high-water mark. Resolves immediately when no
256
+ * backpressure is in flight.
257
+ *
258
+ * Called at async boundaries inside `commit()` so a slow sink throttles
259
+ * the producer instead of letting bytes accumulate unboundedly.
260
+ */
261
+ async _waitForUserSinkDrain() {
262
+ // Short-circuit if the sink already errored — no point waiting for a
263
+ // drain that will never come. The error itself surfaces from
264
+ // `_finalize()` later.
265
+ if (this._sinkError) {
266
+ return;
267
+ }
268
+ if (!this._needsDrain) {
269
+ return;
270
+ }
271
+ return new Promise(resolve => this._drainResolvers.push(resolve));
272
+ }
90
273
  get definedNames() {
91
274
  return this._definedNames;
92
275
  }
@@ -135,24 +318,32 @@ export class WorkbookWriterBase {
135
318
  }
136
319
  zipFile.push(buffer, true);
137
320
  }
138
- _commitWorksheets() {
139
- const commitWorksheet = (worksheet) => {
140
- if (!worksheet.committed) {
141
- return new Promise(resolve => {
142
- worksheet.stream.once("zipped", () => resolve());
143
- worksheet.commit();
144
- });
321
+ async _commitWorksheets() {
322
+ // Commit worksheets sequentially (not in parallel) so we can park on
323
+ // user-sink backpressure between them. Parallel commit was the old
324
+ // behavior; for a single-worksheet workbook the difference is nil, and
325
+ // for multi-sheet workbooks honoring backpressure between them keeps
326
+ // memory bounded against slow sinks. ZIP itself is inherently serial
327
+ // (StreamingZip processes one entry at a time via `activeFile`), so
328
+ // sequential commit imposes no real CPU cost — measured throughput is
329
+ // identical to parallel commit on multi-sheet workbooks.
330
+ for (const worksheet of this._worksheets) {
331
+ if (!worksheet || worksheet.committed) {
332
+ continue;
145
333
  }
146
- return Promise.resolve();
147
- };
148
- const promises = this._worksheets.map(commitWorksheet);
149
- return promises.length ? Promise.all(promises).then(() => { }) : Promise.resolve();
334
+ await new Promise(resolve => {
335
+ worksheet.stream.once("zipped", () => resolve());
336
+ worksheet.commit();
337
+ });
338
+ await this._waitForUserSinkDrain();
339
+ }
150
340
  }
151
341
  async commit() {
152
342
  await this.promise;
153
343
  await this._commitWorksheets();
154
344
  await this.addMedia();
155
345
  this.addDrawings();
346
+ await this._waitForUserSinkDrain();
156
347
  await Promise.all([
157
348
  this.addThemes(),
158
349
  this.addOfficeRels(),
@@ -165,7 +356,9 @@ export class WorkbookWriterBase {
165
356
  this.addMetadata(),
166
357
  this.addWorkbookRels()
167
358
  ]);
359
+ await this._waitForUserSinkDrain();
168
360
  await this.addWorkbook();
361
+ await this._waitForUserSinkDrain();
169
362
  await this._finalize();
170
363
  }
171
364
  get nextId() {
@@ -436,6 +629,22 @@ export class WorkbookWriterBase {
436
629
  });
437
630
  }
438
631
  _finalize() {
632
+ // If the user sink errored earlier in the commit pipeline (captured by
633
+ // `_attachSinkLifecycleListeners`), surface that error now — `commit()`
634
+ // would otherwise reach `_finalize` and hang waiting for `'close'` from
635
+ // a sink that's already destroyed.
636
+ if (this._sinkError) {
637
+ // End the zip pipeline cleanly so its internal callbacks don't keep
638
+ // firing into a torn-down sink. Best-effort: ignore any error from
639
+ // end() since the original `_sinkError` is what we care about.
640
+ try {
641
+ this.zip.end();
642
+ }
643
+ catch {
644
+ // Best-effort cleanup.
645
+ }
646
+ return Promise.reject(this._sinkError);
647
+ }
439
648
  // Wait for "close" — emitted by all supported output streams (Node Writable,
440
649
  // browser Writable, and StreamBuf) after "finish". For file streams this
441
650
  // guarantees the fd is released, which is critical on Windows where reading
@@ -451,6 +660,12 @@ export class WorkbookWriterBase {
451
660
  };
452
661
  const onDone = () => {
453
662
  cleanup();
663
+ // If an error fired between us checking `_sinkError` and reaching
664
+ // 'close' (rare but possible with concurrent emit), surface it.
665
+ if (this._sinkError) {
666
+ reject(this._sinkError);
667
+ return;
668
+ }
454
669
  resolve(this);
455
670
  };
456
671
  this.stream.once("error", onError);
@@ -1,84 +1,7 @@
1
1
  /**
2
- * StringBuf - Cross-Platform String Buffer
2
+ * Re-export of the shared {@link StringBuf} from `@utils/string-buf`.
3
3
  *
4
- * A way to keep string memory operations to a minimum while building XML strings.
5
- * Uses TextEncoder and Uint8Array for cross-platform compatibility (Node.js + Browser).
4
+ * Kept as a thin alias so existing imports (`@excel/utils/string-buf`)
5
+ * continue to work without churn.
6
6
  */
7
- const encoder = new TextEncoder();
8
- /**
9
- * StringBuf - efficient string builder using Uint8Array
10
- * Works identically in Node.js and Browser environments.
11
- */
12
- class StringBuf {
13
- constructor(options) {
14
- this._buf = new Uint8Array((options && options.size) || 16384);
15
- // TextEncoder only supports UTF-8, so encoding option is ignored
16
- this._inPos = 0;
17
- this._buffer = undefined;
18
- }
19
- get length() {
20
- return this._inPos;
21
- }
22
- get capacity() {
23
- return this._buf.length;
24
- }
25
- get buffer() {
26
- return this._buf;
27
- }
28
- toBuffer() {
29
- // Return the current data as a single enclosing buffer
30
- if (!this._buffer) {
31
- this._buffer = this._buf.slice(0, this._inPos);
32
- }
33
- return this._buffer;
34
- }
35
- reset(position) {
36
- position = position ?? 0;
37
- this._buffer = undefined;
38
- this._inPos = position;
39
- }
40
- _grow(min) {
41
- let size = this._buf.length * 2;
42
- while (size < min) {
43
- size *= 2;
44
- }
45
- const buf = new Uint8Array(size);
46
- buf.set(this._buf);
47
- this._buf = buf;
48
- }
49
- addText(text) {
50
- this._buffer = undefined;
51
- // Ensure there's room for at least the string length (optimistic: 1 byte per char).
52
- const optimistic = this._inPos + text.length;
53
- if (optimistic > this._buf.length - 4) {
54
- this._grow(optimistic);
55
- }
56
- // Use encodeInto to write directly into the buffer, avoiding the
57
- // intermediate Uint8Array allocation that encoder.encode() creates.
58
- const target = this._buf.subarray(this._inPos);
59
- const result = encoder.encodeInto(text, target);
60
- if (result.read < text.length) {
61
- // Didn't fit — text has multi-byte UTF-8 chars that exceed the optimistic estimate.
62
- // Grow to accommodate the remainder (worst case: 3 bytes per remaining char).
63
- const remaining = text.length - result.read;
64
- this._grow(this._inPos + result.written + remaining * 3);
65
- const result2 = encoder.encodeInto(text.substring(result.read), this._buf.subarray(this._inPos + result.written));
66
- this._inPos += result.written + result2.written;
67
- }
68
- else {
69
- this._inPos += result.written;
70
- }
71
- }
72
- addStringBuf(inBuf) {
73
- if (inBuf.length) {
74
- this._buffer = undefined;
75
- if (this.length + inBuf.length > this.capacity) {
76
- this._grow(this.length + inBuf.length);
77
- }
78
- // Copy bytes from input buffer
79
- this._buf.set(inBuf._buf.subarray(0, inBuf.length), this._inPos);
80
- this._inPos += inBuf.length;
81
- }
82
- }
83
- }
84
- export { StringBuf };
7
+ export { StringBuf } from "../../../utils/string-buf.js";
@@ -231,6 +231,59 @@ function isReadableStream(input) {
231
231
  // =============================================================================
232
232
  // CSV Helper Functions (Internal)
233
233
  // =============================================================================
234
+ /**
235
+ * Iterate worksheet rows lazily — yields `{row, rowNumber}` for every row
236
+ * with values, in sheet order. Reaches into the worksheet's internal
237
+ * `_rows` array directly so we don't have to materialise the whole row
238
+ * set up front (matters for very large worksheets piped to slow sinks).
239
+ *
240
+ * Note: `_rows` is 0-based but XLSX row numbers are 1-based. Row N lives
241
+ * at `_rows[N - 1]`, so the yielded `rowNumber` is `i + 1`.
242
+ */
243
+ function* iterateWorksheetRows(worksheet) {
244
+ const rows = worksheet._rows;
245
+ if (!rows || rows.length === 0) {
246
+ return;
247
+ }
248
+ for (let i = 0; i < rows.length; i++) {
249
+ const row = rows[i];
250
+ if (row && row.hasValues) {
251
+ yield { row, rowNumber: i + 1 };
252
+ }
253
+ }
254
+ }
255
+ /**
256
+ * Build a `() => Promise<void>` that resolves on the next `'drain'` event
257
+ * of `emitter`, but rejects promptly if `'error'` or `'close'` fires first.
258
+ *
259
+ * Without the error/close races, a producer parked on `once('drain')`
260
+ * would hang forever after the downstream sink errors mid-write — the
261
+ * Transform is destroyed and never emits drain again.
262
+ */
263
+ function createDrainRacer(emitter) {
264
+ return () => new Promise((resolve, reject) => {
265
+ const cleanup = () => {
266
+ emitter.off("drain", onDrain);
267
+ emitter.off("error", onError);
268
+ emitter.off("close", onClose);
269
+ };
270
+ const onDrain = () => {
271
+ cleanup();
272
+ resolve();
273
+ };
274
+ const onError = (err) => {
275
+ cleanup();
276
+ reject(err);
277
+ };
278
+ const onClose = () => {
279
+ cleanup();
280
+ reject(new Error("stream closed before drain"));
281
+ };
282
+ emitter.once("drain", onDrain);
283
+ emitter.once("error", onError);
284
+ emitter.once("close", onClose);
285
+ });
286
+ }
234
287
  function buildParserOptions(options) {
235
288
  return {
236
289
  delimiter: options?.delimiter ?? ",",
@@ -596,26 +649,56 @@ class Workbook {
596
649
  const map = options?.map || createDefaultWriteMapper(options?.dateFormat, options?.dateUTC);
597
650
  const includeEmptyRows = options?.includeEmptyRows !== false;
598
651
  const formatter = new CsvFormatterStream(buildFormatterOptions(options));
599
- if (worksheet) {
600
- setTimeout(() => {
652
+ if (!worksheet) {
653
+ setTimeout(() => formatter.end(), 0);
654
+ return formatter;
655
+ }
656
+ // Drive rows asynchronously so the formatter's backpressure signal can
657
+ // throttle production. The drain wait races against `'error'` / `'close'`
658
+ // so a downstream sink failure unwinds the producer instead of hanging.
659
+ const awaitFormatterDrain = createDrainRacer(formatter);
660
+ const writeAndDrain = (values) => {
661
+ if (formatter.write(values)) {
662
+ return;
663
+ }
664
+ return awaitFormatterDrain();
665
+ };
666
+ (async () => {
667
+ try {
601
668
  let lastRow = 1;
602
- worksheet.eachRow((row, rowNumber) => {
669
+ // Iterate worksheet rows lazily — no snapshot. Each row's `values`
670
+ // are mapped at iteration time, so already-yielded data is GC-able
671
+ // as the consumer drains the formatter.
672
+ for (const { row, rowNumber } of iterateWorksheetRows(worksheet)) {
673
+ if (formatter.destroyed) {
674
+ return;
675
+ }
676
+ // First slot is the 1-based padding cell — skip without mutating
677
+ // the row (mutating would corrupt subsequent reads / writes).
678
+ const dataValues = row.values.slice(1).map(map);
603
679
  if (includeEmptyRows) {
604
680
  while (lastRow++ < rowNumber - 1) {
605
- formatter.write([]);
681
+ const p = writeAndDrain([]);
682
+ if (p) {
683
+ await p;
684
+ }
685
+ if (formatter.destroyed) {
686
+ return;
687
+ }
606
688
  }
607
689
  }
608
- const { values } = row;
609
- values.shift();
610
- formatter.write(values.map(map));
690
+ const p = writeAndDrain(dataValues);
691
+ if (p) {
692
+ await p;
693
+ }
611
694
  lastRow = rowNumber;
612
- });
695
+ }
613
696
  formatter.end();
614
- }, 0);
615
- }
616
- else {
617
- setTimeout(() => formatter.end(), 0);
618
- }
697
+ }
698
+ catch (err) {
699
+ formatter.destroy(err instanceof Error ? err : new Error(String(err)));
700
+ }
701
+ })();
619
702
  return formatter;
620
703
  }
621
704
  /**
@@ -814,20 +897,47 @@ class Workbook {
814
897
  const includeEmptyRows = options?.includeEmptyRows !== false;
815
898
  const formatter = new CsvFormatterStream(buildFormatterOptions(options));
816
899
  const pipelinePromise = pipeline(formatter, stream);
817
- let lastRow = 1;
818
- worksheet.eachRow((row, rowNumber) => {
819
- if (includeEmptyRows) {
820
- while (lastRow++ < rowNumber - 1) {
821
- formatter.write([]);
900
+ // Race drain against error / close so a mid-stream sink failure makes
901
+ // `writeAndDrain` reject (and the for-loop unwind) instead of hanging
902
+ // on a 'drain' the destroyed formatter will never emit.
903
+ const awaitFormatterDrain = createDrainRacer(formatter);
904
+ const writeAndDrain = async (values) => {
905
+ if (!formatter.write(values)) {
906
+ await awaitFormatterDrain();
907
+ }
908
+ };
909
+ try {
910
+ let lastRow = 1;
911
+ // Iterate worksheet rows directly without pre-collecting them. The
912
+ // Workbook model is already in memory, so reaching into `_rows` here
913
+ // adds no per-row allocation — just a Row reference per iteration,
914
+ // immediately reassigned. The async loop honours formatter
915
+ // backpressure between rows so the formatter's internal buffer can't
916
+ // grow unbounded against a slow sink.
917
+ for (const { row, rowNumber } of iterateWorksheetRows(worksheet)) {
918
+ // First slot is the 1-based padding cell — skip without mutating
919
+ // the row (mutating would corrupt subsequent reads / writes).
920
+ const dataValues = row.values.slice(1).map(map);
921
+ if (includeEmptyRows) {
922
+ while (lastRow++ < rowNumber - 1) {
923
+ await writeAndDrain([]);
924
+ }
822
925
  }
926
+ await writeAndDrain(dataValues);
927
+ lastRow = rowNumber;
823
928
  }
824
- const { values } = row;
825
- values.shift();
826
- formatter.write(values.map(map));
827
- lastRow = rowNumber;
828
- });
829
- formatter.end();
830
- await pipelinePromise;
929
+ formatter.end();
930
+ await pipelinePromise;
931
+ }
932
+ catch (err) {
933
+ // Sink errored mid-write (or pipeline tore down for any reason).
934
+ // Destroy the formatter so the pipeline unwinds, swallow the
935
+ // pipeline rejection (the original error is what we want to surface),
936
+ // and rethrow.
937
+ formatter.destroy(err instanceof Error ? err : new Error(String(err)));
938
+ await pipelinePromise.catch(() => { });
939
+ throw err;
940
+ }
831
941
  }
832
942
  /**
833
943
  * Populate a worksheet from a parsed Markdown table result.
@@ -764,16 +764,11 @@ class ChartSpaceXform extends BaseXform {
764
764
  this._renderMarker(xml, pf.marker);
765
765
  }
766
766
  // `c:pivotFmt` may carry a bare `c:dLbl` (no `c:dLbls` wrapper).
767
- // Prefer the structured representation when present so callers
768
- // can mutate label attributes programmatically; fall back to
769
- // the captured raw bytes for files parsed before the structured
770
- // slot existed.
767
+ // Use the structured representation so callers can mutate label
768
+ // attributes programmatically.
771
769
  if (pf.dLbl) {
772
770
  this._renderDataLabelEntry(xml, pf.dLbl);
773
771
  }
774
- else if (pf.rawDLbl) {
775
- xml.writeRaw(pf.rawDLbl);
776
- }
777
772
  else if (pf.dataLabels) {
778
773
  this._renderDataLabels(xml, pf.dataLabels);
779
774
  }
@@ -3710,18 +3705,11 @@ class ChartSpaceXform extends BaseXform {
3710
3705
  !this.currentDataLabelEntry) {
3711
3706
  this.rawXmlTarget = "c:tx:trendlineLbl";
3712
3707
  }
3713
- // c:dLbl inside pivotFmt is now parsed structurally (see the
3714
- // `currentDataLabelEntry` branch below `c:dLbl` open always
3708
+ // c:dLbl inside pivotFmt is parsed structurally see the
3709
+ // `currentDataLabelEntry` branch below. `c:dLbl` open always
3715
3710
  // starts an entry, and the matching close routes it to the
3716
3711
  // pivotFormat or the data-labels bundle depending on the
3717
- // surrounding state). The previous raw-capture branch that
3718
- // preempted structured parsing has been removed because it
3719
- // made `PivotFormat.dLbl` unreachable from XML — callers could
3720
- // only populate the field by mutating the model directly, and
3721
- // the writer then had to consult both `dLbl` and the
3722
- // deprecated `rawDLbl` fallback. Now the parser always
3723
- // produces `dLbl`; `rawDLbl` remains on the type only for
3724
- // legacy round-trip of files parsed by older versions.
3712
+ // surrounding state.
3725
3713
  return true;
3726
3714
  }
3727
3715
  switch (name) {
@@ -4327,9 +4315,7 @@ class ChartSpaceXform extends BaseXform {
4327
4315
  // Bare `<c:dLbl>` inside `<c:pivotFmt>` (no `<c:dLbls>`
4328
4316
  // wrapper). Pivot samples from Excel emit a single dLbl
4329
4317
  // here and the structured slot on `PivotFormat.dLbl`
4330
- // captures it. Previously this element was raw-captured
4331
- // into `rawDLbl`, which made the structured field
4332
- // unreachable from on-disk files.
4318
+ // captures it.
4333
4319
  this.currentPivotFormat.dLbl = this.currentDataLabelEntry;
4334
4320
  this.currentDataLabelEntry = null;
4335
4321
  }