2019-09-20 07:18:28 +08:00
|
|
|
<?php namespace BookStack\Entities;
|
|
|
|
|
2019-10-05 19:55:01 +08:00
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
2019-09-20 07:18:28 +08:00
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class BookChild
|
|
|
|
* @property int $book_id
|
2019-10-05 19:55:01 +08:00
|
|
|
* @property int $priority
|
|
|
|
* @property Book $book
|
|
|
|
* @method Builder whereSlugs(string $bookSlug, string $childSlug)
|
2019-09-20 07:18:28 +08:00
|
|
|
*/
|
|
|
|
class BookChild extends Entity
|
|
|
|
{
|
|
|
|
|
2019-10-05 19:55:01 +08:00
|
|
|
/**
|
|
|
|
* Scope a query to find items where the 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);
|
|
|
|
}
|
|
|
|
|
2019-09-20 07:18:28 +08:00
|
|
|
/**
|
|
|
|
* Get the book this page sits in.
|
|
|
|
* @return BelongsTo
|
|
|
|
*/
|
|
|
|
public function book(): BelongsTo
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Book::class);
|
|
|
|
}
|
|
|
|
|
2019-10-05 19:55:01 +08:00
|
|
|
/**
|
|
|
|
* Change the book that this entity belongs to.
|
|
|
|
*/
|
|
|
|
public function changeBook(int $newBookId): Entity
|
|
|
|
{
|
|
|
|
$this->book_id = $newBookId;
|
|
|
|
$this->refreshSlug();
|
|
|
|
$this->save();
|
|
|
|
$this->refresh();
|
|
|
|
|
|
|
|
// Update related activity
|
|
|
|
$this->activity()->update(['book_id' => $newBookId]);
|
|
|
|
|
|
|
|
// Update all child pages if a chapter
|
|
|
|
if ($this instanceof Chapter) {
|
|
|
|
foreach ($this->pages as $page) {
|
|
|
|
$page->changeBook($newBookId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
}
|