Browse Source

Remove unnecessary `useAsync` layer

We can make further modifications of the body in the event handler,
no need for doing another `useAsync`.
debug-collab-settlement
Thomas Eizinger 3 years ago
parent
commit
cdf5610ccd
No known key found for this signature in database GPG Key ID: 651AC83A6C6C8B96
  1. 2
      taker-frontend/src/App.tsx
  2. 34
      taker-frontend/src/components/Trade.tsx

2
taker-frontend/src/App.tsx

@ -184,7 +184,7 @@ export const App = () => {
calculateMargin(payload); calculateMargin(payload);
}} }}
onLongSubmit={makeNewOrderRequest} onLongSubmit={makeNewOrderRequest}
isSubmitting={isCreatingNewOrderRequest} isLongSubmitting={isCreatingNewOrderRequest}
/> />
<History <History
cfds={cfds.filter((cfd) => cfd.state.getGroup() !== StateGroupKey.CLOSED)} cfds={cfds.filter((cfd) => cfd.state.getGroup() !== StateGroupKey.CLOSED)}

34
taker-frontend/src/components/Trade.tsx

@ -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>

Loading…
Cancel
Save