From 9197d8a9aedb9660963f4496c7b0a91193a043f8 Mon Sep 17 00:00:00 2001 From: Mister-Mario Date: Sat, 2 Mar 2024 21:25:31 +0100 Subject: [PATCH] Fixed logic, but cannot handle server errors, like having the server down --- .../main/java/com/wiq/wiq/CustomConfig.java | 2 +- .../java/com/wiq/wiq/model/TestClass.java | 2 +- .../questionView/QuestionGenerator.js | 29 +++++++------ .../components/questionView/QuestionView.js | 42 ++++++++++++++----- 4 files changed, 50 insertions(+), 25 deletions(-) diff --git a/backend/wiq/src/main/java/com/wiq/wiq/CustomConfig.java b/backend/wiq/src/main/java/com/wiq/wiq/CustomConfig.java index 8dfd6dea..0ae372a0 100644 --- a/backend/wiq/src/main/java/com/wiq/wiq/CustomConfig.java +++ b/backend/wiq/src/main/java/com/wiq/wiq/CustomConfig.java @@ -10,7 +10,7 @@ public class CustomConfig implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") - .allowedOrigins("http://localhost:5500") + .allowedOrigins("http://localhost:3000") .allowedMethods("GET", "POST", "PUT", "DELETE") .allowedHeaders("*"); } diff --git a/backend/wiq/src/main/java/com/wiq/wiq/model/TestClass.java b/backend/wiq/src/main/java/com/wiq/wiq/model/TestClass.java index 421b8eb8..f66f75d3 100644 --- a/backend/wiq/src/main/java/com/wiq/wiq/model/TestClass.java +++ b/backend/wiq/src/main/java/com/wiq/wiq/model/TestClass.java @@ -24,7 +24,7 @@ public String createJSON() { answers0.put("correct", "correct answer"); // Crear un arreglo de respuestas incorrectas - String[] wrongAnswers = {"wrong1", "wrong2"}; + String[] wrongAnswers = {"wrong1", "wrong2", "wrong3"}; answers0.put("wrong", wrongAnswers); // Agregar las respuestas al objeto "0" diff --git a/webapp/src/components/questionView/QuestionGenerator.js b/webapp/src/components/questionView/QuestionGenerator.js index 16f1fdae..42049447 100644 --- a/webapp/src/components/questionView/QuestionGenerator.js +++ b/webapp/src/components/questionView/QuestionGenerator.js @@ -6,19 +6,22 @@ class QuestionGenerator{ } - generateQuestions(){ - //Deberíamos recoger el json - fetch(this.apiUrl) - .then(response => response.json()) - .then(receivedQuestions => { - let i = 0; - var questions = []; - for(const question in receivedQuestions){//To have a condition, no legth or size - questions[i] = new Question(receivedQuestions[i]); - i += 1; - } - return questions; - }); + async generateQuestions() { + try { + const response = await fetch(this.apiUrl); + const receivedQuestions = await response.json(); + + let i = 0; + var questions = []; + for (const question in receivedQuestions) { + questions[i] = new Question(receivedQuestions[i]); + i += 1; + } + console.log(questions); + return questions; + } catch (error) { + throw new Error(error); + } } } diff --git a/webapp/src/components/questionView/QuestionView.js b/webapp/src/components/questionView/QuestionView.js index b151ad88..302a5e35 100644 --- a/webapp/src/components/questionView/QuestionView.js +++ b/webapp/src/components/questionView/QuestionView.js @@ -1,37 +1,59 @@ import Question from './Question'; import QuestionGenerator from './QuestionGenerator'; -import { useState } from 'react'; +import { useEffect, useState } from 'react'; -const questionGenerator = new QuestionGenerator(); -var questions = questionGenerator.generateQuestions(); function QuestionView(){ - const [numQuestion, setnumQuestion] = useState(0); + const questionGenerator = new QuestionGenerator(); + const [numQuestion, setnumQuestion] = useState(-1); + const [questions, setQuestions] = useState([]); + + const generateQuestions = async (numQuestion) => { + if (numQuestion < 0) { + try { + var generatedQuestions = await questionGenerator.generateQuestions(); + setQuestions(generatedQuestions); + setnumQuestion(0); + } catch (error) { + //Como hacer que funcione esto + console.log(error.response.data.error); + } + + } + } function handleClick(){ setnumQuestion(numQuestion + 1); } - return (
+ + useEffect(() => {generateQuestions(numQuestion)}, []); + + return ( +
{/*Nav*/} - + {numQuestion >= 0 ? + : +

Please Wait a bit

} +
); } -function QuestionComponent({numQuestion, handleClick}){ +function QuestionComponent({questions, numQuestion, handleClick}){ return (
-

questions[numQuestion].getQuestion()

+

{questions[numQuestion].getQuestion()}

{questions[numQuestion].getAnswers().map((item, index) => ( ))} +

Question counter: {numQuestion}

); } -function Answer({text, handleClick}){ +function Answer({text, onClick}){ return ( - + ); }