@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.
@@ -1,13 +1,12 @@
1
- import "@simplysm/core-common";
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 _cellMap;
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
  /** 열의 모든 셀 반환 */
@@ -1 +1 @@
1
- {"version":3,"file":"excel-col.d.ts","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,wDAAwD;AACxD,qBAAa,QAAQ;IAIjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,EAAE;IALrB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgC;gBAGtC,SAAS,EAAE,QAAQ,EACnB,eAAe,EAAE,MAAM,EACvB,EAAE,EAAE,MAAM;IAG7B,6BAA6B;IAC7B,IAAI,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS;IAO1B,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"}
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
- _cellMap = new Map();
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._cellMap.getOrCreate(r, new ExcelCell(this._zipCache, this._targetFileName, r, this._c));
15
+ return this._cellFactory(r);
17
16
  }
18
17
  /** 열의 모든 셀 반환 */
19
18
  async getCells() {
@@ -1 +1 @@
1
- {"version":3,"file":"excel-col.js","sourceRoot":"","sources":["..\\src\\excel-col.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,wDAAwD;AACxD,MAAM,OAAO,QAAQ;IAIA;IACA;IACA;IALF,QAAQ,GAAG,IAAI,GAAG,EAAqB,CAAC;IAEzD,YACmB,SAAmB,EACnB,eAAuB,EACvB,EAAU;QAFV,cAAS,GAAT,SAAS,CAAU;QACnB,oBAAe,GAAf,eAAe,CAAQ;QACvB,OAAE,GAAF,EAAE,CAAQ;IAC1B,CAAC;IAEJ,6BAA6B;IAC7B,IAAI,CAAC,CAAS;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,WAAW,CAC9B,CAAC,EACD,IAAI,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAChE,CAAC;IACJ,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"}
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"}
@@ -1,13 +1,12 @@
1
- import "@simplysm/core-common";
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 _cellMap;
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
  /** 행의 모든 셀 반환 */
@@ -1 +1 @@
1
- {"version":3,"file":"excel-row.d.ts","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,8CAA8C;AAC9C,qBAAa,QAAQ;IAIjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,EAAE;IALrB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgC;gBAGtC,SAAS,EAAE,QAAQ,EACnB,eAAe,EAAE,MAAM,EACvB,EAAE,EAAE,MAAM;IAG7B,6BAA6B;IAC7B,IAAI,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS;IAO1B,iBAAiB;IACX,QAAQ,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YAYxB,UAAU;CAGzB"}
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
- _cellMap = new Map();
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._cellMap.getOrCreate(c, new ExcelCell(this._zipCache, this._targetFileName, this._r, c));
15
+ return this._cellFactory(c);
17
16
  }
18
17
  /** 행의 모든 셀 반환 */
19
18
  async getCells() {
@@ -1 +1 @@
1
- {"version":3,"file":"excel-row.js","sourceRoot":"","sources":["..\\src\\excel-row.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,8CAA8C;AAC9C,MAAM,OAAO,QAAQ;IAIA;IACA;IACA;IALF,QAAQ,GAAG,IAAI,GAAG,EAAqB,CAAC;IAEzD,YACmB,SAAmB,EACnB,eAAuB,EACvB,EAAU;QAFV,cAAS,GAAT,SAAS,CAAU;QACnB,oBAAe,GAAf,eAAe,CAAQ;QACvB,OAAE,GAAF,EAAE,CAAQ;IAC1B,CAAC;IAEJ,6BAA6B;IAC7B,IAAI,CAAC,CAAS;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,WAAW,CAC9B,CAAC,EACD,IAAI,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAChE,CAAC;IACJ,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
+ {"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 type { ExcelCell } from "./excel-cell";
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":"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"}
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,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAWlD;;;GAGG;AACH,qBAAa,cAAc;IAMvB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,eAAe;IAPlC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA+B;IACvD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA+B;IACvD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgC;gBAGtC,SAAS,EAAE,QAAQ,EACnB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM;IAK1C,iBAAiB;IACX,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;IAShC,iBAAiB;IACX,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7C,qBAAqB;IACrB,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,QAAQ;IAOxB,yBAAyB;IACzB,IAAI,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,SAAS;IAIrC,qBAAqB;IACrB,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,QAAQ;IAOxB,OAAO,CAAC,gBAAgB;IAcxB,2BAA2B;IACrB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQhE,0BAA0B;IACpB,aAAa,CAAC,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7F,6BAA6B;IACvB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK3D,qBAAqB;IACf,QAAQ,CAAC,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAKxF;;;;;OAKG;IACG,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAqCjE,sBAAsB;IAChB,QAAQ,IAAI,OAAO,CAAC,sBAAsB,CAAC;IAKjD,uBAAuB;IACjB,QAAQ,IAAI,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC;IAgBxC;;;;;OAKG;IACG,YAAY,CAAC,GAAG,CAAC,EAAE;QACvB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,kBAAkB,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,OAAO,CAAC;KACtD,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,EAAE,CAAC;IA0C7C;;;OAGG;IACG,aAAa,CAAC,MAAM,EAAE,cAAc,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAY9D;;;OAGG;IACG,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA+B1E,6BAA6B;IACvB,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C,kBAAkB;IACZ,QAAQ,CAAC,KAAK,EAAE;QAAE,CAAC,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAYhE;;;;;;OAMG;IACG,QAAQ,CAAC,IAAI,EAAE;QACnB,KAAK,EAAE,KAAK,CAAC;QACb,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;QAC/E,EAAE,CAAC,EAAE;YAAE,CAAC,EAAE,MAAM,CAAC;YAAC,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KAC/E,GAAG,OAAO,CAAC,IAAI,CAAC;YAuGH,UAAU;YAIV,UAAU;YAIV,aAAa;YAyBb,gBAAgB;IAuB9B,OAAO,CAAC,iBAAiB;CA0C1B"}
@@ -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.row(r).cell(c);
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
- await this.cell(r, c).setValue(matrix[r][c]);
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
- await this.cell(0, c).setValue(headers[c]);
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
- await this.cell(r, c).setValue(records[r - 1][headers[c]]);
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 match = /[0-9]+$/.exec(rel.$.Id);
68
- if (match == null) {
67
+ const result = num.parseInt(rel.$.Id);
68
+ if (result == null) {
69
69
  throw new Error(`잘못된 관계 ID 형식: ${rel.$.Id}`);
70
70
  }
71
- return num.parseInt(match[0]);
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":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAG5C;;;GAGG;AACH,MAAM,OAAO,oBAAoB;IAC/B,IAAI,CAA2B;IAE/B,YAAY,IAA+B;QACzC,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,GAAG;gBACV,aAAa,EAAE;oBACb,CAAC,EAAE;wBACD,KAAK,EAAE,8DAA8D;qBACtE;iBACF;aACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACnB,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,GAAW;QAC1B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC;YAC9F,EAAE,CAAC,CAAC,MAAM,CAAC;IACf,CAAC;IAED,GAAG,CAAC,MAAc,EAAE,IAAY;QAC9B,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,WAAW,CAAC,MAAc,EAAE,IAAY;QACtC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,IAAI,EAAE,CAAC;QAElF,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAEtC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC;YACxC,CAAC,EAAE;gBACD,EAAE,EAAE,MAAM,KAAK,EAAE;gBACjB,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI;aACX;SACF,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,GAAW,EAAE,MAAc,EAAE,IAAY;QAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,IAAI,EAAE,CAAC;QAElF,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,CAC3D,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,GAAG,CACpC,CAAC;QACF,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACvD,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC;YACxC,CAAC,EAAE;gBACD,EAAE,EAAE,MAAM,GAAG,EAAE;gBACf,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI;aACX;SACF,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,IAAY,OAAO;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;QAClD,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,SAAS,CAAC;QACjD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;QACtE,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACrD,CAAC;IAEO,SAAS,CAAC,GAA0B;QAC1C,MAAM,MAAM,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACtC,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/C,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;CACF"}
@@ -54,7 +54,7 @@ export class ExcelXmlSharedString {
54
54
  if (typeof firstItem === "string") {
55
55
  return firstItem;
56
56
  }
57
- return firstItem._ ?? " ";
57
+ return firstItem._ ?? "";
58
58
  }
59
59
  _getHasInnerStyleOnSiTag(si) {
60
60
  return Object.keys(si).some((item) => item !== "t");
@@ -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.6",
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.6"
27
+ "@simplysm/core-common": "14.0.8"
28
28
  }
29
29
  }
package/src/excel-col.ts CHANGED
@@ -1,24 +1,19 @@
1
- import "@simplysm/core-common";
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._cellMap.getOrCreate(
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 "@simplysm/core-common";
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._cellMap.getOrCreate(
19
- c,
20
- new ExcelCell(this._zipCache, this._targetFileName, this._r, c),
21
- );
16
+ return this._cellFactory(c);
22
17
  }
23
18
 
24
19
  /** 행의 모든 셀 반환 */
@@ -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 type { ExcelCell } from "./excel-cell";
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(r, new ExcelRow(this._zipCache, this._targetFileName, r));
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.row(r).cell(c);
68
+ return this._getOrCreateCell(r, c);
60
69
  }
61
70
 
62
71
  /** 열 객체 반환 (0 기반) */
63
72
  col(c: number): ExcelCol {
64
- return this._colMap.getOrCreate(c, new ExcelCol(this._zipCache, this._targetFileName, c));
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
- await this.cell(r, c).setValue(matrix[r][c]);
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
- await this.cell(0, c).setValue(headers[c]);
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
- await this.cell(r, c).setValue(records[r - 1][headers[c]]);
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 match = /[0-9]+$/.exec(rel.$.Id);
84
- if (match == null) {
83
+ const result = num.parseInt(rel.$.Id);
84
+ if (result == null) {
85
85
  throw new Error(`잘못된 관계 ID 형식: ${rel.$.Id}`);
86
86
  }
87
- return num.parseInt(match[0])!;
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 {