Greasy Fork 支持简体中文。

InQuizitive Hack

Easily Complete Your Assigments

  1. // ==UserScript==
  2. // @name InQuizitive Hack
  3. // @namespace http://tampermonkey.net/
  4. // @version 2024-09-01
  5. // @description Easily Complete Your Assigments
  6. // @author You
  7. // @match https://ncia.wwnorton.com/*
  8. // @icon 
  9. // @grant GM_addStyle
  10. // @grant unsafeWindow
  11. // ==/UserScript==
  12.  
  13. (function() {
  14. 'use strict';
  15. function waitForScore() {
  16. if (unsafeWindow.Score !== undefined) {
  17. console.log("Score object is now accessible.");
  18. console.log(unsafeWindow.Score);
  19. clearInterval(interval);
  20. } else {
  21. console.log("Waiting for Score object...");
  22. console.log(unsafeWindow.Score);
  23. }
  24. }
  25.  
  26.  
  27. var interval = setInterval(waitForScore, 100);
  28. GM_addStyle(`
  29. #tmGuiContainer input[type="range"], #tmGuiContainer input[type="text"], #tmGuiContainer button {
  30. display: block;
  31. margin-top: 10px;
  32. width: 200px;
  33. }
  34.  
  35. #toggleButton {
  36. background-color: #f9f9f9; /* Light grey background */
  37. color: black;
  38. border: 1px solid #ccc;
  39. padding: 5px 10px;
  40. border-radius: 5px;
  41. cursor: pointer;
  42. outline: none;
  43. }
  44.  
  45. #toggleButton.active {
  46. background-color: #4CAF50; /* Green background for active state */
  47. color: white;
  48. }
  49.  
  50. #tmGuiContainer input[type="range"] {
  51. -webkit-appearance: none; /* Override default CSS styles */
  52. appearance: none;
  53. width: 100%;
  54. height: 5px;
  55. background: #ddd; /* Light grey background */
  56. outline: none; /* Remove outline */
  57. opacity: 0.7; /* Partial transparency */
  58. transition: opacity .2s;
  59. }
  60.  
  61. #tmGuiContainer input[type="range"]:hover {
  62. opacity: 1; /* Fully opaque on hover */
  63. }
  64.  
  65. #tmGuiContainer input[type="range"]::-webkit-slider-thumb {
  66. -webkit-appearance: none; /* Override default styles */
  67. appearance: none;
  68. width: 20px; /* Set a specific slider handle width */
  69. height: 20px; /* Set a specific slider handle height */
  70. background: #800080; /* Purple background */
  71. cursor: pointer; /* Cursor on hover */
  72. border-radius: 50%; /* Circular handle */
  73. }
  74.  
  75. #tmGuiContainer input[type="range"]::-moz-range-thumb {
  76. width: 20px;
  77. height: 20px;
  78. background: #800080;
  79. cursor: pointer;
  80. border-radius: 50%;
  81. }
  82. `);
  83.  
  84.  
  85. var guiContainer = document.createElement('div');
  86. guiContainer.id = "tmGuiContainer";
  87. guiContainer.style.position = "fixed";
  88. guiContainer.style.top = "10px";
  89. guiContainer.style.right = "10px";
  90. guiContainer.style.zIndex = "1000";
  91. guiContainer.style.padding = "10px";
  92. guiContainer.style.backgroundColor = "#f9f9f9";
  93. guiContainer.style.border = "1px solid #ccc";
  94. guiContainer.style.borderRadius = "5px";
  95. document.body.appendChild(guiContainer);
  96.  
  97. var slider = document.createElement('input');
  98. slider.type = "range";
  99. slider.min = "0";
  100. slider.max = "100";
  101. slider.value = "50";
  102. slider.id = "betAmountSlider";
  103. slider.style.width = "200px";
  104.  
  105.  
  106. var label = document.createElement('label');
  107. label.htmlFor = "betAmountSlider";
  108. label.textContent = "Bet Amount: " + slider.value;
  109. label.style.display = "block";
  110. label.style.marginTop = "10px";
  111.  
  112. guiContainer.appendChild(slider);
  113. guiContainer.appendChild(label);
  114.  
  115.  
  116. var maxBetInput = document.createElement('input');
  117. maxBetInput.type = "text";
  118. maxBetInput.value = slider.max;
  119. maxBetInput.style.marginTop = "10px";
  120. maxBetInput.style.display = "block";
  121.  
  122. var maxBetLabel = document.createElement('label');
  123. maxBetLabel.textContent = "Set Max Bet:";
  124. maxBetLabel.style.display = "block";
  125. maxBetLabel.style.marginTop = "10px";
  126.  
  127. var setMaxButton = document.createElement('button');
  128. setMaxButton.textContent = "Set Max";
  129. setMaxButton.style.marginTop = "5px";
  130. setMaxButton.onclick = function() {
  131. var newMax = parseInt(maxBetInput.value, 10);
  132. if (isNaN(newMax) || newMax < 0) {
  133. alert("Please enter a valid positive number.");
  134. } else {
  135. slider.max = newMax;
  136. }
  137. };
  138.  
  139. guiContainer.appendChild(maxBetLabel);
  140. guiContainer.appendChild(maxBetInput);
  141. guiContainer.appendChild(setMaxButton);
  142.  
  143.  
  144. slider.oninput = function() {
  145. label.textContent = "Bet Amount: " + this.value;
  146. window.betAmount = parseInt(this.value, 10);
  147. unsafeWindow.Score.set_bet(this.value);
  148. };
  149. })();