BookStack/app/Repos/ChapterRepo.php

171 lines
4.5 KiB
PHP
Raw Normal View History

<?php namespace BookStack\Repos;
2015-07-28 03:17:08 +08:00
use Activity;
2015-07-28 03:17:08 +08:00
use Illuminate\Support\Str;
use BookStack\Chapter;
2015-07-28 03:17:08 +08:00
class ChapterRepo
{
protected $chapter;
/**
* ChapterRepo constructor.
* @param $chapter
*/
public function __construct(Chapter $chapter)
{
$this->chapter = $chapter;
}
/**
* Check if an id exists.
* @param $id
* @return bool
*/
public function idExists($id)
{
return $this->chapter->where('id', '=', $id)->count() > 0;
}
/**
* Get a chapter by a specific id.
* @param $id
* @return mixed
*/
2015-07-28 03:17:08 +08:00
public function getById($id)
{
return $this->chapter->findOrFail($id);
}
/**
* Get all chapters.
* @return \Illuminate\Database\Eloquent\Collection|static[]
*/
2015-07-28 03:17:08 +08:00
public function getAll()
{
return $this->chapter->all();
}
/**
* Get a chapter that has the given slug within the given book.
* @param $slug
* @param $bookId
* @return mixed
*/
2015-07-28 03:17:08 +08:00
public function getBySlug($slug, $bookId)
{
2015-12-29 01:19:23 +08:00
$chapter = $this->chapter->where('slug', '=', $slug)->where('book_id', '=', $bookId)->first();
if ($chapter === null) abort(404);
return $chapter;
2015-07-28 03:17:08 +08:00
}
/**
* Create a new chapter from request input.
* @param $input
* @return $this
*/
2015-07-28 03:17:08 +08:00
public function newFromInput($input)
{
return $this->chapter->fill($input);
}
/**
* Destroy a chapter and its relations by providing its slug.
* @param Chapter $chapter
*/
public function destroy(Chapter $chapter)
2015-07-28 03:17:08 +08:00
{
if (count($chapter->pages) > 0) {
foreach ($chapter->pages as $page) {
$page->chapter_id = 0;
$page->save();
}
}
Activity::removeEntity($chapter);
$chapter->views()->delete();
$chapter->delete();
2015-07-28 03:17:08 +08:00
}
/**
* Check if a chapter's slug exists.
* @param $slug
* @param $bookId
* @param bool|false $currentId
* @return bool
*/
2015-07-28 03:17:08 +08:00
public function doesSlugExist($slug, $bookId, $currentId = false)
{
$query = $this->chapter->where('slug', '=', $slug)->where('book_id', '=', $bookId);
2015-11-22 02:11:46 +08:00
if ($currentId) {
2015-07-28 03:17:08 +08:00
$query = $query->where('id', '!=', $currentId);
}
return $query->count() > 0;
}
/**
* Finds a suitable slug for the provided name.
* Checks database to prevent duplicate slugs.
* @param $name
* @param $bookId
* @param bool|false $currentId
* @return string
*/
public function findSuitableSlug($name, $bookId, $currentId = false)
2015-07-28 03:17:08 +08:00
{
$slug = Str::slug($name);
2015-11-22 02:11:46 +08:00
while ($this->doesSlugExist($slug, $bookId, $currentId)) {
2015-07-28 03:17:08 +08:00
$slug .= '-' . substr(md5(rand(1, 500)), 0, 3);
}
return $slug;
}
/**
* Get chapters by the given search term.
* @param $term
* @param array $whereTerms
* @param int $count
* @param array $paginationAppends
* @return mixed
*/
public function getBySearch($term, $whereTerms = [], $count = 20, $paginationAppends = [])
{
preg_match_all('/"(.*?)"/', $term, $matches);
if (count($matches[1]) > 0) {
$terms = $matches[1];
$term = trim(preg_replace('/"(.*?)"/', '', $term));
} else {
$terms = [];
}
$terms = array_merge($terms, explode(' ', $term));
$chapters = $this->chapter->fullTextSearchQuery(['name', 'description'], $terms, $whereTerms)
->paginate($count)->appends($paginationAppends);
$words = join('|', explode(' ', preg_quote(trim($term), '/')));
foreach ($chapters as $chapter) {
//highlight
$result = preg_replace('#' . $words . '#iu', "<span class=\"highlight\">\$0</span>", $chapter->getExcerpt(100));
$chapter->searchSnippet = $result;
}
return $chapters;
}
/**
2015-11-22 02:11:46 +08:00
* Changes the book relation of this chapter.
* @param $bookId
* @param Chapter $chapter
* @return Chapter
*/
2015-11-22 02:11:46 +08:00
public function changeBook($bookId, Chapter $chapter)
2015-09-06 21:35:53 +08:00
{
$chapter->book_id = $bookId;
2015-11-22 02:11:46 +08:00
foreach ($chapter->activity as $activity) {
2015-09-06 21:35:53 +08:00
$activity->book_id = $bookId;
$activity->save();
}
2015-11-22 02:11:46 +08:00
$chapter->slug = $this->findSuitableSlug($chapter->name, $bookId, $chapter->id);
2015-09-06 21:35:53 +08:00
$chapter->save();
return $chapter;
}
2015-07-28 03:17:08 +08:00
}