take(1); $cartoon = Category::categoryLiveEvents(16,'exhibition') ->take(1); $musical = Category::categoryLiveEvents(8,'concert') ->take(1) ; $categories = $cinema->unionAll($cartoon)->unionAll($musical)->get(); $sliders = Slider::where('active',1) ->where(Config::get('app.locale'),1) ->get(); return $this->render("Pages.HomePage",[ 'categories' => $categories, 'sliders' => $sliders ]); Markdown::parse(); } public function showCategoryEvents($cat_id){ [$order, $data] = $this->sorts_filters(); $locale = Config::get('app.locale'); $category = Category::select('id',"title_{$locale}") ->with(['children'=>function($q) use($data,$locale){ $q->select('id','parent_id','events_limit','view_type',"title_{$locale}"); $q->withCount(['cat_events' => function ($query) use($data) { $query->onLive($data['start'], $data['end']); }]); $q->whereHas('cat_events', function ($query) use($data){ $query->onLive($data['start'], $data['end']); })->orderBy('cat_events_count','desc'); }])->findOrFail($cat_id); $data['category'] = $category; // get all live events belong to sub categories if($category->children->count()){ $sub_cat_last = $category->children->pop(); $sub_cats_events = $sub_cat_last->cat_events() ->onLive($data['start'],$data['end']) ->orderBy($order['field'],$order['order']) ->take($sub_cat_last->events_limit); foreach ($category->children as $sub_cat){ $events_query = $sub_cat->cat_events() ->onLive($data['start'],$data['end']) ->orderBy($order['field'],$order['order']) ->take($sub_cat->events_limit); $sub_cats_events = $sub_cats_events->unionAll($events_query); } $category->children->push($sub_cat_last); $data['events'] = $sub_cats_events->get(); } return $this->render("Pages.EventsPage",$data); } public function showSubCategoryEvents($cat_id){ $category = Category::select('id','title_tk','title_ru','view_type','events_limit','parent_id') ->findOrFail($cat_id); [$order, $data] = $this->sorts_filters(); $data['category'] = $category; $data['events'] = $category->cat_events() ->onLive($data['start'],$data['end']) ->orderBy($order['field'],$order['order']) ->paginate(16); return $this->render("Pages.CategoryEventsPage",$data); } private function sorts_filters(){ $data['start'] = \request()->get('start'); $data['end'] = \request()->get('end'); $sort = \request()->get('sort'); if($sort == 'new') $orderBy = ['field'=>'created_at','order'=>'desc']; if ($sort =='popular') { $orderBy = ['field' => 'views', 'order' => 'desc']; } else { $orderBy =['field'=>'start_date','order'=>'asc']; $sort = 'start_date'; } $data['sort'] = $sort; //todo check date formats; return [$orderBy, $data]; } public function search(SearchRequest $request){ //todo implement with elastick search and scout $query = sanitise($request->get('q')); $events = Event::onLive() ->with(['mainCategory','subCategory']) ->where('title_ru','like',"%{$query}%") ->orWhere('title_tk','like',"%{$query}%") ->withCount(['stats as views' => function($q){ $q->select(DB::raw("SUM(views) as v"));}]) ->paginate(10); return $this->render('Pages.SearchResults',[ 'events' => $events, 'query' => $query ]); } public function postAddEvent(AddEventRequest $request){ $addEvent = EventRequest::create([ 'name' => sanitise($request->get('name')), 'email' => sanitise($request->get('email')), 'phone' => sanitise($request->get('phone')), 'details' => sanitise($request->get('details')) ]); if($addEvent) return response()->json([ 'status' => 'success', 'message' => trans('ClientSide.add_event_success_message'), ]); else return response()->json([ 'status' => 'error', 'message' => trans('ClientSide.add_event_error_message'), ]); } public function subscribe(SubscribeRequest $request){ $email = sanitise($request->get('email')); //todo validate email $subscribe = Subscriber::updateOrCreate(['email'=>$email,'active'=>1]); if($subscribe) return response()->json([ 'status' => 'success', 'message' => trans('ClientSide.subscribe_success_message'), ]); else return response()->json([ 'status' => 'error', 'message' => trans('ClientSide.subscribe_error_message'), ]); } public function venues($id = false){ $data['venues'] = App\Models\Venue::select('id','venue_name_'.Config::get('app.locale'), 'description_'.Config::get('app.locale').' as description','address','images') ->where('active',1) ->orderBy('venue_name_'.Config::get('app.locale'),'ASC') ->get(); $data['current'] = $id ? $data['venues']->where('id',$id)->first() ?? $data['venues']->first(): $data['venues']->first(); return $this->render('Pages.VenuesPage',$data); } }