slug | title | authors | image | description | tags | ||||
---|---|---|---|---|---|---|---|---|---|
let-this-script-type-instead-of-you |
Let this script type instead of you when you record a video |
|
/img/blog/typing-script/image.jpg |
Describing a simple script that types the string instead of me when I hit a specific shortcut. Now I use this to record videos, when I have to fill in an input |
|
I was working on cool gifs for Tolgee's new readme, where we show how simply you can modify a localization string in your App. But when I need to type something into input, I always make like 5 mistakes and my typing is not very nice to look at. So I created a script that types the string instead of me when I hit a specific shortcut. Now I use this to record videos, where I have to fill in some input, and I don't want to record it like 1000 times because I was typing inconsistently.
It can be useful for some pranks if you extend this. But let's leave this to your imagination.
So how does it work? It takes the array of strings. When I hit ctrl + h
for the first time, it iterates over
characters in the first string and modifies the value of the currently focused input by adding the current character. It waits 30ms
between every character addition. When I hit the shortcut a second time, it does the same thing with the second string.
When you just modify the value property of an input element, React doesn't trigger your onChange listener and so the value is not changed,
since React state is not updated. To trigger the onChange event listener you have to also dispatch input
and do some
other stuff you can read
about here.
The script (I call it typescript 😄):
(() => {
const strs = ["This is text...", "This is another text."];
let hits = 0;
window.onkeyup = async (event) => {
if (event.ctrlKey && event.key === "h") {
const input = document.activeElement;
for (const char of strs[hits]) {
if (input.value !== undefined) {
setNativeValue(input, input.value + char)
}
await new Promise((resolve) => setTimeout(resolve, 30))
}
hits++;
}
}
// Boring part starts here
// It makes it working with react.js apps
function setNativeValue(element, value) {
let lastValue = element.value;
element.value = value;
let event = new Event("input", {target: element, bubbles: true});
// React 15
event.simulated = true;
// React 16
let tracker = element._valueTracker;
if (tracker) {
tracker.setValue(lastValue);
}
element.dispatchEvent(event);
}
})()
- Copy the script and modify the strings to be typed
- Copy the modified script
- Go to the console of developer tools in your browser and paste the script
- Hit enter
- Focus an input and hit
ctrl + h
- Your text is being typed