Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 6521 | Rev 6685 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
5050 efrain 1
<?php
2
declare(strict_types=1);
3
 
4
namespace LeadersLinked\Controller;
5
 
6
use Laminas\Db\Adapter\AdapterInterface;
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;
6388 efrain 12
use LeadersLinked\Mapper\MyCoachCategoryMapper;
6521 efrain 13
 
6388 efrain 14
use LeadersLinked\Form\MyCoach\MyCoachQuestionForm;
6521 efrain 15
use LeadersLinked\Library\MyCoachAccessControl;
16
use LeadersLinked\Form\MyCoach\MyCoachAnswerForm;
17
use LeadersLinked\Mapper\MyCoachQuestionMapper;
18
use LeadersLinked\Mapper\MyCoachQuestionCategoryMapper;
19
use LeadersLinked\Model\MyCoachQuestionCategory;
20
use LeadersLinked\Mapper\QueryMapper;
21
use LeadersLinked\Model\MyCoachQuestion;
22
use Laminas\Db\ResultSet\HydratingResultSet;
23
use Laminas\Paginator\Adapter\DbSelect;
24
use Laminas\Paginator\Paginator;
25
use LeadersLinked\Mapper\UserMapper;
26
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
27
use LeadersLinked\Library\Functions;
28
use LeadersLinked\Mapper\MyCoachAnswerMapper;
29
use LeadersLinked\Mapper\CommentMapper;
30
use LeadersLinked\Model\MyCoachAnswer;
31
use LeadersLinked\Form\MyCoach\CommentForm;
32
use LeadersLinked\Model\Comment;
33
use LeadersLinked\Mapper\ContentReactionMapper;
34
use LeadersLinked\Model\ContentReaction;
35
use LeadersLinked\Mapper\MyCoachQuestionViewMapper;
36
use LeadersLinked\Model\MyCoachQuestionView;
37
use Laminas\Db\Sql\Expression;
5050 efrain 38
 
39
class MyCoachController extends AbstractActionController
40
{
41
    /**
42
     *
43
     * @var AdapterInterface
44
     */
45
    private $adapter;
6388 efrain 46
 
47
 
5050 efrain 48
    /**
49
     *
50
     * @var AbstractAdapter
51
     */
52
    private $cache;
6388 efrain 53
 
5050 efrain 54
    /**
55
     *
56
     * @var  LoggerInterface
57
     */
58
    private $logger;
59
 
6388 efrain 60
 
5050 efrain 61
    /**
62
     *
63
     * @var array
64
     */
65
    private $config;
6388 efrain 66
 
5050 efrain 67
    /**
68
     *
69
     * @param AdapterInterface $adapter
70
     * @param AbstractAdapter $cache
71
     * @param LoggerInterface $logger
72
     * @param array $config
73
     */
6388 efrain 74
    public function __construct($adapter, $cache, $logger,  $config)
5050 efrain 75
    {
76
        $this->adapter      = $adapter;
77
        $this->cache        = $cache;
78
        $this->logger       = $logger;
79
        $this->config       = $config;
6388 efrain 80
    }
5050 efrain 81
 
82
    /**
83
     *
84
     * Generación del listado de perfiles
85
     * {@inheritDoc}
86
     * @see \Laminas\Mvc\Controller\AbstractActionController::indexAction()
87
     */
88
    public function indexAction()
89
    {
6388 efrain 90
        $currentUserPlugin = $this->plugin('currentUserPlugin');
91
        $currentUser = $currentUserPlugin->getUser();
92
 
93
        $currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
94
        $currentNetwork = $currentNetworkPlugin->getNetwork();
95
 
5050 efrain 96
        $request = $this->getRequest();
6388 efrain 97
        if ($request->isGet()) {
6521 efrain 98
 
99
            $myCoachAccesControl = MyCoachAccessControl::getInstance($this->adapter);
100
            $categories = $myCoachAccesControl->getCategoriesWithAccessToFormSelect($currentUser->id, $currentNetwork->id);
101
 
102
            $formQuestion = new MyCoachQuestionForm($categories);
103
            $formAnswer = new MyCoachAnswerForm();
5050 efrain 104
 
6388 efrain 105
 
6521 efrain 106
            $this->layout()->setTemplate('layout/layout');
107
            $viewModel = new ViewModel();
108
            $viewModel->setTemplate('leaders-linked/my-coach/index');
109
            $viewModel->setVariables([
110
                'categories' => $categories,
111
                'formQuestion' => $formQuestion,
112
                'formAnswer' => $formAnswer,
113
            ]);
114
            return $viewModel;
6388 efrain 115
 
6521 efrain 116
        } else {
117
            return new JsonModel([
118
                'success' => false,
119
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
120
            ]);
121
        }
122
    }
123
 
124
    public function questionsAction()
125
    {
126
        $currentUserPlugin = $this->plugin('currentUserPlugin');
127
        $currentUser = $currentUserPlugin->getUser();
128
 
129
        $currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
130
        $currentNetwork = $currentNetworkPlugin->getNetwork();
131
 
132
 
133
        $request = $this->getRequest();
134
        if ($request->isGet()) {
135
            $userMapper                     = UserMapper::getInstance($this->adapter);
136
            $myCoachCategoryMapper          = MyCoachCategoryMapper::getInstance($this->adapter);
137
            $myCoachQuestionCategoryMapper  = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
138
            $myCoachAccessControl           = MyCoachAccessControl::getInstance($this->adapter);
139
 
140
            $category_filter_id = filter_var($this->params()->fromQuery('category_id'), FILTER_SANITIZE_STRING);
141
            $search = filter_var($this->params()->fromQuery('search'), FILTER_SANITIZE_STRING);
142
            $page   = intval($this->params()->fromQuery('start', 1), 10);
143
 
144
            $order_field        = 'added_on';
145
            $order_direction    = 'asc';
146
            $records_x_page     = 12;
147
 
148
 
149
            if ($category_filter_id) {
150
 
151
                $message_error = '';
152
                if(!$myCoachAccessControl->hasAccessForCategory($currentUser->id, $category_filter_id, $currentNetwork->id, $message_error)) {
153
 
154
                    return new JsonModel([
155
                        'success' => true,
156
                        'data' => $message_error,
157
                    ]);
158
 
6388 efrain 159
                }
6521 efrain 160
 
161
 
162
 
163
                $categoryFilter = $myCoachCategoryMapper->fetchOneByUuid($category_filter_id);
164
                $category_ids = [$categoryFilter->id];
165
 
166
            } else {
167
                $category_ids = $myCoachAccessControl->getCategoryIdsWithAccess($currentUser->id, $currentNetwork->id);
168
            }
169
 
170
            $category_ids_with_edition = $myCoachAccessControl->getCategoryIdsWithEdition($currentUser->id);
171
 
172
            $queryMapper = QueryMapper::getInstance($this->adapter);
173
 
174
            $prototype = new MyCoachQuestion();
175
            $selectIn = $queryMapper->getSql()->select(MyCoachQuestionCategoryMapper::_TABLE);
176
            $selectIn->columns(['question_id' => new Expression('DISTINCT(id)')]);
177
            $selectIn->where->in('category_id', $category_ids);
178
 
179
 
180
 
181
            $select = $queryMapper->getSql()->select(MyCoachQuestionMapper::_TABLE);
182
            $select->where->in('id', $selectIn);
183
 
184
            if($search) {
185
                $select->where->nest()
186
                -> like('title', '%' . $search . '%')->or->like('description', '%' . $search . '%')
187
                ->unnest();
188
            }
189
            $select->order($order_field . ' ' . $order_direction);
190
 
191
            //echo $select->getSqlString($this->adapter->platform);
192
            //exit;
193
 
194
 
195
            $users = [];
196
            $categories = [];
197
            //echo $select->getSqlString($this->adapter->platform); exit;
198
 
199
            $hydrator   = new ObjectPropertyHydrator();
200
            $resultset  = new HydratingResultSet($hydrator, $prototype);
201
 
202
            $adapter = new DbSelect($select, $queryMapper->getSql(), $resultset);
203
            $paginator = new Paginator($adapter);
204
            $paginator->setItemCountPerPage($records_x_page);
205
            $paginator->setCurrentPageNumber($page);
206
 
207
 
208
            $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
209
            $commentMapper = CommentMapper::getInstance($this->adapter);
210
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
211
            $myCoachQuestionViewMapper = MyCoachQuestionViewMapper::getInstance($this->adapter);
212
 
213
            $items = [];
214
            $records = $paginator->getCurrentItems();
215
            foreach ($records as $record)
216
            {
217
                $bags_categories = [];
218
 
219
                $questionCategories = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($record->id);
6388 efrain 220
 
6521 efrain 221
 
222
 
223
 
224
                $allowEdit   = $myCoachAccessControl->hasAccessEditQuestion($currentUser->id, $record->id, $currentNetwork->id, $message_error);
225
                $allowDelete = $myCoachAccessControl->hasAccessDeleteQuestion($currentUser->id, $record->id, $currentNetwork->id, $message_error);
226
                foreach($questionCategories as $questionCategory)
227
                {
228
                    if(in_array($questionCategory->category_id, $category_ids_with_edition)) {
229
 
230
                        $allowDelete = true;
231
                    }
232
 
233
                    if (!isset($categories[$questionCategory->category_id])) {
234
                        $category = $myCoachCategoryMapper->fetchOne($questionCategory->category_id);
235
                        if ($category) {
236
                            $categories[$category->id] = $category->name;
237
 
6388 efrain 238
                        }
239
                    }
6521 efrain 240
 
241
                    array_push($bags_categories,['category' => $categories[ $questionCategory->category_id ] ]);
6388 efrain 242
                }
6521 efrain 243
 
244
                if(isset($users[$record->user_id])) {
245
                    $user = $users[ $record->user_id ];
246
                } else {
247
                    $user = $userMapper->fetchOne($record->user_id);
248
                    $users[ $record->user_id ] = $user;
249
                }
250
 
251
 
252
                $description = strip_tags($record->description);
253
                if (strlen($description) > 250) {
254
                    $description = substr($description, 0, 250) . '...';
255
                }
256
 
257
 
258
                $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->added_on);
259
                $added_on = $dt->format('d/m/Y H:i a');
260
 
261
                $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->updated_on);
262
                $updated_on = $dt->format('d/m/Y H:i a');
263
 
264
                $item = [
265
                    'uuid' => $record->uuid,
266
                    'user_name' => trim($user->first_name . ' ' . $user->last_name),
267
                    'user_image' => $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]),
268
                    'title' => $record->title,
269
                    'description' => $description,
270
                    'categories' => $bags_categories,
271
                    'views' => intval($myCoachQuestionViewMapper->fetchCountByQuestionId($record->id), 10),
272
                    'answers' =>  intval($myCoachAnswerMapper->fetchCountByMyCoachQuestionId($record->id), 10),
273
                    'reactions' => intval($contentReactionMapper->fetchCountByMyCoachQuestionId($record->id), 10),
274
                    'comments' =>  intval($commentMapper->fetchCountByMyCoachQuestionId($record->id), 10),
275
                    'added_on' => $added_on,
276
                    'updated_on' => $updated_on,
277
                    'link_add_comment' => $this->url()->fromRoute('my-coach/questions/comments/add', ['id' => $record->uuid]),
278
                    'link_view' => $this->url()->fromRoute('my-coach/questions/view', ['id' => $record->uuid]),
279
                    'link_edit' => $allowEdit ?  $this->url()->fromRoute('my-coach/questions/edit', ['id' => $record->uuid]) : '',
280
                    'link_delete' => $allowDelete ? $this->url()->fromRoute('my-coach/questions/delete', ['id' =>  $record->uuid]) : '',
281
                ];
