AllenAI Playground Auto-Focus

Automatically focuses the input on AllenAI Playground when typing

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         AllenAI Playground Auto-Focus
// @description  Automatically focuses the input on AllenAI Playground when typing
// @match        https://playground.allenai.org/*
// @version 0.0.1.20250501101156
// @namespace https://greasyfork.org/users/1435046
// ==/UserScript==

document.addEventListener('keydown', e => {
    const textarea = document.querySelector('textarea.auto-sized-input');
    const active = document.activeElement;
    
    if (textarea && !/^textarea|input$/i.test(active.tagName) && 
        e.key.length === 1 && /^[\w\s\W]$/.test(e.key) && !e.ctrlKey && !e.metaKey) {
        
        e.preventDefault();
        textarea.focus();
        
        // Insert text at cursor position
        const start = textarea.selectionStart;
        const end = textarea.selectionEnd;
        textarea.setRangeText(e.key, start, end, "end");
        
        // Trigger input events for React state updates
        textarea.dispatchEvent(new Event('input', { bubbles: true }));
        textarea.dispatchEvent(new Event('change', { bubbles: true }));
    }
});