Skip to content
This repository was archived by the owner on Nov 29, 2023. It is now read-only.
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
211 changes: 205 additions & 6 deletions dist/index.cjs.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ var antd = require('antd');
var jsxRuntime = require('react/jsx-runtime');
var icons = require('@ant-design/icons');
var truncateEthAddress = require('truncate-eth-address');
var reactChartjs2 = require('react-chartjs-2');
require('chart.js/auto');

function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }

Expand Down Expand Up @@ -95,7 +97,7 @@ function _nonIterableRest() {

var img = "";

var getDataFromCovalentAPI = function getDataFromCovalentAPI(URL) {
var getDataFromCovalentAPI$1 = function getDataFromCovalentAPI(URL) {
var headers = new Headers();
var authString = "".concat(process.env.REACT_APP_COVALENT_API_KEY, ":");
headers.set('Authorization', 'Basic ' + btoa(authString));
Expand Down Expand Up @@ -140,7 +142,7 @@ var TokenBalances = function TokenBalances(_ref) {
setError(false);
setIsLoading(true);
var URL = "https://api.covalenthq.com/v1/".concat(chainId, "/address/").concat(address, "/balances_v2/?quote-currency=").concat(quoteCurrency, "&format=JSON&nft=").concat(nft, "&no-nft-fetch=").concat(noNFTFetch);
getDataFromCovalentAPI(URL).then(function (response) {
getDataFromCovalentAPI$1(URL).then(function (response) {
setIsLoading(false);
getData(response.data.items);
}).catch(function (e) {
Expand Down Expand Up @@ -534,7 +536,7 @@ var ERC20Transfers = function ERC20Transfers(_ref) {
setError(false);
setIsLoading(true);
var URL = "https://api.covalenthq.com/v1/".concat(chainId, "/address/").concat(address, "/transactions_v2/?quote-currency=").concat(quoteCurrency, "&format=JSON&block-signed-at-asc=").concat(ascending, "&no-logs=").concat(noLogs);
getDataFromCovalentAPI(URL).then(function (response) {
getDataFromCovalentAPI$1(URL).then(function (response) {
var transfersData = erc20TransfersHelper.filterForTransfers(response);
var transfers = erc20TransfersHelper.pruneTransfers(transfersData, address);
setIsLoading(false);
Expand Down Expand Up @@ -701,7 +703,7 @@ var TokenHolders = function TokenHolders(_ref) {
setError(false);
setIsLoading(true);
var URL = "https://api.covalenthq.com/v1/".concat(chainId, "/tokens/").concat(tokenAddress, "/token_holders/?quote-currency=").concat(quoteCurrency, "&format=JSON&block-height=").concat(blockHeight, "&page-size=").concat(pageSize);
getDataFromCovalentAPI(URL).then(function (response) {
getDataFromCovalentAPI$1(URL).then(function (response) {
setIsLoading(false);
getData(response.data.items);
}).catch(function (e) {
Expand Down Expand Up @@ -1320,7 +1322,7 @@ var Transactions = function Transactions(_ref) {
setError(false);
setIsLoading(true);
var transactionsEndpoint = "https://api.covalenthq.com/v1/".concat(chainId, "/address/").concat(address, "/transactions_v2/?quote-currency=").concat(quoteCurrency, "&format=JSON&block-signed-at-asc=").concat(ascending, "&no-logs=").concat(noLogs, "&page-size=").concat(pageSize);
getDataFromCovalentAPI(transactionsEndpoint).then(function (response) {
getDataFromCovalentAPI$1(transactionsEndpoint).then(function (response) {
setIsLoading(false);
var transformedTransactions = transform(response.data.items.filter(function (txn) {
return txn.log_events.length < 20;
Expand Down Expand Up @@ -1370,7 +1372,7 @@ var ChainSelector = function ChainSelector(_ref) {
var fetchData = function fetchData() {
setError(false);
var URL = "https://api.covalenthq.com/v1/chains/";
getDataFromCovalentAPI(URL).then(function (response) {
getDataFromCovalentAPI$1(URL).then(function (response) {
getChains(response.data.items);
}).catch(function (e) {
return setError(true);
Expand Down Expand Up @@ -1400,8 +1402,205 @@ var ChainSelector = function ChainSelector(_ref) {
}
};

var ExchangeSelector = function ExchangeSelector(_ref) {
var setCurrentDex = _ref.setCurrentDex;
var _useState = react.useState([]),
_useState2 = _slicedToArray(_useState, 2),
options = _useState2[0],
setOptions = _useState2[1];
var _useState3 = react.useState(false),
_useState4 = _slicedToArray(_useState3, 2),
error = _useState4[0],
setError = _useState4[1];
var fetchExchanges = react.useCallback(function () {
setError(false);
var chainsUrl = "https://api.covalenthq.com/v1/chains/";
var dexesUrl = "https://api.covalenthq.com/v1/xy=k/supported_dexes/";
Promise.all([getDataFromCovalentAPI$1(chainsUrl), getDataFromCovalentAPI$1(dexesUrl)]).then(function (_ref2) {
var _ref3 = _slicedToArray(_ref2, 2),
chainsResponse = _ref3[0],
dexesResponse = _ref3[1];
var chains = chainsResponse.data.items;
var dexes = dexesResponse.data.items.filter(function (dex) {
return !!dex.dex_name;
});
var chainAndDexes = chains.map(function (chain) {
var label = chain.label;
var options = dexes.filter(function (dex) {
return dex.chain_id === chain.chain_id;
}).map(function (dex) {
return {
label: dex.dex_name,
value: "".concat(chain.chain_id, "-").concat(dex.dex_name)
};
});
return {
label: label,
options: options
};
});
setOptions(chainAndDexes.filter(function (option) {
return option.options.length > 0;
}));
}).catch(function () {
return setError(true);
});
}, []);
var handleChange = function handleChange(value) {
setCurrentDex(value);
};
react.useEffect(function () {
fetchExchanges();
}, [fetchExchanges]);
if (error) {
return /*#__PURE__*/jsxRuntime.jsx("p", {
children: " Unable to fetch exchanges"
});
}
return /*#__PURE__*/jsxRuntime.jsx(antd.Select, {
style: {
width: 250
},
onChange: handleChange,
options: options
});
};

var ExchangeChart = function ExchangeChart(_ref) {
var chainId = _ref.chainId,
exchangeName = _ref.exchangeName;
var _useState = react.useState([]),
_useState2 = _slicedToArray(_useState, 2),
data = _useState2[0],
setData = _useState2[1];
var _useState3 = react.useState(false),
_useState4 = _slicedToArray(_useState3, 2),
isLoading = _useState4[0],
setIsLoading = _useState4[1];
var _useState5 = react.useState(false),
_useState6 = _slicedToArray(_useState5, 2),
error = _useState6[0],
setError = _useState6[1];
var _useState7 = react.useState('7d'),
_useState8 = _slicedToArray(_useState7, 2),
period = _useState8[0],
setPeriod = _useState8[1];
var fetchData = react.useCallback(function () {
if (!(chainId && exchangeName)) {
setData([]);
setError(false);
}
setError(false);
setIsLoading(true);
var URL = "https://api.covalenthq.com/v1/".concat(chainId, "/xy=k/").concat(exchangeName, "/ecosystem/");
getDataFromCovalentAPI(URL).then(function (response) {
setIsLoading(false);
setData(response.data.items);
}).catch(function () {
return setError(true);
});
}, [chainId, exchangeName]);
react.useEffect(function () {
fetchData();
}, [fetchData]);
if (isLoading) {
return /*#__PURE__*/jsxRuntime.jsx(antd.Table, {
loading: true
});
}
if (error || data.length === 0) {
return /*#__PURE__*/jsxRuntime.jsx("p", {
children: " Unable to fetch data"
});
}
var togglePeriod = function togglePeriod() {
setPeriod(function (period) {
return period === '7d' ? '30d' : '7d';
});
};
var _data$ = data[0],
liquidity_chart_7d = _data$.liquidity_chart_7d,
liquidity_chart_30d = _data$.liquidity_chart_30d,
volume_chart_7d = _data$.volume_chart_7d,
volume_chart_30d = _data$.volume_chart_30d;
var liquidityChart7d = (period === '7d' ? liquidity_chart_7d : liquidity_chart_30d).map(function (item) {
var date = new Date(item.dt);
var x = new Intl.DateTimeFormat('en-US').format(date);
var y = item.liquidity_quote;
return {
x: x,
y: y
};
});
var volumeChart7d = (period === '7d' ? volume_chart_7d : volume_chart_30d).map(function (item) {
var date = new Date(item.dt);
var x = new Intl.DateTimeFormat('en-US').format(date);
var y = item.volume_quote;
return {
x: x,
y: y
};
});
var liquidityChart7dData = {
datasets: [{
label: 'Liquidity',
data: liquidityChart7d,
yAxisID: 'y',
borderColor: '#ff0000'
}, {
label: 'Volume',
data: volumeChart7d,
yAxisID: 'y2',
borderColor: '#3275a8'
}]
};
return /*#__PURE__*/jsxRuntime.jsxs("div", {
children: [/*#__PURE__*/jsxRuntime.jsx("div", {
style: {
marginTop: 10
},
children: /*#__PURE__*/jsxRuntime.jsxs(antd.Button.Group, {
children: [/*#__PURE__*/jsxRuntime.jsx(antd.Button, {
rounded: true,
disabled: period === '7d',
onClick: togglePeriod,
children: "7d"
}), /*#__PURE__*/jsxRuntime.jsx(antd.Button, {
rounded: true,
disabled: period === '30d',
onClick: togglePeriod,
children: "30d"
})]
})
}), /*#__PURE__*/jsxRuntime.jsx("div", {
style: {
height: 500,
width: '100%'
},
children: /*#__PURE__*/jsxRuntime.jsx(reactChartjs2.Line, {
height: 100,
data: liquidityChart7dData,
options: {
scales: {
y: {
type: 'linear',
position: 'left'
},
y2: {
type: 'linear',
position: 'right'
}
}
}
})
})]
});
};

exports.ChainSelector = ChainSelector;
exports.ERC20Transfers = ERC20Transfers;
exports.ExchangeChart = ExchangeChart;
exports.ExchangeSelector = ExchangeSelector;
exports.TokenBalances = TokenBalances;
exports.TokenHolders = TokenHolders;
exports.Transactions = Transactions;
Loading