Blame view
app/Http/Controllers/Admin/EmployersController.php
7.34 KB
8de035475 Создание: Структу... |
1 2 3 4 5 |
<?php namespace App\Http\Controllers\Admin; use App\Http\Controllers\Controller; |
e688e0d8a Статистика работн... |
6 |
use App\Models\Ad_employer; |
29350503f Расширение полей ... |
7 |
use App\Models\Answer; |
00652ea57 Оптимизация запро... |
8 |
use App\Models\CategoryEmp; |
c84db5243 Форма редактирова... |
9 |
use App\Models\Employer; |
e688e0d8a Статистика работн... |
10 |
use App\Models\Static_ad; |
8de035475 Создание: Структу... |
11 12 |
use App\Models\User; use Illuminate\Http\Request; |
622420a67 Расширение функци... |
13 |
use Illuminate\Support\Facades\DB; |
8c73c7b41 Категории ваканси... |
14 15 |
use Illuminate\Support\Facades\Storage; use Illuminate\Support\Facades\Validator; |
8de035475 Создание: Структу... |
16 17 18 19 |
class EmployersController extends Controller { public function index(Request $request) { |
4452df326 Миграции Категори... |
20 |
//$all_employer = User::where('is_worker', '0')->count(); |
8de035475 Создание: Структу... |
21 22 23 24 25 |
if ($request->ajax()) { $user = User::find($request->id); $request->offsetUnset('id'); $user->update($request->all()); } |
00652ea57 Оптимизация запро... |
26 |
$users = User::with('employers')->select(['users.*','users.id as usr_id', 'emp.id as emp_id', 'emp.*'])->join('employers as emp','emp.user_id','users.id') |
622420a67 Расширение функци... |
27 |
->where('users.is_worker', '0'); |
4452df326 Миграции Категори... |
28 |
$all_employer = $users->count(); |
be3039cb9 Правки по работод... |
29 30 31 32 33 34 35 36 |
$find_cat = ""; if (isset($request->category)) { if ($request->category != 'Все категории') { $users = $users->where('category', '=', $request->category); $find_cat = $request->category; } } |
622420a67 Расширение функци... |
37 |
$find_key = ""; |
be3039cb9 Правки по работод... |
38 |
|
622420a67 Расширение функци... |
39 40 41 42 43 44 45 |
if (isset($request->find)) { $find_key = $request->find; $users = $users->where(function($query) use($find_key) { $query->Where('users.name', 'LIKE', "%$find_key%") ->orWhere('emp.email', 'LIKE', "%$find_key%") ->orWhere('emp.telephone', 'LIKE', "%$find_key%"); }); |
93a3f79f0 Поисковый движок ... |
46 |
} |
622420a67 Расширение функци... |
47 48 |
//DB::enableQueryLog(); |
93a3f79f0 Поисковый движок ... |
49 |
$users = $users->paginate(15); |
622420a67 Расширение функци... |
50 |
//dd(DB::getQueryLog()); |
93a3f79f0 Поисковый движок ... |
51 |
|
be3039cb9 Правки по работод... |
52 |
$select_category = CategoryEmp::query()->active()->get(); |
8de035475 Создание: Структу... |
53 54 55 |
if ($request->ajax()) { return view('admin.employer.index_ajax', compact('users')); } else { |
be3039cb9 Правки по работод... |
56 |
return view('admin.employer.index', compact('users', 'find_key', 'find_cat', 'all_employer', 'select_category')); |
8de035475 Создание: Структу... |
57 58 |
} } |
c84db5243 Форма редактирова... |
59 60 |
public function form_update_employer(Employer $employer) { |
00652ea57 Оптимизация запро... |
61 62 |
$select_category = CategoryEmp::query()->active()->get(); return view('admin.employer.edit', compact('employer', 'select_category')); |
c84db5243 Форма редактирова... |
63 |
} |
8c73c7b41 Категории ваканси... |
64 65 66 67 68 69 70 71 72 |
public function update_employer(Employer $employer, Request $request) { $params = $request->all(); unset($params['logo']); unset($params['telephone']); unset($params['email']); unset($params['address']); unset($params['site']); |
622420a67 Расширение функци... |
73 74 75 76 |
unset($params['status_hidden']); unset($params['oficial_status']); unset($params['social_is']); unset($params['sending_is']); |
00652ea57 Оптимизация запро... |
77 78 |
unset($params['category']); unset($params['comment_admin']); |
8c73c7b41 Категории ваканси... |
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 |
$rules = [ 'name' => 'required|string|max:255', ]; $messages = [ 'required' => 'Укажите обязательное поле «:attribute»', 'confirmed' => 'Пароли не совпадают', 'email' => 'Введите корректный email', 'min' => [ 'string' => 'Поле «:attribute» должно быть не меньше :min символов', 'file' => 'Файл «:attribute» должен быть не меньше :min Кбайт' ], 'max' => [ 'string' => 'Поле «:attribute» должно быть не больше :max символов', 'file' => 'Файл «:attribute» должен быть не больше :max Кбайт' ], ]; $validator = Validator::make($params, $rules, $messages); if ($validator->fails()) { return back()->withErrors($validator)->withInput(); //->route('admin.register') } else { //$user = User::find($employer->user_id); $user_id = $employer->user_id; $employer->telephone = $request->telephone; $employer->email = $request->email; $employer->address = $request->address; $employer->site = $request->site; $employer->text = $request->text; |
622420a67 Расширение функци... |
112 113 114 115 |
$employer->status_hidden = $request->status_hidden; $employer->oficial_status = $request->oficial_status; $employer->social_is = $request->social_is; $employer->sending_is = $request->sending_is; |
00652ea57 Оптимизация запро... |
116 117 |
$employer->category = $request->category; $employer->comment_admin = $request->comment_admin; |
8c73c7b41 Категории ваканси... |
118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 |
if ($request->has('logo')) { if (!empty($employer->logo)) { Storage::delete($employer->logo); } $employer->logo = $request->file('logo')->store("employer/$user_id", 'public'); } $employer->save(); $user = User::find($user_id); $user->update($params); return redirect()->route('admin.employer-profile', ['employer' => $employer->id]) ->with('success', 'Данные были успешно сохранены'); } } |
bb2fb443d Архитектурное доп... |
134 |
|
00652ea57 Оптимизация запро... |
135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 |
// Удаление работодателя, вакансий и профиля юзера public function delete_employer(Employer $employer, User $user) { try { if (!empty($employer)) { $employer->ads()->delete(); if (!empty($employer->logo)) { Storage::delete($employer->logo); } $employer->delete(); } } finally { $user->delete(); } return redirect()->route('admin.employers')->with('success', 'Данные были удалены о работодателе'); } |
bb2fb443d Архитектурное доп... |
151 |
// кабинет - отзывы о работодателе для модерации |
29350503f Расширение полей ... |
152 153 154 155 156 157 158 159 160 161 162 163 164 165 |
public function answers(Request $request) { if ($request->ajax()) { $user = Answer::find($request->id); $request->offsetUnset('id'); $user->update($request->all()); } $answers = Answer::query()->orderByDesc('id')->paginate(15); if ($request->ajax()) { return view('admin.answers.index_ajax', compact('answers')); } else { return view('admin.answers.index', compact('answers')); } |
bb2fb443d Архитектурное доп... |
166 167 168 |
} // кабинет - статистика вакансий работодателя |
e688e0d8a Статистика работн... |
169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 |
public function static_ads(Request $request) { $stat = Static_ad::with('ads'); $ads = Ad_employer::query()->active()->OrderBy('id')->get(); $periods = Static_ad::query()->distinct('year_month')->select('year_month')->get(); if ($request->ajax()) { if (isset($request->ad_employer_id)) if (!$request->ad_employer_id == "0") $stat = $stat->Where('ad_employer_id', '=', $request->ad_employer_id); if (isset($request->year_month)) { if (!$request->year_month == "0") $stat = $stat->Where('year_month', '=', $request->year_month); } } $stat = $stat->OrderByDesc('year_month'); $stat = $stat->paginate(15); if ($request->ajax()) return view('admin.static.index_ads_ajax', compact('stat')); else return view('admin.static.index_ads', compact('stat', 'ads', 'periods')); |
bb2fb443d Архитектурное доп... |
190 |
} |
8de035475 Создание: Структу... |
191 |
} |