diff --git a/src/lib/utils/parse-lap-time.ts b/src/lib/utils/parse-lap-time.ts index 1b23ba5..13a1de6 100644 --- a/src/lib/utils/parse-lap-time.ts +++ b/src/lib/utils/parse-lap-time.ts @@ -1,21 +1,6 @@ export default (lap: number): string => { const ingestedLap = String(lap); - const placeDecimal = () => { - switch (ingestedLap.length) { - case 1: - return `0.000${ingestedLap}`; - case 2: - return `0.00${ingestedLap}`; - case 3: - return `0.0${ingestedLap}`; - case 4: - return `0.${ingestedLap}`; - default: - const decimal = ingestedLap.match(/[0-9]{4}$/); - return ingestedLap.replace(String(decimal), `.${decimal}`); - } - }; - const withDecimal = lap > 0 ? placeDecimal() : ingestedLap; + const withDecimal = lap > 0 ? String((lap / 10000).toFixed(4)) : ingestedLap; const [priorToDecimal, _] = withDecimal.split("."); if (priorToDecimal.length > 2) { const seconds = String(priorToDecimal.match(/[0-9]{2}$/)); diff --git a/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/index.astro b/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/index.astro index 208cfde..b9d0ae3 100644 --- a/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/index.astro +++ b/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/index.astro @@ -39,7 +39,8 @@ const allSeasonRaceResultsForUser = await db .where( and( eq(SubsessionRaceResults.cust_id, Number(id)), - eq(SubsessionRaceResults.car_class_id, Number(carClassId)) + eq(SubsessionRaceResults.car_class_id, Number(carClassId)), + sql`${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE", "N/A"]}` ) ); const results = allSeasonSubsessions diff --git a/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/season-summary.astro b/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/season-summary.astro index 2575913..7f215b2 100644 --- a/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/season-summary.astro +++ b/src/pages/user/[id]/season/[seasonId]/car-class/[carClassId]/season-summary.astro @@ -40,7 +40,8 @@ const allSeasonRaceResultsForUser = await db .where( and( eq(SubsessionRaceResults.cust_id, Number(id)), - eq(SubsessionRaceResults.car_class_id, Number(carClassId)) + eq(SubsessionRaceResults.car_class_id, Number(carClassId)), + sql`${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE", "N/A"]}` ) ); const subsessions = allSeasonSubsessions.filter((v) => diff --git a/src/pages/user/[id]/subsessions/by-car-class/[carClassId].astro b/src/pages/user/[id]/subsessions/by-car-class/[carClassId].astro index 81919c9..2bfe840 100644 --- a/src/pages/user/[id]/subsessions/by-car-class/[carClassId].astro +++ b/src/pages/user/[id]/subsessions/by-car-class/[carClassId].astro @@ -41,7 +41,8 @@ const subsessionRaceResults = await db .where( and( eq(SubsessionRaceResults.cust_id, Number(id)), - eq(SubsessionRaceResults.car_class_id, Number(carClassId)) + eq(SubsessionRaceResults.car_class_id, Number(carClassId)), + sql`${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE", "N/A"]}` ) ); const subsessionsWithoutResult = await db diff --git a/src/pages/user/[id]/subsessions/by-track/[trackSlug].astro b/src/pages/user/[id]/subsessions/by-track/[trackSlug].astro index eef54c6..3076151 100644 --- a/src/pages/user/[id]/subsessions/by-track/[trackSlug].astro +++ b/src/pages/user/[id]/subsessions/by-track/[trackSlug].astro @@ -80,7 +80,7 @@ const subsessionRaceResults = await db .from(SubsessionRaceResults) .where( // @ts-ignore - sql`${SubsessionRaceResults.cust_id} IS ${id} AND ${SubsessionRaceResults.subsession_id} IN ${subsessionsWithoutResult.filter((subsession) => subsession.track?.track_name === trackName && subsession.track?.config_name === configName).map((subsessionWithoutResult) => subsessionWithoutResult.subsession_id)}` + sql`${SubsessionRaceResults.cust_id} IS ${id} AND ${SubsessionRaceResults.subsession_id} IN ${subsessionsWithoutResult.filter((subsession) => subsession.track?.track_name === trackName && subsession.track?.config_name === configName).map((subsessionWithoutResult) => subsessionWithoutResult.subsession_id)} AND ${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE"]}` ); const subsessions = subsessionsWithoutResult diff --git a/src/pages/user/[id]/subsessions/by-year/[year].astro b/src/pages/user/[id]/subsessions/by-year/[year].astro index c6e9bf6..2784474 100644 --- a/src/pages/user/[id]/subsessions/by-year/[year].astro +++ b/src/pages/user/[id]/subsessions/by-year/[year].astro @@ -1,5 +1,13 @@ --- -import { db, eq, desc, sql, SubsessionRaceResults, Subsession } from "astro:db"; +import { + db, + desc, + eq, + and, + sql, + Subsession, + SubsessionRaceResults, +} from "astro:db"; import SubsessionsLayout from "$lib/layouts/subsessions.astro"; import userIds from "$lib/utils/user-ids"; export async function getStaticPaths() { @@ -39,7 +47,7 @@ const subsessionRaceResults = await db .select() .from(SubsessionRaceResults) .where( - sql`${SubsessionRaceResults.cust_id} IS ${id} AND ${SubsessionRaceResults.subsession_id} IN ${subsessionsWithoutResult.map((subsessionWithoutResult) => subsessionWithoutResult.subsession_id)}` + sql`${SubsessionRaceResults.cust_id} IS ${id} AND ${SubsessionRaceResults.subsession_id} IN ${subsessionsWithoutResult.map((subsessionWithoutResult) => subsessionWithoutResult.subsession_id)} AND ${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE"]}` ); const subsessions = subsessionsWithoutResult diff --git a/src/pages/user/[id]/subsessions/index.astro b/src/pages/user/[id]/subsessions/index.astro index 3c28749..28fb7fe 100644 --- a/src/pages/user/[id]/subsessions/index.astro +++ b/src/pages/user/[id]/subsessions/index.astro @@ -1,5 +1,13 @@ --- -import { db, desc, eq, sql, Subsession, SubsessionRaceResults } from "astro:db"; +import { + db, + desc, + eq, + and, + sql, + Subsession, + SubsessionRaceResults, +} from "astro:db"; import SubsessionsLayout from "$lib/layouts/subsessions.astro"; import userIds from "$lib/utils/user-ids"; export function getStaticPaths() { @@ -11,7 +19,12 @@ const seoDescription = `Subsessions page for user ID: ${id}`; const subsessionRaceResults = await db .select() .from(SubsessionRaceResults) - .where(eq(SubsessionRaceResults.cust_id, Number(id))); + .where( + and( + eq(SubsessionRaceResults.cust_id, Number(id)), + sql`${SubsessionRaceResults.simsession_name} IN ${["RACE", "FEATURE", "N/A"]}` + ) + ); const subsessionsWithoutResult = await db .select() .from(Subsession)