Files
nnterp-react-admin/app/Http/Controllers/ProfileController.php
2026-03-13 20:49:46 +08:00

59 lines
1.7 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Http\Requests\ProfileUpdateRequest;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Redirect;
use Inertia\Inertia;
use Inertia\Response;
class ProfileController extends Controller
{
/**
* Display the user's profile form.
*/
public function edit(Request $request): Response|RedirectResponse
{
if(Auth::user()->can('manage-profile')){
return Inertia::render('profile/edit', [
'mustVerifyEmail' => $request->user() instanceof MustVerifyEmail,
'status' => session('status'),
]);
}else{
return redirect()->back()->with('error', __('Permission denied'));
}
}
/**
* Update the user's profile information.
*/
public function update(ProfileUpdateRequest $request): RedirectResponse
{
if(Auth::user()->can('edit-profile') && Auth::user()->id === $request->user()->id){
$user = $request->user();
$validated = $request->validated();
if (isset($validated['avatar']) && $validated['avatar']) {
$validated['avatar'] = basename($validated['avatar']);
}
$user->fill($validated);
if ($user->isDirty('email')) {
$user->email_verified_at = null;
}
$user->save();
return Redirect::route('profile.edit')->with('success', __('The profile details are updated successfully.'));
}
else{
return Redirect::route('profile.edit')->with('error', __('Permission denied'));
}
}
}