GitHub Quick Translate

Listen to the keyboard shortcut Ctrl + Q to translate text and replace the original text in the input field with the translation. Supports Issue and Pull Request pages.

目前為 2025-03-20 提交的版本,檢視 最新版本

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

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

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

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

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

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

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

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

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

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

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

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

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

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


// ==UserScript==
// @name         GitHub Quick Translate
// @name:zh-CN   GitHub 快捷键翻译助手
// @description  Listen to the keyboard shortcut Ctrl + Q to translate text and replace the original text in the input field with the translation. Supports Issue and Pull Request pages.
// @description:zh-CN 监听键盘快捷键 Ctrl + Q,实现对文本进行翻译并将翻译结果替换到原文本框中的功能 支持Issue和pull request 页面.
// @author       人民的勤务员 <[email protected]>
// @namespace    https://github.com/ChinaGodMan/UserScripts
// @supportURL   https://github.com/ChinaGodMan/UserScripts/issues
// @homepageURL  https://github.com/ChinaGodMan/UserScripts
// @license      MIT
// @match        https://github.com/*
// @icon              
// @compatible   chrome
// @compatible   firefox
// @compatible   edge
// @compatible   opera
// @compatible   safari
// @compatible   kiwi
// @compatible   qq
// @compatible   via
// @compatible   brave
// @grant        GM_xmlhttpRequest
// @version      2025.03.20.0728
// @created      2025-03-20 07:28:08
// @modified     2025-03-20 07:28:08
// ==/UserScript==
/**
 * File: github-comment-translate.user.js
 * Project: UserScripts
 * File Created: 2025/03/20,Thursday 07:28:12
 * Author: 人民的勤务员@ChinaGodMan ([email protected])
 * -----
 * Last Modified: 2025/03/20,Thursday 09:02:35
 * Modified By: 人民的勤务员@ChinaGodMan ([email protected])
 * -----
 * License: MIT License
 * Copyright © 2024 - 2025 ChinaGodMan,Inc
 */
const translate = 'en'
document.addEventListener('keydown', function (event) {
    if (event.ctrlKey && event.key.toLowerCase() === 'q') {
        event.preventDefault()
        translateComment()
    }
})
function translateComment() {
    const fields = document.querySelectorAll(
        'textarea.js-comment-field, textarea[aria-labelledby="comment-composer-heading"]'
    )
    if (fields.length > 0) {
        const lastField = fields[fields.length - 1]

        const start = lastField.selectionStart
        const end = lastField.selectionEnd
        if (start !== end) {
            const before = lastField.value.slice(0, start)
            const selectedText = lastField.value.slice(lastField.selectionStart, lastField.selectionEnd)
            const after = lastField.value.slice(end)
            googleTranslate(selectedText).then(translatedText => {
                lastField.value = before + translatedText + after
                lastField.selectionStart = lastField.selectionEnd = start + translatedText.length
                document.execCommand('insertText', false, '.')
                document.execCommand('delete', false, null)
            }).catch(error => {
                console.log('翻译失败', error)
            })
        } else {
            console.log('未选文本')
        }
    } else {
        console.log('未找到域')
    }
}
function googleTranslate(text) {
    return new Promise((resolve, reject) => {
        var api = 'https://translate.googleapis.com/translate_a/single'
        var params = {
            client: 'gtx',
            dt: 't',
            sl: 'auto',
            tl: translate,
            q: text
        }

        GM_xmlhttpRequest({
            method: 'GET',
            url: api + buildQueryString(params),
            onload: function (response) {
                try {
                    var data = JSON.parse(response.responseText.replace('\'', '\u2019'))
                    var translatedText = data[0].reduce((acc, item) => acc + item[0], '')
                    resolve(translatedText)
                } catch (error) {
                    console.error('翻译失败:', error)
                    reject('翻译失败')
                }
            },
            onerror: function (response) {
                console.error('请求翻译失败:', response.statusText)
                reject('请求翻译失败')
            }
        })
    })
}
function buildQueryString(params) {
    return '?' + Object.keys(params).map(function (key) {
        return encodeURIComponent(key) + '=' + encodeURIComponent(params[key])
    }).join('&')
}