File size: 2,341 Bytes
f124856
 
 
d58e416
52bf539
 
 
 
cc05239
 
 
52bf539
d58e416
52bf539
 
 
 
 
 
d58e416
f124856
d58e416
 
52bf539
 
 
d58e416
f124856
 
52bf539
d58e416
f124856
52bf539
cc05239
 
 
 
 
 
 
52bf539
 
 
d58e416
52bf539
cc05239
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
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';
    case 'JPY': return 'yen-sign';
    case 'BRL': return 'money-bill-wave';
    case 'KRW': return 'won-sign';
    case 'AUD': return 'dollar-sign';
    case 'CAD': return 'dollar-sign';
    default: return 'coins';
  }
}