|
@ -45,7 +45,6 @@ import { |
|
|
} from "@chakra-ui/react"; |
|
|
} from "@chakra-ui/react"; |
|
|
import { motion } from "framer-motion"; |
|
|
import { motion } from "framer-motion"; |
|
|
import * as React from "react"; |
|
|
import * as React from "react"; |
|
|
import { useAsync } from "react-async"; |
|
|
|
|
|
import { CfdOrderRequestPayload } from "./Types"; |
|
|
import { CfdOrderRequestPayload } from "./Types"; |
|
|
|
|
|
|
|
|
const MotionBox = motion<BoxProps>(Box); |
|
|
const MotionBox = motion<BoxProps>(Box); |
|
@ -61,10 +60,10 @@ interface TradeProps { |
|
|
leverage?: number; |
|
|
leverage?: number; |
|
|
quantity: string; |
|
|
quantity: string; |
|
|
liquidationPrice?: number; |
|
|
liquidationPrice?: number; |
|
|
isSubmitting: boolean; |
|
|
|
|
|
onQuantityChange: any; |
|
|
onQuantityChange: any; |
|
|
walletBalance?: number; |
|
|
walletBalance?: number; |
|
|
onLongSubmit: (payload: CfdOrderRequestPayload) => void; |
|
|
onLongSubmit: (payload: CfdOrderRequestPayload) => void; |
|
|
|
|
|
isLongSubmitting: boolean; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
interface AlertBoxProps { |
|
|
interface AlertBoxProps { |
|
@ -93,6 +92,7 @@ const Trade = ( |
|
|
leverage, |
|
|
leverage, |
|
|
liquidationPrice: liquidationPriceAsNumber, |
|
|
liquidationPrice: liquidationPriceAsNumber, |
|
|
onLongSubmit, |
|
|
onLongSubmit, |
|
|
|
|
|
isLongSubmitting, |
|
|
orderId, |
|
|
orderId, |
|
|
walletBalance, |
|
|
walletBalance, |
|
|
}: TradeProps, |
|
|
}: TradeProps, |
|
@ -107,19 +107,6 @@ const Trade = ( |
|
|
|
|
|
|
|
|
const { isOpen, onOpen, onClose } = useDisclosure(); |
|
|
const { isOpen, onOpen, onClose } = useDisclosure(); |
|
|
|
|
|
|
|
|
let { run: goLong, isLoading: isSubmitting } = useAsync({ |
|
|
|
|
|
deferFn: async () => { |
|
|
|
|
|
const quantityAsNumber = quantity.replace("$", ""); |
|
|
|
|
|
|
|
|
|
|
|
let payload: CfdOrderRequestPayload = { |
|
|
|
|
|
order_id: orderId!, |
|
|
|
|
|
quantity: Number.parseFloat(quantityAsNumber), |
|
|
|
|
|
}; |
|
|
|
|
|
await onLongSubmit(payload); |
|
|
|
|
|
onClose(); |
|
|
|
|
|
}, |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const parse = (val: any) => Number.parseInt(val.replace(/^\$/, "")); |
|
|
const parse = (val: any) => Number.parseInt(val.replace(/^\$/, "")); |
|
|
|
|
|
|
|
|
const balanceTooLow = walletBalance && walletBalance < parse(margin); |
|
|
const balanceTooLow = walletBalance && walletBalance < parse(margin); |
|
@ -127,7 +114,7 @@ const Trade = ( |
|
|
const quantityTooLow = minQuantity > parse(quantity); |
|
|
const quantityTooLow = minQuantity > parse(quantity); |
|
|
const quantityGreaterZero = parse(quantity) > 0; |
|
|
const quantityGreaterZero = parse(quantity) > 0; |
|
|
|
|
|
|
|
|
const canSubmit = orderId && !isSubmitting && !balanceTooLow |
|
|
const canSubmit = orderId && !isLongSubmitting && !balanceTooLow |
|
|
&& !quantityTooHigh && !quantityTooLow && quantityGreaterZero; |
|
|
&& !quantityTooHigh && !quantityTooLow && quantityGreaterZero; |
|
|
|
|
|
|
|
|
let alertBox; |
|
|
let alertBox; |
|
@ -257,7 +244,20 @@ const Trade = ( |
|
|
|
|
|
|
|
|
<ModalFooter> |
|
|
<ModalFooter> |
|
|
<HStack> |
|
|
<HStack> |
|
|
<Button colorScheme="teal" isLoading={isSubmitting} onClick={goLong}> |
|
|
<Button |
|
|
|
|
|
colorScheme="teal" |
|
|
|
|
|
isLoading={isLongSubmitting} |
|
|
|
|
|
onClick={() => { |
|
|
|
|
|
const quantityAsNumber = quantity.replace("$", ""); |
|
|
|
|
|
|
|
|
|
|
|
let payload: CfdOrderRequestPayload = { |
|
|
|
|
|
order_id: orderId!, |
|
|
|
|
|
quantity: Number.parseFloat(quantityAsNumber), |
|
|
|
|
|
}; |
|
|
|
|
|
onLongSubmit(payload); |
|
|
|
|
|
onClose(); |
|
|
|
|
|
}} |
|
|
|
|
|
> |
|
|
Confirm |
|
|
Confirm |
|
|
</Button> |
|
|
</Button> |
|
|
</HStack> |
|
|
</HStack> |
|
|