Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
7290 eleazar 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
8
use Laminas\Mvc\Controller\AbstractActionController;
9
use Laminas\Log\LoggerInterface;
10
use Laminas\View\Model\ViewModel;
11
use Laminas\View\Model\JsonModel;
12
use LeadersLinked\Library\Functions;
13
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
14
use LeadersLinked\Mapper\UserMapper;
15
use LeadersLinked\Mapper\CompanyMapper;
16
use LeadersLinked\Model\Company;
17
use Laminas\Hydrator\ArraySerializableHydrator;
18
use Laminas\Db\ResultSet\HydratingResultSet;
19
use LeadersLinked\Mapper\QueryMapper;
20
use Laminas\Paginator\Adapter\DbSelect;
21
use Laminas\Paginator\Paginator;
22
use Laminas\Db\Adapter\AdapterInterface;
23
use LeadersLinked\Mapper\OrganizationalClimateTestMapper;
24
use LeadersLinked\Mapper\OrganizationalClimateMapper;
25
use LeadersLinked\Mapper\OrganizationalClimateFormMapper;
26
use LeadersLinked\Form\OrganizationalClimateTestForm;
27
use LeadersLinked\Model\OrganizationalClimateTest;
7533 eleazar 28
use LeadersLinked\Library\UniqueSurveyReport;
7290 eleazar 29
 
30
class OrganizationalClimateTestController extends AbstractActionController {
31
 
32
    /**
33
     *
34
     * @var AdapterInterface
35
     */
36
    private $adapter;
37
 
38
    /**
39
     *
40
     * @var AbstractAdapter
41
     */
42
    private $cache;
43
 
44
    /**
45
     *
46
     * @var  LoggerInterface
47
     */
48
    private $logger;
49
 
50
    /**
51
     *
52
     * @var array
53
     */
54
    private $config;
55
 
56
    /**
57
     *
58
     * @param AdapterInterface $adapter
59
     * @param AbstractAdapter $cache
60
     * @param LoggerInterface $logger
61
     * @param array $config
62
     */
63
    public function __construct($adapter, $cache, $logger, $config) {
64
        $this->adapter = $adapter;
65
        $this->cache = $cache;
66
        $this->logger = $logger;
67
        $this->config = $config;
68
    }
69
 
70
    public function indexAction() {
71
 
72
        $request = $this->getRequest();
73
        $currentUserPlugin = $this->plugin('currentUserPlugin');
74
        $currentCompany = $currentUserPlugin->getCompany();
75
        $currentUser = $currentUserPlugin->getUser();
76
 
7395 eleazar 77
 
7290 eleazar 78
        $request = $this->getRequest();
79
        if ($request->isGet()) {
80
 
81
            $headers = $request->getHeaders();
82
 
83
            $isJson = false;
84
            if ($headers->has('Accept')) {
85
                $accept = $headers->get('Accept');
86
 
87
                $prioritized = $accept->getPrioritized();
88
 
89
                foreach ($prioritized as $key => $value) {
90
                    $raw = trim($value->getRaw());
91
 
92
                    if (!$isJson) {
93
                        $isJson = strpos($raw, 'json');
94
                    }
95
                }
96
            }
97
 
98
            if ($isJson) {
99
                $organizationalClimate_uuid = $this->params()->fromRoute('organizationalClimate_id');
100
 
101
                if(!$organizationalClimate_uuid){
102
                    return new JsonModel([
103
                        'success' => true,
104
                        'data' => [
105
                            'items' => [],
106
                            'total' => 0
107
                        ]
108
                    ]);
109
                }
110
 
111
                $organizationalClimateMapper = OrganizationalClimateMapper::getInstance($this->adapter);
112
                $organizationalClimate = $organizationalClimateMapper->fetchOneByUuid($organizationalClimate_uuid);
7393 eleazar 113
 
7290 eleazar 114
                $search = $this->params()->fromQuery('search', []);
115
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
116
 
117
                $page = intval($this->params()->fromQuery('start', 1), 10);
118
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
119
                $order = $this->params()->fromQuery('order', []);
120
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
121
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
122
 
123
                $fields = ['first_name'];
124
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';
125
 
126
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
127
                    $order_direction = 'ASC';
128
                }
129
 
130
                $organizationalClimateTestMapper = OrganizationalClimateTestMapper::getInstance($this->adapter);
7394 eleazar 131
                $paginator = $organizationalClimateTestMapper->fetchAllDataTableBySurveyId($organizationalClimate->id, $search, $page, $records_x_page, $order_field, $order_direction);
7290 eleazar 132
 
133
                $items = [];
134
                $records = $paginator->getCurrentItems();
135
 
136
                foreach ($records as $record) {
137
 
138
                    $item = [
139
                        'id' => $record->id,
140
                        'first_name' => $record->first_name,
11234 eleazar 141
                        'last_name' => $record->last_name,
7290 eleazar 142
                        'date' => $record->added_on,
143
 
144
                        'actions' => [
145
                            'link_delete' => $this->url()->fromRoute('organizational-climate/test/delete', ['id' => $record->id, 'organizationalClimate_id' => $organizationalClimate->uuid]),
146
                            'link_report' => $this->url()->fromRoute('organizational-climate/test/report', ['uuid' => $record->uuid, 'organizationalClimate_id' => $organizationalClimate->uuid])
147
                        ]
148
                    ];
149
 
150
                    array_push($items, $item);
151
                }
152
 
153
                return new JsonModel([
154
                    'success' => true,
155
                    'data' => [
156
                        'items' => $items,
157
                        'total' => $paginator->getTotalItemCount(),
158
                    ]
159
                ]);
160
            } else {
161
                $organizationalClimateMapper = OrganizationalClimateMapper::getInstance($this->adapter);
162
                $organizationalClimate = $organizationalClimateMapper->fetchAllByCompanyId($currentCompany->id);
163
 
164
                $form = new OrganizationalClimateTestForm($this->adapter, $currentCompany->id);
165
 
166
                $this->layout()->setTemplate('layout/layout-backend');
167
                $viewModel = new ViewModel();
168
                $viewModel->setTemplate('leaders-linked/organizational-climate-test/index.phtml');
169
                $viewModel->setVariables([
170
                    'form'      => $form,
171
                    'organizationalClimate' => $organizationalClimate
172
                ]);
173
                return $viewModel;
174
            }
175
        } else {
176
            return new JsonModel([
177
                'success' => false,
178
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
179
            ]);
180
 
181
        }
7395 eleazar 182
 
7290 eleazar 183
    }
184
 
185
    public function addAction() {
186
        $request = $this->getRequest();
187
        $currentUserPlugin = $this->plugin('currentUserPlugin');
188
        $currentCompany = $currentUserPlugin->getCompany();
189
        $currentUser = $currentUserPlugin->getUser();
190
 
191
        $request = $this->getRequest();
192
 
193
        $organizationalClimate_id = $this->params()->fromRoute('organizationalClimate_id');
194
 
195
        if ($request->isGet()) {
196
            $organizationalClimateMapper = OrganizationalClimateMapper::getInstance($this->adapter);
197
            $organizationalClimate = $organizationalClimateMapper->fetchOneByUuid($organizationalClimate_id);
198
 
199
            $organizationalClimateFormMapper = OrganizationalClimateFormMapper::getInstance($this->adapter);
200
            $organizationalClimateForm = $organizationalClimateFormMapper->fetchOne($organizationalClimate->form_id);
201
 
202
            $data = [
203
                'organizationalClimate' => [
204
                    'id' => $organizationalClimate->uuid,
205
                    'content' => $organizationalClimateForm->content ? json_decode($organizationalClimateForm->content) : [],
206
                    'description' => $organizationalClimateForm->description,
207
                    'text' => $organizationalClimateForm->text,
208
                ],
209
            ];
210
 
211
        } else if ($request->isPost()) {
212
 
213
            $form = new OrganizationalClimateTestForm($this->adapter, $currentCompany->id);
214
 
215
            $dataPost = $request->getPost()->toArray();
216
 
217
            $form->setData($dataPost);
218
 
219
            if ($form->isValid()) {
220
                $dataPost = (array) $form->getData();
221
 
222
                $hydrator = new ObjectPropertyHydrator();
223
                $organizationalClimate = new OrganizationalClimateTest();
224
                $hydrator->hydrate($dataPost, $organizationalClimate);
225
 
226
                $organizationalClimateDoneMapper = OrganizationalClimateMapper::getInstance($this->adapter);
227
                $organizationalClimateDone = $organizationalClimateDoneMapper->fetchOneByUuid($organizationalClimate_id);
228
 
229
                $organizationalClimate->company_id = $currentCompany->id;
7525 eleazar 230
                $organizationalClimate->organizationalClimate_id = $organizationalClimateDone->id;
7290 eleazar 231
 
232
                $organizationalClimateMapper = OrganizationalClimateTestMapper::getInstance($this->adapter);
233
                $result = $organizationalClimateMapper->insert($organizationalClimate);
234
 
235
                if ($result) {
236
                    $this->logger->info('Se agrego el formulario' . $organizationalClimate->first_name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
237
 
238
                    // Get record by id
239
                    $record = $organizationalClimateMapper->fetchOne($organizationalClimate->id);
240
 
241
                    if ($record) {
242
 
243
                        $data = [
244
                            'success' => true,
245
                            'id' => $record->id,
246
                            'data' => 'LABEL_RECORD_ADDED'
247
                        ];
248
                    } else {
249
 
250
                        $data = [
251
                            'success' => false,
252
                            'data' => 'ERROR_RECORD_NOT_FOUND'
253
                        ];
254
                    }
255
                } else {
256
                    $data = [
257
                        'success' => false,
258
                        'data' => $organizationalClimateMapper->getError()
259
                    ];
260
                }
261
 
262
                return new JsonModel($data);
263
            } else {
264
                $messages = [];
265
                $form_messages = (array) $form->getMessages();
266
                foreach ($form_messages as $fieldname => $field_messages) {
267
 
268
                    $messages[$fieldname] = array_values($field_messages);
269
                }
270
 
271
                return new JsonModel([
272
                    'success' => false,
273
                    'data' => $messages
274
                ]);
275
            }
276
        } else {
277
            $data = [
278
                'success' => false,
279
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
280
            ];
281
 
282
            return new JsonModel($data);
283
        }
284
 
285
        return new JsonModel($data);
286
    }
287
 
288
    public function deleteAction() {
289
        $request = $this->getRequest();
290
        $currentUserPlugin = $this->plugin('currentUserPlugin');
291
        $currentCompany = $currentUserPlugin->getCompany();
292
        $currentUser = $currentUserPlugin->getUser();
293
        try{
294
        $request = $this->getRequest();
295
        $id = $this->params()->fromRoute('id');
296
 
297
        if (!$id) {
298
            $data = [
299
                'success' => false,
300
                'data' => 'ERROR_INVALID_PARAMETER'
301
            ];
302
 
303
            return new JsonModel($data);
304
        }
305
 
306
        $organizationalClimateTestMapper = OrganizationalClimateTestMapper::getInstance($this->adapter);
307
        $organizationalClimate = $organizationalClimateTestMapper->fetchOne($id);
308
        if (!$organizationalClimate) {
309
            $data = [
310
                'success' => false,
311
                'data' => 'ERROR_RECORD_NOT_FOUND'
312
            ];
313
 
314
            return new JsonModel($data);
315
        }
316
 
317
        if ($organizationalClimate->company_id != $currentCompany->id) {
318
            return new JsonModel([
319
                'success' => false,
320
                'data' => 'ERROR_UNAUTHORIZED'
321
            ]);
322
        }
323
 
324
        if ($request->isPost()) {
325
 
326
            $result = $organizationalClimateTestMapper->delete($organizationalClimate->id);
327
            if ($result) {
328
               // $this->logger->info('Se borro el formulario ' . $organizationalClimate->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
329
 
330
                $data = [
331
                    'success' => true,
332
                    'data' => 'LABEL_RECORD_DELETED'
333
                ];
334
            } else {
335
 
336
                $data = [
337
                    'success' => false,
338
                    'data' => $organizationalClimateTestMapper->getError()
339
                ];
340
 
341
                return new JsonModel($data);
342
            }
343
        } else {
344
            $data = [
345
                'success' => false,
346
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
347
            ];
348
 
349
            return new JsonModel($data);
350
        }
351
 
352
        return new JsonModel($data);
353
        } catch (\Throwable $e) {
354
            $e->getMessage();
355
            return new JsonModel([
356
                'success' => false,
357
                'data' => $e
358
            ]);
359
        }
360
 
361
    }
362
 
363
    public function reportAction() {
364
        $request = $this->getRequest();
365
        $currentUserPlugin = $this->plugin('currentUserPlugin');
366
        $currentCompany = $currentUserPlugin->getCompany();
367
        $currentUser = $currentUserPlugin->getUser();
368
 
369
        $request = $this->getRequest();
370
        $uuid = $this->params()->fromRoute('uuid');
371
 
372
 
373
 
374
        if (!$uuid) {
375
            $data = [
376
                'success' => false,
377
                'data' => 'ERROR_INVALID_PARAMETER'
378
            ];
379
 
380
            return new JsonModel($data);
381
        }
382
 
383
        $organizationalClimateTestMapper = OrganizationalClimateTestMapper::getInstance($this->adapter);
384
        $organizationalClimateTest = $organizationalClimateTestMapper->fetchOneByuuid($uuid);
385
 
386
 
387
        $organizationalClimateMapper = OrganizationalClimateMapper::getInstance($this->adapter);
388
        $organizationalClimate = $organizationalClimateMapper->fetchOne($organizationalClimateTest->organizationalClimate_id);
389
 
390
        if (!$organizationalClimateTest) {
391
            $data = [
392
                'success' => false,
393
                'data' => 'ERROR_RECORD_NOT_FOUND'
394
            ];
395
 
396
            return new JsonModel($data);
397
        }
398
 
399
 
400
        if ($request->isGet()) {
401
            $hydrator = new ObjectPropertyHydrator();
402
 
403
            //get form data
404
            $organizationalClimateFormMapper = OrganizationalClimateFormMapper::getInstance($this->adapter);
405
            $organizationalClimateForm = $organizationalClimateFormMapper->fetchOne($organizationalClimate->form_id);
406
 
407
            if ($organizationalClimateForm) {
408
 
409
                return $this->renderPDF($organizationalClimateForm, $organizationalClimateTest, $organizationalClimate);
410
            } else {
411
 
412
                $data = [
413
                    'success' => false,
414
                    'data' => 'ERROR_METHOD_NOT_ALLOWED'
415
                ];
416
 
417
                return new JsonModel($data);
418
            }
419
        } else {
420
            $data = [
421
                'success' => false,
422
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
423
            ];
424
 
425
            return new JsonModel($data);
426
        }
427
 
428
        return new JsonModel($data);
429
    }
430
 
431
    public function renderPDF($organizationalClimateForm, $organizationalClimateTest, $organizationalClimate) {
432
 
433
        $target_path = $this->config['leaderslinked.fullpath.company'] . DIRECTORY_SEPARATOR . $organizationalClimate->uuid;
434
 
435
 
436
        if(file_exists($target_path)) {
437
            Functions::deleteFiles($target_path);
438
        } else {
439
            @mkdir($target_path, 0755, true);
440
        }
441
 
442
        // Set Data
443
        $headerFormName = utf8_decode($organizationalClimateForm->name);
444
        $headerOrganizationalClimateName = utf8_decode('Informe de Encuesta: ' . trim($organizationalClimate->name) . ' al ' . date("m-d-Y H:i:s", strtotime($organizationalClimate->added_on)));
445
        $sections = json_decode($organizationalClimateForm->content, true);
446
 
447
        $test = json_decode($organizationalClimateTest->content, true);
448
 
449
        //Generate New PDF
450
        $pdf = new UniqueSurveyReport();
451
 
452
        $pdf->AliasNbPages();
453
        $pdf->AddPage();
454
 
455
        // Set header secundary
456
        $pdf->customHeader($headerFormName, $headerOrganizationalClimateName);
457
 
458
        $countSection = 0;
459
 
460
        for ($i = 0; $i < count($sections); $i++) {
461
            if ($countSection > 1) {
462
                $countSection = 0;
463
                $pdf->AddPage();
464
                $pdf->customHeader($headerFormName);
465
            }
466
            $section = $sections[$i];
467
 
468
            foreach ($section['questions'] as $question) {
469
 
470
                    switch ($question['type']) {
471
                        case 'simple':
472
                            $options = [];
473
 
474
                            foreach($question['options'] as $option) {
475
                                $options []= [
476
                                    'text' => strip_tags($option['text']),
477
                                    'selected' => $option['slug_option'] == $test[$question['slug_question']],
478
                                ];
479
                            }
480
 
481
                            $pdf->optionTable(strip_tags($question['text']), $options);
482
 
483
                            break;
484
 
485
                        case 'multiple':
486
                            $options = [];
487
 
488
                            foreach($question['options'] as $option) {
489
                                $options []= [
490
                                    'text' => strip_tags($option['text']),
491
                                    'selected' => in_array($option['slug_option'], $test[$question['slug_question']]),
492
                                ];
493
                            }
494
 
495
                            $pdf->optionTable(strip_tags($question['text']), $options);
496
 
497
                            break;
498
                        case 'open':
499
                            $pdf->borderTable(strip_tags($question['text']), [['content' => $test[$question['slug_question']]]]);
500
 
501
 
502
                            break;
503
                    }
504
                $countSection++;
505
            }
506
 
507
 
508
        }
509
 
510
        return $pdf->Output();
511
    }
512
 
513
 
514
}