-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
68 lines (61 loc) · 1.46 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
const submit = document.getElementById("convert-btn");
const input = document.getElementById("number");
const output = document.getElementById("output");
const form = document.getElementById("number-form");
const roman = [
["M", 1000],
["CM", 900],
["D", 500],
["CD", 400],
["C", 100],
["XC", 90],
["L", 50],
["XL", 40],
["X", 10],
["IX", 9],
["V", 5],
["IV", 4],
["I", 1],
];
function removeDisappear() {
const disappear = output.classList.contains("disappear");
if (disappear) {
output.classList.remove("disappear");
}
}
function converter(number) {
let result = "";
for (const [symbol, key] of roman) {
while (number >= key) {
result += symbol;
number -= key;
}
}
return result;
}
function changeOutput(result) {
output.innerText = result;
removeDisappear();
}
function handleClick() {
const number = input.value;
let result = converter(number);
if (number < 0) {
changeOutput("Please enter a number greater than or equal to 1");
return;
}
if (number > 3999) {
changeOutput("Please enter a number less than or equal to 3999");
return;
}
if (!/\d/.test(Number(number)) || number === "") {
changeOutput("Please enter a valid number");
return;
}
changeOutput(result);
removeDisappear();
}
form.addEventListener("submit", (e) => {
e.preventDefault();
});
submit.addEventListener("click", handleClick);