Proyectos de Subversion LeadersLinked - Backend

Rev

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

Rev Autor Línea Nro. Línea
1 www 1
<?php
1098 geraldo 2
 
1 www 3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
8
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
11
use Laminas\Log\LoggerInterface;
12
use Laminas\View\Model\ViewModel;
13
use Laminas\View\Model\JsonModel;
14
use LeadersLinked\Library\Functions;
15
use LeadersLinked\Mapper\CompetencyMapper;
16
use LeadersLinked\Model\Competency;
17
use LeadersLinked\Form\CompetencyForm;
18
use LeadersLinked\Mapper\CompetencyTypeMapper;
1142 geraldo 19
use LeadersLinked\Model\CompetencyType;
1140 geraldo 20
use LeadersLinked\Mapper\BehaviorCompetencyMapper;
21
use LeadersLinked\Model\BehaviorCompetency;
1142 geraldo 22
use LeadersLinked\Mapper\BehaviorsMapper;
23
use LeadersLinked\Model\Behaviors;
1 www 24
 
1098 geraldo 25
class CompetencyController extends AbstractActionController {
1 www 26
 
27
    /**
28
     *
29
     * @var AdapterInterface
30
     */
31
    private $adapter;
1098 geraldo 32
 
1 www 33
    /**
34
     *
35
     * @var AbstractAdapter
36
     */
37
    private $cache;
1098 geraldo 38
 
1 www 39
    /**
40
     *
41
     * @var  LoggerInterface
42
     */
43
    private $logger;
44
 
45
    /**
46
     *
47
     * @var array
48
     */
49
    private $config;
1098 geraldo 50
 
1 www 51
    /**
52
     *
53
     * @param AdapterInterface $adapter
54
     * @param AbstractAdapter $cache
55
     * @param LoggerInterface $logger
56
     * @param array $config
57
     */
1098 geraldo 58
    public function __construct($adapter, $cache, $logger, $config) {
59
        $this->adapter = $adapter;
60
        $this->cache = $cache;
61
        $this->logger = $logger;
62
        $this->config = $config;
1 www 63
    }
1098 geraldo 64
 
65
    public function indexAction() {
28 efrain 66
        $currentUserPlugin = $this->plugin('currentUserPlugin');
67
        $currentUser = $currentUserPlugin->getUser();
68
        $currentCompany = $currentUserPlugin->getCompany();
1098 geraldo 69
 
1 www 70
        $request = $this->getRequest();
1098 geraldo 71
 
72
        $headers = $request->getHeaders();
73
 
1 www 74
        $request = $this->getRequest();
1098 geraldo 75
        if ($request->isGet()) {
76
 
77
 
78
            $headers = $request->getHeaders();
79
 
1 www 80
            $isJson = false;
1098 geraldo 81
            if ($headers->has('Accept')) {
1 www 82
                $accept = $headers->get('Accept');
1098 geraldo 83
 
1 www 84
                $prioritized = $accept->getPrioritized();
1098 geraldo 85
 
86
                foreach ($prioritized as $key => $value) {
1 www 87
                    $raw = trim($value->getRaw());
1098 geraldo 88
 
89
                    if (!$isJson) {
1 www 90
                        $isJson = strpos($raw, 'json');
91
                    }
92
                }
93
            }
1098 geraldo 94
 
95
            if ($isJson) {
1 www 96
                $search = $this->params()->fromQuery('search', []);
97
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
1098 geraldo 98
 
99
                $page = intval($this->params()->fromQuery('start', 1), 10);
100
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
101
                $order = $this->params()->fromQuery('order', []);
102
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
103
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
104
 
105
                $fields = ['type', 'name'];
1 www 106
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';
1098 geraldo 107
 
108
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
1 www 109
                    $order_direction = 'ASC';
110
                }
1098 geraldo 111
 
1 www 112
                $competenceMapper = CompetencyMapper::getInstance($this->adapter);
1098 geraldo 113
 
114
                if ($currentCompany) {
28 efrain 115
                    $paginator = $competenceMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);
116
                } else {
117
                    $paginator = $competenceMapper->fetchAllDataTable($search, $page, $records_x_page, $order_field, $order_direction);
118
                }
1 www 119
                $items = [];
120
                $records = $paginator->getCurrentItems();
1098 geraldo 121
                foreach ($records as $record) {
1 www 122
                    $item = [
123
                        'type' => $record['type'],
124
                        'name' => $record['name'],
125
                        'status' => $record['status'],
126
                        'actions' => [
1098 geraldo 127
                            'link_edit' => $this->url()->fromRoute('settings/competencies/edit', ['id' => $record['uuid']]),
128
                            'link_delete' => $this->url()->fromRoute('settings/competencies/delete', ['id' => $record['uuid']])
129
                        ]
1 www 130
                    ];
1098 geraldo 131
 
1 www 132
                    array_push($items, $item);
133
                }
1098 geraldo 134
 
1 www 135
                return new JsonModel([
136
                    'success' => true,
137
                    'data' => [
138
                        'items' => $items,
139
                        'total' => $paginator->getTotalItemCount(),
140
                    ]
141
                ]);
1098 geraldo 142
            } else {
143
                if ($currentCompany) {
66 efrain 144
                    $form = new CompetencyForm($this->adapter, $currentCompany->id);
145
                } else {
146
                    $form = new CompetencyForm($this->adapter);
147
                }
1098 geraldo 148
 
1 www 149
                $this->layout()->setTemplate('layout/layout-backend');
150
                $viewModel = new ViewModel();
151
                $viewModel->setTemplate('leaders-linked/competencies/index.phtml');
152
                $viewModel->setVariable('form', $form);
1098 geraldo 153
                return $viewModel;
154
            }
1 www 155
        } else {
156
            return new JsonModel([
157
                'success' => false,
158
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
1098 geraldo 159
            ]);
160
            ;
1 www 161
        }
162
    }
1098 geraldo 163
 
164
    public function addAction() {
1 www 165
        $currentUserPlugin = $this->plugin('currentUserPlugin');
166
        $currentUser = $currentUserPlugin->getUser();
28 efrain 167
        $currentCompany = $currentUserPlugin->getCompany();
1098 geraldo 168
 
1 www 169
        $request = $this->getRequest();
1098 geraldo 170
 
171
 
172
        if ($request->isPost()) {
173
            if ($currentCompany) {
66 efrain 174
                $form = new CompetencyForm($this->adapter, $currentCompany->id);
175
            } else {
176
                $form = new CompetencyForm($this->adapter);
177
            }
1 www 178
            $dataPost = $request->getPost()->toArray();
1098 geraldo 179
 
1 www 180
            $form->setData($dataPost);
1098 geraldo 181
 
182
            if ($form->isValid()) {
1 www 183
                $dataPost = (array) $form->getData();
184
                $dataPost['status'] = $dataPost['status'] ? $dataPost['status'] : Competency::STATUS_INACTIVE;
1098 geraldo 185
 
1 www 186
                $competenceTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
187
                $competenceType = $competenceTypeMapper->fetchOneByUuid($dataPost['competency_type_id']);
188
                $dataPost['competency_type_id'] = $competenceType->id;
189
 
28 efrain 190
 
1 www 191
                $hydrator = new ObjectPropertyHydrator();
28 efrain 192
                $competence = new Competency();
1098 geraldo 193
 
28 efrain 194
                $hydrator->hydrate($dataPost, $competence);
1098 geraldo 195
 
196
                if ($currentCompany) {
28 efrain 197
                    $competence->company_id = $currentCompany->id;
198
                }
1 www 199
 
200
                $competenceMapper = CompetencyMapper::getInstance($this->adapter);
28 efrain 201
                $result = $competenceMapper->insert($competence);
1098 geraldo 202
 
203
                if ($result) {
1151 geraldo 204
 
1140 geraldo 205
                    $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
1147 geraldo 206
                    $behaviorMapper = BehaviorsMapper::getInstance($this->adapter);
207
 
1140 geraldo 208
                    $behaviorCompetencyMapper->deleteAllBCompetencyId($competence->id);
209
 
210
                    $behaviors = json_decode($dataPost['behaviors'], true);
211
 
212
                    for ($i = 0; $i < count($behaviors); $i++) {
213
 
1147 geraldo 214
                        $behavior = $behaviorMapper->fetchOneByUuid($behaviors[$i]['id']);
215
                        if ($behavior) {
1151 geraldo 216
                            $behaviorCompetency = new BehaviorCompetency();
217
                            $behaviorCompetency->competency_id = $competence->id;
218
                            $behaviorCompetency->behavior_id = $behavior->id;
219
                            $behaviorCompetencyMapper->insert($behaviorCompetency);
1147 geraldo 220
                        }
1140 geraldo 221
                    }
1151 geraldo 222
 
1144 geraldo 223
                    $this->logger->info('Se agrego la competencia ' . $competence->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1140 geraldo 224
 
1 www 225
                    $data = [
1098 geraldo 226
                        'success' => true,
227
                        'data' => 'LABEL_RECORD_ADDED'
1 www 228
                    ];
229
                } else {
230
                    $data = [
1098 geraldo 231
                        'success' => false,
232
                        'data' => $competenceMapper->getError()
1 www 233
                    ];
234
                }
1098 geraldo 235
 
1 www 236
                return new JsonModel($data);
237
            } else {
238
                $messages = [];
239
                $form_messages = (array) $form->getMessages();
1098 geraldo 240
                foreach ($form_messages as $fieldname => $field_messages) {
241
 
1 www 242
                    $messages[$fieldname] = array_values($field_messages);
243
                }
1098 geraldo 244
 
1 www 245
                return new JsonModel([
1098 geraldo 246
                    'success' => false,
247
                    'data' => $messages
1 www 248
                ]);
249
            }
250
        } else {
251
            $data = [
252
                'success' => false,
253
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
254
            ];
1098 geraldo 255
 
1 www 256
            return new JsonModel($data);
257
        }
1098 geraldo 258
 
1 www 259
        return new JsonModel($data);
260
    }
1098 geraldo 261
 
262
    public function editAction() {
1 www 263
        $currentUserPlugin = $this->plugin('currentUserPlugin');
264
        $currentUser = $currentUserPlugin->getUser();
28 efrain 265
        $currentCompany = $currentUserPlugin->getCompany();
1098 geraldo 266
 
1 www 267
        $request = $this->getRequest();
268
        $uuid = $this->params()->fromRoute('id');
269
 
1098 geraldo 270
 
271
        if (!$uuid) {
1 www 272
            $data = [
1098 geraldo 273
                'success' => false,
274
                'data' => 'ERROR_INVALID_PARAMETER'
1 www 275
            ];
1098 geraldo 276
 
1 www 277
            return new JsonModel($data);
278
        }
279
 
280
        $competenceMapper = CompetencyMapper::getInstance($this->adapter);
281
        $competence = $competenceMapper->fetchOneByUuid($uuid);
1098 geraldo 282
        if (!$competence) {
1 www 283
            $data = [
1098 geraldo 284
                'success' => false,
285
                'data' => 'ERROR_RECORD_NOT_FOUND'
1 www 286
            ];
1098 geraldo 287
 
1 www 288
            return new JsonModel($data);
289
        }
1098 geraldo 290
 
291
        if ($currentCompany) {
292
            if ($competence->company_id != $currentCompany->id) {
28 efrain 293
                $data = [
1098 geraldo 294
                    'success' => false,
295
                    'data' => 'ERROR_UNAUTHORIZED'
28 efrain 296
                ];
1098 geraldo 297
 
28 efrain 298
                return new JsonModel($data);
299
            }
300
        } else {
1098 geraldo 301
            if ($competence->company_id) {
28 efrain 302
                $data = [
1098 geraldo 303
                    'success' => false,
304
                    'data' => 'ERROR_UNAUTHORIZED'
28 efrain 305
                ];
1098 geraldo 306
 
28 efrain 307
                return new JsonModel($data);
308
            }
309
        }
1098 geraldo 310
 
311
        if ($request->isPost()) {
312
            if ($currentCompany) {
66 efrain 313
                $form = new CompetencyForm($this->adapter, $currentCompany->id);
314
            } else {
315
                $form = new CompetencyForm($this->adapter);
316
            }
1 www 317
            $dataPost = $request->getPost()->toArray();
1098 geraldo 318
 
319
 
1 www 320
            $form->setData($dataPost);
1098 geraldo 321
 
322
            if ($form->isValid()) {
1 www 323
                $dataPost = (array) $form->getData();
324
                $dataPost['status'] = $dataPost['status'] ? $dataPost['status'] : Competency::STATUS_INACTIVE;
1098 geraldo 325
 
1 www 326
                $competenceTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
327
                $competenceType = $competenceTypeMapper->fetchOneByUuid($dataPost['competency_type_id']);
328
                $dataPost['competency_type_id'] = $competenceType->id;
1098 geraldo 329
 
1 www 330
                $hydrator = new ObjectPropertyHydrator();
28 efrain 331
                $hydrator->hydrate($dataPost, $competence);
332
 
333
                $result = $competenceMapper->update($competence);
1098 geraldo 334
 
335
                if ($result) {
1151 geraldo 336
 
1144 geraldo 337
                    $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
1147 geraldo 338
                    $behaviorMapper = BehaviorsMapper::getInstance($this->adapter);
339
 
1144 geraldo 340
                    $behaviorCompetencyMapper->deleteAllBCompetencyId($competence->id);
341
 
342
                    $behaviors = json_decode($dataPost['behaviors'], true);
343
 
344
                    for ($i = 0; $i < count($behaviors); $i++) {
345
 
1147 geraldo 346
                        $behavior = $behaviorMapper->fetchOneByUuid($behaviors[$i]['id']);
347
                        if ($behavior) {
1151 geraldo 348
                            $behaviorCompetency = new BehaviorCompetency();
349
                            $behaviorCompetency->competency_id = $competence->id;
350
                            $behaviorCompetency->behavior_id = $behavior->id;
351
                            $behaviorCompetencyMapper->insert($behaviorCompetency);
1147 geraldo 352
                        }
1144 geraldo 353
                    }
1151 geraldo 354
 
1 www 355
                    $this->logger->info('Se actualizo la competencia ' . $competenceType->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1098 geraldo 356
 
1 www 357
                    $data = [
358
                        'success' => true,
359
                        'data' => 'LABEL_RECORD_UPDATED'
360
                    ];
361
                } else {
362
                    $data = [
1098 geraldo 363
                        'success' => false,
364
                        'data' => $competenceMapper->getError()
1 www 365
                    ];
366
                }
1098 geraldo 367
 
1 www 368
                return new JsonModel($data);
369
            } else {
370
                $messages = [];
371
                $form_messages = (array) $form->getMessages();
1098 geraldo 372
                foreach ($form_messages as $fieldname => $field_messages) {
1 www 373
                    $messages[$fieldname] = array_values($field_messages);
374
                }
1098 geraldo 375
 
1 www 376
                return new JsonModel([
1098 geraldo 377
                    'success' => false,
378
                    'data' => $messages
1 www 379
                ]);
380
            }
381
        } else if ($request->isGet()) {
1151 geraldo 382
 
1 www 383
            $competenceTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
384
            $competenceType = $competenceTypeMapper->fetchOne($competence->competency_type_id);
1143 geraldo 385
            $behaviorCompetencyMapper = BehaviorCompetencyMapper::getInstance($this->adapter);
386
            $behaviorMapper = BehaviorsMapper::getInstance($this->adapter);
1098 geraldo 387
 
1 www 388
            $hydrator = new ObjectPropertyHydrator();
1098 geraldo 389
 
1 www 390
            $data = $hydrator->extract($competence);
391
            $data['competency_type_id'] = $competenceType->uuid;
1141 geraldo 392
            $data['behaviors'] = [];
1098 geraldo 393
 
1155 geraldo 394
            $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competence->id);
1143 geraldo 395
            foreach ($behaviorCompetencies as $record) {
1141 geraldo 396
                $behavior = $behaviorMapper->fetchOne($record->behavior_id);
397
                if ($behavior) {
398
                    array_push($data['behaviors'], [
399
                        'id' => $behavior->uuid,
400
                        'description' => $behavior->description,
401
                    ]);
402
                }
403
            }
404
 
1 www 405
            $response = [
406
                'success' => true,
407
                'data' => $data
408
            ];
1098 geraldo 409
 
1 www 410
            return new JsonModel($response);
411
        } else {
412
            $data = [
413
                'success' => false,
414
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
415
            ];
1098 geraldo 416
 
1 www 417
            return new JsonModel($data);
418
        }
1098 geraldo 419
 
1 www 420
        return new JsonModel($data);
421
    }
1098 geraldo 422
 
423
    public function deleteAction() {
1 www 424
        $currentUserPlugin = $this->plugin('currentUserPlugin');
425
        $currentUser = $currentUserPlugin->getUser();
28 efrain 426
        $currentCompany = $currentUserPlugin->getCompany();
1098 geraldo 427
 
1 www 428
        $request = $this->getRequest();
429
        $uuid = $this->params()->fromRoute('id');
1098 geraldo 430
 
431
        if (!$uuid) {
1 www 432
            $data = [
1098 geraldo 433
                'success' => false,
434
                'data' => 'ERROR_INVALID_PARAMETER'
1 www 435
            ];
1098 geraldo 436
 
1 www 437
            return new JsonModel($data);
438
        }
1098 geraldo 439
 
440
 
1 www 441
        $competenceMapper = CompetencyMapper::getInstance($this->adapter);
28 efrain 442
        $competence = $competenceMapper->fetchOneByUuid($uuid);
1098 geraldo 443
        if (!$competence) {
1 www 444
            $data = [
1098 geraldo 445
                'success' => false,
446
                'data' => 'ERROR_RECORD_NOT_FOUND'
1 www 447
            ];
1098 geraldo 448
 
1 www 449
            return new JsonModel($data);
450
        }
1098 geraldo 451
 
452
        if ($currentCompany) {
453
            if ($competence->company_id != $currentCompany->id) {
28 efrain 454
                $data = [
1098 geraldo 455
                    'success' => false,
456
                    'data' => 'ERROR_UNAUTHORIZED'
28 efrain 457
                ];
1098 geraldo 458
 
28 efrain 459
                return new JsonModel($data);
460
            }
461
        } else {
1098 geraldo 462
            if ($competence->company_id) {
28 efrain 463
                $data = [
1098 geraldo 464
                    'success' => false,
465
                    'data' => 'ERROR_UNAUTHORIZED'
28 efrain 466
                ];
1098 geraldo 467
 
28 efrain 468
                return new JsonModel($data);
469
            }
470
        }
1098 geraldo 471
 
472
        if ($request->isPost()) {
28 efrain 473
            $result = $competenceMapper->delete($competence);
1098 geraldo 474
            if ($result) {
28 efrain 475
                $this->logger->info('Se borro la competencia ' . $competence->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1098 geraldo 476
 
1 www 477
                $data = [
478
                    'success' => true,
479
                    'data' => 'LABEL_RECORD_DELETED'
480
                ];
481
            } else {
482
 
483
                $data = [
1098 geraldo 484
                    'success' => false,
485
                    'data' => $competenceMapper->getError()
1 www 486
                ];
487
 
488
                return new JsonModel($data);
489
            }
490
        } else {
491
            $data = [
492
                'success' => false,
493
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
494
            ];
1098 geraldo 495
 
1 www 496
            return new JsonModel($data);
497
        }
1098 geraldo 498
 
1 www 499
        return new JsonModel($data);
500
    }
1098 geraldo 501
 
502
    public function importAction() {
28 efrain 503
        $currentUserPlugin = $this->plugin('currentUserPlugin');
504
        $currentUser = $currentUserPlugin->getUser();
505
        $currentCompany = $currentUserPlugin->getCompany();
1098 geraldo 506
 
507
        if (!$currentCompany) {
28 efrain 508
            $data = [
509
                'success' => false,
510
                'data' => 'ERROR_UNAUTHORIZED'
511
            ];
1098 geraldo 512
 
28 efrain 513
            return new JsonModel($data);
514
        }
1098 geraldo 515
 
28 efrain 516
        $request = $this->getRequest();
1098 geraldo 517
 
518
        if ($request->isPost()) {
519
 
28 efrain 520
            $competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);
521
            $competenceMapper = CompetencyMapper::getInstance($this->adapter);
522
            $competenciesDefault = $competenceMapper->fetchAllByDefault();
1098 geraldo 523
 
28 efrain 524
            $new_records = 0;
1098 geraldo 525
            foreach ($competenciesDefault as $competencyDefault) {
28 efrain 526
 
1098 geraldo 527
                if ($competencyDefault->status == Competency::STATUS_INACTIVE) {
28 efrain 528
                    continue;
529
                }
1098 geraldo 530
 
28 efrain 531
                $competency = $competenceMapper->fetchOneByCompanyIdAndCompetencyIdDefault($currentCompany->id, $competencyDefault->id);
1098 geraldo 532
                if (!$competency) {
533
 
534
 
28 efrain 535
                    $competencyType = $competencyTypeMapper->fetchOneByCompanyId($currentCompany->id, $competencyDefault->competency_type_id);
1098 geraldo 536
                    if (!$competencyType) {
537
 
538
 
28 efrain 539
                        $competencyTypeDefault = $competencyTypeMapper->fetchOne($competencyDefault->competency_type_id);
1098 geraldo 540
                        if (!$competencyTypeDefault) {
28 efrain 541
                            continue;
542
                        }
1098 geraldo 543
 
28 efrain 544
                        $competencyType = new CompetencyType();
545
                        $competencyType->company_id = $currentCompany->id;
546
                        $competencyType->competency_type_id_default = $competencyTypeDefault->id;
547
                        $competencyType->description = $competencyTypeDefault->description;
548
                        $competencyType->name = $competencyTypeDefault->name;
549
                        $competencyType->status = CompetencyType::STATUS_ACTIVE;
1098 geraldo 550
 
551
 
552
                        if (!$competencyTypeMapper->insert($competencyType)) {
553
 
28 efrain 554
                            $data = [
555
                                'success' => false,
556
                                'data' => 'ERROR_CANT_ADD_COMPETENCY_TYPE'
557
                            ];
1098 geraldo 558
 
28 efrain 559
                            return new JsonModel($data);
1098 geraldo 560
                        }
28 efrain 561
                    }
1098 geraldo 562
 
563
 
28 efrain 564
                    $competency = new Competency();
565
                    $competency->competency_id_default = $competencyDefault->id;
566
                    $competency->company_id = $currentCompany->id;
567
                    $competency->competency_type_id = $competencyType->id;
568
                    $competency->description = $competencyDefault->description;
569
                    $competency->name = $competencyDefault->name;
570
                    $competency->status = Competency::STATUS_ACTIVE;
1098 geraldo 571
 
1155 geraldo 572
                    $behaviorCompetencies = $behaviorCompetencyMapper->fetchByCompetencyId($competence->id);
1154 geraldo 573
 
1152 geraldo 574
                    foreach ($behaviorCompetencies as $record) {
575
                        $behavior = $behaviorMapper->fetchOne($record->behavior_id);
1098 geraldo 576
 
1152 geraldo 577
                        $behavior = $behaviorMapper->fetchOneByCompanyIdAndBehaviorIdDefault($currentCompany->id, $record->behavior_id);
578
                        if ($behavior) {
579
                            $behaviorCompetency = new BehaviorCompetency();
580
                            $behaviorCompetency->competency_id = $competency->id;
581
                            $behaviorCompetency->behavior_id = $behavior->id;
582
                            $behaviorCompetencyMapper->insert($behaviorCompetency);
583
                        }
584
                    }
1098 geraldo 585
 
1152 geraldo 586
 
587
 
1098 geraldo 588
                    if ($competenceMapper->insert($competency)) {
28 efrain 589
                        $new_records++;
590
                    } else {
591
                        $data = [
592
                            'success' => false,
593
                            'data' => 'ERROR_CANT ADD THE COMPETENCY'
594
                        ];
1098 geraldo 595
 
28 efrain 596
                        return new JsonModel($data);
597
                    }
598
                }
599
            }
1098 geraldo 600
 
601
            if ($new_records) {
602
 
603
                if (1 == $new_records) {
28 efrain 604
                    $data = [
605
                        'success' => true,
606
                        'data' => 'LABEL_1_COMPETENCY_IMPORTED'
607
                    ];
1098 geraldo 608
 
28 efrain 609
                    return new JsonModel($data);
610
                } else {
611
                    $data = [
612
                        'success' => true,
1098 geraldo 613
                        'data' => $new_records . ' LABEL_MULTI_COMPETENCIES_IMPORTED'
28 efrain 614
                    ];
1098 geraldo 615
 
28 efrain 616
                    return new JsonModel($data);
617
                }
618
            } else {
619
                $data = [
620
                    'success' => true,
621
                    'data' => 'LABEL_NO_COMPETENCY_IMPORTED'
622
                ];
1098 geraldo 623
 
28 efrain 624
                return new JsonModel($data);
625
            }
626
        } else {
627
            $data = [
628
                'success' => false,
629
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
630
            ];
1098 geraldo 631
 
28 efrain 632
            return new JsonModel($data);
633
        }
1098 geraldo 634
 
28 efrain 635
        return new JsonModel($data);
636
    }
1098 geraldo 637
 
1 www 638
}