Abnormal Menu

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

目前为 2023-03-17 提交的版本。查看 最新版本

此脚本不应直接安装,它是一个供其他脚本使用的外部库。如果您需要使用该库,请在脚本元属性加入:// @require https://update.gf.qytechs.cn/scripts/462013/1162637/Abnormal%20Menu.js

  1. /*
  2. Created by anonimbiri
  3. */
  4.  
  5. const link = document.createElement('link');
  6. link.rel = 'stylesheet';
  7. link.href = 'https://fonts.googleapis.com/css?family=Nunito:bold';
  8. document.getElementsByTagName('head')[0].appendChild(link);
  9. var style = document.createElement('style');
  10. style.type = 'text/css';
  11. style.innerHTML = `
  12. @keyframes blur-in {
  13. 0% {
  14. backdrop-filter:blur(0px);
  15. }
  16. 100% {
  17. backdrop-filter:blur(10px);
  18. }
  19. }
  20. @keyframes blur-out {
  21. 100% {
  22. backdrop-filter:blur(0px);
  23. }
  24. 0% {
  25. backdrop-filter:blur(10px);
  26. }
  27. }
  28. .menus {
  29. position: absolute;
  30. z-index: 1000;
  31. top: 0;
  32. left: 0;
  33. display: flex;
  34. width: 100%;
  35. height: 100vh;
  36. justify-content: center;
  37. align-items: center;
  38. }
  39. .bg-blur {
  40. position: absolute;
  41. top: 0;
  42. left: 0;
  43. width: 100%;
  44. height: 100%;
  45. background: rgba(0, 0, 0, .16);
  46. }
  47. .menus.open {
  48. animation:blur-in .3s;
  49. animation-fill-mode:forwards;
  50. visibility: visible;
  51. }
  52. .menus.close {
  53. animation:blur-out .3s;
  54. animation-fill-mode: forwards;
  55. visibility: hidden;
  56. }
  57. .close-button {
  58. background: url('');
  59. background-size: 32px !important;
  60. position: absolute;
  61. z-index: 1001;
  62. right: 32px;
  63. top: 32px;
  64. width: 32px;
  65. height: 32px;
  66. opacity: 0.3;
  67. border: none;
  68. }
  69. .close-button:hover {
  70. opacity: 1;
  71. }
  72. .close-button:before, .close-button:after {
  73. position: absolute;
  74. left: 15px;
  75. height: 33px;
  76. width: 2px;
  77. background-color: #333;
  78. }
  79. .close-button:before {
  80. transform: rotate(45deg);
  81. }
  82. .close-button:after {
  83. transform: rotate(-45deg);
  84. }
  85. .menu {
  86. background-color: #111111;
  87. width: 640px;
  88. height: 520px;
  89. margin: 0 auto;
  90. border-radius: 5px;
  91. position: absolute;
  92. transform: scale(0.82971);
  93. flex-direction: column;
  94. z-index: 1001;
  95. }
  96. .menu.pinned {
  97. visibility: visible;
  98. }
  99. .menu-items {
  100. width: 640px;
  101. height: 480px;
  102. overflow-y: scroll;
  103. }
  104. ::-webkit-scrollbar {
  105. width: 10px;
  106. }
  107. ::-webkit-scrollbar-thumb {
  108. background: #888;
  109. border-radius: 10px;
  110. }
  111. ::-webkit-scrollbar-track {
  112. background: transparent;
  113. }
  114. .gradient-slider .title {
  115. font-family: 'Nunito', sans-serif;
  116. font-weight: bold;
  117. font-size: 20px;
  118. margin: 0px 0px 20px;
  119. color: rgb(0, 0, 0);
  120. position: relative;
  121. display: flex;
  122. flex-direction: column;
  123. align-items: center;
  124. padding: 5px;
  125. }
  126. .gradient-slider {
  127. background: linear-gradient(268deg, #ff3939, #eeff30, #37ff30, #30ffd6, #ff30f4);
  128. background-size: 1000% 1000%;
  129. width: 100%;
  130. height: 30px;
  131. margin: 0 auto;
  132. border-radius: 5px 5px 0px 0px;
  133. animation: AnimationName 30s ease infinite;
  134. cursor: move;
  135. }
  136. @keyframes AnimationName {
  137. 0%{background-position:0% 50%}
  138. 50%{background-position:100% 50%}
  139. 100%{background-position:0% 50%}
  140. }
  141. .gradient-slider .pin-button {
  142. background: url('');
  143. background-size: 25px !important;
  144. position: absolute;
  145. z-index: 1001;
  146. top: 10;
  147. left: 10px;
  148. width: 25px;
  149. height: 25px;
  150. opacity: 0.3;
  151. border: none;
  152. }
  153. .menu.pinned .gradient-slider .pin-button {
  154. background: url('');
  155. }
  156. .pin-button:hover {
  157. opacity: 1;
  158. }
  159. .pin-button:before, .close-button:after {
  160. position: absolute;
  161. right: 15px;
  162. height: 33px;
  163. width: 2px;
  164. background-color: #333;
  165. }
  166. .pin-button:before {
  167. transform: rotate(45deg);
  168. }
  169. .pin-button:after {
  170. transform: rotate(-45deg);
  171. }
  172. .ui-tooltip {
  173. padding: 8px;
  174. position: absolute;
  175. z-index: 9999;
  176. max-width: 300px;
  177. width: 120px;
  178. background-color: #042c70;
  179. color: #fff;
  180. text-align: center;
  181. padding: 5px 10px;
  182. border-radius: 3px;
  183. font-family: nunitobold;
  184. font-size: 14px;
  185. }
  186. body .ui-tooltip {
  187. border-width: 2px;
  188. }
  189. .ui-tooltip:after {
  190. position: absolute;
  191. top: -8px;
  192. left: 50%;
  193. -webkit-transform: translateX(-50%);
  194. -moz-transform: translateX(-50%);
  195. -ms-transform: translateX(-50%);
  196. -o-transform: translateX(-50%);
  197. transform: translateX(-50%);
  198. content: '';
  199. border-style: solid;
  200. border-width: 0 10px 15px;
  201. border-color: transparent transparent #042c70 transparent;
  202. z-index: -1;
  203. }
  204. .ui-helper-hidden-accessible {
  205. border: 0;
  206. clip: rect(0 0 0 0);
  207. height: 1px;
  208. margin: -1px;
  209. overflow: hidden;
  210. padding: 0;
  211. position: absolute;
  212. width: 1px;
  213. }
  214. .toast-color {
  215. display: block;
  216. width: 15px;
  217. margin-right: 5px;
  218. border-radius: 3px 0 0 3px;
  219. position: relative;
  220. box-sizing: border-box;
  221. color: #eee;
  222. font-size: 16px;
  223. font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
  224. }
  225. .toast-color.red {
  226. background-color: #b90909;
  227. }
  228. .toast-color.green {
  229. background-color: #4caf50;
  230. }
  231. .toast-color.yellow {
  232. background-color: #ff9800;
  233. }
  234. .toast-color.blue {
  235. background-color: #2196f3;
  236. }
  237. .toast-img {
  238. padding: 5px;
  239. position: relative;
  240. box-sizing: border-box;
  241. width: 42px;
  242. height: 42px;
  243. object-fit: cover;
  244. }
  245. .toast-title {
  246. padding: 12px;
  247. position: relative;
  248. box-sizing: border-box;
  249. color: #eee;
  250. font-size: 16px;
  251. font-weight: bold;
  252. font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
  253. }
  254. .toast-msg {
  255. padding: 12px;
  256. position: relative;
  257. box-sizing: border-box;
  258. color: #eee;
  259. font-size: 16px;
  260. font-family: 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
  261. }
  262. #toasts {
  263. position: absolute;
  264. bottom: 0;
  265. right: 0;
  266. display: flex;
  267. flex-direction: column;
  268. align-items: flex-end;
  269. max-width: 100%;
  270. padding: 10px;
  271. overflow: hidden;
  272. }
  273. #toast {
  274. height: 43px;
  275. opacity: 1;
  276. margin-top: 5px;
  277. margin-bottom: 5px;
  278. overflow: hidden;
  279. margin: 5px 0;
  280. border-radius: 3px;
  281. box-shadow: 0 0 4px 0 #000;
  282. box-sizing: border-box;
  283. display: block;
  284. z-index: 1001;
  285. position: relative;
  286. }
  287. .toast.group {
  288. display: inline-flex;
  289. box-sizing: border-box;
  290. border-radius: 3px;
  291. color: #eee;
  292. font-size: 16px;
  293. background-color: #262626;
  294. vertical-align: bottom;
  295. }
  296. #toast.show {
  297. -webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s;
  298. animation: fadein 0.5s, fadeout 0.5s 2.5s;
  299. }
  300. @-webkit-keyframes fadein {
  301. from {right: -30%; opacity: 0;}
  302. to {right: 1%; opacity: 1;}
  303. }
  304. @keyframes fadein {
  305. from {right: -30%; opacity: 0;}
  306. to {right: 1%; opacity: 1;}
  307. }
  308. @-webkit-keyframes fadeout {
  309. from {right: 1%; opacity: 1;}
  310. to {right: -30%; opacity: 0;}
  311. }
  312. @keyframes fadeout {
  313. from {right: 1%; opacity: 1;}
  314. to {right: -30%; opacity: 0;}
  315. }
  316. .button {
  317. background-color: transparent;
  318. border: 2px solid #e0e1e2;
  319. color: #e0e1e2;
  320. padding: 16px 32px;
  321. text-align: center;
  322. text-decoration: none;
  323. display: inline-block;
  324. font-size: 16px;
  325. margin: 4px 2px;
  326. transition-duration: 0.4s;
  327. cursor: pointer;
  328. border-radius: 5px;
  329. font-family: 'Nunito', sans-serif;
  330. font-weight: bold;
  331. }
  332. .button:hover { color: rgba(0,0,0,.6); background: #cacbcd }
  333. .switch {
  334. position: relative;
  335. display: inline-block;
  336. width: 60px;
  337. height: 34px;
  338. border-radius:40px;
  339. border:2px solid #e0e1e2;
  340. }
  341. .switch input {
  342. opacity: 0;
  343. }
  344. .slider {
  345. position: absolute;
  346. cursor:pointer;
  347. top:0;
  348. left:0;
  349. right:0;
  350. bottom:0;
  351. border-radius: 34px;
  352. -webkit-transition:.5s;
  353. }
  354. .slider:before {
  355. position: absolute;
  356. content:"";
  357. height: 26px;
  358. width: 26px;
  359. top:3px;
  360. left:4px;
  361. background-color: #e0e1e2;
  362. -webkit-transition:.5s;
  363. }
  364. input:checked + .slider:before{
  365. -webkit-transform: translateX(26px);
  366. -ms-transform: translateX(26px);
  367. transform: translateX(26px);
  368. }
  369. .slider:before {
  370. border-radius: 50%;
  371. }
  372. .list-group {
  373. align-items: center;
  374. display: flex;
  375. padding-left: 10px;
  376. padding-right: 10px;
  377. padding-top: 20px;
  378. justify-content: space-between;
  379. }
  380. .list-group .label {
  381. display: inline-block;
  382. color: white;
  383. font-family: 'Nunito', sans-serif;
  384. font-weight: bold;
  385. }
  386. .DropZone {
  387. width: 200px;
  388. max-width: 200px;
  389. height: 200px;
  390. padding: 25px;
  391. display: flex;
  392. align-items: center;
  393. justify-content: center;
  394. border: 4px dashed #e0e1e27a;
  395. cursor:pointer;
  396. }
  397. .DropZone:hover {
  398. border-color: #cacbcd;
  399. }
  400. .DropZone.Error {
  401. border: 4px dashed #ff00007a;
  402. }
  403. .DropZone.Error:hover {
  404. border: 4px dashed #ff003b;
  405. }
  406. .DropZone.Error div{
  407. color: #ff003b;
  408. }
  409. .DropZone div{
  410. text-align: center;
  411. font-family: 'Nunito', sans-serif;
  412. font-weight: 500;
  413. font-size: 20px;
  414. color: lightgray;
  415. position: relative;
  416. }
  417. .Fileİnput {
  418. display: none;
  419. }
  420. .DropThumb {
  421. width: 100%;
  422. height: 100%;
  423. border-radius: 10px;
  424. overflow: hidden;
  425. background-color: #cccccc;
  426. background-size: cover;
  427. position: relative;
  428. }
  429. .DropThumb::after {
  430. content: attr(data-label);
  431. position: absolute;
  432. bottom: 0;
  433. left: 0;
  434. width: 100%;
  435. padding: 5px 0;
  436. color: #ffffff;
  437. background: rgba(0, 0, 0, 0.75);
  438. font-size: 14px;
  439. text-align: center;
  440. }
  441. .options-menu {
  442. background-color: #e0e1e2;
  443. width: 200px;
  444. position: relative;
  445. display: inline-block;
  446. border-radius: 5px;
  447. }
  448. .select-style {
  449. background-color: transparent;
  450. border: none;
  451. padding: 5px 10px;
  452. font-size: 16px;
  453. color: #555;
  454. width: 100%;
  455. border-radius: 5px;
  456. -webkit-appearance: none;
  457. -moz-appearance: none;
  458. appearance: none;
  459. cursor: pointer;
  460. outline: none;
  461. font-family: 'Nunito', sans-serif;
  462. font-weight: bold;
  463. }
  464. .select-style:after {
  465. content: "\f107";
  466. font-family: "Font Awesome 5 Free";
  467. font-weight: 900;
  468. position: absolute;
  469. right: 10px;
  470. top: 50%;
  471. transform: translateY(-50%);
  472. pointer-events: none;
  473. }
  474. .select-style option {
  475. background-color: #e0e1e2;
  476. color: #555;
  477. font-size: 16px;
  478. padding: 5px 10px;
  479. cursor: pointer;
  480. }
  481. .select-style option:checked {
  482. background-color: #8f8f8f;
  483. color: #fff;
  484. }
  485. `;
  486. document.getElementsByTagName('head')[0].appendChild(style);
  487.  
  488. var CreateToasts = document.createElement("div");
  489. var CreateMenus = document.createElement("div");
  490. var close_button = document.createElement("button");
  491. window.addEventListener('load', (event) => {
  492. CreateToasts.setAttribute("id", "toasts");
  493. document.body.prepend(CreateToasts);
  494. CreateMenus.setAttribute("class", "menus open");
  495. document.body.prepend(CreateMenus);
  496. var blur_bg = document.createElement("div");
  497. blur_bg.setAttribute("class", "bg-blur");
  498. CreateMenus.prepend(blur_bg);
  499. close_button.setAttribute("class", "close-button");
  500. close_button.setAttribute("title", "Close");
  501. CreateMenus.prepend(close_button);
  502. 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)');
  503. });
  504.  
  505. class SendToast {
  506. constructor(options) {
  507. var toast = document.createElement("div");
  508. toast.setAttribute("id", "toast");
  509. toast.classList.add('show');
  510. CreateToasts.prepend(toast);
  511. var ToastGroup = document.createElement("div");
  512. ToastGroup.setAttribute("class", "toast group");
  513. toast.prepend(ToastGroup);
  514. if (!options) console.error("Data is empty");
  515. if (options.message) var CreateMsgToast = document.createElement("span");
  516. if (options.message) CreateMsgToast.setAttribute("class", "toast-msg");
  517. if (options.message) ToastGroup.prepend(CreateMsgToast);
  518. if (options.title) var CreateTitleToast = document.createElement("span");
  519. if (options.title) CreateTitleToast.setAttribute("class", "toast-title");
  520. if (options.title) ToastGroup.prepend(CreateTitleToast);
  521. if (options.icon) var CreateimageToast = document.createElement("img");
  522. if (options.icon) CreateimageToast.setAttribute("class", "toast-img");
  523. if (options.icon) CreateimageToast.setAttribute("src", options.icon);
  524. if (options.icon) ToastGroup.prepend(CreateimageToast);
  525. if (options.type) var CreateColorToast = document.createElement("span");
  526. if (options.type) CreateColorToast.setAttribute("class", "toast-color");
  527. if (options.type) ToastGroup.prepend(CreateColorToast);
  528. if (options.title) CreateTitleToast.innerText = options.title;
  529. if (options.message) CreateMsgToast.innerText = options.message;
  530. switch (options.type) {
  531. case "Success":
  532. ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color green");
  533. break;
  534.  
  535. case "Error":
  536. ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color red");
  537. break;
  538.  
  539. case "Warning":
  540. ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color yellow");
  541. break;
  542.  
  543. case "Info":
  544. ToastGroup.querySelector('.toast-color').setAttribute("class", "toast-color blue");
  545. break;
  546. }
  547.  
  548. setTimeout(function () { toast.remove(); }, 2900);
  549. return toast;
  550. }
  551. }
  552.  
  553. class CreateMenu {
  554. constructor(options) {
  555. this.title = options.title;
  556. this.menuItems = [];
  557. this.menuItemsContainer = null;
  558.  
  559. const Menu = document.createElement("div");
  560. Menu.setAttribute("class", "menu");
  561. Menu.style.width = `${options.width}px`;
  562. Menu.style.height = `${options.height}px`;
  563. Menu.style.left = `${options.startX}px`;
  564. Menu.style.top = `${options.startY}px`;
  565. CreateMenus.prepend(Menu);
  566. const gradient_slider = document.createElement("div");
  567. gradient_slider.setAttribute("class", "gradient-slider");
  568. Menu.prepend(gradient_slider);
  569. const menu_items = document.createElement("div");
  570. menu_items.setAttribute("class", "menu-items");
  571. menu_items.style.width = `${options.width}px`;
  572. menu_items.style.height = `${options.height - 40}px`
  573. Menu.append(menu_items);
  574. this.menuItemsContainer = menu_items;
  575. if (options.title) var menu_title = document.createElement("div");
  576. if (options.title) menu_title.setAttribute("class", "title");
  577. if (options.title) menu_title.textContent = options.title;
  578. if (options.title) gradient_slider.prepend(menu_title);
  579. if (options.pin == true) var pin_button = document.createElement("button");
  580. if (options.pin == true) pin_button.setAttribute("class", "pin-button");
  581. if (options.pin == true) gradient_slider.prepend(pin_button);
  582. if (options.pin == true) pin_button.addEventListener("click", (e) => { if (Menu.classList.contains('pinned')) { Menu.classList.remove('pinned'); } else { Menu.classList.add('pinned'); } });
  583.  
  584. let scaleFactor = 1.4;
  585. window.addEventListener('resize', () => {
  586. let width = window.innerWidth - (window.innerWidth < 1920 ? 180 : 320);
  587. let e = width / 1150;
  588. let scale = e < scaleFactor ? e / scaleFactor : 1;
  589. Menu.style.transform = `scale(${scale})`;
  590. Menu.style.transformOrigin = 'center';
  591. });
  592.  
  593.  
  594.  
  595. gradient_slider.addEventListener("mousedown", (e) => {
  596. let initialX = e.clientX;
  597. let initialY = e.clientY;
  598.  
  599. function moveMenu(e) {
  600. let currentX = e.clientX;
  601. let currentY = e.clientY;
  602. let diffX = currentX - initialX;
  603. let diffY = currentY - initialY;
  604. Menu.style.left = `${Menu.offsetLeft + diffX}px`;
  605. Menu.style.top = `${Menu.offsetTop + diffY}px`;
  606. initialX = currentX;
  607. initialY = currentY;
  608. }
  609.  
  610. function removeListeners() {
  611. document.removeEventListener("mousemove", moveMenu);
  612. document.removeEventListener("mouseup", removeListeners);
  613. }
  614.  
  615. document.addEventListener("mousemove", moveMenu);
  616. document.addEventListener("mouseup", removeListeners);
  617. });
  618.  
  619.  
  620. }
  621.  
  622. addButton(options) {
  623. var Group = document.createElement("div");
  624. Group.setAttribute("class", "list-group Buton");
  625. this.menuItemsContainer.append(Group);
  626. var Text = document.createElement("div");
  627. Text.setAttribute("class", "label");
  628. if (options.label) Text.innerText = options.label;
  629. Group.append(Text);
  630. var Button = document.createElement("button");
  631. Button.setAttribute("class", "button");
  632. Button.innerText = options.title;
  633. Group.append(Button);
  634. this.menuItems.push(Group);
  635.  
  636.  
  637. const self = {
  638. element: Button,
  639. html: () => self.element,
  640. on: (event, callback) => {
  641. self.element.addEventListener(event, callback);
  642. }
  643. };
  644. return self;
  645. }
  646.  
  647. addSwitch(options) {
  648. var ToggleSwitch = document.createElement("div");
  649. ToggleSwitch.setAttribute("class", "list-group toggle-switch");
  650. this.menuItemsContainer.append(ToggleSwitch);
  651. var Text = document.createElement("div");
  652. Text.setAttribute("class", "label");
  653. Text.innerText = options.label;
  654. ToggleSwitch.append(Text);
  655. var Label = document.createElement("label");
  656. Label.setAttribute("class", "switch");
  657. ToggleSwitch.append(Label);
  658. var checkbox = document.createElement("input");
  659. checkbox.setAttribute("type", "checkbox");
  660. //checkbox.checked = value; // set initial value
  661. Label.append(checkbox);
  662. var slider = document.createElement("span");
  663. slider.setAttribute("class", "slider");
  664. Label.append(slider);
  665. this.menuItems.push(ToggleSwitch);
  666.  
  667. const self = {
  668. element: ToggleSwitch,
  669. html: () => self.element,
  670. on: (event, callback) => {
  671. self.element.addEventListener(event, callback);
  672. },
  673. getValue: () => checkbox.checked
  674. };
  675. return self;
  676. }
  677.  
  678. addFileDrop(options) {
  679. var Group = document.createElement("div");
  680. Group.setAttribute("class", "list-group FileDrop");
  681. this.menuItemsContainer.append(Group);
  682. var Text = document.createElement("div");
  683. Text.setAttribute("class", "label");
  684. Text.innerText = options.label;
  685. Group.append(Text);
  686. var DropZone = document.createElement("div");
  687. DropZone.setAttribute("class", "DropZone");
  688. Group.append(DropZone);
  689. var Title = document.createElement("div");
  690. Title.innerText = options.title;
  691. DropZone.append(Title);
  692. var Thumb = document.createElement("div");
  693. Thumb.setAttribute("class", "DropThumb");
  694. Thumb.setAttribute("style", "display: none;");
  695. DropZone.append(Thumb);
  696. var Fileİnput = document.createElement("input");
  697. Fileİnput.setAttribute("class", "Fileİnput");
  698. Fileİnput.setAttribute("type", "file");
  699. Fileİnput.setAttribute("accept", "image/*");
  700. DropZone.append(Fileİnput);
  701. this.menuItems.push(Group);
  702.  
  703.  
  704. Fileİnput.addEventListener('change', function (e) {
  705. if (!e.target.files.length) e.target.parentElement.classList.add('Error');
  706. if (e.target.files.length) updateThumbnail(e.target.files[0]);
  707. const myEvent = new CustomEvent("Filedrop", { detail: e.target.files });
  708. DropZone.dispatchEvent(myEvent);
  709. });
  710.  
  711. DropZone.addEventListener('click', function (e) {
  712. e.target.classList.remove('Error');
  713. Fileİnput.click();
  714. });
  715.  
  716. DropZone.addEventListener("dragover", function (e) {
  717. e.preventDefault();
  718. });
  719.  
  720. DropZone.addEventListener('drop', function (e) {
  721. e.preventDefault();
  722. if (e.dataTransfer.files.length) {
  723. e.target.classList.remove('Error');
  724.  
  725. const myEvent = new CustomEvent("Filedrop", { detail: e.dataTransfer.files });
  726. DropZone.dispatchEvent(myEvent);
  727. updateThumbnail(e.dataTransfer.files[0]);
  728. } else {
  729. e.target.classList.add('Error');
  730. }
  731. });
  732.  
  733. function updateThumbnail(file) {
  734.  
  735. if (Thumb) {
  736. Thumb.dataset.label = file.name;
  737. if (file.type.startsWith("image/")) {
  738. var reader = new FileReader();
  739.  
  740. reader.onload = function (e) {
  741. Thumb.style.backgroundImage = `url('${e.target.result}')`;
  742. Thumb.style.display = null;
  743. Title.style.display = "none";
  744. }
  745.  
  746. reader.readAsDataURL(file);
  747. } else {
  748. Thumb.style.backgroundImage = null;
  749. Title.style.display = null;
  750. }
  751. }
  752. }
  753.  
  754.  
  755. const self =
  756. {
  757. element: DropZone,
  758. html: () => self.element,
  759. on: (event, callback) => {
  760. self.element.addEventListener(event, callback);
  761. }
  762. }
  763. return self;
  764. }
  765.  
  766. addSelectMenu(options) {
  767. var Group = document.createElement("div");
  768. Group.setAttribute("class", "list-group FileDrop");
  769. this.menuItemsContainer.append(Group);
  770. var Text = document.createElement("div");
  771. Text.setAttribute("class", "label");
  772. Text.innerText = options.label;
  773. Group.append(Text);
  774. const optionsMenu = document.createElement("div");
  775. optionsMenu.setAttribute("class", "options-menu");
  776. Group.appendChild(optionsMenu);
  777. const select = document.createElement("select");
  778. select.setAttribute("class", "select-style");
  779. optionsMenu.appendChild(select);
  780. if (options.options && options.options.length > 0) {
  781. for (let i = 0; i < options.options.length; i++) {
  782. const option = document.createElement("option");
  783. option.setAttribute("value", options.options[i].value);
  784. option.textContent = options.options[i].name;
  785. select.appendChild(option);
  786. }
  787. }
  788. this.menuItems.push(Group);
  789.  
  790. const self =
  791. {
  792. element: select,
  793. html: () => self.element,
  794. changeSelectedIndex: (Index) => {
  795. self.element.selectedIndex = Index;
  796. },
  797. addItem: (name, value) => {
  798. const option = document.createElement("option");
  799. option.setAttribute("value", value);
  800. option.textContent = name;
  801. select.appendChild(option);
  802. },
  803. on: (event, callback) => {
  804. self.element.addEventListener(event, callback);
  805. }
  806. }
  807. return self;
  808. }
  809.  
  810. addHotkey(options) {
  811. if (options.keyevent instanceof KeyboardEvent) {
  812. var Group = document.createElement("div");
  813. Group.setAttribute("class", "list-group Buton");
  814. this.menuItemsContainer.append(Group);
  815. var Text = document.createElement("div");
  816. Text.setAttribute("class", "label");
  817. if (options.label) Text.innerText = options.label;
  818. Group.append(Text);
  819. var Button = document.createElement("button");
  820. Button.setAttribute("class", "button");
  821. if (options.keyevent.ctrlKey) {
  822. Button.innerText = `CTRL + ${options.keyevent.key.toUpperCase()}`;
  823. } else if (options.keyevent.altKey) {
  824. Button.innerText = `ALT + ${options.keyevent.key.toUpperCase()}`;
  825. } else if (options.keyevent.shiftKey) {
  826. Button.innerText = `SHIFT + ${options.keyevent.key.toUpperCase()}`;
  827. } else {
  828. Button.innerText = `${options.keyevent.key.toUpperCase()}`;
  829. }
  830. Group.append(Button);
  831. this.menuItems.push(Group);
  832.  
  833. Button.addEventListener("click", () => {
  834. Button.innerText = `...`;
  835. document.addEventListener("keyup", handleKeyDown);
  836. });
  837.  
  838. function handleKeyDown(event) {
  839. event.preventDefault();
  840.  
  841. // Kontrol tuşlarına basılıysa, basılan tuşa göre değil de
  842. // kontrol tuşu kombinasyonuna göre hareket et.
  843. if (event.ctrlKey) {
  844. Button.innerText = `CTRL + ${event.key.toUpperCase()}`;
  845. } else if (event.altKey) {
  846. Button.innerText = `ALT + ${event.key.toUpperCase()}`;
  847. } else if (event.shiftKey) {
  848. Button.innerText = `SHIFT + ${event.key.toUpperCase()}`;
  849. } else {
  850. Button.innerText = `${event.key.toUpperCase()}`;
  851. }
  852.  
  853. const myEvent = new CustomEvent("Hotkey", { detail: event });
  854. Button.dispatchEvent(myEvent);
  855. document.removeEventListener("keyup", handleKeyDown);
  856. }
  857.  
  858. const self = {
  859. element: Button,
  860. html: () => self.element,
  861. on: (event, callback) => {
  862. self.element.addEventListener(event, callback);
  863. },
  864. };
  865. return self;
  866.  
  867. }else{
  868. console.error("this is not a KeyboardEvent");
  869. }
  870. }
  871.  
  872. }
  873.  
  874. MenuShowHide = function () {
  875. if (document.querySelector('.menus').className.split(' ').indexOf('open') != -1) {
  876. document.querySelector('.menus').classList.add('close');
  877. document.querySelector('.menus').classList.remove('open');
  878. } else {
  879. document.querySelector('.menus').classList.add('open');
  880. document.querySelector('.menus').classList.remove('close');
  881. document.querySelector('.menus').removeAttribute("style");
  882. }
  883. }
  884.  
  885. close_button.addEventListener('click', function () {
  886. MenuShowHide();
  887. });

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址