@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.
- package/LICENSE +1 -0
- package/README.md +165 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.js +748 -0
- package/dist/index.js.map +1 -0
- package/dist/workbook-import-content-types.d.ts +10 -0
- package/dist/workbook-import-content-types.js +30 -0
- package/dist/workbook-import-content-types.js.map +1 -0
- package/dist/workbook-import-helpers.d.ts +21 -0
- package/dist/workbook-import-helpers.js +77 -0
- package/dist/workbook-import-helpers.js.map +1 -0
- package/dist/workbook-import-preview.d.ts +19 -0
- package/dist/workbook-import-preview.js +12 -0
- package/dist/workbook-import-preview.js.map +1 -0
- package/dist/xlsx-array-formulas.d.ts +6 -0
- package/dist/xlsx-array-formulas.js +186 -0
- package/dist/xlsx-array-formulas.js.map +1 -0
- package/dist/xlsx-axis-entries.d.ts +3 -0
- package/dist/xlsx-axis-entries.js +90 -0
- package/dist/xlsx-axis-entries.js.map +1 -0
- package/dist/xlsx-calculation-settings.d.ts +9 -0
- package/dist/xlsx-calculation-settings.js +198 -0
- package/dist/xlsx-calculation-settings.js.map +1 -0
- package/dist/xlsx-cell-insertion.d.ts +11 -0
- package/dist/xlsx-cell-insertion.js +164 -0
- package/dist/xlsx-cell-insertion.js.map +1 -0
- package/dist/xlsx-cell-metadata.d.ts +15 -0
- package/dist/xlsx-cell-metadata.js +380 -0
- package/dist/xlsx-cell-metadata.js.map +1 -0
- package/dist/xlsx-chart-artifacts.d.ts +7 -0
- package/dist/xlsx-chart-artifacts.js +327 -0
- package/dist/xlsx-chart-artifacts.js.map +1 -0
- package/dist/xlsx-charts.d.ts +4 -0
- package/dist/xlsx-charts.js +671 -0
- package/dist/xlsx-charts.js.map +1 -0
- package/dist/xlsx-comment-vml.d.ts +11 -0
- package/dist/xlsx-comment-vml.js +292 -0
- package/dist/xlsx-comment-vml.js.map +1 -0
- package/dist/xlsx-comments.d.ts +7 -0
- package/dist/xlsx-comments.js +120 -0
- package/dist/xlsx-comments.js.map +1 -0
- package/dist/xlsx-conditional-formats.d.ts +5 -0
- package/dist/xlsx-conditional-formats.js +513 -0
- package/dist/xlsx-conditional-formats.js.map +1 -0
- package/dist/xlsx-control-artifacts.d.ts +7 -0
- package/dist/xlsx-control-artifacts.js +404 -0
- package/dist/xlsx-control-artifacts.js.map +1 -0
- package/dist/xlsx-data-model-artifacts.d.ts +4 -0
- package/dist/xlsx-data-model-artifacts.js +240 -0
- package/dist/xlsx-data-model-artifacts.js.map +1 -0
- package/dist/xlsx-data-table-formulas.d.ts +4 -0
- package/dist/xlsx-data-table-formulas.js +138 -0
- package/dist/xlsx-data-table-formulas.js.map +1 -0
- package/dist/xlsx-defined-names.d.ts +7 -0
- package/dist/xlsx-defined-names.js +292 -0
- package/dist/xlsx-defined-names.js.map +1 -0
- package/dist/xlsx-dimensions.d.ts +4 -0
- package/dist/xlsx-dimensions.js +495 -0
- package/dist/xlsx-dimensions.js.map +1 -0
- package/dist/xlsx-drawing-artifacts.d.ts +7 -0
- package/dist/xlsx-drawing-artifacts.js +477 -0
- package/dist/xlsx-drawing-artifacts.js.map +1 -0
- package/dist/xlsx-escaped-text.d.ts +2 -0
- package/dist/xlsx-escaped-text.js +22 -0
- package/dist/xlsx-escaped-text.js.map +1 -0
- package/dist/xlsx-export-xml.d.ts +8 -0
- package/dist/xlsx-export-xml.js +99 -0
- package/dist/xlsx-export-xml.js.map +1 -0
- package/dist/xlsx-export.d.ts +2 -0
- package/dist/xlsx-export.js +800 -0
- package/dist/xlsx-export.js.map +1 -0
- package/dist/xlsx-external-link-artifacts.d.ts +4 -0
- package/dist/xlsx-external-link-artifacts.js +317 -0
- package/dist/xlsx-external-link-artifacts.js.map +1 -0
- package/dist/xlsx-external-references.d.ts +29 -0
- package/dist/xlsx-external-references.js +356 -0
- package/dist/xlsx-external-references.js.map +1 -0
- package/dist/xlsx-filters.d.ts +4 -0
- package/dist/xlsx-filters.js +273 -0
- package/dist/xlsx-filters.js.map +1 -0
- package/dist/xlsx-formula-translation.d.ts +10 -0
- package/dist/xlsx-formula-translation.js +391 -0
- package/dist/xlsx-formula-translation.js.map +1 -0
- package/dist/xlsx-formulas.d.ts +2 -0
- package/dist/xlsx-formulas.js +136 -0
- package/dist/xlsx-formulas.js.map +1 -0
- package/dist/xlsx-freeze-panes.d.ts +4 -0
- package/dist/xlsx-freeze-panes.js +206 -0
- package/dist/xlsx-freeze-panes.js.map +1 -0
- package/dist/xlsx-hyperlinks.d.ts +5 -0
- package/dist/xlsx-hyperlinks.js +64 -0
- package/dist/xlsx-hyperlinks.js.map +1 -0
- package/dist/xlsx-ignored-errors.d.ts +4 -0
- package/dist/xlsx-ignored-errors.js +106 -0
- package/dist/xlsx-ignored-errors.js.map +1 -0
- package/dist/xlsx-import-cell-styles.d.ts +8 -0
- package/dist/xlsx-import-cell-styles.js +255 -0
- package/dist/xlsx-import-cell-styles.js.map +1 -0
- package/dist/xlsx-import-sheet-metadata.d.ts +40 -0
- package/dist/xlsx-import-sheet-metadata.js +41 -0
- package/dist/xlsx-import-sheet-metadata.js.map +1 -0
- package/dist/xlsx-import-warnings.d.ts +8 -0
- package/dist/xlsx-import-warnings.js +44 -0
- package/dist/xlsx-import-warnings.js.map +1 -0
- package/dist/xlsx-import-workbook-metadata.d.ts +28 -0
- package/dist/xlsx-import-workbook-metadata.js +29 -0
- package/dist/xlsx-import-workbook-metadata.js.map +1 -0
- package/dist/xlsx-macros.d.ts +10 -0
- package/dist/xlsx-macros.js +63 -0
- package/dist/xlsx-macros.js.map +1 -0
- package/dist/xlsx-merge-entries.d.ts +3 -0
- package/dist/xlsx-merge-entries.js +17 -0
- package/dist/xlsx-merge-entries.js.map +1 -0
- package/dist/xlsx-number-formats.d.ts +7 -0
- package/dist/xlsx-number-formats.js +222 -0
- package/dist/xlsx-number-formats.js.map +1 -0
- package/dist/xlsx-pivot-artifacts.d.ts +29 -0
- package/dist/xlsx-pivot-artifacts.js +292 -0
- package/dist/xlsx-pivot-artifacts.js.map +1 -0
- package/dist/xlsx-pivots.d.ts +10 -0
- package/dist/xlsx-pivots.js +589 -0
- package/dist/xlsx-pivots.js.map +1 -0
- package/dist/xlsx-print-page-setup.d.ts +6 -0
- package/dist/xlsx-print-page-setup.js +224 -0
- package/dist/xlsx-print-page-setup.js.map +1 -0
- package/dist/xlsx-printer-settings.d.ts +4 -0
- package/dist/xlsx-printer-settings.js +279 -0
- package/dist/xlsx-printer-settings.js.map +1 -0
- package/dist/xlsx-protected-ranges.d.ts +4 -0
- package/dist/xlsx-protected-ranges.js +183 -0
- package/dist/xlsx-protected-ranges.js.map +1 -0
- package/dist/xlsx-rich-text-artifacts.d.ts +4 -0
- package/dist/xlsx-rich-text-artifacts.js +303 -0
- package/dist/xlsx-rich-text-artifacts.js.map +1 -0
- package/dist/xlsx-sheet-properties.d.ts +4 -0
- package/dist/xlsx-sheet-properties.js +89 -0
- package/dist/xlsx-sheet-properties.js.map +1 -0
- package/dist/xlsx-sheet-protection.d.ts +4 -0
- package/dist/xlsx-sheet-protection.js +153 -0
- package/dist/xlsx-sheet-protection.js.map +1 -0
- package/dist/xlsx-sheet-visibility.d.ts +4 -0
- package/dist/xlsx-sheet-visibility.js +53 -0
- package/dist/xlsx-sheet-visibility.js.map +1 -0
- package/dist/xlsx-slicer-connection-artifacts.d.ts +4 -0
- package/dist/xlsx-slicer-connection-artifacts.js +426 -0
- package/dist/xlsx-slicer-connection-artifacts.js.map +1 -0
- package/dist/xlsx-sorts.d.ts +5 -0
- package/dist/xlsx-sorts.js +216 -0
- package/dist/xlsx-sorts.js.map +1 -0
- package/dist/xlsx-sparklines.d.ts +4 -0
- package/dist/xlsx-sparklines.js +115 -0
- package/dist/xlsx-sparklines.js.map +1 -0
- package/dist/xlsx-style-only-blank-cells.d.ts +3 -0
- package/dist/xlsx-style-only-blank-cells.js +96 -0
- package/dist/xlsx-style-only-blank-cells.js.map +1 -0
- package/dist/xlsx-style-runs.d.ts +12 -0
- package/dist/xlsx-style-runs.js +35 -0
- package/dist/xlsx-style-runs.js.map +1 -0
- package/dist/xlsx-styles.d.ts +25 -0
- package/dist/xlsx-styles.js +857 -0
- package/dist/xlsx-styles.js.map +1 -0
- package/dist/xlsx-tab-colors.d.ts +4 -0
- package/dist/xlsx-tab-colors.js +166 -0
- package/dist/xlsx-tab-colors.js.map +1 -0
- package/dist/xlsx-tables.d.ts +4 -0
- package/dist/xlsx-tables.js +371 -0
- package/dist/xlsx-tables.js.map +1 -0
- package/dist/xlsx-theme-artifacts.d.ts +6 -0
- package/dist/xlsx-theme-artifacts.js +126 -0
- package/dist/xlsx-theme-artifacts.js.map +1 -0
- package/dist/xlsx-threaded-comment-artifacts.d.ts +8 -0
- package/dist/xlsx-threaded-comment-artifacts.js +329 -0
- package/dist/xlsx-threaded-comment-artifacts.js.map +1 -0
- package/dist/xlsx-validations.d.ts +4 -0
- package/dist/xlsx-validations.js +542 -0
- package/dist/xlsx-validations.js.map +1 -0
- package/dist/xlsx-view-state.d.ts +8 -0
- package/dist/xlsx-view-state.js +144 -0
- package/dist/xlsx-view-state.js.map +1 -0
- package/dist/xlsx-workbook-properties.d.ts +5 -0
- package/dist/xlsx-workbook-properties.js +388 -0
- package/dist/xlsx-workbook-properties.js.map +1 -0
- package/dist/xlsx-workbook-protection.d.ts +4 -0
- package/dist/xlsx-workbook-protection.js +147 -0
- package/dist/xlsx-workbook-protection.js.map +1 -0
- package/dist/xlsx-workbook-sheet-paths.d.ts +4 -0
- package/dist/xlsx-workbook-sheet-paths.js +96 -0
- package/dist/xlsx-workbook-sheet-paths.js.map +1 -0
- package/dist/xlsx-worksheet-cells.d.ts +16 -0
- package/dist/xlsx-worksheet-cells.js +104 -0
- package/dist/xlsx-worksheet-cells.js.map +1 -0
- package/dist/xlsx-worksheet-text-values.d.ts +2 -0
- package/dist/xlsx-worksheet-text-values.js +136 -0
- package/dist/xlsx-worksheet-text-values.js.map +1 -0
- package/dist/xlsx-zip.d.ts +6 -0
- package/dist/xlsx-zip.js +12 -0
- package/dist/xlsx-zip.js.map +1 -0
- 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('&', '&').replaceAll('<', '<').replaceAll('>', '>').replaceAll('"', '"').replaceAll("'", ''');
|
|
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":"AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAA;AAGpD,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,kBAAkB,EAA2C,MAAM,eAAe,CAAA;AAQzH,MAAM,eAAe,GAAG,MAAM,CAAA;AAC9B,MAAM,qBAAqB,GAAG,8DAA8D,CAAA;AAC5F,MAAM,2BAA2B,GAAG,qEAAqE,CAAA;AACzG,MAAM,+BAA+B,GAAG,qFAAqF,CAAA;AAC7H,MAAM,0BAA0B,GAAG,6EAA6E,CAAA;AAChH,MAAM,0BAA0B,GAAG,oCAAoC,CAAA;AAEvE,MAAM,qBAAqB,GAAG;IAC5B,cAAc;IACd,WAAW;IACX,WAAW;IACX,kBAAkB;IAClB,aAAa;IACb,eAAe;IACf,WAAW;IACX,SAAS;IACT,eAAe;IACf,iBAAiB;IACjB,SAAS;IACT,YAAY;IACZ,UAAU;IACV,iBAAiB;IACjB,YAAY;IACZ,QAAQ;CACA,CAAA;AAEV,SAAS,kBAAkB,CAAC,KAAiB;IAC3C,IAAI,MAAM,GAAG,EAAE,CAAA;IACf,KAAK,IAAI,MAAM,GAAG,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,MAAM,EAAE,MAAM,IAAI,eAAe,EAAE,CAAC;QACtE,MAAM,IAAI,MAAM,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,eAAe,CAAC,CAAC,CAAA;IACpF,CAAC;IACD,OAAO,MAAM,CAAA;AACf,CAAC;AAED,SAAS,kBAAkB,CAAC,MAAc;IACxC,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC3C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC;QACtD,KAAK,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED,SAAS,YAAY,CAAC,KAAiB;IACrC,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAA;IAC5B,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;QAC/B,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAA;IACxC,CAAC;IACD,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;AAC9C,CAAC;AAED,SAAS,YAAY,CAAC,UAAkB;IACtC,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAA;IAC5B,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;QAC/B,OAAO,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAA;IAC7C,CAAC;IACD,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAA;AAC1D,CAAC;AAED,SAAS,SAAS,CAAC,KAAa;IAC9B,OAAO,KAAK,CAAC,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;AAC3I,CAAC;AAED,SAAS,UAAU,CAAC,GAAmB,EAAE,IAAY,EAAE,IAAY;IACjE,GAAG,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;AAC7C,CAAC;AAED,SAAS,aAAa,CAAC,GAAW,EAAE,aAAqB;IACvD,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,MAAM,aAAa,wBAAwB,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACpF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;AAC3B,CAAC;AAED,SAAS,kBAAkB,CAAC,GAAkB;IAC5C,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,OAAO,EAAE,CAAA;IACX,CAAC;IACD,OAAO,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,8BAA8B,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;QACzE,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAA;QACjC,MAAM,EAAE,GAAG,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;QAC1C,MAAM,MAAM,GAAG,aAAa,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAClD,MAAM,IAAI,GAAG,aAAa,CAAC,UAAU,EAAE,MAAM,CAAC,CAAA;QAC9C,OAAO,EAAE,IAAI,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IAC3D,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,SAAS,kBAAkB,CAAC,aAA4C;IACtE,IAAI,IAAI,GAAG,CAAC,CAAA;IACZ,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;QACzC,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;QACjD,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA;QAC7C,CAAC;IACH,CAAC;IACD,OAAO,MAAM,MAAM,CAAC,IAAI,CAAC,EAAE,CAAA;AAC7B,CAAC;AAED,SAAS,eAAe,CAAC,YAAgC;IACvD,OAAO,qBAAqB,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,WAAW,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAA;AAC/I,CAAC;AAED,SAAS,qBAAqB,CAAC,GAAkB,EAAE,YAAgC;IACjF,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,OAAO,gFAAgF,qBAAqB,KAAK,eAAe,CAC9H,YAAY,CACb,kBAAkB,CAAA;IACrB,CAAC;IACD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;QACtC,OAAO,GAAG,CAAA;IACZ,CAAC;IACD,OAAO,GAAG,CAAC,OAAO,CAAC,kBAAkB,EAAE,GAAG,eAAe,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAA;AAC5F,CAAC;AAED,SAAS,iBAAiB,CAAC,YAAoB,EAAE,MAAc;IAC7D,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACrC,KAAK,CAAC,GAAG,EAAE,CAAA;IACX,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QACxC,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;YACrB,KAAK,CAAC,GAAG,EAAE,CAAA;QACb,CAAC;aAAM,IAAI,OAAO,KAAK,GAAG,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACjD,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QACrB,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACxB,CAAC;AAED,SAAS,yBAAyB,CAAC,UAAkB;IACnD,OAAO,4BAA4B,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,WAAW,CAAA;AACtE,CAAC;AAED,SAAS,gBAAgB,CAAC,QAAuB,EAAE,cAAsB;IACvE,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,SAAS,CAAA;IAClB,CAAC;IACD,MAAM,YAAY,GAAG,kDAAkD,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC3F,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,OAAO,SAAS,CAAA;IAClB,CAAC;IACD,MAAM,uBAAuB,GAAG,aAAa,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,aAAa,CAAC,YAAY,EAAE,IAAI,CAAC,CAAA;IACxG,OAAO,uBAAuB,KAAK,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAA;AAC9E,CAAC;AAED,MAAM,UAAU,mCAAmC,CACjD,MAAqB,EACrB,UAA6B;IAE7B,MAAM,GAAG,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAA;IACtC,MAAM,sBAAsB,GAAG,IAAI,GAAG,EAA6C,CAAA;IAEnF,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,EAAE;QAC3C,MAAM,SAAS,GAAG,sBAAsB,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,MAAM,CAAA;QACpE,MAAM,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;QAC3C,MAAM,aAAa,GAAG,kBAAkB,CAAC,UAAU,CAAC,GAAG,EAAE,yBAAyB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CACrG,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,+BAA+B,CAC1D,CAAA;QACD,MAAM,QAAQ,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAqC,EAAE;YACzF,MAAM,QAAQ,GAAG,iBAAiB,CAAC,SAAS,EAAE,YAAY,CAAC,MAAM,CAAC,CAAA;YAClE,MAAM,KAAK,GAAG,GAAG,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAA;YAC7C,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,OAAO,EAAE,CAAA;YACX,CAAC;YACD,MAAM,YAAY,GAAG,gBAAgB,CAAC,QAAQ,EAAE,YAAY,CAAC,EAAE,CAAC,CAAA;YAChE,OAAO;gBACL;oBACE,kBAAkB,EAAE,YAAY,CAAC,MAAM;oBACvC,OAAO,EAAE,QAAQ;oBACjB,UAAU,EAAE,YAAY,CAAC,KAAK,CAAC;oBAC/B,UAAU,EAAE,KAAK,CAAC,UAAU;oBAC5B,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;iBAC1C;aACF,CAAA;QACH,CAAC,CAAC,CAAA;QACF,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,sBAAsB,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QACjD,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,OAAO,sBAAsB,CAAA;AAC/B,CAAC;AAED,SAAS,aAAa,CAAC,GAAmB;IACxC,IAAI,IAAI,GAAG,CAAC,CAAA;IACZ,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACpC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,oCAAoC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YACrF,SAAQ;QACV,CAAC;QACD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,oCAAoC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACnF,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAA;QACzB,IAAI,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YAC7C,IAAI,GAAG,KAAK,GAAG,CAAC,CAAA;QAClB,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAS,yBAAyB,CAAC,KAA4F;IAI7H,MAAM,QAAQ,GAAG,gBAAgB,CAAC,iBAAiB,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAA;IACnF,IAAI,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC9C,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAA;IAC3C,CAAC;IACD,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACtC,OAAO;QACL,MAAM,EAAE,qCAAqC,MAAM,CAAC,KAAK,CAAC,MAAM;QAChE,QAAQ,EAAE,qCAAqC,MAAM,CAAC,KAAK,CAAC,MAAM;KACnE,CAAA;AACH,CAAC;AAED,SAAS,qCAAqC,CAAC,eAA8B,EAAE,QAAgB;IAC7F,IAAI,CAAC,eAAe,EAAE,CAAC;QACrB,OAAO,IAAI,CAAA;IACb,CAAC;IACD,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,QAAQ,CAAC,EAAE,CAAA;IACjD,IAAI,eAAe,CAAC,QAAQ,CAAC,aAAa,QAAQ,GAAG,CAAC,EAAE,CAAC;QACvD,OAAO,eAAe,CAAA;IACxB,CAAC;IACD,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QAC1C,OAAO,eAAe,CAAA;IACxB,CAAC;IACD,OAAO,eAAe,CAAC,OAAO,CAC5B,UAAU,EACV,uBAAuB,SAAS,CAAC,QAAQ,CAAC,kBAAkB,0BAA0B,aAAa,CACpG,CAAA;AACH,CAAC;AAED,SAAS,iCAAiC,CAAC,QAAgB;IACzD,IAAI,6BAA6B,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjD,OAAO,QAAQ,CAAA;IACjB,CAAC;IACD,OAAO,QAAQ,CAAC,OAAO,CAAC,uBAAuB,EAAE,yBAAyB,2BAA2B,IAAI,CAAC,CAAA;AAC5G,CAAC;AAED,SAAS,eAAe,CAAC,GAAW,EAAE,IAAY,EAAE,KAAa;IAC/D,MAAM,SAAS,GAAG,GAAG,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,GAAG,CAAA;IACjD,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,MAAM,IAAI,sBAAsB,EAAE,GAAG,CAAC,CAAA;IAC3E,IAAI,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAChC,OAAO,GAAG,CAAC,OAAO,CAAC,iBAAiB,EAAE,IAAI,SAAS,EAAE,CAAC,CAAA;IACxD,CAAC;IACD,OAAO,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,SAAS,GAAG,MAAM,EAAE,CAAC,CAAA;AACpE,CAAC;AAED,SAAS,2BAA2B,CAAC,YAAgC,EAAE,cAAsB;IAC3F,MAAM,MAAM,GAAG,YAAY,IAAI,cAAc,CAAA;IAC7C,OAAO,MAAM,CAAC,OAAO,CAAC,6BAA6B,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC,CAAA;AACrH,CAAC;AAED,SAAS,wBAAwB,CAAC,QAAgB,EAAE,YAAoB;IACtE,MAAM,aAAa,GAAG,iCAAiC,CAAC,QAAQ,CAAC,CAAA;IACjE,IAAI,kDAAkD,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;QAC3E,OAAO,aAAa,CAAC,OAAO,CAAC,kDAAkD,EAAE,YAAY,CAAC,CAAA;IAChG,CAAC;IAED,IAAI,WAAW,GAAG,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,CAAA;IACvD,KAAK,MAAM,WAAW,IAAI,qBAAqB,EAAE,CAAC;QAChD,MAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,WAAW,KAAK,EAAE,GAAG,CAAC,CAAC,CAAA;QAChF,IAAI,YAAY,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,YAAY,GAAG,WAAW,CAAC,EAAE,CAAC;YACzE,WAAW,GAAG,YAAY,CAAA;QAC5B,CAAC;IACH,CAAC;IACD,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;QACpB,OAAO,aAAa,CAAA;IACtB,CAAC;IACD,OAAO,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,WAAW,CAAC,GAAG,YAAY,GAAG,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,CAAA;AACnG,CAAC;AAED,SAAS,8BAA8B,CAAC,KAIvC;IACC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO,KAAK,CAAA;IACd,CAAC;IACD,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;IACpD,IAAI,KAAK,CAAC,UAAU,KAAK,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QAClD,OAAO,KAAK,CAAA;IACd,CAAC;IAED,MAAM,SAAS,GAAG,sBAAsB,MAAM,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,MAAM,CAAA;IAC1E,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;IACjD,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,KAAK,CAAA;IACd,CAAC;IACD,MAAM,MAAM,GAAG,yBAAyB,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAA;IACjH,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAA;IAElC,MAAM,aAAa,GAAG,yBAAyB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IACjE,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,aAAa,CAAC,CAAA;IACzD,MAAM,aAAa,GAAG,kBAAkB,CAAC,YAAY,CAAC,CAAA;IACtD,MAAM,oBAAoB,GAAG,aAAa,CAAC,IAAI,CAC7C,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,KAAK,+BAA+B,IAAI,YAAY,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CACjH,CAAA;IACD,MAAM,cAAc,GAAG,oBAAoB,EAAE,EAAE,IAAI,kBAAkB,CAAC,aAAa,CAAC,CAAA;IACpF,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC1B,UAAU,CACR,KAAK,CAAC,GAAG,EACT,aAAa,EACb,qBAAqB,CAAC,YAAY,EAAE;YAClC,EAAE,EAAE,cAAc;YAClB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,IAAI,EAAE,+BAA+B;SACtC,CAAC,CACH,CAAA;IACH,CAAC;IAED,MAAM,YAAY,GAAG,2BAA2B,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,cAAc,CAAC,CAAA;IAC5F,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,wBAAwB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAA;IAElF,MAAM,eAAe,GAAG,qCAAqC,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,qBAAqB,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC5H,IAAI,eAAe,EAAE,CAAC;QACpB,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,qBAAqB,EAAE,eAAe,CAAC,CAAA;IAC/D,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC;AAED,MAAM,UAAU,mCAAmC,CAAC,KAAiB,EAAE,QAA0B;IAC/F,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;QACzF,OAAO,KAAK,CAAA;IACd,CAAC;IAED,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,CAAA;IAC5B,IAAI,OAAO,GAAG,KAAK,CAAA;IACnB,QAAQ,CAAC,MAAM;SACZ,QAAQ,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;SACnD,OAAO,CAAC,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;QAC7B,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,QAAQ,EAAE,eAAe,IAAI,EAAE,EAAE,CAAC;YAC5D,OAAO,GAAG,8BAA8B,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,IAAI,OAAO,CAAA;QACnF,CAAC;IACH,CAAC,CAAC,CAAA;IAEJ,OAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;AACvC,CAAC"}
|
|
@@ -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[]>;
|