main
Ilham Wara Nugroho 2025-12-16 15:49:41 +07:00
parent e2dcdee265
commit f1d9e6fa52
12 changed files with 590 additions and 19 deletions

View File

@ -4,15 +4,82 @@ namespace App\Http\Controllers\Pengaturan;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\EF;
use App\Models\SumberDataEF;
use App\Models\Master\Activity;
class EFController extends Controller
{
protected $title = 'Data EF';
protected $template = 'modules.pengaturan.ef';
protected $route = 'modules.pengaturan.ef';
/**
* Display a listing of the resource.
*/
public function index()
{
//
permission('is_read', $this->route, 'module',true);
$data['breadcrumbs'] = [
['name' => 'Dashboard'],
['name' => 'Pengaturan'],
['name' => 'EF','active' => true],
];
$data['title'] = $this->title;
$data['route'] = $this->route;
$data['activity'] = Activity::all();
return view($this->template.'.index',$data);
}
public function grid(Request $request)
{
if(request()->activity){
$data = EF::with(['activity','sumberdata'])->where('ms_activity_id',decode_id(request()->activity))->orderBy('nomor_baris','ASC')->get();
}else{
$data = EF::with(['activity','sumberdata'])->orderBy('nomor_baris','ASC')->get();
}
$_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>';
}
$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->EFId).'" href="'.url('pengaturan/ef/update/'.encode_id($row->EFId)).'" 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/ef/delete/'.encode_id($row->EFId)).'" 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->EFId),
'activity' => @$row->activity->nama,
'sumberdata' => @$row->sumberdata->nama,
'kategori' => @$row->category,
'kode' => @$row->kode,
'nilai' => @$row->value,
'status' => @$status,
'action' => @$action,
];
}
// return response()->json($_data); // Return the data as a JSON response
return response()->json($_data);
}
/**
@ -28,7 +95,55 @@ class EFController extends Controller
*/
public function store(Request $request)
{
//
$request->validate([
'ms_activity_id' => 'required',
'sumberdata_ef_id' => 'required',
'value' => 'required',
'category' => 'required|string|max:255',
'tag_1' => 'nullable|string|max:255',
'tag_2' => 'nullable|string|max:255',
'tag_3' => 'nullable|string|max:255',
]);
try {
if(@request()->secure_id){
$keyId = decode_id(@request()->secure_id);
$data = EF::find($keyId);
$data->ms_activity_id = decode_id($request->ms_activity_id);
$data->tag_1 = $request->tag_1;
$data->tag_2 = $request->tag_2;
$data->tag_3 = $request->tag_3;
$data->category = $request->category;
$data->sumberdata_ef_id = decode_id($request->sumberdata_ef_id);
$data->value = $request->value;
$data->deskripsi = $request->deskripsi;
$data->status = $request->status;
$data->save();
}else{
$data = new EF;
$data->ms_activity_id = decode_id($request->ms_activity_id);
$data->tag_1 = $request->tag_1;
$data->tag_2 = $request->tag_2;
$data->tag_3 = $request->tag_3;
$data->category = $request->category;
$data->sumberdata_ef_id = decode_id($request->sumberdata_ef_id);
$data->value = $request->value;
$data->deskripsi = $request->deskripsi;
$data->status = $request->status;
$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 +165,31 @@ class EFController extends Controller
/**
* 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' => 'AR','active' => true],
];
$keyId = decode_id($id);
$data['title'] = $this->title;
$data['route'] = $this->route;
$data['keyId'] = $id;
$data['item'] = EF::where('EFId',$keyId)->first();
$data['activity'] = Activity::all();
$data['sumberdata'] = SumberDataEF::all();
return view($this->template.'.form',$data);
}
public function delete($id)
{
$keyId = decode_id($id);
$data = EF::where('EFId',$keyId)->delete();
return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']);
}
/**

View File

@ -22,7 +22,7 @@ class SumberDataEFController extends Controller
$data['breadcrumbs'] = [
['name' => 'Dashboard'],
['name' => 'Pengaturan'],
['name' => 'AR','active' => true],
['name' => 'Sumber Data EF','active' => true],
];
$data['title'] = $this->title;
$data['route'] = $this->route;

23
app/Models/EF.php 100644
View File

@ -0,0 +1,23 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class EF extends Model
{
use SoftDeletes;
protected $table = 'p_ef';
protected $primaryKey = 'EFId';
protected $guarded = [];
function activity(){
return $this->belongsTo(\App\Models\Master\Activity::class,'ms_activity_id');
}
function sumberdata(){
return $this->belongsTo(\App\Models\SumberDataEF::class,'sumberdata_ef_id');
}
}

View File

@ -0,0 +1,15 @@
<?php
namespace App\Models\Master;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Activity extends Model
{
use SoftDeletes;
protected $table = 'ms_activity';
protected $primaryKey = 'MsActivityId';
protected $guarded = [];
}

View File

@ -0,0 +1,38 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('p_ef', function (Blueprint $table) {
$table->id('EFId');
$table->integer('ms_activity_id');
$table->integer('sumberdata_ef_id');
$table->string('tag_1')->nullable();
$table->string('tag_2')->nullable();
$table->string('tag_3')->nullable();
$table->string('category')->nullable();
$table->string('value')->nullable();
$table->text('deskripsi')->nullable();
$table->integer('status')->nullable();
$table->integer('nomor_baris');
$table->timestampsTz();
$table->softdeletesTz();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('p_ef');
}
};

View File

@ -0,0 +1,34 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('ms_activity', function (Blueprint $table) {
$table->id('MsActivityId');
$table->string('kode')->nullable();
$table->string('nama')->nullable();
$table->string('unit_category')->nullable();
$table->integer('nomor_baris');
$table->text('deskripsi')->nullable();
$table->integer('status')->default(0);
$table->timestampsTz();
$table->softdeletesTz();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('ms_activity');
}
};

View File

@ -0,0 +1,29 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::table('p_ef', function (Blueprint $table) {
$table->foreign('ms_activity_id')->references('MsActivityId')->on('ms_activity')->cascadeOnDelete();
$table->foreign('sumberdata_ef_id')->references('SumberDataId')->on('p_sumberdata_ef')->cascadeOnDelete();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
// Schema::table('p_ef', function (Blueprint $table) {
// //
// });
}
};

View File

@ -72,11 +72,10 @@
<script src="{{ asset('assets/libs/alertifyjs/build/alertify.min.js') }}"></script>
<script src="{{ asset('assets/libs/choices.js/public/assets/scripts/choices.min.js') }}"></script>
@yield('js')
<script>
new Choices('.choices', {
shouldSort: false,
});
@if (Session::get('type')=='invalid')
@if (Session::get('type')=='error')
alertify.error("{{ Session::get('message') }}");
@endif
@if (Session::get('type')=='success')
@ -86,8 +85,6 @@
alertify.warning("{{ Session::get('message') }}");
@endif
</script>
@yield('js')
</body>
</html>

View File

@ -0,0 +1,160 @@
@extends('layouts.master')
@section('content')
<div class="page-content">
<div class="container-fluid">
<div class="row">
<div class="col-lg-12">
<div class="card">
<div class="card-header">
<i class="mdi mdi-account"></i> {{$title}}
</div>
<form action="{{route($route.'.store')}}" method="POST" class="">
{{csrf_field()}}
<div class="card-body">
<div class="row">
<div class="col-md-12">
<input type="hidden" name="secure_id" value="{{@$keyId}}">
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Aktifitas</label>
<div class="col-12 ">
<select name="ms_activity_id" class="form-control @error('ms_activity_id') is-invalid @enderror" id="" required>
<option value="">-- PILIH AKTIFITAS --</option>
@foreach ( $activity as $dataAct)
<option {{ @$item->ms_activity_id == $dataAct->MsActivityId ? 'selected' : ''}} value="{{ encode_id($dataAct->MsActivityId) }}">{{ $dataAct->nama }}</option>
@endforeach
</select>
@error('kode')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Tag 1</label>
<div class="col-12 ">
<input type="text" value="{{@$item->tag_1 ? @$item->tag_1 : old('tag_1')}}" name="tag_1" class="form-control @error('tag_1') is-invalid @enderror" placeholder="Masukan Tag 1">
@error('tag_1')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Tag 2</label>
<div class="col-12 ">
<input type="text" value="{{@$item->tag_2 ? @$item->tag_2 : old('tag_2')}}" name="tag_2" class="form-control @error('tag_2') is-invalid @enderror" placeholder="Masukan Tag 2">
@error('tag_2')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Tag 3</label>
<div class="col-12 ">
<input type="text" value="{{@$item->tag_3 ? @$item->tag_3 : old('tag_3')}}" name="tag_3" class="form-control @error('tag_3') is-invalid @enderror" placeholder="Masukan Tag 3">
@error('tag_3')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Kategori</label>
<div class="col-12 ">
<input type="text" required value="{{@$item->category ? @$item->category : old('category')}}" name="category" class="form-control @error('category') is-invalid @enderror" placeholder="Masukan Kategori">
@error('category')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Sumber Data EF</label>
<div class="col-12 ">
<select name="sumberdata_ef_id" class="form-control @error('sumberdata_ef_id') is-invalid @enderror" id="" required>
<option value="">-- PILIH SUMBER DATA EF --</option>
@foreach ( $sumberdata as $dataSumber)
<option {{ @$item->sumberdata_ef_id == $dataSumber->SumberDataId ? 'selected' : ''}} value="{{ encode_id($dataSumber->SumberDataId) }}">{{ $dataSumber->nama }}</option>
@endforeach
</select>
@error('kode')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Nilai</label>
<div class="col-12 ">
<input type="text" value="{{@$item->value ? @$item->value : old('value')}}" name="value" class="form-control @error('value') is-invalid @enderror" placeholder="Masukan Nilai" required>
@error('value')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Deskripsi</label>
<div class="col-12 ">
<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')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
<div class="col-12 mb-3">
<div class="form-group">
<label class="col-xl-12 form-label">Status</label>
<div class="col-12 ">
<select name="status" class="form-control @error('status') is-invalid @enderror" id="" required>
<option {{ @$item->status == '0' ? 'selected' : ''}} value="0">Tidak Aktif</option>
<option {{ @$item->status == '1' ? 'selected' : ''}} value="1">Aktif</option>
</select>
@error('status')
<span class="invalid-feedback" style="display: block!important;"><strong>{{$message}}</strong></span>
@enderror
</div>
</div>
</div>
</div>
</div>
<div class="card-footer">
<div class="row">
<div class="col-md-12 text-right">
<a href="{{route($route.'.index')}}" class="btn btn-danger"><i class="mdi mdi-cancel"></i> Batal</a>
<button type="submit" class="btn btn-success"><i class="mdi mdi-content-save-outline"></i> Simpan</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('js')
@endsection

View File

@ -0,0 +1,130 @@
@extends('layouts.master')
@section('css')
@endsection
@section('content')
<div class="page-content">
<div class="container-fluid">
<div class="row">
<div class="col-lg-12">
<div class="card">
<div class="card-header d-flex">
<a href="{{route($route.'.update')}}" id="btn-add" class="btn btn-primary">
<i class="mdi mdi-plus"></i> Tambah Data
</a>
</div>
<div class="card-body">
<div id="toolbar">
<div class="row">
<div class="col-12">
<select name="activity" class="form-control select2 activity @error('activity') is-invalid @enderror select2" id="" required>
<option value="">- PILIH AKTIFITAS -</option>
@foreach ( $activity as $dataAct)
<option {{ $dataAct->MsActivityId == decode_id(@request()->activity) ? 'selected' : '' }} value="{{ encode_id($dataAct->MsActivityId)}}">{{ $dataAct->nama }}</option>
@endforeach
</select>
</div>
</div>
</div>
<table class="table w-100"
data-search="true"
data-toggle="table"
data-pagination="true"
data-toolbar="#toolbar"
data-show-refresh="false"
data-url="{{route($route.'.grid')}}"
data-ajax-options='{"xhrFields": {"withCredentials": true}}'
data-sort-name="ids"
data-sort-order="desc"
data-page-size="10"
data-id-field="id"
data-query-params="queryParams"
id="grid-data">
<thead class="table-secondary text-primary">
<tr>
<th data-width="15%" class="text-center" data-field="action">#</th>
<th data-field="activity">Aktivitas</th>
<th data-field="kategori">Kategori</th>
<th data-field="sumberdata">Sumber Data EF</th>
<th data-field="nilai">Nilai</th>
<th data-field="status">Status</th>
</tr>
</thead>
<tbody></tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('js')
<script type="text/javascript">
var $table = $('#grid-data')
var $ok = $('#ok')
$(function() {
$('.activity').on('change',function(){
var activity = $(this).val();
// window.location.href="{{ url('pengaturan/ef?activity=') }}"+activity;
$table.bootstrapTable('refresh');
});
})
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() {
var base_url = $(this).attr('data-href');
var id = $(this).attr('data-id');
Swal.fire({
title: "Hapus Data!",
text: "Apa anda yakin ingin menghapus data ini ?",
icon: "warning",
showCancelButton: true,
confirmButtonColor: "#DD6B55",
confirmButtonText: "Ya Hapus Sekarang",
cancelButtonText: "Tidak"
}).then((result) => {
if (result.isConfirmed) {
request = $.ajax({
url: base_url,
xhrFields: {
withCredentials: true
},
type: "GET",
});
// Callback handler that will be called on success
request.done(function(response, textStatus, jqXHR){
console.log(response);
alertify.success("Berhasil Menhapus Data");
$('#grid-data').bootstrapTable('refresh');
});
// Callback handler that will be called on failure
request.fail(function (jqXHR, textStatus, errorThrown){
alertify.error("Gagal " + textStatus, errorThrown);
});
}
});
return false;
});
</script>
@endsection

View File

@ -11,15 +11,15 @@
<form action="{{route($route.'.store')}}" method="POST" class="">
{{csrf_field()}}
<div class="card-body">
<div class="col-lg-3" id="pencarian">
<select name="kategori_id" class="form-control choices kategori_id @error('kategori_id') is-invalid @enderror select2" id="" required>
<option value="">- PILIH KATEGORI -</option>
@foreach ( $kategori as $dataKat)
<option {{ $dataKat->KategoriId == decode_id(@request()->kategori_id) ? 'selected' : '' }} value="{{ encode_id($dataKat->KategoriId)}}">{{ $dataKat->nama }}</option>
@endforeach
</select>
</div>
<div id="toolbar">
<div id="pencarian">
<select name="kategori_id" class="form-control kategori_id @error('kategori_id') is-invalid @enderror select2" id="" required>
<option value="">- PILIH KATEGORI -</option>
@foreach ( $kategori as $dataKat)
<option {{ $dataKat->KategoriId == decode_id(@request()->kategori_id) ? 'selected' : '' }} value="{{ encode_id($dataKat->KategoriId)}}">{{ $dataKat->nama }}</option>
@endforeach
</select>
</div>
<div class="d-flex flex-row d-none">
<div class="col-12">
<a href="{{route($route.'.update')}}" id="btn-add" class="btn d-flex justify-content-center align-items-center w-100 h-100 btn-primary">

View File

@ -16,11 +16,19 @@ use App\Http\Controllers\Pengaturan\KategoriController;
use App\Http\Controllers\Pengaturan\UnitController;
use App\Http\Controllers\Pengaturan\UnitKonversiController;
use App\Http\Controllers\Pengaturan\SumberDataEFController;
use App\Http\Controllers\Pengaturan\EFController;
Route::get('dashboard',[HomeController::class,'index'])->name('index');
Route::name('pengaturan.')->prefix('pengaturan')->group(function () {
Route::name('ef.')->prefix('ef')->group(function () {
Route::resource('/',EFController::class);
Route::get('grid',[EFController::class,'grid'])->name('grid');
Route::get('update/{id?}',[EFController::class,'update'])->name('update');
Route::get('delete/{id?}',[EFController::class,'delete'])->name('delete');
});
Route::name('sumberdata-ef.')->prefix('sumberdata-ef')->group(function () {
Route::resource('/',SumberDataEFController::class);
Route::get('grid',[SumberDataEFController::class,'grid'])->name('grid');