@php echo "namespaces->dataTables }}; use {{ $config->namespaces->model }}\{{ $config->modelNames->name }}; @if($config->options->localized) use Yajra\DataTables\Html\Column; @endif use Yajra\DataTables\Services\DataTable; use Yajra\DataTables\EloquentDataTable; class {{ $config->modelNames->name }}DataTable extends DataTable { /** * Build DataTable class. * * @param mixed $query Results from query() method. * @return \Yajra\DataTables\DataTableAbstract */ public function dataTable($query) { $dataTable = new EloquentDataTable($query); $dataTable->editColumn('photo', function ({{ $config->modelNames->name }} $model) { $photo = $model->photo ; return view('includes.lazy_photo', compact('photo')); }); $dataTable->editColumn('is_active', function ({{ $config->modelNames->name }} $model) { $value = $model->is_active; return view('includes.datatables_column_bool', compact('value')); }); return $dataTable->addColumn('action', '{{ $config->prefixes->getViewPrefixForInclude() }}{{ $config->modelNames->snakePlural }}.datatables_actions'); } /** * Get query source of dataTable. * * @param \App\Models\{{ $config->modelNames->name }} $model * @return \Illuminate\Database\Eloquent\Builder */ public function query({{ $config->modelNames->name }} $model) { return $model->newQuery(); } /** * Optional method if you want to use html builder. * * @return \Yajra\DataTables\Html\Builder */ public function html() { return $this->builder() ->columns($this->getColumns()) ->minifiedAjax() ->addAction(['width' => 'auto', 'printable' => false, 'searchable' => false, 'exporting' => false, 'title' => __('lang.action')]) ->parameters([ 'stateSave' => true, 'responsive' => true, "autoWidth" => true, 'dom' => 'Bfrltip', 'orderable' => true, 'order' => [[0, 'desc']], 'buttons' => [ // Enable Buttons as per your need // ['extend' => 'create', 'className' => 'btn btn-default btn-sm no-corner',], // ['extend' => 'export', 'className' => 'btn btn-default btn-sm no-corner',], // ['extend' => 'print', 'className' => 'btn btn-default btn-sm no-corner',], // ['extend' => 'reset', 'className' => 'btn btn-default btn-sm no-corner',], // ['extend' => 'reload', 'className' => 'btn btn-default btn-sm no-corner',], ], 'drawCallback' => 'function() { lazyLoadInstance.update();}', @if($config->options->localized) 'language' => [ 'url' => url('//cdn.datatables.net/plug-ins/1.10.12/i18n/English.json'), ], @endif ]); } /** * Get columns. * * @return array */ protected function getColumns() { return [ {!! $columns !!} ]; } /** * Get filename for export. * * @return string */ protected function filename(): string { return '{{ $config->modelNames->snakePlural }}_datatable_' . time(); } }