-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
59 lines (48 loc) · 1.54 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
const container = document.createElement('div');
container.id = 'container';
container.className = 'mx-auto my-2';
document.body.appendChild(container);
function makeRows(rows, cols) {
container.style.setProperty('--grid-rows', rows);
container.style.setProperty('--grid-cols', cols);
container.style.border = '3px solid #0000FF'
for (c = 0; c < (rows * cols); c++) {
let cell = document.createElement("div");
container.appendChild(cell).className = "grid-item";
cell.addEventListener("mouseover", paint);
};
};
const color = document.getElementById('favcolor');
function paint(e) {
let chooseColor = color.value;
e.target.style.backgroundColor= chooseColor;
}
let size = 0;
const start = document.getElementById('start');
start.addEventListener('click', function(){
size = prompt('Please enter the side of the grid(max 64):');
if(size <= 64){
container.innerHTML = '';
makeRows(size, size);
} else if (size > 64) {
alert('You exceeded the limits. Please Try Again:');
}
});
const reset = document.getElementById('reset');
reset.addEventListener('click', function(){
container.innerHTML = '';
makeRows(size, size);
});
document.addEventListener("keypress", function stopPaint(event){
let x = event.keyCode;
const grid = document.getElementsByClassName('grid-item');
if(x !== 13) {
Array.from(grid).forEach((el) => {
el.removeEventListener("mouseover", paint);
});
} else {
Array.from(grid).forEach((el) => {
el.addEventListener("mouseover", paint);
})
};
});