282
 
283
                array_push($items, $item);
284
            }
285
 
286
            return new JsonModel([
287
                'success' => true,
288
                'data' => [
289
                    'items' => $items,
290
                    'total' => $paginator->getTotalItemCount(),
291
                    'page' => $paginator->getCurrentPageNumber(),
292
                    'total_pages' => $paginator->getPageRange()
293
                ]
294
            ]);
295
 
296
 
297
        } else {
298
            return new JsonModel([
299
                'success' => false,
300
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
301
            ]);
302
        }
303
    }
304
 
305
    public function addQuestionAction()
306
    {
307
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
308
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
309
 
310
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
311
        $currentUser        = $currentUserPlugin->getUser();
312
 
313
        $request            = $this->getRequest();
314
 
315
        if ($request->isPost()) {
316
 
317
            $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
318
 
319
 
320
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
321
            $categories = $myCoachAccessControl->getCategoriesWithAccessToFormSelect($currentUser->id, $currentNetwork->id);
322
 
323
            $form = new MyCoachQuestionForm($categories);
324
            $form->setData($dataPost);
325
 
326
            if ($form->isValid()) {
327
                $dataPost = (array) $form->getData();
328
 
329
                $myCoachQuestion = new MyCoachQuestion();
330
                $myCoachQuestion->network_id    = $currentNetwork ->id;
331
                $myCoachQuestion->user_id       = $currentUser->id;
332
                $myCoachQuestion->title         = $dataPost['title'];
333
                $myCoachQuestion->description   = $dataPost['description'];
334
 
335
 
336
                $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
337
                if ($myCoachQuestionMapper->insert($myCoachQuestion)) {
338
                    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
339
                    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
340
 
341
                    $category_ids = $dataPost['category_id'];
342
                    foreach($category_ids as $category_id)
343
                    {
344
                        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_id);
345
                        if($myCoachCategory) {
346
                            $myCoachQuestionCategory = new MyCoachQuestionCategory();
347
                            $myCoachQuestionCategory->category_id = $myCoachCategory->id;
348
                            $myCoachQuestionCategory->question_id = $myCoachQuestion->id;
349
 
350
                            $myCoachQuestionCategoryMapper->insert($myCoachQuestionCategory);
351
                        }
352
                    }
353
 
354
 
355
                    $this->logger->info('Se agrego la pregunta ' . $myCoachQuestion->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
356
 
357
                    $data = [
358
                        'success'   => true,
359
                        'data'   => 'LABEL_RECORD_ADDED'
360
                    ];
361
                } else {
362
                    $data = [
363
                        'success'   => false,
364
                        'data'      => $myCoachQuestionMapper->getError()
365
                    ];
366
                }
367
 
368
                return new JsonModel($data);
369
            } else {
370
                $messages = [];
371
                $form_messages = (array) $form->getMessages();
372
                foreach ($form_messages  as $fieldname => $field_messages)
373
                {
374
                    $messages[$fieldname] = array_values($field_messages);
375
                }
376
 
377
                return new JsonModel([
378
                    'success'   => false,
379
                    'data'   => $messages
380
                ]);
381
            }
382
        } else {
383
            $data = [
384
                'success' => false,
385
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
386
            ];
387
 
388
            return new JsonModel($data);
389
        }
390
 
391
        return new JsonModel($data);
392
    }
393
 
394
 
395
 
396
    public function deleteQuestionAction()
397
    {
398
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
399
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
400
 
401
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
402
        $currentUser        = $currentUserPlugin->getUser();
403
 
404
        $request    = $this->getRequest();
405
        $id         = $this->params()->fromRoute('id');
406
 
407
        $message_error = '';
408
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
409
        if(!$myCoachAccessControl->hasAccessDeleteQuestion($currentUser->id, $id, $currentNetwork->id, $message_error)) {
410
            return new JsonModel([
411
                'success'   => false,
412
                'data'   => $message_error
413
            ]);
414
        }
415
 
416
 
417
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
418
        $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
6388 efrain 419
 
6521 efrain 420
 
421
        if ($request->isPost()) {
422
 
423
            $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
424
            $myCoachQuestionCategoryMapper->deleteAllByQuestionId($myCoachQuestion->id);
425
 
426
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
427
            $myCoachAnswerMapper->deleteAllByQuestionId($myCoachQuestion->id);
428
 
429
            $result =  $myCoachQuestionMapper->delete($myCoachQuestion);
430
            if ($result) {
431
                $data = [
432
                    'success' => true,
433
                    'data' => 'LABEL_RECORD_DELETED'
434
                ];
435
            } else {
436
 
437
                $data = [
438
                    'success'   => false,
439
                    'data'      => $myCoachQuestionMapper->getError()
440
                ];
441
 
442
                return new JsonModel($data);
443
            }
444
        } else {
445
            $data = [
446
                'success' => false,
447
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
448
            ];
449
 
450
            return new JsonModel($data);
451
        }
452
 
453
        return new JsonModel($data);
454
    }
455
 
456
 
457
    public function editQuestionAction()
458
    {
459
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
460
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
461
 
462
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
463
        $currentUser        = $currentUserPlugin->getUser();
464
 
465
        $request    = $this->getRequest();
466
        $id    = $this->params()->fromRoute('id');
467
 
468
        $message_error = '';
469
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
470
        if(!$myCoachAccessControl->hasAccessEditQuestion($currentUser->id, $id, $currentNetwork->id, $message_error)) {
471
            return new JsonModel([
472
                'success'   => false,
473
                'data'   => $message_error
474
            ]);
475
        }
476
 
477
 
478
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
479
        $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
480
 
481
 
482
        if ($request->isGet()) {
483
 
484
            $category_ids = [];
485
            $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
486
 
487
            $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
488
            $records = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
489
            foreach($records as $record)
490
            {
491
                $myCoachCategory = $myCoachCategoryMapper->fetchOne($record->category_id);
492
                if($myCoachCategory) {
493
                    array_push($category_ids,$myCoachCategory->uuid);
494
                }
495
            }
496
 
497
 
498
 
499
            $data = [
500
                'success' => true,
501
                'data' => [
502
                    'category_id' => $category_ids,
503
                    'title' => $myCoachQuestion->title,
504
                    'description' => $myCoachQuestion->description,
505
                ]
506
            ];
507
 
508
            return new JsonModel($data);
509
        } else if ($request->isPost()) {
510
 
511
            $categories = $myCoachAccessControl->getCategoriesWithAccessToFormSelect($myCoachQuestion->user_id, $currentNetwork->id);
512
            $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
513
 
514
            $form = new MyCoachQuestionForm($categories);
515
            $form->setData($dataPost);
516
 
517
            if ($form->isValid()) {
518
                $dataPost = (array) $form->getData();
519
 
520
 
521
 
522
                $myCoachQuestion->title = $dataPost['title'];
523
                $myCoachQuestion->description = $dataPost['description'];
524
 
525
 
526
                if ($myCoachQuestionMapper->update($myCoachQuestion)) {
527
 
528
 
529
                    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
530
 
531
                    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
532
                    $myCoachQuestionCategoryMapper->deleteAllByQuestionId($myCoachQuestion->id);
533
 
534
                    $category_ids = $dataPost['category_id'];
535
                    foreach($category_ids as $category_id)
536
                    {
537
                        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_id);
538
                        if($myCoachCategory) {
539
                            $myCoachQuestionCategory = new MyCoachQuestionCategory();
540
                            $myCoachQuestionCategory->category_id = $myCoachCategory->id;
541
                            $myCoachQuestionCategory->question_id = $myCoachQuestion->id;
542
 
543
                            $myCoachQuestionCategoryMapper->insert($myCoachQuestionCategory);
6388 efrain 544
                        }
545
                    }
6521 efrain 546
 
547
 
548
                    $this->logger->info('Se edito la pregunta ' . $myCoachQuestion->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
549
 
550
                    $data = [
551
                        'success'   => true,
552
                        'data'   => 'LABEL_RECORD_UPDATED'
553
                    ];
554
                } else {
555
                    $data = [
556
                        'success'   => false,
557
                        'data'      => $myCoachQuestionMapper->getError()
558
                    ];
6388 efrain 559
                }
6521 efrain 560
 
561
                return new JsonModel($data);
562
            } else {
563
                $messages = [];
564
                $form_messages = (array) $form->getMessages();
565
                foreach ($form_messages  as $fieldname => $field_messages) {
566
 
567
                    $messages[$fieldname] = array_values($field_messages);
568
                }
569
 
570
                return new JsonModel([
571
                    'success'   => false,
572
                    'data'   => $messages
573
                ]);
574
            }
575
        } else {
576
            $data = [
577
                'success' => false,
578
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
579
            ];
580
 
581
            return new JsonModel($data);
582
        }
583
 
584
        return new JsonModel($data);
585
    }
586
 
587
 
588
    public function viewQuestionAction()
589
    {
590
        $currentUserPlugin = $this->plugin('currentUserPlugin');
591
        $currentUser = $currentUserPlugin->getUser();
592
 
593
        $currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
594
        $currentNetwork = $currentNetworkPlugin->getNetwork();
595
 
596
        $request    = $this->getRequest();
597
        $id    = $this->params()->fromRoute('id');
598
 
599
        $message_error = '';
600
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
601
        if(!$myCoachAccessControl->hasAccessViewQuestion($currentUser->id, $id, $currentNetwork->id, $message_error)) {
602
            return new JsonModel([
603
                'success'   => false,
604
                'data'   => $message_error
605
            ]);
606
        }
607
 
608
 
609
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
610
        $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
611
 
612
        $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
613
        $commentMapper = CommentMapper::getInstance($this->adapter);
614
        $myCoachQuestionViewMapper = MyCoachQuestionViewMapper::getInstance($this->adapter);
615
        $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
616
 
617
 
618
        $request = $this->getRequest();
619
        if ($request->isGet()) {
620
 
621
            $categories = [];
622
            $users = [];
623
 
624
 
625
 
626
            $bags_categories = [];
627
 
628
            $myCoachQuestionViewMapper = MyCoachQuestionViewMapper::getInstance($this->adapter);
629
            $myCoachQuestionView = $myCoachQuestionViewMapper->fetchOneByQuestionIdAndUserId($myCoachQuestion->id, $currentUser->id);
630
            if(!$myCoachQuestionView) {
631
                $myCoachQuestionView = new MyCoachQuestionView();
632
                $myCoachQuestionView->question_id = $myCoachQuestion->id;
633
                $myCoachQuestionView->user_id = $currentUser->id;
634
 
635
                $myCoachQuestionViewMapper->insert($myCoachQuestionView);
636
 
637
            }
638
 
639
 
640
 
641
            $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
642
            $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
643
 
644
            $questionCategories = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
645
            foreach($questionCategories as $questionCategory)
646
            {
647
 
648
                if (!isset($categories[$questionCategory->category_id])) {
649
                    $category = $myCoachCategoryMapper->fetchOne($questionCategory->category_id);
650
                    if ($category) {
651
                        $categories[$category->id] = $category->name;
652
                    }
653
                }
654
 
655
                array_push($bags_categories,['category' => $categories[ $questionCategory->category_id ] ]);
656
            }
657
 
658
            $users = [];
659
            $userMapper = UserMapper::getInstance($this->adapter);
660
            if(isset($users[$myCoachQuestion->user_id])) {
661
                $user = $users[$myCoachQuestion->user_id];
662
            } else {
663
                $user = $userMapper->fetchOne( $myCoachQuestion->user_id );
664
                $users[ $myCoachQuestion->user_id ] = $user;
665
            }
666
 
667
 
668
 
669
            $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $myCoachQuestion->added_on);
670
            $added_on = $dt->format('d/m/Y H:i a');
671
 
672
            $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $myCoachQuestion->updated_on);
673
            $updated_on = $dt->format('d/m/Y H:i a');
674
 
675
 
676
 
677
            $allowDelete = $myCoachAccessControl->hasAccessDeleteQuestion($currentUser->id, $myCoachQuestion->id, $currentNetwork->id, $message_error);
678
            if($allowDelete) {
679
                $link_delete = $this->url()->fromRoute('my-coach/questions/delete', ['id' => $myCoachQuestion->uuid]);
680
            } else {
681
                $link_delete = '';
682
            }
683
 
684
            $allowAnswerAdd = $myCoachAccessControl->hasAccessAnswerQuestion($currentUser->id, $myCoachQuestion->id, $currentNetwork->id, $message_error);
685
            if ($allowAnswerAdd) {
686
                $link_answers_add = $this->url()->fromRoute('my-coach/questions/answers/add', ['id' => $myCoachQuestion->uuid]);
687
            } else {
688
                $link_answers_add = '';
689
            }
6547 efrain 690
 
6521 efrain 691
 
6388 efrain 692
 
6521 efrain 693
            $myCoachLastAnswer = $myCoachAnswerMapper->fetchOneLastAnswerByQuestionId($myCoachQuestion->id);
694
 
695
            if( $myCoachLastAnswer) {
696
                $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $myCoachLastAnswer->added_on);
697
                $last_answer_on = $dt->format('d/m/Y H:i a');
698
 
699
 
700
 
701
            } else {
702
                $last_answer_on = '';
703
            }
704
 
6388 efrain 705
 
6521 efrain 706
            return new JsonModel([
707
                'success' => true,
708
                'data' => [
709
                    'uuid' => $myCoachQuestion->uuid,
710
                    'user_name' => trim($user->first_name . ' ' . $user->last_name),
711
                    'user_image' => $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]),
712
                    'title' => $myCoachQuestion->title,
713
                    'description' => $myCoachQuestion->description,
714
                    'categories' => $bags_categories,
715
                    'views' => intval($myCoachQuestionViewMapper->fetchCountByQuestionId($myCoachQuestion->id) , 10),
6547 efrain 716
                    'answers' => intval($myCoachAnswerMapper->fetchCountByMyCoachQuestionId($myCoachQuestion->id) , 10),
6521 efrain 717
                    'reactions' => intval($contentReactionMapper->fetchCountByMyCoachQuestionId($myCoachQuestion->id), 10),
718
                    'comments' => intval($commentMapper->fetchCountByMyCoachQuestionId($myCoachQuestion->id), 10),
719
                    'added_on' => $added_on,
720
                    'updated_on' => $updated_on,
721
                    'last_answer_on' => $last_answer_on,
722
                    'link_answers' => $this->url()->fromRoute('my-coach/questions/answers', ['id' => $myCoachQuestion->uuid]),
723
                    'link_answers_add' => $link_answers_add,
724
                    'link_delete' => $link_delete,
725
                ]
726
 
727
            ]);
728
 
729
 
730
        } else {
731
            return new JsonModel([
732
                'success' => false,
733
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
734
            ]);
735
        }
736
 
737
 
738
 
739
 
740
 
