Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 9 additions & 6 deletions app/Http/Controllers/ProfileController.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,9 @@
namespace App\Http\Controllers;

use App\Http\Requests\ProfileUpdateRequest;
use Illuminate\Auth\Events\Validated;
use Illuminate\Support\Facades\Hash;
use Illuminate\Http\Request;

class ProfileController extends Controller
{
Expand All @@ -14,15 +16,16 @@ public function show()

public function update(ProfileUpdateRequest $request)
{
if ($request->password) {
auth()->user()->update(['password' => Hash::make($request->password)]);

if ($request['email'] != auth()->user()->email) {
auth()->user()->forceFill(['email_verified_at' => null]);
}

auth()->user()->update([
'name' => $request->name,
'email' => $request->email,
]);
auth()->user()->update($request->validated());

if ($request['password']) {
auth()->user()->update(['password' => Hash::make($request['password'])]);
}
return redirect()->back()->with('success', 'Profile updated.');
}
}
9 changes: 6 additions & 3 deletions app/Http/Requests/ProfileUpdateRequest.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,12 @@ class ProfileUpdateRequest extends FormRequest
public function rules()
{
return [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'email', 'string', 'max:255', Rule::unique('users')->ignore(Auth::user())],
'password' => ['nullable', 'string', 'confirmed', 'min:8'],
'firstname' => 'required|min:3|max:255|string',
'lastname' => 'required|min:3|max:255|string',
'email' => ['required', 'email', 'string', 'max:255', Rule::unique('users')->ignore(Auth::user())],
'phone' => 'required|digits_between:10,10',
'password' => 'required|min:6|confirmed',
'password_confirmation' => 'required|min:6'
];
}

Expand Down
1 change: 1 addition & 0 deletions app/Models/User.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
use Laravel\Sanctum\HasApiTokens;
use willvincent\Rateable\Rateable;


class User extends Authenticatable
{
use HasApiTokens, HasFactory, Notifiable, SoftDeletes, Rateable;
Expand Down
22 changes: 19 additions & 3 deletions resources/views/auth/profile.blade.php
Original file line number Diff line number Diff line change
Expand Up @@ -45,10 +45,18 @@


<div class="mb-3">
<label class="form-label required">{{ __('Name') }}</label>
<input type="text" name="name" class="form-control @error('name') is-invalid @enderror" placeholder="{{ __('Name') }}" value="{{ old('name', auth()->user()->name) }}" required>
<label class="form-label required">{{ __('First Name') }}</label>
<input type="text" name="firstname" class="form-control @error('firstname') is-invalid @enderror" placeholder="{{ __('First name') }}" value="{{ old('firstname', auth()->user()->firstname) }}" required>
</div>
@error('name')
@error('firstname')
<div class="invalid-feedback">{{ $message }}</div>
@enderror

<div class="mb-3">
<label class="form-label required">{{ __('Last Name') }}</label>
<input type="text" name="lastname" class="form-control @error('lastname') is-invalid @enderror" placeholder="{{ __('Last name') }}" value="{{ old('lastname', auth()->user()->lastname) }}" >
</div>
@error('lastname')
<div class="invalid-feedback">{{ $message }}</div>
@enderror

Expand All @@ -60,6 +68,14 @@
<div class="invalid-feedback">{{ $message }}</div>
@enderror

<div class="mb-3">
<label class="form-label required">{{ __('Phone number') }}</label>
<input type="text" name="phone" class="form-control @error('phone') is-invalid @enderror" placeholder="{{ __('Phone') }}" value="{{ old('phone', auth()->user()->phone) }}" required>
</div>
@error('phone')
<div class="invalid-feedback">{{ $message }}</div>
@enderror

<div class="mb-3">
<label class="form-label required">{{ __('New password') }}</label>
<input type="password" name="password" class="form-control @error('password') is-invalid @enderror" placeholder="{{ __('New password') }}">
Expand Down