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 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":"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"}
package/logging.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- import { LogEntry, Logger } from 'scheduler-models/general';
1
+ import { LogEntry } from 'scheduler-models/general';
2
+ import { Logger } from './logger';
2
3
  export declare const logConnection: {
3
4
  log?: Logger;
4
5
  employeeLog?: Logger;
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 general_1.Logger(`${process.env.LOG_DIR}/${application}/process_${(new Date().toDateString())}.log`);
11
- exports.logConnection.employeeLog = new general_1.Logger(`${process.env.LOG_DIR}/${application}/employee_${(new Date().toDateString())}.log`);
12
- exports.logConnection.siteLog = new general_1.Logger(`${process.env.LOG_DIR}/${application}/site_${(new Date().toDateString())}.log`);
13
- exports.logConnection.teamLog = new general_1.Logger(`${process.env.LOG_DIR}/${application}/team_${(new Date().toDateString())}.log`);
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":";;;AAUA,gCASC;AAED,oCA4BC;AAjDD,sDAA4D;AAC5D,mCAAwC;AAE3B,QAAA,aAAa,GAKtB,EAAE,CAAA;AAEC,KAAK,UAAU,UAAU,CAAC,WAAmB;IAClD,qBAAa,CAAC,GAAG,GAAG,IAAI,gBAAM,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,gBAAM,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,gBAAM,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,gBAAM,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"}
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "scheduler-services",
3
- "version": "1.3.16",
3
+ "version": "1.3.17",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "files": [
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":";;;AAEA,MAAa,OAAO;IACX,OAAO,GAAW,EAAE,CAAC;IAE5B,YAAY,OAAe;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;CACF;AAND,0BAMC;AAED,MAAa,MAAM;IACjB,SAAS,CAAC,GAAoB,EAAE,GAAW;QACzC,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC5B,OAAO,GAAG,GAAG,GAAG,GAAG,EAAE,CAAC;QACxB,CAAC;QACD,MAAM,OAAO,GAAG,4BAA4B,CAAC;QAC7C,IAAI,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACzB,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,GAAC,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjD,MAAM,IAAI,GAAG,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC;YAClC,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,GAAC,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,GAAC,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC;QACxF,CAAC;IACH,CAAC;IAED,OAAO,CAAC,KAAgB,EAAE,KAAa,EAAE,GAAW,EAAE,KAAqB,EACzE,KAAyD,EAAE,MAAe;QAC1E,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC;YAClB,KAAK,CAAC,UAAU,CAAC,GAAG,KAAK,IAAI,GAAG,EAAE,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACzC,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACzC,CAAC;QACD,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;YACpB,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;QACnD,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACjB,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC7C,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACjB,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC7C,CAAC;QACD,IAAI,MAAM,IAAI,MAAM,KAAK,EAAE,EAAE,CAAC;YAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,EAAE,CAAC;YAC3C,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;QAClC,CAAC;aAAM,IAAI,KAAK,YAAY,OAAO,EAAE,CAAC;YACpC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAClE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC;QACrD,CAAC;IACH,CAAC;IAED,aAAa,CAAC,IAAU;QACtB,MAAM,MAAM,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK;YAC3E,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEvB,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;IACxD,CAAC;IAED,aAAa,CAAC,OAAe;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,OAAO,GAAG,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;QAEpC,OAAO,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC;cAC9C,CAAC,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,eAAe,CAAC,KAAa,EAAE,OAAe;QAC5C,OAAO,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC/B,CAAC;CACF;AApED,wBAoEC"}
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sapIngest.js","sourceRoot":"","sources":["../src/sapIngest.ts"],"names":[],"mappings":"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"}