File: /var/www/html/dashboard.orbiwheels.com/app/DataTables/Admin/RideDataTable.php
<?php
namespace App\DataTables\Admin;
use App\Models\BookingRide;
use App\Models\Ride;
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
use Yajra\DataTables\EloquentDataTable;
use Yajra\DataTables\Html\Builder as HtmlBuilder;
use Yajra\DataTables\Html\Button;
use Yajra\DataTables\Html\Column;
use Yajra\DataTables\Html\Editor\Editor;
use Yajra\DataTables\Html\Editor\Fields;
use Yajra\DataTables\Services\DataTable;
class RideDataTable extends DataTable
{
/**
* Build the DataTable class.
*
* @param QueryBuilder<Ride> $query Results from query() method.
*/
public function dataTable(QueryBuilder $query): EloquentDataTable
{
return (new EloquentDataTable($query))
->addIndexColumn()
->editColumn('booking_code', function ($row) {
if ($row->booking) {
$url = route('admin.booking.view', encrypt($row->booking->id));
return '<a href="' . $url . '">' . $row->booking->booking_code . '</a>';
}
})
->addColumn('transporter', function ($row) {
if ($row->trip->transporter) {
return '<a href="' . route('admin.transporter.view', $row->trip->transporter->id) . '">'
. e($row->trip->transporter->company_name) . '</a>';
}
return '-';
})
->addColumn('no_of_passengers', function ($row) {
if (!empty($row->booking->no_of_passengers)) {
return $row->booking->no_of_passengers ?? '-';
}
return '-';
})
->addColumn('ride_type', function ($row) {
if (!empty($row->booking->ride_type)) {
return $row->booking->ride_type_name ?? '-';
}
return '-';
})
->addColumn('ride_date', function ($row) {
return !empty($row->ride_date)
? \Carbon\Carbon::parse($row->ride_date)->format('M d, Y') // Aug 25, 2025
: '-';
})
->addColumn('pickup_time', function ($row) {
if (!empty($row->pickup_time)) {
return date('h:i A', strtotime($row->pickup_time));
}
return '-';
})
->addColumn('pickup_location', function ($row) {
return $row->locations['pickup_location'] ?? '-';
})
->addColumn('drop_location', function ($row) {
return $row->locations['drop_location'] ?? '-';
})
->addColumn('fare', function ($row) {
if (isset($row)) {
return '₹ ' . number_format($row->fare, 2);
}
return null;
})
->addColumn('vehicle', function ($row) {
if (isset($row->vehicle)) {
return $row->vehicle->registration_number;
}
return 'Not Assigned';
})
->addColumn('driver', function ($row) {
if (isset($row->driver)) {
return $row->driver->name;
}
return 'Not Assigned';
})
->addColumn('status', function ($row) {
switch ($row->status) {
case 0:
return '<span class="badge badge-warning text-white">Pending</span>';
case 1:
return '<span class="badge badge-dark text-white">Assigned</span>';
case 2:
return '<span class="badge badge-info text-white">Ongoing</span>';
case 3:
return '<span class="badge badge-success text-white">Completed</span>';
case 4:
return '<span class="badge badge-primary text-white">Cancelled</span>';
default:
return '<span class="badge badge-secondary text-white">Unknown</span>';
}
})
->addColumn('created_at', function ($row) {
return date('d-m-Y', strtotime($row->created_at));
})
->addColumn('action', function ($row) {
$buttons = '<div class="table-actions d-flex">';
$buttons .= '
<a href="' . route('admin.rides.view', encrypt($row->id)) . '" class="btn btn-primary btn-sm" title="view">
<i class="fa fa-eye"></i>
</a>';
return $buttons;
})
->filterColumn('driver', function ($query, $keyword) {
$keyword = strtolower(trim($keyword));
if ($keyword === 'assigned') {
$query->whereNotNull('driver_id');
} elseif ($keyword === 'non-assigned') {
$query->whereNull('driver_id');
} else {
$query->whereHas('driver', function ($q) use ($keyword) {
// Assuming driver name column is 'name'
$q->whereRaw('LOWER(name) LIKE ?', ["%{$keyword}%"]);
});
}
})
->filterColumn('vehicle', function ($query, $keyword) {
$keyword = strtolower(trim($keyword));
if ($keyword === 'assigned') {
$query->whereNotNull('vehicle_id');
} elseif ($keyword === 'non-assigned') {
$query->whereNull('vehicle_id');
} else {
$query->whereHas('vehicle', function ($q) use ($keyword) {
// Assuming registration number column is 'registration_number'
$q->whereRaw('LOWER(registration_number) LIKE ?', ["%{$keyword}%"]);
});
}
})
->rawColumns(['status', 'booking_code', 'action', 'transporter'])
->setRowId('id');
}
/**
* Get the query source of dataTable.
*
* @return QueryBuilder<Ride>
*/
public function query(BookingRide $model): QueryBuilder
{
$query = $model->newQuery()->with(['trip','booking', 'driver', 'vehicle']);
// Status filter
if ($status = request('status')) {
$query->where('status', $status);
}
// Driver assigned/non-assigned filter
if ($driver = request('driver')) {
if ($driver === 'assigned') {
$query->whereNotNull('driver_id');
} elseif ($driver === 'non-assigned') {
$query->whereNull('driver_id');
}
}
// Vehicle assigned/non-assigned filter
if ($vehicle = request('vehicle')) {
if ($vehicle === 'assigned') {
$query->whereNotNull('vehicle_id');
} elseif ($vehicle === 'non-assigned') {
$query->whereNull('vehicle_id');
}
}
// Ride date filter
if ($rideDate = request('ride_date')) {
$query->where('ride_date', $rideDate);
}
return $query->orderBy('ride_date', 'asc')
->orderBy('pickup_time', 'asc');
}
/**
* Optional method if you want to use the html builder.
*/
public function html(): HtmlBuilder
{
return $this->builder()
->setTableId('ride-table')
->setTableAttribute('class', 'table table-striped table-bordered dt-responsive nowrap jambo_table bulk_action')
->columns($this->getColumns())
->minifiedAjax(route('admin.rides.index'), null, [
'status' => 'function(){ return $("#statusFilter").val(); }',
'driver' => 'function(){ return $("#driverFilter").val(); }',
'vehicle' => 'function(){ return $("#vehicleFilter").val(); }',
'ride_date' => 'function(){ return $("#rideDateFilter").val(); }',
])
->orderBy(1)
->selectStyleSingle()
->responsive(true)
->autoWidth(false)
->buttons([
// Button::make('excel'),
// Button::make('csv'),
// Button::make('pdf'),
// Button::make('print'),
// Button::make('reset'),
// Button::make('reload')
]);
}
/**
* Get the dataTable columns definition.
*/
protected function getColumns(): array
{
return [
Column::computed('control')
->title('')
->exportable(false)
->printable(false)
->width(30)
->addClass('control')
->orderable(false)
->searchable(false)
->data('control')
->defaultContent(''),
Column::make('booking_code')->title('Booking Code')->orderable(false)->addClass('all'),
Column::make('transporter')->title('Transporter')->addClass('all'),
Column::make('ride_type')->title('Ride Type')->addClass('all'),
Column::make('ride_date')->title('Ride Date')->addClass('all'),
Column::make('pickup_time')->title('Pickup Time')->addClass('all'),
Column::make('pickup_location')->title('Pickup Location')->addClass('all'),
Column::make('drop_location')->title('Drop Location')->addClass('all'),
Column::make('distance_km')->title('Distance (km)')->addClass('none'),
Column::make('fare')->title('Total Fare')->addClass('none'),
Column::make('no_of_passengers')->title('Passenger')->addClass('none'),
Column::make('vehicle')->title('Vehicle')->searchable(true)->addClass('none'),
Column::make('driver')->title('Driver')->searchable(true)->addClass('none'),
Column::make('status')->title('Status')->addClass('all'),
Column::computed('action')
->exportable(false)
->printable(false)
->width(120)
->addClass('text-center all'),
];
}
/**
* Get the filename for export.
*/
protected function filename(): string
{
return 'Ride_' . date('YmdHis');
}
}