update
This commit is contained in:
@ -370,7 +370,61 @@ class Tracks extends Model
|
||||
|
||||
$query .= " ;";
|
||||
|
||||
return DB::select($query, $params);
|
||||
// return DB::select($query, $params);
|
||||
$rawTracks = DB::select($query, $params);
|
||||
$cleanTracks = self::filterJumps($rawTracks);
|
||||
|
||||
if (isset($filter["limit"])) {
|
||||
return array_slice($cleanTracks, 0, $filter["limit"]);
|
||||
}
|
||||
return $cleanTracks;
|
||||
}
|
||||
|
||||
public static function haversineDistance($lat1, $lon1, $lat2, $lon2)
|
||||
{
|
||||
$earthRadius = 6371000; // meters
|
||||
|
||||
$lat1 = deg2rad($lat1);
|
||||
$lon1 = deg2rad($lon1);
|
||||
$lat2 = deg2rad($lat2);
|
||||
$lon2 = deg2rad($lon2);
|
||||
|
||||
$dlat = $lat2 - $lat1;
|
||||
$dlon = $lon2 - $lon1;
|
||||
|
||||
$a = sin($dlat / 2) ** 2 + cos($lat1) * cos($lat2) * sin($dlon / 2) ** 2;
|
||||
$c = 2 * atan2(sqrt($a), sqrt(1 - $a));
|
||||
|
||||
return $earthRadius * $c;
|
||||
}
|
||||
|
||||
public static function filterJumps($points, $maxDistance = 50, $maxTimeGap = 10)
|
||||
{
|
||||
$filtered = [];
|
||||
$last = null;
|
||||
|
||||
foreach ($points as $p) {
|
||||
if (!$last) {
|
||||
$filtered[] = $p;
|
||||
$last = $p;
|
||||
continue;
|
||||
}
|
||||
|
||||
$distance = self::haversineDistance(
|
||||
$last->latitude,
|
||||
$last->longitude,
|
||||
$p->latitude,
|
||||
$p->longitude
|
||||
);
|
||||
$timeGap = $p->lst_loc_crt - $last->lst_loc_crt;
|
||||
|
||||
if ($distance <= $maxDistance || $timeGap > $maxTimeGap) {
|
||||
$filtered[] = $p;
|
||||
$last = $p;
|
||||
}
|
||||
}
|
||||
|
||||
return $filtered;
|
||||
}
|
||||
|
||||
public static function nearestInCircle($lat, $lng, $rad, $filter = [])
|
||||
|
||||
@ -766,13 +766,13 @@
|
||||
},
|
||||
calcPeriodeDate: function(startDate, endDate) {
|
||||
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
|
||||
Helper.toast('Warning', 'just now', 'Start date of the period is not valid');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
|
||||
Helper.toast('Warning', 'just now', 'End date of the period is not valid');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
@ -781,13 +781,13 @@
|
||||
const duration = moment.duration(endDate.diff(startDate));
|
||||
const diffDays = duration.days();
|
||||
if (diffDays > 30) {
|
||||
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
|
||||
Helper.toast('Warning', 'just now', 'Maximum period is 1 month');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (diffDays < 0) {
|
||||
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
|
||||
Helper.toast('Warning', 'just now', 'Invalid period range');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
@ -2606,7 +2606,7 @@
|
||||
let startMarker = Leaflet.addMarkers({
|
||||
lat: start.latitude,
|
||||
lng: start.longitude,
|
||||
label: `<b>Titik Awal</b><br>${start.nopol1} ${start.nopol2} ${start.nopol3}<br>${moment.unix(start?.lst_loc_crt).format('DD MMM YYYY HH:mm')}<br>Speed: ${(typeof start.lst_speed != 'undefined') ? start.lst_speed : '0'}<br>${Number(start.latitude).toFixed(5)},${Number(start.longitude).toFixed(6)}<br>${decodeURIComponent(start.fulladdress || 'address')}`,
|
||||
label: `<b>Start Poin</b><br>${start.nopol1} ${start.nopol2} ${start.nopol3}<br>${moment.unix(start?.lst_loc_crt).format('DD MMM YYYY HH:mm')}<br>Speed: ${(typeof start.lst_speed != 'undefined') ? start.lst_speed : '0'}<br>${Number(start.latitude).toFixed(5)},${Number(start.longitude).toFixed(6)}<br>${decodeURIComponent(start.fulladdress || 'address')}`,
|
||||
options: {
|
||||
icon: Icon.titikAwal(),
|
||||
// rotationAngle: 290
|
||||
@ -2615,7 +2615,7 @@
|
||||
let finishMarker = Leaflet.addMarkers({
|
||||
lat: finish.latitude,
|
||||
lng: finish.longitude,
|
||||
label: `<b>Titik Akhir</b><br>${finish.nopol1} ${finish.nopol2} ${finish.nopol3}<br>${moment.unix(finish?.lst_loc_crt).format('DD MMM YYYY HH:mm')}<br>Speed: ${(typeof finish.lst_speed != 'undefined') ? finish.lst_speed : '0'}<br>${Number(finish.latitude).toFixed(5)},${Number(finish.longitude).toFixed(6)}<br>${decodeURIComponent(finish.fulladdress || 'address')}`,
|
||||
label: `<b>End Poin</b><br>${finish.nopol1} ${finish.nopol2} ${finish.nopol3}<br>${moment.unix(finish?.lst_loc_crt).format('DD MMM YYYY HH:mm')}<br>Speed: ${(typeof finish.lst_speed != 'undefined') ? finish.lst_speed : '0'}<br>${Number(finish.latitude).toFixed(5)},${Number(finish.longitude).toFixed(6)}<br>${decodeURIComponent(finish.fulladdress || 'address')}`,
|
||||
options: {
|
||||
icon: Icon.titikAkhir()
|
||||
}
|
||||
|
||||
@ -78,8 +78,7 @@
|
||||
<tr class="">
|
||||
<td class="">1</td>
|
||||
<td class="">
|
||||
<a href="{{ route('view_keuangan_billing_view') }}"
|
||||
class="">
|
||||
<a href="{{ route('view_keuangan_billing_view') }}" class="">
|
||||
<span class="icon ion-eye text-danger fz-16"></span>
|
||||
</a>
|
||||
</td>
|
||||
@ -177,14 +176,20 @@
|
||||
},
|
||||
evPeriodeDate: function() {
|
||||
$('#filter-startDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
DTable.reload();
|
||||
});
|
||||
$('#filter-endDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
@ -194,23 +199,37 @@
|
||||
calcPeriodeDate: function(startDate, endDate) {
|
||||
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
|
||||
return { isValid: false };
|
||||
Helper.toast('Warning', 'just now', 'End date of the period is not valid');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
const duration = moment.duration(endDate.diff(startDate));
|
||||
const diffDays = duration.days();
|
||||
if (diffDays > 30) {
|
||||
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (diffDays < 0) {
|
||||
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
return { isValid: true, data: { startDate, endDate } };
|
||||
return {
|
||||
isValid: true,
|
||||
data: {
|
||||
startDate,
|
||||
endDate
|
||||
}
|
||||
};
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
@ -187,14 +187,20 @@
|
||||
},
|
||||
evPeriodeDate: function() {
|
||||
$('#filter-startDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
DTable.reload();
|
||||
});
|
||||
$('#filter-endDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
@ -204,23 +210,37 @@
|
||||
calcPeriodeDate: function(startDate, endDate) {
|
||||
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
|
||||
return { isValid: false };
|
||||
Helper.toast('Warning', 'just now', 'End date of the period is not valid');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
const duration = moment.duration(endDate.diff(startDate));
|
||||
const diffDays = duration.days();
|
||||
if (diffDays > 30) {
|
||||
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (diffDays < 0) {
|
||||
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
return { isValid: true, data: { startDate, endDate } };
|
||||
return {
|
||||
isValid: true,
|
||||
data: {
|
||||
startDate,
|
||||
endDate
|
||||
}
|
||||
};
|
||||
},
|
||||
}
|
||||
|
||||
@ -363,8 +383,7 @@
|
||||
// This row is already open - close it
|
||||
row.child.hide();
|
||||
tr.removeClass('shown');
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
// Open this row
|
||||
row.child(DTable.formatChildRow(row.data())).show();
|
||||
tr.addClass('shown');
|
||||
@ -393,7 +412,10 @@
|
||||
if (item.calc_to_vdr == State.calc_to_vdr.yes && item.is_aprv != State.is_aprv.yes) continue;
|
||||
if (item.invc_to_client == State.invc_to_client.yes && item.is_bill_aprv != State.is_aprv.yes) continue;
|
||||
|
||||
let small_desc = '', amt_in = 0, amt_out = 0, amt_bl = 0;
|
||||
let small_desc = '',
|
||||
amt_in = 0,
|
||||
amt_out = 0,
|
||||
amt_bl = 0;
|
||||
if (item.is_bill_paid == State.is_a_item_paid.paid) {
|
||||
amt_in = item.amt_in;
|
||||
small_desc += `<br><small>waktu dibayarkan <span class="text-success">${moment.unix(item.paid_bill_at).format('DD MMM YYYY HH:mm:ss')}</span></small>`;
|
||||
|
||||
@ -192,14 +192,20 @@
|
||||
},
|
||||
evPeriodeDate: function() {
|
||||
$('#filter-startDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
DTable.reload();
|
||||
});
|
||||
$('#filter-endDate').on('change', function(e) {
|
||||
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
const {
|
||||
isValid,
|
||||
data
|
||||
} = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
|
||||
if (!isValid) return false;
|
||||
State.periodeStartDate = data.startDate.unix();
|
||||
State.periodeEndDate = data.endDate.unix();
|
||||
@ -209,23 +215,37 @@
|
||||
calcPeriodeDate: function(startDate, endDate) {
|
||||
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
|
||||
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
|
||||
return { isValid: false };
|
||||
Helper.toast('Warning', 'just now', 'End date of the period is not valid');
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
const duration = moment.duration(endDate.diff(startDate));
|
||||
const diffDays = duration.days();
|
||||
if (diffDays > 30) {
|
||||
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
if (diffDays < 0) {
|
||||
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
|
||||
return { isValid: false };
|
||||
return {
|
||||
isValid: false
|
||||
};
|
||||
}
|
||||
return { isValid: true, data: { startDate, endDate } };
|
||||
return {
|
||||
isValid: true,
|
||||
data: {
|
||||
startDate,
|
||||
endDate
|
||||
}
|
||||
};
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user