@delon/abc 12.2.3 → 12.3.0

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.
Files changed (44) hide show
  1. package/bundles/abc.umd.js +1 -1
  2. package/bundles/autoFocus.umd.js +1 -1
  3. package/bundles/avatarList.umd.js +1 -1
  4. package/bundles/count-down.umd.js +1 -1
  5. package/bundles/datePicker.umd.js +1 -1
  6. package/bundles/downFile.umd.js +1 -1
  7. package/bundles/edit.umd.js +1 -1
  8. package/bundles/ellipsis.umd.js +1 -1
  9. package/bundles/errorCollect.umd.js +1 -1
  10. package/bundles/exception.umd.js +1 -1
  11. package/bundles/footerToolbar.umd.js +1 -1
  12. package/bundles/fullContent.umd.js +1 -1
  13. package/bundles/globalFooter.umd.js +1 -1
  14. package/bundles/grid.umd.js +1 -1
  15. package/bundles/image.umd.js +1 -1
  16. package/bundles/let.umd.js +1 -1
  17. package/bundles/loading.umd.js +1 -1
  18. package/bundles/lodop.umd.js +1 -1
  19. package/bundles/media.umd.js +1 -1
  20. package/bundles/noticeIcon.umd.js +1 -1
  21. package/bundles/onboarding.umd.js +1 -1
  22. package/bundles/pageHeader.umd.js +1 -1
  23. package/bundles/pdf.umd.js +1 -1
  24. package/bundles/qr.umd.js +1 -1
  25. package/bundles/quickMenu.umd.js +1 -1
  26. package/bundles/result.umd.js +1 -1
  27. package/bundles/reuseTab.umd.js +1 -1
  28. package/bundles/table.umd.js +4 -1
  29. package/bundles/table.umd.js.map +1 -1
  30. package/bundles/tagSelect.umd.js +1 -1
  31. package/bundles/view.umd.js +1 -1
  32. package/bundles/xlsx.umd.js +27 -32
  33. package/bundles/xlsx.umd.js.map +1 -1
  34. package/bundles/zip.umd.js +1 -1
  35. package/esm2015/st/st-column-source.js +4 -1
  36. package/esm2015/xlsx/xlsx.service.js +23 -29
  37. package/esm2015/xlsx/xlsx.types.js +1 -1
  38. package/fesm2015/table.js +3 -0
  39. package/fesm2015/table.js.map +1 -1
  40. package/fesm2015/xlsx.js +22 -28
  41. package/fesm2015/xlsx.js.map +1 -1
  42. package/package.json +4 -4
  43. package/xlsx/xlsx.metadata.json +1 -1
  44. package/xlsx/xlsx.types.d.ts +3 -0
@@ -1,7 +1,6 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
2
  import { HttpClient } from '@angular/common/http';
3
3
  import { Injectable, NgZone } from '@angular/core';
4
- import { saveAs } from 'file-saver';
5
4
  import isUtf8 from 'isutf8';
6
5
  import { AlainConfigService } from '@delon/util/config';
7
6
  import { ZoneOutside } from '@delon/util/decorator';
@@ -25,24 +24,22 @@ export class XlsxService {
25
24
  ? Promise.resolve([])
26
25
  : this.lazy.load([this.cog.url].concat(this.cog.modules));
27
26
  }
