Greasy Fork is available in English.

Abnormal Menu

This is a JavaScript script that creates a menu for scripts.

This script should not be not be installed directly. It is a library for other scripts to include with the meta directive // @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();
});