MIF_E31221264/app/Http/Controllers/PakaianController.php

219 lines
6.7 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\Pakaian;
use App\Models\Kriteria;
use App\Models\SubKriteria;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Storage;
class PakaianController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index(Request $request)
{
$kriteria = Kriteria::all();
$perPage = $request->input('entries', 10);
$search = $request->input('search');
$alternatif = Pakaian::with(['subKriterias.kriteria'])
->when($search, function ($query, $search) {
$query->where('nama_pakaian', 'like', '%' . $search . '%');
})
->paginate($perPage)
->appends($request->query());
return view('admin.pages.pakaian.index', compact('kriteria', 'alternatif'));
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
$kriterias = Kriteria::with('subKriteria')->get(); // load kriteria + sub_kriterias
return view('admin.pages.pakaian.create', compact('kriterias'));
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
$request->validate([
'nama_pakaian' => 'required|string|max:255',
'harga' => 'required|numeric',
'img' => 'nullable|image|max:2048',
'sub_kriterias' => 'nullable',
'deskripsi' => 'nullable|string|max:1000',
]);
DB::beginTransaction();
try {
// Upload image jika ada
$path = null;
if ($request->hasFile('img')) {
$path = $request->file('img')->store('pakaian', 'public');
}
// Simpan pakaian
$pakaian = Pakaian::create([
'nama_pakaian' => $request->nama_pakaian,
'harga' => $request->harga,
'img' => $path ? 'storage/' . $path : null,
'deskripsi' => $request->deskripsi,
]);
$inputSub = $request->input('sub_kriterias', []);
$subkriteriaIds = [];
foreach ($inputSub as $key => $value) {
if (is_array($value)) {
$subkriteriaIds = array_merge($subkriteriaIds, $value);
} else {
$subkriteriaIds[] = $value;
}
}
$pakaian->subKriterias()->sync($subkriteriaIds);
// Tambahkan penilaian default untuk semua subkriteria
$allSubkriterias = SubKriteria::all();
foreach ($allSubkriterias as $sub) {
\App\Models\PenilaianPakaian::firstOrCreate([
'pakaian_id' => $pakaian->id,
'sub_kriteria_id' => $sub->id,
], [
'nilai' => 3 // bisa disesuaikan nilai defaultnya
]);
}
DB::commit();
return redirect()->route('admin.pakaian.index', ['page' => $request->input('page')])
->with('success', 'Pakaian berhasil ditambahkan.');
} catch (\Exception $e) {
// Rollback semua jika ada error
DB::rollBack();
// Hapus file yang sudah di-upload jika perlu
if ($path && Storage::disk('public')->exists($path)) {
Storage::disk('public')->delete($path);
}
return redirect()->back()->with('error', 'Gagal menambahkan pakaian: ' . $e->getMessage());
}
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit($id)
{
$pakaian = Pakaian::with('subKriterias')->findOrFail($id);
$kriterias = Kriteria::with('subKriteria')->get();
return view('admin.pages.pakaian.edit', compact('pakaian', 'kriterias'));
}
public function update(Request $request, $id)
{
$request->validate([
'nama_pakaian' => 'required|string|max:255',
'harga' => 'required|numeric',
'img' => 'nullable|image|max:2048',
'sub_kriterias' => 'array|nullable',
'deskripsi' => 'nullable|string|max:1000',
]);
DB::beginTransaction();
try {
$pakaian = Pakaian::findOrFail($id);
$path = $pakaian->img;
if ($request->hasFile('img')) {
// Hapus gambar lama dari storage
if ($pakaian->img && Storage::disk('public')->exists(str_replace('storage/', '', $pakaian->img))) {
Storage::disk('public')->delete(str_replace('storage/', '', $pakaian->img));
}
// Simpan gambar baru
$storedPath = $request->file('img')->store('pakaian', 'public');
$path = 'storage/' . $storedPath;
}
$pakaian->update([
'nama_pakaian' => $request->nama_pakaian,
'harga' => $request->harga,
'img' => $path,
'deskripsi' => $request->deskripsi,
]);
// Update relasi sub_kriterias
$inputSub = $request->input('sub_kriterias', []);
$subkriteriaIds = [];
foreach ($inputSub as $key => $value) {
if (is_array($value)) {
$subkriteriaIds = array_merge($subkriteriaIds, $value);
} else {
$subkriteriaIds[] = $value;
}
}
$pakaian->subKriterias()->sync($subkriteriaIds);
DB::commit();
return redirect()->route('admin.pakaian.index', ['page' => $request->input('page')])
->with('success', 'Pakaian berhasil diperbarui.');
} catch (\Exception $e) {
DB::rollBack();
return redirect()->back()->with('error', 'Gagal memperbarui pakaian: ' . $e->getMessage());
}
}
/**
* Remove the specified resource from storage.
*/
public function destroy(Request $request, string $id)
{
$pakaian = Pakaian::findOrFail($id);
// Hapus gambar dari storage jika ada
if ($pakaian->img && Storage::disk('public')->exists(str_replace('storage/', '', $pakaian->img))) {
Storage::disk('public')->delete(str_replace('storage/', '', $pakaian->img));
}
// Hapus relasi subkriteria (pivot table)
$pakaian->subKriterias()->detach();
// Hapus data pakaian dari database
$pakaian->delete();
return redirect()->route('admin.pakaian.index', ['page' => $request->input('page')])
->with('success', 'Data pakaian berhasil dihapus.');
}
}