@ -1,4 +1,3 @@
import { RepeatIcon } from "@chakra-ui/icons" ;
import {
import {
Box ,
Box ,
Button ,
Button ,
@ -7,7 +6,7 @@ import {
Grid ,
Grid ,
GridItem ,
GridItem ,
HStack ,
HStack ,
IconButton ,
Switch ,
Tab ,
Tab ,
TabList ,
TabList ,
TabPanel ,
TabPanel ,
@ -17,7 +16,7 @@ import {
useToast ,
useToast ,
VStack ,
VStack ,
} from "@chakra-ui/react" ;
} from "@chakra-ui/react" ;
import React , { useState } from "react" ;
import React , { useEffect , use State } from "react" ;
import { useAsync } from "react-async" ;
import { useAsync } from "react-async" ;
import { useEventSource } from "react-sse-hooks" ;
import { useEventSource } from "react-sse-hooks" ;
import { CfdTable } from "./components/cfdtables/CfdTable" ;
import { CfdTable } from "./components/cfdtables/CfdTable" ;
@ -44,7 +43,13 @@ export default function App() {
let [ minQuantity , setMinQuantity ] = useState < string > ( "10" ) ;
let [ minQuantity , setMinQuantity ] = useState < string > ( "10" ) ;
let [ maxQuantity , setMaxQuantity ] = useState < string > ( "100" ) ;
let [ maxQuantity , setMaxQuantity ] = useState < string > ( "100" ) ;
let [ orderPrice , setOrderPrice ] = useState < string > ( "0" ) ;
let [ orderPrice , setOrderPrice ] = useState < string > ( "0" ) ;
let [ hasEnteredPrice , setHasEnteredPrice ] = useState ( false ) ;
let [ autoRefresh , setAutoRefresh ] = useState ( true ) ;
useEffect ( ( ) = > {
if ( autoRefresh && priceInfo ) {
setOrderPrice ( ( priceInfo . ask * SPREAD ) . toFixed ( 2 ) . toString ( ) ) ;
}
} , [ priceInfo , autoRefresh ] ) ;
let { run : makeNewCfdSellOrder , isLoading : isCreatingNewCfdOrder } = useAsync ( {
let { run : makeNewCfdSellOrder , isLoading : isCreatingNewCfdOrder } = useAsync ( {
deferFn : async ( [ payload ] : any [ ] ) = > {
deferFn : async ( [ payload ] : any [ ] ) = > {
@ -110,19 +115,18 @@ export default function App() {
< CurrencyInputField
< CurrencyInputField
onChange = { ( valueString : string ) = > {
onChange = { ( valueString : string ) = > {
setOrderPrice ( parse ( valueString ) ) ;
setOrderPrice ( parse ( valueString ) ) ;
setHasEnteredPrice ( true ) ;
setAutoRefresh ( false ) ;
} }
value = { priceToDisplay ( hasEnteredPrice , orderPrice , priceInfo ) }
/ >
< IconButton
aria - label = "Reduce"
icon = { < RepeatIcon / > }
onClick = { ( ) = > {
if ( priceInfo ) {
setOrderPrice ( ( priceInfo . ask * SPREAD ) . toString ( ) ) ;
}
} }
} }
value = { format ( orderPrice ) }
/ >
/ >
< HStack >
< Switch
id = "auto-refresh"
isChecked = { autoRefresh }
onChange = { ( ) = > setAutoRefresh ( ! autoRefresh ) }
/ >
< Text > Auto - refresh < / Text >
< / HStack >
< / HStack >
< / HStack >
< Text > Leverage : < / Text >
< Text > Leverage : < / Text >
@ -138,7 +142,7 @@ export default function App() {
< GridItem colSpan = { 2 } textAlign = "center" >
< GridItem colSpan = { 2 } textAlign = "center" >
< Button
< Button
disabled = { isCreatingNewCfdOrder }
disabled = { isCreatingNewCfdOrder || orderPrice === "0" }
variant = { "solid" }
variant = { "solid" }
colorScheme = { "blue" }
colorScheme = { "blue" }
onClick = { ( ) = > {
onClick = { ( ) = > {
@ -194,18 +198,6 @@ export default function App() {
) ;
) ;
}
}
function priceToDisplay ( hasEnteredPrice : boolean , orderPrice : string , priceInfo : PriceInfo | null ) {
if ( ! priceInfo ) {
return format ( "0" ) ;
}
if ( ! hasEnteredPrice ) {
return format ( ( priceInfo . ask * SPREAD ) . toString ( ) ) ;
}
return format ( orderPrice ) ;
}
function format ( val : any ) {
function format ( val : any ) {
return ` $ ` + val ;
return ` $ ` + val ;
}
}