@sd-angular/core 1.3.145 → 1.3.146

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"sd-angular-core-export.js","sources":["../../../../projects/sd-core/export/src/lib/export.model.ts","../../../../projects/sd-core/export/src/lib/export.service.ts","../../../../projects/sd-core/export/sd-angular-core-export.ts"],"sourcesContent":["export * from './excel.model';\r\nexport interface SdExportTemplate {\r\n fileName?: string;\r\n columns: SdExportTempateColumn[];\r\n sheets?: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[];\r\n}\r\n\r\nexport interface SdExportTempateColumn {\r\n field: string;\r\n title: string;\r\n required?: boolean;\r\n color?: string;\r\n width?: string;\r\n description?: string;\r\n fontColor?: string;\r\n fill?: string;\r\n}\r\n\r\nexport interface SdExportFile {\r\n fileName?: string;\r\n filePath?: string;\r\n}\r\n\r\nexport interface SdExportColumn {\r\n field: string;\r\n title: string;\r\n description?: string;\r\n width?: string;\r\n}\r\n\r\nexport interface IExportOption {\r\n columns: SdExportTempateColumn[];\r\n items: any[];\r\n fileName?: string;\r\n sheets?: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[];\r\n}\r\n\r\nexport interface IBigExportRequest {\r\n filePath?: string;\r\n destination?: string;\r\n latestRow: number;\r\n columns: {\r\n field: string,\r\n title: string,\r\n description?: string,\r\n width?: string,\r\n }[];\r\n items: any[];\r\n}\r\n\r\nexport interface IBigExportResponse {\r\n filePath: string;\r\n destination: string;\r\n latestRow: number;\r\n}\r\n\r\nexport type GroupPermission = 'view' | 'add' | 'delete';\r\n\r\nexport const API = {\r\n uploadTemplate: '/excel/uploadTemplate',\r\n generateUploadTemplate: '/excel/generateUploadTemplate',\r\n filesInFolder: '/excel/filesInFolder',\r\n removeFile: '/excel/remove',\r\n sdExportByTemplate: '/excel/sd-export-by-template',\r\n sdMergePDF: '/excel/sd-merge-pdf',\r\n};\r\n","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}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["uuid.v4"],"mappings":"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"}
1
+ {"version":3,"file":"sd-angular-core-export.js","sources":["../../../../projects/sd-core/export/src/lib/export.model.ts","../../../../projects/sd-core/export/src/lib/export.service.ts","../../../../projects/sd-core/export/sd-angular-core-export.ts"],"sourcesContent":["export * from './excel.model';\r\nexport interface SdExportTemplate {\r\n fileName?: string;\r\n columns: SdExportTempateColumn[];\r\n sheets?: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[];\r\n}\r\n\r\nexport interface SdExportTempateColumn {\r\n field: string;\r\n title: string;\r\n required?: boolean;\r\n color?: string;\r\n width?: string;\r\n description?: string;\r\n fontColor?: string;\r\n fill?: string;\r\n}\r\n\r\nexport interface SdExportFile {\r\n fileName?: string;\r\n filePath?: string;\r\n}\r\n\r\nexport interface SdExportColumn {\r\n field: string;\r\n title: string;\r\n description?: string;\r\n width?: string;\r\n}\r\n\r\nexport interface IExportOption {\r\n columns: SdExportTempateColumn[];\r\n items: any[];\r\n fileName?: string;\r\n sheets?: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[];\r\n}\r\n\r\nexport interface IBigExportRequest {\r\n filePath?: string;\r\n destination?: string;\r\n latestRow: number;\r\n columns: {\r\n field: string,\r\n title: string,\r\n description?: string,\r\n width?: string,\r\n }[];\r\n items: any[];\r\n}\r\n\r\nexport interface IBigExportResponse {\r\n filePath: string;\r\n destination: string;\r\n latestRow: number;\r\n}\r\n\r\nexport type GroupPermission = 'view' | 'add' | 'delete';\r\n\r\nexport const API = {\r\n uploadTemplate: '/excel/uploadTemplate',\r\n generateUploadTemplate: '/excel/generateUploadTemplate',\r\n filesInFolder: '/excel/filesInFolder',\r\n removeFile: '/excel/remove',\r\n sdExportByTemplate: '/excel/sd-export-by-template',\r\n sdMergePDF: '/excel/sd-merge-pdf',\r\n};\r\n","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}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["uuid.v4"],"mappings":";;;;;;;;;;MAkEa,GAAG,GAAG;IACjB,cAAc,EAAE,uBAAuB;IACvC,sBAAsB,EAAE,+BAA+B;IACvD,aAAa,EAAE,sBAAsB;IACrC,UAAU,EAAE,eAAe;IAC3B,kBAAkB,EAAE,8BAA8B;IAClD,UAAU,EAAE,qBAAqB;;;;MC1DtB,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,EAAA;QACD,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,EAAA;QAED,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,EAAA;QAED,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,EAAA;QAED,qBAA6B;YAC3B,SAAS,EAAE;gBACT,QAAQ,EAAE,QAAQ;gBAClB,QAAQ,EAAE,IAAI;aACf;SACF,EAAA;QAQD,qBAAa,CAAC,GAAW,EAAE,KAAa;YACtC,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;SACvE,EAAA;QAED,qBAAgB,GAAG,CAAO,QAA0B;YAClD,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,IAAI,MAAM,CAAC,WAAW,CAAC,CAAC;YAClE,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;YAChC,MAAM,UAAU,GAAG,QAAQ,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;YACrD,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK;;gBAC5B,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;aACF,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;4BAChC,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;yBAC9C,CAAC,CAAC;wBACH,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,IAAI;4BAC7B,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,IAAI;gCAC/B,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;6BAC9D,CAAC,CAAC;yBACJ,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;SACnI,CAAA,CAAA;QAED,mBAAc,GAAG,CAAO,IAIvB;YACC,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;oBACtF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC;oBAChD,MAAM,GAAG,CAAC;iBACX,CAAC,CAAC;gBACH,OAAO;oBACL,QAAQ;oBACR,QAAQ;iBACT,CAAC;aACH;YACD,OAAO,IAAI,CAAC;SACb,CAAA,CAAA;QAED,2BAAsB,GAAG,CAAO,IAI/B;YACC,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;SAC/B,CAAA,CAAA;QAED,eAAU,GAAG,CAAO,IAInB;YACC,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;SACjC,CAAA,CAAA;QAED,kBAAa,GAAG,CAAO,IAGtB;;YAOC,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,OAAA,GAAG,CAAC,KAAK,0CAAE,GAAG,CAAC,CAAC,KAAK;gBAC1B,QAAQ,EAAE,CAAC,CAAC,SAAS;gBACrB,QAAQ,EAAE,CAAC,CAAC,IAAI;aACjB,CAAC,MAAK,EAAE,CAAC;SACX,CAAA,CAAA;QAED,aAAQ,GAAG,CAAC,QAAgB,EAAE,QAAiB;YAC7C,MAAM,IAAI,GAAQ,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAC9C,IAAI,CAAC,QAAQ,GAAG,GAAG,QAAQ,IAAIA,EAAO,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;SACjC,CAAA;QAED,qBAAgB,GAAG,CAAO,IAKzB;YACC,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,CAAC,GAAG,EAAE;gBAC7C,QAAQ;gBACR,OAAO;gBACP,KAAK;gBACL,QAAQ;aACT,EAAE,IAAI,EAAE;gBACP,YAAY,EAAE,aAAa;aAC5B,CAAC,CAAC;YACH,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;SACxC,CAAA,CAAA;QAED,cAAS,GAAG,CAAO,MAAqB;YACtC,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;SAChD,CAAA,CAAA;QAED,WAAM,GAAG,CAAO,MAAqB;YACnC,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;YAChC,MAAM,UAAU,GAAG,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YACjD,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK;gBAC5B,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,CAAA;gBACzD,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;aACF,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;4BAChC,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;yBAC9C,CAAC,CAAC;wBACH,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,IAAI;4BAC7B,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,IAAI;gCAC/B,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;6BAC9D,CAAC,CAAC;yBACJ,CAAC,CAAC;qBACJ;iBACF;aACF;YAED,MAAM,OAAO,GAAG,cAAc,GAAG,CAAC,GAAG,CAAC,CAAC;YACvC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI;gBACpB,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,IAAI;oBAC3B,IAAI,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,QAAQ,EAAE;wBACzC,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;iBACtE,CAAC,CAAC;aACJ,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;SACnI,CAAA,CAAA;QAED,iBAAY,GAAG,CAAO,MAA4B;YAChD,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,CAAA;gBACtC,MAAM,SAAS,GAAG,QAAQ,CAAC,YAAY,CAAC,IAAI,IAAI,SAAS,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;gBACpE,KAAK,MAAM,MAAM,KAAK,OAAO,IAAI,EAAE,GAAG;oBACpC,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;SACnI,CAAA,CAAA;QAED,aAAQ,GAAG,CAAO,IAAc;YAC9B,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,CAAC,GAAG,EAAE;gBAC7C,IAAI;aACL,EAAE,IAAI,EAAE;gBACP,YAAY,EAAE,aAAa;aAC5B,CAAC,CAAC;YACH,SAAS,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,CAAC,CAAC;SACzE,CAAA,CAAA;QAED,eAAU,GAAG;YACX,OAAO,MAAM,SAAS,CAAC,MAAM,CAAC;gBAC5B,UAAU,EAAE,CAAC,MAAM,CAAC;gBACpB,WAAW,EAAE,EAAE;aAChB,CAAC,CAAC,IAAI,CAAC,IAAI;gBACV,IAAI,IAAI,EAAE;oBACR,OAAO,IAAI,OAAO,CAA+B,CAAC,OAAO,EAAE,MAAM;wBAC/D,MAAM,EAAE,GAAG,IAAI,QAAQ,EAAE,CAAC;wBAC1B,MAAM,MAAM,GAAe,IAAI,UAAU,EAAE,CAAC;wBAC5C,MAAM,CAAC,MAAM,GAAG;4BACd,MAAM,MAAM,GAAG,MAAM,CAAC,MAAqB,CAAC;4BAC5C,IAAI,CAAC,MAAM,EAAE;gCACX,MAAM,CAAC,4BAA4B,CAAC,CAAC;gCACrC,OAAO;6BACR;4BACD,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ;gCAChC,MAAM,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gCACrC,IAAI,CAAC,KAAK,EAAE;oCACV,MAAM,CAAC,+BAA+B,CAAC,CAAC;oCACxC,OAAO;iCACR;gCACD,MAAM,KAAK,GAAU,EAAE,CAAC;gCACxB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gCACvC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oCAC1B,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,QAAQ;wCAC1B,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,GAAG,GAAG,CAAC;wCACnC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,CAAA;wCACnC,IAAI,SAAS,IAAI,QAAQ,GAAG,CAAC,EAAE;4CAC7B,MAAM,IAAI,GAAQ,EAAE,CAAC;4CACrB,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,KAAK;gDAC/B,IAAI,SAAS,EAAE;oDACb,MAAM,KAAK,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;oDACnC,IAAI,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;oDAC5B,IAAI,QAAQ,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,QAAQ,EAAE;wDACrC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;qDAClC;oDACD,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,SAAS,EAAE;wDACnD,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;qDACpB;iDACF;6CACF,CAAC,CAAC;4CACH,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;yCAClB;qCACF,CAAC,CAAC;oCACH,OAAO,CAAC;wCACN,KAAK;wCACL,IAAI;qCACL,CAAC,CAAA;iCACH;6BACF,CAAC,CAAA;yBACH,CAAC;wBACF,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;qBAChC,CAAC,CAAA;iBACH;qBAAM;oBACL,OAAO;wBACL,KAAK,EAAE,EAAE;wBACT,IAAI,EAAE,IAAI;qBACX,CAAC;iBACH;aACF,CAAC,CAAC;SACJ,CAAA,CAAA;KA1XA;IAlID,IAAY,WAAW;;QACrB,aAAO,IAAI,CAAC,qBAAqB,0CAAE,WAAW,CAAC;KAChD;IAED,IAAY,MAAM;QAChB,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,qBAAqB,CAAC;QACpD,OAAO,GAAG,OAAO,IAAI,GAAG,EAAE,CAAC;KAC5B;IAED,IAAY,UAAU;QACpB,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAC9C,IAAI,CAAC,MAAM,EAAE;YACX,OAAO;SACR;QACD,IAAI,QAAQ,MAAM,CAAC,KAAK,QAAQ,EAAE;YAChC,OAAO,MAAM,CAAC;SACf;QACD,OAAO,MAAM,EAAE,CAAC;KACjB;;;;;YAtBF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YAXQ,YAAY;YAMZ,eAAe;4CAwInB,MAAM,SAAC,eAAe,cAAG,QAAQ;;;AChJtC;;;;;;"}
@@ -1,8 +1,6 @@
1
1
  import { __classPrivateFieldGet, __awaiter, __classPrivateFieldSet } from 'tslib';
2
2
  import { Pipe, Injectable, EventEmitter, Component, ChangeDetectorRef, Input, ViewChild, Output, NgModule } from '@angular/core';
3
3
  import { v4 } from 'uuid';
4
- import $ from 'jquery';
5
- import XLSX from 'xlsx';
6
4
  import { SdNotifyService, SdNotifyModule } from '@sd-angular/core/notify';
7
5
  import { SdLoadingService } from '@sd-angular/core/loading';
8
6
  import { SdTranslateService, SdTranslateModule } from '@sd-angular/core/translate';
@@ -50,7 +48,7 @@ SdColumnHiddenPipe.decorators = [
50
48
  ];
51
49
  SdColumnHiddenPipe.ctorParameters = () => [];
52
50
 
53
- var _paginator, _subscription, _reset, _reload, _isError, _isWarning, _isSuccess, _parse, _mapItem, _import, _isValidDate, _isValidTime, _isValidDateTime;
51
+ var _paginator, _subscription, _reset, _reload, _isError, _isWarning, _isSuccess, _parse, _mapItem, _isValidDate, _isValidTime, _isValidDateTime;
54
52
  class SdUploadExcel {
55
53
  constructor(ref, exportService, translateService, notifyService, sdColumnHidden, loadingService) {
56
54
  this.ref = ref;
@@ -118,7 +116,7 @@ class SdUploadExcel {
118
116
  try {
119
117
  const { mappingItems, errorValidation, warningValidation } = this.option;
120
118
  const { translate } = this.translateService;
121
- const { items, file } = yield __classPrivateFieldGet(this, _import).call(this);
119
+ const { items, file } = yield this.exportService.uploadXlsx();
122
120
  this.hasDescription = this.option.columns.some(e => !!e.description);
123
121
  const offset = this.hasDescription ? 2 : 1;
124
122
  items.splice(0, offset);
@@ -421,71 +419,6 @@ class SdUploadExcel {
421
419
  })
422
420
  }).finally(this.loadingService.stop);
423
421
  });
424
- _import.set(this, () => {
425
- const { translate } = this.translateService;
426
- return new Promise((resolve, reject) => {
427
- if ($(`#${this.importId}`).length) {
428
- $('body').children(`#${this.importId}`).remove();
429
- }
430
- $('body').append(`<input id="${this.importId}" style="display: none" type="file" />`);
431
- $(`#${this.importId}`).on('change', (evt) => {
432
- try {
433
- const target = evt.target;
434
- if (target.files.length !== 1) {
435
- throw new Error(translate('Cannot use multiple files'));
436
- }
437
- const file = target.files[0];
438
- const lastDot = file.name.lastIndexOf('.');
439
- if (lastDot === -1) {
440
- throw new Error(translate('Invalid file extension'));
441
- }
442
- const extension = file.name.substring(lastDot + 1);
443
- if (extension.toLowerCase() !== 'xlsx') {
444
- throw new Error(translate('Please upload .xlsx file'));
445
- }
446
- const reader = new FileReader();
447
- reader.onload = (e) => {
448
- const bstr = e.target.result;
449
- const wb = XLSX.read(bstr, { type: 'binary' });
450
- const wsname = wb.SheetNames[0];
451
- const ws = wb.Sheets[wsname];
452
- const lines = (XLSX.utils.sheet_to_json(ws, { header: 1 }));
453
- const records = [];
454
- const headers = lines[0];
455
- lines.splice(0, 1);
456
- lines.forEach(line => {
457
- const record = {};
458
- let hasValue = false;
459
- headers.forEach((header, index) => {
460
- record[header] = line[index];
461
- if (line[index] !== undefined && line[index] !== null && line[index].toString()) {
462
- hasValue = true;
463
- }
464
- if (typeof (record[header]) === 'string') {
465
- record[header] = record[header].trim();
466
- }
467
- if (record[header] === '' || record[header] === undefined) {
468
- record[header] = null;
469
- }
470
- });
471
- if (hasValue) {
472
- records.push(record);
473
- }
474
- });
475
- resolve({
476
- items: records,
477
- file: target.files[0]
478
- });
479
- };
480
- reader.readAsBinaryString(target.files[0]);
481
- }
482
- catch (error) {
483
- reject(error);
484
- }
485
- });
486
- $(`#${this.importId}`).trigger('click');
487
- });
488
- });
489
422
  _isValidDate.set(this, (format, value) => {
490
423
  if ((value === null || value === void 0 ? void 0 : value.length) !== (format === null || format === void 0 ? void 0 : format.length)) {
491
424
  return false;
@@ -532,7 +465,7 @@ class SdUploadExcel {
532
465
  __classPrivateFieldGet(this, _subscription).unsubscribe();
533
466
  }
534
467
  }
535
- _paginator = new WeakMap(), _subscription = new WeakMap(), _reset = new WeakMap(), _reload = new WeakMap(), _isError = new WeakMap(), _isWarning = new WeakMap(), _isSuccess = new WeakMap(), _parse = new WeakMap(), _mapItem = new WeakMap(), _import = new WeakMap(), _isValidDate = new WeakMap(), _isValidTime = new WeakMap(), _isValidDateTime = new WeakMap();
468
+ _paginator = new WeakMap(), _subscription = new WeakMap(), _reset = new WeakMap(), _reload = new WeakMap(), _isError = new WeakMap(), _isWarning = new WeakMap(), _isSuccess = new WeakMap(), _parse = new WeakMap(), _mapItem = new WeakMap(), _isValidDate = new WeakMap(), _isValidTime = new WeakMap(), _isValidDateTime = new WeakMap();
536
469
  SdUploadExcel.decorators = [
537
470
  { type: Component, args: [{
538
471
  selector: 'sd-upload-excel',
@@ -1 +1 @@
1
- {"version":3,"file":"sd-angular-core-upload-excel.js","sources":["../../../../projects/sd-core/upload-excel/src/lib/upload-excel.model.ts","../../../../projects/sd-core/upload-excel/src/lib/pipes/columm-hidden.pipe.ts","../../../../projects/sd-core/upload-excel/src/lib/upload-excel.component.ts","../../../../projects/sd-core/upload-excel/src/lib/pipes/column-transform.pipe.ts","../../../../projects/sd-core/upload-excel/src/lib/upload-excel.module.ts","../../../../projects/sd-core/upload-excel/sd-angular-core-upload-excel.ts"],"sourcesContent":["interface Validation {\r\n idx: number;\r\n message: string;\r\n}\r\n\r\nexport interface SdUploadExcelOption<T = any> {\r\n title?: string;\r\n note?: string;\r\n fileName?: string;\r\n columns?: SdUploadExcelColumn<T>[];\r\n limit?: number;\r\n key?: string;\r\n sheets?: {\r\n name: string,\r\n items: any[] | (() => Promise<any[]>),\r\n fields: string[]\r\n }[];\r\n onAccept?: (items?: T[], successItems?: T[], errorItems?: T[], warningItems?: T[], file?: File) => void | Promise<void>;\r\n mappingItems?: (items: SdExcelItem<T>[]) => SdExcelItem<T>[] | Promise<SdExcelItem<T>[]>;\r\n errorValidation?: (items?: T[]) => Validation[] | Promise<Validation[]>;\r\n warningValidation?: (items?: T[]) => Validation[] | Promise<Validation[]>;\r\n}\r\n\r\nexport interface SdUploadExcelSheet {\r\n name: string,\r\n items: any[] | (() => Promise<any[]>),\r\n fields: string[]\r\n}\r\n\r\nexport type SdUploadExcelColumn<T = any> =\r\n SdUploadExcelColumnString<T> |\r\n SdUploadExcelColumnNumber<T> |\r\n SdUploadExcelColumnBool<T> |\r\n SdUploadExcelColumnDate<T> |\r\n SdUploadExcelColumnTime<T> |\r\n SdUploadExcelColumnDateTime<T> |\r\n SdUploadExcelColumnValues<T> |\r\n SdUploadExcelColumnStringArray<T>;\r\n\r\nexport interface SdUploadExcelBaseColumn<T = any> {\r\n field: string;\r\n title: string;\r\n required?: boolean;\r\n width?: string;\r\n description?: string;\r\n hidden?: boolean | (() => boolean);\r\n fontColor?: string;\r\n fill?: string;\r\n transform?: (rowData: T, value: any) => string | Promise<string>;\r\n errorValidation?: (rowData?: T, value?: any, idx?: number) => string | Promise<string>;\r\n warningValidation?: (rowData?: T, value?: any, idx?: number) => string | Promise<string>;\r\n}\r\n\r\nexport interface SdUploadExcelColumnString<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'string';\r\n defaultValue?: string;\r\n pattern?: string;\r\n minLength?: number;\r\n maxLength?: number;\r\n}\r\n\r\nexport interface SdUploadExcelColumnNumber<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'number';\r\n defaultValue?: number;\r\n minValue?: number;\r\n maxValue?: number;\r\n}\r\n\r\nexport interface SdUploadExcelColumnBool<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'bool';\r\n defaultValue?: boolean;\r\n parseToBool?: boolean;\r\n}\r\n\r\nexport interface SdUploadExcelColumnDate<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'date';\r\n format?: 'dd/MM/yyyy';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnTime<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'time';\r\n format?: 'HH:mm' | 'HH:mm:ss';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnDateTime<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'datetime';\r\n format?: 'dd/MM/yyyy HH:mm' | 'dd/MM/yyyy';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnValues<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'values' | 'radio';\r\n defaultValue?: string | number;\r\n values: (string | number)[];\r\n checkValueInArray?: boolean;\r\n}\r\n\r\nexport interface SdUploadExcelColumnStringArray<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'array';\r\n divideString: string | ';';\r\n unitString: string | 'items';\r\n defaultValue?: string;\r\n minLength?: number;\r\n maxLength?: number;\r\n}\r\n\r\nexport interface SdUploadExcelValidation {\r\n error?: string;\r\n warning?: string;\r\n success?: string;\r\n data?: {\r\n [column: string]: {\r\n error?: string;\r\n warning?: string;\r\n }\r\n };\r\n}\r\n\r\nexport type SdExcelItem<T = any> = {\r\n data: T;\r\n sd?: {\r\n excelIndex?: number;\r\n origin?: T,\r\n validation?: SdUploadExcelValidation;\r\n }\r\n};\r\n\r\n// export type ExcelItem<T> = {\r\n// origin?: T;\r\n// excelIndex?: number;\r\n// validation: SdUploadExcelValidation;\r\n// } & T;\r\n","import { Injectable, Pipe, PipeTransform } from '@angular/core';\r\nimport { SdUploadExcelColumn } from '../upload-excel.model';\r\n@Pipe({\r\n name: 'columnHidden'\r\n})\r\n@Injectable()\r\nexport class SdColumnHiddenPipe implements PipeTransform {\r\n constructor() { }\r\n transform(column: SdUploadExcelColumn): boolean {\r\n if (column.hidden === undefined) {\r\n return true;\r\n }\r\n if (typeof (column.hidden) === 'boolean') {\r\n return !column.hidden;\r\n }\r\n if (typeof (column.hidden) === 'function') {\r\n return !column.hidden();\r\n }\r\n return false;\r\n }\r\n}\r\n","import { Component, OnInit, Input, ViewChild, ChangeDetectorRef, OnDestroy, Output, EventEmitter } from '@angular/core';\r\nimport * as uuid from 'uuid';\r\nimport $ from 'jquery';\r\nimport XLSX from 'xlsx';\r\n\r\nimport {\r\n SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n SdLoadingService\r\n} from '@sd-angular/core/loading';\r\n\r\nimport {\r\n SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\nimport { SdExcelItem, SdUploadExcelOption, SdUploadExcelValidation } from './upload-excel.model';\r\nimport { SdExportTempateColumn, SdExportTemplate, SdExportService } from '@sd-angular/core/export';\r\nimport { SdColumnHiddenPipe } from './pipes/columm-hidden.pipe';\r\ntype AOA = Array<Array<any>>;\r\n\r\n@Component({\r\n selector: 'sd-upload-excel',\r\n templateUrl: './upload-excel.component.html',\r\n styleUrls: ['./upload-excel.component.scss']\r\n})\r\nexport class SdUploadExcel implements OnInit, OnDestroy {\r\n private importId = 'I' + uuid.v4();\r\n @Input() option: SdUploadExcelOption;\r\n @ViewChild('modal') modal: SdModal;\r\n items: SdExcelItem[] = [];\r\n // originItems: SdExcelItem[] = [];\r\n hasDescription = false;\r\n\r\n showing: 'ALL' | 'SUCCESS' | 'WARNING' | 'ERROR' = 'ALL';\r\n filteredItems: SdExcelItem[] = [];\r\n viewItems: SdExcelItem[] = [];\r\n numberOfSuccess = 0;\r\n numberOfError = 0;\r\n numberOfWarning = 0;\r\n file: File;\r\n #paginator: MatPaginator;\r\n @ViewChild(MatPaginator) set paginator(paginator: MatPaginator) {\r\n if (paginator && this.#paginator !== paginator) {\r\n this.#paginator = paginator;\r\n this.#subscription.add(paginator.page.subscribe(this.#reload));\r\n }\r\n }\r\n #subscription = new Subscription();\r\n uploading: boolean;\r\n isUploaded: boolean;\r\n isDownloadTemplate = false;\r\n @Output() sdClosed = new EventEmitter();\r\n constructor(\r\n private ref: ChangeDetectorRef,\r\n private exportService: SdExportService,\r\n private translateService: SdTranslateService,\r\n private notifyService: SdNotifyService,\r\n private sdColumnHidden: SdColumnHiddenPipe,\r\n private loadingService: SdLoadingService) {\r\n }\r\n\r\n ngOnInit() {\r\n this.isUploaded = false;\r\n }\r\n\r\n ngOnDestroy() {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n open = () => {\r\n this.#reset();\r\n this.modal.open();\r\n }\r\n\r\n close = () => {\r\n this.modal.close();\r\n }\r\n\r\n #reset = () => {\r\n this.items = [];\r\n this.filteredItems = [];\r\n this.viewItems = [];\r\n this.numberOfSuccess = 0;\r\n this.numberOfError = 0;\r\n this.numberOfWarning = 0;\r\n this.showing = 'ALL';\r\n }\r\n\r\n #reload = () => {\r\n const pageIndex = this.#paginator.pageIndex;\r\n const pageSize = this.#paginator.pageSize;\r\n this.filteredItems = this.items.filter((item) => {\r\n const { validation } = item.sd;\r\n if (this.showing === 'SUCCESS') {\r\n return !validation?.error && !validation?.warning;\r\n } else if (this.showing === 'WARNING') {\r\n return !!validation?.warning && !validation?.error;\r\n } else if (this.showing === 'ERROR') {\r\n return !!validation?.error;\r\n }\r\n return true;\r\n });\r\n this.viewItems = this.filteredItems\r\n .filter((item, index) => index >= pageIndex * pageSize && index < (pageIndex + 1) * pageSize);\r\n\r\n this.numberOfSuccess = this.items.filter(this.#isSuccess).length;\r\n this.numberOfError = this.items.filter(this.#isError).length;\r\n this.numberOfWarning = this.items.filter(this.#isWarning).length;\r\n }\r\n\r\n #isError = (item: SdExcelItem) => !!item.sd.validation.error;\r\n #isWarning = (item: SdExcelItem) => item.sd.validation?.warning && !item.sd.validation?.error;\r\n #isSuccess = (item: SdExcelItem) => !item.sd.validation?.error && !item.sd.validation?.warning;\r\n\r\n upload = async () => {\r\n try {\r\n const { mappingItems, errorValidation, warningValidation } = this.option;\r\n const { translate } = this.translateService;\r\n const { items, file } = await this.#import();\r\n this.hasDescription = this.option.columns.some(e => !!e.description);\r\n const offset = this.hasDescription ? 2 : 1;\r\n items.splice(0, offset);\r\n if (items.length === 0) {\r\n this.notifyService.notify.warning(`${translate(`No data to import`)}`);\r\n return;\r\n }\r\n if (items.length > this.option.limit) {\r\n this.notifyService.notify.warning(`${translate(`Limit rows`)}: ${this.option.limit}`);\r\n return;\r\n }\r\n this.#reset();\r\n // this.originItems = items.map(data => ({\r\n // data,\r\n // sd: {}\r\n // }));\r\n this.items = items.map((data, idx) => ({\r\n data,\r\n sd: {\r\n excelIndex: idx + (this.hasDescription ? 4 : 3),\r\n validation: {\r\n data: {}\r\n },\r\n origin: { ...data }\r\n }\r\n }));\r\n\r\n if (mappingItems) {\r\n const mappedItems = mappingItems(this.items);\r\n if (mappedItems instanceof Promise) {\r\n this.uploading = true;\r\n this.items = (await mappedItems.finally(() => this.uploading = false));\r\n } else {\r\n this.items = (mappedItems || this.items);\r\n }\r\n }\r\n this.file = file;\r\n this.loadingService.start();\r\n for (const [idx, item] of this.items.entries()) {\r\n await this.validate(item, idx);\r\n }\r\n\r\n // Nếu không có error thì tiếp tục validate từ option validate truyền vào\r\n if (!this.items.some(this.#isError) && errorValidation) {\r\n const results = await errorValidation(this.items.map(e => e.data));\r\n results.forEach(result => this.items[result.idx].sd.validation.error = result.message);\r\n }\r\n\r\n // Nếu không có warning thì tiếp tục validate từ option validate truyền vào\r\n if (!this.items.some(this.#isWarning) && warningValidation) {\r\n const results = await warningValidation(this.items.map(e => e.data));\r\n results.forEach(result => this.items[result.idx].sd.validation.warning = result.message);\r\n }\r\n\r\n this.#paginator.pageIndex = 0;\r\n this.#reload();\r\n this.ref.detectChanges();\r\n\r\n this.isUploaded = false;\r\n } catch (err) {\r\n this.notifyService.handle.error(err);\r\n } finally {\r\n this.loadingService.stop();\r\n }\r\n }\r\n\r\n validate = async (excelItem: SdExcelItem, idx: number) => {\r\n const { data: item, sd: { validation } } = excelItem;\r\n const { translate } = this.translateService;\r\n const errors: string[] = [];\r\n for (const column of this.option.columns) {\r\n validation.data[column.field] = {};\r\n if (!this.sdColumnHidden.transform(column)) {\r\n continue;\r\n }\r\n try {\r\n if (column.defaultValue !== undefined) {\r\n item[column.field] = item[column.field] ?? column.defaultValue;\r\n } else if (column.required && !item[column.field] && item[column.field] !== 0) {\r\n validation.data[column.field].error = `${translate('required')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.type === 'string') {\r\n const value = (item[column.field] || '').toString();\r\n if (column.minLength !== undefined && value.length < column.minLength) {\r\n validation.data[column.field].error = `${translate('Min length')}: ${column.minLength}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.maxLength !== undefined && value.length > column.maxLength) {\r\n validation.data[column.field].error = `${translate('Max length')}: ${column.maxLength}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = value;\r\n } else if (column.type === 'number') {\r\n if (item[column.field]) {\r\n const value = +item[column.field];\r\n if (Number.isNaN(value)) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('is not a number')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = value;\r\n }\r\n if (!item[column.field] && item[column.field] !== 0) {\r\n item[column.field] = undefined;\r\n }\r\n if (column.minValue !== undefined && item[column.field] < column.minValue) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Min value')}: ${column.minValue}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.maxValue !== undefined && item[column.field] > column.maxValue) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Max value')}: ${column.maxValue}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n } else if (column.type === 'bool') {\r\n if (item[column.field] === 0 || item[column.field] === false) {\r\n item[column.field] = '0';\r\n }\r\n if (item[column.field] === 1 || item[column.field] === true) {\r\n item[column.field] = '1';\r\n }\r\n\r\n if (item[column.field]) {\r\n const value = +item[column.field];\r\n if (Number.isNaN(value) || (value !== 0 && value !== 1)) {\r\n validation.data[column.field].error = `${translate('Value shoud be 0 or 1')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n } else {\r\n if (column.parseToBool) {\r\n item[column.field] = item[column.field] === '1';\r\n }\r\n }\r\n }\r\n } else if (column.type === 'values') {\r\n if (item[column.field] && typeof (item[column.field]) !== 'number' && typeof (item[column.field]) !== 'string') {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Invalid data type')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.checkValueInArray && item[column.field] && !column.values.some(e => e.toString() === item[column.field].toString())) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Value not in')} [${column.values.join()}]`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n } else if (column.type === 'date' || column.type === 'datetime' || column.type === 'time') {\r\n const { type, format } = column;\r\n const val = item[column.field];\r\n if (format && item[column.field]) {\r\n if (typeof (val) !== 'string') {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'date' && !this.#isValidDate(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'time' && !this.#isValidTime(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'datetime' && !this.#isValidDateTime(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = Date.parseFrom(val, column.format).toFormat('MM/dd/yyyy HH:mm:ss');\r\n }\r\n if (item[column.field] && !Date.isDate(item[column.field])) {\r\n validation.data[column.field].error = `${translate('Invalid date')}: ${item[column.field]}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n }\r\n\r\n if (!validation.data[column.field].error && column.errorValidation) {\r\n const error = await column.errorValidation(item, item[column.field], idx);\r\n if (error) {\r\n validation.data[column.field].error = `${error}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n }\r\n }\r\n\r\n if (!validation.data[column.field].warning && column.warningValidation) {\r\n const warning = await column.warningValidation(item, item[column.field], idx);\r\n if (warning) {\r\n validation.data[column.field].warning = `${warning}`;\r\n validation.warning += `<strong>[${column.title || column.field}]</strong> ${warning}<br>`;\r\n }\r\n }\r\n } catch (ex) {\r\n validation.data[column.field].error = `${ex?.message || ex?.error || ex || 'Có lỗi xảy ra'}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n }\r\n }\r\n validation.error = errors.join('<br>');\r\n }\r\n\r\n #parse = (item: SdExcelItem) => {\r\n const { data } = item;\r\n return data;\r\n }\r\n\r\n #mapItem = (item: SdExcelItem) => {\r\n const { data } = item;\r\n return data;\r\n }\r\n\r\n accept = () => {\r\n const successItems = this.items.filter(this.#isSuccess).map(this.#mapItem);\r\n const errorItems = this.items.filter(this.#isError).map(this.#mapItem);\r\n const warningItems = this.items.filter(this.#isWarning).map(this.#mapItem);\r\n this.option?.onAccept(this.items.map(this.#mapItem), successItems, errorItems, warningItems, this.file);\r\n this.isUploaded = true;\r\n }\r\n\r\n setValidation = (validates: { idx: number, messageError?: string, messageWarning?: string, messageSuccess?: string }[]) => {\r\n if (Array.isArray(validates)) {\r\n validates.forEach(validate => {\r\n this.items[validate.idx].sd.validation.error = validate.messageError;\r\n this.items[validate.idx].sd.validation.warning = validate.messageWarning;\r\n this.items[validate.idx].sd.validation.success = validate.messageSuccess;\r\n });\r\n }\r\n this.#reload();\r\n this.ref.detectChanges();\r\n }\r\n\r\n view = (showing: 'ALL' | 'SUCCESS' | 'WARNING' | 'ERROR' = 'ALL') => {\r\n this.showing = showing;\r\n this.#paginator.pageIndex = 0;\r\n this.#reload();\r\n }\r\n\r\n downloadTemplate = async () => {\r\n const sheets: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[] = [];\r\n if (Array.isArray(this.option?.sheets)) {\r\n for (const sheet of this.option.sheets) {\r\n if (sheet.name && sheet.items && sheet.fields) {\r\n if (Array.isArray(sheet.items)) {\r\n sheets.push({\r\n name: sheet.name,\r\n items: sheet.items,\r\n fields: sheet.fields\r\n });\r\n } else {\r\n sheets.push({\r\n name: sheet.name,\r\n items: await sheet.items(),\r\n fields: sheet.fields\r\n });\r\n }\r\n }\r\n }\r\n }\r\n const columnNotHiddens = this.option.columns.filter(column => this.sdColumnHidden.transform(column));\r\n const excelTemplate: SdExportTemplate = {\r\n fileName: this.option.fileName || 'Template',\r\n columns: columnNotHiddens.map(column => {\r\n return {\r\n field: column.field,\r\n title: column.title,\r\n width: column.width,\r\n required: column.required,\r\n description: column.description,\r\n fontColor: column.fontColor,\r\n fill: column.fill\r\n };\r\n }),\r\n sheets\r\n };\r\n this.isDownloadTemplate = true;\r\n await this.exportService.generateTemplate(excelTemplate).finally(() => {\r\n this.isDownloadTemplate = false;\r\n });\r\n }\r\n\r\n export = async () => {\r\n this.loadingService.start();\r\n const columns: SdExportTempateColumn[] = [{\r\n field: 'sdMessage',\r\n title: this.translateService.translate('Upload message'),\r\n width: '250px',\r\n required: false\r\n }, ... this.option.columns.filter(column => this.sdColumnHidden.transform(column))];\r\n await this.exportService.export({\r\n columns,\r\n items: this.filteredItems.map(e => {\r\n let result = {};\r\n for (const column of columns) {\r\n result = {\r\n ...result,\r\n [column.field]: e.sd.origin?.[column.field]\r\n }\r\n }\r\n return {\r\n ...result,\r\n sdMessage: (e.sd.validation?.error || e.sd.validation?.warning || e.sd.validation?.success)?.replace(/<strong>/g, '')\r\n .replace(/<\\/strong>/g, '')\r\n .replace(/<br>/g, '\\n')\r\n };\r\n })\r\n }).finally(this.loadingService.stop);\r\n }\r\n\r\n #import = () => {\r\n const { translate } = this.translateService;\r\n return new Promise<{ items: any[], file: File }>((resolve, reject) => {\r\n if ($(`#${this.importId}`).length) {\r\n $('body').children(`#${this.importId}`).remove();\r\n }\r\n $('body').append(`<input id=\"${this.importId}\" style=\"display: none\" type=\"file\" />`);\r\n\r\n $(`#${this.importId}`).on('change', (evt: any) => {\r\n try {\r\n const target: DataTransfer = evt.target;\r\n if (target.files.length !== 1) {\r\n throw new Error(translate('Cannot use multiple files'));\r\n }\r\n const file = target.files[0];\r\n const lastDot = file.name.lastIndexOf('.');\r\n if (lastDot === -1) {\r\n throw new Error(translate('Invalid file extension'));\r\n }\r\n const extension = file.name.substring(lastDot + 1);\r\n if (extension.toLowerCase() !== 'xlsx') {\r\n throw new Error(translate('Please upload .xlsx file'));\r\n }\r\n const reader: FileReader = new FileReader();\r\n reader.onload = (e: any) => {\r\n const bstr: string = e.target.result;\r\n const wb: XLSX.WorkBook = XLSX.read(bstr, { type: 'binary' });\r\n const wsname: string = wb.SheetNames[0];\r\n const ws: XLSX.WorkSheet = wb.Sheets[wsname];\r\n const lines: AOA = (XLSX.utils.sheet_to_json(ws, { header: 1 }));\r\n const records = [];\r\n const headers = lines[0];\r\n lines.splice(0, 1);\r\n lines.forEach(line => {\r\n const record = {};\r\n let hasValue = false;\r\n headers.forEach((header, index) => {\r\n record[header] = line[index];\r\n if (line[index] !== undefined && line[index] !== null && line[index].toString()) {\r\n hasValue = true;\r\n }\r\n if (typeof (record[header]) === 'string') {\r\n record[header] = record[header].trim();\r\n }\r\n if (record[header] === '' || record[header] === undefined) {\r\n record[header] = null;\r\n }\r\n });\r\n if (hasValue) {\r\n records.push(record);\r\n }\r\n });\r\n resolve({\r\n items: records,\r\n file: target.files[0]\r\n });\r\n };\r\n reader.readAsBinaryString(target.files[0]);\r\n } catch (error) {\r\n reject(error);\r\n }\r\n });\r\n $(`#${this.importId}`).trigger('click');\r\n });\r\n }\r\n\r\n #isValidDate = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n const regex = /^(?:(?:31(\\/|-|\\.)(?:0?[13578]|1[02]))\\1|(?:(?:29|30)(\\/|-|\\.)(?:0?[13-9]|1[0-2])\\2))(?:(?:1[6-9]|[2-9]\\d)?\\d{2})$|^(?:29(\\/|-|\\.)0?2\\3(?:(?:(?:1[6-9]|[2-9]\\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))$|^(?:0?[1-9]|1\\d|2[0-8])(\\/|-|\\.)(?:(?:0?[1-9])|(?:1[0-2]))\\4(?:(?:1[6-9]|[2-9]\\d)?\\d{2})$/;\r\n return regex.test(value);\r\n }\r\n\r\n #isValidTime = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n #isValidDateTime = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n const dates = value?.split(' ');\r\n if (dates.length !== 2) {\r\n return false;\r\n }\r\n const date = dates[0];\r\n if (!this.#isValidDate('dd/MM/yyyy', date)) {\r\n return false;\r\n }\r\n const time = dates[1];\r\n const regex = /^(0[0-9]|1[0-9]|2[0-3])(\\:)(0[0-9]|[0-5][0-9])$/;\r\n return regex.test(time);\r\n }\r\n onClosed = () => {\r\n this.sdClosed.emit();\r\n }\r\n}\r\n\r\n","import { DecimalPipe } from '@angular/common';\r\nimport { Pipe, PipeTransform } from '@angular/core';\r\nimport { SdExcelItem, SdUploadExcelColumn } from '../upload-excel.model';\r\n@Pipe({\r\n name: 'columnTransform'\r\n})\r\nexport class SdColumnTransformPipe implements PipeTransform {\r\n constructor(private decimalPipe: DecimalPipe) {\r\n\r\n }\r\n transform = async (rowData: SdExcelItem, column: SdUploadExcelColumn): Promise<string> => {\r\n const { type, transform } = column;\r\n const value = rowData.data[column.field];\r\n if (rowData.sd.validation.data[column.field]?.error) {\r\n return rowData.sd.origin[column.field] ?? value ?? '';\r\n }\r\n if (transform) {\r\n return transform(rowData.data, value);\r\n }\r\n if (column.type === 'number') {\r\n return Number.toVNCurrency(value) ?? '';\r\n }\r\n if (column.type === 'bool') {\r\n if (value === '1' || value === true) {\r\n return `<div class=\"text-center\"><input type=\"checkbox\" checked disabled></div>`;\r\n } else if (value === '0' || value === false) {\r\n return `<div class=\"text-center\"><input type=\"checkbox\" disabled></div>`;\r\n }\r\n }\r\n if (column.type === 'date') {\r\n return Date.toFormat(value, column.format || 'dd/MM/yyyy') ?? '';\r\n }\r\n if (column.type === 'datetime') {\r\n return Date.toFormat(value, column.format || 'dd/MM/yyyy HH:mm') ?? '';\r\n }\r\n return value ?? '';\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule, DecimalPipe } from '@angular/common';\r\nimport { DeviceDetectorModule } from 'ngx-device-detector';\r\nimport { SdNotifyModule } from '@sd-angular/core/notify';\r\nimport { SdTranslateModule } from '@sd-angular/core/translate';\r\nimport { SdUploadExcel } from './upload-excel.component';\r\nimport { SdButtonModule } from '@sd-angular/core/button';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\nimport { SdModalModule } from '@sd-angular/core/modal';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatPaginatorModule } from '@angular/material/paginator';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { SdInputModule } from '@sd-angular/core/input';\r\nimport { SdUtilityModule } from '@sd-angular/core/utility';\r\nimport {MatIconModule} from '@angular/material/icon';\r\nimport {MatMenuModule} from '@angular/material/menu';\r\nimport { SdColumnHiddenPipe } from './pipes/columm-hidden.pipe';\r\nimport { SdColumnTransformPipe } from './pipes/column-transform.pipe';\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n DeviceDetectorModule.forRoot(),\r\n MatSlideToggleModule,\r\n MatTooltipModule,\r\n MatPaginatorModule,\r\n MatSlideToggleModule,\r\n SdNotifyModule,\r\n SdTranslateModule,\r\n SdUtilityModule,\r\n SdButtonModule,\r\n SdModalModule,\r\n SdInputModule,\r\n MatIconModule,\r\n MatMenuModule\r\n ],\r\n declarations: [\r\n SdUploadExcel,\r\n // pipe\r\n SdColumnHiddenPipe,\r\n SdColumnTransformPipe\r\n ],\r\n exports: [\r\n SdUploadExcel\r\n ],\r\n providers: [\r\n DecimalPipe,\r\n SdColumnHiddenPipe\r\n ]\r\n})\r\nexport class SdUploadExcelModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdColumnHiddenPipe as ɵa} from './src/lib/pipes/columm-hidden.pipe';\nexport {SdColumnTransformPipe as ɵb} from './src/lib/pipes/column-transform.pipe';"],"names":["uuid.v4"],"mappings":"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"}
1
+ {"version":3,"file":"sd-angular-core-upload-excel.js","sources":["../../../../projects/sd-core/upload-excel/src/lib/upload-excel.model.ts","../../../../projects/sd-core/upload-excel/src/lib/pipes/columm-hidden.pipe.ts","../../../../projects/sd-core/upload-excel/src/lib/upload-excel.component.ts","../../../../projects/sd-core/upload-excel/src/lib/pipes/column-transform.pipe.ts","../../../../projects/sd-core/upload-excel/src/lib/upload-excel.module.ts","../../../../projects/sd-core/upload-excel/sd-angular-core-upload-excel.ts"],"sourcesContent":["interface Validation {\r\n idx: number;\r\n message: string;\r\n}\r\n\r\nexport interface SdUploadExcelOption<T = any> {\r\n title?: string;\r\n note?: string;\r\n fileName?: string;\r\n columns?: SdUploadExcelColumn<T>[];\r\n limit?: number;\r\n key?: string;\r\n sheets?: {\r\n name: string,\r\n items: any[] | (() => Promise<any[]>),\r\n fields: string[]\r\n }[];\r\n onAccept?: (items?: T[], successItems?: T[], errorItems?: T[], warningItems?: T[], file?: File) => void | Promise<void>;\r\n mappingItems?: (items: SdExcelItem<T>[]) => SdExcelItem<T>[] | Promise<SdExcelItem<T>[]>;\r\n errorValidation?: (items?: T[]) => Validation[] | Promise<Validation[]>;\r\n warningValidation?: (items?: T[]) => Validation[] | Promise<Validation[]>;\r\n}\r\n\r\nexport interface SdUploadExcelSheet {\r\n name: string,\r\n items: any[] | (() => Promise<any[]>),\r\n fields: string[]\r\n}\r\n\r\nexport type SdUploadExcelColumn<T = any> =\r\n SdUploadExcelColumnString<T> |\r\n SdUploadExcelColumnNumber<T> |\r\n SdUploadExcelColumnBool<T> |\r\n SdUploadExcelColumnDate<T> |\r\n SdUploadExcelColumnTime<T> |\r\n SdUploadExcelColumnDateTime<T> |\r\n SdUploadExcelColumnValues<T> |\r\n SdUploadExcelColumnStringArray<T>;\r\n\r\nexport interface SdUploadExcelBaseColumn<T = any> {\r\n field: string;\r\n title: string;\r\n required?: boolean;\r\n width?: string;\r\n description?: string;\r\n hidden?: boolean | (() => boolean);\r\n fontColor?: string;\r\n fill?: string;\r\n transform?: (rowData: T, value: any) => string | Promise<string>;\r\n errorValidation?: (rowData?: T, value?: any, idx?: number) => string | Promise<string>;\r\n warningValidation?: (rowData?: T, value?: any, idx?: number) => string | Promise<string>;\r\n}\r\n\r\nexport interface SdUploadExcelColumnString<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'string';\r\n defaultValue?: string;\r\n pattern?: string;\r\n minLength?: number;\r\n maxLength?: number;\r\n}\r\n\r\nexport interface SdUploadExcelColumnNumber<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'number';\r\n defaultValue?: number;\r\n minValue?: number;\r\n maxValue?: number;\r\n}\r\n\r\nexport interface SdUploadExcelColumnBool<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'bool';\r\n defaultValue?: boolean;\r\n parseToBool?: boolean;\r\n}\r\n\r\nexport interface SdUploadExcelColumnDate<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'date';\r\n format?: 'dd/MM/yyyy';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnTime<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'time';\r\n format?: 'HH:mm' | 'HH:mm:ss';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnDateTime<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'datetime';\r\n format?: 'dd/MM/yyyy HH:mm' | 'dd/MM/yyyy';\r\n defaultValue?: Date;\r\n minDate?: Date;\r\n maxDate?: Date;\r\n}\r\n\r\nexport interface SdUploadExcelColumnValues<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'values' | 'radio';\r\n defaultValue?: string | number;\r\n values: (string | number)[];\r\n checkValueInArray?: boolean;\r\n}\r\n\r\nexport interface SdUploadExcelColumnStringArray<T = any> extends SdUploadExcelBaseColumn<T> {\r\n type: 'array';\r\n divideString: string | ';';\r\n unitString: string | 'items';\r\n defaultValue?: string;\r\n minLength?: number;\r\n maxLength?: number;\r\n}\r\n\r\nexport interface SdUploadExcelValidation {\r\n error?: string;\r\n warning?: string;\r\n success?: string;\r\n data?: {\r\n [column: string]: {\r\n error?: string;\r\n warning?: string;\r\n }\r\n };\r\n}\r\n\r\nexport type SdExcelItem<T = any> = {\r\n data: T;\r\n sd?: {\r\n excelIndex?: number;\r\n origin?: T,\r\n validation?: SdUploadExcelValidation;\r\n }\r\n};\r\n\r\n// export type ExcelItem<T> = {\r\n// origin?: T;\r\n// excelIndex?: number;\r\n// validation: SdUploadExcelValidation;\r\n// } & T;\r\n","import { Injectable, Pipe, PipeTransform } from '@angular/core';\r\nimport { SdUploadExcelColumn } from '../upload-excel.model';\r\n@Pipe({\r\n name: 'columnHidden'\r\n})\r\n@Injectable()\r\nexport class SdColumnHiddenPipe implements PipeTransform {\r\n constructor() { }\r\n transform(column: SdUploadExcelColumn): boolean {\r\n if (column.hidden === undefined) {\r\n return true;\r\n }\r\n if (typeof (column.hidden) === 'boolean') {\r\n return !column.hidden;\r\n }\r\n if (typeof (column.hidden) === 'function') {\r\n return !column.hidden();\r\n }\r\n return false;\r\n }\r\n}\r\n","import { Component, OnInit, Input, ViewChild, ChangeDetectorRef, OnDestroy, Output, EventEmitter } from '@angular/core';\r\nimport * as uuid from 'uuid';\r\n\r\nimport {\r\n SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n SdLoadingService\r\n} from '@sd-angular/core/loading';\r\n\r\nimport {\r\n SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\nimport { SdExcelItem, SdUploadExcelOption, SdUploadExcelValidation } from './upload-excel.model';\r\nimport { SdExportTempateColumn, SdExportTemplate, SdExportService } from '@sd-angular/core/export';\r\nimport { SdColumnHiddenPipe } from './pipes/columm-hidden.pipe';\r\ntype AOA = Array<Array<any>>;\r\n\r\n@Component({\r\n selector: 'sd-upload-excel',\r\n templateUrl: './upload-excel.component.html',\r\n styleUrls: ['./upload-excel.component.scss']\r\n})\r\nexport class SdUploadExcel implements OnInit, OnDestroy {\r\n private importId = 'I' + uuid.v4();\r\n @Input() option: SdUploadExcelOption;\r\n @ViewChild('modal') modal: SdModal;\r\n items: SdExcelItem[] = [];\r\n // originItems: SdExcelItem[] = [];\r\n hasDescription = false;\r\n\r\n showing: 'ALL' | 'SUCCESS' | 'WARNING' | 'ERROR' = 'ALL';\r\n filteredItems: SdExcelItem[] = [];\r\n viewItems: SdExcelItem[] = [];\r\n numberOfSuccess = 0;\r\n numberOfError = 0;\r\n numberOfWarning = 0;\r\n file: File;\r\n #paginator: MatPaginator;\r\n @ViewChild(MatPaginator) set paginator(paginator: MatPaginator) {\r\n if (paginator && this.#paginator !== paginator) {\r\n this.#paginator = paginator;\r\n this.#subscription.add(paginator.page.subscribe(this.#reload));\r\n }\r\n }\r\n #subscription = new Subscription();\r\n uploading: boolean;\r\n isUploaded: boolean;\r\n isDownloadTemplate = false;\r\n @Output() sdClosed = new EventEmitter();\r\n constructor(\r\n private ref: ChangeDetectorRef,\r\n private exportService: SdExportService,\r\n private translateService: SdTranslateService,\r\n private notifyService: SdNotifyService,\r\n private sdColumnHidden: SdColumnHiddenPipe,\r\n private loadingService: SdLoadingService) {\r\n }\r\n\r\n ngOnInit() {\r\n this.isUploaded = false;\r\n }\r\n\r\n ngOnDestroy() {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n open = () => {\r\n this.#reset();\r\n this.modal.open();\r\n }\r\n\r\n close = () => {\r\n this.modal.close();\r\n }\r\n\r\n #reset = () => {\r\n this.items = [];\r\n this.filteredItems = [];\r\n this.viewItems = [];\r\n this.numberOfSuccess = 0;\r\n this.numberOfError = 0;\r\n this.numberOfWarning = 0;\r\n this.showing = 'ALL';\r\n }\r\n\r\n #reload = () => {\r\n const pageIndex = this.#paginator.pageIndex;\r\n const pageSize = this.#paginator.pageSize;\r\n this.filteredItems = this.items.filter((item) => {\r\n const { validation } = item.sd;\r\n if (this.showing === 'SUCCESS') {\r\n return !validation?.error && !validation?.warning;\r\n } else if (this.showing === 'WARNING') {\r\n return !!validation?.warning && !validation?.error;\r\n } else if (this.showing === 'ERROR') {\r\n return !!validation?.error;\r\n }\r\n return true;\r\n });\r\n this.viewItems = this.filteredItems\r\n .filter((item, index) => index >= pageIndex * pageSize && index < (pageIndex + 1) * pageSize);\r\n\r\n this.numberOfSuccess = this.items.filter(this.#isSuccess).length;\r\n this.numberOfError = this.items.filter(this.#isError).length;\r\n this.numberOfWarning = this.items.filter(this.#isWarning).length;\r\n }\r\n\r\n #isError = (item: SdExcelItem) => !!item.sd.validation.error;\r\n #isWarning = (item: SdExcelItem) => item.sd.validation?.warning && !item.sd.validation?.error;\r\n #isSuccess = (item: SdExcelItem) => !item.sd.validation?.error && !item.sd.validation?.warning;\r\n\r\n upload = async () => {\r\n try {\r\n const { mappingItems, errorValidation, warningValidation } = this.option;\r\n const { translate } = this.translateService;\r\n const { items, file } = await this.exportService.uploadXlsx();\r\n this.hasDescription = this.option.columns.some(e => !!e.description);\r\n const offset = this.hasDescription ? 2 : 1;\r\n items.splice(0, offset);\r\n if (items.length === 0) {\r\n this.notifyService.notify.warning(`${translate(`No data to import`)}`);\r\n return;\r\n }\r\n if (items.length > this.option.limit) {\r\n this.notifyService.notify.warning(`${translate(`Limit rows`)}: ${this.option.limit}`);\r\n return;\r\n }\r\n this.#reset();\r\n // this.originItems = items.map(data => ({\r\n // data,\r\n // sd: {}\r\n // }));\r\n this.items = items.map((data, idx) => ({\r\n data,\r\n sd: {\r\n excelIndex: idx + (this.hasDescription ? 4 : 3),\r\n validation: {\r\n data: {}\r\n },\r\n origin: { ...data }\r\n }\r\n }));\r\n\r\n if (mappingItems) {\r\n const mappedItems = mappingItems(this.items);\r\n if (mappedItems instanceof Promise) {\r\n this.uploading = true;\r\n this.items = (await mappedItems.finally(() => this.uploading = false));\r\n } else {\r\n this.items = (mappedItems || this.items);\r\n }\r\n }\r\n this.file = file;\r\n this.loadingService.start();\r\n for (const [idx, item] of this.items.entries()) {\r\n await this.validate(item, idx);\r\n }\r\n\r\n // Nếu không có error thì tiếp tục validate từ option validate truyền vào\r\n if (!this.items.some(this.#isError) && errorValidation) {\r\n const results = await errorValidation(this.items.map(e => e.data));\r\n results.forEach(result => this.items[result.idx].sd.validation.error = result.message);\r\n }\r\n\r\n // Nếu không có warning thì tiếp tục validate từ option validate truyền vào\r\n if (!this.items.some(this.#isWarning) && warningValidation) {\r\n const results = await warningValidation(this.items.map(e => e.data));\r\n results.forEach(result => this.items[result.idx].sd.validation.warning = result.message);\r\n }\r\n\r\n this.#paginator.pageIndex = 0;\r\n this.#reload();\r\n this.ref.detectChanges();\r\n\r\n this.isUploaded = false;\r\n } catch (err) {\r\n this.notifyService.handle.error(err);\r\n } finally {\r\n this.loadingService.stop();\r\n }\r\n }\r\n\r\n validate = async (excelItem: SdExcelItem, idx: number) => {\r\n const { data: item, sd: { validation } } = excelItem;\r\n const { translate } = this.translateService;\r\n const errors: string[] = [];\r\n for (const column of this.option.columns) {\r\n validation.data[column.field] = {};\r\n if (!this.sdColumnHidden.transform(column)) {\r\n continue;\r\n }\r\n try {\r\n if (column.defaultValue !== undefined) {\r\n item[column.field] = item[column.field] ?? column.defaultValue;\r\n } else if (column.required && !item[column.field] && item[column.field] !== 0) {\r\n validation.data[column.field].error = `${translate('required')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.type === 'string') {\r\n const value = (item[column.field] || '').toString();\r\n if (column.minLength !== undefined && value.length < column.minLength) {\r\n validation.data[column.field].error = `${translate('Min length')}: ${column.minLength}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.maxLength !== undefined && value.length > column.maxLength) {\r\n validation.data[column.field].error = `${translate('Max length')}: ${column.maxLength}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = value;\r\n } else if (column.type === 'number') {\r\n if (item[column.field]) {\r\n const value = +item[column.field];\r\n if (Number.isNaN(value)) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('is not a number')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = value;\r\n }\r\n if (!item[column.field] && item[column.field] !== 0) {\r\n item[column.field] = undefined;\r\n }\r\n if (column.minValue !== undefined && item[column.field] < column.minValue) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Min value')}: ${column.minValue}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.maxValue !== undefined && item[column.field] > column.maxValue) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Max value')}: ${column.maxValue}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n } else if (column.type === 'bool') {\r\n if (item[column.field] === 0 || item[column.field] === false) {\r\n item[column.field] = '0';\r\n }\r\n if (item[column.field] === 1 || item[column.field] === true) {\r\n item[column.field] = '1';\r\n }\r\n\r\n if (item[column.field]) {\r\n const value = +item[column.field];\r\n if (Number.isNaN(value) || (value !== 0 && value !== 1)) {\r\n validation.data[column.field].error = `${translate('Value shoud be 0 or 1')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n } else {\r\n if (column.parseToBool) {\r\n item[column.field] = item[column.field] === '1';\r\n }\r\n }\r\n }\r\n } else if (column.type === 'values') {\r\n if (item[column.field] && typeof (item[column.field]) !== 'number' && typeof (item[column.field]) !== 'string') {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Invalid data type')}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (column.checkValueInArray && item[column.field] && !column.values.some(e => e.toString() === item[column.field].toString())) {\r\n validation.data[column.field].error = `${item[column.field]} ${translate('Value not in')} [${column.values.join()}]`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n } else if (column.type === 'date' || column.type === 'datetime' || column.type === 'time') {\r\n const { type, format } = column;\r\n const val = item[column.field];\r\n if (format && item[column.field]) {\r\n if (typeof (val) !== 'string') {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'date' && !this.#isValidDate(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'time' && !this.#isValidTime(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n if (type === 'datetime' && !this.#isValidDateTime(format, val)) {\r\n validation.data[column.field].error = `${translate('Invalid format')} ${column.format}: ${val}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n item[column.field] = Date.parseFrom(val, column.format).toFormat('MM/dd/yyyy HH:mm:ss');\r\n }\r\n if (item[column.field] && !Date.isDate(item[column.field])) {\r\n validation.data[column.field].error = `${translate('Invalid date')}: ${item[column.field]}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n continue;\r\n }\r\n }\r\n\r\n if (!validation.data[column.field].error && column.errorValidation) {\r\n const error = await column.errorValidation(item, item[column.field], idx);\r\n if (error) {\r\n validation.data[column.field].error = `${error}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n }\r\n }\r\n\r\n if (!validation.data[column.field].warning && column.warningValidation) {\r\n const warning = await column.warningValidation(item, item[column.field], idx);\r\n if (warning) {\r\n validation.data[column.field].warning = `${warning}`;\r\n validation.warning += `<strong>[${column.title || column.field}]</strong> ${warning}<br>`;\r\n }\r\n }\r\n } catch (ex) {\r\n validation.data[column.field].error = `${ex?.message || ex?.error || ex || 'Có lỗi xảy ra'}`;\r\n errors.push(`<strong>[${column.title || column.field}]</strong> ${validation.data[column.field].error}`);\r\n }\r\n }\r\n validation.error = errors.join('<br>');\r\n }\r\n\r\n #parse = (item: SdExcelItem) => {\r\n const { data } = item;\r\n return data;\r\n }\r\n\r\n #mapItem = (item: SdExcelItem) => {\r\n const { data } = item;\r\n return data;\r\n }\r\n\r\n accept = () => {\r\n const successItems = this.items.filter(this.#isSuccess).map(this.#mapItem);\r\n const errorItems = this.items.filter(this.#isError).map(this.#mapItem);\r\n const warningItems = this.items.filter(this.#isWarning).map(this.#mapItem);\r\n this.option?.onAccept(this.items.map(this.#mapItem), successItems, errorItems, warningItems, this.file);\r\n this.isUploaded = true;\r\n }\r\n\r\n setValidation = (validates: { idx: number, messageError?: string, messageWarning?: string, messageSuccess?: string }[]) => {\r\n if (Array.isArray(validates)) {\r\n validates.forEach(validate => {\r\n this.items[validate.idx].sd.validation.error = validate.messageError;\r\n this.items[validate.idx].sd.validation.warning = validate.messageWarning;\r\n this.items[validate.idx].sd.validation.success = validate.messageSuccess;\r\n });\r\n }\r\n this.#reload();\r\n this.ref.detectChanges();\r\n }\r\n\r\n view = (showing: 'ALL' | 'SUCCESS' | 'WARNING' | 'ERROR' = 'ALL') => {\r\n this.showing = showing;\r\n this.#paginator.pageIndex = 0;\r\n this.#reload();\r\n }\r\n\r\n downloadTemplate = async () => {\r\n const sheets: {\r\n name: string,\r\n items: any[],\r\n fields: string[]\r\n }[] = [];\r\n if (Array.isArray(this.option?.sheets)) {\r\n for (const sheet of this.option.sheets) {\r\n if (sheet.name && sheet.items && sheet.fields) {\r\n if (Array.isArray(sheet.items)) {\r\n sheets.push({\r\n name: sheet.name,\r\n items: sheet.items,\r\n fields: sheet.fields\r\n });\r\n } else {\r\n sheets.push({\r\n name: sheet.name,\r\n items: await sheet.items(),\r\n fields: sheet.fields\r\n });\r\n }\r\n }\r\n }\r\n }\r\n const columnNotHiddens = this.option.columns.filter(column => this.sdColumnHidden.transform(column));\r\n const excelTemplate: SdExportTemplate = {\r\n fileName: this.option.fileName || 'Template',\r\n columns: columnNotHiddens.map(column => {\r\n return {\r\n field: column.field,\r\n title: column.title,\r\n width: column.width,\r\n required: column.required,\r\n description: column.description,\r\n fontColor: column.fontColor,\r\n fill: column.fill\r\n };\r\n }),\r\n sheets\r\n };\r\n this.isDownloadTemplate = true;\r\n await this.exportService.generateTemplate(excelTemplate).finally(() => {\r\n this.isDownloadTemplate = false;\r\n });\r\n }\r\n\r\n export = async () => {\r\n this.loadingService.start();\r\n const columns: SdExportTempateColumn[] = [{\r\n field: 'sdMessage',\r\n title: this.translateService.translate('Upload message'),\r\n width: '250px',\r\n required: false\r\n }, ... this.option.columns.filter(column => this.sdColumnHidden.transform(column))];\r\n await this.exportService.export({\r\n columns,\r\n items: this.filteredItems.map(e => {\r\n let result = {};\r\n for (const column of columns) {\r\n result = {\r\n ...result,\r\n [column.field]: e.sd.origin?.[column.field]\r\n }\r\n }\r\n return {\r\n ...result,\r\n sdMessage: (e.sd.validation?.error || e.sd.validation?.warning || e.sd.validation?.success)?.replace(/<strong>/g, '')\r\n .replace(/<\\/strong>/g, '')\r\n .replace(/<br>/g, '\\n')\r\n };\r\n })\r\n }).finally(this.loadingService.stop);\r\n }\r\n\r\n #isValidDate = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n const regex = /^(?:(?:31(\\/|-|\\.)(?:0?[13578]|1[02]))\\1|(?:(?:29|30)(\\/|-|\\.)(?:0?[13-9]|1[0-2])\\2))(?:(?:1[6-9]|[2-9]\\d)?\\d{2})$|^(?:29(\\/|-|\\.)0?2\\3(?:(?:(?:1[6-9]|[2-9]\\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))$|^(?:0?[1-9]|1\\d|2[0-8])(\\/|-|\\.)(?:(?:0?[1-9])|(?:1[0-2]))\\4(?:(?:1[6-9]|[2-9]\\d)?\\d{2})$/;\r\n return regex.test(value);\r\n }\r\n\r\n #isValidTime = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n #isValidDateTime = (format: string, value: string) => {\r\n if (value?.length !== format?.length) {\r\n return false;\r\n }\r\n const dates = value?.split(' ');\r\n if (dates.length !== 2) {\r\n return false;\r\n }\r\n const date = dates[0];\r\n if (!this.#isValidDate('dd/MM/yyyy', date)) {\r\n return false;\r\n }\r\n const time = dates[1];\r\n const regex = /^(0[0-9]|1[0-9]|2[0-3])(\\:)(0[0-9]|[0-5][0-9])$/;\r\n return regex.test(time);\r\n }\r\n onClosed = () => {\r\n this.sdClosed.emit();\r\n }\r\n}\r\n\r\n","import { DecimalPipe } from '@angular/common';\r\nimport { Pipe, PipeTransform } from '@angular/core';\r\nimport { SdExcelItem, SdUploadExcelColumn } from '../upload-excel.model';\r\n@Pipe({\r\n name: 'columnTransform'\r\n})\r\nexport class SdColumnTransformPipe implements PipeTransform {\r\n constructor(private decimalPipe: DecimalPipe) {\r\n\r\n }\r\n transform = async (rowData: SdExcelItem, column: SdUploadExcelColumn): Promise<string> => {\r\n const { type, transform } = column;\r\n const value = rowData.data[column.field];\r\n if (rowData.sd.validation.data[column.field]?.error) {\r\n return rowData.sd.origin[column.field] ?? value ?? '';\r\n }\r\n if (transform) {\r\n return transform(rowData.data, value);\r\n }\r\n if (column.type === 'number') {\r\n return Number.toVNCurrency(value) ?? '';\r\n }\r\n if (column.type === 'bool') {\r\n if (value === '1' || value === true) {\r\n return `<div class=\"text-center\"><input type=\"checkbox\" checked disabled></div>`;\r\n } else if (value === '0' || value === false) {\r\n return `<div class=\"text-center\"><input type=\"checkbox\" disabled></div>`;\r\n }\r\n }\r\n if (column.type === 'date') {\r\n return Date.toFormat(value, column.format || 'dd/MM/yyyy') ?? '';\r\n }\r\n if (column.type === 'datetime') {\r\n return Date.toFormat(value, column.format || 'dd/MM/yyyy HH:mm') ?? '';\r\n }\r\n return value ?? '';\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule, DecimalPipe } from '@angular/common';\r\nimport { DeviceDetectorModule } from 'ngx-device-detector';\r\nimport { SdNotifyModule } from '@sd-angular/core/notify';\r\nimport { SdTranslateModule } from '@sd-angular/core/translate';\r\nimport { SdUploadExcel } from './upload-excel.component';\r\nimport { SdButtonModule } from '@sd-angular/core/button';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\nimport { SdModalModule } from '@sd-angular/core/modal';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatPaginatorModule } from '@angular/material/paginator';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { SdInputModule } from '@sd-angular/core/input';\r\nimport { SdUtilityModule } from '@sd-angular/core/utility';\r\nimport {MatIconModule} from '@angular/material/icon';\r\nimport {MatMenuModule} from '@angular/material/menu';\r\nimport { SdColumnHiddenPipe } from './pipes/columm-hidden.pipe';\r\nimport { SdColumnTransformPipe } from './pipes/column-transform.pipe';\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n DeviceDetectorModule.forRoot(),\r\n MatSlideToggleModule,\r\n MatTooltipModule,\r\n MatPaginatorModule,\r\n MatSlideToggleModule,\r\n SdNotifyModule,\r\n SdTranslateModule,\r\n SdUtilityModule,\r\n SdButtonModule,\r\n SdModalModule,\r\n SdInputModule,\r\n MatIconModule,\r\n MatMenuModule\r\n ],\r\n declarations: [\r\n SdUploadExcel,\r\n // pipe\r\n SdColumnHiddenPipe,\r\n SdColumnTransformPipe\r\n ],\r\n exports: [\r\n SdUploadExcel\r\n ],\r\n providers: [\r\n DecimalPipe,\r\n SdColumnHiddenPipe\r\n ]\r\n})\r\nexport class SdUploadExcelModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdColumnHiddenPipe as ɵa} from './src/lib/pipes/columm-hidden.pipe';\nexport {SdColumnTransformPipe as ɵb} from './src/lib/pipes/column-transform.pipe';"],"names":["uuid.v4"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sd-angular/core",
3
- "version": "1.3.145",
3
+ "version": "1.3.146",
4
4
  "homepage": "https://www.facebook.com/DarkP3ter",
5
5
  "author": {
6
6
  "name": "darkpeter",
@@ -44,7 +44,6 @@
44
44
  "jsoneditor": "^9.7.4",
45
45
  "tslib": "^2.0.0",
46
46
  "uuid": "^8.3.2",
47
- "xlsx": "^0.16.3",
48
47
  "export-to-csv": "^0.2.1",
49
48
  "ngx-print": "^1.2.0-beta.5",
50
49
  "exceljs": "^4.3.0",