Server IP : 66.29.132.124 / Your IP : 18.191.174.4 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/modules/Page/Admin/ |
Upload File : |
<?php namespace Modules\Page\Admin; use function Couchbase\defaultDecoder; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use Modules\AdminController; use Modules\Page\Models\Page; use Modules\Page\Models\PageTranslation; use Modules\Template\Models\Template; class PageController extends AdminController { public function __construct() { $this->setActiveMenu(route('page.admin.index')); parent::__construct(); } public function index(Request $request) { $this->checkPermission('page_view'); $page_name = $request->query('page_name'); $datapage = new Page(); if ($page_name) { $datapage = Page::where('title', 'LIKE', '%' . $page_name . '%'); } $datapage = $datapage->orderBy('title', 'asc'); $data = [ 'rows' => $datapage->paginate(20), 'page_title'=>__("Page Management"), 'breadcrumbs' => [ [ 'name' => __('Pages'), 'url' => route('page.admin.index') ], [ 'name' => __('All'), 'class' => 'active' ], ] ]; return view('Page::admin.index', $data); } public function create(Request $request) { $this->checkPermission('page_create'); $row = new Page(); $row->fill([ 'status' => 'publish', ]); $data = [ 'row' => $row, 'translation'=>new PageTranslation(), 'templates' => Template::orderBy('id', 'desc')->limit(100)->get(), 'breadcrumbs' => [ [ 'name' => __('Pages'), 'url' => route('page.admin.index') ], [ 'name' => __('Add Page'), 'class' => 'active' ], ] ]; return view('Page::admin.detail', $data); } public function edit(Request $request, $id) { $this->checkPermission('page_update'); $row = Page::find($id); if (empty($row)) { return redirect(route('page.admin.index')); } $translation = $row->translateOrOrigin($request->query('lang')); $data = [ 'translation' => $translation, 'row' =>$row, 'templates' => Template::orderBy('id', 'desc')->limit(100)->get(), 'breadcrumbs' => [ [ 'name' => __('Pages'), 'url' => route('page.admin.index') ], [ 'name' => __('Edit Page'), 'class' => 'active' ], ], 'enable_multi_lang'=>true ]; return view('Page::admin.detail', $data); } public function store(Request $request, $id){ if(is_demo_mode()){ return redirect()->back('danger',__("DEMO MODE: Disable update")); } if($id>0){ $this->checkPermission('page_update'); $row = Page::find($id); if (empty($row)) { return redirect(route('page.admin.index')); } }else{ $this->checkPermission('page_create'); $row = new Page(); } $row->fill($request->input()); if($request->input('slug')){ $row->slug = $request->input('slug'); } $row->saveOriginOrTranslation($request->query('lang'),true); if($id > 0 ){ return back()->with('success', __('Page updated') ); }else{ return redirect()->route('page.admin.edit',['id'=>$row->id])->with('success', $id > 0 ? __('Page updated') : __('Page created')); } } public function getForSelect2(Request $request) { $q = $request->query('q'); $query = Page::select('id', 'title as text'); if ($q) { $query->where('title', 'like', '%' . $q . '%'); } $res = $query->orderBy('id', 'desc')->limit(20)->get(); return response()->json([ 'results' => $res ]); } public function bulkEdit(Request $request) { if(is_demo_mode()){ return redirect()->back('danger',__("DEMO MODE: Disable update")); } $ids = $request->input('ids'); $action = $request->input('action'); if (empty($ids)) { return redirect()->back()->with('error', __('Please select at least 1 item!')); } if (empty($action)) { return redirect()->back()->with('error', __('No Action is selected!')); } if ($action == "delete") { foreach ($ids as $id) { $query = Page::where("id", $id); if (!$this->hasPermission('page_manage_others')) { $query->where("create_user", Auth::id()); $this->checkPermission('page_delete'); } $query->first(); if(!empty($query)){ $query->delete(); } } } else { foreach ($ids as $id) { $query = Page::where("id", $id); if (!$this->hasPermission('page_manage_others')) { $query->where("create_user", Auth::id()); $this->checkPermission('page_update'); } $query->update(['status' => $action]); } } return redirect()->back()->with('success', __('Update success!')); } }