repository = $datasetRepository; } public function index() { permission('is_read', $this->route, 'module',true); $data['breadcrumbs'] = [ ['name' => 'Dashboard','url' => url('dashboard')], ['name' => 'Open Data'], ['name' => 'Dataset','active' => true], ]; $data['title'] = $this->title; $data['route'] = $this->route; return view($this->template.'.index',$data); } public function gridDetail(Request $request) { $id = $request->query('id'); $keyId = decode_id($id); $item = Dataset::find($keyId); // atau pakai ->pluck(), ->find(), dll $json = json_decode($item->data, true); $limit = $request->input('limit', 10); $offset = $request->input('offset', 0); $rows = array_slice($json, $offset, $limit); return response()->json([ 'total' => count($json), 'rows' => $rows ]); } public function grid(Request $request) { if(session('group_id') == 1){ $data = Dataset::with(['template'])->orderBy('DatasetId','DESC')->get(); }else{ $data = Dataset::with(['template'])->orderBy('DatasetId','DESC')->whereIn('instansi_id',[auth()->user()->ms_instansi_id])->get(); } // $data = User::with(['group'])->orderBy('id','DESC')->get(); $_data = []; foreach ($data as $key => $row) { $action = ''; if((permission('is_create', $this->route.'.*','module',false)) || (permission('is_update', $this->route.'.*','module',false))){ $action .= '
'; if($row->created_by == auth()->user()->id){ $action .= ''; } $action .= ''; if(session('group_id') == 1){ // $action .= ''; if($row->status == 1){ $action .= ''; }else{ $action .= ''; } } $action .= '
'; } $status = ''; if($row->status == 1){ $status = ''; }else{ $status = ''; } $_data[] = [ 'no' => $key+1, 'id' => encode_id($row->id), 'name' => @$row->name, 'publik' => @$row->publik, 'tahun' => @$row->tahun, 'template' => @$row->template->name, 'created_at' => date('d-m-Y H:i:s',strtotime(@$row->created_at)), 'instansi' => @$row->instansi->name, 'action' => @$action, 'status' => @$status, ]; } // return response()->json($_data); // Return the data as a JSON response return response()->json($_data); } /** * Show the form for creating a new resource. */ public function create() { // } /** * Store a newly created resource in storage. */ public function store(Request $request) { // dd(request()->all()); try { $keyId = decode_id($request->secure_id); if(@$keyId){ Validator::make($request->all(), [ 'name' => 'required', 'instansi_id' => 'required', 'template_id' => 'required', 'publik' => 'required', 'tags' => 'required', ])->validate(); }else{ // dd($request->all()); Validator::make($request->all(), [ 'name' => 'required', 'instansi_id' => 'required', 'template_id' => 'required', 'publik' => 'required', 'template_id' => 'required', ])->validate(); } $template = Template::find(decode_id($request->template_id)); $filename = pathinfo($template->template_url, PATHINFO_FILENAME); $modelClass = "App\\Models\\Dataset\\Dataset" . ucfirst($filename); $importClass = "App\\Imports\\Dataset". ucfirst($filename)."Import"; try { $insert = $this->repository->createDatasetTable($modelClass,$importClass,$request->file('file'),$request->all()); return redirect()->back()->with([ 'message' => 'Berhasil update data', 'type' => 'success', ]); } catch (\Exception $e) { return redirect()->back()->with([ 'message' => $e->getMessage(), 'type' => "error" ]); } } catch (Exception $e) { return redirect()->back()->with([ 'message' => $e->getMessage(), 'type' => "error" ]); } } /** * Display the specified resource. */ public function show(string $id) { // } /** * Show the form for editing the specified resource. */ public function edit(string $id) { // } /** * Update the specified resource in storage. */ public function update($id = null) { $data['breadcrumbs'] = [ ['name' => 'Dashboard','url' => url('dashboard')], ['name' => 'Open Data'], ['name' => 'Dataset','active' => true], ]; $keyId = decode_id($id); $data['title'] = $this->title; $data['route'] = $this->route; $data['keyId'] = $id; $data['item'] = Dataset::find($keyId); if(session('group_alias') == 'administrator'){ $data['instansi'] = Instansi::all(); }else{ $data['instansi'] = Instansi::where('MsInstansiId',session('instansi_id'))->get(); } $data['topik'] = Topik::all(); $data['template'] = Template::all(); return view($this->template.'.form',$data); } public function view($id = null) { $data['breadcrumbs'] = [ ['name' => 'Dashboard','url' => url('dashboard')], ['name' => 'Open Data'], ['name' => 'Dataset','active' => true], ]; $keyId = decode_id($id); $data['title'] = $this->title; $data['route'] = $this->route; $data['keyId'] = $id; $data['item'] = Dataset::find($keyId); $data['instansi'] = Instansi::all(); $data['topik'] = Topik::all(); $data['template'] = Template::all(); return view($this->template.'.view',$data); } /** * Remove the specified resource from storage. */ public function destroy(string $id) { // } public function delete($id) { $keyId = decode_id($id); $dataset = Dataset::find($keyId); $dataset->status = 0; $dataset->save(); return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']); } public function aktif($id) { $keyId = decode_id($id); $dataset = Dataset::find($keyId); $dataset->status = 1; $dataset->save(); return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']); } }