-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcountry.js
81 lines (71 loc) · 2.98 KB
/
country.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
// Fetch data from API
let url = "https://restcountries.com/v3.1/all"
let data = [];
async function getData(url) {
let response = await fetch(url)
data = await response.json()
displayCountry()
}
getData(url)
//display country
function displayCountry() {
let singleCountry = localStorage.getItem('viewCountry')
singleCountry = JSON.parse(singleCountry)
let country = singleCountry[0]
// currencies
let currencies = country.currencies
currencies = Object.values(currencies)
let currenciesList = []
for (let i = 0; i < currencies.length; i++) {
currenciesList.push(currencies[i]["name"])
}
currencies = currenciesList.join(", ")
// languages
let languages = Object.values(country.languages)
languages = languages.join(", ")
//native name
let nativeName = Object.values(country.name.nativeName)
nativeName = nativeName[0].common
//borders
let borders = country.borders?.map(element => {
let borderName = data.filter(country => country.cca3 == element)
return (`<a class="btn" onclick="viewBorderCountry('${borderName[0].name.common}')">${borderName[0].name.common}</a>`)
}).join("")
//country entry point
let renderCountry = `
<div class="country-container">
<div class="country-image">
<img src="${country.flags.png}" alt="${country.name.common} flag">
</div>
<div class="country-details-container">
<h2>${country.name.common}</h2>
<div class="country-details">
<div>
<p><span class="prop-name">Native Name:</span> <span class="prop-value">${nativeName}</span></p>
<p><span class="prop-name">Population:</span> <span class="prop-value">${country.population}</span></p>
<p><span class="prop-name">Region:</span> <span class="prop-value">${country.region}</span></p>
<p><span class="prop-name">Sub Region:</span> <span class="prop-value">${country.subregion}</span></p>
<p><span class="prop-name">Capital:</span> <span class="prop-value">${country.capital}</span></p>
</div>
<div>
<p><span class="prop-name">Top Level Domain:</span> <span class="prop-value">${country.tld}</span></p>
<p><span class="prop-name">Currencies:</span> <span class="prop-value">${currencies}</span></p>
<p><span class="prop-name">Languages:</span> <span class="prop-value">${languages}</span></p>
</div>
</div>
<div class="border-countries">
<p>Border Countries: </p>
<div class="borders">
${borders ? borders : "<p>No Border</p>"}
</div>
</div>
</div>
</div>`
document.getElementById('country').innerHTML = renderCountry
}
//view border country
function viewBorderCountry(name) {
let country = data.filter(country => country.name.common == name)
localStorage.setItem('viewCountry', JSON.stringify(country))
window.location.href = `country.html`
}