ChatGPT Shortcut Anywhere

Toggle AiShort sidebar on the page

目前為 2024-07-10 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

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

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         ChatGPT Shortcut Anywhere
// @name:zh-CN   ChatGPT Shortcut Anywhere
// @name:ja      どこでもChatGPTショートカット
// @name:pt      Atalho ChatGPT Em Qualquer Lugar
// @namespace    https://www.aishort.top/
// @version      0.0.7
// @description  Toggle AiShort sidebar on the page
// @author       BensonLi
// @description:zh-CN ChatGPT Shortcut 扩展的增强版,任意网站都能打开 AiShort 侧边栏
// @description:ja ChatGPT Shortcut 拡張の強化版、任意のウェブサイトで AiShort サイドバーを開くことができます
// @description:pt Versão aprimorada da extensão ChatGPT Shortcut, abre a barra lateral AiShort em qualquer site
// @match        *://chatgpt.com/*
// @match        *://claude.ai/*
// @match        *://gemini.google.com/*
// @match        *://yiyan.baidu.com/*
// @match        *://chatglm.cn/*
// @match        *://*.siliconflow.cn/*
// @match        *://tongyi.aliyun.com/*
// @match        *://kimi.moonshot.cn/*
// @match        *://www.doubao.com/*
// @match        *://xinghuo.xfyun.cn/*
// @match        *://ying.baichuan-ai.com/*
// @match        *://yuanbao.tencent.com/*
// @match        *://groq.com/*
// @match        *://openrouter.ai/*
// @exclude      *://www.aishort.top/*
// @icon         https://www.aishort.top/img/logo.svg
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    window.onload = function() {
        // Check for existing extension to prevent duplicate rendering
        var iframes = document.getElementsByTagName('iframe');
        for (var i = 0; i < iframes.length; i++) {
            if (iframes[i].src.includes('www.aishort.top')) {
                return;
            }
        }

        // You can directly set your preferred language by editing this variable.
        // For example, replace 'null' with 'zh' for Chinese, 'en' for English, 'ja' for Japanese, etc.
        // Supported language codes include: 'en', 'zh', 'ja', 'ko', 'es', 'fr', 'de', 'it', 'ru', 'pt', 'hi', 'ar', and 'bn'.
        // If set to 'null', the script will automatically use the browser's default language.
        const userSelectedLanguage = null; // Example: const userSelectedLanguage = 'zh';

        // Array of available languages
        const AVAILABLE_LANGUAGES = ['en', 'zh', 'ja', 'ko', 'es', 'fr', 'de', 'it', 'ru', 'pt', 'hi', 'ar', 'bn'];

        // Function to get the user-selected language or the browser's default language
        function getLanguage() {
            if (AVAILABLE_LANGUAGES.includes(userSelectedLanguage)) {
                return userSelectedLanguage;
            }
            const browserLanguage = navigator.language.split('-')[0];
            return AVAILABLE_LANGUAGES.includes(browserLanguage) ? browserLanguage : 'en';
        }

        // Determine the language to use
        const userLanguage = getLanguage();
        // Set the URL for the iframe based on the selected language
        const iframeUrl = userLanguage === 'zh' ? 'https://www.aishort.top/' : `https://www.aishort.top/${userLanguage}/`;

        // svg toggleIcon
        const toggleIcon = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
        toggleIcon.setAttribute('viewBox', '0 0 1024 1024');
        toggleIcon.setAttribute('width', '35');
        toggleIcon.setAttribute('height', '35');
        toggleIcon.innerHTML = '<path d="M85.333333 490.666667A64 64 0 0 0 149.333333 554.666667h725.333334a64 64 0 0 0 0-128h-725.333334A64 64 0 0 0 85.333333 490.666667z" fill="#5cac7c"></path><path d="M405.333333 853.333333a64 64 0 0 1 0-128h469.333334a64 64 0 0 1 0 128h-469.333334z m256-597.333333a64 64 0 0 1 0-128h213.333334a64 64 0 0 1 0 128h-213.333334z" fill="#5cac7c" opacity=".5"></path>';

        toggleIcon.style.position = 'fixed';
        toggleIcon.style.bottom = '300px';
        toggleIcon.style.right = '15px';
        toggleIcon.style.zIndex = '1000';
        toggleIcon.style.cursor = 'pointer';
        document.body.appendChild(toggleIcon);

        const isChrome = /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor);
        const hostsRequiringPopup = ['chatgpt.com', 'gemini.google.com', 'groq.com', 'openrouter.ai'];

        if (hostsRequiringPopup.includes(window.location.host)) {
            // Separate Window model
            toggleIcon.addEventListener('click', function() {
                window.open(iframeUrl, '_blank', 'width=500,height=700');
            });
        } else {
            // iframe model
            const iframe = document.createElement('iframe');
            iframe.style.width = '400px';
            iframe.style.height = '100%';
            iframe.style.position = 'fixed';
            iframe.style.right = '0';
            iframe.style.top = '0';
            iframe.style.zIndex = '999';
            iframe.style.border = 'none';
            iframe.style.display = 'none';
            iframe.src = iframeUrl;
            document.body.appendChild(iframe);

            toggleIcon.addEventListener('click', function() {
                // Toggle the display of the iframe
                iframe.style.display = (iframe.style.display === 'none') ? 'block' : 'none';
            });
        }};
})();