Файловый менеджер - Редактировать - /home/clickysoft/public_html/somni.clickysoft.net/app/Http/Controllers/Admin/UsersController.php
Назад
<?php namespace App\Http\Controllers\Admin; use App\Http\Controllers\Controller; use App\Http\Controllers\Traits\MediaUploadingTrait; use App\Http\Requests\MassDestroyUserRequest; use App\Http\Requests\StoreUserRequest; use App\Http\Requests\UpdateUserRequest; use App\Models\Role; use App\Models\User; use Gate; use Illuminate\Http\Request; use Spatie\MediaLibrary\MediaCollections\Models\Media; use Symfony\Component\HttpFoundation\Response; use Yajra\DataTables\Facades\DataTables; use App\Repositories\UserRepository; use App\Interfaces\UserRepositoryInterface; class UsersController extends Controller { use MediaUploadingTrait; private UserRepositoryInterface $userInterfaceObj; public function __construct(UserRepository $userRepo){ $this->userInterfaceObj = $userRepo; } public function index(Request $request) { abort_if(Gate::denies('user_access'), Response::HTTP_FORBIDDEN, '403 Forbidden'); if ($request->ajax()) { $query = User::with(['roles'])->select(sprintf('%s.*', (new User)->table)); $table = Datatables::of($query); $table->addColumn('placeholder', ' '); $table->addColumn('actions', ' '); $table->editColumn('actions', function ($row) { $viewGate = 'user_show'; $editGate = 'user_edit'; $deleteGate = 'user_delete'; $crudRoutePart = 'users'; return view('partials.datatablesActions', compact( 'viewGate', 'editGate', 'deleteGate', 'crudRoutePart', 'row' )); }); $table->editColumn('id', function ($row) { return $row->id ? $row->id : ''; }); $table->editColumn('name', function ($row) { return $row->name ? $row->name : ''; }); $table->editColumn('email', function ($row) { return $row->email ? $row->email : ''; }); $table->editColumn('phone', function ($row) { return $row->phone ? $row->phone : ''; }); $table->editColumn('profile_image', function ($row) { if ($photo = $row->profile_image) { return sprintf( '<a href="%s" target="_blank"><img src="%s" width="50px" height="50px"></a>', $photo->url, $photo->thumbnail ); } return ''; }); $table->editColumn('roles', function ($row) { $labels = []; foreach ($row->roles as $role) { $labels[] = sprintf('<span class="label label-info label-many">%s</span>', $role->title); } return implode(' ', $labels); }); $table->rawColumns(['actions', 'placeholder', 'profile_image', 'roles']); return $table->make(true); } $roles = Role::get(); return view('admin.users.index', compact('roles')); } public function create() { abort_if(Gate::denies('user_create'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $roles = Role::pluck('title', 'id'); return view('admin.users.create', compact('roles')); } public function store(StoreUserRequest $request) { $user = User::create($request->all()); $user->roles()->sync($request->input('roles', [])); if ($request->input('profile_image', false)) { $user->addMedia(storage_path('tmp/uploads/' . basename($request->input('profile_image'))))->toMediaCollection('profile_image'); } if ($media = $request->input('ck-media', false)) { Media::whereIn('id', $media)->update(['model_id' => $user->id]); } return redirect()->route('admin.users.index'); } public function edit(User $user) { abort_if(Gate::denies('user_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $roles = Role::pluck('title', 'id'); $user->load('roles'); return view('admin.users.edit', compact('roles', 'user')); } public function update(UpdateUserRequest $request, User $user) { $user->update($request->all()); $user->roles()->sync($request->input('roles', [])); if ($request->input('profile_image', false)) { if (! $user->profile_image || $request->input('profile_image') !== $user->profile_image->file_name) { if ($user->profile_image) { $user->profile_image->delete(); } $user->addMedia(storage_path('tmp/uploads/' . basename($request->input('profile_image'))))->toMediaCollection('profile_image'); } } elseif ($user->profile_image) { $user->profile_image->delete(); } return redirect()->route('admin.users.index'); } public function show(User $user) { abort_if(Gate::denies('user_show'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $user->load('roles', 'userUserAlerts'); return view('admin.users.show', compact('user')); } public function destroy(User $user) { abort_if(Gate::denies('user_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $user->delete(); return back(); } public function massDestroy(MassDestroyUserRequest $request) { $users = User::find(request('ids')); foreach ($users as $user) { $user->delete(); } return response(null, Response::HTTP_NO_CONTENT); } public function storeCKEditorImages(Request $request) { abort_if(Gate::denies('user_create') && Gate::denies('user_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $model = new User(); $model->id = $request->input('crud_id', 0); $model->exists = true; $media = $model->addMediaFromRequest('upload')->toMediaCollection('ck-media'); return response()->json(['id' => $media->id, 'url' => $media->getUrl()], Response::HTTP_CREATED); } public function changeStatus($user_id,$status){ abort_if(Gate::denies('user_edit') && Gate::denies('user_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $user = $this->userInterfaceObj->getUserById($user_id); $status = $this->userInterfaceObj->changeStatus($user,(int)$status); return $status; } }
| ver. 1.4 |
Github
|
.
| PHP 8.1.29 | Генерация страницы: 0 |
proxy
|
phpinfo
|
Настройка