Skip to content

Commit

Permalink
unitcircle validate input(#88)
Browse files Browse the repository at this point in the history
  • Loading branch information
rakilkim authored and jpaten committed Feb 28, 2024
1 parent c09035e commit af07904
Show file tree
Hide file tree
Showing 4 changed files with 172 additions and 75 deletions.
7 changes: 5 additions & 2 deletions src/components/shared/ExerciseSide.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -147,8 +147,8 @@ ExerciseSideProps): JSX.Element {
<div>
<UnitCircleExercise
turtleAngle={1}
markers={['0\xB0', '', '90\xB0', '', '']}
labels={['A', 'C', 'B', '', '']}
markers={['-90\xB0', '-45\xB0', '0\xB0', '45\xB0', '90\xB0']}
labels={['A', 'C', '', 'B', '']}
/>
<UnitCircleInput
nextExercise={() => {
Expand All @@ -157,6 +157,9 @@ ExerciseSideProps): JSX.Element {
incrementExercise();
return;
}}
markers={[['-90\xB0', '-45\xB0', '0\xB0', '45\xB0', '90\xB0']]}
labels={[['A', 'C', '', 'B', '']]}
directions={[['left', 'right', '', 'right', '']]}
/>
</div>
</div>
Expand Down
68 changes: 35 additions & 33 deletions src/components/shared/Exercises/UnitCircleExercise.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,10 @@ function UnitCircleExercise({
labels,
}: UnitCircleProps): JSX.Element {
const rotateString = turtleAngle + 'deg';
const angleBetweenTicks = Math.PI / (labels.length - 3);
const angleBetweenTicks = Math.PI / (labels.length - 1);
let curAngle = 0 - angleBetweenTicks;
const cursorTicks = Math.PI / (labels.length - 1);
let cursorAngle = 0 - cursorTicks;
let curAngle = 0 - angleBetweenTicks;
const scaleCursor = 'scale(1.5)';
return (
<div className="circle-container">
Expand All @@ -38,48 +38,50 @@ function UnitCircleExercise({
className="circle-exercise"
style={{
left: `${
(1 - Math.cos(curAngle)) * 40 +
(1 - Math.cos(curAngle)) * 31 + //middle right and left
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? -12
: 19
: -12)
? 17 //middle
: 19 //left
: 14) //right
}%`,
bottom: `${
Math.sin(curAngle) * 50 +
Math.sin(curAngle) * 53 + //middle right and left
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? 13
: 25
: 63)
? 28 //middle
: 25 //left
: 25) //right
}%`,
}}
>
{element}
</div>
<div
className="circle-label"
style={{
left: `${
(1 - Math.cos(curAngle)) * 45 +
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? 2
: 49
: -15)
}%`,
bottom: `${
Math.sin(curAngle) * 50 +
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? 2
: 83
: 26)
}%`,
}}
>
{markers[idx]}
</div>
{labels[idx] === '' ? (
<div
className="circle-label"
style={{
left: `${
(1 - Math.cos(curAngle)) * 30 + //middle left and right
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? 19 //middle
: 20 //left
: 15) //right
}%`,
bottom: `${
Math.sin(curAngle) * 55 + //middle left and right
(curAngle <= Math.PI / 2
? curAngle == Math.PI / 2
? 30 //middle
: 25 //left
: 25) //right
}%`,
}}
>
{markers[idx]}
</div>
) : null}

<img
src={Cursor}
Expand Down
160 changes: 123 additions & 37 deletions src/components/shared/Exercises/UnitCircleInput.tsx
Original file line number Diff line number Diff line change
@@ -1,51 +1,137 @@
//import { useState } from 'react';
import { useState } from 'react';
import '../../../styles/Exercises/UnitCircleInput.scss';

interface UnitCircleInputProps {
nextExercise: () => void;
markers: string[][];
labels: string[][];
directions: string[][];
}

function UnitCircleInput({ nextExercise }: UnitCircleInputProps): JSX.Element {
return (
<div id="unitcircle-question-container">
<div id="unitcircle-check-question">
Type the correct numbers into the blanks below!
</div>
interface CircleQuestion {
label: string;
answer: string; // Should change to being strings
direction: string;
id: number; //This sucks lol
}

<div id="unitcircle-check-question">
{' '}
<i>A</i> = left
function UnitCircleInput({
nextExercise,
markers,
labels,
directions,
}: UnitCircleInputProps): JSX.Element {
function MakeQuestion({ label, id, direction }: CircleQuestion): JSX.Element {
const handleChange = (event: { target: { value: string } }) => {
setText(event.target.value, id);
};
/* lines 25-35, try to get component to look like this */
return (
<div id="unitcircle-question-container">
<p id="unitcircle-check-question">
{label} = {direction}{' '}
</p>
<input
type="text"
className="unitcircle-check-box"
//onChange={handleChange}
//value={inputText[id]}
onChange={handleChange}
value={inputText[id]}
/>
<p>
{' '}
<i>B</i> = right
<input
type="text"
className="unitcircle-check-box"
//onChange={handleChange}
//value={inputText[id]}
/>
</p>
<p>
{' '}
<i>C</i> = right
<input
type="text"
className="unitcircle-check-box"
//onChange={handleChange}
//value={inputText[id]}
/>
</p>
<div id="unitcircleinput-check-button-container">
<button id="unitcircleinput-check-button" onClick={nextExercise}>
Check
</button>
</div>
</div>
);
}

function checkAnswer() {
// Invoked to check answers and switch to the next question or set the answer wrong
for (let i = 0; i < answers[counter].length; i++) {
if (inputText[i] != answers[counter][i]) {
setWrong(true);
return;
}
}
if (counter == questionLabels.length - 1) {
setIsDone(true);
//setIsComplete(true);
nextExercise();
return;
}
setCounter(counter + 1);
setWrong(false);
setInputText(startInputStrings);
nextExercise();
}

const answers: string[][] = [];
const questionLabels: string[][] = [];
const questionDirections: string[][] = [];
for (let i = 0; i < markers.length; i++) {
const currentAnswers = [];
const currentLabels = [];
const currentDirections = [];
const length = markers[i].length;
for (let j = 0; j < length; j++) {
if (labels[i][j] !== '') {
currentAnswers.push(markers[i][j].slice(0, -1));
currentLabels.push(labels[i][j]);
currentDirections.push(directions[i][j]);
}
}
answers.push(currentAnswers);
questionLabels.push(currentLabels);
questionDirections.push(currentDirections);
}

function wrongMessage(isWrong: boolean) {
if (isWrong) {
return "That's not quite right. Try again!";
} else {
return;
}
}

const [counter, setCounter] = useState(0);
const [wrong, setWrong] = useState(false);
const [isDone, setIsDone] = useState(false);
const questions = [];
const startInputStrings: string[] = [];
for (let i = 0; i < questionLabels[counter].length; i++) {
startInputStrings.push('');
}
const [inputText, setInputText] = useState<string[]>(startInputStrings);
function setText(text: string, id: number) {
const tempInputStrings = [...inputText];
tempInputStrings[id] = text;
setInputText(tempInputStrings);
}

if (!isDone) {
for (let i = 0; i < questionLabels[counter].length; i++) {
questions.push({
label: questionLabels[counter][i],
direction: questionDirections[counter][i],
answer: answers[counter][i],
id: i,
});
}
} else {
return <h2>Done!</h2>;
}

//console.log(questionLabels[counter]);
const questionOutput = questions.map(MakeQuestion);
return (
<div className="unitcircle-question-container">
<div id="unitcircle-question">
Type the correct numbers into the blanks below!
</div>
<div className="unitcircle-question-box">{questionOutput}</div>
<div className="unitcircle-wrong-box">
<h3 id="unitcircle-check-wrong">&nbsp;{wrongMessage(wrong)}&nbsp;</h3>
</div>
<div className="unitcircleinput-check-button-container">
<button id="unitcircleinput-check-button" onClick={checkAnswer}>
Check
</button>
</div>
</div>
);
Expand Down
12 changes: 9 additions & 3 deletions src/styles/Exercises/UnitCircleInput.scss
Original file line number Diff line number Diff line change
Expand Up @@ -21,20 +21,25 @@
flex-direction: column;
}

#unitcircle-question {
@include font-styles();
margin-bottom: 2vh;
margin-left: 2vh;
}

#unitcircle-question-container {
align-items: baseline;
display: flex;
flex-direction: column;
margin-bottom: -15px;
margin-top: -15px;
padding-left: 8%;
padding-left: 0;
}

#unitcircle-check-question {
@include font-styles();
font-size: calc(13px + 1vw);
font-style: normal;
margin-bottom: 2vh;
margin-bottom: 4vh;
margin-left: auto;
margin-right: auto;
}
Expand All @@ -47,6 +52,7 @@
font-family: Cascadia Code, sans-serif;
font-size: calc(16px + 1vw);
height: 18pt;
margin-bottom: 0;
margin-left: 2vh;
size: 64pt;
text-align: center;
Expand Down

0 comments on commit af07904

Please sign in to comment.