update
This commit is contained in:
		| @ -370,7 +370,61 @@ class Tracks extends Model | |||||||
|  |  | ||||||
|         $query .= " ;"; |         $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 = []) |     public static function nearestInCircle($lat, $lng, $rad, $filter = []) | ||||||
|  | |||||||
| @ -766,13 +766,13 @@ | |||||||
|             }, |             }, | ||||||
|             calcPeriodeDate: function(startDate, endDate) { |             calcPeriodeDate: function(startDate, endDate) { | ||||||
|                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { |                 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 { |                     return { | ||||||
|                         isValid: false |                         isValid: false | ||||||
|                     }; |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (endDate.format('YYYY-MM-DD') === 'Invalid date') { |                 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 { |                     return { | ||||||
|                         isValid: false |                         isValid: false | ||||||
|                     }; |                     }; | ||||||
| @ -781,13 +781,13 @@ | |||||||
|                 const duration = moment.duration(endDate.diff(startDate)); |                 const duration = moment.duration(endDate.diff(startDate)); | ||||||
|                 const diffDays = duration.days(); |                 const diffDays = duration.days(); | ||||||
|                 if (diffDays > 30) { |                 if (diffDays > 30) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); |                     Helper.toast('Warning', 'just now', 'Maximum period is 1 month'); | ||||||
|                     return { |                     return { | ||||||
|                         isValid: false |                         isValid: false | ||||||
|                     }; |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (diffDays < 0) { |                 if (diffDays < 0) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Rentang periode tidak valid'); |                     Helper.toast('Warning', 'just now', 'Invalid period range'); | ||||||
|                     return { |                     return { | ||||||
|                         isValid: false |                         isValid: false | ||||||
|                     }; |                     }; | ||||||
| @ -2606,7 +2606,7 @@ | |||||||
|                 let startMarker = Leaflet.addMarkers({ |                 let startMarker = Leaflet.addMarkers({ | ||||||
|                     lat: start.latitude, |                     lat: start.latitude, | ||||||
|                     lng: start.longitude, |                     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: { |                     options: { | ||||||
|                         icon: Icon.titikAwal(), |                         icon: Icon.titikAwal(), | ||||||
|                         // rotationAngle: 290 |                         // rotationAngle: 290 | ||||||
| @ -2615,7 +2615,7 @@ | |||||||
|                 let finishMarker = Leaflet.addMarkers({ |                 let finishMarker = Leaflet.addMarkers({ | ||||||
|                     lat: finish.latitude, |                     lat: finish.latitude, | ||||||
|                     lng: finish.longitude, |                     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: { |                     options: { | ||||||
|                         icon: Icon.titikAkhir() |                         icon: Icon.titikAkhir() | ||||||
|                     } |                     } | ||||||
|  | |||||||
| @ -78,8 +78,7 @@ | |||||||
|                                         <tr class=""> |                                         <tr class=""> | ||||||
|                                             <td class="">1</td> |                                             <td class="">1</td> | ||||||
|                                             <td class=""> |                                             <td class=""> | ||||||
|                                                 <a href="{{ route('view_keuangan_billing_view') }}" |                                                 <a href="{{ route('view_keuangan_billing_view') }}" class=""> | ||||||
|                                                     class=""> |  | ||||||
|                                                     <span class="icon ion-eye text-danger fz-16"></span> |                                                     <span class="icon ion-eye text-danger fz-16"></span> | ||||||
|                                                 </a> |                                                 </a> | ||||||
|                                             </td> |                                             </td> | ||||||
| @ -177,14 +176,20 @@ | |||||||
|             }, |             }, | ||||||
|             evPeriodeDate: function() { |             evPeriodeDate: function() { | ||||||
|                 $('#filter-startDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
|                     DTable.reload(); |                     DTable.reload(); | ||||||
|                 }); |                 }); | ||||||
|                 $('#filter-endDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
| @ -194,23 +199,37 @@ | |||||||
|             calcPeriodeDate: function(startDate, endDate) { |             calcPeriodeDate: function(startDate, endDate) { | ||||||
|                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { |                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { | ||||||
|                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); |                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (endDate.format('YYYY-MM-DD') === 'Invalid date') { |                 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 }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 const duration = moment.duration(endDate.diff(startDate)); |                 const duration = moment.duration(endDate.diff(startDate)); | ||||||
|                 const diffDays = duration.days(); |                 const diffDays = duration.days(); | ||||||
|                 if (diffDays > 30) { |                 if (diffDays > 30) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); |                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (diffDays < 0) { |                 if (diffDays < 0) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Rentang periode tidak valid'); |                     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() { |             evPeriodeDate: function() { | ||||||
|                 $('#filter-startDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
|                     DTable.reload(); |                     DTable.reload(); | ||||||
|                 }); |                 }); | ||||||
|                 $('#filter-endDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
| @ -204,23 +210,37 @@ | |||||||
|             calcPeriodeDate: function(startDate, endDate) { |             calcPeriodeDate: function(startDate, endDate) { | ||||||
|                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { |                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { | ||||||
|                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); |                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (endDate.format('YYYY-MM-DD') === 'Invalid date') { |                 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 }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 const duration = moment.duration(endDate.diff(startDate)); |                 const duration = moment.duration(endDate.diff(startDate)); | ||||||
|                 const diffDays = duration.days(); |                 const diffDays = duration.days(); | ||||||
|                 if (diffDays > 30) { |                 if (diffDays > 30) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); |                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (diffDays < 0) { |                 if (diffDays < 0) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Rentang periode tidak valid'); |                     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 | ||||||
|  |                     } | ||||||
|  |                 }; | ||||||
|             }, |             }, | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @ -355,21 +375,20 @@ | |||||||
|                 $('#totAllOut').text((new Intl.NumberFormat('id-ID')).format(total_out)); |                 $('#totAllOut').text((new Intl.NumberFormat('id-ID')).format(total_out)); | ||||||
|             }, |             }, | ||||||
|             eventChildRow: function() { |             eventChildRow: function() { | ||||||
| 				$('#tLedgerBl tbody').on('click', 'td.dt-control', function () { |                 $('#tLedgerBl tbody').on('click', 'td.dt-control', function() { | ||||||
|                     var tr = $(this).closest('tr'); |                     var tr = $(this).closest('tr'); | ||||||
| 					var row = DTable.table.row( tr ); |                     var row = DTable.table.row(tr); | ||||||
|  |  | ||||||
| 					if ( row.child.isShown() ) { |                     if (row.child.isShown()) { | ||||||
|                         // This row is already open - close it |                         // This row is already open - close it | ||||||
|                         row.child.hide(); |                         row.child.hide(); | ||||||
|                         tr.removeClass('shown'); |                         tr.removeClass('shown'); | ||||||
| 					} |                     } else { | ||||||
| 					else { |  | ||||||
|                         // Open this row |                         // Open this row | ||||||
| 						row.child( DTable.formatChildRow(row.data()) ).show(); |                         row.child(DTable.formatChildRow(row.data())).show(); | ||||||
|                         tr.addClass('shown'); |                         tr.addClass('shown'); | ||||||
|                     } |                     } | ||||||
| 				} ); |                 }); | ||||||
|             }, |             }, | ||||||
|             formatChildRow: function(d) { |             formatChildRow: function(d) { | ||||||
|                 // `d` is the original data object for the row |                 // `d` is the original data object for the row | ||||||
| @ -393,7 +412,10 @@ | |||||||
|                 if (item.calc_to_vdr == State.calc_to_vdr.yes && item.is_aprv != State.is_aprv.yes) continue; |                 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; |                 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) { |                 if (item.is_bill_paid == State.is_a_item_paid.paid) { | ||||||
|                     amt_in = item.amt_in; |                     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>`; |                     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() { |             evPeriodeDate: function() { | ||||||
|                 $('#filter-startDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
|                     DTable.reload(); |                     DTable.reload(); | ||||||
|                 }); |                 }); | ||||||
|                 $('#filter-endDate').on('change', function(e) { |                 $('#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; |                     if (!isValid) return false; | ||||||
|                     State.periodeStartDate = data.startDate.unix(); |                     State.periodeStartDate = data.startDate.unix(); | ||||||
|                     State.periodeEndDate = data.endDate.unix(); |                     State.periodeEndDate = data.endDate.unix(); | ||||||
| @ -209,23 +215,37 @@ | |||||||
|             calcPeriodeDate: function(startDate, endDate) { |             calcPeriodeDate: function(startDate, endDate) { | ||||||
|                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { |                 if (startDate.format('YYYY-MM-DD') === 'Invalid date') { | ||||||
|                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); |                     Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (endDate.format('YYYY-MM-DD') === 'Invalid date') { |                 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 }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 const duration = moment.duration(endDate.diff(startDate)); |                 const duration = moment.duration(endDate.diff(startDate)); | ||||||
|                 const diffDays = duration.days(); |                 const diffDays = duration.days(); | ||||||
|                 if (diffDays > 30) { |                 if (diffDays > 30) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); |                     Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan'); | ||||||
| 					return { isValid: false }; |                     return { | ||||||
|  |                         isValid: false | ||||||
|  |                     }; | ||||||
|                 } |                 } | ||||||
|                 if (diffDays < 0) { |                 if (diffDays < 0) { | ||||||
|                     Helper.toast('Warning', 'just now', 'Rentang periode tidak valid'); |                     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
	 meusinfirmary
					meusinfirmary