219 lines
6.7 KiB
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.');
|
|
}
|
|
|
|
}
|