/home2/mshostin/farms.ms-hostingladz.com/app/Http/Controllers/ProfileController.php
<?php

namespace App\Http\Controllers;

use App\Http\Requests\ProfileUpdateRequest;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Str;
use Illuminate\View\View;
use Illuminate\Support\Facades\Hash;

class ProfileController extends Controller
{
    public function __construct()
    {
        $permissions = [
            'update'  => 'edit-profile',
            'destroy' => 'delete-profile',
        ];

        foreach ($permissions as $method => $permission) {
            $this->middleware("permission:{$permission}")->only($method);
        }
    }

    /**
     * Display the user's profile form.
     */
    public function edit(Request $request): View
    {
        $user = $request->user();

        if (!$user->detail) {
            $user->detail()->create([]);
            $user->refresh(); // refresh the relation
        }

        return view('dashboard.profile.edit', [
            'user' => $user,
        ]);
    }

    /**
     * Update the user's profile information.
     */
    public function update(ProfileUpdateRequest $request): RedirectResponse
    {
        $user = $request->user();

        // Update basic fields
        $user->fill($request->validated());

        if ($user->isDirty('email')) {
            $user->email_verified_at = null;
        }

        // Handle password change
        if ($request->filled('password')) {
            // Make sure password confirmation is correct (ProfileUpdateRequest should validate this)
            $user->password = Hash::make($request->password);
        }

        $user->save();

        // Update user detail
        $detailData = $request->only([
            'phone_1',
            'date_of_birth',
            'gender',
            'address_1',
            'city',
            'state',
            'country',
            'postal_code',
            'emergency_contact_name',
            'emergency_contact_relation',
            'emergency_contact_phone',
            'department',
            'designation',
            'shift_timings'
        ]);

        $detail = $user->detail ?? $user->detail()->create([]);
        $detail->fill($detailData);

        // Handle profile image upload
        if ($request->hasFile('profile_image')) {
            $file = $request->file('profile_image');
            $fileName = Str::slug($user->name) . '_' . time() . '.' . $file->getClientOriginalExtension();
            $folderPath = 'userDocs/';
            $file->move(public_path($folderPath), $fileName);

            $detail->profile_image = $folderPath . $fileName;
        }

        $detail->save();

        return Redirect::route('profile.edit')->with('status', 'profile-updated');
    }

    /**
     * Delete the user's account.
     */
    public function destroy(Request $request): RedirectResponse
    {
        $request->validateWithBag('userDeletion', [
            'password' => ['required', 'current_password'],
        ]);

        $user = $request->user();

        Auth::logout();
        $user->delete();

        $request->session()->invalidate();
        $request->session()->regenerateToken();

        return Redirect::to('/');
    }
}