Skip to content

Smoothie logger with MySQL, Node, Express, Handlebars and a homemade ORM

Notifications You must be signed in to change notification settings

nfrazier08/smoothieMountain

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Heroku: https://desolate-beyond-88163.herokuapp.com/

smoothieMountain

Smoothie logger with MySQL, Node, Express, Handlebars and a homemade ORM

Node Express Handlebars

Overview

In this assignment, you'll create a smoothie logger with MySQL, Node, Express, Handlebars and a homemade ORM (yum!). Be sure to follow the MVC design pattern; use Node and MySQL to query and route data in your app, and Handlebars to generate your HTML.

Important

Be sure to utilize the MYSQL Heroku Deployment Guide in order to deploy your assignment.

Before You Begin

  • Eat-Da-smoothie! is a restaurant app that lets users input the names of smoothies they'd like to eat.
  • Whenever a user submits a smoothie's name, your app will display the smoothie on the left side of the page -- waiting to be devoured.
  • Each smoothie in the waiting area also has a Devour it! button. When the user clicks it, the smoothie will move to the right side of the page.
  • Your app will store every smoothie in a database, whether devoured or not.
  • Check out this video of the app for a run-through of how it works.

Instructions

App Setup

  1. Create a GitHub repo called smoothie and clone it to your computer.**
  2. Make a package.json file by running npm init from the command line.**
  3. Install the Express npm package: npm install express --save.**
  4. Create a server.js file.**
  5. Install the Handlebars npm package: npm install express-handlebars --save. **
  6. Install the method-override npm package: npm install method-override --save.**
  7. Install the body-parser npm package: npm install body-parser --save. **
  8. Install MySQL npm package: npm install mysql --save.
  9. Require the following npm packages inside of the server.js file:**
    • express
    • method-override
    • body-parser

DB Setup

  1. Inside your smoothie directory, create a folder named db. **

  2. In the db folder, create a file named schema.sql. Write SQL queries this file that do the following:

    • Create the smoothies_db.
    • Switch to or use the smoothies_db.
    • Create a smoothies table with these fields:
      • id: an auto incrementing int that serves as the primary key.
      • smoothie_name: a string.
      • devoured: a boolean.
      • date: a TIMESTAMP.
  3. Still in the db folder, create a seeds.sql file. In this file, write insert queries to populate the smoothies table with at least three entries.

  4. Run the schema.sql and seeds.sql files into the mysql server from the command line

  5. Now you're going to run these SQL files.

    • Make sure you're in the db folder of your app.
    • Start MySQL command line tool and login: mysql -u root -p.
    • With the mysql> command line tool running, enter the command source schema.sql. This will run your schema file and all of the queries in it -- in other words, you'll be creating your database.
    • Now insert the entries you defined in seeds.sql by running the file: source seeds.sql.
    • Close out of the MySQL command line tool: exit.

Config Setup

  1. Inside your smoothie directory, create a folder named config.**
  2. Create a connection.js file inside config directory.**
    • Inside the connection.js file, setup the code to connect Node to MySQL.
    • Export the connection.
  3. Create an orm.js file inside config directory.
    • Import (require) connection.js into orm.js

    • In the orm.js file, create the methods that will execute the necessary MySQL commands in the controllers. These are the methods you will need to use in order to retrieve and store data in your database.

      • selectAll()
      • insertOne()
      • updateOne()
    • Export the ORM object in module.exports.

Model setup

  • Inside your smoothie directory, create a folder named models.
    • In models, make a smoothie.js file.
      • Inside smoothie.js, import orm.js into smoothie.js
      • Also inside smoothie.js, create the code that will call the ORM functions using smoothie specific input for the ORM.
      • Export at the end of the smoothie.js file.

Controller setup

  1. Inside your smoothie directory, create a folder named controllers.
  2. In controllers, create the smoothies_controller.js file.
  3. Inside the smoothies_controller.js file, import the following:
    • Express
    • smoothie.js
  4. Create the router for the app, and export the router at the end of your file.

View setup

  1. Inside your smoothie directory, create a folder named views.
    • Create the index.handlebars file inside views directory.
    • Create the layouts directory inside views directory.
      • Create the main.handlebars file inside layouts directory.
      • Setup the main.handlebars file so it's able to be used by Handlebars.
      • Setup the index.handlebars to have the template that Handlebars can render onto.
      • Create a button in index.handlebars that will submit the user input into the database.

Directory structure

All the recommended files and directories from the steps above should look like the following structure:

.
├── config
│   ├── connection.js
│   └── orm.js
│ 
├── controllers
│   └── smoothies_controller.js
│
├── db
│   ├── schema.sql
│   └── seeds.sql
│
├── models
│   └── smoothie.js
│ 
├── node_modules
│ 
├── package.json
│
├── public
│   ├── assets
│   │   ├── css
│   │   │   └── smoothie_style.css
│   │   └── img
│   │       └── smoothie.png
│   └── test.html
│
├── server.js
│
└── views
    ├── index.handlebars
    └── layouts
        └── main.handlebars

Minimum Requirements

Attempt to complete homework assignment as described in instructions. If unable to complete certain portions, please pseudocode these portions to describe what remains to be completed.


Hosting on Heroku

Now that we have a backend to our applications, we use Heroku for hosting. Please note that while Heroku is free, it will request credit card information if you have more than 5 applications at a time or are adding a database.

Please see Heroku’s Account Verification Information for more details.


One More Thing

This is a really tough homework assignment, but we want you to put in your best effort to finish it.

If you have any questions about this project or the material we have covered, please post them in the community channels in slack so that your fellow developers can help you! If you're still having trouble, you can come to office hours for assistance from your instructor and TAs.

Good Luck!

Copyright

Coding Boot Camp (C) 2016. All Rights Reserved.

About

Smoothie logger with MySQL, Node, Express, Handlebars and a homemade ORM

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published