fix graph only showing 49 days of data
This commit is contained in:
@ -63,7 +63,7 @@ export class Player {
|
||||
const statisticHistory = this.getStatisticHistory();
|
||||
const history: Record<string, PlayerHistory> = {};
|
||||
|
||||
for (let i = 0; i < days; i++) {
|
||||
for (let i = 1; i <= days; i++) {
|
||||
const date = formatDateMinimal(getMidnightAlignedDate(getDaysAgoDate(i)));
|
||||
const playerHistory = statisticHistory[date];
|
||||
if (playerHistory !== undefined && Object.keys(playerHistory).length > 0) {
|
||||
|
@ -3,7 +3,7 @@
|
||||
import React from "react";
|
||||
import GenericChart, { DatasetConfig } from "@/components/chart/generic-chart";
|
||||
import ScoreSaberPlayer from "@ssr/common/player/impl/scoresaber-player";
|
||||
import { parseDate } from "@ssr/common/utils/time-utils";
|
||||
import { getDaysAgoDate, parseDate } from "@ssr/common/utils/time-utils";
|
||||
import { getValueFromHistory } from "@ssr/common/utils/player-utils";
|
||||
|
||||
type Props = {
|
||||
@ -43,25 +43,19 @@ export default function GenericPlayerChart({ player, datasetConfig }: Props) {
|
||||
([a], [b]) => parseDate(a).getTime() - parseDate(b).getTime()
|
||||
);
|
||||
|
||||
const today = new Date();
|
||||
let currentHistoryIndex = 0;
|
||||
|
||||
// Iterate from historyDays-1 to 0 (last 'historyDays' days)
|
||||
for (let dayAgo = historyDays - 1; dayAgo >= 0; dayAgo--) {
|
||||
const targetDate = new Date();
|
||||
targetDate.setDate(today.getDate() - dayAgo);
|
||||
labels.push(targetDate); // Push the target date to labels
|
||||
for (let dayAgo = historyDays; dayAgo >= 0; dayAgo--) {
|
||||
const targetDate = getDaysAgoDate(dayAgo);
|
||||
labels.push(targetDate); // Add the target date to labels
|
||||
|
||||
// Check if currentHistoryIndex is within bounds of statisticEntries
|
||||
if (currentHistoryIndex < statisticEntries.length) {
|
||||
const [dateString, history] = statisticEntries[currentHistoryIndex];
|
||||
const entryDate = parseDate(dateString);
|
||||
|
||||
// If the entry date matches the target date, use this entry
|
||||
if (entryDate.toDateString() === targetDate.toDateString()) {
|
||||
datasetConfig.forEach(config => {
|
||||
// Use the correct index for histories
|
||||
histories[config.field][historyDays - 1 - dayAgo] = getValueFromHistory(history, config.field) ?? null;
|
||||
histories[config.field][historyDays - dayAgo] = getValueFromHistory(history, config.field) ?? null;
|
||||
});
|
||||
currentHistoryIndex++;
|
||||
}
|
||||
|
Reference in New Issue
Block a user