1 <?php namespace BookStack\Services;
14 * ViewService constructor.
17 public function __construct(View $view)
20 $this->user = auth()->user();
24 * Add a view to the given entity.
25 * @param Entity $entity
28 public function add(Entity $entity)
30 if($this->user === null) return 0;
31 $view = $entity->views()->where('user_id', '=', $this->user->id)->first();
32 // Add view if model exists
34 $view->increment('views');
38 // Otherwise create new view count
39 $entity->views()->save($this->view->create([
40 'user_id' => $this->user->id,
49 * Get the entities with the most views.
52 * @param bool|false $filterModel
54 public function getPopular($count = 10, $page = 0, $filterModel = false)
56 $skipCount = $count * $page;
57 $query = $this->view->select('id', 'viewable_id', 'viewable_type', \DB::raw('SUM(views) as view_count'))
58 ->groupBy('viewable_id', 'viewable_type')
59 ->orderBy('view_count', 'desc');
61 if($filterModel) $query->where('viewable_type', '=', get_class($filterModel));
63 $views = $query->with('viewable')->skip($skipCount)->take($count)->get();
64 $viewedEntities = $views->map(function ($item) {
65 return $item->viewable()->getResults();
67 return $viewedEntities;
71 * Get all recently viewed entities for the current user.
74 * @param Entity|bool $filterModel
77 public function getUserRecentlyViewed($count = 10, $page = 0, $filterModel = false)
79 if($this->user === null) return collect();
80 $skipCount = $count * $page;
81 $query = $this->view->where('user_id', '=', auth()->user()->id);
83 if ($filterModel) $query->where('viewable_type', '=', get_class($filterModel));
85 $views = $query->with('viewable')->orderBy('updated_at', 'desc')->skip($skipCount)->take($count)->get();
86 $viewedEntities = $views->map(function ($item) {
87 return $item->viewable()->getResults();
89 return $viewedEntities;
94 * Reset all view counts by deleting all views.
96 public function resetAll()
98 $this->view->truncate();