addSelect(['book_slug' => function ($builder) { $builder->select('slug') ->from('books') ->whereColumn('books.id', '=', 'book_id'); }]); }); } /** * Scope a query to find items where the child has the given childSlug * where its parent has the bookSlug. */ public function scopeWhereSlugs(Builder $query, string $bookSlug, string $childSlug) { return $query->with('book') ->whereHas('book', function (Builder $query) use ($bookSlug) { $query->where('slug', '=', $bookSlug); }) ->where('slug', '=', $childSlug); } /** * Get the book this page sits in. */ public function book(): BelongsTo { return $this->belongsTo(Book::class)->withTrashed(); } /** * Change the book that this entity belongs to. */ public function changeBook(int $newBookId): Entity { $oldUrl = $this->getUrl(); $this->book_id = $newBookId; $this->refreshSlug(); $this->save(); $this->refresh(); if ($oldUrl !== $this->getUrl()) { app()->make(ReferenceUpdater::class)->updateEntityReferences($this, $oldUrl); } // Update all child pages if a chapter if ($this instanceof Chapter) { foreach ($this->pages()->withTrashed()->get() as $page) { $page->changeBook($newBookId); } } return $this; } }