-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcal.js
107 lines (88 loc) · 3.38 KB
/
cal.js
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
var calculate = function (n1, operator, n2) {
var result = '';
if (operator === 'add') {
result = parseFloat(n1) + parseFloat(n2);
} else if (operator === 'subtract') {
result = parseFloat(n1) - parseFloat(n2);
} else if (operator === 'multiply') {
result = parseFloat(n1) * parseFloat(n2);
} else if (operator === 'divide') {
result = parseFloat(n1) / parseFloat(n2);
}
return result;
}
const calculator = document.body.querySelector('.calculator');
var display = calculator.querySelector('.calculator__display');
var keys = calculator.querySelector('.calculator__keys');
keys.addEventListener('click', function(e) {
if (e.target.matches('button')) {
var key = e.target;
var action = key.dataset.action;
var keyContent = key.textContent;
var displayedNum = display.textContent;
var previousKeyType = calculator.dataset.previousKeyType;
Array.from(key.parentNode.children)
.forEach(function(k){ k.classList.remove('is-depressed')});
if (!action) {
if ( displayedNum === '0' || previousKeyType === 'operator' || previousKeyType === 'calculate' ) {
display.textContent = keyContent;
} else {
display.textContent = displayedNum + keyContent;
}
calculator.dataset.previousKeyType = 'number';
}
if (action === 'decimal') {
if (!displayedNum.includes('.')) {
display.textContent = displayedNum + '.';
} else if ( previousKeyType === 'operator' || previousKeyType === 'calculate' ) {
display.textContent = '0.';
}
calculator.dataset.previousKeyType = 'decimal';
}
if ( action === 'add' || action === 'subtract' || action === 'multiply' || action === 'divide' ) {
var firstValue = calculator.dataset.firstValue;
var operator = calculator.dataset.operator;
var secondValue = displayedNum;
if ( firstValue && operator && previousKeyType !== 'operator' && previousKeyType !== 'calculate' ) {
var calcValue = calculate(firstValue, operator, secondValue);
display.textContent = calcValue;
calculator.dataset.firstValue = calcValue;
} else {
calculator.dataset.firstValue = displayedNum;
}
key.classList.add('is-depressed');
calculator.dataset.previousKeyType = 'operator';
calculator.dataset.operator = action;
}
if (action === 'clear') {
if (key.textContent === 'AC') {
calculator.dataset.firstValue = '';
calculator.dataset.modValue = '';
calculator.dataset.operator = '';
calculator.dataset.previousKeyType = '';
} else {
key.textContent = 'AC';
}
display.textContent = 0;
calculator.dataset.previousKeyType = 'clear';
}
if (action !== 'clear') {
var clearButton = calculator.querySelector('[data-action=clear]');
clearButton.textContent = 'CE';
}
if (action === 'calculate') {
var firstValue = calculator.dataset.firstValue;
var operator = calculator.dataset.operator;
var secondValue = displayedNum;
if (firstValue) {
if (previousKeyType === 'calculate') {
firstValue = displayedNum;
secondValue = calculator.dataset.modValue;
}
display.textContent = calculate(firstValue, operator, secondValue);
}
calculator.dataset.modValue = secondValue;
calculator.dataset.previousKeyType = 'calculate';
}
}
})