/**
* BookRepo constructor.
- * @param Book $book
+ * @param Book $book
* @param PageRepo $pageRepo
*/
public function __construct(Book $book, PageRepo $pageRepo)
return $this->book->findOrFail($id);
}
- public function getAll()
+ public function getAll($count = 10)
{
- return $this->book->all();
+ return $this->book->orderBy('name', 'asc')->take($count)->get();
+ }
+
+ /**
+ * Getas
+ * @param int $count
+ * @return mixed
+ */
+ public function getAllPaginated($count = 10)
+ {
+ return $this->book->orderBy('name', 'asc')->paginate($count);
}
public function getBySlug($slug)
public function destroyBySlug($bookSlug)
{
$book = $this->getBySlug($bookSlug);
- foreach($book->pages as $page) {
+ foreach ($book->pages as $page) {
\Activity::removeEntity($page);
$page->delete();
}
- foreach($book->chapters as $chapter) {
+ foreach ($book->chapters as $chapter) {
\Activity::removeEntity($chapter);
$chapter->delete();
}
public function doesSlugExist($slug, $currentId = false)
{
$query = $this->book->where('slug', '=', $slug);
- if($currentId) {
+ if ($currentId) {
$query = $query->where('id', '!=', $currentId);
}
return $query->count() > 0;
$originalSlug = Str::slug($name);
$slug = $originalSlug;
$count = 2;
- while($this->doesSlugExist($slug, $currentId)) {
+ while ($this->doesSlugExist($slug, $currentId)) {
$slug = $originalSlug . '-' . $count;
$count++;
}