<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; use App\Models\Location; class FrontIndexController extends Controller { private $limit = 15; public function start() { $locations = Location::where("active", true)->get(); $count = count($locations); $recent = Location::where("active", true) ->limit(5)->orderByDesc('updated_at')->get(); //$result = DB::select("SELECT * FROM searchlocations('$terms')"); return view('front.index', [ 'count' => $count, 'recent' => $recent, 'title' => "The Bad Space" ]); } public function indexSearch(Request $request) { $terms = $request->index_search; $rawSearch = $terms; $terms = str_replace(",", "", $terms); $terms = str_replace(" ", "|", $terms); $results = DB::select("SELECT * FROM searchlocations('$terms')"); $locations = Location::where("active", true)->get(); $count = count($locations); $recent = Location::where("active", true) ->limit(5)->orderByDesc('updated_at')->get(); return view('front.index', [ 'count' => $count, 'recent' => $recent, 'title' => "The Bad Space", 'results' => $results ]); } public function about() { return view('front.about', [ 'title' => "ABOUT" ]); } public function location(string $uuid = "1") { $location = Location::where("uuid", $uuid)->first(); $name = "NO LOCATION FOUND"; if ($location) { $name = $location->name; } return view('front.location', [ 'title' => str_replace(".", " ", $name), 'location' => $location, 'images' => json_decode($location->images), 'updated' => $location->updated_at->format('Y M d'), ]); } public function listings(int $pageNum = 1) { $range = $pageNum * $this->limit - $this->limit; $active = Location::where("active", true)->where('block_count', '>', 2)->get(); $locations = Location::where("active", true)->where('block_count', '>', 2) ->limit($this->limit)->offset($range)->orderByDesc('id')->get(); $pageCount = ceil(count($active) / $this->limit); $next = $pageNum + 1; if ($next > $pageCount) { $next = 1; } $prev = $pageNum - 1; if ($prev <= 0) { $prev = $pageCount; } return view('front.listing', [ 'title' => "Listings", "totalPages" => $pageCount, "prev" => $prev, "next" => $next, 'pageNum' => $pageNum, 'locations' => $locations ]); } }