Hidder

Make "hide" button works

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

You will need to install an extension such as Tampermonkey to install this script.

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name         Hidder
// @version      1.2
// @description  Make "hide" button works
// @author       Rst00
// @match        https://www.wykop.pl/wykopalisko/*
// @namespace WykopHidder
// ==/UserScript==

const localStorageKey = 'WykopHidder';

(function() {
    'use strict';

    hideAllArticles();

    hideOldButton();
    addNewButton();
    handleNewButtonClick();

    clearOldEnteries();
})();

function hideOldButton() {
    const allButtons = document.querySelectorAll('.fix-tagline a.ajax.affect.create');

    allButtons.forEach(button => button.style.display = 'none');
}

function addNewButton() {
    const allContainers = document.querySelectorAll('.fix-tagline');

    allContainers.forEach(container => {
        const newButton = document.createElement('button');

        newButton.type = 'button';
        newButton.classList = 'rst-hide-button';
        newButton.innerText = 'ukryj';

        container.appendChild(newButton);
    });
}

function handleNewButtonClick() {
    $(document).on('click', '.rst-hide-button', function() {
        const container = $(this).parents('li.link');
        const articleId = container.find('.article').attr('data-id');

        saveDataToLS({
            id: articleId,
            createdAt: getCurrentDate(),
        });
        $(this).closest('li.link').remove();
    });
}

function hideAllArticles() {
    const articlesToHide = getDataFromLS();
    const allIds = articlesToHide.reduce((allIds, currentArticle) => [...allIds, currentArticle.id], []);

    const allArticles = document.querySelectorAll('#itemsStream .article');

    allArticles.forEach((article) => {
        if (allIds.includes(article.getAttribute('data-id'))) {
            article.parentNode.remove();
        }
    });
    wykop.bindLazy();
}

function getDataFromLS() {
    const articles = localStorage.getItem(localStorageKey);

    return articles ? JSON.parse(articles) : [];
}

function saveDataToLS(articleData) {
    const newDataToSave = JSON.stringify([...getDataFromLS(), articleData]);

    localStorage.setItem(localStorageKey, newDataToSave);
}

function clearOldEnteries() {
    const allArticles = getDataFromLS();
    const nowDate = getCurrentDate();
    const filteredArticles = allArticles.filter(article => article.createdAt + 60*60*24*7 > nowDate);

    localStorage.setItem(localStorageKey, JSON.stringify(filteredArticles));
}

function getCurrentDate() {
    return Math.floor(new Date().getTime() / 1000);
}