Greasy Fork is available in English.

Contests helper

Показывает сколько кандидатов из турнира есть в твоих списках.

Verze ze dne 21. 02. 2025. Zobrazit nejnovější verzi.

// ==UserScript==
// @name         Contests helper
// @icon         https://www.google.com/s2/favicons?domain=shikimori.me
// @namespace    https://shikimori.one
// @version      1.4
// @description  Показывает сколько кандидатов из турнира есть в твоих списках.
// @author       LifeH
// @match        *://shikimori.org/*
// @match        *://shikimori.one/*
// @match        *://shikimori.me/*
// @grant        none
// @license MIT
// ==/UserScript==

(function() {
    'use strict';
      const CopyBtnI = "";
      const CopyBtnSelI = "";
  
  function main() {
        const path = window.location.pathname;
        if (!path.startsWith('/contests/')) {
            return;
        }
  
        const entries = document.querySelectorAll('.c-column.b-catalog_entry.c-anime, .c-column.b-catalog_entry.c-manga');
        if (entries.length === 0) {
            return;
        }
  
        const list = {
            'completed': 0,
            'planned': 0,
            'dropped': 0,
            'on_hold': 0,
            'watching': 0,
            'rewatching': 0,
            'no_list': 0
        };
  
        const colors = {
            'completed': '#419541',
            'planned': '#176093',
            'dropped': '#FC575E',
            'on_hold': '#7b8084',
            'watching': '#176093',
            'rewatching': '#176093',
            'no_list': '#000'
        };
  
        const entryIds = new Set();
  
        entries.forEach(article => {
            const entryId = article.getAttribute('id');
            if (entryIds.has(entryId)) {
                return;
            }
  
            entryIds.add(entryId);
  
            let found = false;
            for (let key in list) {
                if (article.classList.contains(key)) {
                    list[key]++;
                    found = true;
                    break;
                }
            }
            if (!found) {
                list['no_list']++;
            }
        });
  
        showR(list, entryIds.size, colors);
    }
  
    function showR(list, size, colors) {
        const existingContainer = document.querySelector('.list-container');
        if (existingContainer) {
            existingContainer.remove();
        }
  
        const container = document.createElement('div');
        container.classList.add('list-container');
        container.style.marginTop = '20px';
        container.style.fontSize = '32px';
        container.style.padding = '30px';
        container.style.maxWidth = '250px';
        container.style.position = 'relative';
  
        let resultHTML = '';
        let clipboardText = '';
  
        Object.entries(list).forEach(([key, value]) => {
            if (value > 0) {
                resultHTML += `
                <div class="b-add_to_list ${key}">
                    <div class="trigger">
                        <span class="status-name">${getStatusName(key)}&nbsp;&nbsp;–&nbsp;&nbsp;${value}</span>
                    </div>
                </div>`;
                clipboardText += `[color=${colors[key]}][b]${getStatusName(key)}[/b][/color] – ${value}\n`;
            }
        });
  
        container.innerHTML = resultHTML;
        addCopyButton(container, clipboardText);
  
        const element = document.querySelector('.b-contests-menu');
        if (element) {
            element.parentNode.appendChild(container);
        }
    }
  
    function addCopyButton(container, text) {
        let button = document.createElement("span");
        button.classList.add("copy-list-button");
        button.title = "Скопировать";
        button.style.backgroundImage = `url(${CopyBtnI})`;
        button.style.backgroundRepeat = "no-repeat";
        button.style.backgroundSize = "contain";
        button.style.width = "16px";
        button.style.height = "16px";
        button.style.cursor = "pointer";
        button.style.position = "absolute";
        button.style.top = "5px";
        button.style.right = "5px";
        button.style.zIndex = "10";
  
        button.onmouseover = () => button.style.backgroundImage = `url(${CopyBtnSelI})`;
        button.onmouseout = () => button.style.backgroundImage = `url(${CopyBtnI})`;
  
        button.onclick = (event) => {
            event.stopPropagation();
            event.preventDefault();
            navigator.clipboard.writeText(text).then(() => {
                button.style.transform = "scale(1.1)";
                setTimeout(() => button.style.transform = "scale(1)", 200);
            }).catch(err => console.error(err));
        };
  
        container.appendChild(button);
    }
  
   function getStatusName(status) {
        const names = {
            'planned': 'Запланировано',
            'dropped': 'Брошено',
            'on_hold': 'Отложено',
            'watching': 'Смотрю',
            'rewatching': 'Пересматриваю',
            'completed': 'Просмотрено',
            'no_list': 'Не в списках'
        };
        return names[status] || status;
    }
  
    function ready(fn) {
        document.addEventListener('page:load', fn);
        document.addEventListener('turbolinks:load', fn);
        if (document.attachEvent ? document.readyState === "complete" : document.readyState !== "loading") {
            fn();
        } else {
            document.addEventListener('DOMContentLoaded', fn);
        }
    }
  
    ready(main);
  
  })();