From c438379bfb9b80f7830a2ef0aed37340bd03c221 Mon Sep 17 00:00:00 2001 From: Chen Yu Date: Tue, 7 Nov 2023 17:11:40 +0900 Subject: [PATCH] fix: fix frozen epoch time chart (#139) * fix: fix frozen epoch time chart The type of data is number, but it's asserted to be string while exception is not properly handled * feat: hide empty epoch time and epoch length because they are invalid * fix: fix condition expression --- .../mining/DifficultyUncleRateEpoch.tsx | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/pages/StatisticsChart/mining/DifficultyUncleRateEpoch.tsx b/src/pages/StatisticsChart/mining/DifficultyUncleRateEpoch.tsx index bd7be7eab..7229f9b0e 100644 --- a/src/pages/StatisticsChart/mining/DifficultyUncleRateEpoch.tsx +++ b/src/pages/StatisticsChart/mining/DifficultyUncleRateEpoch.tsx @@ -1,7 +1,7 @@ import { FC } from 'react' import BigNumber from 'bignumber.js' import { useTranslation } from 'react-i18next' -import { assertSerialsDataIsString, assertIsArray, assertSerialsItem, handleAxis } from '../../../utils/chart' +import { assertIsArray, assertSerialsItem, handleAxis } from '../../../utils/chart' import { tooltipColor, tooltipWidth, SeriesItem, SmartChartPage } from '../common' import { parseHourFromMillisecond } from '../../../utils/date' import { ChartItem, explorerService } from '../../../services/ExplorerService' @@ -14,11 +14,13 @@ const widthSpan = (value: string, currentLanguage: SupportedLng) => const useTooltip = () => { const { t } = useTranslation() const currentLanguage = useCurrentLanguage() - return ({ seriesName, data, color }: SeriesItem & { data: string }) => { - if (seriesName === t('block.epoch_time')) { + return ({ seriesName, data, color }: SeriesItem & { data?: unknown }) => { + // empty epoch time is invalid and could be hidden, epoch time is expected to be around 4 hours + if (seriesName === t('block.epoch_time') && data) { return `
${tooltipColor(color)}${widthSpan(t('block.epoch_time'), currentLanguage)} ${data} h
` } - if (seriesName === t('block.epoch_length')) { + // empty epoch length is invalid and could be hidden, epoch length is determined by avg block time, it's expected to be 4h / avg_block_time + if (seriesName === t('block.epoch_length') && data) { return `
${tooltipColor(color)}${widthSpan(t('block.epoch_length'), currentLanguage)} ${data}
` } return '' @@ -70,7 +72,6 @@ const useOption = ( }` dataList.forEach(data => { assertSerialsItem(data) - assertSerialsDataIsString(data) result += parseTooltip(data) }) return result