Blame view

app/Http/Controllers/WorkerController.php 44.2 KB
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
1
2
3
  <?php
  
  namespace App\Http\Controllers;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
4
  use App\Classes\RusDate;
ad0b69c97   Fedor   task-132687 tasks...
5
  use App\Classes\Tools;
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
6
  use App\Http\Requests\DocumentsRequest;
492296b6f   Андрей Ларионов   Коммит по итогу п...
7
8
  use App\Http\Requests\PrevCompanyRequest;
  use App\Http\Requests\SertificationRequest;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
9
  use App\Models\Ad_employer;
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
10
  use App\Models\ad_response;
2f592b01f   Сергей П   сообщения
11
  use App\Models\Chat;
99a41e761   Андрей Ларионов   Личный кабинет по...
12
  use App\Models\Dop_info;
8ec6b4403   Fedor   task-132985 autor...
13
14
  use App\Models\Employer;
  use App\Models\EmployerAutoliftOption;
99a41e761   Андрей Ларионов   Личный кабинет по...
15
  use App\Models\infobloks;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
16
  use App\Models\Job_title;
dc2a9a876   Андрей Ларионов   Коммит на понедел...
17
  use App\Models\Like_vacancy;
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
18
  use App\Models\Message;
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
19
  use App\Models\place_works;
492296b6f   Андрей Ларионов   Коммит по итогу п...
20
  use App\Models\PrevCompany;
6b9776dfb   Андрей Ларионов   Вторник работа на...
21
  use App\Models\ResponseWork;
99a41e761   Андрей Ларионов   Личный кабинет по...
22
  use App\Models\sertification;
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
23
  use App\Models\Static_worker;
b17c06a23   Андрей Ларионов   Коммит по системе...
24
  use App\Models\Title_worker;
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
25
  use App\Models\User;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
26
  use App\Models\User as User_Model;
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
27
  use App\Models\Worker;
8ec6b4403   Fedor   task-132985 autor...
28
  use App\Models\WorkerAutoliftOption;
99702d426   Андрей Ларионов   Коммит вечер воск...
29
  use Barryvdh\DomPDF\Facade\Pdf;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
30
  use Carbon\Carbon;
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
31
  use Illuminate\Auth\Events\Registered;
f3766c7c1   Андрей Ларионов   Коммит по регистр...
32
  use Illuminate\Database\Eloquent\Builder;
8ec6b4403   Fedor   task-132985 autor...
33
  use Illuminate\Http\RedirectResponse;
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
34
  use Illuminate\Http\Request;
ab181e741   Fedor   task-132985 autol...
35
  use Illuminate\Pagination\LengthAwarePaginator;
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
36
  use Illuminate\Support\Facades\Auth;
5c0ae0519   Fedor   task-132687 minor...
37
  use Illuminate\Support\Facades\DB;
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
38
  use Illuminate\Support\Facades\Hash;
99a41e761   Андрей Ларионов   Личный кабинет по...
39
  use Illuminate\Support\Facades\Storage;
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
40
  use Illuminate\Support\Facades\Validator;
8ec6b4403   Fedor   task-132985 autor...
41
42
  use Illuminate\View\View;
  use JsonException;
d3496aa08   Сергей П   Изменения для раз...
43
44
45
46
  use PhpOffice\PhpSpreadsheet\Spreadsheet;
  use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
  use Symfony\Component\HttpFoundation\StreamedResponse;
  use App\Enums\DbExportColumns;
0388bf4f0   Сергей П   Задачи 44,46,48
47
  use App\Enums\WorkerStatuses;
