-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAvailableMeals.js
More file actions
51 lines (41 loc) · 1.22 KB
/
AvailableMeals.js
File metadata and controls
51 lines (41 loc) · 1.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import Card from '../UI/Card';
import MealItem from './MealItem/MealItem';
import classes from './AvailableMeals.module.css';
import {useEffect, useState} from "react";
const AvailableMeals = () => {
const [meals,setMeals] =useState([])
useEffect(()=> {
const fetchMeals = async () => {
const response = await fetch("https://react-tasks-731ef-default-rtdb.firebaseio.com/meals.json")
const responseData = await response.json()
const loadedMeals =[]
for (const key in responseData){
loadedMeals.push({
id :key,
name :responseData[key].name,
description :responseData[key].description,
price :responseData[key].price
})
}
setMeals(loadedMeals)
}
fetchMeals()
},[])
const mealsList = meals.map((meal) => (
<MealItem
key={meal.id}
id={meal.id}
name={meal.name}
description={meal.description}
price={meal.price}
/>
));
return (
<section className={classes.meals}>
<Card>
<ul>{mealsList}</ul>
</Card>
</section>
);
};
export default AvailableMeals;