Skip to content

Commit

Permalink
etherium restake is supported
Browse files Browse the repository at this point in the history
  • Loading branch information
dimitardanailov committed Jun 8, 2024
1 parent 70ff75c commit b767ee2
Show file tree
Hide file tree
Showing 8 changed files with 248 additions and 0 deletions.
89 changes: 89 additions & 0 deletions apps/website/src/app/demos/dashboard-etherium-restake/Content.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
'use client'

import {useState} from 'react'

import Collapse from '@mui/material/Collapse'

import AdaptiveGridTwoEqualItems from '@/components/AdaptiveGrid/TwoEqualItems'

import TableBody from '@/components/Coingecko/TableBody'
import TableHeader from '@/components/Coingecko/TableHeader'
import CustomAlert from '@/components/Coingecko/CustomAlert'
import PageHeaderContainer from '@/components/Coingecko/PageHeaderContainer'

import {Slogan} from '@/styled-components'
import Table from '@/styled-components/Coingecko/Table/Table'

import {
useCryptoCurrencyList,
useSortingCryptoCurrencyList,
} from '@/hooks/coingecko/simplePrices'

import {getCoingeckoRequestParams} from './db'

import stack from './stack'

import {
coinCellParams,
usdCellParams,
btcCellParams,
ethCellParams,
} from './setting'

const Content = () => {
const [priceListNotifacationIsVisible, setPriceListNotifacationIsVisible] =
useState(false)

const params = getCoingeckoRequestParams()
const {prices, setPrices, apiRequest} = useCryptoCurrencyList({
setPriceListNotifacationIsVisible,
params,
})

const {sorting, setSorting} = useSortingCryptoCurrencyList({
prices,
setPrices,
setPriceListNotifacationIsVisible,
})

return (
<>
<Slogan>Coingecko portfolio fetcher</Slogan>
<AdaptiveGridTwoEqualItems
ItemA={
<>
<div>Technologies: {stack.join(', ')}</div>
<p>
Sort by usd price, Old price USD (24h), Old price BTC (24h), Old
price ETH (24h)
</p>
</>
}
ItemB={<PageHeaderContainer apiRequest={apiRequest} />}
/>

<Collapse in={priceListNotifacationIsVisible}>
<CustomAlert sorting={sorting} />
</Collapse>

<Table>
<TableHeader
setSorting={setSorting}
sorting={sorting}
coinCellParams={coinCellParams}
usdCellParams={usdCellParams}
btcCellParams={btcCellParams}
/>
<TableBody
items={prices}
coinCellParams={coinCellParams}
usdCellParams={usdCellParams}
ethCellParams={ethCellParams}
btcCellParams={btcCellParams}
/>
</Table>
</>
)
}

export default Content
24 changes: 24 additions & 0 deletions apps/website/src/app/demos/dashboard-etherium-restake/db/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import {CoingeckoSimplePriceRequest} from '@/types/coingecko/simplePrices/RequestParams'
import Currency from '@/enums/CoingeckoCryptoCurrency'

export function getCoingeckoRequestParams(): CoingeckoSimplePriceRequest {
const coingeckoIds = [
Currency.BTC,
Currency.ETHEREUM,
Currency.STETH,
Currency.METH,
Currency.RSETH,
Currency.WEETH,
Currency.EZETH,
Currency.STONE,
Currency.CBETH,
]

return {
ids: coingeckoIds.join(','),
vs_currencies: 'usd,btc,eth',
include_24hr_change: true,
include_7d_change: true,
include_last_updated_at: true,
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import layout from '@/components/NextjsLayout'
import generateMetadata from '@/seo/metadata'
import props from './seo'

export const metadata = generateMetadata(props)

export default layout
39 changes: 39 additions & 0 deletions apps/website/src/app/demos/dashboard-etherium-restake/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
'use client'

import type {NextPage} from 'next'

import Content from './Content'

import Layout from '@/components/MainLayout'
import LeftDrawer from '@/components/Drawers/LeftDrawer'
import {menuItems} from '@/menu'

import {drawerWidth} from '@/config/layout'
import {LayoutProvider} from '@/providers'

import {title} from './seo'

const Title = () => {
return <h1>{title}</h1>
}

const PageContent = () => {
return (
<LayoutProvider>
<Content />
</LayoutProvider>
)
}

const Page: NextPage = () => {
return (
<Layout
PageContent={PageContent}
HeaderTitle={Title}
drawerWidth={drawerWidth}
LeftDrawer={<LeftDrawer items={menuItems} />}
/>
)
}

export default Page
15 changes: 15 additions & 0 deletions apps/website/src/app/demos/dashboard-etherium-restake/seo.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import {InternalMetadata} from '@/seo/metadata'

const title = 'Coingecko: etherium restake price checker'
const description = 'Pairs are'
const canonical = '/demos/dashboard-solana-airdrops'

const props: InternalMetadata = {
title,
description,
canonical,
}

export default props

export {title}
62 changes: 62 additions & 0 deletions apps/website/src/app/demos/dashboard-etherium-restake/setting.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
import {UICellParams, UICoinCellParams} from '@/types/coingecko/cells'

export const coinCellParams: UICoinCellParams = {
label: 'Coin',
width: '8%',
mobile: {
hidden: false,
},
}

export const usdCellParams: UICellParams = {
lastUpdatedItemParams: {
label: 'USD',
width: '12.5%',
mobile: {
hidden: false,
width: '30%',
},
},
historicItemParams: {
label: 'Day ago',
width: '20%',
mobile: {
hidden: false,
width: '62%',
},
},
}

export const btcCellParams: UICellParams = {
lastUpdatedItemParams: {
label: 'BTC',
width: '10.5%',
mobile: {
hidden: true,
},
},
historicItemParams: {
label: 'Day ago',
width: '19.25%',
mobile: {
hidden: true,
},
},
}

export const ethCellParams: UICellParams = {
lastUpdatedItemParams: {
label: 'ETH',
width: '10.5%',
mobile: {
hidden: true,
},
},
historicItemParams: {
label: 'Day ago',
width: '19.25%',
mobile: {
hidden: true,
},
},
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
const stack = ['React', 'React Custom Hooks', 'Coingecko API']

export default stack
9 changes: 9 additions & 0 deletions apps/website/src/enums/CoingeckoCryptoCurrency.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,15 @@ enum CoingeckoCryptoCurrency {
PARCL = 'parcl',
PYTH_NETWORK = 'pyth-network',
JITO_GOVERNANCE_TOKEN = 'jito-governance-token',

// ETHERIUM RESTAKE
STETH = 'staked-ether',
METH = 'mantle-staked-ether',
RSETH = 'kelp-dao-restaked-eth',
WEETH = 'wrapped-eeth',
EZETH = 'renzo-restaked-eth',
STONE = 'stakestone-ether',
CBETH = 'coinbase-wrapped-staked-eth',
}

export default CoingeckoCryptoCurrency

0 comments on commit b767ee2

Please sign in to comment.