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
 
169
                foreach ($records as $record) {
170
                    $params = [
7966 eleazar 171
                        'vacancy_uuid' => $vacancy_uuid,
3537 eleazar 172
                        'interview_uuid' => $record['uuid'],
3484 eleazar 173
                    ];
3536 eleazar 174
 
175
                    $link_delete = $this->url()->fromRoute('recruitment-and-selection/interview/form/delete', $params);
176
 
177
                    $link_edit = $this->url()->fromRoute('recruitment-and-selection/interview/form/edit', $params);
3710 eleazar 178
 
179
                    $link_report = $this->url()->fromRoute('recruitment-and-selection/interview/report', $params);
3536 eleazar 180
 
3484 eleazar 181
 
182
                    $item = [
183
                        'uuid' => $record['uuid'],
184
                        'first_name' => $record['first_name'],
185
                        'last_name' => $record['last_name'],
186
                        'email' => $record['email'],
3882 eleazar 187
                        'vacancy' =>$record['name'],
3953 eleazar 188
                        'last_date' =>$record['last_date'],
3543 eleazar 189
                        'status' => $record['status'],
3561 eleazar 190
                        'type' => $record['type'],
3484 eleazar 191
                        // 'file' => $this->url()->fromRoute('storage', ['type' => 'recruitment_selection', 'code' => $record['uuid'], 'filename' => $record['file']]),
3536 eleazar 192
                        'actions' => [
193
                            'link_edit' => $allowEdit ? $link_edit : '',
194
                            'link_delete' => $allowDelete ? $link_delete : '',
3710 eleazar 195
                            'link_report' => $allowReport ? $link_report : '',
3536 eleazar 196
                        ]
3484 eleazar 197
                    ];
198
 
199
                    array_push($items, $item);
200
                }
201
 
2029 eleazar 202
                return new JsonModel([
203
                    'success' => true,
2033 eleazar 204
                    'data' => [
3528 eleazar 205
                        'items' => $items,
206
                        'total' => $paginator->getTotalItemCount()
2033 eleazar 207
                    ],
2029 eleazar 208
                ]);
1709 eleazar 209
            } else {
2199 eleazar 210
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2203 eleazar 211
                $vacancies = $vacancyMapper->fetchAllByCompanyId($currentCompany->id);
2211 eleazar 212
 
213
                $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany ? $currentCompany->id : null);
3458 eleazar 214
 
1709 eleazar 215
                $this->layout()->setTemplate('layout/layout-backend');
216
                $viewModel = new ViewModel();
1718 eleazar 217
                $viewModel->setTemplate('leaders-linked/recruitment-and-selection-interview/index.phtml');
1709 eleazar 218
                $viewModel->setVariables([
2211 eleazar 219
                    'form'      => $form,
2207 eleazar 220
                    'vacancies' => $vacancies
1709 eleazar 221
                ]);
3458 eleazar 222
 
1709 eleazar 223
                return $viewModel ;
224
            }
3458 eleazar 225
 
1709 eleazar 226
        } else {
227
            return new JsonModel([
228
                'success' => false,
229
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
230
            ]);
231
        }
232
    }
233
 
