@bilig/excel-import 0.14.14

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 (198) hide show
  1. package/LICENSE +1 -0
  2. package/README.md +165 -0
  3. package/dist/index.d.ts +31 -0
  4. package/dist/index.js +748 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/workbook-import-content-types.d.ts +10 -0
  7. package/dist/workbook-import-content-types.js +30 -0
  8. package/dist/workbook-import-content-types.js.map +1 -0
  9. package/dist/workbook-import-helpers.d.ts +21 -0
  10. package/dist/workbook-import-helpers.js +77 -0
  11. package/dist/workbook-import-helpers.js.map +1 -0
  12. package/dist/workbook-import-preview.d.ts +19 -0
  13. package/dist/workbook-import-preview.js +12 -0
  14. package/dist/workbook-import-preview.js.map +1 -0
  15. package/dist/xlsx-array-formulas.d.ts +6 -0
  16. package/dist/xlsx-array-formulas.js +186 -0
  17. package/dist/xlsx-array-formulas.js.map +1 -0
  18. package/dist/xlsx-axis-entries.d.ts +3 -0
  19. package/dist/xlsx-axis-entries.js +90 -0
  20. package/dist/xlsx-axis-entries.js.map +1 -0
  21. package/dist/xlsx-calculation-settings.d.ts +9 -0
  22. package/dist/xlsx-calculation-settings.js +198 -0
  23. package/dist/xlsx-calculation-settings.js.map +1 -0
  24. package/dist/xlsx-cell-insertion.d.ts +11 -0
  25. package/dist/xlsx-cell-insertion.js +164 -0
  26. package/dist/xlsx-cell-insertion.js.map +1 -0
  27. package/dist/xlsx-cell-metadata.d.ts +15 -0
  28. package/dist/xlsx-cell-metadata.js +380 -0
  29. package/dist/xlsx-cell-metadata.js.map +1 -0
  30. package/dist/xlsx-chart-artifacts.d.ts +7 -0
  31. package/dist/xlsx-chart-artifacts.js +327 -0
  32. package/dist/xlsx-chart-artifacts.js.map +1 -0
  33. package/dist/xlsx-charts.d.ts +4 -0
  34. package/dist/xlsx-charts.js +671 -0
  35. package/dist/xlsx-charts.js.map +1 -0
  36. package/dist/xlsx-comment-vml.d.ts +11 -0
  37. package/dist/xlsx-comment-vml.js +292 -0
  38. package/dist/xlsx-comment-vml.js.map +1 -0
  39. package/dist/xlsx-comments.d.ts +7 -0
  40. package/dist/xlsx-comments.js +120 -0
  41. package/dist/xlsx-comments.js.map +1 -0
  42. package/dist/xlsx-conditional-formats.d.ts +5 -0
  43. package/dist/xlsx-conditional-formats.js +513 -0
  44. package/dist/xlsx-conditional-formats.js.map +1 -0
  45. package/dist/xlsx-control-artifacts.d.ts +7 -0
  46. package/dist/xlsx-control-artifacts.js +404 -0
  47. package/dist/xlsx-control-artifacts.js.map +1 -0
  48. package/dist/xlsx-data-model-artifacts.d.ts +4 -0
  49. package/dist/xlsx-data-model-artifacts.js +240 -0
  50. package/dist/xlsx-data-model-artifacts.js.map +1 -0
  51. package/dist/xlsx-data-table-formulas.d.ts +4 -0
  52. package/dist/xlsx-data-table-formulas.js +138 -0
  53. package/dist/xlsx-data-table-formulas.js.map +1 -0
  54. package/dist/xlsx-defined-names.d.ts +7 -0
  55. package/dist/xlsx-defined-names.js +292 -0
  56. package/dist/xlsx-defined-names.js.map +1 -0
  57. package/dist/xlsx-dimensions.d.ts +4 -0
  58. package/dist/xlsx-dimensions.js +495 -0
  59. package/dist/xlsx-dimensions.js.map +1 -0
  60. package/dist/xlsx-drawing-artifacts.d.ts +7 -0
  61. package/dist/xlsx-drawing-artifacts.js +477 -0
  62. package/dist/xlsx-drawing-artifacts.js.map +1 -0
  63. package/dist/xlsx-escaped-text.d.ts +2 -0
  64. package/dist/xlsx-escaped-text.js +22 -0
  65. package/dist/xlsx-escaped-text.js.map +1 -0
  66. package/dist/xlsx-export-xml.d.ts +8 -0
  67. package/dist/xlsx-export-xml.js +99 -0
  68. package/dist/xlsx-export-xml.js.map +1 -0
  69. package/dist/xlsx-export.d.ts +2 -0
  70. package/dist/xlsx-export.js +800 -0
  71. package/dist/xlsx-export.js.map +1 -0
  72. package/dist/xlsx-external-link-artifacts.d.ts +4 -0
  73. package/dist/xlsx-external-link-artifacts.js +317 -0
  74. package/dist/xlsx-external-link-artifacts.js.map +1 -0
  75. package/dist/xlsx-external-references.d.ts +29 -0
  76. package/dist/xlsx-external-references.js +356 -0
  77. package/dist/xlsx-external-references.js.map +1 -0
  78. package/dist/xlsx-filters.d.ts +4 -0
  79. package/dist/xlsx-filters.js +273 -0
  80. package/dist/xlsx-filters.js.map +1 -0
  81. package/dist/xlsx-formula-translation.d.ts +10 -0
  82. package/dist/xlsx-formula-translation.js +391 -0
  83. package/dist/xlsx-formula-translation.js.map +1 -0
  84. package/dist/xlsx-formulas.d.ts +2 -0
  85. package/dist/xlsx-formulas.js +136 -0
  86. package/dist/xlsx-formulas.js.map +1 -0
  87. package/dist/xlsx-freeze-panes.d.ts +4 -0
  88. package/dist/xlsx-freeze-panes.js +206 -0
  89. package/dist/xlsx-freeze-panes.js.map +1 -0
  90. package/dist/xlsx-hyperlinks.d.ts +5 -0
  91. package/dist/xlsx-hyperlinks.js +64 -0
  92. package/dist/xlsx-hyperlinks.js.map +1 -0
  93. package/dist/xlsx-ignored-errors.d.ts +4 -0
  94. package/dist/xlsx-ignored-errors.js +106 -0
  95. package/dist/xlsx-ignored-errors.js.map +1 -0
  96. package/dist/xlsx-import-cell-styles.d.ts +8 -0
  97. package/dist/xlsx-import-cell-styles.js +255 -0
  98. package/dist/xlsx-import-cell-styles.js.map +1 -0
  99. package/dist/xlsx-import-sheet-metadata.d.ts +40 -0
  100. package/dist/xlsx-import-sheet-metadata.js +41 -0
  101. package/dist/xlsx-import-sheet-metadata.js.map +1 -0
  102. package/dist/xlsx-import-warnings.d.ts +8 -0
  103. package/dist/xlsx-import-warnings.js +44 -0
  104. package/dist/xlsx-import-warnings.js.map +1 -0
  105. package/dist/xlsx-import-workbook-metadata.d.ts +28 -0
  106. package/dist/xlsx-import-workbook-metadata.js +29 -0
  107. package/dist/xlsx-import-workbook-metadata.js.map +1 -0
  108. package/dist/xlsx-macros.d.ts +10 -0
  109. package/dist/xlsx-macros.js +63 -0
  110. package/dist/xlsx-macros.js.map +1 -0
  111. package/dist/xlsx-merge-entries.d.ts +3 -0
  112. package/dist/xlsx-merge-entries.js +17 -0
  113. package/dist/xlsx-merge-entries.js.map +1 -0
  114. package/dist/xlsx-number-formats.d.ts +7 -0
  115. package/dist/xlsx-number-formats.js +222 -0
  116. package/dist/xlsx-number-formats.js.map +1 -0
  117. package/dist/xlsx-pivot-artifacts.d.ts +29 -0
  118. package/dist/xlsx-pivot-artifacts.js +292 -0
  119. package/dist/xlsx-pivot-artifacts.js.map +1 -0
  120. package/dist/xlsx-pivots.d.ts +10 -0
  121. package/dist/xlsx-pivots.js +589 -0
  122. package/dist/xlsx-pivots.js.map +1 -0
  123. package/dist/xlsx-print-page-setup.d.ts +6 -0
  124. package/dist/xlsx-print-page-setup.js +224 -0
  125. package/dist/xlsx-print-page-setup.js.map +1 -0
  126. package/dist/xlsx-printer-settings.d.ts +4 -0
  127. package/dist/xlsx-printer-settings.js +279 -0
  128. package/dist/xlsx-printer-settings.js.map +1 -0
  129. package/dist/xlsx-protected-ranges.d.ts +4 -0
  130. package/dist/xlsx-protected-ranges.js +183 -0
  131. package/dist/xlsx-protected-ranges.js.map +1 -0
  132. package/dist/xlsx-rich-text-artifacts.d.ts +4 -0
  133. package/dist/xlsx-rich-text-artifacts.js +303 -0
  134. package/dist/xlsx-rich-text-artifacts.js.map +1 -0
  135. package/dist/xlsx-sheet-properties.d.ts +4 -0
  136. package/dist/xlsx-sheet-properties.js +89 -0
  137. package/dist/xlsx-sheet-properties.js.map +1 -0
  138. package/dist/xlsx-sheet-protection.d.ts +4 -0
  139. package/dist/xlsx-sheet-protection.js +153 -0
  140. package/dist/xlsx-sheet-protection.js.map +1 -0
  141. package/dist/xlsx-sheet-visibility.d.ts +4 -0
  142. package/dist/xlsx-sheet-visibility.js +53 -0
  143. package/dist/xlsx-sheet-visibility.js.map +1 -0
  144. package/dist/xlsx-slicer-connection-artifacts.d.ts +4 -0
  145. package/dist/xlsx-slicer-connection-artifacts.js +426 -0
  146. package/dist/xlsx-slicer-connection-artifacts.js.map +1 -0
  147. package/dist/xlsx-sorts.d.ts +5 -0
  148. package/dist/xlsx-sorts.js +216 -0
  149. package/dist/xlsx-sorts.js.map +1 -0
  150. package/dist/xlsx-sparklines.d.ts +4 -0
  151. package/dist/xlsx-sparklines.js +115 -0
  152. package/dist/xlsx-sparklines.js.map +1 -0
  153. package/dist/xlsx-style-only-blank-cells.d.ts +3 -0
  154. package/dist/xlsx-style-only-blank-cells.js +96 -0
  155. package/dist/xlsx-style-only-blank-cells.js.map +1 -0
  156. package/dist/xlsx-style-runs.d.ts +12 -0
  157. package/dist/xlsx-style-runs.js +35 -0
  158. package/dist/xlsx-style-runs.js.map +1 -0
  159. package/dist/xlsx-styles.d.ts +25 -0
  160. package/dist/xlsx-styles.js +857 -0
  161. package/dist/xlsx-styles.js.map +1 -0
  162. package/dist/xlsx-tab-colors.d.ts +4 -0
  163. package/dist/xlsx-tab-colors.js +166 -0
  164. package/dist/xlsx-tab-colors.js.map +1 -0
  165. package/dist/xlsx-tables.d.ts +4 -0
  166. package/dist/xlsx-tables.js +371 -0
  167. package/dist/xlsx-tables.js.map +1 -0
  168. package/dist/xlsx-theme-artifacts.d.ts +6 -0
  169. package/dist/xlsx-theme-artifacts.js +126 -0
  170. package/dist/xlsx-theme-artifacts.js.map +1 -0
  171. package/dist/xlsx-threaded-comment-artifacts.d.ts +8 -0
  172. package/dist/xlsx-threaded-comment-artifacts.js +329 -0
  173. package/dist/xlsx-threaded-comment-artifacts.js.map +1 -0
  174. package/dist/xlsx-validations.d.ts +4 -0
  175. package/dist/xlsx-validations.js +542 -0
  176. package/dist/xlsx-validations.js.map +1 -0
  177. package/dist/xlsx-view-state.d.ts +8 -0
  178. package/dist/xlsx-view-state.js +144 -0
  179. package/dist/xlsx-view-state.js.map +1 -0
  180. package/dist/xlsx-workbook-properties.d.ts +5 -0
  181. package/dist/xlsx-workbook-properties.js +388 -0
  182. package/dist/xlsx-workbook-properties.js.map +1 -0
  183. package/dist/xlsx-workbook-protection.d.ts +4 -0
  184. package/dist/xlsx-workbook-protection.js +147 -0
  185. package/dist/xlsx-workbook-protection.js.map +1 -0
  186. package/dist/xlsx-workbook-sheet-paths.d.ts +4 -0
  187. package/dist/xlsx-workbook-sheet-paths.js +96 -0
  188. package/dist/xlsx-workbook-sheet-paths.js.map +1 -0
  189. package/dist/xlsx-worksheet-cells.d.ts +16 -0
  190. package/dist/xlsx-worksheet-cells.js +104 -0
  191. package/dist/xlsx-worksheet-cells.js.map +1 -0
  192. package/dist/xlsx-worksheet-text-values.d.ts +2 -0
  193. package/dist/xlsx-worksheet-text-values.js +136 -0
  194. package/dist/xlsx-worksheet-text-values.js.map +1 -0
  195. package/dist/xlsx-zip.d.ts +6 -0
  196. package/dist/xlsx-zip.js +12 -0
  197. package/dist/xlsx-zip.js.map +1 -0
  198. package/package.json +56 -0
