Adde speed uhc mastery stats
This commit is contained in:
@@ -1,7 +1,57 @@
|
||||
import { MODES, TITLES } from "@/data/hypixel/speeduhc"
|
||||
import { MASTERIES, MODES, TITLES } from "@/data/hypixel/speeduhc"
|
||||
import { NonNullStats } from "@/lib/schema/player"
|
||||
import { devide } from "../general"
|
||||
|
||||
export function getSpeedUHCMasteryName(modeId: Exclude<typeof MASTERIES[number]["id"], ""> | "all") {
|
||||
if (modeId === "all") {
|
||||
return MASTERIES.find(m => m.id === "")!.name
|
||||
}
|
||||
|
||||
return MASTERIES.find(m => m.id === modeId)!.name
|
||||
}
|
||||
|
||||
export function getSpeedUHCBestMastery(stats: NonNullable<NonNullStats["SpeedUHC"]>) {
|
||||
let bestMastery: typeof MASTERIES[number]["id"] | null = null
|
||||
let maxGames = 0
|
||||
|
||||
for (const mode of MASTERIES) {
|
||||
if (mode.id === "") continue
|
||||
|
||||
const wins = stats[`wins_${mode.id}`]
|
||||
const losses = stats[`losses_${mode.id}`]
|
||||
const totalGames = wins + losses
|
||||
|
||||
if (totalGames > maxGames) {
|
||||
maxGames = totalGames
|
||||
bestMastery = mode.id
|
||||
}
|
||||
}
|
||||
|
||||
return bestMastery
|
||||
}
|
||||
|
||||
export function getSpeedUHCMasteryStats(id: Exclude<typeof MASTERIES[number]["id"], ""> | "all", stats: NonNullable<NonNullStats["SpeedUHC"]>) {
|
||||
if (id === "all") {
|
||||
return [
|
||||
stats.kills,
|
||||
stats.deaths,
|
||||
devide(stats.kills, stats.deaths),
|
||||
stats.wins,
|
||||
stats.losses,
|
||||
devide(stats.wins, stats.losses)
|
||||
]
|
||||
}
|
||||
|
||||
return [
|
||||
stats[`kills_${id}`],
|
||||
stats[`deaths_${id}`],
|
||||
devide(stats[`kills_${id}`], stats[`deaths_${id}`]),
|
||||
stats[`wins_${id}`],
|
||||
stats[`losses_${id}`],
|
||||
devide(stats[`wins_${id}`], stats[`losses_${id}`])
|
||||
]
|
||||
}
|
||||
|
||||
export function getSpeedUHCModeName(modeId: Exclude<typeof MODES[number]["id"], ""> | "all_modes") {
|
||||
if (modeId === "all_modes") {
|
||||
return MODES.find(m => m.id === "")!.name
|
||||
@@ -32,25 +82,13 @@ export function getSpeedUHCBestMode(stats: NonNullable<NonNullStats["SpeedUHC"]>
|
||||
|
||||
export function getSpeedUHCModeStats(modeId: Exclude<typeof MODES[number]["id"], ""> | "all_modes", stats: NonNullable<NonNullStats["SpeedUHC"]>) {
|
||||
if (modeId === "all_modes") {
|
||||
const bestMode = getSpeedUHCBestMode(stats)
|
||||
if (!bestMode) {
|
||||
return [
|
||||
stats.kills,
|
||||
stats.deaths,
|
||||
devide(stats.kills, stats.deaths),
|
||||
stats.wins,
|
||||
stats.losses,
|
||||
devide(stats.wins, stats.losses)
|
||||
]
|
||||
}
|
||||
|
||||
return [
|
||||
stats[`kills_${bestMode}`],
|
||||
stats[`deaths_${bestMode}`],
|
||||
devide(stats[`kills_${bestMode}`], stats[`deaths_${bestMode}`]),
|
||||
stats[`wins_${bestMode}`],
|
||||
stats[`losses_${bestMode}`],
|
||||
devide(stats[`wins_${bestMode}`], stats[`losses_${bestMode}`])
|
||||
stats.kills,
|
||||
stats.deaths,
|
||||
devide(stats.kills, stats.deaths),
|
||||
stats.wins,
|
||||
stats.losses,
|
||||
devide(stats.wins, stats.losses)
|
||||
]
|
||||
}
|
||||
|
||||
|
||||
@@ -1048,6 +1048,40 @@ export const arcadeStatsSchema = z.object({
|
||||
...arcadeZombiesTypeStats()
|
||||
})
|
||||
|
||||
function speedUhcModeModeMasteryStats() {
|
||||
const ids = [
|
||||
"mastery_wild_specialist",
|
||||
"mastery_sniper",
|
||||
"mastery_berserk",
|
||||
"mastery_fortune",
|
||||
"mastery_master_baker",
|
||||
"mastery_invigorate",
|
||||
"mastery_huntsman",
|
||||
"mastery_vampirism",
|
||||
"mastery_guardian",
|
||||
"solo_normal",
|
||||
"solo_insane",
|
||||
"team_normal",
|
||||
"team_insane"
|
||||
] as const
|
||||
|
||||
const stats = [
|
||||
"kills",
|
||||
"deaths",
|
||||
"wins",
|
||||
"losses"
|
||||
] as const
|
||||
|
||||
const entries = new Map<string, z.ZodDefault<z.ZodNumber>>()
|
||||
for (const id of ids) {
|
||||
for (const stat of stats) {
|
||||
entries.set(`${stat}_${id}`, z.number().default(0))
|
||||
}
|
||||
}
|
||||
|
||||
return Object.fromEntries(entries) as Record<`${typeof stats[number]}_${typeof ids[number]}`, z.ZodDefault<z.ZodNumber>>
|
||||
}
|
||||
|
||||
export const speedUhcStatsSchema = z.object({
|
||||
kills: z.number().default(0),
|
||||
deaths: z.number().default(0),
|
||||
@@ -1055,20 +1089,5 @@ export const speedUhcStatsSchema = z.object({
|
||||
losses: z.number().default(0),
|
||||
score: z.number().default(0),
|
||||
coins: z.number().default(0),
|
||||
kills_solo_normal: z.number().default(0),
|
||||
deaths_solo_normal: z.number().default(0),
|
||||
wins_solo_normal: z.number().default(0),
|
||||
losses_solo_normal: z.number().default(0),
|
||||
kills_solo_insane: z.number().default(0),
|
||||
deaths_solo_insane: z.number().default(0),
|
||||
wins_solo_insane: z.number().default(0),
|
||||
losses_solo_insane: z.number().default(0),
|
||||
kills_team_normal: z.number().default(0),
|
||||
deaths_team_normal: z.number().default(0),
|
||||
wins_team_normal: z.number().default(0),
|
||||
losses_team_normal: z.number().default(0),
|
||||
kills_team_insane: z.number().default(0),
|
||||
deaths_team_insane: z.number().default(0),
|
||||
wins_team_insane: z.number().default(0),
|
||||
losses_team_insane: z.number().default(0)
|
||||
...speedUhcModeModeMasteryStats()
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user