-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
61 lines (52 loc) · 1.94 KB
/
app.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
const baseURL = `https://cdn.jsdelivr.net/npm/@fawazahmed0/currency-api@latest/v1/currencies`;
const dropsowns = document.querySelectorAll('.dropdown select');
const btn = document.querySelector('form button');
const fromCurr = document.querySelector('.from select');
const toCurr = document.querySelector('.to select');
const msg = document.querySelector('.msg');
window.addEventListener('load', () => {
updateExchangeRate();
});
for (let select of dropsowns) {
for (currCode in countryList) {
let newOption = document.createElement('option');
newOption.innerText = currCode;
newOption.value = currCode;
if (select.name === 'from' && currCode === 'USD') {
newOption.selected = 'selected';
}
else if (select.name === 'to' && currCode === 'INR') {
newOption.selected = 'selected';
}
select.append(newOption);
}
select.addEventListener('change', (evt) => {
updateFlag(evt.target);
});
}
const updateFlag = (element) => {
let currCode = element.value;
let countryCode = countryList[currCode];
let newSrc = `https://flagsapi.com/${countryCode}/flat/64.png`;
let img = element.parentElement.querySelector('img');
img.src = newSrc;
};
btn.addEventListener('click', (evt) => {
evt.preventDefault();
updateExchangeRate();
});
const updateExchangeRate = async () => {
let amount = document.querySelector('.amount input');
let amtVal = amount.value;
if (amtVal === '' || amtVal < 1) {
amtVal = 1;
amount.value = '1';
}
const URL = `${baseURL}/${fromCurr.value.toLowerCase()}.json`;
let response = await fetch(URL);
let data = await response.json();
let rate = data[fromCurr.value.toLowerCase()][toCurr.value.toLowerCase()];
let finalAmt = amtVal * rate;
finalAmt = Math.round(finalAmt * 1000) / 1000;
msg.innerText = `${amtVal} ${fromCurr.value} = ${finalAmt} ${toCurr.value}`;
};