A modern e-commerce web application inspired by Walmart, built with React, TypeScript, Vite, and Redux Toolkit. This project demonstrates a scalable architecture for online shopping platforms, featuring authentication, product browsing, cart, wishlist, and order management.
- Home Page: Showcases featured products and deals.
- Product Search: Search and filter products by category or keyword.
- Product Details: View detailed information for each product.
- Cart: Add, remove, and update products in the shopping cart.
- Wishlist: Save products for later (requires login).
- Orders: View order history (requires login).
- Authentication: Protected routes for user-specific pages.
- Dark Mode: Theme toggle with persistent storage.
- Responsive Design: Works on desktop and mobile devices.
- React
- TypeScript
- JavaScript
- Vite
- Redux Toolkit
- React Redux
- Redux Thunk
- React Router DOM
- ESLint
- Tailwind CSS
- shadcn/ui
- tweakcn
- Auth0
- lucide-react
- react-bits
- Platzi Fake Store API
- exalidraw
- gsap
- three.js
- Clone the repository:
git clone https://github.com/your-username/Walmart_v1.git cd Walmart_v1
- Install dependencies:
npm install 
- Start the development server:
npm run dev 
- Open in browser: Visit http://localhost:5173
To enable authentication, you need to configure Auth0:
- 
Create an Auth0 Application: - Go to Auth0 Dashboard.
- Create a new application (type: Single Page Application).
- Note your Domain and Client ID.
 
- 
Configure Environment Variables: - Create a .envfile in the root of your project (if not already present).
- Add the following variables:
VITE_AUTH0_DOMAIN=your-auth0-domain VITE_AUTH0_CLIENT_ID=your-auth0-client-id VITE_AUTH0_AUDIENCE=your-auth0-audience (if required) 
- Replace the values with those from your Auth0 dashboard.
 
- Create a 
- 
Update Auth0 Callback URLs: - In your Auth0 application settings, add http://localhost:5173to the Allowed Callback URLs and Allowed Logout URLs.
 
- In your Auth0 application settings, add 
- 
Integrate Auth0 in the App: - The project uses Auth0 React SDK. Make sure the provider is set up in your app (see the relevant code in your srcdirectory).
 
- The project uses Auth0 React SDK. Make sure the provider is set up in your app (see the relevant code in your 
For more details, see the Auth0 React Quickstart.
.  
├── Project_SS
│   ├── Screenshot 2025-06-28 110644.png
│   ├── Screenshot 2025-06-28 110719.png
│   ├── Screenshot 2025-06-28 110744.png
│   ├── Screenshot 2025-06-28 110816.png
│   ├── Screenshot 2025-06-28 110922.png
│   ├── Screenshot 2025-06-28 110958.png
│   └── Walmart_logo_(2025;_Alt).svg
├── README.md
├── components.json
├── eslint.config.js
├── index.html
├── package-lock.json
├── package.json
├── public
│   └── vite.svg
├── src
│   ├── App.css
│   ├── App.tsx
│   ├── assets
│   │   └── react.svg
│   ├── components
│   │   ├── Cart.tsx
│   │   ├── Category.tsx
│   │   ├── CategoryPage.tsx
│   │   ├── Deals.tsx
│   │   ├── Features.tsx
│   │   ├── Footer.tsx
│   │   ├── Home.tsx
│   │   ├── Homegrid.tsx
│   │   ├── Navbar.tsx
│   │   ├── Notfound.tsx
│   │   ├── OrdersPage.tsx
│   │   ├── ProductCard.tsx
│   │   ├── ProductDesPage.tsx
│   │   ├── ProductList.tsx
│   │   ├── ProtectedRoute.tsx
│   │   ├── SearchProductList.tsx
│   │   ├── SearchResults.tsx
│   │   ├── Wishlist.tsx
│   │   ├── login.tsx
│   │   ├── logout.tsx
│   │   ├── magicui
│   │   │   ├── animated-grid-pattern.tsx
│   │   │   ├── dot-pattern.tsx
│   │   │   ├── grid-pattern.tsx
│   │   │   ├── interactive-grid-pattern.tsx
│   │   │   ├── ripple.tsx
│   │   │   └── warp-background.tsx
│   │   ├── mode-toggle.tsx
│   │   ├── profile.tsx
│   │   ├── theme-provider.tsx
│   │   └── ui
│   │       ├── avatar.tsx
│   │       ├── badge.tsx
│   │       ├── button.tsx
│   │       ├── calendar.tsx
│   │       ├── card.tsx
│   │       ├── dropdown-menu.tsx
│   │       ├── input.tsx
│   │       ├── menubar.tsx
│   │       ├── navigation-menu.tsx
│   │       ├── separator.tsx
│   │       ├── sheet.tsx
│   │       ├── sonner.tsx
│   │       ├── switch.tsx
│   │       └── toggle.tsx
│   ├── constants
│   │   └── grid.tsx
│   ├── grid
│   │   ├── Item10.tsx
│   │   ├── Item11.tsx
│   │   ├── Item8.tsx
│   │   └── Item9.tsx
│   ├── index.css
│   ├── lib
│   │   └── utils.ts
│   ├── main.tsx
│   ├── store
│   │   ├── ReduxProvider.tsx
│   │   ├── cartSlice.ts
│   │   ├── index.ts
│   │   ├── orderSlice.ts
│   │   ├── productsSlice.ts
│   │   └── wishlistSlice.ts
│   └── vite-env.d.ts
├── tsconfig.app.json
├── tsconfig.json
├── tsconfig.node.json
└── vite.config.ts
The following screenshots from the Project_SS folder showcase the application:
|  |  |  | 
|  |  |  | 
Contributions are welcome! Please open issues or submit pull requests for improvements and bug fixes.
This project is licensed under the MIT License.