import { DatumValue } from '@nivo/core' import { Point, ResponsiveLine } from '@nivo/line' import { NUMERIC_GRAPH_COLOR } from 'common/numeric-constants' import { memo } from 'react' import { range } from 'lodash' import { getDpmOutcomeProbabilities } from '../../../common/calculate-dpm' import { NumericContract } from '../../../common/contract' import { useWindowSize } from '../../hooks/use-window-size' import { Col } from '../layout/col' import { formatLargeNumber } from 'common/util/format' 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 (