-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
125 lines (98 loc) · 3.33 KB
/
script.js
File metadata and controls
125 lines (98 loc) · 3.33 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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
// balance (id)
// money_plus (id)
// money_minus (id)
// list (class,id)
// minus (class)
// delete-btn(class)
// form (id)
// form-control(class)
// text (id , for - add text in transaction )
// amount (id)
const balance = document.getElementById('balance');
const money_plus = document.getElementById('money-plus');
const money_minus = 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 localStorageTransactionHistory = JSON.parse(localStorage.getItem('transaction'));
let transaction = localStorage.getItem('transaction') !== null ? localStorageTransactionHistory : [];
// add new transaction
function addNewTransaction(e) {
e.preventDefault();
if (text.value.trim() === '' || amount.value.trim() === '') {
alert('Please enter amount and text to add transaction ');
} else {
const transactionx = {
id: getRandomID(),
text: text.value,
amount: +amount.value
};
transaction.push(transactionx);
addTransactionDOM(transactionx);
updateValues();
updateLocalStorage();
text.value = '';
amount.value = '';
}
}
// get random id using - Math.floor()
function getRandomID() {
return Math.floor(Math.random() * 10000000000);
}
// Using the DOM element, inserting transaction values into the page.
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="removeTransactionHistory(${transaction.id})">x</button>
`
list.appendChild(item);
}
// update values
function updateValues() {
//Balance Logic
const amounts = transaction.map((transaction) => {
return transaction.amount;
})
const total = amounts.reduce((accumulator, currentValue) => {
return accumulator + currentValue;
}, 0)
//Income logic
const getPlusValues = amounts.filter((item) => {
return item > 0
})
const income = getPlusValues.reduce((accumulator, currentValue) => {
return accumulator + currentValue;
}, 0)
// Expense Logic
const getMinusValues = amounts.filter((item) => {
return item < 0
})
const expense = getMinusValues.reduce((accumulator, currentValue) => {
return +(accumulator - currentValue);
}, 0)
balance.innerText = ` INR(₹) : ${total} `
money_plus.innerText = ` ₹${income} `
money_minus.innerText = ` ₹${expense} `
}
//removeTransactionHistory - remove transaction history
function removeTransactionHistory(id) {
transaction = transaction.filter(transaction => transaction.id !== id);
updateLocalStorage();
init();
}
// update local storage
function updateLocalStorage() {
localStorage.setItem('transaction', JSON.stringify(transaction));
}
// init()
function init() {
list.innerHTML = '';
transaction.forEach(addTransactionDOM);
updateValues()
}
init();
form.addEventListener('submit', addNewTransaction);
//* @mondalcodehub | NOV-2022 | *//