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(); });