Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/debrajhyper/e-commerce
This is a comprehensive e-commerce full-stack application built using Next.js for the frontend and Node.js with Express.js for the backend. It provides functionality for user authentication, seller product management, and buyer shopping experience.
https://github.com/debrajhyper/e-commerce
bcryptjs cors expressjs jwt-authentication nextjs14 nodejs postgresql reacthookform reactjs shadcn-ui tailwindcss typescript zod zustand
Last synced: 3 months ago
JSON representation
This is a comprehensive e-commerce full-stack application built using Next.js for the frontend and Node.js with Express.js for the backend. It provides functionality for user authentication, seller product management, and buyer shopping experience.
- Host: GitHub
- URL: https://github.com/debrajhyper/e-commerce
- Owner: debrajhyper
- Created: 2024-08-24T07:14:44.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-24T18:28:47.000Z (5 months ago)
- Last Synced: 2024-09-28T12:41:05.489Z (4 months ago)
- Topics: bcryptjs, cors, expressjs, jwt-authentication, nextjs14, nodejs, postgresql, reacthookform, reactjs, shadcn-ui, tailwindcss, typescript, zod, zustand
- Language: TypeScript
- Homepage: https://ecommerce-work.vercel.app
- Size: 4.57 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# đī¸ E-commerce Full Stack Application
This is a comprehensive e-commerce full-stack application built using Next.js for the frontend and Node.js with Express.js for the backend. It provides functionality for user authentication, seller product management, and buyer shopping experience.
## đ UI
Homepage & 404 error page
Login & Signup Page
Login & Signup form validation
Buyer & Seller dashboard Page
Advance search functionality for product name & category
Fallback loading UI
Unauthorize access page for protected routes & Buyer cart page
Seller Add & Edit product page
Add & Edit product form fields with custom validation
## đšī¸ Tech Stack
### Frontend
- Next.js 14.2.6
- React 18
- TypeScript
- Tailwind CSS
- Additional libraries:
- @hookform/resolvers
- @radix-ui (for UI components)
- axios (for API requests)
- react-hook-form (for form handling)
- zod (for schema validation)
- zustand (for state management)### Backend
- Node.js
- Express.js
- PostgreSQL (pg driver)
- Additional libraries:
- bcryptjs (for password hashing)
- jsonwebtoken (for JWT authentication)
- cors (for handling Cross-Origin Resource Sharing)
- dotenv (for environment variable management)## đ Features
### User Authentication & Authorization
- Role based dynamic routes based on user login.
- JSON Web Tokens (JWT) used for maintaining user sessions.
- Tokens securely stored on the client-side for persistent authentication.
- Distinct user roles (seller and buyer) with different permissions and access levels.
- Users can create accounts as either sellers or buyers.
- Custom form validation enforced for enhanced security.
- Passwords hashed using bcrypt before storage in the database.
- Handled Unauthorized access for all roles.
- Seamless one click logout feature.### Seller Functionality
- Sellers can easily add new products with detailed information:
- Product name
- Category selection from predefined options
- Rich text description support
- Price setting with discount
- Edit existing product details and update information in real-time.
- Remove products from the marketplace with safeguards against accidental deletion.
- Have access for his own added products only.### Buyer Functionality
- Search functionality allowing users to find products by name or category.
- Implemented advance debounced search functionality for better UI rendering.
- Sort results automatically by acceding order on every request.
- Buyer can have the flexibility for add to card with quantity directly from product card.
- Remove items or adjust quantities directly from the cart table.
- Persistent cart that saves items for logged-in users across sessions.
- Added cart notification dot with cart count for real time updates.### Responsive Design
- Fully responsive interface adaptable to various screen sizes (desktop, tablet, mobile).
- Consistent user experience across different devices.### Security Features
- HTTPS encryption for all data transmissions.
- CSRF protection for form submissions.
- Input validation and sanitization to prevent SQL injection and XSS attacks.## đĒ Best Practices
- [âī¸] **Input Validation**: All user inputs are validated and sanitized using Zod before being processed or stored in the database.
- [âī¸] **Routing**: Next.js file-based routing system is used effectively, with dynamic routes implemented where necessary.
- [âī¸] **Responsiveness**: The application is designed to be responsive across various devices and screen sizes using Tailwind CSS.
- [âī¸] **Error Handling**: Proper error handling is implemented for various scenarios, with clear and meaningful error messages returned to the client.
- [âī¸] **Code Quality**: The codebase maintains high standards of readability and maintainability, with appropriate comments explaining complex logic.
- [âī¸] **Security**: Best practices for security are followed, including secure authentication with JWT and bcrypt for password hashing.
- [âī¸] **State Management**: Zustand is used for efficient and scalable state management on the frontend.
- [âī¸] **Form Handling**: react-hook-form is utilized for efficient and performant form handling.
- [âī¸] **API Requests**: Axios is used for making HTTP requests, providing a consistent interface for both browser and node.js environments.
- [âī¸] **UI Components**: Shadcn UI is used for accessible and customizable UI components.## đĻ Setup Instructions
### Frontend Setup
1. Clone and navigate to the client directory:
```bash
git clone https://github.com/debrajhyper/e-commerce.git
cd e-commerce/client
```2. Install dependencies:
```bash
npm install
```3. Create a .env file in the root of the client directory and add:
```bash
API_BASE_URL=http://localhost:5000/api // Backend server URL
```4. Run the development server:
```bash
npm run dev
```5. Open [http://localhost:3000](http://localhost:3000) in your browser to see the application.
### Backend Setup
1. Navigate to the server directory:
```bash
cd e-commerce/server
```2. Install dependencies:
```bash
npm install
```3. Create a `.env` file in the root of the server directory and add:
```bash
DB_USER=DATABASE_USER
DB_HOST=DATABASE_HOST
DB_NAME=DATABASE_NAME
DB_PASSWORD=DATABASE_PASSWORD
DB_PORT=DATABASE_PORT
JWT_SECRET=JWT_SECRET
AUTH_ROLE_BUYER=buyer
AUTH_ROLE_SELLER=seller
PORT=5000
```4. Set up your PostgreSQL database and update the connection string in `.env`.
5. Run the server:
```bash
node serve.js
```## đ API Documentation
### Authentication
#### POST /api/auth/signup
Create a new user account.Request body:
```json
{
"email": "string",
"password": "string",
"role": "seller" | "buyer"
}
```#### POST /api/auth/login
Log in to an existing account.Request body:
```json
{
"email": "string",
"password": "string"
}
```Response:
```json
{
"token": "jwt_token",
}
```### Products
#### GET /api/products
Get all products.Response:
```json
[
{
"id": "string",
"name": "string",
"category": "string",
"description": "string",
"price": number,
"discount": number,
"sellerId": "string"
}
]
```#### GET /api/products/:id
Get a specific product by ID.Response:
```json
{
"id": "string",
"name": "string",
"category": "string",
"description": "string",
"price": "string",
"discount": "string",
"sellerId": "string"
}
```#### POST /api/products
Create a new product (seller only).Request body:
```json
{
"name": "string",
"category": "string",
"description": "string",
"price": "string",
"discount": "string"
}
```#### PUT /api/products/:id
Update an existing product (seller only).Request body:
```json
{
"id": "string",
"name": "string",
"category": "string",
"description": "string",
"price": "string",
"discount": "string"
}
```#### DELETE /api/products/:id
Delete a product (seller only).### Cart
#### GET /api/cart
Get the current user's cart.Response:
```json
[
{
"id": "string",
"name": "string",
"category": "string",
"description": "string",
"price": "string",
"discount": "string",
"quantity": number,
"seller_id": number
}
]
```#### POST /api/cart
Add a product to the cart.Request body:
```json
{
"productId": "string",
"quantity": number
}
```#### DELETE /api/cart/:productId
Remove a product from the cart.## đī¸ Project Structure
### Frontend (Next.js)
```
client/
âââ public/
âââ src/
â âââ app/
â | âââ auth/
â | | âââ login/
â | | | âââ page.tsx
â | | âââ signup/
â | | âââ page.tsx
â | âââ buyer/
â | | âââ cart/
â | | | âââ page.tsx
â | | âââ dashboard/
â | | âââ page.tsx
â | âââ seller/
â | | âââ add-product/
â | | | âââ page.tsx
â | | âââ dashboard/
â | | | âââ page.tsx
â | | âââ edit-product/
â | | âââ page.tsx
â | âââ unauthorize/
â | âââ layout.tsx
â | âââ not-found.tsx
â | âââ page.tsx
â âââ components/
â | âââ ui/
â | âââ DashboardTitle.tsx
â | âââ ErrorAlert.tsx
â | âââ Footer.tsx
â | âââ Header.tsx
â | âââ ProductCard.tsx
â | âââ ProductCardLoading.tsx
â | âââ ProductCount.tsx
â | âââ ProductForm.tsx
â | âââ SearchBar.tsx
â âââ constants/
â âââ helpers/
â âââ hooks/
â âââ lib/
â âââ public/
â âââ store/
â âââ styles/
â âââ utils/
âââ .eslintrc.json
âââ next.config.js
âââ package.json
âââ postcss.config.js
âââ tailwind.config.js
âââ tsconfig.json
```### Backend (Node.js)
```
server/
âââ config/
â âââ database.js
âââ controllers/
â âââ authController.js
â âââ cartController.js
â âââ productController.js
âââ middleware/
â âââ auth.js
âââ models/
â âââ Cart.js
â âââ Product.js
â âââ User.js
âââ routes/
â âââ auth.js
â âââ cart.js
â âââ products.js
âââ .env
âââ package.json
âââ server.js
```