3571 eleazar 234
    public function addAction(){
1827 eleazar 235
        $currentUserPlugin = $this->plugin('currentUserPlugin');
236
        $currentUser = $currentUserPlugin->getUser();
237
        $currentCompany = $currentUserPlugin->getCompany();
1709 eleazar 238
 
7964 eleazar 239
        $request = $this->getRequest();
7962 eleazar 240
        $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
241
 
7961 eleazar 242
        if ($request->isPost()) {
2578 eleazar 243
            $dataPost = $request->getPost()->toArray();
7965 eleazar 244
            $dataPost['vacancy_uuid'] = $vacancy_uuid;
3458 eleazar 245
 
2578 eleazar 246
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
7962 eleazar 247
            $vacancy = $vacancyMapper->fetchOneByUuid($vacancy_uuid);
2606 eleazar 248
 
249
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
250
            $candidate = $candidateMapper->fetchOneByUuid($dataPost['candidate_uuid']);
3458 eleazar 251
 
2578 eleazar 252
            $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany->id, $vacancy->id);
1827 eleazar 253
 
2574 eleazar 254
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : RecruitmentSelectionInterview::STATUS_REJECTED;
3911 eleazar 255
            $dataPost['type'] = RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE;
2573 eleazar 256
 
2572 eleazar 257
            $form->setData($dataPost);
258
 
1827 eleazar 259
            if ($form->isValid()) {
260
                $dataPost = (array) $form->getData();
2603 eleazar 261
 
2596 eleazar 262
                $hydrator = new ObjectPropertyHydrator();
263
                $recruitmentSelectionInterview = new RecruitmentSelectionInterview();
264
                $hydrator->hydrate($dataPost, $recruitmentSelectionInterview);
1827 eleazar 265
 
2597 eleazar 266
                if (!$recruitmentSelectionInterview->status) {
267
                    $recruitmentSelectionInterview->status = RecruitmentSelectionInterview::STATUS_REJECTED;
268
                }
3458 eleazar 269
 
2598 eleazar 270
                $recruitmentSelectionInterview->company_id = $currentCompany->id;
3458 eleazar 271
                $recruitmentSelectionInterview->vacancy_id = $vacancy->id;
272
                $recruitmentSelectionInterview->candidate_id = $candidate->id;
2613 eleazar 273
                $recruitmentSelectionInterview->user_id = $currentUser->id;
3458 eleazar 274
 
2599 eleazar 275
                $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
3626 eleazar 276
 
277
                $interviews = $recruitmentSelectionInterviewMapper->fetchAllByCandidateIdAndVacancyId($candidate->id, $vacancy->id);
278
 
279
                if (count($interviews) > 0) {
280
                    $hasHumanResourcesInterview = false;
281
 
282
                    foreach($interviews as $interview) {
283
                        if ($interview->type === RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE) {
284
                            $hasHumanResourcesInterview = true;
285
                        }
4199 eleazar 286
                        if ($interview->type === RecruitmentSelectionInterview::STATUS_BOSS){
287
                            return new JsonModel([
288
                                'success' => false,
4202 eleazar 289
                                'data' => 'LABEL_BOSS_DONE'
4199 eleazar 290
                            ]);
291
                        }
3626 eleazar 292
                    }
293
 
294
                    $recruitmentSelectionInterview->type = $hasHumanResourcesInterview
295
                        ? RecruitmentSelectionInterview::STATUS_BOSS
296
                        : RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE;
297
                }
298
 
2600 eleazar 299
                $result = $recruitmentSelectionInterviewMapper->insert($recruitmentSelectionInterview);
7952 eleazar 300
 
2588 eleazar 301
 
1827 eleazar 302
                if ($result) {
2621 eleazar 303
                    $this->logger->info('Se agrego la entrevista ' . $recruitmentSelectionInterview->id, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
3458 eleazar 304
 
2622 eleazar 305
                    // Get record by id
306
                    $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
307
                    $record = $recruitmentSelectionInterviewMapper->fetchOne($recruitmentSelectionInterview->id);
308
 
3458 eleazar 309
 
2504 eleazar 310
                    if ($record) {
1827 eleazar 311
 
2504 eleazar 312
                        $data = [
313
                            'success' => true,
314
                            'id' => $record->id,
315
                            'data' => 'LABEL_RECORD_ADDED'
316
                        ];
317
                    } else {
1827 eleazar 318
 
2504 eleazar 319
                        $data = [
320
                            'success' => false,
321
                            'data' => 'ERROR_RECORD_NOT_FOUND'
322
                        ];
1827 eleazar 323
                    }
324
                } else {
325
                    $data = [
326
                        'success' => false,
2504 eleazar 327
                        'data' => $recruitmentSelectionInterviewMapper->getError()
1827 eleazar 328
                    ];
329
                }
330
 
331
                return new JsonModel($data);
332
            } else {
333
                $messages = [];
334
                $form_messages = (array) $form->getMessages();
335
                foreach ($form_messages as $fieldname => $field_messages) {
1906 eleazar 336
 
1827 eleazar 337
                    $messages[$fieldname] = array_values($field_messages);
338
                }
339
 
340
                return new JsonModel([
341
                    'success' => false,
342
                    'data' => $messages
343
                ]);
344
            }
345
        } else {
346
            $data = [
347
                'success' => false,
348
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
349
            ];
350
 
351
            return new JsonModel($data);
352
        }
353
 
354
        return new JsonModel($data);
355
    }