@@ -0,0 +1,224 @@
1
+ import { unzipSync, zipSync } from 'fflate';
2
+ import { getZipText, normalizeZipPath, readXlsxZipEntries } from './xlsx-zip.js';
3
+ import { parseRelationships, resolveTargetPath, setZipText } from './xlsx-pivot-artifacts.js';
4
+ const workbookPath = 'xl/workbook.xml';
5
+ const workbookRelationshipsPath = 'xl/_rels/workbook.xml.rels';
6
+ const worksheetRelationshipType = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet';
7
+ const printPageSetupElementNames = ['printOptions', 'pageMargins', 'pageSetup', 'headerFooter', 'rowBreaks', 'colBreaks'];
8
+ const printPageSetupTailElements = [
9
+ 'customProperties',
10
+ 'cellWatches',
11
+ 'ignoredErrors',
12
+ 'smartTags',
13
+ 'drawing',
14
+ 'legacyDrawing',
15
+ 'legacyDrawingHF',
16
+ 'picture',
17
+ 'oleObjects',
18
+ 'controls',
19
+ 'webPublishItems',
20
+ 'tableParts',
21
+ 'extLst',
22
+ ];
23
+ function readXmlAttribute(attributes, attributeName) {
24
+ return new RegExp(`\\b${attributeName}=("|')([\\s\\S]*?)\\1`, 'u').exec(attributes)?.[2] ?? null;
25
+ }
26
+ function decodeXmlText(value) {
27
+ return value.replace(/&(#x[0-9a-fA-F]+|#[0-9]+|amp|lt|gt|quot|apos);/gu, (_match, entity) => {
28
+ if (entity.startsWith('#x')) {
29
+ const codePoint = Number.parseInt(entity.slice(2), 16);
30
+ return Number.isFinite(codePoint) ? String.fromCodePoint(codePoint) : '';
31
+ }
32
+ if (entity.startsWith('#')) {
33
+ const codePoint = Number.parseInt(entity.slice(1), 10);
34
+ return Number.isFinite(codePoint) ? String.fromCodePoint(codePoint) : '';
35
+ }
36
+ switch (entity) {
37
+ case 'amp':
38
+ return '&';
39
+ case 'lt':
40
+ return '<';
41
+ case 'gt':
42
+ return '>';
43
+ case 'quot':
44
+ return '"';
45
+ case 'apos':
46
+ return "'";
47
+ default:
48
+ return '';
49
+ }
50
+ });
51
+ }
52
+ function readWorkbookSheetEntries(workbookXml) {
53
+ if (!workbookXml) {
54
+ return [];
55
+ }
56
+ return [...workbookXml.matchAll(/<(?:[A-Za-z_][\w.-]*:)?sheet\b([^>]*)\/?>/gu)].flatMap((match) => {
57
+ const attributes = match[1] ?? '';
58
+ const name = readXmlAttribute(attributes, 'name');
59
+ const relationshipId = readXmlAttribute(attributes, 'r:id') ?? readXmlAttribute(attributes, 'id');
60
+ return name && relationshipId ? [{ name: decodeXmlText(name), relationshipId }] : [];
61
+ });
62
+ }
63
+ function sheetPath(sheetIndex) {
64
+ return `xl/worksheets/sheet${String(sheetIndex + 1)}.xml`;
65
+ }
66
+ function worksheetPathsBySheetName(zip, sheetNames) {
67
+ const paths = new Map();
68
+ const workbookRelationships = parseRelationships(getZipText(zip, workbookRelationshipsPath));
69
+ const worksheetRelationshipsById = new Map(workbookRelationships
70
+ .filter((relationship) => relationship.type === worksheetRelationshipType || relationship.target.includes('worksheets/'))
71
+ .map((relationship) => [relationship.id, normalizeZipPath(resolveTargetPath(workbookPath, relationship.target))]));
72
+ readWorkbookSheetEntries(getZipText(zip, workbookPath)).forEach((entry) => {
73
+ const worksheetPath = worksheetRelationshipsById.get(entry.relationshipId);
74
+ if (worksheetPath) {
75
+ paths.set(entry.name, worksheetPath);
76
+ }
77
+ });
78
+ sheetNames.forEach((sheetName, sheetIndex) => {
79
+ if (!paths.has(sheetName)) {
80
+ paths.set(sheetName, sheetPath(sheetIndex));
81
+ }
82
+ });
83
+ return paths;
84
+ }
85
+ function elementPattern(elementName) {
86
+ return new RegExp(`<((?:[A-Za-z_][\\w.-]*:)?${elementName})\\b[^>]*(?:/>|>[\\s\\S]*?</\\1>)`, 'gu');
87
+ }
88
+ function usedNamespacePrefixes(xml) {
89
+ const prefixes = new Set();
90
+ for (const match of xml.matchAll(/\b([A-Za-z_][\w.-]*):[A-Za-z_][\w.-]*\b/gu)) {
91
+ const prefix = match[1];
92
+ if (prefix && prefix !== 'xml' && prefix !== 'xmlns') {
93
+ prefixes.add(prefix);
94
+ }
95
+ }
96
+ return prefixes;
97
+ }
98
+ function worksheetNamespaceDeclaration(sheetXml, prefix) {
99
+ const worksheetOpening = /<worksheet\b([^>]*)>/u.exec(sheetXml)?.[1] ?? '';
100
+ const declaration = new RegExp(`\\sxmlns:${prefix}=(["'])([\\s\\S]*?)\\1`, 'u').exec(worksheetOpening);
101
+ return declaration ? `xmlns:${prefix}=${declaration[1]}${declaration[2] ?? ''}${declaration[1]}` : null;
102
+ }
103
+ function addMissingNamespaceDeclarations(sheetXml, elementXml) {
104
+ const missingDeclarations = [...usedNamespacePrefixes(elementXml)].flatMap((prefix) => {
105
+ if (new RegExp(`\\sxmlns:${prefix}=`, 'u').test(elementXml)) {
106
+ return [];
107
+ }
108
+ const declaration = worksheetNamespaceDeclaration(sheetXml, prefix);
109
+ return declaration ? [declaration] : [];
110
+ });
111
+ if (missingDeclarations.length === 0) {
112
+ return elementXml;
113
+ }
114
+ return elementXml.replace(/<((?:[A-Za-z_][\w.-]*:)?[A-Za-z_][\w.-]*)\b([^>]*?)(\/?)>/u, (_match, tagName, attributes, selfClosing) => `<${tagName}${attributes} ${missingDeclarations.join(' ')}${selfClosing}>`);
115
+ }
116
+ function readElementXml(sheetXml, elementName) {
117
+ const match = elementPattern(elementName).exec(sheetXml)?.[0];
118
+ return match ? addMissingNamespaceDeclarations(sheetXml, match) : undefined;
119
+ }
120
+ function readSheetPrintPageSetup(sheetXml) {
121
+ const snapshot = {};
122
+ const printOptionsXml = readElementXml(sheetXml, 'printOptions');
123
+ const pageMarginsXml = readElementXml(sheetXml, 'pageMargins');
124
+ const pageSetupXml = readElementXml(sheetXml, 'pageSetup');
125
+ const headerFooterXml = readElementXml(sheetXml, 'headerFooter');
126
+ const rowBreaksXml = readElementXml(sheetXml, 'rowBreaks');
127
+ const colBreaksXml = readElementXml(sheetXml, 'colBreaks');
128
+ if (printOptionsXml) {
129
+ snapshot.printOptionsXml = printOptionsXml;
130
+ }
131
+ if (pageMarginsXml) {
132
+ snapshot.pageMarginsXml = pageMarginsXml;
133
+ }
134
+ if (pageSetupXml) {
135
+ snapshot.pageSetupXml = pageSetupXml;
136
+ }
137
+ if (headerFooterXml) {
138
+ snapshot.headerFooterXml = headerFooterXml;
139
+ }
140
+ if (rowBreaksXml) {
141
+ snapshot.rowBreaksXml = rowBreaksXml;
142
+ }
143
+ if (colBreaksXml) {
144
+ snapshot.colBreaksXml = colBreaksXml;
145
+ }
146
+ return Object.keys(snapshot).length > 0 ? snapshot : undefined;
147
+ }
148
+ function removePrintPageSetupElements(sheetXml) {
149
+ return printPageSetupElementNames.reduce((xml, elementName) => xml.replace(elementPattern(elementName), ''), sheetXml);
150
+ }
151
+ function printPageSetupXml(snapshot) {
152
+ return [
153
+ snapshot.printOptionsXml,
154
+ snapshot.pageMarginsXml,
155
+ snapshot.pageSetupXml,
156
+ snapshot.headerFooterXml,
157
+ snapshot.rowBreaksXml,
158
+ snapshot.colBreaksXml,
159
+ ]
160
+ .filter((element) => Boolean(element))
161
+ .join('');
162
+ }
163
+ function insertPrintPageSetupXml(sheetXml, snapshot) {
164
+ const payload = printPageSetupXml(snapshot);
165
+ const withoutPrintPageSetup = removePrintPageSetupElements(sheetXml);
166
+ if (payload.length === 0) {
167
+ return withoutPrintPageSetup;
168
+ }
169
+ let insertIndex = withoutPrintPageSetup.indexOf('</worksheet>');
170
+ for (const elementName of printPageSetupTailElements) {
171
+ const elementIndex = withoutPrintPageSetup.search(new RegExp(`<(?:[A-Za-z_][\\w.-]*:)?${elementName}\\b`, 'u'));
172
+ if (elementIndex >= 0 && (insertIndex < 0 || elementIndex < insertIndex)) {
173
+ insertIndex = elementIndex;
174
+ }
175
+ }
176
+ if (insertIndex < 0) {
177
+ return withoutPrintPageSetup;
178
+ }
179
+ return `${withoutPrintPageSetup.slice(0, insertIndex)}${payload}${withoutPrintPageSetup.slice(insertIndex)}`;
180
+ }
181
+ export function readImportedWorkbookPrintPageSetup(source, sheetNames) {
182
+ const zip = readXlsxZipEntries(source);
183
+ const printPageSetupBySheet = new Map();
184
+ const worksheetPaths = worksheetPathsBySheetName(zip, sheetNames);
185
+ sheetNames.forEach((sheetName, sheetIndex) => {
186
+ const worksheetPath = worksheetPaths.get(sheetName) ?? sheetPath(sheetIndex);
187
+ const sheetXml = getZipText(zip, worksheetPath);
188
+ if (!sheetXml) {
189
+ return;
190
+ }
191
+ const printPageSetup = readSheetPrintPageSetup(sheetXml);
192
+ if (printPageSetup) {
193
+ printPageSetupBySheet.set(sheetName, printPageSetup);
194
+ }
195
+ });
196
+ return printPageSetupBySheet;
197
+ }
198
+ export function addExportPrintPageSetupToXlsxBytes(bytes, snapshot) {
199
+ if (!snapshot.sheets.some((sheet) => sheet.metadata?.printPageSetup)) {
200
+ return bytes;
201
+ }
202
+ const zip = unzipSync(bytes);
203
+ let changed = false;
204
+ snapshot.sheets
205
+ .toSorted((left, right) => left.order - right.order)
206
+ .forEach((sheet, sheetIndex) => {
207
+ const printPageSetup = sheet.metadata?.printPageSetup;
208
+ if (!printPageSetup) {
209
+ return;
210
+ }
211
+ const path = sheetPath(sheetIndex);
212
+ const sheetXml = getZipText(zip, path);
213
+ if (!sheetXml) {
214
+ return;
215
+ }
216
+ const nextSheetXml = insertPrintPageSetupXml(sheetXml, printPageSetup);
217
+ if (nextSheetXml !== sheetXml) {
218
+ setZipText(zip, path, nextSheetXml);
219
+ changed = true;
220
+ }
221
+ });
222
+ return changed ? zipSync(zip) : bytes;
223
+ }
224
+ //# sourceMappingURL=xlsx-print-page-setup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xlsx-print-page-setup.js","sourceRoot":"","sources":["../src/xlsx-print-page-setup.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { WorkbookPrinterSettingsSnapshot, WorkbookSnapshot } from '@bilig/protocol';
2
+ import { type XlsxZipSource } from './xlsx-zip.js';
3
+ export declare function readImportedWorkbookPrinterSettings(source: XlsxZipSource, sheetNames: readonly string[]): Map<string, WorkbookPrinterSettingsSnapshot[]>;
4
+ export declare function addExportPrinterSettingsToXlsxBytes(bytes: Uint8Array, snapshot: WorkbookSnapshot): Uint8Array;
@@ -0,0 +1,279 @@
1
+ import { strToU8, unzipSync, zipSync } from 'fflate';
2
+ import { getZipText, normalizeZipPath, readXlsxZipEntries } from './xlsx-zip.js';
3
+ const binaryChunkSize = 0x8000;
4
+ const relationshipNamespace = 'http://schemas.openxmlformats.org/package/2006/relationships';
5
+ const officeRelationshipNamespace = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships';
6
+ const printerSettingsRelationshipType = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/printerSettings';
7
+ const printerSettingsContentType = 'application/vnd.openxmlformats-officedocument.spreadsheetml.printerSettings';
8
+ const printerSettingsPathPattern = /^xl\/printerSettings\/[^/]+\.bin$/u;
9
+ const pageSetupTailElements = [
10
+ 'headerFooter',
11
+ 'rowBreaks',
12
+ 'colBreaks',
13
+ 'customProperties',
14
+ 'cellWatches',
15
+ 'ignoredErrors',
16
+ 'smartTags',
17
+ 'drawing',
18
+ 'legacyDrawing',
19
+ 'legacyDrawingHF',
20
+ 'picture',
21
+ 'oleObjects',
22
+ 'controls',
23
+ 'webPublishItems',
24
+ 'tableParts',
25
+ 'extLst',
26
+ ];
27
+ function encodeBinaryString(bytes) {
28
+ let binary = '';
29
+ for (let offset = 0; offset < bytes.length; offset += binaryChunkSize) {
30
+ binary += String.fromCharCode(...bytes.subarray(offset, offset + binaryChunkSize));
31
+ }
32
+ return binary;
33
+ }
34
+ function decodeBinaryString(binary) {
35
+ const bytes = new Uint8Array(binary.length);
36
+ for (let index = 0; index < binary.length; index += 1) {
37
+ bytes[index] = binary.charCodeAt(index);
38
+ }
39
+ return bytes;
40
+ }
41
+ function encodeBase64(bytes) {
42
+ const btoa = globalThis.btoa;
43
+ if (typeof btoa === 'function') {
44
+ return btoa(encodeBinaryString(bytes));
45
+ }
46
+ return Buffer.from(bytes).toString('base64');
47
+ }
48
+ function decodeBase64(dataBase64) {
49
+ const atob = globalThis.atob;
50
+ if (typeof atob === 'function') {
51
+ return decodeBinaryString(atob(dataBase64));
52
+ }
53
+ return new Uint8Array(Buffer.from(dataBase64, 'base64'));
54
+ }
55
+ function escapeXml(value) {
56
+ return value.replaceAll('&', '&amp;').replaceAll('<', '&lt;').replaceAll('>', '&gt;').replaceAll('"', '&quot;').replaceAll("'", '&apos;');
57
+ }
58
+ function setZipText(zip, path, text) {
59
+ zip[normalizeZipPath(path)] = strToU8(text);
60
+ }
61
+ function readAttribute(xml, attributeName) {
62
+ const match = new RegExp(`\\s${attributeName}=(["'])([\\s\\S]*?)\\1`, 'u').exec(xml);
63
+ return match?.[2] ?? null;
64
+ }
65
+ function parseRelationships(xml) {
66
+ if (!xml) {
67
+ return [];
68
+ }
69
+ return [...xml.matchAll(/<Relationship\b([^>]*)\/?>/gu)].flatMap((match) => {
70
+ const attributes = match[1] ?? '';
71
+ const id = readAttribute(attributes, 'Id');
72
+ const target = readAttribute(attributes, 'Target');
73
+ const type = readAttribute(attributes, 'Type');
74
+ return id && target && type ? [{ id, target, type }] : [];
75
+ });
76
+ }
77
+ function nextRelationshipId(relationships) {
78
+ let next = 1;
79
+ for (const relationship of relationships) {
80
+ const match = /^rId(\d+)$/u.exec(relationship.id);
81
+ if (match) {
82
+ next = Math.max(next, Number(match[1]) + 1);
83
+ }
84
+ }
85
+ return `rId${String(next)}`;
86
+ }
87
+ function relationshipXml(relationship) {
88
+ return `<Relationship Id="${escapeXml(relationship.id)}" Type="${escapeXml(relationship.type)}" Target="${escapeXml(relationship.target)}"/>`;
89
+ }
90
+ function appendRelationshipXml(xml, relationship) {
91
+ if (!xml) {
92
+ return `<?xml version="1.0" encoding="UTF-8" standalone="yes"?><Relationships xmlns="${relationshipNamespace}">${relationshipXml(relationship)}</Relationships>`;
93
+ }
94
+ if (!xml.includes('</Relationships>')) {
95
+ return xml;
96
+ }
97
+ return xml.replace('</Relationships>', `${relationshipXml(relationship)}</Relationships>`);
98
+ }
99
+ function resolveTargetPath(basePartPath, target) {
100
+ const parts = basePartPath.split('/');
101
+ parts.pop();
102
+ for (const segment of target.split('/')) {
103
+ if (segment === '..') {
104
+ parts.pop();
105
+ }
106
+ else if (segment !== '.' && segment.length > 0) {
107
+ parts.push(segment);
108
+ }
109
+ }
110
+ return parts.join('/');
111
+ }
112
+ function readSheetRelationshipPath(sheetIndex) {
113
+ return `xl/worksheets/_rels/sheet${String(sheetIndex + 1)}.xml.rels`;
114
+ }
115
+ function readPageSetupXml(sheetXml, relationshipId) {
116
+ if (!sheetXml) {
117
+ return undefined;
118
+ }
119
+ const pageSetupXml = /<pageSetup\b[^>]*(?:\/>|>[\s\S]*?<\/pageSetup>)/u.exec(sheetXml)?.[0];
120
+ if (!pageSetupXml) {
121
+ return undefined;
122
+ }
123
+ const pageSetupRelationshipId = readAttribute(pageSetupXml, 'r:id') ?? readAttribute(pageSetupXml, 'id');
124
+ return pageSetupRelationshipId === relationshipId ? pageSetupXml : undefined;
125
+ }
126
+ export function readImportedWorkbookPrinterSettings(source, sheetNames) {
127
+ const zip = readXlsxZipEntries(source);
128
+ const printerSettingsBySheet = new Map();
129
+ sheetNames.forEach((sheetName, sheetIndex) => {
130
+ const sheetPath = `xl/worksheets/sheet${String(sheetIndex + 1)}.xml`;
131
+ const sheetXml = getZipText(zip, sheetPath);
132
+ const relationships = parseRelationships(getZipText(zip, readSheetRelationshipPath(sheetIndex))).filter((entry) => entry.type === printerSettingsRelationshipType);
133
+ const settings = relationships.flatMap((relationship) => {
134
+ const partPath = resolveTargetPath(sheetPath, relationship.target);
135
+ const bytes = zip[normalizeZipPath(partPath)];
136
+ if (!bytes) {
137
+ return [];
138
+ }
139
+ const pageSetupXml = readPageSetupXml(sheetXml, relationship.id);
140
+ return [
141
+ {
142
+ relationshipTarget: relationship.target,
143
+ storage: 'base64',
144
+ dataBase64: encodeBase64(bytes),
145
+ byteLength: bytes.byteLength,
146
+ ...(pageSetupXml ? { pageSetupXml } : {}),
147
+ },
148
+ ];
149
+ });
150
+ if (settings.length > 0) {
151
+ printerSettingsBySheet.set(sheetName, settings);
152
+ }
153
+ });
154
+ return printerSettingsBySheet;
155
+ }
156
+ function nextPartIndex(zip) {
157
+ let next = 1;
158
+ for (const path of Object.keys(zip)) {
159
+ if (!path.startsWith('xl/printerSettings/printerSettings') || !path.endsWith('.bin')) {
160
+ continue;
161
+ }
162
+ const raw = path.slice('xl/printerSettings/printerSettings'.length, -'.bin'.length);
163
+ const value = Number(raw);
164
+ if (Number.isInteger(value) && value >= next) {
165
+ next = value + 1;
166
+ }
167
+ }
168
+ return next;
169
+ }
170
+ function safePrinterSettingsTarget(input) {
171
+ const partPath = normalizeZipPath(resolveTargetPath(input.sheetPath, input.target));
172
+ if (printerSettingsPathPattern.test(partPath)) {
173
+ return { target: input.target, partPath };
174
+ }
175
+ const index = nextPartIndex(input.zip);
176
+ return {
177
+ target: `../printerSettings/printerSettings${String(index)}.bin`,
178
+ partPath: `xl/printerSettings/printerSettings${String(index)}.bin`,
179
+ };
180
+ }
181
+ function addPrinterSettingsContentTypeOverride(contentTypesXml, partPath) {
182
+ if (!contentTypesXml) {
183
+ return null;
184
+ }
185
+ const partName = `/${normalizeZipPath(partPath)}`;
186
+ if (contentTypesXml.includes(`PartName="${partName}"`)) {
187
+ return contentTypesXml;
188
+ }
189
+ if (!contentTypesXml.includes('</Types>')) {
190
+ return contentTypesXml;
191
+ }
192
+ return contentTypesXml.replace('</Types>', `<Override PartName="${escapeXml(partName)}" ContentType="${printerSettingsContentType}"/></Types>`);
193
+ }
194
+ function ensureOfficeRelationshipNamespace(sheetXml) {
195
+ if (/\sxmlns:r=(["'])[\s\S]*?\1/u.test(sheetXml)) {
196
+ return sheetXml;
197
+ }
198
+ return sheetXml.replace(/<worksheet\b([^>]*)>/u, `<worksheet$1 xmlns:r="${officeRelationshipNamespace}">`);
199
+ }
200
+ function setXmlAttribute(tag, name, value) {
201
+ const attribute = `${name}="${escapeXml(value)}"`;
202
+ const existingAttribute = new RegExp(`\\s${name}=(["'])[\\s\\S]*?\\1`, 'u');
203
+ if (existingAttribute.test(tag)) {
204
+ return tag.replace(existingAttribute, ` ${attribute}`);
205
+ }
206
+ return tag.replace(/\/?>$/u, (ending) => ` ${attribute}${ending}`);
207
+ }
208
+ function pageSetupXmlForRelationship(pageSetupXml, relationshipId) {
209
+ const source = pageSetupXml ?? '<pageSetup/>';
210
+ return source.replace(/<pageSetup\b[^>]*(?:\/>|>)/u, (opening) => setXmlAttribute(opening, 'r:id', relationshipId));
211
+ }
212
+ function insertOrReplacePageSetup(sheetXml, pageSetupXml) {
213
+ const withNamespace = ensureOfficeRelationshipNamespace(sheetXml);
214
+ if (/<pageSetup\b[^>]*(?:\/>|>[\s\S]*?<\/pageSetup>)/u.test(withNamespace)) {
215
+ return withNamespace.replace(/<pageSetup\b[^>]*(?:\/>|>[\s\S]*?<\/pageSetup>)/u, pageSetupXml);
216
+ }
217
+ let insertIndex = withNamespace.indexOf('</worksheet>');
218
+ for (const elementName of pageSetupTailElements) {
219
+ const elementIndex = withNamespace.search(new RegExp(`<${elementName}\\b`, 'u'));
220
+ if (elementIndex >= 0 && (insertIndex < 0 || elementIndex < insertIndex)) {
221
+ insertIndex = elementIndex;
222
+ }
223
+ }
224
+ if (insertIndex < 0) {
225
+ return withNamespace;
226
+ }
227
+ return `${withNamespace.slice(0, insertIndex)}${pageSetupXml}${withNamespace.slice(insertIndex)}`;
228
+ }
229
+ function restorePrinterSettingsForSheet(input) {
230
+ if (input.setting.storage !== 'base64') {
231
+ return false;
232
+ }
233
+ const bytes = decodeBase64(input.setting.dataBase64);
234
+ if (bytes.byteLength !== input.setting.byteLength) {
235
+ return false;
236
+ }
237
+ const sheetPath = `xl/worksheets/sheet${String(input.sheetIndex + 1)}.xml`;
238
+ const sheetXml = getZipText(input.zip, sheetPath);
239
+ if (!sheetXml) {
240
+ return false;
241
+ }
242
+ const target = safePrinterSettingsTarget({ zip: input.zip, sheetPath, target: input.setting.relationshipTarget });
243
+ input.zip[target.partPath] = bytes;
244
+ const sheetRelsPath = readSheetRelationshipPath(input.sheetIndex);
245
+ const sheetRelsXml = getZipText(input.zip, sheetRelsPath);
246
+ const relationships = parseRelationships(sheetRelsXml);
247
+ const existingRelationship = relationships.find((relationship) => relationship.type === printerSettingsRelationshipType && relationship.target === target.target);
248
+ const relationshipId = existingRelationship?.id ?? nextRelationshipId(relationships);
249
+ if (!existingRelationship) {
250
+ setZipText(input.zip, sheetRelsPath, appendRelationshipXml(sheetRelsXml, {
251
+ id: relationshipId,
252
+ target: target.target,
253
+ type: printerSettingsRelationshipType,
254
+ }));
255
+ }
256
+ const pageSetupXml = pageSetupXmlForRelationship(input.setting.pageSetupXml, relationshipId);
257
+ setZipText(input.zip, sheetPath, insertOrReplacePageSetup(sheetXml, pageSetupXml));
258
+ const contentTypesXml = addPrinterSettingsContentTypeOverride(getZipText(input.zip, '[Content_Types].xml'), target.partPath);
259
+ if (contentTypesXml) {
260
+ setZipText(input.zip, '[Content_Types].xml', contentTypesXml);
261
+ }
262
+ return true;
263
+ }
264
+ export function addExportPrinterSettingsToXlsxBytes(bytes, snapshot) {
265
+ if (!snapshot.sheets.some((sheet) => (sheet.metadata?.printerSettings?.length ?? 0) > 0)) {
266
+ return bytes;
267
+ }
268
+ const zip = unzipSync(bytes);
269
+ let changed = false;
270
+ snapshot.sheets
271
+ .toSorted((left, right) => left.order - right.order)
272
+ .forEach((sheet, sheetIndex) => {
273
+ for (const setting of sheet.metadata?.printerSettings ?? []) {
274
+ changed = restorePrinterSettingsForSheet({ zip, sheetIndex, setting }) || changed;
275
+ }
276
+ });
277
+ return changed ? zipSync(zip) : bytes;
278
+ }
279
+ //# sourceMappingURL=xlsx-printer-settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xlsx-printer-settings.js","sourceRoot":"","sources":["../src/xlsx-printer-settings.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { WorkbookRangeProtectionSnapshot, WorkbookSnapshot } from '@bilig/protocol';
2
+ import { type XlsxZipSource } from './xlsx-zip.js';
3
+ export declare function addExportProtectedRangesToXlsxBytes(bytes: Uint8Array, snapshot: WorkbookSnapshot): Uint8Array;
4
+ export declare function readImportedWorkbookProtectedRanges(source: XlsxZipSource, sheetNames: readonly string[]): Map<string, WorkbookRangeProtectionSnapshot[]>;