@sd-angular/core 1.3.29 → 1.3.31

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 (62) hide show
  1. package/bundles/sd-angular-core-common.umd.js.map +1 -1
  2. package/bundles/sd-angular-core-common.umd.min.js.map +1 -1
  3. package/bundles/sd-angular-core-export.umd.js +38 -44
  4. package/bundles/sd-angular-core-export.umd.js.map +1 -1
  5. package/bundles/sd-angular-core-export.umd.min.js +1 -1
  6. package/bundles/sd-angular-core-export.umd.min.js.map +1 -1
  7. package/bundles/sd-angular-core-grid.umd.js +50 -187
  8. package/bundles/sd-angular-core-grid.umd.js.map +1 -1
  9. package/bundles/sd-angular-core-grid.umd.min.js +1 -1
  10. package/bundles/sd-angular-core-grid.umd.min.js.map +1 -1
  11. package/bundles/sd-angular-core-upload-excel.umd.js.map +1 -1
  12. package/bundles/sd-angular-core-upload-excel.umd.min.js.map +1 -1
  13. package/bundles/sd-angular-core.umd.js +4 -4
  14. package/bundles/sd-angular-core.umd.min.js +1 -1
  15. package/bundles/sd-angular-core.umd.min.js.map +1 -1
  16. package/common/sd-angular-core-common.metadata.json +1 -1
  17. package/common/src/lib/configurations/firebase.configuration.d.ts +1 -0
  18. package/esm2015/common/src/lib/configurations/firebase.configuration.js +1 -1
  19. package/esm2015/export/src/lib/export.model.js +1 -3
  20. package/esm2015/export/src/lib/export.service.js +25 -34
  21. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.js +35 -27
  22. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.model.js +1 -1
  23. package/esm2015/grid/src/lib/grid.component.js +11 -118
  24. package/esm2015/public-api.js +1 -3
  25. package/esm2015/upload-excel/src/lib/upload-excel.component.js +1 -1
  26. package/export/sd-angular-core-export.metadata.json +1 -1
  27. package/export/src/lib/export.model.d.ts +0 -15
  28. package/export/src/lib/export.service.d.ts +6 -4
  29. package/fesm2015/sd-angular-core-common.js.map +1 -1
  30. package/fesm2015/sd-angular-core-export.js +25 -35
  31. package/fesm2015/sd-angular-core-export.js.map +1 -1
  32. package/fesm2015/sd-angular-core-grid.js +43 -142
  33. package/fesm2015/sd-angular-core-grid.js.map +1 -1
  34. package/fesm2015/sd-angular-core-upload-excel.js.map +1 -1
  35. package/fesm2015/sd-angular-core.js +0 -1
  36. package/fesm2015/sd-angular-core.js.map +1 -1
  37. package/grid/sd-angular-core-grid.metadata.json +1 -1
  38. package/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.d.ts +12 -12
  39. package/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.model.d.ts +1 -2
  40. package/grid/src/lib/grid.component.d.ts +5 -6
  41. package/package.json +1 -1
  42. package/public-api.d.ts +0 -1
  43. package/{sd-angular-core-1.3.29.tgz → sd-angular-core-1.3.31.tgz} +0 -0
  44. package/upload-excel/sd-angular-core-upload-excel.metadata.json +1 -1
  45. package/bundles/sd-angular-core-excel.umd.js +0 -500
  46. package/bundles/sd-angular-core-excel.umd.js.map +0 -1
  47. package/bundles/sd-angular-core-excel.umd.min.js +0 -16
  48. package/bundles/sd-angular-core-excel.umd.min.js.map +0 -1
  49. package/esm2015/excel/index.js +0 -2
  50. package/esm2015/excel/sd-angular-core-excel.js +0 -5
  51. package/esm2015/excel/src/lib/excel.model.js +0 -3
  52. package/esm2015/excel/src/lib/excel.service.js +0 -91
  53. package/esm2015/excel/src/public-api.js +0 -6
  54. package/excel/index.d.ts +0 -1
  55. package/excel/package.json +0 -12
  56. package/excel/sd-angular-core-excel.d.ts +0 -4
  57. package/excel/sd-angular-core-excel.metadata.json +0 -1
  58. package/excel/src/lib/excel.model.d.ts +0 -65
  59. package/excel/src/lib/excel.service.d.ts +0 -26
  60. package/excel/src/public-api.d.ts +0 -2
  61. package/fesm2015/sd-angular-core-excel.js +0 -100
  62. package/fesm2015/sd-angular-core-excel.js.map +0 -1
@@ -7,20 +7,21 @@ import * as uuid from 'uuid';
7
7
  import hash from 'object-hash';
8
8
  import { ExportToCsv } from 'export-to-csv';
9
9
  import * as XLSX from 'xlsx';
10
- import { EXPORT_CONFIG, API } from './export.model';
10
+ import { API } from './export.model';
11
11
  import { SdNotifyService } from '@sd-angular/core/notify';
12
12
  import { SdUtilityService } from '@sd-angular/core/utility';
13
+ import { FIREBASE_CONFIG } from '@sd-angular/core/common';
13
14
  import * as i0 from "@angular/core";
14
15
  import * as i1 from "@sd-angular/core/api";
15
16
  import * as i2 from "@sd-angular/core/utility";
16
17
  import * as i3 from "@sd-angular/core/notify";
