Skip to content

Latest commit

 

History

History
76 lines (50 loc) · 2.24 KB

README.md

File metadata and controls

76 lines (50 loc) · 2.24 KB

Recipe Finder Website

This repository aims to recommend recipes to the users bsed on their search filters.

Built with MERN, HTML, CSS, Jest and Vitest

🌟 Features

* Secure System: Implemented robust user authentication by hashing and securely storing passwords in a MongoDB database, adhering to security-first design principles.
* Dynamic Data Integration: Developed an asynchronous search function using JavaScript Promises and API integration to fetch and filter results dynamically based on user-defined criteria, emphasizing reusability and modularity.
* Responsive Design: Utilized React's component-based architecture and styled components with CSS, to ensure a seamless experience across devices.
* Interactivity: Implemented state management and event-driven functionality in JavaScript to enable features like saving recipes, managing favorites, following users, and posting comments.
* Custom Recipe Creation: Built an intuitive recipe-generation tool leveraging form handling and data validation.

🔧 Prerequisites

Ensure you have Node.js and MongoDB installed.

Project set-up

Install dependencies for both the frontend and api applications:

cd frontend
npm install
cd ../api
npm install

Install an ESLint plugin for your editor, for example ESLint for VSCode

Setting up environment variables.

You need to create two .env files, one in the frontend and one in the api.

Frontend

Create a file frontend/.env with the following contents:

VITE_BACKEND_URL="http://localhost:3000"

Backend

Create a file api/.env with the following contents:

MONGODB_URL="mongodb://0.0.0.0/recipes"
NODE_ENV="development"
JWT_SECRET= [YOUR CHOICE OF PASSWORD]

For an explanation of these environment variables, see the documentation.

How to run the server and use the app

  1. Start the server application (in the api directory) in dev mode:
; cd api
; npm run dev
  1. Start the front end application (in the frontend directory)

In a new terminal session...

; cd frontend
; npx vite

You should now be able to open your browser and go to http://localhost:5174/signup to create a new user.