@servicelabsco/slabs-access-manager 0.1.59 → 0.1.61
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/dist/access/access.module.js +2 -1
- package/dist/access/access.module.js.map +1 -1
- package/dist/access/controllers/bulk.upload.controller.d.ts +25 -0
- package/dist/access/controllers/bulk.upload.controller.js +141 -0
- package/dist/access/controllers/bulk.upload.controller.js.map +1 -0
- package/dist/access/controllers/bulk.upload.item.controller.d.ts +12 -0
- package/dist/access/controllers/bulk.upload.item.controller.js +63 -0
- package/dist/access/controllers/bulk.upload.item.controller.js.map +1 -0
- package/dist/access/controllers/choice.type.controller.d.ts +3 -3
- package/dist/access/controllers/choice.type.controller.js +6 -6
- package/dist/access/controllers/choice.type.controller.js.map +1 -1
- package/dist/access/controllers/index.d.ts +2 -0
- package/dist/access/controllers/index.js +2 -0
- package/dist/access/controllers/index.js.map +1 -1
- package/dist/access/dtos/bulk.upload.item.list.filter.dto.d.ts +6 -0
- package/dist/access/dtos/bulk.upload.item.list.filter.dto.js +30 -0
- package/dist/access/dtos/bulk.upload.item.list.filter.dto.js.map +1 -0
- package/dist/access/dtos/bulk.upload.list.filter.dto.d.ts +4 -0
- package/dist/access/dtos/bulk.upload.list.filter.dto.js +25 -0
- package/dist/access/dtos/bulk.upload.list.filter.dto.js.map +1 -0
- package/dist/access/dtos/index.d.ts +2 -0
- package/dist/access/dtos/index.js +2 -0
- package/dist/access/dtos/index.js.map +1 -1
- package/dist/access/es6.classes.d.ts +11 -5
- package/dist/access/es6.classes.js +16 -0
- package/dist/access/es6.classes.js.map +1 -1
- package/dist/access/jobs/group.role.job.js +3 -3
- package/dist/access/jobs/index.d.ts +1 -0
- package/dist/access/jobs/index.js +1 -0
- package/dist/access/jobs/index.js.map +1 -1
- package/dist/access/jobs/sync.b.u.role.job.d.ts +9 -0
- package/dist/access/jobs/sync.b.u.role.job.js +46 -0
- package/dist/access/jobs/sync.b.u.role.job.js.map +1 -0
- package/dist/access/libraries/index.d.ts +3 -0
- package/dist/access/libraries/index.js +3 -0
- package/dist/access/libraries/index.js.map +1 -1
- package/dist/access/libraries/process.bulk.upload.item.list.d.ts +21 -0
- package/dist/access/libraries/process.bulk.upload.item.list.js +42 -0
- package/dist/access/libraries/process.bulk.upload.item.list.js.map +1 -0
- package/dist/access/libraries/process.bulk.upload.list.d.ts +21 -0
- package/dist/access/libraries/process.bulk.upload.list.js +40 -0
- package/dist/access/libraries/process.bulk.upload.list.js.map +1 -0
- package/dist/access/libraries/process.business.user.role.update.js +3 -3
- package/dist/access/libraries/sync.business.user.role.d.ts +12 -0
- package/dist/access/libraries/sync.business.user.role.js +51 -0
- package/dist/access/libraries/sync.business.user.role.js.map +1 -0
- package/dist/access/services/es6.jobs.service.d.ts +3 -1
- package/dist/access/services/es6.jobs.service.js +5 -1
- package/dist/access/services/es6.jobs.service.js.map +1 -1
- package/dist/accessUtility/dtos/bulk.upload.attributes.dto.d.ts +1 -0
- package/dist/accessUtility/dtos/bulk.upload.attributes.dto.js.map +1 -1
- package/dist/accessUtility/dtos/bulk.upload.item.attributes.dto.d.ts +2 -0
- package/dist/accessUtility/dtos/bulk.upload.item.attributes.dto.js.map +1 -1
- package/dist/accessUtility/dtos/document.file.upload.dto.d.ts +4 -0
- package/dist/accessUtility/dtos/document.file.upload.dto.js +27 -0
- package/dist/accessUtility/dtos/document.file.upload.dto.js.map +1 -0
- package/dist/accessUtility/dtos/index.d.ts +1 -0
- package/dist/accessUtility/dtos/index.js +1 -0
- package/dist/accessUtility/dtos/index.js.map +1 -1
- package/dist/accessUtility/es6.classes.d.ts +7 -2
- package/dist/accessUtility/es6.classes.js +9 -2
- package/dist/accessUtility/es6.classes.js.map +1 -1
- package/dist/accessUtility/jobs/bulk.upload.job.d.ts +8 -2
- package/dist/accessUtility/jobs/bulk.upload.job.js +40 -2
- package/dist/accessUtility/jobs/bulk.upload.job.js.map +1 -1
- package/dist/accessUtility/libraries/analyse.bulk.upload.d.ts +12 -0
- package/dist/accessUtility/libraries/analyse.bulk.upload.js +35 -0
- package/dist/accessUtility/libraries/analyse.bulk.upload.js.map +1 -0
- package/dist/accessUtility/libraries/generate.bulk.upload.sheet.d.ts +32 -0
- package/dist/accessUtility/libraries/generate.bulk.upload.sheet.js +211 -0
- package/dist/accessUtility/libraries/generate.bulk.upload.sheet.js.map +1 -0
- package/dist/accessUtility/libraries/index.d.ts +4 -0
- package/dist/accessUtility/libraries/index.js +4 -0
- package/dist/accessUtility/libraries/index.js.map +1 -1
- package/dist/accessUtility/libraries/read.xls.file.d.ts +24 -0
- package/dist/accessUtility/libraries/read.xls.file.js +149 -0
- package/dist/accessUtility/libraries/read.xls.file.js.map +1 -0
- package/dist/accessUtility/libraries/set.bulk.upload.log.file.d.ts +22 -0
- package/dist/accessUtility/libraries/set.bulk.upload.log.file.js +112 -0
- package/dist/accessUtility/libraries/set.bulk.upload.log.file.js.map +1 -0
- package/dist/accessUtility/services/bulk.upload.service.d.ts +9 -0
- package/dist/accessUtility/services/bulk.upload.service.js +53 -0
- package/dist/accessUtility/services/bulk.upload.service.js.map +1 -0
- package/dist/accessUtility/services/index.d.ts +1 -0
- package/dist/accessUtility/services/index.js +1 -0
- package/dist/accessUtility/services/index.js.map +1 -1
- package/dist/accessUtility/subscribers/bulk.upload.item.subscriber.d.ts +1 -0
- package/dist/accessUtility/subscribers/bulk.upload.item.subscriber.js +6 -0
- package/dist/accessUtility/subscribers/bulk.upload.item.subscriber.js.map +1 -1
- package/dist/config/source.hash.d.ts +2 -2
- package/dist/config/source.hash.js +2 -2
- package/dist/migrations/{1681373004868-AddCustomFieldTypesDataSeederTable.d.ts → 1681369386555-AddCustomColumnTypesDataSeederTable.d.ts} +1 -1
- package/dist/migrations/1681369386555-AddCustomColumnTypesDataSeederTable.js +79 -0
- package/dist/migrations/1681369386555-AddCustomColumnTypesDataSeederTable.js.map +1 -0
- package/package.json +4 -2
- package/dist/migrations/1681373004868-AddCustomFieldTypesDataSeederTable.js +0 -107
- package/dist/migrations/1681373004868-AddCustomFieldTypesDataSeederTable.js.map +0 -1
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ReadXlsFile = void 0;
|
|
4
|
+
const nestjs_utility_services_1 = require("@servicelabsco/nestjs-utility-services");
|
|
5
|
+
const path_1 = require("path");
|
|
6
|
+
const fs_1 = require("fs");
|
|
7
|
+
const ExcelJS = require("exceljs");
|
|
8
|
+
const csv = require("csv-parser");
|
|
9
|
+
const bulk_upload_item_entity_1 = require("../entities/bulk.upload.item.entity");
|
|
10
|
+
class ReadXlsFile {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.promises = [];
|
|
13
|
+
}
|
|
14
|
+
async handle(types) {
|
|
15
|
+
const extension = this.upload.file_url.split('.').pop().toLowerCase();
|
|
16
|
+
if (extension === 'csv')
|
|
17
|
+
return this.processCsv(types);
|
|
18
|
+
if (extension === 'xlsx')
|
|
19
|
+
return this.processXls(types);
|
|
20
|
+
this.upload.attributes = { ...this.upload.attributes, error: 'cannot parse file. Invalid extension' };
|
|
21
|
+
return this.upload.save();
|
|
22
|
+
}
|
|
23
|
+
async processXls(types) {
|
|
24
|
+
await this.excelInit();
|
|
25
|
+
if (!types.length)
|
|
26
|
+
return this.readAllSheets();
|
|
27
|
+
for (const type of types) {
|
|
28
|
+
const d = this.getDictionaryOfType(type);
|
|
29
|
+
await this.readWorksheet(d.sheetName, d.columns);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async processCsv(types) {
|
|
33
|
+
const d = this.getDictionaryOfType(types[0]);
|
|
34
|
+
const buffer = await this.uploadService.getBufferFromUrl(this.upload.file_url);
|
|
35
|
+
const tempPath = (0, path_1.join)(__dirname, `../../../tmp/${this.upload.uuid}.${nestjs_utility_services_1.PlatformUtility.generateRandomAlpha(6).toLowerCase()}.${d.sheetName}.csv`);
|
|
36
|
+
(0, fs_1.writeFileSync)(tempPath, buffer);
|
|
37
|
+
await this.readCsv(tempPath, d?.sheetName, d?.columns);
|
|
38
|
+
return (0, fs_1.unlink)(tempPath, () => { });
|
|
39
|
+
}
|
|
40
|
+
getDictionaryOfType(type) {
|
|
41
|
+
const columns = this.getDictionary(type?.columns);
|
|
42
|
+
const sheetName = type?.name || 'sheet 1';
|
|
43
|
+
return { columns, sheetName };
|
|
44
|
+
}
|
|
45
|
+
async excelInit() {
|
|
46
|
+
this.workbook = new ExcelJS.Workbook();
|
|
47
|
+
const buffer = await this.uploadService.getBufferFromUrl(this.upload.file_url);
|
|
48
|
+
await this.workbook.xlsx.load(buffer);
|
|
49
|
+
}
|
|
50
|
+
async readWorksheet(sheet, columns = {}) {
|
|
51
|
+
const tempPath = (0, path_1.join)(__dirname, `../../../tmp/${this.upload.uuid}.${nestjs_utility_services_1.PlatformUtility.generateRandomAlpha(6).toLowerCase()}.${sheet}.csv`);
|
|
52
|
+
const writeStream = (0, fs_1.createWriteStream)(tempPath);
|
|
53
|
+
await this.workbook.csv.write(writeStream, { sheetName: sheet });
|
|
54
|
+
await this.readCsv(tempPath, sheet, columns);
|
|
55
|
+
return (0, fs_1.unlink)(tempPath, () => { });
|
|
56
|
+
}
|
|
57
|
+
async readAllSheets() {
|
|
58
|
+
for (let i = 1; i < 100; ++i) {
|
|
59
|
+
const worksheet = this.workbook.getWorksheet(i);
|
|
60
|
+
const sheet = worksheet?.name;
|
|
61
|
+
if (!sheet)
|
|
62
|
+
continue;
|
|
63
|
+
await this.readWorksheet(sheet, {});
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async readCsv(tempPath, sheet, columns) {
|
|
67
|
+
const fn = this;
|
|
68
|
+
let rowNumber = 0;
|
|
69
|
+
return new Promise((resolve, reject) => {
|
|
70
|
+
this.promises = [];
|
|
71
|
+
(0, fs_1.createReadStream)(tempPath)
|
|
72
|
+
.pipe(csv({
|
|
73
|
+
mapHeaders: ({ header, index }) => fn.mapHeader(header, columns?.headers),
|
|
74
|
+
mapValues: ({ header, index, value }) => fn.castValue(columns, header, value),
|
|
75
|
+
}))
|
|
76
|
+
.on('data', (data) => {
|
|
77
|
+
++rowNumber;
|
|
78
|
+
fn.promises.push(fn.processRow(sheet, rowNumber, data));
|
|
79
|
+
})
|
|
80
|
+
.on('end', () => {
|
|
81
|
+
resolve(rowNumber);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
async processRow(sheet, rowNumber, record) {
|
|
86
|
+
const r = await bulk_upload_item_entity_1.BulkUploadItemEntity.firstOrNew({ bulk_upload_id: this.upload.id, sheet, row_num: rowNumber });
|
|
87
|
+
r.data = record;
|
|
88
|
+
await r.save();
|
|
89
|
+
}
|
|
90
|
+
castValue(columns = {}, header, value) {
|
|
91
|
+
if (!Object.keys(columns).length)
|
|
92
|
+
return this.getStringValue(value);
|
|
93
|
+
if (columns.stringColumns.includes(header))
|
|
94
|
+
return this.getStringValue(value);
|
|
95
|
+
if (columns.numberColumns.includes(header))
|
|
96
|
+
return this.getNumberValue(value);
|
|
97
|
+
if (columns.booleanColumns.includes(header))
|
|
98
|
+
return this.getBooleanValue(value);
|
|
99
|
+
return this.getStringValue(value);
|
|
100
|
+
}
|
|
101
|
+
getDictionary(columns) {
|
|
102
|
+
const headers = {};
|
|
103
|
+
const stringColumns = [];
|
|
104
|
+
const numberColumns = [];
|
|
105
|
+
const booleanColumns = [];
|
|
106
|
+
columns.forEach((column) => {
|
|
107
|
+
const header = column.identifier;
|
|
108
|
+
headers[column.name] = header;
|
|
109
|
+
if (column.column_type_id === 1)
|
|
110
|
+
stringColumns.push(header);
|
|
111
|
+
if (column.column_type_id === 2)
|
|
112
|
+
numberColumns.push(header);
|
|
113
|
+
if (column.column_type_id === 5)
|
|
114
|
+
booleanColumns.push(header);
|
|
115
|
+
});
|
|
116
|
+
return { headers, stringColumns, numberColumns, booleanColumns };
|
|
117
|
+
}
|
|
118
|
+
mapHeader(header, headers = []) {
|
|
119
|
+
let str = header.replace(/[^a-zA-Z0-9 ]/g, '');
|
|
120
|
+
str = str.trim().replaceAll(' ', '_');
|
|
121
|
+
return headers[str] || str.toLowerCase();
|
|
122
|
+
}
|
|
123
|
+
getStringValue(str) {
|
|
124
|
+
if (!str)
|
|
125
|
+
return null;
|
|
126
|
+
if (str.length)
|
|
127
|
+
return str.trim();
|
|
128
|
+
return null;
|
|
129
|
+
}
|
|
130
|
+
getNumberValue(str) {
|
|
131
|
+
if (!str)
|
|
132
|
+
return null;
|
|
133
|
+
str = str.replaceAll(',', '');
|
|
134
|
+
if (str.length)
|
|
135
|
+
return +str.trim();
|
|
136
|
+
return null;
|
|
137
|
+
}
|
|
138
|
+
getBooleanValue(str) {
|
|
139
|
+
if (!str)
|
|
140
|
+
return null;
|
|
141
|
+
if (!str.length)
|
|
142
|
+
return null;
|
|
143
|
+
if (str.toLowerCase() === 'true')
|
|
144
|
+
return true;
|
|
145
|
+
return false;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
exports.ReadXlsFile = ReadXlsFile;
|
|
149
|
+
//# sourceMappingURL=read.xls.file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read.xls.file.js","sourceRoot":"","sources":["../../../src/accessUtility/libraries/read.xls.file.ts"],"names":[],"mappings":";;;AAAA,oFAAwF;AAGxF,+BAA4B;AAC5B,2BAAgF;AAChF,mCAAoC;AACpC,kCAAkC;AAClC,iFAA2E;AAG3E,MAAa,WAAW;IAAxB;QAIY,aAAQ,GAAG,EAAE,CAAC;IAwK1B,CAAC;IAtKa,KAAK,CAAC,MAAM,CAAC,KAA6B;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;QAEtE,IAAI,SAAS,KAAK,KAAK;YAAE,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,SAAS,KAAK,MAAM;YAAE,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAExD,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,KAAK,EAAE,sCAAsC,EAAE,CAAC;QAEtG,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC;IAEO,KAAK,CAAC,UAAU,CAAC,KAA6B;QAClD,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;QAEvB,IAAI,CAAC,KAAK,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;QAE/C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACvB,MAAM,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAEzC,MAAM,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC;IACL,CAAC;IACO,KAAK,CAAC,UAAU,CAAC,KAA6B;QAClD,MAAM,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE/E,MAAM,QAAQ,GAAG,IAAA,WAAI,EACjB,SAAS,EACT,gBAAgB,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,yCAAe,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,SAAS,MAAM,CAChH,CAAC;QAEF,IAAA,kBAAa,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEhC,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QACvD,OAAO,IAAA,WAAM,EAAC,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACtC,CAAC;IAEO,mBAAmB,CAAC,IAA0B;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,SAAS,GAAG,IAAI,EAAE,IAAI,IAAI,SAAS,CAAC;QAE1C,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;IAClC,CAAC;IAEO,KAAK,CAAC,SAAS;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QAEvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC/E,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,KAAa,EAAE,UAAe,EAAE;QACxD,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,SAAS,EAAE,gBAAgB,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,yCAAe,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,IAAI,KAAK,MAAM,CAAC,CAAC;QAE1I,MAAM,WAAW,GAAG,IAAA,sBAAiB,EAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAEjE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QAE7C,OAAO,IAAA,WAAM,EAAC,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACtC,CAAC;IAEO,KAAK,CAAC,aAAa;QACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC;YAC3B,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAChD,MAAM,KAAK,GAAG,SAAS,EAAE,IAAI,CAAC;YAE9B,IAAI,CAAC,KAAK;gBAAE,SAAS;YAErB,MAAM,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,OAAO,CAAC,QAAgB,EAAE,KAAa,EAAE,OAAY;QAC/D,MAAM,EAAE,GAAG,IAAI,CAAC;QAChB,IAAI,SAAS,GAAG,CAAC,CAAC;QAElB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACnC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;YACnB,IAAA,qBAAgB,EAAC,QAAQ,CAAC;iBACrB,IAAI,CACD,GAAG,CAAC;gBACA,UAAU,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC;gBACzE,SAAS,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC;aAChF,CAAC,CACL;iBACA,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;gBACjB,EAAE,SAAS,CAAC;gBACZ,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC;YAC5D,CAAC,CAAC;iBACD,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;gBACZ,OAAO,CAAC,SAAS,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,MAAW;QAClD,MAAM,CAAC,GAAG,MAAM,8CAAoB,CAAC,UAAU,CAAC,EAAE,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QAE/G,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC;QAEhB,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC;IACnB,CAAC;IAEO,SAAS,CAAC,UAAe,EAAE,EAAE,MAAc,EAAE,KAAa;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAEpE,IAAI,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9E,IAAI,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9E,IAAI,OAAO,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAEhF,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEO,aAAa,CAAC,OAAiC;QACnD,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,MAAM,aAAa,GAAa,EAAE,CAAC;QACnC,MAAM,aAAa,GAAa,EAAE,CAAC;QACnC,MAAM,cAAc,GAAa,EAAE,CAAC;QAEpC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACvB,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC;YACjC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;YAE9B,IAAI,MAAM,CAAC,cAAc,KAAK,CAAC;gBAAE,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5D,IAAI,MAAM,CAAC,cAAc,KAAK,CAAC;gBAAE,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5D,IAAI,MAAM,CAAC,cAAc,KAAK,CAAC;gBAAE,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,EAAE,CAAC;IACrE,CAAC;IAEO,SAAS,CAAC,MAAc,EAAE,UAAe,EAAE;QAC/C,IAAI,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC;QAC/C,GAAG,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACtC,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAEO,cAAc,CAAC,GAAW;QAC9B,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QAEtB,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO,GAAG,CAAC,IAAI,EAAE,CAAC;QAElC,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,cAAc,CAAC,GAAW;QAC9B,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QAEtB,GAAG,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAE9B,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QAEnC,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,eAAe,CAAC,GAAW;QAC/B,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QAEtB,IAAI,CAAC,GAAG,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC;QAE7B,IAAI,GAAG,CAAC,WAAW,EAAE,KAAK,MAAM;YAAE,OAAO,IAAI,CAAC;QAE9C,OAAO,KAAK,CAAC;IACjB,CAAC;CACJ;AA5KD,kCA4KC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { UploadService } from '@servicelabsco/nestjs-utility-services';
|
|
2
|
+
import { BulkUploadEntity } from '../entities/bulk.upload.entity';
|
|
3
|
+
import { BulkUploadService } from '../services/bulk.upload.service';
|
|
4
|
+
export declare class SetBulkUploadLogFile {
|
|
5
|
+
private readonly uploadService;
|
|
6
|
+
private readonly bulkUploadService;
|
|
7
|
+
private workbook;
|
|
8
|
+
private upload;
|
|
9
|
+
private headersMapping;
|
|
10
|
+
constructor(uploadService: UploadService, bulkUploadService: BulkUploadService);
|
|
11
|
+
process(upload: BulkUploadEntity): Promise<BulkUploadEntity>;
|
|
12
|
+
private handleSheet;
|
|
13
|
+
private setError;
|
|
14
|
+
private addAdditionalLogColumns;
|
|
15
|
+
private init;
|
|
16
|
+
private setMapping;
|
|
17
|
+
private getColumnPrefix;
|
|
18
|
+
private getMaxWidthOfSheet;
|
|
19
|
+
private getCell;
|
|
20
|
+
private getColumn;
|
|
21
|
+
private getFile;
|
|
22
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SetBulkUploadLogFile = void 0;
|
|
4
|
+
const nestjs_utility_services_1 = require("@servicelabsco/nestjs-utility-services");
|
|
5
|
+
const bulk_upload_entity_1 = require("../entities/bulk.upload.entity");
|
|
6
|
+
const bulk_upload_item_entity_1 = require("../entities/bulk.upload.item.entity");
|
|
7
|
+
const ExcelJS = require("exceljs");
|
|
8
|
+
const custom_field_entity_1 = require("../../access/entities/custom.field.entity");
|
|
9
|
+
class SetBulkUploadLogFile {
|
|
10
|
+
constructor(uploadService, bulkUploadService) {
|
|
11
|
+
this.uploadService = uploadService;
|
|
12
|
+
this.bulkUploadService = bulkUploadService;
|
|
13
|
+
this.headersMapping = {};
|
|
14
|
+
}
|
|
15
|
+
async process(upload) {
|
|
16
|
+
this.upload = upload;
|
|
17
|
+
await this.init();
|
|
18
|
+
const types = await this.bulkUploadService.getUploadTypes(upload);
|
|
19
|
+
for (const type of types) {
|
|
20
|
+
await this.handleSheet(type);
|
|
21
|
+
}
|
|
22
|
+
const file = await this.getFile();
|
|
23
|
+
const entity = await bulk_upload_entity_1.BulkUploadEntity.first(upload.id);
|
|
24
|
+
entity.stats = { ...entity.stats, log_file: file };
|
|
25
|
+
return entity.save();
|
|
26
|
+
}
|
|
27
|
+
async handleSheet(type) {
|
|
28
|
+
await this.setMapping(type);
|
|
29
|
+
const sheet = type.name.toLowerCase();
|
|
30
|
+
const worksheet = this.workbook.getWorksheet(sheet);
|
|
31
|
+
if (!worksheet)
|
|
32
|
+
return;
|
|
33
|
+
const width = await this.getMaxWidthOfSheet(type);
|
|
34
|
+
this.addAdditionalLogColumns(worksheet, width);
|
|
35
|
+
const items = await bulk_upload_item_entity_1.BulkUploadItemEntity.find({ where: { bulk_upload_id: this.upload.id, sheet }, order: { row_num: 'asc' } });
|
|
36
|
+
for (const item of items) {
|
|
37
|
+
await this.setError(item, worksheet, width);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
async setError(item, worksheet, width) {
|
|
41
|
+
const statusCell = this.getCell(item.row_num + 1, width + 1);
|
|
42
|
+
const recordCell = this.getCell(item.row_num + 1, width + 2);
|
|
43
|
+
const errorCell = this.getCell(item.row_num + 1, width + 3);
|
|
44
|
+
let status = 'success';
|
|
45
|
+
if (item.attributes?.object_id)
|
|
46
|
+
worksheet.getCell(recordCell).value = item.attributes?.object_id;
|
|
47
|
+
for (const [key, value] of Object.entries(item.error?.columns || {})) {
|
|
48
|
+
const column = this.getColumn(item.sheet, key, item.row_num + 1);
|
|
49
|
+
worksheet.getCell(column).note = value;
|
|
50
|
+
status = 'Partial';
|
|
51
|
+
}
|
|
52
|
+
if (item.error?.error) {
|
|
53
|
+
worksheet.getCell(errorCell).value = item.error.error;
|
|
54
|
+
status = 'error';
|
|
55
|
+
}
|
|
56
|
+
worksheet.getCell(statusCell).value = status;
|
|
57
|
+
}
|
|
58
|
+
addAdditionalLogColumns(worksheet, width) {
|
|
59
|
+
const statusCell = this.getCell(1, width + 1);
|
|
60
|
+
const recordCell = this.getCell(1, width + 2);
|
|
61
|
+
const errorCell = this.getCell(1, width + 3);
|
|
62
|
+
worksheet.getCell(statusCell).value = 'Status';
|
|
63
|
+
worksheet.getCell(recordCell).value = 'Reference Record';
|
|
64
|
+
worksheet.getCell(errorCell).value = 'Errors';
|
|
65
|
+
}
|
|
66
|
+
async init() {
|
|
67
|
+
this.workbook = new ExcelJS.Workbook();
|
|
68
|
+
const buffer = await this.uploadService.getBufferFromUrl(this.upload.file_url);
|
|
69
|
+
await this.workbook.xlsx.load(buffer);
|
|
70
|
+
}
|
|
71
|
+
async setMapping(type) {
|
|
72
|
+
const headers = {};
|
|
73
|
+
const sheet = type.name.toLowerCase();
|
|
74
|
+
type.columns.forEach((column) => {
|
|
75
|
+
const header = column.identifier.split('.')[0].toLowerCase();
|
|
76
|
+
headers[header] = this.getColumnPrefix(column.priority);
|
|
77
|
+
});
|
|
78
|
+
this.headersMapping[sheet] = headers;
|
|
79
|
+
}
|
|
80
|
+
getColumnPrefix(i, pre) {
|
|
81
|
+
let prefix = '';
|
|
82
|
+
if (pre)
|
|
83
|
+
prefix = this.getColumnPrefix(pre - 1);
|
|
84
|
+
const quotient = Math.floor(i / 26);
|
|
85
|
+
const fraction = i % 26;
|
|
86
|
+
if (quotient)
|
|
87
|
+
return this.getColumnPrefix(fraction, quotient);
|
|
88
|
+
const str = String.fromCharCode(65 + fraction);
|
|
89
|
+
return `${prefix}${str}`;
|
|
90
|
+
}
|
|
91
|
+
async getMaxWidthOfSheet(type) {
|
|
92
|
+
if (!type.custom_field_id)
|
|
93
|
+
return type.columns.length;
|
|
94
|
+
const count = await custom_field_entity_1.CustomFieldEntity.count({ where: { business_id: this.upload.business_id, type_id: type.custom_field_id } });
|
|
95
|
+
return type.columns.length + count;
|
|
96
|
+
}
|
|
97
|
+
getCell(row, i) {
|
|
98
|
+
const str = this.getColumnPrefix(i);
|
|
99
|
+
return `${str}${row}`;
|
|
100
|
+
}
|
|
101
|
+
getColumn(sheet, column, rowNum) {
|
|
102
|
+
const cell = this.headersMapping[sheet][column];
|
|
103
|
+
return `${cell}${rowNum}`;
|
|
104
|
+
}
|
|
105
|
+
async getFile() {
|
|
106
|
+
const buffer = await this.workbook.xlsx.writeBuffer();
|
|
107
|
+
const originalname = `i-${nestjs_utility_services_1.PlatformUtility.generateRandomAlphaNumeric(6).toLowerCase()}-${nestjs_utility_services_1.DateUtil.getDateInFormat()}.xlsx`;
|
|
108
|
+
return this.uploadService.upload({ buffer, originalname }, { folder: 'public/bulk' });
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
exports.SetBulkUploadLogFile = SetBulkUploadLogFile;
|
|
112
|
+
//# sourceMappingURL=set.bulk.upload.log.file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set.bulk.upload.log.file.js","sourceRoot":"","sources":["../../../src/accessUtility/libraries/set.bulk.upload.log.file.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BulkUploadEntity } from '../entities/bulk.upload.entity';
|
|
2
|
+
import { BulkUploadTypeEntity } from '../entities/bulk.upload.type.entity';
|
|
3
|
+
import { AccessBusinessEntity } from '../../access/entities/access.business.entity';
|
|
4
|
+
import { DocumentFileUploadDto } from '../dtos/document.file.upload.dto';
|
|
5
|
+
export declare class BulkUploadService {
|
|
6
|
+
setUpload(business: AccessBusinessEntity, typeId: number, files: DocumentFileUploadDto): Promise<BulkUploadEntity>;
|
|
7
|
+
getUploadTypes(upload: BulkUploadEntity): Promise<BulkUploadTypeEntity[]>;
|
|
8
|
+
getSheets(upload: BulkUploadEntity): Promise<string[]>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.BulkUploadService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const nestjs_utility_services_1 = require("@servicelabsco/nestjs-utility-services");
|
|
12
|
+
const bulk_definition_entity_1 = require("../entities/bulk.definition.entity");
|
|
13
|
+
const bulk_definition_load_entity_1 = require("../entities/bulk.definition.load.entity");
|
|
14
|
+
const bulk_upload_entity_1 = require("../entities/bulk.upload.entity");
|
|
15
|
+
let BulkUploadService = class BulkUploadService {
|
|
16
|
+
async setUpload(business, typeId, files) {
|
|
17
|
+
const type = await bulk_definition_entity_1.BulkDefinitionEntity.first(typeId);
|
|
18
|
+
if (!type)
|
|
19
|
+
throw new nestjs_utility_services_1.OperationException(`This type is not valid`);
|
|
20
|
+
const record = bulk_upload_entity_1.BulkUploadEntity.create({ business_id: business.id });
|
|
21
|
+
record.definition_id = typeId;
|
|
22
|
+
record.file_url = files.files[0].document_url;
|
|
23
|
+
record.attributes = { ...record.attributes, ...files.files[0].attributes };
|
|
24
|
+
return record.save();
|
|
25
|
+
}
|
|
26
|
+
async getUploadTypes(upload) {
|
|
27
|
+
if (!upload.definition_id)
|
|
28
|
+
return [];
|
|
29
|
+
const loads = await bulk_definition_load_entity_1.BulkDefinitionLoadEntity.find({
|
|
30
|
+
where: { definition_id: upload.definition_id },
|
|
31
|
+
relations: ['type', 'type.columns'],
|
|
32
|
+
order: { priority: 'ASC' },
|
|
33
|
+
});
|
|
34
|
+
const types = [];
|
|
35
|
+
loads.forEach((load) => {
|
|
36
|
+
types.push(load.type);
|
|
37
|
+
});
|
|
38
|
+
return types;
|
|
39
|
+
}
|
|
40
|
+
async getSheets(upload) {
|
|
41
|
+
const types = await this.getUploadTypes(upload);
|
|
42
|
+
const sheets = [];
|
|
43
|
+
types.forEach((type) => {
|
|
44
|
+
sheets.push(type.name.toLowerCase());
|
|
45
|
+
});
|
|
46
|
+
return sheets;
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
exports.BulkUploadService = BulkUploadService;
|
|
50
|
+
exports.BulkUploadService = BulkUploadService = __decorate([
|
|
51
|
+
(0, common_1.Injectable)()
|
|
52
|
+
], BulkUploadService);
|
|
53
|
+
//# sourceMappingURL=bulk.upload.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bulk.upload.service.js","sourceRoot":"","sources":["../../../src/accessUtility/services/bulk.upload.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,oFAA4E;AAC5E,+EAA0E;AAC1E,yFAAmF;AACnF,uEAAkE;AAM3D,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC1B,KAAK,CAAC,SAAS,CAAC,QAA8B,EAAE,MAAc,EAAE,KAA4B;QACxF,MAAM,IAAI,GAAG,MAAM,6CAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI;YAAE,MAAM,IAAI,4CAAkB,CAAC,wBAAwB,CAAC,CAAC;QAElE,MAAM,MAAM,GAAG,qCAAgB,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,aAAa,GAAG,MAAM,CAAC;QAE9B,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QAE9C,MAAM,CAAC,UAAU,GAAG,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC;QAE3E,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,MAAwB;QACzC,IAAI,CAAC,MAAM,CAAC,aAAa;YAAE,OAAO,EAAE,CAAC;QAErC,MAAM,KAAK,GAAG,MAAM,sDAAwB,CAAC,IAAI,CAAC;YAC9C,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,CAAC,aAAa,EAAE;YAC9C,SAAS,EAAE,CAAC,MAAM,EAAE,cAAc,CAAC;YACnC,KAAK,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE;SAC7B,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,EAAE,CAAC;QAEjB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACnB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,MAAwB;QACpC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAEhD,MAAM,MAAM,GAAa,EAAE,CAAC;QAC5B,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACnB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC;IAClB,CAAC;CACJ,CAAA;AA3CY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;GACA,iBAAiB,CA2C7B"}
|
|
@@ -14,5 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./bulk.upload.service"), exports);
|
|
17
18
|
__exportStar(require("./test.access.service"), exports);
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/accessUtility/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAqC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/accessUtility/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC;AAAA,wDAAqC"}
|
|
@@ -8,5 +8,6 @@ export declare class BulkUploadItemSubscriber extends CommonSubscriber<BulkUploa
|
|
|
8
8
|
constructor(dataSource: DataSource, bulkUploadItemJob: BulkUploadItemJob);
|
|
9
9
|
listenTo(): typeof BulkUploadItemEntity;
|
|
10
10
|
afterInsert(evt: InsertEvent<BulkUploadItemEntity>): Promise<void>;
|
|
11
|
+
beforeUpdate(evt: UpdateEvent<BulkUploadItemEntity>): Promise<void>;
|
|
11
12
|
afterUpdate(evt: UpdateEvent<BulkUploadItemEntity>): Promise<void>;
|
|
12
13
|
}
|
|
@@ -27,6 +27,12 @@ let BulkUploadItemSubscriber = class BulkUploadItemSubscriber extends nestjs_uti
|
|
|
27
27
|
async afterInsert(evt) {
|
|
28
28
|
await this.bulkUploadItemJob.delayedDispatch(this.getEventData(evt));
|
|
29
29
|
}
|
|
30
|
+
async beforeUpdate(evt) {
|
|
31
|
+
if (evt.entity.error) {
|
|
32
|
+
const keys = Object.keys(evt.entity.error);
|
|
33
|
+
evt.entity.errors_count = keys.length;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
30
36
|
async afterUpdate(evt) {
|
|
31
37
|
await this.bulkUploadItemJob.delayedDispatch(this.getEventData(evt));
|
|
32
38
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bulk.upload.item.subscriber.js","sourceRoot":"","sources":["../../../src/accessUtility/subscribers/bulk.upload.item.subscriber.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,oFAA0E;AAC1E,qCAAgF;AAChF,iFAA2E;AAC3E,uEAAiE;AAG1D,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,0CAAsC;IAChF,YACqB,UAAsB,EACtB,iBAAoC;QAErD,KAAK,EAAE,CAAC;QAHS,eAAU,GAAV,UAAU,CAAY;QACtB,sBAAiB,GAAjB,iBAAiB,CAAmB;QAGrD,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;
|
|
1
|
+
{"version":3,"file":"bulk.upload.item.subscriber.js","sourceRoot":"","sources":["../../../src/accessUtility/subscribers/bulk.upload.item.subscriber.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,oFAA0E;AAC1E,qCAAgF;AAChF,iFAA2E;AAC3E,uEAAiE;AAG1D,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,0CAAsC;IAChF,YACqB,UAAsB,EACtB,iBAAoC;QAErD,KAAK,EAAE,CAAC;QAHS,eAAU,GAAV,UAAU,CAAY;QACtB,sBAAiB,GAAjB,iBAAiB,CAAmB;QAGrD,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ;QACJ,OAAO,8CAAoB,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,GAAsC;QACpD,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,GAAsC;QACrD,IAAI,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YACnB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC3C,GAAG,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1C,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,GAAsC;QACpD,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACzE,CAAC;CACJ,CAAA;AA3BY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,yBAAe,GAAE;qCAGmB,oBAAU;QACH,wCAAiB;GAHhD,wBAAwB,CA2BpC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
declare const
|
|
1
|
+
declare const SourceHash: {
|
|
2
2
|
roleGroup: string;
|
|
3
3
|
businessUserRole: string;
|
|
4
4
|
groupMember: string;
|
|
@@ -6,4 +6,4 @@ declare const SOURCEHASH: {
|
|
|
6
6
|
choiceType: string;
|
|
7
7
|
choiceList: string;
|
|
8
8
|
};
|
|
9
|
-
export =
|
|
9
|
+
export = SourceHash;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
const
|
|
2
|
+
const SourceHash = {
|
|
3
3
|
roleGroup: '6e61f45b585911c9b7aeb6dd9723adf2',
|
|
4
4
|
businessUserRole: 'db2456e356ed67bad6d4d1b02760663e',
|
|
5
5
|
groupMember: '20f23c4fb23ea7e31f1db48bb44fe1e6',
|
|
@@ -7,5 +7,5 @@ const SOURCEHASH = {
|
|
|
7
7
|
choiceType: '615ea717c42c26609e3a4441ef01cdc2',
|
|
8
8
|
choiceList: '7874e58032a1eaf165d2151c1db160b5',
|
|
9
9
|
};
|
|
10
|
-
module.exports =
|
|
10
|
+
module.exports = SourceHash;
|
|
11
11
|
//# sourceMappingURL=source.hash.js.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { SeederUtility } from '@servicelabsco/nestjs-utility-services';
|
|
2
|
-
export declare class
|
|
2
|
+
export declare class AddCustomColumnTypesDataSeederTable1681369386555 extends SeederUtility {
|
|
3
3
|
constructor();
|
|
4
4
|
process(): void;
|
|
5
5
|
addLookupType(): void;
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AddCustomColumnTypesDataSeederTable1681369386555 = void 0;
|
|
4
|
+
const nestjs_utility_services_1 = require("@servicelabsco/nestjs-utility-services");
|
|
5
|
+
class AddCustomColumnTypesDataSeederTable1681369386555 extends nestjs_utility_services_1.SeederUtility {
|
|
6
|
+
constructor() {
|
|
7
|
+
super('sys_lookup_values');
|
|
8
|
+
this.process();
|
|
9
|
+
}
|
|
10
|
+
process() {
|
|
11
|
+
this.addLookupType();
|
|
12
|
+
this.addLookupValues();
|
|
13
|
+
}
|
|
14
|
+
addLookupType() {
|
|
15
|
+
this.addRecord({
|
|
16
|
+
id: 109,
|
|
17
|
+
name: 'Custom Column Field Types',
|
|
18
|
+
description: 'Custom column field types',
|
|
19
|
+
}, 'sys_lookup_types');
|
|
20
|
+
}
|
|
21
|
+
addLookupValues() {
|
|
22
|
+
const records = [
|
|
23
|
+
{
|
|
24
|
+
id: 1038,
|
|
25
|
+
name: 'Text',
|
|
26
|
+
value: 'Text',
|
|
27
|
+
description: 'Text',
|
|
28
|
+
lookup_type_id: 109,
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
id: 1039,
|
|
32
|
+
name: 'TextArea',
|
|
33
|
+
value: 'TextArea',
|
|
34
|
+
description: 'TextArea',
|
|
35
|
+
lookup_type_id: 109,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
id: 1040,
|
|
39
|
+
name: 'Date',
|
|
40
|
+
value: 'Date',
|
|
41
|
+
description: 'Date',
|
|
42
|
+
lookup_type_id: 109,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
id: 1041,
|
|
46
|
+
name: 'Datetime',
|
|
47
|
+
value: 'Datetime',
|
|
48
|
+
description: 'Datetime',
|
|
49
|
+
lookup_type_id: 109,
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
id: 1042,
|
|
53
|
+
name: 'Boolean',
|
|
54
|
+
value: 'Boolean',
|
|
55
|
+
description: 'Boolean',
|
|
56
|
+
lookup_type_id: 109,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
id: 1043,
|
|
60
|
+
name: 'Number',
|
|
61
|
+
value: 'Number',
|
|
62
|
+
description: 'Number',
|
|
63
|
+
lookup_type_id: 109,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
id: 1044,
|
|
67
|
+
name: 'Choicelist',
|
|
68
|
+
value: 'Choicelist',
|
|
69
|
+
description: 'Choicelist',
|
|
70
|
+
lookup_type_id: 109,
|
|
71
|
+
},
|
|
72
|
+
];
|
|
73
|
+
for (const record of records) {
|
|
74
|
+
this.addRecord(record);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.AddCustomColumnTypesDataSeederTable1681369386555 = AddCustomColumnTypesDataSeederTable1681369386555;
|
|
79
|
+
//# sourceMappingURL=1681369386555-AddCustomColumnTypesDataSeederTable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1681369386555-AddCustomColumnTypesDataSeederTable.js","sourceRoot":"","sources":["../../src/migrations/1681369386555-AddCustomColumnTypesDataSeederTable.ts"],"names":[],"mappings":";;;AAAA,oFAAuE;AAEvE,MAAa,gDAAiD,SAAQ,uCAAa;IAC/E;QACI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,OAAO;QACH,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,aAAa;QACT,IAAI,CAAC,SAAS,CACV;YACI,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,2BAA2B;YACjC,WAAW,EAAE,2BAA2B;SAC3C,EACD,kBAAkB,CACrB,CAAC;IACN,CAAC;IAED,eAAe;QACX,MAAM,OAAO,GAAG;YACZ;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,MAAM;gBACb,WAAW,EAAE,MAAM;gBACnB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,UAAU;gBAChB,KAAK,EAAE,UAAU;gBACjB,WAAW,EAAE,UAAU;gBACvB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,MAAM;gBACb,WAAW,EAAE,MAAM;gBACnB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,UAAU;gBAChB,KAAK,EAAE,UAAU;gBACjB,WAAW,EAAE,UAAU;gBACvB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,SAAS;gBAChB,WAAW,EAAE,SAAS;gBACtB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,QAAQ;gBACf,WAAW,EAAE,QAAQ;gBACrB,cAAc,EAAE,GAAG;aACtB;YACD;gBACI,EAAE,EAAE,IAAI;gBACR,IAAI,EAAE,YAAY;gBAClB,KAAK,EAAE,YAAY;gBACnB,WAAW,EAAE,YAAY;gBACzB,cAAc,EAAE,GAAG;aACtB;SACJ,CAAC;QAEF,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC;CACJ;AA/ED,4GA+EC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@servicelabsco/slabs-access-manager",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.61",
|
|
4
4
|
"description": "Support for application level menus and dashboards",
|
|
5
5
|
"author": "Hemant Kumar Sah <hemantanshu@gmail.com>",
|
|
6
6
|
"license": "MIT",
|
|
@@ -37,7 +37,9 @@
|
|
|
37
37
|
"console": "node dist/console.js"
|
|
38
38
|
},
|
|
39
39
|
"dependencies": {
|
|
40
|
-
"@servicelabsco/nestjs-utility-services": "^1.2.2"
|
|
40
|
+
"@servicelabsco/nestjs-utility-services": "^1.2.2",
|
|
41
|
+
"csv-parser": "^3.0.0",
|
|
42
|
+
"exceljs": "^4.4.0"
|
|
41
43
|
},
|
|
42
44
|
"devDependencies": {
|
|
43
45
|
"@nestjs/cli": "^10.0.0",
|