17
- import * as i4 from "./export.model";
18
+ import * as i4 from "@sd-angular/core/common";
18
19
  export class SdExportService {
19
- constructor(apiService, utilityService, notifyService, configuration) {
20
+ constructor(apiService, utilityService, notifyService, firebaseConfiguration) {
20
21
  this.apiService = apiService;
21
22
  this.utilityService = utilityService;
22
23
  this.notifyService = notifyService;
23
- this.configuration = configuration;
24
+ this.firebaseConfiguration = firebaseConfiguration;
24
25
  _directory.set(this, (key, group) => {
25
26
  let hashedFolder = hash({
26
27
  folder: this.folder,
@@ -36,11 +37,8 @@ export class SdExportService {
36
37
  return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;
37
38
  });
38
39
  this.generateTemplate = (template) => __awaiter(this, void 0, void 0, function* () {
39
- const { firebaseUrl } = this.configuration;
40
40
  const { sdGenerateTemplate } = API;
41
- const url = `${firebaseUrl}${sdGenerateTemplate}`;
42
- // const { filePath, fileName } = await this.apiService.post(url, template);
43
- // return { filePath, fileName };
41
+ const url = `${this.functionUrl}${sdGenerateTemplate}`;
44
42
  const buffer = yield this.apiService.post(url, template, null, {
45
43
  responseType: 'arraybuffer'
46
44
  });
@@ -49,9 +47,8 @@ export class SdExportService {
49
47
  });
50
48
  this.uploadTemplate = (args) => __awaiter(this, void 0, void 0, function* () {
51
49
  const { key, group, validator } = args;
52
- const { firebaseUrl } = this.configuration;
53
50
  const { uploadTemplate } = API;
54
- const url = `${firebaseUrl}${uploadTemplate}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
51
+ const url = `${this.functionUrl}${uploadTemplate}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
55
52
  const file = yield this.utilityService.upload({
56
53
  extensions: ['xlsx'],
57
54
  maxSizeInMb: 0.1,
@@ -71,25 +68,22 @@ export class SdExportService {
71
68
  });
72
69
  this.generateUploadTemplate = (args) => __awaiter(this, void 0, void 0, function* () {
73
70
  const { key, template, group } = args;
74
- const { firebaseUrl } = this.configuration;
75
71
  const { generateUploadTemplate } = API;
76
- const url = `${firebaseUrl}${generateUploadTemplate}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
72
+ const url = `${this.functionUrl}${generateUploadTemplate}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
77
73
  const { filePath, fileName } = yield this.apiService.post(url, template);
78
74
  return { filePath, fileName };
79
75
  });
80
76
  this.removeFile = (args) => __awaiter(this, void 0, void 0, function* () {
81
77
  const { key, group, fileName } = args;
82
- const { firebaseUrl } = this.configuration;
83
78
  const { removeFile } = API;
84
- const url = `${firebaseUrl}${removeFile}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}&name=${fileName}`;
79
+ const url = `${this.functionUrl}${removeFile}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}&name=${fileName}`;
85
80
  yield this.apiService.post(url);
86
81
  });
87
82
  this.filesInFolder = (args) => __awaiter(this, void 0, void 0, function* () {
88
83
  var _a;
89
84
  const { key, group } = args;
90
- const { firebaseUrl } = this.configuration;
91
85
  const { filesInFolder } = API;
92
- const url = `${firebaseUrl}${filesInFolder}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
86
+ const url = `${this.functionUrl}${filesInFolder}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
93
87
  const res = yield this.apiService.get(url);
94
88
  return ((_a = res.files) === null || _a === void 0 ? void 0 : _a.map(e => ({
95
89
  filePath: e.publicUrl,
@@ -106,9 +100,8 @@ export class SdExportService {
106
100
  };
107
101
  this.exportByTemplate = (args) => __awaiter(this, void 0, void 0, function* () {
108
102
  const { filePath, columns, items, fileName } = args;
109
- const { firebaseUrl } = this.configuration;
110
103
  const { sdExportByTemplate } = API;
111
- const url = `${firebaseUrl}${sdExportByTemplate}`;
104
+ const url = `${this.functionUrl}${sdExportByTemplate}`;
112
105
  const buffer = yield this.apiService.post(url, {
113
106
  filePath,
114
107
  columns,
@@ -121,9 +114,8 @@ export class SdExportService {
121
114
  __classPrivateFieldGet(this, _blobToSaveAs).call(this, blob, fileName);
122
115
  });
123
116
  this.export = (option) => __awaiter(this, void 0, void 0, function* () {
124
- const { firebaseUrl } = this.configuration;
125
117
  const { sdExport } = API;
126
- const url = `${firebaseUrl}${sdExport}`;
118
+ const url = `${this.functionUrl}${sdExport}`;
127
119
  const buffer = yield this.apiService.post(url, option, null, {
128
120
  responseType: 'arraybuffer'
129
121
  });
@@ -181,9 +173,8 @@ export class SdExportService {
181
173
  __classPrivateFieldGet(this, _blobToSaveAs).call(this, blob, fileName);
182
174
  });
183
175
  this.mergePDF = (urls) => __awaiter(this, void 0, void 0, function* () {
184
- const { firebaseUrl } = this.configuration;
185
176
  const { sdMergePDF } = API;
186
- const url = `${firebaseUrl}${sdMergePDF}`;
177
+ const url = `${this.functionUrl}${sdMergePDF}`;
187
178
  const buffer = yield this.apiService.post(url, {
188
179
  urls
189
180
  }, null, {
@@ -216,21 +207,21 @@ export class SdExportService {
216
207
  }
217
208
  get hasConfiguration() {
218
209
  var _a;
219
- return !!((_a = this.configuration) === null || _a === void 0 ? void 0 : _a.firebaseUrl);
210
+ return !!((_a = this.firebaseConfiguration) === null || _a === void 0 ? void 0 : _a.functionUrl);
211
+ }
212
+ get functionUrl() {
213
+ var _a;
214
+ return (_a = this.firebaseConfiguration) === null || _a === void 0 ? void 0 : _a.functionUrl;
220
215
  }
221
216
  get folder() {
222
- const { folder } = this.configuration;
223
- if (typeof (folder) === 'string') {
224
- return folder;
225
- }
226
- return folder();
217
+ const { project, env } = this.firebaseConfiguration;
218
+ return `${project}-${env}`;
227
219
  }
228
220
  get userFolder() {
229
- const { user } = this.configuration;
230
- if (!(user === null || user === void 0 ? void 0 : user.folder)) {
221
+ const { folder } = this.firebaseConfiguration;
222
+ if (!folder) {
231
223
  return;
232
224
  }
233
- const { folder } = user;
234
225
  if (typeof (folder) === 'string') {
235
226
  return folder;
236
227
  }
@@ -238,7 +229,7 @@ export class SdExportService {
238
229
  }
239
230
  }
240
231
  _directory = new WeakMap(), _blobToSaveAs = new WeakMap();
241
- SdExportService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdExportService_Factory() { return new SdExportService(i0.ɵɵinject(i1.SdApiService), i0.ɵɵinject(i2.SdUtilityService), i0.ɵɵinject(i3.SdNotifyService), i0.ɵɵinject(i4.EXPORT_CONFIG, 8)); }, token: SdExportService, providedIn: "root" });
232
+ SdExportService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdExportService_Factory() { return new SdExportService(i0.ɵɵinject(i1.SdApiService), i0.ɵɵinject(i2.SdUtilityService), i0.ɵɵinject(i3.SdNotifyService), i0.ɵɵinject(i4.FIREBASE_CONFIG, 8)); }, token: SdExportService, providedIn: "root" });
242
233
  SdExportService.decorators = [
243
234
  { type: Injectable, args: [{
244
235
  providedIn: 'root'
@@ -248,6 +239,6 @@ SdExportService.ctorParameters = () => [
248
239
  { type: SdApiService },
249
240
  { type: SdUtilityService },
250
241
  { type: SdNotifyService },
251
- { type: undefined, decorators: [{ type: Inject, args: [EXPORT_CONFIG,] }, { type: Optional }] }
242
+ { type: undefined, decorators: [{ type: Inject, args: [FIREBASE_CONFIG,] }, { type: Optional }] }
252
243
  ];
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export.service.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/export/","sources":["src/lib/export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Optional } from '@angular/core';\r\nimport { Injectable, Inject } from '@angular/core';\r\nimport { SdApiService } from '@sd-angular/core/api';\r\nimport * as uuid from 'uuid';\r\nimport hash from 'object-hash';\r\nimport { ExportToCsv } from 'export-to-csv';\r\nimport * as XLSX from 'xlsx';\r\nimport { ExportTemplate, IExportConfiguration, EXPORT_CONFIG, IExportOption, API, SdExportFile } from './export.model';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SdExportService {\r\n  get hasConfiguration() {\r\n    return !!this.configuration?.firebaseUrl;\r\n  }\r\n  constructor(\r\n    private apiService: SdApiService,\r\n    private utilityService: SdUtilityService,\r\n    private notifyService: SdNotifyService,\r\n    @Inject(EXPORT_CONFIG) @Optional() private configuration: IExportConfiguration) {\r\n  }\r\n\r\n  private get folder() {\r\n    const { folder } = this.configuration;\r\n    if (typeof (folder) === 'string') {\r\n      return folder;\r\n    }\r\n    return folder();\r\n  }\r\n\r\n  private get userFolder() {\r\n    const { user } = this.configuration;\r\n    if (!user?.folder) {\r\n      return;\r\n    }\r\n    const { folder } = user;\r\n    if (typeof (folder) === 'string') {\r\n      return folder;\r\n    }\r\n    return folder();\r\n  }\r\n\r\n  #directory = (key: string, group: string) => {\r\n    let hashedFolder = hash({\r\n      folder: this.folder,\r\n      userFolder: this.userFolder\r\n    });\r\n    if (!group) {\r\n      return `dir1=${this.folder}&dir2=U-${hashedFolder}&dir3=${key || ''}`;\r\n    }\r\n    hashedFolder = hash({\r\n      folder: this.folder,\r\n      group\r\n    });\r\n    return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;\r\n  }\r\n\r\n  generateTemplate = async (template: ExportTemplate) => {\r\n    const { firebaseUrl } = this.configuration;\r\n    const { sdGenerateTemplate } = API;\r\n    const url = `${firebaseUrl}${sdGenerateTemplate}`;\r\n    // const { filePath, fileName } = await this.apiService.post(url, template);\r\n    // return { filePath, fileName };\r\n    const buffer = await this.apiService.post(url, template, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, template.fileName || 'Template');\r\n  }\r\n\r\n  uploadTemplate = async (args: {\r\n    key: string;\r\n    group?: string;\r\n    validator?: (fileName: string) => string\r\n  }): Promise<SdExportFile> => {\r\n    const { key, group, validator } = args;\r\n    const { firebaseUrl } = this.configuration;\r\n    const { uploadTemplate } = API;\r\n    const url = `${firebaseUrl}${uploadTemplate}?${this.#directory(key, group)}`;\r\n    const file = await this.utilityService.upload({\r\n      extensions: ['xlsx'],\r\n      maxSizeInMb: 0.1,\r\n      validator\r\n    });\r\n    if (file) {\r\n      const { filePath, fileName } = await this.apiService.upload(url, file).catch((err: Error) => {\r\n        this.notifyService.notify.warning(err?.message);\r\n        throw err;\r\n      });\r\n      return {\r\n        filePath,\r\n        fileName,\r\n      };\r\n    }\r\n    return null;\r\n  }\r\n\r\n  generateUploadTemplate = async (args: {\r\n    key: string;\r\n    template: ExportTemplate;\r\n    group?: string;\r\n  }) => {\r\n    const { key, template, group } = args;\r\n    const { firebaseUrl } = this.configuration;\r\n    const { generateUploadTemplate } = API;\r\n    const url = `${firebaseUrl}${generateUploadTemplate}?${this.#directory(key, group)}`;\r\n    const { filePath, fileName } = await this.apiService.post(url, template);\r\n    return { filePath, fileName };\r\n  }\r\n\r\n  removeFile = async (args: {\r\n    key: string;\r\n    group?: string;\r\n    fileName?: string;\r\n  }) => {\r\n    const { key, group, fileName } = args;\r\n    const { firebaseUrl } = this.configuration;\r\n    const { removeFile } = API;\r\n    const url = `${firebaseUrl}${removeFile}?${this.#directory(key, group)}&name=${fileName}`;\r\n    await this.apiService.post(url);\r\n  }\r\n\r\n  filesInFolder = async (args: {\r\n    key: string;\r\n    group?: string;\r\n  }): Promise<SdExportFile[]> => {\r\n    interface FilesInFolderRes {\r\n      directory: string;\r\n      files: {\r\n        publicUrl: string, fullPath: string, name: string\r\n      }[];\r\n    }\r\n    const { key, group } = args;\r\n    const { firebaseUrl } = this.configuration;\r\n    const { filesInFolder } = API;\r\n    const url = `${firebaseUrl}${filesInFolder}?${this.#directory(key, group)}`;\r\n    const res = await this.apiService.get<FilesInFolderRes>(url);\r\n    return res.files?.map(e => ({\r\n      filePath: e.publicUrl,\r\n      fileName: e.name\r\n    })) || [];\r\n  }\r\n\r\n  download = (filePath: string, fileName?: string) => {\r\n    const link: any = document.createElement('a');\r\n    link.download = `${fileName || uuid.v4()}.xlsx`;\r\n    link.href = filePath;\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n  }\r\n\r\n  exportByTemplate = async (args: {\r\n    filePath: string,\r\n    columns: any[],\r\n    items: any[],\r\n    fileName?: string\r\n  }) => {\r\n    const { filePath, columns, items, fileName } = args;\r\n    const { firebaseUrl } = this.configuration;\r\n    const { sdExportByTemplate } = API;\r\n    const url = `${firebaseUrl}${sdExportByTemplate}`;\r\n    const buffer = await this.apiService.post(url, {\r\n      filePath,\r\n      columns,\r\n      items,\r\n      fileName\r\n    }, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, fileName);\r\n  }\r\n\r\n  export = async (option: IExportOption) => {\r\n    const { firebaseUrl } = this.configuration;\r\n    const { sdExport } = API;\r\n    const url = `${firebaseUrl}${sdExport}`;\r\n    const buffer = await this.apiService.post(url, option, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, option?.fileName);\r\n  }\r\n\r\n  // exportCSV = async (option: IExportOption) => {\r\n  //   const { columns, items, fileName } = option;\r\n  //   const options = {\r\n  //     fieldSeparator: ',',\r\n  //     quoteStrings: '\"',\r\n  //     decimalseparator: '.',\r\n  //     showLabels: true,\r\n  //     showTitle: false,\r\n  //     title: fileName || 'CSV',\r\n  //     useBom: true,\r\n  //     noDownload: false,\r\n  //     useHeader: false,\r\n  //     nullToEmptyString: true,\r\n  //   };\r\n  //   const headerCSV = {};\r\n  //   for (const column of columns) {\r\n  //     headerCSV[column.field] = column.title;\r\n  //   }\r\n  //   return new AngularCsv([...[headerCSV], ...items], `${fileName || 'CSV'}_${Date.toFormat(new Date(), 'yyyy-MM-dd-HH-mm-ss')}`, options);\r\n  // }\r\n\r\n  exportCSV = async (option: IExportOption) => {\r\n    const { columns, items, fileName } = option;\r\n    const headerCSV = {};\r\n    for (const column of columns) {\r\n      headerCSV[column.field] = column.title;\r\n    }\r\n    const csvExporter = new ExportToCsv({\r\n      filename: `${fileName || 'CSV'}_${Date.toFormat(new Date(), 'yyyy-MM-dd-HH-mm-ss')}`,\r\n      fieldSeparator: ',',\r\n      quoteStrings: '\"',\r\n      decimalSeparator: '.',\r\n      showLabels: true,\r\n      showTitle: false,\r\n      title: fileName || 'CSV',\r\n      useBom: true,\r\n    });\r\n    csvExporter.generateCsv([headerCSV, ...items]);\r\n  }\r\n\r\n  exportExcelRaw = async (option: IExportOption) => {\r\n    const { columns, items, fileName } = option;\r\n    const header = {};\r\n    for (const column of columns) {\r\n      header[column.field] = column.title;\r\n    }\r\n    const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet([header, ...items]);\r\n    const wb: XLSX.WorkBook = { Sheets: { data: ws }, SheetNames: ['data'] };\r\n    const excelBuffer: any = XLSX.write(wb, { bookType: 'xlsx', type: 'array' });\r\n    const blob = new Blob([excelBuffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8' });\r\n    this.#blobToSaveAs(blob, fileName);\r\n  }\r\n\r\n  mergePDF = async (urls: string[]) => {\r\n    const { firebaseUrl } = this.configuration;\r\n    const { sdMergePDF } = API;\r\n    const url = `${firebaseUrl}${sdMergePDF}`;\r\n    const buffer = await this.apiService.post(url, {\r\n      urls\r\n    }, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/pdf' });\r\n    this.#blobToSaveAs(blob, `${uuid.v4()}`);\r\n  }\r\n\r\n  loadExportedItems = async (items: (pageSize: number, pageNumber: number) => { total: number,  }) => {\r\n\r\n  }\r\n\r\n  #blobToSaveAs = (blob: Blob, fileName: string = 'Export') => {\r\n    try {\r\n      const url = window.URL.createObjectURL(blob);\r\n      const link = document.createElement('a');\r\n      fileName = fileName.replace(/.xlsx/i, '');\r\n      fileName = fileName.replace(/.pdf/i, '');\r\n      if (link.download !== undefined) { // feature detection\r\n        link.setAttribute('href', url);\r\n        link.setAttribute('download', `${fileName}_${new Date().toFormat('yyyy_MM_dd_HH_mm')}`);\r\n        link.style.visibility = 'hidden';\r\n        document.body.appendChild(link);\r\n        link.click();\r\n        document.body.removeChild(link);\r\n      }\r\n    } catch (e) {\r\n      console.error('BlobToSaveAs error', e);\r\n    }\r\n  }\r\n}\r\n\r\nexport interface IExportInfo {\r\n  data: any[];\r\n  sheetName?: string;\r\n  fileName?: string;\r\n}\r\n"]}
244
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export.service.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/export/","sources":["src/lib/export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Optional } from '@angular/core';\r\nimport { Injectable, Inject } from '@angular/core';\r\nimport { SdApiService } from '@sd-angular/core/api';\r\nimport * as uuid from 'uuid';\r\nimport hash from 'object-hash';\r\nimport { ExportToCsv } from 'export-to-csv';\r\nimport * as XLSX from 'xlsx';\r\nimport { ExportTemplate, IExportOption, API, SdExportFile } from './export.model';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { FIREBASE_CONFIG, IFirebaseConfiguration } from '@sd-angular/core/common';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SdExportService {\r\n  private get hasConfiguration() {\r\n    return !!this.firebaseConfiguration?.functionUrl;\r\n  }\r\n  private get functionUrl() {\r\n    return this.firebaseConfiguration?.functionUrl;\r\n  }\r\n\r\n  private get folder() {\r\n    const { project, env } = this.firebaseConfiguration;\r\n    return `${project}-${env}`;\r\n  }\r\n\r\n  private get userFolder() {\r\n    const { folder } = this.firebaseConfiguration;\r\n    if (!folder) {\r\n      return;\r\n    }\r\n    if (typeof (folder) === 'string') {\r\n      return folder;\r\n    }\r\n    return folder();\r\n  }\r\n\r\n  constructor(\r\n    private apiService: SdApiService,\r\n    private utilityService: SdUtilityService,\r\n    private notifyService: SdNotifyService,\r\n    @Inject(FIREBASE_CONFIG) @Optional() private firebaseConfiguration: IFirebaseConfiguration) {\r\n  }\r\n\r\n  #directory = (key: string, group: string) => {\r\n    let hashedFolder = hash({\r\n      folder: this.folder,\r\n      userFolder: this.userFolder\r\n    });\r\n    if (!group) {\r\n      return `dir1=${this.folder}&dir2=U-${hashedFolder}&dir3=${key || ''}`;\r\n    }\r\n    hashedFolder = hash({\r\n      folder: this.folder,\r\n      group\r\n    });\r\n    return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;\r\n  }\r\n\r\n  generateTemplate = async (template: ExportTemplate) => {\r\n    const { sdGenerateTemplate } = API;\r\n    const url = `${this.functionUrl}${sdGenerateTemplate}`;\r\n    const buffer = await this.apiService.post(url, template, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, template.fileName || 'Template');\r\n  }\r\n\r\n  uploadTemplate = async (args: {\r\n    key: string;\r\n    group?: string;\r\n    validator?: (fileName: string) => string\r\n  }): Promise<SdExportFile> => {\r\n    const { key, group, validator } = args;\r\n    const { uploadTemplate } = API;\r\n    const url = `${this.functionUrl}${uploadTemplate}?${this.#directory(key, group)}`;\r\n    const file = await this.utilityService.upload({\r\n      extensions: ['xlsx'],\r\n      maxSizeInMb: 0.1,\r\n      validator\r\n    });\r\n    if (file) {\r\n      const { filePath, fileName } = await this.apiService.upload(url, file).catch((err: Error) => {\r\n        this.notifyService.notify.warning(err?.message);\r\n        throw err;\r\n      });\r\n      return {\r\n        filePath,\r\n        fileName,\r\n      };\r\n    }\r\n    return null;\r\n  }\r\n\r\n  generateUploadTemplate = async (args: {\r\n    key: string;\r\n    template: ExportTemplate;\r\n    group?: string;\r\n  }) => {\r\n    const { key, template, group } = args;\r\n    const { generateUploadTemplate } = API;\r\n    const url = `${this.functionUrl}${generateUploadTemplate}?${this.#directory(key, group)}`;\r\n    const { filePath, fileName } = await this.apiService.post(url, template);\r\n    return { filePath, fileName };\r\n  }\r\n\r\n  removeFile = async (args: {\r\n    key: string;\r\n    group?: string;\r\n    fileName?: string;\r\n  }) => {\r\n    const { key, group, fileName } = args;\r\n    const { removeFile } = API;\r\n    const url = `${this.functionUrl}${removeFile}?${this.#directory(key, group)}&name=${fileName}`;\r\n    await this.apiService.post(url);\r\n  }\r\n\r\n  filesInFolder = async (args: {\r\n    key: string;\r\n    group?: string;\r\n  }): Promise<SdExportFile[]> => {\r\n    interface FilesInFolderRes {\r\n      directory: string;\r\n      files: {\r\n        publicUrl: string, fullPath: string, name: string\r\n      }[];\r\n    }\r\n    const { key, group } = args;\r\n    const { filesInFolder } = API;\r\n    const url = `${this.functionUrl}${filesInFolder}?${this.#directory(key, group)}`;\r\n    const res = await this.apiService.get<FilesInFolderRes>(url);\r\n    return res.files?.map(e => ({\r\n      filePath: e.publicUrl,\r\n      fileName: e.name\r\n    })) || [];\r\n  }\r\n\r\n  download = (filePath: string, fileName?: string) => {\r\n    const link: any = document.createElement('a');\r\n    link.download = `${fileName || uuid.v4()}.xlsx`;\r\n    link.href = filePath;\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n  }\r\n\r\n  exportByTemplate = async (args: {\r\n    filePath: string,\r\n    columns: any[],\r\n    items: any[],\r\n    fileName?: string\r\n  }) => {\r\n    const { filePath, columns, items, fileName } = args;\r\n    const { sdExportByTemplate } = API;\r\n    const url = `${this.functionUrl}${sdExportByTemplate}`;\r\n    const buffer = await this.apiService.post(url, {\r\n      filePath,\r\n      columns,\r\n      items,\r\n      fileName\r\n    }, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, fileName);\r\n  }\r\n\r\n  export = async (option: IExportOption) => {\r\n    const { sdExport } = API;\r\n    const url = `${this.functionUrl}${sdExport}`;\r\n    const buffer = await this.apiService.post(url, option, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n    this.#blobToSaveAs(blob, option?.fileName);\r\n  }\r\n\r\n  // exportCSV = async (option: IExportOption) => {\r\n  //   const { columns, items, fileName } = option;\r\n  //   const options = {\r\n  //     fieldSeparator: ',',\r\n  //     quoteStrings: '\"',\r\n  //     decimalseparator: '.',\r\n  //     showLabels: true,\r\n  //     showTitle: false,\r\n  //     title: fileName || 'CSV',\r\n  //     useBom: true,\r\n  //     noDownload: false,\r\n  //     useHeader: false,\r\n  //     nullToEmptyString: true,\r\n  //   };\r\n  //   const headerCSV = {};\r\n  //   for (const column of columns) {\r\n  //     headerCSV[column.field] = column.title;\r\n  //   }\r\n  //   return new AngularCsv([...[headerCSV], ...items], `${fileName || 'CSV'}_${Date.toFormat(new Date(), 'yyyy-MM-dd-HH-mm-ss')}`, options);\r\n  // }\r\n\r\n  exportCSV = async (option: IExportOption) => {\r\n    const { columns, items, fileName } = option;\r\n    const headerCSV = {};\r\n    for (const column of columns) {\r\n      headerCSV[column.field] = column.title;\r\n    }\r\n    const csvExporter = new ExportToCsv({\r\n      filename: `${fileName || 'CSV'}_${Date.toFormat(new Date(), 'yyyy-MM-dd-HH-mm-ss')}`,\r\n      fieldSeparator: ',',\r\n      quoteStrings: '\"',\r\n      decimalSeparator: '.',\r\n      showLabels: true,\r\n      showTitle: false,\r\n      title: fileName || 'CSV',\r\n      useBom: true,\r\n    });\r\n    csvExporter.generateCsv([headerCSV, ...items]);\r\n  }\r\n\r\n  exportExcelRaw = async (option: IExportOption) => {\r\n    const { columns, items, fileName } = option;\r\n    const header = {};\r\n    for (const column of columns) {\r\n      header[column.field] = column.title;\r\n    }\r\n    const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet([header, ...items]);\r\n    const wb: XLSX.WorkBook = { Sheets: { data: ws }, SheetNames: ['data'] };\r\n    const excelBuffer: any = XLSX.write(wb, { bookType: 'xlsx', type: 'array' });\r\n    const blob = new Blob([excelBuffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8' });\r\n    this.#blobToSaveAs(blob, fileName);\r\n  }\r\n\r\n  mergePDF = async (urls: string[]) => {\r\n    const { sdMergePDF } = API;\r\n    const url = `${this.functionUrl}${sdMergePDF}`;\r\n    const buffer = await this.apiService.post(url, {\r\n      urls\r\n    }, null, {\r\n      responseType: 'arraybuffer'\r\n    });\r\n    const blob = new Blob([buffer], { type: 'application/pdf' });\r\n    this.#blobToSaveAs(blob, `${uuid.v4()}`);\r\n  }\r\n\r\n  loadExportedItems = async (items: (pageSize: number, pageNumber: number) => { total: number, }) => {\r\n\r\n  }\r\n\r\n  #blobToSaveAs = (blob: Blob, fileName: string = 'Export') => {\r\n    try {\r\n      const url = window.URL.createObjectURL(blob);\r\n      const link = document.createElement('a');\r\n      fileName = fileName.replace(/.xlsx/i, '');\r\n      fileName = fileName.replace(/.pdf/i, '');\r\n      if (link.download !== undefined) { // feature detection\r\n        link.setAttribute('href', url);\r\n        link.setAttribute('download', `${fileName}_${new Date().toFormat('yyyy_MM_dd_HH_mm')}`);\r\n        link.style.visibility = 'hidden';\r\n        document.body.appendChild(link);\r\n        link.click();\r\n        document.body.removeChild(link);\r\n      }\r\n    } catch (e) {\r\n      console.error('BlobToSaveAs error', e);\r\n    }\r\n  }\r\n}\r\n\r\nexport interface IExportInfo {\r\n  data: any[];\r\n  sheetName?: string;\r\n  fileName?: string;\r\n}\r\n"]}
@@ -1,15 +1,15 @@
1
1
  import { __awaiter } from "tslib";
2
2
  import { Component, ViewChild, Output, EventEmitter, Input, ChangeDetectorRef } from '@angular/core';
3
- import { SdExcelService } from '@sd-angular/core/excel';
4
3
  import { SdNotifyService } from '@sd-angular/core/notify';
5
4
  import { SdLoadingService } from '@sd-angular/core/loading';
6
5
  import { SdTranslateService } from '@sd-angular/core/translate';
7
6
  import hash from 'object-hash';
7
+ import { SdExportService } from '@sd-angular/core/export';
8
8
  export class SdGridPopupExportExcel {
9
- constructor(ref, loadingService, excelService, notifyService, translateService) {
9
+ constructor(ref, loadingService, exportService, notifyService, translateService) {
10
10
  this.ref = ref;
11
11
  this.loadingService = loadingService;
12
- this.excelService = excelService;
12
+ this.exportService = exportService;
13
13
  this.notifyService = notifyService;
14
14
  this.translateService = translateService;
15
15
  this.prefix = 'Popup Export Excel';
@@ -73,7 +73,7 @@ export class SdGridPopupExportExcel {
73
73
  }
74
74
  }
75
75
  }
76
- return yield this.excelService.generateExcelTemplate({
76
+ return yield this.exportService.generateTemplate({
77
77
  fileName: fileName || this.fileName,
78
78
  columns: this.generateExcelColumns(columns),
79
79
  sheets
@@ -86,10 +86,7 @@ export class SdGridPopupExportExcel {
86
86
  });
87
87
  this.generateTemplate = () => __awaiter(this, void 0, void 0, function* () {
88
88
  this.loadingService.start();
89
- const result = yield this.initDefaultTemplate().finally(this.loadingService.stop);
90
- if (result === null || result === void 0 ? void 0 : result.filePath) {
91
- this.excelService.downloadTemplate(result.filePath, `${this.fileName}.xlsx`);
92
- }
89
+ yield this.initDefaultTemplate().finally(this.loadingService.stop);
93
90
  });
94
91
  this.generateAndUploadTemplate = (columns, fileName) => __awaiter(this, void 0, void 0, function* () {
95
92
  var _b;
@@ -114,10 +111,13 @@ export class SdGridPopupExportExcel {
114
111
  }
115
112
  }
116
113
  }
117
- return yield this.excelService.generateAndUploadExcelTemplate(this.fullKey, {
118
- fileName: fileName || this.fileName,
119
- columns: this.generateExcelColumns(columns),
120
- sheets
114
+ return yield this.exportService.generateUploadTemplate({
115
+ key: this.fullKey,
116
+ template: {
117
+ fileName: fileName || this.fileName,
118
+ columns: this.generateExcelColumns(columns),
119
+ sheets
120
+ }
121
121
  });
122
122
  });
123
123
  this.onExportByTemplate = (excelConfig) => {
@@ -130,21 +130,24 @@ export class SdGridPopupExportExcel {
130
130
  this.ref.detectChanges();
131
131
  };
132
132
  this.uploadTemplate = () => __awaiter(this, void 0, void 0, function* () {
133
- const excelConfig = yield this.excelService.uploadTemplate(this.fullKey, this.validator);
133
+ const excelConfig = yield this.exportService.uploadTemplate({
134
+ key: this.fullKey,
135
+ validator: this.validator
136
+ });
134
137
  this.excelConfigs.push({
135
- name: excelConfig.name,
136
- fullPath: excelConfig.fullPath,
138
+ name: excelConfig.fileName,
139
+ fullPath: excelConfig.filePath,
137
140
  removable: true
138
141
  });
139
142
  this.ref.detectChanges();
140
143
  });
141
144
  this.downloadTemplate = (excelConfig) => {
142
- this.excelService.downloadTemplate(excelConfig.fullPath, excelConfig.name);
145
+ this.exportService.download(excelConfig.fullPath, excelConfig.name);
143
146
  };
144
147
  this.removeTemplate = (excelConfig) => {
145
148
  this.notifyService.confirm(this.translateService.translate('Remove template')).then(() => __awaiter(this, void 0, void 0, function* () {
146
149
  this.loadingService.start();
147
- yield this.excelService.remove(this.fullKey, excelConfig.name).finally(this.loadingService.stop);
150
+ yield this.exportService.removeFile({ key: this.fullKey, fileName: excelConfig.name }).finally(this.loadingService.stop);
148
151
  const idx = this.excelConfigs.indexOf(excelConfig);
149
152
  this.excelConfigs.splice(idx, 1);
150
153
  this.ref.detectChanges();
@@ -176,13 +179,13 @@ export class SdGridPopupExportExcel {
176
179
  });
177
180
  }
178
181
  }
179
- this.exportByTemplate.emit({
180
- excelConfig: {
181
- fullPath: result.filePath,
182
- name: `[${this.fullKey}] Default.xlsx`
183
- },
184
- excelColumns
185
- });
182
+ // this.exportByTemplate.emit({
183
+ // excelConfig: {
184
+ // fullPath: result.filePath,
185
+ // name: `[${this.fullKey}] Default.xlsx`
186
+ // },
187
+ // excelColumns
188
+ // });
186
189
  this.ref.detectChanges();
187
190
  });
188
191
  this.newTemplate = () => {
@@ -271,7 +274,12 @@ export class SdGridPopupExportExcel {
271
274
  loadConfiguration() {
272
275
  return __awaiter(this, void 0, void 0, function* () {
273
276
  this.excelConfigs = [];
274
- this.excelConfigs = yield this.excelService.getFiles(this.fullKey);
277
+ const files = yield this.exportService.filesInFolder({ key: this.fullKey });
278
+ this.excelConfigs = files.map(e => ({
279
+ fullPath: e.filePath,
280
+ name: e.fileName,
281
+ removable: true
282
+ }));
275
283
  });
276
284
  }
277
285
  }
@@ -285,7 +293,7 @@ SdGridPopupExportExcel.decorators = [
285
293
  SdGridPopupExportExcel.ctorParameters = () => [
286
294
  { type: ChangeDetectorRef },
287
295
  { type: SdLoadingService },
288
- { type: SdExcelService },
296
+ { type: SdExportService },
289
297
  { type: SdNotifyService },
290
298
  { type: SdTranslateService }
291
299
  ];
@@ -299,4 +307,4 @@ SdGridPopupExportExcel.propDecorators = {
299
307
  exportOption: [{ type: Input }],
300
308
  exportByTemplate: [{ type: Output }]
301
309
  };
302
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-popup-export-excel.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, Output, EventEmitter, Input, ChangeDetectorRef } from '@angular/core';\r\nimport { SdGridColumn, GridBaseOptionExport } from '../../grid.model';\r\n\r\nimport {\r\n  SdExcelService,\r\n  ExcelConfig,\r\n  ExcelTempateColumn\r\n} from '@sd-angular/core/excel';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdLoadingService\r\n} from '@sd-angular/core/loading';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport hash from 'object-hash';\r\nimport { MatRadioChange } from '@angular/material/radio';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\n\r\n@Component({\r\n  selector: 'sd-grid-popup-export-excel',\r\n  templateUrl: './grid-popup-export-excel.component.html',\r\n  styleUrls: ['./grid-popup-export-excel.component.scss']\r\n})\r\nexport class SdGridPopupExportExcel implements OnInit, AfterViewInit {\r\n  private prefix = 'Popup Export Excel';\r\n  newExcelConfig = 'fd8fb5db-a7ad-4398-93ac-cb3350261180';\r\n  @ViewChild('modal') modal: SdModal;\r\n  @Input() key = '';\r\n  get fullKey() {\r\n    if (!this.key) {\r\n      return '';\r\n    }\r\n    return hash({\r\n      prefix: this.prefix,\r\n      key: this.key\r\n    });\r\n  }\r\n  @Input() columns: SdGridColumn[] = [];\r\n  @Input() extendColumns: SdGridColumn[] = [];\r\n  @Input() fileName: string;\r\n  @Input() validator: (fileName: string) => string;\r\n  @Input() exportOption: GridBaseOptionExport;\r\n  excelConfigs: ExcelConfig[] = [];\r\n  @Output() exportByTemplate = new EventEmitter<{ excelConfig: ExcelConfig, excelColumns: ExcelTempateColumn[] }>();\r\n  tabIndex = 0;\r\n  selectedExcelConfig: ExcelConfig = {};\r\n  exportableColumns: SdGridColumn[] = [];\r\n  selected: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private loadingService: SdLoadingService,\r\n    private excelService: SdExcelService,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n  }\r\n\r\n  async open() {\r\n    if (!this.fullKey) {\r\n      await this.exportDefault();\r\n      return;\r\n    }\r\n    await this.loadConfiguration();\r\n    this.exportableColumns = [...this.columns, ...(this.extendColumns || [])].filter(e => e.type !== 'image');\r\n    this.selected = {};\r\n    if (!this.selectedExcelConfig?.name) {\r\n      if (this.excelConfigs?.length > 0) {\r\n        this.selectedExcelConfig = this.excelConfigs[0];\r\n      } else {\r\n        this.selectedExcelConfig = {\r\n          name: this.newExcelConfig\r\n        };\r\n      }\r\n    }\r\n    this.modal.open();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  private generateExcelColumns = (columns: SdGridColumn[]) => {\r\n    const excelColumns: ExcelTempateColumn[] = [];\r\n    for (const column of columns) {\r\n      if (column.type === 'children') {\r\n        for (const childColumn of column.children) {\r\n          if (childColumn.type !== 'image') {\r\n            excelColumns.push({\r\n              field: childColumn.field,\r\n              title: childColumn.title,\r\n              description: childColumn.description,\r\n              width: childColumn.width\r\n            });\r\n          }\r\n        }\r\n      } else if (column.type !== 'image') {\r\n        excelColumns.push({\r\n          field: column.field,\r\n          title: column.title,\r\n          description: column.description,\r\n          width: column.width\r\n        });\r\n      }\r\n    }\r\n    return excelColumns;\r\n  }\r\n\r\n  private initTemplate = async (columns: SdGridColumn[], fileName?: string) => {\r\n    columns = columns || [];\r\n    const sheets: {\r\n      name: string,\r\n      items: any[],\r\n      fields: string[]\r\n    }[] = [];\r\n    if (Array.isArray(this.exportOption?.sheets)) {\r\n      for (const sheet of this.exportOption.sheets) {\r\n        if (sheet.name && sheet.items && sheet.fields) {\r\n          if (Array.isArray(sheet.items)) {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: sheet.items,\r\n              fields: sheet.fields\r\n            });\r\n          } else {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: await sheet.items(),\r\n              fields: sheet.fields\r\n            });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return await this.excelService.generateExcelTemplate({\r\n      fileName: fileName || this.fileName,\r\n      columns: this.generateExcelColumns(columns),\r\n      sheets\r\n    });\r\n  }\r\n\r\n  private initDefaultTemplate = async () => {\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    return await this.initTemplate(columns);\r\n  }\r\n\r\n  generateTemplate = async () => {\r\n    this.loadingService.start();\r\n    const result = await this.initDefaultTemplate().finally(this.loadingService.stop);\r\n    if (result?.filePath) {\r\n      this.excelService.downloadTemplate(result.filePath, `${this.fileName}.xlsx`);\r\n    }\r\n  }\r\n\r\n  generateAndUploadTemplate = async (columns: SdGridColumn[], fileName?: string) => {\r\n    const sheets: {\r\n      name: string,\r\n      items: any[],\r\n      fields: string[]\r\n    }[] = [];\r\n    if (Array.isArray(this.exportOption?.sheets)) {\r\n      for (const sheet of this.exportOption.sheets) {\r\n        if (sheet.name && sheet.items && sheet.fields) {\r\n          if (Array.isArray(sheet.items)) {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: sheet.items,\r\n              fields: sheet.fields\r\n            });\r\n          } else {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: await sheet.items(),\r\n              fields: sheet.fields\r\n            });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return await this.excelService.generateAndUploadExcelTemplate(this.fullKey, {\r\n      fileName: fileName || this.fileName,\r\n      columns: this.generateExcelColumns(columns),\r\n      sheets\r\n    });\r\n  }\r\n\r\n  onExportByTemplate = (excelConfig: ExcelConfig) => {\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    this.exportByTemplate.emit({\r\n      excelConfig,\r\n      excelColumns: this.generateExcelColumns(columns)\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  uploadTemplate = async () => {\r\n    const excelConfig = await this.excelService.uploadTemplate(this.fullKey, this.validator);\r\n    this.excelConfigs.push({\r\n      name: excelConfig.name,\r\n      fullPath: excelConfig.fullPath,\r\n      removable: true\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  downloadTemplate = (excelConfig: ExcelConfig) => {\r\n    this.excelService.downloadTemplate(excelConfig.fullPath, excelConfig.name);\r\n  }\r\n\r\n  removeTemplate = (excelConfig: ExcelConfig) => {\r\n    this.notifyService.confirm(this.translateService.translate('Remove template')).then(async () => {\r\n      this.loadingService.start();\r\n      await this.excelService.remove(this.fullKey, excelConfig.name).finally(this.loadingService.stop);\r\n      const idx = this.excelConfigs.indexOf(excelConfig);\r\n      this.excelConfigs.splice(idx, 1);\r\n      this.ref.detectChanges();\r\n    });\r\n  }\r\n\r\n  async loadConfiguration() {\r\n    this.excelConfigs = [];\r\n    this.excelConfigs = await this.excelService.getFiles(this.fullKey);\r\n  }\r\n\r\n  exportDefault = async () => {\r\n    this.loadingService.start();\r\n    const result = await this.initDefaultTemplate().finally(this.loadingService.stop);\r\n    const excelColumns: ExcelTempateColumn[] = [];\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    for (const column of columns) {\r\n      if (column.type === 'children') {\r\n        for (const childColumn of column.children) {\r\n          if (childColumn.type !== 'image') {\r\n            excelColumns.push({\r\n              field: childColumn.field,\r\n              title: childColumn.title,\r\n              width: childColumn.width\r\n            });\r\n          }\r\n        }\r\n      } else if (column.type !== 'image') {\r\n        excelColumns.push({\r\n          field: column.field,\r\n          title: column.title,\r\n          width: column.width\r\n        });\r\n      }\r\n    }\r\n    this.exportByTemplate.emit({\r\n      excelConfig: {\r\n        fullPath: result.filePath,\r\n        name: `[${this.fullKey}] Default.xlsx`\r\n      },\r\n      excelColumns\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  newTemplate = () => {\r\n    this.notifyService.confirmWithInput(this.translateService.translate('Enter your template name'), {\r\n      maxlength: 50\r\n    }).then(async (fileName: string) => {\r\n      this.loadingService.start();\r\n      fileName = fileName + '.xlsx';\r\n      try {\r\n        if (this.validator?.(fileName)) {\r\n          this.notifyService.notify.warning(this.validator(fileName));\r\n          return;\r\n        }\r\n        let exportableColumns = this.exportableColumns.filter(column => this.selected[column.field]);\r\n        if (!exportableColumns.length) {\r\n          exportableColumns = this.exportableColumns;\r\n        }\r\n        const result = await this.generateAndUploadTemplate(exportableColumns, fileName);\r\n        if (result?.filePath) {\r\n          const excelConfig: ExcelConfig = {\r\n            fullPath: result.filePath,\r\n            name: result.fileName,\r\n            removable: true\r\n          };\r\n          this.excelConfigs.push(excelConfig);\r\n          this.onExportByTemplate(excelConfig);\r\n        }\r\n      } finally {\r\n        this.loadingService.stop();\r\n      }\r\n    });\r\n  }\r\n\r\n  onChangeRadio = (matRadioChange: MatRadioChange) => {\r\n    const selectedExcelConfig = this.excelConfigs.find(e => e.name === matRadioChange.value);\r\n    if (!selectedExcelConfig) {\r\n      this.selectedExcelConfig = {\r\n        name: this.newExcelConfig\r\n      };\r\n    } else {\r\n      this.selectedExcelConfig = selectedExcelConfig;\r\n    }\r\n    this.exportableColumns = [...this.columns, ...(this.extendColumns || [])].filter(e => e.type !== 'image');\r\n    this.selected = {};\r\n  }\r\n}\r\n"]}
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-popup-export-excel.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, Output, EventEmitter, Input, ChangeDetectorRef } from '@angular/core';\r\nimport { SdGridColumn, GridBaseOptionExport } from '../../grid.model';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdLoadingService\r\n} from '@sd-angular/core/loading';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport hash from 'object-hash';\r\nimport { MatRadioChange } from '@angular/material/radio';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\nimport { SdExportService } from '@sd-angular/core/export';\r\n\r\n@Component({\r\n  selector: 'sd-grid-popup-export-excel',\r\n  templateUrl: './grid-popup-export-excel.component.html',\r\n  styleUrls: ['./grid-popup-export-excel.component.scss']\r\n})\r\nexport class SdGridPopupExportExcel implements OnInit, AfterViewInit {\r\n  private prefix = 'Popup Export Excel';\r\n  newExcelConfig = 'fd8fb5db-a7ad-4398-93ac-cb3350261180';\r\n  @ViewChild('modal') modal: SdModal;\r\n  @Input() key = '';\r\n  get fullKey() {\r\n    if (!this.key) {\r\n      return '';\r\n    }\r\n    return hash({\r\n      prefix: this.prefix,\r\n      key: this.key\r\n    });\r\n  }\r\n  @Input() columns: SdGridColumn[] = [];\r\n  @Input() extendColumns: SdGridColumn[] = [];\r\n  @Input() fileName: string;\r\n  @Input() validator: (fileName: string) => string;\r\n  @Input() exportOption: GridBaseOptionExport;\r\n  excelConfigs: any[] = [];\r\n  @Output() exportByTemplate = new EventEmitter<{ excelConfig: any, excelColumns: any[] }>();\r\n  tabIndex = 0;\r\n  selectedExcelConfig: any = {};\r\n  exportableColumns: SdGridColumn[] = [];\r\n  selected: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private loadingService: SdLoadingService,\r\n    private exportService: SdExportService,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n  }\r\n\r\n  async open() {\r\n    if (!this.fullKey) {\r\n      await this.exportDefault();\r\n      return;\r\n    }\r\n    await this.loadConfiguration();\r\n    this.exportableColumns = [...this.columns, ...(this.extendColumns || [])].filter(e => e.type !== 'image');\r\n    this.selected = {};\r\n    if (!this.selectedExcelConfig?.name) {\r\n      if (this.excelConfigs?.length > 0) {\r\n        this.selectedExcelConfig = this.excelConfigs[0];\r\n      } else {\r\n        this.selectedExcelConfig = {\r\n          name: this.newExcelConfig\r\n        };\r\n      }\r\n    }\r\n    this.modal.open();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  private generateExcelColumns = (columns: SdGridColumn[]) => {\r\n    const excelColumns: any[] = [];\r\n    for (const column of columns) {\r\n      if (column.type === 'children') {\r\n        for (const childColumn of column.children) {\r\n          if (childColumn.type !== 'image') {\r\n            excelColumns.push({\r\n              field: childColumn.field,\r\n              title: childColumn.title,\r\n              description: childColumn.description,\r\n              width: childColumn.width\r\n            });\r\n          }\r\n        }\r\n      } else if (column.type !== 'image') {\r\n        excelColumns.push({\r\n          field: column.field,\r\n          title: column.title,\r\n          description: column.description,\r\n          width: column.width\r\n        });\r\n      }\r\n    }\r\n    return excelColumns;\r\n  }\r\n\r\n  private initTemplate = async (columns: SdGridColumn[], fileName?: string) => {\r\n    columns = columns || [];\r\n    const sheets: {\r\n      name: string,\r\n      items: any[],\r\n      fields: string[]\r\n    }[] = [];\r\n    if (Array.isArray(this.exportOption?.sheets)) {\r\n      for (const sheet of this.exportOption.sheets) {\r\n        if (sheet.name && sheet.items && sheet.fields) {\r\n          if (Array.isArray(sheet.items)) {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: sheet.items,\r\n              fields: sheet.fields\r\n            });\r\n          } else {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: await sheet.items(),\r\n              fields: sheet.fields\r\n            });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return await this.exportService.generateTemplate({\r\n      fileName: fileName || this.fileName,\r\n      columns: this.generateExcelColumns(columns),\r\n      sheets\r\n    });\r\n  }\r\n\r\n  private initDefaultTemplate = async () => {\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    return await this.initTemplate(columns);\r\n  }\r\n\r\n  generateTemplate = async () => {\r\n    this.loadingService.start();\r\n    await this.initDefaultTemplate().finally(this.loadingService.stop);\r\n  }\r\n\r\n  generateAndUploadTemplate = async (columns: SdGridColumn[], fileName?: string) => {\r\n    const sheets: {\r\n      name: string,\r\n      items: any[],\r\n      fields: string[]\r\n    }[] = [];\r\n    if (Array.isArray(this.exportOption?.sheets)) {\r\n      for (const sheet of this.exportOption.sheets) {\r\n        if (sheet.name && sheet.items && sheet.fields) {\r\n          if (Array.isArray(sheet.items)) {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: sheet.items,\r\n              fields: sheet.fields\r\n            });\r\n          } else {\r\n            sheets.push({\r\n              name: sheet.name,\r\n              items: await sheet.items(),\r\n              fields: sheet.fields\r\n            });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return await this.exportService.generateUploadTemplate({\r\n      key: this.fullKey,\r\n      template: {\r\n        fileName: fileName || this.fileName,\r\n        columns: this.generateExcelColumns(columns),\r\n        sheets\r\n      }\r\n    });\r\n  }\r\n\r\n  onExportByTemplate = (excelConfig: any) => {\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    this.exportByTemplate.emit({\r\n      excelConfig,\r\n      excelColumns: this.generateExcelColumns(columns)\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  uploadTemplate = async () => {\r\n    const excelConfig = await this.exportService.uploadTemplate({\r\n      key: this.fullKey,\r\n      validator: this.validator\r\n    });\r\n    this.excelConfigs.push({\r\n      name: excelConfig.fileName,\r\n      fullPath: excelConfig.filePath,\r\n      removable: true\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  downloadTemplate = (excelConfig: any) => {\r\n    this.exportService.download(excelConfig.fullPath, excelConfig.name);\r\n  }\r\n\r\n  removeTemplate = (excelConfig: any) => {\r\n    this.notifyService.confirm(this.translateService.translate('Remove template')).then(async () => {\r\n      this.loadingService.start();\r\n      await this.exportService.removeFile({key: this.fullKey, fileName: excelConfig.name}).finally(this.loadingService.stop);\r\n      const idx = this.excelConfigs.indexOf(excelConfig);\r\n      this.excelConfigs.splice(idx, 1);\r\n      this.ref.detectChanges();\r\n    });\r\n  }\r\n\r\n  async loadConfiguration() {\r\n    this.excelConfigs = [];\r\n    const files = await this.exportService.filesInFolder({key: this.fullKey});\r\n    this.excelConfigs = files.map(e=> ({\r\n      fullPath: e.filePath,\r\n      name: e.fileName,\r\n      removable: true\r\n    }));\r\n  }\r\n\r\n  exportDefault = async () => {\r\n    this.loadingService.start();\r\n    const result = await this.initDefaultTemplate().finally(this.loadingService.stop);\r\n    const excelColumns: any[] = [];\r\n    const extendColumns = this.extendColumns || [];\r\n    const columns = [...this.columns, ...extendColumns];\r\n    for (const column of columns) {\r\n      if (column.type === 'children') {\r\n        for (const childColumn of column.children) {\r\n          if (childColumn.type !== 'image') {\r\n            excelColumns.push({\r\n              field: childColumn.field,\r\n              title: childColumn.title,\r\n              width: childColumn.width\r\n            });\r\n          }\r\n        }\r\n      } else if (column.type !== 'image') {\r\n        excelColumns.push({\r\n          field: column.field,\r\n          title: column.title,\r\n          width: column.width\r\n        });\r\n      }\r\n    }\r\n    // this.exportByTemplate.emit({\r\n    //   excelConfig: {\r\n    //     fullPath: result.filePath,\r\n    //     name: `[${this.fullKey}] Default.xlsx`\r\n    //   },\r\n    //   excelColumns\r\n    // });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  newTemplate = () => {\r\n    this.notifyService.confirmWithInput(this.translateService.translate('Enter your template name'), {\r\n      maxlength: 50\r\n    }).then(async (fileName: string) => {\r\n      this.loadingService.start();\r\n      fileName = fileName + '.xlsx';\r\n      try {\r\n        if (this.validator?.(fileName)) {\r\n          this.notifyService.notify.warning(this.validator(fileName));\r\n          return;\r\n        }\r\n        let exportableColumns = this.exportableColumns.filter(column => this.selected[column.field]);\r\n        if (!exportableColumns.length) {\r\n          exportableColumns = this.exportableColumns;\r\n        }\r\n        const result = await this.generateAndUploadTemplate(exportableColumns, fileName);\r\n        if (result?.filePath) {\r\n          const excelConfig: any = {\r\n            fullPath: result.filePath,\r\n            name: result.fileName,\r\n            removable: true\r\n          };\r\n          this.excelConfigs.push(excelConfig);\r\n          this.onExportByTemplate(excelConfig);\r\n        }\r\n      } finally {\r\n        this.loadingService.stop();\r\n      }\r\n    });\r\n  }\r\n\r\n  onChangeRadio = (matRadioChange: MatRadioChange) => {\r\n    const selectedExcelConfig = this.excelConfigs.find(e => e.name === matRadioChange.value);\r\n    if (!selectedExcelConfig) {\r\n      this.selectedExcelConfig = {\r\n        name: this.newExcelConfig\r\n      };\r\n    } else {\r\n      this.selectedExcelConfig = selectedExcelConfig;\r\n    }\r\n    this.exportableColumns = [...this.columns, ...(this.extendColumns || [])].filter(e => e.type !== 'image');\r\n    this.selected = {};\r\n  }\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwubW9kZWwuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvbmdoaWF0dDE1X29uZW1vdW50L0RvY3VtZW50cy9saWItY29yZS11aS9wcm9qZWN0cy9zZC1jb3JlL2dyaWQvIiwic291cmNlcyI6WyJzcmMvbGliL2NvbXBvbmVudHMvZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwvZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV4Y2VsQ29uZmlnIH0gZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9leGNlbCc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEV4Y2VsQ29uZmlndXJhdGlvbiB7XHJcbiAgZXhjZWxDb25maWdzOiBFeGNlbENvbmZpZ1tdO1xyXG59XHJcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwubW9kZWwuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvbmdoaWF0dDE1X29uZW1vdW50L0RvY3VtZW50cy9saWItY29yZS11aS9wcm9qZWN0cy9zZC1jb3JlL2dyaWQvIiwic291cmNlcyI6WyJzcmMvbGliL2NvbXBvbmVudHMvZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwvZ3JpZC1wb3B1cC1leHBvcnQtZXhjZWwubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRXhjZWxDb25maWd1cmF0aW9uIHtcclxuICBleGNlbENvbmZpZ3M6IGFueVtdO1xyXG59XHJcbiJdfQ==