Blame view
app/Http/Controllers/EmployerController.php
31.1 KB
5b68533bb Работа над проект... |
1 2 3 |
<?php namespace App\Http\Controllers; |
e3c7b0ffb Коммит на понедел... |
4 5 |
use App\Classes\RusDate; use App\Classes\Tools; |
6e2255214 Работа над сообще... |
6 7 |
use App\Http\Requests\BaseUser_min_Request; use App\Http\Requests\BaseUserRequest; |
e3c7b0ffb Коммит на понедел... |
8 9 |
use App\Http\Requests\FlotRequest; use App\Http\Requests\MessagesRequiest; |
7571b20fd Коммит 13 марта 2024 |
10 |
use App\Http\Requests\VacancyRequestEdit; |
e3c7b0ffb Коммит на понедел... |
11 12 13 |
use App\Http\Requests\VacansiaRequiest; use App\Mail\MailSotrudnichestvo; use App\Mail\SendAllMessages; |
d152a3a68 Создание основных... |
14 |
use App\Models\Ad_employer; |
e3c7b0ffb Коммит на понедел... |
15 16 |
use App\Models\Ad_jobs; use App\Models\ad_response; |
d152a3a68 Создание основных... |
17 |
use App\Models\Category; |
e3c7b0ffb Коммит на понедел... |
18 19 20 21 22 |
use App\Models\Education; use App\Models\Employer; use App\Models\employers_main; use App\Models\Flot; use App\Models\Job_title; |
dc2a9a876 Коммит на понедел... |
23 24 |
use App\Models\Like_vacancy; use App\Models\Like_worker; |
e3c7b0ffb Коммит на понедел... |
25 |
use App\Models\Message; |
df4edc01d Обновление данных |
26 |
use App\Models\Positions; |
e3c7b0ffb Коммит на понедел... |
27 |
use App\Models\Worker; |
f3766c7c1 Коммит по регистр... |
28 29 |
use Carbon\Carbon; use Illuminate\Auth\Events\Registered; |
e3c7b0ffb Коммит на понедел... |
30 |
use Illuminate\Database\Eloquent\Builder; |
f3766c7c1 Коммит по регистр... |
31 |
use Illuminate\Database\Eloquent\Model; |
e3c7b0ffb Коммит на понедел... |
32 |
use Illuminate\Foundation\Auth\User; |
5b68533bb Работа над проект... |
33 |
use Illuminate\Http\Request; |
a13ce8670 Обновление проект... |
34 |
use Illuminate\Support\Facades\Auth; |
e3c7b0ffb Коммит на понедел... |
35 36 37 38 39 |
use Illuminate\Support\Facades\Hash; use Illuminate\Support\Facades\Mail; use Illuminate\Support\Facades\Storage; use App\Models\User as User_Model; use Illuminate\Support\Facades\Validator; |
5b68533bb Работа над проект... |
40 41 42 |
class EmployerController extends Controller { |
d152a3a68 Создание основных... |
43 44 |
public function vacancie($vacancy, Request $request) { $title = 'Заголовок вакансии'; |
d152a3a68 Создание основных... |
45 46 47 48 49 50 |
$Query = Ad_employer::with('jobs')-> with('cat')-> with('employer')-> with('jobs_code')-> select('ad_employers.*')-> where('id', '=', $vacancy)->get(); |
ad2cc280b Правки финальные ... |
51 52 53 54 |
if (isset(Auth()->user()->id)) $uid = Auth()->user()->id; else $uid = 0; |
d152a3a68 Создание основных... |
55 56 |
$title = $Query[0]->name; if ($request->ajax()) { |
ad2cc280b Правки финальные ... |
57 |
return view('ajax.vacance-item', compact('Query','uid')); |
d152a3a68 Создание основных... |
58 |
} else { |
ad2cc280b Правки финальные ... |
59 |
return view('vacance-item', compact('title', 'Query', 'uid')); |
d152a3a68 Создание основных... |
60 61 |
} } |
a13ce8670 Обновление проект... |
62 63 64 65 66 67 |
public function logout() { Auth::logout(); return redirect()->route('index') ->with('success', 'Вы вышли из личного кабинета'); } |
e3c7b0ffb Коммит на понедел... |
68 |
|
6e2255214 Работа над сообще... |
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
public function employer_info() { // код юзера $user_info = Auth()->user(); // вьюшка для вывода данных return view('employers.info', compact('user_info')); } public function employer_info_save(User_Model $user, BaseUser_min_Request $request) { // Все данные через реквест $all = $request->all(); unset($all['_token']); // обновление $user->update($all); return redirect()->route('employer.employer_info'); } |
e3c7b0ffb Коммит на понедел... |
84 85 86 87 88 89 90 91 |
public function cabinet() { $id = Auth()->user()->id; $Employer = Employer::query()->with('users')->with('ads')->with('flots')-> WhereHas('users', function (Builder $query) use ($id) {$query->Where('id', $id); })->get(); return view('employers.cabinet45', compact('Employer')); } |
b3d27fa36 Обновление проект... |
92 93 94 95 96 97 98 99 |
public function slider_flot() { $id = Auth()->user()->id; $Employer = Employer::query()->with('users')->with('ads')->with('flots')-> WhereHas('users', function (Builder $query) use ($id) {$query->Where('id', $id); })->get(); return view('employers.fly-flot', compact('Employer')); } |
e3c7b0ffb Коммит на понедел... |
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 |
public function cabinet_save(Employer $Employer, Request $request) { $params = $request->all(); $params['user_id'] = Auth()->user()->id; $id = $Employer->id; if ($request->has('logo')) { if (!empty($Employer->logo)) { Storage::delete($Employer->logo); } $params['logo'] = $request->file('logo')->store("employer/$id", 'public'); } $Employer->update($params); return redirect()->route('employer.cabinet')->with('success', 'Данные были успешно сохранены'); } public function save_add_flot(FlotRequest $request) { // отмена $params = $request->all(); if ($request->has('image')) { $params['image'] = $request->file('image')->store("flot", 'public'); } Flot::create($params); $data_flots = Flot::query()->where('employer_id', $request->get('employer_if'))->get(); |
b3d27fa36 Обновление проект... |
126 |
return redirect()->route('employer.slider_flot')->with('success', 'Новый корабль был добавлен'); |
e3c7b0ffb Коммит на понедел... |
127 |
} |
14681d2d2 Работодатели каби... |
128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 |
public function edit_flot(Flot $Flot, Employer $Employer) { return view('employers.edit-flot', compact('Flot', 'Employer')); } public function update_flot(FlotRequest $request, Flot $Flot) { $params = $request->all(); if ($request->has('image')) { if (!empty($flot->image)) { Storage::delete($flot->image); } $params['image'] = $request->file('image')->store("flot", 'public'); } else { if (!empty($flot->image)) $params['image'] = $flot->image; } $Flot->update($params); return redirect()->route('employer.slider_flot')->with('success', 'Новый корабль был добавлен'); } |
e3c7b0ffb Коммит на понедел... |
147 148 149 150 |
public function delete_flot(Flot $Flot) { $data_flots = Flot::query()->where('employer_id', $Flot->employer_id)->get(); if (isset($Flot->id)) $Flot->delete(); |
b3d27fa36 Обновление проект... |
151 |
return redirect()->route('employer.slider_flot')->with('success', 'Корабль был удален'); |
e3c7b0ffb Коммит на понедел... |
152 153 154 155 156 |
} // Форма добавления вакансий public function cabinet_vacancie() { $id = Auth()->user()->id; |
31fe4e458 Показ проекта зак... |
157 |
|
0fc30621f коммит от пятницы... |
158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 |
if (Auth()->user()->is_public) { $categories = Category::query()->active()->get(); $jobs = Job_title::query()->OrderBy('name')->where('is_remove', '=', '0')->where('is_bd', '=', '0')->get(); $Employer = Employer::query()->with('users')->with('ads')->with('flots')-> WhereHas('users', function (Builder $query) use ($id) { $query->Where('id', $id); })->get(); return view('employers.add_vacancy', compact('Employer', 'jobs', 'categories')); } else { return redirect()->route('employer.cabinet_vacancie_danger'); } } // Форма предупреждения об оплате public function cabinet_vacancie_danger() { return view('employers.add_vacancy_danger'); |
e3c7b0ffb Коммит на понедел... |
178 179 180 |
} // Сохранение вакансии |
7571b20fd Коммит 13 марта 2024 |
181 |
public function cabinet_vacancy_save1(VacancyRequestEdit $request) { |
2be890eea коммит по изменен... |
182 |
$params_emp = $request->all(); |
468369903 Изменение структу... |
183 |
|
2be890eea коммит по изменен... |
184 |
$params_job["job_title_id"] = $params_emp['job_title_id']; |
468369903 Изменение структу... |
185 186 187 188 189 190 191 |
//$params_job["min_salary"] = $params_emp['min_salary']; //$params_job["max_salary"] = $params_emp['max_salary']; //$params_job["region"] = $params_emp['region']; //$params_job["power"] = $params_emp['power']; //$params_job["sytki"] = $params_emp['sytki']; //$params_job["start"] = $params_emp['start']; //$params_job["flot"] = $params_emp['flot']; |
5104f48b2 Изменение структу... |
192 |
//$params_job["description"] = $params_emp['description']; |
2be890eea коммит по изменен... |
193 194 |
$ad_jobs = Ad_employer::create($params_emp); |
468369903 Изменение структу... |
195 196 197 |
//$params_job['ad_employer_id'] = $ad_jobs->id; //Ad_jobs::create($params_job); $ad_jobs->jobs()->sync($request->get('job_title_id')); |
365e6ad01 Реализация проекта |
198 |
return redirect()->route('employer.vacancy_list'); |
e3c7b0ffb Коммит на понедел... |
199 200 201 202 203 204 |
} // Список вакансий public function vacancy_list(Request $request) { $id = Auth()->user()->id; $Employer = Employer::query()->where('user_id', $id)->first(); |
2be890eea коммит по изменен... |
205 206 207 |
$vacancy_list = Ad_employer::query()->with('jobs')-> with('jobs_code')-> where('employer_id', $Employer->id); |
365e6ad01 Реализация проекта |
208 209 210 211 212 213 214 215 216 217 218 219 |
if ($request->get('sort')) { $sort = $request->get('sort'); switch ($sort) { case 'name_up': $vacancy_list = $vacancy_list->orderBy('name')->orderBy('id'); break; case 'name_down': $vacancy_list = $vacancy_list->orderByDesc('name')->orderby('id'); break; case 'created_at_up': $vacancy_list = $vacancy_list->OrderBy('created_at')->orderBy('id'); break; case 'created_at_down': $vacancy_list = $vacancy_list->orderByDesc('created_at')->orderBy('id'); break; case 'default': $vacancy_list = $vacancy_list->orderBy('id')->orderby('updated_at'); break; default: $vacancy_list = $vacancy_list->orderBy('id')->orderby('updated_at'); break; } } |
31fe4e458 Показ проекта зак... |
220 |
$vacancy_list = $vacancy_list->paginate(4); |
365e6ad01 Реализация проекта |
221 222 223 224 225 226 |
//ajax if ($request->ajax()) { return view('employers.ajax.list_vacancy', compact('vacancy_list', 'Employer')); } else { return view('employers.list_vacancy', compact('vacancy_list', 'Employer')); } |
e3c7b0ffb Коммит на понедел... |
227 228 229 230 231 |
} // Карточка вакансии public function vacancy_edit(Ad_employer $ad_employer) { $id = Auth()->user()->id; |
f8a3cafe5 диалоговые пробле... |
232 |
$Positions = Category::query()->where('is_remove', '=', '0')->get(); |
3e8ab15f2 Статусы должносте... |
233 234 |
$jobs = Job_title::query()->OrderBy('name')-> where('is_remove', 0)->where('is_bd', '=' , '0')->get(); |
f8a3cafe5 диалоговые пробле... |
235 |
|
7571b20fd Коммит 13 марта 2024 |
236 237 |
$Employer = Employer::query()->with('users')->with('ads')->with('flots')-> where('user_id', $id)->first(); |
f8a3cafe5 диалоговые пробле... |
238 |
return view('employers.edit_vacancy', compact('ad_employer', 'Positions','Employer', 'jobs')); |
7571b20fd Коммит 13 марта 2024 |
239 |
} |
e3c7b0ffb Коммит на понедел... |
240 |
|
7571b20fd Коммит 13 марта 2024 |
241 242 |
// Сохранение-редактирование записи public function vacancy_save_me(VacancyRequestEdit $request, Ad_employer $ad_employer) { |
31fe4e458 Показ проекта зак... |
243 |
$params = $request->all(); |
7571b20fd Коммит 13 марта 2024 |
244 |
|
31fe4e458 Показ проекта зак... |
245 |
//$jobs['flot'] = $params['flot']; |
d7c3522a7 Коммит изменение ... |
246 |
//$jobs['job_title_id'] = $params['job_title_id']; |
31fe4e458 Показ проекта зак... |
247 |
//$titles['position_id'] = $params['position_id']; |
d7c3522a7 Коммит изменение ... |
248 |
//unset($params['job_title_id']); |
31fe4e458 Показ проекта зак... |
249 250 |
$ad_employer->update($params); |
d7c3522a7 Коммит изменение ... |
251 252 253 254 |
//$job_ = Ad_jobs::query()->where('job_title_id', $jobs['job_title_id'])-> // where('ad_employer_id', $ad_employer->id)->first(); //$data = Ad_jobs::find($job_->id); //$ad_jobs = $data->update($jobs); |
7571b20fd Коммит 13 марта 2024 |
255 256 |
return redirect()->route('employer.vacancy_list'); |
e3c7b0ffb Коммит на понедел... |
257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 |
} // Сохранение карточки вакансии public function vacancy_save(Request $request, Ad_employer $ad_employer) { $all = $request->all(); $ad_employer->update($all); return redirect()->route('employer.cabinet_vacancie'); } // Удаление карточки вакансии public function vacancy_delete(Ad_employer $ad_employer) { $ad_employer->delete(); return redirect()->route('employer.vacancy_list') ->with('success', 'Данные были успешно сохранены'); } // Обновление даты public function vacancy_up(Ad_employer $ad_employer) { $up = date('m/d/Y h:i:s', time());; $vac_emp = Ad_employer::findOrFail($ad_employer->id); $vac_emp->updated_at = $up; $vac_emp->save(); return redirect()->route('employer.vacancy_list'); // начало конца } //Видимость вакансии public function vacancy_eye(Ad_employer $ad_employer, $status) { $vac_emp = Ad_employer::findOrFail($ad_employer->id); $vac_emp->active_is = $status; $vac_emp->save(); return redirect()->route('employer.vacancy_list'); } //Вакансия редактирования (шаблон) public function vacancy_update(Ad_employer $id) { } //Отклики на вакансию - лист public function answers(Employer $employer, Request $request) { $user_id = Auth()->user()->id; $answer = Ad_employer::query()->where('employer_id', $employer->id); if ($request->has('search')) { $search = trim($request->get('search')); if (!empty($search)) $answer = $answer->where('name', 'LIKE', "%$search%"); } $answer = $answer->with('response')->get(); return view('employers.list_answer', compact('answer', 'user_id', 'employer')); } //Обновление статуса public function supple_status(employer $employer, ad_response $ad_response, $flag) { $ad_response->update(Array('flag' => $flag)); return redirect()->route('employer.answers', ['employer' => $employer->id]); } //Страницы сообщений список public function messages($type_message) { $user_id = Auth()->user()->id; $messages_input = Message::query()->with('vacancies')->with('user_from')-> Where('to_user_id', $user_id)->OrderByDesc('created_at'); $messages_output = Message::query()->with('vacancies')-> with('user_to')->where('user_id', $user_id)-> OrderByDesc('created_at'); $count_input = $messages_input->count(); $count_output = $messages_output->count(); if ($type_message == 'input') { |
6e2255214 Работа над сообще... |
335 |
$messages = $messages_input->paginate(5); |
e3c7b0ffb Коммит на понедел... |
336 337 338 |
} if ($type_message == 'output') { |
6e2255214 Работа над сообще... |
339 |
$messages = $messages_output->paginate(5); |
e3c7b0ffb Коммит на понедел... |
340 |
} |
6e2255214 Работа над сообще... |
341 342 |
//dd($user_id, $messages[2]->vacancies); //jobs); |
e3c7b0ffb Коммит на понедел... |
343 344 345 346 |
return view('employers.messages', compact('messages', 'count_input', 'count_output', 'type_message', 'user_id')); } // Диалог между пользователями |
6e2255214 Работа над сообще... |
347 348 349 350 351 352 353 |
public function dialog(Request $request, User_Model $user1, User_Model $user2) { // Получение параметров. if ($request->has('ad_employer')){ $ad_employer = $request->get('ad_employer'); } else { $ad_employer = 0; } |
e3c7b0ffb Коммит на понедел... |
354 355 356 357 358 |
if (isset($user2->id)) { $companion = User_Model::query()->with('workers')-> with('employers')-> where('id', $user2->id)->first(); } |
6e2255214 Работа над сообще... |
359 360 361 |
$Messages = Message::query()-> where('ad_employer_id', '=', $ad_employer)-> where(function($query) use ($user1, $user2) { |
e3c7b0ffb Коммит на понедел... |
362 363 364 |
$query->where('user_id', $user1->id)->where('to_user_id', $user2->id); })->orWhere(function($query) use ($user1, $user2) { $query->where('user_id', $user2->id)->where('to_user_id', $user1->id); |
6e2255214 Работа над сообще... |
365 |
})->where('ad_employer_id', '=', $ad_employer)->OrderBy('created_at')->get(); |
e3c7b0ffb Коммит на понедел... |
366 |
|
f8a3cafe5 диалоговые пробле... |
367 |
$id_vac = $Messages[$Messages->count() - 1]->ad_employer_id; |
e3c7b0ffb Коммит на понедел... |
368 |
|
6e2255214 Работа над сообще... |
369 370 |
//$ad_employer = null; //if (!is_null($id_vac)) $ad_employer = Ad_employer::query()->where('id', $id_vac)->first(); |
e3c7b0ffb Коммит на понедел... |
371 |
$sender = $user1; |
6e2255214 Работа над сообще... |
372 373 |
return view('employers.dialog', compact('companion', 'sender', 'ad_employer', 'Messages')); |
e3c7b0ffb Коммит на понедел... |
374 |
} |
f3766c7c1 Коммит по регистр... |
375 376 377 378 379 |
// Регистрация работодателя public function register_employer(Request $request) { $params = $request->all(); $rules = [ |
ac8b91cfd Обновление системы. |
380 381 |
//'surname' => ['required', 'string', 'max:255'], //'name_man' => ['required', 'string', 'max:255'], |
f3766c7c1 Коммит по регистр... |
382 383 |
'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 'name_company' => ['required', 'string', 'max:255'], |
e20c428e5 Коммит по 20 числу |
384 |
'password' => ['required', 'string', 'min:6'], |
f3766c7c1 Коммит по регистр... |
385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 |
]; $messages = [ 'required' => 'Укажите обязательное поле', 'min' => [ 'string' => 'Поле «:attribute» должно быть не меньше :min символов', 'integer' => 'Поле «:attribute» должно быть :min или больше', 'file' => 'Файл «:attribute» должен быть не меньше :min Кбайт' ], 'max' => [ 'string' => 'Поле «:attribute» должно быть не больше :max символов', 'integer' => 'Поле «:attribute» должно быть :max или меньше', 'file' => 'Файл «:attribute» должен быть не больше :max Кбайт' ] ]; |
2be890eea коммит по изменен... |
401 402 403 404 |
$email = $request->get('email'); if (!preg_match("/^[a-zA-Z0-9_\-.]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-.]+$/", $email)) { return json_encode(Array("ERROR" => "Error: Отсутствует емайл или некорректный емайл")); } |
f3766c7c1 Коммит по регистр... |
405 406 407 |
if ($request->get('password') !== $request->get('confirmed')){ return json_encode(Array("ERROR" => "Error: Не совпадают пароль и подтверждение пароля")); } |
e20c428e5 Коммит по 20 числу |
408 |
if (strlen($request->get('password')) < 6) { |
b17c06a23 Коммит по системе... |
409 410 |
return json_encode(Array("ERROR" => "Error: Недостаточная длина пароля! Увеличьте себе длину пароля!")); } |
e20c428e5 Коммит по 20 числу |
411 |
/* |
b17c06a23 Коммит по системе... |
412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 |
$specsumbol = Array('!','~', '#', '$', '%', '^', '&', '*', '(', ')', '-', '=', ';', ':', '<', '>', '?'); $alpha = Array('Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', 'A', 'S', 'D', 'F', 'G', 'H', 'J', 'K', 'L', 'Z', 'X', 'C', 'V', 'B', 'N', 'M'); $spec_bool = false; $alpha_bool = false; $haystack = $request->get('password'); foreach ($specsumbol as $it) { if (strpos($haystack, $it) !== false) { $spec_bool = true; } } foreach ($alpha as $it) { if (strpos($haystack, $it) !== false) { $alpha_bool = true; } } if ((!$spec_bool) || (!$alpha_bool)) { return json_encode(Array("ERROR" => "Error: Нет спецсимволов в пароле, латинские буквы заглавные, а также один из символов: !~#$%^&*()-=;,:<>?")); |
e20c428e5 Коммит по 20 числу |
434 |
}*/ |
b17c06a23 Коммит по системе... |
435 |
|
ac8b91cfd Обновление системы. |
436 437 438 |
if (empty($request->get('surname'))) { $params['surname'] = 'Неизвестно'; } |
ac8b91cfd Обновление системы. |
439 440 441 |
if (empty($request->get('name_man'))) { $params['name_man'] = 'Неизвестно'; } |
ac8b91cfd Обновление системы. |
442 |
$validator = Validator::make($params, $rules, $messages); |
f3766c7c1 Коммит по регистр... |
443 444 445 446 447 448 |
if ($validator->fails()) { return json_encode(Array("ERROR" => "Error1: Регистрация оборвалась ошибкой! Не все обязательные поля заполнены. Либо вы уже были зарегистрированы в системе.")); } else { $user = $this->create($params); event(new Registered($user)); |
f3766c7c1 Коммит по регистр... |
449 450 |
Auth::guard()->login($user); } |
b17c06a23 Коммит по системе... |
451 |
|
f3766c7c1 Коммит по регистр... |
452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 |
if ($user) { return json_encode(Array("REDIRECT" => redirect()->route('employer.cabinet')->getTargetUrl()));; } else { return json_encode(Array("ERROR" => "Error2: Данные были утеряны!")); } } // Создание пользователя protected function create(array $data) { $Use = new User_Model(); $Code_user = $Use->create([ 'name' => $data['surname']." ".$data['name_man'], 'name_man' => $data['name_man'], 'surname' => $data['surname'], 'surname2' => $data['surname2'], 'subscribe_email' => $data['email'], 'email' => $data['email'], 'telephone' => $data['telephone'], 'is_worker' => 0, 'password' => Hash::make($data['password']), 'pubpassword' => base64_encode($data['password']), 'email_verified_at' => Carbon::now() ]); if ($Code_user->id > 0) { $Employer = new Employer(); $Employer->user_id = $Code_user->id; $Employer->name_company = $data['name_company']; $Employer->email = $data['email']; $Employer->telephone = $data['telephone']; $Employer->code = Tools::generator_id(10); $Employer->save(); return $Code_user; } } |
e3c7b0ffb Коммит на понедел... |
489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 |
// Отправка сообщения от работодателя public function send_message(MessagesRequiest $request) { $params = $request->all(); dd($params); $user1 = $params['user_id']; $user2 = $params['to_user_id']; if ($request->has('file')) { $params['file'] = $request->file('file')->store("messages", 'public'); } Message::create($params); return redirect()->route('employer.dialog', ['user1' => $user1, 'user2' => $user2]); } public function test123(Request $request) { $params = $request->all(); $user1 = $params['user_id']; $user2 = $params['to_user_id']; $rules = [ 'text' => 'required|min:1|max:150000', 'file' => 'file|mimes:doc,docx,xlsx,csv,txt,xlx,xls,pdf|max:150000' ]; $messages = [ 'required' => 'Укажите обязательное поле', 'min' => [ 'string' => 'Поле «:attribute» должно быть не меньше :min символов', 'integer' => 'Поле «:attribute» должно быть :min или больше', 'file' => 'Файл «:attribute» должен быть не меньше :min Кбайт' ], 'max' => [ 'string' => 'Поле «:attribute» должно быть не больше :max символов', 'integer' => 'Поле «:attribute» должно быть :max или меньше', 'file' => 'Файл «:attribute» должен быть не больше :max Кбайт' ] ]; $validator = Validator::make($request->all(), $rules, $messages); if ($validator->fails()) { return redirect()->route('employer.dialog', ['user1' => $user1, 'user2' => $user2]) ->withErrors($validator); } else { if ($request->has('file')) { $params['file'] = $request->file('file')->store("messages", 'public'); } Message::create($params); return redirect()->route('employer.dialog', ['user1' => $user1, 'user2' => $user2]); } } //Избранные люди public function favorites(Request $request) { |
dc2a9a876 Коммит на понедел... |
543 544 545 546 547 548 549 550 551 552 |
$IP_address = RusDate::ip_addr_client(); $Arr = Like_worker::Query()->select('code_record')->where('ip_address', '=', $IP_address)->get(); if ($Arr->count()) { $A = Array(); foreach ($Arr as $it) { $A[] = $it->code_record; } $Workers = Worker::query()->whereIn('id', $A); |
478431073 Баг-ошибка это с ... |
553 |
} else { |
136bdb8d2 Статус избранные |
554 |
$Workers = Worker::query()->where('id', '=', '0'); |
478431073 Баг-ошибка это с ... |
555 |
} |
e3c7b0ffb Коммит на понедел... |
556 |
|
e3c7b0ffb Коммит на понедел... |
557 558 559 560 561 562 563 564 565 566 567 568 569 570 |
if (($request->has('search')) && (!empty($request->get('search')))) { $search = $request->get('search'); $Workers = $Workers->WhereHas('users', function (Builder $query) use ($search) { $query->Where('surname', 'LIKE', "%$search%") ->orWhere('name_man', 'LIKE', "%$search%") ->orWhere('surname2', 'LIKE', "%$search%"); }); } else { $Workers = $Workers->with('users'); } $Workers = $Workers->get(); |
415bebd6c Баг с избранными ... |
571 |
|
e3c7b0ffb Коммит на понедел... |
572 573 574 575 576 577 578 579 580 581 582 583 584 585 |
return view('employers.favorite', compact('Workers')); } // База данных public function bd(Request $request) { // для типа BelongsTo //$documents = Document::query()->orderBy(Location::select('name') // ->whereColumn('locations.id', 'documents.location_id') //); // для типа HasOne/Many // $documents = Document::::query()->orderBy(Location::select('name') // ->whereColumn('locations.document_id', 'documents.id') //); |
ac8b91cfd Обновление системы. |
586 |
|
e3c7b0ffb Коммит на понедел... |
587 |
$users = User_Model::query()->with('workers'); |
ac8b91cfd Обновление системы. |
588 589 590 |
if ($request->has('search')) { $find_key = $request->get('search'); |
e3c7b0ffb Коммит на понедел... |
591 |
$users = $users->where('name', 'LIKE', "%$find_key%") |
ac8b91cfd Обновление системы. |
592 593 |
->orWhere('surname', 'LIKE', "%$find_key%") ->orWhere('name_man', 'LIKE', "%$find_key%") |
e3c7b0ffb Коммит на понедел... |
594 595 596 597 598 599 |
->orWhere('email', 'LIKE', "%$find_key%") ->orWhere('telephone', 'LIKE', "%$find_key%"); } // Данные $users = $users->Baseuser()-> |
e20c428e5 Коммит по 20 числу |
600 601 602 |
orderBy(Worker::select('position_work')->whereColumn('Workers.user_id', 'users.id')); $count_users = $users; $users = $users->paginate(5); |
e3c7b0ffb Коммит на понедел... |
603 |
|
ac8b91cfd Обновление системы. |
604 |
|
e20c428e5 Коммит по 20 числу |
605 |
return view('employers.bd', compact('users', 'count_users')); |
e3c7b0ffb Коммит на понедел... |
606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 |
} //Настройка уведомлений public function subscribe() { return view('employers.subcribe'); } //Установка уведомлений сохранение public function save_subscribe(Request $request) { dd($request->all()); $msg = $request->validate([ 'subscribe_email' => 'required|email|min:5|max:255', ]); return redirect()->route('employer.subscribe')->with('Вы успешно подписались на рассылку'); } //Сбросить форму с паролем public function password_reset() { $email = Auth()->user()->email; return view('employers.password-reset', compact('email')); } //Обновление пароля public function new_password(Request $request) { $use = Auth()->user(); $request->validate([ 'password' => 'required|string', 'new_password' => 'required|string', 'new_password2' => 'required|string' ]); if ($request->get('new_password') == $request->get('new_password2')) if ($request->get('password') !== $request->get('new_password')) { $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { if (!is_null($use->email_verified_at)){ $user_data = User_Model::find($use->id); $user_data->update([ 'password' => Hash::make($request->get('new_password')), 'pubpassword' => base64_encode($request->get('new_password')), ]); return redirect() ->route('employer.password_reset') ->with('success', 'Поздравляю! Вы обновили свой пароль!'); } return redirect() ->route('employer.password_reset') ->withError('Данная учетная запись не было верифицированна!'); } } return redirect() ->route('employer.password_reset') ->withErrors('Не совпадение данных, обновите пароли!'); } |
f3766c7c1 Коммит по регистр... |
664 |
|
e3c7b0ffb Коммит на понедел... |
665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 |
// Форма Удаление пипла public function delete_people() { $login = Auth()->user()->email; return view('employers.delete_people', compact('login')); } // Удаление аккаунта public function action_delete_user(Request $request) { $Answer = $request->all(); $user_id = Auth()->user()->id; $request->validate([ 'password' => 'required|string', ]); $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { Auth::logout(); $it = User_Model::find($user_id); |
dc2a9a876 Коммит на понедел... |
683 |
$it->delete(); |
e3c7b0ffb Коммит на понедел... |
684 685 686 687 688 689 |
return redirect()->route('index')->with('success', 'Вы успешно удалили свой аккаунт'); } else { return redirect()->route('employer.delete_people') ->withErrors( 'Неверный пароль! Нужен корректный пароль'); } } |
6370754b6 Обновление бага с... |
690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 |
public function ajax_delete_user(Request $request) { $Answer = $request->all(); $user_id = Auth()->user()->id; $request->validate([ 'password' => 'required|string', ]); $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { return json_encode(Array('SUCCESS' => 'Вы успешно удалили свой аккаунт', 'email' => $request->get('email'), 'password' => $request->get('password'))); } else { return json_encode(Array('ERROR' => 'Неверный пароль! Нужен корректный пароль')); } } |
e3c7b0ffb Коммит на понедел... |
706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 |
// FAQ - Вопросы/ответы для работодателей и соискателей public function faq() { return view('employers.faq'); } // Рассылка сообщений public function send_all_messages() { return view('employers.send_all'); } // Отправка сообщений для информации public function send_all_post(Request $request) { $data = $request->all(); $emails = User_Model::query()->where('is_worker', '1')->get(); foreach ($emails as $e) { Mail::to($e->email)->send(new SendAllMessages($data)); } return redirect()->route('employer.send_all_messages')->with('success', 'Письма были отправлены'); } // База резюме public function bd_tupe(Request $request) { $Resume = User_Model::query()->with('workers')->where('is_bd', '=', '1')->get(); return view('employers.bd_tupe', compact('Resume')); } |
b6103c749 Обновление js и c... |
735 736 |
////////////////////////////////////////////////////////////////// |
b6103c749 Обновление js и c... |
737 |
// Отправил сообщение |
b6103c749 Обновление js и c... |
738 739 740 |
////////////////////////////////////////////////////////////////// public function new_message(Request $request) { $params = $request->all(); |
b6103c749 Обновление js и c... |
741 742 743 744 745 746 747 748 749 |
$id = $params['_user_id']; $message = new Message(); $message->user_id = $params['_user_id']; $message->to_user_id = $params['_to_user_id']; $message->title = $params['title']; $message->text = $params['text']; if ($request->has('_file')) { $message->file = $request->file('_file')->store("worker/$id", 'public'); } |
f8a3cafe5 диалоговые пробле... |
750 |
$message->ad_employer_id = $params['_vacancy']; |
b6103c749 Обновление js и c... |
751 752 |
$message->flag_new = 1; $id_message = $message->save(); |
f8a3cafe5 диалоговые пробле... |
753 754 755 |
//$data['message_id'] = $id_message; //$data['ad_employer_id'] = $params['_vacancy']; //$data['job_title_id'] = 0; |
b6103c749 Обновление js и c... |
756 757 |
$data['flag'] = 1; |
f8a3cafe5 диалоговые пробле... |
758 |
//$ad_responce = ad_response::create($data); |
b6103c749 Обновление js и c... |
759 760 761 762 763 764 |
return redirect()->route('employer.messages', ['type_message' => 'output']); } // Восстановление пароля public function repair_password(Request $request) { $params = $request->get('email'); |
31fe4e458 Показ проекта зак... |
765 |
} |
b6103c749 Обновление js и c... |
766 |
|
31fe4e458 Показ проекта зак... |
767 768 769 |
// Избранные люди на корабль public function selected_people(Request $request) { $id = $request->get('id'); |
f8a3cafe5 диалоговые пробле... |
770 |
$favorite_people = Job_title::query()->Notbdif()->where('is_remove', '=', '0')->where('position_id', $id)->get(); |
31fe4e458 Показ проекта зак... |
771 |
return view('favorite_people', compact('favorite_people')); |
b6103c749 Обновление js и c... |
772 |
} |
5b68533bb Работа над проект... |
773 |
} |