Использование разбиения на страницы в Eloquent генерирует ресурс Ошибка неопределенного свойства $ id в Laravel

Я пытаюсь создать приложение в Laravel 5.7 где у меня есть модель по имени CompanyBehaviour:

protected $table = 'company_behaviour';

protected $guarded= [];

public function companies()
{
return $this->belongsTo('Noetic\Plugins\Conxn\Models\Company','company_id','id');
}

public function companyRole()
{
return $this->belongsTo('Noetic\Plugins\Conxn\Models\Variables\Company\Role', 'company_role_id', 'id');
}

public function companySpecialisation()
{
return $this->belongsTo('Noetic\Plugins\Conxn\Models\Variables\Company\Role', 'company_specialisation_id', 'id');
}

У меня есть файл ресурсов для этого:

class CompanyBehaviourResource extends JsonResource
{
/**
* Transform the resource into an array.
*
* @param  \Illuminate\Http\Request  $request
* @return array
*/
public function toArray($request)
{
return [
'id' => $this->id,
'company' => $this->company->name,
'company_role' => $this->companyRole->name,
'company_specialisation' => $this->companySpecialisation->name,
];
}
}

Что мне нужно использовать при получении данных в моем контроллере:

public function index(Request $request)
{

return new CompanyBehaviourResource(CompanyBehaviour::whereHas('companies', function ($q) use($request) {
$q->where('name', 'like', '%'.$request->search.'%');
})->orderBy('created_at', 'desc')
->paginate(20)
);
}

Но когда я позвонил это, я получаю ошибку нумерации страниц:

Неопределенное свойство: Illuminate \ Pagination \ LengthAwarePaginator :: $ id

И след представляет, что:

class: "Illuminate\Http\Resources\Json\JsonResource"file: "D:\~Resource\CompanyBehaviourResource.php"function: "__get"line: 17
type: "->"

Заявляя 'id' => $this->id, эта линия. Я просмотрел документацию Laravel Resource API Я не могу найти, где я делаю неправильно. Помоги мне с этим. Благодарю.

0

Решение

Ваш звонок возвращает красноречивую коллекцию вместо одного результата, таким образом, не удерживая $id имущество.
Вместо этого вы должны вызвать метод сбора:

public function index(Request $request)
{

return new CompanyBehaviourResource::collection(CompanyBehaviour::whereHas('companies', function ($q) use($request) {
$q->where('name', 'like', '%'.$request->search.'%');
})->orderBy('created_at', 'desc')
->paginate(20)
);
}
2

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]