Skip to content

Commit

Permalink
fix(billing): properly handle user state for email verification
Browse files Browse the repository at this point in the history
  • Loading branch information
baktun14 committed Dec 10, 2024
1 parent 979ea68 commit 049c03e
Show file tree
Hide file tree
Showing 7 changed files with 88 additions and 51 deletions.
45 changes: 27 additions & 18 deletions apps/deploy-web/src/components/get-started/GetStartedStepper.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import { browserEnvConfig } from "@src/config/browser-env.config";
import { useChainParam } from "@src/context/ChainParamProvider";
import { useWallet } from "@src/context/WalletProvider";
import { useCustomUser } from "@src/hooks/useCustomUser";
import { useIsEmailVerified } from "@src/hooks/useRequiredEmailVerified";
import { useWalletBalance } from "@src/hooks/useWalletBalance";
import walletStore from "@src/store/walletStore";
import { RouteStep } from "@src/types/route-steps.type";
Expand All @@ -26,6 +27,7 @@ import { uaktToAKT } from "@src/utils/priceUtils";
import { UrlService } from "@src/utils/urlUtils";
import LiquidityModal from "../liquidity-modal";
import { ExternalLink } from "../shared/ExternalLink";
import { VerifyEmail } from "../shared/VerifyEmail";
import { ConnectWalletButton } from "../wallet/ConnectWalletButton";
import { QontoConnector, QontoStepIcon } from "./Stepper";

