User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
import React, { FunctionComponent, useEffect, useState } from 'react'
|
|
|
|
import { RadioGroup } from '@headlessui/react'
|
|
|
|
import { CheckCircleIcon } from '@heroicons/react/solid'
|
|
|
|
import {
|
|
|
|
ChevronLeftIcon,
|
|
|
|
CurrencyDollarIcon,
|
|
|
|
PlusCircleIcon,
|
|
|
|
} from '@heroicons/react/outline'
|
|
|
|
import useMangoStore from '../stores/useMangoStore'
|
2021-06-23 08:32:33 -07:00
|
|
|
import { MangoAccount } from '@blockworks-foundation/mango-client'
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
import { abbreviateAddress } from '../utils'
|
|
|
|
import useLocalStorageState from '../hooks/useLocalStorageState'
|
|
|
|
import Modal from './Modal'
|
|
|
|
import { ElementTitle } from './styles'
|
|
|
|
import Button, { LinkButton } from './Button'
|
|
|
|
import NewAccount from './NewAccount'
|
|
|
|
|
|
|
|
interface AccountsModalProps {
|
|
|
|
onClose: () => void
|
|
|
|
isOpen: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
const AccountsModal: FunctionComponent<AccountsModalProps> = ({
|
|
|
|
isOpen,
|
|
|
|
onClose,
|
|
|
|
}) => {
|
|
|
|
const [showNewAccountForm, setShowNewAccountForm] = useState(false)
|
|
|
|
const [newAccPublicKey, setNewAccPublicKey] = useState(null)
|
2021-06-23 08:32:33 -07:00
|
|
|
const mangoAccounts = useMangoStore((s) => s.mangoAccounts)
|
|
|
|
const selectedMangoAccount = useMangoStore(
|
|
|
|
(s) => s.selectedMangoAccount.current
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
)
|
|
|
|
const selectedMangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
|
|
|
|
const prices = useMangoStore((s) => s.selectedMangoGroup.prices)
|
|
|
|
const setMangoStore = useMangoStore((s) => s.set)
|
2021-06-07 10:00:00 -07:00
|
|
|
const actions = useMangoStore((s) => s.actions)
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
const [, setLastAccountViewed] = useLocalStorageState('lastAccountViewed')
|
|
|
|
|
2021-06-23 08:32:33 -07:00
|
|
|
const handleMangoAccountChange = (mangoAccount: MangoAccount) => {
|
|
|
|
setLastAccountViewed(mangoAccount.publicKey.toString())
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
setMangoStore((state) => {
|
2021-06-23 08:32:33 -07:00
|
|
|
state.selectedMangoAccount.current = mangoAccount
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
})
|
2021-06-07 10:00:00 -07:00
|
|
|
actions.fetchTradeHistory()
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
onClose()
|
|
|
|
}
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (newAccPublicKey) {
|
|
|
|
setMangoStore((state) => {
|
2021-06-23 08:32:33 -07:00
|
|
|
state.selectedMangoAccount.current = mangoAccounts.find((ma) =>
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
ma.publicKey.equals(newAccPublicKey)
|
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
2021-06-23 08:32:33 -07:00
|
|
|
}, [mangoAccounts, newAccPublicKey])
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
|
|
|
|
const handleNewAccountCreation = (newAccPublicKey) => {
|
|
|
|
if (newAccPublicKey) {
|
|
|
|
setNewAccPublicKey(newAccPublicKey)
|
|
|
|
}
|
|
|
|
setShowNewAccountForm(false)
|
|
|
|
}
|
|
|
|
|
|
|
|
const handleShowNewAccountForm = () => {
|
|
|
|
setNewAccPublicKey(null)
|
|
|
|
setShowNewAccountForm(true)
|
|
|
|
}
|
|
|
|
|
|
|
|
const getAccountInfo = (acc) => {
|
|
|
|
const accountEquity = acc
|
|
|
|
.computeValue(selectedMangoGroup, prices)
|
|
|
|
.toFixed(2)
|
2021-06-07 16:33:59 -07:00
|
|
|
|
|
|
|
const collRatio = acc.getCollateralRatio(selectedMangoGroup, prices)
|
|
|
|
|
|
|
|
const leverage =
|
|
|
|
accountEquity && collRatio ? (1 / (collRatio - 1)).toFixed(2) : '0.00'
|
|
|
|
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
return (
|
|
|
|
<div className="text-th-fgd-3 text-xs">
|
|
|
|
${accountEquity}
|
|
|
|
<span className="px-1.5 text-th-fgd-4">|</span>
|
|
|
|
<span
|
|
|
|
className={
|
|
|
|
parseFloat(leverage) > 4
|
2021-06-05 15:10:34 -07:00
|
|
|
? 'text-th-red'
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
: parseFloat(leverage) > 2
|
|
|
|
? 'text-th-orange'
|
|
|
|
: 'text-th-green'
|
|
|
|
}
|
|
|
|
>
|
|
|
|
{leverage}x
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Modal isOpen={isOpen} onClose={onClose}>
|
2021-06-23 08:32:33 -07:00
|
|
|
{mangoAccounts.length > 0 ? (
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
!showNewAccountForm ? (
|
|
|
|
<>
|
|
|
|
<Modal.Header>
|
|
|
|
<ElementTitle noMarignBottom>Margin Accounts</ElementTitle>
|
|
|
|
</Modal.Header>
|
|
|
|
<div className="flex items-center justify-between pb-3 text-th-fgd-1">
|
|
|
|
<div className="font-semibold">
|
2021-06-23 08:32:33 -07:00
|
|
|
{mangoAccounts.length > 1
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
? 'Select an account'
|
|
|
|
: 'Your Account'}
|
|
|
|
</div>
|
|
|
|
<Button
|
|
|
|
className="text-xs flex items-center justify-center pt-0 pb-0 h-8 pl-3 pr-3"
|
|
|
|
onClick={() => handleShowNewAccountForm()}
|
|
|
|
>
|
|
|
|
<div className="flex items-center">
|
|
|
|
<PlusCircleIcon className="h-5 w-5 mr-1.5" />
|
|
|
|
New
|
|
|
|
</div>
|
|
|
|
</Button>
|
|
|
|
</div>
|
|
|
|
<RadioGroup
|
2021-06-23 08:32:33 -07:00
|
|
|
value={selectedMangoAccount}
|
|
|
|
onChange={(acc) => handleMangoAccountChange(acc)}
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
>
|
|
|
|
<RadioGroup.Label className="sr-only">
|
|
|
|
Select a Margin Account
|
|
|
|
</RadioGroup.Label>
|
|
|
|
<div className="space-y-2">
|
2021-06-23 08:32:33 -07:00
|
|
|
{mangoAccounts.map((account) => (
|
User account page (#22)
* layout, overview, start on assets, borrows and open orders
* trade history, sortable data hook for tables, borrow page
* handle deposit and withdraw buttons
* borrow modal ui and integration + settle borrow for individual assets
* in orders balance to asset table and totals, responsive css, new connected wallet button + small tweaks
* account switch/creation flow
* accounts modal, update to usebalances hook
* handle settle, deposit before settle, save last account
* disable borrow/withdraw button when no account
2021-06-05 07:11:44 -07:00
|
|
|
<RadioGroup.Option
|
|
|
|
key={account.publicKey.toString()}
|
|
|
|
value={account}
|
|
|
|
className={({ checked }) =>
|
|
|
|
`${
|
|
|
|
checked
|
|
|
|
? 'bg-th-bkg-3 ring-1 ring-th-green ring-inset'
|
|
|
|
: 'bg-th-bkg-1'
|
|
|
|
}
|
|
|
|
relative rounded-md w-full px-3 py-3 cursor-pointer default-transition flex hover:bg-th-bkg-3 focus:outline-none`
|
|
|
|
}
|
|
|
|
>
|
|
|
|
{({ checked }) => (
|
|
|
|
<>
|
|
|
|
<div className="flex items-center justify-between w-full">
|
|
|
|
<div className="flex items-center">
|
|
|
|
<div className="text-sm">
|
|
|
|
<RadioGroup.Label className="cursor-pointer flex items-center text-th-fgd-1">
|
|
|
|
<CurrencyDollarIcon className="h-5 w-5 mr-2.5" />
|
|
|
|
<div>
|
|
|
|
<div className="pb-0.5">
|
|
|
|
{abbreviateAddress(account.publicKey)}
|
|
|
|
</div>
|
|
|
|
{prices && selectedMangoGroup ? (
|
|
|
|
<div className="text-th-fgd-3 text-xs">
|
|
|
|
{getAccountInfo(account)}
|
|
|
|
</div>
|
|
|
|
) : null}
|
|
|
|
</div>
|
|
|
|
</RadioGroup.Label>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{checked && (
|
|
|
|
<div className="flex-shrink-0 text-th-green">
|
|
|
|
<CheckCircleIcon className="w-5 h-5" />
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</RadioGroup.Option>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
</RadioGroup>
|
|
|
|
</>
|
|
|
|
) : (
|
|
|
|
<>
|
|
|
|
<NewAccount onAccountCreation={handleNewAccountCreation} />
|
|
|
|
<LinkButton
|
|
|
|
className="flex items-center mt-4 text-th-fgd-3"
|
|
|
|
onClick={() => setShowNewAccountForm(false)}
|
|
|
|
>
|
|
|
|
<ChevronLeftIcon className="h-5 w-5 mr-1" />
|
|
|
|
Back
|
|
|
|
</LinkButton>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
) : (
|
|
|
|
<NewAccount onAccountCreation={handleNewAccountCreation} />
|
|
|
|
)}
|
|
|
|
</Modal>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default React.memo(AccountsModal)
|