ChatAssistant

ChatAssistant test

Este script não deve ser instalado diretamente. Este script é uma biblioteca de outros scripts para incluir com o diretório meta // @require https://update.greasyfork.org/scripts/536368/1591164/ChatAssistant.js

Você precisará instalar uma extensão como Tampermonkey, Greasemonkey ou Violentmonkey para instalar este script.

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

Você precisará instalar uma extensão como Tampermonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Userscripts para instalar este script.

Você precisará instalar uma extensão como o Tampermonkey para instalar este script.

Você precisará instalar um gerenciador de scripts de usuário para instalar este script.

(Eu já tenho um gerenciador de scripts de usuário, me deixe instalá-lo!)

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

(Eu já possuo um gerenciador de estilos de usuário, me deixar fazer a instalação!)

Tabs.ChatAssistant = {
    init: function() {
        var div = document.createElement('div');
        div.className = 'tabContent';
        div.style.display = 'none';
        return div;
    },

    paint: function() {
        // Create response options
        var responseOptions = Object.keys(this.cannedResponses).map(key => `
            <option value="${key}">${this.cannedResponses[key]}</option>
        `).join('');

        var m = `
            <div class="divHeader" align="center">Chat Assistant</div>
            <br>
            <div align="center">
                <select id="cannedResponseSelect" class="btInput">
                    <option value="">-- Select Response --</option>
                    ${responseOptions}
                </select>
                <br><br>
                <textarea id="chatInput" rows="3" cols="50" class="btInput"></textarea>
                <br>
                <button id="sendButton" class="buttonv2 std blue">Send to Global</button>
            </div>
        `;

        // Create div if it doesn't exist
        if (!this.myDiv) {
            this.myDiv = document.createElement('div');
            this.myDiv.className = 'tabContent';
        }
        this.myDiv.innerHTML = m;

        // Event listeners
        var self = this;
        $("#cannedResponseSelect").change(function() {
            self.insertCannedResponse();
        });
        $("#sendButton").click(function() {
            self.sendMessage();
        });
    },

    insertCannedResponse: function() {
        var selectedKey = $("#cannedResponseSelect").val();
        var cannedResponse = this.cannedResponses[selectedKey] || "";
        $("#chatInput").val(cannedResponse);
    },

    sendMessage: function() {
        var message = $("#chatInput").val().trim();
        if (message === "") {
            return;
        }

        // Send message to global chat
        unsafeWindow.cm.sendGlobalChat(message);

        $("#chatInput").val(""); // Clear input
    },

    // Canned responses
    cannedResponses: {
        "help": translate("I need help with..."),
        "resources": translate("I'm looking for resources.  Does anyone have..."),
        // ... other canned responses ...
    }
};