dikplhd/app/Http/Controllers/Opendata/DatasetController.php

184 lines
6.3 KiB
PHP

<?php
namespace App\Http\Controllers\Opendata;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use App\Models\Master\Instansi;
use App\Models\Master\Topik;
use App\Models\Dataset;
class DatasetController extends Controller
{
protected $title = 'Dataset';
protected $template = 'modules.opendata.dataset';
protected $route = 'modules.opendata.dataset';
/**
* Display a listing of the resource.
*/
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 grid(Request $request)
{
$data = Dataset::all();
// $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 .= '<div class="flex gap-3 justify-center items-center flex-row">';
$action .= '<a href="'.url('master/dataset/update/'.encode_id($row->DatasetId)).'" data-toggle="tooltip" title="Edit Data" class="btn btn-sm btn-block bg-primary"><i class="ri-pencil-line text-white"></i></a>';
if(session('group_id') == 1){
// $action .= '<a href="#" data-href="'.url('management/user/forcelogin/'.encode_id($row->id)).'" data-toggle="tooltip" title="Force Login" class="forcelogin btn btn-sm btn-block bg-success"><i class="ri-user-2-line text-white"></i></a>';
// $action .= '<a href="#" data-href="'.url('management/user/delete/'.encode_id($row->id)).'" data-toggle="tooltip" title="Hapus Data" class="remove_data btn btn-sm btn-block bg-danger"><i class="ri-delete-bin-line text-white"></i></a>';
}
$action .= '</div>';
}
$_data[] = [
'no' => $key+1,
'id' => encode_id($row->id),
'name' => @$row->name,
'publik' => @$row->publik,
'created_at' => date('d-m-Y H:i:s',strtotime(@$row->created_at)),
'instansi' => @$row->instansi->name,
'action' => @$action,
];
}
// 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)
{
Validator::make($request->all(), [
'name' => 'required',
'instansi_id' => 'required',
'template' => 'required',
'publik' => 'required',
'tags' => 'required',
'file' => 'required',
'topik' => 'required',
])->validate();
try {
$keyId = decode_id($request->secure_id);
if(@$keyId){
$insert = Dataset::find($keyId);
$insert->instansi_id = decode_id($request->instansi_id);
$insert->template = $request->template;
$insert->name = $request->name;
$insert->publik = $request->publik;
$insert->tags = json_encode($request->tags);
$insert->data = json_encode($request->data);
$insert->file = $request->file;
$insert->topik = json_encode($request->topik);
$insert->deskripsi = $request->deskripsi;
$insert->created_by = auth()->user()->id;
$insert->save();
}else{
$insert = new Dataset;
$insert->instansi_id = decode_id($request->instansi_id);
$insert->template = $request->template;
$insert->name = $request->name;
$insert->publik = $request->publik;
$insert->tags = json_encode($request->tags);
$insert->data = json_encode($request->data);
$insert->file = $request->file;
$insert->topik = json_encode($request->topik);
$insert->deskripsi = $request->deskripsi;
$insert->created_by = auth()->user()->id;
$insert->save();
}
return redirect()->back()->with([
'message' => 'Berhasil update data',
'type' => 'success',
]);
} 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'] = null;
$data['instansi'] = Instansi::all();
$data['topik'] = Topik::all();
return view($this->template.'.form',$data);
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
//
}
}