3458 eleazar 356
 
3580 eleazar 357
    public function vacancyAction() {
3571 eleazar 358
        $currentUserPlugin = $this->plugin('currentUserPlugin');
359
        $currentUser = $currentUserPlugin->getUser();
360
        $currentCompany = $currentUserPlugin->getCompany();
361
 
362
        $request = $this->getRequest();
363
 
364
        $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
365
 
366
        if ($request->isGet()) {
367
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
368
            $vacancy = $vacancyMapper->fetchOneByUuid($vacancy_uuid);
369
 
370
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
371
            $jobDescription = $jobDescriptionMapper->fetchOne($vacancy->job_description_id);
372
 
373
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
374
            $jobDescriptionCompetencies = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($jobDescription->id);
375
 
376
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
4030 eleazar 377
            $activeCandidates = $candidateMapper->fetchAllActives($vacancy->id);
3947 eleazar 378
 
3571 eleazar 379
            $competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
380
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
381
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
382
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
4342 eleazar 383
 
3571 eleazar 384
            $data = [
4030 eleazar 385
                'candidates' => $activeCandidates,
3571 eleazar 386
                'job_description' => [
387
                    'uuid' => $jobDescription->uuid,
388
                    'name' => $jobDescription->name,
389
                    'functions' => $jobDescription->functions,
390
                    'objectives' => $jobDescription->objectives,
391
                    'competencies' => []
392
                ],
4341 eleazar 393
                'interview' => [
394
                    'type' => RecruitmentSelectionInterview::STATUS_HUMAN_RESOURCE,
395
                    'status' => RecruitmentSelectionInterview::STATUS_ACCEPTED,
396
                    'points' => 0,
397
                    'comment' => '',
398
                ],
3598 eleazar 399
                'vacancy' => $vacancy,
3571 eleazar 400
            ];
401
 
402
            foreach ($jobDescriptionCompetencies as $jobDescriptionCompetency) {
403
                $competency = $competencyMapper->fetchOne($jobDescriptionCompetency->competency_id);
404
                $competencyType = $competencyTypeMapper->fetchOne($competency->competency_type_id);
405
                $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
406
 
407
                $behaviors = [];
408
 
409
                foreach ($behaviorCompetencies as $behaviorCompetency) {
410
                    $behavior = $behaviorMapper->fetchOne($behaviorCompetency->behavior_id);
411
 
412
                    $behaviors []= [
413
                        'uuid' => $behavior->uuid,
414
                        'description' => $behavior->description,
415
                        'points' => 0,
416
                        'comment' => '',
417
                        'competency_uuid' => $competency->uuid,
418
                    ];
419
                }
420
 
421
                array_push($data['job_description']['competencies'], [
422
                    'competency_uuid' => $competency->uuid,
423
                    'competency_name' => $competency->name,
424
                    'competency_type_uuid' => $competencyType->uuid,
425
                    'competency_type_name' => $competencyType->name,
426
                    'behaviors' => $behaviors,
427
                ]);
428
            }
429
 
430
            return new JsonModel([
431
                'success' => true,
432
                'data' => $data
433
            ]);
434
 
435
        } else {
436
            return new JsonModel([
437
                'success' => true,
438
                'data' => 'ERROR_METHOD_NOT_ALLOWED',
439
            ]);
440
        }
441
    }
442
 
4367 eleazar 443
    public function typeAction(){
4365 eleazar 444
        $currentUserPlugin = $this->plugin('currentUserPlugin');
445
        $currentUser = $currentUserPlugin->getUser();
446
        $currentCompany = $currentUserPlugin->getCompany();
447
 
448
        $request = $this->getRequest();
449
 
450
        $candidate_uuid = $this->params()->fromRoute('candidate_uuid');
451
 
4368 eleazar 452
        if(!$request->isGet()){
4365 eleazar 453
            return new JsonModel([
454
                'success' => false,
455
                'data' => 'ERROR_METHOD_NOT_ALLOWED',
456
            ]);
457
        }
458
 
459
        $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
460
        $candidate = $candidateMapper->fetchOneByUuid($candidate_uuid);
461
 
462
        $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
463
        $vacancy = $vacancyMapper->fetchOne($candidate->vacancy_id);
464
 
465
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
466
        $interviews = $recruitmentSelectionInterviewMapper->fetchAllByCandidateIdAndVacancyId($candidate->id, $vacancy->id);
467
 
468
        return new JsonModel([
4369 eleazar 469
            'success' => true,
4372 eleazar 470
            'data' => count($interviews) > 0 ? 'Entrevista por el Jefe' : 'Entrevista por Recursos Humanos',
4365 eleazar 471
        ]);
472
    }
