@sd-angular/core 1.3.239 → 1.3.240

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 (26) hide show
  1. package/bundles/sd-angular-core-export.umd.js +95 -88
  2. package/bundles/sd-angular-core-export.umd.js.map +1 -1
  3. package/bundles/sd-angular-core-export.umd.min.js +1 -1
  4. package/bundles/sd-angular-core-export.umd.min.js.map +1 -1
  5. package/bundles/sd-angular-core-table.umd.js +513 -89
  6. package/bundles/sd-angular-core-table.umd.js.map +1 -1
  7. package/bundles/sd-angular-core-table.umd.min.js +2 -2
  8. package/bundles/sd-angular-core-table.umd.min.js.map +1 -1
  9. package/esm2015/export/src/lib/export.service.js +93 -90
  10. package/esm2015/table/sd-angular-core-table.js +19 -18
  11. package/esm2015/table/src/lib/components/popup-export/popup-export.component.js +289 -0
  12. package/esm2015/table/src/lib/models/table-option-export.model.js +1 -1
  13. package/esm2015/table/src/lib/table.component.js +32 -16
  14. package/esm2015/table/src/lib/table.module.js +5 -1
  15. package/export/src/lib/export.service.d.ts +4 -0
  16. package/fesm2015/sd-angular-core-export.js +92 -89
  17. package/fesm2015/sd-angular-core-export.js.map +1 -1
  18. package/fesm2015/sd-angular-core-table.js +318 -17
  19. package/fesm2015/sd-angular-core-table.js.map +1 -1
  20. package/package.json +1 -1
  21. package/{sd-angular-core-1.3.239.tgz → sd-angular-core-1.3.240.tgz} +0 -0
  22. package/table/sd-angular-core-table.d.ts +18 -17
  23. package/table/sd-angular-core-table.metadata.json +1 -1
  24. package/table/src/lib/components/popup-export/popup-export.component.d.ts +56 -0
  25. package/table/src/lib/models/table-option-export.model.d.ts +7 -6
  26. package/table/src/lib/table.component.d.ts +8 -1
@@ -23,12 +23,12 @@ export class SdExportService {
23
23
  border: {
24
24
  bottom: { style: 'thin' },
25
25
  left: { style: 'thin' },
26
- right: { style: 'thin' }
26
+ right: { style: 'thin' },
27
27
  },
28
28
  alignment: {
29
29
  vertical: 'middle',
30
30
  horizontal: 'center',
31
- wrapText: true
31
+ wrapText: true,
32
32
  },
33
33
  font: {
34
34
  bold: true,
@@ -39,9 +39,9 @@ export class SdExportService {
39
39
  type: 'pattern',
40
40
  pattern: 'solid',
41
41
  fgColor: {
42
- argb: 'FAFAFA'
43
- }
44
- }
42
+ argb: 'FAFAFA',
43
+ },
44
+ },
45
45
  });
46
46
  _titleColor.set(this, 'FFFFFF');
47
47
  _titleFgColor.set(this, '143180');
@@ -49,12 +49,12 @@ export class SdExportService {
49
49
  border: {
50
50
  bottom: { style: 'thin' },
51
51
  left: { style: 'thin' },
52
- right: { style: 'thin' }
52
+ right: { style: 'thin' },
53
53
  },
54
54
  alignment: {
55
55
  vertical: 'middle',
56
56
  horizontal: 'center',
57
- wrapText: true
57
+ wrapText: true,
58
58
  },
59
59
  font: {
60
60
  bold: true,
@@ -66,19 +66,19 @@ export class SdExportService {
66
66
  pattern: 'solid',
67
67
  fgColor: {
68
68
  argb: __classPrivateFieldGet(this, _titleFgColor),
69
- }
70
- }
69
+ },
70
+ },
71
71
  });
72
72
  _requiredStyle.set(this, {
73
73
  border: {
74
74
  bottom: { style: 'thin' },
75
75
  left: { style: 'thin' },
76
- right: { style: 'thin' }
76
+ right: { style: 'thin' },
77
77
  },
78
78
  alignment: {
79
79
  vertical: 'middle',
80
80
  horizontal: 'center',
81
- wrapText: true
81
+ wrapText: true,
82
82
  },
83
83
  font: {
84
84
  italic: true,
@@ -89,18 +89,18 @@ export class SdExportService {
89
89
  type: 'pattern',
90
90
  pattern: 'solid',
91
91
  fgColor: {
92
- argb: 'FF1744'
93
- }
94
- }
92
+ argb: 'FF1744',
93
+ },
94
+ },
95
95
  });
96
96
  _descriptionStyle.set(this, {
97
97
  border: {
98
98
  bottom: { style: 'thin' },
99
99
  left: { style: 'thin' },
100
- right: { style: 'thin' }
100
+ right: { style: 'thin' },
101
101
  },
102
102
  alignment: {
103
- wrapText: true
103
+ wrapText: true,
104
104
  },
105
105
  font: {
106
106
  italic: true,
@@ -111,27 +111,27 @@ export class SdExportService {
111
111
  type: 'pattern',
112
112
  pattern: 'solid',
113
113
  fgColor: {
114
- argb: 'CFD8DC'
115
- }
116
- }
114
+ argb: 'CFD8DC',
115
+ },
116
+ },
117
117
  });
118
118
  _cellStyle.set(this, {
119
119
  alignment: {
120
120
  vertical: 'middle',
121
- wrapText: true
122
- }
121
+ wrapText: true,
122
+ },
123
123
  });
124
124
  _directory.set(this, (key, group) => {
125
125
  let hashedFolder = hash({
126
126
  folder: this.folder,
127
- userFolder: this.userFolder
127
+ userFolder: this.userFolder,
128
128
  });
129
129
  if (!group) {
130
130
  return `dir1=${this.folder}&dir2=U-${hashedFolder}&dir3=${key || ''}`;
131
131
  }
132
132
  hashedFolder = hash({
133
133
  folder: this.folder,
134
- group
134
+ group,
135
135
  });
136
136
  return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;
137
137
  });
@@ -173,8 +173,8 @@ export class SdExportService {
173
173
  type: 'pattern',
174
174
  pattern: 'solid',
175
175
  fgColor: {
176
- argb: fill || __classPrivateFieldGet(this, _titleFgColor)
177
- }
176
+ argb: fill || __classPrivateFieldGet(this, _titleFgColor),
177
+ },
178
178
  } });
179
179
  cellField.value = column.field;
180
180
  cellTitle.value = column.title;
