Skip to content

Latest commit

 

History

History
232 lines (131 loc) · 5.61 KB

README.md

File metadata and controls

232 lines (131 loc) · 5.61 KB

keto-diet-capstone-client

"Everything Keto" app will help users gain all the information they need about the Keto diet. Keto dieters usually have to thoroughly search through scattered information to gather just the basic guidelines. The app will teach the users about the keto diet and guide them through the process. Once successfully registered and logged in, users will be able to search for keto recipes based on a choosen ingredient. The app will be using Spoonacular API. It will display recipes nutriment information as well as their pictures. They will also be able to save their favorite recipes into their account, as well as access them every time they log in. All the more, the app will enable users to read post comments about diet routine, general ideas or even share their own recipes. It’s user-friendly, and accessible to everyone.

Working Prototype

You can access a working prototype of the node app here: https://keto-diet-api.herokuapp.com/ and react app

User Stories

This app is for logged-in user.

Landing Page

  • As a visitor,
  • I want to understand what I can do with this app (or sign up, or log in),
  • So I can decide if I want to use it.

Login Page

  • As a returning register user
  • I want to enter my password and username to use this app,
  • So I can have access to my account.

Sign Up

  • As a visitor
  • I want to register to use this app
  • So I can create a personal Everything Keto account.

Home Page

  • As a logged-in user,
  • I want to be able to preview the content of the app,
  • So i can decide what section I want to navigate to.

About Page

  • As a logged-in user,
  • I want to see guidelines about the keto diet,
  • So that I can start searching and gathering information about the keto diet.

Recipes Page

  • As a logged-in user,
  • I want to be able to find diversed keto recipes from the app,
  • So that I can control and monitor my eating habits.

Forum Page

  • As a logged-in user,
  • I want to be able to search and post comments about the keto experience,
  • So that I can share ideas with the other members.

Account Page

  • As a logged-in user,
  • I want to be able to see my saved favorite recipes from my previous searches, as well as my previous submitted comments,
  • So that I can keep track of my activity on the app.

Wireframes

Landing/Login Page
Landing/Login Page
Home Page
Home Page
Forum Page
Forum Page
My Posts Page
My Posts Page
My recipes Page
My recipes Page

Graybox Wireframes

Full website graybox wireframes
Full website graybox wireframes

Screenshot

Full Page Screenshot
Landing Page

Functionality

The app's functionality includes:

  • User can sort entries by: meal (eg. dinner, dessert, snack, breakfast)

Business Objects (back-end structure)

  • Users (database table)

    • id
    • email (email validation)
    • password (at least one number, one lowercase and one uppercase letter at least eight characters that are letters, numbers or the underscore)
  • Forum

    • id
    • user_id
    • forum_folder_id
    • title
    • description
  • Notes

    • id
    • name
    • content
    • modified
    • id_folder
  • Recipes

    • id
    • user_id
    • title
    • image
    • source

Components Structure

  • Index.js (stateless)
    • App.js (stateful)
      • LandingPage.js (stateful) - gets the "prop name" and the "callback prop name" from the App.js
        • Login.js (stateful) -
        • Register.js (stateful) -
      • HomePage.js (stateful) -
        • Navbar.js (stateless) -
        • About.js (stateless) -
        • Recipes.js (stateless) -
        • Forum.js (statelful) -
          • AddPost.js (statelful) -
      • AccountPage.js (stateful) -
        • Navbar.js (stateless) -
      • MyRecipesPage.js (stateful) -
        • Navbar.js (stateless) -

Api Documentation

Technology

  • Front-End: HTML5, CSS3, JavaScript ES6, React
  • Back-End: Node.js, Express.js, Mocha, Chai, RESTful API Endpoints, Postgress
  • Development Environment: Heroku

Responsive

App is built to be usable on mobile devices, as well as responsive across mobile, tablet, laptop, and desktop screen resolutions.

Development Roadmap

This is v1.0 of the app, but future enhancements are expected to include:

  • More pages in order to include more search results
  • A feature that will provide US & Metric Liquid Volume Conversions

How to run it

Use command line to navigate into the project folder and run the following in terminal

Local Node scripts

  • To install the node project ===> npm install
  • To migrate the database ===> npm run migrate -- 1
  • To run Node server (on port 8000) ===> npm run dev
  • To run tests ===> npm run test

Local React scripts

  • To install the react project ===> npm install
  • To run react (on port 3000) ===> npm start
  • To run tests ===> npm run test