741
    }
742
 
743
    /**
744
     *
745
     * {@inheritDoc}
746
     * @see \Laminas\Mvc\Controller\AbstractActionController::indexAction()
747
     */
748
    public function answersAction()
749
    {
750
        $currentUserPlugin = $this->plugin('currentUserPlugin');
751
        $currentUser = $currentUserPlugin->getUser();
752
 
753
        $currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
754
        $currentNetwork = $currentNetworkPlugin->getNetwork();
755
 
756
        $request    = $this->getRequest();
757
        $id    = $this->params()->fromRoute('id');
758
 
759
        $message_error = '';
760
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
761
        if(!$myCoachAccessControl->hasAccessViewQuestion($currentUser->id, $id, $currentNetwork->id, $message_error)) {
762
            return new JsonModel([
763
                'success'   => false,
764
                'data'   => $message_error
765
            ]);
766
        }
767
 
768
 
769
 
770
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
771
        $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
772
 
773
        $request = $this->getRequest();
774
        if ($request->isGet()) {
775
 
776
 
777
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
778
            $now = $myCoachAnswerMapper->getDatebaseNow();
779
 
780
            $records = $myCoachAnswerMapper->fetchAllByQuestionId($myCoachQuestion->id);
781
 
782
 
783
            $items = [];
784
 
785
            foreach($records as $record)
786
            {
787
                $items[] = $this->renderAnswer($record->id, $currentUser->id, $now);
788
            }
789
 
790
 
791
 
792
            return new JsonModel([
793
                'success' => true,
794
                'data' => [
795
                    'items' => $items
796
                ]
797
            ]);
798
 
799
 
800
        } else {
801
            return new JsonModel([
802
                'success' => false,
803
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
804
            ]);
805
        }
806
    }
807
 
6547 efrain 808
    public function deleteAnswerAction()
809
    {
810
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
811
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
812
 
813
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
814
        $currentUser        = $currentUserPlugin->getUser();
815
 
816
        $request    = $this->getRequest();
817
        $answer     = $this->params()->fromRoute('answer');
818
 
819
        $message_error = '';
820
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
821
        if(!$myCoachAccessControl->hasAccessEditOrDeleteAnswer($currentUser->id, $answer, $currentNetwork->id, $message_error)) {
822
            return new JsonModel([
823
                'success'   => false,
824
                'data'   => $message_error
825
            ]);
826
        }
827
 
828
 
829
        $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
830
        $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($answer);
831
 
832
        if ($request->isPost()) {
833
 
834
            if($myCoachAnswerMapper->delete($myCoachAnswer)) {
835
 
836
                $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
837
                $commentMapper = CommentMapper::getInstance($this->adapter);
838
 
839
 
840
                $this->logger->info('Se borro la respuesta ' . $myCoachAnswer->text, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
841
 
842
                $data = [
843
                    'success'   => true,
844
                    'data'   => [
845
                        'total_comments' => intval($commentMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10),
846
                        'total_answers' => intval($myCoachAnswerMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10),
847
                        'total_reactions' => intval($contentReactionMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10)
848
 
849
                    ]
850
                ];
851
            } else {
852
                $data = [
853
                    'success'   => false,
854
                    'data'      => $myCoachAnswerMapper->getError()
855
                ];
856
            }
857
        } else {
858
            $data = [
859
                'success' => false,
860
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
861
            ];
862
 
863
 
864
        }
865
        return new JsonModel($data);
866
 
867
 
868
    }
869
 
870
 
871
    public function editAnswerAction()
872
    {
873
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
874
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
875
 
876
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
877
        $currentUser        = $currentUserPlugin->getUser();
878
 
879
        $request    = $this->getRequest();
880
        $answer     = $this->params()->fromRoute('answer');
881
 
882
        $message_error = '';
883
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
884
        if(!$myCoachAccessControl->hasAccessEditOrDeleteAnswer($currentUser->id, $answer, $currentNetwork->id, $message_error)) {
885
            return new JsonModel([
886
                'success'   => false,
887
                'data'   => $message_error
888
            ]);
889
        }
890
 
891
 
892
        $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
893
        $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($answer);
894
 
895
        if ($request->isPost()) {
896
 
897
            $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
898
            $form = new MyCoachAnswerForm();
899
            $form->setData($dataPost);
900
 
901
            if ($form->isValid()) {
902
                $myCoachAnswer->text        = $dataPost['description'];
6388 efrain 903
 
6547 efrain 904
                if($myCoachAnswerMapper->update($myCoachAnswer)) {
905
 
906
                    $this->logger->info('Se edito la respuesta ' . $myCoachAnswer->text, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
907
 
908
                    $data = [
909
                        'success'   => true,
910
                        'data'   => [
911
                            'description' => $myCoachAnswer->text
912
                        ]
913
                    ];
914
                } else {
915
                    $data = [
916
                        'success'   => false,
917
                        'data'      => $myCoachAnswerMapper->getError()
918
                    ];
919
                }
920
 
921
                return new JsonModel($data);
922
            } else {
923
                $messages = [];
924
                $form_messages = (array) $form->getMessages();
925
                foreach ($form_messages  as $fieldname => $field_messages)
926
                {
927
                    $messages[$fieldname] = array_values($field_messages);
928
                }
929
 
930
                return new JsonModel([
931
                    'success'   => false,
932
                    'data'   => $messages
933
                ]);
934
            }
935
        } else  if ($request->isGet()) {
936
            return new JsonModel([
937
                'success'   => true,
938
                'data'   => [
939
                    'description' => $myCoachAnswer->text
940
                ]
941
            ]);
942
        } else {
943
            $data = [
944
                'success' => false,
945
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
946
            ];
947
 
948
            return new JsonModel($data);
949
        }
950
 
951
 
952
    }
953
 
6521 efrain 954
 
955
 
6547 efrain 956
 
957
 
6521 efrain 958
    public function addAnswerAction()
959
    {
960
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
961
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
962
 
963
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
964
        $currentUser        = $currentUserPlugin->getUser();
965
 
966
        $request    = $this->getRequest();
967
        $id    = $this->params()->fromRoute('id');
968
 
969
        $message_error = '';
970
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
971
        if(!$myCoachAccessControl->hasAccessAnswerQuestion($currentUser->id, $id, $currentNetwork->id, $message_error)) {
972
            return new JsonModel([
973
                'success'   => false,
974
                'data'   => $message_error
975
            ]);
976
        }
977
 
978
 
979
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
980
        $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
981
 
982
        if ($request->isPost()) {
983
 
984
            $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
985
            $form = new MyCoachAnswerForm();
986
            $form->setData($dataPost);
987
 
988
            if ($form->isValid()) {
6388 efrain 989
 
6521 efrain 990
                $myCoachAnswer = new MyCoachAnswer();
991
                $myCoachAnswer->question_id = $myCoachQuestion->id;
992
                $myCoachAnswer->text        = $dataPost['description'];
993
                $myCoachAnswer->user_id     = $currentUser->id;
994
 
995
 
996
                $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
997
                if($myCoachAnswerMapper->insert($myCoachAnswer)) {
998
                    $now = $myCoachAnswerMapper->getDatebaseNow();
999
 
1000
                    $this->logger->info('Se agrego la respuesta ' . $myCoachAnswer->text, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1001
 
1002
                    $data = [
1003
                        'success'   => true,
1004
                        'data'   => [
1005
                            'answers' => $myCoachAnswerMapper->fetchCountByMyCoachQuestionId($myCoachQuestion->id),
1006
                            'item' => $this->renderAnswer($myCoachAnswer->id, $currentUser->id, $now)
1007
                        ]
1008
                    ];
1009
                } else {
1010
                    $data = [
1011
                        'success'   => false,
1012
                        'data'      => $myCoachQuestionMapper->getError()
1013
                    ];
1014
                }
1015
 
1016
                return new JsonModel($data);
1017
            } else {
1018
                $messages = [];
1019
                $form_messages = (array) $form->getMessages();
1020
                foreach ($form_messages  as $fieldname => $field_messages)
6388 efrain 1021
                {
6521 efrain 1022
                    $messages[$fieldname] = array_values($field_messages);
1023
                }
6388 efrain 1024
 
6521 efrain 1025
                return new JsonModel([
1026
                    'success'   => false,
1027
                    'data'   => $messages
1028
                ]);
1029
            }
1030
 
1031
        } else {
1032
            $data = [
1033
                'success' => false,
1034
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
1035
            ];
1036
 
1037
            return new JsonModel($data);
1038
        }
1039
 
1040
 
1041
    }
1042
 
1043
    /*
1044
 
1045
    public function deleteAction()
1046
    {
1047
    $currentUserPlugin = $this->plugin('currentUserPlugin');
1048
    $currentUser    = $currentUserPlugin->getUser();
1049
 
1050
 
1051
    $request    = $this->getRequest();
1052
    $id         = $this->params()->fromRoute('id');
1053
 
1054
 
1055
 
1056
    $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
1057
    $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
1058
    if (!$myCoachQuestion) {
1059
    return new JsonModel([
1060
    'success'   => false,
1061
    'data'   => 'ERROR_RECORD_NOT_FOUND'
1062
    ]);
1063
    }
1064
 
1065
    $ok = false;
1066
    if(!$myCoachQuestion->answers) {
1067
 
1068
    if($currentUser->id == $myCoachQuestion->user_id) {
1069
    $ok = true;
1070
    } else {
1071
    $category_ids_with_edition = [];
1072
 
1073
    $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
1074
    $records = $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchAllByUserId($currentUser->id);
1075
 
1076
    foreach($records as $record)
1077
    {
1078
    array_push($category_ids_with_edition, $record->user_id);
1079
    }
1080
 
1081
 
1082
 
1083
    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
1084
    $records = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
1085
    foreach($records as $record)
1086
    {
1087
    if (in_array($record->category_id, $category_ids_with_edition) && $myCoachCategoryUser->role == MyCoachCategoryUser::ROLE_EDITOR || $myCoachCategoryUser->role == MyCoachCategoryUser::ROLE_ADMINISTRATOR) {
1088
    $ok = true;
1089
    break;
1090
    }
1091
    }
1092
    }
1093
    }
1094
 
1095
 
1096
    if (!$ok) {
1097
    return new JsonModel([
1098
    'success'   => false,
1099
    'data'   => 'ERROR_KNOWLEDGE_AREA_YOU_DO_NOT_HAVE_PERMISSION'
1100
    ]);
1101
    }
1102
 
1103
    if ($request->isPost()) {
1104
 
1105
    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
1106
    $myCoachQuestionCategoryMapper->deleteAllByQuestionId($myCoachQuestion->id);
1107
 
1108
    $result =  $myCoachQuestionMapper->delete($myCoachQuestion);
1109
    if ($result) {
1110
    $data = [
1111
    'success' => true,
1112
    'data' => 'LABEL_RECORD_DELETED'
1113
    ];
1114
    } else {
1115
 
1116
    $data = [
1117
    'success'   => false,
1118
    'data'      => $myCoachQuestionMapper->getError()
1119
    ];
1120
 
1121
    return new JsonModel($data);
1122
    }
1123
    } else {
1124
    $data = [
1125
    'success' => false,
1126
    'data' => 'ERROR_METHOD_NOT_ALLOWED'
1127
    ];
1128
 
1129
    return new JsonModel($data);
1130
    }
1131
 
1132
    return new JsonModel($data);
1133
    }
1134
 
1135
 
1136
    public function editAction()
1137
    {
1138
    $currentUserPlugin = $this->plugin('currentUserPlugin');
1139
    $currentUser    = $currentUserPlugin->getUser();
1140
 
1141
    $request    = $this->getRequest();
1142
    $id    = $this->params()->fromRoute('id');
1143
 
1144
    $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
1145
    $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
1146
    if (!$myCoachQuestion) {
1147
    return new JsonModel([
1148
    'success'   => false,
1149
    'data'   => 'ERROR_RECORD_NOT_FOUND'
1150
    ]);
1151
    }
1152
 
1153
    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
1154
 
1155
    $ok = false;
1156
    if(!$myCoachQuestion->answers) {
1157
 
1158
    if($currentUser->id == $myCoachQuestion->user_id) {
1159
    $ok = true;
1160
    } else {
1161
    $category_ids_with_edition = [];
1162
 
1163
    $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
1164
    $records = $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchAllByUserId($currentUser->id);
1165
 
1166
    foreach($records as $record)
1167
    {
1168
    array_push($category_ids_with_edition, $record->user_id);
1169
    }
1170
 
1171
 
1172
    $records = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
1173
    foreach($records as $record)
1174
    {
1175
    if (in_array($record->category_id, $category_ids_with_edition) && $myCoachCategoryUser->role == MyCoachCategoryUser::ROLE_EDITOR || $myCoachCategoryUser->role == MyCoachCategoryUser::ROLE_ADMINISTRATOR) {
1176
    $ok = true;
1177
    break;
1178
    }
1179
    }
1180
    }
1181
    }
1182
 
1183
 
1184
    if (!$ok) {
1185
    return new JsonModel([
1186
    'success'   => false,
1187
    'data'   => 'ERROR_KNOWLEDGE_AREA_YOU_DO_NOT_HAVE_PERMISSION'
1188
    ]);
1189
    }
1190
 
1191
    if (!$ok) {
1192
    return new JsonModel([
1193
    'success'   => false,
1194
    'data'   => 'ERROR_KNOWLEDGE_AREA_YOU_DO_NOT_HAVE_PERMISSION'
1195
    ]);
1196
    }
1197
 
1198
    if ($request->isGet()) {
1199
 
1200
 
1201
    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
1202
 
1203
 
1204
 
1205
    $category_ids = [];
1206
 
1207
 
1208
 
1209
    $records = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
1210
    foreach($records as $record)
1211
    {
1212
    $myCoachCategory = $myCoachCategoryMapper->fetchOne($record->category_id);
1213
    if($myCoachCategory) {
1214
    array_push($category_ids,$myCoachCategory->uuid);
1215
    }
1216
    }
1217
 
1218
 
1219
 
1220
    $data = [
1221
    'success' => true,
1222
    'data' => [
1223
    'category_id' => $category_ids,
1224
    'title' => $myCoachQuestion->title,
1225
    'description' => $myCoachQuestion->description,
1226
    ]
1227
    ];
1228
 
1229
    return new JsonModel($data);
1230
    } else if ($request->isPost()) {
1231
    $category_with_edition_ids = [];
1232
    $category_ids = [];
1233
 
1234
 
1235
    $categories = [];
1236
 
1237
 
1238
    $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
1239
    $records =  $myCoachCategoryUserMapper->fetchAllByUserId($currentUser->id);
1240
    foreach ($records as $record) {
1241
    if ($record->role == MyCoachCategoryUser::ROLE_ADMINISTRATOR || $record->role == MyCoachCategoryUser::ROLE_USER) {
1242
 
1243
    array_push($category_with_edition_ids, $record->category_id);
1244
    }
1245
 
1246
    array_push($category_ids, $record->category_id);
1247
    }
1248
 
1249
    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
1250
 
1251
    if ($category_ids) {
1252
    $records =  $myCoachCategoryMapper->fetchAllByIds($category_ids);
1253
    foreach ($records as $record) {
1254
    if ($record->status == MyCoachCategory::STATUS_ACTIVE) {
1255
 
1256
    $categories[$record->id] = [
1257
    'uuid' => $record->uuid,
1258
    'name' => $record->name,
1259
    ];
1260
    }
1261
    }
1262
    }
1263
 
1264
 
1265
 
1266
    $categories = array_values($categories);
1267
    usort($categories, function ($a, $b) {
1268
    return $a['name'] <=> $b['name'];
1269
    });
1270
 
1271
    $categories_question_available = [];
1272
    foreach($categories as $cartegory)
1273
    {
1274
    $categories_question_available[ $cartegory['uuid'] ] = $cartegory['name'];
1275
    }
1276
 
1277
    $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
1278
    $form = new MyCoachQuestionForm($categories_question_available);
1279
    $form->setData($dataPost);
1280
 
1281
    if ($form->isValid()) {
1282
    $dataPost = (array) $form->getData();
1283
 
1284
 
1285
 
1286
    $myCoachQuestion->title = $dataPost['title'];
1287
    $myCoachQuestion->description = $dataPost['description'];
1288
 
1289
 
1290
    if ($myCoachQuestionMapper->update($myCoachQuestion)) {
1291
 
1292
 
1293
    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
1294
 
1295
    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
1296
    $myCoachQuestionCategoryMapper->deleteAllByQuestionId($myCoachQuestion->id);
1297
 
1298
    $category_ids = $dataPost['category_id'];
1299
    foreach($category_ids as $category_id)
1300
    {
1301
    $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_id);
1302
    if($myCoachCategory) {
1303
    $myCoachQuestionCategory = new MyCoachQuestionCategory();
1304
    $myCoachQuestionCategory->category_id = $myCoachCategory->id;
1305
    $myCoachQuestionCategory->question_id = $myCoachQuestion->id;
1306
 
1307
    $myCoachQuestionCategoryMapper->insert($myCoachQuestionCategory);
1308
    }
1309
    }
1310
 
1311
 
1312
    $this->logger->info('Se edito la pregunta ' . $myCoachQuestion->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1313
 
1314
    $data = [
1315
    'success'   => true,
1316
    'data'   => 'LABEL_RECORD_UPDATED'
1317
    ];
1318
    } else {
1319
    $data = [
1320
    'success'   => false,
1321
    'data'      => $myCoachQuestionMapper->getError()
1322
    ];
1323
    }
1324
 
1325
    return new JsonModel($data);
1326
    } else {
1327
    $messages = [];
1328
    $form_messages = (array) $form->getMessages();
1329
    foreach ($form_messages  as $fieldname => $field_messages) {
1330
 
1331
    $messages[$fieldname] = array_values($field_messages);
1332
    }
1333
 
1334
    return new JsonModel([
1335
    'success'   => false,
1336
    'data'   => $messages
1337
    ]);
1338
    }
1339
    } else {
1340
    $data = [
1341
    'success' => false,
1342
    'data' => 'ERROR_METHOD_NOT_ALLOWED'
1343
    ];
1344
 
1345
    return new JsonModel($data);
1346
    }
1347
 
1348
    return new JsonModel($data);
1349
    }
1350
 
1351
 
1352
    public function viewAction()
1353
    {
1354
    $currentUserPlugin = $this->plugin('currentUserPlugin');
1355
    $currentUser = $currentUserPlugin->getUser();
1356
 
1357
    $currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
1358
    $currentNetwork = $currentNetworkPlugin->getNetwork();
1359
 
1360
    $request    = $this->getRequest();
1361
    $id    = $this->params()->fromRoute('id');
1362
 
1363
    $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
1364
    $myCoachQuestion = $myCoachQuestionMapper->fetchOneByUuid($id);
1365
    if (!$myCoachQuestion) {
1366
    return new JsonModel([
1367
    'success'   => false,
1368
    'data'   => 'ERROR_RECORD_NOT_FOUND'
1369
    ]);
1370
    }
1371
 
1372
 
1373
    $request = $this->getRequest();
1374
    if ($request->isGet()) {
1375
 
1376
 
1377
 
1378
    $category_with_edition_ids = [];
1379
    $category_ids = [];
1380
    $categories = [];
1381
 
1382
 
1383
    $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
1384
    $records =  $myCoachCategoryUserMapper->fetchAllByUserId($currentUser->id);
1385
    foreach ($records as $record) {
1386
    if ($record->role == MyCoachCategoryUser::ROLE_ADMINISTRATOR || $record->role == MyCoachCategoryUser::ROLE_USER) {
1387
 
1388
    array_push($category_with_edition_ids, $record->category_id);
1389
    }
1390
 
1391
    array_push($category_ids, $record->category_id);
1392
    }
1393
 
1394
    $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
1395
 
1396
 
1397
 
1398
    if ($category_ids) {
1399
    $records =  $myCoachCategoryMapper->fetchAllByIds($category_ids);
1400
    foreach ($records as $record) {
1401
    $categories[$record->id] = [
1402
    'uuid' => $record->uuid,
1403
    'name' => $record->name,
1404
    ];
1405
    }
1406
    }
1407
 
1408
    $records =  $myCoachCategoryMapper->fetchAllPublicByNetworkId($currentNetwork->id);
1409
    foreach ($records as $record) {
1410
    if (!isset($categories[$record->id])) {
1411
 
1412
    $categories[$record->id] = [
1413
    'uuid' => $record->uuid,
1414
    'name' => $record->name,
1415
    ];
1416
    }
1417
    }
1418
 
1419
 
1420
 
1421
 
1422
 
1423
    $categories = array_values($categories);
1424
    usort($categories, function ($a, $b) {
1425
    return $a['name'] <=> $b['name'];
1426
    });
1427
 
1428
 
1429
    $access = $myCoachQuestion->user_id == $currentUser->id;
1430
 
1431
    $allowDelete = false;
1432
    $allowAnswer = false;
1433
 
1434
    $bags_categories = [];
1435
    $myCoachQuestionCategoryMapper = MyCoachQuestionCategoryMapper::getInstance($this->adapter);
1436
 
1437
    $questionCategories = $myCoachQuestionCategoryMapper->fetchAllByQuestionId($myCoachQuestion->id);
1438
    foreach($questionCategories as $questionCategory)
1439
    {
1440
 
1441
    if(in_array($questionCategory->category_id, $categories)) {
1442
    $access = true;
1443
    }
1444
 
1445
 
1446
    if(in_array($questionCategory->category_id, $category_with_edition_ids)) {
1447
 
1448
    $allowDelete = true;
1449
    $allowAnswer = true;
1450
    }
1451
 
1452
    if (!isset($categories[$questionCategory->category_id])) {
1453
    $category = $myCoachCategoryMapper->fetchOne($questionCategory->category_id);
1454
    if ($category) {
1455
    $categories[$category->id] = [
1456
    'uuid' =>  $category->uuid,
1457
    'name' =>  $category->name,
1458
    ];
1459
    }
1460
    }
1461
 
1462
    array_push($bags_categories,['category' => $categories[ $questionCategory->category_id ]['name'] ]);
1463
    }
1464
 
1465
    $users = [];
1466
    $userMapper = UserMapper::getInstance($this->adapter);
1467
    if(isset($users[$myCoachQuestion->user_id])) {
1468
    $user = $users[$myCoachQuestion->user_id];
1469
    } else {
1470
    $user = $userMapper->fetchOne( $myCoachQuestion->user_id );
1471
    $users[ $myCoachQuestion->user_id ] = $user;
1472
    }
1473
 
1474
 
1475
 
1476
    $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->added_on);
1477
    $added_on = $dt->format('d/m/Y H:i a');
1478
 
1479
    $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->updated_on);
1480
    $updated_on = $dt->format('d/m/Y H:i a');
1481
 
1482
 
1483
 
1484
    $data = [
1485
    'user_name' => trim($user->first_name . ' ' . $user->last_name),
1486
    'image' => $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]),
1487
    'title' => $myCoachQuestion->title,
1488
    'description' => $myCoachQuestion->description,
1489
    'categories' => $bags_categories,
1490
    'views' => $myCoachQuestion->views,
1491
    'answers' => $myCoachQuestion->answers,
1492
    'reactions' => $myCoachQuestion->reactions,
1493
    'added_on' => $added_on,
1494
    'updated_on' => $updated_on,
1495
    'answers' => [],
1496
    ];
1497
 
1498
 
1499
 
1500
    if($allowDelete || $myCoachQuestion->zuser_id == $currentUser->id) {
1501
    $data['link_delete'] = $this->url()->fromRoute('my-coach/questions/delete', ['id' => $myCoachQuestion->uuid]);
1502
    } else {
1503
    $data['ink_delete'] = '';
1504
    }
1505
 
1506
 
1507
    if ($allowAnswer) {
1508
    $data['link_answers'] = $this->url()->fromRoute('my-coach/questions/answers', ['id' => $myCoachQuestion->uuid]);
1509
    } else {
1510
    $data['link_answers'] = '';
1511
    }
1512
 
1513
    $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1514
    $records =  $myCoachAnswerMapper->fetchAllByQuestionId($myCoachQuestion->id);
1515
    foreach($records as $record)
1516
    {
1517
 
1518
    $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->added_on);
1519
    $added_on = $dt->format('d/m/Y H:i a');
1520
 
1521
    $dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->updated_on);
1522
    $updated_on = $dt->format('d/m/Y H:i a');
1523
 
1524
    if(isset($users[$record->user_id])) {
1525
    $user = $users[$record->user_id];
1526
    } else {
1527
    $user = $userMapper->fetchOne( $record->user_id );
1528
    $users[ $record->user_id ] = $user;
1529
    }
1530
 
1531
    array_push($data['answers'], [
1532
    'user_name' => trim($user->first_name . ' ' . $user->last_name),
1533
    'image' => $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]),
1534
    'text' => $record->text,
1535
    'added_on' => $added_on,
1536
    'updated_on' => $updated_on,
1537
    'link_delete' => $allowAnswer ? $this->url()->fromRoute('my-coach/questions/answer/delete', ['code' => $myCoachQuestion->uuid, 'answer' => $record->uuid]) : '',
1538
    ]);
1539
 
1540
 
1541
 
1542
    }
1543
 
1544
 
1545
 
1546
 
1547
    return new JsonModel([
1548
    'success' => true,
1549
    'data' => $data
1550
    ]);
1551
 
1552
 
1553
    } else {
1554
    return new JsonModel([
1555
    'success' => false,
1556
    'data' => 'ERROR_METHOD_NOT_ALLOWED'
1557
    ]);
1558
    }
1559
 
1560
 
1561
    return new JsonModel($data);
1562
    }
1563
    */
1564
 
1565
 
1566
    public function addCommentAction()
1567
    {
1568
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1569
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1570
 
1571
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
1572
        $currentUser        = $currentUserPlugin->getUser();
1573
 
1574
        $request    = $this->getRequest();
1575
        $id    = $this->params()->fromRoute('id');
1576
 
1577
 
1578
        $request = $this->getRequest();
1579
        if ($request->isPost()) {
1580
 
1581
            $message_error = '';
1582
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1583
            if(!$myCoachAccessControl->hasAccessViewAnswer($currentUser->id, $id, $currentNetwork->id, $message_error)) {
1584
                return new JsonModel([
1585
                    'success'   => false,
1586
                    'data'   => $message_error
1587
                ]);
1588
            }
1589
 
1590
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1591
            $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($id);
1592
 
1593
            $dataPost = $request->getPost()->toArray();
1594
            $form = new CommentForm();
1595
            $form->setData($dataPost);
1596
 
1597
            if ($form->isValid()) {
1598
 
1599
 
1600
                $currentUserPlugin = $this->plugin('currentUserPlugin');
1601
                $currentUser = $currentUserPlugin->getUser();
1602
 
1603
                $dataPost = (array) $form->getData();
1604
 
1605
 
1606
 
1607
                $comment = new Comment();
1608
                $comment->network_id = $currentUser->network_id;
1609
                $comment->comment = $dataPost['comment'];
1610
                $comment->user_id = $currentUser->id;
1611
                $comment->my_coach_answer_id = $myCoachAnswer->id;
1612
                $comment->relational = Comment::RELATIONAL_MY_COACH;
1613
 
1614
                $commentMapper = CommentMapper::getInstance($this->adapter);
1615
                if ($commentMapper->insert($comment)) {
1616
                    $now = $commentMapper->getDatebaseNow();
1617
 
1618
                    $response = [
1619
                        'success'           => true,
1620
                        'data'              => [
1621
                            'item'  => $this->renderComment($comment->id, $now),
1622
                            'total_comments_answer' => intval( $commentMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id), 10),
1623
                            'total_comments_question' => intval( $commentMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10),
1624
                        ]
1625
                    ];
1626
 
1627
                    return new JsonModel($response);
1628
                } else {
1629
 
1630
                    $response = [
1631
                        'success'   => false,
1632
                        'data'   => $commentMapper->getError()
1633
                    ];
1634
 
1635
                    return new JsonModel($response);
1636
                }
1637
            } else {
1638
                $message = '';;
1639
                $form_messages = (array) $form->getMessages();
1640
                foreach ($form_messages  as $fieldname => $field_messages) {
1641
                    foreach ($field_messages as $key => $value) {
1642
                        $message = $value;
1643
                    }
1644
                }
1645
 
1646
                $response = [
1647
                    'success'   => false,
1648
                    'data'   => $message
1649
                ];
1650
 
1651
                return new JsonModel($response);
1652
            }
1653
        } else {
1654
            $response = [
1655
                'success' => false,
1656
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
1657
            ];
1658
 
1659
            return new JsonModel($response);
1660
        }
1661
    }
1662
 
1663
 
1664
 
1665
    public function deleteCommentAction()
1666
    {
1667
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1668
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1669
 
1670
        $currentUserPlugin      = $this->plugin('currentUserPlugin');
1671
        $currentUser            = $currentUserPlugin->getUser();
1672
 
1673
        $request                = $this->getRequest();
1674
        $id                     = $this->params()->fromRoute('id');
1675
        $comment                = $this->params()->fromRoute('comment');
1676
 
1677
 
1678
        $request = $this->getRequest();
1679
        if ($request->isPost()) {
1680
 
1681
 
1682
 
1683
 
1684
            $message_error = '';
1685
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1686
            if(!$myCoachAccessControl->hasAccessViewAnswer($currentUser->id, $id, $currentNetwork->id, $message_error)) {
1687
                return new JsonModel([
1688
                    'success'   => false,
1689
                    'data'   => $message_error
1690
                ]);
1691
            }
1692
 
1693
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1694
            $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($id);
1695
 
1696
            $commentMapper = CommentMapper::getInstance($this->adapter);
1697
            $comment = $commentMapper->fetchOneByUuid($comment);
1698
 
1699
 
1700
            if ($comment && $comment->my_coach_answer_id == $myCoachAnswer->id && $comment->user_id == $currentUser->id) {
1701
 
1702
                $comment->status = Comment::STATUS_DELETED;
1703
 
1704
                if ($commentMapper->update($comment)) {
6388 efrain 1705
 
6521 efrain 1706
                    $response = [
1707
                        'success' => true,
1708
                        'data' => [
1709
                            'message' => 'LABEL_COMMENT_WAS_DELETED',
1710
                            'total_comments_answer' => intval( $commentMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id), 10),
1711
                            'total_comments_question' => intval( $commentMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10),
1712
                        ]
1713
                    ];
1714
                } else {
1715
                    $response = [
1716
                        'success' => false,
1717
                        'data' => $commentMapper->getError()
1718
                    ];
1719
 
1720
                }
1721
            } else {
1722
                $response = [
1723
                    'success' => false,
1724
                    'data' => 'ERROR_COMMENT_NOT_FOUND'
1725
                ];
1726
            }
1727
        } else {
1728
            $response = [
1729
                'success' => false,
1730
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
1731
            ];
1732
        }
1733
 
1734
        return new JsonModel($response);
1735
    }
1736
 
1737
    public function reactionsAction()
1738
    {
1739
        return new JsonModel([
1740
            'success' => false,
1741
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
1742
        ]);
6388 efrain 1743
 
6521 efrain 1744
    }
1745
 
1746
 
1747
 
1748
    public function saveReactionAction()
1749
    {
1750
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1751
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1752
 
1753
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
1754
        $currentUser        = $currentUserPlugin->getUser();
1755
 
1756
        $request    = $this->getRequest();
1757
 
1758
        $id = $this->params()->fromRoute('id');
1759
        $reaction  = $this->params()->fromPost('reaction');
1760
 
1761
        $request = $this->getRequest();
1762
        if ($request->isPost()) {
1763
 
1764
 
1765
            $message_error = '';
1766
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1767
            if(!$myCoachAccessControl->hasAccessViewAnswer($currentUser->id, $id, $currentNetwork->id, $message_error)) {
1768
                return new JsonModel([
1769
                    'success'   => false,
1770
                    'data'   => $message_error
6388 efrain 1771
                ]);
6521 efrain 1772
            }
1773
 
1774
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1775
            $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($id);
1776
 
1777
            $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
1778
            $contentReaction = $contentReactionMapper->fetchOneByMyCoachAnswerIdAndUserId($myCoachAnswer->id, $currentUser->id);
1779
 
1780
            if ($contentReaction) {
1781
                $contentReaction->reaction = $reaction;
1782
 
1783
                $result = $contentReactionMapper->update($contentReaction);
1784
            } else {
1785
                $contentReaction = new ContentReaction();
1786
                $contentReaction->user_id = $currentUser->id;
1787
                $contentReaction->my_coach_answer_id = $myCoachAnswer->id;
1788
                $contentReaction->relational = ContentReaction::RELATIONAL_MY_COACH;
1789
                $contentReaction->reaction = $reaction;
1790
 
1791
                $result = $contentReactionMapper->insert($contentReaction);
1792
            }
1793
 
1794
 
1795
 
1796
            if ($result) {
1797
 
1798
                $total_reactions_question = intval($contentReactionMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10);
1799
                $total_reactions_answer = intval($contentReactionMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id), 10);
1800
                $response = [
1801
                    'success' => true,
1802
                    'data' => [
1803
                        'reaction' => $reaction,
1804
                        'total_reactions_question' => $total_reactions_question,
1805
                        'total_reactions_answer' => $total_reactions_answer
1806
                    ]
1807
                ];
1808
            } else {
1809
                $response = [
1810
                    'success' => false,
1811
                    'data' => $contentReactionMapper->getError()
1812
                ];
1813
            }
1814
            return new JsonModel($response);
1815
        }
1816
 
1817
        $response = [
1818
            'success' => false,
1819
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
1820
        ];
1821
        return new JsonModel($response);
1822
    }
1823
 
1824
    public function deleteReactionAction()
1825
    {
1826
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1827
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1828
 
1829
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
1830
        $currentUser        = $currentUserPlugin->getUser();
1831
 
1832
        $request    = $this->getRequest();
1833
 
1834
        $id = $this->params()->fromRoute('id');
1835
 
1836
        $request = $this->getRequest();
1837
        if ($request->isPost()) {
1838
 
1839
            $message_error = '';
1840
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1841
            if(!$myCoachAccessControl->hasAccessViewAnswer($currentUser->id, $id, $currentNetwork->id, $message_error)) {
1842
                return new JsonModel([
1843
                    'success'   => false,
1844
                    'data'   => $message_error
1845
                ]);
1846
            }
1847
 
1848
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1849
            $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($id);
1850
 
1851
 
1852
            $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
1853
            $contentReaction = $contentReactionMapper->fetchOneByMyCoachAnswerIdAndUserId($myCoachAnswer->id, $currentUser->id);
1854
 
1855
            if ($contentReaction) {
1856
                if ($contentReactionMapper->deleteByByMyCoachAnswerId($myCoachAnswer->id, $currentUser->id)) {
1857
                    $total_reactions_question = intval($contentReactionMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id), 10);
1858
                    $total_reactions_answer = intval($contentReactionMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id), 10);
1859
 
1860
                    $response = [
1861
                        'success' => true,
1862
                        'data' => [
1863
                            'total_reactions_question' => $total_reactions_question,
1864
                            'total_reactions_answer' => $total_reactions_answer
1865
                        ]
1866
                    ];
1867
                } else {
1868
                    $response = [
1869
                        'success' => false,
1870
                        'data' => $contentReactionMapper->getError()
1871
                    ];
1872
                }
1873
            } else {
1874
                $total_reactions_question = $contentReactionMapper->fetchCountByMyCoachQuestionId($myCoachAnswer->question_id);
1875
                $total_reactions_answer = $contentReactionMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id);
