Skip to content

Commit

Permalink
fix: resolve conflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
RyukTheCoder committed Dec 23, 2024
1 parent 5dbb8c4 commit e2bf41d
Show file tree
Hide file tree
Showing 4 changed files with 141 additions and 31 deletions.
111 changes: 111 additions & 0 deletions src/app/statistics/_components/ChartBarBox/ChartBarBox.helper.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
import { DailySummaryType } from 'src/types';
import type { BarStackDataType, ColorBucketMapType } from '@rango-dev/charts';
import { ChartType } from './ChartBarBox.type';

export const BAR_CHART_BLOCKCHAIN_NUMBER = 10;

export const barChartColors: string[] = [
'#469BF5',
'#29DABA',
Expand All @@ -12,3 +18,108 @@ export const barChartColors: string[] = [
'#8B62FF',
'#F4C932',
];

export const prepareBarChartData = (chartOption: {
dailyData: DailySummaryType[];
isStackBar: boolean;
type: ChartType;
}) => {
const { dailyData, isStackBar, type } = chartOption;
const chartData: BarStackDataType[] = [];
const colorBlockchainMap: ColorBucketMapType = new Map();
const buckets: string[] = [];

if (!isStackBar) {
dailyData.forEach((dailyItem) => {
const dataItem: BarStackDataType = { date: dailyItem.date };
dataItem[type === 'transaction' ? 'Transactions' : 'Volume'] =
type === 'transaction'
? dailyItem.count.toString()
: dailyItem.volume.toString();

chartData.push(dataItem);
});

colorBlockchainMap.set(
type === 'transaction' ? 'Transactions' : 'Volume',
type === 'transaction' ? '#469BF5' : '#8B62FF',
);

buckets.push(type === 'transaction' ? 'Transactions' : 'Volume');

return { chartData, colorBlockchainMap, buckets };
}

// map sum of value base on type(transaction or volume) for each blockchain
const sumBlockchainMap = new Map<string, number>();
dailyData.forEach((dailyItem) => {
const sum = sumBlockchainMap.get(dailyItem.bucket) || 0;
const newValue =
type === 'transaction' ? dailyItem.count : dailyItem.volume;
sumBlockchainMap.set(dailyItem.bucket, sum + newValue);
});

// sort blockchains with sum value base on type (transaction or volume)
const sortedBlockchain = Array.from(sumBlockchainMap).sort(
(a, b) => b[1] - a[1],
);

// get top blockchains for stack bars
const topBlockchain = sortedBlockchain
.map((sortedItem) => sortedItem[0])
.slice(0, BAR_CHART_BLOCKCHAIN_NUMBER);

// create map structure for assign color for each blockchain
topBlockchain.forEach((blockchainItem, index) => {
colorBlockchainMap.set(
blockchainItem,
barChartColors[index % barChartColors.length],
);
buckets.push(blockchainItem);
});
colorBlockchainMap.set('Others', barChartColors[barChartColors.length - 1]);
buckets.push('Others');

// create map structure for assign chart data for each date
const dateMap = new Map<string, DailySummaryType[]>();
dailyData.forEach((dailyItem) => {
if (!dateMap.has(dailyItem.date)) dateMap.set(dailyItem.date, []);

const dateItem = dateMap.get(dailyItem.date);
dateItem?.push(dailyItem);
});

// create data result for bar stack chart
dateMap.forEach((dateDailyList, keyDate) => {
const dataItem: BarStackDataType = { date: keyDate };
dateDailyList
.filter((dailyItem) => topBlockchain.includes(dailyItem.bucket))
.forEach((topDailyItem) => {
const bucketValue =
type === 'transaction' ? topDailyItem.count : topDailyItem.volume;
dataItem[topDailyItem.bucket] = bucketValue
? bucketValue.toString()
: '0';
});

topBlockchain.forEach((topItem) => {
if (!(topItem in dataItem)) dataItem[topItem] = '0';
});

const otherBlockchains = dateDailyList.filter(
(dailyItem) => !topBlockchain.includes(dailyItem.bucket),
);

const othersValue = otherBlockchains
.map((dailyItem) =>
type === 'transaction' ? dailyItem.count : dailyItem.volume,
)
.reduce((accumulator, currentValue) => accumulator + currentValue, 0);

dataItem['Others'] = othersValue.toString();

chartData.push(dataItem);
});

return { chartData, colorBlockchainMap, buckets };
};
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { DailySummaryType, StatisticDaysFilter } from 'types';
import { BlockchainMeta } from 'types/meta';
export type ChartType = 'Transaction' | 'Volume';
import { DailySummaryType, StatisticDaysFilter } from 'src/types';
import { BlockchainMeta } from 'src/types/meta';
export type ChartType = 'transaction' | 'volume';

export interface PropsType {
days: StatisticDaysFilter;
Expand Down
51 changes: 25 additions & 26 deletions src/app/statistics/_components/ChartBarBox/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,19 +7,23 @@ import {
DailySummaryOption,
DailySummaryType,
StatisticDaysFilter,
} from 'types';
import { getDailySummary } from 'services';
import { Select } from 'components/common/Select';
import { OptionType } from 'components/common/Select/Select.types';
import { ActiveFilterIcon, FilterIcon, LoadingIcon } from 'components/icons';
} from 'src/types';
import { getDailySummary } from 'src/services';
import { Select } from 'src/components/common/Select';
import { OptionType } from 'src/components/common/Select/Select.types';
import { prepareBarChartData } from './ChartBarBox.helper';
import {
ActiveFilterIcon,
FilterIcon,
LoadingIcon,
} from 'src/components/icons';
import ModalFilter from './ModalFilter';
import ParentSize from '@visx/responsive/lib/components/ParentSize';
import {
DEFAULT_STATISTIC_BREAK_DOWN_FILTER,
DEFAULT_STATISTIC_DAYS,
} from 'constant';
import { BarChart, prepareBarChartData } from '@rango-dev/charts';
import { barChartColors } from './ChartBarBox.helper';
} from 'src/constant';
import { BarChart } from '@rango-dev/charts';

