Flatten extended stat and use teamName, add placeholder arrow to avoid shifting
This commit is contained in:
parent
f09e93df48
commit
3e6205abf8
@ -5,7 +5,7 @@
|
|||||||
<table class="table table-sm table-striped" id="table-batting-stats">
|
<table class="table table-sm table-striped" id="table-batting-stats">
|
||||||
<thead class="thead-dark">
|
<thead class="thead-dark">
|
||||||
<tr style="min-width: 75px">
|
<tr style="min-width: 75px">
|
||||||
<th @click="sortBy('team')" :class="getArrow('team')">Team</th>
|
<th @click="sortBy('teamName')" :class="getArrow('teamName')">Team</th>
|
||||||
<th @click="sortBy('pa')" :class="getArrow('pa')">PA</th>
|
<th @click="sortBy('pa')" :class="getArrow('pa')">PA</th>
|
||||||
<th @click="sortBy('ab')" :class="getArrow('ab')">AB</th>
|
<th @click="sortBy('ab')" :class="getArrow('ab')">AB</th>
|
||||||
<th @click="sortBy('run')" :class="getArrow('run')">R</th>
|
<th @click="sortBy('run')" :class="getArrow('run')">R</th>
|
||||||
@ -111,6 +111,7 @@
|
|||||||
import { aggregateBattingStats, fetchTeamBattingStatsBySeason, type BattingStat } from '@/services/battingStatsService'
|
import { aggregateBattingStats, fetchTeamBattingStatsBySeason, type BattingStat } from '@/services/battingStatsService'
|
||||||
|
|
||||||
interface ExtendedBattingStat extends BattingStat {
|
interface ExtendedBattingStat extends BattingStat {
|
||||||
|
teamName: string
|
||||||
kPct: string
|
kPct: string
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -122,7 +123,7 @@ export default {
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
battingStats: [] as ExtendedBattingStat[],
|
battingStats: [] as ExtendedBattingStat[],
|
||||||
sortKey: 'team' as keyof ExtendedBattingStat,
|
sortKey: 'teamName' as keyof ExtendedBattingStat,
|
||||||
sortOrder: 1
|
sortOrder: 1
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -152,18 +153,13 @@ export default {
|
|||||||
async fetchData(): Promise<void> {
|
async fetchData(): Promise<void> {
|
||||||
const unsortedBattingStats: BattingStat[] = await fetchTeamBattingStatsBySeason(this.seasonNumber)
|
const unsortedBattingStats: BattingStat[] = await fetchTeamBattingStatsBySeason(this.seasonNumber)
|
||||||
this.battingStats = unsortedBattingStats
|
this.battingStats = unsortedBattingStats
|
||||||
.map(s => ({...s, kPct: this.calculateStrikeoutPercent(s)}))
|
.map(s => ({...s, teamName: s.team.sname, kPct: this.calculateStrikeoutPercent(s)}))
|
||||||
.sort((s1, s2) => s2.team.sname < s1.team.sname ? 1 : -1)
|
.sort((s1, s2) => s2.teamName < s1.teamName ? 1 : -1)
|
||||||
},
|
},
|
||||||
sortBy(stat: keyof ExtendedBattingStat): void {
|
sortBy(stat: keyof ExtendedBattingStat): void {
|
||||||
this.setKey(stat)
|
this.setKey(stat)
|
||||||
|
|
||||||
if (stat == 'team') {
|
|
||||||
this.battingStats.sort((s1, s2) => s2.team.sname < s1.team.sname ? this.sortOrder : -1 * this.sortOrder)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
this.battingStats.sort((s1, s2) => s2[stat] < s1[stat] ? -1 * this.sortOrder : this.sortOrder)
|
this.battingStats.sort((s1, s2) => s2[stat] < s1[stat] ? this.sortOrder : -1 * this.sortOrder)
|
||||||
},
|
},
|
||||||
setKey(stat: keyof ExtendedBattingStat): void {
|
setKey(stat: keyof ExtendedBattingStat): void {
|
||||||
if (this.sortKey === stat) {
|
if (this.sortKey === stat) {
|
||||||
@ -171,11 +167,11 @@ export default {
|
|||||||
this.sortOrder *= -1
|
this.sortOrder *= -1
|
||||||
} else {
|
} else {
|
||||||
this.sortKey = stat
|
this.sortKey = stat
|
||||||
this.sortOrder = 1
|
this.sortOrder = stat === 'teamName' ? 1 : -1
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
getArrow(stat: keyof ExtendedBattingStat): string {
|
getArrow(stat: keyof ExtendedBattingStat): string {
|
||||||
if (this.sortKey !== stat) return ''
|
if (this.sortKey !== stat) return 'faux-arrow'
|
||||||
|
|
||||||
return this.sortOrder > 0 ? 'up' : 'down'
|
return this.sortOrder > 0 ? 'up' : 'down'
|
||||||
},
|
},
|
||||||
@ -194,4 +190,8 @@ export default {
|
|||||||
.down::after {
|
.down::after {
|
||||||
content: "▿"
|
content: "▿"
|
||||||
}
|
}
|
||||||
|
.faux-arrow::after {
|
||||||
|
opacity: 0;
|
||||||
|
content: "▿"
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
<table class="table table-sm table-striped" id="table-pitching-stats">
|
<table class="table table-sm table-striped" id="table-pitching-stats">
|
||||||
<thead class="thead-dark">
|
<thead class="thead-dark">
|
||||||
<tr>
|
<tr>
|
||||||
<th @click="sortBy('team')" :class="getArrow('team')">Team</th>
|
<th @click="sortBy('teamName')" :class="getArrow('teamName')">Team</th>
|
||||||
<th @click="sortBy('win')" :class="getArrow('win')">W</th>
|
<th @click="sortBy('win')" :class="getArrow('win')">W</th>
|
||||||
<th @click="sortBy('loss')" :class="getArrow('loss')">L</th>
|
<th @click="sortBy('loss')" :class="getArrow('loss')">L</th>
|
||||||
<th @click="sortBy('winPct')" :class="getArrow('winPct')">W-L%</th>
|
<th @click="sortBy('winPct')" :class="getArrow('winPct')">W-L%</th>
|
||||||
@ -118,6 +118,7 @@ import { aggregatePitchingStats, fetchTeamPitchingStatsBySeason, type PitchingSt
|
|||||||
import { outsToInnings, winPercentage, hitsPer9, hrsPer9 } from '@/services/utilities'
|
import { outsToInnings, winPercentage, hitsPer9, hrsPer9 } from '@/services/utilities'
|
||||||
|
|
||||||
interface ExtendedPitchingStat extends PitchingStat {
|
interface ExtendedPitchingStat extends PitchingStat {
|
||||||
|
teamName: string
|
||||||
winPct: string
|
winPct: string
|
||||||
irsPct: string
|
irsPct: string
|
||||||
hPer9: string
|
hPer9: string
|
||||||
@ -132,7 +133,7 @@ export default {
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
pitchingStats: [] as ExtendedPitchingStat[],
|
pitchingStats: [] as ExtendedPitchingStat[],
|
||||||
sortKey: 'team' as keyof ExtendedPitchingStat,
|
sortKey: 'teamName' as keyof ExtendedPitchingStat,
|
||||||
sortOrder: 1
|
sortOrder: 1
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -164,22 +165,18 @@ export default {
|
|||||||
this.pitchingStats = unsortedPitchingStats
|
this.pitchingStats = unsortedPitchingStats
|
||||||
.map(s => (
|
.map(s => (
|
||||||
{...s,
|
{...s,
|
||||||
|
teamName: s.team.sname,
|
||||||
winPct: this.winPercentage(s),
|
winPct: this.winPercentage(s),
|
||||||
irsPct: this.formatIRSPercentage(s),
|
irsPct: this.formatIRSPercentage(s),
|
||||||
hPer9: this.hitsPer9(s),
|
hPer9: this.hitsPer9(s),
|
||||||
hrPer9: this.hrsPer9(s)
|
hrPer9: this.hrsPer9(s)
|
||||||
}))
|
}))
|
||||||
.sort((s1, s2) => s2.team.sname < s1.team.sname ? 1 : -1)
|
.sort((s1, s2) => s2.teamName < s1.teamName ? 1 : -1)
|
||||||
},
|
},
|
||||||
sortBy(stat: keyof ExtendedPitchingStat): void {
|
sortBy(stat: keyof ExtendedPitchingStat): void {
|
||||||
this.setKey(stat)
|
this.setKey(stat)
|
||||||
|
|
||||||
if (stat == 'team') {
|
|
||||||
this.pitchingStats.sort((s1, s2) => s2.team.sname < s1.team.sname ? this.sortOrder : -1 * this.sortOrder)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
this.pitchingStats.sort((s1, s2) => s2[stat] < s1[stat] ? -1 * this.sortOrder : this.sortOrder)
|
this.pitchingStats.sort((s1, s2) => s2[stat] < s1[stat] ? this.sortOrder : -1 * this.sortOrder)
|
||||||
},
|
},
|
||||||
setKey(stat: keyof ExtendedPitchingStat): void {
|
setKey(stat: keyof ExtendedPitchingStat): void {
|
||||||
if (this.sortKey === stat) {
|
if (this.sortKey === stat) {
|
||||||
@ -187,11 +184,11 @@ export default {
|
|||||||
this.sortOrder *= -1
|
this.sortOrder *= -1
|
||||||
} else {
|
} else {
|
||||||
this.sortKey = stat
|
this.sortKey = stat
|
||||||
this.sortOrder = 1
|
this.sortOrder = stat === 'teamName' ? 1 : -1
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
getArrow(stat: keyof ExtendedPitchingStat): string {
|
getArrow(stat: keyof ExtendedPitchingStat): string {
|
||||||
if (this.sortKey !== stat) return ''
|
if (this.sortKey !== stat) return 'faux-arrow'
|
||||||
|
|
||||||
return this.sortOrder > 0 ? 'up' : 'down'
|
return this.sortOrder > 0 ? 'up' : 'down'
|
||||||
},
|
},
|
||||||
@ -223,4 +220,8 @@ export default {
|
|||||||
.down::after {
|
.down::after {
|
||||||
content: "▿"
|
content: "▿"
|
||||||
}
|
}
|
||||||
|
.faux-arrow::after {
|
||||||
|
opacity: 0;
|
||||||
|
content: "▿"
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user