ScrollMe is an open-source, feature-rich eCommerce platform that provides a modern shopping experience. Built with JavaScript, React, Styled Components, Node.js (Express.js), and MongoDB, ScrollMe offers a robust front-end with a highly scalable backend. This project is ideal for those looking to contribute to an eCommerce solution or understand the integration of modern web technologies.
- Modern UI/UX: Intuitive, responsive design for a seamless shopping experience.
- Product Management: Admin interface for adding, updating, and removing products.
- User Authentication: Secure user registration, login, and JWT-based authentication.
- Search and Filters: Search for products and apply filters based on categories, prices, and more.
- Shopping Cart: Add, update, or remove items from the cart, with real-time calculations.
- Checkout Process: Easy and secure checkout experience.
- Order History: View past orders and order details.
- Product Reviews and Ratings: Users can review and rate products.
- Wishlist: Save favorite items for later purchase.
- Wishlist: Save favourite items for later purchase.
- Payment Gateway Integration: Add integration with payment providers like Stripe or PayPal.
- Responsive Design: Optimized for all devices (mobile, tablet, and desktop).
- MongoDB Integration: Backend management of products, users, and orders with MongoDB.
- Email Notifications: Send order confirmations and updates via email.
- Inventory Management: Track stock levels and manage out-of-stock notifications.
- Discounts and Promotions: Ability to add coupon codes and discounts.
- Multi-language Support: Internationalization for a global audience.
- Admin Dashboard Analytics: Insights into sales, customers, and product performance.
ScrollMe is built using the following technologies:
- JavaScript (ES6+): Core language for building dynamic features.
- React.js: A JavaScript library for building user interfaces.
- Styled Components: A CSS-in-JS tool for modular and customizable component styling.
- Redux: State management library for maintaining global app state and ensuring predictable data flow across components.
- Node.js: Runtime environment for executing server-side JavaScript.
- Express.js: Backend framework for building RESTful APIs.
- MongoDB: NoSQL database for managing products, users, and orders.
- Mongoose: ODM library to interact with MongoDB.
- JWT: For secure user authentication.
- Axios: HTTP client for API communication.
- Nodemon: Automatically restarts the server during development.
- Biome: Code formatter and linter to maintain consistent code style and detect potential errors.
To get started with ScrollMe locally, follow these steps:
-
Clone the repository:
git clone git@github.com:saurabhbakolia/SCROLLME--ECOMMERCE-WEBSITE.git cd SCROLLME--ECOMMERCE-WEBSITE
-
Install dependencies for both frontend and backend:
# Install frontend dependencies npm install # Install backend dependencies cd ./backend npm install
-
Set up environment variables:
In thebackend
directory, we have a.env.example
file. You can create your own.env
file by copying this file and adding the necessary environment variables:cp backend/.env.example backend/.env
-
Start the development server:
# Start the backend cd backend npm run start # Start the frontend npm start
-
Visit the app in your browser:
Openhttp://localhost:3000
to view the application.
Once the project is set up, you can:
- Browse products, add items to the cart, and proceed to checkout.
- Register or log in to track your orders.
- Admins can manage products and orders through the admin dashboard.
We welcome contributions from the community! To contribute to ScrollMe, follow these steps:
- Fork the repository on GitHub.
- Checkout the
develop
branch
git checkout develop
- Install dependencies Run the following command to install project dependencies:
# Install frontend dependencies
cd frontend
npm install
# Install backend dependencies
cd ../backend
npm install
-
Create a branch for your feature or bugfix
git checkout -b feature-name
-
Commit your changes
git commit -m "Add feature-name"
-
Push to your fork
git push origin feature-name
-
Open a pull request: Provide a detailed description of your changes in the pull request template. Link to any relevant issues.
- Ensure code quality by following consistent formatting and naming conventions.
- Write clear and concise commit messages.
- Test your changes thoroughly before submitting a pull request.
We are committed to fostering a welcoming and harassment-free community. All participants are expected to adhere to our Code of Conduct. Please treat others with respect and professionalism in all interactions.
This project is licensed under the MIT License. See the LICENSE file for details.
We appreciate your interest in ScrollMe and look forward to your contributions!
Join our Discord Server for community discussions, support, and collaboration!
We appreciate your interest in ScrollMe and look forward to your contributions!
Just replace https://discord.gg/w4nKprr5 with the actual link to your Discord server. Let me know if you need any further modifications!