forked from MeenakshiAM/Expense-Tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
90 lines (72 loc) · 2.49 KB
/
script.js
File metadata and controls
90 lines (72 loc) · 2.49 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
let expenses = [];
let total = 0;
let budget = 0; // User sets this via input
// --- Set Budget dynamically ---
function setBudget() {
const budgetInput = document.getElementById("budget-amount");
const newBudget = parseFloat(budgetInput.value);
if (isNaN(newBudget) || newBudget <= 0) {
alert("Please enter a valid positive budget amount.");
return;
}
budget = newBudget;
alert(`Budget set to ₹${budget}`);
budgetInput.value = "";
}
// --- Add Expense ---
function addExpense() {
const nameInput = document.getElementById("expense-name");
const amountInput = document.getElementById("expense-amount");
const name = nameInput.value.trim();
const amount = parseFloat(amountInput.value);
if (name === "" || isNaN(amount) || amount <= 0) {
alert("Please enter a valid expense name and a positive amount greater than 0.");
return;
}
expenses.push({ name, amount });
total += amount;
updateUI();
nameInput.value = "";
amountInput.value = "";
// ✅ Check budget if user has set one
if (budget > 0) {
checkBudget();
}
}
// --- Update UI ---
function updateUI() {
const expenseList = document.getElementById("expense-list");
const totalAmount = document.getElementById("total-amount");
expenseList.innerHTML = "";
expenses.forEach((expense, index) => {
const li = document.createElement("li");
li.innerHTML = `${expense.name}: ₹${expense.amount.toFixed(2)}
<button class="delete-btn" onclick="removeExpense(${index})">X</button>`;
expenseList.appendChild(li);
});
totalAmount.textContent = total.toFixed(2);
}
// --- Remove Expense ---
function removeExpense(index) {
const confirmed = confirm(`Are you sure you want to delete "${expenses[index].name}"?`);
if (!confirmed) return;
total -= expenses[index].amount;
expenses.splice(index, 1);
updateUI();
}
// --- Check Budget ---
function checkBudget() {
if (total > budget) {
alert(`⚠ Warning! Your expenses have exceeded your budget of ₹${budget}.`);
}
}
// --- Dark Mode Toggle ---
const themeToggleBtn = document.getElementById("theme-toggle");
themeToggleBtn.addEventListener("click", () => {
document.body.classList.toggle("dark-mode");
if (document.body.classList.contains("dark-mode")) {
themeToggleBtn.textContent = "☀ Light Mode";
} else {
themeToggleBtn.textContent = "🌙 Dark Mode";
}
});