X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/3acea12f1c0013be4f1e3994cae2ea662e43bb4e..refs/pull/2023/head:/app/Entities/Chapter.php diff --git a/app/Entities/Chapter.php b/app/Entities/Chapter.php index b204f1903..848bc6448 100644 --- a/app/Entities/Chapter.php +++ b/app/Entities/Chapter.php @@ -1,29 +1,18 @@ $pages + * @package BookStack\Entities + */ +class Chapter extends BookChild { public $searchFactor = 1.3; protected $fillable = ['name', 'description', 'priority', 'book_id']; - /** - * Get the morph class for this model. - * @return string - */ - public function getMorphClass() - { - return 'BookStack\\Chapter'; - } - - /** - * Get the book this chapter is within. - * @return \Illuminate\Database\Eloquent\Relations\BelongsTo - */ - public function book() - { - return $this->belongsTo(Book::class); - } - /** * Get the pages that this chapter contains. * @param string $dir @@ -63,20 +52,22 @@ class Chapter extends Entity } /** - * Return a generalised, common raw query that can be 'unioned' across entities. - * @return string + * Check if this chapter has any child pages. + * @return bool */ - public function entityRawQuery() + public function hasChildren() { - return "'BookStack\\\\Chapter' as entity_type, id, id as entity_id, slug, name, {$this->textField} as text, '' as html, book_id, priority, '0' as chapter_id, '0' as draft, created_by, updated_by, updated_at, created_at"; + return count($this->pages) > 0; } /** - * Check if this chapter has any child pages. - * @return bool + * Get the visible pages in this chapter. */ - public function hasChildren() + public function getVisiblePages(): Collection { - return count($this->pages) > 0; + return $this->pages()->visible() + ->orderBy('draft', 'desc') + ->orderBy('priority', 'asc') + ->get(); } }