Skip to content
This repository has been archived by the owner on Jan 13, 2025. It is now read-only.

A fully functional E-commerce website which allows the users to login, add/delete products to/from cart, view products in detail and process payment of the products. This application has been built using React, NextJS, React MUI, Sanity (Headless CMS), and Stripe (Payment API).

License

Notifications You must be signed in to change notification settings

Sumer16/hotelmart-ecommerce

Repository files navigation

License: MIT

HotelMart Landing Page

NOTE: This project is no longer maintained.

About HotelMart

This is a fully functional e-commerce website that allows users to login, add/delete products to/from cart, view products in detail, and process payment for products. This platform is built using React, Next.js, React MUI, Sanity (Headless CMS), and Stripe & PayPal (Payment APIs), and deployed on Vercel.

Key Featues

  • Server-rendered pages using Next.js
  • User authentication & Product management using Sanity Headless CMS
  • Shopping cart functionality using React Context API
  • Payment processing using Stripe & PayPal Payment APIs
  • Stunning UI designed using React Material UI
  • Secure authentication method using JWT & bycrypt
  • Light & Dark mode available for better user accessibility

Installation

Clone the repository

To get started, you'll need to clone this repository to your local machine. You can do this by running the following in the command line:

git clone https://github.com/Sumer16/hotelmart-ecommerce.git 

Install dependencies

Once you've cloned the repository, navigate to the project directory and run npm/yarn install to install all the necessary dependencies.

cd hotelmart-ecommerce

npm install
# or
yarn install

Setup the environment variables

After the dependencies have been installed, create a .env file in the root of the project and add all your necessary API credentials such as Stripe, PayPal and Sanity:

SANITY_PROJECT_ID=your_sanity_project_id
SANITY_DATASET=your_sanity_dataset

JWT_WEB_SECRET=your_secret_key

NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=your_stripe_publishable_key
NEXT_PUBLIC_STRIPE_SECRET_KEY=your_stripe_secret_key

PAYPAL_CLIENT_ID=your_paypal_client_id

Setup Sanity

Create your own Sanity project using the following command:

npm create sanity@latest -- --template clean --create-project "{Your project name}" --dataset production

After creating your Sanity project, run the Sanity studio locally:

cd sanity-project

npm run dev

This will build the studio application and start a local development server so you can run the app in your browser. Once the build is complete, you can head over to http://localhost:3333 to use the Sanity Studio.

Run the development server

After the dependencies have been installed, you can start the development server by running:

npm run dev
# or
yarn dev

This will start the server at http://localhost:3000, and you can view the website in your browser.

Open http://localhost:3000 with your browser to see the result.

Build for production

npm run build
# or
yarn build

Deploy on Vercel

The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.

npm install -g vercel
# or
yarn global add vercel

vercel

Check out our Next.js deployment documentation for more details.

Things to say

I hope you find this e-commerce website to be a solid starting point for building your own online store. If you have any questions or feedback, please feel free to open an issue in this repository. Happy shopping!

About

A fully functional E-commerce website which allows the users to login, add/delete products to/from cart, view products in detail and process payment of the products. This application has been built using React, NextJS, React MUI, Sanity (Headless CMS), and Stripe (Payment API).

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published