Greasy Fork

Greasy Fork is available in English.

HDrezka Cleanup

Cleanup HDrezka: change content width, change player size, remove blocks (telegram, social, support, vk, etc), restyle blocks (cover, status, rating, etc)

当前为 2022-06-13 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name            HDrezka Cleanup
// @name:en         HDrezka Cleanup
// @namespace       http://tampermonkey.net/
// @version         0.32
// @description     Cleanup HDrezka: change content width, change player size, remove blocks (telegram, social, support, vk, etc), restyle blocks (cover, status, rating, etc)
// @description:en  Cleanup HDrezka: change content width, change player size, remove blocks (telegram, social, support, vk, etc), restyle blocks (cover, status, rating, etc)
// @author          rub4ek
// @match           https://hdrezka.me/*
// @match           https://hdrezka.ag/*
// @match           https://rezka.ag/*
// @match           https://rezkify.com/*
// @match           https://kinopub.me/*
// @match           http://hdrezka.co/*
// @icon            https://www.google.com/s2/favicons?domain=rezka.ag
// @grant           GM_addStyle
// @run-at          document-start
// @license         MIT
// ==/UserScript==


(function() {
    'use strict';

    /* ------------------------------------------------- */
    /* --------------GLOBAL----------------------------- */
    /* ------------------------------------------------- */

    const arrowImageURL = ''

    /* ------------------------------------------------- */
    /* --------------GLOBAL-STYLES---------------------- */
    /* ------------------------------------------------- */

    GM_addStyle(`
    /* Padding for content */
    .b-wrapper {
        padding-left: 30px;
        padding-right: 30px;
    }

    /* Remove extra right padding for content page */
    .b-content__columns {
        padding-right: 0;
    }

    /* Remove extra right padding on main content listing */
    .b-content__inline_inner_mainprobar {
        padding-right: 0;
    }
    .b-content__inline_inner_mainprobar .b-content__inline_item {
        margin-left: 16px !important;
    }

    /* Active brand fixes */
    body.active-brand,
    body.active-brand.pp {
        padding-top: 0 !important;
    }
    .active-brand #wrapper {
        width: auto !important;
    }

    /* Style status */
    .b-post__status_wrapper {
        width: auto;
        margin: 0px 10px 0px 13px;
    }

    /* Style and resize rating block */
    .b-post__rating_table {
        width: 100%;
    }
    .b-post__rating_table td > * {
        float: right;
    }
    .b-post__rating_table .label {
        display: none !important;
    }

    /* Hide last episode info */
    .b-post__lastepisodeout {
        display: none !important;
    }

    /* Hide support block */
    .b-post__support_holder {
        display: none !important;
    }
    .b-post__support_holder_report .append {
        display: none !important;
    }

    /* Hide share label */
    .b-post__social_holder_wrapper .share-label {
        display: none !important;
    }

    /* Hide mixedtext */
    .b-post__mixedtext {
        text-indent: -9999px;
        padding: 0;
    }

    /* Tumbler */

    .hc-tumbler {
        width: 38px;
        height: 30px;
        background-color: #000;
        border: #1d92b2;
        border-radius: 30px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0 6px;
        cursor: pointer;
        position: relative;
    }
    .hc-tumbler:before,
    .hc-tumbler:after {
        background-size: 15px 15px;
        background-repeat: no-repeat;
        border-radius: 50%;
        content: '';
        display: block;
        top: 50%;
        margin-top: -7px;
        height: 15px;
        width: 15px;
        position: absolute;
    }
    .hc-tumbler:before {
        background-color: green;
        left: 6px;
    }
    .hc-tumbler:after {
        background-color: indianred;
        right: 6px;
    }
    .hc-tumbler > .hc-tumbler-dot {
        position: absolute;
        height: 20px;
        width: 20px;
        border-radius: 50%;
        background-color: #fff;
        transition: transform .5s,background-color .5s;
        will-change: transform;
        z-index: 2;
    }
    body.b-theme__template__night .hc-tumbler {
        background: #222d33;
    }
    `);

    /* ------------------------------------------------- */
    /* --------------HIDE-ADS--------------------------- */
    /* ------------------------------------------------- */

    function initHideAds() {
        GM_addStyle(`

        /* Hide some ads containers */

        body.hc-hide-ads .b-content__main > .b-post__mixedtext + div[style],
        body.hc-hide-ads .b-content__main > .b-post__rating_table + div[style],
        body.hc-hide-ads .b-content__main > div > .b-player > .b-player__network_issues_holder + div[style],
        body.hc-hide-ads .b-content__main > div > .b-player > a[target='_blank'],
        body.hc-hide-ads .b-content__main + div,
        body.hc-hide-ads .b-wrapper .nopadd,
        body.hc-hide-ads .b-seriesupdate__block_list > .b-seriesupdate__block_list_item[data-url=''] {
            display: none !important;
        }

        /* Setting */

        body.hc-hide-ads .hc-tumbler-hide-ads .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        `);

        resolve();
        document.addEventListener('DOMContentLoaded', resolve);
        document.addEventListener('DOMContentLoaded', settings);


        function resolve() {
            if (!document.body) return;

            if (enabled()) {
                document.body.classList.add('hc-hide-ads');
            } else {
                document.body.classList.remove('hc-hide-ads');
            }
        }

        function enabled() {
            return localStorage.getItem('hc-hide-ads') != 'false';
        }

        function toggle() {
            localStorage.setItem('hc-hide-ads', !enabled());
            resolve();
        }

        function settings() {
            const elem = document.createElement('div');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-tumbler-hide-ads pull-right'>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <span>Скрыть рекламные блоки</span>
            `);
            const tumbler = elem.querySelector('.hc-tumbler');
            tumbler.addEventListener('click', toggle);
            addSetting(elem);
        }
    }

    /* ------------------------------------------------- */
    /* --------------STYLE-IMPROVEMENTS----------------- */
    /* ------------------------------------------------- */

    function initStyleImprovements() {
        GM_addStyle(`

        /* Standard theme */

        body.hc-style .b-content__inline_item .info {
            background-color: #6f6f6f;
            color: #fff;
        }

        /* Night theme */

        body.hc-style.b-theme__template__night .b-content__main a {
            color: #fff;
        }

        body.hc-style.b-theme__template__night .b-content__main a:visited {
            color: #fff;
        }

        body.hc-style.b-theme__template__night .b-post__info a {
            color: #fff;
        }

        body.hc-style.b-theme__template__night .persons-list-holder .person-name-item a {
            color: #fff !important;
            border-color: #fff;
        }

        body.hc-style.b-theme__template__night .b-newest_slider__title span {
            border-color: #fff;
            color: #fff;
        }

        body.hc-style.b-theme__template__night .b-content__inline_item .cat {
            background-color: #060f13 !important;
        }

        body.hc-style.b-theme__template__night .b-content__inline_item .b-content__inline_item-link a,
        body.hc-style.b-theme__template__night .b-content__inline_item .b-content__inline_item-link a:visited {
            color: #fff;
        }

        /* Content items */

        body.hc-style .b-content__inline_item {
            width: 166px;
            margin-right: 10px;
        }

        body.hc-style .b-content__inline_item .cat {
            position: relative;
        }

        body.hc-style .b-content__inline_item .cat .entity {
            display: inline-block !important;
            margin-right: -8px;
            position: absolute;
            left: 0;
            right: 0;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        body.hc-style .b-content__inline_item:hover .cat .entity,
        body.hc-style .b-content__inline_item.active .cat .entity {
            display: none !important;
            margin-right: -10px;
            position: absolute;
            left: 0;
            right: 0;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        body.hc-style .b-content__inline_item-cover {
            padding: 0;
            border: 0;
        }

        body.hc-style .b-content__inline_item .cat {
            position: relative;
            top: unset;
            bottom: 0;
            right: 0;
            border-radius: 0;
            width: 100%;
        }

        body.hc-style .b-content__inline_item .info {
            border-radius: 0 !important;
            width: 100%;
            margin-bottom: 26px;
        }

        body.hc-style .b-content__inline_item .trailer {
            display: none !important;
            left: 0;
        }

        body.hc-style .b-newest_slider__list .b-content__inline_item {
            width: 92px;
            margin-right: 8px;
        }

        body.hc-style .b-sidelist .b-content__inline_item {
            width: 92px;
            margin-right: 8px;
        }

        /* Сontent page */

        body.hc-style .b-post .b-sidetitle {
            background: #cfcfcf;
            font-size: 16px;
            font-weight: bold;
            line-height: 18px;
            overflow: hidden;
            padding: 10px 18px;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        body.hc-style.b-theme__template__night .b-post .b-sidetitle {
            background: #192125;
        }
        body.hc-style .b-post .b-post__schedule .b-sidetitle {
            display: none;
        }
        body.hc-style .b-post .b-post__partcontent {
            margin-top: 0;
        }
        body.hc-style .b-post .b-post__actions .btn {
            border: 0;
            border-radius: 0;
        }

        /* Misc */

        body.hc-style .b-newest_slider__title {
            padding-bottom: 20px;
        }

        /* Setting */

        body.hc-style .hc-tumbler-styles .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        `);

        resolve();
        document.addEventListener('DOMContentLoaded', resolve);
        document.addEventListener('DOMContentLoaded', settings);


        function resolve() {
            if (!document.body) return;

            if (enabled()) {
                document.body.classList.add('hc-style');
            } else {
                document.body.classList.remove('hc-style');
            }
        }

        function enabled() {
            return localStorage.getItem('hc-style-improvements') == 'true';
        }

        function toggle() {
            localStorage.setItem('hc-style-improvements', !enabled());
            resolve();
        }

        function settings() {
            const elem = document.createElement('div');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-tumbler-styles pull-right'>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <span>Визуальные изменения</span>
            `);
            const tumbler = elem.querySelector('.hc-tumbler');
            tumbler.addEventListener('click', toggle);
            addSetting(elem);
        }
    }

    /* ------------------------------------------------- */
    /* --------------RESIZE-PLAYER---------------------- */
    /* ------------------------------------------------- */

    GM_addStyle(`

    /* Style player */

    .b-player {
        padding-top: 0;
    }
    .b-player #cdnplayer-preloader {
        height: 100%;
        width: 100%;
    }
    .b-player .b-simple_seasons__list {
        padding: 10px;
    }
    .b-player .b-player__holder_cdn {
        height: auto !important;
    }
    .b-player .b-player__container_cdn {
        resize: vertical;
        overflow: auto;
        width: 100% !important;
    }
    `);


    function resizePlayer() {
        const playerHolderElem = document.querySelector('.b-player__holder_cdn');
        if (!playerHolderElem) return;

        const playerContainerElem = document.querySelector('.b-player__container_cdn');
        if (!playerContainerElem) return;

        const contentMainElem = document.querySelector('.b-content__main');
        if (!contentMainElem) return;

        const initialWidth = playerHolderElem.offsetWidth;
        const initialHeight = playerHolderElem.offsetHeight;
        let resizedWidth = contentMainElem.offsetWidth;
        let windowHeight = window.innerHeight;

        if (initialHeight > 0 && initialWidth !== resizedWidth) {
            let ratio = initialWidth / initialHeight;
            let resizedHeight = resizedWidth / ratio;
            if (resizedHeight > windowHeight) {
                resizedHeight = windowHeight;
                resizedWidth = windowHeight * ratio;
            }
            playerHolderElem.style.width = resizedWidth + 'px';
            playerContainerElem.style.height = resizedHeight + 'px';
            console.log(
                `HDrezka Cleanup: player resized ` +
                `from ${initialWidth}x${initialHeight} ` +
                `to ${resizedWidth}x${resizedHeight}.`
            )
        }
    }

    /* ------------------------------------------------- */
    /* --------------SIZE-TUMBLER----------------------- */
    /* ------------------------------------------------- */

    function initContentSizeTumbler() {

        GM_addStyle(`

        /* Content Size Tumbler */

        .hc-content-size-tumbler {
            width: 78px !important;
        }
        .hc-content-size-tumbler:before,
        .hc-content-size-tumbler:after {
            display: none !important;
        }
        .hc-content-size-tumbler .hc-content-size-tumbler-point {
            background-size: 15px 15px;
            background-repeat: no-repeat;
            border-radius: 50%;
            content: '';
            display: block;
            height: 20px;
            width: 20px;
            position: absolute;
            background-color: #999;
            background-clip: content-box;
            box-sizing: border-box;
            border-color: transparent;
            border-style: solid;
        }

        .hc-content-size-tumbler .hc-content-size-tumbler-point:nth-child(1) {
            border-width: 8px;
        }
        .hc-content-size-tumbler .hc-content-size-tumbler-point:nth-child(2) {
            border-width: 7px;
            transform: translateX(calc(100% - 2px));
        }
        .hc-content-size-tumbler .hc-content-size-tumbler-point:nth-child(3) {
            border-width: 6px;
            transform: translateX(calc(200% - 2px));
        }
        .hc-content-size-tumbler .hc-content-size-tumbler-point:nth-child(4) {
            border-width: 5px;
            transform: translateX(calc(300% - 2px));
        }

        body.hc-content-size-wide .hc-content-size-tumbler .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        body.hc-content-size-ultrawide .hc-content-size-tumbler .hc-tumbler-dot {
            transform: translateX(calc(200% - 2px));
        }
        body.hc-content-size-full .hc-content-size-tumbler .hc-tumbler-dot {
            transform: translateX(calc(300% - 2px));
        }

        /* Content Sizes */

        body.hc-content-size-wide .b-wrapper {
            width: auto;
            min-width: 960px;
            max-width: 1150px;
        }
        body.hc-content-size-ultrawide .b-wrapper {
            width: auto;
            min-width: 960px;
            max-width: 1340px;
        }
        body.hc-content-size-full .b-wrapper {
            min-width: 960px;
            width: auto;
        }
        body.hc-content-size-full .glory {
            width: auto;
        }
        `);

        resolve();
        document.addEventListener('DOMContentLoaded', settings);
        document.addEventListener('DOMContentLoaded', resolve);

        function settings() {
            const elem = document.createElement('div');
            elem.classList.add('hc-content-size-setting');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-content-size-tumbler pull-right'>
                    <div class='hc-content-size-tumbler-point'></div>
                    <div class='hc-content-size-tumbler-point'></div>
                    <div class='hc-content-size-tumbler-point'></div>
                    <div class='hc-content-size-tumbler-point'></div>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <span>Ширина контента</span>
            `);
            const tumbler = elem.querySelector('.hc-content-size-tumbler');
            tumbler.addEventListener('click', rotate);
            addSetting(elem);
        }

        function getSize() {
            return localStorage.getItem('hc-content-size');
        }

        function setSize(value) {
            return localStorage.setItem('hc-content-size', value);
        }

        function rotate() {
            let size = getSize()
            switch (size) {
                case 'full':
                    size = 'normal';
                    break;
                case 'normal':
                    size = 'wide';
                    break;
                case 'wide':
                    size = 'ultrawide';
                    break;
                default:
                    size = 'full';
                    break;
            }
            setSize(size);
            resolve();
        }

        function resolve() {
            if (!document.body) return;

            document.body.classList.remove('hc-content-size-wide')
            document.body.classList.remove('hc-content-size-ultrawide')
            document.body.classList.remove('hc-content-size-full')
            window.removeEventListener('resize', resizePlayer);

            switch(getSize()) {
                case 'wide':
                    document.body.classList.add('hc-content-size-wide')
                    window.addEventListener('resize', resizePlayer);
                    break;
                case 'ultrawide':
                    document.body.classList.add('hc-content-size-ultrawide')
                    window.addEventListener('resize', resizePlayer);
                    break;
                case 'full':
                    document.body.classList.add('hc-content-size-full')
                    window.addEventListener('resize', resizePlayer);
                    break;
            }

            resizePlayer();
        }
    }

    /* ------------------------------------------------- */
    /* --------------HIDE-INFO-------------------------- */
    /* ------------------------------------------------- */

    function initHideInfoButton() {
        GM_addStyle(`

        /* Content hide info (button) */

        .hc-hide-info-button {
            content: '';
            width: 25px;
            height: 25px;
            margin-right: 5px;
            background-size: 25px 25px;
            background-repeat: no-repeat;
            background-image: url(${arrowImageURL});
            cursor: pointer;
        }
        body.hc-hide-info .hc-hide-info-button {
            transform: rotate(180deg);
        }

        /* Content hide info (hidden styles) */

        body.hc-hide-info .b-post__infotable,
        body.hc-hide-info .b-post__description,
        body.hc-hide-info .b-post__infolast{
            display: none !important;
        }

        /* Content hide info (night theme) */

        body.b-theme__template__night .hc-hide-info-button {
            filter: invert(100%) sepia(95%) saturate(21%) hue-rotate(280deg) brightness(106%) contrast(106%);
        }
        `);

        resolve();
        document.addEventListener('DOMContentLoaded', setup);
        document.addEventListener('DOMContentLoaded', resolve);

        function setup() {
            const title = document.querySelector('.b-post__title');
            if (!title) return;

            const button = document.createElement('div');
            button.classList.add('pull-right');
            button.classList.add('hc-hide-info-button');
            button.addEventListener('click', toggle);
            title.insertBefore(button, title.firstChild);

            initCover();
        }

        function initCover() {
            const cover = document.querySelector('.b-sidecover');
            if (!cover) return;

            const imgURL = cover.querySelector('img').src;

            GM_addStyle(`
            #oframecdnplayer video[style*='position: absolute'] {
                background-image: linear-gradient(to left, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 30%, rgba(0,0,0,.8) 50%, rgba(0,0,0,1) 70%, rgba(0,0,0,1) 100%), url('${imgURL}');
                background-size: auto 100%;
                background-position: center;
                background-repeat: no-repeat;
            }
            `);
        }

        function resolve() {
            if (!document.body) return;

            if (enabled()) {
                document.body.classList.add('hc-hide-info');
            } else {
                document.body.classList.remove('hc-hide-info');
            }
        }

        function enabled() {
            return localStorage.getItem('hc-hide-info') == 'true';
        }

        function toggle() {
            localStorage.setItem('hc-hide-info', !enabled());
            resolve();
        }
    }

    /* ------------------------------------------------- */
    /* --------------TRANSLATORS------------------------ */
    /* ------------------------------------------------- */

    function initHideTranslatorsButton() {
        GM_addStyle(`

        /* Content hide translators */

        .b-translator__item.active {
            cursor: pointer;
        }
        .hc-toggle-translators-button {
            content: '';
            float: left;
            width: 20px;
            height: 20px;
            margin-right: 3px;
            margin-top: 8px;
            margin-left: 5px;
            background-size: 20px 20px;
            background-repeat: no-repeat;
            background-image: url(${arrowImageURL});
            filter: invert(100%) sepia(95%) saturate(21%) hue-rotate(280deg) brightness(106%) contrast(106%);
            transform: rotate(90deg);
            cursor: pointer;
        }
        .hc-show-translators .hc-toggle-translators-button {
            transform: rotate(-90deg);
        }
        .b-translator__item:not(.active):not(.hc-toggle-translators-button) {
            display: none;
        }
        .b-translators__title {
            display: none;
        }
        .hc-show-translators .b-translator__item:not(.active):not(.hc-toggle-translators-button) {
            display: block;
        }
        .hc-show-translators .b-translators__title {
            display: block;
        }
        `);

        document.addEventListener('DOMContentLoaded', setup);

        function setup() {
            const translators = document.querySelector('.b-translators__block');
            if (!translators) return;

            const translatorsList = translators.querySelector('.b-translators__list');
            if (!translatorsList) return;

            const toggler = document.createElement('li');
            toggler.classList.add('hc-toggle-translators-button');
            toggler.addEventListener('click', toggle);
            translatorsList.appendChild(toggler);

            translatorsList.querySelectorAll('.b-translator__item').forEach(button => {
                button.addEventListener('click', function() {
                    if (this.classList.contains('active')) {
                        toggle()
                    }
                });
            });
        }

        function toggle() {
            document.querySelector('.b-translators__block').classList.toggle('hc-show-translators');
        }
    }

    /* ------------------------------------------------- */
    /* --------------HIDE-RUSSIAN----------------------- */
    /* ------------------------------------------------- */

    function initHideRussian() {
        GM_addStyle(`

        /* Main */

        .hc-hide-russian .hc-russian {
            display: none;
        }

        /* Setting */

        body.hc-hide-russian .hc-tumbler-hide-russian .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        `);

        setup();
        document.addEventListener('DOMContentLoaded', setup);
        document.addEventListener('DOMContentLoaded', settings);
        document.addEventListener('DOMContentLoaded', resolve);


        function setup() {
            document.querySelectorAll(".b-content__inline_item").forEach(elem => {
                if (elem.textContent.includes("Россия,") && !elem.classList.contains("hc-russian")) {
                    elem.classList.add("hc-russian");
                    const info = elem.querySelector(".b-content__inline_item-link").textContent.replace(/(\r\n|\n|\r)/gm, "").trim();
                    console.debug(`HDrezka Cleanup: mark russian ${info}`)
                }
            });
        }

        function resolve() {
            if (!document.body) return;

            if (enabled()) {
                document.body.classList.add('hc-hide-russian');
            } else {
                document.body.classList.remove('hc-hide-russian');
            }
        }

        function enabled() {
            return localStorage.getItem('hc-hide-russian') == 'true';
        }

        function toggle() {
            localStorage.setItem('hc-hide-russian', !enabled());
            resolve();
        }

        function settings() {
            const elem = document.createElement('div');
            elem.classList.add('hc-hide-russian-setting');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-tumbler-hide-russian pull-right'>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <span>Скрыть контент из страны-агрессора</span>
            `);
            const tumbler = elem.querySelector('.hc-tumbler');
            tumbler.addEventListener('click', toggle);
            addSetting(elem);
        }
    }

    /* ------------------------------------------------- */
    /* --------------IMDB-RATING------------------------ */
    /* ------------------------------------------------- */

    function initIMDbRating() {

        GM_addStyle(`

        /* Rating */

        .b-content__inline_item-link > .rating {
            position: relative;
            line-height: 15px;
            font-size: 11px;
            font-weight: normal;
            display: block;
            margin-top: 3px;
        }
        .b-content__inline_item-link > .rating .rating-votes {
            font-size: 9px;
        }
        .b-content__inline_item-link > .rating .rating-value {
            margin-left: 29px;
            color: #f09a20;
        }
        .b-content__inline_item-link > .rating:before {
            content: "";
            position: absolute;
            width: 26px;
            height: 100%;
            background-size: auto 24px;
            background-position: center -4px;
            background-repeat: no-repeat;

            /* https://icons8.com/icon/V0AXUEQxEIf5/imdb */
            background-image: url("");

            /* https://codepen.io/sosuke/pen/Pjoqqp */
            filter: invert(66%) sepia(77%) saturate(1448%) hue-rotate(347deg) brightness(99%) contrast(91%);
        }

        /* Setting */

        body.hc-imdb .hc-tumbler-imdb .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        `)

        setup();
        document.addEventListener('DOMContentLoaded', setup);
        document.addEventListener('DOMContentLoaded', settings);

        function setWithExpiry(key, value, ttl) {
            const now = new Date()

            // `item` is an object which contains the original value
            // as well as the time when it's supposed to expire
            const item = {
                value: value,
                expiry: now.getTime() + ttl,
            }
            localStorage.setItem(key, JSON.stringify(item))
        }

        function getWithExpiry(key) {
            const itemStr = localStorage.getItem(key)
            // if the item doesn't exist, return null
            if (!itemStr) {
                return null
            }
            const item = JSON.parse(itemStr)
            const now = new Date()
            // compare the expiry time of the item with the current time
            if (now.getTime() > item.expiry) {
                // If the item is expired, delete the item from storage
                // and return null
                localStorage.removeItem(key)
                return null
            }
            return item.value
        }

        function getRating(id) {
            return new Promise((resolve => {
                console.debug(`HDrezka IMDB Rating: request quick content for id=${id}.`);
                GM_xmlhttpRequest({
                    method: 'POST',
                    url: '/engine/ajax/quick_content.php',
                    data: `id=${id}&is_touch=1`,
                    headers: {'Content-Type': 'application/x-www-form-urlencoded'},
                    onload: response => {
                        // One weak ttl in ms
                        const ttl = 7 * 24 * 60 * 60 * 1000;
                        if (response.status === 200) {
                            // Is 200 status code
                            // Find IMDb block
                            const ratingSpan = /<span class="imdb">IMDb: <b>.{1,60}\)<\/i><\/span>/.exec(response.responseText);
                            if (ratingSpan) {
                                // IMDb block found
                                let rating;
                                let votes;
                                try {
                                    // Get actual rating
                                    const rating = /(<b>)(.*)(<\/b>)/.exec(ratingSpan[0])[2];
                                    // Get actual votes count
                                    const votes = /(<i>)\((.*)\)(<\/i>)/.exec(ratingSpan[0])[2];
                                    // Save real rating to Storage
                                    // Resolve with real rating
                                    const data = {rating: rating, votes: votes, id: id};
                                    setWithExpiry(id, data, ttl);
                                    resolve(data);
                                    console.debug(`HDrezka IMDB Rating: request quick content for id=${id} success.`);
                                    return;
                                }
                                catch(err) {
                                    console.debug(err);
                                }
                            }
                            // IMDb block not found
                            // Save empty rating to storage to not make new request in next page load
                            // Resolve with empty rating
                            const data = {rating: '', votes: '', id: id};
                            setWithExpiry(id, data, ttl);
                            resolve(data);
                            console.debug(`HDrezka IMDB Rating: request quick content for id=${id} success, but no correct data found.`);
                        } else {
                            console.debug(`HDrezka IMDB Rating: request quick content for id=${id} failed with ${response.status} status code.`);
                            // Isn't 200 status code
                            // Don't save any rating so it will be requsted again in next page load
                            // Resolve with null rating
                            resolve({rating: null, votes: null, id: id});
                        }
                    },
                    onerror: () => {
                        console.debug(`HDrezka IMDB Rating: request quick content for id=${id} failed.`);
                        // Request failed
                        // Don't save any rating so it will be requsted again in next page load
                        // Resolve with null rating
                        resolve({rating: null, votes: null, id: id});
                    }
                })
            }))
        }

        function showRating(ratingObject) {
            if (
                ratingObject &&
                ratingObject.id !== null &&
                ratingObject.rating !== null &&
                ratingObject.rating !== ''
            ) {
                // Got rating
                // Find related element to append rating
                const contentItemLinkElement = document.querySelector(
                    `[data-id="${ratingObject.id}"] .b-content__inline_item-link`
                );
                // Check rating wasn't already appended
                if (contentItemLinkElement && !contentItemLinkElement.querySelector('.rating')) {
                    // Append rating block
                    let votesText;
                    try {
                        votesText = `${parseInt(parseInt(ratingObject.votes.replace(/\s/g, ''))/1000)}k`;
                    }
                    catch(err) {
                        console.debug(err);
                        votesText = ''
                    }
                    contentItemLinkElement.innerHTML += `
                        <span class="rating">
                            <span class="rating-value"><b>${ratingObject.rating}</b></span>
                             <span> / </span>
                        <span class="rating-votes">${votesText}</span>
                        </span>
                    `;
                }
            }
        }

        function getAndShowRating(contentItemElement) {
            const id = contentItemElement.dataset.id;
            const ratingObject = getWithExpiry(id);
            if (
                ratingObject !== null &&
                ratingObject.id != null &&
                ratingObject.rating != null &&
                ratingObject.votes != null
            ) {
                // Found vaid saved rating in storage
                // Show rating from storage
                return showRating(ratingObject);
            }
            // Rating not found in storage
            // Request rating and then show
            return getRating(id).then(showRating);
        }

        function setup() {
            if (!document.body) return;

            resolve();

            if (document.body.classList.contains('hc-imdb')) {
                document.querySelectorAll('.b-content__inline_item').forEach(getAndShowRating);
            }
        }

        function resolve() {
            if (!document.body) return;

            if (enabled()) {
                document.body.classList.add('hc-imdb');
            } else {
                document.body.classList.remove('hc-imdb');
            }
        }

        function enabled() {
            return localStorage.getItem('hc-imdb') == 'true';
        }

        function toggle() {
            localStorage.setItem('hc-imdb', !enabled());
            document.location.reload();
        }

        function settings() {
            const elem = document.createElement('div');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-tumbler-imdb pull-right'>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <span>Рейтинг IMDb</span>
            `);
            const tumbler = elem.querySelector('.hc-tumbler');
            tumbler.addEventListener('click', toggle);
            addSetting(elem);
        }
    }

    /* ------------------------------------------------- */
    /* --------------SETTINGS--------------------------- */
    /* ------------------------------------------------- */

    function initSettings() {
        const settingsOpenImgURL = '';
        const settingsCloseImgURL = '';

        GM_addStyle(`

        /* Settings */

        .hc-settings {
            position: relative;
        }

        /* Settings tumbler */

        .hc-settings-tumbler {
            margin-top: 5px;
            margin-left: 10px;
        }
        .hc-settings-tumbler:before {
            background-image: url('${settingsOpenImgURL}');
            background-color: transparent !important;
        }
        .hc-settings-tumbler:after {
            background-image: url('${settingsCloseImgURL}');
            background-color: transparent !important;
        }
        .hc-settings.active .hc-settings-tumbler > .hc-tumbler-dot {
            transform: translateX(calc(100% - 2px));
        }
        .hc-settings ul {
            width: 320px;
            display: none;
            background: #313131;
            border-top: 0;
            position: absolute;
            top: 40px;
            left: 0px;
            white-space: nowrap;
            box-shadow: 0 5px 20px 0px rgb(0 0 0 / 70%);
            border-color: #222d33;
            border-style: solid;
            border-width: 0 3px 3px 3px;
            padding: 5px 0;
        }
        .hc-settings.active ul {
            display: block;
        }
        .hc-settings ul li {
            white-space: nowrap;
            color: #777;
            font-size: 10px;
            font-weight: bold;
            margin: 0 !important;
            padding: 5px 10px;
            line-height: 30px;
        }

        body.b-theme__template__night .hc-settings ul {
            background: #060f13;
        }
        `);

        document.addEventListener('DOMContentLoaded', setup);

        function setup() {
            const tophead = document.querySelector('.b-tophead-left');
            if (!tophead) return;

            const elem = document.createElement('div');
            elem.classList.add('hc-settings');
            elem.classList.add('pull-left');
            elem.insertAdjacentHTML('beforeend', `
                <div class='hc-tumbler hc-settings-tumbler'>
                    <div class='hc-tumbler-dot'></div>
                </div>
                <ul></ul>
            `);

            const tumbler = elem.querySelector('.hc-settings-tumbler');
            tumbler.addEventListener('click', toggle);

            document.addEventListener('click', close);

            tophead.appendChild(elem);
        }

        function toggle(event) {
            event.target.closest('.hc-settings').classList.toggle('active');
            event.stopPropagation();
        }

        function close(event) {
            if (!event.target.closest('.hc-settings')) {
                document.querySelector('.hc-settings').classList.remove('active');
            }
        }
    }

    function addSetting(element) {
        const tophead = document.querySelector('.b-tophead-left');
        if (!tophead) return;

        const dropdown = tophead.querySelector('.hc-settings ul');
        if (!dropdown) return;

        const item = document.createElement('li');
        item.appendChild(element);
        dropdown.appendChild(item);
    }


    /* ------------------------------------------------- */
    /* --------------DOCUMENT--------------------------- */
    /* ------------------------------------------------- */

    function onDocumentStart() {
        initSettings();
        initContentSizeTumbler();
        initHideAds();
        initStyleImprovements();
        initHideInfoButton();
        initHideTranslatorsButton();
        initIMDbRating();
        initHideRussian();
    }

    function onDocumentEnd() {}

    document.addEventListener('DOMContentLoaded', onDocumentEnd);

    onDocumentStart();

})();