From 056bc0662f6d8b93a04c375d12128cfebedeb814 Mon Sep 17 00:00:00 2001 From: Tuan Nguyen Date: Fri, 17 Nov 2023 09:31:36 +0700 Subject: [PATCH] update download csv on address detail page --- public/locales/en/translation.json | 4 ++ .../Details/AddressDetails/AddressDetails.tsx | 64 +++++++++++-------- .../SenseDetails/SimilarRegisteredImages.tsx | 2 +- 3 files changed, 41 insertions(+), 29 deletions(-) diff --git a/public/locales/en/translation.json b/public/locales/en/translation.json index 9630e1e0..70e471d3 100644 --- a/public/locales/en/translation.json +++ b/public/locales/en/translation.json @@ -1269,6 +1269,10 @@ "message": "Download CSV", "description": "Used for the CascadeAndSenseStatistics page" }, + "downloading": { + "message": "Downloading...", + "description": "Used for the CascadeAndSenseStatistics page" + }, "address": { "message": "{{currency}} Address", "description": "Used for the CascadeAndSenseStatistics page" diff --git a/src/pages/Details/AddressDetails/AddressDetails.tsx b/src/pages/Details/AddressDetails/AddressDetails.tsx index 73df1c55..d38a9473 100644 --- a/src/pages/Details/AddressDetails/AddressDetails.tsx +++ b/src/pages/Details/AddressDetails/AddressDetails.tsx @@ -1,6 +1,5 @@ -import React, { useState, useRef, useEffect } from 'react'; +import { useState, useEffect } from 'react'; import { useParams } from 'react-router-dom'; -import { CSVLink } from 'react-csv'; import { CircularProgress, Grid } from '@material-ui/core'; import Box from '@material-ui/core/Box'; import Tooltip from '@material-ui/core/Tooltip'; @@ -13,11 +12,12 @@ import InfinityTable, { import { translate, translateDropdown } from '@utils/helpers/i18n'; import { getCurrencyName, isPastelBurnAddress } from '@utils/appInfo'; -import { eChartLineStyles } from '@pages/HistoricalStatistics/Chart/styles'; import * as TableStyles from '@components/Table/Table.styles'; import Fire from '@components/SvgIcon/Fire'; import { useLatestTransactions, useBalanceHistory } from '@hooks/useAddressDetails'; import BurnAddressIcon from '@pages/Details/TransactionDetails/BurnAddressIcon'; +import * as NftDetailsStyles from '@pages/Details/NftDetails/NftDetails.styles'; +import { axiosInstance, getBaseURL } from '@utils/helpers/useFetch/useFetch'; import { DATA_FETCH_LIMIT, @@ -39,30 +39,20 @@ interface IAddressDataRef { } const AddressDetails = () => { - const transactionHistoryCSVHeaders = [ - { label: translateDropdown('pages.addressDetails.hash'), key: 'transactionHash' }, - { - label: translateDropdown('pages.addressDetails.amount', { currency: getCurrencyName() }), - key: 'amount', - }, - { label: translateDropdown('pages.addressDetails.direction'), key: 'direction' }, - { label: translateDropdown('pages.addressDetails.timestamp'), key: 'timestamp' }, - ]; + const [status, setStatus] = useState(''); const { id } = useParams(); const [apiParams, setParams] = useState({ sortBy: ADDRESS_TRANSACTION_TIMESTAMP_KEY, sortDirection: DATA_DEFAULT_SORT, }); - const { addresses, isLoading, swrSize, swrSetSize, csvData } = useLatestTransactions( + const { addresses, isLoading, swrSize, swrSetSize } = useLatestTransactions( id, DATA_FETCH_LIMIT, apiParams.sortBy, apiParams.sortDirection, ); const swrData = useBalanceHistory(id); - const styles = eChartLineStyles(); - const downloadRef = useRef(null); const [isMobile, setMobileView] = useState(false); const handleFetchMoreTransactions = (reachedTableBottom: boolean) => { @@ -100,6 +90,29 @@ const AddressDetails = () => { const isBurnAddress = isPastelBurnAddress(id); + const handleDownloadFile = () => { + const date = new Date(); + const fileName = `Transaction_History__${id}__${date.getFullYear()}_${ + date.getMonth() + 1 + }_${date.getDate()}.csv`; + + setStatus('downloading'); + const url = `${getBaseURL()}/v1/addresses/download-csv/${id}`; + const link = document.createElement('a'); + link.target = '_blank'; + link.download = fileName; + axiosInstance + .get(url, { responseType: 'blob' }) + .then(res => { + link.href = URL.createObjectURL(new Blob([res.data], { type: 'text/csv' })); + link.click(); + setStatus('done'); + }) + .catch(() => { + setStatus('error'); + }); + }; + const generateAddTitle = () => { return ( @@ -118,23 +131,18 @@ const AddressDetails = () => { }; const generateTitle = () => { - const date = new Date(); - const fileName = `Transaction_History__${id}__${date.getFullYear()}_${ - date.getMonth() + 1 - }_${date.getDate()}.csv`; return (

{parse(translate('pages.addressDetails.latestTransactions'))}

- - {parse(translate('pages.addressDetails.downloadCSV'))} - + {status === 'downloading' + ? parse(translate('pages.addressDetails.downloading')) + : parse(translate('pages.addressDetails.downloadCSV'))} +
); }; diff --git a/src/pages/Details/SenseDetails/SimilarRegisteredImages.tsx b/src/pages/Details/SenseDetails/SimilarRegisteredImages.tsx index 21946702..cb32d1b3 100644 --- a/src/pages/Details/SenseDetails/SimilarRegisteredImages.tsx +++ b/src/pages/Details/SenseDetails/SimilarRegisteredImages.tsx @@ -108,7 +108,7 @@ export const getSimilarRegisteredImagesData = (rarenessScoresTable: string) => { ? `data:image/jpeg;base64,${uncompressedRarenessScoresTable.thumbnail[i]}` : '', imageHash: formatImageHash(uncompressedRarenessScoresTable.image_hash[i]), - imageHashOriginal: uncompressedRarenessScoresTable.image_hash[i], + imageHashOriginal: uncompressedRarenessScoresTable.image_hash[i].split('_')[0], dateTimeAdded: getRegisterTime(uncompressedRarenessScoresTable.register_time[i]), likelyDupe: uncompressedRarenessScoresTable.is_likely_dupe[i], matchType: uncompressedRarenessScoresTable.match_type[i],