Skip to content

Commit

Permalink
Updated checkout flow, to work with guest user
Browse files Browse the repository at this point in the history
  • Loading branch information
gkhaavik committed Dec 1, 2024
1 parent b794744 commit 649c22b
Show file tree
Hide file tree
Showing 29 changed files with 1,464 additions and 282 deletions.
142 changes: 142 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 3 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,12 @@
"@radix-ui/react-checkbox": "^1.1.2",
"@radix-ui/react-dialog": "^1.1.2",
"@radix-ui/react-label": "^2.1.0",
"@radix-ui/react-radio-group": "^1.2.1",
"@radix-ui/react-scroll-area": "^1.2.1",
"@radix-ui/react-select": "^2.1.2",
"@radix-ui/react-separator": "^1.1.0",
"@radix-ui/react-slot": "^1.1.0",
"@radix-ui/react-tabs": "^1.1.1",
"@radix-ui/react-toast": "^1.2.2",
"axios": "^1.7.7",
"class-variance-authority": "^0.7.1",
Expand Down
141 changes: 141 additions & 0 deletions src/app/(client)/checkout/_components/AuthenticationStep.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
"use client";

import React from 'react';
import {
Card,
CardContent,
CardDescription,
CardHeader,
CardTitle,
} from "@/components/ui/card";
import { Button } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import {
Form,
FormControl,
FormField,
FormItem,
FormLabel,
FormMessage,
} from "@/components/ui/form";
import { useForm } from "react-hook-form";
import { zodResolver } from "@hookform/resolvers/zod";
import * as z from "zod";
import { useAuth } from '@/context/AuthContext';
import { useCheckout } from '@/context/CheckoutContext';
import { useToast } from '@/hooks/use-toast';

const loginSchema = z.object({
email: z.string().email(),
password: z.string().min(6, "Password must be at least 6 characters"),
});

export function AuthenticationStep() {
const { isAuthenticated, login } = useAuth();
const { setStep, setIsGuest } = useCheckout();
const { toast } = useToast();
const [isLoading, setIsLoading] = React.useState(false);

const form = useForm<z.infer<typeof loginSchema>>({
resolver: zodResolver(loginSchema),
});

console.log(isAuthenticated);

if (isAuthenticated) {
setStep('information');
return null;
}

const handleLogin = async (data: z.infer<typeof loginSchema>) => {
try {
setIsLoading(true);
await login(data);
setIsGuest(false);
setStep('information');
} catch (error) {
if (error instanceof Error) {
toast({
title: "Login failed",
description: "Invalid email or password",
variant: "destructive",
});
}
} finally {
setIsLoading(false);
}
};

const handleGuestCheckout = () => {
setIsGuest(true);
setStep('information');
};

return (
<Card>
<CardHeader>
<CardTitle>Sign In</CardTitle>
<CardDescription>
Sign in to your account or continue as a guest
</CardDescription>
</CardHeader>
<CardContent className="space-y-6">
<Form {...form}>
<form onSubmit={form.handleSubmit(handleLogin)} className="space-y-4">
<FormField
control={form.control}
name="email"
render={({ field }) => (
<FormItem>
<FormLabel>Email</FormLabel>
<FormControl>
<Input type="email" {...field} />
</FormControl>
<FormMessage />
</FormItem>
)}
/>

<FormField
control={form.control}
name="password"
render={({ field }) => (
<FormItem>
<FormLabel>Password</FormLabel>
<FormControl>
<Input type="password" {...field} />
</FormControl>
<FormMessage />
</FormItem>
)}
/>

<Button type="submit" className="w-full" disabled={isLoading}>
{isLoading ? "Signing in..." : "Sign In"}
</Button>
</form>
</Form>

<div className="relative">
<div className="absolute inset-0 flex items-center">
<div className="w-full border-t border-gray-200" />
</div>
<div className="relative flex justify-center text-sm">
<span className="px-2 bg-background text-muted-foreground">
Or continue with
</span>
</div>
</div>

<Button
variant="outline"
className="w-full"
onClick={handleGuestCheckout}
disabled={isLoading}
>
Continue as Guest
</Button>
</CardContent>
</Card>
);
}
Loading

0 comments on commit 649c22b

Please sign in to comment.