Skip to content

Commit

Permalink
Merge pull request #61 from RealToken-Community/add-rwa
Browse files Browse the repository at this point in the history
✨feat: Add RWA token to the community dashboard
  • Loading branch information
AlexRLT authored Aug 17, 2024
2 parents 1707f15 + 3d51ee6 commit 30a6824
Show file tree
Hide file tree
Showing 21 changed files with 340 additions and 81 deletions.
2 changes: 1 addition & 1 deletion .prettierrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ module.exports = {
'^i18next(.*)',
'^(?!(src|../|./))(.*)',
'^src(.*)$',
'^(.*)$'
'^(.*)$',
],
importOrderSeparation: true,
importOrderSortSpecifiers: true,
Expand Down
6 changes: 3 additions & 3 deletions next.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,11 @@ const nextConfig = {
outputStandalone: true,
},
images: {
domains: ['realt.co']
domains: ['realt.co'],
},
publicRuntimeConfig: {
version,
},
};
}

module.exports = nextConfig;
module.exports = nextConfig
2 changes: 1 addition & 1 deletion postcss.config.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,4 @@ module.exports = {
},
},
},
};
}
10 changes: 6 additions & 4 deletions src/components/assetsView/AssetsView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { useSelector } from 'react-redux'

import { Grid } from '@mantine/core'

import { useRWA } from 'src/hooks/useRWA'
import { selectUserRealtokens } from 'src/store/features/wallets/walletsSelector'

