Minimal ChatGPT Message Logger + Injector + Submitter

Listen for postMessage from parent, log to console, enter it into the chat input, and submit

Od 12.05.2025.. Pogledajte najnovija verzija.

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 or Violentmonkey 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         Minimal ChatGPT Message Logger + Injector + Submitter
// @description  Listen for postMessage from parent, log to console, enter it into the chat input, and submit
// @match        https://chatgpt.com/*
// @version 0.0.1.20250512170044
// @namespace https://greasyfork.org/users/1435046
// ==/UserScript==

(function () {
    'use strict';

    window.addEventListener('message', function (event) {

if (event.data && event.data.type === 'searchButtonClicked') {
    const searchBtn = document.querySelector('[data-testid="composer-button-search"]');
    if (searchBtn) searchBtn.click();
    return;
}

        const composer = document.querySelector('.ProseMirror');
        if (!composer || typeof event.data !== 'string') return;

        // Inject the text
        composer.innerText = event.data;

        // Trigger input event to notify ProseMirror
        composer.dispatchEvent(new InputEvent('input', { bubbles: true }));

        // Set up a MutationObserver to detect when the DOM reflects the new input
        const observer = new MutationObserver(() => {
            // Once mutation is detected, we assume ProseMirror has registered it
            observer.disconnect();

            // Submit the message
            composer.dispatchEvent(new KeyboardEvent('keydown', {
                bubbles: true,
                cancelable: true,
                key: 'Enter',
                code: 'Enter',
                which: 13,
                keyCode: 13
            }));
        });

        // Start observing the ProseMirror node
        observer.observe(composer, {
            childList: true,
            subtree: true,
            characterData: true
        });
    });
})();