d4632b7a2   Сергей П   Анкета работника
48
  use DateTime;
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
49
50
51
  
  class WorkerController extends Controller
  {
5b68533bb   Андрей Ларионов   Работа над проект...
52
      //профиль
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
53
54
      public function profile(Worker $worker)
      {
673a7768d   Андрей Ларионов   Правки в админке,...
55
          $get_date = date('Y.m');
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
  
          $c = Static_worker::query()->where('year_month', '=', $get_date)
              ->where('user_id', '=', $worker->users->id)
              ->get();
  
          if ($c->count() > 0) {
              $upd = Static_worker::find($c[0]->id);
              $upd->lookin = $upd->lookin + 1;
              $upd->save();
          } else {
              $crt = new Static_worker();
              $crt->lookin = 1;
              $crt->year_month = $get_date;
              $crt->user_id = $worker->user_id;
              $crt->save();
          }
  
          $stat = Static_worker::query()->where('year_month', '=', $get_date)
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
74
75
              ->where('user_id', '=', $worker->users->id)
              ->get();
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
76
77
78
  
          return view('public.workers.profile', compact('worker', 'stat'));
      }
5b68533bb   Андрей Ларионов   Работа над проект...
79

a13ce8670   Андрей Ларионов   Обновление проект...
80
      // лист база резюме
ad20c698a   Андрей Ларионов   Результаты на вос...
81
      public function bd_resume(Request $request)
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
82
      {
b6103c749   Андрей Ларионов   Обновление js и c...
83
          if (isset(Auth()->user()->id)) {
ad0b69c97   Fedor   task-132687 tasks...
84
85
              if ((Auth()->user()->is_worker) || (!Auth()->user()->is_lookin))
                  return redirect()->route('index')->withErrors(['errors' => ['Вы не можете просматривать базу резюме. Подробнее в меню: "Условия размещения"']]);
b6103c749   Андрей Ларионов   Обновление js и c...
86
          }
ad0b69c97   Fedor   task-132687 tasks...
87
88
89
90
91
92
93
94
95
96
97
          $status_work = WorkerStatuses::getWorkerStatuses();
  
          $resumes = Worker::query()->with('users')->with('job_titles')->orderByDesc('updated_at');
          $resumes = $resumes->whereHas('users', function (Builder $query) {
              $query->Where('is_worker', '=', '1')
                  ->Where('is_bd', '=', '0');
          });
  
          if (($request->has('job')) && ($request->get('job') > 0)) {
              $resumes = $resumes->whereHas('job_titles', function (Builder $query) use ($request) {
                  $query->Where('job_titles.id', $request->get('job'));
ac8b91cfd   Андрей Ларионов   Обновление системы.
98
              });
ad0b69c97   Fedor   task-132687 tasks...
99
          }
ac8b91cfd   Андрей Ларионов   Обновление системы.
100

ad0b69c97   Fedor   task-132687 tasks...
101
102
103
104
105
          $Job_title = Job_title::query()
              ->where('is_remove', '=', '0')
              ->where('is_bd', '=' , '1')
              ->orderByDesc('sort')
              ->get();
ac8b91cfd   Андрей Ларионов   Обновление системы.
106

ad0b69c97   Fedor   task-132687 tasks...
107
108
109
110
111
112
113
114
115
116
117
118
          if ($request->get('sort')) {
              $sort = $request->get('sort');
              switch ($sort) {
                  case 'looking_for_work':
                      $resumes->where('status_work', '=', WorkerStatuses::LookingForWork->value);
                      break;
                  case 'considering_offers':
                      $resumes->where('status_work', '=', WorkerStatuses::ConsideringOffers->value);
                      break;
                  case 'not_looking_for_work':
                      $resumes->where('status_work', '=', WorkerStatuses::NotLookingForWork->value);
                      break;
ad20c698a   Андрей Ларионов   Результаты на вос...
119
              }
ad0b69c97   Fedor   task-132687 tasks...
120
          }
a13ce8670   Андрей Ларионов   Обновление проект...
121

ab181e741   Fedor   task-132985 autol...
122
123
          $resumes = $resumes->get()->filter(function ($worker) {
              return Tools::getWorkerProfilePercent($worker) >= 50;
ad0b69c97   Fedor   task-132687 tasks...
124
125
126
          });
  
          $res_count = $resumes->count();
ab181e741   Fedor   task-132985 autol...
127
128
129
130
131
132
133
134
  
          $currentPage = $_GET['page'] ?? 1;
          $resumes = new LengthAwarePaginator(
              items: $resumes->slice(4 * ($currentPage - 1), 4),
              total: $res_count,
              perPage: 4,
          );
          $resumes->setPath('bd-resume');
ad0b69c97   Fedor   task-132687 tasks...
135
136
137
138
          if ($request->ajax()) {
              // Условия обставлены
              if ($request->has('block') && ($request->get('block') == 1)) {
                  return view('ajax.resume_1', compact('resumes', 'status_work', 'res_count'));
ad20c698a   Андрей Ларионов   Результаты на вос...
139
140
              }
          } else {
ad0b69c97   Fedor   task-132687 tasks...
141
              return view('resume', compact('resumes', 'status_work', 'res_count', 'Job_title'));
ad20c698a   Андрей Ларионов   Результаты на вос...
142
          }
a13ce8670   Андрей Ларионов   Обновление проект...
143
      }
d4632b7a2   Сергей П   Анкета работника
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
      public function basic_information(){
          if (!isset(Auth()->user()->id)) {
              abort(404);
          }
  
          $user_id = Auth()->user()->id;
  
          $user = User::query()
              ->with('workers')
              ->with(['jobtitles' => function ($query) {
                  $query->select('job_titles.id');
              }])
              ->where('id', '=', $user_id)
              ->first();
          $user->workers[0]->job_titles = $user->workers[0]->job_titles->pluck('id')->toArray();
00076c621   Сергей П   фиксы
159
160
161
          $job_titles = Job_title::query()
              ->where('is_remove', '=', 0)
              ->where('is_bd', '=', 1)
dfdf584b4   Сергей П   фиксы
162
163
              ->orderByDesc('sort')
              ->get()
00076c621   Сергей П   фиксы
164
          ;
d4632b7a2   Сергей П   Анкета работника
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
  
          return view('workers.form_basic_information', compact('user', 'job_titles'));
      }
  
      public function additional_documents(){
          if (!isset(Auth()->user()->id)) {
              abort(404);
          }
  
          $user_id = Auth()->user()->id;
  
          $info_blocks = infobloks::query()->OrderBy('name')->get();
          $additional_document_statuses = [0 => 'Не указано', 1 => 'В наличии', 2 => 'Отсутствует'];
  
          $worker = Worker::query()
              ->with('users')
              ->with('infobloks')
              ->WhereHas('users', function (Builder $query) use ($user_id) {
                  $query->Where('id', $user_id);
              })
              ->first();
          if ($worker->dop_info->count()){
              $worker->dop_info = $worker->dop_info->keyBy('infoblok_id')->toArray();
          }
  
          return view('workers.form_additional_documents', compact('worker', 'info_blocks', 'additional_document_statuses'));
      }
dc2a9a876   Андрей Ларионов   Коммит на понедел...
192
193
194
195
      //Лайк резюме
      public function like_controller() {
  
      }
a13ce8670   Андрей Ларионов   Обновление проект...
196
      // анкета соискателя
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
197
198
      public function resume_profile(Worker $worker)
      {
bfc7d8856   Андрей Ларионов   Финальные изменения
199
200
201
202
203
          if (isset(Auth()->user()->id)) {
              $idiot = Auth()->user()->id;
          } else {
              $idiot = 0;
          }
0388bf4f0   Сергей П   Задачи 44,46,48
204
          $status_work = WorkerStatuses::getWorkerStatuses();
a13ce8670   Андрей Ларионов   Обновление проект...
205
206
          $Query = Worker::query()->with('users')->with('job_titles')
              ->with('place_worker')->with('sertificate')->with('prev_company')
0ea985223   Андрей Ларионов   Коммит по диалога...
207
              ->with('infobloks')->with('response');
a13ce8670   Андрей Ларионов   Обновление проект...
208
209
          $Query = $Query->where('id', '=', $worker->id);
          $Query = $Query->get();
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
210
211
  
          $get_date = date('Y.m');
7f2872aa3   Андрей Ларионов   Коммит Работа-среда
212

8e4c0bff2   Андрей Ларионов   Коммит по срочным...
213
          $infoblocks = infobloks::query()->get();
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
214
          $c = Static_worker::query()->where('year_month', '=', $get_date)
2726f0123   Андрей Ларионов   Коммит по багам д...
215
              ->where('user_id', '=', $worker->user_id)
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
216
217
218
219
220
221
222
223
224
225
226
              ->get();
  
          if ($c->count() > 0) {
              $upd = Static_worker::find($c[0]->id);
              $upd->lookin = $upd->lookin + 1;
              $upd->save();
          } else {
              $crt = new Static_worker();
              $crt->lookin = 1;
              $crt->year_month = $get_date;
              $crt->user_id = $worker->user_id;
2726f0123   Андрей Ларионов   Коммит по багам д...
227
              $status = $crt->save();
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
228
          }
8e4c0bff2   Андрей Ларионов   Коммит по срочным...
229

7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
230
          $stat = Static_worker::query()->where('year_month', '=', $get_date)
0ea985223   Андрей Ларионов   Коммит по диалога...
231
              ->where('user_id', '=', $worker->user_id)
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
232
              ->get();
0ea985223   Андрей Ларионов   Коммит по диалога...
233

8e4c0bff2   Андрей Ларионов   Коммит по срочным...
234
          return view('worker', compact('Query', 'infoblocks', 'status_work', 'idiot', 'stat'));
a13ce8670   Андрей Ларионов   Обновление проект...
235
236
237
      }
  
      // скачать анкету соискателя
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
238
239
      public function resume_download(Worker $worker)
      {
0388bf4f0   Сергей П   Задачи 44,46,48
240
          $status_work = WorkerStatuses::getWorkerStatuses();
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
241
242
243
244
          $Query = Worker::query()->with('users')->with('job_titles')
              ->with('place_worker')->with('sertificate')->with('prev_company')
              ->with('infobloks');
          $Query = $Query->where('id', '=', $worker->id);
92b3de35e   Сергей П   Задача 45 + фиксы
245
          $Query = $Query->get();
99702d426   Андрей Ларионов   Коммит вечер воск...
246

7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
247
          view()->share('Query',$Query);
99702d426   Андрей Ларионов   Коммит вечер воск...
248

0388bf4f0   Сергей П   Задачи 44,46,48
249
          $status_work = WorkerStatuses::getWorkerStatuses();
92b3de35e   Сергей П   Задача 45 + фиксы
250
          $infoblocks = infobloks::query()->get();
5c0ae0519   Fedor   task-132687 minor...
251
          //return view('layout.pdf', compact('Query', 'status_work', 'infoblocks'));
92b3de35e   Сергей П   Задача 45 + фиксы
252
253
254
255
256
          $pdf = PDF::loadView('layout.pdf', [
              'Query' => $Query,
              'status_work' => $status_work,
              'infoblocks' => $infoblocks
          ])->setPaper('a4', 'landscape');
99702d426   Андрей Ларионов   Коммит вечер воск...
257

5c0ae0519   Fedor   task-132687 minor...
258
          return $pdf->download();
5b68533bb   Андрей Ларионов   Работа над проект...
259
      }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
260

d3496aa08   Сергей П   Изменения для раз...
261
262
263
      public function resume_download_all(Request $request) {
          $spreadsheet = new Spreadsheet();
          $sheet = $spreadsheet->getActiveSheet();
ac8b91cfd   Андрей Ларионов   Обновление системы.
264

d3496aa08   Сергей П   Изменения для раз...
265
266
          $columnMap = range('A', 'Z');
          $columns = [];
ac8b91cfd   Андрей Ларионов   Обновление системы.
267

d3496aa08   Сергей П   Изменения для раз...
268
269
          foreach (DbExportColumns::toArray() as $key => $value){
              if ($request->input($key, 0)){
ea2a5ac13   Сергей П   Изменения для раз...
270
271
                  $sheet->setCellValue("{$columnMap[count($columns)]}1", ucfirst($value));
                  $columns[] = str_replace('__', '.', $key);
d3496aa08   Сергей П   Изменения для раз...
272
273
              }
          }
ac8b91cfd   Андрей Ларионов   Обновление системы.
274

d3496aa08   Сергей П   Изменения для раз...
275
276
277
          if (empty($columns)) {
              return redirect()->back()->with('error', 'Пожалуйста выберите хотя бы 1 колонку для экспорта.');
          }
5c0ae0519   Fedor   task-132687 minor...
278
          $jobIds = $request->input('job_title_list', []);
3a2da2a11   Андрей Ларионов   Экспорт данных в ...
279

8ec6b4403   Fedor   task-132985 autor...
280
281
          /* //query for mysql ver 8.0 or higher
            $users = DB::select(
5c0ae0519   Fedor   task-132687 minor...
282
283
284
285
286
287
288
289
290
291
292
293
              "select `job_titles`.`name`, `users`.`surname`, `users`.`name_man`, `users`.`surname2`, `users`.`email`, `users`.`telephone`
              from users
                  join workers on `users`.`id` = `workers`.`user_id`
                  join `job_titles`
              where `users`.`is_bd` = 1
                  and (`workers`.`position_work` = `job_titles`.`id`
                  or exists (select 1
                      from JSON_TABLE(
                          workers.positions_work,
                          '$[*]' COLUMNS (id INT PATH '$')) pw
                      where pw.id = job_titles.id)
                  )". ((!empty($jobIds)) ? 'and job_titles.id in ('. implode(',', $jobIds).')' : '')
8ec6b4403   Fedor   task-132985 autor...
294
          );*/
3a2da2a11   Андрей Ларионов   Экспорт данных в ...
295
          /*$users = DB::select(
8ec6b4403   Fedor   task-132985 autor...
296
297
298
299
              "select `job_titles`.`name`, `users`.`surname`, `users`.`name_man`, `users`.`surname2`, `users`.`email`, `users`.`telephone`
              from users
                  join workers on `users`.`id` = `workers`.`user_id`
                  join `job_titles`
3a2da2a11   Андрей Ларионов   Экспорт данных в ...
300
              where `users`.`is_bd` = 2
8ec6b4403   Fedor   task-132985 autor...
301
302
303
                  and (`workers`.`position_work` = `job_titles`.`id`
                  or `workers`.`positions_work`
                  )". ((!empty($jobIds)) ? 'and job_titles.id in ('. implode(',', $jobIds).')' : '')
3a2da2a11   Андрей Ларионов   Экспорт данных в ...
304
          );*/
5c0ae0519   Fedor   task-132687 minor...
305

3a2da2a11   Андрей Ларионов   Экспорт данных в ...
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
335
336
337
338
339
340
341
342
343
344
          /*$users = DB::select("select `job_titles`.`name`, `users`.`surname`, `users`.`name_man`,
                              `users`.`surname2`, `users`.`email`, `users`.`telephone`, `users`.`id`, `job_titles`.`id`
                              FROM `users`
                                  JOIN `job_titles`
                                   JOIN workers ON `users`.id = `workers`.user_id
                                   JOIN worker_jobs ON `users`.`id` = `worker_jobs`.user_id AND
                                                       `job_titles`.`id` = `worker_jobs`.job_id");
          */
          $first_part = "SELECT
                          w.user_id, u.`name`, u.`surname`, u.`surname2`,
                          GROUP_CONCAT(j.`name` SEPARATOR ', ') AS job_titles_names,
                          u.`email`, u.`telephone`, w.`positions_work`
                      FROM
                          users u
                      INNER JOIN
                          Workers w ON u.id = w.user_id
                      INNER JOIN
                          JSON_TABLE(w.positions_work, '$[*]' COLUMNS (pos INT PATH '$')) AS extracted_positions
                      INNER JOIN
                          job_titles j ON j.id = extracted_positions.pos";
  
          $second_part = " ";
          if (!is_null($jobIds))
              if (is_array($jobIds))
                  if (count($jobIds) > 0)
                  {
                      $second_part = " WHERE ";
                      foreach ($jobIds as $key => $it) {
                          if ($key == 0)
                              $second_part .= "(j.id = ".$it.") ";
                          elseif ($key > 0)
                              $second_part .= "OR (j.id = ".$it.") ";
                      }
                  }
  
          $three_part = "GROUP BY w.user_id, w.positions_work, u.`name`
                      HAVING COUNT(DISTINCT j.id) = JSON_LENGTH(w.positions_work)";
  
          $users = DB::select($first_part.$second_part.$three_part);
5c0ae0519   Fedor   task-132687 minor...
345
346
347
          $users = collect($users);
  
          if ($users->count()) {
d3496aa08   Сергей П   Изменения для раз...
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
              $i = 2;
              foreach ($users->toArray() as $user){
                  $j = 0;
                  foreach ($user as $field){
                      $sheet->setCellValue("{$columnMap[$j++]}$i", $field);
                  }
                  $i++;
              }
          }
          $writer = new Xlsx($spreadsheet);
          $fileName = 'DB.xlsx';
  
          $response = new StreamedResponse(function() use ($writer) {
              $writer->save('php://output');
          });
  
          $response->headers->set('Content-Type', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
          $response->headers->set('Content-Disposition', 'attachment;filename="' . $fileName . '"');
          $response->headers->set('Cache-Control', 'max-age=0');
  
          return $response;
ac8b91cfd   Андрей Ларионов   Обновление системы.
369
      }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
370
      // Кабинет работника
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
371
      public function cabinet(Request $request)
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
372
      {
492296b6f   Андрей Ларионов   Коммит по итогу п...
373
          // дата год и месяц
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
374
          $get_date = date('Y.m');
f3766c7c1   Андрей Ларионов   Коммит по регистр...
375
          $id = Auth()->user()->id;
492296b6f   Андрей Ларионов   Коммит по итогу п...
376
377
  
          $Infobloks = infobloks::query()->get();
d834955fe   Fedor   task-132687 додел...
378
379
380
381
          $Worker = Worker::query()
              ->with(['users', 'sertificate', 'prev_company', 'infobloks', 'place_worker'])
              ->WhereHas('users', function (Builder $query) use ($id) {
                  $query->Where('id', $id);
ad0b69c97   Fedor   task-132687 tasks...
382
              })->first();
99a41e761   Андрей Ларионов   Личный кабинет по...
383

d834955fe   Fedor   task-132687 додел...
384
385
386
387
          $Job_titles = Job_title::query()->where('is_remove', '=', '0')
              ->where('is_bd', '=' , '1')
              ->OrderByDesc('sort')->OrderBy('name')
              ->get();
99a41e761   Андрей Ларионов   Личный кабинет по...
388

7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
389
          $stat = Static_worker::query()->where('year_month', '=', $get_date)
7f2872aa3   Андрей Ларионов   Коммит Работа-среда
390
              ->where('user_id', '=', $id)
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
391
              ->get();
ad0b69c97   Fedor   task-132687 tasks...
392
          $persent = Tools::getWorkerProfilePercent($Worker);
d4632b7a2   Сергей П   Анкета работника
393

0388bf4f0   Сергей П   Задачи 44,46,48
394
          $status_work = WorkerStatuses::getWorkerStatuses();
d4632b7a2   Сергей П   Анкета работника
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
          $additional_document_statuses = [0 => 'Не указано', 1 => 'В наличии', 2 => 'Отсутствует'];
          $info_blocks = infobloks::query()->OrderBy('name')->get();
  
          $worker = Worker::query()
              ->with('users')
              ->with('sertificate')
              ->with('prev_company')
              ->with('infobloks')
              ->with('place_worker')
              ->with('job_titles')
              ->WhereHas('users', function (Builder $query) use ($id) {
                  $query->Where('id', $id);
              })
              ->first();
          if ($worker->dop_info->count()){
              $worker->dop_info = $worker->dop_info->keyBy('infoblok_id')->toArray();
          }
  
          //dd($worker->dop_info);
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
414
415
416
          if ($request->has('print')) {
             dd($Worker);
          } else {
d4632b7a2   Сергей П   Анкета работника
417
418
419
              return view('workers.cabinet', compact( 'persent', 'Job_titles', 'stat',
                  'worker', 'info_blocks', 'status_work', 'additional_document_statuses'
              ));
7571b20fd   Андрей Ларионов   Коммит 13 марта 2024
420
          }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
421
422
423
      }
  
      // Сохранение данных
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
424
425
      public function cabinet_save(Worker $worker, Request $request)
      {
99a41e761   Андрей Ларионов   Личный кабинет по...
426
427
          $id = $worker->id;
          $params = $request->all();
99a41e761   Андрей Ларионов   Личный кабинет по...
428
          $job_title_id = $request->get('job_title_id');
99a41e761   Андрей Ларионов   Личный кабинет по...
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
          $rules = [
              'surname' => ['required', 'string', 'max:255'],
              'name_man' => ['required', 'string', 'max:255'],
              'email' => ['required', 'string', 'email', 'max:255'],
  
          ];
  
          $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($params, $rules, $messages);
  
          if ($validator->fails()) {
              return redirect()->route('worker.cabinet')->withErrors($validator);
          } else {
  
              if ($request->has('photo')) {
d4632b7a2   Сергей П   Анкета работника
457
458
                  if (!empty($worker->photo)) {
                      Storage::delete($worker->photo);
99a41e761   Андрей Ларионов   Личный кабинет по...
459
460
461
462
463
                  }
                  $params['photo'] = $request->file('photo')->store("worker/$id", 'public');
              }
  
              if ($request->has('file')) {
d4632b7a2   Сергей П   Анкета работника
464
465
                  if (!empty($worker->file)) {
                      Storage::delete($worker->file);
99a41e761   Андрей Ларионов   Личный кабинет по...
466
467
468
                  }
                  $params['file'] = $request->file('file')->store("worker/$id", 'public');
              }
d4632b7a2   Сергей П   Анкета работника
469
              $worker->update($params);
2be890eea   Андрей Ларионов   коммит по изменен...
470
              $use = User::find($worker->user_id);
99a41e761   Андрей Ларионов   Личный кабинет по...
471
472
473
474
475
476
              $use->surname = $request->get('surname');
              $use->name_man = $request->get('name_man');
              $use->surname2 = $request->get('surname2');
  
              $use->save();
              $worker->job_titles()->sync($job_title_id);
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
477

689548bec   Сергей П   Задачи 52,60 + пр...
478
              return redirect()->route('worker.cabinet')->with('success', 'Данные были успешно сохранены');
99a41e761   Андрей Ларионов   Личный кабинет по...
479
          }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
480
      }
9d2ae55e9   Сергей П   Анкета работника ...
481
482
      public function cabinet_save_foto(Worker $worker, Request $request){
          $params = ['photo' => null];
e60a32501   Сергей П   Измененения для р...
483

9d2ae55e9   Сергей П   Анкета работника ...
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
          if ($request->has('photo')) {
              if (!empty($worker->photo)) {
                  Storage::delete($worker->photo);
              }
              $params['photo'] = $request->file('photo')->store("worker/$worker->id", 'public');
          }
  
          if ($request->has('file')) {
              if (!empty($worker->file)) {
                  Storage::delete($worker->file);
              }
              $params['file'] = $request->file('file')->store("worker/$worker->id", 'public');
          }
  
          $worker->update($params);
  
          return redirect()->route('worker.cabinet');
      }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
502
      // Сообщения данные
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
503
504
      public function messages($type_message)
      {
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
505
          $user_id = Auth()->user()->id;
2f592b01f   Сергей П   сообщения
506
          $chats = Chat::get_user_chats($user_id);
f98ccb92c   Сергей П   Массова рассылка
507
          $admin_chat = Chat::get_user_admin_chat($user_id);
2f592b01f   Сергей П   сообщения
508
          $user_type = 'worker';
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
509

f98ccb92c   Сергей П   Массова рассылка
510
          return view('workers.messages', compact('chats', 'admin_chat','user_id', 'user_type'));
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
511
512
513
      }
  
      // Избранный
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
514
515
      public function favorite()
      {
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
516
517
          return view('workers.favorite');
      }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
518
      // Сменить пароль
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
519
520
      public function new_password()
      {
f3766c7c1   Андрей Ларионов   Коммит по регистр...
521
522
          $email = Auth()->user()->email;
          return view('workers.new_password', compact('email'));
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
523
      }
f3766c7c1   Андрей Ларионов   Коммит по регистр...
524
525
526
527
528
529
530
531
532
533
534
535
      // Обновление пароля
      public function save_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');
ad20c698a   Андрей Ларионов   Результаты на вос...
536
                  if (Auth::attempt($credentials, $request->has('save_me'))) {
f3766c7c1   Андрей Ларионов   Коммит по регистр...
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
  
                      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('worker.new_password')
                              ->with('success', 'Поздравляю! Вы обновили свой пароль!');
                      }
  
                      return redirect()
                          ->route('worker.new_password')
                          ->withError('Данная учетная запись не было верифицированна!');
                  }
              }
  
          return redirect()
              ->route('worker.new_password')
              ->withErrors('Не совпадение данных, обновите пароли!');
      }
  
      // Удаление профиля форма
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
562
563
      public function delete_profile()
      {
f3766c7c1   Андрей Ларионов   Коммит по регистр...
564
565
566
          $login = Auth()->user()->email;
          return view('workers.delete_profile', compact('login'));
      }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
567

f3766c7c1   Андрей Ларионов   Коммит по регистр...
568
569
570
571
572
573
574
575
576
577
578
579
      // Удаление профиля код
      public function delete_profile_result(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   Андрей Ларионов   Коммит на понедел...
580
              $it->delete();
f3766c7c1   Андрей Ларионов   Коммит по регистр...
581
582
583
584
585
              return redirect()->route('index')->with('success', 'Вы успешно удалили свой аккаунт');
          } else {
              return redirect()->route('worker.delete_profile')
                  ->withErrors( 'Неверный пароль! Нужен корректный пароль');
          }
e3c7b0ffb   Андрей Ларионов   Коммит на понедел...
586
      }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
587
588
589
590
591
  
      // Регистрация соискателя
      public function register_worker(Request $request)
      {
          $params = $request->all();
31fe4e458   Андрей Ларионов   Показ проекта зак...
592
          $params['is_worker'] = 1;
bb21d1ccb   Андрей Ларионов   Суббота работа на...
593

142d287bd   Андрей Ларионов   Шаблоны кабинета ...
594
595
596
          $rules = [
              'surname' => ['required', 'string', 'max:255'],
              'name_man' => ['required', 'string', 'max:255'],
b17c06a23   Андрей Ларионов   Коммит по системе...
597
              'email' => ['required', 'email', 'max:255', 'unique:users'],
e20c428e5   Андрей Ларионов   Коммит по 20 числу
598
              'password' => ['required', 'string', 'min:6']
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
          ];
  
          $messages = [
              'required' => 'Укажите обязательное поле',
              'min' => [
                  'string' => 'Поле «:attribute» должно быть не меньше :min символов',
                  'integer' => 'Поле «:attribute» должно быть :min или больше',
                  'file' => 'Файл «:attribute» должен быть не меньше :min Кбайт'
              ],
              'max' => [
                  'string' => 'Поле «:attribute» должно быть не больше :max символов',
                  'integer' => 'Поле «:attribute» должно быть :max или меньше',
                  'file' => 'Файл «:attribute» должен быть не больше :max Кбайт'
              ]
          ];
2be890eea   Андрей Ларионов   коммит по изменен...
614
615
          $email =  $request->get('email');
          if (!preg_match("/^[a-zA-Z0-9_\-.]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-.]+$/", $email)) {
b17c06a23   Андрей Ларионов   Коммит по системе...
616
617
              return json_encode(Array("ERROR" => "Error: Отсутствует емайл или некорректный емайл"));
          }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
618
619
620
          if ($request->get('password') !== $request->get('confirmed')){
              return json_encode(Array("ERROR" => "Error: Не совпадают пароль и подтверждение пароля"));
          }
e20c428e5   Андрей Ларионов   Коммит по 20 числу
621
622
623
          if (strlen($request->get('password')) < 6) {
              return json_encode(Array("ERROR" => "Error: Недостаточная длина пароля! Увеличьте себе длину пароля!"));
          }
bb21d1ccb   Андрей Ларионов   Суббота работа на...
624
          if (($request->has('politik')) && ($request->get('politik') == 1)) {
ac8b91cfd   Андрей Ларионов   Обновление системы.
625
              $validator = Validator::make($params, $rules, $messages);
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
626

bb21d1ccb   Андрей Ларионов   Суббота работа на...
627
628
629
630
631
              if ($validator->fails()) {
                  return json_encode(array("ERROR" => "Error1: Регистрация оборвалась ошибкой! Не все обязательные поля заполнены. Либо вы уже были зарегистрированы в системе."));
              } else {
                  $user = $this->create($params);
                  event(new Registered($user));
bb21d1ccb   Андрей Ларионов   Суббота работа на...
632
633
                  Auth::guard()->login($user);
              }
bb21d1ccb   Андрей Ларионов   Суббота работа на...
634
635
636
637
638
              if ($user) {
                  return json_encode(Array("REDIRECT" => redirect()->route('worker.cabinet')->getTargetUrl()));;
              } else {
                  return json_encode(Array("ERROR" => "Error2: Данные были утеряны!"));
              }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
639

142d287bd   Андрей Ларионов   Шаблоны кабинета ...
640
          } else {
bb21d1ccb   Андрей Ларионов   Суббота работа на...
641
              return json_encode(Array("ERROR" => "Error3: Вы не согласились с политикой  конфидициальности!"));
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
642
643
          }
      }
6b9776dfb   Андрей Ларионов   Вторник работа на...
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
      // Звездная оценка и ответ
      public function stars_answer(Request $request) {
          $params = $request->all();
          $rules = [
              'message' => ['required', 'string', 'max:255'],
          ];
  
          $messages = [
              'required' => 'Укажите обязательное поле',
              'min' => [
                  'string' => 'Поле «:attribute» должно быть не меньше :min символов',
                  'integer' => 'Поле «:attribute» должно быть :min или больше',
                  'file' => 'Файл «:attribute» должен быть не меньше :min Кбайт'
              ],
              'max' => [
                  'string' => 'Поле «:attribute» должно быть не больше :max символов',
                  'integer' => 'Поле «:attribute» должно быть :max или меньше',
                  'file' => 'Файл «:attribute» должен быть не больше :max Кбайт'
              ]
          ];
          $response_worker = ResponseWork::create($params);
          return redirect()->route('resume_profile', ['worker' => $request->get('worker_id')])->with('success', 'Ваше сообщение было отправлено!');
      }
b17c06a23   Андрей Ларионов   Коммит по системе...
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
      public function TestWorker()
      {
          $Use = new User();
  
          $Code_user = $Use->create([
              'name' => 'surname name_man',
              'name_man' => 'name_man',
              'surname' => 'surname',
              'surname2' => 'surname2',
              'subscribe_email' => '1',
              'email' => 'email@mail.com',
              'telephone' => '1234567890',
              'password' => Hash::make('password'),
              'pubpassword' => base64_encode('password'),
              'email_verified_at' => Carbon::now(),
              'is_worker' => 1,
          ]);
  
          if ($Code_user->id > 0) {
              $Worker = new Worker();
              $Worker->user_id = $Code_user->id;
              $Worker->position_work =  1; //'job_titles';
              $Worker->email = 'email@email.com';
              $Worker->telephone = '1234567890';
              $status = $Worker->save();
  
              $Title_Worker = new Title_worker();
              $Title_Worker->worker_id = $Worker->id;
              $Title_Worker->job_title_id = 1;
              $Title_Worker->save();
          }
      }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
699
700
701
702
      // Создание пользователя
      protected function create(array $data)
      {
          $Use = new User();
b17c06a23   Андрей Ларионов   Коммит по системе...
703

142d287bd   Андрей Ларионов   Шаблоны кабинета ...
704
705
          $Code_user = $Use->create([
                              'name' => $data['surname']." ".$data['name_man'],
f3766c7c1   Андрей Ларионов   Коммит по регистр...
706
707
708
                              'name_man' => $data['name_man'],
                              'surname' => $data['surname'],
                              'surname2' => $data['surname2'],
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
709
710
711
712
713
                              'subscribe_email' => $data['email'],
                              'email' => $data['email'],
                              'telephone' => $data['telephone'],
                              'password' => Hash::make($data['password']),
                              'pubpassword' => base64_encode($data['password']),
ac8b91cfd   Андрей Ларионов   Обновление системы.
714
715
                              'email_verified_at' => Carbon::now(),
                              'is_worker' => $data['is_worker'],
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
716
                          ]);
b17c06a23   Андрей Ларионов   Коммит по системе...
717

f3766c7c1   Андрей Ларионов   Коммит по регистр...
718
719
720
721
722
723
724
          if ($Code_user->id > 0) {
              $Worker = new Worker();
              $Worker->user_id = $Code_user->id;
              $Worker->position_work = $data['job_titles'];
              $Worker->email = $data['email'];
              $Worker->telephone = $data['telephone'];
              $Worker->save();
b17c06a23   Андрей Ларионов   Коммит по системе...
725
726
727
728
729
730
              if (isset($Worker->id)) {
                  $Title_Worker = new Title_worker();
                  $Title_Worker->worker_id = $Worker->id;
                  $Title_Worker->job_title_id = $data['job_titles'];
                  $Title_Worker->save();
              }
f3766c7c1   Андрей Ларионов   Коммит по регистр...
731
732
              return $Code_user;
          }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
733
      }
1862e7a3a   Андрей Ларионов   Борьба против кол...
734

dc2a9a876   Андрей Ларионов   Коммит на понедел...
735
      // Вакансии избранные
f3766c7c1   Андрей Ларионов   Коммит по регистр...
736
      public function colorado(Request $request) {
0e7702a32   Fedor   task-132687 minor...
737
738
739
740
          $Arr = Like_vacancy::Query()
              ->select('code_record')
              ->where('user_id', Auth::user()->id)
              ->get();
dc2a9a876   Андрей Ларионов   Коммит на понедел...
741
742
743
744
745
746
747
748
  
          if ($Arr->count()) {
              $A = Array();
              foreach ($Arr as $it) {
                  $A[] = $it->code_record;
              }
  
              $Query = Ad_employer::query()->whereIn('id', $A);
f3766c7c1   Андрей Ларионов   Коммит по регистр...
749
          } else {
136bdb8d2   Андрей Ларионов   Статус избранные
750
              $Query = Ad_employer::query()->where('id', '=', '0');
f3766c7c1   Андрей Ларионов   Коммит по регистр...
751
          }
d834955fe   Fedor   task-132687 додел...
752
753
754
755
756
757
          $Query = $Query->with(['jobs', 'cat', 'employer'])
              ->whereHas('jobs_code', function ($query) use ($request) {
                  if ($request->ajax()) {
                      if (null !== ($request->get('job'))) {
                          $query->where('job_title_id', $request->get('job'));
                      }
f3766c7c1   Андрей Ларионов   Коммит по регистр...
758
                  }
d834955fe   Fedor   task-132687 додел...
759
760
761
762
763
764
765
766
767
              })
              ->select('ad_employers.*');
  
          if ($request->get('search') !== null) {
              $search = $request->get('search');
              $Query->where('name', 'LIKE', "%$search%");
          }
  
          //dd($Query->get());
f3766c7c1   Андрей Ларионов   Коммит по регистр...
768
769
770
771
772
773
774
775
776
777
778
779
  
          $Job_title = Job_title::query()->OrderBy('name')->get();
  
          $Query_count = $Query->count();
  
          $Query = $Query->OrderBy('updated_at')->paginate(3);
  
          return view('workers.favorite', compact('Query',
                                                      'Query_count',
                                                                  'Job_title'));
  
      }
6b9776dfb   Андрей Ларионов   Вторник работа на...
780
      //Переписка
f98ccb92c   Сергей П   Массова рассылка
781
      public function dialog(Chat $chat, Request $request) {
d06d95278   Андрей Ларионов   Работа с избранны...
782
783
784
785
786
787
          // Получение параметров.
          if ($request->has('ad_employer')){
              $ad_employer = $request->get('ad_employer');
          } else {
              $ad_employer = 0;
          }
f98ccb92c   Сергей П   Массова рассылка
788
789
          $sender = User_Model::query()->with('workers')->with('employers')->where('id', $chat->user_id)->first();
          $companion = User_Model::query()->with('workers')->with('employers')->where('id', $chat->to_user_id)->first();
7f2872aa3   Андрей Ларионов   Коммит Работа-среда
790

f98ccb92c   Сергей П   Массова рассылка
791
          $Messages = Chat::get_chat_messages($chat);
d06d95278   Андрей Ларионов   Работа с избранны...
792

df58eaf86   Сергей П   правки
793
          Message::where('chat_id_to', '=', $chat->id)->update(['flag_new' => 0]);
7fa088c5b   Сергей П   Задачи 58,49,51 +...
794

f98ccb92c   Сергей П   Массова рассылка
795
          return view('workers.dialog', compact('companion', 'sender', 'chat', 'Messages', 'ad_employer'));
1862e7a3a   Андрей Ларионов   Борьба против кол...
796
      }
99a41e761   Андрей Ларионов   Личный кабинет по...
797

99702d426   Андрей Ларионов   Коммит вечер воск...
798
      // Даунылоады
99a41e761   Андрей Ларионов   Личный кабинет по...
799
      public function download(Worker $worker) {
99702d426   Андрей Ларионов   Коммит вечер воск...
800
801
802
803
          $arr_house = ['0' => 'Проверка, проверка, проверка, проверка, проверка...'];
          view()->share('house',$arr_house);
          $pdf = PDF::loadView('layout.pdf', $arr_house)->setPaper('a4', 'landscape');
          return $pdf->stream();
99a41e761   Андрей Ларионов   Личный кабинет по...
804
805
806
807
808
809
      }
  
      // Поднятие анкеты
      public function up(Worker $worker) {
          $worker->updated_at = Carbon::now();
          $worker->save();
31fe4e458   Андрей Ларионов   Показ проекта зак...
810
          // 0
99a41e761   Андрей Ларионов   Личный кабинет по...
811
812
          return redirect()->route('worker.cabinet')->with('success', 'Ваша анкета была поднята выше остальных');
      }
b3d27fa36   Андрей Ларионов   Обновление проект...
813
814
815
816
      // Форма сертификате
      public function new_sertificate(Worker $worker) {
          return view('workers.sertificate_add', compact('worker'));
      }
99a41e761   Андрей Ларионов   Личный кабинет по...
817
      // Добавление сертификата
492296b6f   Андрей Ларионов   Коммит по итогу п...
818
      public function add_serificate(SertificationRequest $request) {
d4632b7a2   Сергей П   Анкета работника
819
820
821
822
823
824
825
826
          $request->validate([
              'name' => 'required|string|max:255',
              'end_begin' => 'required|date|date_format:d.m.Y'
          ],
          [
              'name' => 'Навание сертификата обязательно для заполнения.',
              'end_begin' => 'Формат даты должен соответствовать дд.мм.гггг'
          ]);
99a41e761   Андрей Ларионов   Личный кабинет по...
827
          $params = $request->all();
b3d27fa36   Андрей Ларионов   Обновление проект...
828

d4632b7a2   Сергей П   Анкета работника
829
830
          $end_begin = DateTime::createFromFormat('d.m.Y', $params['end_begin']);
          $params['end_begin'] = $end_begin->format('Y-m-d');
99a41e761   Андрей Ларионов   Личный кабинет по...
831
832
          $Sertificate = new sertification();
          $Sertificate->create($params);
d721fd846   Сергей П   правки по сообщен...
833
834
835
836
  
          return response()->json([
              'success' => true
          ]);
99a41e761   Андрей Ларионов   Личный кабинет по...
837
      }
99a41e761   Андрей Ларионов   Личный кабинет по...
838
839
840
841
842
843
      // Удалить сертификат
      public function delete_sertificate(sertification $doc) {
          $doc->delete();
  
          return redirect()->route('worker.cabinet');
      }
492296b6f   Андрей Ларионов   Коммит по итогу п...
844
845
846
847
848
849
850
      // Редактирование сертификата
      public function edit_sertificate(Worker $worker, sertification $doc) {
          return view('workers.sertificate_edit', compact('doc', 'worker'));
      }
  
      // Редактирование обновление сертификата
      public function update_serificate(SertificationRequest $request, sertification $doc) {
d4632b7a2   Сергей П   Анкета работника
851
852
853
854
855
856
857
858
          $request->validate([
              'name' => 'required|string|max:255',
              'end_begin' => 'required|date|date_format:d.m.Y'
          ],
          [
              'name' => 'Навание сертификата обязательно для заполнения.',
              'end_begin' => 'Формат даты должен соответствовать дд.мм.гггг'
          ]);
492296b6f   Андрей Ларионов   Коммит по итогу п...
859
          $all = $request->all();
d4632b7a2   Сергей П   Анкета работника
860
861
862
  
          $end_begin = DateTime::createFromFormat('d.m.Y', $all['end_begin']);
          $all['end_begin'] = $end_begin->format('Y-m-d');
492296b6f   Андрей Ларионов   Коммит по итогу п...
863
864
865
866
867
868
869
          $doc->worker_id = $all['worker_id'];
          $doc->name = $all['name'];
          $doc->end_begin = $all['end_begin'];
          $doc->save();
  
          return redirect()->route('worker.cabinet')->with('success', 'Вы успешно отредактировали запись!');
      }
e60a32501   Сергей П   Измененения для р...
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
      public function edit_diploms(Request $request, Worker $worker) {
          $dop_info_data = $request->input('diploms');
  
          if (empty($dop_info_data)) {
              return redirect()->route('worker.additional_documents')->with('error', 'Данные не предоставлены!');
          }
  
          foreach ($dop_info_data as $infoblok_id => $status) {
              Dop_info::updateOrCreate(
                  ['worker_id' => $worker->id, 'infoblok_id' => $infoblok_id],
                  ['status' => $status]
              );
          }
  
          return redirect()->route('worker.additional_documents')->with('success', 'Успешно сохранено!');
      }
492296b6f   Андрей Ларионов   Коммит по итогу п...
886
887
888
889
890
891
892
893
      public function delete_add_diplom(Request $request, Worker $worker) {
          $infoblok_id = $request->get('infoblok_id');
  
          if (Dop_info::query()->where('worker_id', $worker->id)->where('infoblok_id', $infoblok_id)->count() > 0)
              $id = Dop_info::query()->where('worker_id', $worker->id)->where('infoblok_id', $infoblok_id)->delete();
          else {
              $params['infoblok_id'] = $infoblok_id;
              $params['worker_id'] = $worker->id;
7243b8e24   Андрей Ларионов   Обновление проект...
894
              $params['status'] = $request->get('val');
492296b6f   Андрей Ларионов   Коммит по итогу п...
895
896
897
898
899
900
901
              $id = Dop_info::create($params);
              //$id = $worker->infobloks()->sync([$infoblok_id]);
          }
  
          //$Infoblocks = infobloks::query()->get();
          return $id; //redirect()->route('worker.cabinet')->getTargetUrl(); //view('workers.ajax.diploms_dop', compact('worker', 'Infoblocks'));
      }
99a41e761   Андрей Ларионов   Личный кабинет по...
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
      // Добавление диплома
      public function add_diplom_ajax(Request $request) {
          // конец
          $params = $request->all();
          $count = Dop_info::query()->where('worker_id', $request->get('worker_id'))->where('infoblok_id', $request->get('infoblok_id'))->count();
  
          if ($count == 0) $dop_info = Dop_info::create($params);
          $Infoblocks = infobloks::query()->get();
          $Worker = Worker::query()->where('id', $request->get('worker_id'))->get();
          $data = Dop_info::query()->where('worker_id', $request->has('worker_id'));
          return view('ajax.dop_info', compact('data', 'Infoblocks', 'Worker'));
      }
  
      // Добавление диплома без ajax
      public function add_diplom(Worker $worker) {
          $worker_id = $worker->id;
          $Infoblocks = infobloks::query()->get();
          return view('workers.dop_info', compact('worker_id', 'worker', 'Infoblocks'));
      }
      // Сохранить
      // Сохраняю диплом
      public function add_diplom_save(Request $request) {
          $params = $request->all();
          $count = Dop_info::query()->where('worker_id', $request->get('worker_id'))->where('infoblok_id', $request->get('infoblok_id'))->count();
          if ($count == 0) $dop_info = Dop_info::create($params);
          return redirect()->route('worker.cabinet');
      }
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
929
930
931
932
933
934
935
936
937
  
      // Добавление стандартного документа
      public function add_document(Worker $worker) {
          return view('workers.docs', compact('worker'));
      }
  
      //Сохранение стандартого документа
      public function add_document_save(DocumentsRequest $request) {
          $params = $request->all();
127b2097d   Сергей П   правки в личном к...
938
939
          place_works::create($params);
          return response()->json(['success' => true]);
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
      }
  
      // Редактирование документа
      public function edit_document(place_works $doc, Worker $worker) {
          return view('workers.docs-edit', compact('doc', 'worker'));
      }
  
      //Сохранение отредактированного документа
      public function edit_document_save(DocumentsRequest $request, place_works $doc) {
          $params = $request->all();
          $doc->update($params);
  
          return redirect()->route('worker.cabinet')->with('success', 'Вы успешно отредактировали запись!');
      }
  
      // Удаление документа
      public function delete_document(place_works $doc) {
          $doc->delete();
          return redirect()->route('worker.cabinet')->with('success', 'Вы успешно удалили запись!');
      }
  
      //Отправка нового сообщения
6e9c6423b   Fedor   task-132687 tasks...
962
963
      public function new_message(Request $request)
      {
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
964
          $params = $request->all();
465aace57   Fedor   task-132687 minor...
965
          $id = $params['user_from'];
712f07ca2   Сергей П   часть задачи по р...
966

465aace57   Fedor   task-132687 minor...
967
          Message::add_message(
712f07ca2   Сергей П   часть задачи по р...
968
              $request,
465aace57   Fedor   task-132687 minor...
969
970
971
972
973
974
975
              $params['user_from'],
              $params['user_to'],
              [
                  'text' => $params['comment'] ?? null,
                  'ad_employer_id' => $params['vacancy'],
                  'flag_new' => 1
              ],
712f07ca2   Сергей П   часть задачи по р...
976
977
              file_store_path: "worker/$id"
          );
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
978

ab181e741   Fedor   task-132985 autol...
979
980
981
982
          if ($request->ajax()) {
              return response([]);
          }
          return redirect()->back();
a9dfa8c95   Андрей Ларионов   Обновление на 7 м...
983
      }
6b9776dfb   Андрей Ларионов   Вторник работа на...
984

d06d95278   Андрей Ларионов   Работа с избранны...
985
986
987
988
989
  
      public function test123(Request $request) {
          $params = $request->all();
          $user1 = $params['user_id'];
          $user2 = $params['to_user_id'];
d06d95278   Андрей Ларионов   Работа с избранны...
990
991
  
          $rules = [
3d041f3f0   Сергей П   Изменения для соо...
992
993
              'text' => 'nullable|required_without:file|min:1|max:150000',
              'file' => 'nullable|file|mimes:doc,docx,xlsx,csv,txt,xlx,xls,pdf|max:150000'
d06d95278   Андрей Ларионов   Работа с избранны...
994
995
          ];
          $messages = [
3d041f3f0   Сергей П   Изменения для соо...
996
              'required_without' => 'Поле «:attribute» обязательно, если файл не прикреплен',
d06d95278   Андрей Ларионов   Работа с избранны...
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
              '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()) {
3d041f3f0   Сергей П   Изменения для соо...
1012
1013
1014
              $chat = Chat::where('user_id', $user1)
                  ->where('to_user_id', $user2)
                  ->where('is_removed', 0)
7d97dde35   Fedor   task-132985 minor...
1015
                  ->first();
3d041f3f0   Сергей П   Изменения для соо...
1016
1017
1018
1019
1020
1021
  
              if ($chat->id){
                  return redirect()->route('worker.dialog', ['chat' => $chat->id])->withErrors($validator);
              } else {
                  return redirect()->route('cabinet.messages', ['type_message' => 'input'])->withErrors($validator);
              }
d06d95278   Андрей Ларионов   Работа с избранны...
1022
          } else {
f98ccb92c   Сергей П   Массова рассылка
1023
              $new_message = Message::add_message($request, $user1, $user2, $request->all(), file_store_path: 'messages');
712f07ca2   Сергей П   часть задачи по р...
1024

7d97dde35   Fedor   task-132985 minor...
1025
              //dd('new message', $new_message);
df58eaf86   Сергей П   правки
1026
              return redirect()->route('worker.dialog', ['chat' => $new_message->chat_id_from]);
d06d95278   Андрей Ларионов   Работа с избранны...
1027
1028
          }
      }
492296b6f   Андрей Ларионов   Коммит по итогу п...
1029
1030
1031
1032
1033
1034
1035
1036
1037
      // Информация о предыдущих компаниях
      public function new_prev_company(Worker $worker) {
          return view('workers.prev_company_form', compact('worker'));
      }
  
      // Добавление контакта компании
      public function add_prev_company(PrevCompanyRequest $request) {
          // Возвращение параметров
          $all = $request->all();
127b2097d   Сергей П   правки в личном к...
1038
          PrevCompany::create($all);
492296b6f   Андрей Ларионов   Коммит по итогу п...
1039

127b2097d   Сергей П   правки в личном к...
1040
          return response()->json(['success' => true]);
492296b6f   Андрей Ларионов   Коммит по итогу п...
1041
      }
7243b8e24   Андрей Ларионов   Обновление проект...
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
      // Редактирование контакта компании
      public function edit_prev_company(PrevCompany $doc, Worker $worker) {
          return view('workers.prev_company_edit_form', compact('doc', 'worker'));
      }
  
      //Сохранение редактирования контакта компании
      public function update_prev_company(PrevCompany $doc, Request $request){
          $all = $request->all();
          $doc->update($all);
  
          return redirect()->route('worker.cabinet')->with('success', 'Вы успешно отредактировали запись');
      }
492296b6f   Андрей Ларионов   Коммит по итогу п...
1054
1055
1056
1057
1058
      // Удаление контакта предыдущей компании
      public function delete_prev_company(PrevCompany $doc) {
          $doc->delete();
          return redirect()->route('worker.cabinet')->with('success', 'Вы успешно удалили запись!');
      }
8ec6b4403   Fedor   task-132985 autor...
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
  
      public function autoresponder()
      {
          $user = Auth::user();
          return view('workers.autoresponder', compact('user'));
      }
  
      public function autoresponderSave(Request $request): RedirectResponse
      {
          /** @var Employer $employer */
          $employer = Auth::user();
          $employer->autoresponder = $request->get('autoresponder', false) === 'on';
          $employer->autoresponder_message = $request->get('autoresponder_message');
          $employer->save();
  
          return redirect(route('worker.autoresponder'));
      }
      /**
       * @throws JsonException
       */
      public function resumeAutoLiftForm(): View
      {
          $worker = Auth::user()->workers[0];
  
          $options = $worker->autoliftOptions ?? new WorkerAutoliftOption();
  
          return view('workers.resume_autolift', compact('worker', 'options'));
      }
  
      /**
       * @throws JsonException
       */
      public function resumeAutoLiftSave(Request $request)
      {
          $worker = Auth::user()->workers[0];
  
          $worker->autoliftOptions()->updateOrCreate(
              [
                  'worker_id' => $worker->id,
              ],
              [
bae7fd15b   Fedor   task-132985 minor...
1100
                  'is_enabled' => $request->get('is_enabled') === 'true',
8ec6b4403   Fedor   task-132985 autor...
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
                  'times_per_day' => $request->get('times_per_day'),
                  'days_repeat' => $request->get('days_repeat'),
                  'time_send_first' => $request->get('time_send_first'),
                  'time_send_second' => $request->get('time_send_second'),
                  'time_send_third' => $request->get('time_send_third'),
                  'time_send_tg' => $request->get('time_send_tg'),
                  'autolift_site' => $request->get('autolift_site') === 'on',
              ]
          );
  
          return response()->json(['success' => true]);
      }
b52b1df0d   Андрей Ларионов   Опция поднятия ва...
1113
  }
142d287bd   Андрей Ларионов   Шаблоны кабинета ...
1114