From ee974d57712cdabcc1781a0b763959448244f696 Mon Sep 17 00:00:00 2001 From: Sophia Date: Fri, 8 Dec 2023 15:22:00 -0500 Subject: [PATCH] Centrifuge App: Fetch DAO data dynamically (#1755) * Fetch dao config from public github repo * Remove author * Remove showPortfolio debug flag --- .../src/components/DebugFlags/config.ts | 5 -- centrifuge-app/src/components/Menu/index.tsx | 6 +-- .../src/components/PortfolioCta/index.tsx | 29 +---------- centrifuge-app/src/components/Resolutions.tsx | 51 ++++--------------- centrifuge-app/src/config.ts | 20 -------- centrifuge-app/src/pages/Prime/Detail.tsx | 26 +++++----- centrifuge-app/src/pages/Prime/index.tsx | 18 ++++--- centrifuge-app/src/utils/useDAOConfig.tsx | 51 +++++++++++++++++++ 8 files changed, 91 insertions(+), 115 deletions(-) create mode 100644 centrifuge-app/src/utils/useDAOConfig.tsx diff --git a/centrifuge-app/src/components/DebugFlags/config.ts b/centrifuge-app/src/components/DebugFlags/config.ts index 5b5f1634e2..e246a4f569 100644 --- a/centrifuge-app/src/components/DebugFlags/config.ts +++ b/centrifuge-app/src/components/DebugFlags/config.ts @@ -44,7 +44,6 @@ export type Key = | 'editAdminConfig' | 'showPodAccountCreation' | 'convertAddress' - | 'showPortfolio' | 'showTestNets' | 'showSwaps' | 'showPrime' @@ -114,10 +113,6 @@ export const flagsConfig: Record = { default: null, alwaysShow: true, }, - showPortfolio: { - type: 'checkbox', - default: false, - }, showSwaps: { type: 'checkbox', default: false, diff --git a/centrifuge-app/src/components/Menu/index.tsx b/centrifuge-app/src/components/Menu/index.tsx index 0d317cc4c7..07ed4c2c06 100644 --- a/centrifuge-app/src/components/Menu/index.tsx +++ b/centrifuge-app/src/components/Menu/index.tsx @@ -26,7 +26,7 @@ export function Menu() { const pools = usePoolsThatAnyConnectedAddressHasPermissionsFor() || [] const isLarge = useIsAboveBreakpoint('L') const address = useAddress('substrate') - const { showSwaps, showPortfolio, showPrime } = useDebugFlags() + const { showSwaps, showPrime } = useDebugFlags() return ( )} - {showPortfolio && address && ( + {address && ( Portfolio )} - {showPortfolio && address && ( + {address && ( History diff --git a/centrifuge-app/src/components/PortfolioCta/index.tsx b/centrifuge-app/src/components/PortfolioCta/index.tsx index aa17caabbb..03b5e4326d 100644 --- a/centrifuge-app/src/components/PortfolioCta/index.tsx +++ b/centrifuge-app/src/components/PortfolioCta/index.tsx @@ -7,7 +7,6 @@ import { Dec } from '../../utils/Decimal' import { formatBalance, formatBalanceAbbreviated } from '../../utils/formatting' import { useAddress } from '../../utils/useAddress' import { useListedPools } from '../../utils/useListedPools' -import { useDebugFlags } from '../DebugFlags' import { useComputeLiquidityRewards } from '../LiquidityRewards/hooks' import { Cubes } from './Cubes' @@ -18,7 +17,6 @@ export function PortfolioCta() { const balances = useBalances(address) const consts = useCentrifugeConsts() const [, listedTokens] = useListedPools() - const { showPortfolio } = useDebugFlags() const stakes = balances?.tranches.map(({ poolId, trancheId }) => ({ poolId, trancheId })) ?? [] const rewards = useComputeLiquidityRewards(address, stakes) @@ -44,7 +42,7 @@ export function PortfolioCta() { }, ] - return showPortfolio ? ( + return ( - ) : !address ? ( - - {!address && } - - - Pools on Centrifuge let investors earn yield from real-world assets. - - - - - ) : null + ) } diff --git a/centrifuge-app/src/components/Resolutions.tsx b/centrifuge-app/src/components/Resolutions.tsx index cc63603a5f..ce18137782 100644 --- a/centrifuge-app/src/components/Resolutions.tsx +++ b/centrifuge-app/src/components/Resolutions.tsx @@ -1,45 +1,18 @@ -import { Box, Shelf, Stack, Text } from '@centrifuge/fabric' +import { Shelf, Stack, Text } from '@centrifuge/fabric' import styled from 'styled-components' -import aaveBlog from '../assets/images/aave-blog.png' +import { DAO } from '../utils/useDAOConfig' -const blogs = [ - { - title: '[ARFC] Aave Treasury RWA Allocation', - date: ' Sep 7, 2023', - author: 'Asad Khan', - excerpt: - 'This proposal brings on Centrifuge as a service provider to the Aave DAO to setup a legal structure to support RWA investments, develop RWA specific management and governance processes, and allocate $1M of the Aave Treasury’s stablecoin holdings to a liquid US T-Bill fund on Centrifuge, as a proof of concept investment.', - link: 'https://governance.aave.com/t/arfc-aave-treasury-rwa-allocation/14790', - }, - { - title: '[ARFC] Aave Treasury Proposal for RWA Allocation Snapshot Vote', - date: 'Sep 12, 2023', - author: 'Asad Khan', - excerpt: - 'This is a first step towards a long term effort for Aave to develop and launch an RWA Facilitator that will back GHO with Real World Assets. With this proposal Aave can earn yield on idle stablecoins, establish long-term RWA infrastructure for the protocol, and allow the Aave DAO to begin building internal familiarity and expertise in the RWA industry.', - link: 'https://snapshot.org/#/aave.eth/proposal/0x71db494e4b49e7533c5ccaa566686b2d045b0761cb3296a2d77af4b500566eb0', - }, - { - title: 'Draft Documents for Aave RWA Legal Structure', - date: 'Oct 31, 2023', - author: 'Asad Khan', - excerpt: - 'We have developed an initial draft of the legal documents that will define the Aave’s DAO RWA legal structure. We have shared the below summary and documents with core contributors and delegates for feedback with no issues identified.', - link: 'https://governance.aave.com/t/draft-documents-for-aave-rwa-legal-structure/15283', - }, -] - -export const Resolutions = () => { +export const Resolutions = ({ dao }: { dao: DAO }) => { return ( Resolutions - {blogs.map((blog) => ( + {dao.resolutions.map((blog) => ( { rel="noopener noreferrer" borderRadius="4px" > - {blog.title} + {blog.title} {blog.title} - {blog.date} + {new Date(blog.timestamp * 1000).toLocaleDateString('en-US', { + year: 'numeric', + month: 'long', + day: 'numeric', + })} {blog.excerpt} - - - - {blog.author} - - ))} diff --git a/centrifuge-app/src/config.ts b/centrifuge-app/src/config.ts index 500b2221bf..b7542c1613 100644 --- a/centrifuge-app/src/config.ts +++ b/centrifuge-app/src/config.ts @@ -1,9 +1,7 @@ import { TransactionOptions } from '@centrifuge/centrifuge-js' -import { Network } from '@centrifuge/centrifuge-react' import { altairDark, centrifugeLight } from '@centrifuge/fabric' import * as React from 'react' import { DefaultTheme } from 'styled-components' -import aaveLogo from './assets/images/aave-token-logo.svg' import { LogoAltair, LogoAltairText } from './components/LogoAltair' import { LogoCentrifuge, LogoCentrifugeText } from './components/LogoCentrifuge' @@ -144,24 +142,6 @@ export const ethConfig = { export const config = import.meta.env.REACT_APP_NETWORK === 'altair' ? ALTAIR : CENTRIFUGE -export type DAO = { - slug: string - name: string - network: Network - address: string - icon: string -} - -export const DAOs: DAO[] = [ - { - slug: 'aave', - name: 'Aave', - network: 'centrifuge', - address: 'kALNreUp6oBmtfG87fe7MakWR8BnmQ4SmKjjfG27iVd3nuTue', - icon: aaveLogo, - }, -] - export const parachainNames: Record = { 1000: 'Asset Hub', } diff --git a/centrifuge-app/src/pages/Prime/Detail.tsx b/centrifuge-app/src/pages/Prime/Detail.tsx index 61a4914adb..5d38f2e58e 100644 --- a/centrifuge-app/src/pages/Prime/Detail.tsx +++ b/centrifuge-app/src/pages/Prime/Detail.tsx @@ -8,7 +8,7 @@ import { Holdings } from '../../components/Portfolio/Holdings' import { Transactions } from '../../components/Portfolio/Transactions' import { Resolutions } from '../../components/Resolutions' import { RouterTextLink } from '../../components/TextLink' -import { DAOs } from '../../config' +import { useDAOConfig } from '../../utils/useDAOConfig' export default function PrimeDetailPage() { return ( @@ -20,14 +20,16 @@ export default function PrimeDetailPage() { function PrimeDetail() { const { dao: daoSlug } = useParams<{ dao: string }>() - const dao = DAOs.find((d) => d.slug === daoSlug) + const { data: DAOs, isLoading } = useDAOConfig() + const dao = DAOs?.find((d) => d.slug === daoSlug) const utils = useCentrifugeUtils() - if (!dao) throw new Error('DAO not found') - const centAddress = utils.formatAddress( - typeof dao.network === 'number' ? utils.evmToSubstrateAddress(dao.address, dao.network) : dao.address - ) + const centAddress = + dao && + utils.formatAddress( + typeof dao.network === 'number' ? utils.evmToSubstrateAddress(dao.address, dao.network) : dao.address + ) - return ( + return !isLoading && dao && centAddress ? ( <> @@ -36,18 +38,18 @@ function PrimeDetail() { Prime {' '} - / {dao.name} DAO Investments + / {dao.name} Investments - - {dao.name} DAO Investments + + {dao.name} Investments - + - ) + ) : null } diff --git a/centrifuge-app/src/pages/Prime/index.tsx b/centrifuge-app/src/pages/Prime/index.tsx index 9eff83405a..2efe554c40 100644 --- a/centrifuge-app/src/pages/Prime/index.tsx +++ b/centrifuge-app/src/pages/Prime/index.tsx @@ -6,9 +6,9 @@ import { firstValueFrom } from 'rxjs' import { Column, DataTable, FilterableTableHeader, SortableTableHeader } from '../../components/DataTable' import { LayoutBase } from '../../components/LayoutBase' import { LayoutSection } from '../../components/LayoutBase/LayoutSection' -import { DAO, DAOs } from '../../config' import { formatDate } from '../../utils/date' import { formatBalance, formatPercentage } from '../../utils/formatting' +import { DAO, useDAOConfig } from '../../utils/useDAOConfig' import { useFilters } from '../../utils/useFilters' import { useSubquery } from '../../utils/useSubquery' @@ -55,13 +55,15 @@ function DaoPortfoliosTable() { const utils = useCentrifugeUtils() const cent = useCentrifuge() const getNetworkName = useGetNetworkName() + const { data: daoData } = useDAOConfig() - const daos = DAOs.map((dao) => ({ - ...dao, - address: utils.formatAddress( - typeof dao.network === 'number' ? utils.evmToSubstrateAddress(dao.address, dao.network) : dao.address - ), - })) + const daos = + daoData?.map((dao) => ({ + ...dao, + address: utils.formatAddress( + typeof dao.network === 'number' ? utils.evmToSubstrateAddress(dao.address, dao.network) : dao.address + ), + })) || [] // TODO: Update to use new portfolio Runtime API const { data, isLoading: isPortfoliosLoading } = useQuery(['daoPortfolios', daos.map((dao) => dao.address)], () => @@ -130,7 +132,7 @@ function DaoPortfoliosTable() { header: 'DAO', cell: (row: Row) => ( - + {row.name} ), diff --git a/centrifuge-app/src/utils/useDAOConfig.tsx b/centrifuge-app/src/utils/useDAOConfig.tsx new file mode 100644 index 0000000000..826fbedc23 --- /dev/null +++ b/centrifuge-app/src/utils/useDAOConfig.tsx @@ -0,0 +1,51 @@ +import { Network } from '@centrifuge/centrifuge-react' +import { useQuery } from 'react-query' +import { isTestEnv } from '../config' + +export type DAO = { + name: string + slug: string + network: Network + logo: string + address: string + resolutions: Resolution[] +} + +export type Resolution = { + title: string + image: string + timestamp: number + excerpt: string + link: string +} + +export const useDAOConfig = () => { + const query = useQuery( + 'daoData', + async () => { + const res = await fetch( + `https://api.github.com/repos/centrifuge/prime-data/contents/data${isTestEnv ? '-dev' : ''}.json`, + { + headers: { + 'Content-Type': 'application/json', + Accept: 'application/json', + }, + } + ) + + if (!res.ok) { + throw new Error('Network response was not ok') + } + + const json = await res.json() + const content = atob(json.content) + + const data = JSON.parse(content) + return Object.values(data) as DAO[] + }, + { + staleTime: Infinity, + } + ) + return query +}