-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
51 lines (38 loc) · 1.65 KB
/
Copy pathscript.js
File metadata and controls
51 lines (38 loc) · 1.65 KB
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
class CustomSelect {
constructor(originalSelect) {
this.originalSelect = originalSelect;
this.customSelect = document.createElement("div");
this.customSelect.classList.add("select");
this.originalSelect.querySelectorAll("option").forEach(optionElement => {
const itemElement = document.createElement("div");
itemElement.classList.add("select__item");
itemElement.textContent = optionElement.textContent;
this.customSelect.appendChild(itemElement);
if (optionElement.selected) {
this._select(itemElement);
}
itemElement.addEventListener("click", () => {
if (itemElement.classList.contains("select__item--selected")) {
this._deselect(itemElement);
} else {
this._select(itemElement);
}
});
});
this.originalSelect.insertAdjacentElement("afterend", this.customSelect);
this.originalSelect.style.display = "none";
}
_select(itemElement) {
const index = Array.from(this.customSelect.children).indexOf(itemElement);
this.originalSelect.querySelectorAll("option")[index].selected = true;
itemElement.classList.add("select__item--selected");
}
_deselect(itemElement) {
const index = Array.from(this.customSelect.children).indexOf(itemElement);
this.originalSelect.querySelectorAll("option")[index].selected = false;
itemElement.classList.remove("select__item--selected");
}
}
document.querySelectorAll(".custom-select").forEach(selectElement => {
new CustomSelect(selectElement);
});