Merge pull request #13 from arieeefajar/feat/assessment-history-officer
feat(assessment-history-officer): create assessment history page for …
This commit is contained in:
commit
aa1bd51bf4
|
@ -13,4 +13,10 @@ public function index()
|
||||||
$evaluations = Evaluation::with('land', 'evaluationDetails.indicator')->orderBy('created_at', 'desc')->get();
|
$evaluations = Evaluation::with('land', 'evaluationDetails.indicator')->orderBy('created_at', 'desc')->get();
|
||||||
return view('assessment.index', compact('evaluations'));
|
return view('assessment.index', compact('evaluations'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function officer()
|
||||||
|
{
|
||||||
|
$evaluations = Evaluation::with('land', 'evaluationDetails.indicator')->where('user_id', auth()->user()->id)->orderBy('created_at', 'desc')->get();
|
||||||
|
return view('assessment.officer', compact('evaluations'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,382 @@
|
||||||
|
function detailData(data) {
|
||||||
|
var form = document.getElementById("detail-form");
|
||||||
|
var detailModal = form.querySelector("#detail-body");
|
||||||
|
|
||||||
|
detailModal.innerHTML = "";
|
||||||
|
|
||||||
|
if (Array.isArray(data)) {
|
||||||
|
data.forEach((item) => {
|
||||||
|
let row = `<div class="mb-3">
|
||||||
|
<label for="indicator-${
|
||||||
|
item.indicator.id
|
||||||
|
}" class="form-label">${item.indicator.name}</label>
|
||||||
|
<select name="indicator" class="form-control" id="indicator-${
|
||||||
|
item.indicator.id
|
||||||
|
}" disabled>
|
||||||
|
<option value="" disabled ${
|
||||||
|
item.md_value === null ? "selected" : ""
|
||||||
|
}>Pilih Jawaban</option>
|
||||||
|
<option value="0" ${
|
||||||
|
item.md_value == 0 ? "selected" : ""
|
||||||
|
}>Tidak</option>
|
||||||
|
<option value="0.2" ${
|
||||||
|
item.md_value == 0.2 ? "selected" : ""
|
||||||
|
}>Tidak Tahu</option>
|
||||||
|
<option value="0.4" ${
|
||||||
|
item.md_value == 0.4 ? "selected" : ""
|
||||||
|
}>Mungkin</option>
|
||||||
|
<option value="0.6" ${
|
||||||
|
item.md_value == 0.6 ? "selected" : ""
|
||||||
|
}>Kemungkinan Besar</option>
|
||||||
|
<option value="0.8" ${
|
||||||
|
item.md_value == 0.8 ? "selected" : ""
|
||||||
|
}>Hampir Pasti</option>
|
||||||
|
<option value="1" ${
|
||||||
|
item.md_value == 1 ? "selected" : ""
|
||||||
|
}>Pasti</option>
|
||||||
|
</select>
|
||||||
|
</div>`;
|
||||||
|
detailModal.innerHTML += row;
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
detailModal.innerHTML =
|
||||||
|
"<p class='text-muted'>Data tidak ditemukan</p>";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var checkAll = document.getElementById("checkAll");
|
||||||
|
checkAll &&
|
||||||
|
(checkAll.onclick = function () {
|
||||||
|
for (
|
||||||
|
var e = document.querySelectorAll(
|
||||||
|
'.form-check-all input[type="checkbox"]'
|
||||||
|
),
|
||||||
|
t = 0;
|
||||||
|
t < e.length;
|
||||||
|
t++
|
||||||
|
)
|
||||||
|
(e[t].checked = this.checked),
|
||||||
|
e[t].checked
|
||||||
|
? e[t].closest("tr").classList.add("table-active")
|
||||||
|
: e[t].closest("tr").classList.remove("table-active");
|
||||||
|
});
|
||||||
|
var perPage = 10,
|
||||||
|
options = {
|
||||||
|
valueNames: ["id", "customer_name", "email", "date", "phone", "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 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 =
|
||||||
|
"Add Customer"),
|
||||||
|
(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,
|
||||||
|
});
|
|
@ -0,0 +1,306 @@
|
||||||
|
@extends('layouts.app')
|
||||||
|
@push('title', 'Riwayat Penilaian Petugas')
|
||||||
|
@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">Riwayat Penilaian</h4>
|
||||||
|
|
||||||
|
<div class="page-title-right">
|
||||||
|
<ol class="breadcrumb m-0">
|
||||||
|
<li class="breadcrumb-item">
|
||||||
|
<a href="javascript: void(0);">Menu</a>
|
||||||
|
</li>
|
||||||
|
<li class="breadcrumb-item active">Riwayat Penilaian</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">Riwayat Penilaian</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-primary add-btn" data-bs-toggle="modal"
|
||||||
|
id="create-btn" data-bs-target="#showModal">
|
||||||
|
<i class="ri-add-line align-bottom me-1"></i> Add
|
||||||
|
</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="customer_name">
|
||||||
|
Lahan
|
||||||
|
</th>
|
||||||
|
<th class="sort" data-sort="status">
|
||||||
|
Nilai Presentase
|
||||||
|
</th>
|
||||||
|
<th class="sort" data-sort="action">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="list form-check-all">
|
||||||
|
@foreach ($evaluations as $evaluation)
|
||||||
|
<tr class="text-center">
|
||||||
|
<td class="no">{{ $loop->iteration }}</td>
|
||||||
|
<td class="id" style="display: none">
|
||||||
|
<a href="javascript:void(0);"
|
||||||
|
class="fw-medium link-primary">#VZ2101</a>
|
||||||
|
</td>
|
||||||
|
<td class="customer_name">{{ $evaluation->land->name }}</td>
|
||||||
|
<td class="status">
|
||||||
|
<span>{{ number_format($evaluation->cf_value, 2) * 100 }}%</span>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<div class="d-flex gap-2 justify-content-center">
|
||||||
|
<div class="edit">
|
||||||
|
<button class="btn btn-sm btn-primary edit-item-btn"
|
||||||
|
data-bs-toggle="modal" data-bs-target="#detailModal"
|
||||||
|
onclick="detailData({{ $evaluation->evaluationDetails }})">
|
||||||
|
Detail
|
||||||
|
</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>
|
||||||
|
<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="customername-field" class="form-label">Customer Name</label>
|
||||||
|
<input type="text" id="customername-field" class="form-control"
|
||||||
|
placeholder="Enter Name" required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="email-field" class="form-label">Email</label>
|
||||||
|
<input type="email" id="email-field" class="form-control"
|
||||||
|
placeholder="Enter Email" required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="phone-field" class="form-label">Phone</label>
|
||||||
|
<input type="text" id="phone-field" class="form-control"
|
||||||
|
placeholder="Enter Phone no." required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="date-field" class="form-label">Joining Date</label>
|
||||||
|
<input type="text" id="date-field" class="form-control" placeholder="Select Date"
|
||||||
|
required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<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">
|
||||||
|
Close
|
||||||
|
</button>
|
||||||
|
<button type="submit" class="btn btn-primary" id="add-btn">
|
||||||
|
Add Customer
|
||||||
|
</button>
|
||||||
|
<button type="button" class="btn btn-primary" id="edit-btn">
|
||||||
|
Update
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="modal fade" id="detailModal" 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">Detail Penilaian</h5>
|
||||||
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||||
|
id="close-modal"></button>
|
||||||
|
</div>
|
||||||
|
<form id="detail-form">
|
||||||
|
<div class="modal-body" id="detail-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="customername-field" class="form-label">Customer Name</label>
|
||||||
|
<input type="text" id="customername-field" class="form-control"
|
||||||
|
placeholder="Enter Name" required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="email-field" class="form-label">Email</label>
|
||||||
|
<input type="email" id="email-field" class="form-control"
|
||||||
|
placeholder="Enter Email" required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="phone-field" class="form-label">Phone</label>
|
||||||
|
<input type="text" id="phone-field" class="form-control"
|
||||||
|
placeholder="Enter Phone no." required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="date-field" class="form-label">Joining Date</label>
|
||||||
|
<input type="text" id="date-field" class="form-control" placeholder="Select Date"
|
||||||
|
required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<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>
|
||||||
|
</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>Are you sure ?</h4>
|
||||||
|
<p class="text-muted mx-4 mb-0">
|
||||||
|
Are you sure you want to remove this record ?
|
||||||
|
</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">
|
||||||
|
Close
|
||||||
|
</button>
|
||||||
|
<button type="button" class="btn w-sm btn-primary" id="delete-record">
|
||||||
|
Yes, Delete It!
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!--end modal -->
|
||||||
|
</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/assessment/officer.js"></script>
|
||||||
|
|
||||||
|
<script src="assets/js/pages/form-validation.init.js"></script>
|
||||||
|
@endpush
|
||||||
|
@endsection
|
|
@ -101,8 +101,8 @@ class="nav-link {{ request()->routeIs('master_data.aturan.*') ? 'active' : '' }}
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="nav-link menu-link {{ request()->routeIs('assessment_history_officer.officer') ? 'active' : '' }}"
|
<a class="nav-link menu-link {{ request()->routeIs('assessment_history_officer.index') ? 'active' : '' }}"
|
||||||
href="{{ route('assessment_history_officer.officer') }}">
|
href="{{ route('assessment_history_officer.index') }}">
|
||||||
<i data-feather="book" class="icon-dual"></i> <span data-key="t-dashboards">Riwayat
|
<i data-feather="book" class="icon-dual"></i> <span data-key="t-dashboards">Riwayat
|
||||||
Penilaian</span>
|
Penilaian</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -105,5 +105,9 @@
|
||||||
Route::get('/', 'index')->name('index');
|
Route::get('/', 'index')->name('index');
|
||||||
Route::post('/', 'store')->name('store');
|
Route::post('/', 'store')->name('store');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Route::prefix('riwayat-penilaian-lahan')->controller(AssessmentHistoryController::class)->name('assessment_history_officer.')->group(function () {
|
||||||
|
Route::get('/', 'officer')->name('index');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue