fix(master-rule): crud func rule user
This commit is contained in:
parent
47c987a397
commit
e9d20b60ff
|
@ -13,7 +13,7 @@ class RuleController extends Controller
|
|||
public function index()
|
||||
{
|
||||
$indicators = Indicator::with('rules')->orderBy('created_at', 'desc')->get();
|
||||
return view('master-data.aturan.index', compact('indicators'));
|
||||
return view('master-data.aturan.rule_user', compact('indicators'));
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
|
@ -61,7 +61,6 @@ public function store(Request $request)
|
|||
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
// dd($request->all());
|
||||
$customMessage = [
|
||||
'parameter_type.required' => 'Jenis parameter wajib diisi',
|
||||
'parameter_type.string' => 'Jenis parameter harus berupa teks',
|
||||
|
|
|
@ -15,9 +15,23 @@ checkAll &&
|
|||
: e[t].closest("tr").classList.remove("table-active");
|
||||
});
|
||||
|
||||
function updateData(data) {
|
||||
var form = document.getElementById("edit-form");
|
||||
var indicator = form.querySelector("#indicator-edit-field");
|
||||
var category = form.querySelector("#category-edit-field");
|
||||
var description = form.querySelector("#description-edit-field");
|
||||
var cf = form.querySelector("#cf-edit-field");
|
||||
|
||||
form.action = "/data-aturan-pengguna/" + data.id;
|
||||
indicator.value = data.indicator_id;
|
||||
category.value = data.parameter_type;
|
||||
description.value = data.description;
|
||||
cf.value = data.cf;
|
||||
}
|
||||
|
||||
function deleteData(id) {
|
||||
var form = document.getElementById("delete-form");
|
||||
form.action = "/data-aturan/" + id;
|
||||
form.action = "/data-aturan-pengguna/" + id;
|
||||
}
|
||||
|
||||
var perPage = 10,
|
||||
|
@ -122,7 +136,7 @@ refreshCallbacks(),
|
|||
.addEventListener("show.bs.modal", function (e) {
|
||||
e.relatedTarget.classList.contains("edit-item-btn")
|
||||
? ((document.getElementById("exampleModalLabel").innerHTML =
|
||||
"Edit Customer"),
|
||||
"Edit Data Aturan"),
|
||||
(document
|
||||
.getElementById("showModal")
|
||||
.querySelector(".modal-footer").style.display = "block"),
|
||||
|
@ -130,7 +144,7 @@ refreshCallbacks(),
|
|||
(document.getElementById("edit-btn").style.display = "block"))
|
||||
: e.relatedTarget.classList.contains("add-btn")
|
||||
? ((document.getElementById("exampleModalLabel").innerHTML =
|
||||
"Add Customer"),
|
||||
"Tambah Data Aturan"),
|
||||
(document
|
||||
.getElementById("showModal")
|
||||
.querySelector(".modal-footer").style.display = "block"),
|
|
@ -0,0 +1,325 @@
|
|||
@extends('layouts.app')
|
||||
@push('title', 'Data Aturan')
|
||||
@section('content')
|
||||
<div class="page-content">
|
||||
<div class="container-fluid">
|
||||
<!-- start page title -->
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<div class="page-title-box d-sm-flex align-items-center justify-content-between">
|
||||
<h4 class="mb-sm-0">Data Aturan Petugas</h4>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- end page title -->
|
||||
|
||||
<div class="row">
|
||||
<div class="col-lg-12">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<h4 class="card-title mb-0">Data Aturan Petugas</h4>
|
||||
</div><!-- end card header -->
|
||||
|
||||
<div class="card-body">
|
||||
<div id="customerList">
|
||||
<div class="row g-4 mb-3">
|
||||
<div class="col-sm-auto">
|
||||
<div>
|
||||
<button type="button" class="btn btn-success add-btn" data-bs-toggle="modal"
|
||||
id="create-btn" data-bs-target="#showModal"><i
|
||||
class="ri-add-line align-bottom me-1"></i> Tambah</button>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-sm">
|
||||
<div class="d-flex justify-content-sm-end">
|
||||
<div class="search-box ms-2">
|
||||
<input type="text" class="form-control search" placeholder="Search...">
|
||||
<i class="ri-search-line search-icon"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="table-responsive table-card mt-3 mb-1">
|
||||
<table class="table align-middle table-nowrap" id="customerTable">
|
||||
<thead class="table-light">
|
||||
<tr class="text-center">
|
||||
<th scope="col" data-sort="no">
|
||||
No
|
||||
</th>
|
||||
<th class="sort" data-sort="customer_name">Indikator</th>
|
||||
<th class="sort" data-sort="email">Kategori</th>
|
||||
<th class="sort" data-sort="phone">Deskripsi</th>
|
||||
<th class="sort" data-sort="status">CF(e)</th>
|
||||
<th class="sort" data-sort="action">Action</th>
|
||||
</tr>
|
||||
</thead>
|
||||
@php
|
||||
$no = 1;
|
||||
@endphp
|
||||
<tbody class="list form-check-all">
|
||||
@foreach ($indicators as $indicator)
|
||||
@foreach ($indicator->rules as $index => $rule)
|
||||
<tr class="text-center">
|
||||
<th scope="row" class="no">
|
||||
{{ $no++ }}
|
||||
</th>
|
||||
<td class="id" style="display:none;"><a
|
||||
href="javascript:void(0);"
|
||||
class="fw-medium link-primary">#VZ2101</a></td>
|
||||
<td class="customer_name">{{ $indicator->name }}</td>
|
||||
<td class="email">{{ $rule->parameter_type }}</td>
|
||||
<td class="phone">{{ $rule->description }}</td>
|
||||
<td class="status"><span>{{ $rule->cf }}</span>
|
||||
</td>
|
||||
<td>
|
||||
<div class="d-flex gap-2 justify-content-center">
|
||||
<div class="edit">
|
||||
<button class="btn btn-sm btn-warning edit-item-btn"
|
||||
data-bs-toggle="modal" data-bs-target="#editModal"
|
||||
onclick="updateData({{ $rule }})">Edit</button>
|
||||
</div>
|
||||
<div class="remove">
|
||||
<button class="btn btn-sm btn-danger remove-item-btn"
|
||||
data-bs-toggle="modal"
|
||||
data-bs-target="#deleteRecordModal"
|
||||
onclick="deleteData({{ $rule->id }})">Hapus</button>
|
||||
</div>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
@endforeach
|
||||
@endforeach
|
||||
</tbody>
|
||||
</table>
|
||||
<div class="noresult" style="display: none">
|
||||
<div class="text-center">
|
||||
<lord-icon src="https://cdn.lordicon.com/msoeawqm.json" trigger="loop"
|
||||
colors="primary:#25a0e2,secondary:#00bd9d"
|
||||
style="width: 75px; height: 75px">
|
||||
</lord-icon>
|
||||
<h5 class="mt-2">Maaf! Data Tidak Ditemukan</h5>
|
||||
<p class="text-muted mb-0">Silahkan gunakan kata kunci lain</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="d-flex justify-content-end">
|
||||
<div class="pagination-wrap hstack gap-2">
|
||||
<a class="page-item pagination-prev disabled" href="#">
|
||||
Sebelumnya
|
||||
</a>
|
||||
<ul class="pagination listjs-pagination mb-0"></ul>
|
||||
<a class="page-item pagination-next" href="#">
|
||||
Selanjutnya
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div><!-- end card -->
|
||||
</div>
|
||||
<!-- end col -->
|
||||
</div>
|
||||
<!-- end col -->
|
||||
</div>
|
||||
<!-- end row -->
|
||||
|
||||
<div class="modal fade" id="showModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header bg-light p-3">
|
||||
<h5 class="modal-title" id="exampleModalLabel">Tambah Data Aturan</h5>
|
||||
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||
id="close-modal"></button>
|
||||
</div>
|
||||
<form action="{{ route('master_data.aturan.user_store') }}" class="needs-validation"
|
||||
method="POST" novalidate id="add-form">
|
||||
@csrf
|
||||
<div class="modal-body">
|
||||
<div class="mb-3" id="modal-id" style="display: none">
|
||||
<label for="id-field" class="form-label">ID</label>
|
||||
<input type="text" id="id-field" class="form-control" placeholder="ID"
|
||||
readonly />
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="indicatorname-field" class="form-label">Indikator</label>
|
||||
<select name="indicator" class="form-control" id="indicator-field" required>
|
||||
<option value="" selected disabled>Pilih Indikator</option>
|
||||
@foreach ($indicators as $indicator)
|
||||
<option value="{{ $indicator->id }}">{{ $indicator->name }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
<div class="invalid-feedback">
|
||||
Pilih Indikator
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="category-field" class="form-label">Kategori</label>
|
||||
<input type="text" id="category-field" class="form-control" name="parameter_type"
|
||||
placeholder="Masukan kategori" required />
|
||||
<div class="invalid-feedback">
|
||||
Masukan kategori
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="description-field" class="form-label">Deskripsi</label>
|
||||
<textarea class="form-control" name="description" id="description-field" rows="5"
|
||||
placeholder="Masukan Deskripsi" required></textarea>
|
||||
<div class="invalid-feedback">
|
||||
Masukan Nilai Ideal Max
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<label for="cf-field" class="form-label">CF(e)</label>
|
||||
<input type="text" id="cf-field" class="form-control" name="cf"
|
||||
placeholder="Masukan nilai CF pakar" required oninput="validateCfInput(this)" />
|
||||
<div class="invalid-feedback">
|
||||
Masukan Nilai CF
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<div class="hstack gap-2 justify-content-end">
|
||||
<button type="button" class="btn btn-light" data-bs-dismiss="modal">Tutup</button>
|
||||
<button type="submit" class="btn btn-success" id="add-btn">Simpan</button>
|
||||
<button type="button" class="btn btn-primary" id="edit-btn">Ubah</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="modal fade" id="editModal" tabindex="-1" aria-labelledby="exampleModalLabel"
|
||||
aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header bg-light p-3">
|
||||
<h5 class="modal-title" id="exampleModalLabel">Edit Data Aturan</h5>
|
||||
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||
id="close-modal"></button>
|
||||
</div>
|
||||
<form class="needs-validation" method="POST" novalidate id="edit-form">
|
||||
@csrf
|
||||
@method('PUT')
|
||||
<div class="modal-body">
|
||||
|
||||
<div class="mb-3" id="modal-id" style="display: none;">
|
||||
<label for="id-field" class="form-label">ID</label>
|
||||
<input type="text" id="id-field" class="form-control" placeholder="ID"
|
||||
readonly />
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="indicator-edit-field" class="form-label">Indikator</label>
|
||||
<select name="indicator" class="form-control" id="indicator-edit-field" required>
|
||||
<option value="" selected disabled>Pilih Indikator</option>
|
||||
@foreach ($indicators as $indicator)
|
||||
<option value="{{ $indicator->id }}">{{ $indicator->name }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
<div class="invalid-feedback">
|
||||
Harap pilih indikator
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="category-edit-field" class="form-label">Kategori</label>
|
||||
<input type="text" id="category-edit-field" class="form-control"
|
||||
name="parameter_type" placeholder="Masukan kategori" required />
|
||||
<div class="invalid-feedback">
|
||||
Masukan kategori
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="description-edit-field" class="form-label">Deskirpsi</label>
|
||||
<textarea class="form-control" name="description" id="description-edit-field" rows="5"
|
||||
placeholder="Masukan Deskripsi" required></textarea>
|
||||
<div class="invalid-feedback">
|
||||
Masukan Deskirpsi
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<label for="cf-edit-field" class="form-label">CF(e)</label>
|
||||
<input type="text" id="cf-edit-field" class="form-control" name="cf"
|
||||
placeholder="Masukan Nilai CF(e)" required oninput="validateCfInput(this)" />
|
||||
<div class="invalid-feedback">
|
||||
Masukan CF(e)
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="d-none">
|
||||
<label for="status-field" class="form-label">Status</label>
|
||||
<select class="form-control" data-trigger name="status-field" id="status-field">
|
||||
<option value="">Status</option>
|
||||
<option value="Active">Active</option>
|
||||
<option value="Block">Block</option>
|
||||
</select>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<div class="hstack gap-2 justify-content-end">
|
||||
<button type="button" class="btn btn-light" data-bs-dismiss="modal">Tutup</button>
|
||||
<button type="submit" class="btn btn-success" id="edit-btn">Ubah</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Modal -->
|
||||
<div class="modal fade zoomIn" id="deleteRecordModal" tabindex="-1" aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||
id="btn-close"></button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<div class="mt-2 text-center">
|
||||
<lord-icon src="https://cdn.lordicon.com/gsqxdxog.json" trigger="loop"
|
||||
colors="primary:#25a0e2,secondary:#00bd9d"
|
||||
style="width:100px;height:100px"></lord-icon>
|
||||
<div class="mt-4 pt-2 fs-15 mx-4 mx-sm-5">
|
||||
<h4>Anda yakin ?</h4>
|
||||
<p class="text-muted mx-4 mb-0">Anda yakin akan menghapus data ini ?</p>
|
||||
</div>
|
||||
</div>
|
||||
<div class="d-flex gap-2 justify-content-center mt-4 mb-2">
|
||||
<button type="button" class="btn w-sm btn-light" data-bs-dismiss="modal">Tutup</button>
|
||||
<form action="" method="post" id="delete-form">
|
||||
@csrf
|
||||
@method('DELETE')
|
||||
<button type="submit" class="btn w-sm btn-danger" id="delete-record">Ya
|
||||
Hapus!</button>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- container-fluid -->
|
||||
</div>
|
||||
<!-- End Page-content -->
|
||||
|
||||
@push('other-js')
|
||||
<!-- prismjs plugin -->
|
||||
<script src="assets/libs/prismjs/prism.js"></script>
|
||||
<script src="assets/libs/list.js/list.min.js"></script>
|
||||
<script src="assets/libs/list.pagination.js/list.pagination.min.js"></script>
|
||||
|
||||
<!-- listjs init -->
|
||||
<script src="assets/js/pages/customJs/master-data/aturan/petugas.js"></script>
|
||||
|
||||
<script src="assets/js/pages/form-validation.init.js"></script>
|
||||
@endpush
|
||||
@endsection
|
|
@ -70,10 +70,33 @@ class="nav-link {{ request()->routeIs('master_data.indikator.*') ? 'active' : ''
|
|||
</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="{{ route('master_data.aturan.index') }}"
|
||||
{{-- <a href="{{ route('master_data.aturan.index') }}"
|
||||
class="nav-link {{ request()->routeIs('master_data.aturan.*') ? 'active' : '' }}"
|
||||
data-key="t-calendar"> Aturan
|
||||
</a> --}}
|
||||
<a href="#rules"
|
||||
class="nav-link {{ request()->routeIs('master_data.aturan.*') ? 'collapsed active' : '' }}"
|
||||
data-bs-toggle="collapse" role="button"
|
||||
aria-expanded="{{ request()->routeIs('master_data.aturan.*') ? 'true' : 'false' }}"
|
||||
aria-controls="rules" data-key="t-level-2.2"> Aturan
|
||||
</a>
|
||||
<div class="collapse menu-dropdown {{ request()->routeIs('master_data.aturan.*') ? 'show' : '' }}"
|
||||
id="rules">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="" class="nav-link" data-key="t-level-3.1"> Keyakinan
|
||||
Pakar
|
||||
</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="{{ route('master_data.aturan.user') }}"
|
||||
class="nav-link {{ request()->routeIs('master_data.aturan.user') ? 'active' : '' }}"
|
||||
data-key="t-level-3.2"> Keyakikan
|
||||
Pengguna
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
|
|
@ -101,11 +101,14 @@
|
|||
Route::delete('/{id}', 'destroy')->name('destroy');
|
||||
});
|
||||
|
||||
Route::prefix('data-aturan')->controller(RuleController::class)->name('aturan.')->group(function () {
|
||||
Route::get('/', 'index')->name('index');
|
||||
Route::post('/', 'store')->name('store');
|
||||
Route::put('/{id}', 'update')->name('update');
|
||||
Route::delete('/{id}', 'destroy')->name('destroy');
|
||||
Route::name('aturan.')->group(function () {
|
||||
|
||||
Route::prefix('data-aturan-pengguna')->controller(RuleController::class)->group(function () {
|
||||
Route::get('/', 'index')->name('user');
|
||||
Route::post('/', 'store')->name('user_store');
|
||||
Route::put('/{id}', 'update')->name('user_update');
|
||||
Route::delete('/{id}', 'destroy')->name('user_destroy');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
|
Loading…
Reference in New Issue