108 lines
2.7 KiB
TypeScript
108 lines
2.7 KiB
TypeScript
import { format } from 'date-fns'
|
|
|
|
import { IChartDataset } from '@/types/chart'
|
|
import { ISport } from '@/types/sports'
|
|
import {
|
|
IStatisticsChartData,
|
|
IStatisticsDateParams,
|
|
TStatisticsDatasetKeys,
|
|
TStatisticsDatasets,
|
|
TStatisticsFromApi,
|
|
} from '@/types/statistics'
|
|
import { incrementDate, startDate } from '@/utils/dates'
|
|
import { sportColors } from '@/utils/sports'
|
|
|
|
// date format from api
|
|
const dateFormats: Record<string, string> = {
|
|
week: 'yyyy-MM-dd',
|
|
month: 'yyyy-MM',
|
|
year: 'yyyy',
|
|
}
|
|
|
|
export const datasetKeys: TStatisticsDatasetKeys[] = [
|
|
'nb_workouts',
|
|
'total_duration',
|
|
'total_distance',
|
|
]
|
|
|
|
export const getDateKeys = (
|
|
params: IStatisticsDateParams,
|
|
weekStartingMonday: boolean
|
|
): Date[] => {
|
|
const days = []
|
|
for (
|
|
let day = startDate(params.duration, params.start, weekStartingMonday);
|
|
day <= params.end;
|
|
day = incrementDate(params.duration, day)
|
|
) {
|
|
days.push(day)
|
|
}
|
|
return days
|
|
}
|
|
|
|
const getStatisticsChartDataset = (
|
|
sportLabel: string,
|
|
color: string
|
|
): IChartDataset => {
|
|
return {
|
|
label: sportLabel,
|
|
backgroundColor: [color],
|
|
data: [],
|
|
}
|
|
}
|
|
|
|
export const getDatasets = (displayedSports: ISport[]): TStatisticsDatasets => {
|
|
const datasets: TStatisticsDatasets = {
|
|
nb_workouts: [],
|
|
total_distance: [],
|
|
total_duration: [],
|
|
}
|
|
displayedSports.map((sport) => {
|
|
const color = sportColors[sport.label]
|
|
datasets.nb_workouts.push(getStatisticsChartDataset(sport.label, color))
|
|
datasets.total_distance.push(getStatisticsChartDataset(sport.label, color))
|
|
datasets.total_duration.push(getStatisticsChartDataset(sport.label, color))
|
|
})
|
|
return datasets
|
|
}
|
|
|
|
export const formatStats = (
|
|
params: IStatisticsDateParams,
|
|
weekStartingMonday: boolean,
|
|
sports: ISport[],
|
|
displayedSportsId: number[],
|
|
apiStats: TStatisticsFromApi
|
|
): IStatisticsChartData => {
|
|
const dayKeys = getDateKeys(params, weekStartingMonday)
|
|
const dateFormat = dateFormats[params.duration]
|
|
const displayedSports = sports.filter((sport) =>
|
|
displayedSportsId.includes(sport.id)
|
|
)
|
|
const labels: string[] = []
|
|
const datasets = getDatasets(displayedSports)
|
|
const sportsId: Record<string, number> = {}
|
|
displayedSports.map(
|
|
(displayedSport) => (sportsId[displayedSport.label] = displayedSport.id)
|
|
)
|
|
|
|
dayKeys.map((key) => {
|
|
const date: string = format(key, dateFormat)
|
|
labels.push(date)
|
|
datasetKeys.map((datasetKey) => {
|
|
datasets[datasetKey].map((dataset) => {
|
|
dataset.data.push(
|
|
apiStats !== {} &&
|
|
date in apiStats &&
|
|
sportsId[dataset.label] in apiStats[date]
|
|
? apiStats[date][sportsId[dataset.label]][datasetKey]
|
|
: 0
|
|
)
|
|
})
|
|
})
|
|
})
|
|
return {
|
|
labels,
|
|
datasets,
|
|
}
|
|
}
|