@simplysm/excel 14.0.6 → 14.0.8
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/dist/excel-col.d.ts +3 -4
- package/dist/excel-col.d.ts.map +1 -1
- package/dist/excel-col.js +4 -5
- package/dist/excel-col.js.map +1 -1
- package/dist/excel-row.d.ts +3 -4
- package/dist/excel-row.d.ts.map +1 -1
- package/dist/excel-row.js +4 -5
- package/dist/excel-row.js.map +1 -1
- package/dist/excel-worksheet.d.ts +6 -1
- package/dist/excel-worksheet.d.ts.map +1 -1
- package/dist/excel-worksheet.js +86 -7
- package/dist/excel-worksheet.js.map +1 -1
- package/dist/xml/excel-xml-relationship.js +3 -3
- package/dist/xml/excel-xml-relationship.js.map +1 -1
- package/dist/xml/excel-xml-shared-string.js +1 -1
- package/dist/xml/excel-xml-shared-string.js.map +1 -1
- package/package.json +2 -2
- package/src/excel-col.ts +3 -8
- package/src/excel-row.ts +3 -8
- package/src/excel-worksheet.ts +133 -8
- package/src/xml/excel-xml-relationship.ts +3 -3
- package/src/xml/excel-xml-shared-string.ts +1 -1
package/dist/excel-col.d.ts
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import { ExcelCell } from "./excel-cell";
|
|
1
|
+
import type { ExcelCell } from "./excel-cell";
|
|
3
2
|
import type { ZipCache } from "./utils/zip-cache";
|
|
4
3
|
/** Excel 워크시트의 열을 나타내는 클래스. 셀 접근 및 열 너비 설정 기능을 제공한다. */
|
|
5
4
|
export declare class ExcelCol {
|
|
6
5
|
private readonly _zipCache;
|
|
7
6
|
private readonly _targetFileName;
|
|
8
7
|
private readonly _c;
|
|
9
|
-
private readonly
|
|
10
|
-
constructor(_zipCache: ZipCache, _targetFileName: string, _c: number);
|
|
8
|
+
private readonly _cellFactory;
|
|
9
|
+
constructor(_zipCache: ZipCache, _targetFileName: string, _c: number, _cellFactory: (r: number) => ExcelCell);
|
|
11
10
|
/** 지정된 행 인덱스의 셀 반환 (0 기반) */
|
|
12
11
|
cell(r: number): ExcelCell;
|
|
13
12
|
/** 열의 모든 셀 반환 */
|
package/dist/excel-col.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-col.d.ts","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"excel-col.d.ts","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE9C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,wDAAwD;AACxD,qBAAa,QAAQ;IAEjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAHZ,SAAS,EAAE,QAAQ,EACnB,eAAe,EAAE,MAAM,EACvB,EAAE,EAAE,MAAM,EACV,YAAY,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,SAAS;IAGzD,6BAA6B;IAC7B,IAAI,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS;IAI1B,iBAAiB;IACX,QAAQ,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAYtC,cAAc;IACR,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAK7B,UAAU;CAGzB"}
|
package/dist/excel-col.js
CHANGED
|
@@ -1,19 +1,18 @@
|
|
|
1
|
-
import "@simplysm/core-common";
|
|
2
|
-
import { ExcelCell } from "./excel-cell.js";
|
|
3
1
|
/** Excel 워크시트의 열을 나타내는 클래스. 셀 접근 및 열 너비 설정 기능을 제공한다. */
|
|
4
2
|
export class ExcelCol {
|
|
5
3
|
_zipCache;
|
|
6
4
|
_targetFileName;
|
|
7
5
|
_c;
|
|
8
|
-
|
|
9
|
-
constructor(_zipCache, _targetFileName, _c) {
|
|
6
|
+
_cellFactory;
|
|
7
|
+
constructor(_zipCache, _targetFileName, _c, _cellFactory) {
|
|
10
8
|
this._zipCache = _zipCache;
|
|
11
9
|
this._targetFileName = _targetFileName;
|
|
12
10
|
this._c = _c;
|
|
11
|
+
this._cellFactory = _cellFactory;
|
|
13
12
|
}
|
|
14
13
|
/** 지정된 행 인덱스의 셀 반환 (0 기반) */
|
|
15
14
|
cell(r) {
|
|
16
|
-
return this.
|
|
15
|
+
return this._cellFactory(r);
|
|
17
16
|
}
|
|
18
17
|
/** 열의 모든 셀 반환 */
|
|
19
18
|
async getCells() {
|
package/dist/excel-col.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-col.js","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"excel-col.js","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"AAIA,wDAAwD;AACxD,MAAM,OAAO,QAAQ;IAEA;IACA;IACA;IACA;IAJnB,YACmB,SAAmB,EACnB,eAAuB,EACvB,EAAU,EACV,YAAsC;QAHtC,cAAS,GAAT,SAAS,CAAU;QACnB,oBAAe,GAAf,eAAe,CAAQ;QACvB,OAAE,GAAF,EAAE,CAAQ;QACV,iBAAY,GAAZ,YAAY,CAA0B;IACtD,CAAC;IAEJ,6BAA6B;IAC7B,IAAI,CAAC,CAAS;QACZ,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,iBAAiB;IACjB,KAAK,CAAC,QAAQ;QACZ,MAAM,MAAM,GAAgB,EAAE,CAAC;QAC/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAE3B,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,cAAc;IACd,KAAK,CAAC,QAAQ,CAAC,IAAY;QACzB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAChE,CAAC;IAEO,KAAK,CAAC,UAAU;QACtB,OAAO,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,eAAe,EAAE,CAAC,CAAsB,CAAC;IAClG,CAAC;CACF"}
|
package/dist/excel-row.d.ts
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import { ExcelCell } from "./excel-cell";
|
|
1
|
+
import type { ExcelCell } from "./excel-cell";
|
|
3
2
|
import type { ZipCache } from "./utils/zip-cache";
|
|
4
3
|
/** Excel 워크시트의 행을 나타내는 클래스. 셀 접근 기능을 제공한다. */
|
|
5
4
|
export declare class ExcelRow {
|
|
6
5
|
private readonly _zipCache;
|
|
7
6
|
private readonly _targetFileName;
|
|
8
7
|
private readonly _r;
|
|
9
|
-
private readonly
|
|
10
|
-
constructor(_zipCache: ZipCache, _targetFileName: string, _r: number);
|
|
8
|
+
private readonly _cellFactory;
|
|
9
|
+
constructor(_zipCache: ZipCache, _targetFileName: string, _r: number, _cellFactory: (c: number) => ExcelCell);
|
|
11
10
|
/** 지정된 열 인덱스의 셀 반환 (0 기반) */
|
|
12
11
|
cell(c: number): ExcelCell;
|
|
13
12
|
/** 행의 모든 셀 반환 */
|
package/dist/excel-row.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-row.d.ts","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"excel-row.d.ts","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE9C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,8CAA8C;AAC9C,qBAAa,QAAQ;IAEjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAHZ,SAAS,EAAE,QAAQ,EACnB,eAAe,EAAE,MAAM,EACvB,EAAE,EAAE,MAAM,EACV,YAAY,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,SAAS;IAGzD,6BAA6B;IAC7B,IAAI,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS;IAI1B,iBAAiB;IACX,QAAQ,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YAYxB,UAAU;CAGzB"}
|
package/dist/excel-row.js
CHANGED
|
@@ -1,19 +1,18 @@
|
|
|
1
|
-
import "@simplysm/core-common";
|
|
2
|
-
import { ExcelCell } from "./excel-cell.js";
|
|
3
1
|
/** Excel 워크시트의 행을 나타내는 클래스. 셀 접근 기능을 제공한다. */
|
|
4
2
|
export class ExcelRow {
|
|
5
3
|
_zipCache;
|
|
6
4
|
_targetFileName;
|
|
7
5
|
_r;
|
|
8
|
-
|
|
9
|
-
constructor(_zipCache, _targetFileName, _r) {
|
|
6
|
+
_cellFactory;
|
|
7
|
+
constructor(_zipCache, _targetFileName, _r, _cellFactory) {
|
|
10
8
|
this._zipCache = _zipCache;
|
|
11
9
|
this._targetFileName = _targetFileName;
|
|
12
10
|
this._r = _r;
|
|
11
|
+
this._cellFactory = _cellFactory;
|
|
13
12
|
}
|
|
14
13
|
/** 지정된 열 인덱스의 셀 반환 (0 기반) */
|
|
15
14
|
cell(c) {
|
|
16
|
-
return this.
|
|
15
|
+
return this._cellFactory(c);
|
|
17
16
|
}
|
|
18
17
|
/** 행의 모든 셀 반환 */
|
|
19
18
|
async getCells() {
|
package/dist/excel-row.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-row.js","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"excel-row.js","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"AAIA,8CAA8C;AAC9C,MAAM,OAAO,QAAQ;IAEA;IACA;IACA;IACA;IAJnB,YACmB,SAAmB,EACnB,eAAuB,EACvB,EAAU,EACV,YAAsC;QAHtC,cAAS,GAAT,SAAS,CAAU;QACnB,oBAAe,GAAf,eAAe,CAAQ;QACvB,OAAE,GAAF,EAAE,CAAQ;QACV,iBAAY,GAAZ,YAAY,CAA0B;IACtD,CAAC;IAEJ,6BAA6B;IAC7B,IAAI,CAAC,CAAS;QACZ,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,iBAAiB;IACjB,KAAK,CAAC,QAAQ;QACZ,MAAM,MAAM,GAAgB,EAAE,CAAC;QAC/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAE3B,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,UAAU;QACtB,OAAO,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,eAAe,EAAE,CAAC,CAAsB,CAAC;IAClG,CAAC;CACF"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { Bytes } from "@simplysm/core-common";
|
|
2
2
|
import "@simplysm/core-common";
|
|
3
|
-
import
|
|
3
|
+
import { ExcelCell } from "./excel-cell";
|
|
4
4
|
import { ExcelCol } from "./excel-col";
|
|
5
5
|
import { ExcelRow } from "./excel-row";
|
|
6
6
|
import type { ExcelAddressPoint, ExcelAddressRangePoint, ExcelValueType } from "./types";
|
|
@@ -15,6 +15,7 @@ export declare class ExcelWorksheet {
|
|
|
15
15
|
private readonly _targetFileName;
|
|
16
16
|
private readonly _rowMap;
|
|
17
17
|
private readonly _colMap;
|
|
18
|
+
private readonly _cellMap;
|
|
18
19
|
constructor(_zipCache: ZipCache, _relId: number, _targetFileName: string);
|
|
19
20
|
/** 워크시트 이름 반환 */
|
|
20
21
|
getName(): Promise<string>;
|
|
@@ -26,6 +27,7 @@ export declare class ExcelWorksheet {
|
|
|
26
27
|
cell(r: number, c: number): ExcelCell;
|
|
27
28
|
/** 열 객체 반환 (0 기반) */
|
|
28
29
|
col(c: number): ExcelCol;
|
|
30
|
+
private _getOrCreateCell;
|
|
29
31
|
/** 원본 행에서 대상 행으로 스타일 복사 */
|
|
30
32
|
copyRowStyle(srcR: number, targetR: number): Promise<void>;
|
|
31
33
|
/** 원본 셀에서 대상 셀로 스타일 복사 */
|
|
@@ -98,5 +100,8 @@ export declare class ExcelWorksheet {
|
|
|
98
100
|
}): Promise<void>;
|
|
99
101
|
private _getWsData;
|
|
100
102
|
private _getWbData;
|
|
103
|
+
private _ensureSsData;
|
|
104
|
+
private _ensureStyleData;
|
|
105
|
+
private _setCellValueSync;
|
|
101
106
|
}
|
|
102
107
|
//# sourceMappingURL=excel-worksheet.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-worksheet.d.ts","sourceRoot":"","sources":["..\\src\\excel-worksheet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,uBAAuB,CAAC;AAG/B,OAAO,
|
|
1
|
+
{"version":3,"file":"excel-worksheet.d.ts","sourceRoot":"","sources":["..\\src\\excel-worksheet.ts"],"names":[],"mappings":"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"}
|
package/dist/excel-worksheet.js
CHANGED
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import "@simplysm/core-common";
|
|
2
|
-
import { str } from "@simplysm/core-common";
|
|
2
|
+
import { DateOnly, DateTime, str, Time } from "@simplysm/core-common";
|
|
3
3
|
import mime from "mime";
|
|
4
|
+
import { ExcelCell } from "./excel-cell.js";
|
|
4
5
|
import { ExcelCol } from "./excel-col.js";
|
|
5
6
|
import { ExcelRow } from "./excel-row.js";
|
|
7
|
+
import { ExcelUtils } from "./utils/excel-utils.js";
|
|
6
8
|
import { ExcelXmlDrawing } from "./xml/excel-xml-drawing.js";
|
|
7
9
|
import { ExcelXmlRelationship } from "./xml/excel-xml-relationship.js";
|
|
10
|
+
import { ExcelXmlSharedString as ExcelXmlSharedStringClass } from "./xml/excel-xml-shared-string.js";
|
|
11
|
+
import { ExcelXmlStyle as ExcelXmlStyleClass } from "./xml/excel-xml-style.js";
|
|
8
12
|
/**
|
|
9
13
|
* Excel 워크시트를 나타내는 클래스.
|
|
10
14
|
* 셀 접근, 행/열 복사, 데이터 테이블 처리, 이미지 삽입 기능을 제공한다.
|
|
@@ -15,6 +19,7 @@ export class ExcelWorksheet {
|
|
|
15
19
|
_targetFileName;
|
|
16
20
|
_rowMap = new Map();
|
|
17
21
|
_colMap = new Map();
|
|
22
|
+
_cellMap = new Map();
|
|
18
23
|
constructor(_zipCache, _relId, _targetFileName) {
|
|
19
24
|
this._zipCache = _zipCache;
|
|
20
25
|
this._relId = _relId;
|
|
@@ -39,15 +44,24 @@ export class ExcelWorksheet {
|
|
|
39
44
|
//#region Cell Access Methods
|
|
40
45
|
/** 행 객체 반환 (0 기반) */
|
|
41
46
|
row(r) {
|
|
42
|
-
return this._rowMap.getOrCreate(r, new ExcelRow(this._zipCache, this._targetFileName, r));
|
|
47
|
+
return this._rowMap.getOrCreate(r, new ExcelRow(this._zipCache, this._targetFileName, r, (c) => this._getOrCreateCell(r, c)));
|
|
43
48
|
}
|
|
44
49
|
/** 셀 객체 반환 (0 기반 행/열) */
|
|
45
50
|
cell(r, c) {
|
|
46
|
-
return this.
|
|
51
|
+
return this._getOrCreateCell(r, c);
|
|
47
52
|
}
|
|
48
53
|
/** 열 객체 반환 (0 기반) */
|
|
49
54
|
col(c) {
|
|
50
|
-
return this._colMap.getOrCreate(c, new ExcelCol(this._zipCache, this._targetFileName, c));
|
|
55
|
+
return this._colMap.getOrCreate(c, new ExcelCol(this._zipCache, this._targetFileName, c, (r) => this._getOrCreateCell(r, c)));
|
|
56
|
+
}
|
|
57
|
+
_getOrCreateCell(r, c) {
|
|
58
|
+
const key = `${r},${c}`;
|
|
59
|
+
let cell = this._cellMap.get(key);
|
|
60
|
+
if (cell === undefined) {
|
|
61
|
+
cell = new ExcelCell(this._zipCache, this._targetFileName, r, c);
|
|
62
|
+
this._cellMap.set(key, cell);
|
|
63
|
+
}
|
|
64
|
+
return cell;
|
|
51
65
|
}
|
|
52
66
|
//#endregion
|
|
53
67
|
//#region Copy Methods
|
|
@@ -168,9 +182,12 @@ export class ExcelWorksheet {
|
|
|
168
182
|
* @param matrix 2차원 배열 데이터 (행 우선, 인덱스 0이 첫 번째 행)
|
|
169
183
|
*/
|
|
170
184
|
async setDataMatrix(matrix) {
|
|
185
|
+
const wsData = await this._getWsData();
|
|
186
|
+
const ssData = await this._ensureSsData();
|
|
187
|
+
const styleData = await this._ensureStyleData();
|
|
171
188
|
for (let r = 0; r < matrix.length; r++) {
|
|
172
189
|
for (let c = 0; c < matrix[r].length; c++) {
|
|
173
|
-
|
|
190
|
+
this._setCellValueSync(wsData, ssData, styleData, { r, c }, matrix[r][c]);
|
|
174
191
|
}
|
|
175
192
|
}
|
|
176
193
|
}
|
|
@@ -183,12 +200,15 @@ export class ExcelWorksheet {
|
|
|
183
200
|
.flatMap((item) => Object.keys(item))
|
|
184
201
|
.distinct()
|
|
185
202
|
.filter((item) => !str.isNullOrEmpty(item));
|
|
203
|
+
const wsData = await this._getWsData();
|
|
204
|
+
const ssData = await this._ensureSsData();
|
|
205
|
+
const styleData = await this._ensureStyleData();
|
|
186
206
|
for (let c = 0; c < headers.length; c++) {
|
|
187
|
-
|
|
207
|
+
this._setCellValueSync(wsData, ssData, styleData, { r: 0, c }, headers[c]);
|
|
188
208
|
}
|
|
189
209
|
for (let r = 1; r < records.length + 1; r++) {
|
|
190
210
|
for (let c = 0; c < headers.length; c++) {
|
|
191
|
-
|
|
211
|
+
this._setCellValueSync(wsData, ssData, styleData, { r, c }, records[r - 1][headers[c]]);
|
|
192
212
|
}
|
|
193
213
|
}
|
|
194
214
|
}
|
|
@@ -301,5 +321,64 @@ export class ExcelWorksheet {
|
|
|
301
321
|
async _getWbData() {
|
|
302
322
|
return (await this._zipCache.get("xl/workbook.xml"));
|
|
303
323
|
}
|
|
324
|
+
async _ensureSsData() {
|
|
325
|
+
let ssData = (await this._zipCache.get("xl/sharedStrings.xml"));
|
|
326
|
+
if (ssData == null) {
|
|
327
|
+
ssData = new ExcelXmlSharedStringClass();
|
|
328
|
+
this._zipCache.set("xl/sharedStrings.xml", ssData);
|
|
329
|
+
const typeData = (await this._zipCache.get("[Content_Types].xml"));
|
|
330
|
+
typeData.add("/xl/sharedStrings.xml", "application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml");
|
|
331
|
+
const wbRelData = (await this._zipCache.get("xl/_rels/workbook.xml.rels"));
|
|
332
|
+
wbRelData.add("sharedStrings.xml", "http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings");
|
|
333
|
+
}
|
|
334
|
+
return ssData;
|
|
335
|
+
}
|
|
336
|
+
async _ensureStyleData() {
|
|
337
|
+
let styleData = (await this._zipCache.get("xl/styles.xml"));
|
|
338
|
+
if (styleData == null) {
|
|
339
|
+
styleData = new ExcelXmlStyleClass();
|
|
340
|
+
this._zipCache.set("xl/styles.xml", styleData);
|
|
341
|
+
const typeData = (await this._zipCache.get("[Content_Types].xml"));
|
|
342
|
+
typeData.add("/xl/styles.xml", "application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml");
|
|
343
|
+
const wbRelData = (await this._zipCache.get("xl/_rels/workbook.xml.rels"));
|
|
344
|
+
wbRelData.add("styles.xml", "http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles");
|
|
345
|
+
}
|
|
346
|
+
return styleData;
|
|
347
|
+
}
|
|
348
|
+
_setCellValueSync(wsData, ssData, styleData, addr, val) {
|
|
349
|
+
if (val === undefined) {
|
|
350
|
+
wsData.deleteCell(addr);
|
|
351
|
+
}
|
|
352
|
+
else if (typeof val === "string") {
|
|
353
|
+
const ssId = ssData.getIdByString(val) ?? ssData.add(val);
|
|
354
|
+
wsData.setCellType(addr, "s");
|
|
355
|
+
wsData.setCellVal(addr, ssId.toString());
|
|
356
|
+
}
|
|
357
|
+
else if (typeof val === "boolean") {
|
|
358
|
+
wsData.setCellType(addr, "b");
|
|
359
|
+
wsData.setCellVal(addr, val ? "1" : "0");
|
|
360
|
+
}
|
|
361
|
+
else if (typeof val === "number") {
|
|
362
|
+
wsData.setCellType(addr, undefined);
|
|
363
|
+
wsData.setCellVal(addr, val.toString());
|
|
364
|
+
}
|
|
365
|
+
else if (val instanceof DateOnly || val instanceof DateTime || val instanceof Time) {
|
|
366
|
+
wsData.setCellType(addr, undefined);
|
|
367
|
+
wsData.setCellVal(addr, ExcelUtils.convertTimeTickToNumber(val.tick).toString());
|
|
368
|
+
const numFmtName = val instanceof DateOnly ? "DateOnly" : val instanceof DateTime ? "DateTime" : "Time";
|
|
369
|
+
const numFmtId = ExcelUtils.convertNumFmtNameToId(numFmtName).toString();
|
|
370
|
+
let styleId = wsData.getCellStyleId(addr);
|
|
371
|
+
if (styleId == null) {
|
|
372
|
+
styleId = styleData.add({ numFmtId });
|
|
373
|
+
}
|
|
374
|
+
else {
|
|
375
|
+
styleId = styleData.addWithClone(styleId, { numFmtId });
|
|
376
|
+
}
|
|
377
|
+
wsData.setCellStyleId(addr, styleId);
|
|
378
|
+
}
|
|
379
|
+
else {
|
|
380
|
+
throw new Error(`[${ExcelUtils.stringifyAddr(addr)}] 지원하지 않는 타입: ${typeof val}`);
|
|
381
|
+
}
|
|
382
|
+
}
|
|
304
383
|
}
|
|
305
384
|
//# sourceMappingURL=excel-worksheet.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-worksheet.js","sourceRoot":"","sources":["..\\src\\excel-worksheet.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"excel-worksheet.js","sourceRoot":"","sources":["..\\src\\excel-worksheet.ts"],"names":[],"mappings":"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"}
|
|
@@ -64,11 +64,11 @@ export class ExcelXmlRelationship {
|
|
|
64
64
|
return maxRel ? this._getRelId(maxRel) : undefined;
|
|
65
65
|
}
|
|
66
66
|
_getRelId(rel) {
|
|
67
|
-
const
|
|
68
|
-
if (
|
|
67
|
+
const result = num.parseInt(rel.$.Id);
|
|
68
|
+
if (result == null) {
|
|
69
69
|
throw new Error(`잘못된 관계 ID 형식: ${rel.$.Id}`);
|
|
70
70
|
}
|
|
71
|
-
return
|
|
71
|
+
return result;
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
74
|
//# sourceMappingURL=excel-xml-relationship.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-xml-relationship.js","sourceRoot":"","sources":["..\\..\\src\\xml\\excel-xml-relationship.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"excel-xml-relationship.js","sourceRoot":"","sources":["..\\..\\src\\xml\\excel-xml-relationship.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"excel-xml-shared-string.js","sourceRoot":"","sources":["..\\..\\src\\xml\\excel-xml-shared-string.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"excel-xml-shared-string.js","sourceRoot":"","sources":["..\\..\\src\\xml\\excel-xml-shared-string.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@simplysm/excel",
|
|
3
|
-
"version": "14.0.
|
|
3
|
+
"version": "14.0.8",
|
|
4
4
|
"description": "심플리즘 패키지 - 엑셀 (neutral)",
|
|
5
5
|
"author": "심플리즘",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -24,6 +24,6 @@
|
|
|
24
24
|
"dependencies": {
|
|
25
25
|
"mime": "^4.1.0",
|
|
26
26
|
"zod": "^4.3.6",
|
|
27
|
-
"@simplysm/core-common": "14.0.
|
|
27
|
+
"@simplysm/core-common": "14.0.8"
|
|
28
28
|
}
|
|
29
29
|
}
|
package/src/excel-col.ts
CHANGED
|
@@ -1,24 +1,19 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import { ExcelCell } from "./excel-cell";
|
|
1
|
+
import type { ExcelCell } from "./excel-cell";
|
|
3
2
|
import type { ExcelXmlWorksheet } from "./xml/excel-xml-worksheet";
|
|
4
3
|
import type { ZipCache } from "./utils/zip-cache";
|
|
5
4
|
|
|
6
5
|
/** Excel 워크시트의 열을 나타내는 클래스. 셀 접근 및 열 너비 설정 기능을 제공한다. */
|
|
7
6
|
export class ExcelCol {
|
|
8
|
-
private readonly _cellMap = new Map<number, ExcelCell>();
|
|
9
|
-
|
|
10
7
|
constructor(
|
|
11
8
|
private readonly _zipCache: ZipCache,
|
|
12
9
|
private readonly _targetFileName: string,
|
|
13
10
|
private readonly _c: number,
|
|
11
|
+
private readonly _cellFactory: (r: number) => ExcelCell,
|
|
14
12
|
) {}
|
|
15
13
|
|
|
16
14
|
/** 지정된 행 인덱스의 셀 반환 (0 기반) */
|
|
17
15
|
cell(r: number): ExcelCell {
|
|
18
|
-
return this.
|
|
19
|
-
r,
|
|
20
|
-
new ExcelCell(this._zipCache, this._targetFileName, r, this._c),
|
|
21
|
-
);
|
|
16
|
+
return this._cellFactory(r);
|
|
22
17
|
}
|
|
23
18
|
|
|
24
19
|
/** 열의 모든 셀 반환 */
|
package/src/excel-row.ts
CHANGED
|
@@ -1,24 +1,19 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import { ExcelCell } from "./excel-cell";
|
|
1
|
+
import type { ExcelCell } from "./excel-cell";
|
|
3
2
|
import type { ExcelXmlWorksheet } from "./xml/excel-xml-worksheet";
|
|
4
3
|
import type { ZipCache } from "./utils/zip-cache";
|
|
5
4
|
|
|
6
5
|
/** Excel 워크시트의 행을 나타내는 클래스. 셀 접근 기능을 제공한다. */
|
|
7
6
|
export class ExcelRow {
|
|
8
|
-
private readonly _cellMap = new Map<number, ExcelCell>();
|
|
9
|
-
|
|
10
7
|
constructor(
|
|
11
8
|
private readonly _zipCache: ZipCache,
|
|
12
9
|
private readonly _targetFileName: string,
|
|
13
10
|
private readonly _r: number,
|
|
11
|
+
private readonly _cellFactory: (c: number) => ExcelCell,
|
|
14
12
|
) {}
|
|
15
13
|
|
|
16
14
|
/** 지정된 열 인덱스의 셀 반환 (0 기반) */
|
|
17
15
|
cell(c: number): ExcelCell {
|
|
18
|
-
return this.
|
|
19
|
-
c,
|
|
20
|
-
new ExcelCell(this._zipCache, this._targetFileName, this._r, c),
|
|
21
|
-
);
|
|
16
|
+
return this._cellFactory(c);
|
|
22
17
|
}
|
|
23
18
|
|
|
24
19
|
/** 행의 모든 셀 반환 */
|
package/src/excel-worksheet.ts
CHANGED
|
@@ -1,15 +1,20 @@
|
|
|
1
1
|
import type { Bytes } from "@simplysm/core-common";
|
|
2
2
|
import "@simplysm/core-common";
|
|
3
|
-
import { str } from "@simplysm/core-common";
|
|
3
|
+
import { DateOnly, DateTime, str, Time } from "@simplysm/core-common";
|
|
4
4
|
import mime from "mime";
|
|
5
|
-
import
|
|
5
|
+
import { ExcelCell } from "./excel-cell";
|
|
6
6
|
import { ExcelCol } from "./excel-col";
|
|
7
7
|
import { ExcelRow } from "./excel-row";
|
|
8
8
|
import type { ExcelAddressPoint, ExcelAddressRangePoint, ExcelValueType } from "./types";
|
|
9
|
+
import { ExcelUtils } from "./utils/excel-utils";
|
|
9
10
|
import type { ZipCache } from "./utils/zip-cache";
|
|
10
11
|
import type { ExcelXmlContentType } from "./xml/excel-xml-content-type";
|
|
11
12
|
import { ExcelXmlDrawing } from "./xml/excel-xml-drawing";
|
|
12
13
|
import { ExcelXmlRelationship } from "./xml/excel-xml-relationship";
|
|
14
|
+
import type { ExcelXmlSharedString } from "./xml/excel-xml-shared-string";
|
|
15
|
+
import { ExcelXmlSharedString as ExcelXmlSharedStringClass } from "./xml/excel-xml-shared-string";
|
|
16
|
+
import type { ExcelXmlStyle } from "./xml/excel-xml-style";
|
|
17
|
+
import { ExcelXmlStyle as ExcelXmlStyleClass } from "./xml/excel-xml-style";
|
|
13
18
|
import type { ExcelXmlWorkbook } from "./xml/excel-xml-workbook";
|
|
14
19
|
import type { ExcelXmlWorksheet } from "./xml/excel-xml-worksheet";
|
|
15
20
|
|
|
@@ -20,6 +25,7 @@ import type { ExcelXmlWorksheet } from "./xml/excel-xml-worksheet";
|
|
|
20
25
|
export class ExcelWorksheet {
|
|
21
26
|
private readonly _rowMap = new Map<number, ExcelRow>();
|
|
22
27
|
private readonly _colMap = new Map<number, ExcelCol>();
|
|
28
|
+
private readonly _cellMap = new Map<string, ExcelCell>();
|
|
23
29
|
|
|
24
30
|
constructor(
|
|
25
31
|
private readonly _zipCache: ZipCache,
|
|
@@ -51,17 +57,33 @@ export class ExcelWorksheet {
|
|
|
51
57
|
|
|
52
58
|
/** 행 객체 반환 (0 기반) */
|
|
53
59
|
row(r: number): ExcelRow {
|
|
54
|
-
return this._rowMap.getOrCreate(
|
|
60
|
+
return this._rowMap.getOrCreate(
|
|
61
|
+
r,
|
|
62
|
+
new ExcelRow(this._zipCache, this._targetFileName, r, (c) => this._getOrCreateCell(r, c)),
|
|
63
|
+
);
|
|
55
64
|
}
|
|
56
65
|
|
|
57
66
|
/** 셀 객체 반환 (0 기반 행/열) */
|
|
58
67
|
cell(r: number, c: number): ExcelCell {
|
|
59
|
-
return this.
|
|
68
|
+
return this._getOrCreateCell(r, c);
|
|
60
69
|
}
|
|
61
70
|
|
|
62
71
|
/** 열 객체 반환 (0 기반) */
|
|
63
72
|
col(c: number): ExcelCol {
|
|
64
|
-
return this._colMap.getOrCreate(
|
|
73
|
+
return this._colMap.getOrCreate(
|
|
74
|
+
c,
|
|
75
|
+
new ExcelCol(this._zipCache, this._targetFileName, c, (r) => this._getOrCreateCell(r, c)),
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
private _getOrCreateCell(r: number, c: number): ExcelCell {
|
|
80
|
+
const key = `${r},${c}`;
|
|
81
|
+
let cell = this._cellMap.get(key);
|
|
82
|
+
if (cell === undefined) {
|
|
83
|
+
cell = new ExcelCell(this._zipCache, this._targetFileName, r, c);
|
|
84
|
+
this._cellMap.set(key, cell);
|
|
85
|
+
}
|
|
86
|
+
return cell;
|
|
65
87
|
}
|
|
66
88
|
|
|
67
89
|
//#endregion
|
|
@@ -222,9 +244,13 @@ export class ExcelWorksheet {
|
|
|
222
244
|
* @param matrix 2차원 배열 데이터 (행 우선, 인덱스 0이 첫 번째 행)
|
|
223
245
|
*/
|
|
224
246
|
async setDataMatrix(matrix: ExcelValueType[][]): Promise<void> {
|
|
247
|
+
const wsData = await this._getWsData();
|
|
248
|
+
const ssData = await this._ensureSsData();
|
|
249
|
+
const styleData = await this._ensureStyleData();
|
|
250
|
+
|
|
225
251
|
for (let r = 0; r < matrix.length; r++) {
|
|
226
252
|
for (let c = 0; c < matrix[r].length; c++) {
|
|
227
|
-
|
|
253
|
+
this._setCellValueSync(wsData, ssData, styleData, { r, c }, matrix[r][c]);
|
|
228
254
|
}
|
|
229
255
|
}
|
|
230
256
|
}
|
|
@@ -239,13 +265,23 @@ export class ExcelWorksheet {
|
|
|
239
265
|
.distinct()
|
|
240
266
|
.filter((item) => !str.isNullOrEmpty(item));
|
|
241
267
|
|
|
268
|
+
const wsData = await this._getWsData();
|
|
269
|
+
const ssData = await this._ensureSsData();
|
|
270
|
+
const styleData = await this._ensureStyleData();
|
|
271
|
+
|
|
242
272
|
for (let c = 0; c < headers.length; c++) {
|
|
243
|
-
|
|
273
|
+
this._setCellValueSync(wsData, ssData, styleData, { r: 0, c }, headers[c]);
|
|
244
274
|
}
|
|
245
275
|
|
|
246
276
|
for (let r = 1; r < records.length + 1; r++) {
|
|
247
277
|
for (let c = 0; c < headers.length; c++) {
|
|
248
|
-
|
|
278
|
+
this._setCellValueSync(
|
|
279
|
+
wsData,
|
|
280
|
+
ssData,
|
|
281
|
+
styleData,
|
|
282
|
+
{ r, c },
|
|
283
|
+
records[r - 1][headers[c]],
|
|
284
|
+
);
|
|
249
285
|
}
|
|
250
286
|
}
|
|
251
287
|
}
|
|
@@ -399,5 +435,94 @@ export class ExcelWorksheet {
|
|
|
399
435
|
return (await this._zipCache.get("xl/workbook.xml")) as ExcelXmlWorkbook;
|
|
400
436
|
}
|
|
401
437
|
|
|
438
|
+
private async _ensureSsData(): Promise<ExcelXmlSharedString> {
|
|
439
|
+
let ssData = (await this._zipCache.get("xl/sharedStrings.xml")) as
|
|
440
|
+
| ExcelXmlSharedString
|
|
441
|
+
| undefined;
|
|
442
|
+
if (ssData == null) {
|
|
443
|
+
ssData = new ExcelXmlSharedStringClass();
|
|
444
|
+
this._zipCache.set("xl/sharedStrings.xml", ssData);
|
|
445
|
+
|
|
446
|
+
const typeData = (await this._zipCache.get("[Content_Types].xml")) as ExcelXmlContentType;
|
|
447
|
+
typeData.add(
|
|
448
|
+
"/xl/sharedStrings.xml",
|
|
449
|
+
"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",
|
|
450
|
+
);
|
|
451
|
+
|
|
452
|
+
const wbRelData = (await this._zipCache.get(
|
|
453
|
+
"xl/_rels/workbook.xml.rels",
|
|
454
|
+
)) as ExcelXmlRelationship;
|
|
455
|
+
wbRelData.add(
|
|
456
|
+
"sharedStrings.xml",
|
|
457
|
+
"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",
|
|
458
|
+
);
|
|
459
|
+
}
|
|
460
|
+
return ssData;
|
|
461
|
+
}
|
|
462
|
+
|
|
463
|
+
private async _ensureStyleData(): Promise<ExcelXmlStyle> {
|
|
464
|
+
let styleData = (await this._zipCache.get("xl/styles.xml")) as ExcelXmlStyle | undefined;
|
|
465
|
+
if (styleData == null) {
|
|
466
|
+
styleData = new ExcelXmlStyleClass();
|
|
467
|
+
this._zipCache.set("xl/styles.xml", styleData);
|
|
468
|
+
|
|
469
|
+
const typeData = (await this._zipCache.get("[Content_Types].xml")) as ExcelXmlContentType;
|
|
470
|
+
typeData.add(
|
|
471
|
+
"/xl/styles.xml",
|
|
472
|
+
"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",
|
|
473
|
+
);
|
|
474
|
+
|
|
475
|
+
const wbRelData = (await this._zipCache.get(
|
|
476
|
+
"xl/_rels/workbook.xml.rels",
|
|
477
|
+
)) as ExcelXmlRelationship;
|
|
478
|
+
wbRelData.add(
|
|
479
|
+
"styles.xml",
|
|
480
|
+
"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",
|
|
481
|
+
);
|
|
482
|
+
}
|
|
483
|
+
return styleData;
|
|
484
|
+
}
|
|
485
|
+
|
|
486
|
+
private _setCellValueSync(
|
|
487
|
+
wsData: ExcelXmlWorksheet,
|
|
488
|
+
ssData: ExcelXmlSharedString,
|
|
489
|
+
styleData: ExcelXmlStyle,
|
|
490
|
+
addr: ExcelAddressPoint,
|
|
491
|
+
val: ExcelValueType,
|
|
492
|
+
): void {
|
|
493
|
+
if (val === undefined) {
|
|
494
|
+
wsData.deleteCell(addr);
|
|
495
|
+
} else if (typeof val === "string") {
|
|
496
|
+
const ssId = ssData.getIdByString(val) ?? ssData.add(val);
|
|
497
|
+
wsData.setCellType(addr, "s");
|
|
498
|
+
wsData.setCellVal(addr, ssId.toString());
|
|
499
|
+
} else if (typeof val === "boolean") {
|
|
500
|
+
wsData.setCellType(addr, "b");
|
|
501
|
+
wsData.setCellVal(addr, val ? "1" : "0");
|
|
502
|
+
} else if (typeof val === "number") {
|
|
503
|
+
wsData.setCellType(addr, undefined);
|
|
504
|
+
wsData.setCellVal(addr, val.toString());
|
|
505
|
+
} else if (val instanceof DateOnly || val instanceof DateTime || val instanceof Time) {
|
|
506
|
+
wsData.setCellType(addr, undefined);
|
|
507
|
+
wsData.setCellVal(addr, ExcelUtils.convertTimeTickToNumber(val.tick).toString());
|
|
508
|
+
|
|
509
|
+
const numFmtName =
|
|
510
|
+
val instanceof DateOnly ? "DateOnly" : val instanceof DateTime ? "DateTime" : "Time";
|
|
511
|
+
const numFmtId = ExcelUtils.convertNumFmtNameToId(numFmtName).toString();
|
|
512
|
+
|
|
513
|
+
let styleId = wsData.getCellStyleId(addr);
|
|
514
|
+
if (styleId == null) {
|
|
515
|
+
styleId = styleData.add({ numFmtId });
|
|
516
|
+
} else {
|
|
517
|
+
styleId = styleData.addWithClone(styleId, { numFmtId });
|
|
518
|
+
}
|
|
519
|
+
wsData.setCellStyleId(addr, styleId);
|
|
520
|
+
} else {
|
|
521
|
+
throw new Error(
|
|
522
|
+
`[${ExcelUtils.stringifyAddr(addr)}] 지원하지 않는 타입: ${typeof val}`,
|
|
523
|
+
);
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
|
|
402
527
|
//#endregion
|
|
403
528
|
}
|
|
@@ -80,10 +80,10 @@ export class ExcelXmlRelationship implements ExcelXml {
|
|
|
80
80
|
}
|
|
81
81
|
|
|
82
82
|
private _getRelId(rel: ExcelRelationshipData): number {
|
|
83
|
-
const
|
|
84
|
-
if (
|
|
83
|
+
const result = num.parseInt(rel.$.Id);
|
|
84
|
+
if (result == null) {
|
|
85
85
|
throw new Error(`잘못된 관계 ID 형식: ${rel.$.Id}`);
|
|
86
86
|
}
|
|
87
|
-
return
|
|
87
|
+
return result;
|
|
88
88
|
}
|
|
89
89
|
}
|
|
@@ -71,7 +71,7 @@ export class ExcelXmlSharedString implements ExcelXml {
|
|
|
71
71
|
if (typeof firstItem === "string") {
|
|
72
72
|
return firstItem;
|
|
73
73
|
}
|
|
74
|
-
return firstItem._ ?? "
|
|
74
|
+
return firstItem._ ?? "";
|
|
75
75
|
}
|
|
76
76
|
|
|
77
77
|
private _getHasInnerStyleOnSiTag(si: ExcelXmlSharedStringDataSi): boolean {
|