Skip to content

Latest commit

 

History

History
138 lines (100 loc) · 5.17 KB

README.md

File metadata and controls

138 lines (100 loc) · 5.17 KB

Gadget Gizmo - eCommerce Platform

MIT License Website Status Follow Me

Gadget Gizmo is a feature-rich eCommerce platform designed to provide a seamless online shopping experience. This platform offers a variety of functionalities and technologies to enhance both user and admin experiences. The project is licensed under the MIT License.

Explore it live at http://gadgetgizmo.shop/

Table of Contents

Key Features

Gadget Gizmo boasts a wide range of features including:

  • Shopping Made Easy: Seamlessly add, remove, and manage items in the shopping cart.
  • Effortless Checkout: Effortlessly navigate the checkout process for a smooth transaction.
  • Admin Product Management: Admins enjoy efficient product management capabilities.
  • User-Centric Profiles: Users can access their order history conveniently.
  • Admin Order View: Administrators gain insights with a detailed view of orders.
  • Smooth PayPal Integration: Effortless payment options for users.
  • Feedback and Ratings: Users can contribute reviews and ratings for products.
  • Highlight Top Products: Highlight top products in an engaging carousel.
  • Efficient Product Search: Easily find desired products through the search feature.
  • Optimized Image Storage: Cloud-based image storage ensures optimal performance.
  • Order Updates: Users can stay informed about their order delivery status.
  • Browse with Ease: Browse products seamlessly with pagination.

Technology Stack

The platform is built using the following technologies:

  • Frontend: Utilizes React and Redux for dynamic user interfaces.
  • Backend: Employs Node.js and Express to handle server-side operations.
  • Database: Relies on MongoDB for efficient data storage and retrieval.
  • Image Storage: Utilizes Cloudinary for efficient image storage and management.
  • Payment Integration: Seamlessly integrates with PayPal JS SDK for smooth payments.
  • Styling: Utilizes Bootstrap for a visually appealing and responsive design.
  • Build Tool: Leverages Vite for fast and efficient project building.
  • Deployment: Uses Cyclic and Fly.io for reliable and scalable deployment.

Usage

To set up and run Gadget Gizmo:

  1. Create a MongoDB database and obtain the MongoDB URI.
  2. Create a PayPal Developer account and obtain the Client ID.
  3. Sign up for a Cloudinary account and obtain the Cloud Name, API Key, and API Secret.
  4. Rename .env.example to .env and fill in the necessary environment variables.
  5. Install server and frontend dependencies using npm install.
  6. Launch the frontend and backend using npm run dev.

Env Variables

Rename the .env.example file to .env and add the following

# Set the environment mode: development or production
NODE_ENV=development

# Choose a port for your server
PORT=5000

# Replace with your MongoDB connection URI
MONGO_URI=ADD_YOUR_MONGO_URI

# Replace with your preferred JWT secret key
JWT_SECRET=ADD_YOUR_SECRET

# Replace with your PayPal client ID for payments
PAYPAL_CLIENT_ID=ADD_YOUR_PAYPAL_CLIENT_ID

# Set the number of items per page for pagination
PAGINATION_LIMIT=PAGE_SIZE_NUMBER

# Replace with your Cloudinary cloud name
CLOUDINARY_CLOUD_NAME=ADD_YOUR_CLOUD_NAME

# Replace with your Cloudinary API key
CLOUDINARY_API_KEY=ADD_YOUR_API_KEY

# Replace with your Cloudinary API secret
CLOUDINARY_API_SECRET=ADD_YOUR_API_SECRET

# Cloudinary URL with API key and secret
CLOUDINARY_URL=cloudinary://ADD_YOUR_API_KEY:ADD_YOUR_API_SECRET@ADD_YOUR_CLOUD_NAME

Install Dependencies

# Install server and frontend dependencies
npm install
cd frontend
npm install

Run

# Launch the frontend (:3000) and backend (:5000)
npm run dev

# Start only the backend server
npm run server

Build & Deploy

For production deployment:

  1. Generate a production build for the frontend using npm run build.
  2. You can seed the database with sample data using npm run data:import and delete all data with npm run data:destroy.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Author

Hey there! I'm Bryan King Pecho, a passionate software developer behind Gadget Gizmo. Let's connect! 👋