Файловый менеджер - Редактировать - /home/clickysoft/public_html/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\Company; use App\Models\Organization; 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; class UsersController extends Controller { use MediaUploadingTrait; public function index(Request $request) { abort_if(Gate::denies('user_access'), Response::HTTP_FORBIDDEN, '403 Forbidden'); if ($request->ajax()) { $query = User::with(['organization', 'companies', '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->addColumn('organization_name', function ($row) { return $row->organization ? $row->organization->name : ''; }); $table->editColumn('company', function ($row) { $labels = []; foreach ($row->companies as $company) { $labels[] = sprintf('<span class="label label-info label-many">%s</span>', $company->name); } return implode(' ', $labels); }); $table->editColumn('name', function ($row) { return $row->name ? $row->name : ''; }); $table->editColumn('email', function ($row) { return $row->email ? $row->email : ''; }); $table->editColumn('contact_number', function ($row) { return $row->contact_number ? $row->contact_number : ''; }); $table->editColumn('avatar', function ($row) { if ($photo = $row->avatar) { 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', 'organization', 'company', 'avatar', 'roles']); return $table->make(true); } $organizations = Organization::get(); $companies = Company::get(); $roles = Role::get(); return view('admin.users.index', compact('organizations', 'companies', 'roles')); } public function create() { abort_if(Gate::denies('user_create'), Response::HTTP_FORBIDDEN, '403 Forbidden'); $organizations = Organization::pluck('name', 'id')->prepend(trans('global.pleaseSelect'), ''); $companies = Company::pluck('name', 'id'); $roles = Role::pluck('title', 'id'); return view('admin.users.create', compact('companies', 'organizations', 'roles')); } public function store(StoreUserRequest $request) { $user = User::create($request->all()); $user->companies()->sync($request->input('companies', [])); $user->roles()->sync($request->input('roles', [])); if ($request->input('avatar', false)) { $user->addMedia(storage_path('tmp/uploads/' . basename($request->input('avatar'))))->toMediaCollection('avatar'); } 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'); $organizations = Organization::pluck('name', 'id')->prepend(trans('global.pleaseSelect'), ''); $companies = Company::pluck('name', 'id'); $roles = Role::pluck('title', 'id'); $user->load('organization', 'companies', 'roles'); return view('admin.users.edit', compact('companies', 'organizations', 'roles', 'user')); } public function update(UpdateUserRequest $request, User $user) { $user->update($request->all()); $user->companies()->sync($request->input('companies', [])); $user->roles()->sync($request->input('roles', [])); if ($request->input('avatar', false)) { if (! $user->avatar || $request->input('avatar') !== $user->avatar->file_name) { if ($user->avatar) { $user->avatar->delete(); } $user->addMedia(storage_path('tmp/uploads/' . basename($request->input('avatar'))))->toMediaCollection('avatar'); } } elseif ($user->avatar) { $user->avatar->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('organization', 'companies', 'roles'); 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); } }
| ver. 1.4 |
Github
|
.
| PHP 8.1.29 | Генерация страницы: 0 |
proxy
|
phpinfo
|
Настройка