mirror of
https://github.com/oceanprotocol/market.git
synced 2024-12-02 05:57:29 +01:00
Remove slider quick wins (#222)
* make max display into max button * effect refactor, get amountOcean as early as possible * fix slider styles in Chrome * max button fixes * fix debounce Signed-off-by: mihaisc <mihai.scarlat@smartcontrol.ro> * remove console.log * lower threshold Co-authored-by: mihaisc <mihai.scarlat@smartcontrol.ro>
This commit is contained in:
parent
9f211a14d9
commit
eabb696f49
@ -211,16 +211,28 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
input[type='range'] {
|
input[type='range'] {
|
||||||
background: none;
|
background: transparent;
|
||||||
|
appearance: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type='range']:focus {
|
input[type='range']:focus {
|
||||||
outline: none;
|
outline: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type='range']::-webkit-slider-thumb,
|
/* Selectors need to be split up to work in both engines */
|
||||||
|
input[type='range']::-webkit-slider-thumb {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
margin-top: -0.5rem;
|
||||||
|
background: var(--brand-gradient);
|
||||||
|
border: 2px solid var(--border-color);
|
||||||
|
width: var(--font-size-h4);
|
||||||
|
height: var(--font-size-h4);
|
||||||
|
border-radius: 50%;
|
||||||
|
cursor: pointer;
|
||||||
|
box-shadow: 0 2px 9px 0 rgba(0, 0, 0, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
input[type='range']::-moz-range-thumb {
|
input[type='range']::-moz-range-thumb {
|
||||||
appearance: none;
|
|
||||||
background: var(--brand-gradient);
|
background: var(--brand-gradient);
|
||||||
border: 2px solid var(--border-color);
|
border: 2px solid var(--border-color);
|
||||||
width: var(--font-size-large);
|
width: var(--font-size-large);
|
||||||
@ -230,7 +242,14 @@ input[type='range']::-moz-range-thumb {
|
|||||||
box-shadow: 0 2px 9px 0 rgba(0, 0, 0, 0.2);
|
box-shadow: 0 2px 9px 0 rgba(0, 0, 0, 0.2);
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type='range']::-webkit-slider-runnable-track,
|
input[type='range']::-webkit-slider-runnable-track {
|
||||||
|
margin-top: -1rem;
|
||||||
|
background: var(--border-color);
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
height: 0.3rem;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
input[type='range']::-moz-range-track {
|
input[type='range']::-moz-range-track {
|
||||||
background: var(--border-color);
|
background: var(--border-color);
|
||||||
border-radius: var(--border-radius);
|
border-radius: var(--border-radius);
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
composes: addInput from './Add/index.module.css';
|
composes: addInput from './Add/index.module.css';
|
||||||
padding-left: calc(var(--spacer) * 2);
|
padding-left: calc(var(--spacer) * 2);
|
||||||
padding-right: calc(var(--spacer) * 2);
|
padding-right: calc(var(--spacer) * 2);
|
||||||
|
padding-bottom: calc(var(--spacer) / 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
.userLiquidity {
|
.userLiquidity {
|
||||||
@ -31,15 +32,6 @@
|
|||||||
margin-right: -2rem;
|
margin-right: -2rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.range button {
|
|
||||||
margin-top: calc(var(--spacer) / 4);
|
|
||||||
margin-bottom: 0;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 1rem;
|
|
||||||
right: 2rem;
|
|
||||||
font-size: var(--font-size-mini);
|
|
||||||
}
|
|
||||||
|
|
||||||
.slider {
|
.slider {
|
||||||
position: relative;
|
position: relative;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
@ -47,11 +39,18 @@
|
|||||||
|
|
||||||
.maximum {
|
.maximum {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: -1.5rem;
|
right: -2rem;
|
||||||
bottom: 1.5rem;
|
bottom: 2rem;
|
||||||
font-size: var(--font-size-small);
|
font-size: var(--font-size-mini);
|
||||||
z-index: 0;
|
min-width: 5rem;
|
||||||
pointer-events: none;
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.toggle {
|
||||||
|
margin-top: calc(var(--spacer) / 2);
|
||||||
|
margin-bottom: 0;
|
||||||
|
font-size: var(--font-size-mini);
|
||||||
|
margin-bottom: -2rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.output {
|
.output {
|
||||||
|
@ -3,7 +3,8 @@ import React, {
|
|||||||
useState,
|
useState,
|
||||||
ChangeEvent,
|
ChangeEvent,
|
||||||
useEffect,
|
useEffect,
|
||||||
FormEvent
|
FormEvent,
|
||||||
|
useRef
|
||||||
} from 'react'
|
} from 'react'
|
||||||
import styles from './Remove.module.css'
|
import styles from './Remove.module.css'
|
||||||
import { useOcean } from '@oceanprotocol/react'
|
import { useOcean } from '@oceanprotocol/react'
|
||||||
@ -14,7 +15,7 @@ import { Logger } from '@oceanprotocol/lib'
|
|||||||
import Token from './Token'
|
import Token from './Token'
|
||||||
import FormHelp from '../../../atoms/Input/Help'
|
import FormHelp from '../../../atoms/Input/Help'
|
||||||
import Button from '../../../atoms/Button'
|
import Button from '../../../atoms/Button'
|
||||||
import { getMaxValuesRemove } from './utils'
|
import { getMaxPercentRemove } from './utils'
|
||||||
import { graphql, useStaticQuery } from 'gatsby'
|
import { graphql, useStaticQuery } from 'gatsby'
|
||||||
import PriceUnit from '../../../atoms/Price/PriceUnit'
|
import PriceUnit from '../../../atoms/Price/PriceUnit'
|
||||||
import debounce from 'lodash.debounce'
|
import debounce from 'lodash.debounce'
|
||||||
@ -100,67 +101,46 @@ export default function Remove({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function handleAmountPercentChange(e: ChangeEvent<HTMLInputElement>) {
|
// Get and set max percentage
|
||||||
setAmountPercent(e.target.value)
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleAdvancedButton(e: FormEvent<HTMLButtonElement>) {
|
|
||||||
e.preventDefault()
|
|
||||||
setIsAdvanced(!isAdvanced)
|
|
||||||
}
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!ocean || !poolTokens) return
|
if (!ocean || !poolTokens) return
|
||||||
async function resetValues() {
|
|
||||||
setAmountPoolShares(`0`)
|
|
||||||
setAmountPercent('0')
|
|
||||||
setAmountOcean('0')
|
|
||||||
|
|
||||||
if (isAdvanced === true) {
|
async function getMax() {
|
||||||
setAmountMaxPercent('100')
|
const amountMaxPercent =
|
||||||
setAmountDatatoken('0')
|
isAdvanced === true
|
||||||
} else {
|
? '100'
|
||||||
const { amountMaxPercent } = await getMaxValuesRemove(
|
: await getMaxPercentRemove(ocean, poolAddress, poolTokens)
|
||||||
ocean,
|
|
||||||
poolAddress,
|
|
||||||
poolTokens,
|
|
||||||
`0`
|
|
||||||
)
|
|
||||||
setAmountMaxPercent(amountMaxPercent)
|
setAmountMaxPercent(amountMaxPercent)
|
||||||
}
|
}
|
||||||
}
|
getMax()
|
||||||
resetValues()
|
}, [ocean, isAdvanced, poolAddress, poolTokens])
|
||||||
}, [isAdvanced])
|
|
||||||
|
|
||||||
// Check and set outputs when percentage changes
|
|
||||||
useEffect(() => {
|
|
||||||
if (!ocean || !poolTokens) return
|
|
||||||
|
|
||||||
const getValues = debounce(async () => {
|
|
||||||
const amountPoolShares =
|
|
||||||
(Number(amountPercent) / 100) * Number(poolTokens)
|
|
||||||
setAmountPoolShares(`${amountPoolShares}`)
|
|
||||||
|
|
||||||
|
const getValues = useRef(
|
||||||
|
debounce(async (newAmountPoolShares, isAdvanced) => {
|
||||||
if (isAdvanced === true) {
|
if (isAdvanced === true) {
|
||||||
const tokens = await ocean.pool.getTokensRemovedforPoolShares(
|
const tokens = await ocean.pool.getTokensRemovedforPoolShares(
|
||||||
poolAddress,
|
poolAddress,
|
||||||
`${amountPoolShares}`
|
`${newAmountPoolShares}`
|
||||||
)
|
)
|
||||||
setAmountOcean(tokens?.oceanAmount)
|
setAmountOcean(tokens?.oceanAmount)
|
||||||
setAmountDatatoken(tokens?.dtAmount)
|
setAmountDatatoken(tokens?.dtAmount)
|
||||||
} else {
|
return
|
||||||
const { amountOcean } = await getMaxValuesRemove(
|
}
|
||||||
ocean,
|
|
||||||
|
const amountOcean = await ocean.pool.getOceanRemovedforPoolShares(
|
||||||
poolAddress,
|
poolAddress,
|
||||||
poolTokens,
|
newAmountPoolShares
|
||||||
`${amountPoolShares}`
|
|
||||||
)
|
)
|
||||||
setAmountOcean(amountOcean)
|
setAmountOcean(amountOcean)
|
||||||
}
|
}, 150)
|
||||||
}, 300)
|
)
|
||||||
getValues()
|
// Check and set outputs when amountPoolShares changes
|
||||||
|
useEffect(() => {
|
||||||
|
if (!ocean || !poolTokens) return
|
||||||
|
console.log('eff', amountPoolShares, isAdvanced)
|
||||||
|
getValues.current(amountPoolShares, isAdvanced)
|
||||||
}, [
|
}, [
|
||||||
amountPercent,
|
amountPoolShares,
|
||||||
isAdvanced,
|
isAdvanced,
|
||||||
ocean,
|
ocean,
|
||||||
poolTokens,
|
poolTokens,
|
||||||
@ -168,6 +148,37 @@ export default function Remove({
|
|||||||
totalPoolTokens
|
totalPoolTokens
|
||||||
])
|
])
|
||||||
|
|
||||||
|
// Set amountPoolShares based on set slider value
|
||||||
|
function handleAmountPercentChange(e: ChangeEvent<HTMLInputElement>) {
|
||||||
|
setAmountPercent(e.target.value)
|
||||||
|
if (!poolTokens) return
|
||||||
|
|
||||||
|
const amountPoolShares = (Number(e.target.value) / 100) * Number(poolTokens)
|
||||||
|
setAmountPoolShares(`${amountPoolShares}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleMaxButton(e: ChangeEvent<HTMLInputElement>) {
|
||||||
|
e.preventDefault()
|
||||||
|
setAmountPercent(amountMaxPercent)
|
||||||
|
|
||||||
|
const amountPoolShares =
|
||||||
|
(Number(amountMaxPercent) / 100) * Number(poolTokens)
|
||||||
|
setAmountPoolShares(`${amountPoolShares}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleAdvancedButton(e: FormEvent<HTMLButtonElement>) {
|
||||||
|
e.preventDefault()
|
||||||
|
setIsAdvanced(!isAdvanced)
|
||||||
|
|
||||||
|
setAmountPoolShares('0')
|
||||||
|
setAmountPercent('0')
|
||||||
|
setAmountOcean('0')
|
||||||
|
|
||||||
|
if (isAdvanced === true) {
|
||||||
|
setAmountDatatoken('0')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={styles.remove}>
|
<div className={styles.remove}>
|
||||||
<Header title={content.title} backAction={() => setShowRemove(false)} />
|
<Header title={content.title} backAction={() => setShowRemove(false)} />
|
||||||
@ -190,17 +201,25 @@ export default function Remove({
|
|||||||
value={amountPercent}
|
value={amountPercent}
|
||||||
onChange={handleAmountPercentChange}
|
onChange={handleAmountPercentChange}
|
||||||
/>
|
/>
|
||||||
{isAdvanced === false && (
|
<Button
|
||||||
<span
|
style="text"
|
||||||
|
size="small"
|
||||||
className={styles.maximum}
|
className={styles.maximum}
|
||||||
>{`${amountMaxPercent}% max.`}</span>
|
onClick={handleMaxButton}
|
||||||
)}
|
>
|
||||||
|
{`${amountMaxPercent}% max`}
|
||||||
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<FormHelp>
|
<FormHelp>
|
||||||
{isAdvanced === true ? content.advanced : content.simple}
|
{isAdvanced === true ? content.advanced : content.simple}
|
||||||
</FormHelp>
|
</FormHelp>
|
||||||
<Button style="text" size="small" onClick={handleAdvancedButton}>
|
<Button
|
||||||
|
style="text"
|
||||||
|
size="small"
|
||||||
|
onClick={handleAdvancedButton}
|
||||||
|
className={styles.toggle}
|
||||||
|
>
|
||||||
{isAdvanced === true ? 'Simple' : 'Advanced'}
|
{isAdvanced === true ? 'Simple' : 'Advanced'}
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
import { Ocean } from '@oceanprotocol/lib'
|
import { Ocean } from '@oceanprotocol/lib'
|
||||||
|
|
||||||
export async function getMaxValuesRemove(
|
export async function getMaxPercentRemove(
|
||||||
ocean: Ocean,
|
ocean: Ocean,
|
||||||
poolAddress: string,
|
poolAddress: string,
|
||||||
poolTokens: string,
|
poolTokens: string
|
||||||
amountPoolShares: string
|
): Promise<string> {
|
||||||
): Promise<{ amountMaxPercent: string; amountOcean: string }> {
|
|
||||||
const amountMaxOcean = await ocean.pool.getOceanMaxRemoveLiquidity(
|
const amountMaxOcean = await ocean.pool.getOceanMaxRemoveLiquidity(
|
||||||
poolAddress
|
poolAddress
|
||||||
)
|
)
|
||||||
@ -22,10 +21,5 @@ export async function getMaxValuesRemove(
|
|||||||
amountMaxPercent = '100'
|
amountMaxPercent = '100'
|
||||||
}
|
}
|
||||||
|
|
||||||
const amountOcean = await ocean.pool.getOceanRemovedforPoolShares(
|
return amountMaxPercent
|
||||||
poolAddress,
|
|
||||||
amountPoolShares
|
|
||||||
)
|
|
||||||
|
|
||||||
return { amountMaxPercent, amountOcean }
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user