1876
 
1877
                $response = [
1878
                    'success' => true,
1879
                    'data' => [
1880
                        'total_reactions_question' => $total_reactions_question,
1881
                        'total_reactions_answer' => $total_reactions_answer
1882
                    ]
1883
                ];
1884
 
1885
 
1886
            }
1887
 
1888
 
1889
 
1890
            return new JsonModel($response);
1891
        }
1892
 
1893
        $response = [
1894
            'success' => false,
1895
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
1896
        ];
1897
        return new JsonModel($response);
1898
    }
1899
 
1900
    public function commentsAction()
1901
    {
1902
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1903
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1904
 
1905
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
1906
        $currentUser        = $currentUserPlugin->getUser();
1907
 
1908
 
1909
        $id = $this->params()->fromRoute('id');
1910
 
1911
        $request = $this->getRequest();
1912
        if ($request->isGet()) {
1913
            $message_error = '';
1914
            $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1915
            if(!$myCoachAccessControl->hasAccessViewAnswer($currentUser->id, $id, $currentNetwork->id, $message_error)) {
1916
                return new JsonModel([
1917
                    'success'   => false,
1918
                    'data'   => $message_error
1919
                ]);
1920
            }
1921
 
1922
            $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1923
            $myCoachAnswer = $myCoachAnswerMapper->fetchOneByUuid($id);
1924
            $now = $myCoachAnswerMapper->getDatebaseNow();
1925
 
1926
            $commentMapper = CommentMapper::getInstance($this->adapter);
1927
            $records = $commentMapper->fetchAllPublishedByMyCoachAnswerId($myCoachAnswer->id);
1928
 
1929
            $comments = [];
1930
            foreach ($records as $record) {
1931
                $comment = $this->renderComment($record->id, $now);
1932
                array_push($comments, $comment);
1933
            }
1934
 
1935
            $response = [
1936
                'success' => true,
1937
                'data' => $comments
1938
            ];
1939
 
1940
            return new JsonModel($response);
5050 efrain 1941
        } else {
6521 efrain 1942
 
1943
 
1944
 
1945
            $response = [
5050 efrain 1946
                'success' => false,
1947
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
6521 efrain 1948
            ];
1949
 
1950
 
1951
            return new JsonModel($response);
5050 efrain 1952
        }
1953
    }
