-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
85 lines (77 loc) · 2.25 KB
/
script.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
const numberInput = document.getElementById('number-input');
const convertBtn = document.getElementById('convert-btn');
const result = document.getElementById('result');
const animationContainer = document.getElementById('animation-container');
const animationData = [
{
inputVal: 5,
marginTop: 300,
addElDelay: 1000,
msg: `decimalToBinary(5) returns "10" + 1 (5 % 2). Then it pops off the stack.`,
showMsgDelay: 15000,
removeElDelay: 20000,
},
{
inputVal: 2,
marginTop: -200,
addElDelay: 1500,
msg: `decimalToBinary(2) returns "1" + 0 (2 % 2) and gives that value to the stack below. Then it pops off the stack.`,
showMsgDelay: 10000,
removeElDelay: 15000,
},
{
inputVal: 1,
marginTop: -200,
addElDelay: 2000,
msg: `decimalToBinary(1) returns "1" (base case) and gives that value to the stack below. Then it pops off the stack.`,
showMsgDelay: 5000,
removeElDelay: 10000,
},
];
const decimalToBinary = (input) => {
if (input === 0 || input === 1) {
return String(input);
} else {
return decimalToBinary(Math.floor(input / 2)) + (input % 2);
}
};
const showAnimation = () => {
result.innerText = 'Call Stack Animation';
animationData.forEach((obj) => {
setTimeout(() => {
animationContainer.innerHTML += `
<p id="${obj.inputVal}" style="margin-top: ${obj.marginTop}px;" class="animation-frame">
decimalToBinary(${obj.inputVal})
</p>
`;
}, obj.addElDelay);
setTimeout(() => {
document.getElementById(obj.inputVal).textContent = obj.msg;
}, obj.showMsgDelay);
setTimeout(() => {
document.getElementById(obj.inputVal).remove();
}, obj.removeElDelay);
});
setTimeout(() => {
result.textContent = decimalToBinary(5);
}, 20000);
};
const checkUserInput = () => {
const inputInt = parseInt(numberInput.value);
if (!numberInput.value || isNaN(inputInt)) {
alert('Please provide a decimal number');
return;
}
if (inputInt === 5) {
showAnimation();
return;
}
result.textContent = decimalToBinary(inputInt);
numberInput.value = '';
};
convertBtn.addEventListener('click', checkUserInput);
numberInput.addEventListener('keydown', (e) => {
if (e.key === 'Enter') {
checkUserInput();
}
});