Greasy Fork

Greasy Fork is available in English.

Мовний щит: переклад результатів пошуку

Визначає результати пошуку москальською мовою. Коли знаходить, то робить їх сірими. Якщо біля результату пошуку є посилання "Перекласти цю сторінку", то підсвічує її для кращої видимості. Попередження! Для того, щоб коректно відображалось це посилання "Перекласти цю сторінку" і переклад був саме на українську, знадобиться зробити правильні налаштування в інших місцях: налаштування пошуку гугл (на сторінці https://www.google.com/preferences?hl=uk&lang=1), можливо також мова браузера і облікового запису гугл.

目前为 2025-05-07 提交的版本,查看 最新版本

// ==UserScript==
// @name         Мовний щит: переклад результатів пошуку
// @namespace    https://constantine-ketskalo.azurewebsites.net/uk/
// @version      1.3
// @description  Визначає результати пошуку москальською мовою. Коли знаходить, то робить їх сірими. Якщо біля результату пошуку є посилання "Перекласти цю сторінку", то підсвічує її для кращої видимості. Попередження! Для того, щоб коректно відображалось це посилання "Перекласти цю сторінку" і переклад був саме на українську, знадобиться зробити правильні налаштування в інших місцях: налаштування пошуку гугл (на сторінці https://www.google.com/preferences?hl=uk&lang=1), можливо також мова браузера і облікового запису гугл.
// @author       Constantine Ketskalo
// @match        http*://www.google.com/search*
// @include      http*://www.google.com.*/search*
// @icon         
// @icon64       
// @run-at       document-end
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // 1. Унікальні москальські літери
    const moskalUniqueLetters = ['ы', 'э', 'ё', 'ъ'];

    // 2. Часті москальські слова без унікальних літер
    const moskalCommonWords = ['и', 'что', 'как', 'да', 'нет', 'она', 'они', 'из', 'с', 'к', 'года', 'также', 'или', 'будет', 'время', 'их', 'после', 'есть', 'более', 'только', 'еще', 'всегда', 'может', 'если', 'тогда', 'где', 'когда', 'здесь'];

    const ismoskalDomain = (url) => {
        const hostname = new URL(url).hostname.toLowerCase();

        return hostname.endsWith('.ru') ||
                hostname.startsWith('ru.') ||
                url.includes('/ru/')
    };

    const ismoskalText = (text) => {
        text = text.toLowerCase();

        if (!text) {
            return false;
        }

        for (const letter of moskalUniqueLetters) {
            if (text.includes(letter)) {
                return true;
            }
        }

        for (const word of text.split(' ')) {
            if (moskalCommonWords.includes(word)) {
                return true;
            }
        }

        return false;
    }

    const formatStylesForSearchResult = (result) => {
        const mainLinkElement = result.querySelector('a:not([hreftranslate])');
        const translatedLinkElement = result.querySelector('a[hreftranslate]');
        const contentElement = result.querySelector('div.VwiC3b');

        for (const element of [mainLinkElement, contentElement]) {
            element.style.color = 'gray';
            element.style.textDecoration = 'line-through';
            element.style.opacity = '0.5';
        }

        if (translatedLinkElement && translatedLinkElement.getAttribute('hreftranslate') === 'uk') {
            translatedLinkElement.style.fontWeight = 'bold';
        }
    }

    const redirectClickToTranslateLink = (result) => {
        const mainLinkElement = result.querySelector('a:not([hreftranslate])');
        const translatedLinkElement = result.querySelector('a[hreftranslate]');

        let translateUrl = '/';
        let ping = null;
        if (translatedLinkElement && translatedLinkElement.getAttribute('hreftranslate') === 'uk') {
            translateUrl = translatedLinkElement.getAttribute('href');
            ping = translatedLinkElement.getAttribute('ping');
        } else {
            translateUrl = `https://translate.google.com/translate?hl=uk&sl=ru&tl=uk&u=${encodeURIComponent(mainLinkElement.href)}`;
        }

        mainLinkElement.setAttribute('href', translateUrl);
        mainLinkElement.setAttribute('hreftranslate', 'uk');
        if (ping) {
            mainLinkElement.setAttribute('ping', ping);
        }
    }

    const searchResults = document.querySelectorAll('div.MjjYud');

    for (const result of searchResults) {
        const mainLinkElement = result.querySelector('a:not([hreftranslate])');
        const text = result.innerText;

        if (mainLinkElement && ismoskalDomain(mainLinkElement.href) || ismoskalText(text)) {
            formatStylesForSearchResult(result);
            redirectClickToTranslateLink(result);
        }
    }
})();