6521 efrain 1954
 
1955
 
1956
    private function renderAnswer($answer_id, $current_user_id, $now)
1957
    {
6547 efrain 1958
        $currentNetworkPlugin  = $this->plugin('currentNetworkPlugin');
1959
        $currentNetwork        = $currentNetworkPlugin->getNetwork();
1960
        $message_error = '';
6521 efrain 1961
 
1962
        $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
1963
        $myCoachAnswer =  $myCoachAnswerMapper->fetchOne($answer_id);
6547 efrain 1964
 
1965
        $myCoachQuestionMapper = MyCoachQuestionMapper::getInstance($this->adapter);
1966
        $myCoachQuestion = $myCoachQuestionMapper->fetchOne($myCoachAnswer->question_id);
6521 efrain 1967
 
1968
 
6547 efrain 1969
        $myCoachAccessControl = MyCoachAccessControl::getInstance($this->adapter);
1970
        $hasAccessEditOrDeleteAnswer = $myCoachAccessControl->hasAccessEditOrDeleteAnswer($current_user_id, $answer_id, $currentNetwork->id, $message_error);
1971
        if($hasAccessEditOrDeleteAnswer) {
1972
 
1973
 
1974
            $link_edit = $this->url()->fromRoute('my-coach/questions/answers/edit',['id' => $myCoachQuestion->uuid, 'answer' => $myCoachAnswer->uuid]);
1975
            $link_delete = $this->url()->fromRoute('my-coach/questions/answers/delete',['id' => $myCoachQuestion->uuid, 'answer' => $myCoachAnswer->uuid]);
1976
 
1977
        } else {
1978
            $link_edit = '';
1979
            $link_delete = '';
1980
        }
1981
 
6521 efrain 1982
        $userMapper = UserMapper::getInstance($this->adapter);
1983
        $user = $userMapper->fetchOne($myCoachAnswer->user_id);
1984
 
1985
        $contentReactionMapper = ContentReactionMapper::getInstance($this->adapter);
1986
        $contentReaction = $contentReactionMapper->fetchOneByMyCoachAnswerIdAndUserId($myCoachAnswer->id, $current_user_id);
6547 efrain 1987
        $total_reactions = intval($contentReactionMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id), 10);
6521 efrain 1988
 
1989
 
1990
 
1991
 
1992
        $comments = [];
1993
        $commentMapper = CommentMapper::getInstance($this->adapter);
1994
        $total_comments = $commentMapper->fetchCountByMyCoachAnswerId($myCoachAnswer->id);
1995
        $records = $commentMapper->fetchAllPublishedByMyCoachAnswerId($myCoachAnswer->id);
1996
        foreach($records as $record)
1997
        {
1998
            $comments[] = $this->renderComment($record->id, $now);
1999
        }
2000
 
2001
 
2002
        $item = [
2003
            'unique' => uniqid(),
2004
            'uuid' => $myCoachAnswer->uuid,
6547 efrain 2005
            'question_uuid' => $myCoachQuestion->uuid,
6521 efrain 2006
            'user_image' => $this->url()->fromRoute('storage', ['type' => 'user',  'code' => $user->uuid, 'filename' =>  $user->image]),
2007
            'user_url' => $this->url()->fromRoute('profile/view', ['id' => $user->uuid]),
2008
            'user_name' => $user->first_name . ' ' . $user->last_name,
2009
            'time_elapsed' => Functions::timeAgo($myCoachAnswer->added_on, $now),
2010
            'text' => $myCoachAnswer->text,
2011
            'reaction' => $contentReaction ? $contentReaction->reaction : '',
2012
            'total_comments' => $total_comments,
2013
            'total_reactions' => $total_reactions,
2014
            'comments' => $comments,
6547 efrain 2015
            'link_edit' => $link_edit,
2016
            'link_delete' => $link_delete,
6521 efrain 2017
            'link_reaction_delete' => $this->url()->fromRoute('my-coach/questions/reaction/delete', ['id' => $myCoachAnswer->uuid]),
2018
            'link_save_reaction' => $this->url()->fromRoute('my-coach/questions/reaction/save', ['id' => $myCoachAnswer->uuid]),
2019
            'link_add_comment' => $this->url()->fromRoute('my-coach/questions/comments/add', ['id' => $myCoachAnswer->uuid]),
2020
        ];
6388 efrain 2021
 
6521 efrain 2022
        return $item;
2023
 
2024
 
2025
 
2026
    }
2027
 
2028
 
2029
 
2030
    private function renderComment($comment_id, $now)
2031
    {
2032
        $item = [];
2033
 
2034
        $commentMapper = CommentMapper::getInstance($this->adapter);
2035
        $record = $commentMapper->fetchOne($comment_id);
2036
 
2037
        $myCoachAnswerMapper = MyCoachAnswerMapper::getInstance($this->adapter);
2038
        $myCoachAnswer = $myCoachAnswerMapper->fetchOne($record->my_coach_answer_id);
2039
 
2040
 
2041
        if ($record) {
2042
            $userMapper = UserMapper::getInstance($this->adapter);
2043
 
2044
            $user = $userMapper->fetchOne($record->user_id);
2045
 
2046
            $item['unique'] = uniqid();
2047
            $item['answer_uuid'] = $myCoachAnswer->uuid;
2048
            $item['user_image'] = $this->url()->fromRoute('storage', ['type' => 'user',  'code' => $user->uuid, 'filename' =>  $user->image]);
2049
            $item['user_url'] = $this->url()->fromRoute('profile/view', ['id' => $user->uuid]);
2050
            $item['user_name'] = $user->first_name . ' ' . $user->last_name;
2051
            $item['time_elapsed'] = Functions::timeAgo($record->added_on, $now);
2052
            $item['comment'] = $record->comment;
2053
            $item['link_delete'] = $this->url()->fromRoute('my-coach/questions/comments/delete', ['id' => $myCoachAnswer->uuid, 'comment' => $record->uuid]);
2054
        }
2055
        return $item;
2056
    }
2057
 
5050 efrain 2058
}