Skip to content

Fabric Clothing is a full-stack react app with complex state management, featuring eCommerce functionalities like login, cart, payment and checkout etc.

License

Notifications You must be signed in to change notification settings

nidhish-nayak/fabric-clothing

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fabric Clothing

Warning This app is completed. I've built this in public. You can follow the process on Github.

Open in GitHub Codespaces

About the Project

Welcome to Fabric Clothing! This application is built using React, Redux, Redux-Thunk, Redux-Toolkit, Firebase and Styled Components. It aims to provide users with an intuitive and seamless shopping experience for clothing items made from premium fabrics.

fabric-clothing

GitHub Language Count GitHub Top Language GitHub Issues GitHub Closed Issues GitHub Pull Requests GitHub Closed Pull Requests GitHub Last Commit GitHub Commit Activity (Year) Github License

Features ✨

  • User Authentication: Users can create accounts, log in, and securely access their personalized profiles.
  • Product Catalog: Browse through a wide range of clothing items, organized into categories for easy navigation.
  • Product Details: View detailed information about each product, including images and descriptions.
  • Shopping Cart: Add desired items to the cart, adjust quantities, and proceed to checkout.
  • Checkout Menu: Users can review and manage their orders and make any changes in the checkout menu.
  • Order History: Users can view their order history to track previous purchases.
  • Razorpay Payment Gateway Integration: Seamlessly integrate Razorpay as the payment gateway for secure and convenient transactions.
  • Responsive Design: Enjoy a consistent and visually appealing experience across various devices.
  • User Experience: You might notice initial load on opening new pages. This is intended for caching the page data for fast loads in the future.
  • Performance: Better performance and accessibility.

fabric-lighthouse

Installation 💻

To run the Fabric Clothing App locally, follow these steps:

  1. Clone the repository:

    git clone https://github.com/Nidhish-D-Nayak/fabric-clothing.git
  2. Navigate to the project directory:

    cd fabric-clothing
  3. Install the dependencies:

    yarn install
  4. Set up Firebase:

    • Create a Firebase project and obtain the necessary configuration credentials.
    • Copy the Firebase configuration object into the src/utils/firebase/firebase.utils.js file.
    • Enable the desired Firebase authentication methods (e.g., Email/Password, Google, etc.).
  5. Start the development server:

    yarn start
  6. Open your browser and visit http://localhost:3000 to access the Fabric Clothing App.

Folder Structure 📂

Here's an overview of the project's folder structure:

├── public/             # Public assets and HTML template
├── src/
│   ├── assets/         # Assets used in the application
│   ├── components/     # Reusable React components
│   ├── routes/         # Top-level application pages
│   ├── store/          # Redux store - redux actions, reducers, and store
|   ├── types/          # Custom and global types defined
│   └── utils/          # Utility functions and constants - Firebase & Reducer
└── ...

Technologies Used 🔧

  • React: JavaScript library for building user interfaces.
  • Redux: State management tool for predictable state updates.
  • Thunks: Middleware libraries for managing asynchronous actions in Redux.
  • Redux Toolkit: A more opinionated state management tool for better developer experience.
  • Styled Components: CSS-in-JS library for styling React components.
  • Firebase: Backend-as-a-Service (BaaS) platform for authentication, database, and storage.
  • Axios: Promise-based HTTP client for making API requests.
  • Typescript: TypeScript checks a program for errors before execution, ensures better developer experience.

How razorpay backend service works 🔌

  • Repository Link: https://github.com/nidhish-nayak/node-razorpay
  • src > components > payment-form.tsx component handles the frontend for the above razorpay backend.
  • To get more insights on razorpay backend service you can refer to the repository which handles this service.
  • Please do not make multiple requests. Instead, you can clone the repo, create your own razorpay account to get KEY_ID and KEY_SECRET.
  • You will be able to recreate this by running it on localhost:4000 using command npm run dev.
  • When both fabric-clothing & node-razorpay are run on localhost, the payment should work seamlessly as I have configured the endpoints.
  • If you need to make this work in production env, you can host node-razorpay on a free backend service and fabric-clothing on vercel/netlify. (Make sure to configure the endpoints & env variables on both services)

ReadMe Card

Contributing 🤝

We welcome contributions to the Fabric Clothing App project! If you would like to try/add any new features or contribute, please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature/fix: git checkout -b feature-name.
  3. Make your changes and commit them: git commit -m 'Add some feature'.
  4. Push the changes to your forked repository: git push origin feature-name.
  5. Open a pull request to the main repository's main branch.

Contributors

License 📝

This project is licensed under the MIT License. Feel free to use, modify, and distribute the code as per the terms of the license.

Contact 💬

If you have any questions, suggestions, or feedback, please don't hesitate to reach out. You can contact the project maintainer at nidhibelthangady@gmail.com.

Happy shopping with the Fabric Clothing App! 🛍️