toArray(), array_flip($this->simpleAttributes)); $array['url'] = $this->getUrl(); return $array; } /** * Get the parent item */ public function parent(): Entity { return $this->chapter_id ? $this->chapter : $this->book; } /** * Get the chapter that this page is in, If applicable. * @return BelongsTo */ public function chapter() { return $this->belongsTo(Chapter::class); } /** * Check if this page has a chapter. * @return bool */ public function hasChapter() { return $this->chapter()->count() > 0; } /** * Get the associated page revisions, ordered by created date. * @return mixed */ public function revisions() { return $this->hasMany(PageRevision::class)->where('type', '=', 'version')->orderBy('created_at', 'desc')->orderBy('id', 'desc'); } /** * Get the attachments assigned to this page. * @return HasMany */ public function attachments() { return $this->hasMany(Attachment::class, 'uploaded_to')->orderBy('order', 'asc'); } /** * Get the url for this page. * @param string|bool $path * @return string */ public function getUrl($path = false) { $bookSlug = $this->getAttribute('bookSlug') ? $this->getAttribute('bookSlug') : $this->book->slug; $midText = $this->draft ? '/draft/' : '/page/'; $idComponent = $this->draft ? $this->id : urlencode($this->slug); $url = '/books/' . urlencode($bookSlug) . $midText . $idComponent; if ($path !== false) { $url .= '/' . trim($path, '/'); } return url($url); } /** * Get the current revision for the page if existing * @return PageRevision|null */ public function getCurrentRevision() { return $this->revisions()->first(); } }