@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,99 @@
|
|
|
1
|
+
import { strFromU8, strToU8, unzipSync, zipSync } from 'fflate';
|
|
2
|
+
export const customNumberFormatStartId = 164;
|
|
3
|
+
export function escapeXmlAttribute(value) {
|
|
4
|
+
return value.replace(/&/g, '&').replace(/"/g, '"').replace(/</g, '<').replace(/>/g, '>');
|
|
5
|
+
}
|
|
6
|
+
function xmlPrefixForTagName(tagName) {
|
|
7
|
+
const separator = tagName.indexOf(':');
|
|
8
|
+
return separator >= 0 ? tagName.slice(0, separator + 1) : '';
|
|
9
|
+
}
|
|
10
|
+
function xmlTagName(prefix, localName) {
|
|
11
|
+
return `${prefix}${localName}`;
|
|
12
|
+
}
|
|
13
|
+
export function addCustomNumberFormatsToStylesXml(stylesXml, formatIdsByCode) {
|
|
14
|
+
if (formatIdsByCode.size === 0) {
|
|
15
|
+
return stylesXml;
|
|
16
|
+
}
|
|
17
|
+
const buildNumFmtEntries = (prefix) => [...formatIdsByCode.entries()]
|
|
18
|
+
.map(([formatCode, id]) => `<${xmlTagName(prefix, 'numFmt')} numFmtId="${String(id)}" formatCode="${escapeXmlAttribute(formatCode)}"/>`)
|
|
19
|
+
.join('');
|
|
20
|
+
const selfClosingNumFmts = /<((?:[A-Za-z_][\w.-]*:)?numFmts)\b[^>]*\/>/u;
|
|
21
|
+
const selfClosingMatch = selfClosingNumFmts.exec(stylesXml);
|
|
22
|
+
if (selfClosingMatch) {
|
|
23
|
+
const tagName = selfClosingMatch[1];
|
|
24
|
+
const prefix = xmlPrefixForTagName(tagName);
|
|
25
|
+
return stylesXml.replace(selfClosingNumFmts, () => `<${tagName} count="${String(formatIdsByCode.size)}">${buildNumFmtEntries(prefix)}</${tagName}>`);
|
|
26
|
+
}
|
|
27
|
+
const existingNumFmts = /<((?:[A-Za-z_][\w.-]*:)?numFmts)\b[^>]*>/u.exec(stylesXml);
|
|
28
|
+
if (existingNumFmts) {
|
|
29
|
+
const openingTag = existingNumFmts[0];
|
|
30
|
+
const tagName = existingNumFmts[1];
|
|
31
|
+
const prefix = xmlPrefixForTagName(tagName);
|
|
32
|
+
const count = readXmlNumberAttribute(openingTag, 'count') ?? 0;
|
|
33
|
+
const nextCount = Number.isFinite(count) ? count + formatIdsByCode.size : formatIdsByCode.size;
|
|
34
|
+
const closingTag = `</${tagName}>`;
|
|
35
|
+
return stylesXml
|
|
36
|
+
.replace(openingTag, () => setXmlAttribute(openingTag, 'count', String(nextCount)))
|
|
37
|
+
.replace(closingTag, () => `${buildNumFmtEntries(prefix)}${closingTag}`);
|
|
38
|
+
}
|
|
39
|
+
const fontsMatch = /<((?:[A-Za-z_][\w.-]*:)?fonts)\b/u.exec(stylesXml);
|
|
40
|
+
const prefix = fontsMatch ? xmlPrefixForTagName(fontsMatch[1]) : '';
|
|
41
|
+
const numFmtsTagName = xmlTagName(prefix, 'numFmts');
|
|
42
|
+
const numFmtsXml = `<${numFmtsTagName} count="${String(formatIdsByCode.size)}">${buildNumFmtEntries(prefix)}</${numFmtsTagName}>`;
|
|
43
|
+
return fontsMatch ? stylesXml.replace(fontsMatch[0], (match) => `${numFmtsXml}${match}`) : stylesXml;
|
|
44
|
+
}
|
|
45
|
+
export function repairLeadingZeroNumberFormatIds(bytes) {
|
|
46
|
+
const zip = unzipSync(bytes);
|
|
47
|
+
const styles = zip['xl/styles.xml'];
|
|
48
|
+
if (!styles) {
|
|
49
|
+
return bytes;
|
|
50
|
+
}
|
|
51
|
+
let stylesXml = strFromU8(styles);
|
|
52
|
+
const leadingZeroFormatCodes = [...new Set([...stylesXml.matchAll(/\bnumFmtId="(0[0-9]+)"/gu)].map((match) => match[1]))];
|
|
53
|
+
if (leadingZeroFormatCodes.length === 0) {
|
|
54
|
+
return bytes;
|
|
55
|
+
}
|
|
56
|
+
const usedIds = new Set([...stylesXml.matchAll(/\bnumFmtId="([0-9]+)"/gu)].map((match) => Number(match[1])));
|
|
57
|
+
const formatIdsByCode = new Map();
|
|
58
|
+
let nextId = customNumberFormatStartId;
|
|
59
|
+
for (const formatCode of leadingZeroFormatCodes) {
|
|
60
|
+
while (usedIds.has(nextId)) {
|
|
61
|
+
nextId += 1;
|
|
62
|
+
}
|
|
63
|
+
formatIdsByCode.set(formatCode, nextId);
|
|
64
|
+
usedIds.add(nextId);
|
|
65
|
+
}
|
|
66
|
+
for (const [formatCode, id] of formatIdsByCode.entries()) {
|
|
67
|
+
stylesXml = stylesXml.replaceAll(`numFmtId="${formatCode}"`, `numFmtId="${String(id)}"`);
|
|
68
|
+
}
|
|
69
|
+
const customIds = [...formatIdsByCode.values()].map(String).join('|');
|
|
70
|
+
const xfWithCustomNumberFormatPattern = new RegExp(`<(?:[A-Za-z_][\\w.-]*:)?xf\\b[^>]*\\bnumFmtId="(${customIds})"[^>]*(?:/?>)`, 'gu');
|
|
71
|
+
stylesXml = stylesXml.replace(xfWithCustomNumberFormatPattern, (tag) => tag.includes('applyNumberFormat=') ? tag : setXmlAttribute(tag, 'applyNumberFormat', '1'));
|
|
72
|
+
stylesXml = addCustomNumberFormatsToStylesXml(stylesXml, formatIdsByCode);
|
|
73
|
+
zip['xl/styles.xml'] = strToU8(stylesXml);
|
|
74
|
+
return zipSync(zip);
|
|
75
|
+
}
|
|
76
|
+
export function getZipText(zip, path) {
|
|
77
|
+
const file = zip[path];
|
|
78
|
+
return file ? strFromU8(file) : null;
|
|
79
|
+
}
|
|
80
|
+
export function setZipText(zip, path, text) {
|
|
81
|
+
zip[path] = strToU8(text);
|
|
82
|
+
}
|
|
83
|
+
export function setXmlAttribute(tag, name, value) {
|
|
84
|
+
const attribute = `${name}="${escapeXmlAttribute(value)}"`;
|
|
85
|
+
const existingAttribute = new RegExp(`\\s${name}="[^"]*"`, 'u');
|
|
86
|
+
if (existingAttribute.test(tag)) {
|
|
87
|
+
return tag.replace(existingAttribute, ` ${attribute}`);
|
|
88
|
+
}
|
|
89
|
+
return tag.replace(/\/?>$/u, (ending) => ` ${attribute}${ending}`);
|
|
90
|
+
}
|
|
91
|
+
export function readXmlNumberAttribute(tag, name) {
|
|
92
|
+
const match = new RegExp(`\\s${name}="([0-9]+)"`, 'u').exec(tag);
|
|
93
|
+
if (!match) {
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
const value = Number(match[1]);
|
|
97
|
+
return Number.isSafeInteger(value) && value >= 0 ? value : null;
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=xlsx-export-xml.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xlsx-export-xml.js","sourceRoot":"","sources":["../src/xlsx-export-xml.ts"],"names":[],"mappings":"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"}
|