@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,327 @@
|
|
|
1
|
+
import { unzipSync, zipSync } from 'fflate';
|
|
2
|
+
import { getZipText, normalizeZipPath, readXlsxZipEntries } from './xlsx-zip.js';
|
|
3
|
+
import { addContentTypeOverride, buildRelationshipsXml, nextRelationshipId, parseRelationships, resolveTargetPath, setZipText, } from './xlsx-pivot-artifacts.js';
|
|
4
|
+
const binaryChunkSize = 0x8000;
|
|
5
|
+
const chartSheetRelationshipType = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/chartsheet';
|
|
6
|
+
const worksheetRelationshipType = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet';
|
|
7
|
+
const chartSheetPartPathPattern = /^xl\/chartsheets\/sheet\d+\.xml$/u;
|
|
8
|
+
const chartSheetRelsPathPattern = /^xl\/chartsheets\/_rels\/sheet\d+\.xml\.rels$/u;
|
|
9
|
+
function encodeBinaryString(bytes) {
|
|
10
|
+
let binary = '';
|
|
11
|
+
for (let offset = 0; offset < bytes.length; offset += binaryChunkSize) {
|
|
12
|
+
binary += String.fromCharCode(...bytes.subarray(offset, offset + binaryChunkSize));
|
|
13
|
+
}
|
|
14
|
+
return binary;
|
|
15
|
+
}
|
|
16
|
+
function decodeBinaryString(binary) {
|
|
17
|
+
const bytes = new Uint8Array(binary.length);
|
|
18
|
+
for (let index = 0; index < binary.length; index += 1) {
|
|
19
|
+
bytes[index] = binary.charCodeAt(index);
|
|
20
|
+
}
|
|
21
|
+
return bytes;
|
|
22
|
+
}
|
|
23
|
+
function encodeBase64(bytes) {
|
|
24
|
+
const btoa = globalThis.btoa;
|
|
25
|
+
if (typeof btoa === 'function') {
|
|
26
|
+
return btoa(encodeBinaryString(bytes));
|
|
27
|
+
}
|
|
28
|
+
return Buffer.from(bytes).toString('base64');
|
|
29
|
+
}
|
|
30
|
+
function decodeBase64(dataBase64) {
|
|
31
|
+
const atob = globalThis.atob;
|
|
32
|
+
if (typeof atob === 'function') {
|
|
33
|
+
return decodeBinaryString(atob(dataBase64));
|
|
34
|
+
}
|
|
35
|
+
return new Uint8Array(Buffer.from(dataBase64, 'base64'));
|
|
36
|
+
}
|
|
37
|
+
function encodedPartSnapshot(path, bytes) {
|
|
38
|
+
return {
|
|
39
|
+
path,
|
|
40
|
+
storage: 'base64',
|
|
41
|
+
dataBase64: encodeBase64(bytes),
|
|
42
|
+
byteLength: bytes.byteLength,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
function decodedPartBytes(part) {
|
|
46
|
+
if (part.storage !== 'base64') {
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
const bytes = decodeBase64(part.dataBase64);
|
|
50
|
+
return bytes.byteLength === part.byteLength ? bytes : undefined;
|
|
51
|
+
}
|
|
52
|
+
function preservedPartsByPath(parts) {
|
|
53
|
+
const output = new Map();
|
|
54
|
+
parts.forEach((part) => {
|
|
55
|
+
const bytes = decodedPartBytes(part);
|
|
56
|
+
if (bytes) {
|
|
57
|
+
output.set(normalizeZipPath(part.path), bytes);
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
return output;
|
|
61
|
+
}
|
|
62
|
+
function readXmlAttribute(attributes, attributeName) {
|
|
63
|
+
return new RegExp(`\\b${attributeName}=("|')([\\s\\S]*?)\\1`, 'u').exec(attributes)?.[2] ?? null;
|
|
64
|
+
}
|
|
65
|
+
function decodeXmlAttribute(value) {
|
|
66
|
+
return value.replaceAll('"', '"').replaceAll(''', "'").replaceAll('<', '<').replaceAll('>', '>').replaceAll('&', '&');
|
|
67
|
+
}
|
|
68
|
+
function workbookSheetRelationshipEntries(workbookXml) {
|
|
69
|
+
if (!workbookXml) {
|
|
70
|
+
return [];
|
|
71
|
+
}
|
|
72
|
+
return [...workbookXml.matchAll(/<(?:[A-Za-z_][\w.-]*:)?sheet\b([^>]*)\/?>/gu)].flatMap((match) => {
|
|
73
|
+
const attributes = match[1] ?? '';
|
|
74
|
+
const rawName = readXmlAttribute(attributes, 'name');
|
|
75
|
+
const relationshipId = readXmlAttribute(attributes, 'r:id') ?? readXmlAttribute(attributes, 'id');
|
|
76
|
+
const sheetId = Number(readXmlAttribute(attributes, 'sheetId'));
|
|
77
|
+
const state = readXmlAttribute(attributes, 'state');
|
|
78
|
+
return rawName && relationshipId
|
|
79
|
+
? [
|
|
80
|
+
{
|
|
81
|
+
name: decodeXmlAttribute(rawName),
|
|
82
|
+
relationshipId,
|
|
83
|
+
...(Number.isSafeInteger(sheetId) && sheetId > 0 ? { sheetId } : {}),
|
|
84
|
+
...(state === 'hidden' || state === 'veryHidden' ? { state } : {}),
|
|
85
|
+
},
|
|
86
|
+
]
|
|
87
|
+
: [];
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
function packageRelationshipsPath(partPath) {
|
|
91
|
+
const normalizedPath = normalizeZipPath(partPath);
|
|
92
|
+
const directory = normalizedPath.slice(0, normalizedPath.lastIndexOf('/'));
|
|
93
|
+
const fileName = normalizedPath.slice(normalizedPath.lastIndexOf('/') + 1);
|
|
94
|
+
return `${directory}/_rels/${fileName}.rels`;
|
|
95
|
+
}
|
|
96
|
+
function collectPackageDependencyPaths(zip, rootPartPath) {
|
|
97
|
+
const collectedPaths = new Set();
|
|
98
|
+
const pending = [normalizeZipPath(rootPartPath)];
|
|
99
|
+
while (pending.length > 0) {
|
|
100
|
+
const partPath = pending.pop();
|
|
101
|
+
if (!partPath || collectedPaths.has(partPath) || !zip[partPath]) {
|
|
102
|
+
continue;
|
|
103
|
+
}
|
|
104
|
+
collectedPaths.add(partPath);
|
|
105
|
+
const relsPath = packageRelationshipsPath(partPath);
|
|
106
|
+
const relsXml = getZipText(zip, relsPath);
|
|
107
|
+
if (!relsXml) {
|
|
108
|
+
continue;
|
|
109
|
+
}
|
|
110
|
+
collectedPaths.add(relsPath);
|
|
111
|
+
parseRelationships(relsXml).forEach((relationship) => {
|
|
112
|
+
if (relationship.targetMode === 'External') {
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
pending.push(normalizeZipPath(resolveTargetPath(partPath, relationship.target)));
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
return collectedPaths;
|
|
119
|
+
}
|
|
120
|
+
function extensionFromPath(path) {
|
|
121
|
+
const fileName = normalizeZipPath(path).slice(normalizeZipPath(path).lastIndexOf('/') + 1);
|
|
122
|
+
const extensionIndex = fileName.lastIndexOf('.');
|
|
123
|
+
return extensionIndex >= 0 && extensionIndex < fileName.length - 1 ? fileName.slice(extensionIndex + 1).toLowerCase() : null;
|
|
124
|
+
}
|
|
125
|
+
function readContentTypeDefaults(contentTypesXml, partPaths) {
|
|
126
|
+
const neededExtensions = new Set(partPaths.map(extensionFromPath).filter((extension) => Boolean(extension)));
|
|
127
|
+
const defaultsByExtension = new Map();
|
|
128
|
+
for (const match of contentTypesXml.matchAll(/<Default\b([^>]*)\/?>/gu)) {
|
|
129
|
+
const attributes = match[1] ?? '';
|
|
130
|
+
const extension = readXmlAttribute(attributes, 'Extension')?.toLowerCase();
|
|
131
|
+
const contentType = readXmlAttribute(attributes, 'ContentType');
|
|
132
|
+
if (!extension || !contentType || !neededExtensions.has(extension)) {
|
|
133
|
+
continue;
|
|
134
|
+
}
|
|
135
|
+
defaultsByExtension.set(extension, { extension, contentType });
|
|
136
|
+
}
|
|
137
|
+
return [...defaultsByExtension.values()].toSorted((left, right) => left.extension.localeCompare(right.extension));
|
|
138
|
+
}
|
|
139
|
+
function readContentTypeOverrides(contentTypesXml, partPaths) {
|
|
140
|
+
const neededPartNames = new Set(partPaths.map((path) => `/${normalizeZipPath(path)}`));
|
|
141
|
+
const overridesByPartName = new Map();
|
|
142
|
+
for (const match of contentTypesXml.matchAll(/<Override\b([^>]*)\/?>/gu)) {
|
|
143
|
+
const attributes = match[1] ?? '';
|
|
144
|
+
const partName = readXmlAttribute(attributes, 'PartName');
|
|
145
|
+
const contentType = readXmlAttribute(attributes, 'ContentType');
|
|
146
|
+
if (!partName || !contentType || !neededPartNames.has(partName)) {
|
|
147
|
+
continue;
|
|
148
|
+
}
|
|
149
|
+
overridesByPartName.set(partName, { partName, contentType });
|
|
150
|
+
}
|
|
151
|
+
return [...overridesByPartName.values()].toSorted((left, right) => left.partName.localeCompare(right.partName));
|
|
152
|
+
}
|
|
153
|
+
function addContentTypeDefault(contentTypesXml, extension, contentType) {
|
|
154
|
+
const existingDefaultPattern = new RegExp(`<Default\\b[^>]*\\bExtension=("|')${extension}\\1`, 'u');
|
|
155
|
+
if (existingDefaultPattern.test(contentTypesXml) || !contentTypesXml.includes('</Types>')) {
|
|
156
|
+
return contentTypesXml;
|
|
157
|
+
}
|
|
158
|
+
return contentTypesXml.replace('</Types>', `<Default Extension="${extension}" ContentType="${contentType}"/></Types>`);
|
|
159
|
+
}
|
|
160
|
+
function removeContentTypeOverride(contentTypesXml, partName) {
|
|
161
|
+
return contentTypesXml.replace(new RegExp(`<Override\\b[^>]*\\bPartName="${partName}"[^>]*/>`, 'u'), '');
|
|
162
|
+
}
|
|
163
|
+
function escapeXml(value) {
|
|
164
|
+
return value.replaceAll('&', '&').replaceAll('<', '<').replaceAll('>', '>').replaceAll('"', '"').replaceAll("'", ''');
|
|
165
|
+
}
|
|
166
|
+
function normalizeRelationshipTarget(target) {
|
|
167
|
+
return normalizeZipPath(target).replace(/^xl\//u, '');
|
|
168
|
+
}
|
|
169
|
+
function replaceWorkbookSheetRelationship(relationships, relationshipId, target) {
|
|
170
|
+
return relationships.map((relationship) => relationship.id === relationshipId
|
|
171
|
+
? {
|
|
172
|
+
id: relationship.id,
|
|
173
|
+
type: chartSheetRelationshipType,
|
|
174
|
+
target,
|
|
175
|
+
}
|
|
176
|
+
: relationship);
|
|
177
|
+
}
|
|
178
|
+
function workbookSheetByName(workbookXml, sheetName) {
|
|
179
|
+
return workbookSheetRelationshipEntries(workbookXml).find((sheet) => sheet.name === sheetName);
|
|
180
|
+
}
|
|
181
|
+
function nextWorkbookSheetId(workbookXml, preferredSheetId) {
|
|
182
|
+
const usedIds = new Set(workbookSheetRelationshipEntries(workbookXml).flatMap((sheet) => (sheet.sheetId ? [sheet.sheetId] : [])));
|
|
183
|
+
if (preferredSheetId !== undefined && !usedIds.has(preferredSheetId)) {
|
|
184
|
+
return preferredSheetId;
|
|
185
|
+
}
|
|
186
|
+
let next = 1;
|
|
187
|
+
while (usedIds.has(next)) {
|
|
188
|
+
next += 1;
|
|
189
|
+
}
|
|
190
|
+
return next;
|
|
191
|
+
}
|
|
192
|
+
function ensureWorkbookSheetEntry(workbookXml, entry, relationshipId) {
|
|
193
|
+
if (workbookSheetByName(workbookXml, entry.name)) {
|
|
194
|
+
return workbookXml;
|
|
195
|
+
}
|
|
196
|
+
const sheetId = nextWorkbookSheetId(workbookXml, entry.sheetId);
|
|
197
|
+
const stateAttribute = entry.state ? ` state="${entry.state}"` : '';
|
|
198
|
+
const sheetXml = `<sheet name="${escapeXml(entry.name)}" sheetId="${String(sheetId)}" r:id="${escapeXml(relationshipId)}"${stateAttribute}/>`;
|
|
199
|
+
const withRelationshipNamespace = /xmlns:r=/u.test(workbookXml)
|
|
200
|
+
? workbookXml
|
|
201
|
+
: workbookXml.replace(/<workbook\b([^>]*)>/u, `<workbook$1 xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships">`);
|
|
202
|
+
return withRelationshipNamespace.includes('</sheets>')
|
|
203
|
+
? withRelationshipNamespace.replace('</sheets>', `${sheetXml}</sheets>`)
|
|
204
|
+
: withRelationshipNamespace.replace('</workbook>', `<sheets>${sheetXml}</sheets></workbook>`);
|
|
205
|
+
}
|
|
206
|
+
export function readImportedWorkbookChartArtifacts(source) {
|
|
207
|
+
const zip = readXlsxZipEntries(source);
|
|
208
|
+
const workbookRelationships = parseRelationships(getZipText(zip, 'xl/_rels/workbook.xml.rels'));
|
|
209
|
+
const chartSheetArtifacts = [];
|
|
210
|
+
const partPaths = new Set();
|
|
211
|
+
workbookSheetRelationshipEntries(getZipText(zip, 'xl/workbook.xml')).forEach((sheet) => {
|
|
212
|
+
const relationship = workbookRelationships.find((candidate) => candidate.id === sheet.relationshipId && candidate.type === chartSheetRelationshipType);
|
|
213
|
+
if (!relationship || relationship.targetMode === 'External') {
|
|
214
|
+
return;
|
|
215
|
+
}
|
|
216
|
+
const chartSheetPath = normalizeZipPath(resolveTargetPath('xl/workbook.xml', relationship.target));
|
|
217
|
+
if (!chartSheetPartPathPattern.test(chartSheetPath)) {
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
chartSheetArtifacts.push({
|
|
221
|
+
name: sheet.name,
|
|
222
|
+
relationshipTarget: relationship.target,
|
|
223
|
+
...(sheet.sheetId !== undefined ? { sheetId: sheet.sheetId } : {}),
|
|
224
|
+
...(sheet.state !== undefined ? { state: sheet.state } : {}),
|
|
225
|
+
});
|
|
226
|
+
collectPackageDependencyPaths(zip, chartSheetPath).forEach((path) => {
|
|
227
|
+
partPaths.add(path);
|
|
228
|
+
});
|
|
229
|
+
});
|
|
230
|
+
if (partPaths.size === 0) {
|
|
231
|
+
return { artifacts: undefined, chartSheetArtifacts: undefined };
|
|
232
|
+
}
|
|
233
|
+
const contentTypePartPaths = [...partPaths].filter((path) => !path.endsWith('.rels'));
|
|
234
|
+
const contentTypesXml = getZipText(zip, '[Content_Types].xml') ?? '';
|
|
235
|
+
const parts = [...partPaths].toSorted().flatMap((path) => {
|
|
236
|
+
const bytes = zip[path];
|
|
237
|
+
return bytes ? [encodedPartSnapshot(path, bytes)] : [];
|
|
238
|
+
});
|
|
239
|
+
return {
|
|
240
|
+
artifacts: {
|
|
241
|
+
parts,
|
|
242
|
+
...(contentTypesXml
|
|
243
|
+
? {
|
|
244
|
+
...(readContentTypeDefaults(contentTypesXml, contentTypePartPaths).length > 0
|
|
245
|
+
? { contentTypeDefaults: readContentTypeDefaults(contentTypesXml, contentTypePartPaths) }
|
|
246
|
+
: {}),
|
|
247
|
+
...(readContentTypeOverrides(contentTypesXml, contentTypePartPaths).length > 0
|
|
248
|
+
? { contentTypeOverrides: readContentTypeOverrides(contentTypesXml, contentTypePartPaths) }
|
|
249
|
+
: {}),
|
|
250
|
+
}
|
|
251
|
+
: {}),
|
|
252
|
+
},
|
|
253
|
+
chartSheetArtifacts: chartSheetArtifacts.length > 0 ? chartSheetArtifacts : undefined,
|
|
254
|
+
};
|
|
255
|
+
}
|
|
256
|
+
export function addExportChartArtifactsToXlsxBytes(bytes, snapshot) {
|
|
257
|
+
const workbookArtifacts = snapshot.workbook.metadata?.chartArtifacts;
|
|
258
|
+
const chartSheetArtifacts = snapshot.workbook.metadata?.chartSheetArtifacts ?? [];
|
|
259
|
+
const orderedSheets = snapshot.sheets.toSorted((left, right) => left.order - right.order);
|
|
260
|
+
if (!workbookArtifacts || chartSheetArtifacts.length === 0) {
|
|
261
|
+
return bytes;
|
|
262
|
+
}
|
|
263
|
+
const zip = unzipSync(bytes);
|
|
264
|
+
const partsByPath = preservedPartsByPath(workbookArtifacts.parts);
|
|
265
|
+
const copiedPartPaths = new Set();
|
|
266
|
+
let changed = false;
|
|
267
|
+
partsByPath.forEach((partBytes, path) => {
|
|
268
|
+
zip[path] = partBytes;
|
|
269
|
+
copiedPartPaths.add(path);
|
|
270
|
+
changed = true;
|
|
271
|
+
});
|
|
272
|
+
let workbookXml = getZipText(zip, 'xl/workbook.xml');
|
|
273
|
+
let workbookRelationships = parseRelationships(getZipText(zip, 'xl/_rels/workbook.xml.rels'));
|
|
274
|
+
chartSheetArtifacts.forEach((chartSheet) => {
|
|
275
|
+
if (!workbookXml) {
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
const existingSheet = workbookSheetByName(workbookXml, chartSheet.name);
|
|
279
|
+
const relationshipId = existingSheet?.relationshipId ?? nextRelationshipId(workbookRelationships);
|
|
280
|
+
const existingRelationship = workbookRelationships.find((relationship) => relationship.id === relationshipId);
|
|
281
|
+
if (existingRelationship?.type === worksheetRelationshipType) {
|
|
282
|
+
const generatedWorksheetPath = normalizeZipPath(resolveTargetPath('xl/workbook.xml', existingRelationship.target));
|
|
283
|
+
delete zip[generatedWorksheetPath];
|
|
284
|
+
delete zip[packageRelationshipsPath(generatedWorksheetPath)];
|
|
285
|
+
changed = true;
|
|
286
|
+
}
|
|
287
|
+
if (!existingRelationship) {
|
|
288
|
+
workbookRelationships.push({
|
|
289
|
+
id: relationshipId,
|
|
290
|
+
type: chartSheetRelationshipType,
|
|
291
|
+
target: chartSheet.relationshipTarget,
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
workbookRelationships = replaceWorkbookSheetRelationship(workbookRelationships, relationshipId, chartSheet.relationshipTarget);
|
|
295
|
+
workbookXml = ensureWorkbookSheetEntry(workbookXml, chartSheet, relationshipId);
|
|
296
|
+
changed = true;
|
|
297
|
+
});
|
|
298
|
+
setZipText(zip, 'xl/_rels/workbook.xml.rels', buildRelationshipsXml(workbookRelationships));
|
|
299
|
+
if (workbookXml) {
|
|
300
|
+
setZipText(zip, 'xl/workbook.xml', workbookXml);
|
|
301
|
+
}
|
|
302
|
+
let contentTypesXml = getZipText(zip, '[Content_Types].xml') ?? '';
|
|
303
|
+
chartSheetArtifacts.forEach((chartSheet) => {
|
|
304
|
+
const sheetIndex = orderedSheets.findIndex((candidate) => candidate.name === chartSheet.name);
|
|
305
|
+
if (sheetIndex >= 0) {
|
|
306
|
+
contentTypesXml = removeContentTypeOverride(contentTypesXml, `/xl/worksheets/sheet${String(sheetIndex + 1)}.xml`);
|
|
307
|
+
}
|
|
308
|
+
});
|
|
309
|
+
for (const defaultEntry of workbookArtifacts.contentTypeDefaults ?? []) {
|
|
310
|
+
contentTypesXml = addContentTypeDefault(contentTypesXml, defaultEntry.extension, defaultEntry.contentType);
|
|
311
|
+
}
|
|
312
|
+
for (const overrideEntry of workbookArtifacts.contentTypeOverrides ?? []) {
|
|
313
|
+
if (!copiedPartPaths.has(normalizeZipPath(overrideEntry.partName))) {
|
|
314
|
+
continue;
|
|
315
|
+
}
|
|
316
|
+
contentTypesXml = addContentTypeOverride(contentTypesXml, overrideEntry.partName, overrideEntry.contentType);
|
|
317
|
+
}
|
|
318
|
+
if (contentTypesXml.length > 0) {
|
|
319
|
+
setZipText(zip, '[Content_Types].xml', contentTypesXml);
|
|
320
|
+
}
|
|
321
|
+
const copiedChartSheetParts = [...copiedPartPaths].some((path) => chartSheetPartPathPattern.test(path) || chartSheetRelsPathPattern.test(path));
|
|
322
|
+
const workbookHasChartSheetRelationship = workbookRelationships.some((relationship) => relationship.type === chartSheetRelationshipType &&
|
|
323
|
+
copiedPartPaths.has(normalizeZipPath(resolveTargetPath('xl/workbook.xml', relationship.target))) &&
|
|
324
|
+
normalizeRelationshipTarget(relationship.target).startsWith('chartsheets/'));
|
|
325
|
+
return changed && copiedChartSheetParts && workbookHasChartSheetRelationship ? zipSync(zip) : bytes;
|
|
326
|
+
}
|
|
327
|
+
//# sourceMappingURL=xlsx-chart-artifacts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xlsx-chart-artifacts.js","sourceRoot":"","sources":["../src/xlsx-chart-artifacts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { WorkbookChartSnapshot, WorkbookSnapshot } from '@bilig/protocol';
|
|
2
|
+
import { type XlsxZipSource } from './xlsx-zip.js';
|
|
3
|
+
export declare function addExportChartsToXlsxBytes(bytes: Uint8Array, snapshot: WorkbookSnapshot, exportSheetNamesByOriginalName: ReadonlyMap<string, string>): Uint8Array;
|
|
4
|
+
export declare function readImportedWorkbookCharts(source: XlsxZipSource, sheetNames: readonly string[]): WorkbookChartSnapshot[] | undefined;
|