Я использую класс данных на моем контроллере и использовал его для рисования таблицы данных, в которой у меня есть объединенный столбец «Имя».поэтому поиск по умолчанию не работает. Я не могу найти пример для пользовательского фильтра в этом сценарии
// Это дата.я пытался использовать filterColumn () для функции dataTable, но он сказал, что метод не найден.
namespace App\DataTables;
use App\User;
use Illuminate\Support\Facades\DB;
use Yajra\DataTables\Services\DataTable;
class UsersDatatable extends DataTable
{
public function dataTable($query)
{
return datatables($query)
->addColumn('action', function ($users) {
return '<a href="'.route('users.edit',$users->id).'" class="btn btn-sm btn-primary" style="margin:3px"><i
class="glyphicon glyphicon-edit"></i> Edit</a></a> <a href="'.route('users.destroy',$users->id).'" class="btn btn-sm btn-danger"><i class="glyphicon glyphicon-remove"></i> Delete</a>';
});
}
public function query(User $model)
{
return $model->newQuery()->select('id', DB::raw('CONCAT(FirstName," ", Surname ) AS name'), 'email', 'phone_no');
}
public function html()
{
//
return $this->builder()
->columns($this->getColumns())
->minifiedAjax()
->addAction(['width' => '130px'])
->parameters($this->getBuilderParameters());
}
protected function getColumns()
{
return [
'id',
'name',
'email',
'phone_no',
];
}
protected function filename()
{
return 'Users_' . date('YmdHis');
}
}
это контроллер
namespace App\Http\Controllers\Backend;
use App\DataTables\UsersDatatable;
use App\User;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Yajra\DataTables\DataTables;
class RegisterController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index(UsersDatatable $user)
{
return $user->render('backend.Users.indexUser');
}
// это представление
<div class="card-header">
Index User
</div>
<div class="card-body">
<h5 class="card-title">Table</h5>
{!! $dataTable->table(['class' => 'table table-striped ']) !!}
</div>
</div>
@endsection
@section('scripts')
<script src="https://cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>
<!-- from dataTables push-->
<script src="https://cdn.datatables.net/buttons/1.4.2/js/dataTables.buttons.min.js"></script>
<script src="{{asset('vendor/datatables/buttons.server-side.js')}}"></script>
{!! $dataTable->scripts() !!}```