You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

108 lines
3.5 KiB

2 years ago
<?php
namespace App\Http\Controllers\Vendor;
use App\CentralLogics\Helpers;
use App\Http\Controllers\Controller;
use App\Models\Vendor;
use Brian2694\Toastr\Facades\Toastr;
use Illuminate\Http\Request;
class ProfileController extends Controller
{
public function view()
{
return view('vendor-views.profile.index');
}
public function bank_view()
{
$data = Helpers::get_vendor_data();
return view('vendor-views.profile.bankView', compact('data'));
}
public function edit()
{
$data = Helpers::get_vendor_data();
return view('vendor-views.profile.edit', compact('data'));
}
public function update(Request $request)
{
$table=auth('vendor')->check()?'vendors':'vendor_employees';
$seller = auth('vendor')->check()?auth('vendor')->user():auth('vendor_employee')->user();
$request->validate([
'f_name' => 'required|max:100',
'l_name' => 'nullable|max:100',
'email' => 'required|unique:'.$table.',email,'.$seller->id,
'phone' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:10|max:20|unique:'.$table.',phone,'.$seller->id,
'image' => 'nullable|max:2048',
], [
'f_name.required' => translate('messages.first_name_is_required'),
]);
$seller = auth('vendor')->check()?auth('vendor')->user():auth('vendor_employee')->user();
$seller->f_name = $request->f_name;
$seller->l_name = $request->l_name;
$seller->phone = $request->phone;
$seller->email = $request->email;
if ($request->image) {
$seller->image = Helpers::update('vendor/', $seller->image, 'png', $request->file('image'));
}
$seller->save();
Toastr::success(translate('messages.profile_updated_successfully'));
return back();
}
public function settings_password_update(Request $request)
{
$request->validate([
'password' => 'required|same:confirm_password|min:6',
'confirm_password' => 'required',
]);
$seller = auth('vendor')->check()?Helpers::get_vendor_data():auth('vendor_employee')->user();
$seller->password = bcrypt($request['password']);
$seller->save();
Toastr::success(translate('messages.vendor_pasword_updated_successfully'));
return back();
}
public function bank_update(Request $request)
{
$request->validate([
'bank_name' => 'required|max:191',
'branch' => 'required|max:191',
'holder_name' => 'required|max:191',
'account_no' => 'required|max:191',
]);
$bank = Helpers::get_vendor_data();
$bank->bank_name = $request->bank_name;
$bank->branch = $request->branch;
$bank->holder_name = $request->holder_name;
$bank->account_no = $request->account_no;
$bank->save();
Toastr::success(translate('messages.bank_info_updated_successfully'));
return redirect()->route('vendor.profile.bankView');
}
public function bank_edit()
{
$data = Helpers::get_vendor_data();
return view('vendor-views.profile.bankEdit', compact('data'));
}
public function bank_delete()
{
$data = Helpers::get_vendor_data();
$data->bank_name = null;
$data->branch = null;
$data->holder_name = null;
$data->account_no = null;
$data->save();
Toastr::success(translate('messages.bank_info_updated_successfully'));
return redirect()->route('vendor.profile.bankView');
}
}