From e8825e102f62a3dae17a47f49864fad43fa27a31 Mon Sep 17 00:00:00 2001 From: Keith Date: Wed, 4 Dec 2024 17:02:50 +0900 Subject: [PATCH] feat: add chart of knowledge size --- src/locales/en.json | 2 + src/locales/zh.json | 2 + src/pages/Home/Banner/index.tsx | 13 +- .../activities/KnowledgeSize.tsx | 116 ++++++++++++++++++ src/pages/StatisticsChart/index.tsx | 7 ++ src/routes/index.tsx | 5 + src/services/ExplorerService/fetcher.ts | 7 +- src/services/ExplorerService/types.ts | 5 + 8 files changed, 148 insertions(+), 9 deletions(-) create mode 100644 src/pages/StatisticsChart/activities/KnowledgeSize.tsx diff --git a/src/locales/en.json b/src/locales/en.json index 256ff42f5..07fdf8438 100644 --- a/src/locales/en.json +++ b/src/locales/en.json @@ -225,6 +225,7 @@ "rgbpp_transaction_list": "RGB++ Transaction List", "transaction_count": "Transaction Count", "address_count": "Unique Addresses Used", + "knowledge_size": "Knowledge Size", "total_dao_deposit_depositor": "Total Nervos DAO Deposit & Accrued Total Depositors", "total_dao_deposit_title": "Total Deposit", "total_dao_deposit": "Total Deposit", @@ -300,6 +301,7 @@ "percent": "Percentage", "others": "Others", "address_count_description": "The total number of unique addresses used on the blockchain.", + "knowledge_size_description": "Bytes occupied by on-chain knowledge", "block_time_distribution_description": "The x axis is block intervals in seconds, and the y axis is the frequency of occurrence in the latest 50,000 blocks.", "epoch_time_distribution_description": "The x axis is epoch intervals in hours, and the y axis is the frequency of occurrence in the latest 500 epochs.", "average_block_time_description": "Average block intervals with daily & weekly smooth window", diff --git a/src/locales/zh.json b/src/locales/zh.json index 21935169a..f19701f60 100644 --- a/src/locales/zh.json +++ b/src/locales/zh.json @@ -240,6 +240,7 @@ "rgbpp_transaction_list": "RGB++ 交易列表", "transaction_count": "交易数量", "address_count": "已使用的地址数", + "knowledge_size": "知识总量", "total_dao_deposit_depositor": "Nervos DAO 锁定总额 & 累计锁定地址数", "total_dao_deposit_title": "Nervos DAO 锁定总额", "total_dao_deposit": "锁定总额", @@ -314,6 +315,7 @@ "percent": "百分比", "others": "其他", "address_count_description": "链上已使用的地址总数", + "knowledge_size_description": "链上知识占用的空间", "block_time_distribution_description": "横轴表示区块间隔,纵轴表示对应区块间隔在过去 50,000 个区块中出现的比率。", "epoch_time_distribution_description": "横轴表示 epoch 时长,纵轴表示该时长的 epoch 在过去 500 个 epoch 中过去出现的次数。", "average_block_time_description": "按日和周进行滑动窗口平均统计的平均区块间隔", diff --git a/src/pages/Home/Banner/index.tsx b/src/pages/Home/Banner/index.tsx index a4a50d482..b9996237b 100644 --- a/src/pages/Home/Banner/index.tsx +++ b/src/pages/Home/Banner/index.tsx @@ -1,5 +1,6 @@ import { useQuery } from '@tanstack/react-query' -import { InfoCircledIcon } from '@radix-ui/react-icons' +import { BarChartIcon } from '@radix-ui/react-icons' +import { Link } from '../../../components/Link' import config from '../../../config' import styles from './index.module.scss' import { getKnowledgeSize } from './utils' @@ -31,13 +32,9 @@ export default () => {
CKBytes - - - + + +
diff --git a/src/pages/StatisticsChart/activities/KnowledgeSize.tsx b/src/pages/StatisticsChart/activities/KnowledgeSize.tsx new file mode 100644 index 000000000..8a4ffd223 --- /dev/null +++ b/src/pages/StatisticsChart/activities/KnowledgeSize.tsx @@ -0,0 +1,116 @@ +import BigNumber from 'bignumber.js' +import { useTranslation } from 'react-i18next' +import dayjs from 'dayjs' +import { DATA_ZOOM_CONFIG, assertIsArray, handleAxis } from '../../../utils/chart' +import { tooltipColor, tooltipWidth, SmartChartPage } from '../common' +import { ChartItem, explorerService } from '../../../services/ExplorerService' +import { useCurrentLanguage } from '../../../utils/i18n' +import { ChartColorConfig } from '../../../constants/common' + +const useOption = ( + statisticKnowledgeSize: ChartItem.KnowledgeSize[], + chartColor: ChartColorConfig, + isMobile: boolean, + isThumbnail = false, +): echarts.EChartOption => { + const { t } = useTranslation() + const currentLanguage = useCurrentLanguage() + const gridThumbnail = { + left: '4%', + right: '10%', + top: '8%', + bottom: '6%', + containLabel: true, + } + const grid = { + left: '3%', + right: '3%', + top: isMobile ? '3%' : '8%', + bottom: '5%', + containLabel: true, + } + return { + color: chartColor.colors, + tooltip: !isThumbnail + ? { + trigger: 'axis', + formatter: dataList => { + assertIsArray(dataList) + const widthSpan = (value: string) => tooltipWidth(value, currentLanguage === 'en' ? 155 : 110) + let result = `
${tooltipColor('#333333')}${widthSpan(t('statistic.date'))} ${dataList[0].data[0]}
` + result += `
${tooltipColor(chartColor.colors[0])}\ + ${widthSpan(t('statistic.knowledge_size'))} ${handleAxis(dataList[0].data[1], 2)}
` + return result + }, + } + : undefined, + grid: isThumbnail ? gridThumbnail : grid, + dataZoom: isThumbnail ? [] : DATA_ZOOM_CONFIG, + xAxis: [ + { + name: isMobile || isThumbnail ? '' : t('statistic.date'), + nameLocation: 'middle', + nameGap: 30, + type: 'category', + boundaryGap: false, + splitLine: { + show: false, + }, + }, + ], + yAxis: [ + { + position: 'left', + name: isMobile || isThumbnail ? '' : t('statistic.knowledge_size'), + type: 'value', + scale: true, + nameTextStyle: { + align: 'left', + }, + axisLine: { + lineStyle: { + color: chartColor.colors[0], + }, + }, + axisLabel: { + formatter: (value: string) => handleAxis(new BigNumber(value)), + }, + }, + ], + series: [ + { + name: t('statistic.knowledge_size'), + type: 'line', + yAxisIndex: 0, + symbol: isThumbnail ? 'none' : 'circle', + symbolSize: 3, + }, + ], + dataset: { + source: statisticKnowledgeSize.map(data => [ + dayjs(+data.createdAtUnixtimestamp * 1000).format('YYYY/MM/DD'), + new BigNumber(data.knowledgeSize).toNumber(), + ]), + }, + } +} + +const toCSV = (statisticKnowledge?: ChartItem.KnowledgeSize[]) => + statisticKnowledge ? statisticKnowledge.map(data => [data.createdAtUnixtimestamp, data.knowledgeSize]) : [] + +export const KnowledgeSizeChart = ({ isThumbnail = false }: { isThumbnail?: boolean }) => { + const [t] = useTranslation() + return ( + + ) +} + +export default KnowledgeSizeChart diff --git a/src/pages/StatisticsChart/index.tsx b/src/pages/StatisticsChart/index.tsx index 48090e5d8..c85c9e457 100644 --- a/src/pages/StatisticsChart/index.tsx +++ b/src/pages/StatisticsChart/index.tsx @@ -6,6 +6,7 @@ import { DifficultyHashRateChart } from './mining/DifficultyHashRate' import { DifficultyUncleRateEpochChart } from './mining/DifficultyUncleRateEpoch' import { TransactionCountChart } from './activities/TransactionCount' import { AddressCountChart } from './activities/AddressCount' +import { KnowledgeSizeChart } from './activities/KnowledgeSize' import { CellCountChart } from './activities/CellCount' import { CkbHodlWaveChart } from './activities/CkbHodlWave' import { TotalDaoDepositChart } from './nervosDao/TotalDaoDeposit' @@ -120,6 +121,12 @@ const useChartsData = () => { path: '/charts/contract-resource-distributed', description: t('statistic.contract_resource_distributed_description'), }, + { + title: `${t('statistic.knowledge_size')}`, + chart: , + path: '/charts/knowledge-size', + description: t('statistic.knowledge_size'), + }, ], }, { diff --git a/src/routes/index.tsx b/src/routes/index.tsx index 1b2cb7fb9..2fbe2276c 100644 --- a/src/routes/index.tsx +++ b/src/routes/index.tsx @@ -55,6 +55,7 @@ const CellCountChart = lazy(() => import('../pages/StatisticsChart/activities/Ce const ContractResourceDistributedChart = lazy( () => import('../pages/StatisticsChart/activities/ContractResourceDistributed'), ) +const KnowledgeSizeChart = lazy(() => import('../pages/StatisticsChart/activities/KnowledgeSize')) const CkbHodlWaveChart = lazy(() => import('../pages/StatisticsChart/activities/CkbHodlWave')) const AddressBalanceRankChart = lazy(() => import('../pages/StatisticsChart/activities/AddressBalanceRank')) const BalanceDistributionChart = lazy(() => import('../pages/StatisticsChart/activities/BalanceDistribution')) @@ -256,6 +257,10 @@ const routes: RouteProps[] = [ path: '/charts/contract-resource-distributed', component: ContractResourceDistributedChart, }, + { + path: '/charts/knowledge-size', + component: KnowledgeSizeChart, + }, { path: '/charts/block-time-distribution', diff --git a/src/services/ExplorerService/fetcher.ts b/src/services/ExplorerService/fetcher.ts index b395471be..bd68e347e 100644 --- a/src/services/ExplorerService/fetcher.ts +++ b/src/services/ExplorerService/fetcher.ts @@ -3,7 +3,7 @@ import BigNumber from 'bignumber.js' import { Dayjs } from 'dayjs' import { ReactNode } from 'react' import { pick } from '../../utils/object' -import { toCamelcase } from '../../utils/util' +import { shannonToCkb, toCamelcase } from '../../utils/util' import { requesterV1, requesterV2 } from './requester' import { ChartItem, @@ -243,6 +243,11 @@ export const apiFetcher = { .get(`statistics/contract_resource_distributed`) .then(res => toCamelcase(res.data)), + fetchStatisticKnowledgeSize: () => + v1GetUnwrappedList(`/daily_statistics/knowledge_size`).then(res => + res.map(i => ({ ...i, knowledgeSize: +shannonToCkb(i.knowledgeSize) })), + ), + fetchTransactionByHash: (hash: string, displayCells: boolean = false) => v1GetUnwrapped(`transactions/${hash}?display_cells=${displayCells}`), diff --git a/src/services/ExplorerService/types.ts b/src/services/ExplorerService/types.ts index 8c07c87ed..07f8399b3 100644 --- a/src/services/ExplorerService/types.ts +++ b/src/services/ExplorerService/types.ts @@ -196,6 +196,11 @@ export namespace ChartItem { address: string radio: string } + + export interface KnowledgeSize { + createdAtUnixtimestamp: string + knowledgeSize: number + } } export interface NervosDaoDepositor {