scheduler-services 1.3.16 → 1.3.17
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/emailer.d.ts +1 -0
- package/emailer.js +29 -0
- package/emailer.js.map +1 -0
- package/excelRowIngest.d.ts +18 -0
- package/excelRowIngest.js +148 -0
- package/excelRowIngest.js.map +1 -0
- package/index.d.ts +4 -0
- package/index.js +4 -0
- package/index.js.map +1 -1
- package/logger.d.ts +11 -0
- package/logger.js +69 -0
- package/logger.js.map +1 -0
- package/logging.d.ts +2 -1
- package/logging.js +5 -4
- package/logging.js.map +1 -1
- package/package.json +1 -1
- package/report.d.ts +25 -0
- package/report.js +77 -0
- package/report.js.map +1 -0
- package/sapIngest.d.ts +9 -0
- package/sapIngest.js +123 -0
- package/sapIngest.js.map +1 -0
package/emailer.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const sendMail: (to: string, subject: string, html: string) => Promise<void>;
|
package/emailer.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.sendMail = void 0;
|
|
4
|
+
const nodemailer = require("nodemailer");
|
|
5
|
+
const sendMail = async (to, subject, html) => {
|
|
6
|
+
const transporter = nodemailer.createTransport({
|
|
7
|
+
service: 'gmail',
|
|
8
|
+
auth: {
|
|
9
|
+
user: process.env.SMTP_USER,
|
|
10
|
+
pass: process.env.SMTP_PASSWORD
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
const mailOptions = {
|
|
14
|
+
from: process.env.SMTP_USER,
|
|
15
|
+
to: to,
|
|
16
|
+
subject: subject,
|
|
17
|
+
html: html
|
|
18
|
+
};
|
|
19
|
+
transporter.sendMail(mailOptions, (error, info) => {
|
|
20
|
+
if (error) {
|
|
21
|
+
console.error(error);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
console.log('Email sent: ' + info.response);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
exports.sendMail = sendMail;
|
|
29
|
+
//# sourceMappingURL=emailer.js.map
|
package/emailer.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"emailer.js","sourceRoot":"","sources":["../src/emailer.ts"],"names":[],"mappings":";;;AAAA,yCAAyC;AAElC,MAAM,QAAQ,GAAG,KAAK,EAAC,EAAU,EAAE,OAAe,EAAE,IAAY,EAAE,EAAE;IAEzE,MAAM,WAAW,GAAG,UAAU,CAAC,eAAe,CAAC;QAC7C,OAAO,EAAE,OAAO;QAChB,IAAI,EAAE;YACJ,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS;YAC3B,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa;SAChC;KACF,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG;QAClB,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS;QAC3B,EAAE,EAAE,EAAE;QACN,OAAO,EAAE,OAAO;QAChB,IAAI,EAAE,IAAI;KACX,CAAC;IAEF,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QAChD,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAA;AAxBY,QAAA,QAAQ,YAwBpB"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Row } from "exceljs";
|
|
2
|
+
import { ISite, Site } from "scheduler-models/scheduler/sites";
|
|
3
|
+
import { ITeam, Team } from "scheduler-models/scheduler/teams";
|
|
4
|
+
import { ExcelRow, ExcelRowPeriod } from "scheduler-models/scheduler/ingest/excelRow";
|
|
5
|
+
import { LaborCode } from "scheduler-models/scheduler/labor";
|
|
6
|
+
import { Employee } from "scheduler-models/scheduler/employees";
|
|
7
|
+
export declare class ExcelRowIngest {
|
|
8
|
+
files: Express.Multer.File[];
|
|
9
|
+
team: Team;
|
|
10
|
+
site: Site;
|
|
11
|
+
company: string;
|
|
12
|
+
docDate: Date;
|
|
13
|
+
constructor(date: Date, files?: Express.Multer.File[], team?: ITeam, site?: ISite, company?: string);
|
|
14
|
+
Process(): Promise<ExcelRowPeriod[]>;
|
|
15
|
+
processFile(file: Express.Multer.File): Promise<ExcelRowPeriod>;
|
|
16
|
+
getForecast(date: Date): Promise<LaborCode[]>;
|
|
17
|
+
readCell(row: Row, c: number, colDate: Date, emp: Employee): Promise<ExcelRow | null>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExcelRowIngest = void 0;
|
|
4
|
+
const exceljs_1 = require("exceljs");
|
|
5
|
+
const sites_1 = require("scheduler-models/scheduler/sites");
|
|
6
|
+
const teams_1 = require("scheduler-models/scheduler/teams");
|
|
7
|
+
const excelRow_1 = require("scheduler-models/scheduler/ingest/excelRow");
|
|
8
|
+
const labor_1 = require("scheduler-models/scheduler/labor");
|
|
9
|
+
const stream_1 = require("stream");
|
|
10
|
+
class ExcelRowIngest {
|
|
11
|
+
files;
|
|
12
|
+
team;
|
|
13
|
+
site;
|
|
14
|
+
company;
|
|
15
|
+
docDate;
|
|
16
|
+
constructor(date, files, team, site, company) {
|
|
17
|
+
this.files = (files) ? files : [];
|
|
18
|
+
this.team = (team) ? new teams_1.Team(team) : new teams_1.Team();
|
|
19
|
+
this.site = (site) ? new sites_1.Site(site) : new sites_1.Site();
|
|
20
|
+
this.company = (company) ? company : '';
|
|
21
|
+
this.docDate = new Date(Date.UTC(date.getFullYear(), date.getMonth(), 1));
|
|
22
|
+
}
|
|
23
|
+
async Process() {
|
|
24
|
+
const results = [];
|
|
25
|
+
if (this.files.length > 0) {
|
|
26
|
+
const allfiles = this.files.map(async (file, f) => {
|
|
27
|
+
const result = await this.processFile(file);
|
|
28
|
+
results.push(result);
|
|
29
|
+
});
|
|
30
|
+
await Promise.allSettled(allfiles);
|
|
31
|
+
}
|
|
32
|
+
return results;
|
|
33
|
+
}
|
|
34
|
+
async processFile(file) {
|
|
35
|
+
const result = new excelRow_1.ExcelRowPeriod();
|
|
36
|
+
const filereader = stream_1.Readable.from(file.buffer);
|
|
37
|
+
const fileDataU8 = [];
|
|
38
|
+
while (true) {
|
|
39
|
+
const { done, value } = await filereader.read();
|
|
40
|
+
if (done)
|
|
41
|
+
break;
|
|
42
|
+
fileDataU8.push(...value);
|
|
43
|
+
}
|
|
44
|
+
const fileBinary = Buffer.from(fileDataU8);
|
|
45
|
+
const workbook = new exceljs_1.Workbook();
|
|
46
|
+
await workbook.xlsx.load(fileBinary.buffer);
|
|
47
|
+
const worksheet = workbook.getWorksheet('Sheet1');
|
|
48
|
+
const monthDates = [];
|
|
49
|
+
for (let d = 0; d < 31; d++) {
|
|
50
|
+
const nDate = new Date(this.docDate.getTime() + (d * 24 * 3600000));
|
|
51
|
+
if (nDate.getTime() < result.start.getTime()) {
|
|
52
|
+
result.start = new Date(nDate);
|
|
53
|
+
}
|
|
54
|
+
if (nDate.getTime() > result.end.getTime()) {
|
|
55
|
+
result.end = new Date(nDate);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
if (worksheet) {
|
|
59
|
+
worksheet.eachRow(async (row, r) => {
|
|
60
|
+
if (row.getCell(1) && row.getCell(1) !== null && row.getCell(1).value !== null) {
|
|
61
|
+
const name = row.getCell(1).toString().trim();
|
|
62
|
+
if (name.includes(',')) {
|
|
63
|
+
if (this.site.employees) {
|
|
64
|
+
const emp = this.site.employees.find(e => e.name.getLastFirst().toLowerCase() === name.toLowerCase());
|
|
65
|
+
if (emp) {
|
|
66
|
+
const rowPromises = monthDates.map(async (day, d) => {
|
|
67
|
+
const erow = await this.readCell(row, d + 3, day, emp);
|
|
68
|
+
if (erow !== null) {
|
|
69
|
+
result.addRow(erow);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
await Promise.allSettled(rowPromises);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
throw new Error('No employees in site');
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
throw new Error('No worksheet');
|
|
84
|
+
}
|
|
85
|
+
return result;
|
|
86
|
+
}
|
|
87
|
+
async getForecast(date) {
|
|
88
|
+
const laborcodes = [];
|
|
89
|
+
this.site.forecasts.forEach(fcst => {
|
|
90
|
+
if (fcst.use(date, this.company)) {
|
|
91
|
+
fcst.laborCodes.forEach(lc => {
|
|
92
|
+
laborcodes.push(new labor_1.LaborCode(lc));
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
return laborcodes;
|
|
97
|
+
}
|
|
98
|
+
async readCell(row, c, colDate, emp) {
|
|
99
|
+
const hPattern = "^[0-9]{1,2}(\.[0-9]+)?$";
|
|
100
|
+
const hourRE = new RegExp(hPattern);
|
|
101
|
+
const sValue = row.getCell(c).toString().trim();
|
|
102
|
+
if (sValue !== '') {
|
|
103
|
+
if (hourRE.test(sValue)) {
|
|
104
|
+
let laborcode = new labor_1.LaborCode();
|
|
105
|
+
const laborcodes = await this.getForecast(colDate);
|
|
106
|
+
emp.assignments.forEach(asgmt => {
|
|
107
|
+
if (asgmt.useAssignment(colDate)) {
|
|
108
|
+
asgmt.laborcodes.forEach(alc => {
|
|
109
|
+
laborcodes.forEach(flc => {
|
|
110
|
+
if (flc.chargeNumber === alc.chargenumber
|
|
111
|
+
&& flc.extension === alc.extension) {
|
|
112
|
+
laborcode.chargeNumber = flc.chargeNumber;
|
|
113
|
+
laborcode.extension = flc.extension;
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
if (laborcode.chargeNumber !== '') {
|
|
120
|
+
const eRow = new excelRow_1.ExcelRow();
|
|
121
|
+
eRow.date = new Date(colDate);
|
|
122
|
+
eRow.employee = emp.companyinfo.employeeid;
|
|
123
|
+
eRow.chargeNumber = laborcode.chargeNumber;
|
|
124
|
+
eRow.extension = laborcode.extension;
|
|
125
|
+
eRow.premium = '1';
|
|
126
|
+
eRow.hours = Number(sValue);
|
|
127
|
+
return new excelRow_1.ExcelRow(eRow);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
this.team.workcodes.forEach(wc => {
|
|
132
|
+
if (wc.isLeave && wc.altcode
|
|
133
|
+
&& sValue.toLowerCase() === wc.altcode.toLowerCase()) {
|
|
134
|
+
const eRow = new excelRow_1.ExcelRow();
|
|
135
|
+
eRow.date = new Date(colDate);
|
|
136
|
+
eRow.employee = emp.companyinfo.employeeid;
|
|
137
|
+
eRow.code = wc.id;
|
|
138
|
+
eRow.hours = emp.getStandardWorkday(colDate);
|
|
139
|
+
return new excelRow_1.ExcelRow(eRow);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
return null;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
exports.ExcelRowIngest = ExcelRowIngest;
|
|
148
|
+
//# sourceMappingURL=excelRowIngest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excelRowIngest.js","sourceRoot":"","sources":["../src/excelRowIngest.ts"],"names":[],"mappings":"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"}
|
package/index.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export * from './buildInitial';
|
|
2
|
+
export * from './emailer';
|
|
3
|
+
export * from './logger';
|
|
2
4
|
export * from './logging';
|
|
3
5
|
export * from './logPosting';
|
|
4
6
|
export * from './mongoconnect';
|
|
@@ -8,3 +10,5 @@ export * from './employeeService';
|
|
|
8
10
|
export * from './teamService';
|
|
9
11
|
export * from './noticeService';
|
|
10
12
|
export * from './logService';
|
|
13
|
+
export * from './report';
|
|
14
|
+
export * from './sapIngest';
|
package/index.js
CHANGED
|
@@ -15,6 +15,8 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./buildInitial"), exports);
|
|
18
|
+
__exportStar(require("./emailer"), exports);
|
|
19
|
+
__exportStar(require("./logger"), exports);
|
|
18
20
|
__exportStar(require("./logging"), exports);
|
|
19
21
|
__exportStar(require("./logPosting"), exports);
|
|
20
22
|
__exportStar(require("./mongoconnect"), exports);
|
|
@@ -24,4 +26,6 @@ __exportStar(require("./employeeService"), exports);
|
|
|
24
26
|
__exportStar(require("./teamService"), exports);
|
|
25
27
|
__exportStar(require("./noticeService"), exports);
|
|
26
28
|
__exportStar(require("./logService"), exports);
|
|
29
|
+
__exportStar(require("./report"), exports);
|
|
30
|
+
__exportStar(require("./sapIngest"), exports);
|
|
27
31
|
//# sourceMappingURL=index.js.map
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,4CAA0B;AAC1B,+CAA6B;AAC7B,iDAA+B;AAC/B,0CAAwB;AACxB,gDAA8B;AAC9B,oDAAkC;AAClC,gDAA8B;AAC9B,kDAAgC;AAChC,+CAA6B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,4CAA0B;AAC1B,2CAAyB;AACzB,4CAA0B;AAC1B,+CAA6B;AAC7B,iDAA+B;AAC/B,0CAAwB;AACxB,gDAA8B;AAC9B,oDAAkC;AAClC,gDAA8B;AAC9B,kDAAgC;AAChC,+CAA6B;AAC7B,2CAAyB;AACzB,8CAA4B"}
|
package/logger.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare class Logger {
|
|
2
|
+
private logFile;
|
|
3
|
+
private flushInterval;
|
|
4
|
+
private buffer;
|
|
5
|
+
private interval;
|
|
6
|
+
constructor(logFile: string, flushInterval?: number);
|
|
7
|
+
log(message: string): void;
|
|
8
|
+
private flush;
|
|
9
|
+
stop(): void;
|
|
10
|
+
createDirIfNotExists(directoryPath: string): void;
|
|
11
|
+
}
|
package/logger.js
ADDED
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Logger = void 0;
|
|
4
|
+
const fs = require("fs");
|
|
5
|
+
class Logger {
|
|
6
|
+
logFile;
|
|
7
|
+
flushInterval;
|
|
8
|
+
buffer = [];
|
|
9
|
+
interval;
|
|
10
|
+
constructor(logFile, flushInterval = 100) {
|
|
11
|
+
this.logFile = logFile;
|
|
12
|
+
this.flushInterval = flushInterval;
|
|
13
|
+
this.interval = setInterval(() => this.flush(), flushInterval);
|
|
14
|
+
}
|
|
15
|
+
log(message) {
|
|
16
|
+
const now = new Date();
|
|
17
|
+
this.buffer.push(`${now.getTime()}\t${message}`);
|
|
18
|
+
}
|
|
19
|
+
flush() {
|
|
20
|
+
this.logFile = this.logFile.replaceAll(' ', '_');
|
|
21
|
+
this.createDirIfNotExists(this.logFile);
|
|
22
|
+
if (this.buffer.length > 0) {
|
|
23
|
+
const logLines = this.buffer.join('\n') + '\n';
|
|
24
|
+
try {
|
|
25
|
+
const tf = fs.open(this.logFile, (err) => {
|
|
26
|
+
if (err) {
|
|
27
|
+
const dirIndex = this.logFile.lastIndexOf('/');
|
|
28
|
+
const logDir = this.logFile.substring(0, dirIndex);
|
|
29
|
+
fs.mkdir(logDir, { recursive: true, }, (err) => {
|
|
30
|
+
if (err) {
|
|
31
|
+
console.log(err);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
const dirIndex = this.logFile.lastIndexOf('/');
|
|
39
|
+
const logDir = this.logFile.substring(0, dirIndex);
|
|
40
|
+
fs.mkdir(logDir, { recursive: true }, (err) => {
|
|
41
|
+
if (err) {
|
|
42
|
+
console.log(err);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
fs.appendFile(this.logFile, logLines, (err) => {
|
|
47
|
+
if (err) {
|
|
48
|
+
console.error(`Error writing to log file: ${err}`);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
this.buffer = [];
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
stop() {
|
|
55
|
+
clearInterval(this.interval);
|
|
56
|
+
this.flush();
|
|
57
|
+
}
|
|
58
|
+
createDirIfNotExists(directoryPath) {
|
|
59
|
+
if (directoryPath.endsWith('.log')) {
|
|
60
|
+
const index = directoryPath.lastIndexOf('/');
|
|
61
|
+
directoryPath = directoryPath.substring(0, index);
|
|
62
|
+
}
|
|
63
|
+
if (!fs.existsSync(directoryPath)) {
|
|
64
|
+
fs.mkdirSync(directoryPath, { recursive: true });
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.Logger = Logger;
|
|
69
|
+
//# sourceMappingURL=logger.js.map
|
package/logger.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":";;;AAAA,yBAAyB;AAEzB,MAAa,MAAM;IAIG;IAAyB;IAHrC,MAAM,GAAa,EAAE,CAAC;IACtB,QAAQ,CAAiB;IAEjC,YAAoB,OAAe,EAAU,gBAAwB,GAAG;QAApD,YAAO,GAAP,OAAO,CAAQ;QAAU,kBAAa,GAAb,aAAa,CAAc;QACtE,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,aAAa,CAAC,CAAC;IACjE,CAAC;IAED,GAAG,CAAC,OAAe;QACjB,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACjD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QACvC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;YAC/C,IAAI,CAAC;gBACH,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;oBACvC,IAAI,GAAG,EAAE,CAAC;wBACR,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;wBAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;wBACnD,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE;4BAC7C,IAAI,GAAG,EAAE,CAAC;gCACR,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;4BACnB,CAAC;wBACH,CAAC,CAAC,CAAA;oBACJ,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;YAAC,MAAM,CAAC;gBACP,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACnD,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,EAAE,EAAE;oBAC5C,IAAI,GAAG,EAAE,CAAC;wBACR,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;oBACnB,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;YACD,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,EAAE;gBAC5C,IAAI,GAAG,EAAE,CAAC;oBACR,OAAO,CAAC,KAAK,CAAC,8BAA8B,GAAG,EAAE,CAAC,CAAC;gBACrD,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAED,IAAI;QACF,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,oBAAoB,CAAC,aAAqB;QACxC,IAAI,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,MAAM,KAAK,GAAG,aAAa,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;YAC7C,aAAa,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QACpD,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;YAClC,EAAE,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;CACF;AA9DD,wBA8DC"}
|
package/logging.d.ts
CHANGED
package/logging.js
CHANGED
|
@@ -5,12 +5,13 @@ exports.createLogs = createLogs;
|
|
|
5
5
|
exports.postLogEntry = postLogEntry;
|
|
6
6
|
const general_1 = require("scheduler-models/general");
|
|
7
7
|
const sqldb_1 = require("./sqldb");
|
|
8
|
+
const logger_1 = require("./logger");
|
|
8
9
|
exports.logConnection = {};
|
|
9
10
|
async function createLogs(application) {
|
|
10
|
-
exports.logConnection.log = new
|
|
11
|
-
exports.logConnection.employeeLog = new
|
|
12
|
-
exports.logConnection.siteLog = new
|
|
13
|
-
exports.logConnection.teamLog = new
|
|
11
|
+
exports.logConnection.log = new logger_1.Logger(`${process.env.LOG_DIR}/${application}/process_${(new Date().toDateString())}.log`);
|
|
12
|
+
exports.logConnection.employeeLog = new logger_1.Logger(`${process.env.LOG_DIR}/${application}/employee_${(new Date().toDateString())}.log`);
|
|
13
|
+
exports.logConnection.siteLog = new logger_1.Logger(`${process.env.LOG_DIR}/${application}/site_${(new Date().toDateString())}.log`);
|
|
14
|
+
exports.logConnection.teamLog = new logger_1.Logger(`${process.env.LOG_DIR}/${application}/team_${(new Date().toDateString())}.log`);
|
|
14
15
|
}
|
|
15
16
|
async function postLogEntry(application, message) {
|
|
16
17
|
let conn;
|
package/logging.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../src/logging.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../src/logging.ts"],"names":[],"mappings":";;;AAWA,gCASC;AAED,oCA4BC;AAlDD,sDAAoD;AACpD,mCAAwC;AACxC,qCAAkC;AAErB,QAAA,aAAa,GAKtB,EAAE,CAAA;AAEC,KAAK,UAAU,UAAU,CAAC,WAAmB;IAClD,qBAAa,CAAC,GAAG,GAAG,IAAI,eAAM,CAC9B,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,WAAW,YAAY,CAAC,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC;IACpF,qBAAa,CAAC,WAAW,GAAG,IAAI,eAAM,CACtC,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,WAAW,aAAa,CAAC,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC;IACrF,qBAAa,CAAC,OAAO,GAAG,IAAI,eAAM,CAClC,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,WAAW,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC;IACjF,qBAAa,CAAC,OAAO,GAAG,IAAI,eAAM,CAClC,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,WAAW,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC;AACnF,CAAC;AAEM,KAAK,UAAU,YAAY,CAAC,WAAmB,EAAE,OAAe;IACrE,IAAI,IAAI,CAAC;IACT,IAAI,QAAQ,GAAG,IAAI,kBAAQ,EAAE,CAAC;IAC9B,IAAI,CAAC;QACH,IAAI,qBAAa,CAAC,IAAI,EAAE,CAAC;YAEvB,IAAI,GAAG,MAAM,qBAAa,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAChD,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;YAG7B,MAAM,MAAM,GAAG,0CAA0C,CAAC;YAC1D,MAAM,MAAM,GAAG,CAAE,SAAS,EAAE,WAAW,EAAE,OAAO,CAAE,CAAC;YACnD,MAAM,KAAK,GAAG,2DAA2D,CAAC;YAC1E,MAAM,IAAI,CAAC,KAAK,CAAQ,MAAM,EAAE,MAAM,CAAC,CAAC;YAExC,QAAQ,GAAG,IAAI,kBAAQ,CAAC;gBACtB,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,OAAO;aACf,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,CAAC;IACZ,CAAC;YAAS,CAAC;QACT,IAAI,IAAI;YAAE,IAAI,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
package/package.json
CHANGED
package/report.d.ts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { RichText, Style, Worksheet } from "exceljs";
|
|
2
|
+
export declare class Formula {
|
|
3
|
+
formula: string;
|
|
4
|
+
constructor(formula: string);
|
|
5
|
+
}
|
|
6
|
+
export declare class Report {
|
|
7
|
+
getCellID(col: string | number, row: number): string;
|
|
8
|
+
setCell(sheet: Worksheet, begin: string, end: string, style: Partial<Style>, value: string | number | Formula | RichText[] | undefined, numFmt?: string): void;
|
|
9
|
+
getDateString(date: Date): string;
|
|
10
|
+
getTimeString(minutes: number): string;
|
|
11
|
+
getNumberString(value: number, decimal: number): string;
|
|
12
|
+
}
|
|
13
|
+
export interface ReportRequest {
|
|
14
|
+
reportType: string;
|
|
15
|
+
period?: string;
|
|
16
|
+
subreport?: string;
|
|
17
|
+
teamid?: string;
|
|
18
|
+
siteid?: string;
|
|
19
|
+
companyid?: string;
|
|
20
|
+
password?: string;
|
|
21
|
+
startDate?: string;
|
|
22
|
+
endDate?: string;
|
|
23
|
+
userid?: string;
|
|
24
|
+
includeDaily: boolean;
|
|
25
|
+
}
|
package/report.js
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Report = exports.Formula = void 0;
|
|
4
|
+
class Formula {
|
|
5
|
+
formula = "";
|
|
6
|
+
constructor(formula) {
|
|
7
|
+
this.formula = formula;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
exports.Formula = Formula;
|
|
11
|
+
class Report {
|
|
12
|
+
getCellID(col, row) {
|
|
13
|
+
if (typeof col === 'string') {
|
|
14
|
+
return `${col}${row}`;
|
|
15
|
+
}
|
|
16
|
+
const letters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
|
17
|
+
if (col < letters.length) {
|
|
18
|
+
return `${letters.substring(col, col + 1)}${row}`;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const first = Math.floor(col / letters.length) - 1;
|
|
22
|
+
const next = col % letters.length;
|
|
23
|
+
return `${letters.substring(first, first + 1)}${letters.substring(next, next + 1)}${row}`;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
setCell(sheet, begin, end, style, value, numFmt) {
|
|
27
|
+
if (begin !== end) {
|
|
28
|
+
sheet.mergeCells(`${begin}:${end}`);
|
|
29
|
+
}
|
|
30
|
+
if (style.fill) {
|
|
31
|
+
sheet.getCell(begin).fill = style.fill;
|
|
32
|
+
}
|
|
33
|
+
if (style.font) {
|
|
34
|
+
sheet.getCell(begin).font = style.font;
|
|
35
|
+
}
|
|
36
|
+
if (style.alignment) {
|
|
37
|
+
sheet.getCell(begin).alignment = style.alignment;
|
|
38
|
+
}
|
|
39
|
+
if (style.border) {
|
|
40
|
+
sheet.getCell(begin).border = style.border;
|
|
41
|
+
}
|
|
42
|
+
if (style.numFmt) {
|
|
43
|
+
sheet.getCell(begin).numFmt = style.numFmt;
|
|
44
|
+
}
|
|
45
|
+
if (numFmt && numFmt !== '') {
|
|
46
|
+
sheet.getCell(begin).numFmt = numFmt;
|
|
47
|
+
}
|
|
48
|
+
if (!value && !(typeof value === 'number')) {
|
|
49
|
+
sheet.getCell(begin).value = '';
|
|
50
|
+
}
|
|
51
|
+
else if (value instanceof Formula) {
|
|
52
|
+
sheet.getCell(begin).value = { formula: value.formula };
|
|
53
|
+
}
|
|
54
|
+
else if (typeof value === 'string' || typeof value === 'number') {
|
|
55
|
+
sheet.getCell(begin).value = value;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
sheet.getCell(begin).value = { 'richText': value };
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
getDateString(date) {
|
|
62
|
+
const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',
|
|
63
|
+
'Oct', 'Nov', 'Dec'];
|
|
64
|
+
return `${months[date.getMonth()]} ${date.getDate()}`;
|
|
65
|
+
}
|
|
66
|
+
getTimeString(minutes) {
|
|
67
|
+
const hours = Math.floor(minutes / 60);
|
|
68
|
+
const mins = minutes - (hours * 60);
|
|
69
|
+
return ((hours < 10) ? `0${hours}:` : `${hours}:`)
|
|
70
|
+
+ ((mins < 10) ? `0${mins}` : `${mins}`);
|
|
71
|
+
}
|
|
72
|
+
getNumberString(value, decimal) {
|
|
73
|
+
return value.toFixed(decimal);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
exports.Report = Report;
|
|
77
|
+
//# sourceMappingURL=report.js.map
|
package/report.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.js","sourceRoot":"","sources":["../src/report.ts"],"names":[],"mappings":"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"}
|
package/sapIngest.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ITeam, Team } from "scheduler-models/scheduler/teams";
|
|
2
|
+
import { ExcelRowPeriod } from "scheduler-models/scheduler/ingest/excelRow";
|
|
3
|
+
export declare class SAPIngest {
|
|
4
|
+
files: Express.Multer.File[];
|
|
5
|
+
team: Team;
|
|
6
|
+
constructor(files?: Express.Multer.File[], team?: ITeam);
|
|
7
|
+
Process(): Promise<ExcelRowPeriod[]>;
|
|
8
|
+
processFile(file: Express.Multer.File): Promise<ExcelRowPeriod>;
|
|
9
|
+
}
|
package/sapIngest.js
ADDED
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SAPIngest = void 0;
|
|
4
|
+
const teams_1 = require("scheduler-models/scheduler/teams");
|
|
5
|
+
const excelRow_1 = require("scheduler-models/scheduler/ingest/excelRow");
|
|
6
|
+
const exceljs_1 = require("exceljs");
|
|
7
|
+
const stream_1 = require("stream");
|
|
8
|
+
class SAPIngest {
|
|
9
|
+
files;
|
|
10
|
+
team;
|
|
11
|
+
constructor(files, team) {
|
|
12
|
+
this.files = (files) ? files : [];
|
|
13
|
+
this.team = (team) ? new teams_1.Team(team) : new teams_1.Team();
|
|
14
|
+
}
|
|
15
|
+
async Process() {
|
|
16
|
+
const result = [];
|
|
17
|
+
if (this.files.length > 0) {
|
|
18
|
+
const allfiles = this.files.map(async (file, f) => {
|
|
19
|
+
const results = await this.processFile(file);
|
|
20
|
+
result.push(results);
|
|
21
|
+
});
|
|
22
|
+
await Promise.allSettled(allfiles);
|
|
23
|
+
}
|
|
24
|
+
return result;
|
|
25
|
+
}
|
|
26
|
+
async processFile(file) {
|
|
27
|
+
const result = new excelRow_1.ExcelRowPeriod();
|
|
28
|
+
const filereader = stream_1.Readable.from(file.buffer);
|
|
29
|
+
const fileDataU8 = [];
|
|
30
|
+
while (true) {
|
|
31
|
+
const { done, value } = await filereader.read();
|
|
32
|
+
if (done)
|
|
33
|
+
break;
|
|
34
|
+
fileDataU8.push(...value);
|
|
35
|
+
}
|
|
36
|
+
const fileBinary = Buffer.from(fileDataU8);
|
|
37
|
+
const workbook = new exceljs_1.Workbook();
|
|
38
|
+
await workbook.xlsx.load(fileBinary.buffer);
|
|
39
|
+
const worksheet = workbook.getWorksheet('Data');
|
|
40
|
+
if (worksheet) {
|
|
41
|
+
const columns = new Map();
|
|
42
|
+
const nameRow = worksheet.getRow(1);
|
|
43
|
+
nameRow.eachCell((cell, col) => {
|
|
44
|
+
if (cell.value) {
|
|
45
|
+
columns.set(cell.value.toString().toLowerCase(), col);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
const explanation = (columns.get('explanation')) ? columns.get('explanation')
|
|
49
|
+
: -1;
|
|
50
|
+
const dataCols = ['date', 'personnel no.', 'charge number', 'prem. no.', 'ext.',
|
|
51
|
+
'hours', 'charge number desc', 'explanation'];
|
|
52
|
+
if (explanation && explanation >= 0) {
|
|
53
|
+
worksheet.eachRow((row, r) => {
|
|
54
|
+
let value = row.getCell(explanation);
|
|
55
|
+
if (r > 1 && value && !value.toString().toLowerCase().includes('total')) {
|
|
56
|
+
const eRow = new excelRow_1.ExcelRow();
|
|
57
|
+
dataCols.forEach(sCol => {
|
|
58
|
+
const col = columns.get(sCol);
|
|
59
|
+
if (col) {
|
|
60
|
+
const sValue = row.getCell(col).toString().trim();
|
|
61
|
+
switch (sCol) {
|
|
62
|
+
case 'date':
|
|
63
|
+
eRow.date = new Date(Date.parse(sValue));
|
|
64
|
+
break;
|
|
65
|
+
case 'personnel no.':
|
|
66
|
+
eRow.employee = sValue;
|
|
67
|
+
break;
|
|
68
|
+
case 'charge number':
|
|
69
|
+
eRow.chargeNumber = sValue;
|
|
70
|
+
break;
|
|
71
|
+
case 'prem. no.':
|
|
72
|
+
eRow.premium = sValue;
|
|
73
|
+
break;
|
|
74
|
+
case 'ext.':
|
|
75
|
+
eRow.extension = sValue;
|
|
76
|
+
break;
|
|
77
|
+
case 'hours':
|
|
78
|
+
const hPattern = "^[0-9]{1,2}(\.[0-9]+)?$";
|
|
79
|
+
const hourRE = new RegExp(hPattern);
|
|
80
|
+
if (hourRE.test(sValue)) {
|
|
81
|
+
eRow.hours = Number(sValue);
|
|
82
|
+
}
|
|
83
|
+
break;
|
|
84
|
+
case 'charge number desc':
|
|
85
|
+
eRow.description = sValue;
|
|
86
|
+
break;
|
|
87
|
+
case 'explanation':
|
|
88
|
+
eRow.comment = sValue;
|
|
89
|
+
break;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
this.team.workcodes.forEach(wc => {
|
|
94
|
+
if (wc.isLeave && wc.search) {
|
|
95
|
+
if (eRow.description.toLowerCase().includes(wc.search.toLowerCase())) {
|
|
96
|
+
eRow.code = wc.id;
|
|
97
|
+
if (wc.id.toLowerCase() === 'h') {
|
|
98
|
+
const hPattern = '[hfHF][0-9]{1,2}';
|
|
99
|
+
const holRE = new RegExp(hPattern);
|
|
100
|
+
const matches = holRE.exec(eRow.comment);
|
|
101
|
+
if (matches && matches !== null) {
|
|
102
|
+
eRow.holidayID = matches[0];
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
if (eRow.date.getTime() < result.start.getTime()) {
|
|
109
|
+
result.start = new Date(eRow.date);
|
|
110
|
+
}
|
|
111
|
+
if (eRow.date.getTime() > result.end.getTime()) {
|
|
112
|
+
result.end = new Date(eRow.date);
|
|
113
|
+
}
|
|
114
|
+
result.addRow(eRow);
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return result;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
exports.SAPIngest = SAPIngest;
|
|
123
|
+
//# sourceMappingURL=sapIngest.js.map
|
package/sapIngest.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sapIngest.js","sourceRoot":"","sources":["../src/sapIngest.ts"],"names":[],"mappings":"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"}
|