update
parent
7977aafeb7
commit
056cb9da05
|
|
@ -4,15 +4,77 @@ namespace App\Http\Controllers\Pengaturan;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\File;
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use App\Models\FilePengumuman;
|
||||||
|
|
||||||
class PengumumanController extends Controller
|
class PengumumanController extends Controller
|
||||||
{
|
{
|
||||||
|
protected $title = 'Pengumuman/Peraturan';
|
||||||
|
protected $template = 'modules.pengaturan.pengumuman';
|
||||||
|
protected $route = 'modules.pengaturan.pengumuman';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display a listing of the resource.
|
* Display a listing of the resource.
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
//
|
permission('is_read', $this->route, 'module',true);
|
||||||
|
|
||||||
|
$data['breadcrumbs'] = [
|
||||||
|
['name' => 'Dashboard'],
|
||||||
|
['name' => 'Pengaturan'],
|
||||||
|
['name' => 'Pengumuman/Peraturan','active' => true],
|
||||||
|
];
|
||||||
|
$data['title'] = $this->title;
|
||||||
|
$data['route'] = $this->route;
|
||||||
|
|
||||||
|
return view($this->template.'.index',$data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function grid(Request $request)
|
||||||
|
{
|
||||||
|
|
||||||
|
$data = FilePengumuman::all();
|
||||||
|
$_data = [];
|
||||||
|
|
||||||
|
|
||||||
|
foreach ($data as $key => $row) {
|
||||||
|
|
||||||
|
|
||||||
|
$action = '';
|
||||||
|
$status = '';
|
||||||
|
if($row->status == 0){
|
||||||
|
$status = '<span class="btn btn-sm btn-block btn-danger"> Tidak Aktif </span>';
|
||||||
|
}else{
|
||||||
|
$status = '<span class="btn btn-sm btn-block btn-success"> Aktif </span>';
|
||||||
|
}
|
||||||
|
$file = '<a download href="'.asset($row->file).'" class="btn btn-sm w-100 btn-success"><i class="mdi mdi-download text-white"></i></a>';
|
||||||
|
$action .= '<div class="d-flex gap-1">';
|
||||||
|
if((permission('is_create', $this->route.'.*','module',false)) || (permission('is_update', $this->route.'.*','module',false))){
|
||||||
|
$action .= '<a data-id="'.encode_id($row->FilePengumumanId).'" href="'.url('pengaturan/pengumuman/update/'.encode_id($row->FilePengumumanId)).'" data-toggle="tooltip" title="Edit Data" class="btn btn-sm btn-block btn-primary"><i class="mdi mdi-pencil text-white"></i></a>';
|
||||||
|
if(session('group_id') == 1){
|
||||||
|
$action .= '<a href="#" data-href="'.url('pengaturan/pengumuman/delete/'.encode_id($row->FilePengumumanId)).'" data-toggle="tooltip" title="Edit Data" class="remove_data btn btn-sm btn-block btn-danger"><i class="mdi mdi-delete text-white"></i></a>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$action .= '</div>';
|
||||||
|
|
||||||
|
$_data[] = [
|
||||||
|
'no' => $key+1,
|
||||||
|
'id' => encode_id($row->FilePengumumanId),
|
||||||
|
'tahun' => @$row->tahun,
|
||||||
|
'nama' => @$row->nama,
|
||||||
|
'file' => @$file,
|
||||||
|
'created_at' => date('d-m-Y H:i:s',strtotime(@$row->created_at)),
|
||||||
|
'status' => @$status,
|
||||||
|
'action' => @$action,
|
||||||
|
];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// return response()->json($_data); // Return the data as a JSON response
|
||||||
|
return response()->json($_data);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -28,7 +90,69 @@ class PengumumanController extends Controller
|
||||||
*/
|
*/
|
||||||
public function store(Request $request)
|
public function store(Request $request)
|
||||||
{
|
{
|
||||||
//
|
// dd(request()->all());
|
||||||
|
$request->validate([
|
||||||
|
'tahun' => 'required',
|
||||||
|
'nama' => 'required',
|
||||||
|
'file' => 'required|file|mimes:xls,xlsx,pdf,png,jpg,jpeg,docx|max:2000',
|
||||||
|
]);
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
if (@$request->file) {
|
||||||
|
$file = $request->file;
|
||||||
|
$destinationPath = public_path('uploads/pengumuman');
|
||||||
|
$current = Carbon::now()->format('Y/m/d');
|
||||||
|
$path = $destinationPath . '/' . $current;
|
||||||
|
$fileName = $file->getClientOriginalName();
|
||||||
|
$fileMime = $file->getClientMimeType();
|
||||||
|
$fileExtension = $file->getClientOriginalExtension();
|
||||||
|
$fileSize = $file->getSize();
|
||||||
|
if(($fileExtension != 'xls') && ($fileExtension != 'xlsx') && ($fileExtension != 'pdf') && ($fileExtension != 'docx') && ($fileExtension != 'png') && ($fileExtension != 'jpg') && ($fileExtension != 'jpeg') ){
|
||||||
|
return redirect()->back()->with([
|
||||||
|
'message' => 'Maaf File Harus Berupa xls,xlsx,pdf,png,jpg,jpeg,docx!',
|
||||||
|
'type' => "error"
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
$newFilename = session('id').'_'.uniqid('file_') . '.' . $fileExtension;
|
||||||
|
|
||||||
|
if (!File::exists($path)) {
|
||||||
|
File::isDirectory($path) or File::makeDirectory($path, 0777, true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
$filePath = 'pengumuman/' . $current . '/' . $newFilename;
|
||||||
|
$uploaded = $file->move($path, $newFilename);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(@request()->secure_id){
|
||||||
|
$keyId = decode_id(@request()->secure_id);
|
||||||
|
$data = FilePengumuman::find($keyId);
|
||||||
|
$data->tahun = $request->tahun;
|
||||||
|
$data->nama = $request->nama;
|
||||||
|
$data->file = $filePath;
|
||||||
|
$data->deskripsi = $request->deskripsi;
|
||||||
|
$data->save();
|
||||||
|
}else{
|
||||||
|
$data = new FilePengumuman;
|
||||||
|
$data->tahun = $request->tahun;
|
||||||
|
$data->nama = $request->nama;
|
||||||
|
$data->file = $filePath;
|
||||||
|
$data->deskripsi = $request->deskripsi;
|
||||||
|
$data->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return redirect()->back()->with([
|
||||||
|
'message' => 'Berhasil update data',
|
||||||
|
'type' => 'success',
|
||||||
|
]);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return redirect()->back()->with([
|
||||||
|
'message' => 'Gagal disimpan. Silakan coba lagi. Error: ' . $e->getMessage(),
|
||||||
|
'type' => 'error',
|
||||||
|
]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -50,9 +174,29 @@ class PengumumanController extends Controller
|
||||||
/**
|
/**
|
||||||
* Update the specified resource in storage.
|
* Update the specified resource in storage.
|
||||||
*/
|
*/
|
||||||
public function update(Request $request, string $id)
|
public function update($id = null)
|
||||||
{
|
{
|
||||||
//
|
$data['breadcrumbs'] = [
|
||||||
|
['name' => 'Dashboard'],
|
||||||
|
['name' => 'Pengaturan'],
|
||||||
|
['name' => 'Data Aktivitas','active' => true],
|
||||||
|
];
|
||||||
|
$keyId = decode_id($id);
|
||||||
|
$data['title'] = $this->title;
|
||||||
|
$data['route'] = $this->route;
|
||||||
|
$data['keyId'] = $id;
|
||||||
|
$data['item'] = FilePengumuman::where('FilePengumumanId',$keyId)->first();
|
||||||
|
|
||||||
|
return view($this->template.'.form',$data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete($id)
|
||||||
|
{
|
||||||
|
$keyId = decode_id($id);
|
||||||
|
|
||||||
|
$data = FilePengumuman::where('FilePengumumanId',$keyId)->delete();
|
||||||
|
|
||||||
|
return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,7 @@ use Illuminate\Database\Eloquent\SoftDeletes;
|
||||||
|
|
||||||
class FilePengumuman extends Model
|
class FilePengumuman extends Model
|
||||||
{
|
{
|
||||||
use SoftDeletes;
|
// use SoftDeletes;
|
||||||
protected $table = 'file_pengumuman';
|
protected $table = 'file_pengumuman';
|
||||||
protected $primaryKey = 'FilePengumumanId';
|
protected $primaryKey = 'FilePengumumanId';
|
||||||
|
|
||||||
|
|
|
||||||
Binary file not shown.
|
|
@ -8,20 +8,25 @@
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<i class="mdi mdi-account"></i> {{$title}}
|
<i class="mdi mdi-account"></i> {{$title}}
|
||||||
</div>
|
</div>
|
||||||
<form action="{{route($route.'.store')}}" method="POST" class="">
|
<form action="{{route($route.'.store')}}" method="POST" class="" enctype="multipart/form-data">
|
||||||
{{csrf_field()}}
|
{{csrf_field()}}
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
<input type="hidden" name="secure_id" value="{{@$keyId}}">
|
<input type="hidden" name="secure_id" value="{{@$keyId}}">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-12 mb-3">
|
<div class="col-12 mb-3">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-xl-12 form-label">Kode</label>
|
<label class="col-xl-12 form-label">Tahun</label>
|
||||||
<div class="col-12 ">
|
<div class="col-12 ">
|
||||||
<input type="text" value="{{@$item->kode ? @$item->kode : old('kode')}}" name="kode" class="form-control @error('kode') is-invalid @enderror" placeholder="Masukan Kode" required>
|
<select name="tahun" class=" select2" id="">
|
||||||
@error('kode')
|
<option value=""> PILIH TAHUN </option>
|
||||||
|
@for ($i = date('Y')-5; date('Y') > $i; $i++)
|
||||||
|
<option {{ @$item->tahun == $i ? 'selected' : '' }} value="{{$i}}">{{$i}}</option>
|
||||||
|
@endfor
|
||||||
|
<option {{ @$item->tahun == date('Y') ? 'selected' : '' }} value="{{date('Y')}}">{{date('Y')}}</option>
|
||||||
|
</select>
|
||||||
|
@error('tahun')
|
||||||
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
|
|
@ -44,7 +49,7 @@
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-xl-12 form-label">Deskripsi</label>
|
<label class="col-xl-12 form-label">Deskripsi</label>
|
||||||
<div class="col-12 ">
|
<div class="col-12 ">
|
||||||
<textarea name="deskripsi" class="form-control @error('deskripsi') is-invalid @enderror" placeholder="Masukan deskripsi" required id="" cols="30" rows="10">{{@$item->deskripsi ? @$item->deskripsi : old('deskripsi')}}</textarea>
|
<textarea name="deskripsi" class="form-control @error('deskripsi') is-invalid @enderror" placeholder="Masukan Deskripsi" id="" cols="30" rows="10">{{@$item->deskripsi ? @$item->deskripsi : old('deskripsi')}}</textarea>
|
||||||
@error('deskripsi')
|
@error('deskripsi')
|
||||||
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
||||||
@enderror
|
@enderror
|
||||||
|
|
@ -54,25 +59,17 @@
|
||||||
|
|
||||||
<div class="col-12 mb-3">
|
<div class="col-12 mb-3">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="col-xl-12 form-label">Nomor Baris</label>
|
<label class="col-xl-12 form-label d-flex justify-content-between align-items-center">
|
||||||
<div class="col-12 ">
|
<span>File Dokumen</span>
|
||||||
<input type="text" value="{{@$item->nomor_baris ? @$item->nomor_baris : old('nomor_baris')}}" name="nomor_baris" class="form-control @error('nomor_baris') is-invalid @enderror" placeholder="Masukan Nomor Baris" required>
|
@if(@$item->file)
|
||||||
@error('nomor_baris')
|
<a download href="{{ asset($item->file) }}" class="btn btn-sm btn-success">Download File <i class="mdi mdi-download text-white"></i></a>
|
||||||
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
@endif
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-12 mb-3">
|
</label>
|
||||||
<div class="form-group">
|
|
||||||
<label class="col-xl-12 form-label">Status</label>
|
|
||||||
<div class="col-12 ">
|
<div class="col-12 ">
|
||||||
<select name="status" class="form-control @error('status') is-invalid @enderror" id="" required>
|
<input type="file" accept=".pdf,.xls,.xlsx,.docx,.png,.jpg,.jpeg" value="{{@$item->file ? @$item->file : old('file')}}" name="file" class="form-control @error('file') is-invalid @enderror" required>
|
||||||
<option {{ @$item->status == '0' ? 'selected' : ''}} value="0">Tidak Aktif</option>
|
<small class="text-danger"><i>Max File : 2MB</i></small>
|
||||||
<option {{ @$item->status == '1' ? 'selected' : ''}} value="1">Aktif</option>
|
@error('file')
|
||||||
</select>
|
|
||||||
@error('status')
|
|
||||||
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
|
|
@ -97,4 +94,90 @@
|
||||||
</div>
|
</div>
|
||||||
@endsection
|
@endsection
|
||||||
@section('js')
|
@section('js')
|
||||||
|
<script type="text/javascript">
|
||||||
|
function clear(elementId) {
|
||||||
|
$('#' + elementId).empty();
|
||||||
|
$('#' + elementId).select2();
|
||||||
|
}
|
||||||
|
|
||||||
|
$('select').on("select2:selecting", function(e) {
|
||||||
|
var selectorOrigin = this.id;
|
||||||
|
var id = e.params.args.data.id;
|
||||||
|
|
||||||
|
|
||||||
|
if(selectorOrigin=='sektor'){
|
||||||
|
$('#loading-spinner').show();
|
||||||
|
clear('subsektor');
|
||||||
|
selector = 'subsektor';
|
||||||
|
url_to = 'subsektor';
|
||||||
|
getSelect(id, selector, url_to);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
function getSelect(id, selectTo, urlTo, selected = "") {
|
||||||
|
id = id;
|
||||||
|
var base_url = "{{url('/')}}";
|
||||||
|
//alert(id);
|
||||||
|
destino = "#" + selectTo;
|
||||||
|
valor = $('#' + id).find(":selected").val();
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
method: "POST",
|
||||||
|
url: base_url + "/get/" + urlTo,
|
||||||
|
data: {
|
||||||
|
_token: '{{csrf_token()}}',
|
||||||
|
id: id
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.done(function(msg) {
|
||||||
|
obj = msg.data;
|
||||||
|
|
||||||
|
if (obj.length > 0) {
|
||||||
|
//Clear the current options
|
||||||
|
$(destino).empty();
|
||||||
|
|
||||||
|
if(selectTo=='subsektor'){
|
||||||
|
$(destino).append('<option value="">-PILIH SUBSEKTOR-</option>');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$.each(obj, function(index) {
|
||||||
|
value = obj[index].id;
|
||||||
|
text = obj[index].name;
|
||||||
|
$(destino).append('<option value=' + value + '>' + text + '</option>');
|
||||||
|
});
|
||||||
|
console.log(selected)
|
||||||
|
if (selected) {
|
||||||
|
$(destino).val(selected).trigger('change');
|
||||||
|
selected = "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if(selectTo=='subsektor'){
|
||||||
|
$(destino).empty().append('<option value="">-PILIH SUBSEKTOR-</option>');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$('#loading-spinner').hide();
|
||||||
|
});
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function queryParams(params) {
|
||||||
|
$('#toolbar').find('input[name], select').each(function() {
|
||||||
|
params[$(this).attr('name')] = $(this).val()
|
||||||
|
})
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
function ajaxRequest(params) {
|
||||||
|
var url = "{{ route($route.'.grid') }}";
|
||||||
|
$.get(url + '?' + $.param(params.data)).then(function (res) {
|
||||||
|
params.success(res)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@endsection
|
@endsection
|
||||||
|
|
@ -8,33 +8,47 @@
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-12">
|
<div class="col-lg-12">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
|
<div class="card-header">
|
||||||
|
<a href="{{route($route.'.update')}}" id="btn-add" class="btn btn-primary">
|
||||||
|
<i class="mdi mdi-upload"></i> Upload
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div id="toolbar">
|
<div id="toolbar" class="">
|
||||||
<a href="{{route($route.'.update')}}" id="btn-add" class="btn btn-primary">
|
<div class="d-flex gap-1">
|
||||||
<i class="mdi mdi-plus"></i> Tambah Data
|
<div>
|
||||||
</a>
|
<select name="tahun" class=" select2" id="">
|
||||||
|
<option value=""> PILIH TAHUN </option>
|
||||||
|
@for ($i = date('Y')-5; date('Y') > $i; $i++)
|
||||||
|
<option value="{{$i}}">{{$i}}</option>
|
||||||
|
@endfor
|
||||||
|
<option value="{{date('Y')}}">{{date('Y')}}</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<table class="table w-100"
|
<table class="table w-100"
|
||||||
data-search="true"
|
data-search="true"
|
||||||
data-toggle="table"
|
data-toggle="table"
|
||||||
data-pagination="true"
|
data-pagination="true"
|
||||||
data-toolbar="#toolbar"
|
data-toolbar="#toolbar"
|
||||||
data-show-refresh="false"
|
data-show-refresh="false"
|
||||||
data-url="{{route($route.'.grid')}}"
|
data-url="{{route($route.'.grid')}}"
|
||||||
data-ajax-options='{"xhrFields": {"withCredentials": true}}'
|
data-ajax-options='{"xhrFields": {"withCredentials": true}}'
|
||||||
data-sort-name="ids"
|
data-sort-name="ids"
|
||||||
data-sort-order="desc"
|
data-sort-order="desc"
|
||||||
data-page-size="10"
|
data-page-size="10"
|
||||||
data-id-field="id"
|
data-query-params="queryParams"
|
||||||
id="grid-data">
|
data-id-field="id"
|
||||||
|
id="grid-data">
|
||||||
<thead class="table-secondary text-primary">
|
<thead class="table-secondary text-primary">
|
||||||
<tr>
|
<tr>
|
||||||
<th data-width="15%" class="text-center" data-field="action">#</th>
|
<th data-width="15%" class="text-center" data-field="action">#</th>
|
||||||
<th data-field="kode">Kode</th>
|
<th data-field="tahun">Tahun</th>
|
||||||
<th data-field="nama">Nama</th>
|
<th data-field="nama">Nama</th>
|
||||||
<th data-field="nomor_baris">Nomor Baris</th>
|
<th data-field="file">File</th>
|
||||||
<th data-field="status">Status</th>
|
<th data-field="created_at">Tanggal Upload</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody></tbody>
|
<tbody></tbody>
|
||||||
|
|
@ -48,6 +62,22 @@
|
||||||
@endsection
|
@endsection
|
||||||
@section('js')
|
@section('js')
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
|
|
||||||
|
function queryParams(params) {
|
||||||
|
$('#toolbar').find('input[name], select').each(function() {
|
||||||
|
params[$(this).attr('name')] = $(this).val()
|
||||||
|
})
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
function ajaxRequest(params) {
|
||||||
|
var url = "{{ route($route.'.grid') }}";
|
||||||
|
$.get(url + '?' + $.param(params.data)).then(function (res) {
|
||||||
|
params.success(res)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
$("#grid-data").on("click", ".remove_data", function() {
|
$("#grid-data").on("click", ".remove_data", function() {
|
||||||
var base_url = $(this).attr('data-href');
|
var base_url = $(this).attr('data-href');
|
||||||
var id = $(this).attr('data-id');
|
var id = $(this).attr('data-id');
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue