// ==UserScript==
// @name Monkeytyper
// @author Carson at Fyre
// @description Type really fast on Monkeytype! Useful for scuffing leaderboard entries.
// @icon 
// @version 0.1
// @match *://monkeytype.com/*
// @run-at document-start
// @grant none
// @license MIT
// @namespace https://greasyfork.org/en/users/1431993-carson-at-fyre
// ==/UserScript==
/* jshint esversion:6 */
/*
Author: Carson at Fyre
Github: https://github.com/carsonatfyre
Greasyfork: https://greasyfork.org/en/users/1431993-carson-at-fyre
READ BEFORE USING:
- Log out of your account before using this script and reload the page
- Press [Right arrow] on your keyboard to start.
- Modify `MIN_DELAY` and `MAX_DELAY` variables to change your typing speed
*/
(function() {
"use strict";
const MIN_DELAY = 0;
const MAX_DELAY = 10;
const TOGGLE_KEY = "ArrowRight";
const log = console.log;
function random(min, max) {
return Math.floor(Math.random() * (max - min + 1) + min);
}
let toggle = false;
function canType() {
const typingTest = document.getElementById("typingTest");
const isHidden = typingTest.classList.contains("hidden");
if (isHidden) toggle = false;
return toggle && !isHidden;
}
function getNextCharacter() {
const currentWord = document.querySelector(".word.active");
for (const letter of currentWord.children) {
if (letter.className === "") return letter.textContent;
}
return " ";
}
const InputEvents = {};
function pressKey(key) {
const wordsInput = document.getElementById("wordsInput");
const KeyboardEvent = Object.assign({}, DEFAULT_INPUT_OPTIONS, { target: wordsInput, data: key });
const InputEvent = Object.assign({}, DEFAULT_KEY_OPTIONS, { target: wordsInput, key: key });
wordsInput.value += key;
InputEvents.beforeinput(InputEvent);
InputEvents.input(InputEvent);
InputEvents.keyup(KeyboardEvent);
}
function typeCharacter() {
if (!canType()) {
log("Finished typing.");
return;
}
pressKey(getNextCharacter());
setTimeout(typeCharacter, random(MIN_DELAY, MAX_DELAY));
}
window.addEventListener("keydown", function(event) {
if (event.code === TOGGLE_KEY) {
event.preventDefault();
if (event.repeat) return;
toggle = !toggle;
if (toggle) {
log("Started typing.");
typeCharacter();
}
}
})
function hook(element) {
element.addEventListener = new Proxy(element.addEventListener, {
apply(target, _this, args) {
const [type, listener, ...options] = args;
if (_this.id === "wordsInput") {
InputEvents[type] = listener;
}
return target.apply(_this, args);
}
})
}
hook(HTMLInputElement.prototype);
const DEFAULT_KEY_OPTIONS = {
key: "", code: "", keyCode: 0, which: 0, isTrusted: true, altKey: false,
bubbles: true, cancelBubble: false, cancelable: true, charCode: 0,
composed: true, ctrlKey: false, currentTarget: null, defaultPrevented: false,
detail: 0, eventPhase: 0, isComposing: false, location: 0, metaKey: false,
path: null, repeat: false, returnValue: true, shiftKey: false, srcElement: null,
target: null, timeStamp: 6338.5, type: "", view: window,
};
const DEFAULT_INPUT_OPTIONS = {
isTrusted: true, bubbles: true, cancelBubble: false, cancelable: false,
composed: true, data: "", dataTransfer: null, defaultPrevented: false,
detail: 0, eventPhase: 0, inputType: "insertText", isComposing: false,
path: null, returnValue: true, sourceCapabilities: null, srcElement: null,
target: null, currentTarget: null, timeStamp: 11543, type: "input",
view: null, which: 0
};
})();