123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- <?php
- namespace App\Http\Controllers;
- use Illuminate\Http\Request;
- use App\Services\LiquidRenderer;
- use App\Models\DistProduct;
- use App\Models\DistProductCategory;
- use App\Models\SitePage;
- class ProductController extends Controller
- {
- protected $liquidRenderer;
- public function __construct(LiquidRenderer $liquidRenderer)
- {
- $this->liquidRenderer = $liquidRenderer;
- }
-
- public function category($slug)
- {
-
-
-
- $category = DistProductCategory::where(function ($query) use ($slug) {
- $query->where('slug', $slug)
- ->orWhere('id', $slug);
- })
- ->where('dist_id', getDistId())
- ->firstOrFail();
- if (!$category) {
- abort('404');
- }
- $categoryIds = [$category->id];
- if ($category) {
-
- $subCategories = DistProductCategory::where('parent_id', $category->id)->get();
- foreach ($subCategories as $subCategory) {
- $categoryIds[] = $subCategory->id;
- }
- }
-
- $products = DistProduct::whereIn('category_id', $categoryIds)
- ->where('dist_id', getDistId())
- ->where('enabled', 1)
- ->where('status', 2)
- ->with('images')
- ->orderBy('order', 'desc')
- ->orderBy('id', 'desc')
- ->paginate(12);
-
- $paginator = [
- 'previous_page' => $products->previousPageUrl() ? true : false,
- 'previous_page_url' => $products->previousPageUrl(),
- 'next_page' => $products->nextPageUrl() ? true : false,
- 'next_page_url' => $products->nextPageUrl(),
- 'current_page' => $products->currentPage(),
- 'total_pages' => $products->lastPage(),
- 'pages' => range(1, $products->lastPage()),
- 'page_url' => array_combine(
- range(1, $products->lastPage()),
- array_map(fn($page) => $products->url($page), range(1, $products->lastPage()))
- ),
- ];
-
- $breadcrumbs = [
- [
- 'url' => '/',
- 'name' => 'Home',
- ]
- ];
- $breadcrumbs[] = [
- 'url' => '#',
- 'name' => $category->name,
- ];
-
- $cacheKey = "product_category_{$category->id}_page_{$products->currentPage()}";
-
- return $this->liquidRenderer->render('products_categories.liquid', [
- 'category' => $category,
- 'products' => $products,
- 'paginator' => $paginator,
- 'breadcrumbs' => $breadcrumbs,
- ], $cacheKey);
- }
-
- public function detail($id)
- {
- $product = DistProduct::getProduct($id);
- if(!$product)
- {
- $product = DistProduct::getProductSlug($id);
- if(!$product)
- {
- abort('404');
- }
- }
-
- $relatedProducts = DistProduct::where('category_id', $product->category_id)
- ->where('dist_id', getDistId())
- ->where('enabled', 1)
- ->where('status', 2)
- ->where('id', '<>', $product->id)
- ->with('images')
- ->orderBy('order', 'desc')
- ->orderBy('id', 'desc')
- ->limit(4)
- ->get();
-
- $category=$product->distProductCategory;
- $categoryUrl = $category->slug ? "/products/categories/{$category->slug}" : "/products/categories/{$category->id}";
- $breadcrumbs = [
- [
- 'url' => '/',
- 'name' => 'Home',
- ]
- ];
- $breadcrumbs[] = [
- 'url' => $categoryUrl,
- 'name' => $category->name,
- ];
- $breadcrumbs[] = [
- 'url' => '#',
- 'name' => $product->title,
- ];
-
- $seo_keywords = $product->seo_keywords;
- if($seo_keywords) {
- $seo_keywords_array = explode(',', $seo_keywords);
- }
- else {
- $seo_keywords_array = [];
- }
- $relatedPages= [];
- if(!empty($seo_keywords_array))
- {
- $seo_keywords_array = array_map('trim', $seo_keywords_array);
- $seo_keywords_array = array_unique($seo_keywords_array);
-
- $query = SitePage::where('dist_id', getDistId())
- ->where('status', 1);
-
- $query->where(function($q) use ($seo_keywords_array) {
- foreach ($seo_keywords_array as $keyword) {
- $q->orWhere(function($subQ) use ($keyword) {
- $subQ->where('seo_keywords', 'LIKE', $keyword)
- ->orWhere('seo_keywords', 'LIKE', $keyword . ',%')
- ->orWhere('seo_keywords', 'LIKE', '%,' . $keyword)
- ->orWhere('seo_keywords', 'LIKE', '%,' . $keyword . ',%');
- });
- }
- });
-
- $relatedPages = $query->orderBy('id', 'desc')
- ->limit(10)
- ->get();
- }
-
- return $this->liquidRenderer->render('products_detail.liquid',
- [
- 'product' => $product,
- 'relatedProducts' => $relatedProducts,
- 'breadcrumbs' => $breadcrumbs,
- 'relatedPages' => $relatedPages,
- ]);
- }
- }
|