Greasy Fork is available in English.

Twitter External Translator

Adds external & internal translators

اعتبارا من 08-12-2021. شاهد أحدث إصدار.

// ==UserScript==
// @name         Twitter External Translator
// @name:bg      Външен преводач на Twitter
// @name:zh      Twitter外部翻译器
// @name:zh-CN   Twitter外部翻译器
// @name:zh-TW   Twitter外部翻译器
// @name:cs      Externí překladatel Twitter
// @name:da      Twitter ekstern oversætter
// @name:et      Twitteri väline tõlkija
// @name:fi      Twitter Ulkoinen kääntäjä
// @name:el      Εξωτερικός μεταφραστής Twitter
// @name:hu      Twitter külső fordító
// @name:lv      Twitter Ārējais tulkotājs
// @name:lt      "Twitter" išorinis vertėjas
// @name:ro      Twitter Traducător extern
// @name:sk      Externý prekladateľ Twitter
// @name:sl      Twitter Zunanji prevajalec
// @name:sv      Twitter Extern översättare
// @name:nl      Twitter Externe Vertaler
// @name:fr      Traducteur externe Twitter
// @name:de      Externer Twitter-Übersetzer
// @name:it      Traduttore esterno di Twitter
// @name:ja      ツイッター外部翻訳者
// @name:pl      Zewnętrzny tłumacz Twittera
// @name:pt      Tradutor externo do Twitter
// @name:pt-BR   Tradutor externo do Twitter
// @name:ru-RU   Twitter Внешний переводчик
// @name:ru      Twitter Внешний переводчик
// @name:es      Traductor externo de Twitter
// @description  Adds external & internal translators
// @description:zh      将第三方翻译添加到推特
// @description:zh-CN   将第三方翻译添加到推特
// @description:zh-TW   將第三方翻譯添加到推特
// @description:bg      Добавя преводачи на трети страни в Twitter
// @description:cs      Přidává překladatele třetích stran na Twitter
// @description:da      Tilføjer tredjepartsoversættere til Twitter
// @description:et      Lisab kolmanda osapoole tõlkijad Twitterisse
// @description:fi      Lisää kolmannen osapuolen kääntäjiä Twitteriin
// @description:el      Προσθέτει μεταφραστές 3ου μέρους στο Twitter
// @description:hu      Hozzáadja a 3. féltől származó fordítókat a Twitterhez
// @description:lv      Pievieno trešās puses tulkotājus Twitter
// @description:lt      Prideda trečiųjų šalių vertėjus į "Twitter
// @description:ro      Adaugă traducători de la terțe părți la Twitter
// @description:sk      Pridáva prekladateľov tretích strán na Twitter
// @description:sl      Dodaja prevajalce tretjih oseb na Twitterju
// @description:sv      Lägger till översättare från tredje part till Twitter
// @description:nl      Voegt vertalers van derden toe aan Twitter
// @description:fr      Ajout de traducteurs tiers à Twitter
// @description:de      Fügt Drittanbieter-Übersetzer zu Twitter hinzu
// @description:it      Aggiunge traduttori di terze parti a Twitter
// @description:pl      Dodaje tłumaczy innych firm do Twittera
// @description:pt      Adiciona tradutores de terceiros ao Twitter
// @description:pt-BR   Adiciona tradutores de terceiros ao Twitter
// @description:ja      サードパーティの翻訳者をツイッターに追加
// @description:ru-RU   Добавляет сторонних переводчиков в Twitter
// @description:ru      Добавляет сторонних переводчиков в Twitter
// @description:es      Añade traductores de terceros a Twitter
// @author       Magic <magicoflolis@tuta.io>
// @icon         https://abs.twimg.com/favicons/twitter.ico
// @version      0.28
// @license      MIT
// @namespace    https://github.com/magicoflolis/userscriptrepo/tree/master/ExternalTranslator#twitter-external-translator
// @homepageURL  https://github.com/magicoflolis/userscriptrepo/tree/master/ExternalTranslator#twitter-external-translator
// @supportURL   https://github.com/magicoflolis/userscriptrepo/issues/new
// @require      https://code.jquery.com/jquery-3.6.0.slim.min.js?_=1638935718515
// @match        https://mobile.twitter.com/*
// @match        https://twitter.com/*
// @match        https://tweetdeck.twitter.com/*
// @match        https://www.twitlonger.com/show/*
// @match        https://nitter.net/*
// @match        https://nitter.*/*
// @match        https://nitter.*.*/*
// @match        https://nitter.domain.glass/*
// @match        https://nitter-home.kavin.rocks/*
// @match        https://birdsite.xanny.family/*
// @match        https://twitr.gq/*
// @exclude      https://twitter.com/login
// @exclude      https://twitter.com/signup
// @exclude      https://twitter.com/i/flow/signup
// @exclude      https://twitter.com/teams/*
// @exclude      https://twitter.com/*/authorize?*
// @exclude      https://twitter.com/*/begin_password_reset
// @grant        GM_getValue
// @grant        GM.getValue
// @grant        GM_setValue
// @grant        GM.setValue
// @grant        GM_deleteValue
// @grant        GM.deleteValue
// @grant        GM_info
// @grant        GM_xmlhttpRequest
// ==/UserScript==

// Uncompressed source code:
// https://github.com/magicoflolis/userscriptrepo/tree/master/ExternalTranslator/src


"use strict";

