Rev 16768 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?php
/**
*
* Controlador: Mis Perfiles
*
*/
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\QueryMapper;
use LeadersLinked\Model\CompanyMicrolearningQuiz;
use LeadersLinked\Mapper\CompanyMicrolearningQuizMapper;
use LeadersLinked\Form\QuizCreateOrEditForm;
use Laminas\Hydrator\ObjectPropertyHydrator;
use LeadersLinked\Mapper\CompanyMicrolearningQuestionMapper;
use LeadersLinked\Mapper\CompanyMicrolearningAnswerMapper;
use LeadersLinked\Model\CompanyMicrolearningQuestion;
use LeadersLinked\Model\CompanyMicrolearningAnswer;
use LeadersLinked\Mapper\CompanyMicrolearningSlideMapper;
class MicrolearningQuizController 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');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
$request = $this->getRequest();
if($request->isGet()) {
$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) {
$acl = $this->getEvent()->getViewModel()->getVariable('acl');
$allowQuestion = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/questions');
$allowAdd = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/add');
$allowEdit = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/edit');
$allowDelete = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/delete');
$allowCopy = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/copy');
$allowCheck = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/check');
$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';
}
$companyMicrolearningSlideMapper = CompanyMicrolearningSlideMapper::getInstance($this->adapter);
$companyMicrolearningQuizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
$paginator = $companyMicrolearningQuizMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);
$items = [];
foreach($paginator as $record)
{
$slides = $companyMicrolearningSlideMapper->fetchTotalCountByCompanyIdQuizId($currentCompany->id, $record->id);
$status_description = '';
switch ($record->status)
{
case CompanyMicrolearningQuiz::STATUS_ACTIVE :
$status_description = 'LABEL_ACTIVE';
break;
case CompanyMicrolearningQuiz::STATUS_INACTIVE :
$status_description = 'LABEL_INACTIVE';
break;
}
$check_description = '';
switch($record->check)
{
case CompanyMicrolearningQuiz::CHECK_OK :
$check_description = 'LABEL_WITHOUT_ERRORS';
break;
case CompanyMicrolearningQuiz::CHECK_WRONG :
$check_description = 'LABEL_WITH_ERRORS';
break;
case CompanyMicrolearningQuiz::CHECK_PENDING :
$check_description = 'LABEL_PENDING';
break;
}
$params = [
'quiz_id' => $record->uuid
];
$item = [
'name' => $record->name,
'details' => [
'status' => $status_description,
'check' => $check_description,
'points' => $record->points,
'max_time' => $record->max_time,
'slides' => $slides,
],
'actions' => [
'link_question' => $allowQuestion ? $this->url()->fromRoute('microlearning/content/quizzes/questions', $params) : '',
'link_edit' => $allowEdit ? $this->url()->fromRoute('microlearning/content/quizzes/edit', $params) : '',
'link_delete' => $allowDelete ? $this->url()->fromRoute('microlearning/content/quizzes/delete', $params) : '',
'link_copy' => $allowCopy ? $this->url()->fromRoute('microlearning/content/quizzes/copy', $params) : '',
'link_check' => $allowCheck ? $this->url()->fromRoute('microlearning/content/quizzes/check', $params) : '',
],
];
array_push($items, $item);
}
$data = [];
$data['items'] = $items;
$data['total'] = $paginator->getTotalItemCount();
if($allowAdd) {
$data['link_add'] = $this->url()->fromRoute('microlearning/content/quizzes/add');
} else {
$data['link_add'] = '';
}
$response = [
'success' => true,
'data' => $data
];
return new JsonModel($response);
} else {
$form = new QuizCreateOrEditForm();
$this->layout()->setTemplate('layout/layout-backend.phtml');
$viewModel = new ViewModel();
$viewModel->setTemplate('leaders-linked/microlearning-quizzes/index.phtml');
$viewModel->setVariables([
'form' => $form,
]);
return $viewModel ;
}
} else {
return new JsonModel([
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
]);
}
}
public function addAction()
{
$request = $this->getRequest();
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
if($request->isPost()) {
$formCreateOrEdit = new QuizCreateOrEditForm();
$formCreateOrEdit->setData($request->getPost()->toArray());
if($formCreateOrEdit->isValid()) {
$dataPost = (array) $formCreateOrEdit->getData();
$hydrator = new ObjectPropertyHydrator();
$quiz = new CompanyMicrolearningQuiz();
$hydrator->hydrate($dataPost, $quiz);
$quiz->company_id = $currentCompany->id;
$quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
if($quizMapper->insert($quiz)) {
$this->logger->info('Se agrego el quiz ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
$data = [
'success' => true,
'data' => 'LABEL_RECORD_ADDED'
];
} else {
$data = [
'success' => false,
'data' => $quizMapper->getError()
];
}
return new JsonModel($data);
} else {
$messages = [];
$form_messages = (array) $formCreateOrEdit->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);
}
/**
*
* Borrar un perfil excepto el público
* @return \Laminas\View\Model\JsonModel
*/
public function deleteAction()
{
$request = $this->getRequest();
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
$quiz_id = $this->params()->fromRoute('quiz_id');
$quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
$quiz = $quizMapper->fetchOneByUuid($quiz_id);
if(!$quiz) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_FORM_NOT_FOUND'
]);
}
if($quiz->company_id != $currentCompany->id) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_UNAUTHORIZED'
]);
}
if($request->isPost()) {
$result = $quizMapper->delete($quiz);
if($result) {
$this->logger->info('Se borro el cuestionario : ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
$data = [
'success' => true,
'data' => 'LABEL_RECORD_DELETED'
];
} else {
$data = [
'success' => false,
'data' => $quizMapper->getError()
];
return new JsonModel($data);
}
} 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');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
$quiz_id = $this->params()->fromRoute('quiz_id');
$quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
$quiz = $quizMapper->fetchOneByUuid($quiz_id);
if(!$quiz) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_FORM_NOT_FOUND'
]);
}
if($quiz->company_id != $currentCompany->id) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_UNAUTHORIZED'
]);
}
if($request->isGet()) {
$data = [
'success' => true,
'data' => [
'name' => $quiz->name,
'text' => $quiz->text,
'status' => $quiz->status,
'points' => $quiz->points,
'minimum_points_required' => $quiz->minimum_points_required,
'max_time' => $quiz->max_time,
'failed' => $quiz->failed,
]
];
return new JsonModel($data);
}
else if($request->isPost()) {
$formCreateOrEdit = new QuizCreateOrEditForm();
$formCreateOrEdit->setData($request->getPost()->toArray());
if($formCreateOrEdit->isValid()) {
$dataPost = (array) $formCreateOrEdit->getData();
$hydrator = new ObjectPropertyHydrator();
$hydrator->hydrate($dataPost, $quiz);
$quiz->check = CompanyMicrolearningQuiz::CHECK_PENDING;
if($quizMapper->update($quiz)) {
$this->logger->info('Se edito el cuestionario ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
$data = [
'success' => true,
'data' => 'LABEL_RECORD_UPDATED'
];
} else {
$data = [
'success' => false,
'data' => $quizMapper->getError()
];
}
return new JsonModel($data);
} else {
$messages = [];
$form_messages = (array) $formCreateOrEdit->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 checkAction()
{
$request = $this->getRequest();
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
$quiz_id = $this->params()->fromRoute('quiz_id');
$quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
$quiz = $quizMapper->fetchOneByUuid($quiz_id);
if(!$quiz) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_QUIZ_NOT_FOUND'
]);
}
if($quiz->company_id != $currentCompany->id) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_UNAUTHORIZED'
]);
}
if($request->isPost()) {
$questionMapper = CompanyMicrolearningQuestionMapper::getInstance($this->adapter);
$answerMapper = CompanyMicrolearningAnswerMapper::getInstance($this->adapter);
$total_wrong_questions = 0;
$total_point_questions = 0;
$questions = $questionMapper->fetchAllByQuizId($quiz->id);
foreach($questions as $question)
{
$total_point_questions += $question->points;
$answers = $answerMapper->fetchAllByQuizIdAndQuestionId($question->quiz_id, $question->id);
if($question->type == CompanyMicrolearningQuestion::TYPE_SINGLE_SELECTION ) {
$number_correct = 0;
$number_incorrect = 0;
foreach($answers as $answer)
{
if($answer->correct == CompanyMicrolearningAnswer::CORRECT_YES) {
$number_correct++;
} else {
$number_incorrect++;
}
}
if($number_correct == 1 && $number_incorrect >= 1 ) {
$check_question = CompanyMicrolearningQuestion::CHECK_OK;
} else {
$check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
}
} else if($question->type == CompanyMicrolearningQuestion::TYPE_MULTIPLE_SELECTION ) {
$number_correct = 0;
$number_incorrect = 0;
$points = 0;
foreach($answers as $answer)
{
$points += $answer->points;
if($answer->correct == CompanyMicrolearningAnswer::CORRECT_YES) {
$number_correct++;
} else {
$number_incorrect++;
}
}
if($number_correct < 2 || $number_incorrect < 1) {
$check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
} else {
if($points == $question->points) {
$check_question = CompanyMicrolearningQuestion::CHECK_OK;
} else {
$check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
}
}
} else {
$check_question = CompanyMicrolearningQuestion::CHECK_OK;
}
if($check_question == CompanyMicrolearningQuestion::CHECK_WRONG) {
$quiz->check = CompanyMicrolearningQuiz::CHECK_WRONG;
}
$question->check = $check_question;
$questionMapper->update($question);
}
if($quiz->check == CompanyMicrolearningQuiz::CHECK_PENDING) {
$quiz->check = $quiz->points == $total_point_questions ? CompanyMicrolearningQuiz::CHECK_OK : CompanyMicrolearningQuiz::CHECK_WRONG;
}
$quizMapper->update($quiz);
if($quiz->check == CompanyMicrolearningQuiz::CHECK_OK) {
$this->logger->info('Se comprobo el cuestionario ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
$data = [
'success' => true,
'data' => 'LABEL_QUIZ_CHECK_OK'
];
} else {
$messages = [];
if($total_wrong_questions == 1) {
array_push($messages, '1 LABEL_QUESTION_CHECK_WRONG ');
} else if($total_wrong_questions > 1) {
array_push($messages, $total_wrong_questions . 'LABEL_QUESTIONS_CHECK_WRONG ');
}
if(!$messages) {
$messages = 'LABEL_QUIZ_CHECK_WRONG';
} else {
$messages = implode(', ', $messages);
}
$data = [
'success' => false,
'data' => $messages
];
}
} else {
$data = [
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
];
return new JsonModel($data);
}
return new JsonModel($data);
}
public function copyAction()
{
$request = $this->getRequest();
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentCompany = $currentUserPlugin->getCompany();
$quiz_id = $this->params()->fromRoute('quiz_id');
$quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
$quiz = $quizMapper->fetchOneByUuid($quiz_id);
if(!$quiz) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_QUIZ_NOT_FOUND'
]);
}
if($quiz->company_id != $currentCompany->id) {
return new JsonModel([
'success' => false,
'data' => 'ERROR_UNAUTHORIZED'
]);
}
if($request->isPost()) {
$quizClone = new CompanyMicrolearningQuiz();
$quizClone->check = CompanyMicrolearningQuiz::CHECK_PENDING;
$quizClone->status = CompanyMicrolearningQuiz::STATUS_INACTIVE;
$quizClone->company_id = $quiz->company_id;
$quizClone->failed = $quiz->failed;
$quizClone->name = 'COPIA - ' . $quiz->name;
$quizClone->max_time = $quiz->max_time;
$quizClone->minimum_points_required = $quiz->minimum_points_required;
$quizClone->points = $quiz->points;
$quizClone->text = $quiz->text;
if($quizMapper->insert($quizClone)) {
$this->logger->info('Se copio el quiz ' . $quizClone->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
$questionMapper = CompanyMicrolearningQuestionMapper::getInstance($this->adapter);
$answerMapper = CompanyMicrolearningAnswerMapper::getInstance($this->adapter);
$questions = $questionMapper->fetchAllByQuizId($quiz->id);
foreach($questions as $question)
{
$questionClone = new CompanyMicrolearningQuestion();
$questionClone->check = CompanyMicrolearningQuestion::CHECK_PENDING;
$questionClone->company_id = $question->company_id;
$questionClone->maxlength = $question->maxlength;
$questionClone->points = $question->points;
$questionClone->quiz_id = $quizClone->id;
$questionClone->text = $question->text;
$questionClone->type = $question->type;
if($questionMapper->insert($questionClone)) {
$answers = $answerMapper->fetchAllByQuizIdAndQuestionId($question->quiz_id, $question->id);
foreach($answers as $answer)
{
$answerClone = new CompanyMicrolearningAnswer();
$answerClone->company_id = $answer->company_id;
$answerClone->correct = $answer->correct;
$answerClone->points = $answer->points;
$answerClone->question_id = $questionClone->id;
$answerClone->quiz_id = $quizClone->id;
$answerClone->text = $answer->text;
if(!$answerMapper->insert($answerClone)) {
$response = [
'success' => false,
'data' => $answerMapper->getError()
];
}
}
} else {
$response = [
'success' => false,
'data' => $questionMapper->getError()
];
}
}
$response = [
'success' => true,
'data' => 'LABEL_RECORD_ADDED'
];
} else {
$response = [
'success' => false,
'data' => $quizMapper->getError()
];
}
} else {
$response = [
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
];
}
return new JsonModel($response);
}
}