From d1cf2f8f3a61fc2cee49b4d508cc2e50816c2859 Mon Sep 17 00:00:00 2001 From: Diogo Ferreira Date: Wed, 12 Jun 2024 15:30:57 +0100 Subject: [PATCH] refactor StackModal - extract StackFrequencyAndDates - Rename StackOrdersProgress and move related orders componentd there --- .../stack-modal/StackFrequencyAndDates.tsx | 54 ++++++++ .../app/components/stack-modal/StackModal.tsx | 119 ++++++------------ ...ckProgress.tsx => StackOrdersProgress.tsx} | 47 ++++--- 3 files changed, 123 insertions(+), 97 deletions(-) create mode 100644 packages/app/components/stack-modal/StackFrequencyAndDates.tsx rename packages/app/components/stack-modal/{StackProgress.tsx => StackOrdersProgress.tsx} (60%) diff --git a/packages/app/components/stack-modal/StackFrequencyAndDates.tsx b/packages/app/components/stack-modal/StackFrequencyAndDates.tsx new file mode 100644 index 00000000..2dc62a5f --- /dev/null +++ b/packages/app/components/stack-modal/StackFrequencyAndDates.tsx @@ -0,0 +1,54 @@ +import { + StackOrderProps, + stackIsComplete, + stackIsFinishedWithFunds, + totalOrderSlotsDone, +} from "@/models"; +import { BodyText } from "@/ui"; +import { formatFrequencyHours, formatTimestampToDateWithTime } from "@/utils"; +import { ReactNode } from "react"; + +const StackDetail = ({ + title, + children, +}: { + title: string; + children: ReactNode; +}) => ( +
+ + {title} + + {children} +
+); + +export const StackFrequencyAndDates = ({ stackOrder }: StackOrderProps) => { + const orderSlots = stackOrder.orderSlots; + const firstSlot = orderSlots[0]; + const lastSlot = orderSlots[orderSlots.length - 1]; + const nextSlot = orderSlots[totalOrderSlotsDone(stackOrder)]; + + return ( +
+ + {formatTimestampToDateWithTime(firstSlot)} + + + {formatTimestampToDateWithTime(lastSlot)} + + + Every {formatFrequencyHours(Number(stackOrder.interval))} + + + {stackIsComplete(stackOrder) + ? "Complete" + : stackIsFinishedWithFunds(stackOrder) + ? "Finished with funds" + : stackOrder.cancelledAt + ? "Cancelled" + : formatTimestampToDateWithTime(nextSlot)} + +
+ ); +}; diff --git a/packages/app/components/stack-modal/StackModal.tsx b/packages/app/components/stack-modal/StackModal.tsx index f9976ac7..715e0704 100644 --- a/packages/app/components/stack-modal/StackModal.tsx +++ b/packages/app/components/stack-modal/StackModal.tsx @@ -1,10 +1,10 @@ "use client"; import Link from "next/link"; -import { ReactNode, useState } from "react"; +import { useState } from "react"; import { cx } from "class-variance-authority"; -import { orderPairSymbolsText, totalOrderSlotsDone } from "@/models/order"; +import { orderPairSymbolsText } from "@/models/order"; import { Modal, ModalFooter, @@ -13,40 +13,40 @@ import { ModalContent, BodyText, ModalHeader, - TitleText, ModalBaseProps, DialogContent, DialogFooterActions, Dialog, } from "@/ui"; -import { - formatFrequencyHours, - formatTimestampToDateWithTime, -} from "@/utils/datetime"; + import { StackOrder, StackOrderProps, calculateStackAveragePrice, - totalStackOrdersDone, totalStacked, totalFundsUsed, stackIsFinishedWithFunds, stackIsComplete, stackRemainingFunds, } from "@/models/stack-order"; -import { formatTokenValue } from "@/utils/token"; -import { getDCAOrderContract } from "@stackly/sdk"; -import { getExplorerLink } from "@/utils/transaction"; -import { useEthersSigner } from "@/utils/ethers"; + import { DialogConfirmTransactionLoading, FromToStackTokenPair, TokenLogoPair, + TransactionLink, } from "@/components"; -import { StackProgress } from "@/components/stack-modal/StackProgress"; -import { StackOrdersTable } from "@/components/stack-modal/StackOrdersTable"; + +import { StackOrdersProgress } from "@/components/stack-modal/StackOrdersProgress"; +import { StackFrequencyAndDates } from "@/components/stack-modal/StackFrequencyAndDates"; + +import { formatTokenValue } from "@/utils/token"; +import { getDCAOrderContract } from "@stackly/sdk"; +import { getExplorerLink } from "@/utils/transaction"; +import { useEthersSigner } from "@/utils/ethers"; + import { ModalId, useModalContext, useNetworkContext } from "@/contexts"; -import { TransactionLink } from "./TransactionLink"; + import { Transaction } from "@/models/stack"; interface StackModalProps extends ModalBaseProps { @@ -75,11 +75,6 @@ export const StackModal = ({ const [cancellationTx, setCancellationTx] = useState(); - const orderSlots = stackOrder.orderSlots; - const firstSlot = orderSlots[0]; - const lastSlot = orderSlots[orderSlots.length - 1]; - const nextSlot = orderSlots[totalOrderSlotsDone(stackOrder)]; - const stackRemainingFundsWithTokenText = `${stackRemainingFunds( stackOrder )} ${stackOrder.sellToken.symbol}`; @@ -183,43 +178,15 @@ export const StackModal = ({ -
- - {formatTimestampToDateWithTime(firstSlot)} - - - {formatTimestampToDateWithTime(lastSlot)} - - - Every {formatFrequencyHours(Number(stackOrder.interval))} - - - {stackIsComplete(stackOrder) - ? "Complete" - : stackIsFinishedWithFunds(stackOrder) - ? "Finished with funds" - : stackOrder.cancelledAt - ? "Cancelled" - : formatTimestampToDateWithTime(nextSlot)} - -
+
- {stackIsFinishedWithFunds(stackOrder) && ( -
- -
- )} +
- - Orders - - - {totalStackOrdersDone(stackOrder) > 0 && ( - - )} +
( ); -const HasRemainingFundsAlertMessage = ({ - remainingFundsWithSymbol, -}: { - remainingFundsWithSymbol: string; -}) => ( -
- - This contract has {remainingFundsWithSymbol} remaining funds. - -
-); +interface WarningHasRemainingFundsProps extends StackOrderProps { + stackRemainingFundsWithTokenText: string; +} -const StackDetail = ({ - title, - children, -}: { - title: string; - children: ReactNode; -}) => ( -
- - {title} - - {children} -
-); +const WarningHasRemainingFunds = ({ + stackOrder, + stackRemainingFundsWithTokenText, +}: WarningHasRemainingFundsProps) => { + if (!stackIsFinishedWithFunds(stackOrder)) return; + + return ( +
+
+ + This contract has {stackRemainingFundsWithTokenText} remaining funds. + +
+
+ ); +}; diff --git a/packages/app/components/stack-modal/StackProgress.tsx b/packages/app/components/stack-modal/StackOrdersProgress.tsx similarity index 60% rename from packages/app/components/stack-modal/StackProgress.tsx rename to packages/app/components/stack-modal/StackOrdersProgress.tsx index 9c65d214..99c80679 100644 --- a/packages/app/components/stack-modal/StackProgress.tsx +++ b/packages/app/components/stack-modal/StackOrdersProgress.tsx @@ -4,7 +4,7 @@ import { totalOrderSlotsDone, } from "@/models/order"; import { OrdersProgressBar } from "@/components/OrdersProgressBar"; -import { BodyText } from "@/ui"; +import { BodyText, TitleText } from "@/ui"; import { TokenIcon } from "@/components/TokenIcon"; import { StackOrderProps, @@ -14,26 +14,37 @@ import { stackIsComplete, } from "@/models/stack-order"; import { formatTokenValue } from "@/utils/token"; +import { StackOrdersTable } from "@/components/stack-modal/StackOrdersTable"; -export const StackProgress = ({ stackOrder }: StackOrderProps) => ( -
-
- -
- - Total funds used:{" "} - - {formatTokenValue(totalFundsUsed(stackOrder), 2)}{" "} - of{" "} - {totalFundsAmountWithTokenText(stackOrder)} - - - +export const StackOrdersProgress = ({ stackOrder }: StackOrderProps) => ( + <> +
+ + Orders + +
+
+ +
+ + Total funds used:{" "} + + {formatTokenValue(totalFundsUsed(stackOrder), 2)}{" "} + of{" "} + {totalFundsAmountWithTokenText(stackOrder)} + + + +
+
+ +
- - -
+ {totalStackOrdersDone(stackOrder) > 0 && ( + + )} + ); const TotalStackEstimationText = ({ stackOrder }: StackOrderProps) => {