-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
149 lines (135 loc) · 4.34 KB
/
index.js
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
import Button from "./components/Button";
import MenuItem from "./components/MenuItem";
import "./main.css";
const menu = [
new MenuItem({
id: 1,
title: "buttermilk pancakes",
category: "breakfast",
price: 15.99,
img: "./img/item-1.jpeg",
cook: "John",
desc: `I'm baby woke mlkshk wolf bitters live-edge blue bottle, hammock freegan copper mug whatever cold-pressed `,
}),
new MenuItem({
id: 2,
title: "diner double",
category: "lunch",
price: 13.99,
img: "./img/item-2.jpeg",
desc: `vaporware iPhone mumblecore selvage raw denim slow-carb leggings gochujang helvetica man braid jianbing. Marfa thundercats `,
}),
new MenuItem({
id: 3,
title: "godzilla milkshake",
category: "shakes",
price: 6.99,
img: "./img/item-3.jpeg",
desc: `ombucha chillwave fanny pack 3 wolf moon street art photo booth before they sold out organic viral.`,
}),
new MenuItem({
id: 4,
title: "country delight",
category: "breakfast",
price: 20.99,
img: "./img/item-4.jpeg",
desc: `Shabby chic keffiyeh neutra snackwave pork belly shoreditch. Prism austin mlkshk truffaut, `,
}),
new MenuItem({
id: 5,
title: "egg attack",
category: "lunch",
price: 22.99,
img: "./img/item-5.jpeg",
desc: `franzen vegan pabst bicycle rights kickstarter pinterest meditation farm-to-table 90's pop-up `,
}),
new MenuItem({
id: 6,
title: "oreo dream",
category: "shakes",
price: 18.99,
img: "./img/item-6.jpeg",
desc: `Portland chicharrones ethical edison bulb, palo santo craft beer chia heirloom iPhone everyday`,
}),
new MenuItem({
id: 7,
title: "bacon overflow",
category: "breakfast",
price: 8.99,
img: "./img/item-7.jpeg",
desc: `carry jianbing normcore freegan. Viral single-origin coffee live-edge, pork belly cloud bread iceland put a bird `,
}),
new MenuItem({
id: 8,
title: "american classic",
category: "lunch",
price: 12.99,
img: "./img/item-8.jpeg",
desc: `on it tumblr kickstarter thundercats migas everyday carry squid palo santo leggings. Food truck truffaut `,
}),
new MenuItem({
id: 9,
title: "quarantine buddy",
category: "shakes",
price: 16.99,
img: "./img/item-9.jpeg",
desc: `skateboard fam synth authentic semiotics. Live-edge lyft af, edison bulb yuccie crucifix microdosing.`,
}),
];
const buttonsContainer = document.querySelector("#filters-container");
const menuContainer = document.querySelector("#menu");
function displayMenuItems(menuItems) {
if (menuItems.length > 0) {
const displayItems = menuItems.map((item) => item.render()).join("");
menuContainer.innerHTML = displayItems;
} else {
menuContainer.style.justifyContent = "center";
menuContainer.innerHTML = "<h1>Menu is empty.</h1>";
}
}
function displayFilterButtons(menuItems) {
let categoriesBtns = ["all"];
let categories = menuItems
.map((item) => item.category)
.forEach((category) => {
if (categoriesBtns.includes(category) === false) {
categoriesBtns.push(category);
}
});
// let categories = ["all"].concat(
// Array.from(new Set(menuItems.map((item) => item.category)))
// );
categoriesBtns = categoriesBtns.map((category) => new Button(category));
buttonsContainer.innerHTML = categoriesBtns
.map((btn) => btn.render())
.join("");
const filterBtns = buttonsContainer.querySelectorAll(".filter-btn");
filterBtns.forEach((btn) => {
btn.addEventListener("click", (event) => {
const currentFilter = event.currentTarget;
const lastActiveFilter = buttonsContainer.querySelector(".active");
if (lastActiveFilter) {
lastActiveFilter.classList.remove("active");
}
currentFilter.classList.add("active");
const filterCondition = currentFilter.dataset.filter;
const filteredMenu = menu.filter((menuItem) => {
switch (filterCondition) {
case "all":
return true;
case "breakfast":
return menuItem.category === "breakfast";
case "lunch":
return menuItem.category === "lunch";
case "shakes":
return menuItem.category === "shakes";
default:
return false;
}
});
displayMenuItems(filteredMenu);
});
});
}
displayMenuItems(menu);
displayFilterButtons(menu);