Ten skrypt nie powinien być instalowany bezpośrednio. Jest to biblioteka dla innych skyptów do włączenia dyrektywą meta // @require https://update.greasyfork.org/scripts/462013/1164920/Abnormal%20Menu.js
/*
Created by anonimbiri
*/
const link = document.createElement('link');
link.rel = 'stylesheet';
link.href = 'https://fonts.googleapis.com/css?family=Nunito:bold';
document.getElementsByTagName('head')[0].appendChild(link);
var style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = `
@keyframes blur-in {
0% {
backdrop-filter:blur(0px);
}
100% {
backdrop-filter:blur(10px);
}
}
@keyframes blur-out {
100% {
backdrop-filter:blur(0px);
}
0% {
backdrop-filter:blur(10px);
}
}
.menus {
position: absolute;
z-index: 1000;
top: 0;
left: 0;
display: flex;
width: 100%;
height: 100vh;
justify-content: center;
align-items: center;
}
.bg-blur {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, .16);
}
.menus.open {
animation:blur-in .3s;
animation-fill-mode:forwards;
visibility: visible;
}
.menus.close {
animation:blur-out .3s;
animation-fill-mode: forwards;
visibility: hidden;
}
.close-button {
background: url('');
background-size: 32px !important;
position: absolute;
z-index: 1001;
right: 32px;
top: 32px;
width: 32px;
height: 32px;
opacity: 0.3;
border: none;
}
.close-button:hover {
opacity: 1;
}
.close-button:before, .close-button:after {
position: absolute;
left: 15px;
height: 33px;
width: 2px;
background-color: #333;
}
.close-button:before {
transform: rotate(45deg);
}
.close-button:after {
transform: rotate(-45deg);
}
.menu {
background-color: #111111;
width: 640px;
height: 520px;
margin: 0 auto;
border-radius: 5px;
position: absolute;
transform: scale(0.82971);
flex-direction: column;
z-index: 1001;
}
.menu.pinned {
visibility: visible;
}
.menu-items {
width: 640px;
height: 480px;
overflow-y: scroll;
}
::-webkit-scrollbar {
width: 10px;
}
::-webkit-scrollbar-thumb {
background: #888;
border-radius: 10px;
}
::-webkit-scrollbar-track {
background: transparent;
}
.gradient-slider .title {
font-family: 'Nunito', sans-serif;
font-weight: bold;
font-size: 20px;
margin: 0px 0px 20px;
color: rgb(0, 0, 0);
position: relative;
display: flex;
flex-direction: column;
align-items: center;
padding: 5px;
}
.gradient-slider {
background: linear-gradient(268deg, #ff3939, #eeff30, #37ff30, #30ffd6, #ff30f4);
background-size: 1000% 1000%;
width: 100%;
height: 30px;
margin: 0 auto;
border-radius: 5px 5px 0px 0px;
animation: AnimationName 30s ease infinite;
cursor: move;
}
@keyframes AnimationName {
0%{background-position:0% 50%}
50%{background-position:100% 50%}
100%{background-position:0% 50%}
}
.gradient-slider .pin-button {
background: url('');
background-size: 25px !important;
position: absolute;
z-index: 1001;
top: 10;
left: 10px;
width: 25px;
height: 25px;
opacity: 0.3;
border: none;
}
.menu.pinned .gradient-slider .pin-button {
background: url('');
}
.pin-button:hover {
opacity: 1;
}
.pin-button:before, .close-button:after {
position: absolute;
right: 15px;
height: 33px;
width: 2px;
background-color: #333;
}
.pin-button:before {
transform: rotate(45deg);
}
.pin-button:after {
transform: rotate(-45deg);
}
.ui-tooltip {
padding: 8px;
position: absolute;
z-index: 9999;
max-width: 300px;
width: 120px;
background-color: #042c70;
color: #fff;
text-align: center;
padding: 5px 10px;
border-radius: 3px;
font-family: nunitobold;
font-size: 14px;
}
body .ui-tooltip {
border-width: 2px;
}
.ui-tooltip:after {
position: absolute;
top: -8px;
left: 50%;
-webkit-transform: translateX(-50%);
-moz-transform: translateX(-50%);
-ms-transform: translateX(-50%);
-o-transform: translateX(-50%);
transform: translateX(-50%);
content: '';
border-style: solid;
border-width: 0 10px 15px;
border-color: transparent transparent #042c70 transparent;
z-index: -1;
}
.ui-helper-hidden-accessible {
border: 0;
clip: rect(0 0 0 0);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
}
.toast-color {
display: block;
width: 15px;
margin-right: 5px;
border-radius: 3px 0 0 3px;
position: relative;
box-sizing: border-box;
color: #eee;
font-size: 16px;
font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
}
.toast-color.red {
background-color: #b90909;
}
.toast-color.green {
background-color: #4caf50;
}
.toast-color.yellow {
background-color: #ff9800;
}
.toast-color.blue {
background-color: #2196f3;
}
.toast-img {
padding: 5px;
position: relative;
box-sizing: border-box;
width: 42px;
height: 42px;
object-fit: cover;
}
.toast-title {
padding: 12px;
position: relative;
box-sizing: border-box;
color: #eee;
font-size: 16px;
font-weight: bold;
font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
}
.toast-msg {
padding: 12px;
position: relative;
box-sizing: border-box;
color: #eee;
font-size: 16px;
font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
}
#toasts {
position: absolute;
bottom: 0;
right: 0;
display: flex;
flex-direction: column;
align-items: flex-end;
max-width: 100%;
padding: 10px;
overflow: hidden;
}
#toast {
height: 43px;
opacity: 1;
margin-top: 5px;
margin-bottom: 5px;
overflow: hidden;
margin: 5px 0;
border-radius: 3px;
box-shadow: 0 0 4px 0 #000;
box-sizing: border-box;
display: block;
z-index: 1001;
position: relative;
}
.toast.group {
display: inline-flex;
box-sizing: border-box;
border-radius: 3px;
color: #eee;
font-size: 16px;
background-color: #262626;
vertical-align: bottom;
}
#toast.show {
-webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s;
animation: fadein 0.5s, fadeout 0.5s 2.5s;
}
@-webkit-keyframes fadein {
from {right: -30%; opacity: 0;}
to {right: 1%; opacity: 1;}
}
@keyframes fadein {
from {right: -30%; opacity: 0;}
to {right: 1%; opacity: 1;}
}
@-webkit-keyframes fadeout {
from {right: 1%; opacity: 1;}
to {right: -30%; opacity: 0;}
}
@keyframes fadeout {
from {right: 1%; opacity: 1;}
to {right: -30%; opacity: 0;}
}
.button {
background-color: transparent;
border: 2px solid #e0e1e2;
color: #e0e1e2;
padding: 16px 32px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
margin: 4px 2px;
transition-duration: 0.4s;
cursor: pointer;
border-radius: 5px;
font-family: 'Nunito', sans-serif;
font-weight: bold;
}
.button:hover { color: rgba(0,0,0,.6); background: #cacbcd }
.switch {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
border-radius:40px;
border:2px solid #e0e1e2;
}
.switch input {
opacity: 0;
}
.slider {
position: absolute;
cursor:pointer;
top:0;
left:0;
right:0;
bottom:0;
border-radius: 34px;
-webkit-transition:.5s;
}
.slider:before {
position: absolute;
content:"";
height: 26px;
width: 26px;
top:3px;
left:4px;
background-color: #e0e1e2;
-webkit-transition:.5s;
}
input:checked + .slider:before{
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
.slider:before {
border-radius: 50%;
}
.list-group {
align-items: center;
display: flex;
padding-left: 10px;
padding-right: 10px;
padding-top: 20px;
justify-content: space-between;
}
.list-group .label {
display: inline-block;
color: white;
font-family: 'Nunito', sans-serif;
font-weight: bold;
}
.DropZone {
width: 200px;
max-width: 200px;
height: 200px;
padding: 25px;
display: flex;
align-items: center;
justify-content: center;
border: 4px dashed #e0e1e27a;
cursor:pointer;
}
.DropZone:hover {
border-color: #cacbcd;
}
.DropZone.Error {
border: 4px dashed #ff00007a;
}
.DropZone.Error:hover {
border: 4px dashed #ff003b;
}
.DropZone.Error div{
color: #ff003b;
}
.DropZone div{
text-align: center;
font-family: 'Nunito', sans-serif;
font-weight: 500;
font-size: 20px;
color: lightgray;
position: relative;
}
.Fileİnput {
display: none;
}
.DropThumb {
width: 100%;
height: 100%;
border-radius: 10px;
overflow: hidden;
background-color: #cccccc;
background-size: cover;
position: relative;
}
.DropThumb::after {
content: attr(data-label);
position: absolute;
bottom: 0;
left: 0;
width: 100%;
padding: 5px 0;
color: #ffffff;
background: rgba(0, 0, 0, 0.75);
font-size: 14px;
text-align: center;
}
.options-menu {
background-color: #e0e1e2;
width: 200px;
position: relative;
display: inline-block;
border-radius: 5px;
}
.select-style {
background-color: transparent;
border: none;
padding: 5px 10px;
font-size: 16px;
color: #555;
width: 100%;
border-radius: 5px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
cursor: pointer;
outline: none;
font-family: 'Nunito', sans-serif;
font-weight: bold;
}
.select-style:after {
content: "\f107";
font-family: "Font Awesome 5 Free";
font-weight: 900;
position: absolute;
right: 10px;
top: 50%;
transform: translateY(-50%);
pointer-events: none;
}
.select-style option {
background-color: #e0e1e2;
color: #555;
font-size: 16px;
padding: 5px 10px;
cursor: pointer;
}
.select-style option:checked {
background-color: #8f8f8f;
color: #fff;
}
.list-group.Input input {
font-size: 16px;
padding: 10px;
background-color: #e0e1e2;
border-radius: 9px;
font-family: 'Nunito', sans-serif;
font-weight: bold;
border: 4px solid;
}
.list-group.Input .input {
width: 200px;
}
.list-group.Input input:focus {
outline: none;
border: 4px solid #007fff;
}
`;
document.getElementsByTagName('head')[0].appendChild(style);
var CreateToasts = document.createElement("div");
var CreateMenus = document.createElement("div");
var close_button = document.createElement("button");
window.addEventListener('load', (event) => {
CreateToasts.setAttribute("id", "toasts");
document.body.prepend(CreateToasts);
CreateMenus.setAttribute("class", "menus open");
document.body.prepend(CreateMenus);
var blur_bg = document.createElement("div");
blur_bg.setAttribute("class", "bg-blur");
CreateMenus.prepend(blur_bg);
close_button.setAttribute("class", "close-button");
close_button.setAttribute("title", "Close");
CreateMenus.prepend(close_button);
console.log('%c╦═══════════════════════════╦\n║Anonim Biri - Abnormal-Menu║\n╩═══════════════════════════╩\n%cGtihub doc: %chttps://github.com/anonimbiri/Abnormal-Menu\n\n%cNote: %cthis doesn\'t give you cheats, it\'s a ui design.', 'font-weight: bold; font-size: 50px;color: rgb(255, 10, 63); text-shadow: 3px 3px 0 rgb(64, 1, 25)', 'font-weight: bold; font-size: 15px;color: rgb(245, 236, 66); text-shadow: 1px 1px 0 rgb(145, 140, 33)', 'font-weight: bold; font-size: 15px;color: rgb(240, 239, 233); text-shadow: 1px 1px 0 rgb(145, 145, 144)', 'font-weight: bold; font-size: 15px;color: rgb(245, 236, 66); text-shadow: 1px 1px 0 rgb(145, 140, 33)', 'font-weight: bold; font-size: 15px;color: rgb(240, 239, 233); text-shadow: 1px 1px 0 rgb(145, 145, 144)');
});
class SendToast {
constructor(options) {
var toast = document.createElement("div");
toast.setAttribute("id", "toast");
toast.classList.add('show');
CreateToasts.prepend(toast);
var ToastGroup = document.createElement("div");
ToastGroup.setAttribute("class", "toast group");
toast.prepend(ToastGroup);
if (!options) console.error("Data is empty");
if (options.message) var CreateMsgToast = document.createElement("span");
if (options.message) CreateMsgToast.setAttribute("class", "toast-msg");
if (options.message) ToastGroup.prepend(CreateMsgToast);
if (options.title) var CreateTitleToast = document.createElement("span");
if (options.title) CreateTitleToast.setAttribute("class", "toast-title");
if (options.title) ToastGroup.prepend(CreateTitleToast);
if (options.icon) var CreateimageToast = document.createElement("img");
if (options.icon) CreateimageToast.setAttribute("class", "toast-img");
if (options.icon) CreateimageToast.setAttribute("src", options.icon);
if (options.icon) ToastGroup.prepend(CreateimageToast);
if (options.type) var CreateColorToast = document.createElement("span");
if (options.type) CreateColorToast.setAttribute("class", "toast-color");
if (options.type) ToastGroup.prepend(CreateColorToast);
if (options.title) CreateTitleToast.innerText = options.title;
if (options.message) CreateMsgToast.innerText = options.message;
switch (options.type) {
case "Success":
ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color green");
break;
case "Error":
ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color red");
break;
case "Warning":
ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color yellow");
break;
case "Info":
ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color blue");
break;
}
setTimeout(function () { toast.remove(); }, 2900);
return toast;
}
}
class CreateMenu {
constructor(options) {
this.title = options.title;
this.menuItems = [];
this.menuItemsContainer = null;
const Menu = document.createElement("div");
Menu.setAttribute("class", "menu");
Menu.style.width = `${options.width}px`;
Menu.style.height = `${options.height}px`;
Menu.style.left = `${options.startX}px`;
Menu.style.top = `${options.startY}px`;
CreateMenus.prepend(Menu);
const gradient_slider = document.createElement("div");
gradient_slider.setAttribute("class", "gradient-slider");
Menu.prepend(gradient_slider);
const menu_items = document.createElement("div");
menu_items.setAttribute("class", "menu-items");
menu_items.style.width = `${options.width}px`;
menu_items.style.height = `${options.height - 40}px`
Menu.append(menu_items);
this.menuItemsContainer = menu_items;
if (options.title) var menu_title = document.createElement("div");
if (options.title) menu_title.setAttribute("class", "title");
if (options.title) menu_title.textContent = options.title;
if (options.title) gradient_slider.prepend(menu_title);
if (options.pin == true) var pin_button = document.createElement("button");
if (options.pin == true) pin_button.setAttribute("class", "pin-button");
if (options.pin == true) gradient_slider.prepend(pin_button);
if (options.pin == true) pin_button.addEventListener("click", (e) => { if (Menu.classList.contains('pinned')) { Menu.classList.remove('pinned'); } else { Menu.classList.add('pinned'); } });
let scaleFactor = 1.4;
window.addEventListener('resize', () => {
let width = window.innerWidth - (window.innerWidth < 1920 ? 180 : 320);
let e = width / 1150;
let scale = e < scaleFactor ? e / scaleFactor : 1;
Menu.style.transform = `scale(${scale})`;
Menu.style.transformOrigin = 'center';
});
gradient_slider.addEventListener("mousedown", (e) => {
let initialX = e.clientX;
let initialY = e.clientY;
function moveMenu(e) {
let currentX = e.clientX;
let currentY = e.clientY;
let diffX = currentX - initialX;
let diffY = currentY - initialY;
Menu.style.left = `${Menu.offsetLeft + diffX}px`;
Menu.style.top = `${Menu.offsetTop + diffY}px`;
initialX = currentX;
initialY = currentY;
}
function removeListeners() {
document.removeEventListener("mousemove", moveMenu);
document.removeEventListener("mouseup", removeListeners);
}
document.addEventListener("mousemove", moveMenu);
document.addEventListener("mouseup", removeListeners);
});
}
addButton(options) {
var Group = document.createElement("div");
Group.setAttribute("class", "list-group Buton");
this.menuItemsContainer.append(Group);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
if (options.label) Text.innerText = options.label;
Group.append(Text);
var Button = document.createElement("button");
Button.setAttribute("class", "button");
Button.innerText = options.title;
Group.append(Button);
this.menuItems.push(Group);
const self = {
element: Button,
html: () => self.element,
on: (event, callback) => {
self.element.addEventListener(event, callback);
}
};
return self;
}
addSwitch(options) {
var ToggleSwitch = document.createElement("div");
ToggleSwitch.setAttribute("class", "list-group toggle-switch");
this.menuItemsContainer.append(ToggleSwitch);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
Text.innerText = options.label;
ToggleSwitch.append(Text);
var Label = document.createElement("label");
Label.setAttribute("class", "switch");
ToggleSwitch.append(Label);
var checkbox = document.createElement("input");
checkbox.setAttribute("type", "checkbox");
if (options.value) checkbox.checked = options.value;
Label.append(checkbox);
var slider = document.createElement("span");
slider.setAttribute("class", "slider");
Label.append(slider);
this.menuItems.push(ToggleSwitch);
const self = {
element: ToggleSwitch,
html: () => self.element,
on: (event, callback) => {
self.element.addEventListener(event, callback);
},
getValue: () => checkbox.checked
};
return self;
}
addFileDrop(options) {
var Group = document.createElement("div");
Group.setAttribute("class", "list-group FileDrop");
this.menuItemsContainer.append(Group);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
Text.innerText = options.label;
Group.append(Text);
var DropZone = document.createElement("div");
DropZone.setAttribute("class", "DropZone");
Group.append(DropZone);
var Title = document.createElement("div");
Title.innerText = options.title;
DropZone.append(Title);
var Thumb = document.createElement("div");
Thumb.setAttribute("class", "DropThumb");
Thumb.setAttribute("style", "display: none;");
DropZone.append(Thumb);
var Fileİnput = document.createElement("input");
Fileİnput.setAttribute("class", "Fileİnput");
Fileİnput.setAttribute("type", "file");
Fileİnput.setAttribute("accept", "image/*");
DropZone.append(Fileİnput);
this.menuItems.push(Group);
Fileİnput.addEventListener('change', function (e) {
if (!e.target.files.length) e.target.parentElement.classList.add('Error');
if (e.target.files.length) updateThumbnail(e.target.files[0]);
const myEvent = new CustomEvent("Filedrop", { detail: e.target.files });
DropZone.dispatchEvent(myEvent);
});
DropZone.addEventListener('click', function (e) {
e.target.classList.remove('Error');
Fileİnput.click();
});
DropZone.addEventListener("dragover", function (e) {
e.preventDefault();
});
DropZone.addEventListener('drop', function (e) {
e.preventDefault();
if (e.dataTransfer.files.length) {
e.target.classList.remove('Error');
const myEvent = new CustomEvent("Filedrop", { detail: e.dataTransfer.files });
DropZone.dispatchEvent(myEvent);
updateThumbnail(e.dataTransfer.files[0]);
} else {
e.target.classList.add('Error');
}
});
function updateThumbnail(file) {
if (Thumb) {
Thumb.dataset.label = file.name;
if (file.type.startsWith("image/")) {
var reader = new FileReader();
reader.onload = function (e) {
Thumb.style.backgroundImage = `url('${e.target.result}')`;
Thumb.style.display = null;
Title.style.display = "none";
}
reader.readAsDataURL(file);
} else {
Thumb.style.backgroundImage = null;
Title.style.display = null;
}
}
}
const self =
{
element: DropZone,
html: () => self.element,
on: (event, callback) => {
self.element.addEventListener(event, callback);
}
}
return self;
}
addSelectMenu(options) {
var Group = document.createElement("div");
Group.setAttribute("class", "list-group FileDrop");
this.menuItemsContainer.append(Group);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
Text.innerText = options.label;
Group.append(Text);
const optionsMenu = document.createElement("div");
optionsMenu.setAttribute("class", "options-menu");
Group.appendChild(optionsMenu);
const select = document.createElement("select");
select.setAttribute("class", "select-style");
if (options.value) select.value = options.value;
optionsMenu.appendChild(select);
if (options.options && options.options.length > 0) {
for (let i = 0; i < options.options.length; i++) {
const option = document.createElement("option");
option.setAttribute("value", options.options[i].value);
option.textContent = options.options[i].name;
select.appendChild(option);
}
}
this.menuItems.push(Group);
const self =
{
element: select,
html: () => self.element,
changeSelectedIndex: (Index) => {
self.element.selectedIndex = Index;
},
addItem: (name, value) => {
const option = document.createElement("option");
option.setAttribute("value", value);
option.textContent = name;
select.appendChild(option);
},
removeItem: (value) => {
const options = select.querySelectorAll('option');
options.forEach((option) => {
if (option.value === value) {
option.remove();
}
});
},
clearAllItems: () => {
const options = select.querySelectorAll('option');
for (let i = 0; i < options.length; i++) {
const option = options[i];
option.remove();
}
},
getValue: () => self.element.value,
on: (event, callback) => {
self.element.addEventListener(event, callback);
}
}
return self;
}
addHotkey(options) {
if (options.keyevent instanceof KeyboardEvent) {
var Group = document.createElement("div");
Group.setAttribute("class", "list-group Buton");
this.menuItemsContainer.append(Group);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
if (options.label) Text.innerText = options.label;
Group.append(Text);
var Button = document.createElement("button");
Button.setAttribute("class", "button");
if (options.keyevent.ctrlKey) {
Button.innerText = `CTRL + ${options.keyevent.key.toUpperCase()}`;
} else if (options.keyevent.altKey) {
Button.innerText = `ALT + ${options.keyevent.key.toUpperCase()}`;
} else if (options.keyevent.shiftKey) {
Button.innerText = `SHIFT + ${options.keyevent.key.toUpperCase()}`;
} else {
Button.innerText = `${options.keyevent.key.toUpperCase()}`;
}
Group.append(Button);
this.menuItems.push(Group);
Button.addEventListener("click", () => {
Button.innerText = `...`;
document.addEventListener("keyup", handleKeyDown);
});
function handleKeyDown(event) {
event.preventDefault();
// Kontrol tuşlarına basılıysa, basılan tuşa göre değil de
// kontrol tuşu kombinasyonuna göre hareket et.
if (event.ctrlKey) {
Button.innerText = `CTRL + ${event.key.toUpperCase()}`;
} else if (event.altKey) {
Button.innerText = `ALT + ${event.key.toUpperCase()}`;
} else if (event.shiftKey) {
Button.innerText = `SHIFT + ${event.key.toUpperCase()}`;
} else {
Button.innerText = `${event.key.toUpperCase()}`;
}
const myEvent = new CustomEvent("Hotkey", { detail: event });
Button.dispatchEvent(myEvent);
document.removeEventListener("keyup", handleKeyDown);
}
const self = {
element: Button,
html: () => self.element,
on: (event, callback) => {
self.element.addEventListener(event, callback);
},
};
return self;
} else {
console.error("this is not a KeyboardEvent");
}
}
addInput(options) {
var Group = document.createElement("div");
Group.setAttribute("class", "list-group Input");
this.menuItemsContainer.append(Group);
var Text = document.createElement("div");
Text.setAttribute("class", "label");
if (options.label) Text.innerText = options.label;
Group.append(Text);
var Input = document.createElement("input");
Input.setAttribute("class", "input");
if (options.placeholder) Input.setAttribute("placeholder", options.placeholder);
Input.setAttribute("type", options.type === "number" ? "number" : "text");
if (options.value) Input.value = options.value;
if (options.min) Input.setAttribute("min", options.min);
if (options.max) Input.setAttribute("max", options.max);
Group.append(Input);
Input.addEventListener("input", function() {
if (Input.validity.rangeOverflow) {
Input.value = Input.max;
} else if (Input.validity.rangeUnderflow) {
Input.value = Input.min;
}
});
this.menuItems.push(Group);
const self = {
element: Input,
html: () => self.element,
on: (event, callback) => {
self.element.addEventListener(event, callback);
},
changeValue: (text) => {
self.element.value = text;
},
getValue: () => self.element.value,
};
return self;
}
}
MenuShowHide = function () {
if (document.querySelector('.menus').className.split(' ').indexOf('open') != -1) {
document.querySelector('.menus').classList.add('close');
document.querySelector('.menus').classList.remove('open');
} else {
document.querySelector('.menus').classList.add('open');
document.querySelector('.menus').classList.remove('close');
document.querySelector('.menus').removeAttribute("style");
}
}
close_button.addEventListener('click', function () {
MenuShowHide();
});