473
 
2126 efrain 474
    public function editAction() {
2757 eleazar 475
        $request = $this->getRequest();
476
        $currentUserPlugin = $this->plugin('currentUserPlugin');
477
        $currentCompany = $currentUserPlugin->getCompany();
478
        $currentUser = $currentUserPlugin->getUser();
3458 eleazar 479
 
2757 eleazar 480
        $request = $this->getRequest();
2668 eleazar 481
        $interview_uuid = $this->params()->fromRoute('interview_uuid');
2757 eleazar 482
 
483
        if (!$interview_uuid) {
484
            $data = [
485
                'success' => false,
486
                'data' => 'ERROR_INVALID_PARAMETER'
487
            ];
488
 
489
            return new JsonModel($data);
490
        }
491
 
492
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
493
        $interview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($interview_uuid);
494
 
2838 eleazar 495
        $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
496
        $vacancy = $vacancyMapper->fetchOne($interview->vacancy_id);
497
 
2757 eleazar 498
        if(!$interview){
499
           $data = [
500
               'success' => false,
501
               'data' => 'ERROR_INVALID_PARAMETER'
502
           ];
503
 
504
           return new JsonModel($data);
505
        }
506
 
507
        if ($interview->company_id != $currentCompany->id) {
508
            return new JsonModel([
509
                'success' => false,
510
                'data' => 'ERROR_UNAUTHORIZED'
511
            ]);
512
        }
513
 
514
        if ($request->isPost()) {
2838 eleazar 515
            $form = new RecruitmentSelectionInterviewFormForm($this->adapter, $currentCompany->id, $vacancy->id);
2757 eleazar 516
            $dataPost = $request->getPost()->toArray();
517
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : RecruitmentSelectionInterview::STATUS_REJECTED;
3632 eleazar 518
            $dataPost['type'] = $interview->type;
2757 eleazar 519
 
520
            $form->setData($dataPost);
521
 
522
            if ($form->isValid()) {
523
                $dataPost = (array) $form->getData();
524
 
525
                $hydrator = new ObjectPropertyHydrator();
526
                $hydrator->hydrate($dataPost, $interview);
527
 
528
                if (!$interview->status) {
529
                    $interview->status = RecruitmentSelectionInterview::STATUS_REJECTED;
530
                }
531
 
2831 eleazar 532
                $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
2837 eleazar 533
                $candidate = $candidateMapper->fetchOneByUuid($dataPost['candidate_uuid']);
3458 eleazar 534
 
2831 eleazar 535
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2837 eleazar 536
                $vacancy = $vacancyMapper->fetchOneByUuid($dataPost['vacancy_uuid']);
2831 eleazar 537
 
2757 eleazar 538
                $interview->company_id = $currentCompany->id;
3458 eleazar 539
                $interview->vacancy_id = $vacancy->id;
540
                $interview->candidate_id = $candidate->id;
2757 eleazar 541
                $interview->user_id = $currentUser->id;
542
 
543
                $result = $recruitmentSelectionInterviewMapper->update($interview);
544
 
3458 eleazar 545
 
2757 eleazar 546
                if ($result) {
547
                    $this->logger->info('Se edito correctamente la entrevista' . $interview->id, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
548
                    $data = [
549
                        'success' => true,
550
                        'data' => 'LABEL_RECORD_UPDATED'
551
                    ];
552
                } else {
553
                    $data = [
554
                        'success' => false,
555
                        'data' => $recruitmentSelectionInterviewMapper->getError()
556
                    ];
557
                }
558
 
559
                return new JsonModel($data);
560
            } else {
561
                $messages = [];
562
                $form_messages = (array) $form->getMessages();
563
                foreach ($form_messages as $fieldname => $field_messages) {
564
                    $messages[$fieldname] = array_values($field_messages);
565
                }
566
 
567
                return new JsonModel([
568
                    'success' => false,
569
                    'data' => $messages
570
                ]);
571
            }
572
        } else if ($request->isGet()) {
573
            $hydrator = new ObjectPropertyHydrator();
574
 
2793 eleazar 575
            $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
576
            $candidate = $candidateMapper->fetchOne($interview->candidate_id);
3458 eleazar 577
 
2793 eleazar 578
            $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
579
            $vacancy = $vacancyMapper->fetchOne($candidate->vacancy_id);
3458 eleazar 580
 
2793 eleazar 581
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
582
            $jobDescription = $jobDescriptionMapper->fetchOne($vacancy->job_description_id);
3458 eleazar 583
 
2793 eleazar 584
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
585
            $jobDescriptionCompetencies = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($jobDescription->id);
3458 eleazar 586
 
2793 eleazar 587
            $competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
588
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
589
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
590
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
591
 
2757 eleazar 592
            $data = [
2793 eleazar 593
                'candidate' => [
594
                    'uuid' => $candidate->uuid,
595
                    'first_name' => $candidate->first_name,
596
                    'last_name' => $candidate->last_name,
597
                    'email' => $candidate->email
3458 eleazar 598
                ],
2793 eleazar 599
                'job_description' => [
600
                    'uuid' => $jobDescription->uuid,
601
                    'name' => $jobDescription->name,
3458 eleazar 602
                    'functions' => $jobDescription->functions,
2793 eleazar 603
                    'objectives' => $jobDescription->objectives,
604
                    'competencies' => []
3458 eleazar 605
                ],
2793 eleazar 606
                'interview' => [
2757 eleazar 607
                    'id' => $interview->uuid,
608
                    'status' => $interview->status,
609
                    'content' => $interview->content ? json_decode($interview->content) : [],
3458 eleazar 610
                    'type' => $interview->type,
611
                    'status' => $interview->status,
612
                    'points' => $interview->points,
2757 eleazar 613
                    'comment' => $interview->comment,
3634 eleazar 614
                ],
615
                'vacancy' => $vacancy,
2757 eleazar 616
            ];
617
 
2793 eleazar 618
            foreach ($jobDescriptionCompetencies as $jobDescriptionCompetency) {
619
                $competency = $competencyMapper->fetchOne($jobDescriptionCompetency->competency_id);
620
                $competencyType = $competencyTypeMapper->fetchOne($competency->competency_type_id);
621
                $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
622
 
623
                $behaviors = [];
624
 
625
                foreach ($behaviorCompetencies as $behaviorCompetency) {
626
                    $behavior = $behaviorMapper->fetchOne($behaviorCompetency->behavior_id);
3458 eleazar 627
 
2853 eleazar 628
                    $behaviors []= [
2793 eleazar 629
                        'uuid' => $behavior->uuid,
630
                        'description' => $behavior->description,
631
                        'points' => 0,
2853 eleazar 632
                        'comment' => '',
633
                        'competency_uuid' => $competency->uuid,
634
                    ];
2793 eleazar 635
                }
636
 
637
                array_push($data['job_description']['competencies'], [
638
                    'competency_uuid' => $competency->uuid,
639
                    'competency_name' => $competency->name,
640
                    'competency_type_uuid' => $competencyType->uuid,
641
                    'competency_type_name' => $competencyType->name,
642
                    'behaviors' => $behaviors,
643
                ]);
644
            }
2830 eleazar 645
 
2796 eleazar 646
            return new JsonModel([
647
                'success' => true,
648
                'data' => $data
649
            ]);
2757 eleazar 650
        } else {
651
            $data = [
652
                'success' => false,
653
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
654
            ];
655
 
656
            return new JsonModel($data);
657
        }
658
 
659
        return new JsonModel($data);
2126 efrain 660
    }
1827 eleazar 661
 
2747 eleazar 662
    public function deleteAction() {
2667 eleazar 663
        $request = $this->getRequest();
664
        $currentUserPlugin = $this->plugin('currentUserPlugin');
665
        $currentCompany = $currentUserPlugin->getCompany();
666
        $currentUser = $currentUserPlugin->getUser();
667
 
668
        $request = $this->getRequest();
2789 eleazar 669
        $uuid = $this->params()->fromRoute('interview_uuid');
2667 eleazar 670
 
671
        if (!$uuid) {
672
            $data = [
673
                'success' => false,
674
                'data' => 'ERROR_INVALID_PARAMETER'
675
            ];
676
 
677
            return new JsonModel($data);
678
        }
679
 
2754 eleazar 680
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
681
        $recruitmentSelectionInterview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($uuid);
682
        if (!$recruitmentSelectionInterview) {
2667 eleazar 683
            $data = [
684
                'success' => false,
685
                'data' => 'ERROR_RECORD_NOT_FOUND'
686
            ];
687
 
688
            return new JsonModel($data);
689
        }
690
 
2754 eleazar 691
        if ($recruitmentSelectionInterview->company_id != $currentCompany->id) {
2667 eleazar 692
            return new JsonModel([
693
                'success' => false,
694
                'data' => 'ERROR_UNAUTHORIZED'
695
            ]);
696
        }
697
 
698
        if ($request->isPost()) {
699
 
2754 eleazar 700
            $result = $recruitmentSelectionInterviewMapper->delete($recruitmentSelectionInterview->id);
2667 eleazar 701
            if ($result) {
2755 eleazar 702
                $this->logger->info('Se borro la entrevista ' . $recruitmentSelectionInterview->uuid, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
2667 eleazar 703
 
704
                $data = [
705
                    'success' => true,
706
                    'data' => 'LABEL_RECORD_DELETED'
707
                ];
708
            } else {
709
 
710
                $data = [
711
                    'success' => false,
2754 eleazar 712
                    'data' => $recruitmentSelectionInterviewMapper->getError()
2667 eleazar 713
                ];
714
 
715
                return new JsonModel($data);
716
            }
717
        } else {
718
            $data = [
719
                'success' => false,
720
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
721
            ];
722
 
723
            return new JsonModel($data);
724
        }
725
 
726
        return new JsonModel($data);
727
    }
2864 eleazar 728
 
2667 eleazar 729
    public function reportAction() {
730
        $currentUserPlugin = $this->plugin('currentUserPlugin');
731
        $currentUser = $currentUserPlugin->getUser();
732
        $currentCompany = $currentUserPlugin->getCompany();
733
 
2880 eleazar 734
        $uuid = $this->params()->fromRoute('interview_uuid');
2667 eleazar 735
 
2747 eleazar 736
        $recruitmentSelectionInterviewMapper = RecruitmentSelectionInterviewMapper::getInstance($this->adapter);
737
        $recruitmentSelectionInterview = $recruitmentSelectionInterviewMapper->fetchOneByUuid($uuid);
2667 eleazar 738
 
2747 eleazar 739
        $recruitmentSelectionVacancyMapper = RecruitmentSelectionvacancyMapper::getInstance($this->adapter);
740
        $recruitmentSelectionVacancy = $recruitmentSelectionVacancyMapper->fetchOne($recruitmentSelectionInterview->vacancy_id);
741
 
742
 
743
        if (!$recruitmentSelectionInterview) {
2667 eleazar 744
            return new JsonModel([
745
                'success' => false,
746
                'data' => 'ERROR_FORM_EVALUATION_NOT_FOUND'
747
            ]);
748
        }
749
 
750
        $request = $this->getRequest();
751
        if ($request->isGet()) {
752
            //Competencies
753
 
754
            $jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);
755
            $competencyMapper = CompetencyMapper::getInstance($this->adapter);
756
            $competenceTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
757
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
758
            $jobDescriptionBehaviorCompetencyMapper = JobDescriptionBehaviorCompetencyMapper::getInstance($this->adapter);
759
            $behaviorMapper = BehaviorMapper::getInstance($this->adapter);
760
 
761
            $competencies = [];
762
 
2747 eleazar 763
            $jobDescriptionCompetency = $jobDescriptionCompetencyMapper->fetchByJobDescriptionId($recruitmentSelectionVacancy->job_description_id);
2667 eleazar 764
 
3458 eleazar 765
            $content = json_decode($recruitmentSelectionInterview->content, true);
2898 eleazar 766
 
2667 eleazar 767
            foreach ($jobDescriptionCompetency as $record) {
768
 
769
                $competency = $competencyMapper->fetchOne($record->competency_id);
770
                $competenceType = $competenceTypeMapper->fetchOne($competency->competency_type_id);
771
 
772
                if ($competency && $competenceType) {
773
 
774
                    $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competency->id);
775
                    $behaviors = [];
776
 
777
                    foreach ($behaviorCompetencies as $rows) {
778
 
779
                        $behavior = $behaviorMapper->fetchOne($rows->behavior_id);
2747 eleazar 780
                        $jobDescriptionBehaviorCompetency = $jobDescriptionBehaviorCompetencyMapper->fetchOneByBehavior($recruitmentSelectionVacancy->job_description_id, $record->competency_id, $rows->behavior_id);
2667 eleazar 781
 
782
                        if ($behavior && $jobDescriptionBehaviorCompetency) {
2898 eleazar 783
                            $rowData = [
2667 eleazar 784
                                'description' => $behavior->description,
785
                                'level' => $jobDescriptionBehaviorCompetency->level,
2898 eleazar 786
                                'comment' => '',
4077 eleazar 787
                                'evaluation' => '',
4040 eleazar 788
 
2898 eleazar 789
                            ];
790
 
791
                            foreach($content as $eval) {
792
                                if ($eval['competencyUuid'] == $competency->uuid &&
793
                                    $eval['behaviorUuid'] == $behavior->uuid) {
3458 eleazar 794
 
2898 eleazar 795
                                    $rowData['comment'] = $eval['comment'];
4077 eleazar 796
                                    $rowData['evaluation'] = $eval['evaluation'];
4040 eleazar 797
 
3458 eleazar 798
 
2898 eleazar 799
                                    break;
800
                                }
801
                            }
802
 
803
                            $behaviors []= $rowData;
2667 eleazar 804
                        }
805
                    }
806
 
807
                    array_push($competencies, [
808
                        'name' => $competency->name,
809
                        'description' => $competency->description,
810
                        'type' => $competenceType->name,
811
                        'behaviors' => $behaviors
812
                    ]);
813
                }
814
            }
815
 
2747 eleazar 816
            return $this->renderPDF($currentCompany, $recruitmentSelectionInterview, $competencies);
2667 eleazar 817
        }
818
 
819
        return new JsonModel([
820
            'success' => false,
821
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
822
        ]);
2747 eleazar 823
    }
