2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								id: 5e302e80e003129199103c78
							 
						 
					
						
							
								
									
										
										
										
											2021-10-21 10:07:52 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								title: Step 21
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								challengeType: 0
							 
						 
					
						
							
								
									
										
										
										
											2021-10-21 10:07:52 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								dashedName: step-21
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# --description--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To track how the `reduce()`  function works, log the values of the `accumulator`  and `currentValue`  in the callback function before the `return`  statement like this: `console.log({ accumulator })` 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can also check your progress by adding `console.log({ total })`  at the end of the `calculate()`  function.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								When you enter calorie values in the form and push the Calculate button, you will see the values of `accumulator`  and `currentValue`  in each iteration of the `reduce()`  callback function.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# --hints--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								See description above for instructions.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								assert(code.replace(/\s/g, '').match(/console.log\({accumulator}\)/));
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# --seed--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## --before-user-code--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```html
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!DOCTYPE html>  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< html >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < head > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < meta  charset = "utf-8"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < title > < / title > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < meta  name = "description"  content = ""  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < meta  name = "viewport"  content = "width=device-width, initial-scale=1"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < link  rel = "stylesheet"  href = "styles.css"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / head > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < body > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < div  class = "container" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < form  id = "calorie-form" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < h2  class = "center" > Calorie Counter< / h2 > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < div  class = "grid" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          < legend > Sex< / legend > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          < div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            < input  type = "radio"  name = "sex"  id = "female"  value = "F"  checked  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            < label  for = "female" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              Female (2,000 calories)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            < / label > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            < div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              < input  type = "radio"  name = "sex"  id = "male"  value = "M"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              < label  for = "male" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                Male (2,500 calories)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              < / label > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < div  class = "grid"  id = "entries" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Breakfast
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          < input 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            type="number"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            min="0"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            class="cal-control"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            id="breakfast"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          />< br  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Lunch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          < input  type = "number"  min = "0"  class = "cal-control"  id = "lunch"  / > < br  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Dinner < input  type = "number"  min = "0"  class = "cal-control"  id = "dinner"  / > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < button  type = "button"  class = "btn-add"  id = "add" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Add Entry
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / button > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < button  type = "submit"  class = "btn-solid"  id = "calculate" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Calculate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / button > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < button  type = "button"  class = "btn-outline"  id = "clear" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Clear
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        < / button > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < / form > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < div  id = "output" > < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / body > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / html >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## --after-user-code--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```html
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / body > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / html >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## --seed-contents--
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```html
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< script >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  document.getElementById('calorie-form').onsubmit = calculate;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  function calculate(e) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    e.preventDefault();
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    const total = Array.from(document.getElementsByClassName('cal-control'))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .map(meal => Number(meal.value))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .reduce((accumulator, currentValue) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // log the values of the `accumulator`  and `currentValue`  here
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return accumulator + currentValue;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      }, 0);
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // log the value of `total`  here
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / script >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-27 19:02:05 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# --solutions--
  
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```html
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< script >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  document.getElementById('calorie-form').onsubmit = calculate;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  function calculate(e) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    e.preventDefault();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const total = Array.from(document.getElementsByClassName('cal-control'))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .map(meal => Number(meal.value))
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      .reduce((accumulator, currentValue) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        console.log({ accumulator });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        console.log({ currentValue });
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return accumulator + currentValue;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      }, 0);
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    console.log({ total });
							 
						 
					
						
							
								
									
										
										
										
											2019-12-07 17:11:14 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / script >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```