Я делаю модель, которая имеет рекурсивную структуру, как показано ниже. Концептуальная модель может иметь родительские и дочерние концепции, и модель работает, как и ожидалось. Моя проблема с реализацией страницы для добавления ссылок между двумя понятиями.
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class Concept extends Model
{
//
public function parentConcepts()
{
return $this->belongsToMany('App\Models\Concept','concept_concept','parent_concept_id','child_concept_id');
}
public function childConcepts()
{
return $this->belongsToMany('App\Models\Concept','concept_concept','child_concept_id','parent_concept_id');
}
public function processes()
{
return $this->hasMany('App\Models\Process');
}
}
Как бы я поступил так, точно? Буду ли я использовать атрибут pivot в модели или я создам новую модель и контроллер для таблицы concept_concept? любая помощь будет очень ценится!
Создание новой функции в контроллере, которая использует функцию attach (), является ключом к этому решению.
public function storeChildLink(Request $request)
{
//get the parent concept id
$concept = Concept::find($request->input('parentConceptId'));
//attach the child concept
$concept->childConcepts()->attach($request->input('childConceptId'));
$concept->save();
return redirect()->route('concept.show', ['id' => $request['parentConceptId']])->with('status', 'Child Concept Successfully Linked');
}
public function storeParentLink(Request $request)
{
//get the child concept id
$concept = Concept::find($request->input('childConceptId'));
//attach the parent concept
$concept->parentConcepts()->attach($request->input('parentConceptId'));
$concept->save();
return redirect()->route('concept.show', ['id' => $request['childConceptId']])->with('status', 'Parent Concept Successfully Linked');
}
Других решений пока нет …