fleetmap-reports 1.0.970 → 1.0.972
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/package.json
CHANGED
package/src/activity-report.js
CHANGED
|
@@ -105,7 +105,7 @@ async function createActivityReportByDevice (from, to, userData, traccarInstance
|
|
|
105
105
|
let summaryByDay = []
|
|
106
106
|
if (userData.allWeek && userData.groupByDay) {
|
|
107
107
|
const dates = getDates(from, to, userData.user.attributes.timezone || getUserPartner(userData.user).timezone)
|
|
108
|
-
summaryByDay = await getSummaryByDay(dates, userData, traccarInstance, allDevices, true)
|
|
108
|
+
summaryByDay = await getSummaryByDay(dates, userData, traccarInstance, allDevices, true, from, to)
|
|
109
109
|
}
|
|
110
110
|
|
|
111
111
|
let deviceCount = 0
|
|
@@ -26,7 +26,7 @@ async function createFuelConsumptionReport (from, to, userData, traccar) {
|
|
|
26
26
|
|
|
27
27
|
const allInOne = await traccarHelper.getAllInOne(traccar, from, to, devices, true, true, false, false)
|
|
28
28
|
const dates = getDates(from, to, userData.user.attributes.timezone || getUserPartner(userData.user).timezone)
|
|
29
|
-
const summary = await getSummaryByDay(dates, userData, traccar, devices)
|
|
29
|
+
const summary = await getSummaryByDay(dates, userData, traccar, devices, true, from, to)
|
|
30
30
|
|
|
31
31
|
const fuelServicesData = []
|
|
32
32
|
if (devices.some(d => d.attributes.odooId)) {
|
package/src/kms-report.js
CHANGED
|
@@ -50,7 +50,7 @@ async function createKmsReportByDevice (from, to, userData, traccarInstance) {
|
|
|
50
50
|
} else {
|
|
51
51
|
if (userData.allWeek && userData.groupByDay) {
|
|
52
52
|
const dates = getDates(from, to, userData.user.attributes.timezone || getUserPartner(userData.user).timezone)
|
|
53
|
-
const summary = await getSummaryByDay(dates, userData, traccarInstance, allDevices)
|
|
53
|
+
const summary = await getSummaryByDay(dates, userData, traccarInstance, allDevices, false, from, to)
|
|
54
54
|
for (const device of allDevices) {
|
|
55
55
|
const days = []
|
|
56
56
|
dates.forEach(date => {
|
|
@@ -2,7 +2,9 @@ const { getReports } = require('./index')
|
|
|
2
2
|
const { createPerformanceReport, exportPerformanceReportToExcel } = require('../partnerReports/performance-report')
|
|
3
3
|
const assert = require('assert')
|
|
4
4
|
const { convertMS } = require('../util/utils')
|
|
5
|
-
const xlsx = require(
|
|
5
|
+
const xlsx = require('@jcardus/json-as-xlsx')
|
|
6
|
+
const {createActivityReport} = require("../activity-report");
|
|
7
|
+
const {createFuelConsumptionReport} = require("../fuelconsumption-report");
|
|
6
8
|
|
|
7
9
|
// eslint-disable-next-line no-undef
|
|
8
10
|
describe('performance', function () {
|
|
@@ -29,11 +31,19 @@ describe('performance', function () {
|
|
|
29
31
|
const userData = await report.getUserData()
|
|
30
32
|
userData.devices = userData.devices.filter(d => d.id === 126442)
|
|
31
33
|
const data = await createPerformanceReport(
|
|
32
|
-
new Date(Date.UTC(2023, 11, 9,
|
|
33
|
-
new Date(Date.UTC(2023, 11, 18,
|
|
34
|
+
new Date(Date.UTC(2023, 11, 9, 14, 58, 0, 0)),
|
|
35
|
+
new Date(Date.UTC(2023, 11, 18, 9, 28, 0, 0)),
|
|
34
36
|
userData,
|
|
35
37
|
report.traccar)
|
|
36
38
|
console.log(data)
|
|
39
|
+
|
|
40
|
+
const data2 = await createFuelConsumptionReport(
|
|
41
|
+
new Date(Date.UTC(2023, 11, 9, 14, 58, 0, 0)),
|
|
42
|
+
new Date(Date.UTC(2023, 11, 18, 9, 28, 0, 0)),
|
|
43
|
+
userData,
|
|
44
|
+
report.traccar)
|
|
45
|
+
console.log(data2)
|
|
46
|
+
|
|
37
47
|
assert.equal(data[0].consumption, 168.51989999999998)
|
|
38
48
|
}, 8000000)
|
|
39
49
|
|
package/src/util/traccar.js
CHANGED
|
@@ -129,12 +129,22 @@ async function getAllInOne (
|
|
|
129
129
|
}
|
|
130
130
|
}
|
|
131
131
|
|
|
132
|
-
async function getSummaryByDay (dates, userData, traccarInstance, allDevices, ignorePercentage = false) {
|
|
132
|
+
async function getSummaryByDay (dates, userData, traccarInstance, allDevices, ignorePercentage = false, from, to) {
|
|
133
133
|
const days = []
|
|
134
134
|
let counter = 0
|
|
135
|
-
for (const date of dates) {
|
|
136
|
-
|
|
137
|
-
|
|
135
|
+
for (const [index, date] of dates.entries()) {
|
|
136
|
+
let startDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + userData.dayHours.startTime)
|
|
137
|
+
if (index === 0) {
|
|
138
|
+
const _startDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + from.toTimeString())
|
|
139
|
+
startDateLocal = startDateLocal.getTime() > _startDateLocal.getTime() ? startDateLocal : _startDateLocal
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
let endDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + userData.dayHours.endTime)
|
|
143
|
+
if (index === dates.length - 1) {
|
|
144
|
+
const _endDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + to.toTimeString())
|
|
145
|
+
endDateLocal = endDateLocal.getTime() < _endDateLocal.getTime() ? endDateLocal : _endDateLocal
|
|
146
|
+
}
|
|
147
|
+
|
|
138
148
|
const startDate = isClientSide() ? startDateLocal : convertFromLocal(startDateLocal, userData.user.attributes.timezone)
|
|
139
149
|
const endDate = isClientSide() ? endDateLocal : convertFromLocal(endDateLocal, userData.user.attributes.timezone)
|
|
140
150
|
|
package/src/util/utils.js
CHANGED
|
@@ -109,6 +109,8 @@ function convertToFeature (geofence) {
|
|
|
109
109
|
function getDates (startDate, endDate, timezone) {
|
|
110
110
|
const dates = []
|
|
111
111
|
let currentDate = new Date(startDate.getFullYear(), startDate.getMonth(), startDate.getDate(), 12, 0, 0, 0)
|
|
112
|
+
const _endDate = new Date(endDate.getFullYear(), endDate.getMonth(), endDate.getDate(), 23, 59, 59, 0)
|
|
113
|
+
|
|
112
114
|
if (!isClientSide() && timezone) {
|
|
113
115
|
const startDateUserTimezone = convertFromUTC(startDate, timezone)
|
|
114
116
|
currentDate = new Date(startDateUserTimezone.getFullYear(), startDateUserTimezone.getMonth(), startDateUserTimezone.getDate(), 12, 0, 0, 0)
|
|
@@ -118,7 +120,7 @@ function getDates (startDate, endDate, timezone) {
|
|
|
118
120
|
date.setDate(date.getDate() + days)
|
|
119
121
|
return date
|
|
120
122
|
}
|
|
121
|
-
while (currentDate <=
|
|
123
|
+
while (currentDate <= _endDate) {
|
|
122
124
|
dates.push(currentDate)
|
|
123
125
|
currentDate = addDays.call(currentDate, 1)
|
|
124
126
|
}
|