Я использую данные Yajra. Я хочу отображать данные и фильтровать данные с именем президента У меня есть 3 таблицы
1- Planes = id, title, description.
2- presidents = id, P_name.
3- Plane_president = plane_id , president_id
Модель самолета:
public function president()
{
return $this->belongsToMany(President::class);
}
Модель президента:
public function planes()
{
return $this->belongsToMany(Plane::class);
}
Мой контроллер:
public function index(Request $request)
{
if ($request->ajax()) {
$query = Plane::with('presidents')->selectRaw('distinct planes.*');
return $this->dataTable
->eloquent($query)
->addColumn('P_name', function (Plane $plane) {
return $plane->presidents->map(function($president) {
return str_limit($president->P_name);
})->implode('<br>');
})
->make(true);
}
return view('planes.index');
}
js код:
<script type="text/javascript">
$('#search').DataTable({
processing: true,
serverSide: true,
ajax: '{{ route("plane.index") }}',
columns: [
{data: 'id', name: 'id'},
{data: 'main_point', name: 'main_point'},
{data: 'presidents[, ].P_name', name: 'president'},
]
});
</script>
У меня эта ошибка
message "Undefined property: App\\Http\\Controllers\\PlaneController::$dataTable"
Как решить эту ошибку?