fix redirect back umkm
This commit is contained in:
@@ -15,41 +15,30 @@ class UmkmController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function index(Request $request)
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
$menuId = $request->query('menu_id');
|
$menuId = $request->query('menu_id', 0);
|
||||||
$user = Auth::user();
|
$permissions = $this->permissions[$menuId] ?? []; // Avoid undefined index error
|
||||||
$userId = $user->id;
|
|
||||||
|
|
||||||
// Ambil role_id yang dimiliki user
|
$creator = $permissions['allow_create'] ?? 0;
|
||||||
$roleIds = DB::table('user_role')
|
$updater = $permissions['allow_update'] ?? 0;
|
||||||
->where('user_id', $userId)
|
$destroyer = $permissions['allow_destroy'] ?? 0;
|
||||||
->pluck('role_id');
|
return view('data.umkm.index', compact('creator', 'updater', 'destroyer', 'menuId'));
|
||||||
|
|
||||||
// Ambil data akses berdasarkan role_id dan menu_id
|
|
||||||
$roleAccess = DB::table('role_menu')
|
|
||||||
->whereIn('role_id', $roleIds)
|
|
||||||
->where('menu_id', $menuId)
|
|
||||||
->first();
|
|
||||||
|
|
||||||
// Pastikan roleAccess tidak null sebelum mengakses properti
|
|
||||||
$creator = $roleAccess->allow_create ?? 0;
|
|
||||||
$updater = $roleAccess->allow_update ?? 0;
|
|
||||||
$destroyer = $roleAccess->allow_destroy ?? 0;
|
|
||||||
return view('data.umkm.index', compact('creator', 'updater', 'destroyer'));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the form for creating a new resource.
|
* Show the form for creating a new resource.
|
||||||
*/
|
*/
|
||||||
public function bulkCreate()
|
public function bulkCreate(Request $request)
|
||||||
{
|
{
|
||||||
return view('data.umkm.form-upload');
|
$menuId = $request->query('menu_id', 0);
|
||||||
|
return view('data.umkm.form-upload', compact('menuId'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the form for creating a new resource.
|
* Show the form for creating a new resource.
|
||||||
*/
|
*/
|
||||||
public function create()
|
public function create(Request $request)
|
||||||
{
|
{
|
||||||
|
$menuId = $request->query('menu_id', 0);
|
||||||
$title = 'UMKM';
|
$title = 'UMKM';
|
||||||
$subtitle = 'Create Data';
|
$subtitle = 'Create Data';
|
||||||
|
|
||||||
@@ -67,14 +56,15 @@ class UmkmController extends Controller
|
|||||||
|
|
||||||
$apiUrl = url('/api/umkm');
|
$apiUrl = url('/api/umkm');
|
||||||
|
|
||||||
return view('data.umkm.form', compact('title', 'subtitle', 'fields', 'fieldTypes', 'apiUrl', 'dropdownOptions'));
|
return view('data.umkm.form', compact('title', 'subtitle', 'fields', 'fieldTypes', 'apiUrl', 'dropdownOptions','menuId'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the form for editing the specified resource.
|
* Show the form for editing the specified resource.
|
||||||
*/
|
*/
|
||||||
public function edit($id)
|
public function edit(Request $request,$id)
|
||||||
{
|
{
|
||||||
|
$menuId = $request->query('menu_id', 0);
|
||||||
$title = 'UMKM';
|
$title = 'UMKM';
|
||||||
$subtitle = 'Update Data';
|
$subtitle = 'Update Data';
|
||||||
$modelInstance = Umkm::find($id);
|
$modelInstance = Umkm::find($id);
|
||||||
@@ -116,7 +106,7 @@ class UmkmController extends Controller
|
|||||||
$apiUrl = url('/api/umkm');
|
$apiUrl = url('/api/umkm');
|
||||||
|
|
||||||
// dd($modelInstance->business_form_id, $dropdownOptions['business_form']);
|
// dd($modelInstance->business_form_id, $dropdownOptions['business_form']);
|
||||||
return view('data.umkm.form', compact('title', 'subtitle', 'modelInstance', 'fields', 'fieldTypes', 'apiUrl', 'dropdownOptions'));
|
return view('data.umkm.form', compact('title', 'subtitle', 'modelInstance', 'fields', 'fieldTypes', 'apiUrl', 'dropdownOptions','menuId'));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getFields()
|
private function getFields()
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import GeneralTable from "../../table-generator.js";
|
|||||||
const tableElement = document.getElementById("umkm-data-table");
|
const tableElement = document.getElementById("umkm-data-table");
|
||||||
const canUpdate = tableElement.getAttribute("data-updater") === "1";
|
const canUpdate = tableElement.getAttribute("data-updater") === "1";
|
||||||
const canDelete = tableElement.getAttribute("data-destroyer") === "1";
|
const canDelete = tableElement.getAttribute("data-destroyer") === "1";
|
||||||
|
let menuId = document.getElementById("menuId").value;
|
||||||
|
|
||||||
const dataUMKMColumns = [
|
const dataUMKMColumns = [
|
||||||
"No",
|
"No",
|
||||||
@@ -31,24 +32,25 @@ const dataUMKMColumns = [
|
|||||||
{
|
{
|
||||||
name: "Actions",
|
name: "Actions",
|
||||||
widht: "120px",
|
widht: "120px",
|
||||||
formatter: function(cell, row) {
|
formatter: function (cell, row) {
|
||||||
const id = row.cells[19].data;
|
const id = row.cells[19].data;
|
||||||
const model = "data/umkm";
|
const model = "data/web-umkm";
|
||||||
|
|
||||||
let actionButtons = '<div class="d-flex justify-items-end gap-10">';
|
let actionButtons = '<div class="d-flex justify-items-end gap-10">';
|
||||||
let hasPrivilege = false;
|
let hasPrivilege = false;
|
||||||
|
|
||||||
// Tampilkan tombol Edit jika user punya akses update
|
// Tampilkan tombol Edit jika user punya akses update
|
||||||
if (canUpdate) {
|
if (canUpdate) {
|
||||||
hasPrivilege = true;
|
hasPrivilege = true;
|
||||||
actionButtons += `
|
actionButtons += `
|
||||||
<button class="btn btn-warning me-2 btn-edit"
|
<button class="btn btn-warning me-2 btn-edit"
|
||||||
data-id="${id}"
|
data-id="${id}"
|
||||||
data-model="${model}">
|
data-model="${model}"
|
||||||
|
data-menu="${menuId}">
|
||||||
<i class='bx bx-edit'></i>
|
<i class='bx bx-edit'></i>
|
||||||
</button>`;
|
</button>`;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tampilkan tombol Delete jika user punya akses delete
|
// Tampilkan tombol Delete jika user punya akses delete
|
||||||
if (canDelete) {
|
if (canDelete) {
|
||||||
hasPrivilege = true;
|
hasPrivilege = true;
|
||||||
@@ -58,13 +60,17 @@ const dataUMKMColumns = [
|
|||||||
<i class='bx bxs-trash'></i>
|
<i class='bx bxs-trash'></i>
|
||||||
</button>`;
|
</button>`;
|
||||||
}
|
}
|
||||||
|
|
||||||
actionButtons += '</div>';
|
actionButtons += "</div>";
|
||||||
|
|
||||||
// Jika tidak memiliki akses, tampilkan teks "No Privilege"
|
// Jika tidak memiliki akses, tampilkan teks "No Privilege"
|
||||||
return gridjs.html(hasPrivilege ? actionButtons : '<span class="text-muted">No Privilege</span>');
|
return gridjs.html(
|
||||||
}
|
hasPrivilege
|
||||||
}
|
? actionButtons
|
||||||
|
: '<span class="text-muted">No Privilege</span>'
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
document.addEventListener("DOMContentLoaded", () => {
|
document.addEventListener("DOMContentLoaded", () => {
|
||||||
@@ -103,4 +109,4 @@ document.addEventListener("DOMContentLoaded", () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
table.init();
|
table.init();
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ document.addEventListener("DOMContentLoaded", function () {
|
|||||||
const modalButton = document.querySelector(".btn-modal");
|
const modalButton = document.querySelector(".btn-modal");
|
||||||
const form = document.querySelector("form#create-update-form");
|
const form = document.querySelector("form#create-update-form");
|
||||||
var authLogo = document.querySelector(".auth-logo");
|
var authLogo = document.querySelector(".auth-logo");
|
||||||
|
let menuId = document.getElementById("menuId").value;
|
||||||
|
|
||||||
if (!saveButton || !form) return;
|
if (!saveButton || !form) return;
|
||||||
|
|
||||||
@@ -74,7 +75,7 @@ document.addEventListener("DOMContentLoaded", function () {
|
|||||||
}, 2000);
|
}, 2000);
|
||||||
|
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "/data/web-umkm";
|
window.location.href = `/data/web-umkm?menu_id=${menuId}`;
|
||||||
}, 1000);
|
}, 1000);
|
||||||
} else {
|
} else {
|
||||||
if (authLogo) {
|
if (authLogo) {
|
||||||
|
|||||||
@@ -28,6 +28,7 @@ console.log(dropzonePreviewNode);
|
|||||||
.getAttribute("content")}`,
|
.getAttribute("content")}`,
|
||||||
},
|
},
|
||||||
init: function () {
|
init: function () {
|
||||||
|
let menuId = document.getElementById("menuId").value;
|
||||||
// Listen for the success event
|
// Listen for the success event
|
||||||
this.on("success", function (file, response) {
|
this.on("success", function (file, response) {
|
||||||
console.log("File successfully uploaded:", file);
|
console.log("File successfully uploaded:", file);
|
||||||
@@ -39,7 +40,7 @@ console.log(dropzonePreviewNode);
|
|||||||
"Upload Files";
|
"Upload Files";
|
||||||
// Tunggu sebentar lalu reload halaman
|
// Tunggu sebentar lalu reload halaman
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "/data/web-umkm";
|
window.location.href = `/data/web-umkm?menu_id=${menuId}`;
|
||||||
}, 2000);
|
}, 2000);
|
||||||
});
|
});
|
||||||
// Listen for the error event
|
// Listen for the error event
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
@section('content')
|
@section('content')
|
||||||
|
|
||||||
@include('layouts.partials/page-title', ['title' => 'Form', 'subtitle' => 'File Uploads'])
|
@include('layouts.partials/page-title', ['title' => 'Form', 'subtitle' => 'File Uploads'])
|
||||||
|
<input type="hidden" id="menuId" value="{{ $menuId ?? 0 }}">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-xl-12">
|
<div class="col-xl-12">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
@section('content')
|
@section('content')
|
||||||
|
|
||||||
@include('layouts.partials/page-title', ['title' => $title, 'subtitle' => $subtitle]) <!-- Menggunakan title dan subtitle dari controller -->
|
@include('layouts.partials/page-title', ['title' => $title, 'subtitle' => $subtitle]) <!-- Menggunakan title dan subtitle dari controller -->
|
||||||
|
<input type="hidden" id="menuId" value="{{ $menuId ?? 0 }}">
|
||||||
<div class="row d-flex justify-content-center">
|
<div class="row d-flex justify-content-center">
|
||||||
@if (session('error'))
|
@if (session('error'))
|
||||||
<div class="alert alert-danger">
|
<div class="alert alert-danger">
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
@include('layouts.partials/page-title', ['title' => 'Data', 'subtitle' => 'UMKM'])
|
@include('layouts.partials/page-title', ['title' => 'Data', 'subtitle' => 'UMKM'])
|
||||||
|
<input type="hidden" id="menuId" value="{{ $menuId ?? 0 }}">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<h5 class="card-title">Daftar UMKM</h5>
|
<h5 class="card-title">Daftar UMKM</h5>
|
||||||
@@ -15,10 +15,10 @@
|
|||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="d-flex justify-content-end gap-10 pb-3">
|
<div class="d-flex justify-content-end gap-10 pb-3">
|
||||||
@if ($creator)
|
@if ($creator)
|
||||||
<button class="btn btn-success me-2 width-lg btn-create" data-model="data/umkm">
|
<button class="btn btn-success me-2 width-lg btn-create" data-model="data/umkm" data-menu="{{ $menuId }}">
|
||||||
<i class='bx bxs-file-plus'></i>
|
<i class='bx bxs-file-plus'></i>
|
||||||
Create</button>
|
Create</button>
|
||||||
<button class="btn btn-primary width-lg btn-bulk-create" data-model="data/umkm">
|
<button class="btn btn-primary width-lg btn-bulk-create" data-model="data/umkm" data-menu="{{ $menuId }}">
|
||||||
<i class='bx bx-upload' ></i>
|
<i class='bx bx-upload' ></i>
|
||||||
Bulk Create
|
Bulk Create
|
||||||
</button>
|
</button>
|
||||||
|
|||||||
Reference in New Issue
Block a user