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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fleetmap-reports",
3
- "version": "1.0.970",
3
+ "version": "1.0.972",
4
4
  "description": "",
5
5
  "main": "src/index.js",
6
6
  "scripts": {
@@ -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("@jcardus/json-as-xlsx");
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, 0, 0, 0, 0)),
33
- new Date(Date.UTC(2023, 11, 18, 23, 59, 59, 0)),
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
 
@@ -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
- const startDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + userData.dayHours.startTime)
137
- const endDateLocal = new Date(convertFromUTC(date, userData.user.attributes.timezone).toISOString().split('T')[0] + ' ' + userData.dayHours.endTime)
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 <= endDate) {
123
+ while (currentDate <= _endDate) {
122
124
  dates.push(currentDate)
123
125
  currentDate = addDays.call(currentDate, 1)
124
126
  }