Skip to content

Commit

Permalink
Add subsidized rent dopdown fileter - resolves #13
Browse files Browse the repository at this point in the history
  • Loading branch information
NandyBa committed Sep 10, 2023
1 parent 92d7e3a commit 3d53b7c
Show file tree
Hide file tree
Showing 7 changed files with 107 additions and 2 deletions.
12 changes: 10 additions & 2 deletions src/components/assetsView/AssetsView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,11 @@ import { selectOwnedRealtokens } from 'src/store/features/wallets/walletsSelecto

import { AssetsSearch, useAssetsSearch } from './AssetsSearch'
import { AssetsSort, useAssetsSort } from './AssetsSort'
import { AttestsSubsidyFilter, useAttestsSubsidyFilter } from './AttestsSubsidyFilter'
import { AssetsViewSelect, useAssetsViewSelect } from './assetsViewSelect'
import { AssetViewType } from './types'
import { AssetGrid, AssetTable } from './views'
import { Realtoken } from 'src/store/features/realtokens/realtokensSelector'

export const AssetsView: FC = () => {
const { assetSortFunction } = useAssetsSort()
Expand All @@ -18,9 +20,12 @@ export const AssetsView: FC = () => {

const realtokens = useSelector(selectOwnedRealtokens)

const assetSubsidyFilterFunction = useAttestsSubsidyFilter()

const data = useMemo(
() => realtokens.filter(assetSearchFunction).sort(assetSortFunction),
[realtokens, assetSearchFunction, assetSortFunction]
() => realtokens.filter(assetSearchFunction).filter(assetSubsidyFilterFunction)
.sort(assetSortFunction),
[realtokens, assetSearchFunction, assetSortFunction, assetSubsidyFilterFunction]
)

return (
Expand All @@ -38,6 +43,9 @@ export const AssetsView: FC = () => {
<AssetsSort />
</Flex>
</Grid.Col>
<Grid.Col xs={12} sm={'content'}>
<AttestsSubsidyFilter />
</Grid.Col>
<Grid.Col xs={12} sm={'content'}>
<AssetsViewSelect />
</Grid.Col>
Expand Down
66 changes: 66 additions & 0 deletions src/components/assetsView/AttestsSubsidyFilter.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
import { FC } from 'react'
import { useTranslation } from 'react-i18next'

import { Select } from '@mantine/core'

import { useAtom } from 'jotai'

import { assetSubsidyChoosedAtom } from 'src/states'

import { useInputStyles } from '../inputs/useInputStyles'
import { AssetSubsidyType } from './types'
import { Realtoken } from 'src/store/features/realtokens/realtokensSelector'

export const AttestsSubsidyFilter: FC = () => {
const { t } = useTranslation('common', { keyPrefix: 'assetSubsidy' })
const { classes: inputClasses } = useInputStyles()

const [choosenSubsidyType, setChoosenSubsidyType] = useAtom(assetSubsidyChoosedAtom)

const viewOptions = [
{
value: AssetSubsidyType.ALL,
label: t('options.all')
},
{
value: AssetSubsidyType.FULLY_SUBSIDIZED,
label: t('options.fullySubsidized')
},
{
value: AssetSubsidyType.SUBSIDIZED,
label: t('options.subsidized')
},
{
value: AssetSubsidyType.NOT_SUBSIDIZED,
label: t('options.notSubsidized')
},
]

return (
<Select
label={t('label')}
data={viewOptions}
value={choosenSubsidyType}
onChange={(value: AssetSubsidyType) => value && setChoosenSubsidyType(value)}
classNames={inputClasses}
/>
)
}
AttestsSubsidyFilter.displayName = 'AssetsSubsidyFilter'

export function useAttestsSubsidyFilter() {
const [choosenSubsidyType] = useAtom(assetSubsidyChoosedAtom)

return (asset: Realtoken) => {
switch (choosenSubsidyType) {
case AssetSubsidyType.FULLY_SUBSIDIZED:
return asset.subsidyStatus === 'yes'
case AssetSubsidyType.SUBSIDIZED:
return asset.subsidyStatus === 'partial' || asset.subsidyStatus === 'yes'
case AssetSubsidyType.NOT_SUBSIDIZED:
return !asset.subsidyStatus || asset.subsidyStatus === 'no'
default:
return true
}
}
}
6 changes: 6 additions & 0 deletions src/components/assetsView/types/assetSubsidy.type.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
export enum AssetSubsidyType {
FULLY_SUBSIDIZED = 'fullySubsidized',
SUBSIDIZED = 'Subsidized',
NOT_SUBSIDIZED = 'notSubsidized',
ALL = 'all',
}
1 change: 1 addition & 0 deletions src/components/assetsView/types/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
export * from './assetSort.type'
export * from './assetView.type'
export * from './assetSubsidy.type'
9 changes: 9 additions & 0 deletions src/i18next/locales/en/common.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,15 @@
"grid": "Grid"
}
},
"assetSubsidy": {
"label": "Subsidized rent",
"options": {
"all": "No filtered",
"fullySubsidized": "Fully subsidized",
"subsidized": "Subsidized",
"notSubsidized": "Not subsidized"
}
},
"assetCard": {
"tokens": "Tokens",
"apr": "APR",
Expand Down
9 changes: 9 additions & 0 deletions src/i18next/locales/fr/common.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,15 @@
"grid": "Carte"
}
},
"assetSubsidy": {
"label": "Loyers subventionnés",
"options": {
"all": "Non filtré",
"fullySubsidized": "Entièrement subventionnés",
"subsidized": "Subventionnés",
"notSubsidized": "Non subventionnés"
}
},
"assetCard": {
"tokens": "Tokens",
"apr": "Rendement annuel",
Expand Down
6 changes: 6 additions & 0 deletions src/states/index.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,18 @@
import { atomWithStorage } from 'jotai/utils'

import { AssetSortType, AssetViewType } from 'src/components/assetsView/types'
import { AssetSubsidyType } from 'src/components/assetsView/types'

export const assetViewChoosedAtom = atomWithStorage<AssetViewType>(
'displayChoosed',
AssetViewType.GRID
)

export const assetSubsidyChoosedAtom = atomWithStorage<AssetSubsidyType>(
'subsidyChoosed',
AssetSubsidyType.FULLY_SUBSIDIZED
)

export const assetSortChoosedAtom = atomWithStorage<AssetSortType>(
'sortChoosed',
AssetSortType.VALUE
Expand Down

0 comments on commit 3d53b7c

Please sign in to comment.