Skip to content

Latest commit

 

History

History
120 lines (87 loc) · 2.09 KB

README.md

File metadata and controls

120 lines (87 loc) · 2.09 KB

Cozy Threads 🌱

A sustainable fashion e-commerce platform built with React, TypeScript, Express, and Stripe integration.

Features

  • Browse sustainable fashion items
  • Shopping cart functionality
  • Secure checkout with Stripe
  • Responsive design for all devices
  • Real-time cart updates

Tech Stack

  • React 18
  • TypeScript
  • Vite
  • Redux Toolkit
  • Tailwind CSS
  • Express.js
  • Stripe API

Prerequisites

  • Node.js (v18 or higher)
  • npm (v8 or higher)
  • Stripe account for payment processing

Installation & Setup

Frontend Setup

  1. Clone the repository:
git clone https://github.com/johnwroge/Cozy_Threads.git
cd Cozy_Threads
  1. Install dependencies:
npm install

Backend Setup

  1. Navigate to the server directory:
cd server
  1. Install server dependencies:
npm install
  1. Create a .env file in the server directory:
STRIPE_SECRET_KEY=your_stripe_secret_key
STRIPE_PUBLISHABLE_KEY=your_stripe_publishable_key

Running the Application

  1. Start the backend server (from the server directory):
npm start
  1. In a new terminal, start the frontend development server (from the root directory):
npm run dev

The application will be available at http://localhost:5173

Running Tests

npm run test

To run tests in watch mode:

npm run test:watch

Build for Production

npm run build

The build output will be in the dist directory.

cd server
node server.js

The dist folder will be served by the Express server at http://localhost:4242/

Environment Variables

Backend (server/.env)

STRIPE_SECRET_KEY=your_stripe_secret_key
STRIPE_PUBLISHABLE_KEY=your_stripe_publishable_key

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

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