@sd-angular/core 1.3.55 → 1.3.57
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sd-angular-core-common.umd.js +131 -0
- package/bundles/sd-angular-core-common.umd.js.map +1 -1
- package/bundles/sd-angular-core-common.umd.min.js +1 -1
- package/bundles/sd-angular-core-common.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-export.umd.js +186 -152
- package/bundles/sd-angular-core-export.umd.js.map +1 -1
- package/bundles/sd-angular-core-export.umd.min.js +1 -1
- package/bundles/sd-angular-core-export.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-pdf.umd.js +3 -22
- package/bundles/sd-angular-core-pdf.umd.js.map +1 -1
- package/bundles/sd-angular-core-pdf.umd.min.js +2 -2
- package/bundles/sd-angular-core-pdf.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-zip.umd.js +3 -21
- package/bundles/sd-angular-core-zip.umd.js.map +1 -1
- package/bundles/sd-angular-core-zip.umd.min.js +2 -2
- package/bundles/sd-angular-core-zip.umd.min.js.map +1 -1
- package/common/src/lib/typings/utility.extension.d.ts +19 -0
- package/common/src/public-api.d.ts +1 -0
- package/esm2015/common/src/lib/typings/utility.extension.js +122 -0
- package/esm2015/common/src/public-api.js +2 -1
- package/esm2015/export/src/lib/export.model.js +1 -6
- package/esm2015/export/src/lib/export.service.js +83 -67
- package/esm2015/pdf/src/lib/pdf.service.js +4 -22
- package/esm2015/zip/src/lib/zip.service.js +4 -21
- package/export/sd-angular-core-export.metadata.json +1 -1
- package/export/src/lib/export.model.d.ts +0 -5
- package/export/src/lib/export.service.d.ts +1 -11
- package/fesm2015/sd-angular-core-common.js +122 -1
- package/fesm2015/sd-angular-core-common.js.map +1 -1
- package/fesm2015/sd-angular-core-export.js +81 -69
- package/fesm2015/sd-angular-core-export.js.map +1 -1
- package/fesm2015/sd-angular-core-pdf.js +3 -21
- package/fesm2015/sd-angular-core-pdf.js.map +1 -1
- package/fesm2015/sd-angular-core-zip.js +3 -20
- package/fesm2015/sd-angular-core-zip.js.map +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-1.3.55.tgz → sd-angular-core-1.3.57.tgz} +0 -0
- package/zip/sd-angular-core-zip.metadata.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _fieldStyle, _titleStyle, _requiredStyle, _descriptionStyle, _cellStyle, _directory
|
|
1
|
+
var _fieldStyle, _titleColor, _titleFgColor, _titleStyle, _requiredStyle, _descriptionStyle, _cellStyle, _directory;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet } from "tslib";
|
|
3
3
|
import { Optional } from '@angular/core';
|
|
4
4
|
import { Injectable, Inject } from '@angular/core';
|
|
@@ -9,17 +9,14 @@ import { ExportToCsv } from 'export-to-csv';
|
|
|
9
9
|
import { Workbook } from 'exceljs';
|
|
10
10
|
import { API } from './export.model';
|
|
11
11
|
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
12
|
-
import { SdUtilityService } from '@sd-angular/core/utility';
|
|
13
12
|
import { FIREBASE_CONFIG } from '@sd-angular/core/common';
|
|
14
13
|
import * as i0 from "@angular/core";
|
|
15
14
|
import * as i1 from "@sd-angular/core/api";
|
|
16
|
-
import * as i2 from "@sd-angular/core/
|
|
17
|
-
import * as i3 from "@sd-angular/core/
|
|
18
|
-
import * as i4 from "@sd-angular/core/common";
|
|
15
|
+
import * as i2 from "@sd-angular/core/notify";
|
|
16
|
+
import * as i3 from "@sd-angular/core/common";
|
|
19
17
|
export class SdExportService {
|
|
20
|
-
constructor(apiService,
|
|
18
|
+
constructor(apiService, notifyService, firebaseConfiguration) {
|
|
21
19
|
this.apiService = apiService;
|
|
22
|
-
this.utilityService = utilityService;
|
|
23
20
|
this.notifyService = notifyService;
|
|
24
21
|
this.firebaseConfiguration = firebaseConfiguration;
|
|
25
22
|
_fieldStyle.set(this, {
|
|
@@ -46,6 +43,8 @@ export class SdExportService {
|
|
|
46
43
|
}
|
|
47
44
|
}
|
|
48
45
|
});
|
|
46
|
+
_titleColor.set(this, 'FFFFFF');
|
|
47
|
+
_titleFgColor.set(this, '143180');
|
|
49
48
|
_titleStyle.set(this, {
|
|
50
49
|
border: {
|
|
51
50
|
bottom: { style: 'thin' },
|
|
@@ -60,13 +59,13 @@ export class SdExportService {
|
|
|
60
59
|
font: {
|
|
61
60
|
bold: true,
|
|
62
61
|
size: 11,
|
|
63
|
-
color: { argb:
|
|
62
|
+
color: { argb: __classPrivateFieldGet(this, _titleColor) },
|
|
64
63
|
},
|
|
65
64
|
fill: {
|
|
66
65
|
type: 'pattern',
|
|
67
66
|
pattern: 'solid',
|
|
68
67
|
fgColor: {
|
|
69
|
-
argb:
|
|
68
|
+
argb: __classPrivateFieldGet(this, _titleFgColor),
|
|
70
69
|
}
|
|
71
70
|
}
|
|
72
71
|
});
|
|
@@ -135,40 +134,81 @@ export class SdExportService {
|
|
|
135
134
|
group
|
|
136
135
|
});
|
|
137
136
|
return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;
|
|
138
|
-
}
|
|
139
|
-
// generateTemplate = async (template: SdExportTemplate) => {
|
|
140
|
-
// const { sdGenerateTemplate } = API;
|
|
141
|
-
// const url = `${this.functionUrl}${sdGenerateTemplate}`;
|
|
142
|
-
// const buffer = await this.apiService.post(url, template, null, {
|
|
143
|
-
// responseType: 'arraybuffer'
|
|
144
|
-
// });
|
|
145
|
-
// const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });
|
|
146
|
-
// this.#blobToSaveAs(blob, template.fileName || 'Template');
|
|
147
|
-
// }
|
|
148
|
-
);
|
|
149
|
-
// generateTemplate = async (template: SdExportTemplate) => {
|
|
150
|
-
// const { sdGenerateTemplate } = API;
|
|
151
|
-
// const url = `${this.functionUrl}${sdGenerateTemplate}`;
|
|
152
|
-
// const buffer = await this.apiService.post(url, template, null, {
|
|
153
|
-
// responseType: 'arraybuffer'
|
|
154
|
-
// });
|
|
155
|
-
// const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });
|
|
156
|
-
// this.#blobToSaveAs(blob, template.fileName || 'Template');
|
|
157
|
-
// }
|
|
137
|
+
});
|
|
158
138
|
this.generateTemplate = (template) => __awaiter(this, void 0, void 0, function* () {
|
|
159
|
-
const {
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
139
|
+
const { fileName, columns, sheets } = template;
|
|
140
|
+
if (!Array.isArray(columns)) {
|
|
141
|
+
throw new Error('Excel template columns must be an array');
|
|
142
|
+
}
|
|
143
|
+
for (const [idx, column] of columns.entries()) {
|
|
144
|
+
if (!column.field) {
|
|
145
|
+
throw new Error(`Column ${idx + 1}: Field is required`);
|
|
146
|
+
}
|
|
147
|
+
if (!column.title) {
|
|
148
|
+
throw new Error(`Column ${idx + 1}: Title is required`);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
const hasDescription = columns.some(column => column.description);
|
|
152
|
+
const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download
|
|
153
|
+
const firstSheet = workbook.addWorksheet('template'); // Lấy ra sheet đầu tiên
|
|
154
|
+
columns.forEach((column, index) => {
|
|
155
|
+
var _a, _b, _c, _d, _e, _f;
|
|
156
|
+
const { required, fill, fontColor } = column;
|
|
157
|
+
const cellField = firstSheet.getCell(1, index + 1);
|
|
158
|
+
const cellTitle = firstSheet.getCell(2, index + 1);
|
|
159
|
+
const cellDescription = firstSheet.getCell(3, index + 1);
|
|
160
|
+
let width = 120;
|
|
161
|
+
if (column.width && column.width.endsWith('px')) {
|
|
162
|
+
width = +column.width.replace('px', '');
|
|
163
|
+
}
|
|
164
|
+
firstSheet.getColumn(index + 1).width = width / 7 || 20;
|
|
165
|
+
cellField.style = __classPrivateFieldGet(this, _fieldStyle);
|
|
166
|
+
if (required) {
|
|
167
|
+
cellField.style = __classPrivateFieldGet(this, _requiredStyle);
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
cellField.style = __classPrivateFieldGet(this, _fieldStyle);
|
|
171
|
+
}
|
|
172
|
+
cellTitle.style = Object.assign(Object.assign({}, __classPrivateFieldGet(this, _titleStyle)), { font: Object.assign(Object.assign({}, (_a = __classPrivateFieldGet(this, _titleStyle)) === null || _a === void 0 ? void 0 : _a.font), { color: Object.assign(Object.assign({}, (_c = (_b = __classPrivateFieldGet(this, _titleStyle)) === null || _b === void 0 ? void 0 : _b.font) === null || _c === void 0 ? void 0 : _c.color), { argb: fontColor || ((_f = (_e = (_d = __classPrivateFieldGet(this, _titleStyle)) === null || _d === void 0 ? void 0 : _d.font) === null || _e === void 0 ? void 0 : _e.color) === null || _f === void 0 ? void 0 : _f.argb) }) }), fill: {
|
|
173
|
+
type: 'pattern',
|
|
174
|
+
pattern: 'solid',
|
|
175
|
+
fgColor: {
|
|
176
|
+
argb: fill || __classPrivateFieldGet(this, _titleFgColor)
|
|
177
|
+
}
|
|
178
|
+
} });
|
|
179
|
+
cellField.value = column.field;
|
|
180
|
+
cellTitle.value = column.title;
|
|
181
|
+
if (hasDescription) {
|
|
182
|
+
cellDescription.style = __classPrivateFieldGet(this, _descriptionStyle);
|
|
183
|
+
cellDescription.value = column.description || '';
|
|
184
|
+
}
|
|
163
185
|
});
|
|
164
|
-
|
|
165
|
-
|
|
186
|
+
if (sheets === null || sheets === void 0 ? void 0 : sheets.length) {
|
|
187
|
+
for (const sheet of sheets) {
|
|
188
|
+
if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {
|
|
189
|
+
const newSheet = workbook.addWorksheet(sheet.name);
|
|
190
|
+
sheet.fields.forEach((field, index) => {
|
|
191
|
+
newSheet.getColumn(index + 1).width = 30;
|
|
192
|
+
newSheet.getCell(1, index + 1).style = __classPrivateFieldGet(this, _titleStyle);
|
|
193
|
+
newSheet.getCell(1, index + 1).value = field;
|
|
194
|
+
});
|
|
195
|
+
sheet.items.forEach((item, idx1) => {
|
|
196
|
+
sheet.fields.forEach((field, idx2) => {
|
|
197
|
+
newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];
|
|
198
|
+
newSheet.getCell(2 + idx1, 1 + idx2).style = __classPrivateFieldGet(this, _cellStyle);
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
const file = yield workbook.xlsx.writeBuffer();
|
|
205
|
+
SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);
|
|
166
206
|
});
|
|
167
207
|
this.uploadTemplate = (args) => __awaiter(this, void 0, void 0, function* () {
|
|
168
208
|
const { key, group, validator } = args;
|
|
169
209
|
const { uploadTemplate } = API;
|
|
170
210
|
const url = `${this.functionUrl}${uploadTemplate}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
|
|
171
|
-
const file = yield
|
|
211
|
+
const file = yield SdUtility.upload({
|
|
172
212
|
extensions: ['xlsx'],
|
|
173
213
|
maxSizeInMb: 0.1,
|
|
174
214
|
validator
|
|
@@ -230,7 +270,7 @@ export class SdExportService {
|
|
|
230
270
|
responseType: 'arraybuffer'
|
|
231
271
|
});
|
|
232
272
|
const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });
|
|
233
|
-
|
|
273
|
+
SdUtility.downloadBlob(blob, fileName);
|
|
234
274
|
});
|
|
235
275
|
this.exportCSV = (option) => __awaiter(this, void 0, void 0, function* () {
|
|
236
276
|
const { columns, items, fileName } = option;
|
|
@@ -312,7 +352,7 @@ export class SdExportService {
|
|
|
312
352
|
});
|
|
313
353
|
});
|
|
314
354
|
const file = yield workbook.xlsx.writeBuffer();
|
|
315
|
-
|
|
355
|
+
SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);
|
|
316
356
|
});
|
|
317
357
|
this.exportCustom = (option) => __awaiter(this, void 0, void 0, function* () {
|
|
318
358
|
const { fileName, sheets } = option;
|
|
@@ -335,7 +375,7 @@ export class SdExportService {
|
|
|
335
375
|
}
|
|
336
376
|
}
|
|
337
377
|
const file = yield workbook.xlsx.writeBuffer();
|
|
338
|
-
|
|
378
|
+
SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);
|
|
339
379
|
});
|
|
340
380
|
this.mergePDF = (urls) => __awaiter(this, void 0, void 0, function* () {
|
|
341
381
|
const { sdMergePDF } = API;
|
|
@@ -345,30 +385,7 @@ export class SdExportService {
|
|
|
345
385
|
}, null, {
|
|
346
386
|
responseType: 'arraybuffer'
|
|
347
387
|
});
|
|
348
|
-
|
|
349
|
-
__classPrivateFieldGet(this, _blobToSaveAs).call(this, blob, `${uuid.v4()}`);
|
|
350
|
-
});
|
|
351
|
-
this.loadExportedItems = (items) => __awaiter(this, void 0, void 0, function* () {
|
|
352
|
-
});
|
|
353
|
-
_blobToSaveAs.set(this, (blob, fileName = 'Export') => {
|
|
354
|
-
try {
|
|
355
|
-
const url = window.URL.createObjectURL(blob);
|
|
356
|
-
const link = document.createElement('a');
|
|
357
|
-
fileName = fileName.replace(/.xlsx/i, '');
|
|
358
|
-
fileName = fileName.replace(/.pdf/i, '');
|
|
359
|
-
if (link.download !== undefined) { // feature detection
|
|
360
|
-
link.setAttribute('href', url);
|
|
361
|
-
link.setAttribute('download', `${fileName}_${new Date().toFormat('yyyy_MM_dd_HH_mm')}`);
|
|
362
|
-
link.style.visibility = 'hidden';
|
|
363
|
-
document.body.appendChild(link);
|
|
364
|
-
link.click();
|
|
365
|
-
window.URL.revokeObjectURL(url);
|
|
366
|
-
link.remove();
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
catch (e) {
|
|
370
|
-
console.error('BlobToSaveAs error', e);
|
|
371
|
-
}
|
|
388
|
+
SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));
|
|
372
389
|
});
|
|
373
390
|
}
|
|
374
391
|
get functionUrl() {
|
|
@@ -390,8 +407,8 @@ export class SdExportService {
|
|
|
390
407
|
return folder();
|
|
391
408
|
}
|
|
392
409
|
}
|
|
393
|
-
_fieldStyle = new WeakMap(),
|
|
394
|
-
SdExportService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdExportService_Factory() { return new SdExportService(i0.ɵɵinject(i1.SdApiService), i0.ɵɵinject(i2.
|
|
410
|
+
_fieldStyle = new WeakMap(), _titleColor = new WeakMap(), _titleFgColor = new WeakMap(), _titleStyle = new WeakMap(), _requiredStyle = new WeakMap(), _descriptionStyle = new WeakMap(), _cellStyle = new WeakMap(), _directory = new WeakMap();
|
|
411
|
+
SdExportService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdExportService_Factory() { return new SdExportService(i0.ɵɵinject(i1.SdApiService), i0.ɵɵinject(i2.SdNotifyService), i0.ɵɵinject(i3.FIREBASE_CONFIG, 8)); }, token: SdExportService, providedIn: "root" });
|
|
395
412
|
SdExportService.decorators = [
|
|
396
413
|
{ type: Injectable, args: [{
|
|
397
414
|
providedIn: 'root'
|
|
@@ -399,8 +416,7 @@ SdExportService.decorators = [
|
|
|
399
416
|
];
|
|
400
417
|
SdExportService.ctorParameters = () => [
|
|
401
418
|
{ type: SdApiService },
|
|
402
|
-
{ type: SdUtilityService },
|
|
403
419
|
{ type: SdNotifyService },
|
|
404
420
|
{ type: undefined, decorators: [{ type: Inject, args: [FIREBASE_CONFIG,] }, { type: Optional }] }
|
|
405
421
|
];
|
|
406
|
-
//# 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 { Workbook, Style } from 'exceljs';\r\nimport { SdExportTemplate, IExportOption, API, SdExportFile, SdExportCustomOption } 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 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  #fieldStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      bold: true,\r\n      size: 11,\r\n      color: { argb: '000000' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'FAFAFA'\r\n      }\r\n    }\r\n  }\r\n\r\n  #titleStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      bold: true,\r\n      size: 11,\r\n      color: { argb: 'FFFFFF' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: '143180'\r\n      }\r\n    }\r\n  }\r\n\r\n  #requiredStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      italic: true,\r\n      size: 11,\r\n      color: { argb: 'FFFFFF' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'FF1744'\r\n      }\r\n    }\r\n  }\r\n\r\n  #descriptionStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      italic: true,\r\n      size: 9,\r\n      color: { argb: '000000' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'CFD8DC'\r\n      }\r\n    }\r\n  }\r\n\r\n  #cellStyle: Partial<Style> = {\r\n    alignment: {\r\n      vertical: 'middle',\r\n      wrapText: true\r\n    }\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: SdExportTemplate) => {\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  generateTemplate = async (template: SdExportTemplate) => {\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: SdExportTemplate;\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\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  export = async (option: IExportOption) => {\r\n    const { columns, items, fileName, sheets } = option;\r\n    let hasDescription = false;\r\n    for (const [idx, column] of columns.entries()) {\r\n      if (!column.field) {\r\n        throw new Error(`Column ${idx + 1}: Field is required`);\r\n      }\r\n      if (!column.title) {\r\n        throw new Error(`Column ${idx + 1}: Title is required`);\r\n      }\r\n      if (column.description) {\r\n        hasDescription = true;\r\n      }\r\n    }\r\n    const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download\r\n    const firstSheet = workbook.addWorksheet('data'); // Lấy ra sheet đầu tiên\r\n    columns.forEach((column, index) => {\r\n      let width = 120;\r\n      if (column.width && column.width.endsWith('px')) {\r\n        width = +column.width.replace('px', '');\r\n      }\r\n      firstSheet.getColumn(index + 1).width = width / 7 || 20;\r\n      firstSheet.getCell(1, index + 1).style = this.#fieldStyle\r\n      if (column.required) {\r\n        firstSheet.getCell(2, index + 1).style = this.#requiredStyle;\r\n      } else {\r\n        firstSheet.getCell(2, index + 1).style = this.#titleStyle;\r\n      }\r\n      firstSheet.getCell(1, index + 1).value = column.field;\r\n      firstSheet.getCell(2, index + 1).value = column.title;\r\n      if (hasDescription) {\r\n        firstSheet.getCell(3, index + 1).style = this.#descriptionStyle;\r\n        firstSheet.getCell(3, index + 1).value = column.description || '';\r\n      }\r\n    });\r\n    if (sheets?.length) {\r\n      for (const sheet of sheets) {\r\n        if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {\r\n          const newSheet = workbook.addWorksheet(sheet.name);\r\n          sheet.fields.forEach((field, index) => {\r\n            newSheet.getColumn(index + 1).width = 30;\r\n            newSheet.getCell(1, index + 1).style = this.#titleStyle;\r\n            newSheet.getCell(1, index + 1).value = field;\r\n          });\r\n          sheet.items.forEach((item, idx1) => {\r\n            sheet.fields.forEach((field, idx2) => {\r\n              newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];\r\n              newSheet.getCell(2 + idx1, 1 + idx2).style = this.#cellStyle;\r\n            });\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    const fromRow = hasDescription ? 4 : 3;\r\n    items.forEach((e, idx1) => {\r\n      columns.forEach((column, idx2) => {\r\n        firstSheet.getCell(fromRow + idx1, 1 + idx2).value = e[column.field];\r\n        firstSheet.getCell(fromRow + idx1, 1 + idx2).style = this.#cellStyle;\r\n      });\r\n    });\r\n    const file = await workbook.xlsx.writeBuffer();\r\n    this.#blobToSaveAs(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n  }\r\n\r\n  exportCustom = async (option: SdExportCustomOption) => {\r\n    const { fileName, sheets } = option;\r\n    if (!sheets?.length) {\r\n      this.notifyService.notify.warning('Phải có ít nhất 1 sheet');\r\n      return;\r\n    }\r\n    const workbook = new Workbook();\r\n    for (const [idx, sheet] of sheets.entries()) {\r\n      const { name, columns, cells } = sheet\r\n      const worksheet = workbook.addWorksheet(name || `Sheet ${idx + 1}`);\r\n      for (const column of (columns || [])) {\r\n        worksheet.getColumn(column.index).style = column.style;\r\n        worksheet.getColumn(column.index).width = column.width;\r\n      }\r\n      for (const cell of cells) {\r\n        const { row, column, value, style } = cell;\r\n        worksheet.getCell(row, column).style = style || worksheet.getColumn(column).style;\r\n        worksheet.getCell(row, column).value = value;\r\n      }\r\n    }\r\n    const file = await workbook.xlsx.writeBuffer();\r\n    this.#blobToSaveAs(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), 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        window.URL.revokeObjectURL(url);\r\n        link.remove();\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"]}
|
|
422
|
+
//# 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 { Workbook, Style } from 'exceljs';\r\nimport { SdExportTemplate, IExportOption, API, SdExportFile, SdExportCustomOption } from './export.model';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\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 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  #fieldStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      bold: true,\r\n      size: 11,\r\n      color: { argb: '000000' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'FAFAFA'\r\n      }\r\n    }\r\n  }\r\n  #titleColor = 'FFFFFF';\r\n  #titleFgColor = '143180';\r\n  #titleStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      bold: true,\r\n      size: 11,\r\n      color: { argb: this.#titleColor },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: this.#titleFgColor,\r\n      }\r\n    }\r\n  }\r\n\r\n  #requiredStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      vertical: 'middle',\r\n      horizontal: 'center',\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      italic: true,\r\n      size: 11,\r\n      color: { argb: 'FFFFFF' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'FF1744'\r\n      }\r\n    }\r\n  }\r\n\r\n  #descriptionStyle: Partial<Style> = {\r\n    border: {\r\n      bottom: { style: 'thin' },\r\n      left: { style: 'thin' },\r\n      right: { style: 'thin' }\r\n    },\r\n    alignment: {\r\n      wrapText: true\r\n    },\r\n    font: {\r\n      italic: true,\r\n      size: 9,\r\n      color: { argb: '000000' },\r\n    },\r\n    fill: {\r\n      type: 'pattern',\r\n      pattern: 'solid',\r\n      fgColor: {\r\n        argb: 'CFD8DC'\r\n      }\r\n    }\r\n  }\r\n\r\n  #cellStyle: Partial<Style> = {\r\n    alignment: {\r\n      vertical: 'middle',\r\n      wrapText: true\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private apiService: SdApiService,\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: SdExportTemplate) => {\r\n    const { fileName, columns, sheets } = template;\r\n    if (!Array.isArray(columns)) {\r\n      throw new Error('Excel template columns must be an array');\r\n    }\r\n    for (const [idx, column] of columns.entries()) {\r\n      if (!column.field) {\r\n        throw new Error(`Column ${idx + 1}: Field is required`);\r\n      }\r\n      if (!column.title) {\r\n        throw new Error(`Column ${idx + 1}: Title is required`);\r\n      }\r\n    }\r\n    const hasDescription = columns.some(column => column.description);\r\n    const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download\r\n    const firstSheet = workbook.addWorksheet('template'); // Lấy ra sheet đầu tiên\r\n    columns.forEach((column, index) => {\r\n      const { required, fill, fontColor } = column;\r\n      const cellField = firstSheet.getCell(1, index + 1);\r\n      const cellTitle = firstSheet.getCell(2, index + 1);\r\n      const cellDescription = firstSheet.getCell(3, index + 1);\r\n      let width = 120;\r\n      if (column.width && column.width.endsWith('px')) {\r\n        width = +column.width.replace('px', '');\r\n      }\r\n      firstSheet.getColumn(index + 1).width = width / 7 || 20;\r\n      cellField.style = this.#fieldStyle;\r\n      if(required) {\r\n        cellField.style = this.#requiredStyle;\r\n      } else {\r\n        cellField.style = this.#fieldStyle;\r\n      }\r\n      cellTitle.style = {\r\n        ...this.#titleStyle,\r\n        font: {\r\n          ...this.#titleStyle?.font,\r\n          color: {\r\n            ...this.#titleStyle?.font?.color,\r\n            argb: fontColor || this.#titleStyle?.font?.color?.argb\r\n          }\r\n        },\r\n        fill: {\r\n          type: 'pattern',\r\n          pattern: 'solid',\r\n          fgColor: {\r\n            argb:  fill || this.#titleFgColor\r\n          }\r\n        }\r\n      };\r\n      cellField.value = column.field;\r\n      cellTitle.value = column.title;\r\n      if (hasDescription) {\r\n        cellDescription.style = this.#descriptionStyle;\r\n        cellDescription.value = column.description || '';\r\n      }\r\n    });\r\n    if (sheets?.length) {\r\n      for (const sheet of sheets) {\r\n        if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {\r\n          const newSheet = workbook.addWorksheet(sheet.name);\r\n          sheet.fields.forEach((field, index) => {\r\n            newSheet.getColumn(index + 1).width = 30;\r\n            newSheet.getCell(1, index + 1).style = this.#titleStyle;\r\n            newSheet.getCell(1, index + 1).value = field;\r\n          });\r\n          sheet.items.forEach((item, idx1) => {\r\n            sheet.fields.forEach((field, idx2) => {\r\n              newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];\r\n              newSheet.getCell(2 + idx1, 1 + idx2).style = this.#cellStyle;\r\n            });\r\n          });\r\n        }\r\n      }\r\n    }\r\n    const file = await workbook.xlsx.writeBuffer();\r\n    SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\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 SdUtility.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: SdExportTemplate;\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    SdUtility.downloadBlob(blob, fileName);\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  export = async (option: IExportOption) => {\r\n    const { columns, items, fileName, sheets } = option;\r\n    let hasDescription = false;\r\n    for (const [idx, column] of columns.entries()) {\r\n      if (!column.field) {\r\n        throw new Error(`Column ${idx + 1}: Field is required`);\r\n      }\r\n      if (!column.title) {\r\n        throw new Error(`Column ${idx + 1}: Title is required`);\r\n      }\r\n      if (column.description) {\r\n        hasDescription = true;\r\n      }\r\n    }\r\n    const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download\r\n    const firstSheet = workbook.addWorksheet('data'); // Lấy ra sheet đầu tiên\r\n    columns.forEach((column, index) => {\r\n      let width = 120;\r\n      if (column.width && column.width.endsWith('px')) {\r\n        width = +column.width.replace('px', '');\r\n      }\r\n      firstSheet.getColumn(index + 1).width = width / 7 || 20;\r\n      firstSheet.getCell(1, index + 1).style = this.#fieldStyle\r\n      if (column.required) {\r\n        firstSheet.getCell(2, index + 1).style = this.#requiredStyle;\r\n      } else {\r\n        firstSheet.getCell(2, index + 1).style = this.#titleStyle;\r\n      }\r\n      firstSheet.getCell(1, index + 1).value = column.field;\r\n      firstSheet.getCell(2, index + 1).value = column.title;\r\n      if (hasDescription) {\r\n        firstSheet.getCell(3, index + 1).style = this.#descriptionStyle;\r\n        firstSheet.getCell(3, index + 1).value = column.description || '';\r\n      }\r\n    });\r\n    if (sheets?.length) {\r\n      for (const sheet of sheets) {\r\n        if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {\r\n          const newSheet = workbook.addWorksheet(sheet.name);\r\n          sheet.fields.forEach((field, index) => {\r\n            newSheet.getColumn(index + 1).width = 30;\r\n            newSheet.getCell(1, index + 1).style = this.#titleStyle;\r\n            newSheet.getCell(1, index + 1).value = field;\r\n          });\r\n          sheet.items.forEach((item, idx1) => {\r\n            sheet.fields.forEach((field, idx2) => {\r\n              newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];\r\n              newSheet.getCell(2 + idx1, 1 + idx2).style = this.#cellStyle;\r\n            });\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    const fromRow = hasDescription ? 4 : 3;\r\n    items.forEach((e, idx1) => {\r\n      columns.forEach((column, idx2) => {\r\n        firstSheet.getCell(fromRow + idx1, 1 + idx2).value = e[column.field];\r\n        firstSheet.getCell(fromRow + idx1, 1 + idx2).style = this.#cellStyle;\r\n      });\r\n    });\r\n    const file = await workbook.xlsx.writeBuffer();\r\n    SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n  }\r\n\r\n  exportCustom = async (option: SdExportCustomOption) => {\r\n    const { fileName, sheets } = option;\r\n    if (!sheets?.length) {\r\n      this.notifyService.notify.warning('Phải có ít nhất 1 sheet');\r\n      return;\r\n    }\r\n    const workbook = new Workbook();\r\n    for (const [idx, sheet] of sheets.entries()) {\r\n      const { name, columns, cells } = sheet\r\n      const worksheet = workbook.addWorksheet(name || `Sheet ${idx + 1}`);\r\n      for (const column of (columns || [])) {\r\n        worksheet.getColumn(column.index).style = column.style;\r\n        worksheet.getColumn(column.index).width = column.width;\r\n      }\r\n      for (const cell of cells) {\r\n        const { row, column, value, style } = cell;\r\n        worksheet.getCell(row, column).style = style || worksheet.getColumn(column).style;\r\n        worksheet.getCell(row, column).value = value;\r\n      }\r\n    }\r\n    const file = await workbook.xlsx.writeBuffer();\r\n    SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), 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    SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));\r\n  }\r\n}"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _API
|
|
1
|
+
var _API;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet } from "tslib";
|
|
3
3
|
import { Optional } from '@angular/core';
|
|
4
4
|
import { Injectable, Inject } from '@angular/core';
|
|
@@ -22,29 +22,11 @@ export class SdPdfService {
|
|
|
22
22
|
responseType: 'arraybuffer'
|
|
23
23
|
});
|
|
24
24
|
const blob = new Blob([buffer], { type: 'application/pdf' });
|
|
25
|
-
|
|
26
|
-
});
|
|
27
|
-
_blobToSaveAs.set(this, (blob, fileName = 'Export') => {
|
|
28
|
-
try {
|
|
29
|
-
const url = window.URL.createObjectURL(blob);
|
|
30
|
-
const link = document.createElement('a');
|
|
31
|
-
fileName = fileName.replace(/.pdf/i, '');
|
|
32
|
-
if (link.download !== undefined) { // feature detection
|
|
33
|
-
link.setAttribute('href', url);
|
|
34
|
-
link.setAttribute('download', `${fileName}_${new Date().toFormat('yyyy_MM_dd_HH_mm')}`);
|
|
35
|
-
link.style.visibility = 'hidden';
|
|
36
|
-
document.body.appendChild(link);
|
|
37
|
-
link.click();
|
|
38
|
-
document.body.removeChild(link);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
catch (e) {
|
|
42
|
-
console.error('BlobToSaveAs error', e);
|
|
43
|
-
}
|
|
25
|
+
SdUtility.downloadBlob(blob, uuid.v4());
|
|
44
26
|
});
|
|
45
27
|
}
|
|
46
28
|
}
|
|
47
|
-
_API = new WeakMap()
|
|
29
|
+
_API = new WeakMap();
|
|
48
30
|
SdPdfService.decorators = [
|
|
49
31
|
{ type: Injectable }
|
|
50
32
|
];
|
|
@@ -52,4 +34,4 @@ SdPdfService.ctorParameters = () => [
|
|
|
52
34
|
{ type: SdApiService },
|
|
53
35
|
{ type: undefined, decorators: [{ type: Inject, args: [FIREBASE_CONFIG,] }, { type: Optional }] }
|
|
54
36
|
];
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRmLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvbmdoaWF0dDE1X29uZW1vdW50L0RvY3VtZW50cy9saWItY29yZS11aS9wcm9qZWN0cy9zZC1jb3JlL3BkZi8iLCJzb3VyY2VzIjpbInNyYy9saWIvcGRmLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNwRCxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUUsZUFBZSxFQUEwQixNQUFNLHlCQUF5QixDQUFDO0FBR2xGLE1BQU0sT0FBTyxZQUFZO0lBSXZCLFlBQ1UsVUFBd0IsRUFDYSxhQUFxQztRQUQxRSxlQUFVLEdBQVYsVUFBVSxDQUFjO1FBQ2Esa0JBQWEsR0FBYixhQUFhLENBQXdCO1FBTHBGLGVBQU87WUFDTCxPQUFPLEVBQUUsZUFBZTtTQUN6QixFQUFDO1FBTUYsVUFBSyxHQUFHLENBQU8sSUFBYyxFQUFFLEVBQUU7WUFDL0IsTUFBTSxFQUFFLFdBQVcsRUFBRSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7WUFDM0MsTUFBTSxFQUFFLE9BQU8sRUFBRSxxQ0FBWSxDQUFDO1lBQzlCLE1BQU0sR0FBRyxHQUFHLEdBQUcsV0FBVyxHQUFHLE9BQU8sRUFBRSxDQUFDO1lBQ3ZDLE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO2dCQUM3QyxJQUFJO2FBQ0wsRUFBRSxJQUFJLEVBQUU7Z0JBQ1AsWUFBWSxFQUFFLGFBQWE7YUFDNUIsQ0FBQyxDQUFDO1lBQ0gsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSxDQUFDLENBQUM7WUFDN0QsU0FBUyxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDMUMsQ0FBQyxDQUFBLENBQUE7SUFiRCxDQUFDOzs7O1lBUkYsVUFBVTs7O1lBSkYsWUFBWTs0Q0FXaEIsTUFBTSxTQUFDLGVBQWUsY0FBRyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkQXBpU2VydmljZSB9IGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYXBpJztcclxuaW1wb3J0ICogYXMgdXVpZCBmcm9tICd1dWlkJztcclxuaW1wb3J0IHsgRklSRUJBU0VfQ09ORklHLCBJRmlyZWJhc2VDb25maWd1cmF0aW9uIH0gZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9jb21tb24nO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU2RQZGZTZXJ2aWNlIHtcclxuICAjQVBJID0ge1xyXG4gICAgc2RNZXJnZTogJy9wZGYvc2QtbWVyZ2UnLFxyXG4gIH07XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGFwaVNlcnZpY2U6IFNkQXBpU2VydmljZSxcclxuICAgIEBJbmplY3QoRklSRUJBU0VfQ09ORklHKSBAT3B0aW9uYWwoKSBwcml2YXRlIGNvbmZpZ3VyYXRpb246IElGaXJlYmFzZUNvbmZpZ3VyYXRpb24pIHtcclxuICB9XHJcblxyXG4gIG1lcmdlID0gYXN5bmMgKHVybHM6IHN0cmluZ1tdKSA9PiB7XHJcbiAgICBjb25zdCB7IGZ1bmN0aW9uVXJsIH0gPSB0aGlzLmNvbmZpZ3VyYXRpb247XHJcbiAgICBjb25zdCB7IHNkTWVyZ2UgfSA9IHRoaXMuI0FQSTtcclxuICAgIGNvbnN0IHVybCA9IGAke2Z1bmN0aW9uVXJsfSR7c2RNZXJnZX1gO1xyXG4gICAgY29uc3QgYnVmZmVyID0gYXdhaXQgdGhpcy5hcGlTZXJ2aWNlLnBvc3QodXJsLCB7XHJcbiAgICAgIHVybHNcclxuICAgIH0sIG51bGwsIHtcclxuICAgICAgcmVzcG9uc2VUeXBlOiAnYXJyYXlidWZmZXInXHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGJsb2IgPSBuZXcgQmxvYihbYnVmZmVyXSwgeyB0eXBlOiAnYXBwbGljYXRpb24vcGRmJyB9KTtcclxuICAgIFNkVXRpbGl0eS5kb3dubG9hZEJsb2IoYmxvYiwgdXVpZC52NCgpKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUV4cG9ydEluZm8ge1xyXG4gIGRhdGE6IGFueVtdO1xyXG4gIHNoZWV0TmFtZT86IHN0cmluZztcclxuICBmaWxlTmFtZT86IHN0cmluZztcclxufVxyXG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _download
|
|
1
|
+
var _download;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet } from "tslib";
|
|
3
3
|
import { Injectable } from '@angular/core';
|
|
4
4
|
import JSZip from 'jszip';
|
|
@@ -13,30 +13,13 @@ export class SdZipService {
|
|
|
13
13
|
});
|
|
14
14
|
_download.set(this, (zip, fileName) => __awaiter(this, void 0, void 0, function* () {
|
|
15
15
|
const blob = yield zip.generateAsync({ type: 'blob' });
|
|
16
|
-
|
|
16
|
+
SdUtility.downloadBlob(blob, fileName || 'sd-zip');
|
|
17
17
|
}));
|
|
18
|
-
_blobToSaveAs.set(this, (blob, fileName = 'sd-zip') => {
|
|
19
|
-
try {
|
|
20
|
-
const url = window.URL.createObjectURL(blob);
|
|
21
|
-
const link = document.createElement('a');
|
|
22
|
-
if (link.download !== undefined) { // feature detection
|
|
23
|
-
link.setAttribute('href', url);
|
|
24
|
-
link.setAttribute('download', `${fileName}_${new Date().toFormat('yyyy_MM_dd_HH_mm')}`);
|
|
25
|
-
link.style.visibility = 'hidden';
|
|
26
|
-
document.body.appendChild(link);
|
|
27
|
-
link.click();
|
|
28
|
-
document.body.removeChild(link);
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
catch (e) {
|
|
32
|
-
console.error('BlobToSaveAs error', e);
|
|
33
|
-
}
|
|
34
|
-
});
|
|
35
18
|
}
|
|
36
19
|
}
|
|
37
|
-
_download = new WeakMap()
|
|
20
|
+
_download = new WeakMap();
|
|
38
21
|
SdZipService.decorators = [
|
|
39
22
|
{ type: Injectable }
|
|
40
23
|
];
|
|
41
24
|
SdZipService.ctorParameters = () => [];
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemlwLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvbmdoaWF0dDE1X29uZW1vdW50L0RvY3VtZW50cy9saWItY29yZS11aS9wcm9qZWN0cy9zZC1jb3JlL3ppcC8iLCJzb3VyY2VzIjpbInNyYy9saWIvemlwLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUUxQixNQUFNLE9BQU8sWUFBWTtJQUN2QjtRQUdBLFFBQUcsR0FBRyxDQUFPLElBQXlDLEVBQUUsUUFBaUIsRUFBRSxFQUFFO1lBQzNFLE1BQU0sS0FBSyxHQUFHLElBQUksS0FBSyxFQUFFLENBQUM7WUFDMUIsS0FBSyxNQUFNLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRTtnQkFDdkMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxJQUFJLFFBQVEsR0FBRyxHQUFHLENBQUMsRUFBRSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUN6RDtZQUNELE1BQU0sNkNBQUEsSUFBSSxFQUFXLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztRQUN4QyxDQUFDLENBQUEsQ0FBQTtRQUVELG9CQUFZLENBQU8sR0FBVSxFQUFFLFFBQWlCLEVBQUUsRUFBRTtZQUNsRCxNQUFNLElBQUksR0FBRyxNQUFNLEdBQUcsQ0FBQyxhQUFhLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztZQUN2RCxTQUFTLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxRQUFRLElBQUksUUFBUSxDQUFDLENBQUM7UUFDckQsQ0FBQyxDQUFBLEVBQUE7SUFiRCxDQUFDOzs7O1lBSEYsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IEpTWmlwIGZyb20gJ2pzemlwJztcclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU2RaaXBTZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICB9XHJcblxyXG4gIHppcCA9IGFzeW5jIChhcmdzOiB7IGZpbGVOYW1lPzogc3RyaW5nLCBibG9iOiBCbG9iIH1bXSwgZmlsZU5hbWU/OiBzdHJpbmcpID0+IHtcclxuICAgIGNvbnN0IGpzemlwID0gbmV3IEpTWmlwKCk7XHJcbiAgICBmb3IgKGNvbnN0IFtpZHgsIGFyZ10gb2YgYXJncy5lbnRyaWVzKCkpIHtcclxuICAgICAganN6aXAuZmlsZShhcmcuZmlsZU5hbWUgfHwgYEZpbGUgJHtpZHggKyAxfWAsIGFyZy5ibG9iKTtcclxuICAgIH1cclxuICAgIGF3YWl0IHRoaXMuI2Rvd25sb2FkKGpzemlwLCBmaWxlTmFtZSk7XHJcbiAgfVxyXG5cclxuICAjZG93bmxvYWQgPSBhc3luYyAoemlwOiBKU1ppcCwgZmlsZU5hbWU/OiBzdHJpbmcpID0+IHtcclxuICAgIGNvbnN0IGJsb2IgPSBhd2FpdCB6aXAuZ2VuZXJhdGVBc3luYyh7IHR5cGU6ICdibG9iJyB9KTtcclxuICAgIFNkVXRpbGl0eS5kb3dubG9hZEJsb2IoYmxvYiwgZmlsZU5hbWUgfHwgJ3NkLXppcCcpO1xyXG4gIH1cclxufSJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"__symbolic":"module","version":4,"metadata":{"SdExportTemplate":{"__symbolic":"interface"},"SdExportTempateColumn":{"__symbolic":"interface"},"SdExportFile":{"__symbolic":"interface"},"SdExportColumn":{"__symbolic":"interface"},"IExportOption":{"__symbolic":"interface"},"IBigExportRequest":{"__symbolic":"interface"},"IBigExportResponse":{"__symbolic":"interface"},"GroupPermission":{"__symbolic":"interface"},"API":{"
|
|
1
|
+
{"__symbolic":"module","version":4,"metadata":{"SdExportTemplate":{"__symbolic":"interface"},"SdExportTempateColumn":{"__symbolic":"interface"},"SdExportFile":{"__symbolic":"interface"},"SdExportColumn":{"__symbolic":"interface"},"IExportOption":{"__symbolic":"interface"},"IBigExportRequest":{"__symbolic":"interface"},"IBigExportResponse":{"__symbolic":"interface"},"GroupPermission":{"__symbolic":"interface"},"API":{"uploadTemplate":"/excel/uploadTemplate","generateUploadTemplate":"/excel/generateUploadTemplate","filesInFolder":"/excel/filesInFolder","removeFile":"/excel/remove","sdExportByTemplate":"/excel/sd-export-by-template","sdMergePDF":"/excel/sd-merge-pdf"},"SdCellValue":{"__symbolic":"interface"},"SdExcelColor":{"__symbolic":"interface"},"SdExcelFont":{"__symbolic":"interface"},"SdExcelAlignment":{"__symbolic":"interface"},"SdExcelBorderStyle":{"__symbolic":"interface"},"SdExcelBorder":{"__symbolic":"interface"},"SdExcelBorders":{"__symbolic":"interface"},"SdExcelFillPatterns":{"__symbolic":"interface"},"SdExcelFillPattern":{"__symbolic":"interface"},"SdExcelFill":{"__symbolic":"interface"},"SdStyle":{"__symbolic":"interface"},"SdCell":{"__symbolic":"interface"},"SdSheet":{"__symbolic":"interface"},"SdExportCustomOption":{"__symbolic":"interface"},"SdExportService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":11,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":144,"character":5},"arguments":[{"__symbolic":"reference","module":"@sd-angular/core/common","name":"FIREBASE_CONFIG","line":144,"character":12}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":144,"character":30}}]],"parameters":[{"__symbolic":"reference","module":"@sd-angular/core/api","name":"SdApiService","line":142,"character":24},{"__symbolic":"reference","module":"@sd-angular/core/notify","name":"SdNotifyService","line":143,"character":27},{"__symbolic":"reference","module":"@sd-angular/core/common","name":"IFirebaseConfiguration","line":144,"character":72}]}]},"statics":{"ɵprov":{}}}},"origins":{"SdExportTemplate":"./src/lib/export.model","SdExportTempateColumn":"./src/lib/export.model","SdExportFile":"./src/lib/export.model","SdExportColumn":"./src/lib/export.model","IExportOption":"./src/lib/export.model","IBigExportRequest":"./src/lib/export.model","IBigExportResponse":"./src/lib/export.model","GroupPermission":"./src/lib/export.model","API":"./src/lib/export.model","SdCellValue":"./src/lib/excel.model","SdExcelColor":"./src/lib/excel.model","SdExcelFont":"./src/lib/excel.model","SdExcelAlignment":"./src/lib/excel.model","SdExcelBorderStyle":"./src/lib/excel.model","SdExcelBorder":"./src/lib/excel.model","SdExcelBorders":"./src/lib/excel.model","SdExcelFillPatterns":"./src/lib/excel.model","SdExcelFillPattern":"./src/lib/excel.model","SdExcelFill":"./src/lib/excel.model","SdStyle":"./src/lib/excel.model","SdCell":"./src/lib/excel.model","SdSheet":"./src/lib/excel.model","SdExportCustomOption":"./src/lib/excel.model","SdExportService":"./src/lib/export.service"},"importAs":"@sd-angular/core/export"}
|
|
@@ -57,15 +57,10 @@ export interface IBigExportResponse {
|
|
|
57
57
|
}
|
|
58
58
|
export declare type GroupPermission = 'view' | 'add' | 'delete';
|
|
59
59
|
export declare const API: {
|
|
60
|
-
generateTemplate: string;
|
|
61
60
|
uploadTemplate: string;
|
|
62
61
|
generateUploadTemplate: string;
|
|
63
|
-
export: string;
|
|
64
|
-
downloadByTemplate: string;
|
|
65
62
|
filesInFolder: string;
|
|
66
63
|
removeFile: string;
|
|
67
|
-
sdExport: string;
|
|
68
64
|
sdExportByTemplate: string;
|
|
69
65
|
sdMergePDF: string;
|
|
70
|
-
sdGenerateTemplate: string;
|
|
71
66
|
};
|
|
@@ -1,18 +1,16 @@
|
|
|
1
1
|
import { SdApiService } from '@sd-angular/core/api';
|
|
2
2
|
import { SdExportTemplate, IExportOption, SdExportFile, SdExportCustomOption } from './export.model';
|
|
3
3
|
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
4
|
-
import { SdUtilityService } from '@sd-angular/core/utility';
|
|
5
4
|
import { IFirebaseConfiguration } from '@sd-angular/core/common';
|
|
6
5
|
export declare class SdExportService {
|
|
7
6
|
#private;
|
|
8
7
|
private apiService;
|
|
9
|
-
private utilityService;
|
|
10
8
|
private notifyService;
|
|
11
9
|
private firebaseConfiguration;
|
|
12
10
|
private get functionUrl();
|
|
13
11
|
private get folder();
|
|
14
12
|
private get userFolder();
|
|
15
|
-
constructor(apiService: SdApiService,
|
|
13
|
+
constructor(apiService: SdApiService, notifyService: SdNotifyService, firebaseConfiguration: IFirebaseConfiguration);
|
|
16
14
|
generateTemplate: (template: SdExportTemplate) => Promise<void>;
|
|
17
15
|
uploadTemplate: (args: {
|
|
18
16
|
key: string;
|
|
@@ -47,12 +45,4 @@ export declare class SdExportService {
|
|
|
47
45
|
export: (option: IExportOption) => Promise<void>;
|
|
48
46
|
exportCustom: (option: SdExportCustomOption) => Promise<void>;
|
|
49
47
|
mergePDF: (urls: string[]) => Promise<void>;
|
|
50
|
-
loadExportedItems: (items: (pageSize: number, pageNumber: number) => {
|
|
51
|
-
total: number;
|
|
52
|
-
}) => Promise<void>;
|
|
53
|
-
}
|
|
54
|
-
export interface IExportInfo {
|
|
55
|
-
data: any[];
|
|
56
|
-
sheetName?: string;
|
|
57
|
-
fileName?: string;
|
|
58
48
|
}
|