feat(master-lahan): create master land page with crud func
This commit is contained in:
parent
ada0629150
commit
9970e0a492
|
@ -0,0 +1,102 @@
|
|||
<?php
|
||||
|
||||
namespace App\Http\Controllers\MasterData;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\Land;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
|
||||
class LandController extends Controller
|
||||
{
|
||||
public function index()
|
||||
{
|
||||
$lands = Land::orderBy('created_at', 'desc')->get();
|
||||
return view('master-data.lahan.index', compact('lands'));
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
{
|
||||
$customMessage = [
|
||||
'name.required' => 'Nama wajib diisi',
|
||||
'name.max' => 'Nama maksimal 255 karakter',
|
||||
'name.string' => 'Nama harus berupa string',
|
||||
|
||||
'description.required' => 'Deskripsi wajib diisi',
|
||||
'description.max' => 'Deskripsi maksimal 255 karakter',
|
||||
'description.string' => 'Deskripsi harus berupa string',
|
||||
];
|
||||
|
||||
$validator = Validator::make($request->all(), [
|
||||
'land_name' => 'required|string|max:255',
|
||||
'description' => 'required|string|max:255',
|
||||
], $customMessage);
|
||||
|
||||
if ($validator->fails()) {
|
||||
toast($validator->messages()->all()[0], 'error')->position('top')->autoclose(3000);
|
||||
return redirect()->back()->withInput();
|
||||
}
|
||||
|
||||
$land = new Land();
|
||||
$land->name = $request->land_name;
|
||||
$land->description = $request->description;
|
||||
|
||||
try {
|
||||
$land->save();
|
||||
toast('Data berhasil disimpan', '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 = [
|
||||
'name.required' => 'Nama wajib diisi',
|
||||
'name.max' => 'Nama maksimal 255 karakter',
|
||||
'name.string' => 'Nama harus berupa string',
|
||||
|
||||
'description.required' => 'Deskripsi wajib diisi',
|
||||
'description.max' => 'Deskripsi maksimal 255 karakter',
|
||||
'description.string' => 'Deskripsi harus berupa string',
|
||||
];
|
||||
|
||||
$validator = Validator::make($request->all(), [
|
||||
'land_name' => 'required|string|max:255',
|
||||
'description' => 'required|string|max:255',
|
||||
], $customMessage);
|
||||
|
||||
if ($validator->fails()) {
|
||||
toast($validator->messages()->all()[0], 'error')->position('top')->autoclose(3000);
|
||||
return redirect()->back()->withInput();
|
||||
}
|
||||
|
||||
$land = Land::find($id);
|
||||
$land->name = $request->land_name;
|
||||
$land->description = $request->description;
|
||||
|
||||
try {
|
||||
$land->save();
|
||||
toast('Data 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)
|
||||
{
|
||||
$land = Land::find($id);
|
||||
try {
|
||||
$land->delete();
|
||||
toast('Data 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,18 @@
|
|||
<?php
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Land extends Model
|
||||
{
|
||||
use HasFactory;
|
||||
|
||||
protected $table = 'land';
|
||||
|
||||
protected $fillable = [
|
||||
'name',
|
||||
'description',
|
||||
];
|
||||
}
|
|
@ -0,0 +1,29 @@
|
|||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
/**
|
||||
* Run the migrations.
|
||||
*/
|
||||
public function up(): void
|
||||
{
|
||||
Schema::create('land', function (Blueprint $table) {
|
||||
$table->id();
|
||||
$table->string('name');
|
||||
$table->text('description');
|
||||
$table->timestamps();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Reverse the migrations.
|
||||
*/
|
||||
public function down(): void
|
||||
{
|
||||
Schema::dropIfExists('land');
|
||||
}
|
||||
};
|
|
@ -20,7 +20,8 @@ public function run(): void
|
|||
// ]);
|
||||
|
||||
$this->call([
|
||||
UsersSeeder::class
|
||||
UsersSeeder::class,
|
||||
LandSeeder::class
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,27 @@
|
|||
<?php
|
||||
|
||||
namespace Database\Seeders;
|
||||
|
||||
use App\Models\Land;
|
||||
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
|
||||
use Illuminate\Database\Seeder;
|
||||
|
||||
class LandSeeder extends Seeder
|
||||
{
|
||||
/**
|
||||
* Run the database seeds.
|
||||
*/
|
||||
public function run(): void
|
||||
{
|
||||
[
|
||||
Land::create([
|
||||
'name' => 'Land 1',
|
||||
'description' => 'Land 1 Description',
|
||||
]),
|
||||
Land::create([
|
||||
'name' => 'Land 2',
|
||||
'description' => 'Land 2 Description',
|
||||
])
|
||||
];
|
||||
}
|
||||
}
|
|
@ -0,0 +1,248 @@
|
|||
function updateData(land) {
|
||||
var form = document.getElementById("edit-form");
|
||||
var landName = document.getElementById("landname-edit-field");
|
||||
var status = document.getElementById("status-edit-field");
|
||||
|
||||
landName.value = land.name;
|
||||
status.value = land.description;
|
||||
form.action = "/data-lahan/" + land.id;
|
||||
}
|
||||
|
||||
function deleteData(id) {
|
||||
var form = document.getElementById("delete-form");
|
||||
form.action = "/data-lahan/" + id;
|
||||
}
|
||||
|
||||
var perPage = 10,
|
||||
options = {
|
||||
valueNames: ["id", "land_name", "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 =
|
||||
"Tambah Data Lahan"),
|
||||
(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++);
|
||||
}),
|
||||
// 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();
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
}
|
||||
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());
|
||||
});
|
|
@ -0,0 +1,264 @@
|
|||
@extends('layouts.app')
|
||||
@push('title', 'Data Tanah')
|
||||
@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 Lahan</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 Lahan</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 Lahan</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="id">
|
||||
No
|
||||
</th>
|
||||
<th class="sort" data-sort="land_name">Nama Lahan</th>
|
||||
<th class="sort" data-sort="description">Deskripsi</th>
|
||||
<th class="sort" data-sort="action">Action</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody class="list form-check-all">
|
||||
@foreach ($lands as $land)
|
||||
<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="land_name">{{ $land->name }}</td>
|
||||
<td class="status"><span>{{ $land->description }}</span></td>
|
||||
<td>
|
||||
<div class="d-flex gap-2 justify-content-center">
|
||||
<div class="edit">
|
||||
<button class="btn btn-sm btn-warning edit-item-btn"
|
||||
data-bs-toggle="modal" data-bs-target="#editModal"
|
||||
onclick="updateData({{ $land }})">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({{ $land->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 -->
|
||||
|
||||
{{-- add modal --}}
|
||||
<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.lahan.store') }}" class="needs-validation" method="POST"
|
||||
novalidate id="add-form">
|
||||
@csrf
|
||||
<div class="modal-body">
|
||||
|
||||
<div class="mb-3" id="modal-id" style="display: none;">
|
||||
<label for="id-field" class="form-label">ID</label>
|
||||
<input type="text" id="id-field" class="form-control" placeholder="ID"
|
||||
readonly />
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="landname-field" class="form-label">Nama Lahan</label>
|
||||
<input type="text" id="landname-field" class="form-control" name="land_name"
|
||||
value="{{ old('land_name') }}" placeholder="Masukan Nama Lahan" required />
|
||||
<div class="invalid-feedback">
|
||||
Masukan Nama Lahan
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<label for="status-field" class="form-label">Deskripsi</label>
|
||||
<textarea name="description" id="status-field" rows="5" placeholder="Masukan Deskripsi" class="form-control"
|
||||
required>{{ old('description') }}</textarea>
|
||||
<div class="invalid-feedback">
|
||||
Masukan Deskripsi
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<div class="hstack gap-2 justify-content-end">
|
||||
<button type="button" class="btn btn-light" data-bs-dismiss="modal">Tutup</button>
|
||||
<button type="submit" class="btn btn-success" id="add-btn">Simpan</button>
|
||||
</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 Lahan</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="landname-edit-field" class="form-label">Nama Lahan</label>
|
||||
<input type="text" id="landname-edit-field" class="form-control" name="land_name"
|
||||
value="{{ old('land_name') }}" placeholder="Masukan Nama Lahan" required />
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<label for="status-edit-field" class="form-label">Deskripsi</label>
|
||||
<textarea name="description" id="status-edit-field" rows="5" placeholder="Masukan Deskripsi"
|
||||
class="form-control" required>{{ old('description') }}</textarea>
|
||||
</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">Ubah</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Modal -->
|
||||
<div class="modal fade zoomIn" id="deleteRecordModal" tabindex="-1" aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
|
||||
id="btn-close"></button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<div class="mt-2 text-center">
|
||||
<lord-icon src="https://cdn.lordicon.com/gsqxdxog.json" trigger="loop"
|
||||
colors="primary:#25a0e2,secondary:#00bd9d"
|
||||
style="width:100px;height:100px"></lord-icon>
|
||||
<div class="mt-4 pt-2 fs-15 mx-4 mx-sm-5">
|
||||
<h4>Anda yakin ?</h4>
|
||||
<p class="text-muted mx-4 mb-0">Anda yakin akan menghapus data ini ?</p>
|
||||
</div>
|
||||
</div>
|
||||
<div class="d-flex gap-2 justify-content-center mt-4 mb-2">
|
||||
<button type="button" class="btn w-sm btn-light" data-bs-dismiss="modal">Tutup</button>
|
||||
<form action="" method="POST" id="delete-form">
|
||||
@csrf
|
||||
@method('DELETE')
|
||||
<button type="submit" class="btn w-sm btn-danger" id="delete-record">Ya,
|
||||
Hapus!</button>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!--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/master-data/lahan/index.js"></script>
|
||||
|
||||
<script src="assets/js/pages/form-validation.init.js"></script>
|
||||
@endpush
|
||||
@endsection
|
|
@ -58,215 +58,11 @@ class="nav-link {{ request()->routeIs('master_data.pengguna.*') ? 'active' : ''
|
|||
</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-chat.html" class="nav-link" data-key="t-chat"> Chat </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-mailbox.html" class="nav-link" data-key="t-mailbox"> Mailbox
|
||||
<a href="{{ route('master_data.lahan.index') }}"
|
||||
class="nav-link {{ request()->routeIs('master_data.lahan.*') ? 'active' : '' }}"
|
||||
data-key="t-calendar"> Lahan
|
||||
</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarEcommerce" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarEcommerce"
|
||||
data-key="t-ecommerce">Ecommerce
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarEcommerce">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-products.html" class="nav-link"
|
||||
data-key="t-products"> Products </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-product-details.html" class="nav-link"
|
||||
data-key="t-product-Details"> Product Details </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-add-product.html" class="nav-link"
|
||||
data-key="t-create-product"> Create Product </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-orders.html" class="nav-link"
|
||||
data-key="t-orders">
|
||||
Orders </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-order-details.html" class="nav-link"
|
||||
data-key="t-order-details"> Order Details </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-customers.html" class="nav-link"
|
||||
data-key="t-customers"> Customers </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-cart.html" class="nav-link"
|
||||
data-key="t-shopping-cart"> Shopping Cart </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-checkout.html" class="nav-link"
|
||||
data-key="t-checkout"> Checkout </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-sellers.html" class="nav-link"
|
||||
data-key="t-sellers"> Sellers </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-ecommerce-seller-details.html" class="nav-link"
|
||||
data-key="t-sellers-details"> Seller Details </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarProjects" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarProjects"
|
||||
data-key="t-projects">
|
||||
Projects
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarProjects">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-projects-list.html" class="nav-link" data-key="t-list">
|
||||
List </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-projects-overview.html" class="nav-link"
|
||||
data-key="t-overview"> Overview </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-projects-create.html" class="nav-link"
|
||||
data-key="t-create-project"> Create Project </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarTasks" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarTasks"
|
||||
data-key="t-tasks"> Tasks
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarTasks">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-tasks-kanban.html" class="nav-link"
|
||||
data-key="t-kanbanboard"> Kanban Board </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-tasks-list-view.html" class="nav-link"
|
||||
data-key="t-list-view"> List View </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-tasks-details.html" class="nav-link"
|
||||
data-key="t-task-details"> Task Details </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</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-crm"> CRM
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarCRM">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-crm-contacts.html" class="nav-link"
|
||||
data-key="t-contacts">
|
||||
Contacts </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crm-companies.html" class="nav-link"
|
||||
data-key="t-companies"> Companies </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crm-deals.html" class="nav-link" data-key="t-deals">
|
||||
Deals
|
||||
</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crm-leads.html" class="nav-link" data-key="t-leads">
|
||||
Leads
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarCrypto" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarCrypto"
|
||||
data-key="t-crypto"> Crypto
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarCrypto">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-transactions.html" class="nav-link"
|
||||
data-key="t-transactions"> Transactions </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-buy-sell.html" class="nav-link"
|
||||
data-key="t-buy-sell"> Buy & Sell </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-orders.html" class="nav-link"
|
||||
data-key="t-orders">
|
||||
Orders </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-wallet.html" class="nav-link"
|
||||
data-key="t-my-wallet"> My Wallet </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-ico.html" class="nav-link"
|
||||
data-key="t-ico-list">
|
||||
ICO List </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-crypto-kyc.html" class="nav-link"
|
||||
data-key="t-kyc-application"> KYC Application </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarInvoices" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarInvoices"
|
||||
data-key="t-invoices">
|
||||
Invoices
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarInvoices">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-invoices-list.html" class="nav-link"
|
||||
data-key="t-list-view"> List View </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-invoices-details.html" class="nav-link"
|
||||
data-key="t-details"> Details </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-invoices-create.html" class="nav-link"
|
||||
data-key="t-create-invoice"> Create Invoice </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="#sidebarTickets" class="nav-link" data-bs-toggle="collapse"
|
||||
role="button" aria-expanded="false" aria-controls="sidebarTickets"
|
||||
data-key="t-supprt-tickets">
|
||||
Support Tickets
|
||||
</a>
|
||||
<div class="collapse menu-dropdown" id="sidebarTickets">
|
||||
<ul class="nav nav-sm flex-column">
|
||||
<li class="nav-item">
|
||||
<a href="apps-tickets-list.html" class="nav-link"
|
||||
data-key="t-list-view">
|
||||
List View </a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a href="apps-tickets-details.html" class="nav-link"
|
||||
data-key="t-ticket-details"> Ticket Details </a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</li>
|
||||
|
|
|
@ -5,7 +5,9 @@
|
|||
use App\Http\Controllers\Auth\RegisteredUserController;
|
||||
use App\Http\Controllers\Auth\TwoStepVerifyController;
|
||||
use App\Http\Controllers\DashboardController;
|
||||
use App\Http\Controllers\MasterData\LandController;
|
||||
use App\Http\Controllers\MasterData\UserController;
|
||||
use Illuminate\Routing\RouteGroup;
|
||||
use Illuminate\Support\Facades\Route;
|
||||
|
||||
/*
|
||||
|
@ -64,7 +66,13 @@
|
|||
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');
|
||||
});
|
||||
|
||||
Route::prefix('data-lahan')->controller(LandController::class)->name('lahan.')->group(function () {
|
||||
Route::get('/', 'index')->name('index');
|
||||
Route::post('/', 'store')->name('store');
|
||||
Route::put('/{id}', 'update')->name('update');
|
||||
Route::delete('/{id}', 'destroy')->name('destroy');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue