Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1709 eleazar 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
2667 eleazar 8
use LeadersLinked\Library\InterviewPDF;
1709 eleazar 9
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
10
use Laminas\Mvc\Controller\AbstractActionController;
11
use Laminas\Log\LoggerInterface;
12
use Laminas\View\Model\JsonModel;
13
use LeadersLinked\Form\RecruitmentSelectionInterviewFormForm;
1828 eleazar 14
use LeadersLinked\Form\JobDescriptionForm;
1829 eleazar 15
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
16
use LeadersLinked\Library\Functions;
17
use LeadersLinked\Mapper\CompanyMapper;
18
use LeadersLinked\Mapper\CompetencyTypeMapper;
19
use LeadersLinked\Model\JobDescription;
20
use LeadersLinked\Mapper\CompetencyMapper;
4029 eleazar 21
use LeadersLinked\Mapper\BehaviorCompetencyMapper;
22
use LeadersLinked\Model\BehaviorCompetency;
1829 eleazar 23
use LeadersLinked\Library\JobPdf;
24
use LeadersLinked\Mapper\JobDescriptionCompetencyMapper;
25
use LeadersLinked\Mapper\JobDescriptionSubordinateMapper;
26
use LeadersLinked\Model\JobDescriptionCompetency;
27
use LeadersLinked\Model\JobDescriptionBehaviorCompetency;
28
use LeadersLinked\Mapper\JobDescriptionBehaviorCompetencyMapper;
29
use LeadersLinked\Model\JobDescriptionSubordinate;
30
use LeadersLinked\Mapper\BehaviorMapper;
31
use LeadersLinked\Model\Behavior;
32
use LeadersLinked\Model\Company;
1713 eleazar 33
use LeadersLinked\Mapper\RecruitmentSelectionInterviewMapper;
34
use LeadersLinked\Model\RecruitmentSelectionInterview;
35
use LeadersLinked\Mapper\RecruitmentSelectionVacancyMapper;
36
use LeadersLinked\Model\RecruitmentSelectionVacancy;
37
use LeadersLinked\Mapper\RecruitmentSelectionCandidateMapper;
38
use LeadersLinked\Model\RecruitmentSelectionCandidate;
39
use LeadersLinked\Mapper\JobDescriptionMapper;
1717 eleazar 40
use Laminas\View\Model\ViewModel;
41
use LeadersLinked\Form\RecruitmentSelectionCandidateFormForm;
42
use Laminas\Hydrator\ArraySerializableHydrator;
43
use Laminas\Db\ResultSet\HydratingResultSet;
44
use LeadersLinked\Mapper\QueryMapper;
45
use Laminas\Paginator\Adapter\DbSelect;
46
use Laminas\Paginator\Paginator;
1709 eleazar 47
 
48
class RecruitmentSelectionInterviewFormController extends AbstractActionController {
49
 
50
    /**
51
     *
52
     * @var AdapterInterface
53
     */
54
    private $adapter;
55
 
56
    /**
57
     *
58
     * @var AbstractAdapter
59
     */
60
    private $cache;
61
 
62
    /**
63
     *
64
     * @var  LoggerInterface
65
     */
66
    private $logger;
67
 
68
    /**
69
     *
70
     * @var array
71
     */
72
    private $config;
73
 
74
    /**
75
     *
76
     * @param AdapterInterface $adapter
77
     * @param AbstractAdapter $cache
78
     * @param LoggerInterface $logger
79
     * @param array $config
80
     */
81
    public function __construct($adapter, $cache, $logger, $config) {
82
        $this->adapter = $adapter;
83
        $this->cache = $cache;
84
        $this->logger = $logger;
85
        $this->config = $config;
86
    }
87
 
88
    public function indexAction() {
89
        $currentUserPlugin = $this->plugin('currentUserPlugin');
90
        $currentUser = $currentUserPlugin->getUser();
91
        $currentCompany = $currentUserPlugin->getCompany();
3458 eleazar 92
 
1709 eleazar 93
        $request = $this->getRequest();
3458 eleazar 94
 
1709 eleazar 95
        if($request->isGet())
96
        {
97
            $headers  = $request->getHeaders();
3458 eleazar 98
 
1709 eleazar 99
            $isJson = false;
100
            if($headers->has('Accept')) {
101
                $accept = $headers->get('Accept');
3458 eleazar 102
 
1709 eleazar 103
                $prioritized = $accept->getPrioritized();
3458 eleazar 104
 
1709 eleazar 105
                foreach($prioritized as $key => $value) {
106
                    $raw = trim($value->getRaw());
3458 eleazar 107
 
1709 eleazar 108
                    if(!$isJson) {
109
                        $isJson = strpos($raw, 'json');
110
                    }
111
                }
112
            }
3458 eleazar 113
 
2021 eleazar 114
            if ($isJson) {
4350 eleazar 115
                $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
116
 
3458 eleazar 117
                $search = $this->params()->fromQuery('search', []);
118
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
119
 
120
                $page = intval($this->params()->fromQuery('start', 1), 10);
121
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
122
                $order = $this->params()->fromQuery('order', []);
123
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
124
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
125
 
126
                $fields = ['uuid', 'first_name', 'last_name', 'email'];
127
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';
128
 
129
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
130
                     $order_direction = 'ASC';
131
                }
132
 
3536 eleazar 133
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
134
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/interview/form/edit');
135
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/interview/form/delete');
136
                $allowReport = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/interview/report');
137
 
3484 eleazar 138
                $queryMapper = QueryMapper::getInstance($this->adapter);
139
                $sql = $queryMapper->getSql();
3515 eleazar 140
                $select = $sql->select();
3884 eleazar 141
                $select->columns(['uuid', 'company_id', 'status', 'type', 'vacancy_id']);
3516 eleazar 142
                $select->from(['i' => RecruitmentSelectionInterviewMapper::_TABLE]);
3526 eleazar 143
                $select->join(['c' => RecruitmentSelectionCandidateMapper::_TABLE], "i.candidate_id = c.id", ['first_name', 'last_name', 'email']);
4361 eleazar 144
                $select->join(['v' => RecruitmentSelectionVacancyMapper::_TABLE],"c.vacancy_id = v.id", ['name', 'last_date']);
4360 eleazar 145
                $select->where->equalTo('i.company_id', $currentCompany->id);
4361 eleazar 146
                $select->where->equalTo('v.uuid', $vacancy_uuid);
3514 eleazar 147
 
3887 eleazar 148
               // echo $select->getSqlString($this->adapter->platform); exit;
3458 eleazar 149
 
3484 eleazar 150
                if($search) {
151
                    $select->where->nest()
152
                    ->like('first_name', '%' . $search . '%')
153
                    ->unnest();
154
                }
3458 eleazar 155
 
3484 eleazar 156
                $select->order($order_field . ' ' . $order_direction);
3458 eleazar 157
 
3484 eleazar 158
                $hydrator = new ArraySerializableHydrator();
159
                $resultset = new HydratingResultSet($hydrator);
160
 
4359 eleazar 161
                $adapter = new DbSelect($select, $sql, $resultset);
162
                $paginator = new Paginator($adapter);
163
                $paginator->setItemCountPerPage($records_x_page);
164
                $paginator->setCurrentPageNumber($page);
165
 
3484 eleazar 166
                $items = [];
167
                $records = $paginator->getCurrentItems();
168
 
3882 eleazar 169
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
170
                $vacancies = $vacancyMapper->fetchAllByCompanyId($currentCompany->id);
171
 
3542 eleazar 172
                /*return new JsonModel([
3540 eleazar 173
                    'success' => true,
174
                    'data' => $records,
3542 eleazar 175
                ]);*/
3540 eleazar 176
 
3484 eleazar 177
                foreach ($records as $record) {
178
                    $params = [
3537 eleazar 179
                        'interview_uuid' => $record['uuid'],
3484 eleazar 180
                    ];
3536 eleazar 181
 
182
                    $link_delete = $this->url()->fromRoute('recruitment-and-selection/interview/form/delete', $params);
183
 
184
                    $link_edit = $this->url()->fromRoute('recruitment-and-selection/interview/form/edit', $params);
3710 eleazar 185
 
186
                    $link_report = $this->url()->fromRoute('recruitment-and-selection/interview/report', $params);
3536 eleazar 187
 
3484 eleazar 188
 
189
                    $item = [
190
                        'uuid' => $record['uuid'],
191
                        'first_name' => $record['first_name'],
192
                        'last_name' => $record['last_name'],
193
                        'email' => $record['email'],
3882 eleazar 194
                        'vacancy' =>$record['name'],
3953 eleazar 195
                        'last_date' =>$record['last_date'],
3543 eleazar 196
                        'status' => $record['status'],
3561 eleazar 197
                        'type' => $record['type'],
3484 eleazar 198
                        // 'file' => $this->url()->fromRoute('storage', ['type' => 'recruitment_selection', 'code' => $record['uuid'], 'filename' => $record['file']]),
3536 eleazar 199
                        'actions' => [
200
                            'link_edit' => $allowEdit ? $link_edit : '',
201
                            'link_delete' => $allowDelete ? $link_delete : '',
3710 eleazar 202
                            'link_report' => $allowReport ? $link_report : '',
3536 eleazar 203
                        ]
3484 eleazar 204
                    ];
205
 
206
                    array_push($items, $item);
207
                }
208
 
2029 eleazar 209
                return new JsonModel([
210
                    'success' => true,
2033 eleazar 211
                    'data' => [
3528 eleazar 212
                        'items' => $items,
213
                        'total' => $paginator->getTotalItemCount()
2033 eleazar 214
                    ],
2029 eleazar 215
                ]);
1709 eleazar 216
            } else {
2199 eleazar 217
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2203 eleazar 218
                $vacancies = $vacancyMapper->fetchAllByCompanyId($currentCompany->id);
2211 eleazar 219
 
220
                $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany ? $currentCompany->id : null);
3458 eleazar 221
 
1709 eleazar 222
                $this->layout()->setTemplate('layout/layout-backend');
223
                $viewModel = new ViewModel();
1718 eleazar 224
                $viewModel->setTemplate('leaders-linked/recruitment-and-selection-interview/index.phtml');
1709 eleazar 225
                $viewModel->setVariables([
2211 eleazar 226
                    'form'      => $form,
2207 eleazar 227
                    'vacancies' => $vacancies
1709 eleazar 228
                ]);
3458 eleazar 229
 
1709 eleazar 230
                return $viewModel ;
231
            }
3458 eleazar 232
 
1709 eleazar 233
        } else {
234
            return new JsonModel([
235
                'success' => false,
236
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
237
            ]);
238
        }
239
    }
240
 
3571 eleazar 241
    public function addAction(){
1827 eleazar 242
        $currentUserPlugin = $this->plugin('currentUserPlugin');
243
        $currentUser = $currentUserPlugin->getUser();
244
        $currentCompany = $currentUserPlugin->getCompany();
1709 eleazar 245
 
1827 eleazar 246
        $request = $this->getRequest();
3454 eleazar 247
 
1906 eleazar 248
        if ($request->isGet()) {
3571 eleazar 249
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getinstance($this->adapter);
250
            $vacancies = $vacancyMapper->fetchAllByCompany($currentCompany->id);
3454 eleazar 251
 
3571 eleazar 252
            new JsonModel([
253
                'success' => false,
254
                'data' => [
255
                    'vacancies' => $vacancies,
2126 efrain 256
                ]
2057 eleazar 257
            ]);
1906 eleazar 258
        } else if ($request->isPost()) {
2578 eleazar 259
            $dataPost = $request->getPost()->toArray();
3458 eleazar 260
 
2578 eleazar 261
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
262
            $vacancy = $vacancyMapper->fetchOneByUuid($dataPost['vacancy_uuid']);
2606 eleazar 263
 
264
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
265
            $candidate = $candidateMapper->fetchOneByUuid($dataPost['candidate_uuid']);
3458 eleazar 266
 
2578 eleazar 267
            $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany->id, $vacancy->id);
1827 eleazar 268
 
2574 eleazar 269
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : RecruitmentSelectionInterview::STATUS_REJECTED;
3911 eleazar 270
            $dataPost['type'] = RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE;
2573 eleazar 271
 
2572 eleazar 272
            $form->setData($dataPost);
273
 
1827 eleazar 274
            if ($form->isValid()) {
275
                $dataPost = (array) $form->getData();
2603 eleazar 276
 
2596 eleazar 277
                $hydrator = new ObjectPropertyHydrator();
278
                $recruitmentSelectionInterview = new RecruitmentSelectionInterview();
279
                $hydrator->hydrate($dataPost, $recruitmentSelectionInterview);
1827 eleazar 280
 
2597 eleazar 281
                if (!$recruitmentSelectionInterview->status) {
282
                    $recruitmentSelectionInterview->status = RecruitmentSelectionInterview::STATUS_REJECTED;
283
                }
3458 eleazar 284
 
2598 eleazar 285
                $recruitmentSelectionInterview->company_id = $currentCompany->id;
3458 eleazar 286
                $recruitmentSelectionInterview->vacancy_id = $vacancy->id;
287
                $recruitmentSelectionInterview->candidate_id = $candidate->id;
2613 eleazar 288
                $recruitmentSelectionInterview->user_id = $currentUser->id;
3458 eleazar 289
 
2599 eleazar 290
                $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
3626 eleazar 291
 
292
                $interviews = $recruitmentSelectionInterviewMapper->fetchAllByCandidateIdAndVacancyId($candidate->id, $vacancy->id);
293
 
294
                if (count($interviews) > 0) {
295
                    $hasHumanResourcesInterview = false;
296
 
297
                    foreach($interviews as $interview) {
298
                        if ($interview->type === RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE) {
299
                            $hasHumanResourcesInterview = true;
300
                        }
4199 eleazar 301
                        if ($interview->type === RecruitmentSelectionInterview::STATUS_BOSS){
302
                            return new JsonModel([
303
                                'success' => false,
4202 eleazar 304
                                'data' => 'LABEL_BOSS_DONE'
4199 eleazar 305
                            ]);
306
                        }
3626 eleazar 307
                    }
308
 
309
                    $recruitmentSelectionInterview->type = $hasHumanResourcesInterview
310
                        ? RecruitmentSelectionInterview::STATUS_BOSS
311
                        : RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE;
312
                }
313
 
2600 eleazar 314
                $result = $recruitmentSelectionInterviewMapper->insert($recruitmentSelectionInterview);
2588 eleazar 315
 
1827 eleazar 316
                if ($result) {
2621 eleazar 317
                    $this->logger->info('Se agrego la entrevista ' . $recruitmentSelectionInterview->id, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
3458 eleazar 318
 
2622 eleazar 319
                    // Get record by id
320
                    $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
321
                    $record = $recruitmentSelectionInterviewMapper->fetchOne($recruitmentSelectionInterview->id);
322
 
3458 eleazar 323
 
2504 eleazar 324
                    if ($record) {
1827 eleazar 325
 
2504 eleazar 326
                        $data = [
327
                            'success' => true,
328
                            'id' => $record->id,
329
                            'data' => 'LABEL_RECORD_ADDED'
330
                        ];
331
                    } else {
1827 eleazar 332
 
2504 eleazar 333
                        $data = [
334
                            'success' => false,
335
                            'data' => 'ERROR_RECORD_NOT_FOUND'
336
                        ];
1827 eleazar 337
                    }
338
                } else {
339
                    $data = [
340
                        'success' => false,
2504 eleazar 341
                        'data' => $recruitmentSelectionInterviewMapper->getError()
1827 eleazar 342
                    ];
343
                }
344
 
345
                return new JsonModel($data);
346
            } else {
347
                $messages = [];
348
                $form_messages = (array) $form->getMessages();
349
                foreach ($form_messages as $fieldname => $field_messages) {
1906 eleazar 350
 
1827 eleazar 351
                    $messages[$fieldname] = array_values($field_messages);
352
                }
353
 
354
                return new JsonModel([
355
                    'success' => false,
356
                    'data' => $messages
357
                ]);
358
            }
359
        } else {
360
            $data = [
361
                'success' => false,
362
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
363
            ];
364
 
365
            return new JsonModel($data);
366
        }
367
 
368
        return new JsonModel($data);
369
    }
3458 eleazar 370
 
3580 eleazar 371
    public function vacancyAction() {
3571 eleazar 372
        $currentUserPlugin = $this->plugin('currentUserPlugin');
373
        $currentUser = $currentUserPlugin->getUser();
374
        $currentCompany = $currentUserPlugin->getCompany();
375
 
376
        $request = $this->getRequest();
377
 
378
        $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
379
 
380
        if ($request->isGet()) {
381
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
382
            $vacancy = $vacancyMapper->fetchOneByUuid($vacancy_uuid);
383
 
384
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
385
            $jobDescription = $jobDescriptionMapper->fetchOne($vacancy->job_description_id);
386
 
387
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
388
            $jobDescriptionCompetencies = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($jobDescription->id);
389
 
390
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
4030 eleazar 391
            $activeCandidates = $candidateMapper->fetchAllActives($vacancy->id);
3947 eleazar 392
 
3571 eleazar 393
            $competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
394
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
395
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
396
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
4342 eleazar 397
 
3571 eleazar 398
            $data = [
4030 eleazar 399
                'candidates' => $activeCandidates,
3571 eleazar 400
                'job_description' => [
401
                    'uuid' => $jobDescription->uuid,
402
                    'name' => $jobDescription->name,
403
                    'functions' => $jobDescription->functions,
404
                    'objectives' => $jobDescription->objectives,
405
                    'competencies' => []
406
                ],
4341 eleazar 407
                'interview' => [
408
                    'type' => RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE,
409
                    'status' => RecruitmentSelectionInterview::STATUS_ACCEPTED,
410
                    'points' => 0,
411
                    'comment' => '',
412
                ],
3598 eleazar 413
                'vacancy' => $vacancy,
3571 eleazar 414
            ];
415
 
416
            foreach ($jobDescriptionCompetencies as $jobDescriptionCompetency) {
417
                $competency = $competencyMapper->fetchOne($jobDescriptionCompetency->competency_id);
418
                $competencyType = $competencyTypeMapper->fetchOne($competency->competency_type_id);
419
                $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
420
 
421
                $behaviors = [];
422
 
423
                foreach ($behaviorCompetencies as $behaviorCompetency) {
424
                    $behavior = $behaviorMapper->fetchOne($behaviorCompetency->behavior_id);
425
 
426
                    $behaviors []= [
427
                        'uuid' => $behavior->uuid,
428
                        'description' => $behavior->description,
429
                        'points' => 0,
430
                        'comment' => '',
431
                        'competency_uuid' => $competency->uuid,
432
                    ];
433
                }
434
 
435
                array_push($data['job_description']['competencies'], [
436
                    'competency_uuid' => $competency->uuid,
437
                    'competency_name' => $competency->name,
438
                    'competency_type_uuid' => $competencyType->uuid,
439
                    'competency_type_name' => $competencyType->name,
440
                    'behaviors' => $behaviors,
441
                ]);
442
            }
443
 
444
            return new JsonModel([
445
                'success' => true,
446
                'data' => $data
447
            ]);
448
 
449
        } else {
450
            return new JsonModel([
451
                'success' => true,
452
                'data' => 'ERROR_METHOD_NOT_ALLOWED',
453
            ]);
454
        }
455
    }
456
 
4367 eleazar 457
    public function typeAction(){
4365 eleazar 458
        $currentUserPlugin = $this->plugin('currentUserPlugin');
459
        $currentUser = $currentUserPlugin->getUser();
460
        $currentCompany = $currentUserPlugin->getCompany();
461
 
462
        $request = $this->getRequest();
463
 
464
        $candidate_uuid = $this->params()->fromRoute('candidate_uuid');
465
 
4368 eleazar 466
        if(!$request->isGet()){
4365 eleazar 467
            return new JsonModel([
468
                'success' => false,
469
                'data' => 'ERROR_METHOD_NOT_ALLOWED',
470
            ]);
471
        }
472
 
473
        $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
474
        $candidate = $candidateMapper->fetchOneByUuid($candidate_uuid);
475
 
476
        $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
477
        $vacancy = $vacancyMapper->fetchOne($candidate->vacancy_id);
478
 
479
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
480
        $interviews = $recruitmentSelectionInterviewMapper->fetchAllByCandidateIdAndVacancyId($candidate->id, $vacancy->id);
481
 
482
        return new JsonModel([
4369 eleazar 483
            'success' => true,
4372 eleazar 484
            'data' => count($interviews) > 0 ? 'Entrevista por el Jefe' : 'Entrevista por Recursos Humanos',
4365 eleazar 485
        ]);
486
    }
487
 
2126 efrain 488
    public function editAction() {
2757 eleazar 489
        $request = $this->getRequest();
490
        $currentUserPlugin = $this->plugin('currentUserPlugin');
491
        $currentCompany = $currentUserPlugin->getCompany();
492
        $currentUser = $currentUserPlugin->getUser();
3458 eleazar 493
 
2757 eleazar 494
        $request = $this->getRequest();
2668 eleazar 495
        $interview_uuid = $this->params()->fromRoute('interview_uuid');
2757 eleazar 496
 
497
        if (!$interview_uuid) {
498
            $data = [
499
                'success' => false,
500
                'data' => 'ERROR_INVALID_PARAMETER'
501
            ];
502
 
503
            return new JsonModel($data);
504
        }
505
 
506
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
507
        $interview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($interview_uuid);
508
 
2838 eleazar 509
        $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
510
        $vacancy = $vacancyMapper->fetchOne($interview->vacancy_id);
511
 
2757 eleazar 512
        if(!$interview){
513
           $data = [
514
               'success' => false,
515
               'data' => 'ERROR_INVALID_PARAMETER'
516
           ];
517
 
518
           return new JsonModel($data);
519
        }
520
 
521
        if ($interview->company_id != $currentCompany->id) {
522
            return new JsonModel([
523
                'success' => false,
524
                'data' => 'ERROR_UNAUTHORIZED'
525
            ]);
526
        }
527
 
528
        if ($request->isPost()) {
2838 eleazar 529
            $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany->id, $vacancy->id);
2757 eleazar 530
            $dataPost = $request->getPost()->toArray();
531
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : RecruitmentSelectionInterview::STATUS_REJECTED;
3632 eleazar 532
            $dataPost['type'] = $interview->type;
2757 eleazar 533
 
534
            $form->setData($dataPost);
535
 
536
            if ($form->isValid()) {
537
                $dataPost = (array) $form->getData();
538
 
539
                $hydrator = new ObjectPropertyHydrator();
540
                $hydrator->hydrate($dataPost, $interview);
541
 
542
                if (!$interview->status) {
543
                    $interview->status = RecruitmentSelectionInterview::STATUS_REJECTED;
544
                }
545
 
2831 eleazar 546
                $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
2837 eleazar 547
                $candidate = $candidateMapper->fetchOneByUuid($dataPost['candidate_uuid']);
3458 eleazar 548
 
2831 eleazar 549
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2837 eleazar 550
                $vacancy = $vacancyMapper->fetchOneByUuid($dataPost['vacancy_uuid']);
2831 eleazar 551
 
2757 eleazar 552
                $interview->company_id = $currentCompany->id;
3458 eleazar 553
                $interview->vacancy_id = $vacancy->id;
554
                $interview->candidate_id = $candidate->id;
2757 eleazar 555
                $interview->user_id = $currentUser->id;
556
 
557
                $result = $recruitmentSelectionInterviewMapper->update($interview);
558
 
3458 eleazar 559
 
2757 eleazar 560
                if ($result) {
561
                    $this->logger->info('Se edito correctamente la entrevista' . $interview->id, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
562
                    $data = [
563
                        'success' => true,
564
                        'data' => 'LABEL_RECORD_UPDATED'
565
                    ];
566
                } else {
567
                    $data = [
568
                        'success' => false,
569
                        'data' => $recruitmentSelectionInterviewMapper->getError()
570
                    ];
571
                }
572
 
573
                return new JsonModel($data);
574
            } else {
575
                $messages = [];
576
                $form_messages = (array) $form->getMessages();
577
                foreach ($form_messages as $fieldname => $field_messages) {
578
                    $messages[$fieldname] = array_values($field_messages);
579
                }
580
 
581
                return new JsonModel([
582
                    'success' => false,
583
                    'data' => $messages
584
                ]);
585
            }
586
        } else if ($request->isGet()) {
587
            $hydrator = new ObjectPropertyHydrator();
588
 
2793 eleazar 589
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
590
            $candidate = $candidateMapper->fetchOne($interview->candidate_id);
3458 eleazar 591
 
2793 eleazar 592
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
593
            $vacancy = $vacancyMapper->fetchOne($candidate->vacancy_id);
3458 eleazar 594
 
2793 eleazar 595
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
596
            $jobDescription = $jobDescriptionMapper->fetchOne($vacancy->job_description_id);
3458 eleazar 597
 
2793 eleazar 598
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
599
            $jobDescriptionCompetencies = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($jobDescription->id);
3458 eleazar 600
 
2793 eleazar 601
            $competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
602
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
603
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
604
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
605
 
2757 eleazar 606
            $data = [
2793 eleazar 607
                'candidate' => [
608
                    'uuid' => $candidate->uuid,
609
                    'first_name' => $candidate->first_name,
610
                    'last_name' => $candidate->last_name,
611
                    'email' => $candidate->email
3458 eleazar 612
                ],
2793 eleazar 613
                'job_description' => [
614
                    'uuid' => $jobDescription->uuid,
615
                    'name' => $jobDescription->name,
3458 eleazar 616
                    'functions' => $jobDescription->functions,
2793 eleazar 617
                    'objectives' => $jobDescription->objectives,
618
                    'competencies' => []
3458 eleazar 619
                ],
2793 eleazar 620
                'interview' => [
2757 eleazar 621
                    'id' => $interview->uuid,
622
                    'status' => $interview->status,
623
                    'content' => $interview->content ? json_decode($interview->content) : [],
3458 eleazar 624
                    'type' => $interview->type,
625
                    'status' => $interview->status,
626
                    'points' => $interview->points,
2757 eleazar 627
                    'comment' => $interview->comment,
3634 eleazar 628
                ],
629
                'vacancy' => $vacancy,
2757 eleazar 630
            ];
631
 
2793 eleazar 632
            foreach ($jobDescriptionCompetencies as $jobDescriptionCompetency) {
633
                $competency = $competencyMapper->fetchOne($jobDescriptionCompetency->competency_id);
634
                $competencyType = $competencyTypeMapper->fetchOne($competency->competency_type_id);
635
                $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
636
 
637
                $behaviors = [];
638
 
639
                foreach ($behaviorCompetencies as $behaviorCompetency) {
640
                    $behavior = $behaviorMapper->fetchOne($behaviorCompetency->behavior_id);
3458 eleazar 641
 
2853 eleazar 642
                    $behaviors []= [
2793 eleazar 643
                        'uuid' => $behavior->uuid,
644
                        'description' => $behavior->description,
645
                        'points' => 0,
2853 eleazar 646
                        'comment' => '',
647
                        'competency_uuid' => $competency->uuid,
648
                    ];
2793 eleazar 649
                }
650
 
651
                array_push($data['job_description']['competencies'], [
652
                    'competency_uuid' => $competency->uuid,
653
                    'competency_name' => $competency->name,
654
                    'competency_type_uuid' => $competencyType->uuid,
655
                    'competency_type_name' => $competencyType->name,
656
                    'behaviors' => $behaviors,
657
                ]);
658
            }
2830 eleazar 659
 
2796 eleazar 660
            return new JsonModel([
661
                'success' => true,
662
                'data' => $data
663
            ]);
2757 eleazar 664
        } else {
665
            $data = [
666
                'success' => false,
667
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
668
            ];
669
 
670
            return new JsonModel($data);
671
        }
672
 
673
        return new JsonModel($data);
2126 efrain 674
    }
1827 eleazar 675
 
2747 eleazar 676
    public function deleteAction() {
2667 eleazar 677
        $request = $this->getRequest();
678
        $currentUserPlugin = $this->plugin('currentUserPlugin');
679
        $currentCompany = $currentUserPlugin->getCompany();
680
        $currentUser = $currentUserPlugin->getUser();
681
 
682
        $request = $this->getRequest();
2789 eleazar 683
        $uuid = $this->params()->fromRoute('interview_uuid');
2667 eleazar 684
 
685
        if (!$uuid) {
686
            $data = [
687
                'success' => false,
688
                'data' => 'ERROR_INVALID_PARAMETER'
689
            ];
690
 
691
            return new JsonModel($data);
692
        }
693
 
2754 eleazar 694
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
695
        $recruitmentSelectionInterview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($uuid);
696
        if (!$recruitmentSelectionInterview) {
2667 eleazar 697
            $data = [
698
                'success' => false,
699
                'data' => 'ERROR_RECORD_NOT_FOUND'
700
            ];
701
 
702
            return new JsonModel($data);
703
        }
704
 
2754 eleazar 705
        if ($recruitmentSelectionInterview->company_id != $currentCompany->id) {
2667 eleazar 706
            return new JsonModel([
707
                'success' => false,
708
                'data' => 'ERROR_UNAUTHORIZED'
709
            ]);
710
        }
711
 
712
        if ($request->isPost()) {
713
 
2754 eleazar 714
            $result = $recruitmentSelectionInterviewMapper->delete($recruitmentSelectionInterview->id);
2667 eleazar 715
            if ($result) {
2755 eleazar 716
                $this->logger->info('Se borro la entrevista ' . $recruitmentSelectionInterview->uuid, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
2667 eleazar 717
 
718
                $data = [
719
                    'success' => true,
720
                    'data' => 'LABEL_RECORD_DELETED'
721
                ];
722
            } else {
723
 
724
                $data = [
725
                    'success' => false,
2754 eleazar 726
                    'data' => $recruitmentSelectionInterviewMapper->getError()
2667 eleazar 727
                ];
728
 
729
                return new JsonModel($data);
730
            }
731
        } else {
732
            $data = [
733
                'success' => false,
734
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
735
            ];
736
 
737
            return new JsonModel($data);
738
        }
739
 
740
        return new JsonModel($data);
741
    }
2864 eleazar 742
 
2667 eleazar 743
    public function reportAction() {
744
        $currentUserPlugin = $this->plugin('currentUserPlugin');
745
        $currentUser = $currentUserPlugin->getUser();
746
        $currentCompany = $currentUserPlugin->getCompany();
747
 
2880 eleazar 748
        $uuid = $this->params()->fromRoute('interview_uuid');
2667 eleazar 749
 
2747 eleazar 750
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
751
        $recruitmentSelectionInterview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($uuid);
2667 eleazar 752
 
2747 eleazar 753
        $recruitmentSelectionVacancyMapper = RecruitmentSelectionvacancyMapper::getInstance($this->adapter);
754
        $recruitmentSelectionVacancy = $recruitmentSelectionVacancyMapper->fetchOne($recruitmentSelectionInterview->vacancy_id);
755
 
756
 
757
        if (!$recruitmentSelectionInterview) {
2667 eleazar 758
            return new JsonModel([
759
                'success' => false,
760
                'data' => 'ERROR_FORM_EVALUATION_NOT_FOUND'
761
            ]);
762
        }
763
 
764
        $request = $this->getRequest();
765
        if ($request->isGet()) {
766
            //Competencies
767
 
768
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
769
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
770
            $competenceTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
771
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
772
            $jobDescriptionBehaviorCompetencyMapper = JobDescriptionBehaviorCompetencyMapper::getInstance($this->adapter);
773
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
774
 
775
            $competencies = [];
776
 
2747 eleazar 777
            $jobDescriptionCompetency = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($recruitmentSelectionVacancy->job_description_id);
2667 eleazar 778
 
3458 eleazar 779
            $content = json_decode($recruitmentSelectionInterview->content, true);
2898 eleazar 780
 
2667 eleazar 781
            foreach ($jobDescriptionCompetency as $record) {
782
 
783
                $competency = $competencyMapper->fetchOne($record->competency_id);
784
                $competenceType = $competenceTypeMapper->fetchOne($competency->competency_type_id);
785
 
786
                if ($competency && $competenceType) {
787
 
788
                    $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
789
                    $behaviors = [];
790
 
791
                    foreach ($behaviorCompetencies as $rows) {
792
 
793
                        $behavior = $behaviorMapper->fetchOne($rows->behavior_id);
2747 eleazar 794
                        $jobDescriptionBehaviorCompetency = $jobDescriptionBehaviorCompetencyMapper->fetchOneByBehavior($recruitmentSelectionVacancy->job_description_id, $record->competency_id, $rows->behavior_id);
2667 eleazar 795
 
796
                        if ($behavior && $jobDescriptionBehaviorCompetency) {
2898 eleazar 797
                            $rowData = [
2667 eleazar 798
                                'description' => $behavior->description,
799
                                'level' => $jobDescriptionBehaviorCompetency->level,
2898 eleazar 800
                                'comment' => '',
4077 eleazar 801
                                'evaluation' => '',
4040 eleazar 802
 
2898 eleazar 803
                            ];
804
 
805
                            foreach($content as $eval) {
806
                                if ($eval['competencyUuid'] == $competency->uuid &&
807
                                    $eval['behaviorUuid'] == $behavior->uuid) {
3458 eleazar 808
 
2898 eleazar 809
                                    $rowData['comment'] = $eval['comment'];
4077 eleazar 810
                                    $rowData['evaluation'] = $eval['evaluation'];
4040 eleazar 811
 
3458 eleazar 812
 
2898 eleazar 813
                                    break;
814
                                }
815
                            }
816
 
817
                            $behaviors []= $rowData;
2667 eleazar 818
                        }
819
                    }
820
 
821
                    array_push($competencies, [
822
                        'name' => $competency->name,
823
                        'description' => $competency->description,
824
                        'type' => $competenceType->name,
825
                        'behaviors' => $behaviors
826
                    ]);
827
                }
828
            }
829
 
2747 eleazar 830
            return $this->renderPDF($currentCompany, $recruitmentSelectionInterview, $competencies);
2667 eleazar 831
        }
832
 
833
        return new JsonModel([
834
            'success' => false,
835
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
836
        ]);
2747 eleazar 837
    }
2667 eleazar 838
 
839
    /**
840
     * Render PDF
841
     * @param Company $currentCompany
2747 eleazar 842
     * @param recruitmentSelectionInterview $interviewEvaluation
2667 eleazar 843
     * @param array $competencies
844
     * @return mixed
845
     */
2864 eleazar 846
    public function renderPDF($currentCompany, $interviewEvaluation, $competencies) {
2667 eleazar 847
 
3458 eleazar 848
        $currentUserPlugin = $this->plugin('currentUserPlugin');
849
        $currentUser = $currentUserPlugin->getUser();
850
 
2667 eleazar 851
        //Generate New PDF
852
        $pdf = new InterviewPDF();
853
 
854
        $pdf->header = '';
855
        $pdf->footer = '';
856
 
857
        if ($currentCompany) {
858
            //get company Data
859
            $companyMapper = CompanyMapper::getInstance($this->adapter);
860
            $company = $companyMapper->fetchOne($currentCompany->id);
861
 
2891 eleazar 862
            $target_path = $this->config['leaderslinked.fullpath.company'] . DIRECTORY_SEPARATOR . $company->uuid;
2667 eleazar 863
 
864
            $pdf->header = $company->header ? $target_path . DIRECTORY_SEPARATOR . $company->header : '';
865
            $pdf->footer = $company->footer ? $target_path . DIRECTORY_SEPARATOR . $company->footer : '';
866
        }
867
 
868
        $pdf->SetMargins(10, 0, 10);
869
 
870
        $pdf->AliasNbPages();
871
        $pdf->AddPage();
872
 
2894 eleazar 873
        $recruitmentSelectionCandidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
874
        $recruitmentSelectionVacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2747 eleazar 875
        $vacancy = $recruitmentSelectionVacancyMapper->fetchOne($interviewEvaluation->vacancy_id);
2894 eleazar 876
        $candidate = $recruitmentSelectionCandidateMapper->fetchOne($interviewEvaluation->candidate_id);
2667 eleazar 877
 
4037 eleazar 878
        switch ($interviewEvaluation->type) {
4036 eleazar 879
            case "r":
4046 eleazar 880
                $type = "Recursos Humanos";
4036 eleazar 881
                break;
882
            case "b":
4038 eleazar 883
                $type = "Jefe";
4036 eleazar 884
                break;
885
            default :
886
                $type = "ERROR";
887
                break;
888
        }
889
 
4247 eleazar 890
        switch ($interviewEvaluation->points) {
891
            case "0":
892
                $points = "Sugerir otro cargo";
893
                break;
894
            case "1":
895
                $points = "25%";
896
                break;
897
            case "2":
898
                $points = "50%";
899
                break;
900
            case "3":
901
                $points = "75%";
902
                break;
903
            case "4":
904
                $points = "100%";
905
                break;
906
            default :
907
                $points = "ERROR";
908
                break;
909
        }
910
 
2667 eleazar 911
        $rows = [
912
            array(
913
                'title' => 'Nombre Evaluado: ',
3458 eleazar 914
                'content' => $candidate ? ' ' . $candidate->first_name . ' ' . $candidate->last_name : 'No Aplica'
2667 eleazar 915
            ),
916
            array(
917
                'title' => 'Cargo: ',
2747 eleazar 918
                'content' => $vacancy ? ' ' . $vacancy->name : ' No aplica'
2667 eleazar 919
            ),
920
            array(
3458 eleazar 921
                'title' => 'Entrevistado por: ',
922
                'content' => $currentUser ? ' ' . $currentUser->first_name . ' ' . $currentUser->last_name : ' No Aplica '
2667 eleazar 923
            ),
924
            array(
3458 eleazar 925
                'title' => 'Estatus del candidato: ',
4036 eleazar 926
                'content' => $type
2667 eleazar 927
            ),
928
            array(
3458 eleazar 929
                'title' => 'Comentarios del entrevistador: ',
930
                'content' => $interviewEvaluation ? ' ' . $interviewEvaluation->comment : 'No Aplica'
2667 eleazar 931
            ),
932
            array(
3458 eleazar 933
                'title' => 'Porcentage de adaptibilidad ',
4247 eleazar 934
                'content' => $points
2667 eleazar 935
            )
936
        ];
937
 
2922 eleazar 938
        $pdf->borderTable('DATOS DE LA ENTREVISTA', $rows);
4050 eleazar 939
 
940
        $sections = json_decode($interviewEvaluation->content, true);
4052 eleazar 941
        /*
4050 eleazar 942
                for ($s = 0; $s < count($sections); $s++) {
943
 
944
                    $pdf->singleTable($sections[$s]['title'], [
945
                        array(
946
                            'content' => $sections[$s]['type'] != 'multiple' ? $sections[$s]['text'] : ''
947
                    )]);
948
 
949
                    if ($sections[$s]['type'] == 'multiple') {
950
 
951
                        $pdf->titleOptionTable($sections[$s]['text']);
952
 
953
                        for ($o = 0; $o < count($sections[$s]['options']); $o++) {
954
 
955
                            $pdf->optionTable($sections[$s]['options'][$o]['title']);
956
                        }
957
                        $pdf->Ln();
958
                    }
959
                    if ($s % 2 == 0 && $s > 1) {
960
                        $pdf->AddPage();
961
                    }
4052 eleazar 962
                }*/
4050 eleazar 963
 
3458 eleazar 964
        // Competencies
2667 eleazar 965
        if (count($competencies) != 0) {
966
 
4053 eleazar 967
            // add new page
2667 eleazar 968
 
969
            $pdf->AddPage();
970
 
971
            $competencies_header[] = array('content' => 'Indique el nivel de desempeño del evaluado en relación a sus conductas y actitudes frente a cada valor, según la clasificación siguiente:');
972
 
973
            $pdf->singleTable('Anexo de valores:', $competencies_header);
974
 
975
 
976
            // Add scale section
977
            $pdf->sectionScale();
978
 
979
            $i = 0;
4053 eleazar 980
 
981
            foreach ($competencies as $record) {
982
 
983
                $i = $i + 1;
984
 
985
                $pdf->competencyTable($i, $record);
986
 
987
                if ($i % 3 == 0 && $i < count($competencies)) {
988
                    $pdf->AddPage();
989
                }
990
            }
4029 eleazar 991
 
2893 eleazar 992
        }
4027 eleazar 993
 
2667 eleazar 994
        return $pdf->Output();
4027 eleazar 995
 
2864 eleazar 996
    }
1709 eleazar 997
}