fix pp value on chart?
This commit is contained in:
9
projects/common/src/utils/number-utils.ts
Normal file
9
projects/common/src/utils/number-utils.ts
Normal file
@ -0,0 +1,9 @@
|
||||
/**
|
||||
* Checks if a number is a whole number
|
||||
*
|
||||
* @param number the number to check
|
||||
* @returns whether the number is a whole number
|
||||
*/
|
||||
export function isWholeNumber(number: number) {
|
||||
return number % 1 === 0;
|
||||
}
|
@ -46,7 +46,7 @@ export type DatasetConfig = {
|
||||
hideOnMobile?: boolean;
|
||||
displayName: string;
|
||||
position: AxisPosition;
|
||||
precision?: number; // Added precision option here
|
||||
valueFormatter?: (value: number) => string; // Added precision option here
|
||||
};
|
||||
labelFormatter: (value: number) => string;
|
||||
};
|
||||
@ -63,7 +63,7 @@ const generateAxis = (
|
||||
display: boolean,
|
||||
position: AxisPosition,
|
||||
displayName: string,
|
||||
precision: number | undefined // Adding precision parameter
|
||||
valueFormatter?: (value: number) => string
|
||||
): Axis => ({
|
||||
id,
|
||||
position,
|
||||
@ -74,7 +74,7 @@ const generateAxis = (
|
||||
stepSize: 10,
|
||||
callback: (value: number) => {
|
||||
// Apply precision if specified, otherwise default to no decimal places
|
||||
return precision !== undefined ? value.toFixed(precision) : value.toString();
|
||||
return valueFormatter !== undefined ? valueFormatter(value) : value.toString();
|
||||
},
|
||||
},
|
||||
reverse,
|
||||
@ -127,7 +127,7 @@ export default function GenericChart({ labels, datasetConfig, histories }: Chart
|
||||
isMobile && config.axisConfig.hideOnMobile ? false : config.axisConfig.display,
|
||||
config.axisConfig.position,
|
||||
config.axisConfig.displayName,
|
||||
config.axisConfig.precision // Pass precision from config to generateAxis
|
||||
config.axisConfig.valueFormatter
|
||||
);
|
||||
|
||||
return generateDataset(config.title, historyArray, config.color, config.axisId);
|
||||
|
@ -5,6 +5,7 @@ import React from "react";
|
||||
import { DatasetConfig } from "@/components/chart/generic-chart";
|
||||
import GenericPlayerChart from "@/components/player/chart/generic-player-chart";
|
||||
import ScoreSaberPlayer from "@ssr/common/types/player/impl/scoresaber-player";
|
||||
import { isWholeNumber } from "@ssr/common/utils/number-utils";
|
||||
|
||||
type Props = {
|
||||
player: ScoreSaberPlayer;
|
||||
@ -49,7 +50,12 @@ const datasetConfig: DatasetConfig[] = [
|
||||
hideOnMobile: true,
|
||||
displayName: "PP",
|
||||
position: "right",
|
||||
precision: 1,
|
||||
valueFormatter: value => {
|
||||
if (isWholeNumber(value)) {
|
||||
return value.toString();
|
||||
}
|
||||
return value.toFixed(1);
|
||||
},
|
||||
},
|
||||
labelFormatter: (value: number) => `PP ${formatNumberWithCommas(value)}pp`,
|
||||
},
|
||||
|
Reference in New Issue
Block a user