import { DatumValue } from '@nivo/core' import { ResponsiveLine } from '@nivo/line' import { NUMERIC_GRAPH_COLOR } from 'common/numeric-constants' import _ from 'lodash' import { memo } from 'react' import { getDpmOutcomeProbabilities } from '../../../common/calculate-dpm' import { NumericContract } from '../../../common/contract' import { useWindowSize } from '../../hooks/use-window-size' export const NumericGraph = memo(function NumericGraph(props: { contract: NumericContract height?: number }) { const { contract, height } = props const { totalShares, bucketCount, min, max } = contract const bucketProbs = getDpmOutcomeProbabilities(totalShares) const xs = _.range(bucketCount).map( (i) => min + ((max - min) * i) / bucketCount ) const probs = _.range(bucketCount).map((i) => bucketProbs[`${i}`] * 100) const points = probs.map((prob, i) => ({ x: xs[i], y: prob })) const maxProb = Math.max(...probs) const data = [{ id: 'Probability', data: points, color: NUMERIC_GRAPH_COLOR }] const yTickValues = [ 0, 0.25 * maxProb, 0.5 & maxProb, 0.75 * maxProb, maxProb, ] const { width } = useWindowSize() const numXTickValues = !width || width < 800 ? 2 : 5 return (
= 800 ? 350 : 250) }} > `${Math.round(+d * 100) / 100}`} axisBottom={{ tickValues: numXTickValues, format: (d) => `${Math.round(+d * 100) / 100}`, }} colors={{ datum: 'color' }} pointSize={0} enableSlices="x" enableGridX={!!width && width >= 800} enableArea margin={{ top: 20, right: 28, bottom: 22, left: 50 }} />
) }) function formatPercent(y: DatumValue) { const p = Math.round(+y * 100) / 100 return `${p}%` }