@ -1,5 +1,9 @@
import { BoxProps } from "@chakra-ui/layout" ;
import { BoxProps } from "@chakra-ui/layout" ;
import {
import {
Alert ,
AlertDescription ,
AlertIcon ,
AlertTitle ,
Box ,
Box ,
Button ,
Button ,
ButtonGroup ,
ButtonGroup ,
@ -47,25 +51,38 @@ import { CfdOrderRequestPayload } from "./Types";
const MotionBox = motion < BoxProps > ( Box ) ;
const MotionBox = motion < BoxProps > ( Box ) ;
interface TradeProps {
interface TradeProps {
order_i d? : string ;
orderI d? : string ;
min_q uantity : number ;
minQ uantity : number ;
max_q uantity : number ;
maxQ uantity : number ;
referencePrice? : number ;
referencePrice? : number ;
askPrice? : number ;
askPrice? : number ;
margin? : string ;
margin? : string ;
leverage? : number ;
leverage? : number ;
quantity : string ;
quantity : string ;
liquidationPrice? : number ;
liquidationPrice? : number ;
canSubmit : boolean ;
isSubmitting : boolean ;
isSubmitting : boolean ;
onQuantityChange : any ;
onQuantityChange : any ;
walletBalance? : number ;
onLongSubmit : ( payload : CfdOrderRequestPayload ) = > void ;
onLongSubmit : ( payload : CfdOrderRequestPayload ) = > void ;
}
}
interface AlertBoxProps {
title : string ;
description : string ;
}
function AlertBox ( { title , description } : AlertBoxProps ) {
return ( < Alert status = "error" >
< AlertIcon / >
< AlertTitle mr = { 2 } > { title } < / AlertTitle >
< AlertDescription > { description } < / AlertDescription >
< / Alert > ) ;
}
const Trade = (
const Trade = (
{
{
min_quantity ,
minQ uantity ,
max_quantity ,
maxQ uantity ,
referencePrice : referencePriceAsNumber ,
referencePrice : referencePriceAsNumber ,
askPrice : askPriceAsNumber ,
askPrice : askPriceAsNumber ,
quantity ,
quantity ,
@ -73,9 +90,9 @@ const Trade = (
margin : marginAsNumber ,
margin : marginAsNumber ,
leverage ,
leverage ,
liquidationPrice : liquidationPriceAsNumber ,
liquidationPrice : liquidationPriceAsNumber ,
canSubmit ,
onLongSubmit ,
onLongSubmit ,
order_id ,
orderId ,
walletBalance ,
} : TradeProps ,
} : TradeProps ,
) = > {
) = > {
let outerCircleBg = useColorModeValue ( "gray.100" , "gray.700" ) ;
let outerCircleBg = useColorModeValue ( "gray.100" , "gray.700" ) ;
@ -93,7 +110,7 @@ const Trade = (
const quantityAsNumber = quantity . replace ( "$" , "" ) ;
const quantityAsNumber = quantity . replace ( "$" , "" ) ;
let payload : CfdOrderRequestPayload = {
let payload : CfdOrderRequestPayload = {
order_id : order_i d ! ,
order_id : orderI d ! ,
quantity : Number.parseFloat ( quantityAsNumber ) ,
quantity : Number.parseFloat ( quantityAsNumber ) ,
} ;
} ;
await onLongSubmit ( payload ) ;
await onLongSubmit ( payload ) ;
@ -101,6 +118,34 @@ const Trade = (
} ,
} ,
} ) ;
} ) ;
const parse = ( val : any ) = > Number . parseInt ( val . replace ( /^\$/ , "" ) ) ;
const balanceTooLow = walletBalance && walletBalance < parse ( margin ) ;
const quantityTooHigh = maxQuantity < parse ( quantity ) ;
const quantityTooLow = minQuantity > parse ( quantity ) ;
const quantityGreaterZero = parse ( quantity ) > 0 ;
const canSubmit = orderId && ! isSubmitting && ! balanceTooLow
&& ! quantityTooHigh && ! quantityTooLow && quantityGreaterZero ;
let alertBox ;
if ( balanceTooLow ) {
alertBox = < AlertBox title = { "Your balance is too low!" } description = { "Pleas deposit more into you wallet." } / > ;
}
if ( quantityTooHigh ) {
alertBox = < AlertBox title = { "Quantity too high!" } description = { ` Max available liquidity is ${ maxQuantity } ` } / > ;
}
if ( quantityTooLow || ! quantityGreaterZero ) {
alertBox = < AlertBox title = { "Quantity too low!" } description = { ` Min quantity is ${ minQuantity } ` } / > ;
}
if ( ! orderId ) {
alertBox = < AlertBox
title = { "No liquidity!" }
description = { "The maker you are connected has not create any offers" }
/ > ;
}
return (
return (
< Center >
< Center >
< Grid
< Grid
@ -138,7 +183,7 @@ const Trade = (
< / Center >
< / Center >
< / GridItem >
< / GridItem >
< GridItem colSpan = { 1 } >
< GridItem colSpan = { 1 } >
< Quantity min = { min_q uantity } max = { max_q uantity } quantity = { quantity } onChange = { onQuantityChange } / >
< Quantity min = { minQ uantity } max = { maxQ uantity } quantity = { quantity } onChange = { onQuantityChange } / >
< / GridItem >
< / GridItem >
< GridItem colSpan = { 1 } >
< GridItem colSpan = { 1 } >
< Leverage leverage = { leverage } / >
< Leverage leverage = { leverage } / >
@ -206,6 +251,7 @@ const Trade = (
< / Modal >
< / Modal >
< / ButtonGroup >
< / ButtonGroup >
< / Center >
< / Center >
{ alertBox }
< / GridItem >
< / GridItem >
< / Grid >
< / Grid >
< / Center >
< / Center >