@@ -211,7 +211,7 @@ export class SdExportService {
211
211
  const file = yield SdUtility.upload({
212
212
  extensions: ['xlsx'],
213
213
  maxSizeInMb: 0.1,
214
- validator
214
+ validator,
215
215
  });
216
216
  if (file) {
217
217
  const { filePath, fileName } = yield this.apiService.upload(url, file).catch((err) => {
@@ -244,10 +244,10 @@ export class SdExportService {
244
244
  const { filesInFolder } = API;
245
245
  const url = `${this.functionUrl}${filesInFolder}?${__classPrivateFieldGet(this, _directory).call(this, key, group)}`;
246
246
  const res = yield this.apiService.get(url);
247
- return ((_a = res.files) === null || _a === void 0 ? void 0 : _a.map(e => ({
247
+ return (((_a = res.files) === null || _a === void 0 ? void 0 : _a.map(e => ({
248
248
  filePath: e.publicUrl,
249
- fileName: e.name
250
- }))) || [];
249
+ fileName: e.name,
250
+ }))) || []);
251
251
  });
252
252
  this.download = (filePath, fileName) => {
253
253
  const link = document.createElement('a');
@@ -265,9 +265,9 @@ export class SdExportService {
265
265
  filePath,
266
266
  columns,
267
267
  items,
268
- fileName
268
+ fileName,
269
269
  }, null, {
270
- responseType: 'arraybuffer'
270
+ responseType: 'arraybuffer',
271
271
  });
272
272
  const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });
273
273
  SdUtility.downloadBlob(blob, fileName);
@@ -347,7 +347,7 @@ export class SdExportService {
347
347
  const fromRow = hasDescription ? 4 : 3;
348
348
  items.forEach((e, idx1) => {
349
349
  columns.forEach((column, idx2) => {
350
- if (typeof (e[column.field]) === 'number') {
350
+ if (typeof e[column.field] === 'number') {
351
351
  firstSheet.getCell(fromRow + idx1, 1 + idx2).value = +e[column.field];
352
352
  firstSheet.getCell(fromRow + idx1, 1 + idx2).numFmt = '#';
353
353
  }
@@ -370,7 +370,7 @@ export class SdExportService {
370
370
  for (const [idx, sheet] of sheets.entries()) {
371
371
  const { name, columns, cells } = sheet;
372
372
  const worksheet = workbook.addWorksheet(name || `Sheet ${idx + 1}`);
373
- for (const column of (columns || [])) {
373
+ for (const column of columns || []) {
374
374
  worksheet.getColumn(column.index).style = column.style;
375
375
  worksheet.getColumn(column.index).width = column.width;
376
376
  }
@@ -387,9 +387,9 @@ export class SdExportService {
387
387
  const { sdMergePDF } = API;
388
388
  const url = `${this.functionUrl}${sdMergePDF}`;
389
389
  const buffer = yield this.apiService.post(url, {
390
- urls
390
+ urls,
391
391
  }, null, {
392
- responseType: 'arraybuffer'
392
+ responseType: 'arraybuffer',
393
393
  });
394
394
  SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));
395
395
  });
@@ -398,62 +398,65 @@ export class SdExportService {
398
398
  extensions: ['xlsx'],
399
399
  maxSizeInMb: 10,
400
400
  }).then(file => {
401
- if (file) {
402
- return new Promise((resolve, reject) => {
403
- const wb = new Workbook();
404
- const reader = new FileReader();
405
- reader.onload = () => {
406
- const buffer = reader.result;
407
- if (!buffer) {
408
- reject('Có lỗi xảy ra khi đọc file');
401
+ return this.parseXlsx(file);
402
+ });
403
+ });
404
+ this.parseXlsx = (file) => __awaiter(this, void 0, void 0, function* () {
405
+ if (file) {
406
+ return new Promise((resolve, reject) => {
407
+ const wb = new Workbook();
408
+ const reader = new FileReader();
409
+ reader.onload = () => {
410
+ const buffer = reader.result;
411
+ if (!buffer) {
412
+ reject('Có lỗi xảy ra khi đọc file');
413
+ return;
414
+ }
415
+ wb.xlsx.load(buffer).then(workbook => {
416
+ const sheet = workbook.worksheets[0];
417
+ if (!sheet) {
418
+ reject('Không tìm thấy dữ liệu');
409
419
  return;
410
420
  }
411
- wb.xlsx.load(buffer).then(workbook => {
412
- const sheet = workbook.worksheets[0];
413
- if (!sheet) {
414
- reject('Không tìm thấy dữ liệu import');
415
- return;
416
- }
417
- const items = [];
418
- const headers = sheet.getRow(1).values;
419
- if (Array.isArray(headers)) {
420
- sheet.eachRow((row, rowIndex) => {
421
- const { hasValues, values, } = row;
422
- // console.log(row, hasValues, values)
423
- if (hasValues && rowIndex > 1) {
424
- const item = {};
425
- headers.forEach((cellValue, index) => {
426
- if (cellValue) {
427
- const field = cellValue.toString();
428
- item[field] = values[index];
429
- if (typeof (item[field]) === 'string') {
430
- item[field] = item[field].trim();
431
- }
432
- if (item[field] === '' || item[field] === undefined) {
433
- item[field] = null;
434
- }
421
+ const items = [];
422
+ const headers = sheet.getRow(1).values;
423
+ if (Array.isArray(headers)) {
424
+ sheet.eachRow((row, rowIndex) => {
425
+ const { hasValues, values } = row;
426
+ // console.log(row, hasValues, values)
427
+ if (hasValues && rowIndex > 1) {
428
+ const item = {};
429
+ headers.forEach((cellValue, index) => {
430
+ if (cellValue) {
431
+ const field = cellValue.toString();
432
+ item[field] = values[index];
433
+ if (typeof item[field] === 'string') {
434
+ item[field] = item[field].trim();
435
435
  }
436
- });
437
- items.push(item);
438
- }
439
- });
440
- resolve({
441
- items,
442
- file
443
- });
444
- }
445
- });
446
- };
447
- reader.readAsArrayBuffer(file);
448
- });
449
- }
450
- else {
451
- return {
452
- items: [],
453
- file: null
436
+ if (item[field] === '' || item[field] === undefined) {
437
+ item[field] = null;
438
+ }
439
+ }
440
+ });
441
+ items.push(item);
442
+ }
443
+ });
444
+ resolve({
445
+ items,
446
+ file,
447
+ });
448
+ }
449
+ });
454
450
  };
455
- }
456
- });
451
+ reader.readAsArrayBuffer(file);
452
+ });
453
+ }
454
+ else {
455
+ return {
456
+ items: [],
457
+ file: null,
458
+ };
459
+ }
457
460
  });
458
461
  }
459
462
  get functionUrl() {
@@ -469,7 +472,7 @@ export class SdExportService {
469
472
  if (!folder) {
470
473
  return;
471
474
  }
472
- if (typeof (folder) === 'string') {
475
+ if (typeof folder === 'string') {
473
476
  return folder;
474
477
  }
475
478
  return folder();
@@ -479,7 +482,7 @@ _fieldStyle = new WeakMap(), _titleColor = new WeakMap(), _titleFgColor = new We
479
482
  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" });
480
483
  SdExportService.decorators = [
481
484
  { type: Injectable, args: [{
482
- providedIn: 'root'
485
+ providedIn: 'root',
483
486
  },] }
484
487
  ];
485
488
  SdExportService.ctorParameters = () => [
@@ -487,4 +490,4 @@ SdExportService.ctorParameters = () => [
487
490
  { type: SdNotifyService },
488
491
  { type: undefined, decorators: [{ type: Inject, args: [FIREBASE_CONFIG,] }, { type: Optional }] }
489
492
  ];
490
- //# 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        if (typeof (e[column.field]) === 'number') {\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).value = +e[column.field];\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).numFmt = '#';\r\n        } else {\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).value = e[column.field];\r\n        }\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\r\n  uploadXlsx = async (): Promise<{ items: any[], file: File } | undefined> => {\r\n    return await SdUtility.upload({\r\n      extensions: ['xlsx'],\r\n      maxSizeInMb: 10,\r\n    }).then(file => {\r\n      if (file) {\r\n        return new Promise<{ items: any[], file: File }>((resolve, reject) => {\r\n          const wb = new Workbook();\r\n          const reader: FileReader = new FileReader();\r\n          reader.onload = () => {\r\n            const buffer = reader.result as ArrayBuffer;\r\n            if (!buffer) {\r\n              reject('Có lỗi xảy ra khi đọc file');\r\n              return;\r\n            }\r\n            wb.xlsx.load(buffer).then(workbook => {\r\n              const sheet = workbook.worksheets[0];\r\n              if (!sheet) {\r\n                reject('Không tìm thấy dữ liệu import');\r\n                return;\r\n              }\r\n              const items: any[] = [];\r\n              const headers = sheet.getRow(1).values;\r\n              if (Array.isArray(headers)) {\r\n                sheet.eachRow((row, rowIndex) => {\r\n                  const { hasValues, values, } = row;\r\n                  // console.log(row, hasValues, values)\r\n                  if (hasValues && rowIndex > 1) {\r\n                    const item: any = {};\r\n                    headers.forEach((cellValue, index) => {\r\n                      if (cellValue) {\r\n                        const field = cellValue.toString();\r\n                        item[field] = values[index];\r\n                        if (typeof (item[field]) === 'string') {\r\n                          item[field] = item[field].trim();\r\n                        }\r\n                        if (item[field] === '' || item[field] === undefined) {\r\n                          item[field] = null;\r\n                        }\r\n                      }\r\n                    });\r\n                    items.push(item);\r\n                  }\r\n                });\r\n                resolve({\r\n                  items,\r\n                  file\r\n                })\r\n              }\r\n            })\r\n          };\r\n          reader.readAsArrayBuffer(file);\r\n        })\r\n      } else {\r\n        return {\r\n          items: [],\r\n          file: null\r\n        };\r\n      }\r\n    });\r\n  }\r\n}"]}
493
+ //# 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":";;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAS,MAAM,SAAS,CAAC;AAC1C,OAAO,EAAmC,GAAG,EAAsC,MAAM,gBAAgB,CAAC;AAC1G,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAA0B,MAAM,yBAAyB,CAAC;;;;;AAKlF,MAAM,OAAO,eAAe;IA+H1B,YACU,UAAwB,EACxB,aAA8B,EACO,qBAA6C;QAFlF,eAAU,GAAV,UAAU,CAAc;QACxB,kBAAa,GAAb,aAAa,CAAiB;QACO,0BAAqB,GAArB,qBAAqB,CAAwB;QA7G5F,sBAA8B;YAC5B,MAAM,EAAE;gBACN,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB;YACD,SAAS,EAAE;gBACT,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,QAAQ;gBACpB,QAAQ,EAAE,IAAI;aACf;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,IAAI;gBACV,IAAI,EAAE,EAAE;gBACR,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC1B;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,SAAS;gBACf,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;iBACf;aACF;SACF,EAAC;QACF,sBAAc,QAAQ,EAAC;QACvB,wBAAgB,QAAQ,EAAC;QACzB,sBAA8B;YAC5B,MAAM,EAAE;gBACN,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB;YACD,SAAS,EAAE;gBACT,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,QAAQ;gBACpB,QAAQ,EAAE,IAAI;aACf;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,IAAI;gBACV,IAAI,EAAE,EAAE;gBACR,KAAK,EAAE,EAAE,IAAI,2CAAkB,EAAE;aAClC;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,SAAS;gBACf,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE;oBACP,IAAI,6CAAoB;iBACzB;aACF;SACF,EAAC;QAEF,yBAAiC;YAC/B,MAAM,EAAE;gBACN,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB;YACD,SAAS,EAAE;gBACT,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,QAAQ;gBACpB,QAAQ,EAAE,IAAI;aACf;YACD,IAAI,EAAE;gBACJ,MAAM,EAAE,IAAI;gBACZ,IAAI,EAAE,EAAE;gBACR,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC1B;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,SAAS;gBACf,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;iBACf;aACF;SACF,EAAC;QAEF,4BAAoC;YAClC,MAAM,EAAE;gBACN,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB;YACD,SAAS,EAAE;gBACT,QAAQ,EAAE,IAAI;aACf;YACD,IAAI,EAAE;gBACJ,MAAM,EAAE,IAAI;gBACZ,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC1B;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,SAAS;gBACf,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;iBACf;aACF;SACF,EAAC;QAEF,qBAA6B;YAC3B,SAAS,EAAE;gBACT,QAAQ,EAAE,QAAQ;gBAClB,QAAQ,EAAE,IAAI;aACf;SACF,EAAC;QAQF,qBAAa,CAAC,GAAW,EAAE,KAAa,EAAE,EAAE;YAC1C,IAAI,YAAY,GAAG,IAAI,CAAC;gBACtB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,UAAU,EAAE,IAAI,CAAC,UAAU;aAC5B,CAAC,CAAC;YACH,IAAI,CAAC,KAAK,EAAE;gBACV,OAAO,QAAQ,IAAI,CAAC,MAAM,WAAW,YAAY,SAAS,GAAG,IAAI,EAAE,EAAE,CAAC;aACvE;YACD,YAAY,GAAG,IAAI,CAAC;gBAClB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,KAAK;aACN,CAAC,CAAC;YACH,OAAO,QAAQ,IAAI,CAAC,MAAM,WAAW,YAAY,SAAS,GAAG,IAAI,EAAE,EAAE,CAAC;QACxE,CAAC,EAAC;QAEF,qBAAgB,GAAG,CAAO,QAA0B,EAAE,EAAE;YACtD,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC;YAC/C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;aAC5D;YACD,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE;gBAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;oBACjB,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;iBACzD;gBACD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;oBACjB,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;iBACzD;aACF;YACD,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YAClE,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC,sEAAsE;YACvG,MAAM,UAAU,GAAG,QAAQ,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,wBAAwB;YAC9E,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;;gBAChC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;gBAC7C,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBACnD,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBACnD,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBACzD,IAAI,KAAK,GAAG,GAAG,CAAC;gBAChB,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBAC/C,KAAK,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;iBACzC;gBACD,UAAU,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,GAAG,CAAC,IAAI,EAAE,CAAC;gBACxD,SAAS,CAAC,KAAK,4CAAmB,CAAC;gBACnC,IAAI,QAAQ,EAAE;oBACZ,SAAS,CAAC,KAAK,+CAAsB,CAAC;iBACvC;qBAAM;oBACL,SAAS,CAAC,KAAK,4CAAmB,CAAC;iBACpC;gBACD,SAAS,CAAC,KAAK,iFAEb,IAAI,2HACmB,IAAI,KACzB,KAAK,iIACkB,IAAI,0CAAE,KAAK,KAChC,IAAI,EAAE,SAAS,0GAAsB,IAAI,0CAAE,KAAK,0CAAE,IAAI,CAAA,QAG1D,IAAI,EAAE;wBACJ,IAAI,EAAE,SAAS;wBACf,OAAO,EAAE,OAAO;wBAChB,OAAO,EAAE;4BACP,IAAI,EAAE,IAAI,+CAAsB;yBACjC;qBACF,GACF,CAAC;gBACF,SAAS,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;gBAC/B,SAAS,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;gBAC/B,IAAI,cAAc,EAAE;oBAClB,eAAe,CAAC,KAAK,kDAAyB,CAAC;oBAC/C,eAAe,CAAC,KAAK,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC;iBAClD;YACH,CAAC,CAAC,CAAC;YACH,IAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,EAAE;gBAClB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;oBAC1B,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;wBAC3E,MAAM,QAAQ,GAAG,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;wBACnD,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;4BACpC,QAAQ,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;4BACzC,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,4CAAmB,CAAC;4BACxD,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;wBAC/C,CAAC,CAAC,CAAC;wBACH,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;4BACjC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;gCACnC,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gCACzD,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,2CAAkB,CAAC;4BAC/D,CAAC,CAAC,CAAC;wBACL,CAAC,CAAC,CAAC;qBACJ;iBACF;aACF;YACD,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YAC/C,SAAS,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,mEAAmE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;QACpI,CAAC,CAAA,CAAC;QAEF,mBAAc,GAAG,CAAO,IAA+E,EAAyB,EAAE;YAChI,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;YACvC,MAAM,EAAE,cAAc,EAAE,GAAG,GAAG,CAAC;YAC/B,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,cAAc,IAAI,8CAAA,IAAI,EAAY,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC;YAClF,MAAM,IAAI,GAAG,MAAM,SAAS,CAAC,MAAM,CAAC;gBAClC,UAAU,EAAE,CAAC,MAAM,CAAC;gBACpB,WAAW,EAAE,GAAG;gBAChB,SAAS;aACV,CAAC,CAAC;YACH,IAAI,IAAI,EAAE;gBACR,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;oBAC1F,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC;oBAChD,MAAM,GAAG,CAAC;gBACZ,CAAC,CAAC,CAAC;gBACH,OAAO;oBACL,QAAQ;oBACR,QAAQ;iBACT,CAAC;aACH;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAA,CAAC;QAEF,2BAAsB,GAAG,CAAO,IAAiE,EAAE,EAAE;YACnG,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;YACtC,MAAM,EAAE,sBAAsB,EAAE,GAAG,GAAG,CAAC;YACvC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,sBAAsB,IAAI,8CAAA,IAAI,EAAY,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC;YAC1F,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;YACzE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;QAChC,CAAC,CAAA,CAAC;QAEF,eAAU,GAAG,CAAO,IAAwD,EAAE,EAAE;YAC9E,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;YACtC,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;YAC3B,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,UAAU,IAAI,8CAAA,IAAI,EAAY,GAAG,EAAE,KAAK,CAAC,SAAS,QAAQ,EAAE,CAAC;YAC/F,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC,CAAA,CAAC;QAEF,kBAAa,GAAG,CAAO,IAAqC,EAA2B,EAAE;;YASvF,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;YAC5B,MAAM,EAAE,aAAa,EAAE,GAAG,GAAG,CAAC;YAC9B,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,aAAa,IAAI,8CAAA,IAAI,EAAY,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC;YACjF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAmB,GAAG,CAAC,CAAC;YAC7D,OAAO,CACL,OAAA,GAAG,CAAC,KAAK,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACnB,QAAQ,EAAE,CAAC,CAAC,SAAS;gBACrB,QAAQ,EAAE,CAAC,CAAC,IAAI;aACjB,CAAC,MAAK,EAAE,CACV,CAAC;QACJ,CAAC,CAAA,CAAC;QAEF,aAAQ,GAAG,CAAC,QAAgB,EAAE,QAAiB,EAAE,EAAE;YACjD,MAAM,IAAI,GAAQ,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAC9C,IAAI,CAAC,QAAQ,GAAG,GAAG,QAAQ,IAAI,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC;YAChD,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;YACrB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAChC,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC;QAEF,qBAAgB,GAAG,CAAO,IAA2E,EAAE,EAAE;YACvG,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;YACpD,MAAM,EAAE,kBAAkB,EAAE,GAAG,GAAG,CAAC;YACnC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,kBAAkB,EAAE,CAAC;YACvD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CACvC,GAAG,EACH;gBACE,QAAQ;gBACR,OAAO;gBACP,KAAK;gBACL,QAAQ;aACT,EACD,IAAI,EACJ;gBACE,YAAY,EAAE,aAAa;aAC5B,CACF,CAAC;YACF,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,EAAE,2EAA2E,EAAE,CAAC,CAAC;YACvH,SAAS,CAAC,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACzC,CAAC,CAAA,CAAC;QAEF,cAAS,GAAG,CAAO,MAAqB,EAAE,EAAE;YAC1C,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;YAC5C,MAAM,SAAS,GAAG,EAAE,CAAC;YACrB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC5B,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC;aACxC;YACD,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC;gBAClC,QAAQ,EAAE,GAAG,QAAQ,IAAI,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,EAAE,EAAE,qBAAqB,CAAC,EAAE;gBACpF,cAAc,EAAE,GAAG;gBACnB,YAAY,EAAE,GAAG;gBACjB,gBAAgB,EAAE,GAAG;gBACrB,UAAU,EAAE,IAAI;gBAChB,SAAS,EAAE,KAAK;gBAChB,KAAK,EAAE,QAAQ,IAAI,KAAK;gBACxB,MAAM,EAAE,IAAI;aACb,CAAC,CAAC;YACH,WAAW,CAAC,WAAW,CAAC,CAAC,SAAS,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;QACjD,CAAC,CAAA,CAAC;QAEF,WAAM,GAAG,CAAO,MAAqB,EAAE,EAAE;YACvC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;YACpD,IAAI,cAAc,GAAG,KAAK,CAAC;YAC3B,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE;gBAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;oBACjB,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;iBACzD;gBACD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;oBACjB,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;iBACzD;gBACD,IAAI,MAAM,CAAC,WAAW,EAAE;oBACtB,cAAc,GAAG,IAAI,CAAC;iBACvB;aACF;YACD,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC,sEAAsE;YACvG,MAAM,UAAU,GAAG,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,wBAAwB;YAC1E,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBAChC,IAAI,KAAK,GAAG,GAAG,CAAC;gBAChB,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBAC/C,KAAK,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;iBACzC;gBACD,UAAU,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,GAAG,CAAC,IAAI,EAAE,CAAC;gBACxD,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,4CAAmB,CAAC;gBAC1D,IAAI,MAAM,CAAC,QAAQ,EAAE;oBACnB,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,+CAAsB,CAAC;iBAC9D;qBAAM;oBACL,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,4CAAmB,CAAC;iBAC3D;gBACD,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;gBACtD,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;gBACtD,IAAI,cAAc,EAAE;oBAClB,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,kDAAyB,CAAC;oBAChE,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC;iBACnE;YACH,CAAC,CAAC,CAAC;YACH,IAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,EAAE;gBAClB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;oBAC1B,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;wBAC3E,MAAM,QAAQ,GAAG,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;wBACnD,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;4BACpC,QAAQ,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;4BACzC,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,4CAAmB,CAAC;4BACxD,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;wBAC/C,CAAC,CAAC,CAAC;wBACH,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;4BACjC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;gCACnC,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gCACzD,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,2CAAkB,CAAC;4BAC/D,CAAC,CAAC,CAAC;wBACL,CAAC,CAAC,CAAC;qBACJ;iBACF;aACF;YAED,MAAM,OAAO,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE;gBACxB,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE;oBAC/B,IAAI,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,QAAQ,EAAE;wBACvC,UAAU,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;wBACtE,UAAU,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,MAAM,GAAG,GAAG,CAAC;qBAC3D;yBAAM;wBACL,UAAU,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;qBACtE;oBACD,UAAU,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,2CAAkB,CAAC;gBACvE,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YAC/C,SAAS,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,mEAAmE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;QACpI,CAAC,CAAA,CAAC;QAEF,iBAAY,GAAG,CAAO,MAA4B,EAAE,EAAE;YACpD,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;YACpC,IAAI,EAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,CAAA,EAAE;gBACnB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC;gBAC7D,OAAO;aACR;YACD,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;YAChC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,EAAE;gBAC3C,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC;gBACvC,MAAM,SAAS,GAAG,QAAQ,CAAC,YAAY,CAAC,IAAI,IAAI,SAAS,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;gBACpE,KAAK,MAAM,MAAM,IAAI,OAAO,IAAI,EAAE,EAAE;oBAClC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvD,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;iBACxD;gBACD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;oBACxB,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;oBAC3C,SAAS,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,KAAK,GAAG,KAAK,IAAI,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC;oBAClF,SAAS,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;iBAC9C;aACF;YACD,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YAC/C,SAAS,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,mEAAmE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;QACpI,CAAC,CAAA,CAAC;QAEF,aAAQ,GAAG,CAAO,IAAc,EAAE,EAAE;YAClC,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;YAC3B,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,UAAU,EAAE,CAAC;YAC/C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CACvC,GAAG,EACH;gBACE,IAAI;aACL,EACD,IAAI,EACJ;gBACE,YAAY,EAAE,aAAa;aAC5B,CACF,CAAC;YACF,SAAS,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,CAAC,CAAC;QAC1E,CAAC,CAAA,CAAC;QAEF,eAAU,GAAG,GAA4D,EAAE;YACzE,OAAO,MAAM,SAAS,CAAC,MAAM,CAAC;gBAC5B,UAAU,EAAE,CAAC,MAAM,CAAC;gBACpB,WAAW,EAAE,EAAE;aAChB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACb,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;QAEF,cAAS,GAAG,CAAO,IAAU,EAAqD,EAAE;YAClF,IAAI,IAAI,EAAE;gBACR,OAAO,IAAI,OAAO,CAA+B,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;oBACnE,MAAM,EAAE,GAAG,IAAI,QAAQ,EAAE,CAAC;oBAC1B,MAAM,MAAM,GAAe,IAAI,UAAU,EAAE,CAAC;oBAC5C,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;wBACnB,MAAM,MAAM,GAAG,MAAM,CAAC,MAAqB,CAAC;wBAC5C,IAAI,CAAC,MAAM,EAAE;4BACX,MAAM,CAAC,4BAA4B,CAAC,CAAC;4BACrC,OAAO;yBACR;wBACD,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;4BACnC,MAAM,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;4BACrC,IAAI,CAAC,KAAK,EAAE;gCACV,MAAM,CAAC,wBAAwB,CAAC,CAAC;gCACjC,OAAO;6BACR;4BACD,MAAM,KAAK,GAAU,EAAE,CAAC;4BACxB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;4BACvC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gCAC1B,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE;oCAC9B,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;oCAClC,sCAAsC;oCACtC,IAAI,SAAS,IAAI,QAAQ,GAAG,CAAC,EAAE;wCAC7B,MAAM,IAAI,GAAQ,EAAE,CAAC;wCACrB,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE;4CACnC,IAAI,SAAS,EAAE;gDACb,MAAM,KAAK,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;gDACnC,IAAI,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;gDAC5B,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,QAAQ,EAAE;oDACnC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;iDAClC;gDACD,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,SAAS,EAAE;oDACnD,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;iDACpB;6CACF;wCACH,CAAC,CAAC,CAAC;wCACH,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qCAClB;gCACH,CAAC,CAAC,CAAC;gCACH,OAAO,CAAC;oCACN,KAAK;oCACL,IAAI;iCACL,CAAC,CAAC;6BACJ;wBACH,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC;oBACF,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBACjC,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,OAAO;oBACL,KAAK,EAAE,EAAE;oBACT,IAAI,EAAE,IAAI;iBACX,CAAC;aACH;QACH,CAAC,CAAA,CAAC;IAxXC,CAAC;IAlIJ,IAAY,WAAW;;QACrB,aAAO,IAAI,CAAC,qBAAqB,0CAAE,WAAW,CAAC;IACjD,CAAC;IAED,IAAY,MAAM;QAChB,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,qBAAqB,CAAC;QACpD,OAAO,GAAG,OAAO,IAAI,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,IAAY,UAAU;QACpB,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAC9C,IAAI,CAAC,MAAM,EAAE;YACX,OAAO;SACR;QACD,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;YAC9B,OAAO,MAAM,CAAC;SACf;QACD,OAAO,MAAM,EAAE,CAAC;IAClB,CAAC;;;;;YAtBF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YAXQ,YAAY;YAMZ,eAAe;4CAwInB,MAAM,SAAC,eAAe,cAAG,QAAQ","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: { key: string; group?: string; validator?: (fileName: string) => string }): 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: { key: string; template: SdExportTemplate; group?: string }) => {\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: { key: string; group?: string; fileName?: string }) => {\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: { key: string; group?: string }): Promise<SdExportFile[]> => {\r\n    interface FilesInFolderRes {\r\n      directory: string;\r\n      files: {\r\n        publicUrl: string;\r\n        fullPath: string;\r\n        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 (\r\n      res.files?.map(e => ({\r\n        filePath: e.publicUrl,\r\n        fileName: e.name,\r\n      })) || []\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: { filePath: string; columns: any[]; items: any[]; fileName?: string }) => {\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(\r\n      url,\r\n      {\r\n        filePath,\r\n        columns,\r\n        items,\r\n        fileName,\r\n      },\r\n      null,\r\n      {\r\n        responseType: 'arraybuffer',\r\n      }\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        if (typeof e[column.field] === 'number') {\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).value = +e[column.field];\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).numFmt = '#';\r\n        } else {\r\n          firstSheet.getCell(fromRow + idx1, 1 + idx2).value = e[column.field];\r\n        }\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(\r\n      url,\r\n      {\r\n        urls,\r\n      },\r\n      null,\r\n      {\r\n        responseType: 'arraybuffer',\r\n      }\r\n    );\r\n    SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));\r\n  };\r\n\r\n  uploadXlsx = async (): Promise<{ items: any[]; file: File } | undefined> => {\r\n    return await SdUtility.upload({\r\n      extensions: ['xlsx'],\r\n      maxSizeInMb: 10,\r\n    }).then(file => {\r\n      return this.parseXlsx(file);\r\n    });\r\n  };\r\n\r\n  parseXlsx = async (file: File): Promise<{ items: any[]; file: File } | undefined> => {\r\n    if (file) {\r\n      return new Promise<{ items: any[]; file: File }>((resolve, reject) => {\r\n        const wb = new Workbook();\r\n        const reader: FileReader = new FileReader();\r\n        reader.onload = () => {\r\n          const buffer = reader.result as ArrayBuffer;\r\n          if (!buffer) {\r\n            reject('Có lỗi xảy ra khi đọc file');\r\n            return;\r\n          }\r\n          wb.xlsx.load(buffer).then(workbook => {\r\n            const sheet = workbook.worksheets[0];\r\n            if (!sheet) {\r\n              reject('Không tìm thấy dữ liệu');\r\n              return;\r\n            }\r\n            const items: any[] = [];\r\n            const headers = sheet.getRow(1).values;\r\n            if (Array.isArray(headers)) {\r\n              sheet.eachRow((row, rowIndex) => {\r\n                const { hasValues, values } = row;\r\n                // console.log(row, hasValues, values)\r\n                if (hasValues && rowIndex > 1) {\r\n                  const item: any = {};\r\n                  headers.forEach((cellValue, index) => {\r\n                    if (cellValue) {\r\n                      const field = cellValue.toString();\r\n                      item[field] = values[index];\r\n                      if (typeof item[field] === 'string') {\r\n                        item[field] = item[field].trim();\r\n                      }\r\n                      if (item[field] === '' || item[field] === undefined) {\r\n                        item[field] = null;\r\n                      }\r\n                    }\r\n                  });\r\n                  items.push(item);\r\n                }\r\n              });\r\n              resolve({\r\n                items,\r\n                file,\r\n              });\r\n            }\r\n          });\r\n        };\r\n        reader.readAsArrayBuffer(file);\r\n      });\r\n    } else {\r\n      return {\r\n        items: [],\r\n        file: null,\r\n      };\r\n    }\r\n  };\r\n}\r\n"]}
@@ -7,24 +7,25 @@ export { SdDesktopCellView as ɵc } from './src/lib/components/desktop-cell-view
7
7
  export { SdDesktopCell as ɵb } from './src/lib/components/desktop-cell/desktop-cell.component';
8
8
  export { SdDesktopCommand as ɵd } from './src/lib/components/desktop-command/desktop-command.component';
9
9
  export { SdPopupConfiguration as ɵf } from './src/lib/components/popup-configuration/popup-configuration.component';
10
- export { SdPopupFilter as ɵk } from './src/lib/components/popup-filter/popup-filter.component';
10
+ export { SdPopupExport as ɵj } from './src/lib/components/popup-export/popup-export.component';
11
+ export { SdPopupFilter as ɵl } from './src/lib/components/popup-filter/popup-filter.component';
11
12
  export { SdTableQuickAction as ɵa } from './src/lib/components/quick-action/quick-action.component';
12
- export { SdTableFilter as ɵj } from './src/lib/components/table-filter/table-filter.component';
13
- export { SdMaterialSubInformationDefDirective as ɵl } from './src/lib/directives/sd-table-expand-def.directive';
14
- export { SdMaterialFooterDefDirective as ɵm } from './src/lib/directives/sd-table-footer-def.directive';
13
+ export { SdTableFilter as ɵk } from './src/lib/components/table-filter/table-filter.component';
14
+ export { SdMaterialSubInformationDefDirective as ɵm } from './src/lib/directives/sd-table-expand-def.directive';
15
+ export { SdMaterialFooterDefDirective as ɵn } from './src/lib/directives/sd-table-footer-def.directive';
15
16
  export { TABLE_CONFIG as ɵi } from './src/lib/models/table-configuration.model';
16
- export { SdColumnTooltipPipe as ɵs } from './src/lib/pipes/column-tooltip.pipe';
17
- export { SdCommandDisablePipe as ɵp } from './src/lib/pipes/command-disable.pipe';
18
- export { SdCommandFilterPipe as ɵo } from './src/lib/pipes/command-filter.pipe';
19
- export { SdCommandIconPipe as ɵq } from './src/lib/pipes/command-icon.pipe';
20
- export { SdCommandTitlePipe as ɵr } from './src/lib/pipes/command-title.pipe';
21
- export { SdFilterColumnPipe as ɵt } from './src/lib/pipes/filter-column.pipe';
22
- export { SdFilterExternalPipe as ɵu } from './src/lib/pipes/filter-external.pipe';
23
- export { SdGroupPipe as ɵz } from './src/lib/pipes/sd-group.pipe';
24
- export { SdSelectionActionFilterPipe as ɵv } from './src/lib/pipes/selection-action-filter.pipe';
25
- export { SdSelectionDisablePipe as ɵx } from './src/lib/pipes/selection-disable.pipe';
26
- export { SdSelectionVisibleSelectAllPipe as ɵy } from './src/lib/pipes/selection-visible-select-all.pipe';
27
- export { SdSelectionVisiblePipe as ɵw } from './src/lib/pipes/selection-visible.pipe';
17
+ export { SdColumnTooltipPipe as ɵt } from './src/lib/pipes/column-tooltip.pipe';
18
+ export { SdCommandDisablePipe as ɵq } from './src/lib/pipes/command-disable.pipe';
19
+ export { SdCommandFilterPipe as ɵp } from './src/lib/pipes/command-filter.pipe';
20
+ export { SdCommandIconPipe as ɵr } from './src/lib/pipes/command-icon.pipe';
21
+ export { SdCommandTitlePipe as ɵs } from './src/lib/pipes/command-title.pipe';
22
+ export { SdFilterColumnPipe as ɵu } from './src/lib/pipes/filter-column.pipe';
23
+ export { SdFilterExternalPipe as ɵv } from './src/lib/pipes/filter-external.pipe';
24
+ export { SdGroupPipe as ɵba } from './src/lib/pipes/sd-group.pipe';
25
+ export { SdSelectionActionFilterPipe as ɵw } from './src/lib/pipes/selection-action-filter.pipe';
26
+ export { SdSelectionDisablePipe as ɵy } from './src/lib/pipes/selection-disable.pipe';
27
+ export { SdSelectionVisibleSelectAllPipe as ɵz } from './src/lib/pipes/selection-visible-select-all.pipe';
28
+ export { SdSelectionVisiblePipe as ɵx } from './src/lib/pipes/selection-visible.pipe';
28
29
  export { SdTableConfigurationService as ɵg } from './src/lib/services/table-configuration.service';
29
- export { SdTableFilterService as ɵn } from './src/lib/services/table-filter/table-filter.service';
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2QtYW5ndWxhci1jb3JlLXRhYmxlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS90YWJsZS8iLCJzb3VyY2VzIjpbInNkLWFuZ3VsYXItY29yZS10YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwRUFBMEUsQ0FBQztBQUNwSCxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sb0VBQW9FLENBQUM7QUFDM0csT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSwwREFBMEQsQ0FBQztBQUM3RixPQUFPLEVBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0VBQWdFLENBQUM7QUFDdEcsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLHdFQUF3RSxDQUFDO0FBQ2xILE9BQU8sRUFBQyxhQUFhLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDN0YsT0FBTyxFQUFDLGtCQUFrQixJQUFJLEVBQUUsRUFBQyxNQUFNLDBEQUEwRCxDQUFDO0FBQ2xHLE9BQU8sRUFBQyxhQUFhLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDN0YsT0FBTyxFQUFDLG9DQUFvQyxJQUFJLEVBQUUsRUFBQyxNQUFNLG9EQUFvRCxDQUFDO0FBQzlHLE9BQU8sRUFBQyw0QkFBNEIsSUFBSSxFQUFFLEVBQUMsTUFBTSxvREFBb0QsQ0FBQztBQUN0RyxPQUFPLEVBQTZCLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUMxRyxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDOUUsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ2hGLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDMUUsT0FBTyxFQUFDLGtCQUFrQixJQUFJLEVBQUUsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLFdBQVcsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUMsMkJBQTJCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDL0YsT0FBTyxFQUFDLHNCQUFzQixJQUFJLEVBQUUsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBQ3BGLE9BQU8sRUFBQywrQkFBK0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxtREFBbUQsQ0FBQztBQUN4RyxPQUFPLEVBQUMsc0JBQXNCLElBQUksRUFBRSxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDcEYsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQ2pHLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxzREFBc0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG5cbmV4cG9ydCB7U2RDb2x1bW5JbmxpbmVGaWx0ZXIgYXMgybVlfSBmcm9tICcuL3NyYy9saWIvY29tcG9uZW50cy9jb2x1bW4taW5saW5lLWZpbHRlci9jb2x1bW4taW5saW5lLWZpbHRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtTZERlc2t0b3BDZWxsVmlldyBhcyDJtWN9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY2VsbC12aWV3L2Rlc2t0b3AtY2VsbC12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQge1NkRGVza3RvcENlbGwgYXMgybVifSBmcm9tICcuL3NyYy9saWIvY29tcG9uZW50cy9kZXNrdG9wLWNlbGwvZGVza3RvcC1jZWxsLmNvbXBvbmVudCc7XG5leHBvcnQge1NkRGVza3RvcENvbW1hbmQgYXMgybVkfSBmcm9tICcuL3NyYy9saWIvY29tcG9uZW50cy9kZXNrdG9wLWNvbW1hbmQvZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudCc7XG5leHBvcnQge1NkUG9wdXBDb25maWd1cmF0aW9uIGFzIMm1Zn0gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvcG9wdXAtY29uZmlndXJhdGlvbi9wb3B1cC1jb25maWd1cmF0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQge1NkUG9wdXBGaWx0ZXIgYXMgybVrfSBmcm9tICcuL3NyYy9saWIvY29tcG9uZW50cy9wb3B1cC1maWx0ZXIvcG9wdXAtZmlsdGVyLmNvbXBvbmVudCc7XG5leHBvcnQge1NkVGFibGVRdWlja0FjdGlvbiBhcyDJtWF9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3F1aWNrLWFjdGlvbi9xdWljay1hY3Rpb24uY29tcG9uZW50JztcbmV4cG9ydCB7U2RUYWJsZUZpbHRlciBhcyDJtWp9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlLWZpbHRlci90YWJsZS1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2RNYXRlcmlhbFN1YkluZm9ybWF0aW9uRGVmRGlyZWN0aXZlIGFzIMm1bH0gZnJvbSAnLi9zcmMvbGliL2RpcmVjdGl2ZXMvc2QtdGFibGUtZXhwYW5kLWRlZi5kaXJlY3RpdmUnO1xuZXhwb3J0IHtTZE1hdGVyaWFsRm9vdGVyRGVmRGlyZWN0aXZlIGFzIMm1bX0gZnJvbSAnLi9zcmMvbGliL2RpcmVjdGl2ZXMvc2QtdGFibGUtZm9vdGVyLWRlZi5kaXJlY3RpdmUnO1xuZXhwb3J0IHtJU2RUYWJsZUNvbmZpZ3VyYXRpb24gYXMgybVoLFRBQkxFX0NPTkZJRyBhcyDJtWl9IGZyb20gJy4vc3JjL2xpYi9tb2RlbHMvdGFibGUtY29uZmlndXJhdGlvbi5tb2RlbCc7XG5leHBvcnQge1NkQ29sdW1uVG9vbHRpcFBpcGUgYXMgybVzfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29sdW1uLXRvb2x0aXAucGlwZSc7XG5leHBvcnQge1NkQ29tbWFuZERpc2FibGVQaXBlIGFzIMm1cH0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbW1hbmQtZGlzYWJsZS5waXBlJztcbmV4cG9ydCB7U2RDb21tYW5kRmlsdGVyUGlwZSBhcyDJtW99IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb21tYW5kLWZpbHRlci5waXBlJztcbmV4cG9ydCB7U2RDb21tYW5kSWNvblBpcGUgYXMgybVxfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29tbWFuZC1pY29uLnBpcGUnO1xuZXhwb3J0IHtTZENvbW1hbmRUaXRsZVBpcGUgYXMgybVyfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29tbWFuZC10aXRsZS5waXBlJztcbmV4cG9ydCB7U2RGaWx0ZXJDb2x1bW5QaXBlIGFzIMm1dH0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2ZpbHRlci1jb2x1bW4ucGlwZSc7XG5leHBvcnQge1NkRmlsdGVyRXh0ZXJuYWxQaXBlIGFzIMm1dX0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2ZpbHRlci1leHRlcm5hbC5waXBlJztcbmV4cG9ydCB7U2RHcm91cFBpcGUgYXMgybV6fSBmcm9tICcuL3NyYy9saWIvcGlwZXMvc2QtZ3JvdXAucGlwZSc7XG5leHBvcnQge1NkU2VsZWN0aW9uQWN0aW9uRmlsdGVyUGlwZSBhcyDJtXZ9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tYWN0aW9uLWZpbHRlci5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25EaXNhYmxlUGlwZSBhcyDJtXh9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tZGlzYWJsZS5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25WaXNpYmxlU2VsZWN0QWxsUGlwZSBhcyDJtXl9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tdmlzaWJsZS1zZWxlY3QtYWxsLnBpcGUnO1xuZXhwb3J0IHtTZFNlbGVjdGlvblZpc2libGVQaXBlIGFzIMm1d30gZnJvbSAnLi9zcmMvbGliL3BpcGVzL3NlbGVjdGlvbi12aXNpYmxlLnBpcGUnO1xuZXhwb3J0IHtTZFRhYmxlQ29uZmlndXJhdGlvblNlcnZpY2UgYXMgybVnfSBmcm9tICcuL3NyYy9saWIvc2VydmljZXMvdGFibGUtY29uZmlndXJhdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCB7U2RUYWJsZUZpbHRlclNlcnZpY2UgYXMgybVufSBmcm9tICcuL3NyYy9saWIvc2VydmljZXMvdGFibGUtZmlsdGVyL3RhYmxlLWZpbHRlci5zZXJ2aWNlJzsiXX0=
30
+ export { SdTableFilterService as ɵo } from './src/lib/services/table-filter/table-filter.service';
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2QtYW5ndWxhci1jb3JlLXRhYmxlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS90YWJsZS8iLCJzb3VyY2VzIjpbInNkLWFuZ3VsYXItY29yZS10YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwRUFBMEUsQ0FBQztBQUNwSCxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sb0VBQW9FLENBQUM7QUFDM0csT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSwwREFBMEQsQ0FBQztBQUM3RixPQUFPLEVBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0VBQWdFLENBQUM7QUFDdEcsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLHdFQUF3RSxDQUFDO0FBQ2xILE9BQU8sRUFBQyxhQUFhLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDN0YsT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSwwREFBMEQsQ0FBQztBQUM3RixPQUFPLEVBQUMsa0JBQWtCLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDbEcsT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSwwREFBMEQsQ0FBQztBQUM3RixPQUFPLEVBQUMsb0NBQW9DLElBQUksRUFBRSxFQUFDLE1BQU0sb0RBQW9ELENBQUM7QUFDOUcsT0FBTyxFQUFDLDRCQUE0QixJQUFJLEVBQUUsRUFBQyxNQUFNLG9EQUFvRCxDQUFDO0FBQ3RHLE9BQU8sRUFBNkIsWUFBWSxJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzFHLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLG1CQUFtQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsa0JBQWtCLElBQUksRUFBRSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDNUUsT0FBTyxFQUFDLGtCQUFrQixJQUFJLEVBQUUsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUNoRixPQUFPLEVBQUMsV0FBVyxJQUFJLEdBQUcsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ2pFLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUMvRixPQUFPLEVBQUMsc0JBQXNCLElBQUksRUFBRSxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDcEYsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ3hHLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUNwRixPQUFPLEVBQUMsMkJBQTJCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDakcsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLHNEQUFzRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IHtTZENvbHVtbklubGluZUZpbHRlciBhcyDJtWV9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2NvbHVtbi1pbmxpbmUtZmlsdGVyL2NvbHVtbi1pbmxpbmUtZmlsdGVyLmNvbXBvbmVudCc7XG5leHBvcnQge1NkRGVza3RvcENlbGxWaWV3IGFzIMm1Y30gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvZGVza3RvcC1jZWxsLXZpZXcvZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCB7U2REZXNrdG9wQ2VsbCBhcyDJtWJ9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY2VsbC9kZXNrdG9wLWNlbGwuY29tcG9uZW50JztcbmV4cG9ydCB7U2REZXNrdG9wQ29tbWFuZCBhcyDJtWR9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY29tbWFuZC9kZXNrdG9wLWNvbW1hbmQuY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cENvbmZpZ3VyYXRpb24gYXMgybVmfSBmcm9tICcuL3NyYy9saWIvY29tcG9uZW50cy9wb3B1cC1jb25maWd1cmF0aW9uL3BvcHVwLWNvbmZpZ3VyYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cEV4cG9ydCBhcyDJtWp9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwLWV4cG9ydC9wb3B1cC1leHBvcnQuY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cEZpbHRlciBhcyDJtWx9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwLWZpbHRlci9wb3B1cC1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2RUYWJsZVF1aWNrQWN0aW9uIGFzIMm1YX0gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvcXVpY2stYWN0aW9uL3F1aWNrLWFjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0IHtTZFRhYmxlRmlsdGVyIGFzIMm1a30gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUtZmlsdGVyL3RhYmxlLWZpbHRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtTZE1hdGVyaWFsU3ViSW5mb3JtYXRpb25EZWZEaXJlY3RpdmUgYXMgybVtfSBmcm9tICcuL3NyYy9saWIvZGlyZWN0aXZlcy9zZC10YWJsZS1leHBhbmQtZGVmLmRpcmVjdGl2ZSc7XG5leHBvcnQge1NkTWF0ZXJpYWxGb290ZXJEZWZEaXJlY3RpdmUgYXMgybVufSBmcm9tICcuL3NyYy9saWIvZGlyZWN0aXZlcy9zZC10YWJsZS1mb290ZXItZGVmLmRpcmVjdGl2ZSc7XG5leHBvcnQge0lTZFRhYmxlQ29uZmlndXJhdGlvbiBhcyDJtWgsVEFCTEVfQ09ORklHIGFzIMm1aX0gZnJvbSAnLi9zcmMvbGliL21vZGVscy90YWJsZS1jb25maWd1cmF0aW9uLm1vZGVsJztcbmV4cG9ydCB7U2RDb2x1bW5Ub29sdGlwUGlwZSBhcyDJtXR9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb2x1bW4tdG9vbHRpcC5waXBlJztcbmV4cG9ydCB7U2RDb21tYW5kRGlzYWJsZVBpcGUgYXMgybVxfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29tbWFuZC1kaXNhYmxlLnBpcGUnO1xuZXhwb3J0IHtTZENvbW1hbmRGaWx0ZXJQaXBlIGFzIMm1cH0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbW1hbmQtZmlsdGVyLnBpcGUnO1xuZXhwb3J0IHtTZENvbW1hbmRJY29uUGlwZSBhcyDJtXJ9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb21tYW5kLWljb24ucGlwZSc7XG5leHBvcnQge1NkQ29tbWFuZFRpdGxlUGlwZSBhcyDJtXN9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb21tYW5kLXRpdGxlLnBpcGUnO1xuZXhwb3J0IHtTZEZpbHRlckNvbHVtblBpcGUgYXMgybV1fSBmcm9tICcuL3NyYy9saWIvcGlwZXMvZmlsdGVyLWNvbHVtbi5waXBlJztcbmV4cG9ydCB7U2RGaWx0ZXJFeHRlcm5hbFBpcGUgYXMgybV2fSBmcm9tICcuL3NyYy9saWIvcGlwZXMvZmlsdGVyLWV4dGVybmFsLnBpcGUnO1xuZXhwb3J0IHtTZEdyb3VwUGlwZSBhcyDJtWJhfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvc2QtZ3JvdXAucGlwZSc7XG5leHBvcnQge1NkU2VsZWN0aW9uQWN0aW9uRmlsdGVyUGlwZSBhcyDJtXd9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tYWN0aW9uLWZpbHRlci5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25EaXNhYmxlUGlwZSBhcyDJtXl9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tZGlzYWJsZS5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25WaXNpYmxlU2VsZWN0QWxsUGlwZSBhcyDJtXp9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tdmlzaWJsZS1zZWxlY3QtYWxsLnBpcGUnO1xuZXhwb3J0IHtTZFNlbGVjdGlvblZpc2libGVQaXBlIGFzIMm1eH0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL3NlbGVjdGlvbi12aXNpYmxlLnBpcGUnO1xuZXhwb3J0IHtTZFRhYmxlQ29uZmlndXJhdGlvblNlcnZpY2UgYXMgybVnfSBmcm9tICcuL3NyYy9saWIvc2VydmljZXMvdGFibGUtY29uZmlndXJhdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCB7U2RUYWJsZUZpbHRlclNlcnZpY2UgYXMgybVvfSBmcm9tICcuL3NyYy9saWIvc2VydmljZXMvdGFibGUtZmlsdGVyL3RhYmxlLWZpbHRlci5zZXJ2aWNlJzsiXX0=