Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 6782 | Rev 12023 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |

<?php

declare(strict_types=1);

namespace LeadersLinked\Controller;

use Laminas\Db\Adapter\AdapterInterface;
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
use Laminas\Mvc\Controller\AbstractActionController;
use Laminas\Log\LoggerInterface;
use Laminas\View\Model\ViewModel;
use Laminas\View\Model\JsonModel;
use LeadersLinked\Library\Functions;
use LeadersLinked\Mapper\SurveyMapper;
use LeadersLinked\Mapper\SurveyFormMapper;
use LeadersLinked\Mapper\SurveyJobDescriptionMapper;
use LeadersLinked\Mapper\SurveyIndustryMapper;
use LeadersLinked\Mapper\SurveySkillMapper;
use LeadersLinked\Mapper\SurveyLocationMapper;
use LeadersLinked\Mapper\SurveyLanguageMapper;
use LeadersLinked\Model\Location;
use LeadersLinked\Mapper\LocationMapper;
use LeadersLinked\Mapper\IndustryMapper;
use LeadersLinked\Mapper\JobDescriptionMapper;
use LeadersLinked\Mapper\BehaviorMapper;
use LeadersLinked\Mapper\JobDescriptionBehaviorCompetencyMapper;
use LeadersLinked\Mapper\CompanyMapper;
use LeadersLinked\Mapper\LanguageMapper;
use LeadersLinked\Model\Company;
use LeadersLinked\Mapper\SkillMapper;
use LeadersLinked\Form\SurveySegmentedForm;
use LeadersLinked\Form\SurveyForm;
use LeadersLinked\Model\Survey;
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
use LeadersLinked\Model\SurveyJobDescription;
use LeadersLinked\Model\SurveySkill;
use LeadersLinked\Model\SurveyIndustry;
use LeadersLinked\Model\SurveyLanguage;
use LeadersLinked\Model\SurveyLocation;

class SurveyController extends AbstractActionController {

    /**
     *
     * @var AdapterInterface
     */
    private $adapter;

    /**
     *
     * @var AbstractAdapter
     */
    private $cache;

    /**
     *
     * @var  LoggerInterface
     */
    private $logger;

    /**
     *
     * @var array
     */
    private $config;

    /**
     *
     * @param AdapterInterface $adapter
     * @param AbstractAdapter $cache
     * @param LoggerInterface $logger
     * @param array $config
     */
    public function __construct($adapter, $cache, $logger, $config) {
        $this->adapter = $adapter;
        $this->cache = $cache;
        $this->logger = $logger;
        $this->config = $config;
    }

    public function indexAction() {
        $request = $this->getRequest();
        $currentUserPlugin = $this->plugin('currentUserPlugin');
        $currentCompany = $currentUserPlugin->getCompany();
        $currentUser = $currentUserPlugin->getUser();


        $request = $this->getRequest();
        if ($request->isGet()) {
            $sandbox = $this->config['leaderslinked.runmode.sandbox'];
            if($sandbox) {
                $google_map_key  = $this->config['leaderslinked.google_map.sandbox_api_key'];
            } else {
                $google_map_key  = $this->config['leaderslinked.google_map.production_api_key'];
            }

            $headers = $request->getHeaders();

            $isJson = false;
            if ($headers->has('Accept')) {
                $accept = $headers->get('Accept');

                $prioritized = $accept->getPrioritized();

                foreach ($prioritized as $key => $value) {
                    $raw = trim($value->getRaw());

                    if (!$isJson) {
                        $isJson = strpos($raw, 'json');
                    }
                }
            }

            if ($isJson) {
                $search = $this->params()->fromQuery('search', []);
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);

                $page = intval($this->params()->fromQuery('start', 1), 10);
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
                $order = $this->params()->fromQuery('order', []);
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));

                $fields = ['name'];
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';

                if (!in_array($order_direction, ['ASC', 'DESC'])) {
                    $order_direction = 'ASC';
                }

                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'survey/add');
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'survey/edit');
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'survey/delete');
                $allowSegment = $acl->isAllowed($currentUser->usertype_id, 'survey/segment');

                $surveyMapper = SurveyMapper::getInstance($this->adapter);
                $paginator = $surveyMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);

                $items = [];
                $records = $paginator->getCurrentItems();
              
                foreach ($records as $record) {
                    $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
                    $surveyForm = $surveyFormMapper->fetchOne($record->form_id);

                    $item = [
                        'id' => $record->id,
                        'name' => $record->name,
                        'form' => $surveyForm->name,
                        'status' => $record->status,
                        'actions' => [
                            'link_edit' => $this->url()->fromRoute('survey/edit', ['id' => $record->uuid]),
                            'link_delete' => $this->url()->fromRoute('survey/delete', ['id' => $record->uuid]),
                            'link_segment' => $this->url()->fromRoute('survey/segment', ['id' => $record->uuid])
                        ]
                    ];

                    array_push($items, $item);
                }

                return new JsonModel([
                    'success' => true,
                    'data' => [
                        'items' => $items,
                        'total' => $paginator->getTotalItemCount(),
                    ]
                ]);
            } else {

                $form = new SurveyForm($this->adapter, $currentCompany->id);

                $this->layout()->setTemplate('layout/layout-backend');
                $viewModel = new ViewModel();
                $viewModel->setTemplate('leaders-linked/survey/index.phtml');
                $viewModel->setVariable('form', $form);
                $viewModel->setVariable('google_map_key', $google_map_key);
                return $viewModel;
            }
        } else {
            return new JsonModel([
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ]);
        }
    }

    public function addAction() {
        $request = $this->getRequest();
        $currentUserPlugin = $this->plugin('currentUserPlugin');
        $currentCompany = $currentUserPlugin->getCompany();
        $currentUser = $currentUserPlugin->getUser();

        $request = $this->getRequest();

        if ($request->isPost()) {
            
            $form = new SurveyForm($this->adapter, $currentCompany->id);
            
            $dataPost = $request->getPost()->toArray();
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : SurveyForm::STATUS_INACTIVE;           


            if($dataPost['since_date'] > $dataPost['last_date']){
                new JsonModel([
                    'success' => false,
                    'data' => 'ERROR_UNAUTHORIZED'
                ]);
            }

            $form->setData($dataPost);

            if ($form->isValid()) {
                $dataPost = (array) $form->getData();

                $hydrator = new ObjectPropertyHydrator();

                $survey = new Survey();
                $hydrator->hydrate($dataPost, $survey);

                if (!$survey->status) {
                    $survey->status = Survey::STATUS_INACTIVE;
                }
                $survey->company_id = $currentCompany->id;

                $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
                $surveyForm = $surveyFormMapper->fetchOneByUuid($dataPost['form_id']);
                $survey->form_id = $surveyForm->id;

                $surveyMapper = SurveyMapper::getInstance($this->adapter);
                //$result = $surveyMapper->insert($survey);

                if($surveyMapper->insert($survey)) {
                    $survey = $surveyMapper->fetchOne($survey->id);

                    $jobDescription = new SurveyJobDescription();
                    $skill = new SurveySkill();
                    $industry = new SurveyIndustry();
                    $language = new SurveyLanguage();

                    if(!empty($dataPost['location_search'])){ 

                        $surveyLocationMapper = SurveyLocationMapper::getInstance($this->adapter);
    
                        $ok = true;

                        $formatted_address = $dataPost['formatted_address'];
                        $city1 = $dataPost['city1'];
                        $city2 = $dataPost['city2'];
                        $address1 = $dataPost['address1'];
                        $address2 = $dataPost['address2'];
                        $country = $dataPost['country'];
                        $latitude = $dataPost['latitude'];
                        $longitude = $dataPost['longitude'];
                        $postal_code = $dataPost['postal_code'];
                        $state = $dataPost['state'];

                        
                        $record = new SurveyLocation();
                        $record->formatted_address = $formatted_address; 
                        $record->city1 = $city1;
                        $record->city2 = $city2;
                        $record->address1 = $address1;
                        $record->address2 = $address2;
                        $record->country = $country;
                        $record->latitude = $latitude;
                        $record->longitude = $longitude;
                        $record->postal_code = $postal_code;
                        $record->state = $state;
                        $record->survey_id = $survey->id;
                        $result = $surveyLocationMapper->insert($record);
                        $ok = $ok && $result;
                           //}
                          if($ok){
    
                        }
                    }

                    if(!empty($dataPost['job_description_id'])){ 

                       // print_r($dataPost['job_description_id']);

                        $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
                        $surveyJobDescriptionMapper = SurveyJobDescriptionMapper::getInstance($this->adapter);

                        $ok = true;

                        foreach($dataPost['job_description_id'] as $jobDescriptionUuid) {
                        
                           // echo '$jobDescriptionUuid = ' . $jobDescriptionUuid ; 


                            $jobDescription = $jobDescriptionMapper->fetchOneByUuid($jobDescriptionUuid);

                           // print_r($jobDescription);
                            //print_r($currentCompany);

                            if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
                                $record = new SurveyJobDescription();
                                $record->job_description_id = $jobDescription->id;
                                $record->survey_id = $survey->id;

                            

                                $result = $surveyJobDescriptionMapper->insert($record);
                                $ok = $ok && $result;
                            }
                        }
                    
                        if($ok){

                        }
                    }

                    $data = [
                        'success' => true,
                        'data' => 'LABEL_RECORD_ADDED'
                    ];
                    //      return new JsonModel($data); 

                    if(!empty($dataPost['skill_id'])){ 

                        // print_r($dataPost['skill_id']);

                         $skillMapper = SkillMapper::getInstance($this->adapter);
                         $surveySkillMapper = SurveySkillMapper::getInstance($this->adapter);

                         $ok = true;

                         foreach($dataPost['skill_id'] as $skillUuid) {

                            // echo '$jobCategoryUuid = ' . $jobCategoryUuid ; 


                             $skill = $skillMapper->fetchOneByUuid($skillUuid);

                            // print_r($skill);
                            //print_r($currentCompany);

                            //if($skill && $skill->company_id == $currentCompany->id) {
                                $record = new SurveySkill();
                                $record->skill_id = $skill->id;
                                $record->survey_id = $survey->id;


                                $result = $surveySkillMapper->insert($record);
                                $ok = $ok && $result;
                            // }
                         }
                     
                         if($ok){

                         }
                     }

                    $data = [
                        'success' => true,
                        'data' => 'test'
                    ];
                    //      return new JsonModel($data); exit;

                    if(!empty($dataPost['industry_id'])){ 

                        // print_r($dataPost['industry_id']);

                         $industryMapper = IndustryMapper::getInstance($this->adapter);
                         $surveyIndustryMapper = SurveyIndustryMapper::getInstance($this->adapter);

                         $ok = true;

                         foreach($dataPost['industry_id'] as $industryUuid) {

                            // echo '$industryUuid = ' . $industryUuid ; 


                             $industry = $industryMapper->fetchOneByUuid($industryUuid);

                            // print_r($industry);
                             //print_r($currentCompany);

                             //if($industry && $industry->company_id == $currentCompany->id) {
                                 $record = new SurveyIndustry();
                                 $record->industry_id = $industry->id;
                                 $record->survey_id = $survey->id;

                            

                                 $result = $surveyIndustryMapper->insert($record);
                                 $ok = $ok && $result;
                             //}
                         }
                     
                         if($ok){

                         }
                     }

                    $data = [
                        'success' => true,
                        'data' => 'test industry'
                    ];
                    // return new JsonModel($data); exit;
                
                    if(!empty($dataPost['language_id'])){ 

                        $surveyLanguageMapper = SurveyLanguageMapper::getInstance($this->adapter);

                        $ok = true;

                        foreach($dataPost['language_id'] as $language_id) {

                                $record = new SurveyLanguage();
                                $record->language_id = $language_id;
                                $record->survey_id = $survey->id;


                                $result = $surveyLanguageMapper->insert($record);
                                $ok = $ok && $result;
                           //}
                        }
                          if($ok){

                        }
                     }

                    $data = [
                        'success' => true,
                        'data' => 'LABEL_RECORD_ADDED'
                    ];

                } else {
                    $data = [
                        'success'   => false,
                        'data'      => $surveyMapper->getError()
                    ];
                }
                
             
                return new JsonModel($data);
            } else {
                $messages = [];
                $form_messages = (array) $form->getMessages();
                foreach ($form_messages as $fieldname => $field_messages) {

                    $messages[$fieldname] = array_values($field_messages);
                }

                return new JsonModel([
                    'success' => false,
                    'data' => $messages
                ]);
            }
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];

            return new JsonModel($data);
        }

        return new JsonModel($data);
    }

    public function segmentAction() {
        $request = $this->getRequest();
        $currentUserPlugin = $this->plugin('currentUserPlugin');
        $currentCompany = $currentUserPlugin->getCompany();
        $currentUser = $currentUserPlugin->getUser();

        $request = $this->getRequest();
        $uuid = $this->params()->fromRoute('id');


        if (!$uuid) {
            $data = [
                'success' => false,
                'data' => 'ERROR_INVALID_PARAMETER'
            ];

            return new JsonModel($data);
        }

        $surveyMapper = SurveyMapper::getInstance($this->adapter);
        $survey = $surveyMapper->fetchOneByUuid($uuid);
        if (!$survey) {
            $data = [
                'success' => false,
                'data' => 'ERROR_RECORD_NOT_FOUND'
            ];

            return new JsonModel($data);
        }

        if ($survey->company_id != $currentCompany->id) {
            return new JsonModel([
                'success' => false,
                'data' => 'ERROR_UNAUTHORIZED'
            ]);
        }

        if($request->isPost()){
            $form = new SurveySegmentedForm($this->adapter, $currentCompany->id);
            
            
            $dataPost = $request->getPost()->toArray();
            $form->setData($dataPost);
            


            if ($form->isValid()) {
                $dataPost = (array) $form->getData();
                
                /*

                $location = new Location();
                $hydrator->hydrate($dataPost, $location);
                
                $locationMapper= LocationMapper::getInstance($this->adapter);
                $resultLocation = $locationMapper->insert($location);

                if (!$resultLocation) {
                    return new JsonModel([
                        'success'   => false,
                        'data' => 'ERROR_THERE_WAS_AN_ERROR'                       
                    ]);
                }
                */
                
                $jobDescription = new SurveyJobDescription();
                $skill = new SurveySkill();
                $industry = new SurveyIndustry();
                $language = new SurveyLanguage();

                if(!empty($dataPost['job_description_id'])){ 
                    
                   // print_r($dataPost['job_description_id']);
                    
                    $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
                    $surveyJobDescriptionMapper = SurveyJobDescriptionMapper::getInstance($this->adapter);
                    
                    $ok = true;
                    
                    foreach($dataPost['job_description_id'] as $jobDescriptionUuid) {
                       
                       // echo '$jobDescriptionUuid = ' . $jobDescriptionUuid ; 
                        
                        
                        $jobDescription = $jobDescriptionMapper->fetchOneByUuid($jobDescriptionUuid);
                        
                       // print_r($jobDescription);
                        //print_r($currentCompany);
                        
                        if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
                            $record = new SurveyJobDescription();
                            $record->job_description_id = $jobDescription->id;
                            $record->survey_id = $survey->id;
                            
             
                            
                            $result = $surveyJobDescriptionMapper->insert($record);
                            $ok = $ok && $result;
                        }
                    }
 
                    if($ok){
                        
                    }
                }
                
                $data = [
                    'success' => true,
                    'data' => 'LABEL_RECORD_ADDED'
                ];
              //  return new JsonModel($data); 

                if(!empty($dataPost['skill_id'])){ 
                    
                    // print_r($dataPost['skill_id']);
                     
                     $skillMapper = SkillMapper::getInstance($this->adapter);
                     $surveySkillMapper = SurveySkillMapper::getInstance($this->adapter);
                     
                     $ok = true;
                     
                     foreach($dataPost['skill_id'] as $skillUuid) {
                        
                        // echo '$jobCategoryUuid = ' . $jobCategoryUuid ; 
                         
                         
                         $skill = $skillMapper->fetchOneByUuid($skillUuid);
                         
                        // print_r($skill);
                        //print_r($currentCompany);
                         
                        //if($skill && $skill->company_id == $currentCompany->id) {
                            $record = new SurveySkill();
                            $record->skill_id = $skill->id;
                            $record->survey_id = $survey->id;
                            
                                          
                            $result = $surveySkillMapper->insert($record);
                            $ok = $ok && $result;
                        // }
                     }
  
                     if($ok){
                         
                     }
                 }
                 
                $data = [
                    'success' => true,
                    'data' => 'test'
                ];
              //  return new JsonModel($data); exit;
                
                if(!empty($dataPost['industry_id'])){ 
                    
                    // print_r($dataPost['industry_id']);
                     
                     $industryMapper = IndustryMapper::getInstance($this->adapter);
                     $surveyIndustryMapper = SurveyIndustryMapper::getInstance($this->adapter);
                     
                     $ok = true;
                     
                     foreach($dataPost['industry_id'] as $industryUuid) {
                        
                        // echo '$industryUuid = ' . $industryUuid ; 
                         
                         
                         $industry = $industryMapper->fetchOneByUuid($industryUuid);
                         
                        // print_r($industry);
                         //print_r($currentCompany);
                         
                         //if($industry && $industry->company_id == $currentCompany->id) {
                             $record = new SurveyIndustry();
                             $record->industry_id = $industry->id;
                             $record->survey_id = $survey->id;
                             
              
                             
                             $result = $surveyIndustryMapper->insert($record);
                             $ok = $ok && $result;
                         //}
                     }
  
                     if($ok){
                         
                     }
                 }
                 
                $data = [
                    'success' => true,
                    'data' => 'test industry'
                ];
               // return new JsonModel($data); exit;
            
                if(!empty($dataPost['language_id'])){ 
                    
                    $surveyLanguageMapper = SurveyLanguageMapper::getInstance($this->adapter);
                    
                    $ok = true;
                    
                    foreach($dataPost['language_id'] as $language_id) {
                        
                            $record = new SurveyLanguage();
                            $record->language_id = $language_id;
                            $record->survey_id = $survey->id;
                            
                                          
                            $result = $surveyLanguageMapper->insert($record);
                            $ok = $ok && $result;
                       //}
                    }
                      if($ok){
                        
                    }
                 }
                 
                $data = [
                    'success' => true,
                    'data' => 'LABEL_RECORD_ADDED'
                ];
               // return new JsonModel($data); exit;
    
               // return new JsonModel($data);
            } else {
                $messages = [];
                $form_messages = (array) $form->getMessages();
                foreach ($form_messages as $fieldname => $field_messages) {

                    $messages[$fieldname] = array_values($field_messages);
                }

                return new JsonModel([
                    'success' => false,
                    'data' => $messages
                ]);
            }
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];

            return new JsonModel($data);
        }

       return new JsonModel($data);
        
    }

    public function editAction() {
        $request = $this->getRequest();
        $currentUserPlugin = $this->plugin('currentUserPlugin');
        $currentCompany = $currentUserPlugin->getCompany();
        $currentUser = $currentUserPlugin->getUser();

        $request = $this->getRequest();
        $uuid = $this->params()->fromRoute('id');


        if (!$uuid) {
            $data = [
                'success' => false,
                'data' => 'ERROR_INVALID_PARAMETER'
            ];

            return new JsonModel($data);
        }

        $surveyMapper = SurveyMapper::getInstance($this->adapter);
        $survey = $surveyMapper->fetchOneByUuid($uuid);
       
        if (!$survey) {
            $data = [
                'success' => false,
                'data' => 'ERROR_RECORD_NOT_FOUND'
            ];

            return new JsonModel($data);
        }

        if ($survey->company_id != $currentCompany->id) {
            return new JsonModel([
                'success' => false,
                'data' => 'ERROR_UNAUTHORIZED'
            ]);
        }


        if ($request->isPost()) {
            $form = new SurveyForm($this->adapter, $currentCompany->id);
            $dataPost = $request->getPost()->toArray();
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : SurveyForm::STATUS_INACTIVE;

            $form->setData($dataPost);

            if ($form->isValid()) {
                $dataPost = (array) $form->getData();
               
                $hydrator = new ObjectPropertyHydrator();
                $hydrator->hydrate($dataPost, $survey);

                if (!$survey->status) {
                    $survey->status = Survey::STATUS_INACTIVE;
                }
               
                $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
                $surveyForm = $surveyFormMapper->fetchOneByUuid($dataPost['form_id']);
                $survey->form_id = $surveyForm->id;
                $result = $surveyMapper->update($survey);
                if($result){
                    $survey = $surveyMapper->fetchOne($survey->id);

                    $jobDescription = new SurveyJobDescription();
                    $skill = new SurveySkill();
                    $industry = new SurveyIndustry();
                    $language = new SurveyLanguage();

                    if(!empty($dataPost['location_search'])){ 

                        $surveyLocationMapper = SurveyLocationMapper::getInstance($this->adapter);
    
                        $ok = true;

                        $formatted_address = $dataPost['formatted_address'];
                        $city1 = $dataPost['city1'];
                        $city2 = $dataPost['city2'];
                        $address1 = $dataPost['address1'];
                        $address2 = $dataPost['address2'];
                        $country = $dataPost['country'];
                        $latitude = $dataPost['latitude'];
                        $longitude = $dataPost['longitude'];
                        $postal_code = $dataPost['postal_code'];
                        $state = $dataPost['state'];

                        
                        $record = new SurveyLocation();
                        $record->formatted_address = $formatted_address; 
                        $record->city1 = $city1;
                        $record->city2 = $city2;
                        $record->address1 = $address1;
                        $record->address2 = $address2;
                        $record->country = $country;
                        $record->latitude = $latitude;
                        $record->longitude = $longitude;
                        $record->postal_code = $postal_code;
                        $record->state = $state;
                        $record->survey_id = $survey->id;
                        $result = $surveyLocationMapper->update($record);
                        $ok = $ok && $result;
                           //}
                          if($ok){
    
                        }
                    }

                    if(!empty($dataPost['job_description_id'])){ 

                       // print_r($dataPost['job_description_id']);

                        $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
                        $surveyJobDescriptionMapper = SurveyJobDescriptionMapper::getInstance($this->adapter);

                        $ok = true;


                        $surveyJobDescriptionMapper->deleteBySurevy($survey->id);

                        foreach($dataPost['job_description_id'] as $jobDescriptionUuid) {
                        
                           // echo '$jobDescriptionUuid = ' . $jobDescriptionUuid ; 


                            $jobDescription = $jobDescriptionMapper->fetchOneByUuid($jobDescriptionUuid);

                           // print_r($jobDescription);
                            //print_r($currentCompany);

                            if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
                                $record = new SurveyJobDescription();
                                $record->job_description_id = $jobDescription->id;
                                $record->survey_id = $survey->id;

                            

                                $result = $surveyJobDescriptionMapper->insert($record);
                                $ok = $ok && $result;
                            }
                        }
                    
                        if($ok){

                        }
                    }

                    $data = [
                        'success' => true,
                        'data' => 'LABEL_RECORD_ADDED'
                    ];
                    //      return new JsonModel($data); 

                    if(!empty($dataPost['skill_id'])){ 

                        // print_r($dataPost['skill_id']);

                         $skillMapper = SkillMapper::getInstance($this->adapter);
                         $surveySkillMapper = SurveySkillMapper::getInstance($this->adapter);

                         $ok = true;
                         
                        $surveySkillMapper->deleteBySurevy($survey->id);
                         

                         foreach($dataPost['skill_id'] as $skillUuid) {

                            // echo '$jobCategoryUuid = ' . $jobCategoryUuid ; 


                             $skill = $skillMapper->fetchOneByUuid($skillUuid);
                        
                            // print_r($skill);
                            //print_r($currentCompany);

                            //if($skill && $skill->company_id == $currentCompany->id) {
                                $record = new SurveySkill();
                                $record->skill_id = $skill->id;
                                $record->survey_id = $survey->id;


                                $result = $surveySkillMapper->insert($record);
                                $ok = $ok && $result;
                            // }
                         }
                     
                         if($ok){

                         }
                    }
                    //      return new JsonModel($data); exit;

                    if(!empty($dataPost['industry_id'])){ 

                        // print_r($dataPost['industry_id']);

                         $industryMapper = IndustryMapper::getInstance($this->adapter);
                         $surveyIndustryMapper = SurveyIndustryMapper::getInstance($this->adapter);

                         $ok = true;

                         $surveyIndustryMapper->deleteBySurevy($survey->id);

                         foreach($dataPost['industry_id'] as $industryUuid) {

                            // echo '$industryUuid = ' . $industryUuid ; 


                             $industry = $industryMapper->fetchOneByUuid($industryUuid);

                            // print_r($industry);
                             //print_r($currentCompany);

                             //if($industry && $industry->company_id == $currentCompany->id) {
                                 $record = new SurveyIndustry();
                                 $record->industry_id = $industry->id;
                                 $record->survey_id = $survey->id;

                            

                                 $result = $surveyIndustryMapper->insert($record);
                                 $ok = $ok && $result;
                             //}
                         }
                     
                         if($ok){

                         }
                    }

                    // return new JsonModel($data); exit;
                
                    if(!empty($dataPost['language_id'])){ 

                        $surveyLanguageMapper = SurveyLanguageMapper::getInstance($this->adapter);

                        $ok = true;

                        $surveyLanguageMapper->deleteBySurevy($survey->id);

                        foreach($dataPost['language_id'] as $language_id) {

                                $record = new SurveyLanguage();
                                $record->language_id = $language_id;
                                $record->survey_id = $survey->id;


                                $result = $surveyLanguageMapper->insert($record);
                                $ok = $ok && $result;
                           //}
                        }
                          if($ok){

                        }
                     }
                }

            return new JsonModel($data);
               

                if ($result) {
                    $this->logger->info('Se edito la encuesta ' . $survey->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
                    $data = [
                        'success' => true,
                        'id' => $survey->id,
                        'action_edit' => $this->url()->fromRoute('survey/edit', ['id' => $survey->uuid]),
                        'data' => 'LABEL_RECORD_UPDATED'
                    ];
                } else {
                    $data = [
                        'success' => false,
                        'data' => $surveyMapper->getError()
                    ];
                }

                return new JsonModel($data);
            } else {
                $messages = [];
                $form_messages = (array) $form->getMessages();
                foreach ($form_messages as $fieldname => $field_messages) {
                    $messages[$fieldname] = array_values($field_messages);
                }

                return new JsonModel([
                    'success' => false,
                    'data' => $messages
                ]);
            }
        } else if ($request->isGet()) {
            $hydrator = new ObjectPropertyHydrator();
           
            $surveylenguageMapper = SurveyLanguageMapper::getInstance($this->adapter);
            $languages  = $surveylenguageMapper->fetchAllBySurveyId($survey->id);
            
            $lenguage = [];
            foreach($languages as $language)
            {
                array_push($lenguage, $language->language_id);
            }

            $surveySkillMapper = SurveySkillMapper::getInstance($this->adapter);
            $skills  = $surveySkillMapper->fetchAllBySurveyId($survey->id);
            
            $skilla = [];
            foreach($skills as $skill)
            {
                array_push($skilla, $skill->skill_id);
            }
            

            $skillMaster = [];
            foreach($skilla as $skillb)
            {
                $skillMapper = SkillMapper::getInstance($this->adapter);
                $skillm = $skillMapper->fetchOne($skillb);
                array_push($skillMaster, $skillm->uuid);
            }

            $SurveyJobDescriptionMapper = SurveyJobDescriptionMapper::getInstance($this->adapter);
            $SurveyJobDescriptions  = $SurveyJobDescriptionMapper->fetchAllBySurveyId($survey->id);
            
            $SurveyJobDescriptionA = [];
            foreach($SurveyJobDescriptions as $SurveyJobDescription)
            {
                array_push($SurveyJobDescriptionA, $SurveyJobDescription->job_description_id);
            }
           
            $SurveyJobDescriptionMaster = [];
            foreach($SurveyJobDescriptionA as $SurveyJobDescriptionB)
            {
                $JobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
                $JobDescriptionm = $JobDescriptionMapper->fetchOne($SurveyJobDescriptionB);
                array_push($SurveyJobDescriptionMaster, $JobDescriptionm->uuid);
            }

            $surveyIndustryMapper = SurveyIndustryMapper::getInstance($this->adapter);
            $industrys = $surveyIndustryMapper->fetchAllBySurveyId($survey->id);
            
            $industrya = [];
            foreach($industrys as $industry)
            {
                array_push($industrya, $industry->industry_id);
            }
            

            $industryMaster = [];
            foreach($industrya as $industryb)
            {
                $industryMapper = IndustryMapper::getInstance($this->adapter);
                $industrym = $industryMapper->fetchOne($industryb);
                array_push($industryMaster, $industrym->uuid);
            }
            

            $surveyLocationMapper = SurveyLocationMapper::getInstance($this->adapter);
            $location  = $surveyLocationMapper->fetchAllbySurveyId($survey->id);
            
            //  return new JsonModel([
            //      'success' => false,
            //      'data' => $location
            //  ]);

           
          
            $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
            $surveyForm = $surveyFormMapper->fetchOne($survey->form_id);
            // return new JsonModel([
            //     'success' => false,
            //     'data' => $SurveyJobDescriptionA
            // ]);
            $data = [
                'success' => true,
                'data' => [
                    'name' => $survey->name,
                    'form_id' => $surveyForm->uuid,
                    'target' => $survey->target,
                    'identity' => $survey->identity,
                    'since_date' => $survey->since_date,
                    'last_date' => $survey->last_date,
                    'status' => $survey->status, 
                    'lenguage_id' => $lenguage,
                    'skill_id' => $skillMaster,
                    'job_description_id' => $SurveyJobDescriptionMaster,
                    'industry_id' => $industryMaster,
                    //'location' => $location->city1,
                ]
            ];

            return new JsonModel($data);
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];

            return new JsonModel($data);
        }

        return new JsonModel($data);
    }

    public function deleteAction() {
        $request = $this->getRequest();
        $currentUserPlugin = $this->plugin('currentUserPlugin');
        $currentCompany = $currentUserPlugin->getCompany();
        $currentUser = $currentUserPlugin->getUser();

        $request = $this->getRequest();
        $uuid = $this->params()->fromRoute('id');

        if (!$uuid) {
            $data = [
                'success' => false,
                'data' => 'ERROR_INVALID_PARAMETER'
            ];

            return new JsonModel($data);
        }

        $surveyMapper = SurveyMapper::getInstance($this->adapter);
        $survey = $surveyMapper->fetchOneByUuid($uuid);
        if (!$survey) {
            $data = [
                'success' => false,
                'data' => 'ERROR_RECORD_NOT_FOUND'
            ];

            return new JsonModel($data);
        }

        if ($survey->company_id != $currentCompany->id) {
            return new JsonModel([
                'success' => false,
                'data' => 'ERROR_UNAUTHORIZED'
            ]);
        }

        if ($request->isPost()) {

            $result = $surveyMapper->delete($survey->id);
            if ($result) {
                //$this->logger->info('Se borro la encuesta ' . $survey->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);

                $data = [
                    'success' => true,
                    'data' => 'LABEL_RECORD_DELETED'
                ];
            } else {

                $data = [
                    'success' => false,
                    'data' => $surveyMapper->getError()
                ];

                return new JsonModel($data);
            }
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];

            return new JsonModel($data);
        }

        return new JsonModel($data);
    }

}