feat/master-user: create master-user page with crud func
This commit is contained in:
parent
a4413389f8
commit
ebfcf13ba0
|
@ -0,0 +1,155 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Controllers\MasterData;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Mail\ActivationAccountMail;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\Hash;
|
||||||
|
use Illuminate\Support\Facades\Mail;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use Illuminate\Support\Str;
|
||||||
|
use PhpParser\Node\Expr\FuncCall;
|
||||||
|
|
||||||
|
class UserController extends Controller
|
||||||
|
{
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$users = User::orderBy('created_at', 'desc')->get();
|
||||||
|
return view('master-data.pengguna.index', compact('users'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function store(Request $request)
|
||||||
|
{
|
||||||
|
|
||||||
|
$customMessage = [
|
||||||
|
'fullname.required' => 'Nama wajib diisi',
|
||||||
|
'fullname.max' => 'Nama maksimal 255 karakter',
|
||||||
|
'fullname.string' => 'Nama harus berupa string',
|
||||||
|
|
||||||
|
'username.required' => 'Username wajib diisi',
|
||||||
|
'username.max' => 'Username maksimal 12 karakter',
|
||||||
|
'username.string' => 'Username harus berupa string',
|
||||||
|
|
||||||
|
'email.required' => 'Email wajib diisi',
|
||||||
|
'email.email' => 'Email tidak valid',
|
||||||
|
'email.unique' => 'Email sudah terdaftar',
|
||||||
|
|
||||||
|
'role.required' => 'Role wajib diisi',
|
||||||
|
'role.in' => 'Role tidak valid',
|
||||||
|
|
||||||
|
'status.required' => 'Status wajib diisi',
|
||||||
|
'status.in' => 'Status tidak valid',
|
||||||
|
];
|
||||||
|
|
||||||
|
$validator = Validator::make($request->all(), [
|
||||||
|
'fullname' => 'required|string|max:255',
|
||||||
|
'username' => 'required|string|max:12',
|
||||||
|
'email' => 'required|string|email|max:255|unique:users',
|
||||||
|
'role' => 'required|in:admin,user',
|
||||||
|
'status' => 'required|in:1,0',
|
||||||
|
], $customMessage);
|
||||||
|
|
||||||
|
if ($validator->fails()) {
|
||||||
|
toast($validator->messages()->all()[0], 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back()->withInput();
|
||||||
|
}
|
||||||
|
|
||||||
|
$user = new User();
|
||||||
|
$user->name = $request->fullname;
|
||||||
|
$user->username = $request->username;
|
||||||
|
$user->email = $request->email;
|
||||||
|
$user->password = Hash::make("12344321");
|
||||||
|
$user->role = $request->role;
|
||||||
|
|
||||||
|
if ($request->status == 0) {
|
||||||
|
$activationCode = Str::random(4);
|
||||||
|
$user->activation_code = $activationCode;
|
||||||
|
$user->is_active = 0;
|
||||||
|
} else {
|
||||||
|
$user->is_active = $request->status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
try {
|
||||||
|
$user->save();
|
||||||
|
toast('Pengguna berhasil ditambahkan', 'success')->position('top-right')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
} catch (\Throwable $th) {
|
||||||
|
toast('Terjadi kesalahan', 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update(Request $request, $id)
|
||||||
|
{
|
||||||
|
$customMessage = [
|
||||||
|
'fullname.required' => 'Nama wajib diisi',
|
||||||
|
'fullname.max' => 'Nama maksimal 255 karakter',
|
||||||
|
'fullname.string' => 'Nama harus berupa string',
|
||||||
|
|
||||||
|
'username.required' => 'Username wajib diisi',
|
||||||
|
'username.max' => 'Username maksimal 12 karakter',
|
||||||
|
'username.string' => 'Username harus berupa string',
|
||||||
|
|
||||||
|
'email.required' => 'Email wajib diisi',
|
||||||
|
'email.email' => 'Email tidak valid',
|
||||||
|
'email.unique' => 'Email sudah terdaftar',
|
||||||
|
|
||||||
|
'role.required' => 'Role wajib diisi',
|
||||||
|
'role.in' => 'Role tidak valid',
|
||||||
|
|
||||||
|
'status.required' => 'Status wajib diisi',
|
||||||
|
'status.in' => 'Status tidak valid',
|
||||||
|
];
|
||||||
|
|
||||||
|
$validator = Validator::make($request->all(), [
|
||||||
|
'fullname' => 'required|string|max:255',
|
||||||
|
'username' => 'required|string|max:12',
|
||||||
|
'email' => 'required|string|email|max:255|unique:users,email,' . $id,
|
||||||
|
'role' => 'required|in:admin,user',
|
||||||
|
'status' => 'required|in:1,0',
|
||||||
|
], $customMessage);
|
||||||
|
|
||||||
|
if ($validator->fails()) {
|
||||||
|
toast($validator->messages()->all()[0], 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back()->withInput();
|
||||||
|
}
|
||||||
|
|
||||||
|
$user = User::find($id);
|
||||||
|
$user->name = $request->fullname;
|
||||||
|
$user->username = $request->username;
|
||||||
|
$user->email = $request->email;
|
||||||
|
$user->role = $request->role;
|
||||||
|
$user->is_active = $request->status;
|
||||||
|
|
||||||
|
try {
|
||||||
|
$user->save();
|
||||||
|
toast('Pengguna berhasil diubah', 'success')->position('top-right')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
} catch (\Throwable $th) {
|
||||||
|
toast('Terjadi kesalahan', 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function destroy($id)
|
||||||
|
{
|
||||||
|
$user = User::find($id);
|
||||||
|
|
||||||
|
if ($user == null) {
|
||||||
|
toast('Pengguna tidak ditemukan', 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$user->delete();
|
||||||
|
toast('Pengguna berhasil dihapus', 'success')->position('top-right')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
} catch (\Throwable $th) {
|
||||||
|
toast('Terjadi kesalahan', 'error')->position('top')->autoclose(3000);
|
||||||
|
return redirect()->back();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,341 @@
|
||||||
|
function updateData(user) {
|
||||||
|
var form = document.getElementById("edit-form");
|
||||||
|
var fullname = document.getElementById("fullname-edit-field");
|
||||||
|
var username = document.getElementById("username-edit-field");
|
||||||
|
var email = document.getElementById("email-edit-field");
|
||||||
|
var role = document.getElementById("role-edit-field");
|
||||||
|
var status = document.getElementById("status-edit-field");
|
||||||
|
|
||||||
|
fullname.value = user.name;
|
||||||
|
username.value = user.username;
|
||||||
|
email.value = user.email;
|
||||||
|
role.value = user.role;
|
||||||
|
status.value = user.is_active;
|
||||||
|
form.action = "/data-pengguna/" + user.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
function deleteData(id) {
|
||||||
|
var form = document.getElementById("delete-form");
|
||||||
|
form.action = "/data-pengguna/" + id;
|
||||||
|
}
|
||||||
|
|
||||||
|
var perPage = 10,
|
||||||
|
options = {
|
||||||
|
valueNames: ["id", "fullname", "email", "username", "role", "status"],
|
||||||
|
page: perPage,
|
||||||
|
pagination: !0,
|
||||||
|
plugins: [ListPagination({ left: 2, right: 2 })],
|
||||||
|
},
|
||||||
|
customerList = new List("customerList", options).on(
|
||||||
|
"updated",
|
||||||
|
function (e) {
|
||||||
|
0 == e.matchingItems.length
|
||||||
|
? (document.getElementsByClassName(
|
||||||
|
"noresult"
|
||||||
|
)[0].style.display = "block")
|
||||||
|
: (document.getElementsByClassName(
|
||||||
|
"noresult"
|
||||||
|
)[0].style.display = "none");
|
||||||
|
var t = 1 == e.i,
|
||||||
|
a = e.i > e.matchingItems.length - e.page;
|
||||||
|
document.querySelector(".pagination-prev.disabled") &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-prev.disabled")
|
||||||
|
.classList.remove("disabled"),
|
||||||
|
document.querySelector(".pagination-next.disabled") &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-next.disabled")
|
||||||
|
.classList.remove("disabled"),
|
||||||
|
t &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-prev")
|
||||||
|
.classList.add("disabled"),
|
||||||
|
a &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-next")
|
||||||
|
.classList.add("disabled"),
|
||||||
|
e.matchingItems.length <= perPage
|
||||||
|
? (document.querySelector(
|
||||||
|
".pagination-wrap"
|
||||||
|
).style.display = "none")
|
||||||
|
: (document.querySelector(
|
||||||
|
".pagination-wrap"
|
||||||
|
).style.display = "flex"),
|
||||||
|
e.matchingItems.length == perPage &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination.listjs-pagination")
|
||||||
|
.firstElementChild.children[0].click(),
|
||||||
|
0 < e.matchingItems.length
|
||||||
|
? (document.getElementsByClassName(
|
||||||
|
"noresult"
|
||||||
|
)[0].style.display = "none")
|
||||||
|
: (document.getElementsByClassName(
|
||||||
|
"noresult"
|
||||||
|
)[0].style.display = "block");
|
||||||
|
}
|
||||||
|
);
|
||||||
|
isCount = new DOMParser().parseFromString(
|
||||||
|
customerList.items.slice(-1)[0]._values.id,
|
||||||
|
"text/html"
|
||||||
|
);
|
||||||
|
var isValue = isCount.body.firstElementChild.innerHTML,
|
||||||
|
idField = document.getElementById("id-field"),
|
||||||
|
customerNameField = document.getElementById("customername-field"),
|
||||||
|
emailField = document.getElementById("email-field"),
|
||||||
|
dateField = document.getElementById("date-field"),
|
||||||
|
phoneField = document.getElementById("phone-field"),
|
||||||
|
statusField = document.getElementById("status-field"),
|
||||||
|
addBtn = document.getElementById("add-btn"),
|
||||||
|
editBtn = document.getElementById("edit-btn"),
|
||||||
|
removeBtns = document.getElementsByClassName("remove-item-btn"),
|
||||||
|
editBtns = document.getElementsByClassName("edit-item-btn");
|
||||||
|
function filterContact(e) {
|
||||||
|
var t = e;
|
||||||
|
customerList.filter(function (e) {
|
||||||
|
matchData = new DOMParser().parseFromString(
|
||||||
|
e.values().status,
|
||||||
|
"text/html"
|
||||||
|
);
|
||||||
|
e = matchData.body.firstElementChild.innerHTML;
|
||||||
|
return "All" == e || "All" == t || e == t;
|
||||||
|
}),
|
||||||
|
customerList.update();
|
||||||
|
}
|
||||||
|
function updateList() {
|
||||||
|
var a = document.querySelector("input[name=status]:checked").value;
|
||||||
|
(data = userList.filter(function (e) {
|
||||||
|
var t = !1;
|
||||||
|
return (
|
||||||
|
"All" == a
|
||||||
|
? (t = !0)
|
||||||
|
: ((t = e.values().sts == a), console.log(t, "statusFilter")),
|
||||||
|
t
|
||||||
|
);
|
||||||
|
})),
|
||||||
|
userList.update();
|
||||||
|
}
|
||||||
|
refreshCallbacks(),
|
||||||
|
filterContact("All"),
|
||||||
|
document
|
||||||
|
.getElementById("showModal")
|
||||||
|
.addEventListener("show.bs.modal", function (e) {
|
||||||
|
e.relatedTarget.classList.contains("edit-item-btn")
|
||||||
|
? ((document.getElementById("exampleModalLabel").innerHTML =
|
||||||
|
"Edit Data Customer"),
|
||||||
|
(document
|
||||||
|
.getElementById("showModal")
|
||||||
|
.querySelector(".modal-footer").style.display = "block"),
|
||||||
|
(document.getElementById("add-btn").style.display = "none"),
|
||||||
|
(document.getElementById("edit-btn").style.display = "block"))
|
||||||
|
: e.relatedTarget.classList.contains("add-btn")
|
||||||
|
? ((document.getElementById("exampleModalLabel").innerHTML =
|
||||||
|
"Tambah Data Pengguna"),
|
||||||
|
(document
|
||||||
|
.getElementById("showModal")
|
||||||
|
.querySelector(".modal-footer").style.display = "block"),
|
||||||
|
(document.getElementById("edit-btn").style.display = "none"),
|
||||||
|
(document.getElementById("add-btn").style.display = "block"))
|
||||||
|
: ((document.getElementById("exampleModalLabel").innerHTML =
|
||||||
|
"List Customer"),
|
||||||
|
(document
|
||||||
|
.getElementById("showModal")
|
||||||
|
.querySelector(".modal-footer").style.display = "none"));
|
||||||
|
}),
|
||||||
|
ischeckboxcheck(),
|
||||||
|
document
|
||||||
|
.getElementById("showModal")
|
||||||
|
.addEventListener("hidden.bs.modal", function () {
|
||||||
|
clearFields();
|
||||||
|
}),
|
||||||
|
document
|
||||||
|
.querySelector("#customerList")
|
||||||
|
.addEventListener("click", function () {
|
||||||
|
refreshCallbacks(), ischeckboxcheck();
|
||||||
|
});
|
||||||
|
var table = document.getElementById("customerTable"),
|
||||||
|
tr = table.getElementsByTagName("tr"),
|
||||||
|
trlist = table.querySelectorAll(".list tr"),
|
||||||
|
count = Number(isValue.replace(/[^0-9]/g, "")) + 1;
|
||||||
|
addBtn.addEventListener("click", function (e) {
|
||||||
|
"" !== customerNameField.value &&
|
||||||
|
"" !== emailField.value &&
|
||||||
|
"" !== dateField.value &&
|
||||||
|
"" !== phoneField.value &&
|
||||||
|
(customerList.add({
|
||||||
|
id:
|
||||||
|
'<a href="javascript:void(0);" class="fw-medium link-primary">#VZ' +
|
||||||
|
count +
|
||||||
|
"</a>",
|
||||||
|
customer_name: customerNameField.value,
|
||||||
|
email: emailField.value,
|
||||||
|
date: dateField.value,
|
||||||
|
phone: phoneField.value,
|
||||||
|
status: isStatus(statusField.value),
|
||||||
|
}),
|
||||||
|
document.getElementById("close-modal").click(),
|
||||||
|
clearFields(),
|
||||||
|
refreshCallbacks(),
|
||||||
|
filterContact("All"),
|
||||||
|
count++);
|
||||||
|
}),
|
||||||
|
editBtn.addEventListener("click", function (e) {
|
||||||
|
(document.getElementById("exampleModalLabel").innerHTML =
|
||||||
|
"Edit Customer"),
|
||||||
|
customerList.get({ id: idField.value }).forEach(function (e) {
|
||||||
|
(isid = new DOMParser().parseFromString(
|
||||||
|
e._values.id,
|
||||||
|
"text/html"
|
||||||
|
)),
|
||||||
|
isid.body.firstElementChild.innerHTML == itemId &&
|
||||||
|
e.values({
|
||||||
|
id:
|
||||||
|
'<a href="javascript:void(0);" class="fw-medium link-primary">' +
|
||||||
|
idField.value +
|
||||||
|
"</a>",
|
||||||
|
customer_name: customerNameField.value,
|
||||||
|
email: emailField.value,
|
||||||
|
date: dateField.value,
|
||||||
|
phone: phoneField.value,
|
||||||
|
status: isStatus(statusField.value),
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
document.getElementById("close-modal").click(),
|
||||||
|
clearFields();
|
||||||
|
});
|
||||||
|
// var statusVal = new Choices(statusField);
|
||||||
|
function isStatus(e) {
|
||||||
|
switch (e) {
|
||||||
|
case "Active":
|
||||||
|
return (
|
||||||
|
'<span class="badge badge-soft-success text-uppercase">' +
|
||||||
|
e +
|
||||||
|
"</span>"
|
||||||
|
);
|
||||||
|
case "Block":
|
||||||
|
return (
|
||||||
|
'<span class="badge badge-soft-danger text-uppercase">' +
|
||||||
|
e +
|
||||||
|
"</span>"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function ischeckboxcheck() {
|
||||||
|
document.getElementsByName("checkAll").forEach(function (e) {
|
||||||
|
e.addEventListener("click", function (e) {
|
||||||
|
e.target.checked
|
||||||
|
? e.target.closest("tr").classList.add("table-active")
|
||||||
|
: e.target.closest("tr").classList.remove("table-active");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function refreshCallbacks() {
|
||||||
|
removeBtns.forEach(function (e) {
|
||||||
|
e.addEventListener("click", function (e) {
|
||||||
|
e.target.closest("tr").children[1].innerText,
|
||||||
|
(itemId = e.target.closest("tr").children[1].innerText),
|
||||||
|
customerList.get({ id: itemId }).forEach(function (e) {
|
||||||
|
deleteid = new DOMParser().parseFromString(
|
||||||
|
e._values.id,
|
||||||
|
"text/html"
|
||||||
|
);
|
||||||
|
var t = deleteid.body.firstElementChild;
|
||||||
|
deleteid.body.firstElementChild.innerHTML == itemId &&
|
||||||
|
document
|
||||||
|
.getElementById("delete-record")
|
||||||
|
.addEventListener("click", function () {
|
||||||
|
customerList.remove("id", t.outerHTML),
|
||||||
|
document
|
||||||
|
.getElementById("deleteRecordModal")
|
||||||
|
.click();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
editBtns.forEach(function (e) {
|
||||||
|
e.addEventListener("click", function (e) {
|
||||||
|
e.target.closest("tr").children[1].innerText,
|
||||||
|
(itemId = e.target.closest("tr").children[1].innerText),
|
||||||
|
customerList.get({ id: itemId }).forEach(function (e) {
|
||||||
|
isid = new DOMParser().parseFromString(
|
||||||
|
e._values.id,
|
||||||
|
"text/html"
|
||||||
|
);
|
||||||
|
var t = isid.body.firstElementChild.innerHTML;
|
||||||
|
t == itemId &&
|
||||||
|
((idField.value = t),
|
||||||
|
(customerNameField.value = e._values.customer_name),
|
||||||
|
(emailField.value = e._values.email),
|
||||||
|
(dateField.value = e._values.date),
|
||||||
|
(phoneField.value = e._values.phone),
|
||||||
|
statusVal && statusVal.destroy(),
|
||||||
|
(statusVal = new Choices(statusField)),
|
||||||
|
(val = new DOMParser().parseFromString(
|
||||||
|
e._values.status,
|
||||||
|
"text/html"
|
||||||
|
)),
|
||||||
|
(t = val.body.firstElementChild.innerHTML),
|
||||||
|
statusVal.setChoiceByValue(t),
|
||||||
|
flatpickr("#date-field", {
|
||||||
|
dateFormat: "d M, Y",
|
||||||
|
defaultDate: e._values.date,
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function clearFields() {
|
||||||
|
(customerNameField.value = ""),
|
||||||
|
(emailField.value = ""),
|
||||||
|
(dateField.value = ""),
|
||||||
|
(phoneField.value = "");
|
||||||
|
}
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-next")
|
||||||
|
.addEventListener("click", function () {
|
||||||
|
!document.querySelector(".pagination.listjs-pagination") ||
|
||||||
|
(document
|
||||||
|
.querySelector(".pagination.listjs-pagination")
|
||||||
|
.querySelector(".active") &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination.listjs-pagination")
|
||||||
|
.querySelector(".active")
|
||||||
|
.nextElementSibling.children[0].click());
|
||||||
|
}),
|
||||||
|
document
|
||||||
|
.querySelector(".pagination-prev")
|
||||||
|
.addEventListener("click", function () {
|
||||||
|
!document.querySelector(".pagination.listjs-pagination") ||
|
||||||
|
(document
|
||||||
|
.querySelector(".pagination.listjs-pagination")
|
||||||
|
.querySelector(".active") &&
|
||||||
|
document
|
||||||
|
.querySelector(".pagination.listjs-pagination")
|
||||||
|
.querySelector(".active")
|
||||||
|
.previousSibling.children[0].click());
|
||||||
|
});
|
||||||
|
var attroptions = {
|
||||||
|
valueNames: [
|
||||||
|
"name",
|
||||||
|
"born",
|
||||||
|
{ data: ["id"] },
|
||||||
|
{ attr: "src", name: "image" },
|
||||||
|
{ attr: "href", name: "link" },
|
||||||
|
{ attr: "data-timestamp", name: "timestamp" },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
attrList = new List("users", attroptions);
|
||||||
|
attrList.add({
|
||||||
|
name: "Leia",
|
||||||
|
born: "1954",
|
||||||
|
image: "assets/images/users/avatar-5.jpg",
|
||||||
|
id: 5,
|
||||||
|
timestamp: "67893",
|
||||||
|
});
|
||||||
|
var existOptionsList = { valueNames: ["contact-name", "contact-message"] },
|
||||||
|
existList = new List("contact-existing-list", existOptionsList),
|
||||||
|
fuzzySearchList = new List("fuzzysearch-list", { valueNames: ["name"] }),
|
||||||
|
paginationList = new List("pagination-list", {
|
||||||
|
valueNames: ["pagi-list"],
|
||||||
|
page: 3,
|
||||||
|
pagination: !0,
|
||||||
|
});
|
|
@ -591,6 +591,7 @@ class="form-check-input">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@include('sweetalert::alert')
|
||||||
|
|
||||||
<!-- JAVASCRIPT -->
|
<!-- JAVASCRIPT -->
|
||||||
<script src="assets/libs/bootstrap/js/bootstrap.bundle.min.js"></script>
|
<script src="assets/libs/bootstrap/js/bootstrap.bundle.min.js"></script>
|
||||||
|
@ -600,6 +601,8 @@ class="form-check-input">
|
||||||
<script src="assets/js/pages/plugins/lord-icon-2.1.0.js"></script>
|
<script src="assets/js/pages/plugins/lord-icon-2.1.0.js"></script>
|
||||||
<script src="assets/js/plugins.js"></script>
|
<script src="assets/js/plugins.js"></script>
|
||||||
|
|
||||||
|
@stack('other-js')
|
||||||
|
|
||||||
<!-- App js -->
|
<!-- App js -->
|
||||||
<script src="assets/js/app.js"></script>
|
<script src="assets/js/app.js"></script>
|
||||||
</body>
|
</body>
|
||||||
|
|
|
@ -0,0 +1,353 @@
|
||||||
|
@extends('layouts.app')
|
||||||
|
@push('title', 'Data Pengguna')
|
||||||
|
@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 Pengguna</h4>
|
||||||
|
|
||||||
|
<div class="page-title-right">
|
||||||
|
<ol class="breadcrumb m-0">
|
||||||
|
<li class="breadcrumb-item"><a href="javascript: void(0);">Master Data</a></li>
|
||||||
|
<li class="breadcrumb-item active">Data Pengguna</li>
|
||||||
|
</ol>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</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 Pengguna</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 class="sort" data-sort="no">
|
||||||
|
No
|
||||||
|
</th>
|
||||||
|
<th class="sort" data-sort="fullname">Nama Lengkap</th>
|
||||||
|
<th class="sort" data-sort="username">Username</th>
|
||||||
|
<th class="sort" data-sort="email">Email</th>
|
||||||
|
<th class="sort" data-sort="role">Role</th>
|
||||||
|
<th class="sort" data-sort="status">Status</th>
|
||||||
|
<th class="sort" data-sort="action">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="list form-check-all">
|
||||||
|
@foreach ($users as $user)
|
||||||
|
<tr class="text-center">
|
||||||
|
<th class="no">
|
||||||
|
{{ $loop->iteration }}
|
||||||
|
</th>
|
||||||
|
<td class="id" style="display:none;"><a href="javascript:void(0);"
|
||||||
|
class="fw-medium link-primary">#VZ2101</a></td>
|
||||||
|
<td class="fullname">{{ $user->name }}</td>
|
||||||
|
<td class="username">{{ $user->username }}</td>
|
||||||
|
<td class="email">{{ $user->email }}</td>
|
||||||
|
<td class="role text-capitalize">{{ $user->role }}</td>
|
||||||
|
<td class="status">
|
||||||
|
@if ($user->is_active == 0)
|
||||||
|
<span class="badge badge-soft-danger text-uppercase">Tidak
|
||||||
|
Aktif</span>
|
||||||
|
@else
|
||||||
|
<span
|
||||||
|
class="badge badge-soft-success text-uppercase">Aktif</span>
|
||||||
|
@endif
|
||||||
|
</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({{ $user }})">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({{ $user->id }})">Hapus</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
@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="#">
|
||||||
|
Kembali
|
||||||
|
</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"></h5>
|
||||||
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||||
|
id="close-modal"></button>
|
||||||
|
</div>
|
||||||
|
<form action="{{ route('master_data.pengguna.store') }}" class="needs-validation" method="POST"
|
||||||
|
novalidate>
|
||||||
|
@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="fullname-field" class="form-label">Nama Lengkap</label>
|
||||||
|
<input type="text" id="fullname-field" class="form-control" name="fullname"
|
||||||
|
placeholder="Masukan Nama Lengkap" value="{{ old('fullname') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Nama Lengkap
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="username-field" class="form-label">Username</label>
|
||||||
|
<input type="text" id="username-field" class="form-control" name="username"
|
||||||
|
placeholder="Masukan Username." value="{{ old('username') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Username
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="email-field" class="form-label">Email</label>
|
||||||
|
<input type="email" id="email-field" class="form-control" name="email"
|
||||||
|
placeholder="Enter Email" value="{{ old('email') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Email
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="date-field" class="form-label">Role</label>
|
||||||
|
<select name="role" id="role-field" data-trigger class="form-control" required>
|
||||||
|
<option value="" selected disabled>Pilih Role</option>
|
||||||
|
<option value="admin">Admin</option>
|
||||||
|
<option value="user">User</option>
|
||||||
|
</select>
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Pilih Role
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<label for="status-field" class="form-label">Status</label>
|
||||||
|
<select class="form-control" data-trigger name="status" id="status-field" required>
|
||||||
|
<option value="" selected disabled>Pilih Status</option>
|
||||||
|
<option value="1">Aktif</option>
|
||||||
|
<option value="0">Tidak Aktif</option>
|
||||||
|
</select>
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Pilih Status
|
||||||
|
</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">Tambah</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{{-- edit modal --}}
|
||||||
|
<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 Pengguna</h5>
|
||||||
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||||
|
id="close-modal"></button>
|
||||||
|
</div>
|
||||||
|
<form action="" 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="fullname-field" class="form-label">Nama Lengkap</label>
|
||||||
|
<input type="text" id="fullname-edit-field" class="form-control" name="fullname"
|
||||||
|
placeholder="Masukan Nama Lengkap" value="{{ old('fullname') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Nama Lengkap
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="username-field" class="form-label">Username</label>
|
||||||
|
<input type="text" id="username-edit-field" class="form-control" name="username"
|
||||||
|
placeholder="Masukan Username." value="{{ old('username') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Username
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="email-field" class="form-label">Email</label>
|
||||||
|
<input type="email" id="email-edit-field" class="form-control" name="email"
|
||||||
|
placeholder="Enter Email" value="{{ old('email') }}" required />
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Masukan Email
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="date-field" class="form-label">Role</label>
|
||||||
|
<select name="role" id="role-edit-field" data-trigger class="form-control"
|
||||||
|
required>
|
||||||
|
<option value="" selected disabled>Pilih Role</option>
|
||||||
|
<option value="admin">Admin</option>
|
||||||
|
<option value="user">User</option>
|
||||||
|
</select>
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Pilih Role
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<label for="status-field" class="form-label">Status</label>
|
||||||
|
<select class="form-control" data-trigger name="status" id="status-edit-field"
|
||||||
|
required>
|
||||||
|
<option value="" selected disabled>Pilih Status</option>
|
||||||
|
<option value="1">Aktif</option>
|
||||||
|
<option value="0">Tidak Aktif</option>
|
||||||
|
</select>
|
||||||
|
<div class="invalid-feedback">
|
||||||
|
Pilih Status
|
||||||
|
</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="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-primary" id="delete-record">Ya,
|
||||||
|
Hapus!</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--end modal -->
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<!-- container-fluid -->
|
||||||
|
</div>
|
||||||
|
|
||||||
|
@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/pengguna/index.js"></script>
|
||||||
|
|
||||||
|
<script src="assets/js/pages/form-validation.init.js"></script>
|
||||||
|
@endpush
|
||||||
|
@endsection
|
|
@ -4,11 +4,11 @@
|
||||||
<div class="col-sm-6">
|
<div class="col-sm-6">
|
||||||
<script>
|
<script>
|
||||||
document.write(new Date().getFullYear())
|
document.write(new Date().getFullYear())
|
||||||
</script> © Velzon.
|
</script> © CornQuest.
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-6">
|
<div class="col-sm-6">
|
||||||
<div class="text-sm-end d-none d-sm-block">
|
<div class="text-sm-end d-none d-sm-block">
|
||||||
Design & Develop by Themesbrand
|
Design & Develop by LAB KSI Politeknik Negeri Jember
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -36,29 +36,25 @@
|
||||||
@if (Auth::user()->role == 'admin')
|
@if (Auth::user()->role == 'admin')
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="nav-link menu-link {{ request()->routeIs('dashboard.admin') ? 'active' : '' }}"
|
<a class="nav-link menu-link {{ request()->routeIs('dashboard.admin') ? 'active' : '' }}"
|
||||||
href="">
|
href="{{ route('dashboard.admin') }}">
|
||||||
<i data-feather="home" class="icon-dual"></i> <span
|
<i data-feather="home" class="icon-dual"></i> <span
|
||||||
data-key="t-dashboards">Dashboards</span>
|
data-key="t-dashboards">Dashboards</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
@else
|
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="nav-link menu-link {{ request()->routeIs('dashboard.petugas') ? 'active' : '' }}"
|
<a class="nav-link menu-link {{ request()->routeIs('master_data.*') ? 'collapsed active' : '' }}"
|
||||||
href="">
|
href="#sidebarApps" data-bs-toggle="collapse" role="button"
|
||||||
<i data-feather="home" class="icon-dual"></i> <span
|
aria-expanded="{{ request()->routeIs('master_data.*') ? 'true' : 'false' }}"
|
||||||
data-key="t-dashboards">Dashboards</span>
|
aria-controls="sidebarApps">
|
||||||
|
<i data-feather="grid" class="icon-dual"></i> <span data-key="t-apps">Master Data</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
<div class="collapse menu-dropdown {{ request()->routeIs('master_data.*') ? 'show' : '' }}"
|
||||||
@endif <!-- end Dashboard Menu -->
|
id="sidebarApps">
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarApps" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarApps">
|
|
||||||
<i data-feather="grid" class="icon-dual"></i> <span data-key="t-apps">Apps</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarApps">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
<ul class="nav nav-sm flex-column">
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-calendar.html" class="nav-link" data-key="t-calendar"> Calendar
|
<a href="{{ route('master_data.pengguna.index') }}"
|
||||||
|
class="nav-link {{ request()->routeIs('master_data.pengguna.*') ? 'active' : '' }}"
|
||||||
|
data-key="t-calendar"> Pengguna
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -69,8 +65,8 @@
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarEcommerce" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarEcommerce" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarEcommerce"
|
role="button" aria-expanded="false" aria-controls="sidebarEcommerce"
|
||||||
data-key="t-ecommerce">Ecommerce
|
data-key="t-ecommerce">Ecommerce
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarEcommerce">
|
<div class="collapse menu-dropdown" id="sidebarEcommerce">
|
||||||
|
@ -88,7 +84,8 @@
|
||||||
data-key="t-create-product"> Create Product </a>
|
data-key="t-create-product"> Create Product </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-ecommerce-orders.html" class="nav-link" data-key="t-orders">
|
<a href="apps-ecommerce-orders.html" class="nav-link"
|
||||||
|
data-key="t-orders">
|
||||||
Orders </a>
|
Orders </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -119,8 +116,9 @@
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarProjects" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarProjects" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarProjects" data-key="t-projects">
|
role="button" aria-expanded="false" aria-controls="sidebarProjects"
|
||||||
|
data-key="t-projects">
|
||||||
Projects
|
Projects
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarProjects">
|
<div class="collapse menu-dropdown" id="sidebarProjects">
|
||||||
|
@ -141,8 +139,9 @@
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarTasks" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarTasks" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarTasks" data-key="t-tasks"> Tasks
|
role="button" aria-expanded="false" aria-controls="sidebarTasks"
|
||||||
|
data-key="t-tasks"> Tasks
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarTasks">
|
<div class="collapse menu-dropdown" id="sidebarTasks">
|
||||||
<ul class="nav nav-sm flex-column">
|
<ul class="nav nav-sm flex-column">
|
||||||
|
@ -168,7 +167,8 @@
|
||||||
<div class="collapse menu-dropdown" id="sidebarCRM">
|
<div class="collapse menu-dropdown" id="sidebarCRM">
|
||||||
<ul class="nav nav-sm flex-column">
|
<ul class="nav nav-sm flex-column">
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-crm-contacts.html" class="nav-link" data-key="t-contacts">
|
<a href="apps-crm-contacts.html" class="nav-link"
|
||||||
|
data-key="t-contacts">
|
||||||
Contacts </a>
|
Contacts </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -176,19 +176,22 @@
|
||||||
data-key="t-companies"> Companies </a>
|
data-key="t-companies"> Companies </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-crm-deals.html" class="nav-link" data-key="t-deals"> Deals
|
<a href="apps-crm-deals.html" class="nav-link" data-key="t-deals">
|
||||||
|
Deals
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-crm-leads.html" class="nav-link" data-key="t-leads"> Leads
|
<a href="apps-crm-leads.html" class="nav-link" data-key="t-leads">
|
||||||
|
Leads
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarCrypto" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarCrypto" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarCrypto" data-key="t-crypto"> Crypto
|
role="button" aria-expanded="false" aria-controls="sidebarCrypto"
|
||||||
|
data-key="t-crypto"> Crypto
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarCrypto">
|
<div class="collapse menu-dropdown" id="sidebarCrypto">
|
||||||
<ul class="nav nav-sm flex-column">
|
<ul class="nav nav-sm flex-column">
|
||||||
|
@ -201,7 +204,8 @@
|
||||||
data-key="t-buy-sell"> Buy & Sell </a>
|
data-key="t-buy-sell"> Buy & Sell </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-crypto-orders.html" class="nav-link" data-key="t-orders">
|
<a href="apps-crypto-orders.html" class="nav-link"
|
||||||
|
data-key="t-orders">
|
||||||
Orders </a>
|
Orders </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -209,7 +213,8 @@
|
||||||
data-key="t-my-wallet"> My Wallet </a>
|
data-key="t-my-wallet"> My Wallet </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-crypto-ico.html" class="nav-link" data-key="t-ico-list">
|
<a href="apps-crypto-ico.html" class="nav-link"
|
||||||
|
data-key="t-ico-list">
|
||||||
ICO List </a>
|
ICO List </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -220,8 +225,9 @@
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarInvoices" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarInvoices" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarInvoices" data-key="t-invoices">
|
role="button" aria-expanded="false" aria-controls="sidebarInvoices"
|
||||||
|
data-key="t-invoices">
|
||||||
Invoices
|
Invoices
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarInvoices">
|
<div class="collapse menu-dropdown" id="sidebarInvoices">
|
||||||
|
@ -242,14 +248,16 @@
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="#sidebarTickets" class="nav-link" data-bs-toggle="collapse" role="button"
|
<a href="#sidebarTickets" class="nav-link" data-bs-toggle="collapse"
|
||||||
aria-expanded="false" aria-controls="sidebarTickets" data-key="t-supprt-tickets">
|
role="button" aria-expanded="false" aria-controls="sidebarTickets"
|
||||||
|
data-key="t-supprt-tickets">
|
||||||
Support Tickets
|
Support Tickets
|
||||||
</a>
|
</a>
|
||||||
<div class="collapse menu-dropdown" id="sidebarTickets">
|
<div class="collapse menu-dropdown" id="sidebarTickets">
|
||||||
<ul class="nav nav-sm flex-column">
|
<ul class="nav nav-sm flex-column">
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a href="apps-tickets-list.html" class="nav-link" data-key="t-list-view">
|
<a href="apps-tickets-list.html" class="nav-link"
|
||||||
|
data-key="t-list-view">
|
||||||
List View </a>
|
List View </a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
|
@ -262,706 +270,18 @@
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
@else
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link menu-link {{ request()->routeIs('dashboard.petugas') ? 'active' : '' }}"
|
||||||
|
href="{{ route('dashboard.petugas') }}">
|
||||||
|
<i data-feather="home" class="icon-dual"></i> <span
|
||||||
|
data-key="t-dashboards">Dashboards</span>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
@endif <!-- end Dashboard Menu -->
|
||||||
|
|
||||||
<li class="nav-item">
|
{{-- <li class="menu-title"><i class="ri-more-fill"></i> <span data-key="t-pages">Pages</span>
|
||||||
<a class="nav-link menu-link" href="#sidebarLayouts" data-bs-toggle="collapse" role="button"
|
</li> --}}
|
||||||
aria-expanded="false" aria-controls="sidebarLayouts">
|
|
||||||
<i data-feather="layout" class="icon-dual"></i> <span data-key="t-layouts">Layouts</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarLayouts">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="layouts-horizontal.html" target="_blank" class="nav-link"
|
|
||||||
data-key="t-horizontal">Horizontal</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="layouts-detached.html" target="_blank" class="nav-link"
|
|
||||||
data-key="t-detached">Detached</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="layouts-two-column.html" target="_blank" class="nav-link"
|
|
||||||
data-key="t-two-column">Two Column</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="layouts-vertical-hovered.html" target="_blank" class="nav-link"
|
|
||||||
data-key="t-hovered">Hovered</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li> <!-- end Dashboard Menu -->
|
|
||||||
|
|
||||||
<li class="menu-title"><i class="ri-more-fill"></i> <span data-key="t-pages">Pages</span>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarAuth" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarAuth">
|
|
||||||
<i data-feather="users" class="icon-dual"></i> <span
|
|
||||||
data-key="t-authentication">Authentication</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarAuth">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarSignIn" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarSignIn" data-key="t-signin"> Sign In
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarSignIn">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-signin-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-signin-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarSignUp" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarSignUp" data-key="t-signup"> Sign Up
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarSignUp">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-signup-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-signup-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarResetPass" class="nav-link" data-bs-toggle="collapse"
|
|
||||||
role="button" aria-expanded="false" aria-controls="sidebarResetPass"
|
|
||||||
data-key="t-password-reset"> Password Reset
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarResetPass">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-pass-reset-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-pass-reset-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarLockScreen" class="nav-link" data-bs-toggle="collapse"
|
|
||||||
role="button" aria-expanded="false" aria-controls="sidebarLockScreen"
|
|
||||||
data-key="t-lock-screen"> Lock Screen
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarLockScreen">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-lockscreen-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-lockscreen-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarLogout" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarLogout" data-key="t-logout"> Logout
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarLogout">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-logout-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-logout-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarSuccessMsg" class="nav-link" data-bs-toggle="collapse"
|
|
||||||
role="button" aria-expanded="false" aria-controls="sidebarSuccessMsg"
|
|
||||||
data-key="t-success-message"> Success Message
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarSuccessMsg">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-success-msg-basic.html" class="nav-link"
|
|
||||||
data-key="t-basic"> Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-success-msg-cover.html" class="nav-link"
|
|
||||||
data-key="t-cover"> Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarTwoStep" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarTwoStep"
|
|
||||||
data-key="t-two-step-verification"> Two Step Verification
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarTwoStep">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-twostep-basic.html" class="nav-link" data-key="t-basic">
|
|
||||||
Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-twostep-cover.html" class="nav-link" data-key="t-cover">
|
|
||||||
Cover </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarErrors" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarErrors" data-key="t-errors"> Errors
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarErrors">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-404-basic.html" class="nav-link" data-key="t-404-basic">
|
|
||||||
404 Basic </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-404-cover.html" class="nav-link" data-key="t-404-cover">
|
|
||||||
404 Cover </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-404-alt.html" class="nav-link" data-key="t-404-alt"> 404
|
|
||||||
Alt </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="auth-500.html" class="nav-link" data-key="t-500"> 500
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarPages" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarPages">
|
|
||||||
<i data-feather="command" class="icon-dual"></i> <span data-key="t-pages">Pages</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarPages">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-starter.html" class="nav-link" data-key="t-starter">
|
|
||||||
Starter </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarProfile" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarProfile" data-key="t-profile">
|
|
||||||
Profile
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarProfile">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-profile.html" class="nav-link" data-key="t-simple-page">
|
|
||||||
Simple Page </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-profile-settings.html" class="nav-link"
|
|
||||||
data-key="t-settings"> Settings </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-team.html" class="nav-link" data-key="t-team"> Team </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-timeline.html" class="nav-link" data-key="t-timeline">
|
|
||||||
Timeline </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-faqs.html" class="nav-link" data-key="t-faqs"> FAQs </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-pricing.html" class="nav-link" data-key="t-pricing">
|
|
||||||
Pricing </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-gallery.html" class="nav-link" data-key="t-gallery">
|
|
||||||
Gallery </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-maintenance.html" class="nav-link" data-key="t-maintenance">
|
|
||||||
Maintenance </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-coming-soon.html" class="nav-link" data-key="t-coming-soon">
|
|
||||||
Coming Soon </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-sitemap.html" class="nav-link" data-key="t-sitemap">
|
|
||||||
Sitemap </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="pages-search-results.html" class="nav-link" data-key="t-search-results">
|
|
||||||
Search Results </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" target="_blank" href="landing.html">
|
|
||||||
<i class="ri-rocket-line"></i> <span data-key="t-landing">Landing</span>
|
|
||||||
<span class="badge badge-pill bg-danger" data-key="t-new">New</span>
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="menu-title"><i class="ri-more-fill"></i> <span data-key="t-components">Components</span>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarUI" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarUI">
|
|
||||||
<i data-feather="package" class="icon-dual"></i> <span data-key="t-base-ui">Base
|
|
||||||
UI</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown mega-dropdown-menu" id="sidebarUI">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-lg-4">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-alerts.html" class="nav-link" data-key="t-alerts">Alerts</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-badges.html" class="nav-link" data-key="t-badges">Badges</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-buttons.html" class="nav-link" data-key="t-buttons">Buttons</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-colors.html" class="nav-link" data-key="t-colors">Colors</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-cards.html" class="nav-link" data-key="t-cards">Cards</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-carousel.html" class="nav-link"
|
|
||||||
data-key="t-carousel">Carousel</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-dropdowns.html" class="nav-link"
|
|
||||||
data-key="t-dropdowns">Dropdowns</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-grid.html" class="nav-link" data-key="t-grid">Grid</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="col-lg-4">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-images.html" class="nav-link" data-key="t-images">Images</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-tabs.html" class="nav-link" data-key="t-tabs">Tabs</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-accordions.html" class="nav-link"
|
|
||||||
data-key="t-accordion-collapse">Accordion & Collapse</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-modals.html" class="nav-link" data-key="t-modals">Modals</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-offcanvas.html" class="nav-link"
|
|
||||||
data-key="t-offcanvas">Offcanvas</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-placeholders.html" class="nav-link"
|
|
||||||
data-key="t-placeholders">Placeholders</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-progress.html" class="nav-link"
|
|
||||||
data-key="t-progress">Progress</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-notifications.html" class="nav-link"
|
|
||||||
data-key="t-notifications">Notifications</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="col-lg-4">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-media.html" class="nav-link" data-key="t-media-object">Media
|
|
||||||
object</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-embed-video.html" class="nav-link" data-key="t-embed-video">Embed
|
|
||||||
Video</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-typography.html" class="nav-link"
|
|
||||||
data-key="t-typography">Typography</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-lists.html" class="nav-link" data-key="t-lists">Lists</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-general.html" class="nav-link" data-key="t-general">General</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-ribbons.html" class="nav-link" data-key="t-ribbons">Ribbons</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="ui-utilities.html" class="nav-link"
|
|
||||||
data-key="t-utilities">Utilities</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarAdvanceUI" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarAdvanceUI">
|
|
||||||
<i data-feather="layers" class="icon-dual"></i> <span data-key="t-advance-ui">Advance
|
|
||||||
UI</span>
|
|
||||||
<span class="badge badge-pill bg-primary" data-key="t-new">New</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarAdvanceUI">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-sweetalerts.html" class="nav-link"
|
|
||||||
data-key="t-sweet-alerts">Sweet Alerts</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-nestable.html" class="nav-link"
|
|
||||||
data-key="t-nestable-list">Nestable List</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-scrollbar.html" class="nav-link"
|
|
||||||
data-key="t-scrollbar">Scrollbar</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-animation.html" class="nav-link"
|
|
||||||
data-key="t-animation">Animation</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-tour.html" class="nav-link" data-key="t-tour">Tour</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-swiper.html" class="nav-link" data-key="t-swiper-slider">Swiper
|
|
||||||
Slider</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-ratings.html" class="nav-link" data-key="t-ratings">Ratings</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-highlight.html" class="nav-link"
|
|
||||||
data-key="t-highlight">Highlight</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="advance-ui-scrollspy.html" class="nav-link"
|
|
||||||
data-key="t-scrollSpy">ScrollSpy</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="widgets.html">
|
|
||||||
<i data-feather="copy" class="icon-dual"></i> <span data-key="t-widgets">Widgets</span>
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarForms" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarForms">
|
|
||||||
<i data-feather="file-text" class="icon-dual"></i> <span data-key="t-forms">Forms</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarForms">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-elements.html" class="nav-link" data-key="t-basic-elements">Basic
|
|
||||||
Elements</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-select.html" class="nav-link" data-key="t-form-select">
|
|
||||||
Form Select </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-checkboxs-radios.html" class="nav-link"
|
|
||||||
data-key="t-checkboxs-radios">Checkboxs & Radios</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-pickers.html" class="nav-link" data-key="t-pickers">
|
|
||||||
Pickers </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-masks.html" class="nav-link" data-key="t-input-masks">Input
|
|
||||||
Masks</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-advanced.html" class="nav-link" data-key="t-advanced">Advanced</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-range-sliders.html" class="nav-link" data-key="t-range-slider"> Range
|
|
||||||
Slider </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-validation.html" class="nav-link"
|
|
||||||
data-key="t-validation">Validation</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-wizard.html" class="nav-link" data-key="t-wizard">Wizard</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-editors.html" class="nav-link" data-key="t-editors">Editors</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-file-uploads.html" class="nav-link" data-key="t-file-uploads">File
|
|
||||||
Uploads</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="forms-layouts.html" class="nav-link" data-key="t-form-layouts">Form
|
|
||||||
Layouts</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarTables" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarTables">
|
|
||||||
<i data-feather="database" class="icon-dual"></i> <span data-key="t-tables">Tables</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarTables">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="tables-basic.html" class="nav-link" data-key="t-basic-tables">Basic
|
|
||||||
Tables</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="tables-gridjs.html" class="nav-link" data-key="t-grid-js">Grid
|
|
||||||
Js</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="tables-listjs.html" class="nav-link" data-key="t-list-js">List
|
|
||||||
Js</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarCharts" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarCharts">
|
|
||||||
<i data-feather="pie-chart" class="icon-dual"></i> <span data-key="t-charts">Charts</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarCharts">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarApexcharts" class="nav-link" data-bs-toggle="collapse"
|
|
||||||
role="button" aria-expanded="false" aria-controls="sidebarApexcharts"
|
|
||||||
data-key="t-apexcharts"> Apexcharts
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarApexcharts">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-line.html" class="nav-link" data-key="t-line"> Line
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-area.html" class="nav-link" data-key="t-area"> Area
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-column.html" class="nav-link" data-key="t-column">
|
|
||||||
Column </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-bar.html" class="nav-link" data-key="t-bar">
|
|
||||||
Bar </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-mixed.html" class="nav-link" data-key="t-mixed">
|
|
||||||
Mixed </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-timeline.html" class="nav-link"
|
|
||||||
data-key="t-timeline"> Timeline </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-candlestick.html" class="nav-link"
|
|
||||||
data-key="t-candlstick"> Candlstick </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-boxplot.html" class="nav-link" data-key="t-boxplot">
|
|
||||||
Boxplot </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-bubble.html" class="nav-link" data-key="t-bubble">
|
|
||||||
Bubble </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-scatter.html" class="nav-link" data-key="t-scatter">
|
|
||||||
Scatter </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-heatmap.html" class="nav-link" data-key="t-heatmap">
|
|
||||||
Heatmap </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-treemap.html" class="nav-link" data-key="t-treemap">
|
|
||||||
Treemap </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-pie.html" class="nav-link" data-key="t-pie">
|
|
||||||
Pie </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-radialbar.html" class="nav-link"
|
|
||||||
data-key="t-radialbar"> Radialbar </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-radar.html" class="nav-link" data-key="t-radar">
|
|
||||||
Radar </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-apex-polar.html" class="nav-link"
|
|
||||||
data-key="t-polar-area"> Polar Area </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-chartjs.html" class="nav-link" data-key="t-chartjs">
|
|
||||||
Chartjs </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="charts-echarts.html" class="nav-link" data-key="t-echarts">
|
|
||||||
Echarts </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarIcons" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarIcons">
|
|
||||||
<i data-feather="archive" class="icon-dual"></i> <span data-key="t-icons">Icons</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarIcons">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="icons-remix.html" class="nav-link" data-key="t-remix">Remix</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="icons-boxicons.html" class="nav-link" data-key="t-boxicons">Boxicons</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="icons-materialdesign.html" class="nav-link"
|
|
||||||
data-key="t-material-design">Material Design</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="icons-lineawesome.html" class="nav-link" data-key="t-line-awesome">Line
|
|
||||||
Awesome</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="icons-feather.html" class="nav-link" data-key="t-feather">Feather</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarMaps" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarMaps">
|
|
||||||
<i data-feather="map-pin" class="icon-dual"></i> <span data-key="t-maps">Maps</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarMaps">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="maps-google.html" class="nav-link" data-key="t-google">
|
|
||||||
Google
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="maps-vector.html" class="nav-link" data-key="t-vector">
|
|
||||||
Vector
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="maps-leaflet.html" class="nav-link" data-key="t-leaflet">
|
|
||||||
Leaflet
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
<li class="nav-item">
|
|
||||||
<a class="nav-link menu-link" href="#sidebarMultilevel" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarMultilevel">
|
|
||||||
<i data-feather="share-2" class="icon-dual"></i> <span data-key="t-multi-level">Multi
|
|
||||||
Level</span>
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarMultilevel">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#" class="nav-link" data-key="t-level-1.1"> Level 1.1 </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarAccount" class="nav-link" data-bs-toggle="collapse" role="button"
|
|
||||||
aria-expanded="false" aria-controls="sidebarAccount" data-key="t-level-1.2">
|
|
||||||
Level 1.2
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarAccount">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#" class="nav-link" data-key="t-level-2.1">
|
|
||||||
Level 2.1 </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#sidebarCrm" class="nav-link" data-bs-toggle="collapse"
|
|
||||||
role="button" aria-expanded="false" aria-controls="sidebarCrm"
|
|
||||||
data-key="t-level-2.2"> Level 2.2
|
|
||||||
</a>
|
|
||||||
<div class="collapse menu-dropdown" id="sidebarCrm">
|
|
||||||
<ul class="nav nav-sm flex-column">
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#" class="nav-link" data-key="t-level-3.1">
|
|
||||||
Level 3.1 </a>
|
|
||||||
</li>
|
|
||||||
<li class="nav-item">
|
|
||||||
<a href="#" class="nav-link" data-key="t-level-3.2">
|
|
||||||
Level 3.2 </a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</li>
|
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
use App\Http\Controllers\Auth\RegisteredUserController;
|
use App\Http\Controllers\Auth\RegisteredUserController;
|
||||||
use App\Http\Controllers\Auth\TwoStepVerifyController;
|
use App\Http\Controllers\Auth\TwoStepVerifyController;
|
||||||
use App\Http\Controllers\DashboardController;
|
use App\Http\Controllers\DashboardController;
|
||||||
|
use App\Http\Controllers\MasterData\UserController;
|
||||||
use Illuminate\Support\Facades\Route;
|
use Illuminate\Support\Facades\Route;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -55,4 +56,15 @@
|
||||||
Route::get('/dashboard-admin', 'admin')->name('admin');
|
Route::get('/dashboard-admin', 'admin')->name('admin');
|
||||||
Route::get('/dashboard-petugas', 'petugas')->name('petugas');
|
Route::get('/dashboard-petugas', 'petugas')->name('petugas');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Route::name('master_data.')->group(function () {
|
||||||
|
|
||||||
|
Route::prefix('data-pengguna')->controller(UserController::class)->name('pengguna.')->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::post('/{id}/send-code', 'sendCode')->name('send_code');
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue