/** * Método que salva as respostas do aluno no testes do capítulo * e retorna a sua nota. */ private function set_respostas() { $usrAux = new Usuarios(); $sqlTopico = new SqlTopico(); $nota = 0; $respostasAluno = array(); try { $this->filtro->initPost('topico'); $tipo = filter_input(INPUT_POST, "testePara"); $aluno = $usrAux->getAluno(false); $topico = $sqlTopico->get($this->filtro->post('topico')); if ($tipo == "capitulo") { $sqlTeste = new SqlTesteCapitulo(); } elseif ($tipo == "topico") { $sqlTeste = new SqlTesteTopico(); } else { throw new Exception("O alvo do teste não é permitido"); } $teste = $sqlTeste->porAlunoTopico($aluno, $topico); if (!$teste) { throw new Exception("O teste não foi encontrado"); } //Verificando se o aluno já realizou o teste e pode refaze-lo if (!$teste->podeRefazer()) { throw new Exception('Desculpe, mas sua nota não ' . 'permite que o teste seja refeito.'); } //Lendo as respostas $resposta = filter_input(INPUT_POST, 'resspostas', FILTER_SANITIZE_MAGIC_QUOTES); $respostasStr = substr($resposta, 0, -1); $respostas = explode(',', $respostasStr); $questoes = $teste->getQuestoes(); if (count($respostas) != count($questoes)) { throw new Exception('Ainda há questões sem resposta. ' . 'Volte e responda todas.'); } foreach ($respostas as $resp) { $par = explode('=', $resp); $respostasAluno[trim($par[0])] = trim($par[1]); foreach ($questoes as $quest) { if ($quest->getId() == $par[0]) { if ($quest->getGabarito() == $par[1]) { ++$nota; } } } } $teste->setNota((double) $nota); if (!$sqlTeste->salvaRespostas($teste, $respostasAluno)) { throw new Exception('Erro ao tentar salvar as suas respostas. ' . 'Tente novamente mais tarde.'); } if (!$sqlTeste->salvarNota($teste)) { throw new Exception('Erro ao tentar salvar a sua nota. ' . 'Tente novamente mais tarde.'); } //Gerando a resposta $tmp = new stdClass(); $tmp->nota = $teste->getNota(); $this->appendResposta($tmp); $this->statusTrue(); $this->setMensagem('Nota salva com sucesso'); } catch (SqlException $sql) { $this->setMensagem('Ocorreu um erro interno. ' . 'Tente novamente mais tarde.'); } catch (Exception $exc) { $this->setMensagem($exc->getMessage()); } $this->printResposta(); }
/** * Método que gera a página de exibição do tópico acessado na home do estudo online. * Só é exibido o tópico já dado em sala de aula. * * @param int $topicoId O código do tópico */ public function estudoOnlineTopico($topicoId) { $this->load->helper('link'); $usrAux = new Usuarios(); $sqlTurma = new SqlTurma(); $sqlTopico = new SqlTopicoAula(); $sqlAnexo = new SqlAnexosAula(); $sqlQuestao = new SqlQuestaoAula(); $sqlAcomp = new SqlAcompanhamento(); $sqlLivreto = new SqlLivretoAula(); $teste = false; try { $aluno = $usrAux->getAluno(false); $turma = $sqlTurma->deALuno($aluno)->fetch(); $topico = $sqlTopico->get((int) $topicoId); $anexos = $sqlAnexo->deTopicoECapitulo($topico); $acomp = $sqlAcomp->deTopico($topico); $livreto = $sqlLivreto->deTopico($topico); if ($acomp->getStatus() == Acompanhamento::STATUS_CONCLUIDO || $acomp->getStatus() == Acompanhamento::STATUS_REVISADO) { //Criando um teste para o tópico $sqlTeste = new SqlTesteTopico(); $teste = $sqlTeste->porAlunoTopico($aluno, $topico); if (!$teste) { //Verificando se existem questões cadastrdas para realizar o teste if ($sqlQuestao->temParaTopico($topico)) { //Tem //Gera o teste $teste = new TesteTopico(); } } } //Passando os dados para o view $this->loadPlugin('shadowbox'); $this->setData('aluno', $aluno); $this->setData('turma', $turma); $this->setData('livro', $livreto); $this->setData('topico', $topico); $this->setData('anexos', $anexos); $this->setData('teste', $teste); $this->printView(); } catch (SqlException $sql) { echo $sql->getMessage(); echo Javascript::alert('Ocorreu um erro interno. ' . 'Tente novamente mais tarde.'); // $this->close(true); } catch (Exception $exc) { echo $exc->getMessage(); // $this->close(true); } }