67 lines
1.6 KiB
PHP
67 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Datatables\Shop;
|
|
|
|
use App\Datatables\ParentDataTable as DataTable;
|
|
use App\Models\Shop\Order;
|
|
use App\Repositories\Shop\Customers;
|
|
use App\Repositories\Shop\Orders;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Yajra\DataTables\Html\Column;
|
|
|
|
class CustomerOrdersDataTable extends DataTable
|
|
{
|
|
public $model_name = 'orders';
|
|
|
|
public $sortedColumn = 1;
|
|
|
|
public $sortedOrder = 'desc';
|
|
|
|
public $stateSave = true;
|
|
|
|
public $url = null;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->url = route('Shop.Orders.index');
|
|
}
|
|
|
|
public function query(Order $model)
|
|
{
|
|
$customerId = Customers::getId();
|
|
$model = $model->byCustomer($customerId);
|
|
|
|
return $this->buildQuery($model);
|
|
}
|
|
|
|
public function getHtmlButtons()
|
|
{
|
|
return self::getButtonShow('uuid', 'Voir la commande');
|
|
}
|
|
|
|
public function modifier($datatables)
|
|
{
|
|
$datatables
|
|
->editColumn('status', function (Order $order) {
|
|
return Orders::getStatus($order->status);
|
|
})
|
|
->editColumn('created_at', function (Order $order) {
|
|
return $order->created_at->isoFormat('DD/MM/YY HH:mm');
|
|
})
|
|
->rawColumns(['action']);
|
|
|
|
return parent::modifier($datatables);
|
|
}
|
|
|
|
protected function getColumns()
|
|
{
|
|
return [
|
|
Column::make('created_at')->title('Date'),
|
|
Column::make('ref')->title('Ref'),
|
|
Column::make('total_shipped')->title('Montant')->class('text-right'),
|
|
Column::make('status')->title('Statut'),
|
|
$this->makeColumnButtons(),
|
|
];
|
|
}
|
|
}
|