search; $tps = LokasiTps::with('kategori') ->withCount('aduan') ->when($search, function ($query) use ($search) { $query->where('nama_tps', 'like', '%' . $search . '%'); }) ->orderBy('id_tps', 'desc') ->paginate(10); return view('admin.tps.index', compact('title', 'tps', 'search')); } 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; } private function rules($isUpdate = false) { return [ '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' => $isUpdate ? 'nullable|image|mimes:jpg,jpeg,png|max:4096' : 'required|image|mimes:jpg,jpeg,png|max:2048', ]; } private function messages() { return [ 'required' => ':attribute wajib diisi.', 'string' => ':attribute harus berupa teks.', 'integer' => ':attribute harus berupa angka.', 'digits' => ':attribute harus 4 digit.', 'min' => ':attribute minimal :min.', 'in' => ':attribute tidak valid.', 'image' => ':attribute harus berupa gambar.', 'mimes' => ':attribute harus format jpg, jpeg, png.', 'max' => ':attribute maksimal :max KB.', 'exists' => ':attribute tidak ditemukan.', ]; } private function attributes() { return [ 'kategori_tps_id' => 'Kategori TPS', 'nama_tps' => 'Nama TPS', 'alamat_tps' => 'Alamat TPS', 'status_tps' => 'Status TPS', 'tahun_pembuatan' => 'Tahun Pembuatan', 'kapasitas_tps' => 'Kapasitas TPS', 'latitude' => 'Latitude', 'longitude' => 'Longitude', 'foto_tps' => 'Foto TPS', ]; } public function store(Request $request) { $validator = Validator::make( $request->all(), $this->rules(), $this->messages(), $this->attributes() ); 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) { return back()->withErrors(['latitude' => 'Latitude tidak valid.'])->withInput(); } if ($longitude === null || $longitude < -180 || $longitude > 180) { return back()->withErrors(['longitude' => 'Longitude tidak valid.'])->withInput(); } $foto = $request->file('foto_tps')->store('tps', 'public'); 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(), $this->rules(true), $this->messages(), $this->attributes() ); 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) { return back()->withErrors(['latitude' => 'Latitude tidak valid.'])->withInput(); } if ($longitude === null || $longitude < -180 || $longitude > 180) { return back()->withErrors(['longitude' => 'Longitude tidak valid.'])->withInput(); } $foto = $tps->foto_tps; if ($request->hasFile('foto_tps')) { if ($tps->foto_tps) { Storage::disk('public')->delete($tps->foto_tps); } $foto = $request->file('foto_tps')->store('tps', 'public'); } $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); if ($tps->foto_tps) { Storage::disk('public')->delete($tps->foto_tps); } $tps->delete(); return redirect()->route('admin.tps.index') ->with('success', 'Data TPS berhasil dihapus.'); } }