28
- read(data, options) {
27
+ read(data) {
28
+ const { read, utils: { sheet_to_json } } = XLSX;
29
29
  const ret = {};
30
- if (options.type === 'binary') {
31
- const buf = new Uint8Array(data);
32
- if (!isUtf8(buf)) {
33
- try {
34
- data = cptable.utils.decode(936, buf);
35
- options.type = 'string';
36
- }
37
- catch (_a) {
38
- options.type = 'array';
39
- }
30
+ const buf = new Uint8Array(data);
31
+ let type = 'array';
32
+ if (!isUtf8(buf)) {
33
+ try {
34
+ data = cptable.utils.decode(936, buf);
35
+ type = 'string';
40
36
  }
37
+ catch (_a) { }
41
38
  }
42
- const wb = XLSX.read(data, options);
39
+ const wb = read(data, { type });
43
40
  wb.SheetNames.forEach((name) => {
44
41
  const sheet = wb.Sheets[name];
45
- ret[name] = XLSX.utils.sheet_to_json(sheet, { header: 1 });
42
+ ret[name] = sheet_to_json(sheet, { header: 1 });
46
43
  });
47
44
  return ret;
48
45
  }
@@ -51,22 +48,18 @@ export class XlsxService {
51
48
  */
52
49
  import(fileOrUrl) {
53
50
  return new Promise((resolve, reject) => {
51
+ const r = (data) => this.ngZone.run(() => resolve(this.read(data)));
54
52
  this.init()
55
53
  .then(() => {
56
54
  // from url
57
55
  if (typeof fileOrUrl === 'string') {
58
- this.http.request('GET', fileOrUrl, { responseType: 'arraybuffer' }).subscribe((res) => {
59
- this.ngZone.run(() => resolve(this.read(new Uint8Array(res), { type: 'array' })));
60
- }, (err) => {
61
- reject(err);
62
- });
56
+ this.http.request('GET', fileOrUrl, { responseType: 'arraybuffer' }).subscribe((res) => r(new Uint8Array(res)), (err) => reject(err));
63
57
  return;
64
58
  }
65
59
  // from file
66
60
  const reader = new FileReader();
67
- reader.onload = (e) => {
68
- this.ngZone.run(() => resolve(this.read(e.target.result, { type: 'binary' })));
69
- };
61
+ reader.onload = (e) => r(e.target.result);
62
+ reader.onerror = (e) => reject(e);
70
63
  reader.readAsArrayBuffer(fileOrUrl);
71
64
  })
72
65
  .catch(() => reject(`Unable to load xlsx.js`));
@@ -77,11 +70,13 @@ export class XlsxService {
77
70
  return new Promise((resolve, reject) => {
78
71
  this.init()
79
72
  .then(() => {
80
- const wb = XLSX.utils.book_new();
73
+ options = Object.assign({ format: 'xlsx' }, options);
74
+ const { writeFile, utils: { book_new, aoa_to_sheet, book_append_sheet } } = XLSX;
75
+ const wb = book_new();
81
76
  if (Array.isArray(options.sheets)) {
82
77
  options.sheets.forEach((value, index) => {
83
- const ws = XLSX.utils.aoa_to_sheet(value.data);
84
- XLSX.utils.book_append_sheet(wb, ws, value.name || `Sheet${index + 1}`);
78
+ const ws = aoa_to_sheet(value.data);
79
+ book_append_sheet(wb, ws, value.name || `Sheet${index + 1}`);
85
80
  });
86
81
  }
87
82
  else {
@@ -90,9 +85,8 @@ export class XlsxService {
90
85
  }
91
86
  if (options.callback)
92
87
  options.callback(wb);
93
- const wbout = XLSX.write(wb, Object.assign({ bookType: 'xlsx', bookSST: false, type: 'array' }, options.opts));
94
- const filename = options.filename || 'export.xlsx';
95
- saveAs(new Blob([wbout], { type: 'application/octet-stream' }), filename);
88
+ const filename = options.filename || `export.${options.format}`;
89
+ writeFile(wb, filename, Object.assign({ bookType: options.format, bookSST: false, type: 'array' }, options.opts));
96
90
  resolve({ filename, wb });
97
91
  })
98
92
  .catch(err => reject(err));
@@ -132,4 +126,4 @@ __decorate([
132
126
  __decorate([
133
127
  ZoneOutside()
134
128
  ], XlsxService.prototype, "export", null);
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../packages/abc/xlsx/xlsx.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEnD,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACpC,OAAO,MAAM,MAAM,QAAQ,CAAC;AAE5B,OAAO,EAAE,kBAAkB,EAAmB,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAc,WAAW,EAAE,MAAM,mBAAmB,CAAC;;;;;AAS5D,MAAM,OAAO,WAAW;IACtB,YACU,IAAgB,EAChB,IAAiB,EACzB,SAA6B,EACrB,MAAc;QAHd,SAAI,GAAJ,IAAI,CAAY;QAChB,SAAI,GAAJ,IAAI,CAAa;QAEjB,WAAM,GAAN,MAAM,CAAQ;QAEtB,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE;YACjC,GAAG,EAAE,gEAAgE;YACrE,OAAO,EAAE,CAAC,8DAA8D,CAAC;SAC1E,CAAE,CAAC;IACN,CAAC;IAGO,IAAI;QACV,OAAO,OAAO,IAAI,KAAK,WAAW;YAChC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACrB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,OAAQ,CAAC,CAAC,CAAC;IAChE,CAAC;IAGO,IAAI,CAAC,IAAe,EAAE,OAAgD;QAC5E,MAAM,GAAG,GAAc,EAAE,CAAC;QAC1B,IAAI,OAAO,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC7B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;gBAChB,IAAI;oBACF,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;oBACtC,OAAO,CAAC,IAAI,GAAG,QAAQ,CAAC;iBACzB;gBAAC,WAAM;oBACN,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC;iBACxB;aACF;SACF;QACD,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACpC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAY,EAAE,EAAE;YACrC,MAAM,KAAK,GAAc,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACzC,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QACH,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,SAAwB;QAC7B,OAAO,IAAI,OAAO,CAAmC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACvE,IAAI,CAAC,IAAI,EAAE;iBACR,IAAI,CAAC,GAAG,EAAE;gBACT,WAAW;gBACX,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;oBACjC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,YAAY,EAAE,aAAa,EAAE,CAAC,CAAC,SAAS,CAC5E,CAAC,GAAgB,EAAE,EAAE;wBACnB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;oBACpF,CAAC,EACD,CAAC,GAAc,EAAE,EAAE;wBACjB,MAAM,CAAC,GAAG,CAAC,CAAC;oBACd,CAAC,CACF,CAAC;oBACF,OAAO;iBACR;gBACD,YAAY;gBACZ,MAAM,MAAM,GAAe,IAAI,UAAU,EAAE,CAAC;gBAC5C,MAAM,CAAC,MAAM,GAAG,CAAC,CAAY,EAAE,EAAE;oBAC/B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC;gBACjF,CAAC,CAAC;gBACF,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YACtC,CAAC,CAAC;iBACD,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACL,CAAC;IAGK,MAAM,CAAC,OAA0B;;YACrC,OAAO,IAAI,OAAO,CAAmB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACvD,IAAI,CAAC,IAAI,EAAE;qBACR,IAAI,CAAC,GAAG,EAAE;oBACT,MAAM,EAAE,GAAc,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;oBAC5C,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;wBAChC,OAAO,CAAC,MAA4B,CAAC,OAAO,CAAC,CAAC,KAAsB,EAAE,KAAa,EAAE,EAAE;4BACtF,MAAM,EAAE,GAAc,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;4BAC1D,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,IAAI,IAAI,QAAQ,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;wBAC1E,CAAC,CAAC,CAAC;qBACJ;yBAAM;wBACL,EAAE,CAAC,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;wBAC5C,EAAE,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;qBAC5B;oBAED,IAAI,OAAO,CAAC,QAAQ;wBAAE,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBAE3C,MAAM,KAAK,GAAgB,IAAI,CAAC,KAAK,CAAC,EAAE,kBACtC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,KAAK,EACd,IAAI,EAAE,OAAO,IACV,OAAO,CAAC,IAAI,EACf,CAAC;oBACH,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,aAAa,CAAC;oBACnD,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,EAAE,0BAA0B,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;oBAE1E,OAAO,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;gBAC5B,CAAC,CAAC;qBACD,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;YAC/B,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;IAED;;;;;OAKG;IACH,cAAc,CAAC,GAAW;QACxB,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,GAAG,GAAG,EAAE,CAAC;QAEb,GAAG;YACD,EAAE,GAAG,CAAC;YACN,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,SAAS,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC;YACxD,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;SACvB,QAAQ,GAAG,GAAG,CAAC,EAAE;QAElB,OAAO,GAAG,CAAC;IACb,CAAC;;;;YA3HF,UAAU,SAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;;YAhBzB,UAAU;YAQE,WAAW;YAFvB,kBAAkB;YALN,MAAM;;AAqCzB;IADC,WAAW,EAAE;uCAoBb;AAiCD;IADC,WAAW,EAAE;yCA+Bb","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable, NgZone } from '@angular/core';\n\nimport { saveAs } from 'file-saver';\nimport isUtf8 from 'isutf8';\n\nimport { AlainConfigService, AlainXlsxConfig } from '@delon/util/config';\nimport { ZoneOutside } from '@delon/util/decorator';\nimport { LazyResult, LazyService } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { XlsxExportOptions, XlsxExportResult, XlsxExportSheet } from './xlsx.types';\n\ndeclare var XLSX: NzSafeAny;\ndeclare var cptable: NzSafeAny;\n\n@Injectable({ providedIn: 'root' })\nexport class XlsxService {\n  constructor(\n    private http: HttpClient,\n    private lazy: LazyService,\n    configSrv: AlainConfigService,\n    private ngZone: NgZone\n  ) {\n    this.cog = configSrv.merge('xlsx', {\n      url: 'https://cdn.bootcdn.net/ajax/libs/xlsx/0.16.8/xlsx.full.min.js',\n      modules: [`https://cdn.bootcdn.net/ajax/libs/xlsx/0.16.8/cpexcel.min.js`]\n    })!;\n  }\n  private cog: AlainXlsxConfig;\n\n  private init(): Promise<LazyResult[]> {\n    return typeof XLSX !== 'undefined'\n      ? Promise.resolve([])\n      : this.lazy.load([this.cog.url!].concat(this.cog.modules!));\n  }\n\n  @ZoneOutside()\n  private read(data: NzSafeAny, options: { type: 'array' | 'binary' | 'string' }): { [key: string]: NzSafeAny[][] } {\n    const ret: NzSafeAny = {};\n    if (options.type === 'binary') {\n      const buf = new Uint8Array(data);\n      if (!isUtf8(buf)) {\n        try {\n          data = cptable.utils.decode(936, buf);\n          options.type = 'string';\n        } catch {\n          options.type = 'array';\n        }\n      }\n    }\n    const wb = XLSX.read(data, options);\n    wb.SheetNames.forEach((name: string) => {\n      const sheet: NzSafeAny = wb.Sheets[name];\n      ret[name] = XLSX.utils.sheet_to_json(sheet, { header: 1 });\n    });\n    return ret;\n  }\n\n  /**\n   * 导入Excel并输出JSON，支持 `<input type=\"file\">`、URL 形式\n   */\n  import(fileOrUrl: File | string): Promise<{ [key: string]: NzSafeAny[][] }> {\n    return new Promise<{ [key: string]: NzSafeAny[][] }>((resolve, reject) => {\n      this.init()\n        .then(() => {\n          // from url\n          if (typeof fileOrUrl === 'string') {\n            this.http.request('GET', fileOrUrl, { responseType: 'arraybuffer' }).subscribe(\n              (res: ArrayBuffer) => {\n                this.ngZone.run(() => resolve(this.read(new Uint8Array(res), { type: 'array' })));\n              },\n              (err: NzSafeAny) => {\n                reject(err);\n              }\n            );\n            return;\n          }\n          // from file\n          const reader: FileReader = new FileReader();\n          reader.onload = (e: NzSafeAny) => {\n            this.ngZone.run(() => resolve(this.read(e.target.result, { type: 'binary' })));\n          };\n          reader.readAsArrayBuffer(fileOrUrl);\n        })\n        .catch(() => reject(`Unable to load xlsx.js`));\n    });\n  }\n\n  @ZoneOutside()\n  async export(options: XlsxExportOptions): Promise<XlsxExportResult> {\n    return new Promise<XlsxExportResult>((resolve, reject) => {\n      this.init()\n        .then(() => {\n          const wb: NzSafeAny = XLSX.utils.book_new();\n          if (Array.isArray(options.sheets)) {\n            (options.sheets as XlsxExportSheet[]).forEach((value: XlsxExportSheet, index: number) => {\n              const ws: NzSafeAny = XLSX.utils.aoa_to_sheet(value.data);\n              XLSX.utils.book_append_sheet(wb, ws, value.name || `Sheet${index + 1}`);\n            });\n          } else {\n            wb.SheetNames = Object.keys(options.sheets);\n            wb.Sheets = options.sheets;\n          }\n\n          if (options.callback) options.callback(wb);\n\n          const wbout: ArrayBuffer = XLSX.write(wb, {\n            bookType: 'xlsx',\n            bookSST: false,\n            type: 'array',\n            ...options.opts\n          });\n          const filename = options.filename || 'export.xlsx';\n          saveAs(new Blob([wbout], { type: 'application/octet-stream' }), filename);\n\n          resolve({ filename, wb });\n        })\n        .catch(err => reject(err));\n    });\n  }\n\n  /**\n   * 数据转符号名\n   * - `1` => `A`\n   * - `27` => `AA`\n   * - `703` => `AAA`\n   */\n  numberToSchema(val: number): string {\n    const startCode = 'A'.charCodeAt(0);\n    let res = '';\n\n    do {\n      --val;\n      res = String.fromCharCode(startCode + (val % 26)) + res;\n      val = (val / 26) >> 0;\n    } while (val > 0);\n\n    return res;\n  }\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../packages/abc/xlsx/xlsx.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable, NgZone } from '@angular/core';\n\nimport isUtf8 from 'isutf8';\n\nimport { AlainConfigService, AlainXlsxConfig } from '@delon/util/config';\nimport { ZoneOutside } from '@delon/util/decorator';\nimport { LazyResult, LazyService } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { XlsxExportOptions, XlsxExportResult, XlsxExportSheet } from './xlsx.types';\n\ndeclare var XLSX: NzSafeAny;\ndeclare var cptable: NzSafeAny;\n\n@Injectable({ providedIn: 'root' })\nexport class XlsxService {\n  constructor(\n    private http: HttpClient,\n    private lazy: LazyService,\n    configSrv: AlainConfigService,\n    private ngZone: NgZone\n  ) {\n    this.cog = configSrv.merge('xlsx', {\n      url: 'https://cdn.bootcdn.net/ajax/libs/xlsx/0.16.8/xlsx.full.min.js',\n      modules: [`https://cdn.bootcdn.net/ajax/libs/xlsx/0.16.8/cpexcel.min.js`]\n    })!;\n  }\n  private cog: AlainXlsxConfig;\n\n  private init(): Promise<LazyResult[]> {\n    return typeof XLSX !== 'undefined'\n      ? Promise.resolve([])\n      : this.lazy.load([this.cog.url!].concat(this.cog.modules!));\n  }\n\n  @ZoneOutside()\n  private read(data: NzSafeAny): { [key: string]: NzSafeAny[][] } {\n    const {\n      read,\n      utils: { sheet_to_json }\n    } = XLSX;\n    const ret: NzSafeAny = {};\n    const buf = new Uint8Array(data);\n    let type = 'array';\n    if (!isUtf8(buf)) {\n      try {\n        data = cptable.utils.decode(936, buf);\n        type = 'string';\n      } catch {}\n    }\n    const wb = read(data, { type });\n    wb.SheetNames.forEach((name: string) => {\n      const sheet: NzSafeAny = wb.Sheets[name];\n      ret[name] = sheet_to_json(sheet, { header: 1 });\n    });\n    return ret;\n  }\n\n  /**\n   * 导入Excel并输出JSON，支持 `<input type=\"file\">`、URL 形式\n   */\n  import(fileOrUrl: File | string): Promise<{ [key: string]: NzSafeAny[][] }> {\n    return new Promise<{ [key: string]: NzSafeAny[][] }>((resolve, reject) => {\n      const r = (data: NzSafeAny) => this.ngZone.run(() => resolve(this.read(data)));\n      this.init()\n        .then(() => {\n          // from url\n          if (typeof fileOrUrl === 'string') {\n            this.http.request('GET', fileOrUrl, { responseType: 'arraybuffer' }).subscribe(\n              (res: ArrayBuffer) => r(new Uint8Array(res)),\n              (err: NzSafeAny) => reject(err)\n            );\n            return;\n          }\n          // from file\n          const reader: FileReader = new FileReader();\n          reader.onload = (e: NzSafeAny) => r(e.target.result);\n          reader.onerror = (e: NzSafeAny) => reject(e);\n          reader.readAsArrayBuffer(fileOrUrl);\n        })\n        .catch(() => reject(`Unable to load xlsx.js`));\n    });\n  }\n\n  @ZoneOutside()\n  async export(options: XlsxExportOptions): Promise<XlsxExportResult> {\n    return new Promise<XlsxExportResult>((resolve, reject) => {\n      this.init()\n        .then(() => {\n          options = { format: 'xlsx', ...options };\n          const {\n            writeFile,\n            utils: { book_new, aoa_to_sheet, book_append_sheet }\n          } = XLSX;\n          const wb: NzSafeAny = book_new();\n          if (Array.isArray(options.sheets)) {\n            (options.sheets as XlsxExportSheet[]).forEach((value: XlsxExportSheet, index: number) => {\n              const ws: NzSafeAny = aoa_to_sheet(value.data);\n              book_append_sheet(wb, ws, value.name || `Sheet${index + 1}`);\n            });\n          } else {\n            wb.SheetNames = Object.keys(options.sheets);\n            wb.Sheets = options.sheets;\n          }\n\n          if (options.callback) options.callback(wb);\n\n          const filename = options.filename || `export.${options.format}`;\n          writeFile(wb, filename, {\n            bookType: options.format,\n            bookSST: false,\n            type: 'array',\n            ...options.opts\n          });\n\n          resolve({ filename, wb });\n        })\n        .catch(err => reject(err));\n    });\n  }\n\n  /**\n   * 数据转符号名\n   * - `1` => `A`\n   * - `27` => `AA`\n   * - `703` => `AAA`\n   */\n  numberToSchema(val: number): string {\n    const startCode = 'A'.charCodeAt(0);\n    let res = '';\n\n    do {\n      --val;\n      res = String.fromCharCode(startCode + (val % 26)) + res;\n      val = (val / 26) >> 0;\n    } while (val > 0);\n\n    return res;\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieGxzeC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FiYy94bHN4L3hsc3gudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTnpTYWZlQW55IH0gZnJvbSAnbmctem9ycm8tYW50ZC9jb3JlL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBYbHN4RXhwb3J0T3B0aW9ucyB7XG4gIC8qKlxuICAgKiB3b3Jrc2hlZXRzIGluIHRoZSB3b3JrYm9vaywgZS5nOlxuICAgKiAtIGB7IFNoZWV0MTogeyBBMTogeyB0OlwiblwiLCB2OjEwMDAwIH0gfSB9YFxuICAgKiAtIGBbWycxJ10sIFsxXV1gXG4gICAqL1xuICBzaGVldHM6IHsgW3NoZWV0OiBzdHJpbmddOiBOelNhZmVBbnkgfSB8IFhsc3hFeHBvcnRTaGVldFtdO1xuICAvKiogc2F2ZSBmaWxlIG5hbWUsIGRlZmF1bHQ6IGBleHBvcnQueGxzeGAgKi9cbiAgZmlsZW5hbWU/OiBzdHJpbmc7XG4gIG9wdHM/OiBOelNhZmVBbnk7XG4gIC8qKiB0cmlnZ2VycyB3aGVuIHNhdmVhcyAqL1xuICBjYWxsYmFjaz86ICh3YjogTnpTYWZlQW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFhsc3hFeHBvcnRTaGVldCB7XG4gIC8qKiBhcnJheXMgdG8gYSB3b3Jrc2hlZXQgKi9cbiAgZGF0YTogTnpTYWZlQW55W11bXTtcbiAgLyoqIHNoZWV0IG5hbWUgKi9cbiAgbmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBYbHN4RXhwb3J0UmVzdWx0IHtcbiAgZmlsZW5hbWU6IHN0cmluZztcbiAgd2I6IE56U2FmZUFueTtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieGxzeC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FiYy94bHN4L3hsc3gudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTnpTYWZlQW55IH0gZnJvbSAnbmctem9ycm8tYW50ZC9jb3JlL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBYbHN4RXhwb3J0T3B0aW9ucyB7XG4gIC8qKlxuICAgKiB3b3Jrc2hlZXRzIGluIHRoZSB3b3JrYm9vaywgZS5nOlxuICAgKiAtIGB7IFNoZWV0MTogeyBBMTogeyB0OlwiblwiLCB2OjEwMDAwIH0gfSB9YFxuICAgKiAtIGBbWycxJ10sIFsxXV1gXG4gICAqL1xuICBzaGVldHM6IHsgW3NoZWV0OiBzdHJpbmddOiBOelNhZmVBbnkgfSB8IFhsc3hFeHBvcnRTaGVldFtdO1xuICAvKiogRmlsZSBmb3JtYXQsIGRlZmF1bHQ6IGB4bHN4YCAqL1xuICBmb3JtYXQ/OiAnY3N2JyB8ICd4bHN4JztcbiAgLyoqIHNhdmUgZmlsZSBuYW1lLCBkZWZhdWx0OiBgZXhwb3J0Lnhsc3hgICovXG4gIGZpbGVuYW1lPzogc3RyaW5nO1xuICAvKiogU2VlIFtXcml0aW5nIE9wdGlvbnNdKGh0dHBzOi8vZ2l0aHViLmNvbS9TaGVldEpTL3NoZWV0anMvYmxvYi9tYXN0ZXIvZG9jYml0cy84MV93cml0ZW9wdHMubWQpICovXG4gIG9wdHM/OiBOelNhZmVBbnk7XG4gIC8qKiB0cmlnZ2VycyB3aGVuIHNhdmVhcyAqL1xuICBjYWxsYmFjaz86ICh3YjogTnpTYWZlQW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFhsc3hFeHBvcnRTaGVldCB7XG4gIC8qKiBhcnJheXMgdG8gYSB3b3Jrc2hlZXQgKi9cbiAgZGF0YTogTnpTYWZlQW55W11bXTtcbiAgLyoqIHNoZWV0IG5hbWUgKi9cbiAgbmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBYbHN4RXhwb3J0UmVzdWx0IHtcbiAgZmlsZW5hbWU6IHN0cmluZztcbiAgd2I6IE56U2FmZUFueTtcbn1cbiJdfQ==
package/fesm2015/table.js CHANGED
@@ -334,6 +334,9 @@ class STColumnSource {
334
334
  if (this.acl && item.acl && !this.acl.can(item.acl)) {
335
335
  continue;
336
336
  }
337
+ if (Array.isArray(item.children) && item.children.length > 0) {
338
+ item.children = this.cleanCond(item.children);
339
+ }
337
340
  res.push(item);
338
341
  }
339
342
  return res;