Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ozematt/shop.co_full-stack_react-nestjs
Shop.co E-commerce App | Full-stack Application Built with NestJS
https://github.com/ozematt/shop.co_full-stack_react-nestjs
api-rest docker jwt-auth nestjs nodejs postgresql postman prisma react react-hook-form react-router react-testing-library redux-toolkit tailwindcss tanstack-query typescript vite vitest zod
Last synced: 9 days ago
JSON representation
Shop.co E-commerce App | Full-stack Application Built with NestJS
- Host: GitHub
- URL: https://github.com/ozematt/shop.co_full-stack_react-nestjs
- Owner: ozematt
- Created: 2025-02-06T16:09:52.000Z (15 days ago)
- Default Branch: main
- Last Pushed: 2025-02-10T18:46:31.000Z (11 days ago)
- Last Synced: 2025-02-10T19:39:39.084Z (11 days ago)
- Topics: api-rest, docker, jwt-auth, nestjs, nodejs, postgresql, postman, prisma, react, react-hook-form, react-router, react-testing-library, redux-toolkit, tailwindcss, tanstack-query, typescript, vite, vitest, zod
- Language: TypeScript
- Homepage:
- Size: 2.26 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Shop.co — Built with NestJS
Welcome to my project Shop.co! The project is available in two versions: one using [Express.js](https://github.com/ozematt/Shop.co_full-stack_React-Express.js) and the other using NestJS. It was created based on a free layout from Figma: [E-commerce Website Template (Freebie)](https://www.figma.com/community/file/1273571982885059508/e-commerce-website-template-freebie). The goal of this project is to practice working with modern frontend and backend tools.
## Features
- **Responsiveness**: The app adjusts to different screen sizes.
- **State Management**: **Redux Toolkit** is used for global state management.
- **Product Search**: Users have access to a product search function.
- **Product Catalog**:
- The app displays products with their images, descriptions, prices, and categories.
- **Filtering** and **sorting** products (e.g., by price, category) features are available.
- **Shopping Cart** – Users can use all the functionalities of the shopping cart.
- **User Management**: Adding and storing users in the database.
- **User Authentication**: After logging in, users can add products to the cart and place an order.
- **Checkout Process** – Users go through the entire shopping process.
- **User Panel** – Users have access to their account information, as well as their purchase history.
- **Theme Support**: Users can switch between **light** and **dark** themes.## Screenshots
### Main View
data:image/s3,"s3://crabby-images/284c6/284c6f05f6d959c7521e2b5f19024ccc6686cd31" alt="HomePage"
### Main View - Dark
data:image/s3,"s3://crabby-images/5b47f/5b47fbcf310dd253db22821459a6f7d4e606ba7e" alt="Mobile"
### Main View - Products
data:image/s3,"s3://crabby-images/0b036/0b03628703c38850a1009914c050f231fbac933c" alt="ProductsView"
### Shopping Cart
data:image/s3,"s3://crabby-images/c9bba/c9bba9e567493baba0d2fab5e9ffaf162edebdbe" alt="CartEmpty"
### Database Schema (to be expanded in the future)
data:image/s3,"s3://crabby-images/a6741/a6741cd4218f9b2afe00b4d1c1387a75700ae735" alt="DatabaseSchema"
## Technology
The project was built using the following technologies:
### FRONTEND:
- **React**: A JavaScript framework for building user interfaces.
- **React-Router**: A library for managing routes in a React application.
- **React Hook Form**: A tool for handling forms in React.
- **TanStack Query**: A tool for managing data from APIs.
- **TypeScript**: A superset of JavaScript that provides static typing, improving the reliability and stability of the app.
- **TailwindCSS**: A modern CSS framework.
- **Vite**: A modern build tool for frontend applications.
- **Redux Toolkit**: A library for global state management.
- **Material-UI (MUI)**: A CSS framework for styling components.
- **Zod**: A data validation library.
- **DummyJSON**: An external API that provides product data such as descriptions, prices, images, and categories (documentation: [https://dummyjson.com/docs](https://dummyjson.com/docs)).
- **REST API**: Data is handled through API endpoints.
- **Vitest** and **React Testing Library**: Tools for unit testing.### BACKEND:
- **Node.js/NestJS**: Backend development framework for scalable applications.
- **Postgres**: A relational database used for storing data.
- **Prisma**: Modern ORM for Node.js with type-safe queries and database migrations.
- **JWT (JSON Web Tokens)**: A technology used for user authentication.
- **CORS**: Middleware that enables resource sharing between different domains.
- **bcryptjs**: A library for securely hashing user passwords before storing them in the database.
- **Docker**: A containerization tool that allows easy deployment and management of the app in isolated environments.
- **Postman**: A tool for testing and documenting APIs. Test collection files and environments are located in the `postman/` directory.The project is set up to run in Docker containers, which ensures seamless integration between the frontend and backend, and maintains consistency across environments.
## Installation
To install the project, follow the steps below:
1. **Clone the repository:**
Fork the repository to your GitHub account, and then clone it locally.
```sh
git clone https://github.com/ozematt/Shop.co_fullstack.git
```
2. **Navigate to the project directory:**
```sh
cd Shop.co_fullstack
```
3. **Build and run the containers:**
Make sure Docker is installed and running. Then, run the following command.```sh
docker-compose up --build
```4. **Access the app:**
- **Frontend**: http://localhost:5173/
- **Backend**: http://localhost:3005/## Features in progress
- **Database**: Expanding the database.
- **Tests**: Adding unit tests and e2e tests.Thank you for visiting the repository! 😊