2022-10-20 15:39:21 +00:00
|
|
|
import {
|
|
|
|
ColumnDef,
|
|
|
|
flexRender,
|
|
|
|
getCoreRowModel,
|
|
|
|
getSortedRowModel,
|
|
|
|
SortingState,
|
|
|
|
useReactTable,
|
|
|
|
} from '@tanstack/react-table'
|
2022-11-09 09:04:06 +00:00
|
|
|
import Image from 'next/image'
|
|
|
|
import React from 'react'
|
2022-10-20 15:39:21 +00:00
|
|
|
|
2022-12-08 20:14:38 +00:00
|
|
|
import ChevronUpIcon from 'components/Icons/chevron-up.svg'
|
|
|
|
import ChevronDownIcon from 'components/Icons/chevron-down.svg'
|
2022-10-20 15:39:21 +00:00
|
|
|
import { formatCurrency } from 'utils/formatters'
|
2022-11-09 09:04:06 +00:00
|
|
|
|
2022-10-20 15:39:21 +00:00
|
|
|
import AssetRow from './AssetRow'
|
|
|
|
|
|
|
|
interface Market {
|
|
|
|
denom: string
|
|
|
|
symbol: string
|
|
|
|
icon: string
|
|
|
|
chain: string
|
|
|
|
borrowed: {
|
|
|
|
amount: number
|
|
|
|
value: number
|
|
|
|
} | null
|
|
|
|
borrowRate: number
|
|
|
|
marketLiquidity: number
|
|
|
|
}
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
data: Market[]
|
|
|
|
onBorrowClick: (denom: string) => void
|
2022-10-28 11:14:14 +00:00
|
|
|
onRepayClick: (denom: string) => void
|
2022-10-20 15:39:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const BorrowTable = ({ data, onBorrowClick, onRepayClick }: Props) => {
|
|
|
|
const [sorting, setSorting] = React.useState<SortingState>([])
|
|
|
|
|
|
|
|
const columns = React.useMemo<ColumnDef<Market>[]>(
|
|
|
|
() => [
|
|
|
|
{
|
|
|
|
header: 'Asset',
|
|
|
|
id: 'symbol',
|
|
|
|
accessorFn: (row) => (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='flex flex-1 items-center'>
|
|
|
|
<Image src={row.icon} alt='token' width={32} height={32} />
|
|
|
|
<div className='pl-2'>
|
2022-10-20 15:39:21 +00:00
|
|
|
<div>{row.symbol}</div>
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='text-xs'>{row.chain}</div>
|
2022-10-20 15:39:21 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
),
|
|
|
|
cell: (info) => info.getValue(),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
accessorKey: 'borrowRate',
|
|
|
|
header: 'Borrow Rate',
|
|
|
|
accessorFn: (row) => (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='flex flex-1 items-center text-xs'>
|
2022-10-20 15:39:21 +00:00
|
|
|
{row.borrowRate ? `${(row.borrowRate * 100).toFixed(2)}%` : '-'}
|
|
|
|
</div>
|
|
|
|
),
|
|
|
|
cell: (info) => info.getValue(),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
accessorKey: 'age',
|
|
|
|
header: 'Borrowed',
|
|
|
|
accessorFn: (row) => (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='flex flex-1 items-center text-xs'>
|
2022-10-20 15:39:21 +00:00
|
|
|
{row.borrowed ? (
|
|
|
|
<div>
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='font-bold'>{row.borrowed.amount}</div>
|
2022-10-20 15:39:21 +00:00
|
|
|
<div>{formatCurrency(row.borrowed.value)}</div>
|
|
|
|
</div>
|
|
|
|
) : (
|
|
|
|
'-'
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
),
|
|
|
|
cell: (info) => info.getValue(),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
accessorKey: 'marketLiquidity',
|
|
|
|
header: 'Liquidity Available',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
accessorKey: 'status',
|
|
|
|
enableSorting: false,
|
|
|
|
header: 'Manage',
|
|
|
|
width: 150,
|
|
|
|
cell: ({ row }) => (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='flex items-center justify-end'>
|
2022-11-29 16:45:00 +00:00
|
|
|
<div className='w-5'>
|
|
|
|
{row.getIsExpanded() ? <ChevronUpIcon /> : <ChevronDownIcon />}
|
|
|
|
</div>
|
2022-10-20 15:39:21 +00:00
|
|
|
</div>
|
|
|
|
),
|
|
|
|
},
|
|
|
|
],
|
2022-11-09 09:04:06 +00:00
|
|
|
[],
|
2022-10-20 15:39:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const table = useReactTable({
|
|
|
|
data,
|
|
|
|
columns,
|
|
|
|
state: {
|
|
|
|
sorting,
|
|
|
|
},
|
|
|
|
onSortingChange: setSorting,
|
|
|
|
getCoreRowModel: getCoreRowModel(),
|
|
|
|
getSortedRowModel: getSortedRowModel(),
|
|
|
|
debugTable: true,
|
|
|
|
})
|
|
|
|
|
|
|
|
return (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='w-full table-fixed border-spacing-10 text-sm'>
|
2022-10-20 15:39:21 +00:00
|
|
|
{table.getHeaderGroups().map((headerGroup) => (
|
2022-11-09 09:04:06 +00:00
|
|
|
<div key={headerGroup.id} className='mb-2 flex rounded-md px-4 py-2 text-xs'>
|
2022-10-20 15:39:21 +00:00
|
|
|
{headerGroup.headers.map((header) => {
|
|
|
|
return (
|
|
|
|
<div key={header.id} className={`${header.index === 4 ? 'w-[50px]' : 'flex-1'}`}>
|
|
|
|
{header.isPlaceholder ? null : (
|
|
|
|
<div
|
|
|
|
{...{
|
|
|
|
className: header.column.getCanSort() ? 'cursor-pointer select-none' : '',
|
|
|
|
onClick: header.column.getToggleSortingHandler(),
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{flexRender(header.column.columnDef.header, header.getContext())}
|
|
|
|
{{
|
|
|
|
asc: ' 🔼',
|
|
|
|
desc: ' 🔽',
|
|
|
|
}[header.column.getIsSorted() as string] ?? null}
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</div>
|
|
|
|
))}
|
2022-11-09 09:04:06 +00:00
|
|
|
<div className='flex flex-col gap-2'>
|
2022-10-28 11:14:14 +00:00
|
|
|
{table.getRowModel().rows.length === 0 ? (
|
|
|
|
<div>No Data</div>
|
|
|
|
) : (
|
|
|
|
table.getRowModel().rows.map((row) => {
|
|
|
|
return (
|
|
|
|
<AssetRow
|
|
|
|
key={row.index}
|
|
|
|
data={row.original}
|
|
|
|
onBorrowClick={() => onBorrowClick(row.original.denom)}
|
|
|
|
onRepayClick={() => onRepayClick(row.original.denom)}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
})
|
|
|
|
)}
|
2022-10-20 15:39:21 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default BorrowTable
|