pembuatan basic data surveyor
This commit is contained in:
@@ -22,7 +22,7 @@ use Modules\Lpj\Models\SpekBangunan;
|
|||||||
use Modules\Lpj\Models\SpekKategoritBangunan;
|
use Modules\Lpj\Models\SpekKategoritBangunan;
|
||||||
use Modules\Lpj\Models\SaranaPelengkap;
|
use Modules\Lpj\Models\SaranaPelengkap;
|
||||||
use Modules\Lpj\Models\ArahMataAngin;
|
use Modules\Lpj\Models\ArahMataAngin;
|
||||||
|
use Modules\Lpj\Http\Requests\SurveyorRequest;
|
||||||
|
|
||||||
class SurveyorController extends Controller
|
class SurveyorController extends Controller
|
||||||
{
|
{
|
||||||
@@ -35,21 +35,7 @@ class SurveyorController extends Controller
|
|||||||
return view('lpj::surveyor.index');
|
return view('lpj::surveyor.index');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Show the form for creating a new resource.
|
|
||||||
*/
|
|
||||||
public function create()
|
|
||||||
{
|
|
||||||
return view('lpj::create');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Store a newly created resource in storage.
|
|
||||||
*/
|
|
||||||
public function store(Request $request): RedirectResponse
|
|
||||||
{
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the specified resource.
|
* Show the specified resource.
|
||||||
@@ -282,9 +268,273 @@ class SurveyorController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function data(Request $request)
|
||||||
|
{
|
||||||
|
|
||||||
|
$type = $request->route('type');
|
||||||
|
|
||||||
|
$headers = [
|
||||||
|
'bentuk-tanah' => ['Bentuk Tanah', 'bentuk-tanah'],
|
||||||
|
'kontur-tanah' => ['Kontur Tanah', 'kontur-tanah'],
|
||||||
|
'posisi-kavling' => ['Posisi Kavling', 'posisi-kavling'],
|
||||||
|
'ketinggian-tanah' => ['Ketinggian Tanah', 'ketinggian-tanah'],
|
||||||
|
'kondisi-fisik-tanah' => ['Kondisi Fisik Tanah', 'kondisi-fisik-tanah'],
|
||||||
|
'jenis-bangunan' => ['Jenis Bangunan', 'jenis-bangunan'],
|
||||||
|
'kondisi-bangunan' => ['Kondisi Bangunan', 'kondisi-bangunan'],
|
||||||
|
'sifat-bangunan' => ['Sifat Bangunan', 'sifat-bangunan'],
|
||||||
|
'sarana-pelengkap' => ['Sarana Pelengkap', 'sarana-pelengkap'],
|
||||||
|
];
|
||||||
|
|
||||||
|
$header = $headers[$type] ?? '';
|
||||||
|
|
||||||
|
return view('lpj::surveyor.data.index', compact('header'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function createData($type)
|
||||||
|
{
|
||||||
|
|
||||||
|
$headers = [
|
||||||
|
'bentuk-tanah' => ['Bentuk Tanah', 'bentuk-tanah'],
|
||||||
|
'kontur-tanah' => ['Kontur Tanah', 'kontur-tanah'],
|
||||||
|
'posisi-kavling' => ['Posisi Kavling', 'posisi-kavling'],
|
||||||
|
'ketinggian-tanah' => ['Ketinggian Tanah', 'ketinggian-tanah'],
|
||||||
|
'kondisi-fisik-tanah' => ['Kondisi Fisik Tanah', 'kondisi-fisik-tanah'],
|
||||||
|
'jenis-bangunan' => ['Jenis Bangunan', 'jenis-bangunan'],
|
||||||
|
'kondisi-bangunan' => ['Kondisi Bangunan', 'kondisi-bangunan'],
|
||||||
|
'sifat-bangunan' => ['Sifat Bangunan', 'sifat-bangunan'],
|
||||||
|
'sarana-pelengkap' => ['Sarana Pelengkap', 'sarana-pelengkap'],
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
$header = $headers[$type] ?? '';
|
||||||
|
return view('lpj::surveyor.data.form', compact('header'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function storeData(SurveyorRequest $request, $type)
|
||||||
|
{
|
||||||
|
|
||||||
|
$validate = $request->validated();
|
||||||
|
if ($validate) {
|
||||||
|
|
||||||
|
$type = $request->route('type');
|
||||||
|
|
||||||
|
$modelClasses = [
|
||||||
|
'bentuk-tanah' => BentukTanah::class,
|
||||||
|
'kontur-tanah' => KonturTanah::class,
|
||||||
|
'posisi-kavling' => PosisiKavling::class,
|
||||||
|
'bentuk-tanah' => BentukTanah::class,
|
||||||
|
'kontur-tanah' => KonturTanah::class,
|
||||||
|
'posisi-kavling' => PosisiKavling::class,
|
||||||
|
'ketinggian-tanah' => KetinggianTanah::class,
|
||||||
|
'kondisi-fisik-tanah' => KondisiFisikTanah::class,
|
||||||
|
'jenis-bangunan' => JenisBangunan::class,
|
||||||
|
'kondisi-bangunan' => KondisiBangunan::class,
|
||||||
|
'sifat-bangunan' => SifatBangunan::class,
|
||||||
|
'sarana-pelengkap' => SaranaPelengkap::class,
|
||||||
|
];
|
||||||
|
|
||||||
|
if (!array_key_exists($type, $modelClasses)) {
|
||||||
|
return redirect()
|
||||||
|
->route('basicdata.'. $type .'.index')
|
||||||
|
->with('error', 'Invalid type specified.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$modelClass = $modelClasses[$type];
|
||||||
|
$data = $request->all();
|
||||||
|
$data['status'] = true;
|
||||||
|
$modelClass::create($data);
|
||||||
|
|
||||||
|
return redirect()
|
||||||
|
->route('basicdata.' . $type .'.index')
|
||||||
|
->with('success', 'created successfully');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function editData($type, $id)
|
||||||
|
{
|
||||||
|
$dataMap = [
|
||||||
|
'bentuk-tanah' => ['Bentuk Tanah', 'bentuk-tanah', BentukTanah::class],
|
||||||
|
'kontur-tanah' => ['Kontur Tanah', 'kontur-tanah', KonturTanah::class],
|
||||||
|
'posisi-kavling' => ['Posisi Kavling', 'posisi-kavling', PosisiKavling::class],
|
||||||
|
'ketinggian-tanah' => ['Ketinggian Tanah', 'ketinggian-tanah', KetinggianTanah::class],
|
||||||
|
'kondisi-fisik-tanah' => ['Kondisi Fisik Tanah', 'kondisi-fisik-tanah', KondisiFisikTanah::class],
|
||||||
|
'jenis-bangunan' => ['Jenis Bangunan', 'jenis-bangunan', JenisBangunan::class],
|
||||||
|
'kondisi-bangunan' => ['Kondisi Bangunan', 'kondisi-bangunan', KondisiBangunan::class],
|
||||||
|
'sifat-bangunan' => ['Sifat Bangunan', 'sifat-bangunan', SifatBangunan::class],
|
||||||
|
'spek-bangunan' => ['Spek Bangunan', 'spek-bangunan', SpekBangunan::class],
|
||||||
|
'spek-kategori-bangunan' => ['Spek Kategori Bangunan', 'spek-kategori-bangunan', SpekKategoritBangunan::class],
|
||||||
|
'sarana-pelengkap' => ['Sarana Pelengkap', 'sarana-pelengkap', SaranaPelengkap::class],
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
if (!array_key_exists($type, $dataMap)) {
|
||||||
|
return redirect()->back()->with('error', 'Invalid type specified.');
|
||||||
|
}
|
||||||
|
|
||||||
|
[$headers, $routeName, $modelClass] = $dataMap[$type];
|
||||||
|
|
||||||
|
$header = $dataMap[$type] ?? '';
|
||||||
|
$model = $modelClass::findOrFail($id);
|
||||||
|
|
||||||
|
return view('lpj::surveyor.data.form', compact('header', 'model'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function updateData(SurveyorRequest $request, $type, $id)
|
||||||
|
{
|
||||||
|
$validate = $request->validated();
|
||||||
|
if ($validate) {
|
||||||
|
$modelClasses = [
|
||||||
|
'bentuk-tanah' => BentukTanah::class,
|
||||||
|
'kontur-tanah' => KonturTanah::class,
|
||||||
|
'posisi-kavling' => PosisiKavling::class,
|
||||||
|
'ketinggian-tanah' => KetinggianTanah::class,
|
||||||
|
'kondisi-fisik-tanah' => KondisiFisikTanah::class,
|
||||||
|
'jenis-bangunan' => JenisBangunan::class,
|
||||||
|
'kondisi-bangunan' => KondisiBangunan::class,
|
||||||
|
'sifat-bangunan' => SifatBangunan::class,
|
||||||
|
'sarana-pelengkap' => SaranaPelengkap::class,
|
||||||
|
|
||||||
|
];
|
||||||
|
|
||||||
|
// Check if the provided type exists in the modelClasses
|
||||||
|
if (!array_key_exists($type, $modelClasses)) {
|
||||||
|
return redirect()
|
||||||
|
->route('basicdata.' . $type . '.index')
|
||||||
|
->with('error', 'Invalid type specified.');
|
||||||
|
}
|
||||||
|
$modelClass = $modelClasses[$type];
|
||||||
|
$model = $modelClass::findOrFail($id);
|
||||||
|
$model->update($validate);
|
||||||
|
|
||||||
|
// Redirect back with a success message
|
||||||
|
return redirect()
|
||||||
|
->route('basicdata.' . $type . '.index')
|
||||||
|
->with('success', 'Updated successfully');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function dataForDatatablesData(Request $request, $type)
|
||||||
|
{
|
||||||
|
if (is_null($this->user) || !$this->user->can('jenis_aset.view')) {
|
||||||
|
//abort(403, 'Sorry! You are not allowed to view users.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve data from the database
|
||||||
|
|
||||||
|
$models = [
|
||||||
|
'Bentuk Tanah' => BentukTanah::class,
|
||||||
|
'Kontur Tanah' => KonturTanah::class,
|
||||||
|
'Posisi Kavling' => PosisiKavling::class,
|
||||||
|
'Ketinggian Tanah' => KetinggianTanah::class,
|
||||||
|
'Kondisi Fisik Tanah' => KondisiFisikTanah::class,
|
||||||
|
'Jenis Bangunan' => JenisBangunan::class,
|
||||||
|
'Kondisi Bangunan' => KondisiBangunan::class,
|
||||||
|
'Sifat Bangunan' => SifatBangunan::class,
|
||||||
|
// 'Spek Kategori Bangunan' => SpekKategoritBangunan::class,
|
||||||
|
// 'Spek Bangunan' => SpekBangunan::class,
|
||||||
|
'Sarana Pelengkap' => SaranaPelengkap::class,
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
if (array_key_exists($type, $models)) {
|
||||||
|
$query = $models[$type]::query();
|
||||||
|
} else {
|
||||||
|
throw new InvalidArgumentException("Invalid type: $type");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = $request->get('search');
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('code', 'LIKE', "%$search%");
|
||||||
|
$q->orWhere('name', 'LIKE', "%$search%");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply sorting if provided
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the total count of records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the filtered count of records
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
// Get the data for the current page
|
||||||
|
$data = $query->get();
|
||||||
|
|
||||||
|
// Calculate the page count
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
// Calculate the current page number
|
||||||
|
$currentPage = 0 + 1;
|
||||||
|
|
||||||
|
// Return the response data as a JSON object
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function destroy($id, $type)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
|
||||||
|
$modelClasses = [
|
||||||
|
'bentuk-tanah' => BentukTanah::class,
|
||||||
|
'kontur-tanah' => KonturTanah::class,
|
||||||
|
'posisi-kavling' => PosisiKavling::class,
|
||||||
|
'ketinggian-tanah' => KetinggianTanah::class,
|
||||||
|
'kondisi-fisik-tanah' => KondisiFisikTanah::class,
|
||||||
|
'jenis-bangunan' => JenisBangunan::class,
|
||||||
|
'kondisi-bangunan' => KondisiBangunan::class,
|
||||||
|
'sifat-bangunan' => SifatBangunan::class,
|
||||||
|
'sarana-pelengkap' => SaranaPelengkap::class,
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
if (!array_key_exists($type, $modelClasses)) {
|
||||||
|
return response()->json(['success' => false, 'message' => 'Invalid type specified.'], 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
$modelClass = $modelClasses[$type];
|
||||||
|
$model = $modelClass::findOrFail($id);
|
||||||
|
|
||||||
|
$model->delete();
|
||||||
|
return response()->json(['success' => true, 'message' => 'deleted successfully']);
|
||||||
|
} catch (ModelNotFoundException $e) {
|
||||||
|
return response()->json(['success' => false, 'message' => 'not found.'], 404);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return response()->json(['success' => false, 'message' => 'Failed to delete.'], 500);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
64
app/Http/Requests/SurveyorRequest.php
Normal file
64
app/Http/Requests/SurveyorRequest.php
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class SurveyorRequest extends FormRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
: array
|
||||||
|
{
|
||||||
|
|
||||||
|
$action = $this->input('action');
|
||||||
|
|
||||||
|
$uniqueTable = [
|
||||||
|
'bentuk-tanah' => 'bentuk_tanah',
|
||||||
|
'kontur-tanah' => 'kontur_tanah',
|
||||||
|
'posisi-kavling' => 'posisi_kavling',
|
||||||
|
'ketinggian-tanah' => 'ketinggian_tanah',
|
||||||
|
'kondisi-fisik-tanah' => 'kondisi_fisik_tanah',
|
||||||
|
'kondisi-bangunan' => 'kondisi_bangunan',
|
||||||
|
'sifat-bangunan' => 'sifat_bangunan',
|
||||||
|
'sarana-pelengkap' => 'sarana_pelengkap',
|
||||||
|
'lalu_lintas_lokasi' => 'lalu_lintas_lokasi',
|
||||||
|
'tingkat-keramaian' => 'tingkat_keramaian',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$rules = [
|
||||||
|
'name' => 'required|max:255',
|
||||||
|
|
||||||
|
];
|
||||||
|
|
||||||
|
$id = $this->route('id');
|
||||||
|
|
||||||
|
if ($this->method() == 'PUT' || $this->method() == 'PATCH') {
|
||||||
|
$rules['code'] = 'required|max:50|unique:' . $uniqueTable[$action] . ',code,' . $id;
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$rules['code'] = 'required|max:50|unique:' . $uniqueTable[$action] . ',code';
|
||||||
|
}
|
||||||
|
return $rules;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
: bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function prepareForValidation()
|
||||||
|
{
|
||||||
|
$this->merge([
|
||||||
|
'status' => true,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -14,7 +14,8 @@ class BentukTanah extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
|
|
||||||
protected static function newFactory(): BentukTanahFactory
|
protected static function newFactory(): BentukTanahFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -15,8 +15,7 @@ class JenisBangunan extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): JenisBangunanFactory
|
protected static function newFactory(): JenisBangunanFactory
|
||||||
{
|
{
|
||||||
//return JenisBangunanFactory::new();
|
//return JenisBangunanFactory::new();
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class KetinggianTanah extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): KetinggianTanahFactory
|
protected static function newFactory(): KetinggianTanahFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ class KondisiFisikTanah extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): KondisiFisikTanahFactory
|
protected static function newFactory(): KondisiFisikTanahFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ class KonturTanah extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): KonturTanahFactory
|
protected static function newFactory(): KonturTanahFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,22 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Models;
|
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
||||||
use Modules\Lpj\Database\Factories\LaliLintasLokasiFactory;
|
|
||||||
|
|
||||||
class LaliLintasLokasi extends Model
|
|
||||||
{
|
|
||||||
use HasFactory;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The attributes that are mass assignable.
|
|
||||||
*/
|
|
||||||
protected $fillable = [];
|
|
||||||
|
|
||||||
protected static function newFactory(): LaliLintasLokasiFactory
|
|
||||||
{
|
|
||||||
//return LaliLintasLokasiFactory::new();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -9,11 +9,12 @@ use Modules\Lpj\Database\Factories\LaluLintasLokasiFactory;
|
|||||||
class LaluLintasLokasi extends Model
|
class LaluLintasLokasi extends Model
|
||||||
{
|
{
|
||||||
use HasFactory;
|
use HasFactory;
|
||||||
|
protected $table = 'lalu_lintas_lokasi';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): LaluLintasLokasiFactory
|
protected static function newFactory(): LaluLintasLokasiFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ class PerkerasanJalan extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): PerkerasanJalanFactory
|
protected static function newFactory(): PerkerasanJalanFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class PosisiKavling extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): PosisiKavlingFactory
|
protected static function newFactory(): PosisiKavlingFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class SaranaPelengkap extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): SaranaPelengkapFactory
|
protected static function newFactory(): SaranaPelengkapFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class SifatBangunan extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): SifatBangunanFactory
|
protected static function newFactory(): SifatBangunanFactory
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ class TingkatKeramaian extends Model
|
|||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*/
|
*/
|
||||||
protected $fillable = [];
|
protected $fillable = ['code', 'name', 'status'];
|
||||||
|
|
||||||
protected static function newFactory(): TingkatKeramaianFactory
|
protected static function newFactory(): TingkatKeramaianFactory
|
||||||
{
|
{
|
||||||
|
|||||||
72
module.json
72
module.json
@@ -344,13 +344,79 @@
|
|||||||
"roles": ["administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Bangunan",
|
"title": "Bentuk Tanah",
|
||||||
"path": "basicdata.ijin_usaha",
|
"path": "basicdata.bentuk-tanah",
|
||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["surveyor"]
|
"roles": ["surveyor"]
|
||||||
}
|
},
|
||||||
|
{
|
||||||
|
"title": "Kontur Tanah",
|
||||||
|
"path": "basicdata.kontur-tanah",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Posisi Kavling",
|
||||||
|
"path": "basicdata.posisi-kavling",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Ketinggian Tanah",
|
||||||
|
"path": "basicdata.ketinggian-tanah",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Kondisi Fisik Tanah",
|
||||||
|
"path": "basicdata.kondisi-fisik-tanah",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Jenis Bangunan",
|
||||||
|
"path": "basicdata.jenis-bangunan",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Kondisi Bangunan",
|
||||||
|
"path": "basicdata.kondisi-bangunan",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Sifat Bangunan",
|
||||||
|
"path": "basicdata.sifat-bangunan",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"title": "Sarana Pelengkap",
|
||||||
|
"path": "basicdata.sarana-pelengkap",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": ["surveyor"]
|
||||||
|
}
|
||||||
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -473,95 +473,6 @@
|
|||||||
</div>
|
</div>
|
||||||
@endsection
|
@endsection
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
{{-- <script>
|
|
||||||
document.addEventListener('DOMContentLoaded', function() {
|
|
||||||
let teamsSelect = document.getElementById('teams_id');
|
|
||||||
let penilaiSelect = document.getElementById('penilaian_id');
|
|
||||||
let surveyorSelect = document.getElementById('surveyor_id');
|
|
||||||
let penilaiSurveyorSelect = document.getElementById('penilai_surveyor_id');
|
|
||||||
|
|
||||||
let selectedSurveyorId = @json($penilaian->surveyor_id ?? null);
|
|
||||||
let selectedPenilaiId = @json($penilaian->penilaian_id ?? null);
|
|
||||||
let selectedPenilaiSurveyorId = @json($penilaian->penilai_surveyor_id ?? null);
|
|
||||||
|
|
||||||
function fetchPenilai(teamId) {
|
|
||||||
penilaiSelect.innerHTML = '<option value="">Pilih Penilai</option>';
|
|
||||||
surveyorSelect.innerHTML = '<option value="">Pilih Surveyor</option>';
|
|
||||||
penilaiSurveyorSelect.innerHTML = '<option value="">Pilih Penilai Surveyor</option>';
|
|
||||||
|
|
||||||
if (teamId) {
|
|
||||||
fetch(`/penilaian/getUserTeams/${teamId}`)
|
|
||||||
.then(response => response.json())
|
|
||||||
.then(data => {
|
|
||||||
if (data && data.length > 0) {
|
|
||||||
data.forEach((user) => {
|
|
||||||
let optionPenilai = document.createElement('option');
|
|
||||||
let optionSurveyor = document.createElement('option');
|
|
||||||
let optionPenilaiSurveyor = document.createElement('option');
|
|
||||||
|
|
||||||
optionPenilai.value = user.id;
|
|
||||||
optionSurveyor.value = user.id;
|
|
||||||
optionPenilaiSurveyor.value = user.id;
|
|
||||||
|
|
||||||
optionPenilai.text = user.name;
|
|
||||||
optionSurveyor.text = user.name;
|
|
||||||
optionPenilaiSurveyor.text = user.name;
|
|
||||||
|
|
||||||
// Tambahkan pengguna ke semua select
|
|
||||||
penilaiSelect.appendChild(optionPenilai);
|
|
||||||
surveyorSelect.appendChild(optionSurveyor);
|
|
||||||
penilaiSurveyorSelect.appendChild(optionPenilaiSurveyor);
|
|
||||||
|
|
||||||
if (selectedPenilaiId && selectedPenilaiId == user.id) {
|
|
||||||
optionPenilai.selected = true;
|
|
||||||
}
|
|
||||||
if (selectedSurveyorId && selectedSurveyorId == user.id) {
|
|
||||||
optionSurveyor.selected = true;
|
|
||||||
}
|
|
||||||
if (selectedPenilaiSurveyorId && selectedPenilaiSurveyorId == user
|
|
||||||
.id) {
|
|
||||||
optionPenilaiSurveyor.selected = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
let noUserOption = document.createElement('option');
|
|
||||||
noUserOption.value = '';
|
|
||||||
noUserOption.text = 'Tidak ada pengguna yang sesuai.';
|
|
||||||
penilaiSelect.appendChild(noUserOption);
|
|
||||||
surveyorSelect.appendChild(noUserOption.cloneNode(true));
|
|
||||||
penilaiSurveyorSelect.appendChild(noUserOption.cloneNode(true));
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.catch(error => {
|
|
||||||
console.error('Error fetching team members:', error);
|
|
||||||
let errorOption = document.createElement('option');
|
|
||||||
errorOption.value = '';
|
|
||||||
errorOption.text = 'Terjadi kesalahan.';
|
|
||||||
penilaiSelect.appendChild(errorOption);
|
|
||||||
surveyorSelect.appendChild(errorOption.cloneNode(true));
|
|
||||||
penilaiSurveyorSelect.appendChild(errorOption.cloneNode(true));
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
let defaultOption = document.createElement('option');
|
|
||||||
defaultOption.value = '';
|
|
||||||
defaultOption.text = 'Pilih tim terlebih dahulu.';
|
|
||||||
penilaiSelect.appendChild(defaultOption);
|
|
||||||
surveyorSelect.appendChild(defaultOption.cloneNode(true));
|
|
||||||
penilaiSurveyorSelect.appendChild(defaultOption.cloneNode(true));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
teamsSelect.addEventListener('change', function() {
|
|
||||||
let teamId = this.value;
|
|
||||||
fetchPenilai(teamId);
|
|
||||||
});
|
|
||||||
|
|
||||||
let selectedTeamId = teamsSelect.value;
|
|
||||||
if (selectedTeamId) {
|
|
||||||
fetchPenilai(selectedTeamId);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script> --}}
|
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener('DOMContentLoaded', function() {
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
@endpush
|
@endpush
|
||||||
|
|
||||||
|
|
||||||
<form action="{{ isset($debitur->id) ? route('debitur.update', $debitur->id) : route('debitur.store') }}" method="POST"
|
<form id="debiturForm" action="{{ isset($debitur->id) ? route('debitur.update', $debitur->id) : route('debitur.store') }}" method="POST"
|
||||||
class="grid gap-5">
|
class="grid gap-5">
|
||||||
@if (isset($debitur->id))
|
@if (isset($debitur->id))
|
||||||
<input type="hidden" name="id" value="{{ $debitur->id }}">
|
<input type="hidden" name="id" value="{{ $debitur->id }}">
|
||||||
@@ -478,6 +478,15 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="flex justify-end gap-2" style="margin-right: 20px; margin-top: 20px">
|
||||||
|
<button type="submit" class="btn btn-success">
|
||||||
|
Save
|
||||||
|
</button>
|
||||||
|
<button type="submit" class="btn btn-primary">
|
||||||
|
Submit
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
|
||||||
@@ -521,4 +530,71 @@
|
|||||||
window.onload = getUserLocation;
|
window.onload = getUserLocation;
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
// Fungsi untuk menyimpan data ke localStorage saat ada perubahan input
|
||||||
|
|
||||||
|
|
||||||
|
const formElement = document.getElementById('debiturForm');
|
||||||
|
|
||||||
|
// Mengambil nilai dari localStorage saat halaman dimuat
|
||||||
|
window.onload = () => {
|
||||||
|
const storedData = localStorage.getItem('debiturData');
|
||||||
|
if (storedData) {
|
||||||
|
const formData = JSON.parse(storedData);
|
||||||
|
// Mengisi nilai untuk elemen select
|
||||||
|
for (const [key, value] of Object.entries(formData)) {
|
||||||
|
const inputElement = formElement.querySelector(`[name="${key}"]`);
|
||||||
|
if (inputElement) {
|
||||||
|
if (inputElement.tagName === 'SELECT') {
|
||||||
|
inputElement.value = value; // Atur nilai select
|
||||||
|
} else if (inputElement.type === 'radio') {
|
||||||
|
const radioButton = document.getElementById(`${key}${value.charAt(0).toUpperCase() + value.slice(1)}`);
|
||||||
|
if (radioButton) {
|
||||||
|
radioButton.checked = true; // Atur radio button yang sesuai sebagai checked
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Simpan data ke localStorage dalam bentuk JSON
|
||||||
|
formElement.addEventListener('change', () => {
|
||||||
|
const formData = {};
|
||||||
|
const inputs = formElement.querySelectorAll('input, select');
|
||||||
|
|
||||||
|
inputs.forEach(input => {
|
||||||
|
if (input.type === 'radio' && input.checked) {
|
||||||
|
formData[input.name] = input.value; // Hanya ambil nilai radio yang terpilih
|
||||||
|
} else if (input.type !== 'radio') {
|
||||||
|
formData[input.name] = input.value; // Ambil nilai dari elemen lain
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
localStorage.setItem('debiturData', JSON.stringify(formData)); // Simpan objek sebagai JSON
|
||||||
|
});
|
||||||
|
|
||||||
|
// Opsi: Reset localStorage saat form disubmit
|
||||||
|
formElement.onsubmit = () => {
|
||||||
|
localStorage.removeItem('debiturData'); // Menghapus data spesifik dari localStorage
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Opsi: Reset localStorage saat form disubmit
|
||||||
|
document.getElementById('debiturForm').onsubmit = (event) => {
|
||||||
|
event.preventDefault(); // Mencegah pengiriman form
|
||||||
|
|
||||||
|
// Menyimpan semua input ke localStorage
|
||||||
|
inputs.forEach(input => {
|
||||||
|
localStorage.setItem(input.name, input.value);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Opsional: Tampilkan pesan bahwa data telah disimpan
|
||||||
|
alert('Data telah disimpan ke localStorage!');
|
||||||
|
|
||||||
|
// Jika ingin menghapus localStorage, uncomment baris di bawah
|
||||||
|
// localStorage.clear();
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
@endpush
|
@endpush
|
||||||
|
|||||||
@@ -35,7 +35,7 @@
|
|||||||
<option value="">Select Hadap Mata Angin</option>
|
<option value="">Select Hadap Mata Angin</option>
|
||||||
@if (isset($arahMataAngin))
|
@if (isset($arahMataAngin))
|
||||||
@foreach ($arahMataAngin as $item)
|
@foreach ($arahMataAngin as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -56,7 +56,7 @@
|
|||||||
<option value="">Select Bentuk Tanah</option>
|
<option value="">Select Bentuk Tanah</option>
|
||||||
@if (isset($bentukTanah))
|
@if (isset($bentukTanah))
|
||||||
@foreach ($bentukTanah as $item)
|
@foreach ($bentukTanah as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -76,7 +76,7 @@
|
|||||||
<option value="">Select Kontur Tanah</option>
|
<option value="">Select Kontur Tanah</option>
|
||||||
@if (isset($konturTanah))
|
@if (isset($konturTanah))
|
||||||
@foreach ($konturTanah as $item)
|
@foreach ($konturTanah as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -98,7 +98,7 @@
|
|||||||
<option value="">Select Ketinggian Dengan Jalan</option>
|
<option value="">Select Ketinggian Dengan Jalan</option>
|
||||||
@if (isset($ketinggianTanah))
|
@if (isset($ketinggianTanah))
|
||||||
@foreach ($ketinggianTanah as $item)
|
@foreach ($ketinggianTanah as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -142,7 +142,7 @@
|
|||||||
<option value="">Select Posisi Kavling</option>
|
<option value="">Select Posisi Kavling</option>
|
||||||
@if (isset($posisiKavling))
|
@if (isset($posisiKavling))
|
||||||
@foreach ($posisiKavling as $item)
|
@foreach ($posisiKavling as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -207,7 +207,7 @@
|
|||||||
<option value="">Select Posisi Kavling</option>
|
<option value="">Select Posisi Kavling</option>
|
||||||
@if (isset($kondisiFisikTanah))
|
@if (isset($kondisiFisikTanah))
|
||||||
@foreach ($kondisiFisikTanah as $item)
|
@foreach ($kondisiFisikTanah as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -258,7 +258,7 @@
|
|||||||
<option value="">Select Jenis Bangunan</option>
|
<option value="">Select Jenis Bangunan</option>
|
||||||
@if (isset($jenisBangunan))
|
@if (isset($jenisBangunan))
|
||||||
@foreach ($jenisBangunan as $item)
|
@foreach ($jenisBangunan as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -279,7 +279,7 @@
|
|||||||
<option value="">Select Kondisi Bangunan</option>
|
<option value="">Select Kondisi Bangunan</option>
|
||||||
@if (isset($kondisiBangunan))
|
@if (isset($kondisiBangunan))
|
||||||
@foreach ($kondisiBangunan as $item)
|
@foreach ($kondisiBangunan as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -300,7 +300,7 @@
|
|||||||
<option value="">Select Sifat Bangunan</option>
|
<option value="">Select Sifat Bangunan</option>
|
||||||
@if (isset($sifatBangunan))
|
@if (isset($sifatBangunan))
|
||||||
@foreach ($sifatBangunan as $item)
|
@foreach ($sifatBangunan as $item)
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
<option value="{{ $item->name }}">{{ $item->name }}</option>
|
||||||
@endforeach
|
@endforeach
|
||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
@@ -330,7 +330,7 @@
|
|||||||
@if (isset($spekBangunan))
|
@if (isset($spekBangunan))
|
||||||
@foreach ($spekBangunan as $spek)
|
@foreach ($spekBangunan as $spek)
|
||||||
@if ($spek->spek_kategori_bagunan_id == $item->id)
|
@if ($spek->spek_kategori_bagunan_id == $item->id)
|
||||||
<option value="{{ $spek->id }}">{{ $spek->name }}
|
<option value="{{ $spek->name }}">{{ $spek->name }}
|
||||||
</option>
|
</option>
|
||||||
@endif
|
@endif
|
||||||
@endforeach
|
@endforeach
|
||||||
|
|||||||
63
resources/views/surveyor/data/form.blade.php
Normal file
63
resources/views/surveyor/data/form.blade.php
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
{{-- @section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
||||||
|
@endsection --}}
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
@if (isset($model->id))
|
||||||
|
<form action="{{ route('basicdata.updateData', ['type' => $header[1], 'id' => $model->id]) }}" method="POST">
|
||||||
|
<input type="hidden" name="id" value="{{ $model->id ?? '' }}">
|
||||||
|
@method('PUT')
|
||||||
|
@else
|
||||||
|
<form method="POST" action="{{ route('basicdata.storeData', ['type' => $header[1]]) }}">
|
||||||
|
@endif
|
||||||
|
@csrf
|
||||||
|
<div class="card pb-2.5">
|
||||||
|
<input type="hidden" name="action" value="{{ $header[1] }}">
|
||||||
|
<div class="card-header" id="basic_settings">
|
||||||
|
<h3 class="card-title">
|
||||||
|
{{ isset($jenisAset->id) ? 'Edit' : 'Tambah' }} {{ $header[0] }}
|
||||||
|
</h3>
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
<a href="{{ route('basicdata.' . $header[1] . '.index') }}" class="btn btn-xs btn-info">
|
||||||
|
<i class="ki-filled ki-exit-left"></i> Back
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-5">
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">
|
||||||
|
Code
|
||||||
|
</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('code') border-danger bg-danger-light @enderror" type="text"
|
||||||
|
name="code" value="{{ $model->code ?? '' }}" >
|
||||||
|
@error('code')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">
|
||||||
|
Name
|
||||||
|
</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('name') border-danger bg-danger-light @enderror" type="text"
|
||||||
|
name="name" value="{{ $model->name ?? '' }}">
|
||||||
|
@error('name')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex justify-end">
|
||||||
|
<button type="submit" class="btn btn-primary">
|
||||||
|
Save
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
153
resources/views/surveyor/data/index.blade.php
Normal file
153
resources/views/surveyor/data/index.blade.php
Normal file
@@ -0,0 +1,153 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
{{-- @section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('surveyor.bentuk-tanah') }}
|
||||||
|
@endsection --}}
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="grid">
|
||||||
|
<div class="card card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="data-table" data-api-url="{{ route('basicdata.datatablesSurveyory', ['type' => $header[0] ]) }}">
|
||||||
|
<div class="card-header py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Daftar {{$header[0]}}
|
||||||
|
</h3>
|
||||||
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
|
<div class="flex">
|
||||||
|
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
||||||
|
<input placeholder="Search {{$header[0]}}" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-wrap gap-2.5">
|
||||||
|
<div class="h-[24px] border border-r-gray-200"></div>
|
||||||
|
<a class="btn btn-sm btn-light" href=""> Export to Excel </a>
|
||||||
|
|
||||||
|
@php
|
||||||
|
$href = route('basicdata.createData', ['type' => $header[1]]);
|
||||||
|
@endphp
|
||||||
|
|
||||||
|
<a class="btn btn-sm btn-primary" href="{{$href}}"> Tambah {{$header[0]}} </a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[250px]" data-datatable-column="code">
|
||||||
|
<span class="sort"> <span class="sort-label"> Code </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[250px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Aset </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="text/javascript">
|
||||||
|
function deleteData(data) {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Are you sure?',
|
||||||
|
text: "You won't be able to revert this!",
|
||||||
|
icon: 'warning',
|
||||||
|
showCancelButton: true,
|
||||||
|
confirmButtonColor: '#3085d6',
|
||||||
|
cancelButtonColor: '#d33',
|
||||||
|
confirmButtonText: 'Yes, delete it!'
|
||||||
|
}).then((result) => {
|
||||||
|
if (result.isConfirmed) {
|
||||||
|
$.ajaxSetup({
|
||||||
|
headers: {
|
||||||
|
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$.ajax(`basic-data/deleteData/${data}/{{$header[1]}}`, {
|
||||||
|
type: 'DELETE'
|
||||||
|
}).then((response) => {
|
||||||
|
swal.fire('Deleted!', 'User has been deleted.', 'success').then(() => {
|
||||||
|
window.location.reload();
|
||||||
|
});
|
||||||
|
}).catch((error) => {
|
||||||
|
console.error('Error:', error);
|
||||||
|
Swal.fire('Error!', 'An error occurred while deleting the file.', 'error');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#data-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
|
||||||
|
const header = '{{$header[1]}}';
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
code: {
|
||||||
|
title: 'Code',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Jenis Aset',
|
||||||
|
},
|
||||||
|
actions: {
|
||||||
|
title: 'Status',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `<div class="flex flex-nowrap justify-center">
|
||||||
|
<a class="btn btn-sm btn-icon btn-clear btn-info" href="basic-data/${header}/${data.id}">
|
||||||
|
<i class="ki-outline ki-notepad-edit"></i>
|
||||||
|
</a>
|
||||||
|
<a onclick="deleteData(${data.id})" class="delete btn btn-sm btn-icon btn-clear btn-danger">
|
||||||
|
<i class="ki-outline ki-trash"></i>
|
||||||
|
</a>
|
||||||
|
</div>`;
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
// Custom search functionality
|
||||||
|
searchInput.addEventListener('input', function () {
|
||||||
|
const searchValue = this.value.trim();
|
||||||
|
dataTable.search(searchValue, true);
|
||||||
|
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
|
|
||||||
@@ -176,14 +176,7 @@
|
|||||||
@include('lpj::surveyor.components.data-pembanding')
|
@include('lpj::surveyor.components.data-pembanding')
|
||||||
@endif
|
@endif
|
||||||
</div>
|
</div>
|
||||||
<div class="flex justify-end gap-2" style="margin-right: 20px; margin-top: 20px">
|
|
||||||
<button type="submit" class="btn btn-success">
|
|
||||||
Save
|
|
||||||
</button>
|
|
||||||
<button type="submit" class="btn btn-primary">
|
|
||||||
Submit
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@endsection
|
@endsection
|
||||||
|
|||||||
@@ -357,6 +357,35 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::resource('jenis_laporan', JenisLaporanController::class);
|
Route::resource('jenis_laporan', JenisLaporanController::class);
|
||||||
// End Activity Jenis Laporan route
|
// End Activity Jenis Laporan route
|
||||||
|
|
||||||
|
// basic data surveyor
|
||||||
|
Route::get('datatablesSurveyory/{type}', [SurveyorController::class, 'dataForDatatablesData'])->name('datatablesSurveyory');
|
||||||
|
Route::get('createData/{type}', [SurveyorController::class, 'createData'])->name('createData');
|
||||||
|
Route::get('/{type}/{id}', [SurveyorController::class, 'editData'])->name('editData');
|
||||||
|
Route::post('storeData/{type}', [SurveyorController::class, 'storeData'])->name('storeData');
|
||||||
|
Route::put('updateData/{type}/{id}', [SurveyorController::class, 'updateData'])->name('updateData');
|
||||||
|
Route::delete('deleteData/{id}/{type}', [SurveyorController::class, 'destroy'])->name('deleteData');
|
||||||
|
|
||||||
|
$headers = [
|
||||||
|
'bentuk-tanah' => 'Bentuk Tanah',
|
||||||
|
'kontur-tanah' => 'Kontur Tanah',
|
||||||
|
'posisi-kavling' => 'Posisi Kavling',
|
||||||
|
'ketinggian-tanah' => 'Ketinggian Tanah',
|
||||||
|
'kondisi-fisik-tanah' => 'Kondisi Fisik Tanah',
|
||||||
|
'jenis-bangunan' => 'Jenis Bangunan',
|
||||||
|
'kondisi-bangunan' => 'Kondisi Bangunan',
|
||||||
|
'sifat-bangunan' => 'Sifat Bangunan',
|
||||||
|
// 'spek-bangunan' => 'Speksifikasi Bangunan',
|
||||||
|
// 'spek-kategori-bagunan' => 'Speksifikasi Kategori Bangunan',
|
||||||
|
'sarana-pelengkap' => 'Sarana Pelengkap',
|
||||||
|
];
|
||||||
|
|
||||||
|
foreach ($headers as $type => $header) {
|
||||||
|
Route::get($type, [SurveyorController::class, 'data'])
|
||||||
|
->name($type . '.index')
|
||||||
|
->defaults('type', $type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -506,6 +535,8 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::get('denah/{id}', [SurveyorController::class, 'denah'])->name('denah');
|
Route::get('denah/{id}', [SurveyorController::class, 'denah'])->name('denah');
|
||||||
Route::get('foto/{id}', [SurveyorController::class, 'foto'])->name('foto');
|
Route::get('foto/{id}', [SurveyorController::class, 'foto'])->name('foto');
|
||||||
Route::get('data-pembanding/{id}', [SurveyorController::class, 'dataPembanding'])->name('data-pembanding');
|
Route::get('data-pembanding/{id}', [SurveyorController::class, 'dataPembanding'])->name('data-pembanding');
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user