forked from Renu-code123/ExpenseFlow
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtrackerscript.js
More file actions
111 lines (93 loc) · 3.15 KB
/
trackerscript.js
File metadata and controls
111 lines (93 loc) · 3.15 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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
document.addEventListener("DOMContentLoaded", () => {
/* =====================
DOM ELEMENTS
====================== */
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 category = document.getElementById("category");
const type = document.getElementById("type");
const navToggle = document.getElementById("nav-toggle");
const navMenu = document.getElementById("nav-menu");
/* =====================
STATE
====================== */
let transactions = JSON.parse(localStorage.getItem("transactions")) || [];
/* =====================
MOBILE NAV
====================== */
if (navToggle && navMenu) {
navToggle.addEventListener("click", () => {
navMenu.classList.toggle("active");
});
}
document.querySelectorAll(".nav-link").forEach(link => {
link.addEventListener("click", () => {
navMenu.classList.remove("active");
});
});
/* =====================
ADD TRANSACTION
====================== */
function addTransaction(e) {
e.preventDefault();
let value = +amount.value;
if (type.value === "expense") value = -Math.abs(value);
const transaction = {
id: Date.now(),
text: text.value,
amount: value
};
transactions.push(transaction);
updateLocalStorage();
init();
text.value = "";
amount.value = "";
category.value = "";
type.value = "";
}
/* =====================
RENDER
====================== */
function addTransactionDOM(tx) {
const item = document.createElement("li");
item.className = tx.amount < 0 ? "minus" : "plus";
item.innerHTML = `
${tx.text}
<span>${tx.amount < 0 ? "-" : "+"}₹${Math.abs(tx.amount)}</span>
<button onclick="removeTransaction(${tx.id})">x</button>
`;
list.appendChild(item);
}
function updateValues() {
const amounts = transactions.map(t => t.amount);
const total = amounts.reduce((a, b) => a + b, 0);
const income = amounts.filter(v => v > 0).reduce((a, b) => a + b, 0);
const expense = amounts.filter(v => v < 0).reduce((a, b) => a + b, 0) * -1;
balance.textContent = `₹${total.toFixed(2)}`;
moneyPlus.textContent = `+₹${income.toFixed(2)}`;
moneyMinus.textContent = `-₹${expense.toFixed(2)}`;
}
function init() {
list.innerHTML = "";
transactions.forEach(addTransactionDOM);
updateValues();
}
function updateLocalStorage() {
localStorage.setItem("transactions", JSON.stringify(transactions));
}
/* =====================
GLOBAL DELETE
====================== */
window.removeTransaction = function(id) {
transactions = transactions.filter(t => t.id !== id);
updateLocalStorage();
init();
};
form.addEventListener("submit", addTransaction);
init();
});