@lyit/exceljs 4.4.1

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 (543) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +3398 -0
  3. package/README_zh.md +2878 -0
  4. package/dist/LICENSE +22 -0
  5. package/dist/es5/csv/csv.js +182 -0
  6. package/dist/es5/csv/csv.js.map +1 -0
  7. package/dist/es5/csv/line-buffer.js +68 -0
  8. package/dist/es5/csv/line-buffer.js.map +1 -0
  9. package/dist/es5/csv/stream-converter.js +110 -0
  10. package/dist/es5/csv/stream-converter.js.map +1 -0
  11. package/dist/es5/doc/anchor.js +73 -0
  12. package/dist/es5/doc/anchor.js.map +1 -0
  13. package/dist/es5/doc/cell.js +960 -0
  14. package/dist/es5/doc/cell.js.map +1 -0
  15. package/dist/es5/doc/column.js +274 -0
  16. package/dist/es5/doc/column.js.map +1 -0
  17. package/dist/es5/doc/data-validations.js +18 -0
  18. package/dist/es5/doc/data-validations.js.map +1 -0
  19. package/dist/es5/doc/defined-names.js +173 -0
  20. package/dist/es5/doc/defined-names.js.map +1 -0
  21. package/dist/es5/doc/enums.js +49 -0
  22. package/dist/es5/doc/enums.js.map +1 -0
  23. package/dist/es5/doc/form-checkbox.js +342 -0
  24. package/dist/es5/doc/form-checkbox.js.map +1 -0
  25. package/dist/es5/doc/image.js +69 -0
  26. package/dist/es5/doc/image.js.map +1 -0
  27. package/dist/es5/doc/modelcontainer.js +16 -0
  28. package/dist/es5/doc/modelcontainer.js.map +1 -0
  29. package/dist/es5/doc/note.js +64 -0
  30. package/dist/es5/doc/note.js.map +1 -0
  31. package/dist/es5/doc/pivot-table.js +247 -0
  32. package/dist/es5/doc/pivot-table.js.map +1 -0
  33. package/dist/es5/doc/range.js +229 -0
  34. package/dist/es5/doc/range.js.map +1 -0
  35. package/dist/es5/doc/row.js +391 -0
  36. package/dist/es5/doc/row.js.map +1 -0
  37. package/dist/es5/doc/table.js +542 -0
  38. package/dist/es5/doc/table.js.map +1 -0
  39. package/dist/es5/doc/workbook.js +221 -0
  40. package/dist/es5/doc/workbook.js.map +1 -0
  41. package/dist/es5/doc/worksheet.js +996 -0
  42. package/dist/es5/doc/worksheet.js.map +1 -0
  43. package/dist/es5/exceljs.bare.js +14 -0
  44. package/dist/es5/exceljs.bare.js.map +1 -0
  45. package/dist/es5/exceljs.browser.js +36 -0
  46. package/dist/es5/exceljs.browser.js.map +1 -0
  47. package/dist/es5/exceljs.nodejs.js +15 -0
  48. package/dist/es5/exceljs.nodejs.js.map +1 -0
  49. package/dist/es5/index.js +15 -0
  50. package/dist/es5/stream/xlsx/hyperlink-reader.js +90 -0
  51. package/dist/es5/stream/xlsx/hyperlink-reader.js.map +1 -0
  52. package/dist/es5/stream/xlsx/sheet-comments-writer.js +94 -0
  53. package/dist/es5/stream/xlsx/sheet-comments-writer.js.map +1 -0
  54. package/dist/es5/stream/xlsx/sheet-rels-writer.js +94 -0
  55. package/dist/es5/stream/xlsx/sheet-rels-writer.js.map +1 -0
  56. package/dist/es5/stream/xlsx/workbook-reader.js +361 -0
  57. package/dist/es5/stream/xlsx/workbook-reader.js.map +1 -0
  58. package/dist/es5/stream/xlsx/workbook-writer.js +347 -0
  59. package/dist/es5/stream/xlsx/workbook-writer.js.map +1 -0
  60. package/dist/es5/stream/xlsx/worksheet-reader.js +392 -0
  61. package/dist/es5/stream/xlsx/worksheet-reader.js.map +1 -0
  62. package/dist/es5/stream/xlsx/worksheet-writer.js +652 -0
  63. package/dist/es5/stream/xlsx/worksheet-writer.js.map +1 -0
  64. package/dist/es5/utils/auto-drain.js +18 -0
  65. package/dist/es5/utils/auto-drain.js.map +1 -0
  66. package/dist/es5/utils/browser-buffer-decode.js +15 -0
  67. package/dist/es5/utils/browser-buffer-decode.js.map +1 -0
  68. package/dist/es5/utils/browser-buffer-encode.js +18 -0
  69. package/dist/es5/utils/browser-buffer-encode.js.map +1 -0
  70. package/dist/es5/utils/cell-matrix.js +149 -0
  71. package/dist/es5/utils/cell-matrix.js.map +1 -0
  72. package/dist/es5/utils/col-cache.js +258 -0
  73. package/dist/es5/utils/col-cache.js.map +1 -0
  74. package/dist/es5/utils/copy-style.js +43 -0
  75. package/dist/es5/utils/copy-style.js.map +1 -0
  76. package/dist/es5/utils/encryptor.js +58 -0
  77. package/dist/es5/utils/encryptor.js.map +1 -0
  78. package/dist/es5/utils/iterate-stream.js +46 -0
  79. package/dist/es5/utils/iterate-stream.js.map +1 -0
  80. package/dist/es5/utils/parse-sax.js +66 -0
  81. package/dist/es5/utils/parse-sax.js.map +1 -0
  82. package/dist/es5/utils/shared-formula.js +42 -0
  83. package/dist/es5/utils/shared-formula.js.map +1 -0
  84. package/dist/es5/utils/shared-strings.js +37 -0
  85. package/dist/es5/utils/shared-strings.js.map +1 -0
  86. package/dist/es5/utils/stream-base64.js +66 -0
  87. package/dist/es5/utils/stream-base64.js.map +1 -0
  88. package/dist/es5/utils/stream-buf.js +365 -0
  89. package/dist/es5/utils/stream-buf.js.map +1 -0
  90. package/dist/es5/utils/string-buf.js +73 -0
  91. package/dist/es5/utils/string-buf.js.map +1 -0
  92. package/dist/es5/utils/string-builder.js +32 -0
  93. package/dist/es5/utils/string-builder.js.map +1 -0
  94. package/dist/es5/utils/stuttered-pipe.js +61 -0
  95. package/dist/es5/utils/stuttered-pipe.js.map +1 -0
  96. package/dist/es5/utils/typed-stack.js +23 -0
  97. package/dist/es5/utils/typed-stack.js.map +1 -0
  98. package/dist/es5/utils/under-dash.js +168 -0
  99. package/dist/es5/utils/under-dash.js.map +1 -0
  100. package/dist/es5/utils/utils.js +205 -0
  101. package/dist/es5/utils/utils.js.map +1 -0
  102. package/dist/es5/utils/xml-stream.js +151 -0
  103. package/dist/es5/utils/xml-stream.js.map +1 -0
  104. package/dist/es5/utils/zip-stream.js +79 -0
  105. package/dist/es5/utils/zip-stream.js.map +1 -0
  106. package/dist/es5/xlsx/defaultnumformats.js +230 -0
  107. package/dist/es5/xlsx/defaultnumformats.js.map +1 -0
  108. package/dist/es5/xlsx/rel-type.js +22 -0
  109. package/dist/es5/xlsx/rel-type.js.map +1 -0
  110. package/dist/es5/xlsx/xform/base-xform.js +139 -0
  111. package/dist/es5/xlsx/xform/base-xform.js.map +1 -0
  112. package/dist/es5/xlsx/xform/book/defined-name-xform.js +85 -0
  113. package/dist/es5/xlsx/xform/book/defined-name-xform.js.map +1 -0
  114. package/dist/es5/xlsx/xform/book/sheet-xform.js +32 -0
  115. package/dist/es5/xlsx/xform/book/sheet-xform.js.map +1 -0
  116. package/dist/es5/xlsx/xform/book/workbook-calc-properties-xform.js +24 -0
  117. package/dist/es5/xlsx/xform/book/workbook-calc-properties-xform.js.map +1 -0
  118. package/dist/es5/xlsx/xform/book/workbook-pivot-cache-xform.js +27 -0
  119. package/dist/es5/xlsx/xform/book/workbook-pivot-cache-xform.js.map +1 -0
  120. package/dist/es5/xlsx/xform/book/workbook-properties-xform.js +27 -0
  121. package/dist/es5/xlsx/xform/book/workbook-properties-xform.js.map +1 -0
  122. package/dist/es5/xlsx/xform/book/workbook-view-xform.js +51 -0
  123. package/dist/es5/xlsx/xform/book/workbook-view-xform.js.map +1 -0
  124. package/dist/es5/xlsx/xform/book/workbook-xform.js +244 -0
  125. package/dist/es5/xlsx/xform/book/workbook-xform.js.map +1 -0
  126. package/dist/es5/xlsx/xform/comment/comment-xform.js +103 -0
  127. package/dist/es5/xlsx/xform/comment/comment-xform.js.map +1 -0
  128. package/dist/es5/xlsx/xform/comment/comments-xform.js +76 -0
  129. package/dist/es5/xlsx/xform/comment/comments-xform.js.map +1 -0
  130. package/dist/es5/xlsx/xform/comment/style/vml-position-xform.js +35 -0
  131. package/dist/es5/xlsx/xform/comment/style/vml-position-xform.js.map +1 -0
  132. package/dist/es5/xlsx/xform/comment/style/vml-protection-xform.js +32 -0
  133. package/dist/es5/xlsx/xform/comment/style/vml-protection-xform.js.map +1 -0
  134. package/dist/es5/xlsx/xform/comment/vml-anchor-xform.js +53 -0
  135. package/dist/es5/xlsx/xform/comment/vml-anchor-xform.js.map +1 -0
  136. package/dist/es5/xlsx/xform/comment/vml-client-data-xform.js +98 -0
  137. package/dist/es5/xlsx/xform/comment/vml-client-data-xform.js.map +1 -0
  138. package/dist/es5/xlsx/xform/comment/vml-notes-xform.js +235 -0
  139. package/dist/es5/xlsx/xform/comment/vml-notes-xform.js.map +1 -0
  140. package/dist/es5/xlsx/xform/comment/vml-shape-xform.js +93 -0
  141. package/dist/es5/xlsx/xform/comment/vml-shape-xform.js.map +1 -0
  142. package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js +61 -0
  143. package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js.map +1 -0
  144. package/dist/es5/xlsx/xform/composite-xform.js +51 -0
  145. package/dist/es5/xlsx/xform/composite-xform.js.map +1 -0
  146. package/dist/es5/xlsx/xform/core/app-heading-pairs-xform.js +30 -0
  147. package/dist/es5/xlsx/xform/core/app-heading-pairs-xform.js.map +1 -0
  148. package/dist/es5/xlsx/xform/core/app-titles-of-parts-xform.js +27 -0
  149. package/dist/es5/xlsx/xform/core/app-titles-of-parts-xform.js.map +1 -0
  150. package/dist/es5/xlsx/xform/core/app-xform.js +93 -0
  151. package/dist/es5/xlsx/xform/core/app-xform.js.map +1 -0
  152. package/dist/es5/xlsx/xform/core/content-types-xform.js +198 -0
  153. package/dist/es5/xlsx/xform/core/content-types-xform.js.map +1 -0
  154. package/dist/es5/xlsx/xform/core/core-xform.js +160 -0
  155. package/dist/es5/xlsx/xform/core/core-xform.js.map +1 -0
  156. package/dist/es5/xlsx/xform/core/relationship-xform.js +23 -0
  157. package/dist/es5/xlsx/xform/core/relationship-xform.js.map +1 -0
  158. package/dist/es5/xlsx/xform/core/relationships-xform.js +65 -0
  159. package/dist/es5/xlsx/xform/core/relationships-xform.js.map +1 -0
  160. package/dist/es5/xlsx/xform/drawing/base-cell-anchor-xform.js +47 -0
  161. package/dist/es5/xlsx/xform/drawing/base-cell-anchor-xform.js.map +1 -0
  162. package/dist/es5/xlsx/xform/drawing/blip-fill-xform.js +61 -0
  163. package/dist/es5/xlsx/xform/drawing/blip-fill-xform.js.map +1 -0
  164. package/dist/es5/xlsx/xform/drawing/blip-xform.js +39 -0
  165. package/dist/es5/xlsx/xform/drawing/blip-xform.js.map +1 -0
  166. package/dist/es5/xlsx/xform/drawing/c-nv-pic-pr-xform.js +35 -0
  167. package/dist/es5/xlsx/xform/drawing/c-nv-pic-pr-xform.js.map +1 -0
  168. package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js +62 -0
  169. package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js.map +1 -0
  170. package/dist/es5/xlsx/xform/drawing/cell-position-xform.js +82 -0
  171. package/dist/es5/xlsx/xform/drawing/cell-position-xform.js.map +1 -0
  172. package/dist/es5/xlsx/xform/drawing/ctrl-prop-xform.js +75 -0
  173. package/dist/es5/xlsx/xform/drawing/ctrl-prop-xform.js.map +1 -0
  174. package/dist/es5/xlsx/xform/drawing/drawing-xform.js +98 -0
  175. package/dist/es5/xlsx/xform/drawing/drawing-xform.js.map +1 -0
  176. package/dist/es5/xlsx/xform/drawing/ext-lst-xform.js +40 -0
  177. package/dist/es5/xlsx/xform/drawing/ext-lst-xform.js.map +1 -0
  178. package/dist/es5/xlsx/xform/drawing/ext-xform.js +38 -0
  179. package/dist/es5/xlsx/xform/drawing/ext-xform.js.map +1 -0
  180. package/dist/es5/xlsx/xform/drawing/hlink-click-xform.js +38 -0
  181. package/dist/es5/xlsx/xform/drawing/hlink-click-xform.js.map +1 -0
  182. package/dist/es5/xlsx/xform/drawing/nv-pic-pr-xform.js +59 -0
  183. package/dist/es5/xlsx/xform/drawing/nv-pic-pr-xform.js.map +1 -0
  184. package/dist/es5/xlsx/xform/drawing/one-cell-anchor-xform.js +63 -0
  185. package/dist/es5/xlsx/xform/drawing/one-cell-anchor-xform.js.map +1 -0
  186. package/dist/es5/xlsx/xform/drawing/pic-xform.js +67 -0
  187. package/dist/es5/xlsx/xform/drawing/pic-xform.js.map +1 -0
  188. package/dist/es5/xlsx/xform/drawing/sp-pr.js +30 -0
  189. package/dist/es5/xlsx/xform/drawing/sp-pr.js.map +1 -0
  190. package/dist/es5/xlsx/xform/drawing/two-cell-anchor-xform.js +62 -0
  191. package/dist/es5/xlsx/xform/drawing/two-cell-anchor-xform.js.map +1 -0
  192. package/dist/es5/xlsx/xform/list-xform.js +91 -0
  193. package/dist/es5/xlsx/xform/list-xform.js.map +1 -0
  194. package/dist/es5/xlsx/xform/pivot-table/cache-field.js +72 -0
  195. package/dist/es5/xlsx/xform/pivot-table/cache-field.js.map +1 -0
  196. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +74 -0
  197. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js.map +1 -0
  198. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js +100 -0
  199. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js.map +1 -0
  200. package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js +229 -0
  201. package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js.map +1 -0
  202. package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js +40 -0
  203. package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js.map +1 -0
  204. package/dist/es5/xlsx/xform/sheet/cell-xform.js +450 -0
  205. package/dist/es5/xlsx/xform/sheet/cell-xform.js.map +1 -0
  206. package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js +282 -0
  207. package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js.map +1 -0
  208. package/dist/es5/xlsx/xform/sheet/cf/cfvo-xform.js +25 -0
  209. package/dist/es5/xlsx/xform/sheet/cf/cfvo-xform.js.map +1 -0
  210. package/dist/es5/xlsx/xform/sheet/cf/color-scale-xform.js +38 -0
  211. package/dist/es5/xlsx/xform/sheet/cf/color-scale-xform.js.map +1 -0
  212. package/dist/es5/xlsx/xform/sheet/cf/conditional-formatting-xform.js +45 -0
  213. package/dist/es5/xlsx/xform/sheet/cf/conditional-formatting-xform.js.map +1 -0
  214. package/dist/es5/xlsx/xform/sheet/cf/conditional-formattings-xform.js +77 -0
  215. package/dist/es5/xlsx/xform/sheet/cf/conditional-formattings-xform.js.map +1 -0
  216. package/dist/es5/xlsx/xform/sheet/cf/databar-xform.js +54 -0
  217. package/dist/es5/xlsx/xform/sheet/cf/databar-xform.js.map +1 -0
  218. package/dist/es5/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +71 -0
  219. package/dist/es5/xlsx/xform/sheet/cf/ext-lst-ref-xform.js.map +1 -0
  220. package/dist/es5/xlsx/xform/sheet/cf/formula-xform.js +22 -0
  221. package/dist/es5/xlsx/xform/sheet/cf/formula-xform.js.map +1 -0
  222. package/dist/es5/xlsx/xform/sheet/cf/icon-set-xform.js +43 -0
  223. package/dist/es5/xlsx/xform/sheet/cf/icon-set-xform.js.map +1 -0
  224. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +28 -0
  225. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js.map +1 -0
  226. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +88 -0
  227. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js.map +1 -0
  228. package/dist/es5/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +38 -0
  229. package/dist/es5/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js.map +1 -0
  230. package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +52 -0
  231. package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js.map +1 -0
  232. package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +43 -0
  233. package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js.map +1 -0
  234. package/dist/es5/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +82 -0
  235. package/dist/es5/xlsx/xform/sheet/cf-ext/databar-ext-xform.js.map +1 -0
  236. package/dist/es5/xlsx/xform/sheet/cf-ext/f-ext-xform.js +22 -0
  237. package/dist/es5/xlsx/xform/sheet/cf-ext/f-ext-xform.js.map +1 -0
  238. package/dist/es5/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +66 -0
  239. package/dist/es5/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js.map +1 -0
  240. package/dist/es5/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +22 -0
  241. package/dist/es5/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js.map +1 -0
  242. package/dist/es5/xlsx/xform/sheet/col-xform.js +78 -0
  243. package/dist/es5/xlsx/xform/sheet/col-xform.js.map +1 -0
  244. package/dist/es5/xlsx/xform/sheet/data-validations-xform.js +247 -0
  245. package/dist/es5/xlsx/xform/sheet/data-validations-xform.js.map +1 -0
  246. package/dist/es5/xlsx/xform/sheet/dimension-xform.js +28 -0
  247. package/dist/es5/xlsx/xform/sheet/dimension-xform.js.map +1 -0
  248. package/dist/es5/xlsx/xform/sheet/drawing-xform.js +32 -0
  249. package/dist/es5/xlsx/xform/sheet/drawing-xform.js.map +1 -0
  250. package/dist/es5/xlsx/xform/sheet/ext-lst-xform.js +69 -0
  251. package/dist/es5/xlsx/xform/sheet/ext-lst-xform.js.map +1 -0
  252. package/dist/es5/xlsx/xform/sheet/header-footer-xform.js +126 -0
  253. package/dist/es5/xlsx/xform/sheet/header-footer-xform.js.map +1 -0
  254. package/dist/es5/xlsx/xform/sheet/hyperlink-xform.js +50 -0
  255. package/dist/es5/xlsx/xform/sheet/hyperlink-xform.js.map +1 -0
  256. package/dist/es5/xlsx/xform/sheet/merge-cell-xform.js +26 -0
  257. package/dist/es5/xlsx/xform/sheet/merge-cell-xform.js.map +1 -0
  258. package/dist/es5/xlsx/xform/sheet/merges.js +52 -0
  259. package/dist/es5/xlsx/xform/sheet/merges.js.map +1 -0
  260. package/dist/es5/xlsx/xform/sheet/outline-properties-xform.js +35 -0
  261. package/dist/es5/xlsx/xform/sheet/outline-properties-xform.js.map +1 -0
  262. package/dist/es5/xlsx/xform/sheet/page-breaks-xform.js +24 -0
  263. package/dist/es5/xlsx/xform/sheet/page-breaks-xform.js.map +1 -0
  264. package/dist/es5/xlsx/xform/sheet/page-margins-xform.js +46 -0
  265. package/dist/es5/xlsx/xform/sheet/page-margins-xform.js.map +1 -0
  266. package/dist/es5/xlsx/xform/sheet/page-setup-properties-xform.js +32 -0
  267. package/dist/es5/xlsx/xform/sheet/page-setup-properties-xform.js.map +1 -0
  268. package/dist/es5/xlsx/xform/sheet/page-setup-xform.js +99 -0
  269. package/dist/es5/xlsx/xform/sheet/page-setup-xform.js.map +1 -0
  270. package/dist/es5/xlsx/xform/sheet/picture-xform.js +32 -0
  271. package/dist/es5/xlsx/xform/sheet/picture-xform.js.map +1 -0
  272. package/dist/es5/xlsx/xform/sheet/print-options-xform.js +45 -0
  273. package/dist/es5/xlsx/xform/sheet/print-options-xform.js.map +1 -0
  274. package/dist/es5/xlsx/xform/sheet/row-breaks-xform.js +37 -0
  275. package/dist/es5/xlsx/xform/sheet/row-breaks-xform.js.map +1 -0
  276. package/dist/es5/xlsx/xform/sheet/row-xform.js +131 -0
  277. package/dist/es5/xlsx/xform/sheet/row-xform.js.map +1 -0
  278. package/dist/es5/xlsx/xform/sheet/sheet-format-properties-xform.js +63 -0
  279. package/dist/es5/xlsx/xform/sheet/sheet-format-properties-xform.js.map +1 -0
  280. package/dist/es5/xlsx/xform/sheet/sheet-properties-xform.js +83 -0
  281. package/dist/es5/xlsx/xform/sheet/sheet-properties-xform.js.map +1 -0
  282. package/dist/es5/xlsx/xform/sheet/sheet-protection-xform.js +84 -0
  283. package/dist/es5/xlsx/xform/sheet/sheet-protection-xform.js.map +1 -0
  284. package/dist/es5/xlsx/xform/sheet/sheet-view-xform.js +190 -0
  285. package/dist/es5/xlsx/xform/sheet/sheet-view-xform.js.map +1 -0
  286. package/dist/es5/xlsx/xform/sheet/table-part-xform.js +32 -0
  287. package/dist/es5/xlsx/xform/sheet/table-part-xform.js.map +1 -0
  288. package/dist/es5/xlsx/xform/sheet/worksheet-xform.js +622 -0
  289. package/dist/es5/xlsx/xform/sheet/worksheet-xform.js.map +1 -0
  290. package/dist/es5/xlsx/xform/simple/boolean-xform.js +27 -0
  291. package/dist/es5/xlsx/xform/simple/boolean-xform.js.map +1 -0
  292. package/dist/es5/xlsx/xform/simple/date-xform.js +58 -0
  293. package/dist/es5/xlsx/xform/simple/date-xform.js.map +1 -0
  294. package/dist/es5/xlsx/xform/simple/float-xform.js +47 -0
  295. package/dist/es5/xlsx/xform/simple/float-xform.js.map +1 -0
  296. package/dist/es5/xlsx/xform/simple/integer-xform.js +53 -0
  297. package/dist/es5/xlsx/xform/simple/integer-xform.js.map +1 -0
  298. package/dist/es5/xlsx/xform/simple/string-xform.js +47 -0
  299. package/dist/es5/xlsx/xform/simple/string-xform.js.map +1 -0
  300. package/dist/es5/xlsx/xform/static-xform.js +61 -0
  301. package/dist/es5/xlsx/xform/static-xform.js.map +1 -0
  302. package/dist/es5/xlsx/xform/strings/phonetic-text-xform.js +98 -0
  303. package/dist/es5/xlsx/xform/strings/phonetic-text-xform.js.map +1 -0
  304. package/dist/es5/xlsx/xform/strings/rich-text-xform.js +92 -0
  305. package/dist/es5/xlsx/xform/strings/rich-text-xform.js.map +1 -0
  306. package/dist/es5/xlsx/xform/strings/shared-string-xform.js +99 -0
  307. package/dist/es5/xlsx/xform/strings/shared-string-xform.js.map +1 -0
  308. package/dist/es5/xlsx/xform/strings/shared-strings-xform.js +116 -0
  309. package/dist/es5/xlsx/xform/strings/shared-strings-xform.js.map +1 -0
  310. package/dist/es5/xlsx/xform/strings/text-xform.js +39 -0
  311. package/dist/es5/xlsx/xform/strings/text-xform.js.map +1 -0
  312. package/dist/es5/xlsx/xform/style/alignment-xform.js +139 -0
  313. package/dist/es5/xlsx/xform/style/alignment-xform.js.map +1 -0
  314. package/dist/es5/xlsx/xform/style/border-xform.js +185 -0
  315. package/dist/es5/xlsx/xform/style/border-xform.js.map +1 -0
  316. package/dist/es5/xlsx/xform/style/color-xform.js +66 -0
  317. package/dist/es5/xlsx/xform/style/color-xform.js.map +1 -0
  318. package/dist/es5/xlsx/xform/style/dxf-xform.js +106 -0
  319. package/dist/es5/xlsx/xform/style/dxf-xform.js.map +1 -0
  320. package/dist/es5/xlsx/xform/style/fill-xform.js +307 -0
  321. package/dist/es5/xlsx/xform/style/fill-xform.js.map +1 -0
  322. package/dist/es5/xlsx/xform/style/font-xform.js +175 -0
  323. package/dist/es5/xlsx/xform/style/font-xform.js.map +1 -0
  324. package/dist/es5/xlsx/xform/style/numfmt-xform.js +58 -0
  325. package/dist/es5/xlsx/xform/style/numfmt-xform.js.map +1 -0
  326. package/dist/es5/xlsx/xform/style/protection-xform.js +53 -0
  327. package/dist/es5/xlsx/xform/style/protection-xform.js.map +1 -0
  328. package/dist/es5/xlsx/xform/style/style-xform.js +118 -0
  329. package/dist/es5/xlsx/xform/style/style-xform.js.map +1 -0
  330. package/dist/es5/xlsx/xform/style/styles-xform.js +611 -0
  331. package/dist/es5/xlsx/xform/style/styles-xform.js.map +1 -0
  332. package/dist/es5/xlsx/xform/style/underline-xform.js +46 -0
  333. package/dist/es5/xlsx/xform/style/underline-xform.js.map +1 -0
  334. package/dist/es5/xlsx/xform/table/auto-filter-xform.js +75 -0
  335. package/dist/es5/xlsx/xform/table/auto-filter-xform.js.map +1 -0
  336. package/dist/es5/xlsx/xform/table/custom-filter-xform.js +30 -0
  337. package/dist/es5/xlsx/xform/table/custom-filter-xform.js.map +1 -0
  338. package/dist/es5/xlsx/xform/table/filter-column-xform.js +92 -0
  339. package/dist/es5/xlsx/xform/table/filter-column-xform.js.map +1 -0
  340. package/dist/es5/xlsx/xform/table/filter-xform.js +28 -0
  341. package/dist/es5/xlsx/xform/table/filter-xform.js.map +1 -0
  342. package/dist/es5/xlsx/xform/table/table-column-xform.js +42 -0
  343. package/dist/es5/xlsx/xform/table/table-column-xform.js.map +1 -0
  344. package/dist/es5/xlsx/xform/table/table-style-info-xform.js +40 -0
  345. package/dist/es5/xlsx/xform/table/table-style-info-xform.js.map +1 -0
  346. package/dist/es5/xlsx/xform/table/table-xform.js +125 -0
  347. package/dist/es5/xlsx/xform/table/table-xform.js.map +1 -0
  348. package/dist/es5/xlsx/xlsx.js +1109 -0
  349. package/dist/es5/xlsx/xlsx.js.map +1 -0
  350. package/dist/es5/xlsx/xml/theme1.js +5 -0
  351. package/dist/es5/xlsx/xml/theme1.js.map +1 -0
  352. package/dist/exceljs.bare.js +65234 -0
  353. package/dist/exceljs.bare.js.map +889 -0
  354. package/dist/exceljs.bare.min.js +45 -0
  355. package/dist/exceljs.bare.min.js.map +1 -0
  356. package/dist/exceljs.js +69987 -0
  357. package/dist/exceljs.js.map +1211 -0
  358. package/dist/exceljs.min.js +45 -0
  359. package/dist/exceljs.min.js.map +1 -0
  360. package/excel.js +13 -0
  361. package/index.d.ts +2041 -0
  362. package/index.ts +2 -0
  363. package/lib/csv/csv.js +191 -0
  364. package/lib/csv/line-buffer.js +74 -0
  365. package/lib/csv/stream-converter.js +135 -0
  366. package/lib/doc/anchor.js +91 -0
  367. package/lib/doc/cell.js +1124 -0
  368. package/lib/doc/column.js +320 -0
  369. package/lib/doc/data/theme1.json +234 -0
  370. package/lib/doc/data-validations.js +19 -0
  371. package/lib/doc/defined-names.js +196 -0
  372. package/lib/doc/enums.js +48 -0
  373. package/lib/doc/form-checkbox.js +336 -0
  374. package/lib/doc/image.js +59 -0
  375. package/lib/doc/modelcontainer.js +18 -0
  376. package/lib/doc/note.js +65 -0
  377. package/lib/doc/pivot-table.js +239 -0
  378. package/lib/doc/range.js +257 -0
  379. package/lib/doc/row.js +424 -0
  380. package/lib/doc/table.js +559 -0
  381. package/lib/doc/workbook.js +240 -0
  382. package/lib/doc/worksheet.js +1041 -0
  383. package/lib/exceljs.bare.js +13 -0
  384. package/lib/exceljs.browser.js +36 -0
  385. package/lib/exceljs.nodejs.js +14 -0
  386. package/lib/stream/xlsx/hyperlink-reader.js +83 -0
  387. package/lib/stream/xlsx/sheet-comments-writer.js +121 -0
  388. package/lib/stream/xlsx/sheet-rels-writer.js +119 -0
  389. package/lib/stream/xlsx/workbook-reader.js +336 -0
  390. package/lib/stream/xlsx/workbook-writer.js +347 -0
  391. package/lib/stream/xlsx/worksheet-reader.js +374 -0
  392. package/lib/stream/xlsx/worksheet-writer.js +717 -0
  393. package/lib/utils/auto-drain.js +15 -0
  394. package/lib/utils/browser-buffer-decode.js +14 -0
  395. package/lib/utils/browser-buffer-encode.js +15 -0
  396. package/lib/utils/cell-matrix.js +165 -0
  397. package/lib/utils/col-cache.js +287 -0
  398. package/lib/utils/copy-style.js +43 -0
  399. package/lib/utils/encryptor.js +55 -0
  400. package/lib/utils/iterate-stream.js +48 -0
  401. package/lib/utils/parse-sax.js +43 -0
  402. package/lib/utils/shared-formula.js +44 -0
  403. package/lib/utils/shared-strings.js +42 -0
  404. package/lib/utils/stream-base64.js +72 -0
  405. package/lib/utils/stream-buf.js +387 -0
  406. package/lib/utils/string-buf.js +82 -0
  407. package/lib/utils/string-builder.js +35 -0
  408. package/lib/utils/stuttered-pipe.js +67 -0
  409. package/lib/utils/typed-stack.js +24 -0
  410. package/lib/utils/under-dash.js +184 -0
  411. package/lib/utils/utils.js +206 -0
  412. package/lib/utils/xml-stream.js +169 -0
  413. package/lib/utils/zip-stream.js +87 -0
  414. package/lib/xlsx/.rels +11 -0
  415. package/lib/xlsx/calcChain.xml +6 -0
  416. package/lib/xlsx/core.xml +7 -0
  417. package/lib/xlsx/defaultnumformats.js +153 -0
  418. package/lib/xlsx/rel-type.js +27 -0
  419. package/lib/xlsx/styles.xml +41 -0
  420. package/lib/xlsx/workbook.xml +16 -0
  421. package/lib/xlsx/xform/base-xform.js +145 -0
  422. package/lib/xlsx/xform/book/defined-name-xform.js +91 -0
  423. package/lib/xlsx/xform/book/sheet-xform.js +34 -0
  424. package/lib/xlsx/xform/book/workbook-calc-properties-xform.js +26 -0
  425. package/lib/xlsx/xform/book/workbook-pivot-cache-xform.js +29 -0
  426. package/lib/xlsx/xform/book/workbook-properties-xform.js +29 -0
  427. package/lib/xlsx/xform/book/workbook-view-xform.js +53 -0
  428. package/lib/xlsx/xform/book/workbook-xform.js +265 -0
  429. package/lib/xlsx/xform/comment/comment-xform.js +105 -0
  430. package/lib/xlsx/xform/comment/comments-xform.js +82 -0
  431. package/lib/xlsx/xform/comment/style/vml-position-xform.js +39 -0
  432. package/lib/xlsx/xform/comment/style/vml-protection-xform.js +36 -0
  433. package/lib/xlsx/xform/comment/vml-anchor-xform.js +60 -0
  434. package/lib/xlsx/xform/comment/vml-client-data-xform.js +92 -0
  435. package/lib/xlsx/xform/comment/vml-notes-xform.js +217 -0
  436. package/lib/xlsx/xform/comment/vml-shape-xform.js +95 -0
  437. package/lib/xlsx/xform/comment/vml-textbox-xform.js +64 -0
  438. package/lib/xlsx/xform/composite-xform.js +56 -0
  439. package/lib/xlsx/xform/core/app-heading-pairs-xform.js +32 -0
  440. package/lib/xlsx/xform/core/app-titles-of-parts-xform.js +28 -0
  441. package/lib/xlsx/xform/core/app-xform.js +100 -0
  442. package/lib/xlsx/xform/core/content-types-xform.js +211 -0
  443. package/lib/xlsx/xform/core/core-xform.js +142 -0
  444. package/lib/xlsx/xform/core/relationship-xform.js +25 -0
  445. package/lib/xlsx/xform/core/relationships-xform.js +73 -0
  446. package/lib/xlsx/xform/drawing/base-cell-anchor-xform.js +48 -0
  447. package/lib/xlsx/xform/drawing/blip-fill-xform.js +71 -0
  448. package/lib/xlsx/xform/drawing/blip-xform.js +42 -0
  449. package/lib/xlsx/xform/drawing/c-nv-pic-pr-xform.js +38 -0
  450. package/lib/xlsx/xform/drawing/c-nv-pr-xform.js +68 -0
  451. package/lib/xlsx/xform/drawing/cell-position-xform.js +77 -0
  452. package/lib/xlsx/xform/drawing/ctrl-prop-xform.js +74 -0
  453. package/lib/xlsx/xform/drawing/drawing-xform.js +109 -0
  454. package/lib/xlsx/xform/drawing/ext-lst-xform.js +43 -0
  455. package/lib/xlsx/xform/drawing/ext-xform.js +44 -0
  456. package/lib/xlsx/xform/drawing/hlink-click-xform.js +41 -0
  457. package/lib/xlsx/xform/drawing/nv-pic-pr-xform.js +65 -0
  458. package/lib/xlsx/xform/drawing/one-cell-anchor-xform.js +63 -0
  459. package/lib/xlsx/xform/drawing/pic-xform.js +77 -0
  460. package/lib/xlsx/xform/drawing/sp-pr.js +17 -0
  461. package/lib/xlsx/xform/drawing/two-cell-anchor-xform.js +62 -0
  462. package/lib/xlsx/xform/list-xform.js +95 -0
  463. package/lib/xlsx/xform/pivot-table/cache-field.js +74 -0
  464. package/lib/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +77 -0
  465. package/lib/xlsx/xform/pivot-table/pivot-cache-records-xform.js +107 -0
  466. package/lib/xlsx/xform/pivot-table/pivot-table-xform.js +265 -0
  467. package/lib/xlsx/xform/sheet/auto-filter-xform.js +38 -0
  468. package/lib/xlsx/xform/sheet/cell-xform.js +498 -0
  469. package/lib/xlsx/xform/sheet/cf/cf-rule-xform.js +308 -0
  470. package/lib/xlsx/xform/sheet/cf/cfvo-xform.js +27 -0
  471. package/lib/xlsx/xform/sheet/cf/color-scale-xform.js +45 -0
  472. package/lib/xlsx/xform/sheet/cf/conditional-formatting-xform.js +48 -0
  473. package/lib/xlsx/xform/sheet/cf/conditional-formattings-xform.js +92 -0
  474. package/lib/xlsx/xform/sheet/cf/databar-xform.js +56 -0
  475. package/lib/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +87 -0
  476. package/lib/xlsx/xform/sheet/cf/formula-xform.js +25 -0
  477. package/lib/xlsx/xform/sheet/cf/icon-set-xform.js +47 -0
  478. package/lib/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +27 -0
  479. package/lib/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +98 -0
  480. package/lib/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +43 -0
  481. package/lib/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +62 -0
  482. package/lib/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +50 -0
  483. package/lib/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +102 -0
  484. package/lib/xlsx/xform/sheet/cf-ext/f-ext-xform.js +25 -0
  485. package/lib/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +73 -0
  486. package/lib/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +25 -0
  487. package/lib/xlsx/xform/sheet/col-xform.js +86 -0
  488. package/lib/xlsx/xform/sheet/data-validations-xform.js +257 -0
  489. package/lib/xlsx/xform/sheet/dimension-xform.js +29 -0
  490. package/lib/xlsx/xform/sheet/drawing-xform.js +33 -0
  491. package/lib/xlsx/xform/sheet/ext-lst-xform.js +86 -0
  492. package/lib/xlsx/xform/sheet/header-footer-xform.js +146 -0
  493. package/lib/xlsx/xform/sheet/hyperlink-xform.js +54 -0
  494. package/lib/xlsx/xform/sheet/merge-cell-xform.js +27 -0
  495. package/lib/xlsx/xform/sheet/merges.js +56 -0
  496. package/lib/xlsx/xform/sheet/outline-properties-xform.js +43 -0
  497. package/lib/xlsx/xform/sheet/page-breaks-xform.js +27 -0
  498. package/lib/xlsx/xform/sheet/page-margins-xform.js +49 -0
  499. package/lib/xlsx/xform/sheet/page-setup-properties-xform.js +35 -0
  500. package/lib/xlsx/xform/sheet/page-setup-xform.js +103 -0
  501. package/lib/xlsx/xform/sheet/picture-xform.js +33 -0
  502. package/lib/xlsx/xform/sheet/print-options-xform.js +49 -0
  503. package/lib/xlsx/xform/sheet/row-breaks-xform.js +39 -0
  504. package/lib/xlsx/xform/sheet/row-xform.js +145 -0
  505. package/lib/xlsx/xform/sheet/sheet-format-properties-xform.js +67 -0
  506. package/lib/xlsx/xform/sheet/sheet-properties-xform.js +90 -0
  507. package/lib/xlsx/xform/sheet/sheet-protection-xform.js +89 -0
  508. package/lib/xlsx/xform/sheet/sheet-view-xform.js +202 -0
  509. package/lib/xlsx/xform/sheet/table-part-xform.js +33 -0
  510. package/lib/xlsx/xform/sheet/worksheet-xform.js +657 -0
  511. package/lib/xlsx/xform/simple/boolean-xform.js +31 -0
  512. package/lib/xlsx/xform/simple/date-xform.js +66 -0
  513. package/lib/xlsx/xform/simple/float-xform.js +51 -0
  514. package/lib/xlsx/xform/simple/integer-xform.js +57 -0
  515. package/lib/xlsx/xform/simple/string-xform.js +51 -0
  516. package/lib/xlsx/xform/static-xform.js +64 -0
  517. package/lib/xlsx/xform/strings/phonetic-text-xform.js +98 -0
  518. package/lib/xlsx/xform/strings/rich-text-xform.js +101 -0
  519. package/lib/xlsx/xform/strings/shared-string-xform.js +102 -0
  520. package/lib/xlsx/xform/strings/shared-strings-xform.js +132 -0
  521. package/lib/xlsx/xform/strings/text-xform.js +44 -0
  522. package/lib/xlsx/xform/style/alignment-xform.js +172 -0
  523. package/lib/xlsx/xform/style/border-xform.js +207 -0
  524. package/lib/xlsx/xform/style/color-xform.js +63 -0
  525. package/lib/xlsx/xform/style/dxf-xform.js +111 -0
  526. package/lib/xlsx/xform/style/fill-xform.js +364 -0
  527. package/lib/xlsx/xform/style/font-xform.js +102 -0
  528. package/lib/xlsx/xform/style/numfmt-xform.js +63 -0
  529. package/lib/xlsx/xform/style/protection-xform.js +60 -0
  530. package/lib/xlsx/xform/style/style-xform.js +125 -0
  531. package/lib/xlsx/xform/style/styles-xform.js +527 -0
  532. package/lib/xlsx/xform/style/underline-xform.js +47 -0
  533. package/lib/xlsx/xform/table/auto-filter-xform.js +81 -0
  534. package/lib/xlsx/xform/table/custom-filter-xform.js +33 -0
  535. package/lib/xlsx/xform/table/filter-column-xform.js +99 -0
  536. package/lib/xlsx/xform/table/filter-xform.js +31 -0
  537. package/lib/xlsx/xform/table/table-column-xform.js +44 -0
  538. package/lib/xlsx/xform/table/table-style-info-xform.js +41 -0
  539. package/lib/xlsx/xform/table/table-xform.js +134 -0
  540. package/lib/xlsx/xlsx.js +1160 -0
  541. package/lib/xlsx/xml/theme1.js +3 -0
  542. package/lib/xlsx/xml/theme1.xml +318 -0
  543. package/package.json +159 -0
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+
3
+ const BaseXform = require('../../base-xform');
4
+ class VmlProtectionXform extends BaseXform {
5
+ constructor(model) {
6
+ super();
7
+ this._model = model;
8
+ }
9
+ get tag() {
10
+ return this._model && this._model.tag;
11
+ }
12
+ render(xmlStream, model) {
13
+ xmlStream.leafNode(`x:${this.tag}`, null, model);
14
+ }
15
+ parseOpen(node) {
16
+ switch (node.name) {
17
+ case this.tag:
18
+ this.text = '';
19
+ return true;
20
+ default:
21
+ return false;
22
+ }
23
+ }
24
+ parseText(text) {
25
+ this.text = text;
26
+ }
27
+ parseClose() {
28
+ return false;
29
+ }
30
+ }
31
+ module.exports = VmlProtectionXform;
32
+ //# sourceMappingURL=vml-protection-xform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vml-protection-xform.js","names":["BaseXform","require","VmlProtectionXform","constructor","model","_model","tag","render","xmlStream","leafNode","parseOpen","node","name","text","parseText","parseClose","module","exports"],"sources":["../../../../../../lib/xlsx/xform/comment/style/vml-protection-xform.js"],"sourcesContent":["const BaseXform = require('../../base-xform');\r\n\r\nclass VmlProtectionXform extends BaseXform {\r\n constructor(model) {\r\n super();\r\n this._model = model;\r\n }\r\n\r\n get tag() {\r\n return this._model && this._model.tag;\r\n }\r\n\r\n render(xmlStream, model) {\r\n xmlStream.leafNode(`x:${this.tag}`, null, model);\r\n }\r\n\r\n parseOpen(node) {\r\n switch (node.name) {\r\n case this.tag:\r\n this.text = '';\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n parseText(text) {\r\n this.text = text;\r\n }\r\n\r\n parseClose() {\r\n return false;\r\n }\r\n}\r\n\r\nmodule.exports = VmlProtectionXform;\r\n"],"mappings":";;AAAA,MAAMA,SAAS,GAAGC,OAAO,CAAC,kBAAkB,CAAC;AAE7C,MAAMC,kBAAkB,SAASF,SAAS,CAAC;EACzCG,WAAWA,CAACC,KAAK,EAAE;IACjB,KAAK,CAAC,CAAC;IACP,IAAI,CAACC,MAAM,GAAGD,KAAK;EACrB;EAEA,IAAIE,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACD,MAAM,IAAI,IAAI,CAACA,MAAM,CAACC,GAAG;EACvC;EAEAC,MAAMA,CAACC,SAAS,EAAEJ,KAAK,EAAE;IACvBI,SAAS,CAACC,QAAQ,CAAC,KAAK,IAAI,CAACH,GAAG,EAAE,EAAE,IAAI,EAAEF,KAAK,CAAC;EAClD;EAEAM,SAASA,CAACC,IAAI,EAAE;IACd,QAAQA,IAAI,CAACC,IAAI;MACf,KAAK,IAAI,CAACN,GAAG;QACX,IAAI,CAACO,IAAI,GAAG,EAAE;QACd,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAChB;EACF;EAEAC,SAASA,CAACD,IAAI,EAAE;IACd,IAAI,CAACA,IAAI,GAAGA,IAAI;EAClB;EAEAE,UAAUA,CAAA,EAAG;IACX,OAAO,KAAK;EACd;AACF;AAEAC,MAAM,CAACC,OAAO,GAAGf,kBAAkB","ignoreList":[]}
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+
3
+ const BaseXform = require('../base-xform');
4
+
5
+ // render the triangle in the cell for the comment
6
+ class VmlAnchorXform extends BaseXform {
7
+ get tag() {
8
+ return 'Anchor'; // SAX parser strips 'x:' prefix
9
+ }
10
+ getAnchorRect(anchor) {
11
+ const l = Math.floor(anchor.left);
12
+ const lf = Math.floor((anchor.left - l) * 68);
13
+ const t = Math.floor(anchor.top);
14
+ const tf = Math.floor((anchor.top - t) * 18);
15
+ const r = Math.floor(anchor.right);
16
+ const rf = Math.floor((anchor.right - r) * 68);
17
+ const b = Math.floor(anchor.bottom);
18
+ const bf = Math.floor((anchor.bottom - b) * 18);
19
+ return [l, lf, t, tf, r, rf, b, bf];
20
+ }
21
+ getDefaultRect(ref) {
22
+ const l = ref.col;
23
+ const lf = 6;
24
+ const t = Math.max(ref.row - 2, 0);
25
+ const tf = 14;
26
+ const r = l + 2;
27
+ const rf = 2;
28
+ const b = t + 4;
29
+ const bf = 16;
30
+ return [l, lf, t, tf, r, rf, b, bf];
31
+ }
32
+ render(xmlStream, model) {
33
+ const rect = model.anchor ? this.getAnchorRect(model.anchor) : this.getDefaultRect(model.refAddress);
34
+ xmlStream.leafNode('x:Anchor', null, rect.join(', ')); // Always write with 'x:' prefix
35
+ }
36
+ parseOpen(node) {
37
+ switch (node.name) {
38
+ case this.tag:
39
+ this.text = '';
40
+ return true;
41
+ default:
42
+ return false;
43
+ }
44
+ }
45
+ parseText(text) {
46
+ this.text = text;
47
+ }
48
+ parseClose() {
49
+ return false;
50
+ }
51
+ }
52
+ module.exports = VmlAnchorXform;
53
+ //# sourceMappingURL=vml-anchor-xform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vml-anchor-xform.js","names":["BaseXform","require","VmlAnchorXform","tag","getAnchorRect","anchor","l","Math","floor","left","lf","t","top","tf","r","right","rf","b","bottom","bf","getDefaultRect","ref","col","max","row","render","xmlStream","model","rect","refAddress","leafNode","join","parseOpen","node","name","text","parseText","parseClose","module","exports"],"sources":["../../../../../lib/xlsx/xform/comment/vml-anchor-xform.js"],"sourcesContent":["const BaseXform = require('../base-xform');\r\n\r\n// render the triangle in the cell for the comment\r\nclass VmlAnchorXform extends BaseXform {\r\n get tag() {\r\n return 'Anchor'; // SAX parser strips 'x:' prefix\r\n }\r\n\r\n getAnchorRect(anchor) {\r\n const l = Math.floor(anchor.left);\r\n const lf = Math.floor((anchor.left - l) * 68);\r\n const t = Math.floor(anchor.top);\r\n const tf = Math.floor((anchor.top - t) * 18);\r\n const r = Math.floor(anchor.right);\r\n const rf = Math.floor((anchor.right - r) * 68);\r\n const b = Math.floor(anchor.bottom);\r\n const bf = Math.floor((anchor.bottom - b) * 18);\r\n return [l, lf, t, tf, r, rf, b, bf];\r\n }\r\n\r\n getDefaultRect(ref) {\r\n const l = ref.col;\r\n const lf = 6;\r\n const t = Math.max(ref.row - 2, 0);\r\n const tf = 14;\r\n const r = l + 2;\r\n const rf = 2;\r\n const b = t + 4;\r\n const bf = 16;\r\n return [l, lf, t, tf, r, rf, b, bf];\r\n }\r\n\r\n render(xmlStream, model) {\r\n const rect = model.anchor\r\n ? this.getAnchorRect(model.anchor)\r\n : this.getDefaultRect(model.refAddress);\r\n\r\n xmlStream.leafNode('x:Anchor', null, rect.join(', ')); // Always write with 'x:' prefix\r\n }\r\n\r\n parseOpen(node) {\r\n switch (node.name) {\r\n case this.tag:\r\n this.text = '';\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n parseText(text) {\r\n this.text = text;\r\n }\r\n\r\n parseClose() {\r\n return false;\r\n }\r\n}\r\n\r\nmodule.exports = VmlAnchorXform;\r\n"],"mappings":";;AAAA,MAAMA,SAAS,GAAGC,OAAO,CAAC,eAAe,CAAC;;AAE1C;AACA,MAAMC,cAAc,SAASF,SAAS,CAAC;EACrC,IAAIG,GAAGA,CAAA,EAAG;IACR,OAAO,QAAQ,CAAC,CAAC;EACnB;EAEAC,aAAaA,CAACC,MAAM,EAAE;IACpB,MAAMC,CAAC,GAAGC,IAAI,CAACC,KAAK,CAACH,MAAM,CAACI,IAAI,CAAC;IACjC,MAAMC,EAAE,GAAGH,IAAI,CAACC,KAAK,CAAC,CAACH,MAAM,CAACI,IAAI,GAAGH,CAAC,IAAI,EAAE,CAAC;IAC7C,MAAMK,CAAC,GAAGJ,IAAI,CAACC,KAAK,CAACH,MAAM,CAACO,GAAG,CAAC;IAChC,MAAMC,EAAE,GAAGN,IAAI,CAACC,KAAK,CAAC,CAACH,MAAM,CAACO,GAAG,GAAGD,CAAC,IAAI,EAAE,CAAC;IAC5C,MAAMG,CAAC,GAAGP,IAAI,CAACC,KAAK,CAACH,MAAM,CAACU,KAAK,CAAC;IAClC,MAAMC,EAAE,GAAGT,IAAI,CAACC,KAAK,CAAC,CAACH,MAAM,CAACU,KAAK,GAAGD,CAAC,IAAI,EAAE,CAAC;IAC9C,MAAMG,CAAC,GAAGV,IAAI,CAACC,KAAK,CAACH,MAAM,CAACa,MAAM,CAAC;IACnC,MAAMC,EAAE,GAAGZ,IAAI,CAACC,KAAK,CAAC,CAACH,MAAM,CAACa,MAAM,GAAGD,CAAC,IAAI,EAAE,CAAC;IAC/C,OAAO,CAACX,CAAC,EAAEI,EAAE,EAAEC,CAAC,EAAEE,EAAE,EAAEC,CAAC,EAAEE,EAAE,EAAEC,CAAC,EAAEE,EAAE,CAAC;EACrC;EAEAC,cAAcA,CAACC,GAAG,EAAE;IAClB,MAAMf,CAAC,GAAGe,GAAG,CAACC,GAAG;IACjB,MAAMZ,EAAE,GAAG,CAAC;IACZ,MAAMC,CAAC,GAAGJ,IAAI,CAACgB,GAAG,CAACF,GAAG,CAACG,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;IAClC,MAAMX,EAAE,GAAG,EAAE;IACb,MAAMC,CAAC,GAAGR,CAAC,GAAG,CAAC;IACf,MAAMU,EAAE,GAAG,CAAC;IACZ,MAAMC,CAAC,GAAGN,CAAC,GAAG,CAAC;IACf,MAAMQ,EAAE,GAAG,EAAE;IACb,OAAO,CAACb,CAAC,EAAEI,EAAE,EAAEC,CAAC,EAAEE,EAAE,EAAEC,CAAC,EAAEE,EAAE,EAAEC,CAAC,EAAEE,EAAE,CAAC;EACrC;EAEAM,MAAMA,CAACC,SAAS,EAAEC,KAAK,EAAE;IACvB,MAAMC,IAAI,GAAGD,KAAK,CAACtB,MAAM,GACrB,IAAI,CAACD,aAAa,CAACuB,KAAK,CAACtB,MAAM,CAAC,GAChC,IAAI,CAACe,cAAc,CAACO,KAAK,CAACE,UAAU,CAAC;IAEzCH,SAAS,CAACI,QAAQ,CAAC,UAAU,EAAE,IAAI,EAAEF,IAAI,CAACG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;EACzD;EAEAC,SAASA,CAACC,IAAI,EAAE;IACd,QAAQA,IAAI,CAACC,IAAI;MACf,KAAK,IAAI,CAAC/B,GAAG;QACX,IAAI,CAACgC,IAAI,GAAG,EAAE;QACd,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAChB;EACF;EAEAC,SAASA,CAACD,IAAI,EAAE;IACd,IAAI,CAACA,IAAI,GAAGA,IAAI;EAClB;EAEAE,UAAUA,CAAA,EAAG;IACX,OAAO,KAAK;EACd;AACF;AAEAC,MAAM,CAACC,OAAO,GAAGrC,cAAc","ignoreList":[]}
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+
3
+ const BaseXform = require('../base-xform');
4
+ const VmlAnchorXform = require('./vml-anchor-xform');
5
+ const VmlProtectionXform = require('./style/vml-protection-xform');
6
+ const VmlPositionXform = require('./style/vml-position-xform');
7
+ const POSITION_TYPE = ['twoCells', 'oneCells', 'absolute'];
8
+ class VmlClientDataXform extends BaseXform {
9
+ constructor() {
10
+ super();
11
+ // SAX parser strips 'x:' prefix from Excel namespace elements
12
+ this.map = {
13
+ Anchor: new VmlAnchorXform(),
14
+ Locked: new VmlProtectionXform({
15
+ tag: 'Locked'
16
+ }),
17
+ LockText: new VmlProtectionXform({
18
+ tag: 'LockText'
19
+ }),
20
+ SizeWithCells: new VmlPositionXform({
21
+ tag: 'SizeWithCells'
22
+ }),
23
+ MoveWithCells: new VmlPositionXform({
24
+ tag: 'MoveWithCells'
25
+ })
26
+ };
27
+ }
28
+ get tag() {
29
+ return 'ClientData'; // SAX parser strips 'x:' prefix
30
+ }
31
+ render(xmlStream, model) {
32
+ const {
33
+ protection,
34
+ editAs
35
+ } = model.note;
36
+ xmlStream.openNode('x:ClientData', {
37
+ ObjectType: 'Note'
38
+ }); // Write with prefix
39
+ this.map.MoveWithCells.render(xmlStream, editAs, POSITION_TYPE);
40
+ this.map.SizeWithCells.render(xmlStream, editAs, POSITION_TYPE);
41
+ this.map.Anchor.render(xmlStream, model);
42
+ this.map.Locked.render(xmlStream, protection.locked);
43
+ xmlStream.leafNode('x:AutoFill', null, 'False');
44
+ this.map.LockText.render(xmlStream, protection.lockText);
45
+ xmlStream.leafNode('x:Row', null, model.refAddress.row - 1);
46
+ xmlStream.leafNode('x:Column', null, model.refAddress.col - 1);
47
+ xmlStream.closeNode();
48
+ }
49
+ parseOpen(node) {
50
+ switch (node.name) {
51
+ case this.tag:
52
+ this.reset();
53
+ this.model = {
54
+ anchor: [],
55
+ protection: {},
56
+ editAs: ''
57
+ };
58
+ break;
59
+ default:
60
+ this.parser = this.map[node.name];
61
+ if (this.parser) {
62
+ this.parser.parseOpen(node);
63
+ }
64
+ break;
65
+ }
66
+ return true;
67
+ }
68
+ parseText(text) {
69
+ if (this.parser) {
70
+ this.parser.parseText(text);
71
+ }
72
+ }
73
+ parseClose(name) {
74
+ if (this.parser) {
75
+ if (!this.parser.parseClose(name)) {
76
+ this.parser = undefined;
77
+ }
78
+ return true;
79
+ }
80
+ switch (name) {
81
+ case this.tag:
82
+ this.normalizeModel();
83
+ return false;
84
+ default:
85
+ return true;
86
+ }
87
+ }
88
+ normalizeModel() {
89
+ const position = Object.assign({}, this.map.MoveWithCells.model, this.map.SizeWithCells.model);
90
+ const len = Object.keys(position).length;
91
+ this.model.editAs = POSITION_TYPE[len];
92
+ this.model.anchor = this.map.Anchor.text;
93
+ this.model.protection.locked = this.map.Locked.text;
94
+ this.model.protection.lockText = this.map.LockText.text;
95
+ }
96
+ }
97
+ module.exports = VmlClientDataXform;
98
+ //# sourceMappingURL=vml-client-data-xform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vml-client-data-xform.js","names":["BaseXform","require","VmlAnchorXform","VmlProtectionXform","VmlPositionXform","POSITION_TYPE","VmlClientDataXform","constructor","map","Anchor","Locked","tag","LockText","SizeWithCells","MoveWithCells","render","xmlStream","model","protection","editAs","note","openNode","ObjectType","locked","leafNode","lockText","refAddress","row","col","closeNode","parseOpen","node","name","reset","anchor","parser","parseText","text","parseClose","undefined","normalizeModel","position","Object","assign","len","keys","length","module","exports"],"sources":["../../../../../lib/xlsx/xform/comment/vml-client-data-xform.js"],"sourcesContent":["const BaseXform = require('../base-xform');\r\n\r\nconst VmlAnchorXform = require('./vml-anchor-xform');\r\nconst VmlProtectionXform = require('./style/vml-protection-xform');\r\nconst VmlPositionXform = require('./style/vml-position-xform');\r\n\r\nconst POSITION_TYPE = ['twoCells', 'oneCells', 'absolute'];\r\n\r\nclass VmlClientDataXform extends BaseXform {\r\n constructor() {\r\n super();\r\n // SAX parser strips 'x:' prefix from Excel namespace elements\r\n this.map = {\r\n Anchor: new VmlAnchorXform(),\r\n Locked: new VmlProtectionXform({tag: 'Locked'}),\r\n LockText: new VmlProtectionXform({tag: 'LockText'}),\r\n SizeWithCells: new VmlPositionXform({tag: 'SizeWithCells'}),\r\n MoveWithCells: new VmlPositionXform({tag: 'MoveWithCells'}),\r\n };\r\n }\r\n\r\n get tag() {\r\n return 'ClientData'; // SAX parser strips 'x:' prefix\r\n }\r\n\r\n render(xmlStream, model) {\r\n const {protection, editAs} = model.note;\r\n xmlStream.openNode('x:ClientData', {ObjectType: 'Note'}); // Write with prefix\r\n this.map.MoveWithCells.render(xmlStream, editAs, POSITION_TYPE);\r\n this.map.SizeWithCells.render(xmlStream, editAs, POSITION_TYPE);\r\n this.map.Anchor.render(xmlStream, model);\r\n this.map.Locked.render(xmlStream, protection.locked);\r\n xmlStream.leafNode('x:AutoFill', null, 'False');\r\n this.map.LockText.render(xmlStream, protection.lockText);\r\n xmlStream.leafNode('x:Row', null, model.refAddress.row - 1);\r\n xmlStream.leafNode('x:Column', null, model.refAddress.col - 1);\r\n xmlStream.closeNode();\r\n }\r\n\r\n parseOpen(node) {\r\n switch (node.name) {\r\n case this.tag:\r\n this.reset();\r\n this.model = {\r\n anchor: [],\r\n protection: {},\r\n editAs: '',\r\n };\r\n break;\r\n default:\r\n this.parser = this.map[node.name];\r\n if (this.parser) {\r\n this.parser.parseOpen(node);\r\n }\r\n break;\r\n }\r\n return true;\r\n }\r\n\r\n parseText(text) {\r\n if (this.parser) {\r\n this.parser.parseText(text);\r\n }\r\n }\r\n\r\n parseClose(name) {\r\n if (this.parser) {\r\n if (!this.parser.parseClose(name)) {\r\n this.parser = undefined;\r\n }\r\n return true;\r\n }\r\n switch (name) {\r\n case this.tag:\r\n this.normalizeModel();\r\n return false;\r\n default:\r\n return true;\r\n }\r\n }\r\n\r\n normalizeModel() {\r\n const position = Object.assign({}, this.map.MoveWithCells.model, this.map.SizeWithCells.model);\r\n const len = Object.keys(position).length;\r\n this.model.editAs = POSITION_TYPE[len];\r\n this.model.anchor = this.map.Anchor.text;\r\n this.model.protection.locked = this.map.Locked.text;\r\n this.model.protection.lockText = this.map.LockText.text;\r\n }\r\n}\r\n\r\nmodule.exports = VmlClientDataXform;\r\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,235 @@
1
+ "use strict";
2
+
3
+ const XmlStream = require('../../../utils/xml-stream');
4
+ const BaseXform = require('../base-xform');
5
+ const VmlShapeXform = require('./vml-shape-xform');
6
+ const FormCheckbox = require('../../../doc/form-checkbox');
7
+
8
+ // Unified VML Drawing Xform - Combines Notes (comments) and Form Controls
9
+ // Excel uses a single VML file per worksheet that can contain:
10
+ // - Comment/note shapes (shapetype 202)
11
+ // - Form control shapes (checkbox shapetype 201, etc.)
12
+ class VmlNotesXform extends BaseXform {
13
+ constructor() {
14
+ super();
15
+ this.map = {
16
+ 'v:shape': new VmlShapeXform()
17
+ };
18
+ }
19
+ get tag() {
20
+ return 'xml';
21
+ }
22
+ render(xmlStream, model) {
23
+ const hasComments = model.comments && model.comments.length > 0;
24
+ const hasFormControls = model.formControls && model.formControls.length > 0;
25
+ xmlStream.openXml(XmlStream.StdDocAttributes);
26
+ xmlStream.openNode(this.tag, VmlNotesXform.DRAWING_ATTRIBUTES);
27
+
28
+ // Shape layout - shared by both notes and form controls
29
+ xmlStream.openNode('o:shapelayout', {
30
+ 'v:ext': 'edit'
31
+ });
32
+ xmlStream.leafNode('o:idmap', {
33
+ 'v:ext': 'edit',
34
+ data: 1
35
+ });
36
+ xmlStream.closeNode();
37
+
38
+ // Shapetype 202 for notes/comments
39
+ if (hasComments) {
40
+ xmlStream.openNode('v:shapetype', {
41
+ id: '_x0000_t202',
42
+ coordsize: '21600,21600',
43
+ 'o:spt': 202,
44
+ path: 'm,l,21600r21600,l21600,xe'
45
+ });
46
+ xmlStream.leafNode('v:stroke', {
47
+ joinstyle: 'miter'
48
+ });
49
+ xmlStream.leafNode('v:path', {
50
+ gradientshapeok: 't',
51
+ 'o:connecttype': 'rect'
52
+ });
53
+ xmlStream.closeNode();
54
+ }
55
+
56
+ // Shapetype 201 for form control checkboxes
57
+ if (hasFormControls) {
58
+ xmlStream.openNode('v:shapetype', {
59
+ id: '_x0000_t201',
60
+ coordsize: '21600,21600',
61
+ 'o:spt': '201',
62
+ path: 'm,l,21600r21600,l21600,xe'
63
+ });
64
+ xmlStream.leafNode('v:stroke', {
65
+ joinstyle: 'miter'
66
+ });
67
+ xmlStream.leafNode('v:path', {
68
+ shadowok: 'f',
69
+ 'o:extrusionok': 'f',
70
+ strokeok: 'f',
71
+ fillok: 'f',
72
+ 'o:connecttype': 'rect'
73
+ });
74
+ xmlStream.leafNode('o:lock', {
75
+ 'v:ext': 'edit',
76
+ shapetype: 't'
77
+ });
78
+ xmlStream.closeNode();
79
+ }
80
+
81
+ // Render comment shapes
82
+ if (hasComments) {
83
+ model.comments.forEach((item, index) => {
84
+ this.map['v:shape'].render(xmlStream, item, index);
85
+ });
86
+ }
87
+
88
+ // Render form control shapes
89
+ if (hasFormControls) {
90
+ model.formControls.forEach(control => {
91
+ this._renderCheckboxShape(xmlStream, control);
92
+ });
93
+ }
94
+ xmlStream.closeNode();
95
+ }
96
+
97
+ /**
98
+ * Render a checkbox form control shape
99
+ */
100
+ _renderCheckboxShape(xmlStream, control) {
101
+ const shapeAttrs = {
102
+ id: `_x0000_s${control.shapeId}`,
103
+ type: '#_x0000_t201',
104
+ style: FormCheckbox.getVmlStyle(control),
105
+ 'o:insetmode': 'auto',
106
+ fillcolor: 'buttonFace [67]',
107
+ strokecolor: 'windowText [64]',
108
+ 'o:preferrelative': 't',
109
+ filled: 'f',
110
+ stroked: 'f'
111
+ };
112
+ xmlStream.openNode('v:shape', shapeAttrs);
113
+
114
+ // Fill element
115
+ xmlStream.leafNode('v:fill', {
116
+ 'o:detectmouseclick': 't'
117
+ });
118
+
119
+ // Lock element
120
+ xmlStream.leafNode('o:lock', {
121
+ 'v:ext': 'edit',
122
+ text: 't'
123
+ });
124
+
125
+ // Textbox for label
126
+ if (control.text) {
127
+ xmlStream.openNode('v:textbox', {
128
+ style: 'mso-direction-alt:auto',
129
+ 'o:singleclick': 't'
130
+ });
131
+ xmlStream.openNode('div', {
132
+ style: 'text-align:left'
133
+ });
134
+ xmlStream.openNode('font', {
135
+ face: 'Tahoma',
136
+ size: '160',
137
+ color: 'auto'
138
+ });
139
+ xmlStream.writeText(control.text);
140
+ xmlStream.closeNode(); // font
141
+ xmlStream.closeNode(); // div
142
+ xmlStream.closeNode(); // v:textbox
143
+ }
144
+
145
+ // ClientData - the core of the checkbox control
146
+ xmlStream.openNode('x:ClientData', {
147
+ ObjectType: 'Checkbox'
148
+ });
149
+
150
+ // Anchor position
151
+ xmlStream.openNode('x:Anchor');
152
+ xmlStream.writeText(FormCheckbox.getVmlAnchor(control));
153
+ xmlStream.closeNode();
154
+
155
+ // Print settings
156
+ xmlStream.leafNode('x:PrintObject', undefined, control.print ? 'True' : 'False');
157
+ xmlStream.leafNode('x:AutoFill', undefined, 'False');
158
+ xmlStream.leafNode('x:AutoLine', undefined, 'False');
159
+ xmlStream.leafNode('x:TextVAlign', undefined, 'Center');
160
+
161
+ // Linked cell
162
+ if (control.link) {
163
+ xmlStream.leafNode('x:FmlaLink', undefined, control.link);
164
+ }
165
+
166
+ // 3D appearance
167
+ if (control.noThreeD) {
168
+ xmlStream.leafNode('x:NoThreeD');
169
+ }
170
+
171
+ // Checked state (0 = unchecked, 1 = checked, 2 = mixed)
172
+ xmlStream.leafNode('x:Checked', undefined, String(FormCheckbox.getVmlCheckedValue(control)));
173
+ xmlStream.closeNode(); // x:ClientData
174
+ xmlStream.closeNode(); // v:shape
175
+ }
176
+ parseOpen(node) {
177
+ if (this.parser) {
178
+ this.parser.parseOpen(node);
179
+ return true;
180
+ }
181
+ switch (node.name) {
182
+ case this.tag:
183
+ this.reset();
184
+ this.model = {
185
+ comments: [],
186
+ formControls: []
187
+ };
188
+ break;
189
+ default:
190
+ this.parser = this.map[node.name];
191
+ if (this.parser) {
192
+ this.parser.parseOpen(node);
193
+ }
194
+ break;
195
+ }
196
+ return true;
197
+ }
198
+ parseText(text) {
199
+ if (this.parser) {
200
+ this.parser.parseText(text);
201
+ }
202
+ }
203
+ parseClose(name) {
204
+ if (this.parser) {
205
+ if (!this.parser.parseClose(name)) {
206
+ this.model.comments.push(this.parser.model);
207
+ this.parser = undefined;
208
+ }
209
+ return true;
210
+ }
211
+ switch (name) {
212
+ case this.tag:
213
+ return false;
214
+ default:
215
+ // could be some unrecognised tags
216
+ return true;
217
+ }
218
+ }
219
+ reconcile(model, options) {
220
+ model.anchors.forEach(anchor => {
221
+ if (anchor.br) {
222
+ this.map['xdr:twoCellAnchor'].reconcile(anchor, options);
223
+ } else {
224
+ this.map['xdr:oneCellAnchor'].reconcile(anchor, options);
225
+ }
226
+ });
227
+ }
228
+ }
229
+ VmlNotesXform.DRAWING_ATTRIBUTES = {
230
+ 'xmlns:v': 'urn:schemas-microsoft-com:vml',
231
+ 'xmlns:o': 'urn:schemas-microsoft-com:office:office',
232
+ 'xmlns:x': 'urn:schemas-microsoft-com:office:excel'
233
+ };
234
+ module.exports = VmlNotesXform;
235
+ //# sourceMappingURL=vml-notes-xform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vml-notes-xform.js","names":["XmlStream","require","BaseXform","VmlShapeXform","FormCheckbox","VmlNotesXform","constructor","map","tag","render","xmlStream","model","hasComments","comments","length","hasFormControls","formControls","openXml","StdDocAttributes","openNode","DRAWING_ATTRIBUTES","leafNode","data","closeNode","id","coordsize","path","joinstyle","gradientshapeok","shadowok","strokeok","fillok","shapetype","forEach","item","index","control","_renderCheckboxShape","shapeAttrs","shapeId","type","style","getVmlStyle","fillcolor","strokecolor","filled","stroked","text","face","size","color","writeText","ObjectType","getVmlAnchor","undefined","print","link","noThreeD","String","getVmlCheckedValue","parseOpen","node","parser","name","reset","parseText","parseClose","push","reconcile","options","anchors","anchor","br","module","exports"],"sources":["../../../../../lib/xlsx/xform/comment/vml-notes-xform.js"],"sourcesContent":["const XmlStream = require('../../../utils/xml-stream');\r\n\r\nconst BaseXform = require('../base-xform');\r\nconst VmlShapeXform = require('./vml-shape-xform');\r\nconst FormCheckbox = require('../../../doc/form-checkbox');\r\n\r\n// Unified VML Drawing Xform - Combines Notes (comments) and Form Controls\r\n// Excel uses a single VML file per worksheet that can contain:\r\n// - Comment/note shapes (shapetype 202)\r\n// - Form control shapes (checkbox shapetype 201, etc.)\r\nclass VmlNotesXform extends BaseXform {\r\n constructor() {\r\n super();\r\n this.map = {\r\n 'v:shape': new VmlShapeXform(),\r\n };\r\n }\r\n\r\n get tag() {\r\n return 'xml';\r\n }\r\n\r\n render(xmlStream, model) {\r\n const hasComments = model.comments && model.comments.length > 0;\r\n const hasFormControls = model.formControls && model.formControls.length > 0;\r\n\r\n xmlStream.openXml(XmlStream.StdDocAttributes);\r\n xmlStream.openNode(this.tag, VmlNotesXform.DRAWING_ATTRIBUTES);\r\n\r\n // Shape layout - shared by both notes and form controls\r\n xmlStream.openNode('o:shapelayout', {'v:ext': 'edit'});\r\n xmlStream.leafNode('o:idmap', {'v:ext': 'edit', data: 1});\r\n xmlStream.closeNode();\r\n\r\n // Shapetype 202 for notes/comments\r\n if (hasComments) {\r\n xmlStream.openNode('v:shapetype', {\r\n id: '_x0000_t202',\r\n coordsize: '21600,21600',\r\n 'o:spt': 202,\r\n path: 'm,l,21600r21600,l21600,xe',\r\n });\r\n xmlStream.leafNode('v:stroke', {joinstyle: 'miter'});\r\n xmlStream.leafNode('v:path', {gradientshapeok: 't', 'o:connecttype': 'rect'});\r\n xmlStream.closeNode();\r\n }\r\n\r\n // Shapetype 201 for form control checkboxes\r\n if (hasFormControls) {\r\n xmlStream.openNode('v:shapetype', {\r\n id: '_x0000_t201',\r\n coordsize: '21600,21600',\r\n 'o:spt': '201',\r\n path: 'm,l,21600r21600,l21600,xe',\r\n });\r\n xmlStream.leafNode('v:stroke', {joinstyle: 'miter'});\r\n xmlStream.leafNode('v:path', {\r\n shadowok: 'f',\r\n 'o:extrusionok': 'f',\r\n strokeok: 'f',\r\n fillok: 'f',\r\n 'o:connecttype': 'rect',\r\n });\r\n xmlStream.leafNode('o:lock', {'v:ext': 'edit', shapetype: 't'});\r\n xmlStream.closeNode();\r\n }\r\n\r\n // Render comment shapes\r\n if (hasComments) {\r\n model.comments.forEach((item, index) => {\r\n this.map['v:shape'].render(xmlStream, item, index);\r\n });\r\n }\r\n\r\n // Render form control shapes\r\n if (hasFormControls) {\r\n model.formControls.forEach(control => {\r\n this._renderCheckboxShape(xmlStream, control);\r\n });\r\n }\r\n\r\n xmlStream.closeNode();\r\n }\r\n\r\n /**\r\n * Render a checkbox form control shape\r\n */\r\n _renderCheckboxShape(xmlStream, control) {\r\n const shapeAttrs = {\r\n id: `_x0000_s${control.shapeId}`,\r\n type: '#_x0000_t201',\r\n style: FormCheckbox.getVmlStyle(control),\r\n 'o:insetmode': 'auto',\r\n fillcolor: 'buttonFace [67]',\r\n strokecolor: 'windowText [64]',\r\n 'o:preferrelative': 't',\r\n filled: 'f',\r\n stroked: 'f',\r\n };\r\n\r\n xmlStream.openNode('v:shape', shapeAttrs);\r\n\r\n // Fill element\r\n xmlStream.leafNode('v:fill', {'o:detectmouseclick': 't'});\r\n\r\n // Lock element\r\n xmlStream.leafNode('o:lock', {'v:ext': 'edit', text: 't'});\r\n\r\n // Textbox for label\r\n if (control.text) {\r\n xmlStream.openNode('v:textbox', {\r\n style: 'mso-direction-alt:auto',\r\n 'o:singleclick': 't',\r\n });\r\n xmlStream.openNode('div', {style: 'text-align:left'});\r\n xmlStream.openNode('font', {face: 'Tahoma', size: '160', color: 'auto'});\r\n xmlStream.writeText(control.text);\r\n xmlStream.closeNode(); // font\r\n xmlStream.closeNode(); // div\r\n xmlStream.closeNode(); // v:textbox\r\n }\r\n\r\n // ClientData - the core of the checkbox control\r\n xmlStream.openNode('x:ClientData', {ObjectType: 'Checkbox'});\r\n\r\n // Anchor position\r\n xmlStream.openNode('x:Anchor');\r\n xmlStream.writeText(FormCheckbox.getVmlAnchor(control));\r\n xmlStream.closeNode();\r\n\r\n // Print settings\r\n xmlStream.leafNode('x:PrintObject', undefined, control.print ? 'True' : 'False');\r\n xmlStream.leafNode('x:AutoFill', undefined, 'False');\r\n xmlStream.leafNode('x:AutoLine', undefined, 'False');\r\n xmlStream.leafNode('x:TextVAlign', undefined, 'Center');\r\n\r\n // Linked cell\r\n if (control.link) {\r\n xmlStream.leafNode('x:FmlaLink', undefined, control.link);\r\n }\r\n\r\n // 3D appearance\r\n if (control.noThreeD) {\r\n xmlStream.leafNode('x:NoThreeD');\r\n }\r\n\r\n // Checked state (0 = unchecked, 1 = checked, 2 = mixed)\r\n xmlStream.leafNode('x:Checked', undefined, String(FormCheckbox.getVmlCheckedValue(control)));\r\n\r\n xmlStream.closeNode(); // x:ClientData\r\n xmlStream.closeNode(); // v:shape\r\n }\r\n\r\n parseOpen(node) {\r\n if (this.parser) {\r\n this.parser.parseOpen(node);\r\n return true;\r\n }\r\n switch (node.name) {\r\n case this.tag:\r\n this.reset();\r\n this.model = {\r\n comments: [],\r\n formControls: [],\r\n };\r\n break;\r\n default:\r\n this.parser = this.map[node.name];\r\n if (this.parser) {\r\n this.parser.parseOpen(node);\r\n }\r\n break;\r\n }\r\n return true;\r\n }\r\n\r\n parseText(text) {\r\n if (this.parser) {\r\n this.parser.parseText(text);\r\n }\r\n }\r\n\r\n parseClose(name) {\r\n if (this.parser) {\r\n if (!this.parser.parseClose(name)) {\r\n this.model.comments.push(this.parser.model);\r\n this.parser = undefined;\r\n }\r\n return true;\r\n }\r\n switch (name) {\r\n case this.tag:\r\n return false;\r\n default:\r\n // could be some unrecognised tags\r\n return true;\r\n }\r\n }\r\n\r\n reconcile(model, options) {\r\n model.anchors.forEach(anchor => {\r\n if (anchor.br) {\r\n this.map['xdr:twoCellAnchor'].reconcile(anchor, options);\r\n } else {\r\n this.map['xdr:oneCellAnchor'].reconcile(anchor, options);\r\n }\r\n });\r\n }\r\n}\r\n\r\nVmlNotesXform.DRAWING_ATTRIBUTES = {\r\n 'xmlns:v': 'urn:schemas-microsoft-com:vml',\r\n 'xmlns:o': 'urn:schemas-microsoft-com:office:office',\r\n 'xmlns:x': 'urn:schemas-microsoft-com:office:excel',\r\n};\r\n\r\nmodule.exports = VmlNotesXform;\r\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+
3
+ const BaseXform = require('../base-xform');
4
+ const VmlTextboxXform = require('./vml-textbox-xform');
5
+ const VmlClientDataXform = require('./vml-client-data-xform');
6
+ class VmlShapeXform extends BaseXform {
7
+ constructor() {
8
+ super();
9
+ // SAX parser strips 'x:' prefix but keeps 'v:' and 'o:' prefixes
10
+ this.map = {
11
+ 'v:textbox': new VmlTextboxXform(),
12
+ ClientData: new VmlClientDataXform()
13
+ };
14
+ }
15
+ get tag() {
16
+ return 'v:shape';
17
+ }
18
+ render(xmlStream, model, index) {
19
+ xmlStream.openNode('v:shape', VmlShapeXform.V_SHAPE_ATTRIBUTES(model, index));
20
+ xmlStream.leafNode('v:fill', {
21
+ color2: 'infoBackground [80]'
22
+ });
23
+ xmlStream.leafNode('v:shadow', {
24
+ color: 'none [81]',
25
+ obscured: 't'
26
+ });
27
+ xmlStream.leafNode('v:path', {
28
+ 'o:connecttype': 'none'
29
+ });
30
+ this.map['v:textbox'].render(xmlStream, model);
31
+ this.map.ClientData.render(xmlStream, model);
32
+ xmlStream.closeNode();
33
+ }
34
+ parseOpen(node) {
35
+ if (this.parser) {
36
+ this.parser.parseOpen(node);
37
+ return true;
38
+ }
39
+ switch (node.name) {
40
+ case this.tag:
41
+ this.reset();
42
+ this.model = {
43
+ margins: {
44
+ insetmode: node.attributes['o:insetmode']
45
+ },
46
+ anchor: '',
47
+ editAs: '',
48
+ protection: {}
49
+ };
50
+ break;
51
+ default:
52
+ this.parser = this.map[node.name];
53
+ if (this.parser) {
54
+ this.parser.parseOpen(node);
55
+ }
56
+ break;
57
+ }
58
+ return true;
59
+ }
60
+ parseText(text) {
61
+ if (this.parser) {
62
+ this.parser.parseText(text);
63
+ }
64
+ }
65
+ parseClose(name) {
66
+ if (this.parser) {
67
+ if (!this.parser.parseClose(name)) {
68
+ this.parser = undefined;
69
+ }
70
+ return true;
71
+ }
72
+ switch (name) {
73
+ case this.tag:
74
+ this.model.margins.inset = this.map['v:textbox'].model && this.map['v:textbox'].model.inset;
75
+ this.model.protection = this.map.ClientData.model && this.map.ClientData.model.protection;
76
+ this.model.anchor = this.map.ClientData.model && this.map.ClientData.model.anchor;
77
+ this.model.editAs = this.map.ClientData.model && this.map.ClientData.model.editAs;
78
+ return false;
79
+ default:
80
+ return true;
81
+ }
82
+ }
83
+ }
84
+ VmlShapeXform.V_SHAPE_ATTRIBUTES = (model, index) => ({
85
+ id: `_x0000_s${1025 + index}`,
86
+ type: '#_x0000_t202',
87
+ style: 'position:absolute; margin-left:105.3pt;margin-top:10.5pt;width:97.8pt;height:59.1pt;z-index:1;visibility:hidden',
88
+ fillcolor: 'infoBackground [80]',
89
+ strokecolor: 'none [81]',
90
+ 'o:insetmode': model.note.margins && model.note.margins.insetmode
91
+ });
92
+ module.exports = VmlShapeXform;
93
+ //# sourceMappingURL=vml-shape-xform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vml-shape-xform.js","names":["BaseXform","require","VmlTextboxXform","VmlClientDataXform","VmlShapeXform","constructor","map","ClientData","tag","render","xmlStream","model","index","openNode","V_SHAPE_ATTRIBUTES","leafNode","color2","color","obscured","closeNode","parseOpen","node","parser","name","reset","margins","insetmode","attributes","anchor","editAs","protection","parseText","text","parseClose","undefined","inset","id","type","style","fillcolor","strokecolor","note","module","exports"],"sources":["../../../../../lib/xlsx/xform/comment/vml-shape-xform.js"],"sourcesContent":["const BaseXform = require('../base-xform');\r\nconst VmlTextboxXform = require('./vml-textbox-xform');\r\nconst VmlClientDataXform = require('./vml-client-data-xform');\r\n\r\nclass VmlShapeXform extends BaseXform {\r\n constructor() {\r\n super();\r\n // SAX parser strips 'x:' prefix but keeps 'v:' and 'o:' prefixes\r\n this.map = {\r\n 'v:textbox': new VmlTextboxXform(),\r\n ClientData: new VmlClientDataXform(),\r\n };\r\n }\r\n\r\n get tag() {\r\n return 'v:shape';\r\n }\r\n\r\n render(xmlStream, model, index) {\r\n xmlStream.openNode('v:shape', VmlShapeXform.V_SHAPE_ATTRIBUTES(model, index));\r\n\r\n xmlStream.leafNode('v:fill', {color2: 'infoBackground [80]'});\r\n xmlStream.leafNode('v:shadow', {color: 'none [81]', obscured: 't'});\r\n xmlStream.leafNode('v:path', {'o:connecttype': 'none'});\r\n this.map['v:textbox'].render(xmlStream, model);\r\n this.map.ClientData.render(xmlStream, model);\r\n\r\n xmlStream.closeNode();\r\n }\r\n\r\n parseOpen(node) {\r\n if (this.parser) {\r\n this.parser.parseOpen(node);\r\n return true;\r\n }\r\n\r\n switch (node.name) {\r\n case this.tag:\r\n this.reset();\r\n this.model = {\r\n margins: {\r\n insetmode: node.attributes['o:insetmode'],\r\n },\r\n anchor: '',\r\n editAs: '',\r\n protection: {},\r\n };\r\n break;\r\n default:\r\n this.parser = this.map[node.name];\r\n if (this.parser) {\r\n this.parser.parseOpen(node);\r\n }\r\n break;\r\n }\r\n return true;\r\n }\r\n\r\n parseText(text) {\r\n if (this.parser) {\r\n this.parser.parseText(text);\r\n }\r\n }\r\n\r\n parseClose(name) {\r\n if (this.parser) {\r\n if (!this.parser.parseClose(name)) {\r\n this.parser = undefined;\r\n }\r\n return true;\r\n }\r\n switch (name) {\r\n case this.tag:\r\n this.model.margins.inset = this.map['v:textbox'].model && this.map['v:textbox'].model.inset;\r\n this.model.protection = this.map.ClientData.model && this.map.ClientData.model.protection;\r\n this.model.anchor = this.map.ClientData.model && this.map.ClientData.model.anchor;\r\n this.model.editAs = this.map.ClientData.model && this.map.ClientData.model.editAs;\r\n return false;\r\n default:\r\n return true;\r\n }\r\n }\r\n}\r\n\r\nVmlShapeXform.V_SHAPE_ATTRIBUTES = (model, index) => ({\r\n id: `_x0000_s${1025 + index}`,\r\n type: '#_x0000_t202',\r\n style:\r\n 'position:absolute; margin-left:105.3pt;margin-top:10.5pt;width:97.8pt;height:59.1pt;z-index:1;visibility:hidden',\r\n fillcolor: 'infoBackground [80]',\r\n strokecolor: 'none [81]',\r\n 'o:insetmode': model.note.margins && model.note.margins.insetmode,\r\n});\r\n\r\nmodule.exports = VmlShapeXform;\r\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ const BaseXform = require('../base-xform');
4
+ class VmlTextboxXform extends BaseXform {
5
+ get tag() {
6
+ return 'v:textbox';
7
+ }
8
+ conversionUnit(value, multiple, unit) {
9
+ return `${parseFloat(value) * multiple.toFixed(2)}${unit}`;
10
+ }
11
+ reverseConversionUnit(inset) {
12
+ return (inset || '').split(',').map(margin => {
13
+ return Number(parseFloat(this.conversionUnit(parseFloat(margin), 0.1, '')).toFixed(2));
14
+ });
15
+ }
16
+ render(xmlStream, model) {
17
+ const attributes = {
18
+ style: 'mso-direction-alt:auto'
19
+ };
20
+ if (model && model.note) {
21
+ let {
22
+ inset
23
+ } = model.note && model.note.margins;
24
+ if (Array.isArray(inset)) {
25
+ inset = inset.map(margin => {
26
+ return this.conversionUnit(margin, 10, 'mm');
27
+ }).join(',');
28
+ }
29
+ if (inset) {
30
+ attributes.inset = inset;
31
+ }
32
+ }
33
+ xmlStream.openNode('v:textbox', attributes);
34
+ xmlStream.leafNode('div', {
35
+ style: 'text-align:left'
36
+ });
37
+ xmlStream.closeNode();
38
+ }
39
+ parseOpen(node) {
40
+ switch (node.name) {
41
+ case this.tag:
42
+ this.model = {
43
+ inset: this.reverseConversionUnit(node.attributes.inset)
44
+ };
45
+ return true;
46
+ default:
47
+ return true;
48
+ }
49
+ }
50
+ parseText() {}
51
+ parseClose(name) {
52
+ switch (name) {
53
+ case this.tag:
54
+ return false;
55
+ default:
56
+ return true;
57
+ }
58
+ }
59
+ }
60
+ module.exports = VmlTextboxXform;
61
+ //# sourceMappingURL=vml-textbox-xform.js.map