fix: tree & guide

This commit is contained in:
2026-03-24 09:21:21 +08:00
parent b74ba1a3f8
commit 42a879e961
15 changed files with 2619 additions and 601 deletions

View File

@@ -33,14 +33,22 @@ class Guide extends Model
public function pages()
{
return $this->hasMany(GuidePage::class)->orderBy('sort_order');
return $this->hasMany(GuidePage::class);
}
public function trunkPages()
public function edges()
{
return $this->hasMany(GuidePage::class)
->where('parent_id', -1)
->orderBy('sort_order');
return $this->hasMany(GuidePageEdge::class);
}
public function entryPage()
{
return $this->hasOne(GuidePage::class)
->whereNotIn('guide_pages.id', function ($q) {
$q->select('to_page_id')
->from('guide_page_edges')
->whereColumn('guide_page_edges.guide_id', 'guide_pages.guide_id');
});
}
public function creator()
@@ -76,7 +84,7 @@ class Guide extends Model
return $query->where(function (Builder $q) use ($stationIds) {
$q->whereDoesntHave('stations')
->orWhereHas('stations', fn ($sq) => $sq->whereIn('stations.id', $stationIds));
->orWhereHas('stations', fn($sq) => $sq->whereIn('stations.id', $stationIds));
});
}