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 + '">';
}
}());