-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
84 lines (75 loc) · 2.46 KB
/
script.js
File metadata and controls
84 lines (75 loc) · 2.46 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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
const balance = document.getElementById("balance");
const moneyPlus = document.getElementById("money-plus");
const moneyMinus = document.getElementById("money-minus");
const list = document.getElementById("list");
const form = document.getElementById("form");
const text = document.getElementById("text");
const amount = document.getElementById("amount");
const notification = document.getElementById("notification");
let transactions = [];
function showNotification() {
notification.classList.add("show");
setTimeout(() => {
notification.classList.remove("show");
}, 2000);
}
function generateID() {
return Math.floor(Math.random() * 100000000);
}
function addTransaction(e) {
e.preventDefault();
if (text.value.trim() === "" || amount.value.trim() === "") {
showNotification();
} else {
const transaction = {
id: generateID(),
text: text.value,
amount: +amount.value,
};
transactions.push(transaction);
addTransactionDOM(transaction);
updateValues();
text.value = "";
amount.value = "";
}
}
function addTransactionDOM(transaction) {
const sign = transaction.amount < 0 ? "-" : "+";
const item = document.createElement("li");
item.classList.add(sign === "+" ? "plus" : "minus");
item.innerHTML = `
${transaction.text} <span>${sign}${Math.abs(transaction.amount)}</span
><button class="delete-btn" onclick="removeTransaction(${
transaction.id
})"><i class="fa fa-times"></i></button>
`;
list.appendChild(item);
}
function updateValues() {
const amounts = transactions.map((transaction) => transaction.amount);
const total = amounts
.reduce((accumulator, value) => (accumulator += value), 0)
.toFixed(2);
const income = amounts
.filter((value) => value > 0)
.reduce((accumulator, value) => (accumulator += value), 0)
.toFixed(2);
const expense = (
amounts
.filter((value) => value < 0)
.reduce((accumulator, value) => (accumulator += value), 0) * -1
).toFixed(2);
balance.innerText = `${total}`;
moneyPlus.innerText = `${income}`;
moneyMinus.innerText = `${expense}`;
}
function removeTransaction(id) {
transactions = transactions.filter((transaction) => transaction.id !== id);
init();
}
function init() {
list.innerHTML = "";
transactions.forEach(addTransactionDOM);
updateValues();
}
form.addEventListener("submit", addTransaction);