209 lines
8.3 KiB
PHP
209 lines
8.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\Request;
|
|
use App\Models\LokasiTps;
|
|
use App\Models\KategoriTps;
|
|
use Illuminate\Support\Facades\Validator;
|
|
|
|
class TpsController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
$title = 'Data TPS';
|
|
$tps = LokasiTps::with('kategori')->withCount('aduan')->get();
|
|
return view('admin.tps.index', compact('title', 'tps'));
|
|
}
|
|
|
|
public function create()
|
|
{
|
|
$title = 'Tambah TPS';
|
|
$kategori = KategoriTps::all();
|
|
return view('admin.tps.create', compact('title', 'kategori'));
|
|
}
|
|
|
|
private function convertToDecimal($coordinate)
|
|
{
|
|
if (is_numeric($coordinate)) {
|
|
return (float) $coordinate;
|
|
}
|
|
|
|
if (!$coordinate) return null;
|
|
|
|
$coordinate = html_entity_decode($coordinate);
|
|
$coordinate = strtoupper(trim($coordinate));
|
|
$coordinate = str_replace(['°', "'", '"'], [' ', ' ', ' '], $coordinate);
|
|
|
|
preg_match('/([NSEW])/', $coordinate, $dir);
|
|
preg_match_all('/\d+(\.\d+)?/', $coordinate, $numbers);
|
|
|
|
if (!$dir || count($numbers[0]) < 3) return null;
|
|
|
|
[$deg, $min, $sec] = array_map('floatval', $numbers[0]);
|
|
$decimal = $deg + ($min / 60) + ($sec / 3600);
|
|
|
|
if (in_array($dir[1], ['S', 'W'])) $decimal *= -1;
|
|
|
|
return $decimal;
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
$validator = Validator::make($request->all(), [
|
|
'kategori_tps_id' => 'required|exists:kategori_tps,id_kategori_tps',
|
|
'nama_tps' => 'required|string|max:255',
|
|
'alamat_tps' => 'required|string|max:255',
|
|
'status_tps' => 'required|in:Aktif,Tidak Aktif,Pembangunan',
|
|
'tahun_pembuatan' => 'required|digits:4',
|
|
'kapasitas_tps' => 'required|integer|min:1',
|
|
'latitude' => 'required',
|
|
'longitude' => 'required',
|
|
'foto_tps' => 'required|image|mimes:jpg,jpeg,png|max:2048',
|
|
], [
|
|
'kategori_tps_id.required' => 'Kategori TPS wajib dipilih.',
|
|
'kategori_tps_id.exists' => 'Kategori TPS tidak valid.',
|
|
'nama_tps.required' => 'Nama TPS wajib diisi.',
|
|
'alamat_tps.required' => 'Alamat TPS wajib diisi.',
|
|
'status_tps.required' => 'Status TPS wajib dipilih.',
|
|
'status_tps.in' => 'Status TPS tidak valid.',
|
|
'tahun_pembuatan.required' => 'Tahun pembuatan wajib diisi.',
|
|
'tahun_pembuatan.digits' => 'Tahun pembuatan harus 4 digit.',
|
|
'kapasitas_tps.required' => 'Kapasitas TPS wajib diisi.',
|
|
'kapasitas_tps.integer' => 'Kapasitas TPS harus angka.',
|
|
'kapasitas_tps.min' => 'Kapasitas minimal 1.',
|
|
'latitude.required' => 'Latitude wajib diisi.',
|
|
'longitude.required' => 'Longitude wajib diisi.',
|
|
'foto_tps.required' => 'Foto TPS wajib diunggah.',
|
|
'foto_tps.image' => 'Foto TPS harus berupa gambar.',
|
|
'foto_tps.mimes' => 'Format foto harus jpg, jpeg, atau png.',
|
|
]);
|
|
|
|
if ($validator->fails()) return back()->withErrors($validator)->withInput();
|
|
|
|
$latitude = $this->convertToDecimal($request->latitude);
|
|
$longitude = $this->convertToDecimal($request->longitude);
|
|
|
|
if ($latitude === null || $latitude < -90 || $latitude > 90)
|
|
$validator->errors()->add('latitude', 'Latitude tidak valid.');
|
|
|
|
if ($longitude === null || $longitude < -180 || $longitude > 180)
|
|
$validator->errors()->add('longitude', 'Longitude tidak valid.');
|
|
|
|
if ($validator->fails()) return back()->withErrors($validator)->withInput();
|
|
|
|
// Upload foto ke public/assets/admin/images/tps
|
|
$foto = null;
|
|
if ($request->hasFile('foto_tps')) {
|
|
$file = $request->file('foto_tps');
|
|
$namaTps = strtoupper(preg_replace('/[^A-Za-z0-9]/', '', $request->nama_tps));
|
|
$extension = $file->getClientOriginalExtension();
|
|
$filename = strtolower(str_replace(' ', '_', $request->nama_tps)) . '_' . time() . '.' . $file->getClientOriginalExtension();
|
|
$file->move(public_path('assets/admin/images/tps'), $filename);
|
|
$foto = $filename;
|
|
}
|
|
|
|
LokasiTps::create([
|
|
'kategori_tps_id' => $request->kategori_tps_id,
|
|
'nama_tps' => $request->nama_tps,
|
|
'alamat_tps' => $request->alamat_tps,
|
|
'status_tps' => $request->status_tps,
|
|
'tahun_pembuatan' => $request->tahun_pembuatan,
|
|
'kapasitas_tps' => $request->kapasitas_tps,
|
|
'latitude' => $latitude,
|
|
'longitude' => $longitude,
|
|
'foto_tps' => $foto,
|
|
]);
|
|
|
|
return redirect()->route('admin.tps.index')->with('success', 'Data TPS berhasil ditambahkan.');
|
|
}
|
|
|
|
public function edit($id)
|
|
{
|
|
$title = 'Edit TPS';
|
|
$tps = LokasiTps::findOrFail($id);
|
|
$kategori = KategoriTps::all();
|
|
return view('admin.tps.edit', compact('title', 'tps', 'kategori'));
|
|
}
|
|
|
|
public function update(Request $request, $id)
|
|
{
|
|
$tps = LokasiTps::findOrFail($id);
|
|
|
|
$validator = Validator::make($request->all(), [
|
|
'kategori_tps_id' => 'required|exists:kategori_tps,id_kategori_tps',
|
|
'nama_tps' => 'required|string|max:255',
|
|
'alamat_tps' => 'required|string|max:255',
|
|
'status_tps' => 'required|in:Aktif,Tidak Aktif,Pembangunan',
|
|
'tahun_pembuatan' => 'required|digits:4',
|
|
'kapasitas_tps' => 'required|integer|min:1',
|
|
'latitude' => 'required',
|
|
'longitude' => 'required',
|
|
'foto_tps' => 'nullable|image|mimes:jpg,jpeg,png|max:4096',
|
|
]);
|
|
|
|
if ($validator->fails()) return back()->withErrors($validator)->withInput();
|
|
|
|
$latitude = $this->convertToDecimal($request->latitude);
|
|
$longitude = $this->convertToDecimal($request->longitude);
|
|
|
|
if ($latitude === null || $latitude < -90 || $latitude > 90)
|
|
$validator->errors()->add('latitude', 'Latitude tidak valid.');
|
|
|
|
if ($longitude === null || $longitude < -180 || $longitude > 180)
|
|
$validator->errors()->add('longitude', 'Longitude tidak valid.');
|
|
|
|
if ($validator->fails()) return back()->withErrors($validator)->withInput();
|
|
|
|
// Upload foto baru jika ada
|
|
$foto = $tps->foto_tps;
|
|
if ($request->hasFile('foto_tps')) {
|
|
if ($tps->foto_tps && file_exists(public_path($tps->foto_tps))) {
|
|
unlink(public_path($tps->foto_tps)); // hapus foto lama
|
|
}
|
|
|
|
$file = $request->file('foto_tps');
|
|
$namaTps = strtoupper(preg_replace('/[^A-Za-z0-9]/', '', $request->nama_tps));
|
|
$extension = $file->getClientOriginalExtension();
|
|
$filename = strtolower(str_replace(' ', '_', $request->nama_tps)) . '_' . time() . '.' . $file->getClientOriginalExtension();
|
|
|
|
$file->move(public_path('assets/admin/images/tps'), $filename);
|
|
$foto = $filename;
|
|
}
|
|
|
|
$tps->update([
|
|
'kategori_tps_id' => $request->kategori_tps_id,
|
|
'nama_tps' => $request->nama_tps,
|
|
'alamat_tps' => $request->alamat_tps,
|
|
'status_tps' => $request->status_tps,
|
|
'tahun_pembuatan' => $request->tahun_pembuatan,
|
|
'kapasitas_tps' => $request->kapasitas_tps,
|
|
'latitude' => $latitude,
|
|
'longitude' => $longitude,
|
|
'foto_tps' => $foto,
|
|
]);
|
|
|
|
return redirect()->route('admin.tps.index')->with('success', 'Data TPS berhasil diperbarui.');
|
|
}
|
|
|
|
public function destroy($id)
|
|
{
|
|
$tps = LokasiTps::findOrFail($id);
|
|
|
|
// Path lengkap foto TPS
|
|
$fotoPath = $tps->foto_tps ? public_path('assets/admin/images/tps/' . $tps->foto_tps) : null;
|
|
|
|
// Hapus file jika ada
|
|
if ($fotoPath && file_exists($fotoPath)) {
|
|
unlink($fotoPath);
|
|
}
|
|
|
|
// Hapus data dari database
|
|
$tps->delete();
|
|
|
|
return redirect()->route('admin.tps.index')
|
|
->with('success', 'Data TPS berhasil dihapus.');
|
|
}
|
|
}
|