React | IronNutrition
Introduction
You just realized that since the beginning of the bootcamp, your diet is not healthy and it may have an impact on your health (and productivity), now and in the long term.
To take care of the food you eat, you decided to create a nutrition app that will track everything you eat!
Requirements
- Fork this repo
- Clone this repo
Submission
-
Upon completion, run the following commands:
git add . git commit -m "done" git push origin master
-
Create Pull Request so your TAs can check up your work.
Instructions
Bulma installation
We will use Bulma for the design :)
$ npm install bulma --save
import 'bulma/css/bulma.css';
Import a JSON
Import the foods from the foods.json
.
import foods from './foods.json'
About the design
If you struggle with the design, you can find a static example of what is expected inside file style-guides.html
in the starter-code
folder.
So let's start:
FoodBox
component
Iteration 1 | Create Create a FoodBox
component that takes at least food
as a prop and displays a box with all the information about an ingredient.
You can use this HTML snippet to display properly the FoodBox
:
<div className="box">
<article className="media">
<div className="media-left">
<figure className="image is-64x64">
<img src="https://i.imgur.com/eTmWoAN.png" />
</figure>
</div>
<div className="media-content">
<div className="content">
<p>
<strong>Pizza</strong> <br />
<small>400 cal</small>
</p>
</div>
</div>
<div className="media-right">
<div className="field has-addons">
<div className="control">
<input
className="input"
type="number"
value="1"
/>
</div>
<div className="control">
<button className="button is-info">
+
</button>
</div>
</div>
</div>
</article>
</div>
Iteration 2 | Display food
In your App
component (your main component), display as many FoodBox
as elements inside the variable foods
.
Iteration 3 | Add new food
Create a button to add new foods.
When a user clicks the button, a form will appear with fields for a name, number of calories, and an image.
When the user clicks submit, the food will be added to the list.
The form should disappear when the user clicks the submit button.
Iteration 4 | Implement search bar
Create a Search
component to perform a search that updates the list of all meal.
Iteration 5 | Create add buttons
On your FoodBox
, you have an input an "+" button. Use them so that when a user clicks on the button, it adds them on a list on the right called "Today's foods".
You will also need to display the total amount of calories at the bottom of the list as a recap.
If you don't remember how to create responsive columns with Bulma, you can check the documentation.
Iteration 5 | Bonus | Group ingredients
You made an awesome application, but you have found a little problem in the UX. For example, if you click twice on "Pizza", it will display 2 lines "1 Pizza = 400 cal" instead of 1 line "2 Pizza = 800 cal". Fix that problem.
Iteration 6 | Bonus | Allow the user to remove an ingredient
On the "Today's food", add a trash icon to let users removing one of their items.
Happy coding! ❤️