Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
16785 efrain 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
8
 
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use Laminas\Log\LoggerInterface;
11
use Laminas\View\Model\JsonModel;
12
use LeadersLinked\Form\Planning\PlanningPeriodForm;
13
use Laminas\View\Model\ViewModel;
14
use LeadersLinked\Library\Functions;
15
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
16
use LeadersLinked\Mapper\PlanningPeriodMapper;
17
use LeadersLinked\Model\PlanningPeriod;
18
 
19
class PlanningPeriodController extends AbstractActionController {
20
 
21
    /**
22
     *
23
     * @var \Laminas\Db\Adapter\AdapterInterface
24
     */
25
    private $adapter;
26
 
27
    /**
28
     *
29
     * @var \LeadersLinked\Cache\CacheInterface
30
     */
31
    private $cache;
32
 
33
 
34
    /**
35
     *
36
     * @var \Laminas\Log\LoggerInterface
37
     */
38
    private $logger;
39
 
40
    /**
41
     *
42
     * @var array
43
     */
44
    private $config;
45
 
46
 
47
    /**
48
     *
49
     * @var \Laminas\Mvc\I18n\Translator
50
     */
51
    private $translator;
52
 
53
 
54
    /**
55
     *
56
     * @param \Laminas\Db\Adapter\AdapterInterface $adapter
57
     * @param \LeadersLinked\Cache\CacheInterface $cache
58
     * @param \Laminas\Log\LoggerInterface LoggerInterface $logger
59
     * @param array $config
60
     * @param \Laminas\Mvc\I18n\Translator $translator
61
     */
62
    public function __construct($adapter, $cache, $logger, $config, $translator)
63
    {
64
        $this->adapter      = $adapter;
65
        $this->cache        = $cache;
66
        $this->logger       = $logger;
67
        $this->config       = $config;
68
        $this->translator   = $translator;
69
    }
70
 
71
    public function indexAction() {
72
 
73
 
74
        $currentUserPlugin = $this->plugin('currentUserPlugin');
75
        $currentUser = $currentUserPlugin->getUser();
76
        $currentCompany = $currentUserPlugin->getCompany();
77
 
78
 
79
        $request = $this->getRequest();
80
        if($request->isGet()) {
81
 
82
 
83
            $headers  = $request->getHeaders();
84
 
85
            $isJson = false;
86
            if($headers->has('Accept')) {
87
                $accept = $headers->get('Accept');
88
 
89
                $prioritized = $accept->getPrioritized();
90
 
91
                foreach($prioritized as $key => $value) {
92
                    $raw = trim($value->getRaw());
93
 
94
                    if(!$isJson) {
95
                        $isJson = strpos($raw, 'json');
96
                    }
97
 
98
                }
99
            }
100
 
101
            if($isJson) {
102
 
103
 
104
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
105
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'planning/periods/edit');
106
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'planning/periods/delete');
107
 
108
                $search = $this->params()->fromQuery('search', []);
109
                $search = empty($search['value']) ? '' :  Functions::sanitizeFilterString($search['value']);
110
 
111
 
112
                $records_x_page     = intval($this->params()->fromQuery('length', 10), 10);
113
                $page               = (intval($this->params()->fromQuery('start', 1), 10)/$records_x_page)+1;
114
                $order =  $this->params()->fromQuery('order', []);
115
                $order_field        = empty($order[0]['column']) ? 99 :  intval($order[0]['column'], 10);
116
                $order_direction    = empty($order[0]['dir']) ? 'ASC' : strtoupper(Functions::sanitizeFilterString($order[0]['dir']));
117
 
118
                $fields =  ['title', 'start', 'end', 'progress'];
119
 
120
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';
121
 
122
                if(!in_array($order_direction, ['ASC', 'DESC'])) {
123
                    $order_direction = 'ASC';
124
                }
125
 
126
                $planningPeriodMapper = PlanningPeriodMapper::getInstance($this->adapter);
127
                $paginator = $planningPeriodMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);
128
 
129
 
130
                $items = [];
131
                $records = $paginator->getCurrentItems();
132
 
133
                foreach($records as $record)
134
                {
135
                    $dtStart = \DateTime::createFromFormat('Y-m-d', $record->start);
136
                    $dtEnd = \DateTime::createFromFormat('Y-m-d', $record->end);
137
 
138
                    $item = [
139
                        'title'         => $record->title,
140
                        'description'   => $record->description,
141
                        'status'        => $record->status,
142
                        'start'         => $dtStart->format('d/m/Y'),
143
                        'end'           => $dtEnd->format('d/m/Y'),
144
                        'progress'      => $record->progress ? $record->progress : 0,
145
                        'actions' => [
146
                            'link_edit' => $allowEdit ? $this->url()->fromRoute('planning/periods/edit', ['id' => $record->uuid]) : '',
147
                            'link_delete' => $allowDelete ? $this->url()->fromRoute('planning/periods/delete', ['id' => $record->uuid]) : '',
148
                            //'link_objective' => $allowObjective ? $this->url()->fromRoute('planning/objectives/goals', ['objective_id' => $record->uuid]) : '',
149
                            //'link_objective_report' => $allowObjectiveReport ? $this->url()->fromRoute('planning/objectives/report', ['id' => $record->uuid]) : '',
150
                        ]
151
                    ];
152
                    array_push($items, $item);
153
                }
154
 
155
                return new JsonModel([
156
                    'success' => true,
157
                    'data' => [
158
                        'items' => $items,
159
                        'total' => $paginator->getTotalItemCount(),
160
                    ]
161
                ]);
162
 
163
            } else  {
164
                $form = new PlanningPeriodForm();
165
 
166
                $this->layout()->setTemplate('layout/layout-backend');
167
                $viewModel = new ViewModel();
168
                $viewModel->setTemplate('leaders-linked/planning/periods');
169
                $viewModel->setVariables([
170
                    'form' => $form,
171
                ]);
172
                return $viewModel ;
173
            }
174
        } else {
175
            return new JsonModel([
176
                'success' => false,
177
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
178
            ]);
179
        }
180
    }
181
 
182
 
183
 
184
    public function addAction()
185
    {
186
        $currentUserPlugin = $this->plugin('currentUserPlugin');
187
        $currentUser = $currentUserPlugin->getUser();
188
        $currentCompany = $currentUserPlugin->getCompany();
189
 
190
        $request = $this->getRequest();
191
        if($request->isPost()) {
192
            $form = new  PlanningPeriodForm();
193
            $dataPost = $request->getPost()->toArray();
194
 
195
            if(!empty($dataPost['date_range'])) {
196
                $s = explode('-', $dataPost['date_range']);
197
                $start = trim($s[0]);
198
                $end = trim($s[1]);
199
 
200
                $dtStart = \DateTime::createFromFormat('d/m/Y', $start);
201
                $dtEnd  = \DateTime::createFromFormat('d/m/Y', $end);
202
                if(!$dtStart &&  !$dtEnd) {
203
                    $dataPost['date_range'] = '';
204
                }
205
            }
206
 
207
 
208
 
209
            $form->setData($dataPost);
210
 
211
            if($form->isValid()) {
212
                $dataPost = (array) $form->getData();
213
                $dataPost['status'] =  empty($dataPost['status']) ? PlanningPeriod::STATUS_INACTIVE : $dataPost['status'];
214
 
215
 
216
 
217
                $hydrator = new ObjectPropertyHydrator();
218
                $planningPeriod = new PlanningPeriod();
219
                $planningPeriod->company_id = $currentCompany->id;
220
 
221
                $hydrator->hydrate($dataPost, $planningPeriod);
222
 
223
 
224
 
225
                $planningPeriodMapper = PlanningPeriodMapper::getInstance($this->adapter);
226
                $result = $planningPeriodMapper->insert($planningPeriod);
227
 
228
                if($result) {
229
                    $this->logger->info('Se agrego el período de planificación : ' . $planningPeriod->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
230
 
231
                    $data = [
232
                        'success'   => true,
233
                        'data'   => 'LABEL_RECORD_ADDED'
234
                    ];
235
                } else {
236
                    $data = [
237
                        'success'   => false,
238
                        'data'      => $planningPeriodMapper->getError()
239
                    ];
240
 
241
                }
242
 
243
                return new JsonModel($data);
244
 
245
            } else {
246
                $messages = [];
247
                $form_messages = (array) $form->getMessages();
248
                foreach($form_messages  as $fieldname => $field_messages)
249
                {
250
 
251
                    $messages[$fieldname] = array_values($field_messages);
252
                }
253
 
254
                return new JsonModel([
255
                    'success'   => false,
256
                    'data'   => $messages
257
                ]);
258
            }
259
 
260
        } else {
261
            $data = [
262
                'success' => false,
263
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
264
            ];
265
 
266
            return new JsonModel($data);
267
        }
268
 
269
        return new JsonModel($data);
270
 
271
 
272
    }
273
 
274
 
275
 
276
    public function editAction(){
277
 
278
        $currentUserPlugin = $this->plugin('currentUserPlugin');
279
        $currentUser = $currentUserPlugin->getUser();
280
        $currentCompany = $currentUserPlugin->getCompany();
281
 
282
 
283
        $request = $this->getRequest();
284
        $uuid = $this->params()->fromRoute('id');
285
 
286
 
287
        if(!$uuid) {
288
            $data = [
289
                'success'   => false,
290
                'data'   => 'ERROR_INVALID_PARAMETER'
291
            ];
292
 
293
            return new JsonModel($data);
294
        }
295
 
296
        $planningPeriodMapper = PlanningPeriodMapper::getInstance($this->adapter);
297
        $planningPeriod = $planningPeriodMapper->fetchOneByUuid($uuid);
298
 
299
        if (!$planningPeriod) {
300
            $data = [
301
                'success' => false,
302
                'data' => 'ERROR_RECORD_NOT_FOUND'
303
            ];
304
 
305
            return new JsonModel($data);
306
        }
307
 
308
        if ($planningPeriod->company_id != $currentCompany->id) {
309
            return new JsonModel([
310
                'success' => false,
311
                'data' => 'ERROR_UNAUTHORIZED'
312
            ]);
313
        }
314
 
315
        if($request->isPost()) {
316
            $form = new  PlanningPeriodForm();
317
            $dataPost = $request->getPost()->toArray();
318
            $dataPost['status'] =  empty($dataPost['status']) ? PlanningPeriod::STATUS_INACTIVE : $dataPost['status'];
319
            if(empty($dataPost['date_range'])) {
320
                $dataPost['start'] = date('Y-m-d');
321
                $dataPost['end'] = date('Y-m-d');
322
            } else {
323
 
324
                $s = explode('-', $dataPost['date_range']);
325
                $start = trim($s[0]);
326
                $end = trim($s[1]);
327
 
328
                $dtStart = \DateTime::createFromFormat('d/m/Y', $start);
329
                $dtEnd  = \DateTime::createFromFormat('d/m/Y', $end);
330
                if($dtStart && $dtEnd) {
331
                    $dataPost['start'] = $dtStart->format('Y-m-d');
332
                    $dataPost['end'] = $dtEnd->format('Y-m-d');
333
 
334
                } else {
335
                    $dataPost['start'] = date('Y-m-d');
336
                    $dataPost['end'] = date('Y-m-d');
337
                }
338
            }
339
 
340
 
341
            $form->setData($dataPost);
342
 
343
            if($form->isValid()) {
344
                $dataPost = (array) $form->getData();
345
 
346
                $hydrator = new ObjectPropertyHydrator();
347
                $hydrator->hydrate($dataPost, $planningPeriod);
348
                $result = $planningPeriodMapper->update($planningPeriod);
349
 
350
                if($result) {
351
                    $this->logger->info('Se actualizo el período de planificación : ' . $planningPeriod->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
352
 
353
                    $data = [
354
                        'success' => true,
355
                        'data' => 'LABEL_RECORD_UPDATED'
356
                    ];
357
                } else {
358
                    $data = [
359
                        'success'   => false,
360
                        'data'      => $planningPeriodMapper->getError()
361
                    ];
362
                }
363
 
364
                return new JsonModel($data);
365
 
366
            } else {
367
                $messages = [];
368
                $form_messages = (array) $form->getMessages();
369
                foreach($form_messages  as $fieldname => $field_messages)
370
                {
371
                    $messages[$fieldname] = array_values($field_messages);
372
                }
373
 
374
                return new JsonModel([
375
                    'success'   => false,
376
                    'data'   => $messages
377
                ]);
378
            }
379
        }else if ($request->isGet()) {
380
 
381
            $data = [
382
                'success' => true,
383
                'data' => [
384
                    'title' => $planningPeriod->title,
385
                    'description' => $planningPeriod->description,
386
                    'start' => $planningPeriod->start,
387
                    'end' => $planningPeriod->end,
388
                    'status' => $planningPeriod->status,
389
                    'progress' => $planningPeriod->progress,
390
                    'budget' => $planningPeriod->budget,
391
                    'cost' => $planningPeriod->cost,
392
                ]
393
            ];
394
 
395
            return new JsonModel($data);
396
        } else {
397
            $data = [
398
                'success' => false,
399
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
400
            ];
401
 
402
            return new JsonModel($data);
403
        }
404
 
405
        return new JsonModel($data);
406
 
407
    }
408
 
409
 
410
 
411
 
412
    public function deleteAction()
413
    {
414
        $currentUserPlugin = $this->plugin('currentUserPlugin');
415
        $currentCompany = $currentUserPlugin->getCompany();
416
        $currentUser = $currentUserPlugin->getUser();
417
 
418
        $request = $this->getRequest();
419
        $uuid = $this->params()->fromRoute('id');
420
 
421
 
422
        if(!$uuid) {
423
            $data = [
424
                'success'   => false,
425
                'data'   => 'ERROR_INVALID_PARAMETER'
426
            ];
427
 
428
            return new JsonModel($data);
429
        }
430
 
431
        $planningPeriodMapper = PlanningPeriodMapper::getInstance($this->adapter);
432
        $planningPeriod = $planningPeriodMapper->fetchOneByUuid($uuid);
433
 
434
        if (!$planningPeriod) {
435
            $data = [
436
                'success' => false,
437
                'data' => 'ERROR_RECORD_NOT_FOUND'
438
            ];
439
 
440
            return new JsonModel($data);
441
        }
442
 
443
        if ($planningPeriod->company_id != $currentCompany->id) {
444
            return new JsonModel([
445
                'success' => false,
446
                'data' => 'ERROR_UNAUTHORIZED'
447
            ]);
448
        }
449
 
450
 
451
        if ($request->isPost()) {
452
 
453
 
454
            $result = $planningPeriodMapper->delete($planningPeriod);
455
            if ($result) {
456
                $this->logger->info('Se borro el período de planificación :' . $planningPeriod->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
457
 
458
                $data = [
459
                    'success' => true,
460
                    'data' => 'LABEL_RECORD_DELETED'
461
                ];
462
            } else {
463
 
464
                $data = [
465
                    'success' => false,
466
                    'data' => $planningPeriodMapper->getError()
467
                ];
468
 
469
                return new JsonModel($data);
470
            }
471
        } else {
472
            $data = [
473
                'success' => false,
474
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
475
            ];
476
 
477
            return new JsonModel($data);
478
        }
479
 
480
        return new JsonModel($data);
481
    }
482
}