165 lines
4.8 KiB
PHP
Executable File
165 lines
4.8 KiB
PHP
Executable File
<?php
|
|
|
|
namespace App\Http\Controllers\Dashboard\User;
|
|
|
|
use App\Exports\UsersExport;
|
|
use App\Http\Requests\Dashboard\User\Create as CreateRequest;
|
|
use App\Imports\UsersImport;
|
|
use App\Jobs\Dashboard\User\Create;
|
|
use App\Models\Role;
|
|
use App\Models\Staff;
|
|
use App\Models\User;
|
|
use App\Http\Controllers\Controller as ExController;
|
|
|
|
use App\Http\Requests\Dashboard\User\Update as UpdateRequest;
|
|
|
|
use App\Jobs\Dashboard\User\Update as UpdateJob;
|
|
use Illuminate\Http\Request;
|
|
use Maatwebsite\Excel\Facades\Excel;
|
|
|
|
class Controller extends ExController
|
|
{
|
|
protected $users;
|
|
|
|
/**
|
|
* Controller constructor.
|
|
* @param User $user
|
|
*/
|
|
public function __construct(User $user)
|
|
{
|
|
$this->users = $user;
|
|
}
|
|
|
|
/**
|
|
* @param Request $request
|
|
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
|
* @throws \Illuminate\Auth\Access\AuthorizationException
|
|
* @throws \Exception
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$this->authorize('view', 'users');
|
|
$users = $this->users->latest('id');
|
|
|
|
if (!is_null($request->date_from)) {
|
|
$users = $users->filterByDate($request->date_from, $request->date_to, $request->sort_type);
|
|
}
|
|
|
|
$users = $users->search($request->search_id, $request->search_phone, $request->search_ip)->paginate(30);
|
|
|
|
return view('dashboard.users.index', compact('users'));
|
|
}
|
|
|
|
public function getStaffs()
|
|
{
|
|
$this->authorize('view', 'staffs');
|
|
|
|
$staffs = Staff::with('role')
|
|
->oldest('id')
|
|
->where('role_id', '!=', 2)
|
|
->paginate(30);
|
|
|
|
return view('dashboard.users.staffs', compact('staffs'));
|
|
}
|
|
|
|
/**
|
|
* @param Staff $staff
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
* @throws \Illuminate\Auth\Access\AuthorizationException
|
|
*/
|
|
public function block(Staff $staff)
|
|
{
|
|
$this->authorize('update', 'staffs');
|
|
|
|
if ($staff->block === true) {
|
|
$staff->block = false;
|
|
} else {
|
|
$staff->block = true;
|
|
}
|
|
|
|
$staff->save();
|
|
|
|
$this->info(trans('admin.messages.updated'));
|
|
return redirect()->back();
|
|
}
|
|
|
|
public function store(CreateRequest $request)
|
|
{
|
|
if ($request->isMethod('get')) {
|
|
$this->authorize('create', 'staffs');
|
|
$roles = Role::whereNotIn('id', [2])->get();
|
|
return view('dashboard.users.create', compact('roles'));
|
|
}
|
|
|
|
$this->dispatchSync(new Create($request));
|
|
|
|
$this->info(trans('admin.messages.created'));
|
|
return redirect()->route('dashboard.staffs');
|
|
}
|
|
|
|
/**
|
|
* @param UpdateRequest $request
|
|
* @param Staff $staff
|
|
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
|
* @throws \Illuminate\Auth\Access\AuthorizationException
|
|
*/
|
|
public function update(UpdateRequest $request, Staff $staff)
|
|
{
|
|
if ($request->isMethod('get')) {
|
|
|
|
$this->authorize('update', 'staffs');
|
|
|
|
$roles = Role::whereNotIn('id', [2])->get();
|
|
return view('dashboard.users.update', compact('staff', 'roles'));
|
|
}
|
|
$this->dispatchSync(new UpdateJob($staff, $request));
|
|
|
|
$this->info(trans('admin.messages.updated'));
|
|
return redirect()->route('dashboard.staffs');
|
|
}
|
|
|
|
public function import()
|
|
{
|
|
$file = '/customers.csv';
|
|
|
|
$excel = Excel::toArray(new UsersImport, $file);
|
|
|
|
$users = collect($excel)->flatten(1);
|
|
|
|
foreach ($users as $user) {
|
|
$phone = str_replace(['+', '(', ')', ' ', '-'], '', $user[8]);
|
|
$user = User::where('phone', $phone)->first();
|
|
if (empty($user)) {
|
|
if (!empty($user[8])) {
|
|
User::create([
|
|
'first_name' => !empty($user[4]) ? $user[4] : null,
|
|
'last_name' => !empty($user[5]) ? $user[5] : null,
|
|
'phone' => str_replace(['+', '(', ')', ' ', '-'], '', $user[8]),
|
|
'email' => !empty($user[7]) ? $user[7] : null,
|
|
'ip' => !empty($user[17]) ? $user[17] : null,
|
|
'role_id' => 2,
|
|
'step' => 3
|
|
]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public function export(Request $request)
|
|
{
|
|
return (new UsersExport($request->date_from, $request->date_to, $request->search_id, $request->search_phone, $request->search_ip, $request->sort_type))
|
|
->download("users_" . now()->toDateString() . ".xlsx");
|
|
}
|
|
|
|
public static function addHours()
|
|
{
|
|
$users = User::all();
|
|
|
|
foreach ($users as $user) {
|
|
$user->update([
|
|
'created_at' => $user->created_at->addHours(5)
|
|
]);
|
|
}
|
|
}
|
|
}
|