-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstyle.js
92 lines (83 loc) · 2.14 KB
/
style.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
//three div with order container flex-box div
let body = document.body;
let trackBlack = 0;
/**
*
* @returns {HTMLDivElement}
*/
function createContainer() {
//create container
let containerDiv = document.createElement("div");
containerDiv.setAttribute("class", "container");
return containerDiv;
}
/**
*
* @returns {HTMLButtonElement}
*/
function createSetButtonSize() {
//create set size button
let setButton = document.createElement("button");
setButton.textContent = "Set Grid";
setButton.setAttribute("class", "buttonset");
setButton.addEventListener("click", () => {
let askSize = prompt("How much size bro:");
if (askSize >= 100 || askSize <= 0) {
alert("Cant have a size more 100 or less than 0");
} else {
//i want to remove the entire element and start all over
while (body.hasChildNodes()) {
body.removeChild(body.firstChild);
}
gridMaker(askSize);
}
});
return setButton;
}
/**
*
* @param {HTMLDivElement} containerDiv
* @param {Number} size
*/
function createTheGrid(containerDiv, size) {
//Grid
for (let k = 1; k <= size; k++) {
//create row
let flexDiv = document.createElement("div");
flexDiv.setAttribute("class", "flex");
//create column
for (let j = 1; j <= size; j++) {
let innerDiv = document.createElement("div");
innerDiv.setAttribute("class", "flexinnerdiv");
innerDiv.addEventListener("mouseenter", () => {
innerDiv.style.cssText = `background-color: rgb(${getColorRandomly()},${getColorRandomly()},${getColorRandomly()})`;
++trackBlack;
});
flexDiv.append(innerDiv);
}
//adding row to container
containerDiv.append(flexDiv);
}
}
/**
*
* @returns {Number}
*/
function getColorRandomly() {
let color = 0;
if (trackBlack > 10) {
trackBlack = 0;
}
while (color == 0 && trackBlack < 10) {
color = Math.round(Math.random() * 255);
}
return color;
}
function gridMaker(size) {
let containerDiv = createContainer();
containerDiv.append(createSetButtonSize());
createTheGrid(containerDiv, size);
//adding container to body
body.append(containerDiv);
}
gridMaker(16);