import { AssetsViewSearch, useAssetsViewSearch } from './AssetsViewSearch'
Expand All @@ -19,11 +20,12 @@ export const AssetsView: FC = () => {
const { choosenAssetView } = useAssetsViewSelect()

const realtokens = useSelector(selectUserRealtokens)
const rwa = useRWA()

const data = useMemo(
() => assetsViewFilterFunction(realtokens.filter(assetSearchFunction)),
[realtokens, assetSearchFunction, assetsViewFilterFunction],
)
const data = useMemo(() => {
const assets = rwa ? [...realtokens, rwa] : realtokens
return assetsViewFilterFunction(assets.filter(assetSearchFunction))
}, [realtokens, rwa, assetSearchFunction, assetsViewFilterFunction])

return realtokens.length ? (
<>
Expand Down
11 changes: 7 additions & 4 deletions src/components/assetsView/AssetsViewSearch.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { TextInput } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../inputs/useInputStyles'

Expand Down Expand Up @@ -36,11 +39,11 @@ export function useAssetsViewSearch() {
[assetSearch],
)

function assetSearchFunction(realtoken: UserRealtoken) {
function assetSearchFunction(asset: UserRealtoken | RWARealtoken) {
return (
!cleanSearch ||
realtoken.shortName.toLowerCase().includes(cleanSearch) ||
realtoken.fullName.toLowerCase().includes(cleanSearch)
asset.shortName.toLowerCase().includes(cleanSearch) ||
asset.fullName.toLowerCase().includes(cleanSearch)
)
}

Expand Down
14 changes: 9 additions & 5 deletions src/components/assetsView/filters/AssetsViewRentStatusFilter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetRentStatusType } from '../types'
Expand Down Expand Up @@ -58,16 +61,17 @@ AssetsViewRentStatusFilter.displayName = 'AssetsViewRentStatusFilter'
export function useAssetsViewRentStatusFilter(
filter: AssetsViewRentStatusFilterModel,
) {
function assetRentStatusFilterFunction(asset: UserRealtoken) {
function assetRentStatusFilterFunction(asset: UserRealtoken | RWARealtoken) {
const Asset = asset as UserRealtoken
switch (filter.rentStatus) {
case AssetRentStatusType.ALL:
return true
case AssetRentStatusType.RENTED:
return asset.rentStatus === 'full'
return Asset.rentStatus === 'full'
case AssetRentStatusType.PARTIALLY_RENTED:
return asset.rentStatus === 'partial'
return Asset.rentStatus === 'partial'
case AssetRentStatusType.NOT_RENTED:
return asset.rentStatus === 'none'
return Asset.rentStatus === 'none'
}
}

Expand Down
12 changes: 8 additions & 4 deletions src/components/assetsView/filters/AssetsViewRmmStatusFilter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetRmmStatusType } from '../types'
Expand Down Expand Up @@ -53,14 +56,15 @@ AssetsViewRmmStatusFilter.displayName = 'AssetsViewRmmStatusFilter'
export function useAssetsViewRmmStatusFilter(
filter: AssetsViewRmmStatusFilterModel,
) {
function assetRmmStatusFilterFunction(asset: UserRealtoken) {
function assetRmmStatusFilterFunction(asset: UserRealtoken | RWARealtoken) {
const Asset = asset as UserRealtoken
switch (filter.rmmStatus) {
case AssetRmmStatusType.ALL:
return true
case AssetRmmStatusType.AVAILABLE:
return asset.isRmmAvailable
return Asset.isRmmAvailable
case AssetRmmStatusType.NOT_AVAILABLE:
return !asset.isRmmAvailable
return !Asset.isRmmAvailable
}
}

Expand Down
47 changes: 29 additions & 18 deletions src/components/assetsView/filters/AssetsViewSort.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ import { useSelector } from 'react-redux'
import { Grid, Select, Switch } from '@mantine/core'

import { selectTransfersIsLoaded } from 'src/store/features/transfers/transfersSelector'
import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetSortType } from '../types'
Expand Down Expand Up @@ -90,42 +93,50 @@ export const AssetsViewSort: FC<AssetsViewSortProps> = ({
AssetsViewSort.displayName = 'AssetsViewSort'

export function useAssetsViewSort(filter: AssetsViewSortFilter) {
function assetSortFunction(a: UserRealtoken, b: UserRealtoken) {
function assetSortFunction(
a: UserRealtoken | RWARealtoken,
b: UserRealtoken | RWARealtoken,
) {
const value = getAssetSortValue(a, b)
return filter.sortReverse ? value * -1 : value
}
function getAssetSortValue(a: UserRealtoken, b: UserRealtoken) {
function getAssetSortValue(
a: UserRealtoken | RWARealtoken,
b: UserRealtoken | RWARealtoken,
) {
const A = a as UserRealtoken
const B = b as UserRealtoken
switch (filter.sortBy) {
case AssetSortType.VALUE:
return b.value - a.value
return B.value - A.value
case AssetSortType.APR:
return b.annualPercentageYield - a.annualPercentageYield
return B.annualPercentageYield - A.annualPercentageYield
case AssetSortType.RENT:
return b.amount * b.netRentDayPerToken - a.amount * a.netRentDayPerToken
return B.amount * B.netRentDayPerToken - A.amount * A.netRentDayPerToken
case AssetSortType.RENT_START:
return b.rentStartDate.date.localeCompare(a.rentStartDate.date)
return B.rentStartDate.date.localeCompare(A.rentStartDate.date)
case AssetSortType.NAME:
return a.shortName.localeCompare(b.shortName)
return A.shortName.localeCompare(b.shortName)
case AssetSortType.SUPPLY:
return b.totalInvestment - a.totalInvestment
return B.totalInvestment - A.totalInvestment
case AssetSortType.TOKEN:
return b.amount - a.amount
return B.amount - A.amount
case AssetSortType.TOTAL_UNIT:
return b.totalUnits - a.totalUnits
return B.totalUnits - A.totalUnits
case AssetSortType.RENTED_UNIT:
return b.rentedUnits - a.rentedUnits
return B.rentedUnits - A.rentedUnits
case AssetSortType.OCCUPANCY:
return b.rentedUnits / b.totalUnits - a.rentedUnits / a.totalUnits
return B.rentedUnits / B.totalUnits - A.rentedUnits / A.totalUnits
case AssetSortType.INITIAL_LAUNCH:
return b.initialLaunchDate?.date.localeCompare(
a.initialLaunchDate?.date,
return B.initialLaunchDate?.date.localeCompare(
A.initialLaunchDate?.date,
)
case AssetSortType.UNIT_PRICE_COST:
return (b.unitPriceCost ?? 0) - (a.unitPriceCost ?? 0)
return (B.unitPriceCost ?? 0) - (A.unitPriceCost ?? 0)
case AssetSortType.UNREALIZED_CAPITAL_GAIN:
return (b.unrealizedCapitalGain ?? 0) - (a.unrealizedCapitalGain ?? 0)
return (B.unrealizedCapitalGain ?? 0) - (A.unrealizedCapitalGain ?? 0)
case AssetSortType.LAST_CHANGE:
return b.lastChanges.localeCompare(a.lastChanges) ?? 0
return B.lastChanges.localeCompare(A.lastChanges) ?? 0
}
}

Expand Down
24 changes: 14 additions & 10 deletions src/components/assetsView/filters/AssetsViewSubsidyFilter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetSubsidyType } from '../types'
Expand Down Expand Up @@ -73,27 +76,28 @@ AssetsViewSubsidyFilter.displayName = 'AssetsViewSubsidyFilter'
export function useAssetsViewSubsidyFilter(
filter: AssetsViewSubsidyFilterModel,
) {
function assetSubsidyFilterFunction(asset: UserRealtoken) {
function assetSubsidyFilterFunction(asset: UserRealtoken | RWARealtoken) {
const Asset = asset as UserRealtoken
switch (filter.subsidy) {
case AssetSubsidyType.ALL:
return true
case AssetSubsidyType.SUBSIDIZED:
return asset.subsidyStatus !== 'no'
return Asset.subsidyStatus !== 'no'
case AssetSubsidyType.FULLY_SUBSIDIZED:
return asset.subsidyStatus === 'yes' && !!asset.subsidyStatusValue
return Asset.subsidyStatus === 'yes' && !!Asset.subsidyStatusValue
case AssetSubsidyType.PARTIALLY_SUBSIDIZED:
return asset.subsidyStatus !== 'no' && !!asset.subsidyStatusValue
return Asset.subsidyStatus !== 'no' && !!Asset.subsidyStatusValue
case AssetSubsidyType.SECTION_8:
return asset.subsidyStatus !== 'no' && asset.subsidyBy === 'Section 8'
return Asset.subsidyStatus !== 'no' && Asset.subsidyBy === 'Section 8'
case AssetSubsidyType.SECTION_42:
return asset.subsidyStatus !== 'no' && asset.subsidyBy === 'Section 42'
return Asset.subsidyStatus !== 'no' && Asset.subsidyBy === 'Section 42'
case AssetSubsidyType.OTHER_SUBSIDY:
return (
asset.subsidyStatus !== 'no' &&
!['Section 8', 'Section 42'].includes(asset.subsidyBy ?? '')
Asset.subsidyStatus !== 'no' &&
!['Section 8', 'Section 42'].includes(Asset.subsidyBy ?? '')
)
case AssetSubsidyType.NOT_SUBSIDIZED:
return !asset.subsidyStatus || asset.subsidyStatus === 'no'
return !Asset.subsidyStatus || Asset.subsidyStatus === 'no'
}
}

Expand Down
18 changes: 12 additions & 6 deletions src/components/assetsView/filters/AssetsViewUserProtocolFilter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetUserProtocolType } from '../types'
Expand Down Expand Up @@ -62,18 +65,21 @@ AssetsViewUserProtocolFilter.displayName = 'AssetsViewUserProtocolFilter'
export function useAssetsViewUserProtocolFilter(
filter: AssetsViewUserProtocolFilterModel,
) {
function assetUserProtocolFilterFunction(asset: UserRealtoken) {
function assetUserProtocolFilterFunction(
asset: UserRealtoken | RWARealtoken,
) {
const Asset = asset as UserRealtoken
switch (filter.userProtocol) {
case AssetUserProtocolType.ALL:
return true
case AssetUserProtocolType.ETHEREUM:
return asset.balance.ethereum.amount > 0
return Asset.balance.ethereum.amount > 0
case AssetUserProtocolType.GNOSIS:
return asset.balance.gnosis.amount > 0
return Asset.balance.gnosis.amount > 0
case AssetUserProtocolType.RMM:
return asset.balance.rmm.amount > 0
return Asset.balance.rmm.amount > 0
case AssetUserProtocolType.LEVINSWAP:
return asset.balance.levinSwap.amount > 0
return Asset.balance.levinSwap.amount > 0
}
}

Expand Down
18 changes: 11 additions & 7 deletions src/components/assetsView/filters/AssetsViewUserStatusFilter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useInputStyles } from '../../inputs/useInputStyles'
import { AssetUserStatusType } from '../types'
Expand Down Expand Up @@ -66,20 +69,21 @@ AssetsViewUserStatusFilter.displayName = 'AssetsViewUserStatusFilter'
export function useAssetsViewUserStatusFilter(
filter: AssetsViewUserStatusFilterModel,
) {
function assetUserStatusFilterFunction(asset: UserRealtoken) {
function assetUserStatusFilterFunction(asset: UserRealtoken | RWARealtoken) {
const Asset = asset as UserRealtoken
switch (filter.userStatus) {
case AssetUserStatusType.ALL:
return true
case AssetUserStatusType.OWNED:
return asset.amount > 0
return Asset.amount > 0
case AssetUserStatusType.WHITELISTED:
return asset.isWhitelisted
return Asset.isWhitelisted
case AssetUserStatusType.WHITELISTED_NOT_OWNED:
return asset.isWhitelisted && asset.amount === 0
return Asset.isWhitelisted && Asset.amount === 0
case AssetUserStatusType.NOT_OWNED:
return asset.amount === 0
return Asset.amount === 0
case AssetUserStatusType.NOT_WHITELISTED:
return !asset.isWhitelisted
return !Asset.isWhitelisted
}
}

Expand Down
9 changes: 7 additions & 2 deletions src/components/assetsView/filters/useFilters.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
import { useAtom } from 'jotai'

import { assetsViewDefaultFilter, assetsViewFilterAtom } from 'src/states'
import { UserRealtoken } from 'src/store/features/wallets/walletsSelector'
import {
RWARealtoken,
UserRealtoken,
} from 'src/store/features/wallets/walletsSelector'

import { useAssetsViewRentStatusFilter } from './AssetsViewRentStatusFilter'
import { useAssetsViewRmmStatusFilter } from './AssetsViewRmmStatusFilter'
Expand All @@ -26,7 +29,9 @@ export function useAssetsViewFilters() {
const { assetUserProtocolFilterFunction } =
useAssetsViewUserProtocolFilter(activeFilter)

function assetsViewFilterFunction(tokenList: UserRealtoken[]) {
function assetsViewFilterFunction(
tokenList: (UserRealtoken | RWARealtoken)[],
) {
return tokenList
.filter(assetUserStatusFilterFunction)
.filter(assetUserProtocolFilterFunction)
Expand Down
Loading

0 comments on commit 30a6824

Please sign in to comment.