WaniKani User Post Blocker

Replaces posts by blocked users with customizable images.

// ==UserScript==
// @name        WaniKani User Post Blocker
// @namespace   ajpazder
// @description Replaces posts by blocked users with customizable images.
// @version     1.0.0
// @author      Johnathon Pazder
// @copyright   2017+, Johnathon Pazder
// @license     MIT; http://opensource.org/licenses/MIT
// @include     http://www.wanikani.com/chat/*/*
// @include     https://www.wanikani.com/chat/*/*
// @run-at      document-end
// @grant       none
// ==/UserScript==

(function () {
	// Anyone you want to block, put their name in here like so: [ "user1", "user2" ]
	var blockedUsers = [ ];

	// Set your own custom replacement images here.  The defaults are a couple of data URLs for abstract
    // paragraph shapes.  They're embedded in the script to guarantee they'll always be available since
    // they don't depend on a 3rd party image host, but you can use images hosted online too.
	var replacementImages = [
        "",
        ""
	];

	blockedUsers.forEach(function (user) {
		// If a quote appears on the same page, we want to make sure
		// that its content matches an earlier post.  It just adds a
        // small bit of continuity between posts.
		var quotableImage;

		var posts = findPostsMadeByUser(user);
		posts.each(function () {
			var replacementImage = chooseRandomElementFromArray(replacementImages);
			var newContent = makeImgElement(replacementImage);
			$(this).html(newContent);

			// To make sure that the quote is of a post that precedes
			// it, we'll always use the first image chosen (because
			// that's just easier).
			if (!quotableImage) {
				quotableImage = replacementImage;
			}
		});

		// If the page is all quotes, we'll just pick a random replacement image.
		// No need for continuity here...
		if (!quotableImage) {
			quotableImage = chooseRandomElementFromArray(replacementImages);
		}

		var quotesOfUserPosts = findQuotesOfUser(user);
		quotesOfUserPosts.each(function () {
			var quoteHeader = $(this).find('.post-quote-author')[0].outerHTML;
			var newContent = quoteHeader + makeImgElement(quotableImage);
			$(this).html(newContent);
		});
	});

    function findPostsMadeByUser(user) {
        var allPosts = $('tr[id^=post]');
        var postsByUser = allPosts.filter(function () {
            return $(this).find(".username").text() == user;
        });
        var postsContent = postsByUser.find(".forum-post");

        return postsContent;
    }

    function findQuotesOfUser(user) {
        return $('.post-quote-author:contains(' + user + ')').parent();
    }

    function chooseRandomElementFromArray(array) {
        return array[Math.floor(Math.random() * array.length)];
    }

    function makeImgElement(srcUrl) {
        return '<img alt="" src="' + srcUrl + '">';
    }
 }());

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址