-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
120 lines (104 loc) · 3.26 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
// variables
const urlBase = "https://api.punkapi.com/v2/beers?page=";
const filterABV = document.getElementById("filterABV");
const filterIBU = document.getElementById("filterIBU");
const pageText = document.getElementById("pageNumber");
const prevPage = document.getElementById("prevPage");
const nextPage = document.getElementById("nextPage");
let optionsABV = "", optionsIBU = "", page = 1;
// filters
filterABV.addEventListener("change", e => {
const value = e.target.value;
switch (value) {
case "all":
optionsABV = "";
break
case "weak":
optionsABV = "&abv_lt=4.6"; // built-in to Punk API
break
case "medium":
optionsABV = "&abv_gt=4.5&abv_lt=7.6"; // gt greater than, lt less than
break
case "strong":
optionsABV = "&abv_gt=7.5";
break
}
page = 1;
getBeers();
})
filterIBU.addEventListener("change", e => {
const value = e.target.value;
switch (value) {
case "all":
optionsIBU = "";
break
case "weak":
optionsIBU = "&ibu_lt=35"; // built-in to Punk API
break
case "medium":
optionsIBU = "&ibu_gt=34&ibu_lt=75"; // gt greater than, lt less than
break
case "strong":
optionsIBU = "&ibu_gt=74";
break
}
page = 1;
getBeers();
})
async function getBeers() {
const url = urlBase + page + optionsABV + optionsIBU
// fetch & process
const beerPromise = await fetch(url);
const beers = await beerPromise.json();
// pagination
pageText.innerText = page;
if (page === 1) {
prevPage.disabled = true;
} else {
prevPage.disabled = false;
}
if (beers.length < 25) { // Punk API will only return a max of 25 results at a time
nextPage.disabled = true;
} else {
nextPage.disabled = false;
}
// render data
const beersDiv = document.querySelector('.beers');
let beerHtml = "";
// In the case of missing images (url is null in database). Use generic
const genericBottle = 'https://cdn.pixabay.com/photo/2014/12/22/00/04/bottle-576717_960_720.png';
beers.forEach(beer => {
beerHtml += `
<div class='beer-wrapper card'>
<div class='beer'>
<img class='beer__img' src="${beer.image_url ? beer.image_url : genericBottle}">
<h3>${beer.name}</h3>
<span class='beer__info'>
<span>ABV: ${beer.abv}%</span>
<span>IBU: ${beer.ibu}</span>
</span>
</div>
<div class='beer__content'>
<div class='beer__name'>${beer.name}</div>
<div class='beer__tagline'>${beer.tagline}</div>
<div class='beer__description'>${beer.description}</div>
<div class='beer__food-pairing'>
Pair with: ${beer.food_pairing.join(', ')}
</div>
</div>
</div>
`;
});
beersDiv.innerHTML = beerHtml;
}
// pagination
prevPage.addEventListener('click', () => {
page--;
getBeers();
})
nextPage.addEventListener('click', () => {
page++;
getBeers();
})
// initial get
getBeers();