CurrencyConverter5 / script.js
GarGerry's picture
Update script.js
d296562 verified
raw
history blame
2.45 kB
document.getElementById('currencyForm').addEventListener('submit', async function(event) {
event.preventDefault();
// Ambil nilai input dari user
const amount = document.getElementById('amount').value;
const fromCurrency = document.getElementById('fromCurrency').value;
const toCurrency = document.getElementById('toCurrency').value;
const resultDiv = document.getElementById('result');
const fromCurrencyIcon = document.getElementById('fromCurrencyIcon');
const toCurrencyIcon = document.getElementById('toCurrencyIcon');
const conversionResult = document.getElementById('conversionResult');
// Validasi jumlah yang dimasukkan
if (!amount || amount <= 0) {
resultDiv.innerHTML = "Please enter a valid amount!";
return;
}
try {
const apiKey = '3ebe2ccf9eeea2aaef280201'; // API Key
const url = `https://v6.exchangerate-api.com/v6/${apiKey}/latest/${fromCurrency}`;
// Mengambil data dari API
const response = await fetch(url);
const data = await response.json();
// Menangani respon API yang error
if (data.result === 'error') {
resultDiv.innerHTML = `Error: ${data['error-type']}`;
} else {
// Menyusun nilai konversi dan menampilkannya
const rate = data.conversion_rates[toCurrency];
const convertedAmount = (amount * rate).toFixed(2);
// Menampilkan hasil konversi
conversionResult.innerHTML = `${amount} ${fromCurrency} = ${convertedAmount} ${toCurrency}`;
// Menentukan ikon mata uang berdasarkan kode
fromCurrencyIcon.className = `fas fa-${getCurrencyIcon(fromCurrency)}`;
toCurrencyIcon.className = `fas fa-${getCurrencyIcon(toCurrency)}`;
}
} catch (error) {
resultDiv.innerHTML = "Error fetching conversion rate.";
console.error("Error:", error); // Menampilkan error di konsol
}
});
// Fungsi untuk mendapatkan ikon mata uang berdasarkan kode mata uang
function getCurrencyIcon(currency) {
switch (currency) {
case 'USD': return 'dollar-sign';
case 'EUR': return 'euro-sign';
case 'GBP': return 'pound-sign';
case 'IDR': return 'money-bill-wave'; // IDR menggunakan money-bill-wave
case 'JPY': return 'yen-sign';
case 'BRL': return 'money-bill-wave'; // BRL menggunakan money-bill-wave
case 'KRW': return 'won-sign';
case 'AUD': return 'dollar-sign';
case 'CAD': return 'dollar-sign';
default: return 'coins'; // Ikon default jika tidak ditemukan
}
}