2667 eleazar 824
 
825
    /**
826
     * Render PDF
827
     * @param Company $currentCompany
2747 eleazar 828
     * @param recruitmentSelectionInterview $interviewEvaluation
2667 eleazar 829
     * @param array $competencies
830
     * @return mixed
831
     */
2864 eleazar 832
    public function renderPDF($currentCompany, $interviewEvaluation, $competencies) {
2667 eleazar 833
 
3458 eleazar 834
        $currentUserPlugin = $this->plugin('currentUserPlugin');
835
        $currentUser = $currentUserPlugin->getUser();
836
 
2667 eleazar 837
        //Generate New PDF
838
        $pdf = new InterviewPDF();
839
 
840
        $pdf->header = '';
841
        $pdf->footer = '';
842
 
843
        if ($currentCompany) {
844
            //get company Data
845
            $companyMapper = CompanyMapper::getInstance($this->adapter);
846
            $company = $companyMapper->fetchOne($currentCompany->id);
847
 
2891 eleazar 848
            $target_path = $this->config['leaderslinked.fullpath.company'] . DIRECTORY_SEPARATOR . $company->uuid;
2667 eleazar 849
 
850
            $pdf->header = $company->header ? $target_path . DIRECTORY_SEPARATOR . $company->header : '';
851
            $pdf->footer = $company->footer ? $target_path . DIRECTORY_SEPARATOR . $company->footer : '';
852
        }
853
 
854
        $pdf->SetMargins(10, 0, 10);
855
 
856
        $pdf->AliasNbPages();
857
        $pdf->AddPage();
858
 
2894 eleazar 859
        $recruitmentSelectionCandidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
860
        $recruitmentSelectionVacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
2747 eleazar 861
        $vacancy = $recruitmentSelectionVacancyMapper->fetchOne($interviewEvaluation->vacancy_id);
2894 eleazar 862
        $candidate = $recruitmentSelectionCandidateMapper->fetchOne($interviewEvaluation->candidate_id);
2667 eleazar 863
 
4037 eleazar 864
        switch ($interviewEvaluation->type) {
4036 eleazar 865
            case "r":
4046 eleazar 866
                $type = "Recursos Humanos";
4036 eleazar 867
                break;
868
            case "b":
4038 eleazar 869
                $type = "Jefe";
4036 eleazar 870
                break;
871
            default :
872
                $type = "ERROR";
873
                break;
874
        }
875
 
4247 eleazar 876
        switch ($interviewEvaluation->points) {
877
            case "0":
878
                $points = "Sugerir otro cargo";
879
                break;
880
            case "1":
881
                $points = "25%";
882
                break;
883
            case "2":
884
                $points = "50%";
885
                break;
886
            case "3":
887
                $points = "75%";
888
                break;
889
            case "4":
890
                $points = "100%";
891
                break;
892
            default :
893
                $points = "ERROR";
894
                break;
895
        }
896
 
2667 eleazar 897
        $rows = [
898
            array(
899
                'title' => 'Nombre Evaluado: ',
3458 eleazar 900
                'content' => $candidate ? ' ' . $candidate->first_name . ' ' . $candidate->last_name : 'No Aplica'
2667 eleazar 901
            ),
902
            array(
903
                'title' => 'Cargo: ',
2747 eleazar 904
                'content' => $vacancy ? ' ' . $vacancy->name : ' No aplica'
2667 eleazar 905
            ),
906
            array(
3458 eleazar 907
                'title' => 'Entrevistado por: ',
908
                'content' => $currentUser ? ' ' . $currentUser->first_name . ' ' . $currentUser->last_name : ' No Aplica '
2667 eleazar 909
            ),
910
            array(
3458 eleazar 911
                'title' => 'Estatus del candidato: ',
4036 eleazar 912
                'content' => $type
2667 eleazar 913
            ),
914
            array(
3458 eleazar 915
                'title' => 'Comentarios del entrevistador: ',
916
                'content' => $interviewEvaluation ? ' ' . $interviewEvaluation->comment : 'No Aplica'
2667 eleazar 917
            ),
918
            array(
3458 eleazar 919
                'title' => 'Porcentage de adaptibilidad ',
4247 eleazar 920
                'content' => $points
2667 eleazar 921
            )
922
        ];
923
 
2922 eleazar 924
        $pdf->borderTable('DATOS DE LA ENTREVISTA', $rows);
4050 eleazar 925
 
926
        $sections = json_decode($interviewEvaluation->content, true);
4052 eleazar 927
        /*
4050 eleazar 928
                for ($s = 0; $s < count($sections); $s++) {
929
 
930
                    $pdf->singleTable($sections[$s]['title'], [
931
                        array(
932
                            'content' => $sections[$s]['type'] != 'multiple' ? $sections[$s]['text'] : ''
933
                    )]);
934
 
935
                    if ($sections[$s]['type'] == 'multiple') {
936
 
937
                        $pdf->titleOptionTable($sections[$s]['text']);
938
 
939
                        for ($o = 0; $o < count($sections[$s]['options']); $o++) {
940
 
941
                            $pdf->optionTable($sections[$s]['options'][$o]['title']);
942
                        }
943
                        $pdf->Ln();
944
                    }
945
                    if ($s % 2 == 0 && $s > 1) {
946
                        $pdf->AddPage();
947
                    }
4052 eleazar 948
                }*/
4050 eleazar 949
 
3458 eleazar 950
        // Competencies
2667 eleazar 951
        if (count($competencies) != 0) {
952
 
4053 eleazar 953
            // add new page
2667 eleazar 954
 
955
            $pdf->AddPage();
956
 
957
            $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:');
958
 
959
            $pdf->singleTable('Anexo de valores:', $competencies_header);
960
 
961
 
962
            // Add scale section
963
            $pdf->sectionScale();
964
 
965
            $i = 0;
4053 eleazar 966
 
967
            foreach ($competencies as $record) {
968
 
969
                $i = $i + 1;
970
 
971
                $pdf->competencyTable($i, $record);
972
 
973
                if ($i % 3 == 0 && $i < count($competencies)) {
974
                    $pdf->AddPage();
975
                }
976
            }
4029 eleazar 977
 
2893 eleazar 978
        }
4027 eleazar 979
 
2667 eleazar 980
        return $pdf->Output();
4027 eleazar 981
 
2864 eleazar 982
    }
1709 eleazar 983
}