@yuanliwei/exceljs 4.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (185) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +3024 -0
  3. package/README_zh.md +2878 -0
  4. package/excel.js +13 -0
  5. package/index.d.ts +2040 -0
  6. package/index.ts +2 -0
  7. package/lib/csv/csv.js +191 -0
  8. package/lib/csv/line-buffer.js +74 -0
  9. package/lib/csv/stream-converter.js +135 -0
  10. package/lib/doc/anchor.js +91 -0
  11. package/lib/doc/cell.js +1124 -0
  12. package/lib/doc/column.js +320 -0
  13. package/lib/doc/data/theme1.json +234 -0
  14. package/lib/doc/data-validations.js +19 -0
  15. package/lib/doc/defined-names.js +196 -0
  16. package/lib/doc/enums.js +48 -0
  17. package/lib/doc/image.js +59 -0
  18. package/lib/doc/modelcontainer.js +18 -0
  19. package/lib/doc/note.js +65 -0
  20. package/lib/doc/pivot-table.js +132 -0
  21. package/lib/doc/range.js +257 -0
  22. package/lib/doc/row.js +415 -0
  23. package/lib/doc/table.js +465 -0
  24. package/lib/doc/workbook.js +224 -0
  25. package/lib/doc/worksheet.js +949 -0
  26. package/lib/exceljs.bare.js +13 -0
  27. package/lib/exceljs.browser.js +36 -0
  28. package/lib/exceljs.nodejs.js +14 -0
  29. package/lib/stream/xlsx/hyperlink-reader.js +83 -0
  30. package/lib/stream/xlsx/sheet-comments-writer.js +121 -0
  31. package/lib/stream/xlsx/sheet-rels-writer.js +119 -0
  32. package/lib/stream/xlsx/workbook-reader.js +337 -0
  33. package/lib/stream/xlsx/workbook-writer.js +347 -0
  34. package/lib/stream/xlsx/worksheet-reader.js +374 -0
  35. package/lib/stream/xlsx/worksheet-writer.js +717 -0
  36. package/lib/utils/auto-drain.js +15 -0
  37. package/lib/utils/browser-buffer-decode.js +14 -0
  38. package/lib/utils/browser-buffer-encode.js +15 -0
  39. package/lib/utils/cell-matrix.js +165 -0
  40. package/lib/utils/col-cache.js +287 -0
  41. package/lib/utils/copy-style.js +43 -0
  42. package/lib/utils/encryptor.js +55 -0
  43. package/lib/utils/iterate-stream.js +48 -0
  44. package/lib/utils/parse-sax.js +30 -0
  45. package/lib/utils/shared-formula.js +44 -0
  46. package/lib/utils/shared-strings.js +35 -0
  47. package/lib/utils/stream-base64.js +72 -0
  48. package/lib/utils/stream-buf.js +364 -0
  49. package/lib/utils/string-buf.js +82 -0
  50. package/lib/utils/string-builder.js +35 -0
  51. package/lib/utils/stuttered-pipe.js +67 -0
  52. package/lib/utils/typed-stack.js +24 -0
  53. package/lib/utils/under-dash.js +184 -0
  54. package/lib/utils/utils.js +205 -0
  55. package/lib/utils/xml-stream.js +169 -0
  56. package/lib/utils/zip-stream.js +87 -0
  57. package/lib/xlsx/.rels +11 -0
  58. package/lib/xlsx/calcChain.xml +6 -0
  59. package/lib/xlsx/core.xml +7 -0
  60. package/lib/xlsx/defaultnumformats.js +153 -0
  61. package/lib/xlsx/rel-type.js +20 -0
  62. package/lib/xlsx/styles.xml +41 -0
  63. package/lib/xlsx/workbook.xml +16 -0
  64. package/lib/xlsx/xform/base-xform.js +145 -0
  65. package/lib/xlsx/xform/book/defined-name-xform.js +91 -0
  66. package/lib/xlsx/xform/book/sheet-xform.js +34 -0
  67. package/lib/xlsx/xform/book/workbook-calc-properties-xform.js +26 -0
  68. package/lib/xlsx/xform/book/workbook-pivot-cache-xform.js +29 -0
  69. package/lib/xlsx/xform/book/workbook-properties-xform.js +29 -0
  70. package/lib/xlsx/xform/book/workbook-view-xform.js +53 -0
  71. package/lib/xlsx/xform/book/workbook-xform.js +259 -0
  72. package/lib/xlsx/xform/comment/comment-xform.js +105 -0
  73. package/lib/xlsx/xform/comment/comments-xform.js +82 -0
  74. package/lib/xlsx/xform/comment/style/vml-position-xform.js +39 -0
  75. package/lib/xlsx/xform/comment/style/vml-protection-xform.js +36 -0
  76. package/lib/xlsx/xform/comment/vml-anchor-xform.js +60 -0
  77. package/lib/xlsx/xform/comment/vml-client-data-xform.js +95 -0
  78. package/lib/xlsx/xform/comment/vml-notes-xform.js +107 -0
  79. package/lib/xlsx/xform/comment/vml-shape-xform.js +95 -0
  80. package/lib/xlsx/xform/comment/vml-textbox-xform.js +64 -0
  81. package/lib/xlsx/xform/composite-xform.js +56 -0
  82. package/lib/xlsx/xform/core/app-heading-pairs-xform.js +32 -0
  83. package/lib/xlsx/xform/core/app-titles-of-parts-xform.js +28 -0
  84. package/lib/xlsx/xform/core/app-xform.js +100 -0
  85. package/lib/xlsx/xform/core/content-types-xform.js +135 -0
  86. package/lib/xlsx/xform/core/core-xform.js +136 -0
  87. package/lib/xlsx/xform/core/relationship-xform.js +25 -0
  88. package/lib/xlsx/xform/core/relationships-xform.js +73 -0
  89. package/lib/xlsx/xform/drawing/base-cell-anchor-xform.js +48 -0
  90. package/lib/xlsx/xform/drawing/blip-fill-xform.js +71 -0
  91. package/lib/xlsx/xform/drawing/blip-xform.js +42 -0
  92. package/lib/xlsx/xform/drawing/c-nv-pic-pr-xform.js +38 -0
  93. package/lib/xlsx/xform/drawing/c-nv-pr-xform.js +68 -0
  94. package/lib/xlsx/xform/drawing/cell-position-xform.js +77 -0
  95. package/lib/xlsx/xform/drawing/drawing-xform.js +109 -0
  96. package/lib/xlsx/xform/drawing/ext-lst-xform.js +43 -0
  97. package/lib/xlsx/xform/drawing/ext-xform.js +44 -0
  98. package/lib/xlsx/xform/drawing/hlink-click-xform.js +41 -0
  99. package/lib/xlsx/xform/drawing/nv-pic-pr-xform.js +65 -0
  100. package/lib/xlsx/xform/drawing/one-cell-anchor-xform.js +63 -0
  101. package/lib/xlsx/xform/drawing/pic-xform.js +77 -0
  102. package/lib/xlsx/xform/drawing/sp-pr.js +17 -0
  103. package/lib/xlsx/xform/drawing/two-cell-anchor-xform.js +62 -0
  104. package/lib/xlsx/xform/list-xform.js +95 -0
  105. package/lib/xlsx/xform/pivot-table/cache-field.js +43 -0
  106. package/lib/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +77 -0
  107. package/lib/xlsx/xform/pivot-table/pivot-cache-records-xform.js +103 -0
  108. package/lib/xlsx/xform/pivot-table/pivot-table-xform.js +189 -0
  109. package/lib/xlsx/xform/sheet/auto-filter-xform.js +38 -0
  110. package/lib/xlsx/xform/sheet/cell-xform.js +498 -0
  111. package/lib/xlsx/xform/sheet/cf/cf-rule-xform.js +301 -0
  112. package/lib/xlsx/xform/sheet/cf/cfvo-xform.js +27 -0
  113. package/lib/xlsx/xform/sheet/cf/color-scale-xform.js +45 -0
  114. package/lib/xlsx/xform/sheet/cf/conditional-formatting-xform.js +48 -0
  115. package/lib/xlsx/xform/sheet/cf/conditional-formattings-xform.js +92 -0
  116. package/lib/xlsx/xform/sheet/cf/databar-xform.js +49 -0
  117. package/lib/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +87 -0
  118. package/lib/xlsx/xform/sheet/cf/formula-xform.js +25 -0
  119. package/lib/xlsx/xform/sheet/cf/icon-set-xform.js +47 -0
  120. package/lib/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +27 -0
  121. package/lib/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +98 -0
  122. package/lib/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +43 -0
  123. package/lib/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +62 -0
  124. package/lib/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +50 -0
  125. package/lib/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +98 -0
  126. package/lib/xlsx/xform/sheet/cf-ext/f-ext-xform.js +25 -0
  127. package/lib/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +73 -0
  128. package/lib/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +25 -0
  129. package/lib/xlsx/xform/sheet/col-xform.js +86 -0
  130. package/lib/xlsx/xform/sheet/data-validations-xform.js +257 -0
  131. package/lib/xlsx/xform/sheet/dimension-xform.js +29 -0
  132. package/lib/xlsx/xform/sheet/drawing-xform.js +33 -0
  133. package/lib/xlsx/xform/sheet/ext-lst-xform.js +86 -0
  134. package/lib/xlsx/xform/sheet/header-footer-xform.js +146 -0
  135. package/lib/xlsx/xform/sheet/hyperlink-xform.js +54 -0
  136. package/lib/xlsx/xform/sheet/merge-cell-xform.js +27 -0
  137. package/lib/xlsx/xform/sheet/merges.js +56 -0
  138. package/lib/xlsx/xform/sheet/outline-properties-xform.js +43 -0
  139. package/lib/xlsx/xform/sheet/page-breaks-xform.js +27 -0
  140. package/lib/xlsx/xform/sheet/page-margins-xform.js +49 -0
  141. package/lib/xlsx/xform/sheet/page-setup-properties-xform.js +35 -0
  142. package/lib/xlsx/xform/sheet/page-setup-xform.js +103 -0
  143. package/lib/xlsx/xform/sheet/picture-xform.js +33 -0
  144. package/lib/xlsx/xform/sheet/print-options-xform.js +49 -0
  145. package/lib/xlsx/xform/sheet/row-breaks-xform.js +39 -0
  146. package/lib/xlsx/xform/sheet/row-xform.js +142 -0
  147. package/lib/xlsx/xform/sheet/sheet-format-properties-xform.js +55 -0
  148. package/lib/xlsx/xform/sheet/sheet-properties-xform.js +90 -0
  149. package/lib/xlsx/xform/sheet/sheet-protection-xform.js +89 -0
  150. package/lib/xlsx/xform/sheet/sheet-view-xform.js +202 -0
  151. package/lib/xlsx/xform/sheet/table-part-xform.js +33 -0
  152. package/lib/xlsx/xform/sheet/worksheet-xform.js +548 -0
  153. package/lib/xlsx/xform/simple/boolean-xform.js +31 -0
  154. package/lib/xlsx/xform/simple/date-xform.js +66 -0
  155. package/lib/xlsx/xform/simple/float-xform.js +51 -0
  156. package/lib/xlsx/xform/simple/integer-xform.js +57 -0
  157. package/lib/xlsx/xform/simple/string-xform.js +51 -0
  158. package/lib/xlsx/xform/static-xform.js +64 -0
  159. package/lib/xlsx/xform/strings/phonetic-text-xform.js +98 -0
  160. package/lib/xlsx/xform/strings/rich-text-xform.js +101 -0
  161. package/lib/xlsx/xform/strings/shared-string-xform.js +102 -0
  162. package/lib/xlsx/xform/strings/shared-strings-xform.js +127 -0
  163. package/lib/xlsx/xform/strings/text-xform.js +44 -0
  164. package/lib/xlsx/xform/style/alignment-xform.js +172 -0
  165. package/lib/xlsx/xform/style/border-xform.js +207 -0
  166. package/lib/xlsx/xform/style/color-xform.js +63 -0
  167. package/lib/xlsx/xform/style/dxf-xform.js +111 -0
  168. package/lib/xlsx/xform/style/fill-xform.js +364 -0
  169. package/lib/xlsx/xform/style/font-xform.js +102 -0
  170. package/lib/xlsx/xform/style/numfmt-xform.js +63 -0
  171. package/lib/xlsx/xform/style/protection-xform.js +60 -0
  172. package/lib/xlsx/xform/style/style-xform.js +125 -0
  173. package/lib/xlsx/xform/style/styles-xform.js +527 -0
  174. package/lib/xlsx/xform/style/underline-xform.js +47 -0
  175. package/lib/xlsx/xform/table/auto-filter-xform.js +81 -0
  176. package/lib/xlsx/xform/table/custom-filter-xform.js +33 -0
  177. package/lib/xlsx/xform/table/filter-column-xform.js +96 -0
  178. package/lib/xlsx/xform/table/filter-xform.js +31 -0
  179. package/lib/xlsx/xform/table/table-column-xform.js +44 -0
  180. package/lib/xlsx/xform/table/table-style-info-xform.js +41 -0
  181. package/lib/xlsx/xform/table/table-xform.js +131 -0
  182. package/lib/xlsx/xlsx.js +774 -0
  183. package/lib/xlsx/xml/theme1.js +3 -0
  184. package/lib/xlsx/xml/theme1.xml +318 -0
  185. package/package.json +149 -0
