BookStack/app/Repos/BookRepo.php

114 lines
2.7 KiB
PHP
Raw Normal View History

2015-07-12 15:01:42 -04:00
<?php namespace Oxbow\Repos;
use Illuminate\Support\Str;
2015-07-12 15:01:42 -04:00
use Oxbow\Book;
class BookRepo
{
protected $book;
2015-07-12 16:31:15 -04:00
protected $pageRepo;
2015-07-12 15:01:42 -04:00
/**
* BookRepo constructor.
2015-07-12 16:31:15 -04:00
* @param Book $book
* @param PageRepo $pageRepo
2015-07-12 15:01:42 -04:00
*/
2015-07-12 16:31:15 -04:00
public function __construct(Book $book, PageRepo $pageRepo)
2015-07-12 15:01:42 -04:00
{
$this->book = $book;
2015-07-12 16:31:15 -04:00
$this->pageRepo = $pageRepo;
2015-07-12 15:01:42 -04:00
}
public function getById($id)
{
return $this->book->findOrFail($id);
}
public function getAll()
{
return $this->book->all();
}
public function getBySlug($slug)
{
return $this->book->where('slug', '=', $slug)->first();
}
2015-09-06 09:35:53 -04: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-12 15:01:42 -04: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-12 15:01:42 -04:00
{
$book = $this->getBySlug($bookSlug);
2015-07-30 18:18:48 -04:00
foreach($book->pages as $page) {
\Activity::removeEntity($page);
2015-07-30 18:18:48 -04:00
$page->delete();
}
foreach($book->chapters as $chapter) {
\Activity::removeEntity($chapter);
2015-07-30 18:18:48 -04:00
$chapter->delete();
2015-07-12 16:31:15 -04:00
}
2015-07-12 15:01:42 -04:00
$book->delete();
}
public function getNewPriority($book)
2015-07-20 17:05:26 -04:00
{
$lastElem = $book->children()->pop();
return $lastElem ? $lastElem->priority + 1 : 0;
2015-07-20 17:05:26 -04:00
}
public function doesSlugExist($slug, $currentId = false)
{
$query = $this->book->where('slug', '=', $slug);
if($currentId) {
$query = $query->where('id', '!=', $currentId);
}
return $query->count() > 0;
}
public function findSuitableSlug($name, $currentId = false)
{
$slug = Str::slug($name);
while($this->doesSlugExist($slug, $currentId)) {
$slug .= '-' . substr(md5(rand(1, 500)), 0, 3);
}
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-12 15:01:42 -04:00
}