import { useMemo } from 'react' import { scaleTime, scaleLinear } from 'd3-scale' import { min, max } from 'lodash' import dayjs from 'dayjs' import { formatPercent } from 'common/util/format' import { Row } from '../layout/row' import { HistoryPoint, SingleValueHistoryChart } from './generic-charts' import { TooltipProps } from './helpers' import { SizedContainer } from 'web/components/sized-container' const MARGIN = { top: 20, right: 10, bottom: 20, left: 40 } const MARGIN_X = MARGIN.left + MARGIN.right const MARGIN_Y = MARGIN.top + MARGIN.bottom const getPoints = (startDate: number, dailyValues: number[]) => { const startDateDayJs = dayjs(startDate) return dailyValues.map((y, i) => ({ x: startDateDayJs.add(i, 'day').toDate(), y: y, })) } const DailyCountTooltip = (props: TooltipProps) => { const { data, mouseX, xScale } = props const d = xScale.invert(mouseX) return ( {dayjs(d).format('MMM DD')} {data.y} ) } const DailyPercentTooltip = (props: TooltipProps) => { const { data, mouseX, xScale } = props const d = xScale.invert(mouseX) return ( {dayjs(d).format('MMM DD')} {formatPercent(data.y)} ) } export function DailyChart(props: { startDate: number dailyValues: number[] excludeFirstDays?: number pct?: boolean }) { const { dailyValues, startDate, excludeFirstDays, pct } = props const data = useMemo( () => getPoints(startDate, dailyValues).slice(excludeFirstDays ?? 0), [startDate, dailyValues, excludeFirstDays] ) // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const minDate = min(data.map((d) => d.x))! // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const maxDate = max(data.map((d) => d.x))! // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const maxValue = max(data.map((d) => d.y))! return ( {(width, height) => ( )} ) }