@@ -0,0 +1,103 @@
1
+ const XmlStream = require('../../../utils/xml-stream');
2
+
3
+ const BaseXform = require('../base-xform');
4
+
5
+ class PivotCacheRecordsXform extends BaseXform {
6
+ constructor() {
7
+ super();
8
+
9
+ this.map = {};
10
+ }
11
+
12
+ prepare(model) {
13
+ // TK
14
+ }
15
+
16
+ get tag() {
17
+ // http://www.datypic.com/sc/ooxml/e-ssml_pivotCacheRecords.html
18
+ return 'pivotCacheRecords';
19
+ }
20
+
21
+ render(xmlStream, model) {
22
+ const {sourceSheet, cacheFields} = model;
23
+ const sourceBodyRows = sourceSheet.getSheetValues().slice(2);
24
+
25
+ xmlStream.openXml(XmlStream.StdDocAttributes);
26
+ xmlStream.openNode(this.tag, {
27
+ ...PivotCacheRecordsXform.PIVOT_CACHE_RECORDS_ATTRIBUTES,
28
+ count: sourceBodyRows.length,
29
+ });
30
+ xmlStream.writeXml(renderTable());
31
+ xmlStream.closeNode();
32
+
33
+ // Helpers
34
+
35
+ function renderTable() {
36
+ const rowsInXML = sourceBodyRows.map(row => {
37
+ const realRow = row.slice(1);
38
+ return [...renderRowLines(realRow)].join('');
39
+ });
40
+ return rowsInXML.join('');
41
+ }
42
+
43
+ function* renderRowLines(row) {
44
+ // PivotCache Record: http://www.datypic.com/sc/ooxml/e-ssml_r-1.html
45
+ // Note: pretty-printing this for now to ease debugging.
46
+ yield '\n <r>';
47
+ for (const [index, cellValue] of row.entries()) {
48
+ yield '\n ';
49
+ yield renderCell(cellValue, cacheFields[index].sharedItems);
50
+ }
51
+ yield '\n </r>';
52
+ }
53
+
54
+ function renderCell(value, sharedItems) {
55
+ // no shared items
56
+ // --------------------------------------------------
57
+ if (sharedItems === null) {
58
+ if (Number.isFinite(value)) {
59
+ // Numeric value: http://www.datypic.com/sc/ooxml/e-ssml_n-2.html
60
+ return `<n v="${value}" />`;
61
+ }
62
+ // Character Value: http://www.datypic.com/sc/ooxml/e-ssml_s-2.html
63
+ return `<s v="${value}" />`;
64
+
65
+ }
66
+
67
+ // shared items
68
+ // --------------------------------------------------
69
+ const sharedItemsIndex = sharedItems.indexOf(value);
70
+ if (sharedItemsIndex < 0) {
71
+ throw new Error(`${JSON.stringify(value)} not in sharedItems ${JSON.stringify(sharedItems)}`);
72
+ }
73
+ // Shared Items Index: http://www.datypic.com/sc/ooxml/e-ssml_x-9.html
74
+ return `<x v="${sharedItemsIndex}" />`;
75
+ }
76
+ }
77
+
78
+ parseOpen(node) {
79
+ // TK
80
+ }
81
+
82
+ parseText(text) {
83
+ // TK
84
+ }
85
+
86
+ parseClose(name) {
87
+ // TK
88
+ }
89
+
90
+ reconcile(model, options) {
91
+ // TK
92
+ }
93
+ }
94
+
95
+ PivotCacheRecordsXform.PIVOT_CACHE_RECORDS_ATTRIBUTES = {
96
+ xmlns: 'http://schemas.openxmlformats.org/spreadsheetml/2006/main',
97
+ 'xmlns:r': 'http://schemas.openxmlformats.org/officeDocument/2006/relationships',
98
+ 'xmlns:mc': 'http://schemas.openxmlformats.org/markup-compatibility/2006',
99
+ 'mc:Ignorable': 'xr',
100
+ 'xmlns:xr': 'http://schemas.microsoft.com/office/spreadsheetml/2014/revision',
101
+ };
102
+
103
+ module.exports = PivotCacheRecordsXform;
@@ -0,0 +1,189 @@
1
+ const XmlStream = require('../../../utils/xml-stream');
2
+ const BaseXform = require('../base-xform');
3
+
4
+ class PivotTableXform extends BaseXform {
5
+ constructor() {
6
+ super();
7
+
8
+ this.map = {};
9
+ }
10
+
11
+ prepare(model) {
12
+ // TK
13
+ }
14
+
15
+ get tag() {
16
+ // http://www.datypic.com/sc/ooxml/e-ssml_pivotTableDefinition.html
17
+ return 'pivotTableDefinition';
18
+ }
19
+
20
+ render(xmlStream, model) {
21
+ // eslint-disable-next-line no-unused-vars
22
+ const {rows, columns, values, metric, cacheFields, cacheId} = model;
23
+
24
+ // Examples
25
+ // --------
26
+ // rows: [0, 1], // only 2 items possible for now
27
+ // columns: [2], // only 1 item possible for now
28
+ // values: [4], // only 1 item possible for now
29
+ // metric: 'sum', // only 'sum' possible for now
30
+ //
31
+ // the numbers are indices into `cacheFields`.
32
+
33
+ xmlStream.openXml(XmlStream.StdDocAttributes);
34
+ xmlStream.openNode(this.tag, {
35
+ ...PivotTableXform.PIVOT_TABLE_ATTRIBUTES,
36
+ 'xr:uid': '{267EE50F-B116-784D-8DC2-BA77DE3F4F4A}',
37
+ name: 'PivotTable2',
38
+ cacheId,
39
+ applyNumberFormats: '0',
40
+ applyBorderFormats: '0',
41
+ applyFontFormats: '0',
42
+ applyPatternFormats: '0',
43
+ applyAlignmentFormats: '0',
44
+ applyWidthHeightFormats: '1',
45
+ dataCaption: 'Values',
46
+ updatedVersion: '8',
47
+ minRefreshableVersion: '3',
48
+ useAutoFormatting: '1',
49
+ itemPrintTitles: '1',
50
+ createdVersion: '8',
51
+ indent: '0',
52
+ compact: '0',
53
+ compactData: '0',
54
+ multipleFieldFilters: '0',
55
+ });
56
+
57
+ // Note: keeping this pretty-printed and verbose for now to ease debugging.
58
+ //
59
+ // location: ref="A3:E15"
60
+ // pivotFields
61
+ // rowFields and rowItems
62
+ // colFields and colItems
63
+ // dataFields
64
+ // pivotTableStyleInfo
65
+ xmlStream.writeXml(`
66
+ <location ref="A3:E15" firstHeaderRow="1" firstDataRow="2" firstDataCol="1" />
67
+ <pivotFields count="${cacheFields.length}">
68
+ ${renderPivotFields(model)}
69
+ </pivotFields>
70
+ <rowFields count="${rows.length}">
71
+ ${rows.map(rowIndex => `<field x="${rowIndex}" />`).join('\n ')}
72
+ </rowFields>
73
+ <rowItems count="1">
74
+ <i t="grand"><x /></i>
75
+ </rowItems>
76
+ <colFields count="${columns.length}">
77
+ ${columns.map(columnIndex => `<field x="${columnIndex}" />`).join('\n ')}
78
+ </colFields>
79
+ <colItems count="1">
80
+ <i t="grand"><x /></i>
81
+ </colItems>
82
+ <dataFields count="${values.length}">
83
+ <dataField
84
+ name="Sum of ${cacheFields[values[0]].name}"
85
+ fld="${values[0]}"
86
+ baseField="0"
87
+ baseItem="0"
88
+ />
89
+ </dataFields>
90
+ <pivotTableStyleInfo
91
+ name="PivotStyleLight16"
92
+ showRowHeaders="1"
93
+ showColHeaders="1"
94
+ showRowStripes="0"
95
+ showColStripes="0"
96
+ showLastColumn="1"
97
+ />
98
+ <extLst>
99
+ <ext
100
+ uri="{962EF5D1-5CA2-4c93-8EF4-DBF5C05439D2}"
101
+ xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main"
102
+ >
103
+ <x14:pivotTableDefinition
104
+ hideValuesRow="1"
105
+ xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main"
106
+ />
107
+ </ext>
108
+ <ext
109
+ uri="{747A6164-185A-40DC-8AA5-F01512510D54}"
110
+ xmlns:xpdl="http://schemas.microsoft.com/office/spreadsheetml/2016/pivotdefaultlayout"
111
+ >
112
+ <xpdl:pivotTableDefinition16
113
+ EnabledSubtotalsDefault="0"
114
+ SubtotalsOnTopDefault="0"
115
+ />
116
+ </ext>
117
+ </extLst>
118
+ `);
119
+
120
+ xmlStream.closeNode();
121
+ }
122
+
123
+ parseOpen(node) {
124
+ // TK
125
+ }
126
+
127
+ parseText(text) {
128
+ // TK
129
+ }
130
+
131
+ parseClose(name) {
132
+ // TK
133
+ }
134
+
135
+ reconcile(model, options) {
136
+ // TK
137
+ }
138
+ }
139
+
140
+ // Helpers
141
+
142
+ function renderPivotFields(pivotTable) {
143
+ /* eslint-disable no-nested-ternary */
144
+ return pivotTable.cacheFields
145
+ .map((cacheField, fieldIndex) => {
146
+ const fieldType =
147
+ pivotTable.rows.indexOf(fieldIndex) >= 0
148
+ ? 'row'
149
+ : pivotTable.columns.indexOf(fieldIndex) >= 0
150
+ ? 'column'
151
+ : pivotTable.values.indexOf(fieldIndex) >= 0
152
+ ? 'value'
153
+ : null;
154
+ return renderPivotField(fieldType, cacheField.sharedItems);
155
+ })
156
+ .join('');
157
+ }
158
+
159
+ function renderPivotField(fieldType, sharedItems) {
160
+ // fieldType: 'row', 'column', 'value', null
161
+
162
+ const defaultAttributes = 'compact="0" outline="0" showAll="0" defaultSubtotal="0"';
163
+
164
+ if (fieldType === 'row' || fieldType === 'column') {
165
+ const axis = fieldType === 'row' ? 'axisRow' : 'axisCol';
166
+ return `
167
+ <pivotField axis="${axis}" ${defaultAttributes}>
168
+ <items count="${sharedItems.length + 1}">
169
+ ${sharedItems.map((item, index) => `<item x="${index}" />`).join('\n ')}
170
+ </items>
171
+ </pivotField>
172
+ `;
173
+ }
174
+ return `
175
+ <pivotField
176
+ ${fieldType === 'value' ? 'dataField="1"' : ''}
177
+ ${defaultAttributes}
178
+ />
179
+ `;
180
+ }
181
+
182
+ PivotTableXform.PIVOT_TABLE_ATTRIBUTES = {
183
+ xmlns: 'http://schemas.openxmlformats.org/spreadsheetml/2006/main',
184
+ 'xmlns:mc': 'http://schemas.openxmlformats.org/markup-compatibility/2006',
185
+ 'mc:Ignorable': 'xr',
186
+ 'xmlns:xr': 'http://schemas.microsoft.com/office/spreadsheetml/2014/revision',
187
+ };
188
+
189
+ module.exports = PivotTableXform;
@@ -0,0 +1,38 @@
1
+ const colCache = require('../../../utils/col-cache');
2
+ const BaseXform = require('../base-xform');
3
+
4
+ class AutoFilterXform extends BaseXform {
5
+ get tag() {
6
+ return 'autoFilter';
7
+ }
8
+
9
+ render(xmlStream, model) {
10
+ if (model) {
11
+ if (typeof model === 'string') {
12
+ // assume range
13
+ xmlStream.leafNode('autoFilter', {ref: model});
14
+ } else {
15
+ const getAddress = function(addr) {
16
+ if (typeof addr === 'string') {
17
+ return addr;
18
+ }
19
+ return colCache.getAddress(addr.row, addr.column).address;
20
+ };
21
+
22
+ const firstAddress = getAddress(model.from);
23
+ const secondAddress = getAddress(model.to);
24
+ if (firstAddress && secondAddress) {
25
+ xmlStream.leafNode('autoFilter', {ref: `${firstAddress}:${secondAddress}`});
26
+ }
27
+ }
28
+ }
29
+ }
30
+
31
+ parseOpen(node) {
32
+ if (node.name === 'autoFilter') {
33
+ this.model = node.attributes.ref;
34
+ }
35
+ }
36
+ }
37
+
38
+ module.exports = AutoFilterXform;