Expand All @@ -38,6 +40,7 @@ export const GetStartedStepper: React.FunctionComponent = () => {
const usdcBalance = walletBalance ? udenomToDenom(walletBalance.balanceUUSDC) : 0;
const [isSignedInWithTrial] = useAtom(walletStore.isSignedInWithTrial);
const { user } = useCustomUser();
const isEmailVerified = useIsEmailVerified();

useEffect(() => {
const getStartedStep = localStorage.getItem("getStartedStep");
Expand Down Expand Up @@ -104,27 +107,33 @@ export const GetStartedStepper: React.FunctionComponent = () => {

<div className="my-4 flex items-center space-x-4">
{isManagedWallet && (
<TopUpAmountPicker popoverClassName="absolute md:min-w-max" mdMode="hover">
<LoginRequiredLink
className={cn("hover:no-underline", buttonVariants({ variant: "outline", className: "mr-2 border-primary" }))}
href="/api/proxy/v1/checkout"
message="Sign In or Sign Up to add funds to your balance"
>
<HandCard className="text-xs text-accent-foreground" />
<span className="m-2 whitespace-nowrap text-accent-foreground">Add Funds</span>
</LoginRequiredLink>
</TopUpAmountPicker>
)}
<Button variant="default" onClick={handleNext}>
Next
</Button>
{!isManagedWallet && (
<Link className={cn(buttonVariants({ variant: "text" }))} href={UrlService.getStartedWallet()}>
Learn how
</Link>
<div className="flex flex-col items-start space-y-2">
<VerifyEmail />

<TopUpAmountPicker popoverClassName="absolute md:min-w-max" mdMode="hover">
<LoginRequiredLink
className={cn("hover:no-underline", buttonVariants({ variant: "outline", className: "mr-2 border-primary" }))}
href="/api/proxy/v1/checkout"
message="Sign In or Sign Up to add funds to your balance"
disabled={!isEmailVerified}
>
<HandCard className="text-xs text-accent-foreground" />
<span className="m-2 whitespace-nowrap text-accent-foreground">Add Funds</span>
</LoginRequiredLink>
</TopUpAmountPicker>
</div>
)}
</div>

<Button variant="default" onClick={handleNext}>
Next
</Button>
{!isManagedWallet && (
<Link className={cn(buttonVariants({ variant: "text" }))} href={UrlService.getStartedWallet()}>
Learn how
</Link>
)}

{isWalletConnected && isTrialing && (
<div className="my-4 flex items-center space-x-2">
<Check className="text-green-600" />
Expand Down
27 changes: 17 additions & 10 deletions apps/deploy-web/src/components/home/YourAccount.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import { UAKT_DENOM } from "@src/config/denom.config";
import { usePricing } from "@src/context/PricingProvider";
import { useWallet } from "@src/context/WalletProvider";
import { useUsdcDenom } from "@src/hooks/useDenom";
import { useIsEmailVerified } from "@src/hooks/useRequiredEmailVerified";
import useTailwind from "@src/hooks/useTailwind";
import { WalletBalance } from "@src/hooks/useWalletBalance";
import sdlStore from "@src/store/sdlStore";
Expand All @@ -30,6 +31,7 @@ import { ConnectWallet } from "../shared/ConnectWallet";
import { LeaseSpecDetail } from "../shared/LeaseSpecDetail";
import { PriceValue } from "../shared/PriceValue";
import { StatusPill } from "../shared/StatusPill";
import { VerifyEmail } from "../shared/VerifyEmail";

type Props = {
isLoadingBalances: boolean;
Expand All @@ -56,6 +58,7 @@ export const YourAccount: React.FunctionComponent<Props> = ({ isLoadingBalances,
const _storage = bytesToShrink(totalStorage);
const [, setDeploySdl] = useAtom(sdlStore.deploySdl);
const { price, isLoaded } = usePricing();
const isEmailVerified = useIsEmailVerified();

const colors = {
balance_akt: customColors.akashRed,
Expand Down Expand Up @@ -230,16 +233,20 @@ export const YourAccount: React.FunctionComponent<Props> = ({ isLoadingBalances,
</Link>
)}
{isManagedWallet && (
<TopUpAmountPicker className="mt-4 inline-flex flex-col" mdMode="hover">
<LoginRequiredLink
className={cn(buttonVariants({ variant: "default" }))}
href="/api/proxy/v1/checkout"
message="Sign In or Sign Up to add funds to your balance"
>
Add Funds
<HandCard className="ml-4 rotate-45 text-sm" />
</LoginRequiredLink>
</TopUpAmountPicker>
<>
<VerifyEmail className="mt-4" />
<TopUpAmountPicker className="mt-4 inline-flex flex-col" mdMode="hover">
<LoginRequiredLink
className={cn(buttonVariants({ variant: "default" }))}
href="/api/proxy/v1/checkout"
message="Sign In or Sign Up to add funds to your balance"
disabled={!isEmailVerified}
>
Add Funds
<HandCard className="ml-4 rotate-45 text-sm" />
</LoginRequiredLink>
</TopUpAmountPicker>
</>
)}
</div>

Expand Down
20 changes: 20 additions & 0 deletions apps/deploy-web/src/components/shared/VerifyEmail.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { Alert, AlertDescription } from "@akashnetwork/ui/components";
import { cn } from "@akashnetwork/ui/utils";
import { WarningCircle } from "iconoir-react";

import { useIsEmailVerified } from "@src/hooks/useRequiredEmailVerified";

export const VerifyEmail = ({ className }: { className?: string }) => {
const isEmailVerified = useIsEmailVerified();

if (isEmailVerified) return null;

return (
<Alert variant="warning" className={className}>
<AlertDescription className="flex items-center space-x-2">
<WarningCircle className="text-lg" />
<span>Verify your email to add funds to your balance.</span>
</AlertDescription>
</Alert>
);
};
10 changes: 9 additions & 1 deletion apps/deploy-web/src/components/user/LoginRequiredLink.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import React from "react";
import { Button } from "@akashnetwork/ui/components";
import Link, { LinkProps } from "next/link";

import { useLoginRequiredEventHandler } from "@src/hooks/useLoginRequiredEventHandler";
Expand All @@ -9,8 +10,15 @@ export const LoginRequiredLink: FCWithChildren<
LinkProps & {
children?: React.ReactNode;
message: string;
disabled?: boolean;
} & React.RefAttributes<HTMLAnchorElement>
> = ({ message, ...props }) => {
const whenLoggedIn = useLoginRequiredEventHandler();
return <Link {...props} onClick={whenLoggedIn(props.onClick || (() => {}), message)} />;
return props.disabled ? (
<Button className={props.className} disabled>
{props.children}
</Button>
) : (
<Link {...props} onClick={whenLoggedIn(props.onClick || (() => {}), message)} />
);
};
27 changes: 7 additions & 20 deletions apps/deploy-web/src/components/wallet/ManagedWalletPopup.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,23 @@
import React from "react";
import { FormattedNumber } from "react-intl";
import { Alert, AlertDescription, Button, Separator } from "@akashnetwork/ui/components";
import { CoinsSwap, HandCard, WarningCircle } from "iconoir-react";
import { Button, Separator } from "@akashnetwork/ui/components";
import { CoinsSwap, HandCard } from "iconoir-react";

import { TopUpAmountPicker } from "@src/components/top-up-amount-picker/TopUpAmountPicker";
import { useWallet } from "@src/context/WalletProvider";
import { useLoginRequiredEventHandler } from "@src/hooks/useLoginRequiredEventHandler";
import { useManagedEscrowFaqModal } from "@src/hooks/useManagedEscrowFaqModal";
import { useIsEmailVerified } from "@src/hooks/useRequiredEmailVerified";
import { WalletBalance } from "@src/hooks/useWalletBalance";
import { LinkTo } from "../shared/LinkTo";
import { useCustomUser } from "@src/hooks/useCustomUser";
import { VerifyEmail } from "../shared/VerifyEmail";

interface ManagedWalletPopupProps extends React.PropsWithChildren {
walletBalance: WalletBalance;
}

export const ManagedWalletPopup: React.FC<ManagedWalletPopupProps> = ({ walletBalance }) => {
const { user } = useCustomUser();
const isEmailVerified = useIsEmailVerified();
const { switchWalletType, isManaged, isTrialing } = useWallet();
const whenLoggedIn = useLoginRequiredEventHandler();
const { showManagedEscrowFaqModal } = useManagedEscrowFaqModal();
Expand All @@ -25,8 +26,6 @@ export const ManagedWalletPopup: React.FC<ManagedWalletPopupProps> = ({ walletBa
window.location.href = "/api/proxy/v1/checkout";
};

console.log(user);

return (
<div className="w-[300px] p-2">
{isManaged && isTrialing && (
Expand Down Expand Up @@ -75,22 +74,10 @@ export const ManagedWalletPopup: React.FC<ManagedWalletPopupProps> = ({ walletBa
)}

<div className="flex flex-col items-center justify-end space-y-2 pt-2">
{!user?.emailVerified && (
<Alert variant="warning">
<AlertDescription className="flex items-center space-x-2">
<WarningCircle className="text-lg" />
<span>Verify your email to add funds to your balance.</span>
</AlertDescription>
</Alert>
)}
<VerifyEmail />

<TopUpAmountPicker mdMode="click" className="w-full">
<Button
onClick={whenLoggedIn(goToCheckout, "Sign In or Sign Up to add funds")}
variant="outline"
className="w-full space-x-2"
disabled={!user?.emailVerified}
>
<Button onClick={whenLoggedIn(goToCheckout, "Sign In or Sign Up to add funds")} variant="outline" className="w-full space-x-2" disabled={!isEmailVerified}>
<HandCard />
<span>Add Funds</span>
</Button>
Expand Down
4 changes: 2 additions & 2 deletions apps/deploy-web/src/hooks/useHasCreditCardBanner.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import { useEffect, useMemo, useState } from "react";
import { useAtom } from "jotai";

import { browserEnvConfig } from "@src/config/browser-env.config";
import { useWallet } from "@src/context/WalletProvider";
import { useUser } from "./useUser";
import { useAtom } from "jotai";
import walletStore from "@src/store/walletStore";
import { useUser } from "./useUser";

const withBilling = browserEnvConfig.NEXT_PUBLIC_BILLING_ENABLED;

Expand Down
6 changes: 6 additions & 0 deletions apps/deploy-web/src/hooks/useRequiredEmailVerified.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import { useCustomUser } from "./useCustomUser";

export const useIsEmailVerified = () => {
const { user } = useCustomUser();
return !user || !!user?.emailVerified;
};

0 comments on commit 049c03e

Please sign in to comment.