BookStack/app/Repos/BookRepo.php

127 lines
3.0 KiB
PHP
Raw Normal View History

<?php namespace BookStack\Repos;
2015-07-13 03:01:42 +08:00
use Illuminate\Support\Str;
use BookStack\Book;
2015-07-13 03:01:42 +08:00
class BookRepo
{
protected $book;
2015-07-13 04:31:15 +08:00
protected $pageRepo;
2015-07-13 03:01:42 +08:00
/**
* BookRepo constructor.
2015-11-10 03:46:04 +08:00
* @param Book $book
2015-07-13 04:31:15 +08:00
* @param PageRepo $pageRepo
2015-07-13 03:01:42 +08:00
*/
2015-07-13 04:31:15 +08:00
public function __construct(Book $book, PageRepo $pageRepo)
2015-07-13 03:01:42 +08:00
{
$this->book = $book;
2015-07-13 04:31:15 +08:00
$this->pageRepo = $pageRepo;
2015-07-13 03:01:42 +08:00
}
public function getById($id)
{
return $this->book->findOrFail($id);
}
public function getAll($count = 10)
2015-07-13 03:01:42 +08:00
{
return $this->book->orderBy('name', 'asc')->take($count)->get();
2015-07-13 03:01:42 +08:00
}
2015-11-10 03:46:04 +08:00
/**
* Getas
* @param int $count
* @return mixed
*/
public function getAllPaginated($count = 10)
{
return $this->book->orderBy('name', 'asc')->paginate($count);
}
2015-07-13 03:01:42 +08:00
public function getBySlug($slug)
{
return $this->book->where('slug', '=', $slug)->first();
}
2015-09-06 21:35:53 +08:00
/**
* Checks if a book exists.
* @param $id
* @return bool
*/
public function exists($id)
{
return $this->book->where('id', '=', $id)->exists();
}
/**
* Get a new book instance from request input.
* @param $input
* @return Book
*/
2015-07-13 03:01:42 +08:00
public function newFromInput($input)
{
return $this->book->fill($input);
}
public function countBySlug($slug)
{
return $this->book->where('slug', '=', $slug)->count();
}
public function destroyBySlug($bookSlug)
2015-07-13 03:01:42 +08:00
{
$book = $this->getBySlug($bookSlug);
2015-11-10 03:46:04 +08:00
foreach ($book->pages as $page) {
\Activity::removeEntity($page);
2015-07-31 06:18:48 +08:00
$page->delete();
}
2015-11-10 03:46:04 +08:00
foreach ($book->chapters as $chapter) {
\Activity::removeEntity($chapter);
2015-07-31 06:18:48 +08:00
$chapter->delete();
2015-07-13 04:31:15 +08:00
}
2015-07-13 03:01:42 +08:00
$book->delete();
}
public function getNewPriority($book)
2015-07-21 05:05:26 +08:00
{
$lastElem = $book->children()->pop();
return $lastElem ? $lastElem->priority + 1 : 0;
2015-07-21 05:05:26 +08:00
}
public function doesSlugExist($slug, $currentId = false)
{
$query = $this->book->where('slug', '=', $slug);
2015-11-10 03:46:04 +08:00
if ($currentId) {
$query = $query->where('id', '!=', $currentId);
}
return $query->count() > 0;
}
public function findSuitableSlug($name, $currentId = false)
{
2015-09-30 04:25:03 +08:00
$originalSlug = Str::slug($name);
$slug = $originalSlug;
$count = 2;
2015-11-10 03:46:04 +08:00
while ($this->doesSlugExist($slug, $currentId)) {
2015-09-30 04:25:03 +08:00
$slug = $originalSlug . '-' . $count;
$count++;
}
return $slug;
}
public function getBySearch($term)
{
$terms = explode(' ', preg_quote(trim($term)));
$books = $this->book->fullTextSearch(['name', 'description'], $terms);
$words = join('|', $terms);
foreach ($books as $book) {
//highlight
$result = preg_replace('#' . $words . '#iu', "<span class=\"highlight\">\$0</span>", $book->getExcerpt(100));
$book->searchSnippet = $result;
}
return $books;
}
2015-07-13 03:01:42 +08:00
}