forked from Phayserlpepe/Expence-tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathScript.js
More file actions
65 lines (53 loc) · 1.72 KB
/
Script.js
File metadata and controls
65 lines (53 loc) · 1.72 KB
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
const balance = document.getElementById('balance');
const form = document.getElementById('form');
const text = document.getElementById('text');
const amount = document.getElementById('amount');
let transactions = JSON.parse(localStorage.getItem('transactions')) || [];
function addTransaction(e) {
e.preventDefault();
if(text.value.trim() === '' || amount.value.trim() === '') {
alert('Please add description + amount');
return;
}
const transaction = {
const transaction = {
id: Math.floor(Math.random() * 100000),
text: text.value,
amount: +amount.value
};
transactions.push(transaction);
updateLocalStorage();
init();
text.value = '';
amount.value = '';
}
function updateLocalStorage() {
localStorage.setItem('transactions', JSON.stringify(transactions));
}
function removeTransaction(id) {
transactions = transactions.filter(transaction => transaction.id !== id);
updateLocalStorage();
init();
}
function init() {
list.innerHTML = '';
transactions.forEach(addTransactionDOM);
updateBalance();
}
function addTransactionDOM(transaction) {
const sign = transaction.amount < 0 ? '-' : '+';
const item = document.createElement('li');
item.classList.add(transaction.amount < 0 ? 'minus' : 'plus');
item.innerHTML = `
${transaction.text} <span>${sign}$${Math.abs(transaction.amount)}</span>
<button class="delete-btn" onclick="removeTransaction(${transaction.id})">x</button>
`;
list.appendChild(item);
}
function updateBalance() {
const amounts = transactions.map(transaction => transaction.amount);
const total = amounts.reduce((acc, item) => acc += item, 0).toFixed(2);
balance.innerText = `$${total}`;
}
form.addEventListener('submit', addTransaction);
init();