Im working on a laravel project which is using innertia, vue stack. In my project some models have hidden attributes. I want to make visible them in some routes. But i cant use makeVisible() with query builder. is there a solution for this?
method in controller
$hosters = Hoster::query()
->when($request->input('search'), function ($query, $search) {
if ($search == "approved") {
return $query->where('is_approved', '=', true);
} elseif ($search == "notapproved") {
return $query->where('is_approved', '=', false);
}
return $query
->where('name', 'like', '%' . $search . '%')
->orWhere('contact_number', 'like', '%' . $search . '%')
->orWhere('email', 'like', '%' . $search . '%');
})
->orderBy('created_at', 'desc')
->paginate(8)
->withQueryString();
return Inertia::render('Hoster/Show', [
'hosters' => $hosters,
'filters' => $request->only(['search']),
]);
hidden fields in model
protected $hidden = [
'past_works',
'anchor',
'contact_number',
'email'
];
use makeVisible
method
The makeVisible method makes attributes visible that are typically "hidden" on each model in the collection
$hosters = Hoster::query()
->when($request->input('search'), function ($query, $search) {
if ($search == "approved") {
return $query->where('is_approved', '=', true);
} elseif ($search == "notapproved") {
return $query->where('is_approved', '=', false);
}
return $query
->where('name', 'like', '%' . $search . '%')
->orWhere('contact_number', 'like', '%' . $search . '%')
->orWhere('email', 'like', '%' . $search . '%');
})
->orderBy('created_at', 'desc')
->paginate(8)
->withQueryString();
$hosters->makeVisible([
'past_works'
]);
return Inertia::render('Hoster/Show', [
'hosters' => $hosters,
'filters' => $request->only(['search']),
]);
Ref: https://laravel.com/docs/8.x/eloquent-collections#method-makeVisible Ref:https://github.com/laravel/framework/issues/16501