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.

20.03.2025 itibariyledir. En son verisyonu görün.

Bu betiği kurabilmeniz için Tampermonkey, Greasemonkey ya da Violentmonkey gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği kurabilmeniz için Tampermonkey ya da Violentmonkey gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği kurabilmeniz için Tampermonkey ya da Violentmonkey gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği kurabilmeniz için Tampermonkey ya da Userscripts gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

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

Bu komut dosyasını yüklemek için bir kullanıcı komut dosyası yöneticisi uzantısı yüklemeniz gerekecek.

(Zaten bir kullanıcı komut dosyası yöneticim var, kurmama izin verin!)

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.

(Zateb bir user-style yöneticim var, yükleyeyim!)


// ==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('&')
}