Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
63.64% |
7 / 11 |
CRAP | |
90.14% |
64 / 71 |
| PageController | |
0.00% |
0 / 1 |
|
63.64% |
7 / 11 |
23.51 | |
90.14% |
64 / 71 |
| index | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
| grid | |
0.00% |
0 / 1 |
6.68 | |
73.33% |
11 / 15 |
|||
| create | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
| store | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
| edit | |
100.00% |
1 / 1 |
2 | |
100.00% |
9 / 9 |
|||
| update | |
100.00% |
1 / 1 |
1 | |
100.00% |
4 / 4 |
|||
| saveData | |
100.00% |
1 / 1 |
2 | |
100.00% |
12 / 12 |
|||
| destroy | |
0.00% |
0 / 1 |
3.03 | |
85.71% |
6 / 7 |
|||
| destroyAll | |
100.00% |
1 / 1 |
2 | |
100.00% |
5 / 5 |
|||
| restore | |
0.00% |
0 / 1 |
2.03 | |
80.00% |
4 / 5 |
|||
| restoreAll | |
0.00% |
0 / 1 |
2.03 | |
80.00% |
4 / 5 |
|||
| <?php | |
| namespace App\Http\Controllers\Admin; | |
| use App\Page; | |
| use Exception; | |
| use App\Language; | |
| use App\PageDescription; | |
| use Illuminate\View\View; | |
| use Illuminate\Http\Request; | |
| use Illuminate\Http\JsonResponse; | |
| use App\Http\Requests\PageRequest; | |
| use Illuminate\Routing\Redirector; | |
| use App\Http\Controllers\Controller; | |
| use Illuminate\Http\RedirectResponse; | |
| use Mcamara\LaravelLocalization\Facades\LaravelLocalization; | |
| class PageController extends Controller | |
| { | |
| /** Redirect to this path after each operation success*/ | |
| private $redirectSuccessPath = '/admin/pages'; | |
| /** View folder */ | |
| private $viewDirectory = 'admin.pages.'; | |
| /** | |
| * Display a listing of the resource. | |
| * @param Request $request | |
| * @return View | |
| */ | |
| public function index(Request $request) :View | |
| { | |
| $title= __('pages.head'); | |
| $request= $request->toArray(); | |
| return view($this->viewDirectory.'index',compact('title')); | |
| } | |
| /** | |
| * return data of the pages. | |
| * | |
| * @param Request $request | |
| * @return View | |
| */ | |
| public function grid(Request $request) :View | |
| { | |
| $query = Page::latest() | |
| ->join('page_descriptions AS pd', 'pages.id', 'pd.page_id') | |
| ->join('languages', 'languages.id', 'pd.language_id') | |
| ->where('local', LaravelLocalization::getCurrentLocale()) | |
| ->select(['pd.title', 'pages.*']); | |
| if ($request->date_from) { | |
| $query->whereDate('pages.created_at', '>=', $request->date_from); | |
| } | |
| if ($request->date_to) { | |
| $query->whereDate('pages.created_at', '<=', $request->date_to); | |
| } | |
| if ($request->name) { | |
| $query->where('pd.title', 'LIKE', '%'.$request->name.'%'); | |
| } | |
| if ( !is_null($request->status) && $request->status == 0) { | |
| $query->onlyTrashed(); | |
| } | |
| $pages= $query->paginate(100); | |
| return view($this->viewDirectory.'grid',compact('pages')); | |
| } | |
| /** | |
| * Show the form for creating a new resource. | |
| * | |
| * @return View | |
| */ | |
| public function create() :View | |
| { | |
| $action= route('pages.store'); | |
| $head = metaFields('pages', 'add_new', getCurrentLocale()) ?? __('pages.new'); | |
| return view( $this->viewDirectory.'form', compact('action', 'head') ); | |
| } | |
| /** | |
| * Store a newly created resource in storage. | |
| * | |
| * @param PageRequest $request | |
| * @return RedirectResponse|Redirector | |
| */ | |
| public function store(PageRequest $request) :RedirectResponse | |
| { | |
| $page = Page::create($request->all()); | |
| // Insert Description | |
| $this->saveData( $request, $page->id ); | |
| return redirect($this->redirectSuccessPath)->with('message', __('dashboard.saveDone')); | |
| } | |
| /** | |
| * Show the form for editing the specified resource. | |
| * | |
| * @param Page $page | |
| * @return View | |
| */ | |
| public function edit(Page $page) :View | |
| { | |
| $action= route('pages.update', $page->id); | |
| $head = metaFields('pages', 'edit', getCurrentLocale()) ?? __('pages.edit'); | |
| $query = PageDescription::where('page_id', $page->id) | |
| ->join('languages', 'languages.id', 'page_descriptions.language_id') | |
| ->select(['page_descriptions.*', 'languages.local']); | |
| $pageDescription= $query->get(); | |
| foreach ($pageDescription as $row) { | |
| $page[$row->local]= $row; | |
| } | |
| return view( $this->viewDirectory.'form', compact('page', 'action', 'head') ); | |
| } | |
| /** | |
| * Update the specified resource in storage. | |
| * | |
| * @param PageRequest $request | |
| * @param Page $page | |
| * @return RedirectResponse|Redirector | |
| */ | |
| public function update(PageRequest $request, Page $page) :RedirectResponse | |
| { | |
| // Update image if request has it | |
| $page->update(['image' => $request->image??null]); | |
| // Delete old description | |
| PageDescription::where('page_id', $page->id)->delete(); | |
| // Insert new description | |
| $this->saveData( $request, $page->id ); | |
| return redirect($this->redirectSuccessPath)->with('message', __('dashboard.saveDone')); | |
| } | |
| /** | |
| * Handle Save form data | |
| * | |
| * @param PageRequest $request | |
| * @param int $page_id | |
| * @return void | |
| */ | |
| private function saveData(PageRequest $request, int $page_id ):void | |
| { | |
| $requestData= $request->all(); | |
| $languages= Language::where('status', 1)->cursor(); | |
| foreach ($languages as $lang) { | |
| $data=[ | |
| 'page_id'=> $page_id, | |
| 'language_id'=> $lang->id, | |
| 'title'=> $requestData['title_'.$lang->local], | |
| 'slug'=> $requestData['slug_'.$lang->local], | |
| 'keywords'=> $requestData['keywords_'.$lang->local], | |
| 'meta_description'=> $requestData['meta_description_'.$lang->local], | |
| 'description'=> $requestData['description_'.$lang->local], | |
| ]; | |
| PageDescription::create($data); | |
| } | |
| } | |
| /** | |
| * Remove the specified resource from storage. | |
| * | |
| * @param Request $request | |
| * @param int $id | |
| * @return JsonResponse | |
| * @throws Exception | |
| */ | |
| public function destroy(Request $request, int $id) :JsonResponse | |
| { | |
| $page = Page::withTrashed()->find($id); | |
| if ($page) { | |
| if ($page->deleted_at) { | |
| $page->forceDelete(); | |
| } else { | |
| $page->delete(); | |
| } | |
| return response()->json(['message'=> __('dashboard.deletedDone')]); | |
| } else{ | |
| return response()->json(['message'=> __('dashboard.noResult')], 400); | |
| } | |
| } | |
| /** | |
| * Remove several pages by IDs. | |
| * | |
| * @param Request $request | |
| * @return JsonResponse | |
| */ | |
| public function destroyAll(Request $request) :JsonResponse | |
| { | |
| $ids= $request->ids; | |
| if ($request->force) { | |
| Page::onlyTrashed()->whereIn('id', $ids)->forceDelete(); | |
| } else { | |
| Page::whereIn('id', $ids)->delete(); | |
| } | |
| return response()->json(['message'=> __('dashboard.deletedDone')]); | |
| } | |
| /** | |
| * Restore the specified category from storage | |
| * | |
| * @param Request $request | |
| * @param int $id | |
| * @return JsonResponse | |
| */ | |
| public function restore(Request $request, int $id) :JsonResponse | |
| { | |
| $page = Page::withTrashed()->find($id); | |
| if ($page){ | |
| $page->restore(); | |
| return response()->json(['message'=> __('dashboard.saveDone')]); | |
| } | |
| return response()->json(['message'=> __('dashboard.noResult')], 400); | |
| } | |
| /** | |
| * Restore several pages by IDs. | |
| * | |
| * @param Request $request | |
| * @return JsonResponse | |
| */ | |
| public function restoreAll(Request $request) :JsonResponse | |
| { | |
| $pages = Page::whereIn('id', $request->ids)->onlyTrashed(); | |
| if ($pages){ | |
| $pages->restore(); | |
| return response()->json(['message'=> __('dashboard.saveDone')]); | |
| } | |
| } | |
| } |