function ChartBarBox(props: PropsType) {
const {
Expand All @@ -31,7 +35,7 @@ function ChartBarBox(props: PropsType) {
description,
className = '',
} = props;
const isTransactionType = type === 'Transaction';

const [filter, setFilter] = useState<FilterBarChart>({
source: '',
destination: '',
Expand All @@ -50,7 +54,7 @@ function ChartBarBox(props: PropsType) {
dailyData &&
dailyData
.map((dailyItem) =>
isTransactionType ? dailyItem.count : dailyItem.volume,
type === 'transaction' ? dailyItem.count : dailyItem.volume,
)
.reduce((accumulator, currentValue) => accumulator + currentValue, 0);

Expand Down Expand Up @@ -104,17 +108,12 @@ function ChartBarBox(props: PropsType) {
(!!source && breakDownBy === BreakDownList['Source chain']) ||
(!!destination && breakDownBy === BreakDownList['Destination chain'])
);
const barChartColor = isTransactionType ? ['#469BF5'] : ['#8B62FF'];

const { chartData, colorBucketMap, buckets } = useMemo(() => {
const { chartData, colorBlockchainMap, buckets } = useMemo(() => {
const result = prepareBarChartData({
dailyData: dailyData.map((item) => ({
date: item.date,
bucket: item.bucket,
value: isTransactionType ? item.count : item.volume,
})),
label: type,
barChartColors: isStackBar ? barChartColors : barChartColor,
dailyData,
isStackBar,
type,
});
setLoading(false);
return result;
Expand All @@ -128,7 +127,7 @@ function ChartBarBox(props: PropsType) {
<div className="flex w-full md:w-auto md:h-[48px] items-center justify-between md:start text-18 md:text-32 font-medium md:font-semibold text-primary-500">
<div className="flex items-center">
<span>
{!isTransactionType && '$'}
{type === 'volume' && '$'}
{numberWithCommas(Math.ceil(totalValue))}
</span>
{loading && (
Expand Down Expand Up @@ -227,9 +226,9 @@ function ChartBarBox(props: PropsType) {
height={height}
data={chartData}
buckets={buckets}
colorBucketMap={colorBucketMap}
colorBucketMap={colorBlockchainMap}
getLabel={(value) =>
!isTransactionType ? `$${value}` : value
type === 'volume' ? `$${value}` : value
}
/>
)}
Expand All @@ -239,7 +238,7 @@ function ChartBarBox(props: PropsType) {
<div className="w-full rounded-normal px-20 md:w-[250px] grid grid-cols-3 md:block h-[140px] md:h-[475px] md:bg-surfacesBackground">
{!loading &&
chartData?.length &&
Array.from(colorBucketMap).map((mapItem, index) => {
Array.from(colorBlockchainMap).map((mapItem, index) => {
const [blockchainItem, blockchainColor] = mapItem;
return (
<React.Fragment key={blockchainItem}>
Expand All @@ -252,7 +251,7 @@ function ChartBarBox(props: PropsType) {
</span>
</div>

{index !== colorBucketMap.size - 1 && (
{index !== colorBlockchainMap.size - 1 && (
<div className="h-[1px] hidden md:block w-full bg-neutral-300"></div>
)}
</React.Fragment>
Expand All @@ -272,9 +271,9 @@ function ChartBarBox(props: PropsType) {
height={height}
data={chartData}
buckets={buckets}
colorBucketMap={colorBucketMap}
colorBucketMap={colorBlockchainMap}
getLabel={(value) =>
!isTransactionType ? `$ ${value}` : value
type === 'volume' ? `$ ${value}` : value
}
/>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -102,14 +102,14 @@ function StatisticsPageContent(props: PropsType) {
<ChartBarBox
days={currentDays}
blockchains={blockchains}
type="Transaction"
type="transaction"
dailySummary={dailySummary}
title="Transaction"
description="Number of transactions by day"
className="mb-10 md:mb-15"
/>
<ChartBarBox
type="Volume"
type="volume"
blockchains={blockchains}
days={currentDays}
dailySummary={dailySummary}
Expand Down

0 comments on commit e2bf41d

Please sign in to comment.