|
Server : Apache/2.4.41 (Ubuntu) System : Linux vmi1525618.contaboserver.net 5.4.0-105-generic #119-Ubuntu SMP Mon Mar 7 18:49:24 UTC 2022 x86_64 User : www-data ( 33) PHP Version : 8.2.12 Disable Function : NONE Directory : /var/www/lecturebazaar.com/app/Http/Controllers/Web/ |
Upload File : |
<?php
namespace App\Http\Controllers\Web;
use App\Http\Controllers\Controller;
use App\Models\Bundle;
use App\Models\Product;
use App\Models\Role;
use App\Models\Tag;
use App\Models\UpcomingCourse;
use App\Models\Webinar;
use App\User;
use Illuminate\Http\Request;
class TagsController extends Controller
{
public function index(Request $request, $type, $tag)
{
$tag = urldecode($tag);
$seoSettings = getSeoMetas('tags');
$pageTitle = !empty($seoSettings['title']) ? $seoSettings['title'] : trans('update.tags_page_title');
$pageDescription = !empty($seoSettings['description']) ? $seoSettings['description'] : trans('update.tags_page_title');
$pageRobot = getPageRobot('tags');
$data = [
'pageTitle' => $pageTitle,
'pageDescription' => $pageDescription,
'pageRobot' => $pageRobot,
'tag' => $tag,
];
if ($type == "courses") {
$data['webinars'] = $this->getCoursesByTag($tag);
} else if ($type == "bundles") {
$data['bundles'] = $this->getBundlesByTag($tag);
} else if ($type == "upcoming-courses") {
$data['upcomingCourses'] = $this->getUpcomingCourseByTag($tag);
}
return view('web.default.pages.tags', $data);
}
private function getCoursesByTag($tag)
{
$ids = Tag::query()->where('title', 'like', "%{$tag}%")
->whereNotNull('webinar_id')
->pluck('webinar_id')
->toArray();
return Webinar::query()->whereIn('id', $ids)
->where('status', 'active')
->where('private', false)
->with([
'teacher' => function ($query) {
$query->select('id', 'full_name', 'avatar', 'avatar_settings');
},
'reviews'
])
->get();
}
private function getBundlesByTag($tag)
{
$ids = Tag::query()->where('title', 'like', "%{$tag}%")
->whereNotNull('bundle_id')
->pluck('bundle_id')
->toArray();
return Bundle::query()->whereIn('id', $ids)
->where('status', 'active')
->with([
'teacher' => function ($query) {
$query->select('id', 'full_name', 'avatar', 'avatar_settings');
},
'reviews'
])
->get();
}
private function getUpcomingCourseByTag($tag)
{
$ids = Tag::query()->where('title', 'like', "%{$tag}%")
->whereNotNull('upcoming_course_id')
->pluck('upcoming_course_id')
->toArray();
return UpcomingCourse::query()->whereIn('id', $ids)
->where('status', 'active')
->with([
'teacher' => function ($query) {
$query->select('id', 'full_name', 'avatar', 'avatar_settings');
}
])
->get();
}
}