Skip to content

Commit

Permalink
Clickable Level Selector
Browse files Browse the repository at this point in the history
When the user clicks on a specific level, it navigates to the desire level, updating the both the level and lesson sides.
  • Loading branch information
ShenranChen authored and jpaten committed Feb 6, 2024
1 parent 79437b1 commit f1d8c1c
Show file tree
Hide file tree
Showing 5 changed files with 167 additions and 251 deletions.
9 changes: 8 additions & 1 deletion src/components/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@ import '../assets/WestwoodSans-Regular.ttf';

function App(): JSX.Element {
const [exerciseCount, setExerciseCount] = useState(0);
// const [completeExercises, setCompleteExercises] = useState(0);

const updateLevel = (newLevel: number): void => {
setExerciseCount(newLevel - 1);
};

if (exerciseCount == 5) {
return (
<main>
Expand All @@ -16,8 +22,9 @@ function App(): JSX.Element {
return (
<div>
<main>
<LessonSide levelNum={exerciseCount + 1} />
<LessonSide levelNum={exerciseCount + 1} updateLevel={updateLevel} />
<ExerciseSide
ExercisesNum={exerciseCount}
incrementExercise={() => setExerciseCount(exerciseCount + 1)}
/>
</main>
Expand Down
10 changes: 9 additions & 1 deletion src/components/shared/ExerciseSide.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,14 @@ import UnitCircleInput from './Exercises/UnitCircleInput';
('./Exercises/AxisExercise');

interface ExerciseSideProps {
ExercisesNum: number;
incrementExercise: () => void;
}

function ExerciseSide({ incrementExercise }: ExerciseSideProps): JSX.Element {
function ExerciseSide({
incrementExercise,
ExercisesNum,
}: ExerciseSideProps): JSX.Element {
const [completeExercises, setCompleteExercises] = useState(0);
type availableExercises = 'axis' | 'congrats' | 'graph' | 'unitcircle';

Expand All @@ -28,6 +32,10 @@ function ExerciseSide({ incrementExercise }: ExerciseSideProps): JSX.Element {
];
let curExercise;

if (completeExercises != ExercisesNum) {
setCompleteExercises(ExercisesNum);
}

if (exercises[completeExercises] == 'graph') {
curExercise = (
<div>
Expand Down
4 changes: 3 additions & 1 deletion src/components/shared/LessonSide/LessonSide.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,10 @@ import Turtle from './Turtle';

interface lessonSideProps {
levelNum: number;
updateLevel: (newCount: number) => void;
}

function LessonSide({ levelNum }: lessonSideProps): JSX.Element {
function LessonSide({ levelNum, updateLevel }: lessonSideProps): JSX.Element {
const lesson_info = LessonSideContent[levelNum] || [];
return (
<section id="lesson-side-container">
Expand All @@ -33,6 +34,7 @@ function LessonSide({ levelNum }: lessonSideProps): JSX.Element {
numLevels={6}
currentLevel={levelNum}
maxLevelReached={6}
updateLevel={updateLevel}
/>
</div>
<Footer />
Expand Down
9 changes: 9 additions & 0 deletions src/components/shared/LessonSide/LevelSelector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,20 @@ interface LevelSelectorProps {
numLevels: number;
currentLevel: number;
maxLevelReached: number;
updateLevel: (newCount: number) => void;
}

function LevelSelector({
numLevels,
currentLevel,
maxLevelReached,
updateLevel,
}: LevelSelectorProps): JSX.Element {
const handleLevelClick = (level: number): void => {
if (level <= maxLevelReached) {
updateLevel(level);
}
};
return (
<div className="selector-box">
<div className="level-selector">
Expand All @@ -23,6 +30,8 @@ function LevelSelector({
// If index is even, add a level button. Else, add a level connector.
return i % 2 == 0 ? (
<div
// key={i}
onClick={() => handleLevelClick(level)}
className={
'level-button' +
(level === currentLevel ? ' current-level' : '')
Expand Down
Loading

0 comments on commit f1d8c1c

Please sign in to comment.