From e2e801329f48b9ee9fe5e162ed551bed67d37f14 Mon Sep 17 00:00:00 2001 From: Cris Lom <36197748+Lombardoc4@users.noreply.github.com> Date: Sun, 4 Feb 2024 16:47:31 -0500 Subject: [PATCH] FRON-10 Document site url endpoints (#18) * chore: FRON-10 main filter url navigation * chore: FRON-10 adding placeholder pages --- README.md | 14 +++++++ .../[location]/[driver]/[session]/page.tsx | 7 ++++ .../[driver]/[session]/telemetry/page.tsx | 3 ++ src/app/[season]/[location]/[driver]/page.tsx | 3 ++ src/app/[season]/[location]/page.tsx | 22 ++--------- src/app/ui/MainFilters.tsx | 27 +++++++++----- src/atoms/drivers.tsx | 19 ++++++++-- src/atoms/races.tsx | 2 +- src/atoms/results.tsx | 37 ++++++++++--------- src/atoms/sessions.tsx | 4 +- src/lib/utils.tsx | 10 +++-- 11 files changed, 91 insertions(+), 57 deletions(-) create mode 100644 src/app/[season]/[location]/[driver]/[session]/page.tsx create mode 100644 src/app/[season]/[location]/[driver]/[session]/telemetry/page.tsx create mode 100644 src/app/[season]/[location]/[driver]/page.tsx diff --git a/README.md b/README.md index b909354..0cbf0fd 100644 --- a/README.md +++ b/README.md @@ -15,6 +15,7 @@ Table of Contents: - [Contribution Guidelines](#contribution-guidelines) - [Tests](#tests) - [Deployment](#deployment) +- [URL Structure](#url-structure) - [Resources](#resources) ## Setting up the project @@ -97,6 +98,19 @@ This project is using [conventional commits](https://www.conventionalcommits.org // TODO [vercel](https://vercel.com/) +## URL Structure + +``` +`/` +├── Results of past seasons +└──`[season]` -> year + └── `[location]` -> race location of race in season + └── `[session]` -> session of race + └── `[driver]` -> driverId in race session + ├── `/` -> ??? + └── `/telemetry` -> ??? +``` + ## Resources Key tools in use: `daisy-ui`, `tailwindcss`, `react`, `nextjs`, `pnpm`, `cypress` diff --git a/src/app/[season]/[location]/[driver]/[session]/page.tsx b/src/app/[season]/[location]/[driver]/[session]/page.tsx new file mode 100644 index 0000000..5583775 --- /dev/null +++ b/src/app/[season]/[location]/[driver]/[session]/page.tsx @@ -0,0 +1,7 @@ +export default function SessionPage({ + params, +}: { + params: { session: string }; +}) { + return

{params.session}

; +} diff --git a/src/app/[season]/[location]/[driver]/[session]/telemetry/page.tsx b/src/app/[season]/[location]/[driver]/[session]/telemetry/page.tsx new file mode 100644 index 0000000..5103797 --- /dev/null +++ b/src/app/[season]/[location]/[driver]/[session]/telemetry/page.tsx @@ -0,0 +1,3 @@ +export default function TelemetryPage() { + return

Telemetry

; +} diff --git a/src/app/[season]/[location]/[driver]/page.tsx b/src/app/[season]/[location]/[driver]/page.tsx new file mode 100644 index 0000000..f89aa92 --- /dev/null +++ b/src/app/[season]/[location]/[driver]/page.tsx @@ -0,0 +1,3 @@ +export default function DriverPage({ params }: { params: { driver: string } }) { + return

{params.driver}

; +} diff --git a/src/app/[season]/[location]/page.tsx b/src/app/[season]/[location]/page.tsx index 1bd34b6..3bc2d8b 100644 --- a/src/app/[season]/[location]/page.tsx +++ b/src/app/[season]/[location]/page.tsx @@ -25,34 +25,18 @@ export default function ResultsPage({ const [races] = useAtom(seasonRacesAtom); const [_, setRace] = useAtom(raceAtom); + // On Mount we need to update the race to use the url params useEffect(() => { setRace( - races.find((race) => race.Location === params.location) || 'All Races', + races.find((race) => race.Location.toLowerCase() === params.location) || + 'All Races', ); }, [races, params.location, setRace]); - // useAtom(fetchStandings); - // useAtom(fetchSessionResults); useAtom(fetchSessionResults); - // const [constructorStandings] = useAtom(constructorStandingsAtom); - // const [driverStandings] = useAtom(driverStandingsAtom); const [drivers] = useAtom(allDriversAtom); const [constructors] = useAtom(allConstructorAtom); - // const [driverStandings] = useAtom(driverStandingsAtom); - - // const [, handleRaceChange] = useAtom(handleRaceChangeAtom); - // const [allRaces] = useAtom(seasonRacesAtom) - - // if (!params) return <>; - // Get all - - // if (allRaces && allRaces.length > 0) { - // console.log('all races', allRaces[parseInt(params.round) - 1]) - - // handleRaceChange(allRaces[parseInt(params.round) - 1]); - // } - return (
{ const [, handleResultsSubmit] = useAtom(handleMainFilterSubmit); // useAtom(fetchSeasons); - // useAtom(toggleTelemetryDisableAtom); + useAtom(toggleTelemetryDisableAtom); // useAtom(fetchSessionResults); const changePath = (url: string) => { @@ -51,9 +54,10 @@ export const MainFilters = () => { if (pathname !== '/') router.push(url); }; - const handleSubmit = () => { + const handleSubmit = (e: React.MouseEvent) => { + const telemetry = (e.target as HTMLButtonElement).innerHTML === 'Telemetry'; const url = handleResultsSubmit(); - router.push('/' + url); + router.push('/' + url + (telemetry && '/telemetry')); }; return ( @@ -70,10 +74,11 @@ export const MainFilters = () => {
-