@sd-angular/core 1.3.241 → 1.3.243
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sd-angular-core-export.umd.js +3 -1
- package/bundles/sd-angular-core-export.umd.js.map +1 -1
- package/bundles/sd-angular-core-export.umd.min.js +1 -1
- package/bundles/sd-angular-core-export.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-table.umd.js +13 -5
- package/bundles/sd-angular-core-table.umd.js.map +1 -1
- package/bundles/sd-angular-core-table.umd.min.js +1 -1
- package/bundles/sd-angular-core-table.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-upload-excel.umd.js +4 -4
- package/bundles/sd-angular-core-upload-excel.umd.js.map +1 -1
- package/bundles/sd-angular-core-upload-excel.umd.min.js +2 -2
- package/bundles/sd-angular-core-upload-excel.umd.min.js.map +1 -1
- package/esm2015/export/src/lib/export.model.js +1 -1
- package/esm2015/export/src/lib/export.service.js +4 -2
- package/esm2015/table/src/lib/table.component.js +14 -6
- package/esm2015/upload-excel/src/lib/upload-excel.component.js +4 -4
- package/export/sd-angular-core-export.metadata.json +1 -1
- package/export/src/lib/export.model.d.ts +15 -34
- package/export/src/lib/export.service.d.ts +3 -3
- package/fesm2015/sd-angular-core-export.js +3 -1
- package/fesm2015/sd-angular-core-export.js.map +1 -1
- package/fesm2015/sd-angular-core-table.js +13 -5
- package/fesm2015/sd-angular-core-table.js.map +1 -1
- package/fesm2015/sd-angular-core-upload-excel.js +2 -2
- package/fesm2015/sd-angular-core-upload-excel.js.map +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-1.3.241.tgz → sd-angular-core-1.3.243.tgz} +0 -0
- package/table/sd-angular-core-table.metadata.json +1 -1
- package/upload-excel/sd-angular-core-upload-excel.metadata.json +1 -1
- package/upload-excel/src/lib/upload-excel.component.d.ts +4 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../projects/sd-core/export/src/lib/export.model.ts","../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/export/src/lib/export.service.ts"],"names":["API","uploadTemplate","generateUploadTemplate","filesInFolder","removeFile","sdExportByTemplate","sdMergePDF","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__values","o","s","m","i","__read","r","ar","error","__classPrivateFieldGet","receiver","state","kind","has","get","SdExportService","apiService","notifyService","firebaseConfiguration","_this","_fieldStyle","set","border","bottom","style","left","right","alignment","vertical","horizontal","wrapText","font","bold","size","color","argb","fill","type","pattern","fgColor","_titleColor","_titleFgColor","_titleStyle","_requiredStyle","italic","_descriptionStyle","_cellStyle","_directory","key","group","hashedFolder","hash","folder","userFolder","generateTemplate","template","fileName","columns","sheets","Array","isArray","Error","_g","entries","_h","_j","idx","column","field","title","hasDescription","some","description","workbook","Workbook","firstSheet","addWorksheet","forEach","index","required","fontColor","cellField","getCell","cellTitle","cellDescription","width","endsWith","replace","getColumn","assign","_a","_c","_b","_f","_e","_d","sheet","name","items","fields","newSheet_1","item","idx1","idx2","sheets_1","sheets_1_1","xlsx","writeBuffer","file","_m","SdUtility","downloadBlob","Blob","args","validator","url","functionUrl","upload","extensions","maxSizeInMb","catch","err","notify","warning","message","filePath","post","res","files","map","publicUrl","download","link","document","createElement","uuid.v4","href","appendChild","click","removeChild","exportByTemplate","responseType","buffer","blob","exportCSV","option","headerCSV","columns_1","columns_1_1","ExportToCsv","filename","Date","toFormat","fieldSeparator","quoteStrings","decimalSeparator","showLabels","showTitle","useBom","generateCsv","arguments","concat","__spread","export","newSheet_2","sheets_2","sheets_2_1","fromRow","numFmt","exportCustom","cells","worksheet","e_7","_k","_l","e_8","cells_1","cells_1_1","cell","row","_q","mergePDF","urls","uploadXlsx","parseXlsx","wb","reader","FileReader","onload","load","worksheets","headers","getRow","values","eachRow","rowIndex","hasValues","item_1","cellValue","toString","trim","undefined","readAsArrayBuffer","defineProperty","prototype","project","env","Injectable","providedIn","SdApiService","SdNotifyService","Inject","FIREBASE_CONFIG","Optional"],"mappings":"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","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","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\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: { key: string; group?: string; validator?: (fileName: string) => string }): Promise<SdExportFile> => {\r\n const { key, group, validator } = args;\r\n const { uploadTemplate } = API;\r\n const url = `${this.functionUrl}${uploadTemplate}?${this.#directory(key, group)}`;\r\n const file = await SdUtility.upload({\r\n extensions: ['xlsx'],\r\n maxSizeInMb: 0.1,\r\n validator,\r\n });\r\n if (file) {\r\n const { filePath, fileName } = await this.apiService.upload(url, file).catch((err: Error) => {\r\n this.notifyService.notify.warning(err?.message);\r\n throw err;\r\n });\r\n return {\r\n filePath,\r\n fileName,\r\n };\r\n }\r\n return null;\r\n };\r\n\r\n generateUploadTemplate = async (args: { key: string; template: SdExportTemplate; group?: string }) => {\r\n const { key, template, group } = args;\r\n const { generateUploadTemplate } = API;\r\n const url = `${this.functionUrl}${generateUploadTemplate}?${this.#directory(key, group)}`;\r\n const { filePath, fileName } = await this.apiService.post(url, template);\r\n return { filePath, fileName };\r\n };\r\n\r\n removeFile = async (args: { key: string; group?: string; fileName?: string }) => {\r\n const { key, group, fileName } = args;\r\n const { removeFile } = API;\r\n const url = `${this.functionUrl}${removeFile}?${this.#directory(key, group)}&name=${fileName}`;\r\n await this.apiService.post(url);\r\n };\r\n\r\n filesInFolder = async (args: { key: string; group?: string }): Promise<SdExportFile[]> => {\r\n interface FilesInFolderRes {\r\n directory: string;\r\n files: {\r\n publicUrl: string;\r\n fullPath: string;\r\n name: string;\r\n }[];\r\n }\r\n const { key, group } = args;\r\n const { filesInFolder } = API;\r\n const url = `${this.functionUrl}${filesInFolder}?${this.#directory(key, group)}`;\r\n const res = await this.apiService.get<FilesInFolderRes>(url);\r\n return (\r\n res.files?.map(e => ({\r\n filePath: e.publicUrl,\r\n fileName: e.name,\r\n })) || []\r\n );\r\n };\r\n\r\n download = (filePath: string, fileName?: string) => {\r\n const link: any = document.createElement('a');\r\n link.download = `${fileName || uuid.v4()}.xlsx`;\r\n link.href = filePath;\r\n document.body.appendChild(link);\r\n link.click();\r\n document.body.removeChild(link);\r\n };\r\n\r\n exportByTemplate = async (args: { filePath: string; columns: any[]; items: any[]; fileName?: string }) => {\r\n const { filePath, columns, items, fileName } = args;\r\n const { sdExportByTemplate } = API;\r\n const url = `${this.functionUrl}${sdExportByTemplate}`;\r\n const buffer = await this.apiService.post(\r\n url,\r\n {\r\n filePath,\r\n columns,\r\n items,\r\n fileName,\r\n },\r\n null,\r\n {\r\n responseType: 'arraybuffer',\r\n }\r\n );\r\n const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n SdUtility.downloadBlob(blob, fileName);\r\n };\r\n\r\n exportCSV = async (option: IExportOption) => {\r\n const { columns, items, fileName } = option;\r\n const headerCSV = {};\r\n for (const column of columns) {\r\n headerCSV[column.field] = column.title;\r\n }\r\n const csvExporter = new ExportToCsv({\r\n filename: `${fileName || 'CSV'}_${Date.toFormat(new Date(), 'yyyy-MM-dd-HH-mm-ss')}`,\r\n fieldSeparator: ',',\r\n quoteStrings: '\"',\r\n decimalSeparator: '.',\r\n showLabels: true,\r\n showTitle: false,\r\n title: fileName || 'CSV',\r\n useBom: true,\r\n });\r\n csvExporter.generateCsv([headerCSV, ...items]);\r\n };\r\n\r\n export = async (option: IExportOption) => {\r\n const { columns, items, fileName, sheets } = option;\r\n let hasDescription = false;\r\n for (const [idx, column] of columns.entries()) {\r\n if (!column.field) {\r\n throw new Error(`Column ${idx + 1}: Field is required`);\r\n }\r\n if (!column.title) {\r\n throw new Error(`Column ${idx + 1}: Title is required`);\r\n }\r\n if (column.description) {\r\n hasDescription = true;\r\n }\r\n }\r\n const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download\r\n const firstSheet = workbook.addWorksheet('data'); // Lấy ra sheet đầu tiên\r\n columns.forEach((column, index) => {\r\n let width = 120;\r\n if (column.width && column.width.endsWith('px')) {\r\n width = +column.width.replace('px', '');\r\n }\r\n firstSheet.getColumn(index + 1).width = width / 7 || 20;\r\n firstSheet.getCell(1, index + 1).style = this.#fieldStyle;\r\n if (column.required) {\r\n firstSheet.getCell(2, index + 1).style = this.#requiredStyle;\r\n } else {\r\n firstSheet.getCell(2, index + 1).style = this.#titleStyle;\r\n }\r\n firstSheet.getCell(1, index + 1).value = column.field;\r\n firstSheet.getCell(2, index + 1).value = column.title;\r\n if (hasDescription) {\r\n firstSheet.getCell(3, index + 1).style = this.#descriptionStyle;\r\n firstSheet.getCell(3, index + 1).value = column.description || '';\r\n }\r\n });\r\n if (sheets?.length) {\r\n for (const sheet of sheets) {\r\n if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {\r\n const newSheet = workbook.addWorksheet(sheet.name);\r\n sheet.fields.forEach((field, index) => {\r\n newSheet.getColumn(index + 1).width = 30;\r\n newSheet.getCell(1, index + 1).style = this.#titleStyle;\r\n newSheet.getCell(1, index + 1).value = field;\r\n });\r\n sheet.items.forEach((item, idx1) => {\r\n sheet.fields.forEach((field, idx2) => {\r\n newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];\r\n newSheet.getCell(2 + idx1, 1 + idx2).style = this.#cellStyle;\r\n });\r\n });\r\n }\r\n }\r\n }\r\n\r\n const fromRow = hasDescription ? 4 : 3;\r\n items.forEach((e, idx1) => {\r\n columns.forEach((column, idx2) => {\r\n if (typeof e[column.field] === 'number') {\r\n firstSheet.getCell(fromRow + idx1, 1 + idx2).value = +e[column.field];\r\n firstSheet.getCell(fromRow + idx1, 1 + idx2).numFmt = '#';\r\n } else {\r\n firstSheet.getCell(fromRow + idx1, 1 + idx2).value = e[column.field];\r\n }\r\n firstSheet.getCell(fromRow + idx1, 1 + idx2).style = this.#cellStyle;\r\n });\r\n });\r\n const file = await workbook.xlsx.writeBuffer();\r\n SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n };\r\n\r\n exportCustom = async (option: SdExportCustomOption) => {\r\n const { fileName, sheets } = option;\r\n if (!sheets?.length) {\r\n this.notifyService.notify.warning('Phải có ít nhất 1 sheet');\r\n return;\r\n }\r\n const workbook = new Workbook();\r\n for (const [idx, sheet] of sheets.entries()) {\r\n const { name, columns, cells } = sheet;\r\n const worksheet = workbook.addWorksheet(name || `Sheet ${idx + 1}`);\r\n for (const column of columns || []) {\r\n worksheet.getColumn(column.index).style = column.style;\r\n worksheet.getColumn(column.index).width = column.width;\r\n }\r\n for (const cell of cells) {\r\n const { row, column, value, style } = cell;\r\n worksheet.getCell(row, column).style = style || worksheet.getColumn(column).style;\r\n worksheet.getCell(row, column).value = value;\r\n }\r\n }\r\n const file = await workbook.xlsx.writeBuffer();\r\n SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n };\r\n\r\n mergePDF = async (urls: string[]) => {\r\n const { sdMergePDF } = API;\r\n const url = `${this.functionUrl}${sdMergePDF}`;\r\n const buffer = await this.apiService.post(\r\n url,\r\n {\r\n urls,\r\n },\r\n null,\r\n {\r\n responseType: 'arraybuffer',\r\n }\r\n );\r\n SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));\r\n };\r\n\r\n uploadXlsx = async (): Promise<{ items: any[]; file: File } | undefined> => {\r\n return await SdUtility.upload({\r\n extensions: ['xlsx'],\r\n maxSizeInMb: 10,\r\n }).then(file => {\r\n return this.parseXlsx(file);\r\n });\r\n };\r\n\r\n parseXlsx = async (file: File): Promise<{ items: any[]; file: File } | undefined> => {\r\n if (file) {\r\n return new Promise<{ items: any[]; file: File }>((resolve, reject) => {\r\n const wb = new Workbook();\r\n const reader: FileReader = new FileReader();\r\n reader.onload = () => {\r\n const buffer = reader.result as ArrayBuffer;\r\n if (!buffer) {\r\n reject('Có lỗi xảy ra khi đọc file');\r\n return;\r\n }\r\n wb.xlsx.load(buffer).then(workbook => {\r\n const sheet = workbook.worksheets[0];\r\n if (!sheet) {\r\n reject('Không tìm thấy dữ liệu');\r\n return;\r\n }\r\n const items: any[] = [];\r\n const headers = sheet.getRow(1).values;\r\n if (Array.isArray(headers)) {\r\n sheet.eachRow((row, rowIndex) => {\r\n const { hasValues, values } = row;\r\n // console.log(row, hasValues, values)\r\n if (hasValues && rowIndex > 1) {\r\n const item: any = {};\r\n headers.forEach((cellValue, index) => {\r\n if (cellValue) {\r\n const field = cellValue.toString();\r\n item[field] = values[index];\r\n if (typeof item[field] === 'string') {\r\n item[field] = item[field].trim();\r\n }\r\n if (item[field] === '' || item[field] === undefined) {\r\n item[field] = null;\r\n }\r\n }\r\n });\r\n items.push(item);\r\n }\r\n });\r\n resolve({\r\n items,\r\n file,\r\n });\r\n }\r\n });\r\n };\r\n reader.readAsArrayBuffer(file);\r\n });\r\n } else {\r\n return {\r\n items: [],\r\n file: null,\r\n };\r\n }\r\n };\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"sources":["../../../../projects/sd-core/export/src/lib/export.model.ts","../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/export/src/lib/export.service.ts"],"names":["API","uploadTemplate","generateUploadTemplate","filesInFolder","removeFile","sdExportByTemplate","sdMergePDF","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__values","o","s","m","i","__read","r","ar","error","__classPrivateFieldGet","receiver","state","kind","has","get","SdExportService","apiService","notifyService","firebaseConfiguration","_this","_fieldStyle","set","border","bottom","style","left","right","alignment","vertical","horizontal","wrapText","font","bold","size","color","argb","fill","type","pattern","fgColor","_titleColor","_titleFgColor","_titleStyle","_requiredStyle","italic","_descriptionStyle","_cellStyle","_directory","key","group","hashedFolder","hash","folder","userFolder","generateTemplate","template","fileName","columns","sheets","Array","isArray","Error","_g","entries","_h","_j","idx","column","field","title","hasDescription","some","description","workbook","Workbook","firstSheet","addWorksheet","forEach","index","required","fontColor","cellField","getCell","cellTitle","cellDescription","width","endsWith","replace","getColumn","assign","_a","_c","_b","_f","_e","_d","sheet","name","items","fields","newSheet_1","item","idx1","idx2","sheets_1","sheets_1_1","xlsx","writeBuffer","file","_m","SdUtility","downloadBlob","Blob","args","validator","url","functionUrl","upload","extensions","maxSizeInMb","catch","err","notify","warning","message","filePath","post","res","files","map","publicUrl","download","link","document","createElement","uuid.v4","href","appendChild","click","removeChild","exportByTemplate","responseType","buffer","blob","exportCSV","option","headerCSV","columns_1","columns_1_1","ExportToCsv","filename","Date","toFormat","fieldSeparator","quoteStrings","decimalSeparator","showLabels","showTitle","useBom","generateCsv","arguments","concat","__spread","export","newSheet_2","sheets_2","sheets_2_1","fromRow","numFmt","exportCustom","cells","worksheet","e_7","_k","_l","e_8","cells_1","cells_1_1","cell","row","_q","mergePDF","urls","uploadXlsx","parseXlsx","wb","reader","FileReader","onload","load","worksheets","headers","getRow","values","eachRow","rowIndex","hasValues","item_1","cellValue","toString","trim","undefined","readAsArrayBuffer","defineProperty","prototype","project","env","Injectable","providedIn","SdApiService","SdNotifyService","Inject","FIREBASE_CONFIG","Optional"],"mappings":"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","sourcesContent":["export * from './excel.model';\r\nexport interface SdExportTemplate {\r\n fileName?: string;\r\n columns: SdExportTemplateColumn[];\r\n sheets?: {\r\n name: string;\r\n items: any[];\r\n fields: 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 numFmt?: string; // Format trong trường hợp muốn sử dụng ví dụ với number, date ...\r\n}\r\n\r\nexport interface SdExportTemplateColumn extends SdExportColumn {\r\n required?: boolean;\r\n color?: string;\r\n fontColor?: string;\r\n fill?: string;\r\n}\r\nexport interface SdExportFile {\r\n fileName?: string;\r\n filePath?: string;\r\n}\r\n\r\n\r\nexport interface SdExportSheet<T = any> {\r\n name: string;\r\n items: T[];\r\n fields: Extract<keyof T, string>[];\r\n}\r\n\r\nexport interface SdExportOption<T = any> {\r\n columns: SdExportTemplateColumn[];\r\n items: T[];\r\n fileName?: string;\r\n sheets?: SdExportSheet[];\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","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\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, SdExportOption, API, SdExportFile, SdExportCustomOption } from './export.model';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { FIREBASE_CONFIG, IFirebaseConfiguration } from '@sd-angular/core/common';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class SdExportService {\r\n private get functionUrl() {\r\n return this.firebaseConfiguration?.functionUrl;\r\n }\r\n\r\n private get folder() {\r\n const { project, env } = this.firebaseConfiguration;\r\n return `${project}-${env}`;\r\n }\r\n\r\n private get userFolder() {\r\n const { folder } = this.firebaseConfiguration;\r\n if (!folder) {\r\n return;\r\n }\r\n if (typeof folder === 'string') {\r\n return folder;\r\n }\r\n return folder();\r\n }\r\n\r\n #fieldStyle: Partial<Style> = {\r\n border: {\r\n bottom: { style: 'thin' },\r\n left: { style: 'thin' },\r\n right: { style: 'thin' },\r\n },\r\n alignment: {\r\n vertical: 'middle',\r\n horizontal: 'center',\r\n wrapText: true,\r\n },\r\n font: {\r\n bold: true,\r\n size: 11,\r\n color: { argb: '000000' },\r\n },\r\n fill: {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: {\r\n argb: 'FAFAFA',\r\n },\r\n },\r\n };\r\n #titleColor = 'FFFFFF';\r\n #titleFgColor = '143180';\r\n #titleStyle: Partial<Style> = {\r\n border: {\r\n bottom: { style: 'thin' },\r\n left: { style: 'thin' },\r\n right: { style: 'thin' },\r\n },\r\n alignment: {\r\n vertical: 'middle',\r\n horizontal: 'center',\r\n wrapText: true,\r\n },\r\n font: {\r\n bold: true,\r\n size: 11,\r\n color: { argb: this.#titleColor },\r\n },\r\n fill: {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: {\r\n argb: this.#titleFgColor,\r\n },\r\n },\r\n };\r\n\r\n #requiredStyle: Partial<Style> = {\r\n border: {\r\n bottom: { style: 'thin' },\r\n left: { style: 'thin' },\r\n right: { style: 'thin' },\r\n },\r\n alignment: {\r\n vertical: 'middle',\r\n horizontal: 'center',\r\n wrapText: true,\r\n },\r\n font: {\r\n italic: true,\r\n size: 11,\r\n color: { argb: 'FFFFFF' },\r\n },\r\n fill: {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: {\r\n argb: 'FF1744',\r\n },\r\n },\r\n };\r\n\r\n #descriptionStyle: Partial<Style> = {\r\n border: {\r\n bottom: { style: 'thin' },\r\n left: { style: 'thin' },\r\n right: { style: 'thin' },\r\n },\r\n alignment: {\r\n wrapText: true,\r\n },\r\n font: {\r\n italic: true,\r\n size: 9,\r\n color: { argb: '000000' },\r\n },\r\n fill: {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: {\r\n argb: 'CFD8DC',\r\n },\r\n },\r\n };\r\n\r\n #cellStyle: Partial<Style> = {\r\n alignment: {\r\n vertical: 'middle',\r\n wrapText: true,\r\n },\r\n };\r\n\r\n constructor(\r\n private apiService: SdApiService,\r\n private notifyService: SdNotifyService,\r\n @Inject(FIREBASE_CONFIG) @Optional() private firebaseConfiguration: IFirebaseConfiguration\r\n ) {}\r\n\r\n #directory = (key: string, group: string) => {\r\n let hashedFolder = hash({\r\n folder: this.folder,\r\n userFolder: this.userFolder,\r\n });\r\n if (!group) {\r\n return `dir1=${this.folder}&dir2=U-${hashedFolder}&dir3=${key || ''}`;\r\n }\r\n hashedFolder = hash({\r\n folder: this.folder,\r\n group,\r\n });\r\n return `dir1=${this.folder}&dir2=G-${hashedFolder}&dir3=${key || ''}`;\r\n };\r\n\r\n generateTemplate = async (template: SdExportTemplate) => {\r\n const { fileName, columns, sheets } = template;\r\n if (!Array.isArray(columns)) {\r\n throw new Error('Excel template columns must be an array');\r\n }\r\n for (const [idx, column] of columns.entries()) {\r\n if (!column.field) {\r\n throw new Error(`Column ${idx + 1}: Field is required`);\r\n }\r\n if (!column.title) {\r\n throw new Error(`Column ${idx + 1}: Title is required`);\r\n }\r\n }\r\n const hasDescription = columns.some(column => column.description);\r\n const workbook = new Workbook(); //await XlsxPopulate.fromBlankAsync(); // Đọc file sau khi đã download\r\n const firstSheet = workbook.addWorksheet('template'); // Lấy ra sheet đầu tiên\r\n columns.forEach((column, index) => {\r\n const { required, fill, fontColor } = column;\r\n const cellField = firstSheet.getCell(1, index + 1);\r\n const cellTitle = firstSheet.getCell(2, index + 1);\r\n const cellDescription = firstSheet.getCell(3, index + 1);\r\n let width = 120;\r\n if (column.width && column.width.endsWith('px')) {\r\n width = +column.width.replace('px', '');\r\n }\r\n firstSheet.getColumn(index + 1).width = width / 7 || 20;\r\n cellField.style = this.#fieldStyle;\r\n if (required) {\r\n cellField.style = this.#requiredStyle;\r\n } else {\r\n cellField.style = this.#fieldStyle;\r\n }\r\n cellTitle.style = {\r\n ...this.#titleStyle,\r\n font: {\r\n ...this.#titleStyle?.font,\r\n color: {\r\n ...this.#titleStyle?.font?.color,\r\n argb: fontColor || this.#titleStyle?.font?.color?.argb,\r\n },\r\n },\r\n fill: {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: {\r\n argb: fill || this.#titleFgColor,\r\n },\r\n },\r\n };\r\n cellField.value = column.field;\r\n cellTitle.value = column.title;\r\n if (hasDescription) {\r\n cellDescription.style = this.#descriptionStyle;\r\n cellDescription.value = column.description || '';\r\n }\r\n });\r\n if (sheets?.length) {\r\n for (const sheet of sheets) {\r\n if (sheet.name && Array.isArray(sheet.items) && Array.isArray(sheet.fields)) {\r\n const newSheet = workbook.addWorksheet(sheet.name);\r\n sheet.fields.forEach((field, index) => {\r\n newSheet.getColumn(index + 1).width = 30;\r\n newSheet.getCell(1, index + 1).style = this.#titleStyle;\r\n newSheet.getCell(1, index + 1).value = field;\r\n });\r\n sheet.items.forEach((item, idx1) => {\r\n sheet.fields.forEach((field, idx2) => {\r\n newSheet.getCell(2 + idx1, 1 + idx2).value = item[field];\r\n newSheet.getCell(2 + idx1, 1 + idx2).style = this.#cellStyle;\r\n });\r\n });\r\n }\r\n }\r\n }\r\n const file = await workbook.xlsx.writeBuffer();\r\n SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n };\r\n\r\n uploadTemplate = async (args: { key: string; group?: string; validator?: (fileName: string) => string }): Promise<SdExportFile> => {\r\n const { key, group, validator } = args;\r\n const { uploadTemplate } = API;\r\n const url = `${this.functionUrl}${uploadTemplate}?${this.#directory(key, group)}`;\r\n const file = await SdUtility.upload({\r\n extensions: ['xlsx'],\r\n maxSizeInMb: 0.1,\r\n validator,\r\n });\r\n if (file) {\r\n const { filePath, fileName } = await this.apiService.upload(url, file).catch((err: Error) => {\r\n this.notifyService.notify.warning(err?.message);\r\n throw err;\r\n });\r\n return {\r\n filePath,\r\n fileName,\r\n };\r\n }\r\n return null;\r\n };\r\n\r\n generateUploadTemplate = async (args: { key: string; template: SdExportTemplate; group?: string }) => {\r\n const { key, template, group } = args;\r\n const { generateUploadTemplate } = API;\r\n const url = `${this.functionUrl}${generateUploadTemplate}?${this.#directory(key, group)}`;\r\n const { filePath, fileName } = await this.apiService.post(url, template);\r\n return { filePath, fileName };\r\n };\r\n\r\n removeFile = async (args: { key: string; group?: string; fileName?: string }) => {\r\n const { key, group, fileName } = args;\r\n const { removeFile } = API;\r\n const url = `${this.functionUrl}${removeFile}?${this.#directory(key, group)}&name=${fileName}`;\r\n await this.apiService.post(url);\r\n };\r\n\r\n filesInFolder = async (args: { key: string; group?: string }): Promise<SdExportFile[]> => {\r\n interface FilesInFolderRes {\r\n directory: string;\r\n files: {\r\n publicUrl: string;\r\n fullPath: string;\r\n name: string;\r\n }[];\r\n }\r\n const { key, group } = args;\r\n const { filesInFolder } = API;\r\n const url = `${this.functionUrl}${filesInFolder}?${this.#directory(key, group)}`;\r\n const res = await this.apiService.get<FilesInFolderRes>(url);\r\n return (\r\n res.files?.map(e => ({\r\n filePath: e.publicUrl,\r\n fileName: e.name,\r\n })) || []\r\n );\r\n };\r\n\r\n download = (filePath: string, fileName?: string) => {\r\n const link: any = document.createElement('a');\r\n link.download = `${fileName || uuid.v4()}.xlsx`;\r\n link.href = filePath;\r\n document.body.appendChild(link);\r\n link.click();\r\n document.body.removeChild(link);\r\n };\r\n\r\n exportByTemplate = async (args: { filePath: string; columns: any[]; items: any[]; fileName?: string }) => {\r\n const { filePath, columns, items, fileName } = args;\r\n const { sdExportByTemplate } = API;\r\n const url = `${this.functionUrl}${sdExportByTemplate}`;\r\n const buffer = await this.apiService.post(\r\n url,\r\n {\r\n filePath,\r\n columns,\r\n items,\r\n fileName,\r\n },\r\n null,\r\n {\r\n responseType: 'arraybuffer',\r\n }\r\n );\r\n const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;base64,' });\r\n SdUtility.downloadBlob(blob, fileName);\r\n };\r\n\r\n exportCSV = async (option: SdExportOption) => {\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: SdExportOption) => {\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' && !column.numFmt) {\r\n // Format mặc định với kiểu số\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 firstSheet.getCell(fromRow + idx1, 1 + idx2).numFmt = column.numFmt;\r\n }\r\n firstSheet.getCell(fromRow + idx1, 1 + idx2).style = this.#cellStyle;\r\n });\r\n });\r\n const file = await workbook.xlsx.writeBuffer();\r\n SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n };\r\n\r\n exportCustom = async (option: SdExportCustomOption) => {\r\n const { fileName, sheets } = option;\r\n if (!sheets?.length) {\r\n this.notifyService.notify.warning('Phải có ít nhất 1 sheet');\r\n return;\r\n }\r\n const workbook = new Workbook();\r\n for (const [idx, sheet] of sheets.entries()) {\r\n const { name, columns, cells } = sheet;\r\n const worksheet = workbook.addWorksheet(name || `Sheet ${idx + 1}`);\r\n for (const column of columns || []) {\r\n worksheet.getColumn(column.index).style = column.style;\r\n worksheet.getColumn(column.index).width = column.width;\r\n }\r\n for (const cell of cells) {\r\n const { row, column, value, style } = cell;\r\n worksheet.getCell(row, column).style = style || worksheet.getColumn(column).style;\r\n worksheet.getCell(row, column).value = value;\r\n }\r\n }\r\n const file = await workbook.xlsx.writeBuffer();\r\n SdUtility.downloadBlob(new Blob([file], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }), fileName);\r\n };\r\n\r\n mergePDF = async (urls: string[]) => {\r\n const { sdMergePDF } = API;\r\n const url = `${this.functionUrl}${sdMergePDF}`;\r\n const buffer = await this.apiService.post(\r\n url,\r\n {\r\n urls,\r\n },\r\n null,\r\n {\r\n responseType: 'arraybuffer',\r\n }\r\n );\r\n SdUtility.downloadBlob(new Blob([buffer], { type: 'application/pdf' }));\r\n };\r\n\r\n uploadXlsx = async (): Promise<{ items: any[]; file: File } | undefined> => {\r\n return await SdUtility.upload({\r\n extensions: ['xlsx'],\r\n maxSizeInMb: 10,\r\n }).then(file => {\r\n return this.parseXlsx(file);\r\n });\r\n };\r\n\r\n parseXlsx = async (file: File): Promise<{ items: any[]; file: File } | undefined> => {\r\n if (file) {\r\n return new Promise<{ items: any[]; file: File }>((resolve, reject) => {\r\n const wb = new Workbook();\r\n const reader: FileReader = new FileReader();\r\n reader.onload = () => {\r\n const buffer = reader.result as ArrayBuffer;\r\n if (!buffer) {\r\n reject('Có lỗi xảy ra khi đọc file');\r\n return;\r\n }\r\n wb.xlsx.load(buffer).then(workbook => {\r\n const sheet = workbook.worksheets[0];\r\n if (!sheet) {\r\n reject('Không tìm thấy dữ liệu');\r\n return;\r\n }\r\n const items: any[] = [];\r\n const headers = sheet.getRow(1).values;\r\n if (Array.isArray(headers)) {\r\n sheet.eachRow((row, rowIndex) => {\r\n const { hasValues, values } = row;\r\n // console.log(row, hasValues, values)\r\n if (hasValues && rowIndex > 1) {\r\n const item: any = {};\r\n headers.forEach((cellValue, index) => {\r\n if (cellValue) {\r\n const field = cellValue.toString();\r\n item[field] = values[index];\r\n if (typeof item[field] === 'string') {\r\n item[field] = item[field].trim();\r\n }\r\n if (item[field] === '' || item[field] === undefined) {\r\n item[field] = null;\r\n }\r\n }\r\n });\r\n items.push(item);\r\n }\r\n });\r\n resolve({\r\n items,\r\n file,\r\n });\r\n }\r\n });\r\n };\r\n reader.readAsArrayBuffer(file);\r\n });\r\n } else {\r\n return {\r\n items: [],\r\n file: null,\r\n };\r\n }\r\n };\r\n}\r\n"]}
|
|
@@ -2274,12 +2274,14 @@
|
|
|
2274
2274
|
else if (column.type === 'date') {
|
|
2275
2275
|
date = item[column.field];
|
|
2276
2276
|
// Nếu là date thì convert theo đúng format
|
|
2277
|
-
obj[column.field] = Date.toFormat(date, 'dd/MM/yyyy');
|
|
2277
|
+
// obj[column.field] = Date.toFormat(date, 'dd/MM/yyyy');
|
|
2278
|
+
obj[column.field] = Date.isDate(date) ? new Date(date) : undefined;
|
|
2278
2279
|
}
|
|
2279
2280
|
else if (column.type === 'datetime') {
|
|
2280
2281
|
date = item[column.field];
|
|
2281
2282
|
// Nếu là datetime thì convert theo đúng format
|
|
2282
|
-
obj[column.field] = Date.toFormat(date, 'dd/MM/yyyy HH:mm');
|
|
2283
|
+
// obj[column.field] = Date.toFormat(date, 'dd/MM/yyyy HH:mm');
|
|
2284
|
+
obj[column.field] = Date.isDate(date) ? new Date(date) : undefined;
|
|
2283
2285
|
}
|
|
2284
2286
|
else if (column.type === 'time') {
|
|
2285
2287
|
date = item[column.field];
|
|
@@ -2485,7 +2487,13 @@
|
|
|
2485
2487
|
});
|
|
2486
2488
|
return;
|
|
2487
2489
|
}
|
|
2488
|
-
tableColumns.push(
|
|
2490
|
+
tableColumns.push({
|
|
2491
|
+
field: column.field,
|
|
2492
|
+
title: column.title,
|
|
2493
|
+
description: column.description,
|
|
2494
|
+
width: column.width,
|
|
2495
|
+
numFmt: column.type === 'datetime' ? 'dd/mm/yyyy hh:mm:ss' : column.type === 'date' ? 'dd/mm/yyyy' : undefined
|
|
2496
|
+
});
|
|
2489
2497
|
});
|
|
2490
2498
|
// Lấy columns từ configuration
|
|
2491
2499
|
if (_this.configuration) {
|
|
@@ -2508,7 +2516,7 @@
|
|
|
2508
2516
|
.map(function (e) { return e.data; });
|
|
2509
2517
|
}
|
|
2510
2518
|
// Chỉ lấy các columns được thiết lập
|
|
2511
|
-
var columnFields = columns.map(function (e) { return e.field; });
|
|
2519
|
+
var columnFields = (columns === null || columns === void 0 ? void 0 : columns.map(function (e) { return e.field; })) || [];
|
|
2512
2520
|
return __spread(tableColumns, (((_b = (_a = _this.tableOption.export) === null || _a === void 0 ? void 0 : _a.columns) === null || _b === void 0 ? void 0 : _b.filter(function (e) { var _a; return !((_a = e.export) === null || _a === void 0 ? void 0 : _a.disabled); })) || [])).filter(function (column) { return !(columnFields === null || columnFields === void 0 ? void 0 : columnFields.length) || columnFields.includes(column.field); });
|
|
2513
2521
|
});
|
|
2514
2522
|
this.exportExcel = function () {
|
|
@@ -3054,7 +3062,7 @@
|
|
|
3054
3062
|
SdTable.decorators = [
|
|
3055
3063
|
{ type: core.Component, args: [{
|
|
3056
3064
|
selector: 'sd-table',
|
|
3057
|
-
template: "<ng-container *ngIf=\"configuration\">\r\n <sd-table-filter\r\n *ngIf=\"!tableOption.filter?.disabled && filterRegister\"\r\n [filterRegister]=\"filterRegister\"\r\n [filter]=\"tableOption?.filter\"\r\n [columns]=\"configuration.firstColumns\"\r\n [externalFilters]=\"tableOption?.filter?.externalFilters\"\r\n [filterDefs]=\"filterDefs\">\r\n </sd-table-filter>\r\n <ng-container *ngIf=\"items | sdGroup : tableOption; $implicit as groupedItems\">\r\n <div class=\"c-container\">\r\n <div class=\"c-loading\" *ngIf=\"isLoading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <ng-container>\r\n <div\r\n class=\"c-table\"\r\n sdScroll\r\n [ngStyle]=\"{\r\n 'max-height': tableOption?.style?.maxHeight,\r\n 'min-height': tableOption?.style?.minHeight\r\n }\">\r\n <table\r\n mat-table\r\n [dataSource]=\"groupedItems\"\r\n [trackBy]=\"trackBy\"\r\n matSort\r\n [matSortDisabled]=\"!tableOption.sort?.enable\"\r\n multiTemplateDataRows>\r\n <ng-container matColumnDef=\"sdSubInformation\" sticky>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdSubInformation?.templateRef\">\r\n <ng-container *ngIf=\"tableOption?.expand?.always; else useExpandCollapse\">\r\n <ng-container *ngTemplateOutlet=\"sdSubInformation.templateRef; context: { item: item }\"> </ng-container>\r\n </ng-container>\r\n <ng-template #useExpandCollapse>\r\n <div [@detailExpand]=\"item.isExpanded ? 'expanded' : 'collapsed'\">\r\n <ng-container *ngIf=\"item.isExpanded\">\r\n <ng-container *ngTemplateOutlet=\"sdSubInformation.templateRef; context: { item: item }\"> </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\" stickyEnd>\r\n <th\r\n class=\"p-0\"\r\n mat-header-cell\r\n *matHeaderCellDef\r\n style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <button\r\n *ngIf=\"!element.isExpanding && !tableOption?.expand?.always\"\r\n mat-icon-button\r\n aria-label=\"Expand & Collapse\"\r\n (click)=\"onExpand(element)\">\r\n <mat-icon *ngIf=\"!element.isExpanded\">expand_more</mat-icon>\r\n <mat-icon *ngIf=\"element.isExpanded\">expand_less</mat-icon>\r\n </button>\r\n <div *ngIf=\"element.isExpanding\" class=\"lds-ring\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"text-center p-0\" mat-header-cell *matHeaderCellDef [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <ng-container *ngIf=\"items | selectionVisibleSelectAll : tableOption?.selector | async\">\r\n <mat-checkbox\r\n *ngIf=\"!tableOption.selector?.single\"\r\n class=\"c-selection px-15\"\r\n style=\"width: 50px\"\r\n color=\"primary\"\r\n [(ngModel)]=\"isSelectAll\"\r\n (change)=\"onSelectAll()\">\r\n </mat-checkbox>\r\n </ng-container>\r\n </th>\r\n <td class=\"text-center p-0\" mat-cell *matCellDef=\"let item\">\r\n <ng-container *ngIf=\"item | selectionVisible : tableOption?.selector\">\r\n <mat-checkbox\r\n class=\"c-selection px-15\"\r\n style=\"width: 50px\"\r\n color=\"primary\"\r\n [(ngModel)]=\"item.meta.selector.isSelected\"\r\n (change)=\"onSelect(item)\"\r\n [disabled]=\"selectedTableItems | selectionDisable : item : tableOption?.selector\">\r\n </mat-checkbox>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\" sticky>\r\n <th\r\n class=\"p-0\"\r\n mat-header-cell\r\n *matHeaderCellDef\r\n style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-command [commands]=\"tableOption.commands\" [item]=\"item\"></sd-desktop-command>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\" [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"!item?.sdGroup ? 1 : configuration.displayedColumns.length\">\r\n <div [innerHtml]=\"item?.sdGroup?.htmlTemplate | safeHtml\"></div>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container\r\n *ngFor=\"let column of configuration.firstColumns\"\r\n [matColumnDef]=\"column.field\"\r\n [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n class=\"px-8 py-8 c-th\"\r\n [ngStyle]=\"{ 'min-width': column.width }\"\r\n [attr.rowspan]=\"configuration.multipleHeader && column.type !== 'children-col' ? 2 : 1\"\r\n [attr.colspan]=\"column.type === 'children-col' ? column.children?.length : 1\">\r\n <div>\r\n <div\r\n aria-hidden=\"true\"\r\n mat-sort-header\r\n [disabled]=\"!column.sortable || column.type === 'children-col'\"\r\n [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter\r\n *ngIf=\"!tableOption.filter?.disabled && !tableOption.filter?.hideInlineFilter && columnOperator\"\r\n [value]=\"columnFilter[column.field]\"\r\n [(inlineOperator)]=\"columnOperator[column.field]\"\r\n (operatorChange)=\"onOperatorChange(column, $event)\"\r\n [columnFilter]=\"columnFilter\"\r\n [cacheValues]=\"cacheValues\"\r\n [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell\r\n class=\"d-block px-8\"\r\n *ngIf=\"!item?.sdGroup\"\r\n [value]=\"item[column.field]\"\r\n [column]=\"column\"\r\n [item]=\"item\"\r\n [cellDef]=\"cellDef\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"footerDef[column.field].templateRef; context: { items: items, column: column }\">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns\" [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header class=\"c-th px-8\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div\r\n [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter\r\n *ngIf=\"!tableOption.filter?.disabled && !tableOption.filter?.hideInlineFilter && columnOperator\"\r\n [value]=\"columnFilter[column.field]\"\r\n [(inlineOperator)]=\"columnOperator[column.field]\"\r\n (operatorChange)=\"onOperatorChange(column, $event)\"\r\n [columnFilter]=\"columnFilter\"\r\n [cacheValues]=\"cacheValues\"\r\n [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" [value]=\"item[column.field]\" [column]=\"column\" [item]=\"item\" [cellDef]=\"cellDef\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"footerDef[column.field].templateRef; context: { items: items, column: column }\">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\"></tr>\r\n <ng-container *ngIf=\"configuration.secondHeaders?.length\">\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\"></tr>\r\n </ng-container>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let row; columns: configuration.displayedColumns\"\r\n matRipple\r\n class=\"c-row\"\r\n [class.selected]=\"row.meta.selector.isSelected\"></tr>\r\n\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdSubInformation']\" class=\"c-detail-row\"></tr>\r\n <ng-container *ngIf=\"hasFooter && configuration.displayedFooters?.length\">\r\n <tr mat-footer-row *matFooterRowDef=\"configuration.displayedFooters; sticky: true\"></tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-paginator\">\r\n <div class=\"c-action\">\r\n <ng-container *sdMobileTablet>\r\n <sd-button\r\n *ngIf=\"tableFilter\"\r\n class=\"mr-8\"\r\n [title]=\"'Filter' | sdTranslate\"\r\n icon=\"filter_alt\"\r\n size=\"sm\"\r\n (action)=\"tableFilter.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-container *sdDesktop>\r\n <sd-button\r\n *ngIf=\"tableOption.reload?.visible\"\r\n class=\"mr-8\"\r\n title=\"T\u1EA3i l\u1EA1i\"\r\n icon=\"refresh\"\r\n size=\"sm\"\r\n (action)=\"reload()\"\r\n [disabled]=\"!items?.length\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-container *ngIf=\"tableOption.export?.visible && items?.length\">\r\n <ng-container *ngIf=\"isExporting; else exportable\">\r\n <sd-button class=\"mr-8\" [loading]=\"isExporting\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\" type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-template #exportable>\r\n <sd-button class=\"mr-8\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\" [matMenuTriggerFor]=\"menu\" type=\"link\">\r\n </sd-button>\r\n </ng-template>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"exportExcel()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> Xu\u1EA5t excel</span>\r\n </button>\r\n <button mat-menu-item (click)=\"exportCSV()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> Xu\u1EA5t CSV</span>\r\n </button>\r\n <button *ngIf=\"tableOption.export?.key\" mat-menu-item (click)=\"sdPopupExport.open()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">settings</mat-icon>\r\n <span>Thi\u1EBFt l\u1EADp</span>\r\n </button>\r\n </mat-menu>\r\n </ng-container>\r\n <ng-container *sdDesktop>\r\n <sd-button\r\n *ngIf=\"popupConfiguration\"\r\n class=\"mr-8\"\r\n [title]=\"'Configure' | sdTranslate\"\r\n icon=\"settings\"\r\n size=\"sm\"\r\n (action)=\"popupConfiguration.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n </div>\r\n <ng-container *sdDesktop>\r\n <mat-paginator\r\n [class.d-none]=\"tableOption.paginate?.hidden\"\r\n [length]=\"total\"\r\n [pageSize]=\"tableOption.paginate?.pageSize\"\r\n [pageSizeOptions]=\"tableOption.paginate?.pages\"\r\n [showFirstLastButtons]=\"tableOption.paginate?.showFirstLastButtons\"></mat-paginator>\r\n </ng-container>\r\n <ng-container *sdMobileTablet>\r\n <mat-paginator\r\n [class.d-none]=\"tableOption.paginate?.hidden\"\r\n [length]=\"total\"\r\n [pageSize]=\"tableOption.paginate?.pageSize\"\r\n hidePageSize=\"true\"></mat-paginator>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <sd-popup-export\r\n *ngIf=\"tableOption.export?.visible\"\r\n [configuration]=\"configuration\"\r\n [tableOption]=\"tableOption\"\r\n (export)=\"onExport($event)\"\r\n #sdPopupExport></sd-popup-export>\r\n <sd-table-quick-action [tableOption]=\"tableOption\" [selectedTableItems]=\"selectedTableItems\" (clear)=\"onClearSelection(groupedItems)\">\r\n </sd-table-quick-action>\r\n <sd-popup-configuration *ngIf=\"tableOption?.key && tableOption.config?.visible\" [tableOption]=\"tableOption\"> </sd-popup-configuration>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
3065
|
+
template: "<ng-container *ngIf=\"configuration\">\r\n <sd-table-filter\r\n *ngIf=\"!tableOption.filter?.disabled && filterRegister\"\r\n [filterRegister]=\"filterRegister\"\r\n [filter]=\"tableOption?.filter\"\r\n [columns]=\"configuration.firstColumns\"\r\n [externalFilters]=\"tableOption?.filter?.externalFilters\"\r\n [filterDefs]=\"filterDefs\">\r\n </sd-table-filter>\r\n <ng-container *ngIf=\"items | sdGroup : tableOption; $implicit as groupedItems\">\r\n <div class=\"c-container\">\r\n <div class=\"c-loading\" *ngIf=\"isLoading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <ng-container>\r\n <div\r\n class=\"c-table\"\r\n sdScroll\r\n [ngStyle]=\"{\r\n 'max-height': tableOption?.style?.maxHeight,\r\n 'min-height': tableOption?.style?.minHeight\r\n }\">\r\n <table\r\n mat-table\r\n [dataSource]=\"groupedItems\"\r\n [trackBy]=\"trackBy\"\r\n matSort\r\n [matSortDisabled]=\"!tableOption.sort?.enable\"\r\n multiTemplateDataRows>\r\n <ng-container matColumnDef=\"sdSubInformation\" sticky>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdSubInformation?.templateRef\">\r\n <ng-container *ngIf=\"tableOption?.expand?.always; else useExpandCollapse\">\r\n <ng-container *ngTemplateOutlet=\"sdSubInformation.templateRef; context: { item: item }\"> </ng-container>\r\n </ng-container>\r\n <ng-template #useExpandCollapse>\r\n <div [@detailExpand]=\"item.isExpanded ? 'expanded' : 'collapsed'\">\r\n <ng-container *ngIf=\"item.isExpanded\">\r\n <ng-container *ngTemplateOutlet=\"sdSubInformation.templateRef; context: { item: item }\"> </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\" stickyEnd>\r\n <th\r\n class=\"p-0\"\r\n mat-header-cell\r\n *matHeaderCellDef\r\n style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <button\r\n *ngIf=\"!element.isExpanding && !tableOption?.expand?.always\"\r\n mat-icon-button\r\n aria-label=\"Expand & Collapse\"\r\n (click)=\"onExpand(element)\">\r\n <mat-icon *ngIf=\"!element.isExpanded\">expand_more</mat-icon>\r\n <mat-icon *ngIf=\"element.isExpanded\">expand_less</mat-icon>\r\n </button>\r\n <div *ngIf=\"element.isExpanding\" class=\"lds-ring\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"text-center p-0\" mat-header-cell *matHeaderCellDef [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <ng-container *ngIf=\"items | selectionVisibleSelectAll : tableOption?.selector | async\">\r\n <mat-checkbox\r\n *ngIf=\"!tableOption.selector?.single\"\r\n class=\"c-selection px-15\"\r\n style=\"width: 50px\"\r\n color=\"primary\"\r\n [(ngModel)]=\"isSelectAll\"\r\n (change)=\"onSelectAll()\">\r\n </mat-checkbox>\r\n </ng-container>\r\n </th>\r\n <td class=\"text-center p-0\" mat-cell *matCellDef=\"let item\">\r\n <ng-container *ngIf=\"item | selectionVisible : tableOption?.selector\">\r\n <mat-checkbox\r\n class=\"c-selection px-15\"\r\n style=\"width: 50px\"\r\n color=\"primary\"\r\n [(ngModel)]=\"item.meta.selector.isSelected\"\r\n (change)=\"onSelect(item)\"\r\n [disabled]=\"selectedTableItems | selectionDisable : item : tableOption?.selector\">\r\n </mat-checkbox>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\" sticky>\r\n <th\r\n class=\"p-0\"\r\n mat-header-cell\r\n *matHeaderCellDef\r\n style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-command [commands]=\"tableOption.commands\" [item]=\"item\"></sd-desktop-command>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\" [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"!item?.sdGroup ? 1 : configuration.displayedColumns.length\">\r\n <div [innerHtml]=\"item?.sdGroup?.htmlTemplate | safeHtml\"></div>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container\r\n *ngFor=\"let column of configuration.firstColumns\"\r\n [matColumnDef]=\"column.field\"\r\n [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n class=\"px-8 py-8 c-th\"\r\n [ngStyle]=\"{ 'min-width': column.width }\"\r\n [attr.rowspan]=\"configuration.multipleHeader && column.type !== 'children-col' ? 2 : 1\"\r\n [attr.colspan]=\"column.type === 'children-col' ? column.children?.length : 1\">\r\n <div>\r\n <div\r\n aria-hidden=\"true\"\r\n mat-sort-header\r\n [disabled]=\"!column.sortable || column.type === 'children-col'\"\r\n [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter\r\n *ngIf=\"!tableOption.filter?.disabled && !tableOption.filter?.hideInlineFilter && columnOperator\"\r\n [value]=\"columnFilter[column.field]\"\r\n [(inlineOperator)]=\"columnOperator[column.field]\"\r\n (operatorChange)=\"onOperatorChange(column, $event)\"\r\n [columnFilter]=\"columnFilter\"\r\n [cacheValues]=\"cacheValues\"\r\n [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell\r\n class=\"d-block px-8\"\r\n *ngIf=\"!item?.sdGroup\"\r\n [value]=\"item[column.field]\"\r\n [column]=\"column\"\r\n [item]=\"item\"\r\n [cellDef]=\"cellDef\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"footerDef[column.field].templateRef; context: { items: items, column: column }\">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns\" [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header class=\"c-th px-8\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div\r\n [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter\r\n *ngIf=\"!tableOption.filter?.disabled && !tableOption.filter?.hideInlineFilter && columnOperator\"\r\n [value]=\"columnFilter[column.field]\"\r\n [(inlineOperator)]=\"columnOperator[column.field]\"\r\n (operatorChange)=\"onOperatorChange(column, $event)\"\r\n [columnFilter]=\"columnFilter\"\r\n [cacheValues]=\"cacheValues\"\r\n [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" [value]=\"item[column.field]\" [column]=\"column\" [item]=\"item\" [cellDef]=\"cellDef\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"footerDef[column.field].templateRef; context: { items: items, column: column }\">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\"></tr>\r\n <ng-container *ngIf=\"configuration.secondHeaders?.length\">\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\"></tr>\r\n </ng-container>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let row; columns: configuration.displayedColumns\"\r\n matRipple\r\n class=\"c-row\"\r\n [class.selected]=\"row.meta.selector.isSelected\"></tr>\r\n\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdSubInformation']\" class=\"c-detail-row\"></tr>\r\n <ng-container *ngIf=\"hasFooter && configuration.displayedFooters?.length\">\r\n <tr mat-footer-row *matFooterRowDef=\"configuration.displayedFooters; sticky: true\"></tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-paginator\">\r\n <div class=\"c-action\">\r\n <ng-container *sdMobileTablet>\r\n <sd-button\r\n *ngIf=\"tableFilter\"\r\n class=\"mr-8\"\r\n [title]=\"'Filter' | sdTranslate\"\r\n icon=\"filter_alt\"\r\n size=\"sm\"\r\n (action)=\"tableFilter.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-container *sdDesktop>\r\n <sd-button\r\n *ngIf=\"tableFilter\"\r\n class=\"mr-8\"\r\n [title]=\"'Filter' | sdTranslate\"\r\n icon=\"filter_alt\"\r\n size=\"sm\"\r\n (action)=\"tableFilter.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n <sd-button\r\n *ngIf=\"tableOption.reload?.visible\"\r\n class=\"mr-8\"\r\n title=\"T\u1EA3i l\u1EA1i\"\r\n icon=\"refresh\"\r\n size=\"sm\"\r\n (action)=\"reload()\"\r\n [disabled]=\"!items?.length\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-container *ngIf=\"tableOption.export?.visible && items?.length\">\r\n <ng-container *ngIf=\"isExporting; else exportable\">\r\n <sd-button class=\"mr-8\" [loading]=\"isExporting\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\" type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-template #exportable>\r\n <sd-button class=\"mr-8\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\" [matMenuTriggerFor]=\"menu\" type=\"link\">\r\n </sd-button>\r\n </ng-template>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"exportExcel()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> Xu\u1EA5t excel</span>\r\n </button>\r\n <button mat-menu-item (click)=\"exportCSV()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> Xu\u1EA5t CSV</span>\r\n </button>\r\n <button *ngIf=\"tableOption.export?.key\" mat-menu-item (click)=\"sdPopupExport.open()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">settings</mat-icon>\r\n <span>Thi\u1EBFt l\u1EADp</span>\r\n </button>\r\n </mat-menu>\r\n </ng-container>\r\n <ng-container *sdDesktop>\r\n <sd-button\r\n *ngIf=\"popupConfiguration\"\r\n class=\"mr-8\"\r\n [title]=\"'Configure' | sdTranslate\"\r\n icon=\"settings\"\r\n size=\"sm\"\r\n (action)=\"popupConfiguration.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n </div>\r\n <ng-container *sdDesktop>\r\n <mat-paginator\r\n [class.d-none]=\"tableOption.paginate?.hidden\"\r\n [length]=\"total\"\r\n [pageSize]=\"tableOption.paginate?.pageSize\"\r\n [pageSizeOptions]=\"tableOption.paginate?.pages\"\r\n [showFirstLastButtons]=\"tableOption.paginate?.showFirstLastButtons\"></mat-paginator>\r\n </ng-container>\r\n <ng-container *sdMobileTablet>\r\n <mat-paginator\r\n [class.d-none]=\"tableOption.paginate?.hidden\"\r\n [length]=\"total\"\r\n [pageSize]=\"tableOption.paginate?.pageSize\"\r\n hidePageSize=\"true\"></mat-paginator>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <sd-popup-export\r\n *ngIf=\"tableOption.export?.visible\"\r\n [configuration]=\"configuration\"\r\n [tableOption]=\"tableOption\"\r\n (export)=\"onExport($event)\"\r\n #sdPopupExport></sd-popup-export>\r\n <sd-table-quick-action [tableOption]=\"tableOption\" [selectedTableItems]=\"selectedTableItems\" (clear)=\"onClearSelection(groupedItems)\">\r\n </sd-table-quick-action>\r\n <sd-popup-configuration *ngIf=\"tableOption?.key && tableOption.config?.visible\" [tableOption]=\"tableOption\"> </sd-popup-configuration>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
3058
3066
|
changeDetection: core.ChangeDetectionStrategy.OnPush,
|
|
3059
3067
|
animations: [
|
|
3060
3068
|
animations.trigger('detailExpand', [
|