This frontend project provides users with e-commerce experience, including product browsing, shopping cart management, and order placement. Built with Next.js and React, it ensures excellent performance and user experience. Additionally, by utilizing Tailwind CSS and Material-Tailwind, the project achieves an aesthetically pleasing and consistent user interface design.
- The homepage displays product carousels and category links, and users can click on the products or categories they are interested in.
- The product page displays all products. Users can search for the desired product using the search bar or click on a product category from the category bar on the left to filter the products.
- Each product has its own page that shows the product name, price, and description. Users can click the “Heart” icon to save products they are interested in and view them on their personal page. After selecting the quantity and adding the product to the shopping cart, users can open the shopping cart page to view the products they have added, along with the quantity and total price. Additionally, relevant product recommendations are provided.
- Modals for user login and registration are available.
- Users can proceed to the checkout page to confirm their shopping list, apply coupons, and provide recipient information for delivery.
- The About page briefly describes this shopping website and the types of products it offers.
- The website is built with responsive design, ensuring a seamless experience across devices of all sizes, whether on mobile, tablet, or desktop.
2024-08-31.14.48.48.-.Compressed.with.FlexClip.mp4
Vercel Link: p-shopping-site-frontend.vercel.app
- frontend
- TypeScript
- React
- Next.js (Next 14)
- Tailwind CSS
- Material Tailwind
- Axios
- backend
- Node.js
- Express.js
- MongoDB
- MongoDB Atlas
- JWT
- bcrypt
Clone this repository and Backend: https://github.com/mollychen7561/p-shoppingSite-backend/
Both run the development CLI:
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
Open http://localhost:3000 with your browser to see the result. (The backend will run on port 5001.)
You can start editing the page by modifying app/page.tsx
. The page auto-updates as you edit the file.
If you want to deploy to vercel and connect to MongoDB Atlas:
- The frontend and backend may need to be deployed separately, as deploying them together often results in failure for me.
- Go to backend project setting -> Integrations -> MongoDB Atlas Connect Account of the vercel project.
- Go to MongoDB Atlas -> Database Access -> Use vercel-admin-user and its password in vercel as the MONGODB_URI of the project environment variable. Remember to add your JWT_SECRET and CORS_ORIGIN (front-end URL).