2020-10-26 23:53:04 -07:00
|
|
|
import { LineChart, XAxis, YAxis, Line, Tooltip, Legend } from "recharts";
|
|
|
|
import { timeFormat } from "d3-time-format";
|
2020-11-02 20:49:52 -08:00
|
|
|
import useWindowSize from '../../utils/hook-windowresize';
|
|
|
|
import styles from '../../styles/styles.module.css';
|
2020-10-26 23:53:04 -07:00
|
|
|
|
2020-10-28 00:53:24 -07:00
|
|
|
interface ToolTipProps {
|
|
|
|
active?: boolean,
|
|
|
|
payload?: object,
|
2020-10-29 12:39:59 -07:00
|
|
|
unit?: string
|
2020-10-31 23:17:44 -07:00
|
|
|
}
|
|
|
|
|
2020-10-28 00:53:24 -07:00
|
|
|
const defaultProps = {
|
|
|
|
active: false,
|
2020-11-01 00:01:37 -07:00
|
|
|
payload: Object,
|
2020-11-02 20:49:52 -08:00
|
|
|
unit: '',
|
2020-10-28 00:53:24 -07:00
|
|
|
};
|
|
|
|
|
2020-11-01 00:01:37 -07:00
|
|
|
interface TimedValue {
|
|
|
|
time: Date;
|
2020-11-02 20:49:52 -08:00
|
|
|
value: number;
|
2020-11-01 00:01:37 -07:00
|
|
|
}
|
|
|
|
|
2020-10-28 00:53:24 -07:00
|
|
|
interface ChartProps {
|
2020-11-01 00:01:37 -07:00
|
|
|
data?: TimedValue[],
|
2020-10-28 00:53:24 -07:00
|
|
|
color: string,
|
|
|
|
unit: string,
|
2020-11-01 00:01:37 -07:00
|
|
|
dataCollections?: any[],
|
2020-10-28 00:53:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
function CustomizedTooltip(props: ToolTipProps) {
|
2020-10-28 18:36:25 -07:00
|
|
|
const { active, payload, unit } = props;
|
2020-10-28 00:53:24 -07:00
|
|
|
if (active && payload && payload[0]) {
|
2020-10-28 18:36:25 -07:00
|
|
|
const time = payload[0].payload ? timeFormat("%I:%M")(new Date(payload[0].payload.time)) : "";
|
2020-10-28 00:53:24 -07:00
|
|
|
return (
|
|
|
|
<div className="custom-tooltip">
|
|
|
|
<p className="label">
|
2020-10-28 18:36:25 -07:00
|
|
|
<strong>{time}</strong> {payload[0].payload.value} {unit}
|
2020-10-28 00:53:24 -07:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
CustomizedTooltip.defaultProps = defaultProps;
|
2020-10-26 23:53:04 -07:00
|
|
|
|
2020-10-28 19:28:52 -07:00
|
|
|
export default function Chart({ data, color, unit, dataCollections }: ChartProps) {
|
2020-11-01 00:01:37 -07:00
|
|
|
if (!data && !dataCollections) {
|
|
|
|
return null;
|
|
|
|
}
|
2020-11-02 20:49:52 -08:00
|
|
|
|
|
|
|
const windowSize = useWindowSize();
|
|
|
|
const chartWidth = windowSize.width * .68;
|
|
|
|
const chartHeight = chartWidth * .333;
|
2020-11-01 00:01:37 -07:00
|
|
|
|
2020-10-28 00:53:24 -07:00
|
|
|
const timeFormatter = (tick: string) => {
|
2020-10-28 18:36:25 -07:00
|
|
|
return timeFormat("%I:%M")(new Date(tick));
|
2020-10-26 23:53:04 -07:00
|
|
|
};
|
|
|
|
|
2020-11-02 20:49:52 -08:00
|
|
|
let ticks = [];
|
2020-11-01 00:01:37 -07:00
|
|
|
if (dataCollections.length > 0) {
|
2020-11-02 20:49:52 -08:00
|
|
|
ticks = dataCollections[0].data?.map((collection) => {
|
2020-11-01 00:01:37 -07:00
|
|
|
return collection?.time;
|
|
|
|
})
|
|
|
|
} else if (data?.length > 0){
|
2020-11-02 20:49:52 -08:00
|
|
|
ticks = data?.map(item => {
|
2020-11-01 00:01:37 -07:00
|
|
|
return item?.time;
|
|
|
|
});
|
2020-10-28 19:28:52 -07:00
|
|
|
}
|
2020-10-31 23:17:44 -07:00
|
|
|
|
2020-10-26 23:53:04 -07:00
|
|
|
return (
|
2020-11-02 20:49:52 -08:00
|
|
|
<div className={styles.lineChartContainer}>
|
|
|
|
<LineChart width={chartWidth} height={chartHeight} data={data}>
|
|
|
|
<XAxis
|
|
|
|
dataKey="time"
|
|
|
|
tickFormatter={timeFormatter}
|
|
|
|
interval="preserveStartEnd"
|
|
|
|
tickCount={5}
|
|
|
|
minTickGap={15}
|
|
|
|
domain={["dataMin", "dataMax"]}
|
|
|
|
ticks={ticks}
|
|
|
|
/>
|
|
|
|
<YAxis
|
2020-10-28 19:28:52 -07:00
|
|
|
dataKey="value"
|
2020-11-02 20:49:52 -08:00
|
|
|
interval="preserveStartEnd"
|
|
|
|
unit={unit}
|
|
|
|
domain={["dataMin", "dataMax"]}
|
|
|
|
/>
|
|
|
|
<Tooltip content={<CustomizedTooltip unit={unit} />} />
|
|
|
|
<Legend />
|
|
|
|
<Line
|
2020-10-28 19:28:52 -07:00
|
|
|
type="monotone"
|
2020-11-02 20:49:52 -08:00
|
|
|
dataKey="value"
|
|
|
|
stroke={color}
|
2020-10-28 19:28:52 -07:00
|
|
|
dot={null}
|
|
|
|
strokeWidth={3}
|
|
|
|
/>
|
2020-11-02 20:49:52 -08:00
|
|
|
{dataCollections?.map((s) => (
|
|
|
|
<Line
|
|
|
|
dataKey="value"
|
|
|
|
data={s.data}
|
|
|
|
name={s.name}
|
|
|
|
key={s.name}
|
|
|
|
type="monotone"
|
|
|
|
stroke={s.color}
|
|
|
|
dot={null}
|
|
|
|
strokeWidth={3}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
</LineChart>
|
|
|
|
</div>
|
2020-10-26 23:53:04 -07:00
|
|
|
);
|
|
|
|
}
|
2020-10-31 23:17:44 -07:00
|
|
|
|
|
|
|
Chart.defaultProps = {
|
|
|
|
dataCollections: [],
|
|
|
|
};
|