-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
79 lines (69 loc) · 2.4 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
//create grid inside div named container
const container = document.querySelector(".grid-container");
function createGrid(size) {
for (let i=0;i<(size*size);i++){
let col = document.createElement("div");
col.classList.add("grid-item");
container.appendChild(col);
container.style.gridTemplateColumns = `repeat(${size}, 1fr)`;
container.style.gridTemplateRows = `repeat(${size}, 1fr)`;
}
}
createGrid(16);
//set up color and hover effect
function hoverEffect(color) {
let grids = document.querySelectorAll(".grid-item");
let gridsArr = Array.from(grids);
gridsArr.forEach(element =>
element.addEventListener("mouseover", ()=>{
element.style.backgroundColor = color;
}));
}
hoverEffect("black");
//buttons declaration
const resetBtn = document.querySelector("#reset");
const newBtn = document.querySelector("#new");
const randomBtn = document.querySelector("#random");
const colorBtn = document.querySelector("#changeColor");
const eraseBtn = document.querySelector("#erase");
//reset
resetBtn.addEventListener("click", ()=>{
container.querySelectorAll('.grid-item').forEach(element =>
element.style.backgroundColor = "white");
hoverEffect("black");
});
//new grid;
newBtn.addEventListener("click", ()=>{
let gridSize=prompt("Input the number of grids you want (max 64)");
if (gridSize>64){
alert("Too big! Try a smaller size.");
gridSize=16;
}
if (isNaN(gridSize)|| gridSize.length===0){
gridSize=16;
alert("Invalid number")
}
container.querySelectorAll('.grid-item').forEach(e => e.remove()); // remove all grids,create grid again, initialize hover effect
createGrid(gridSize);
hoverEffect("black");
});
//random
randomBtn.addEventListener("click", ()=>{
let grids = document.querySelectorAll(".grid-item");
let gridsArr = Array.from(grids);
gridsArr.forEach(element =>
element.addEventListener("mouseover", ()=>{
let randomColor = Math.floor(Math.random()*16777215).toString(16);
element.style.backgroundColor = "#"+randomColor;
}))
});
//change color
colorBtn.addEventListener("click", ()=>{
let colorChoice = prompt("Input color you want (hex code or name)");
colorChoice.toString().toLowerCase();
hoverEffect(colorChoice);
});
//erase
eraseBtn.addEventListener("click", ()=>{
hoverEffect("white");
});