assignPermissionsToController(); } /** * Generate a pagination collection. * * @param array|Collection $items * @param int $perPage * @param int $page * @param array $options * * @return LengthAwarePaginator */ public function paginate($items, $perPage = 15, $page = null, $options = []) { $perPage = $perPage ?: request('limit', setting('default.list_limit', '25')); $page = $page ?: (Paginator::resolveCurrentPage() ?: 1); $items = $items instanceof Collection ? $items : Collection::make($items); return new LengthAwarePaginator($items->forPage($page, $perPage), $items->count(), $perPage, $page, $options); } /** * Generate a response based on request type like HTML, JSON, or anything else. * * @param string $view * @param array $data * * @return \Illuminate\Http\Response */ public function response($view, $data = []) { $class_name = str_replace('Controllers', 'Responses', get_class($this)); if (class_exists($class_name)) { $response = new $class_name($view, $data); } else { $response = new class($view, $data) extends Response {}; } return $response; } /** * Import the excel file or catch errors * * @param $class * @param $request * @param $url * * @return mixed */ public function importExcel($class, $request, $url) { try { Excel::import($class, $request->file('import')); } catch (SheetNotFoundException | ErrorException | Exception | Throwable $e) { flash($e->getMessage())->error()->important(); return redirect()->route('import.create', explode('/', $url)); } return true; } /** * Export the excel file or catch errors * * @param $class * @param $file_name * * @return mixed */ public function exportExcel($class, $file_name, $extension = 'xlsx') { try { return Excel::download($class, Str::filename($file_name) . '.' . $extension); } catch (ErrorException | Exception | Throwable $e) { flash($e->getMessage())->error()->important(); return back(); } } }