1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-11-14 17:24:51 +01:00

basic error handling during add/remove

This commit is contained in:
Matthias Kretschmann 2020-08-19 17:38:14 +02:00
parent da23dd51da
commit cd1c514ac0
Signed by: m
GPG Key ID: 606EEEF3C479A91F
2 changed files with 48 additions and 21 deletions

View File

@ -6,6 +6,7 @@ import Input from '../../../atoms/Input'
import { useOcean } from '@oceanprotocol/react'
import Header from './Header'
import Loader from '../../../atoms/Loader'
import { toast } from 'react-toastify'
export default function Add({
setShowAdd,
@ -19,17 +20,23 @@ export default function Add({
const { ocean, accountId } = useOcean()
const [amount, setAmount] = useState<string>()
const [isLoading, setIsLoading] = useState<boolean>()
const [error, setError] = useState<string>()
async function handleAddLiquidity() {
setIsLoading(true)
const result = await ocean.pool.addOceanLiquidity(
accountId,
poolAddress,
amount
)
console.log(result)
setIsLoading(false)
try {
const result = await ocean.pool.addOceanLiquidity(
accountId,
poolAddress,
amount
)
console.log(result)
} catch (error) {
console.error(error.message)
toast.error(error.message)
} finally {
setIsLoading(false)
}
}
function handleAmountChange(e: ChangeEvent<HTMLInputElement>) {

View File

@ -1,9 +1,12 @@
import React, { ReactElement, useState, ChangeEvent } from 'react'
import styles from './Remove.module.css'
import stylesIndex from './index.module.css'
import Button from '../../../atoms/Button'
import Input from '../../../atoms/Input'
import { useOcean } from '@oceanprotocol/react'
import Header from './Header'
import { toast } from 'react-toastify'
import Loader from '../../../atoms/Loader'
export default function Remove({
setShowRemove,
@ -14,16 +17,27 @@ export default function Remove({
}): ReactElement {
const { ocean, accountId } = useOcean()
const [amount, setAmount] = useState<string>()
const [isLoading, setIsLoading] = useState<boolean>()
const maximumPoolShares = '?'
async function handleRemoveLiquidity() {
await ocean.pool.removeOceanLiquidity(
accountId,
poolAddress,
amount,
maximumPoolShares
)
setIsLoading(true)
try {
const result = await ocean.pool.removeOceanLiquidity(
accountId,
poolAddress,
amount,
maximumPoolShares
)
console.log(result)
} catch (error) {
console.error(error.message)
toast.error(error.message)
} finally {
setIsLoading(false)
}
}
function handleAmountChange(e: ChangeEvent<HTMLInputElement>) {
@ -48,13 +62,19 @@ export default function Remove({
<p>You will receive:</p>
<Button
style="primary"
size="small"
onClick={() => handleRemoveLiquidity()}
>
Remove
</Button>
<div className={stylesIndex.actions}>
{isLoading ? (
<Loader message="Removing Liquidity..." />
) : (
<Button
style="primary"
size="small"
onClick={() => handleRemoveLiquidity()}
>
Supply
</Button>
)}
</div>
</div>
)
}