您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Listens for postMessage events on playground.allenai.org, enters into chat input, and auto-submits
// ==UserScript== // @name AllenAI Auto-Submit Listener // @description Listens for postMessage events on playground.allenai.org, enters into chat input, and auto-submits // @match https://playground.allenai.org/* // @version 0.0.1.20250803182735 // @namespace https://greasyfork.org/users/1435046 // ==/UserScript== (function () { 'use strict'; function setNativeValue(element, value) { const lastValue = element.value; element.value = value; const tracker = element._valueTracker; if (tracker) { tracker.setValue(lastValue); } element.dispatchEvent(new Event('input', { bubbles: true })); } window.addEventListener('message', event => { if (event.data?.type === 'newChatButtonClicked') { const newChatLink = document.querySelector('a[aria-label="Create a new thread"]'); if (newChatLink) { newChatLink.click(); } return; } //hide shit //inline properties get swept away //need properties to be set in style element let allenAiCssStyleId = document.getElementById('allenAiCssStyleId'); let chatMessageInput = document.querySelector('div:has(> div > form > div > div > div > textarea[name="content"])'); let header = document.querySelector('header'); let termsParagraph = document.querySelector('div:has(> p > a[href="https://allenai.org/terms"])'); let termsParagraphRule = 'div:has(> p > a[href="https://allenai.org/terms"]) {display: none !important;}'; let termsHr = document.querySelector('div:has(> p > a[href="https://allenai.org/terms"]) + hr'); let termsHrRule = 'div:has(> p > a[href="https://allenai.org/terms"]) + hr {display: none !important;}'; let modelSelector = document.querySelector('div:has(> div > div > svg > path[d="M7 10l5 5 5-5z"])'); //if event data type is defaultChatMessageInputDisplay if (event.data?.type === 'defaultChatMessageInputDisplay') { console.log('default'); if (chatMessageInput) { //delete the rules here chatMessageInput.style.removeProperty('display'); header.style.removeProperty('display'); allenAiCssStyleId.innerHTML = allenAiCssStyleId.innerHTML.replace(`${termsParagraphRule}`, ''); allenAiCssStyleId.innerHTML = allenAiCssStyleId.innerHTML.replace(`${termsHrRule}`, ''); //termsHr.style.removeProperty('display'); modelSelector.style.removeProperty('display'); //return return; } } if (event.data?.type === 'customizeChatMessageInputDisplay') { console.log('customize'); if (chatMessageInput) { //add the rules here chatMessageInput.style.display = 'none'; header.style.display = 'none'; allenAiCssStyleId.innerHTML += `${termsParagraphRule}` allenAiCssStyleId.innerHTML += `${termsHrRule}` //termsHr.style.display = 'none'; modelSelector.style.display = 'none'; //return return; } } if (event.data.type !== 'prompt' || event.data.content === 'recaptcha-setup') return; const message = event.data.content; // find the MUI/React textarea const textarea = document.querySelector( 'textarea[name="content"], textarea[aria-label="Message OLMo"]' ); if (!textarea) return; // inject into React state setNativeValue(textarea, message); // find and click the submit button const sendButton = document.querySelector('button[aria-label="Submit prompt"]'); if (sendButton) { sendButton.click(); } }); })();