This app is all about eating burgers, yes, that's right! You'll create a burger 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.
- Eat-Da-Burger! is a restaurant app that lets users input the names of burgers they'd like to eat.
* Whenever a user submits a burger's name, your app will display the burger on the
left side of the page -- waiting to be devoured.
* Each burger in the waiting area also has a `Devour it!` button. When the user
clicks it, the burger will move to the right side of the page.
* Your app will store every burger in a database, whether devoured or not.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.
This app requires a number of programs:
- Node.js
- MySQL Workbench
- NPM Packages:
All the recommended files and directories from the steps above should look like the following structure:
Eat-Da-Burger
│
├── config
│ ├── connection.js
│ └── orm.js
│
├── controllers
│ └── burgers_controller.js
│
├── db
│ ├── schema.sql
│ └── seeds.sql
│
├── models
│ └── burger.js
│
├── node_modules
│
├── package.json
│
├──.env
│
├── public
│ ├── assets
│ │ ├── css
│ │ │ └── burger_style.css
│ │ ├── img
│ │ │ └── burger.png
│ │ └── js
│ │ └── burgers.js
│ │
│ └── test.html
│
├── server.js
│
└── views
├── index.handlebars
│
├── layouts
│ └── main.handlebars
│
└── partials
└── burgers
└── burgers.js
-
Fork a copy to your Github repo and clone it to your computer.
-
Got to your Git Bash and got to into the folder called Eat-Da-Burger.
-
To get all the npm packages required to run this app type into the command line
npm install
-
Create a server.js file.
- On your computer, open MySQL Workbench and login to a local server you have set up.
One option for executing the database code required to run the app is:
-
Open a new SQL tab for executing queries.
-
Then go back to your chosen text editor (I suggest either Visual Studio or Sublime Text) and open your
Eat-Da-Burger
folder. -
Inside the
Eat-Da-Burger
folder you will find a folder nameddb
. -
In the
db
folder, open the file namedschema.sql
. Copy the code in the file and paste it to the new SQL tab you opened in MySQL Workbench. -
Go back to the
db
folder in you text editor and open theseeds.sql
file and copy the code and paste it into the open tab in MySQL Workbench and execute the code.
The other option for running the MySQL code is to:
-
Run the
schema.sql
andseeds.sql
files into the mysql server from the command line -
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 commandsource 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
.
-
In the command line of the main folder of
Eat-Da-Burger
typetouch .env
-
In your text editor, open the
.env
file and typeMYSQL_PASSWORD = "enter your MySQL password here"
-
Save the file
-
In the command line go into main folder of
Eat-Da-Burger
-
Type
node server.js
end hit enter
- Go to your browser and open a new tab and type
localhost:3000
then hit enter
As you can see from the image there are 3 columns: Ready to Eat da Burger, Devoured Burgers, Order da Burger
Eat da Burger Option
-
In the
Ready to Eat da Burger
column, if you hit theDevour It !
button it will change the devour status to true in MySQL, which will place the burger in the Devoured Burgers column. This burger will still be listed in MySQL. For example, if you choose to devour the Grilled Onion Cheeseburger, this is what it looks like in MySQL. Note that the Devour number is a 0 which equals true: -
If then I hit the button to devour it, you can see that the Devour number changes to false, which in binary code is 1: <<<<<<< HEAD =======
55d5e40bc8d59e3d7664e0141f160f482ab9d4af
data:image/s3,"s3://crabby-images/c9f6c/c9f6c222eba3cf65b84aa0cb2a8099a6e1df84ec" alt="Image of MySQL After Devour"
Reorder da Burger
- You can choose to reorder a burger that was eaten if it sounds good to you. Just hit the
Reoder It
button under Devoured Burgers and it will show as Ready to Eat again.
Order da Burger
-
You can add or order a burger by going to that column and typing in the name of your favorite buger then hit order. The burger will be added to the Eat da Burger column since the default setting on adding a burger is to set the Devour to true, which places it in that column.
-
Here is MySQL before I added the burger: <<<<<<< HEAD
-
Here I am adding a Egg and Bacon Burger:
=======
data:image/s3,"s3://crabby-images/c027b/c027ba36043645410dc995431edfc164fe4fc211" alt="Here is MySQL before I added the burger:"
55d5e40bc8d59e3d7664e0141f160f482ab9d4af
-
This shows the addition to the Ready to Eat da Burger column:
-
And lastly that it was added to MySQL:
This application is delployed at https://still-sea-48695.herokuapp.com/
- A big thanks to Sunday coding crew, especially Phil Stubbs who is always, without even trying to, pushing me to do more and better.
- Background Photo by Andrew Walton @w_andrew_j (instagram) on Unsplash
- One issue that I have noticed is that there is a lag in time between making changes on the browser and those changes being updated to the browser and MySQL.