Actualizacion de Diseño Logins y Parte de Registro Negocios
This commit is contained in:
177
desarrollo/app/Http/Controllers/CustomerController.php
Normal file
177
desarrollo/app/Http/Controllers/CustomerController.php
Normal file
@@ -0,0 +1,177 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models\Customer;
|
||||
use App\Models\User;
|
||||
|
||||
class CustomerController extends Controller
|
||||
{
|
||||
public function __construct() {
|
||||
// Staff Permission Check
|
||||
$this->middleware(['permission:view_all_customers'])->only('index');
|
||||
$this->middleware(['permission:login_as_customer'])->only('login');
|
||||
$this->middleware(['permission:ban_customer'])->only('ban');
|
||||
$this->middleware(['permission:delete_customer'])->only('destroy');
|
||||
}
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
$sort_search = null;
|
||||
$users = User::where('user_type', 'customer')->where('email_verified_at', '!=', null)->orderBy('created_at', 'desc');
|
||||
if ($request->has('search')){
|
||||
$sort_search = $request->search;
|
||||
$users->where(function ($q) use ($sort_search){
|
||||
$q->where('name', 'like', '%'.$sort_search.'%')->orWhere('email', 'like', '%'.$sort_search.'%');
|
||||
});
|
||||
}
|
||||
$users = $users->paginate(15);
|
||||
return view('backend.customer.customers.index', compact('users', 'sort_search'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'name' => 'required',
|
||||
'email' => 'required|unique:users|email',
|
||||
'phone' => 'required|unique:users',
|
||||
]);
|
||||
|
||||
$response['status'] = 'Error';
|
||||
|
||||
$user = User::create($request->all());
|
||||
|
||||
$customer = new Customer;
|
||||
|
||||
$customer->user_id = $user->id;
|
||||
$customer->save();
|
||||
|
||||
if (isset($user->id)) {
|
||||
$html = '';
|
||||
$html .= '<option value="">
|
||||
'. translate("Walk In Customer") .'
|
||||
</option>';
|
||||
foreach(Customer::all() as $key => $customer){
|
||||
if ($customer->user) {
|
||||
$html .= '<option value="'.$customer->user->id.'" data-contact="'.$customer->user->email.'">
|
||||
'.$customer->user->name.'
|
||||
</option>';
|
||||
}
|
||||
}
|
||||
|
||||
$response['status'] = 'Success';
|
||||
$response['html'] = $html;
|
||||
}
|
||||
|
||||
echo json_encode($response);
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
$customer = User::findOrFail($id);
|
||||
$customer->customer_products()->delete();
|
||||
|
||||
User::destroy($id);
|
||||
flash(translate('Customer has been deleted successfully'))->success();
|
||||
return redirect()->route('customers.index');
|
||||
}
|
||||
|
||||
public function bulk_customer_delete(Request $request) {
|
||||
if($request->id) {
|
||||
foreach ($request->id as $customer_id) {
|
||||
$customer = User::findOrFail($customer_id);
|
||||
$customer->customer_products()->delete();
|
||||
$this->destroy($customer_id);
|
||||
}
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
public function login($id)
|
||||
{
|
||||
$user = User::findOrFail(decrypt($id));
|
||||
|
||||
auth()->login($user, true);
|
||||
|
||||
return redirect()->route('dashboard');
|
||||
}
|
||||
|
||||
public function ban($id) {
|
||||
$user = User::findOrFail(decrypt($id));
|
||||
|
||||
if($user->banned == 1) {
|
||||
$user->banned = 0;
|
||||
flash(translate('Customer UnBanned Successfully'))->success();
|
||||
} else {
|
||||
$user->banned = 1;
|
||||
flash(translate('Customer Banned Successfully'))->success();
|
||||
}
|
||||
|
||||
$user->save();
|
||||
|
||||
return back();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user