(async () => {
let twCSS = `.tet{margin-top:1%}.css-1dbjc4n{-moz-box-align:stretch;-moz-box-direction:normal;-moz-box-orient:vertical;align-items:stretch;border:0px solid #000;box-sizing:border-box;display:flex;flex-basis:auto;flex-direction:column;flex-shrink:0;margin:0px;min-height:0px;min-width:0px;padding:0px;position:relative;z-index:0}.r-b88u0q{font-weight:700}select{height:auto !important}.r-qvutc0{overflow-wrap:break-word}.r-1adg3ll{display:block}.r-u8s1d{position:absolute}.r-1wbh5a2{flex-shrink:1}.r-1ny4l3l{outline-style:none}.r-1mi75qu{box-shadow:rgba(0,0,0,.02) 0px 0px 2px inset}.r-1udh08x{overflow:hidden}.r-1awozwy{-webkit-box-align:center;-moz-box-align:center;align-items:center}.r-1hwvwag{flex-basis:48px}.r-18kxxzh{-webkit-box-flex:0;flex-grow:0}.r-1777fci{-webkit-box-pack:center;-moz-box-pack:center;justify-content:center}.r-18u37iz{-webkit-box-direction:normal;-webkit-box-orient:horizontal;-moz-box-direction:normal;-moz-box-orient:horizontal;flex-direction:row}.r-ipm5af{top:0px}.r-1ifxtd0{margin-bottom:16px}.r-6gpygo{margin-bottom:12px !important}.r-1jgb5lz{margin-left:auto;margin-right:auto}.r-1ye8kvj{max-width:600px}.r-16y2uox{-webkit-box-flex:1;-moz-box-flex:1;flex-grow:1}.r-ttdzmv{padding-top:12px !important}.r-1iusvr4{flex-basis:0px}.r-13qz1uu{width:100%}.r-1dye5f7{padding-left:32px;padding-right:32px}.r-9ilb82{color:#6e767d}.r-16dba41{font-weight:400}.r-1vr29t4{font-weight:800}.r-a023e6{font-size:15px}.r-1qd0xha{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}.r-rjixqe{line-height:20px}.r-1cwl3u0{line-height:16px}.r-bcqeeo{min-width:0px}`,
tetCSS = `#tetMenuButton>span{color:#fff !important}#tetSelector>select{background-color:transparent;border:transparent}.r-kemksi>div#tetName,.r-yfoy6g>div#tetName{color:#6e767d}.tetNitterHover{background-color:#ff6c60}.tetNitter{border-color:#ffaca0;box-shadow:#ffaca0 0px 0px 0px 1px}.tetBtn.nitter{color:#fff;border:transparent;background-color:#ff6c60}h1.tetNTextColor{color:#888889}.nitter{border:1px solid #ff6c60;background-color:#0f0f0f}.nitter #tetName{color:#ff6c60}select.tetNTextColor,div.tetNTextColor{color:#f8f8f2}svg.tetNTextColor{color:#888889}.tetNText{color:#ff6c60 !important}.tetNBackground{background-color:#161616}.Button--primary{border-color:#1da1f2;box-shadow:#1da1f2 0px 0px 0px 1px}.r-tetTD{border-radius:14px;background-color:#15202b}.r-tetTD #tetName{color:#8899a6}.prf-header>div>.tet.tet-td{color:#fff !important}.tet-td{color:#1da1f2}.tet-td#tetName{color:#1da1f2 !important}.tet-td.tet{color:#8899a6}.r-hoverTD{background-color:#005fd1}.r-9ilb82{color:#6e767d}.r-1kqtdi0{border-color:#2f3336}#apifield{border-color:#2f3336}#tetSelector.r-1kqtdi0{border-color:#2f3336}#tetSelector.r-1kqtdi0#tetName{color:#6e767d !important}#tetSelector.r-1kqtdi0.r-tetTD{border-color:#8899a6}.r-urgr8i{background-color:#1da1f2}.r-p1n3y5{border-color:#1da1f2}.r-13gxpu9{color:#1da1f2}.r-13gxpu9#tetName{color:#1da1f2 !important}.r-1q3imqu{background-color:#1a91da}.r-1bih22f{box-shadow:#1da1f2 0px 0px 0px 1px}.r-1vkxrha{background-color:#ffad1f}.r-v6khid{border-color:#ffad1f}.r-61mi1v{color:#ffad1f}.r-61mi1v#tetName{color:#ffad1f !important}.r-1kplyi6{background-color:#e69c1c}.r-cdj8wb{box-shadow:#ffad1f 0px 0px 0px 1px}.r-1dgebii{background-color:#e0245e}.r-1iofnty{border-color:#e0245e}.r-daml9f{color:#e0245e}.r-daml9f#tetName{color:#e0245e !important}.r-1ucxkr8{background-color:#ca2055}.r-jd07pc{box-shadow:#e0245e 0px 0px 0px 1px}.r-168457u{background-color:#7856ff}.r-njt2r9{background-color:#865dca}.r-hy56xe{border-color:#7856ff}.r-11mmphe{box-shadow:#794bc4 0px 0px 0px 1px}.r-xfsgu1{color:#7856ff}.r-xfsgu1#tetName{color:#7856ff !important}.r-18z3xeu{background-color:#f45d22}.r-1kplyi6{background-color:#dc541f}.r-1xl5njo{border-color:#f45d22}.r-b8m25f{box-shadow:#f45d22 0px 0px 0px 1px}.r-1qkqhnw{color:#f45d22}.r-1qkqhnw#tetName{color:#f45d22 !important}.r-b5skir{background-color:#17bf63}.r-zx61xx{background-color:#15ac59}.r-5ctkeg{border-color:#17bf63}.r-1cqwhho{box-shadow:#17bf63 0px 0px 0px 1px}.r-nw8l94{color:#17bf63}.r-nw8l94#tetName{color:#17bf63 !important}.r-yfoy6g{background-color:#15202b}.r-14lw9ot{background-color:#fff}.r-kemksi{background-color:#000}.r-18jsvk2{color:#0f1419}.r-demo{border-style:solid !important;border-radius:16px !important;border-width:1px !important}.demo-TW{border-color:#2f3336 !important}.demo-TD{border:1px solid #8899a6 !important}.demo-NT{border:1px solid #FF6C6091 !important}.r-jwli3a{color:#fff}.tetAvatarFrame,#tetAvatar{align-items:stretch;border:0px solid #000;box-sizing:border-box;display:flex;flex-basis:auto;flex-direction:column;flex-shrink:0;margin:0px;min-height:0px;min-width:0px;padding:0px;position:relative;z-index:0}.tet{margin-top:4px;flex-wrap:wrap;line-height:16px;font-size:13px;font-weight:400;overflow-wrap:break-word;width:fit-content;height:min-content;display:flex}.tetAvatarFrame{flex-basis:auto;z-index:0;position:absolute;top:0px;right:0px;left:0px;bottom:0px;overflow:hidden;border-radius:9999px}.tetAvatarFrame #tetAvatar{background-image:url("https://abs.twimg.com/favicons/twitter.ico");background-size:cover;background-repeat:no-repeat;background-position:center center;z-index:-1;background-color:rgba(0,0,0,0);height:100%;width:100%;position:absolute}.tet-main{padding:0px 32px 32px 32px !important;flex-shrink:1;-moz-box-flex:1;flex-grow:1;width:100%;margin-left:auto;margin-right:auto}.tet-options{display:inline-grid;grid-template-rows:1fr 1fr 1fr}.tet-header{min-width:0px;text-align:center;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;white-space:normal;display:grid;margin:32px 0px 12px 0px !important}.tet-header .css-901oao{line-height:28px;font-size:23px;font-weight:800}.tet-header .tet-info{line-height:20px;font-size:15px;font-weight:400;color:#6e767d;margin-top:1%}.tet-header span{color:inherit;font:inherit;white-space:inherit}.tetAlert{right:0px;left:0px;bottom:0px;position:fixed !important;z-index:10000 !important}.tetAlert h1.tetAlertTxt{line-height:24px;font-size:20px;font-weight:700;min-width:0px}.tetAlert h1.tetAlertTxt span{font-family:inherit}.tetAlert .tetAlertTxt>span,.tetAlert .tetAlertTxt{white-space:normal;text-align:center;overflow-wrap:break-word;font-family:"TwitterChirp",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}.tetAlert div.tetAlertTxt{font-weight:400;font-size:15px;line-height:20px;min-width:0px;width:100%}.tetAlert .tetConfirmation{width:20%;border-radius:16px;left:40%;top:40%;position:fixed}.tetAlert .tetAlertBtns{margin:2% 25% 2% 25%;white-space:nowrap;outline-style:none;transition-property:background-color,box-shadow;transition-duration:.2s;flex-grow:1;user-select:none;border-color:rgba(0,0,0,0);overflow:hidden;border-width:1px;border-style:solid;cursor:pointer}.tetAlert .tetAlertBtns:nth-child(2){margin:0px 25% 4% 25%}.tetAlert .tetAlertBtns>div{font-size:15px;font-weight:700;font-family:"TwitterChirp",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:20px;overflow-wrap:break-word;min-width:0px;align-items:center;justify-content:center;flex-grow:1;flex-direction:row;text-align:center;display:flex}.tetAlert .tetAlertBtns>div>span{font-size:15px;font-family:inherit;line-height:20px;overflow-wrap:break-word;min-width:0px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:inherit;font:inherit;border:0px solid #000;box-sizing:border-box;display:inline;margin:0px;padding:0px}.tetAlert .tetAlertBtns>div>span>span{border:0px solid #000;box-sizing:border-box;display:inline;margin:0px;padding:0px}#tetForm{max-width:80vw;max-height:90vh;min-width:600px !important;flex-shrink:1;border-radius:16px;overflow:hidden}#tetForm>div{border-radius:16px}#tetForm .tetBackground .tetTextColor{overflow-wrap:break-word}#tetForm .tetBackground .tetTextColor span{overflow-wrap:break-word}#tetForm .tet-containter{width:100%}#tetForm .tet-containter.tet-fg{margin-left:auto;margin-right:auto}.tet-head,#tetName>span,#tweet-text>span,#tetMenuButton>span{color:inherit;font:inherit;font-family:inherit;white-space:inherit;overflow-wrap:break-word}.rm,button:not(.mini)>#tetSVG,button.mini>span{display:none !important}.tetFreeze{overflow:hidden !important;overscroll-behavior-y:none !important}#tetMenuButton{z-index:10;width:8vw;height:auto;position:fixed;top:65%;left:0px}#tetMenuButton.tetTD{left:90% !important;top:0% !important}#tetMenuButton>svg{position:relative;max-width:100%;height:1.25em;fill:currentcolor;margin-right:12px;user-select:none;right:35% !important}#tetMenuButton,.tetAlertBtns,#tetReload,#tetReset{list-style:none;text-align:inherit;text-decoration:none;border-radius:15px;justify-content:center;display:flex !important;font-family:inherit;font-size:20px !important;font-weight:bold !important;padding:0px !important}button.tetBtn.mini{border:transparent !important;background:transparent !important}#tetMenuButton,.tetAlertBtns,#tetReload,#tetReset,#tet,.tet{cursor:pointer !important}.tet.tet-td{display:inherit}#tet{justify-items:center}input#apifield,#tetName,#tetSelector>select{padding-left:2% !important}#tetReload,#tetReset{margin:2% 25% 0px 25%}#apifield,#tetSelector{border-radius:4px;border-width:1px;margin:2% 6% 0px 6%}.r-demo{outline-style:none;margin:0px 32px 0px 32px !important;padding:12px 0px 12px 0px !important;overflow:hidden;-webkit-box-direction:normal;-webkit-box-orient:horizontal;-moz-box-direction:normal;-moz-box-orient:horizontal;flex-direction:row !important;flex-shrink:1;-webkit-box-flex:1;-moz-box-flex:1;flex-grow:1}.r-demo .tet-av{width:100%;margin-left:12px !important;margin-right:12px !important;-webkit-box-flex:0;flex-grow:0;flex-shrink:1;flex-basis:48px;-webkit-box-align:center;-moz-box-align:center;align-items:center;height:48px;overflow:hidden;border-radius:9999px;outline-style:none;display:block}.r-demo .tet-txt{flex-basis:0px;-webkit-box-flex:1;-moz-box-flex:1;flex-grow:1;-webkit-box-pack:center;-moz-box-pack:center;justify-content:center}.r-demo .tet-txt .txt-header{margin-bottom:2px;-moz-box-align:start;align-items:start;-moz-box-pack:justify;justify-content:space-between;-moz-box-direction:normal;-moz-box-orient:horizontal;flex-direction:row;max-width:100%}.r-demo .tet-txt .txt-header .tet-at{display:flex;margin-left:4px;color:#6e767d;font-weight:400;font-size:15px;line-height:20px;overflow-wrap:break-word;min-width:0px}#tetDemo{margin:4px 0px 0px 0px;line-height:16px;font-size:13px;flex-wrap:wrap;font-weight:400;min-width:0px;display:flex !important}.btNav{justify-content:center;flex-direction:row;top:0px}.btNav span{font-family:inherit}.btNav,.navbackground{position:fixed !important;width:100vw;height:100vh}.navbackground{top:0;left:0}.navbackground.warn{z-index:10 !important}.mini{min-height:3% !important;overflow:hidden;background:transparent;border-color:transparent}.r-hover{text-decoration-line:underline !important;outline-style:none !important}#tweet-text{font-size:23px !important;font-weight:400 !important;line-height:28px !important}`;

typeof GM === "undefined" ? (GM = {}, GM.setValue = GM_setValue, GM.getValue = GM_getValue) : false;
let tetInfo = {
  icon: GM_info.script.icon,
  name: GM_info.script.name,
  version: GM_info.script.version
},
tetAvatar = tetInfo.icon,
enableLogs = false;
tetInfo.name === "[Dev] Twitter External Translator" ? enableLogs = true : false;
const log = (msg, alert) => {
  return enableLogs || alert === "error" ? console.log('[TET]', msg) : false;
},
qs = (element, all) => {
  return !all ? document.querySelector(element) : document.querySelectorAll(element);
},
ael = (event, callback, elm = document) => {
  return elm.addEventListener(event, callback);
},
  injectCSS = (css, name = "common") => {
  return document.head.insertAdjacentHTML('beforeend', `<style id="tet-${name}">${css}</style>`);
},
  autoHide = async () => {
  await new Promise(resolve => setTimeout(resolve, 5000));
  $('svg#tetSVG').hide();
},
  TETObserve = (elm, callback, options = {
  subtree: true,
  childList: true
}) => {
  let observer = new MutationObserver(callback);
  callback([], observer);
  observer.observe(elm, options);
  return observer;
},
  TETSave = (key = "Config", value = JSON.stringify(TETConfig)) => {
  GM.setValue(key, value);
  localStorage.TETConfig = value;
},
  lh = document.location.host,
  lr = document.location.href,
  find = {
  twitter: lh === "twitter.com" || lh === "mobile.twitter.com",
  tweetdeck: lh === "tweetdeck.twitter.com",
  twitlonger: lh === "www.twitlonger.com",
  nitter: /nitter/.test(lr) || lh === "twitr.gq" || lh === "birdsite.xanny.family"
},
  TETInject = () => {
  find.twitter ? TETObserve(document.body, () => {
    Twitter();
  }) : find.tweetdeck ? TETObserve(document.body, () => {
    TweetDeck();
  }) : find.twitlonger ? ael("DOMContentLoaded", TwitLonger()) : find.nitter ? TETObserve(document.body, () => {
    Nitter();
  }) : false;
},
  isHTML = (str, doc = new DOMParser().parseFromString(str, "text/html")) => {
  return Array.from(doc.body.childNodes).some(node => node.nodeType === 1);
},
  icons = {
  azure: '<img class="exIcon" width="16" src=""/>',
  bing: '<img class="exIcon" width="16" src=""/>',
  deepl: '<img class="exIcon" width="16" src=""/>',
  gCloud: '<img class="exIcon" width="16" src=""/>',
  google: '<img class="exIcon" width="16" src=""/>',
  mymemory: '<img class="exIcon" width="16" src=""/>',
  translate: '<img class="exIcon" width="16" src=""/>',
  yandex: '<img class="exIcon" width="16" src=""/>',
  fn() {
    return {
      azure: this.azure,
      bing: this.bing,
      deepl: this.deepl,
      gCloud: this.gCloud,
      google: this.google,
      mymemory: this.mymemory,
      translate: this.translate,
      yandex: this.yandex
    };
  }

},
  defaultLang = $("html").attr("lang"),
  defaultTheme = () => {
  let b = $("body").attr("style"),
      twit = b === "background-color: #FFFFFF;" ? "#FFFFFF" : b === "background-color: #15202B;" ? "#15202B" : "#000000";
  return find.twitter ? twit : find.tweetdeck ? "tweetdeck" : find.nitter ? "nitter" : find.twitlonger ? "#FFFFFF" : "#000000";
},
  defaultDesc = "Pretend I'm a foreign language.";

let TETConfig = {},
en = {
  sel: `English (en)`,
  tw: `Translate with`,
  lg: `Language`,
  tr: `Translator`,
  ds: `Display`,
  menu: `Menu`,
  th: `Theme`,
  df: `Default`,
  di: `Dim`,
  lo: `Lights out`,
  col: `Color`,
  cb: `Blue`,
  cy: `Yellow`,
  cr: `Red`,
  cp: `Purple`,
  co: `Orange`,
  cg: `Green`,
  t: `Text`,
  i: `Icon`,
  ti: `Text + Icon`,
  res: `Restore to Defaults`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: `Full explanation found on GitHub.`,
    display: `Prefer text only? How about just an icon instead?`,
    color: `A rainbow of choices.`,
    theme: `It's best to match your current theme!`
  },
  quest: {
    head: `Are you sure?`,
    body: `Website will be reloaded.`,
    yes: `Yes`,
    no: `No`
  },
  fn: checkLng
},
    zh = {
  sel: `中文 (zh)`,
  tw: `翻译与`,
  lg: `语种`,
  tr: `译者`,
  ds: `显示`,
  ti: `文本+图标`,
  menu: `菜单`,
  th: `主题`,
  df: `默认情况下`,
  di: `凹陷`,
  lo: `熄灯`,
  col: `颜色`,
  cb: `蓝色`,
  cy: `黄色`,
  cr: `红色`,
  cp: `紫色`,
  co: `橙色`,
  cg: `绿色`,
  t: `案文`,
  i: `图标`,
  res: `恢复`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `你确定吗?`,
    body: `网站将被重新加载`,
    yes: `是的`,
    no: `不确定`
  },
  fn: checkLng
},
    bg = {
  sel: `Български (bg)`,
  tw: `Преведете с`,
  lg: `Език`,
  tr: `Преводач`,
  ds: `Показване на`,
  ti: `Текст + икона`,
  menu: `Меню`,
  th: `Тема`,
  df: `По подразбиране`,
  di: `Dim`,
  lo: `Изгасяне на осветлението`,
  col: `Цвят`,
  cb: `Синьо`,
  cy: `Жълто`,
  cr: `Червено`,
  cp: `Лилаво`,
  co: `Оранжево`,
  cg: `Зелено`,
  t: `Текст`,
  i: `Икона`,
  res: `Възстановявам`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Сигурни ли сте?`,
    body: `Уебсайтът ще бъде презареден.`,
    yes: `Да`,
    no: `Не`
  },
  fn: checkLng
},
    cs = {
  sel: `Česky (cs)`,
  tw: `Přeložit pomocí`,
  lg: `Jazyk`,
  tr: `Překladatel`,
  ds: `Zobrazit`,
  ti: `Text + ikona`,
  menu: `Nabídka`,
  th: `Téma`,
  df: `Výchozí`,
  di: `Dim`,
  lo: `Zhasnout světla`,
  col: `Barva`,
  cb: `Modrá`,
  cy: `Žlutá`,
  cr: `Červená`,
  cp: `Fialová`,
  co: `Oranžová`,
  cg: `Zelená`,
  t: `Text`,
  i: `Ikona`,
  res: `Obnovit`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Jste si jistý?`,
    body: `Webové stránky budou znovu načteny.`,
    yes: `Ano`,
    no: `Ne`
  },
  fn: checkLng
},
    da = {
  sel: `Dansk (da)`,
  tw: `Oversæt med`,
  lg: `Sprog`,
  tr: `Oversætter`,
  ds: `Vis`,
  ti: `Tekst + ikon`,
  menu: `Menu`,
  th: `Tema`,
  df: `Standard`,
  di: `Dim`,
  lo: `Lyset slukkes`,
  col: `Farve`,
  cb: `Blå`,
  cy: `Gul`,
  cr: `Rød`,
  cp: `Lilla`,
  co: `Orange`,
  cg: `Grøn`,
  t: `Tekst`,
  i: `Ikon`,
  res: `Genskabe`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Er du sikker?`,
    body: `Hjemmesiden vil blive genindlæst.`,
    yes: `Ja`,
    no: `Nej`
  },
  fn: checkLng
},
    et = {
  sel: `Eesti (et)`,
  tw: `Tõlge koos`,
  lg: `Keel`,
  tr: `Tõlkija`,
  ds: `Kuva`,
  ti: `Tekst + ikoon`,
  menu: `Menüü`,
  th: `Teema`,
  df: `Vaikimisi`,
  di: `Dim`,
  lo: `Valgus välja lülitatud`,
  col: `Värv`,
  cb: `Sinine`,
  cy: `Kollane`,
  cr: `Punane`,
  cp: `Lilla`,
  co: `Oranž`,
  cg: `Roheline`,
  t: `Tekst`,
  i: `Ikoon`,
  res: `Taastada`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Oled sa kindel?`,
    body: `Veebileht laaditakse uuesti.`,
    yes: `Jah`,
    no: `Ei`
  },
  fn: checkLng
},
    fi = {
  sel: `Suomalainen (fi)`,
  tw: `Käännä kanssa`,
  lg: `Kieli`,
  tr: `Kääntäjä`,
  ds: `Näytä`,
  ti: `Teksti + kuvake`,
  menu: `Valikko`,
  th: `Teema`,
  df: `Oletus`,
  di: `Dim`,
  lo: `Valot pois päältä`,
  col: `Väri`,
  cb: `Sininen`,
  cy: `Keltainen`,
  cr: `Punainen`,
  cp: `Violetti`,
  co: `Oranssi`,
  cg: `Vihreä`,
  t: `Teksti`,
  i: `Kuvake`,
  res: `Palauta`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Oletko varma?`,
    body: `Sivusto ladataan uudelleen.`,
    yes: `Kyllä`,
    no: `Ei`
  },
  fn: checkLng
},
    el = {
  sel: `Ελληνική (el)`,
  tw: `Μεταφράστε με`,
  lg: `Γλώσσα`,
  tr: `Μεταφραστής`,
  ds: `Εμφάνιση`,
  ti: `Κείμενο + εικονίδιο`,
  menu: `Μενού`,
  th: `Θέμα`,
  df: `Προεπιλογή`,
  di: `Dim`,
  lo: `Σβήνει τα φώτα`,
  col: `Χρώμα`,
  cb: `Μπλε`,
  cy: `Κίτρινο`,
  cr: `Κόκκινο`,
  cp: `Μωβ`,
  co: `Πορτοκαλί`,
  cg: `Πράσινο`,
  t: `Κείμενο`,
  i: `Εικονίδιο`,
  res: `Επαναφορά`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Είσαι σίγουρος;`,
    body: `Η ιστοσελίδα θα επαναφορτωθεί.`,
    yes: `Ναι`,
    no: `Όχι`
  },
  fn: checkLng
},
    hu = {
  sel: `Magyar (hu)`,
  tw: `Fordítson a`,
  lg: `Nyelv`,
  tr: `Fordító`,
  ds: `Megjelenítés`,
  ti: `Szöveg + ikon`,
  menu: `Menü`,
  th: `Téma`,
  df: `Alapértelmezett`,
  di: `Dim`,
  lo: `Fények kikapcsolva`,
  col: `Szín`,
  cb: `Kék`,
  cy: `Sárga`,
  cr: `Piros`,
  cp: `Lila`,
  co: `Narancs`,
  cg: `Zöld`,
  t: `Szöveg`,
  i: `Ikon`,
  res: `Visszaállítása`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Biztos vagy benne?`,
    body: `A weboldal újratöltődik.`,
    yes: `Igen`,
    no: `Nem`
  },
  fn: checkLng
},
    lv = {
  sel: `Latviešu (lv)`,
  tw: `Tulkot ar`,
  lg: `Valoda`,
  tr: `Tulkotājs`,
  ds: `Displejs`,
  ti: `Teksts + ikona`,
  menu: `Izvēlne`,
  th: `Tēma`,
  df: `Noklusējuma`,
  di: `Dim`,
  lo: `Izslēgt gaismu`,
  col: `Krāsa`,
  cb: `Zils`,
  cy: `Dzeltens`,
  cr: `Sarkans`,
  cp: `Violeta`,
  co: `Oranža`,
  cg: `Zaļš`,
  t: `Teksts`,
  i: `Ikona`,
  res: `Atjaunot`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Vai esat pārliecināts?`,
    body: `Tīmekļa vietne tiks ielādēta no jauna.`,
    yes: `Jā`,
    no: `Nē`
  },
  fn: checkLng
},
    lt = {
  sel: `Lietuvių kalba (lt)`,
  tw: `Išversti su`,
  lg: `Kalba`,
  tr: `Vertėjas`,
  ds: `Rodyti`,
  ti: `Tekstas + piktograma`,
  menu: `Meniu`,
  th: `Tema`,
  df: `Numatytoji`,
  di: `Dim`,
  lo: `Išjungti šviesą`,
  col: `Spalva`,
  cb: `Mėlyna`,
  cy: `Geltona`,
  cr: `Raudona`,
  cp: `Violetinė`,
  co: `Oranžinė`,
  cg: `Žalia`,
  t: `Tekstas`,
  i: `Ikona`,
  res: `Atkurti`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Ar tikrai?`,
    body: `Svetainė bus iš naujo įkelta.`,
    yes: `Taip`,
    no: `Ne`
  },
  fn: checkLng
},
    ro = {
  sel: `Românesc (ro)`,
  tw: `Tradu cu`,
  lg: `Limba`,
  tr: `Traducător`,
  ds: `Afișați`,
  ti: `Text + Icoană`,
  menu: `Meniu`,
  th: `Tema`,
  df: `Implicit`,
  di: `Dim`,
  lo: `Stinge lumina`,
  col: `Culoare`,
  cb: `Albastru`,
  cy: `Galben`,
  cr: `Roșu`,
  cp: `Violet`,
  co: `Portocaliu`,
  cg: `Verde`,
  t: `Text`,
  i: `Icoană`,
  res: `Restaurați`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Ești sigur?`,
    body: `Site-ul va fi reîncărcat.`,
    yes: `Da`,
    no: `Nu`
  },
  fn: checkLng
},
    sk = {
  sel: `Slovenská (sk)`,
  tw: `Preložiť s`,
  lg: `Jazyk`,
  tr: `Prekladateľ`,
  ds: `Zobraziť`,
  ti: `Text + ikona`,
  menu: `Ponuka`,
  th: `Téma`,
  df: `Predvolené nastavenie`,
  di: `Dim`,
  lo: `Zhasnuté svetlá`,
  col: `Farba`,
  cb: `Modrá`,
  cy: `Žltá`,
  cr: `Červená`,
  cp: `Fialová`,
  co: `Oranžová`,
  cg: `Zelená`,
  t: `Text`,
  i: `Ikona`,
  res: `Obnovenie`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Ste si istý?`,
    body: `Webová stránka bude znovu načítaná.`,
    yes: `Áno`,
    no: `Nie`
  },
  fn: checkLng
},
    sl = {
  sel: `Slovenski (sl)`,
  tw: `Prevedi z`,
  lg: `Jezik`,
  tr: `Prevajalec`,
  ds: `Prikaži`,
  ti: `Besedilo + ikona`,
  menu: `Meni`,
  th: `Tema`,
  df: `Privzeto`,
  di: `Dim`,
  lo: `Ugasne luči`,
  col: `Barva`,
  cb: `Modra`,
  cy: `Rumena`,
  cr: `Rdeča`,
  cp: `Vijolična`,
  co: `Oranžna`,
  cg: `Zelena`,
  t: `Besedilo`,
  i: `Ikona`,
  res: `Obnovitev`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Ste prepričani?`,
    body: `Spletna stran bo ponovno naložena.`,
    yes: `Da`,
    no: `Ne`
  },
  fn: checkLng
},
    sv = {
  sel: `Svenska (sv)`,
  tw: `Översätt med`,
  lg: `Språk`,
  tr: `Översättare`,
  ds: `Visa`,
  ti: `Text + ikon`,
  menu: `Meny`,
  th: `Tema`,
  df: `Standard`,
  di: `Dim`,
  lo: `Ljuset släcks`,
  col: `Färg`,
  cb: `Blå`,
  cy: `Gul`,
  cr: `Röd`,
  cp: `Lila`,
  co: `Orange`,
  cg: `Grön`,
  t: `Text`,
  i: `Ikon`,
  res: `Återställ`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Är du säker?`,
    body: `Webbplatsen kommer att laddas om.`,
    yes: `Ja`,
    no: `Nej`
  },
  fn: checkLng
},
    nl = {
  sel: `Nederlands (nl)`,
  tw: `Vertaal met`,
  lg: `Taal`,
  tr: `Vertaler`,
  ds: `Weergave`,
  ti: `Tekst + Pictogram`,
  menu: `Menu`,
  th: `Thema`,
  df: `Standaard`,
  di: `Dimmen`,
  lo: `Licht uit`,
  col: `Kleur`,
  cb: `Blauw`,
  cy: `Geel`,
  cr: `Rood`,
  cp: `Paars`,
  co: `Oranje`,
  cg: `Groen`,
  t: `Tekst`,
  i: `Icoon`,
  res: `Herstel`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Ben je zeker?`,
    body: `De website wordt opnieuw geladen.`,
    yes: `Ja`,
    no: `Nee`
  },
  fn: checkLng
},
    fr = {
  sel: `Français (fr)`,
  tw: `Traduire avec`,
  lg: `Langue`,
  tr: `Traducteur`,
  ds: `Afficher`,
  ti: `Texte + Icône`,
  menu: `Menu`,
  th: `Thème`,
  df: `Défaut`,
  di: `Dim`,
  lo: `Extinction des lumières`,
  col: `Couleur`,
  cb: `Bleu`,
  cy: `Jaune`,
  cr: `Rouge`,
  cp: `Violet`,
  co: `Orange`,
  cg: `Vert`,
  t: `Texte`,
  i: `Icône`,
  res: `Restaurer`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Vous êtes sûr ?`,
    body: `Le site web va être rechargé.`,
    yes: `Oui`,
    no: `Non`
  },
  fn: checkLng
},
    de = {
  sel: `Deutsch (de)`,
  tw: `Übersetzen mit`,
  lg: `Sprache`,
  tr: `Übersetzer`,
  ds: `Anzeige`,
  ti: `Text + Symbol`,
  menu: `Menü`,
  th: `Thema`,
  df: `Standard`,
  di: `Dimmen`,
  lo: `Licht aus`,
  col: `Farbe`,
  cb: `Blau`,
  cy: `Gelb`,
  cr: `Rot`,
  cp: `Lila`,
  co: `Orange`,
  cg: `Grün`,
  t: `Text`,
  i: `Icon`,
  res: `Wiederherstellen`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Sind Sie sicher?`,
    body: `Die Website wird neu geladen.`,
    yes: `Ja`,
    no: `Nein`
  },
  fn: checkLng
},
    it = {
  sel: `Italiano (it)`,
  tw: `Tradurre con`,
  lg: `Lingua`,
  tr: `Traduttore`,
  ds: `Visualizza`,
  ti: `Testo + icona`,
  menu: `Menu`,
  th: `Tema`,
  df: `Default`,
  di: `Dim`,
  lo: `Luci spente`,
  col: `Colore`,
  cb: `Blu`,
  cy: `Giallo`,
  cr: `Rosso`,
  cp: `Viola`,
  co: `Arancione`,
  cg: `Verde`,
  t: `Testo`,
  i: `Icona`,
  res: `Ripristinare`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Sei sicuro?`,
    body: `Il sito sarà ricaricato.`,
    yes: `Sì`,
    no: `No`
  },
  fn: checkLng
},
    ja = {
  sel: `日本語 (ja)`,
  tw: `で翻訳する`,
  lg: `言語`,
  tr: `翻訳者`,
  ds: `ディスプレイ`,
  ti: `テキスト+アイコン`,
  menu: `メニュー`,
  th: `テーマ`,
  df: `デフォルト`,
  di: `暗い`,
  lo: `消灯`,
  col: `カラー`,
  cb: `青`,
  cy: `黄`,
  cr: `赤`,
  cp: `紫`,
  co: `オレンジ`,
  cg: `グリーン`,
  t: `テキスト`,
  i: `アイコン`,
  res: `リストア`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `本当にいいの?`,
    body: `ウェブサイトが再読み込みされます。`,
    yes: `はい`,
    no: `いいえ`
  },
  fn: checkLng
},
    pl = {
  sel: `Polski (pl)`,
  tw: `Tłumaczenie za pomocą`,
  lg: `Język`,
  tr: `Tłumacz`,
  ds: `Wyświetlacz`,
  ti: `Tekst + Ikona`,
  menu: `Menu`,
  th: `Motyw`,
  df: `Domyślnie`,
  di: `Ściemniaj`,
  lo: `Nie świeci się`,
  col: `Kolor`,
  cb: `Niebieski`,
  cy: `Żółty`,
  cr: `Czerwony`,
  cp: `Purpurowy`,
  co: `Pomarańczowy`,
  cg: `Zielony`,
  t: `Tekst`,
  i: `Ikona`,
  res: `Przywróć`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Czy jesteś pewien?`,
    body: `Strona zostanie przeładowana.`,
    yes: `Tak`,
    no: `Nie`
  },
  fn: checkLng
},
    pt = {
  sel: `Português (pt)`,
  tw: `Traduzir com`,
  lg: `Idioma`,
  tr: `Tradutora`,
  ds: `Mostrar`,
  ti: `Texto + Ícone`,
  menu: `Menu`,
  th: `Tema`,
  df: `Por defeito`,
  di: `Dim`,
  lo: `Luzes apagadas`,
  col: `Cor`,
  cb: `Azul`,
  cy: `Amarelo`,
  cr: `Vermelho`,
  cp: `Púrpura`,
  co: `Laranja`,
  cg: `Verde`,
  t: `Texto`,
  i: `Ícone`,
  res: `Restaurar`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Tem a certeza?`,
    body: `O website será carregado de novo.`,
    yes: `Sim`,
    no: `Não`
  },
  fn: checkLng
},
  ru = {
  sel: `Russisch (ru)`,
  tw: `Перевод с`,
  lg: `Язык`,
  tr: `Переводчик`,
  ds: `Показать`,
  ti: `Текст + иконка`,
  menu: `Меню`,
  th: `Тема`,
  df: `По умолчанию`,
  di: `Приглушить`,
  lo: `Выключить свет`,
  col: `Цвет`,
  cb: `Синий`,
  cy: `Желтый`,
  cr: `Красный`,
  cp: `Фиолетовый`,
  co: `Оранжевый`,
  cg: `Зеленый`,
  t: `Текст`,
  i: `иконка`,
  res: `Восстановить`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `Вы уверены?`,
    body: `Сайт будет перезагружен.`,
    yes: `Да`,
    no: `Нет`
  },
  fn: checkLng
},
    es = {
  sel: `Español (es)`,
  tw: `Traducir con`,
  lg: `Idioma`,
  tr: `Traductor`,
  ds: `Mostrar`,
  ti: `Texto + Icono`,
  menu: `Menú`,
  th: `Tema`,
  df: `Por defecto`,
  di: `Atenuar`,
  lo: `Luces apagadas`,
  col: `Colores`,
  cb: `Azul`,
  cy: `Amarillo`,
  cr: `Rojo`,
  cp: `Púrpura`,
  co: `Naranja`,
  cg: `Verde`,
  t: `Texto`,
  i: `Icono`,
  res: `Restaurar`,
  desc: {
    language: `Site Language: ${defaultLang}`,
    translate: ` [WIP] Translate`,
    display: ` [WIP] Display`,
    color: ` [WIP] Color`,
    theme: ` [WIP] Theme`
  },
  quest: {
    head: `¿Está seguro?`,
    body: `El sitio web será recargado.`,
    yes: `Sí`,
    no: `No`
  },
  fn: checkLng
},
    //#endregion
DefaultConfig = {
  lang: defaultLang,
  translator: 'deepl',
  display: "text + icon",
  colors: "r-urgr8i",
  theme: defaultTheme(),
  api: {
    deepl: "",
    google: "",
    version: "api-free"
  },
  cBG: 'rgba(91, 112, 131, 0.4)',
  cColor: "r-p1n3y5 r-1bih22f",
  cDisplay: `DeepL ${icons.deepl}`,
  cHover: "r-1q3imqu",
  cLang: en.fn().tw,
  cText: "r-jwli3a",
  cTheme: "r-kemksi",
  cSub: "r-13gxpu9"
},
  sidebar = `<button title="Menu" id="tetMenuButton" class="mini tetDisplayColor css-901oao tetBtn" type="button">\n<svg viewBox="0 0 24 24" id="tetSVG" class="tetTextColor" width="15">\n<g>\n<path d="M12 2C6.486 2 2 6.486 2 12s4.486 10 10 10 10-4.486 10-10S17.514 2 12 2zm8.472 9.442c-.242.19-.472.368-.63.486-.68-1.265-1.002-1.78-1.256-2.007-.163-.145-.37-.223-.78-.375-.367-.136-1.482-.55-1.65-.85-.087-.153.136-.602.23-.793.088-.177.164-.33.196-.497.123-.646-.33-1.146-.728-1.59-.066-.072-.153-.17-.23-.26.335-.12.862-.26 1.42-.384 1.95 1.448 3.26 3.704 3.428 6.272zm-9.788-7.83c.076.25.145.5.182.678-.255.15-.663.363-.96.52-.262.136-.522.273-.738.392-.247.137-.442.234-.6.313-.347.174-.598.3-.833.553-.068.073-.26.278-1.02 1.886l-1.79-.656c1.293-1.94 3.362-3.31 5.76-3.685zM12 20.5c-4.687 0-8.5-3.813-8.5-8.5 0-1.197.25-2.335.7-3.37.47.182 1.713.66 2.75 1.035-.107.336-.245.854-.26 1.333-.03.855.502 1.7.562 1.792.053.08.12.15.2.207.303.21.687.5.827.616.063.343.166 1.26.23 1.833.144 1.266.175 1.48.24 1.65.005.012.514 1.188 1.315 1.188.576-.003.673-.206 1.855-2.688.244-.512.45-.95.513-1.058.1-.144.597-.61.87-.83.55-.442.76-1.82.413-2.682-.335-.83-1.92-2.08-2.5-2.195-.17-.033-.43-.04-.953-.053-.497-.01-1.25-.028-1.536-.09-.098-.024-.314-.094-.605-.196.32-.668.627-1.28.71-1.4.05-.052.168-.112.408-.234.17-.086.383-.192.653-.34.208-.116.458-.247.71-.38 1.168-.612 1.484-.8 1.658-1.082.11-.177.263-.44-.04-1.544 1.042.027 2.038.24 2.955.61-.89.32-1.024.595-1.106.77-.367.784.256 1.475.667 1.93.096.107.24.268.32.38l-.017.036c-.234.472-.67 1.35-.196 2.194.406.72 1.384 1.13 2.437 1.52.134.05.25.092.33.126.16.208.496.79 1 1.735l.154.285c.078.14.33.505.842.505.167 0 .363-.04.59-.137.032-.013.083-.035.18-.094C19.72 17.405 16.22 20.5 12 20.5zm-3.812-9.45c.01-.285.102-.646.184-.907l.027.006c.397.09 1.037.11 1.83.13.32.006.59.008.615 0 .326.143 1.355 1 1.483 1.31.113.28.05.812-.034 1.01-.233.197-.845.735-1.085 1.078-.093.13-.212.373-.64 1.274-.133.276-.313.654-.488 1.013-.026-.225-.054-.472-.08-.686-.225-2.003-.273-2.22-.42-2.445-.05-.078-.202-.31-1.135-.973-.117-.213-.268-.564-.26-.813z"></path>\n</g>\n</svg><span class="css-901oao css-16my406 r-bcqeeobuttontc0 r-jwli3a">Menu</span></button>\n<div role="dialog" tabindex="0" id="tetTW" class="btNav css-1dbjc4n r-1awozwy r-18u37iz r-1777fci r-ipm5af r-g6jmlv">\n<div class="navbackground rm"></div>\n<div class="tetAlert rm css-1dbjc4n">\n<div class="tetConfirmation tetBackground css-1dbjc4n">\n<h1 class="tetAlertTxt tetTextColor css-4rbku5 css-901oao"><span class="tet-alert-head css-901oao css-16my406">Are you sure?</span></h1>\n<div class="tetAlertTxt tetTextColor css-901oao"><span class="tet-alert-span css-901oao css-16my406">Website will be reloaded.</span></div>\n<div class="css-1dbjc4n">\n<div role="button" class="tetAlertBtns confirm css-18t94o4 css-1dbjc4n tetBtn" style="background-color:#eff3f4" data-testid="confirmationSheetConfirm">\n<div class="css-901oao" style="color:#0f1419"><span><span class="tet-confirm">Yes</span></span></div>\n</div>\n<div role="button" class="tetAlertBtns deny tetDisplayColor css-18t94o4 css-1dbjc4n tetBtn" data-testid="confirmationSheetCancel">\n<div class="css-901oao" style="color:#eff3f4"><span><span class="tet-deny">No</span></span></div>\n</div>\n</div>\n</div>\n</div>\n<div id="tetForm" class="rm css-1dbjc4n" aria-modal="true">\n<div class="tetBackground css-1dbjc4n r-16y2uox r-1wbh5a2">\n<div class="tetTextColor css-901oao tet-header">\n<span class="css-901oao">${tetInfo.name} Config</span>\n<span class="tetTextColor tet-info">v${tetInfo.version}</span>\n</div>\n<div class="css-1dbjc4n tet-main">\n<div class="demo-TW r-demo css-1dbjc4n">\n<div class="tet-av css-1dbjc4n">\n<div class="r-1adg3ll r-13qz1uu" style="padding-bottom:100%"></div>\n<div class="tetAvatarFrame">\n<div id="tetAvatar"></div>\n</div>\n</div>\n<div class="css-1dbjc4n tet-txt">\n<div class="css-1dbjc4n txt-header">\n<div class="css-1dbjc4n r-1awozwy r-18u37iz r-1wbh5a2 r-dnmrzs r-1ny4l3l">\n<div class="css-1dbjc4n r-1awozwy r-18u37iz r-dnmrzs">\n<div class="tetTextColor css-901oao css-bfa6kz r-1fmj7o5 r-1qd0xha r-a023e6 r-b88u0q r-rjixqe r-bcqeeo r-1udh08x r-3s2u2q r-qvutc0" dir="auto"><span class="css-901oao css-16my406"><span class="css-901oao css-16my406">${tetInfo.name}</span></span></div>\n</div>\n<div class="tet-at css-901oao css-bfa6kz" dir="ltr"><span class="css-901oao css-16my406">@for_lollipops</span></div>\n</div>\n</div>\n<div dir="auto" class="tetTextColor css-901oao r-1fmj7o5 r-1qd0xha r-a023e6 r-16dba41 r-rjixqe r-bcqeeo r-bnwqim r-qvutc0"><span class="css-901oao css-16my406 tet-demotext">${defaultDesc}</span></div>\n<div id="tetDemo" class="css-901oao" dir="auto" aria-expanded="false" role="button" tabindex="0">${TETConfig.cLang} ${TETConfig.cDisplay}</div>\n</div>\n</div>\n<div class="css-1dbjc4n tet-options">\n<div id="tetSelector" class="tetBackground css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Languages</span></div>\n<select id="languages" name="languages" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<option class="tetBackground" value="en">${en.sel}</option>\n<option class="tetBackground" value="es">${es.sel}</option>\n<option class="tetBackground" value="zh">${zh.sel}</option>\n<option class="tetBackground" value="bg">${bg.sel}</option>\n<option class="tetBackground" value="cs">${cs.sel}</option>\n<option class="tetBackground" value="da">${da.sel}</option>\n<option class="tetBackground" value="de">${de.sel}</option>\n<option class="tetBackground" value="el">${el.sel}</option>\n<option class="tetBackground" value="et">${et.sel}</option>\n<option class="tetBackground" value="fi">${fi.sel}</option>\n<option class="tetBackground" value="fr">${fr.sel}</option>\n<option class="tetBackground" value="hu">${hu.sel}</option>\n<option class="tetBackground" value="it">${it.sel}</option>\n<option class="tetBackground" value="ja">${ja.sel}</option>\n<option class="tetBackground" value="lv">${lv.sel}</option>\n<option class="tetBackground" value="lt">${lt.sel}</option>\n<option class="tetBackground" value="nl">${nl.sel}</option>\n<option class="tetBackground" value="pl">${pl.sel}</option>\n<option class="tetBackground" value="pt">${pt.sel}</option>\n<option class="tetBackground" value="ro">${ro.sel}</option>\n<option class="tetBackground" value="ru">${ru.sel}</option>\n<option class="tetBackground" value="sk">${sk.sel}</option>\n<option class="tetBackground" value="sl">${sl.sel}</option>\n<option class="tetBackground" value="sv">${sv.sel}</option>\n</select>\n</div>\n<div id="tetSelector" class="tetBackground css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Translators</span></div>\n<select id="translator" name="translator" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<optgroup class="tetBackground" label="External Translators">\n<option class="tetBackground" value="bing">Bing Translate</option>\n<option class="tetBackground" value="deepl">DeepL Translator</option>\n<option class="tetBackground" value="google">Google Translate</option>\n<option class="tetBackground" value="mymemory">MyMemory</option>\n<option class="tetBackground" value="translate">Translate.com</option>\n<option class="tetBackground" value="yandex">Yandex Translator</option>\n</optgroup>\n<optgroup class="tetBackground" label="Internal Translators">\n<option class="tetBackground" disabled="" value="bingIT">Azure Cognitive Services</option>\n<option class="tetBackground" value="deeplIT">DeepL API</option>\n<option class="tetBackground" value="googleIT">Google Cloud API</option>\n<option class="tetBackground" value="mymemoryIT">MyMemory API</option>\n<option class="tetBackground" disabled="" value="translateIT">Translate.com API</option>\n<option class="tetBackground" disabled="" value="yandexIT">Yandex Translator API</option>\n</optgroup>\n</select>\n</div>\n<div id="tetSelector" class="tetBackground css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Display</span></div>\n<select id="display" name="display" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<option class="tetBackground" value="text + icon">Text + Icon</option>\n<option class="tetBackground" value="text">Text Only</option>\n<option class="tetBackground" value="icon">Icon Only</option>\n</select>\n</div>\n<div id="tetSelector" class="tetBackground css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Color</span></div>\n<select id="colorselect" name="colorselect" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<optgroup class="tetBackground" label="Twitter">\n<option class="tetBackground" value="r-urgr8i">Blue</option>\n<option class="tetBackground" value="r-1vkxrha">Yellow</option>\n<option class="tetBackground" value="r-1dgebii">Red</option>\n<option class="tetBackground" value="r-168457u">Purple</option>\n<option class="tetBackground" value="r-18z3xeu">Orange</option>\n<option class="tetBackground" value="r-b5skir">Green</option>\n<optgroup class="tetBackground" label="Misc">\n<option class="tetBackground" value="tweetdeck">TweetDeck</option>\n<option class="tetBackground" value="nitter">Nitter</option>\n</optgroup>\n</select>\n</div>\n<div id="tetSelector" class="tetBackground css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Theme</span></div>\n<select id="theme" name="theme" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<optgroup class="tetBackground" label="Twitter">\n<option class="tetBackground" value="#FFFFFF">Default</option>\n<option class="tetBackground" value="#15202B">Dim</option>\n<option class="tetBackground" value="#000000">Lights out</option>\n</optgroup>\n<optgroup class="tetBackground" label="Misc">\n<option class="tetBackground" value="tweetdeck">TweetDeck</option>\n<option class="tetBackground" value="nitter">Nitter</option>\n</optgroup>\n</select>\n</div>\n<input id="apifield" type="password" name="apikey" placeholder="PASTE API KEY" class="tetTextColor tetBackground tetFields deepl css-1dbjc4n r-16xksha">\n<div id="tetSelector" class="tetBackground tetFields deepl css-1dbjc4n r-16xksha r-1kqtdi0">\n<div id="tetName" dir="auto" class="css-901oao r-1qd0xha r-n6v787 r-16dba41 r-1cwl3u0 r-bcqeeo r-1pn2ns4 r-tskmnb r-633pao r-u8s1d r-qvutc0"><span class="css-901oao">Version</span></div>\n<select id="api-version" name="api-version" class="tetTextColor r-30o5oe r-1niwhzg r-17gur6a r-1yadl64 r-1loqt21 r-1qd0xha r-a023e6 r-rjixqe r-crgep1 r-t60dpp r-1pn2ns4 r-ttdzmv">\n<option class="tetBackground" value="api-free">Free</option>\n<option class="tetBackground" value="api-pro">Pro</option>\n</select>\n</div>\n<input id="apifield" type="password" name="apikey" placeholder="PASTE API KEY" class="tetTextColor tetBackground tetFields google css-1dbjc4n r-16xksha">\n<input id="apifield" type="password" name="apikey" placeholder="PASTE API KEY" class="tetTextColor tetBackground tetFields bing css-1dbjc4n r-16xksha">\n</div>\n<button id="tetReset" class="tetDisplayColor css-901oao r-poiln3 r-jwli3a tetBtn" type="button">Defaults</button>\n</div>\n</div>\n</div>\n</div>`,
  get = (url, responseType = 'json', retry = 3) => new Promise((resolve, reject) => {
  try {
    GM_xmlhttpRequest({
      method: 'GET',
      url,
      responseType,
      onerror: e => {
        retry === 0 ? reject(e) : (log('Network error, retry.'), setTimeout(() => {
          resolve(get(url, responseType, retry - 1));
        }, 1000));
      },
      onload: ({
        status,
        response
      }) => {
        status === 200 ? resolve(response) : retry === 0 ? reject(`${status} ${url}`) : (log(status, url), setTimeout(() => {
          resolve(get(url, responseType, retry - 1));
        }, 500));
      }
    });
  } catch (error) {
    reject(error);
  }
}),
    tetEach = (elm, context, callback) => {
  for (let i = 0; i < elm.length; i++) {
    if (!callback) {
      elm.addClass(context);
    } else {
      ael("mouseenter", callback, elm[i]);
      ael("mouseleave", callback, elm[i]);
    }

    ;
  }

  ;
}; //#endregion
//#region Site n Menu Fn


function checkLng() {
  return {
    tw: this.tw,
    lg: this.lg,
    tr: this.tr,
    ds: this.ds,
    ti: this.ti,
    res: this.res,
    menu: this.menu,
    th: this.th,
    df: this.df,
    di: this.di,
    lo: this.lo,
    col: this.col,
    cb: this.cb,
    cy: this.cy,
    cr: this.cr,
    cp: this.cp,
    co: this.co,
    cg: this.cg,
    t: this.t,
    i: this.i,
    language: this.desc.language,
    translate: this.desc.translate,
    display: this.desc.display,
    color: this.desc.color,
    theme: this.desc.theme,
    head: this.quest.head,
    body: this.quest.body,
    yes: this.quest.yes,
    no: this.quest.no
  };
};

function TETDisplayChange(mode = "nonrepeat") {
  let cSel = TETConfig.translator,
  v = icons.fn(),
  disA = cSel == "bingIT" ? TETConfig.cDisplay = v.azure : cSel == "googleIT" ? TETConfig.cDisplay = v.gCloud : cSel == "google" ? TETConfig.cDisplay = v.google : cSel == "bing" ? TETConfig.cDisplay = v.bing : cSel == "mymemory" || cSel == "mymemoryIT" ? TETConfig.cDisplay = v.mymemory : cSel == "translate" ? TETConfig.cDisplay = v.translate : cSel == "yandex" ? TETConfig.cDisplay = v.yandex : TETConfig.cDisplay = v.deepl,
  disB = cSel == "mymemoryIT" ? TETConfig.cDisplay = "MyMemory API" : cSel == "bingIT" ? TETConfig.cDisplay = "Azure Cognitive Services" : cSel == "googleIT" ? TETConfig.cDisplay = "Google Cloud API" : cSel == "deeplIT" ? TETConfig.cDisplay = "DeepL API" : cSel == "bing" ? TETConfig.cDisplay = "Bing" : cSel == "google" ? TETConfig.cDisplay = "Google" : cSel == "mymemory" ? TETConfig.cDisplay = "MyMemory" : cSel == "translate" ? TETConfig.cDisplay = "Translate.com" : cSel == "yandex" ? TETConfig.cDisplay = "Yandex" : TETConfig.cDisplay = "DeepL",
  disC = cSel == "mymemoryIT" ? TETConfig.cDisplay = `MyMemory API ${v.mymemory}` : cSel == "bingIT" ? TETConfig.cDisplay = `Azure Cognitive Services ${v.azure}` : cSel == "googleIT" ? TETConfig.cDisplay = `Google Cloud API ${v.gCloud}` : cSel == "deeplIT" ? TETConfig.cDisplay = `DeepL API ${v.deepl}` : cSel == "bing" ? TETConfig.cDisplay = `Bing ${v.bing}` : cSel == "google" ? TETConfig.cDisplay = `Google ${v.google}` : cSel == "mymemory" ? TETConfig.cDisplay = `MyMemory ${v.mymemory}` : cSel == "translate" ? TETConfig.cDisplay = `Translate.com ${v.translate}` : cSel == "yandex" ? TETConfig.cDisplay = `Yandex ${v.yandex}` : TETConfig.cDisplay = `DeepL ${v.deepl}`;
  TETConfig.cDisplay = TETConfig.display == "icon" ? disA : TETConfig.display == "text" ? disB : TETConfig.display == "text + icon" ? disC : log("Fuck Error", "error");
  return mode == "demo" ? $('#tetDemo').html(`${TETConfig.cLang} ${TETConfig.cDisplay}`) : false;
}

;

function site(btLang, content) {
  return TETConfig.translator == 'yandex' ? `https://translate.yandex.com/?lang=${btLang}-${TETConfig.lang}&text=${content}` : TETConfig.translator == 'bing' ? `https://www.bing.com/translator/?text=${content}&from=${btLang}&to=${TETConfig.lang}` : TETConfig.translator == 'google' ? `https://translate.google.com/?q=${content}&sl=${btLang}&tl=${TETConfig.lang}` : TETConfig.translator == 'mymemory' ? `https://mymemory.translated.net/${TETConfig.lang}/${btLang}/${TETConfig.lang}/${content}` : TETConfig.translator == 'translate' ? `https://www.translate.com/machine-translation#${btLang}/${TETConfig.lang}/${content}` : `https://www.deepl.com/translator#${btLang}/${TETConfig.lang}/${content}`;
}

;

function TETBtnClick(source, btLang, content, mode) {
  mode = mode ?? "append";
  btLang = btLang ?? "auto";
  let tetBtn = $(`<div class="tet ${TETConfig.cSub} css-901oao" dir="auto" aria-expanded="false" role="button" tabindex="0">${TETConfig.cLang} ${TETConfig.cDisplay}</div>`);
  mode === "append" ? tetBtn.appendTo(source) : mode === "prepend" ? tetBtn.prependTo(source) : mode === "td" ? source.after(tetBtn) : tetBtn.prependTo(mode);
  tetBtn.on("click", async e => {
    e.preventDefault();
    let vCheck = TETConfig.api.version == "api-pro" ? 'api' : 'api-free';
    TETConfig.translator == 'mymemoryIT' ? get(`https://api.mymemory.translated.net/get?q=${content}&langpair=${btLang}|${TETConfig.lang}`).then(r => {
      let res = r.responseData.translatedText,
          inlineText = $(`<div class="css-1dbjc4n r-14gqq1x"><div dir="auto" class="css-901oao r-1fmj7o5 r-1qd0xha r-bnwqim" id="tweet-text"><span class="css-901oao r-poiln3">${res}</span></div></div>`);
      inlineText.appendTo(source);
    }) : TETConfig.translator == 'googleIT' ? get(`https://translation.googleapis.com/language/translate/v2?q=${content}&target=${TETConfig.lang}&source=${btLang}&key=${TETConfig.api.google}`).then(r => {
      let res = r.data.translations[0],
          inlineText = $(`<div class="css-1dbjc4n r-14gqq1x"><div dir="auto" class="css-901oao r-1fmj7o5 r-1qd0xha r-bnwqim" id="tweet-text"><span class="css-901oao r-poiln3">${res.translatedText}</span></div></div>`);
      inlineText.appendTo(source);
    }) : TETConfig.translator == 'deeplIT' ? get(`https://${vCheck}.deepl.com/v2/translate?auth_key=${TETConfig.api.deepl}&text=${content}&target_lang=${TETConfig.lang}`).then(r => {
      let res = r.translations[0],
          inlineText = $(`<div class="css-1dbjc4n r-14gqq1x"><div dir="auto" class="css-901oao r-1fmj7o5 r-1qd0xha r-bnwqim" id="tweet-text"><span class="css-901oao r-poiln3">${res.text}</span></div></div>`);
      inlineText.appendTo(source);
    }) : window.open(site(btLang, content), '_blank');
  });
  tetBtn.hover(function () {
    $(this).toggleClass("r-hover");
  }, function () {
    $(this).toggleClass("r-hover");
  });
  TETDisplayChange();
}

;

function Twitter(btContainer, content = '') {
  let translateTweet = $("div[lang]").eq(0).siblings().eq(0).children("span"),
  translateBio = $('div[data-testid="UserDescription"]').eq(0).siblings().eq(0).children("span"),
  source = translateTweet.parent().parent(),
      loggout = document.cookie.includes("twid"),
      tweetbtn = (user = "loggedin") => {
    user === "logout" ? (
    btContainer = $("div[lang]").eq(0), source = btContainer.parent()) : (btContainer = translateTweet.parent().siblings().eq(0), source = translateTweet.parent().parent());
    btContainer.children("span").each((index, item) => {
      let tweet = $(item).html().trim();
      tweet && tweet != '' && !isHTML(tweet) ? content += tweet : false;
    });
    TETBtnClick(source, btContainer.attr("lang"), content);
  },
    biobtn = (user = "loggedin") => {
    user === "logout" ? (
    btContainer = $('div[data-testid="UserDescription"]').eq(0), source = $('div[data-testid="UserDescription"]').eq(0).parent()) : (btContainer = translateBio.parent().siblings().eq(0), source = translateBio.parent().parent());
    btContainer.children("span").each((index, item) => {
      let bio = $(item).html().trim();
      bio && bio != '' && !isHTML(bio) ? content += bio : false;
    });
    TETBtnClick(source, "auto", content);
  },
      checker = () => {
    if (!$('.tet').length) {
      return translateBio.length ? biobtn() : $('div[data-testid="UserDescription"]').length && !loggout ? biobtn("logout") : translateTweet.length ? tweetbtn() : !translateTweet.length && !loggout && $("div[lang]").attr("lang") !== TETConfig.lang ? tweetbtn("logout") : false;
    }

    ;
  };

  /login/.test(window.location.href) || /profile/.test(window.location.href) || /keyboard_shortcuts/.test(window.location.href) || /display/.test(window.location.href) || /video/.test(window.location.href) || /photo/.test(window.location.href) || /compose/.test(window.location.href) ? $('#tetMenuButton').attr('style', 'z-index: -1 !important;') : $('#tetMenuButton').attr('style', '');
  return checker();
}

;

function TweetDeck(btContainer) {
  let translateTweet = $('a.js-translate-call-to-action'),
      tweetbtn = () => {
    btContainer = translateTweet.siblings().eq(2),
    TETBtnClick(translateTweet, $('p.js-tweet-text[lang]').attr("lang"), btContainer.text(), "td");
  },
      checker = () => {
    !$('.tet').length ? $('div.prf-header').length ? TETBtnClick($('p.prf-bio').parent(), "auto", $('p.prf-bio').text()) : translateTweet.length ? tweetbtn() : $('.tet').attr('style', 'display: flex !important; align-items: end !important;') : false;
  };

  return checker();
}

;

function Nitter() {
  let trTweet = $('#m > div > div > div.tweet-content.media-body'),
      trBio = $('div.profile-bio > p');
  return !$('.tet').length ? trTweet.length ? TETBtnClick(trTweet, "auto", trTweet.text(), $(".conversation")) : trBio.length ? TETBtnClick(trBio.parent(), "auto", trBio.text()) : false : false;
}

;

function TwitLonger() {
  let content = $('p#posttext').text(),
      source = $('.actions.text-right');
  return !$(".tet").length && source.length ? TETBtnClick(source, "auto", content, "prepend") : false;
}

;

function Menu() {
  try {
    log("Menu init");
    let nav = $('.navbackground'),
        menuBtn = $('button#tetMenuButton'),
        selLG = qs('select#languages'),
        selCS = qs('select#colorselect'),
        selTH = qs('select#theme'),
        selTR = qs('select#translator'),
        selDS = qs('select#display'),
        dlAPI = qs('input.deepl'),
        goAPI = qs('input.google'),
        selAPI = qs('select#api-version'),
        dColor = $(".tetDisplayColor"),
        tColor = $(".tetTextColor"),
        tBG = $(".tetBackground"),
        tDesc = $(".tet-demotext"),
        v = en.fn();
    selLG.value = TETConfig.lang;
    selCS.value = TETConfig.colors;
    selTH.value = TETConfig.theme;
    selTR.value = TETConfig.translator;
    selDS.value = TETConfig.display;
    dlAPI.value = TETConfig.api.deepl ?? "";
    goAPI.value = TETConfig.api.google ?? "";
    selAPI.value = TETConfig.api.version;

    const TETLanguageChange = () => {
      let TETSel = selLG.value;
      TETSel == "en" ?? defaultLang == "en-US" ? v = en.fn() : TETSel == "bg" ? v = bg.fn() : TETSel == "cs" ? v = cs.fn() : TETSel == "da" ? v = da.fn() : TETSel == "et" ? v = et.fn() : TETSel == "fi" ? v = fi.fn() : TETSel == "el" ? v = el.fn() : TETSel == "hu" ? v = hu.fn() : TETSel == "lv" ? v = lv.fn() : TETSel == "lt" ? v = lt.fn() : TETSel == "ro" ? v = ro.fn() : TETSel == "sk" ? v = sk.fn() : TETSel == "sl" ? v = sl.fn() : TETSel == "sv" ? v = sv.fn() : TETSel == "zh" ?? defaultLang == "zh-TW" ?? defaultLang == "zh-CN" ?? defaultLang == "zh-Hant" ? v = zh.fn() : TETSel == "nl" ? v = nl.fn() : TETSel == "fr" ? v = fr.fn() : TETSel == "de" ? v = de.fn() : TETSel == "it" ? v = it.fn() : TETSel == "ja" ? v = ja.fn() : TETSel == "pl" ? v = pl.fn() : TETSel == "pt" ? v = pt.fn() : TETSel == "ru" ? v = ru.fn() : TETSel == "es" ? v = es.fn() : (v = en.fn(), TETSel = "en");
      TETConfig.cLang = v.tw;
      $('button#tetMenuButton').attr('title', v.menu);
      $('button#tetMenuButton > span').text(v.menu);
      $('select#languages').siblings().children("span").text(v.lg);
      $('select#translator').siblings().children("span").text(v.tr);
      $('select#display').siblings().children("span").text(v.ds);
      $('select#theme').siblings().children("span").text(v.th);
      $('option[value="#FFFFFF"]').text(v.df);
      $('option[value="#15202B"]').text(v.di);
      $('option[value="#000000"]').text(v.lo);
      $('select#colorselect').siblings().children("span").text(v.col);
      $('option[value="r-urgr8i"]').text(v.cb);
      $('option[value="r-1vkxrha"]').text(v.cy);
      $('option[value="r-1dgebii"]').text(v.cr);
      $('option[value="r-168457u"]').text(v.cp);
      $('option[value="r-18z3xeu"]').text(v.co);
      $('option[value="r-b5skir"]').text(v.cg);
      $('option[value="text + icon"]').text(v.ti);
      $('option[value="text"]').text(v.t);
      $('option[value="icon"]').text(v.i);
      $('button#tetReset').text(v.res);
      $('.tet-alert-head').text(v.head);
      $('.tet-alert-span').text(v.body);
      $('.tet-confirm').text(v.yes);
      $('.tet-deny').text(v.no);

      TETDisplayChange("demo");
    },
          TETMenuUpdate = (cSel, type) => {
      if (type === "theme") {
        return cSel == "#FFFFFF" ? (TETConfig.cBG = "rgba(0, 0, 0, 0.4)", TETConfig.cTheme = "r-14lw9ot", TETConfig.cText = "r-18jsvk2") : cSel == "#15202B" ? TETConfig.cTheme = "r-yfoy6g" : cSel == "nitter" ? (TETConfig.cBG = "rgba(0, 0, 0, 0.4)", TETConfig.cTheme = "nitter", TETConfig.cText = "tetNTextColor") : cSel == "tweetdeck" ? (TETConfig.cBG = "rgba(0, 0, 0, 0.4)", TETConfig.cTheme = "r-tetTD", TETConfig.cText = "r-jwli3a") : TETConfig.cTheme = "r-kemksi";
      } else if (type === "colors") {
        return cSel == "r-urgr8i" ? (TETConfig.cHover = "r-1q3imqu", TETConfig.cColor = "r-p1n3y5 r-1bih22f", TETConfig.cSub = "r-13gxpu9") : cSel == "nitter" ? (TETConfig.cHover = "tetNitterHover", TETConfig.cColor = "tetNitter", TETConfig.cSub = "tetNText") : cSel == "tweetdeck" ? (TETConfig.cHover = "r-hoverTD", TETConfig.cColor = "Button--primary", TETConfig.cSub = "tet-td") : cSel == "r-1vkxrha" ? (TETConfig.cHover = "r-1kplyi6", TETConfig.cColor = "r-v6khid r-cdj8wb", TETConfig.cSub = "r-61mi1v") : cSel == "r-1dgebii" ? (TETConfig.cHover = "r-1ucxkr8", TETConfig.cColor = "r-1iofnty r-jd07pc", TETConfig.cSub = "r-daml9f") : cSel == "r-168457u" ? (TETConfig.cHover = "r-njt2r9", TETConfig.cColor = "r-hy56xe r-11mmphe", TETConfig.cSub = "r-xfsgu1") : cSel == "r-18z3xeu" ? (TETConfig.cHover = "r-1kplyi6", TETConfig.cColor = "r-1xl5njo r-b8m25f", TETConfig.cSub = "r-1qkqhnw") : cSel == "r-b5skir" ? (TETConfig.cHover = "r-zx61xx", TETConfig.cColor = "r-5ctkeg r-1cqwhho", TETConfig.cSub = "r-nw8l94") : (TETConfig.cHover = "r-1q3imqu", TETConfig.cColor = "r-p1n3y5 r-1bih22f", TETConfig.cSub = "r-13gxpu9");
      } else if (type == "translator") {
        return cSel == "bingIT" ? ($('.google').hide(), $('.bing').show(), $('.deepl').hide()) : cSel == "googleIT" ? ($('.google').show(), $('.bing').hide(), $('.deepl').hide()) : cSel == "deeplIT" ? ($('.deepl').show(), $('.google').hide(), $('.bing').hide()) : $('.tetFields').hide();
      }
    };


    TETConfig.theme == "nitter" ? $('.r-demo').toggleClass('demo-TW').toggleClass('demo-NT') : TETConfig.theme == "tweetdeck" ? $('.r-demo').toggleClass('demo-TW').toggleClass('demo-TD') : false;

    if (find.nitter) {
      injectCSS(twCSS, "foreign");
      $('div.btNav').attr("id", "tetNT");
      tetAvatar = $(`link[rel="icon"]`).attr("href");
      $('#tetAvatar').attr('style', `background-image: url(${tetAvatar}) !important;`);
    } else if (find.tweetdeck) {
      injectCSS(twCSS, "foreign");
      $('#tetMenuButton').toggleClass("tetTD");
      tetAvatar = $(`link[rel="shortcut icon"]`).attr("href");
      $('#tetAvatar').attr('style', `background-image: url(${tetAvatar}) !important;`);
    } else if (find.twitlonger) {
      injectCSS(twCSS, "foreign");
      tetAvatar = $(`link[rel="shortcut icon"]`).attr("href");
      $('#tetAvatar').attr('style', `background-image: url(${tetAvatar}) !important;`);
    }

    ;

    nav.attr("style", `background-color:${TETConfig.cBG}`);
    tetEach(tBG, TETConfig.cTheme);
    tetEach(tColor, TETConfig.cText);
    tetEach(dColor, TETConfig.colors);
    tetEach($('#tetDemo'), TETConfig.cSub);
    tBG.toggleClass(TETConfig.cTheme);
    tColor.toggleClass(TETConfig.cText);
    TETMenuUpdate(selTH.value, "theme");
    tBG.toggleClass(TETConfig.cTheme);
    tColor.toggleClass(TETConfig.cText);
    TETMenuUpdate(selTR.value, "translator");
    log("Menu functions");
    tetEach(qs('div#tetSelector', true), false, e => {
      $(e.target).toggleClass(`${TETConfig.cColor} r-1kqtdi0`).children("div#tetName").toggleClass(`${TETConfig.cSub}`);
    });
    ael("click", e => {
      !$('.tetAlert.rm').length ? $('.tetAlert').toggleClass("rm") : false;
      $('html').toggleClass('tetFreeze');
      $('#tetForm').toggleClass("rm");
      $('.btNav').attr('style', 'z-index: -1 !important;');
      $('svg#tetSVG').show();
      menuBtn.attr("style", "");
      menuBtn.toggleClass("mini");
      $('#tetDemo').toggleClass("rm");
      $(e.target).removeClass("warn").toggleClass("rm");
      selLG.value !== "en" ?? defaultLang !== "en" ?? defaultLang !== "en-US" ? tDesc.text("Hey look, I'm a foreign language!") : tDesc.text(defaultDesc);
      TETConfig.api.google = goAPI.value;
      TETConfig.api.deepl = dlAPI.value;
      TETSave();
      autoHide();
    }, qs('.navbackground'));
    ael("click", () => {
      nav.toggleClass("rm");
      $('#tetForm').toggleClass("rm");
      $('.btNav').attr('style', 'z-index: 10000 !important');
      menuBtn.attr("style", "display: none !important;").toggleClass("mini");
      $('html').toggleClass('tetFreeze');
    }, qs("button#tetMenuButton"));
    ael("mouseenter", () => {
      menuBtn.toggleClass(TETConfig.cHover).toggleClass(TETConfig.colors);
      $('svg#tetSVG').hide();
      menuBtn.toggleClass("mini");
    }, qs("button#tetMenuButton"));
    ael("mouseleave", () => {
      menuBtn.toggleClass(TETConfig.cHover).toggleClass(TETConfig.colors);
      $('svg#tetSVG').show();
      menuBtn.toggleClass("mini");
      autoHide();
    }, qs("button#tetMenuButton"));
    ael("change", e => {
      let cSel = e.target.value;
      tBG.toggleClass(TETConfig.cTheme);
      tColor.toggleClass(TETConfig.cText);
      TETConfig.cText = "r-jwli3a";
      TETConfig.cBG = "rgba(91, 112, 131, 0.4)";
      TETMenuUpdate(cSel, "theme");
      TETConfig.theme = cSel;
      tBG.toggleClass(TETConfig.cTheme);
      tColor.toggleClass(TETConfig.cText);
    }, selTH);
    ael("change", e => {
      let cSel = e.target.value;
      dColor.toggleClass(TETConfig.colors);
      $('#tetDemo').toggleClass(TETConfig.cSub);
      $('.tet').toggleClass(TETConfig.cSub);
      TETMenuUpdate(cSel, "colors");
      TETConfig.colors = cSel;
      $('.tet').toggleClass(TETConfig.cSub);
      $('#tetDemo').toggleClass(TETConfig.cSub);
      dColor.toggleClass(TETConfig.colors);
    }, selCS);
    ael("change", e => {
      TETLanguageChange();
      TETConfig.lang = e.target.value;
    }, selLG);
    ael("change", e => {
      let cSel = e.target.value;
      TETConfig.translator = cSel;
      TETMenuUpdate(cSel, "translator");
      TETDisplayChange("demo");
    }, selTR);
    ael("change", e => {
      TETConfig.display = e.target.value;
      TETDisplayChange("demo");
    }, selDS);
    ael("change", e => {
      TETConfig.api.google = goAPI.value;
      TETConfig.api.deepl = dlAPI.value;
      TETConfig.api.version = e.target.value;
    }, selAPI);
    ael("click", () => {
      tDesc.text(v.theme);
    }, selTH);
    ael("click", () => {
      tDesc.text(v.color);
    }, selCS);
    ael("click", () => {
      tDesc.text(v.language);
    }, selLG);
    ael("click", () => {
      tDesc.text(v.translate);
    }, selTR);
    ael("click", () => {
      tDesc.text(v.display);
    }, selDS);
    ael("click", () => {
      $('.tetAlert').toggleClass("rm");
      nav.toggleClass("warn");
    }, qs('button#tetReset'));
    ael("click", () => {
      TETConfig = DefaultConfig;
      TETSave();
      setTimeout(() => window.location.reload(), 200);
    }, qs('.tetAlertBtns.confirm'));
    ael("click", () => {
      $('.tetAlert').toggleClass("rm");
      nav.removeClass("warn");
    }, qs('.tetAlertBtns.deny'));
    log("Checking for language changes");
    TETConfig.lang !== DefaultConfig.lang || TETConfig.lang !== "en" || TETConfig.lang !== "en-US" ? TETLanguageChange() : false;
    autoHide();
  } catch (e) {
    log(e, "error");
    TETConfig = DefaultConfig;
    TETSave();
  }
}

;

await Promise.all([GM.getValue("Config")]).then(data => {
  if (lh === "tweetdeck.twitter.com" && !document.cookie.includes("twid")) {
    log("Must be login!!! Canceling...", "error");
    return;
  }

  ;
  let res = data[0];
  res || TETConfig === DefaultConfig ? () => {
    try {
      TETConfig = JSON.parse(res);
    } catch (e) {
      log(e, "error");
      TETConfig = res;
    }
  } : (TETConfig = DefaultConfig, log("First time init."));
  const localData = localStorage.TETConfig;
  localData && localData.length > 0 ? TETConfig = JSON.parse(localData) : false;

  for (let key in DefaultConfig) {
    typeof TETConfig[key] ?? (TETConfig[key] = DefaultConfig[key]);
  }

  log("Config Loaded");
  injectCSS(tetCSS);
  let body = $("body");
  body.prepend(sidebar);
  Menu();
  log("Starting TET Injection");
  TETInject();
}).catch(e => {
  TETConfig = DefaultConfig;
  log(e, "error");
});
})();