-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
68 lines (59 loc) · 1.89 KB
/
script.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
function fetchUser() {
showSpinner();
fetch("https://randomuser.me/api")
.then((res) => {
if (!res.ok) {
throw new Error("Request Failed");
}
return res.json();
})
.then((data) => {
hideSpinner();
displayUser(data.results[0]);
})
.catch((error) => {
hideSpinner();
document.querySelector(
"#user"
).innerHTML = `<p class="text-xl text-center text-red-500 mb-5">${error}</p>`;
});
}
function displayUser(user) {
const userDisplay = document.querySelector("#user");
if (user.gender === "female") {
document.body.style.backgroundColor = "rebeccapurple";
} else {
document.body.style.backgroundColor = "steelblue";
}
userDisplay.innerHTML = `<div class="flex justify-between">
<div class="flex">
<img
class="w-48 h-48 rounded-full mr-8"
src="${user.picture.large}"
/>
<div class="space-y-3">
<p class="text-xl">
<span class="font-bold">Name: </span>${user.name.first} ${user.name.last}
</p>
<p class="text-xl">
<span class="font-bold">Email: </span> ${user.email}
</p>
<p class="text-xl">
<span class="font-bold">Phone: </span> ${user.phone}
</p>
<p class="text-xl">
<span class="font-bold">Location: </span> ${user.location.city} ${user.location.country}
</p>
<p class="text-xl"><span class="font-bold">Age: </span> ${user.dob.age}</p>
</div>
</div>
</div>`;
}
function showSpinner() {
document.querySelector(".spinner").style.display = "block";
}
function hideSpinner() {
document.querySelector(".spinner").style.display = "none";
}
document.querySelector("#generate").addEventListener("click", fetchUser);
fetchUser();