Merge pull request #11 from LailaWulandarii/development

Development
This commit is contained in:
Laila Wulandari 2026-02-28 08:53:04 +07:00 committed by GitHub
commit 6939000238
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 46 additions and 0 deletions

View File

@ -7,6 +7,7 @@
use App\Models\PaketFoto;
use App\Http\Requests\Admin\FotoRequest; // Gunakan Request baru
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\Auth;
class FotoController extends Controller
{
@ -20,12 +21,14 @@ public function index()
public function store(FotoRequest $request)
{
$data = $request->validated();
$data['id_user'] = Auth::id();
if ($request->hasFile('foto')) {
$file = $request->file('foto');
$filename = time() . '_' . $file->getClientOriginalName();
$path = $file->storeAs('img/foto', $filename, 'public');
$data['foto'] = $path;
}
PaketFoto::create($data);
return redirect()->back()->with('success', 'Paket foto baru berhasil ditambahkan!');
}
@ -34,6 +37,7 @@ public function update(FotoRequest $request, string $id)
{
$paket = PaketFoto::findOrFail($id);
$data = $request->validated();
$data['id_user'] = Auth::id();
if ($request->hasFile('foto')) {
if ($paket->foto) {
Storage::disk('public')->delete($paket->foto);
@ -49,6 +53,9 @@ public function update(FotoRequest $request, string $id)
public function destroy(string $id)
{
$paket = PaketFoto::findOrFail($id);
if (Auth::user()->role !== 'admin_foto' && Auth::user()->role !== 'owner') {
return redirect()->back()->with('error', 'Anda tidak memiliki akses untuk menghapus paket ini!');
}
if ($paket->foto) {
Storage::disk('public')->delete($paket->foto);
}

View File

@ -18,10 +18,15 @@ class PaketFoto extends Model
'harga',
'foto',
'durasi',
'id_user',
];
public function booking()
{
return $this->hasMany(BookingFoto::class, 'id_paket');
}
public function user()
{
return $this->belongsTo(User::class, 'id_user');
}
}

View File

@ -27,4 +27,8 @@ class User extends Authenticatable
'password',
'remember_token',
];
public function paketFotos()
{
return $this->hasMany(PaketFoto::class, 'id_user');
}
}

View File

@ -0,0 +1,28 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::table('paket_fotos', function (Blueprint $table) {
$table->foreignId('id_user')->after('id_paket')->nullable()->constrained('users', 'id_user')->onDelete('cascade');
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('paket_fotos', function (Blueprint $table) {
//
});
}
};

View File

@ -61,6 +61,8 @@ class="custom-img-box-foto d-flex align-items-center justify-content-center text
</p>
</div>
</div>
<p class="x-small text-muted mb-0">Terakhir diubah oleh:</strong>
{{ $f->user->nama ?? 'Admin' }}</p>
</div>
</div>
</div>