1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-12-02 05:57:29 +01:00

output balance & error feedback

This commit is contained in:
Matthias Kretschmann 2020-07-29 21:08:22 +02:00
parent ef2e5ffad6
commit b36edb2414
Signed by: m
GPG Key ID: 606EEEF3C479A91F
3 changed files with 42 additions and 6 deletions

View File

@ -1,10 +1,29 @@
.advanced { .advanced {
} }
.wallet > button { .wallet {
margin: var(--spacer) auto calc(var(--spacer) / 2) auto; display: flex;
display: block; align-items: center;
justify-content: center;
margin-bottom: calc(var(--spacer) / 2);
}
.balance {
text-align: center;
font-size: var(--font-size-small);
border: 1px solid var(--brand-grey-lighter);
border-right: 0;
margin-right: -3px;
padding: calc(var(--spacer) / 4.5) calc(var(--spacer) / 2);
border-top-left-radius: var(--border-radius);
border-bottom-left-radius: var(--border-radius);
color: var(--color-secondary);
}
.balance strong {
color: var(--brand-grey);
} }
.tokens { .tokens {
margin-bottom: var(--spacer);
} }

View File

@ -1,4 +1,4 @@
import React, { ReactElement, useState, ChangeEvent } from 'react' import React, { ReactElement, useState, ChangeEvent, useEffect } from 'react'
import { InputProps } from '../../../atoms/Input' import { InputProps } from '../../../atoms/Input'
import InputElement from '../../../atoms/Input/InputElement' import InputElement from '../../../atoms/Input/InputElement'
import stylesIndex from './index.module.css' import stylesIndex from './index.module.css'
@ -10,6 +10,7 @@ import Conversion from '../../../atoms/Price/Conversion'
import FormHelp from '../../../atoms/Input/Help' import FormHelp from '../../../atoms/Input/Help'
import Wallet from '../../Wallet' import Wallet from '../../Wallet'
import { useOcean } from '@oceanprotocol/react' import { useOcean } from '@oceanprotocol/react'
import Alert from '../../../atoms/Alert'
export default function Advanced(props: InputProps): ReactElement { export default function Advanced(props: InputProps): ReactElement {
const { price } = props.form.values as MetadataPublishForm const { price } = props.form.values as MetadataPublishForm
@ -21,6 +22,14 @@ export default function Advanced(props: InputProps): ReactElement {
const [ocean, setOcean] = useState('10') const [ocean, setOcean] = useState('10')
const tokensToMint = Number(ocean) * (Number(weightOnDataToken) / 10) const tokensToMint = Number(ocean) * (Number(weightOnDataToken) / 10)
const [error, setError] = useState<string>()
useEffect(() => {
if (balance.ocean < ocean) {
setError(`Insufficiant balance. You need at least ${ocean} OCEAN`)
}
}, [ocean])
function handleOceanChange(event: ChangeEvent<HTMLInputElement>) { function handleOceanChange(event: ChangeEvent<HTMLInputElement>) {
setOcean(event.target.value) setOcean(event.target.value)
} }
@ -34,6 +43,11 @@ export default function Advanced(props: InputProps): ReactElement {
</FormHelp> </FormHelp>
<aside className={styles.wallet}> <aside className={styles.wallet}>
{balance && balance.ocean && (
<div className={styles.balance}>
OCEAN <strong>{balance.ocean}</strong>
</div>
)}
<Wallet /> <Wallet />
</aside> </aside>
@ -70,7 +84,6 @@ export default function Advanced(props: InputProps): ReactElement {
{...props.field} {...props.field}
value={tokensToMint.toString()} value={tokensToMint.toString()}
name="price.tokensToMint" name="price.tokensToMint"
type="number"
readOnly readOnly
/> />
</td> </td>
@ -78,6 +91,8 @@ export default function Advanced(props: InputProps): ReactElement {
</tr> </tr>
</tbody> </tbody>
</table> </table>
{error && <Alert text={error} state="error" />}
</div> </div>
{/* Hidden to fields to actually collect form values for Formik state */} {/* Hidden to fields to actually collect form values for Formik state */}

View File

@ -29,5 +29,7 @@
.help { .help {
text-align: center; text-align: center;
margin-bottom: calc(var(--spacer) / 2); margin-bottom: var(--spacer);
border-bottom: 1px solid var(--brand-grey-lighter);
padding-bottom: var(--spacer);
} }