In this video, we will learn about how to allow users to change their passwords.

Let's explore how to create a change password feature for users or customers.

First, we need to create a new Livewire component.

Switch to the command prompt and run the following command to create a new Livewire component:


php artisan make:livewire user/UserChangePasswordComponent

Now, run the application:


php artisan serve

Next, switch to the project and create a route for this new component.

Go to the routes directory and open the web.php file.

Inside the user middleware route group, create a new route:


Route::get('/user/change-password',UserChangePasswordComponent::class)->name('user.changepassword');

Now, go to the UserChangePasswordComponent.php class file and write the following code:


<?php

namespace App\Http\Livewire\User;

use App\Models\User;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Livewire\Component;

class UserChangePasswordComponent extends Component
{
public $current_password;
public $password;
public $password_confirmation;

public function updated($fields)
{
$this->validateOnly($fields,[
'current_password'=>'required',
'password' => 'required|min:8|confirmed|different:current_password'
]);
}

public function changePassword()
{
$this->validate([
'current_password'=>'required',
'password' => 'required|min:8|confirmed|different:current_password'
]);

if(Hash::check($this->current_password,Auth::user()->password))
{
$user = User::findOrFail(Auth::user()->id);
$user->password = Hash::make($this->password);
$user->save();
session()->flash('password_success','Password has been changed successfully!');
}
else
{
session()->flash('password_error','Password does not match!');
}
}

public function render()
{
return view('livewire.user.user-change-password-component')->layout('layouts.base');
}
}

Open the user-change-password-component.blade.php view file and write the following code:


<div>
<div class="container" style="padding: 30px 0;">
<div class="row">
<div class="col-md-12">
<div class="panel panel-default">
<div class="panel-heading">
Change Password
</div>
<div class="panel-body">
@if(Session::has('password_success'))
<div class="alert alert-success" role="alert">{{Session::get('password_success')}}</div>
@endif
@if(Session::has('password_error'))
<div class="alert alert-danger" role="alert">{{Session::get('password_error')}}</div>
@endif
<form class="form-horizontal" wire:submit.prevent="changePassword">
<div class="form-group">
<label class="col-md-4 control-label">Current Password</label>
<div class="col-md-4">
<input type="password" placeholder="Current Password" class="form-control input-md" name="current_password" wire:model="current_password" />
@error('current_password') <p class="text-danger">{{$message}}</p> @enderror
</div>
</div>
<div class="form-group">
<label class="col-md-4 control-label">New Password</label>
<div class="col-md-4">
<input type="password" placeholder="New Password" class="form-control input-md" name="password" wire:model="password" />
@error('password') <p class="text-danger">{{$message}}</p> @enderror
</div>
</div>

<div class="form-group">
<label class="col-md-4 control-label">Confirm Password</label>
<div class="col-md-4">
<input type="password" placeholder="Confirm Password" class="form-control input-md" name="password_confirmation" wire:model="password_confirmation" />
@error('password_confirmation') <p class="text-danger">{{$message}}</p> @enderror
</div>
</div>
<div class="form-group">
<label class="col-md-4 control-label"></label>
<div class="col-md-4">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
</div>

Let's test the password change feature.

Enter your current password:

Enter your new password:

Retype your new password:

Click on submit.

You should see a message indicating that your password has been changed successfully!

And that's how you can create a change password feature for users.