sn-translator/sn_translator/sn-translator.js

72 lines
2.2 KiB
JavaScript
Raw Normal View History

2022-12-24 22:43:53 +00:00
// ==UserScript==
// @name SN translator
// @namespace http://tampermonkey.net/
// @version 0.1
// @description Translate posts on SN
// @author You
// @match https://stacker.news/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=tampermonkey.net
// @grant GM_xmlhttpRequest
// ==/UserScript==
const headers = {
2022-12-25 01:38:03 +00:00
origin: 'https://libretranslate.com',
accept: '*/*',
'accept-language': 'de-DE,de;q=0.9,ru-DE;q=0.8,ru;q=0.7,en-US;q=0.6,en;q=0.5',
'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"',
'sec-ch-ua-mobile': '?0',
'sec-ch-ua-platform': '"Linux"',
'sec-fetch-dest': 'empty',
'sec-fetch-mode': 'cors',
'sec-fetch-site': 'same-origin',
}
2022-12-24 22:43:53 +00:00
function translate(text, source, target) {
2022-12-25 01:38:03 +00:00
const formData = new FormData()
formData.append('q', text)
formData.append('source', source)
formData.append('target', target)
2022-12-24 22:43:53 +00:00
return new Promise((resolve, reject) => {
GM_xmlhttpRequest({
2022-12-25 01:38:03 +00:00
method: 'POST',
url: 'https://libretranslate.com/translate',
2022-12-24 22:43:53 +00:00
data: formData,
headers,
synchronous: true,
onload: function (res) {
2022-12-25 01:38:03 +00:00
const body = JSON.parse(res.responseText)
if (res.status !== 200) return reject(body)
return resolve(body.translatedText)
2022-12-24 22:43:53 +00:00
},
2022-12-25 01:38:03 +00:00
})
})
2022-12-24 22:43:53 +00:00
}
2022-12-25 01:38:03 +00:00
const sleep = (ms) => new Promise((r) => setTimeout(r, ms))
2022-12-24 22:43:53 +00:00
2022-12-25 01:35:05 +00:00
function addButtons() {
2022-12-25 01:38:03 +00:00
console.log('sn-translator: Adding button to every comment ...')
const commentSection = document.querySelector('.item_comments__cN57K')
const comments = commentSection.querySelectorAll('.comment_comment__5uvl3')
2022-12-24 22:43:53 +00:00
for (const comment of comments) {
2022-12-25 01:38:03 +00:00
const topBar = comment.querySelector('.item_other__qNlji')
const content = comment.querySelector('.comment_text__nHI0E')
const padding = document.createElement('span')
padding.innerText = ' '
const btn = document.createElement('button')
btn.innerText = 'Translate'
2022-12-24 22:43:53 +00:00
btn.onclick = async (e) => {
2022-12-25 01:38:03 +00:00
const t = await translate(content.innerText, 'auto', 'en').catch(console.error)
if (t) content.innerText = t
}
topBar.appendChild(padding)
topBar.appendChild(btn)
2022-12-24 22:43:53 +00:00
}
2022-12-25 01:38:03 +00:00
console.log('Done')
2022-12-25 01:35:05 +00:00
}
2022-12-25 01:38:03 +00:00
;(async function () {
await sleep(1000)
addButtons()
})()