// ==UserScript== // @name Aniscripts // @namespace http://tampermonkey.net/ // @version 3.91 // @description Change stuff on Anilist.co // @author hoh // @match https://anilist.co/* // @grant none // @license GPLv3 // @downloadURL none // ==/UserScript== (function(){ "use strict"; const scriptInfo = { "version" : "3.91", "link" : "https://greasyfork.org/en/scripts/370473-aniscripts", "author" : "hoh", "authorLink" : "https://anilist.co/user/hoh/", "license" : "GPLv3", "language" : "Decensored JAVscript", "realm" : "︵‿︵(´ ͡༎ຶ ͜ʖ ͡༎ຶ `)︵‿︵" }; /* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. . */ /* Aniscripts, sometimes just "the userscript", is modular and contains of several independet functions The URL matching controller can be found near the bottom of this file. Anilist runs on a framework of its own, which mostly avoids reloading the page. (instead it modifies popstate etc.) Therefore, this script does the following: 1. Runs a clock checking if the URL has changed 2. Runs the modules relevant to that URL. Some care must be taken checking if an instance of a module is already running, or if the page content has loaded yet. An ambitious person could try changing those into mutationObserver or something, but it works fine as is. "useScripts" contains the defauls for the various modules. This is stored in the user's localStorage. */ //a shared style node for all the modules. All classes are prefixed by "hoh" to avoid collisions with native Anilist classes var style = document.createElement("style"); style.type = "text/css"; //most of these are used by the notification module //The default colour is rgb(var(--color-blue)) provided by Anilist, but rgb(var(--color-green)) is preferred for things related to manga style.textContent = ` .hohTime{ position: static; float: right; margin-right: 20px; margin-top: 10px; margin-left: auto; font-size: 1.1rem; } .hohUnread{ border-right: 8px; border-color: rgba(var(--color-blue)); border-right-style: solid; } .hohNotification{ margin-bottom: 10px; background: rgb(var(--color-foreground)); border-radius: 4px; justify-content: space-between; line-height: 0; min-height: 72px; } .hohNotification *{ line-height: 1.15; } .hohUserImageSmall{ display: inline-block; background-position: 50%; background-repeat: no-repeat; background-size: cover; position: absolute; } .hohUserImage{ height: 72px; width: 72px; display: inline-block; background-position: 50%; background-repeat: no-repeat; background-size: cover; position: absolute; } .hohMediaImage{ height: 70px; margin-right: 5px; } .hohMessageText{ position: absolute; margin-top: 30px; margin-left: 80px; max-width: 330px; } .hohMediaImageContainer{ vertical-align: bottom; margin-left: 400px; display: inline; position: relative; display: inline-block; min-height: 70px; } .hohMediaImageContainer > a{ height: 70px; line-height: 0!important; } span.hohMediaImageContainer{ line-height: 0!important; } .hohCommentsContainer{ margin-top: 5px; } .hohCommentsArea{ margin: 10px; display: none; padding-bottom: 2px; margin-top: 5px; width: 95%; } .hohComments{ float: right; display: none; margin-top: -30px; margin-right: 15px; cursor: pointer; margin-left: 600px; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .hohCombined .hohComments{ display: none!important; } .hohQuickCom{ padding: 5px; background-color: rgb(var(--color-background)); margin-bottom: 5px; position: relative; } .hohQuickComName{ margin-right: 15px; color: rgb(var(--color-blue)); } .hohThisIsMe{ color: rgb(var(--color-green)); } .hohILikeThis{ color: rgb(var(--color-red)); } .hohQuickComName::after{ content: ":"; } .hohQuickComContent{ margin-right: 40px; display: block; } .hohQuickComContent > p{ margin: 1px; } .hohQuickComLikes{ position: absolute; right: 5px; bottom: 5px; display: inline-block; } .hohQuickComContent img { max-width: 100%; } .hohSpoiler::before{ color: rgb(var(--color-blue)); cursor: pointer; background: rgb(var(--color-background)); border-radius: 3px; content: "Spoiler, click to view"; font-size: 1.3rem; padding: 0 5px; } .hohSpoiler.hohClicked::before{ display: none; } .hohSpoiler > span{ display: none; } .hohMessageText > span > div.time{ display: none; } .hohUnhandledSpecial > div{ margin-top: -20px; } .hohMonospace{ font-family: monospace; } .hohSocialTabActivityCompressedContainer{ min-width: 480px; } .hohSocialTabActivityCompressedStatus{ vertical-align: middle; padding-bottom: 7px; } .hohSocialTabActivityCompressedName{ vertical-align: middle; margin-left: 3px; } .hohForumHider{ margin-right: 3px; cursor: pointer; font-family: monospace; } .hohForumHider:hover{ color: rgb(var(--color-blue)); } .hohBackgroundCover{ height: 70px; width: 50px; display: inline-block; background-repeat: no-repeat; background-size: cover; margin-top: 1px; line-height: 0; margin-bottom: 1px; } #hohDescription{ width: 280px; height: 150px; float: left; color: rgb(var(--color-blue)); } .hohStatsTrigger{ cursor: pointer; border-radius: 3px; color: rgb(var(--color-text-lighter)); display: block; font-size: 1.4rem; margin-bottom: 8px; padding: 5px 10px; } .hohActive{ background: rgba(var(--color-foreground),.8); color: rgb(var(--color-text)); font-weight: 500; } #hohFavCount{ position: absolute; right: 30px; color: rgba(var(--color-red)); top: 10px; font-weight: 400; } .hohShamelessLink{ display: block; margin-bottom: 5px; } .hohSlidePlayer{ display: block; position: relative; width: 500px; } .hohSlide{ position: absolute; top: 0px; font-size: 500%; height: 100%; display: flex; align-items: center; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; opacity:0.5; } .hohSlide:hover{ background-color: rgb(0,0,0,0.4); cursor: pointer; opacity:1; } .hohRightSlide{ right: 0px; padding-left: 10px; padding-right: 20px; } .hohLeftSlide{ left: 0px; padding-left: 20px; padding-right: 10px; } .hohShare{ position: absolute; right: 12px; top: 30px; cursor: pointer; color: rgb(var(--color-blue-dim)); } .activity-entry{ position: relative; } .hohEmbed{ border-style: solid; border-color: rgb(var(--color-text)); border-width: 1px; padding: 15px; position: relative; } .hohEmbed .avatar{ border-radius: 3px; height: 40px; width: 40px; background-position: 50%; background-repeat: no-repeat; background-size: cover; display: inline-block; } .hohEmbed .name{ display: inline-block; height: 40px; line-height: 40px; vertical-align: top; color: rgb(var(--color-blue)); font-size: 1.4rem; margin-left: 12px !important; } .hohEmbed .time{ color: rgb(var(--color-text-lighter)); font-size: 1.1rem; position: absolute; right: 12px; top: 12px; } .hohRecsLabel{ color: rgb(var(--color-blue)) !important; } .hohRecsItem{ margin-top: 5px; margin-bottom: 10px; } .hohTaglessLinkException{ display: block; } .hohTaglessLinkException::after{ content: ""!important; } .hohStatValue{ color: rgb(var(--color-blue)); } .markdown-editor > [title="Image"], .markdown-editor > [title="Youtube Video"], .markdown-editor > [title="WebM Video"]{ color: rgba(var(--color-red)); } .hohBackgroundUserCover{ height: 70px; width: 70px; display: inline-block; background-position: 50%; background-repeat: no-repeat; background-size: cover; margin-top: 1px; margin-bottom: 1px; } .history-day.lv-9{ z-index:1!important } .hohRegularTag{ border-style: solid; border-width: 1px; border-radius: 3px; padding: 2px; margin-right: 3px; } .hohTableHider{ cursor: pointer; margin: 4px; color: rgb(var(--color-blue)); } .hohCross{ cursor: pointer; margin-left: 2px; color: red; } .hohFavCountBrowse{ color: white; position: absolute; right: 2px; font-size: 60%; opacity: 0.7; } .hohColourPicker{ position: absolute; right: 60px; margin-top: -110px; } .hohColourPicker h2{ color: #3db4f2; font-size: 1.6rem; font-weight: 400; padding-bottom: 12px; } .hohSecondaryRow{ background-color: rgb(var(--color-background)); } .hohSecondaryRow:hover{ background-color: rgb(var(--color-foreground)); } .media-preview-card meter{ width: 150px; margin-bottom: 5px; } .hohForumLink{ color: rgb(var(--color-text-lighter)); display: inline-block; margin: 0 10px; padding: 15px; cursor: pointer; } #hohForumContent{ margin-top: 20px; } .hohThreadsBody{ width: 600px; } .hohThreadCard{ margin: 15px; padding: 18px; background-color: rgb(var(--color-foreground)); width: 470px; height: 90px; position: relative; border-radius: 4px; } .hohThreadCard .title{ cursor: pointer; margin-right: 110px; width: 360px; font-size: 1.4rem; } .hohThreadCard .info{ color: rgb(var(--color-text-lighter)); font-size: 1.2rem; position: absolute; right: 12px; top: 12px; } .hohThreadCard .info span{ padding-left: 10px; } .hohThreadCard .category{ border-radius: 100px; color: #fff; display: inline-block; font-size: 1.1rem; margin-left: 10px; padding: 4px 8px; text-transform: lowercase; position: absolute; right: 15px; bottom: 20px; cursor: pointer; } .hohThreadCard .category:hover{ color: black; } .hohThreadCard .threadReply{ position: absolute; left: 20px; bottom: 20px; font-size: 1.3rem; } .hohThreadCard .threadReply .user{ color: rgb(var(--color-blue)); } .tags .tag{ min-height: 35px; margin-bottom: 5px !important; } .custom-lists .el-checkbox__label{ display: inline !important; white-space: pre-wrap; white-space: -webkit-pre-wrap; white-space: normal; word-wrap: anywhere; word-break: break-all; } .hohStatusDot{ position: absolute; width: 10px; height: 10px; border-radius: 50px; } .studio .container.header{ position: relative; } .studio .favourite{ position: absolute; top: 10px; right: 30px; } .filter .view-all{ background-color: rgb(var(--color-foreground)); height: 32px; border-radius: 3px; text-align: center; padding-top: 8px; } .title > a{ line-height: 1.15!important; } .embed .title{ line-height: 18px!important; } #dubNotice{ font-size: 12px; font-weight: 500; text-align: center; text-transform: capitalize; background: rgb(var(--color-foreground)); margin-top: 0em; margin-bottom: 16px; border-radius: 3px; padding: 8px 12px; } #hohDraw3x3{ margin-top: 5px; cursor: pointer; } .hohDisplayBox{ position: fixed; top: 80px; left: 200px; z-index: 999; padding: 20px; background-color: rgb(var(--color-foreground)); } .hohDisplayBoxClose{ position: absolute; right: 20px; top: 20px; cursor: pointer; background-color: red; } .hohFeedFilter{ position: absolute; top: 2px; font-size: 1.4rem; font-weight: 500; } .hohFeedFilter input{ width: 55px; } div.page-content > div > div.header-wrap > div.nav-wrap > div > a:nth-child(5):after{ content: "/Script"; } `; document.getElementsByTagName("head")[0].appendChild(style); //Todo: find out how to parse API headers for an accurate result document.APIcallsUsed = 0;//this is NOT a reliable way to figure out how many more calls we can use, just a way to set some limit var pending = {}; var APIcounter = setTimeout(function(){ document.APIcallsUsed = 0; },60*1000);//reset counter every minute var localStorageAvailable;//localStorage is great for not having to fetch the api data every time var test = "test"; try{ localStorage.setItem(test,test); localStorage.removeItem(test); localStorageAvailable = true; } catch(e){ localStorageAvailable = false; } if(localStorageAvailable){ var aniscriptsUsed = localStorage.getItem("aniscriptsUsed"); if(aniscriptsUsed === null){ aniscriptsUsed = { keys : [] }; } else{ aniscriptsUsed = JSON.parse(aniscriptsUsed); } localStorage.setItem("aniscriptsUsed",JSON.stringify(aniscriptsUsed)); } var useScripts = {//most modules are turned on by default notifications : true, socialTab : true, forumComments : true, staffPages : true, tagDescriptions : true, completedScore : true, moreStats : true, characterFavouriteCount : true, studioFavouriteCount : true, CSSfavs : true, CSScompactBrowse : true, CSSmangaGreen: false, CSSfollowCounter: true, CSSsubmissionCounter: false, CSSprofileClutter: false, CSSdecimalPoint: false, CSSverticalNav: false, hideLikes: false, dubMarker: false, CSSstudioStats: true, CSS3d: false, CSSsmileyScore: true, CSSexpandFeedFilters: false, feedCommentFilter: false, feedCommentComments: 0, feedCommentLikes: 0, colourPicker: true, colourSettings: [], mangaBrowse: false, progressBar: false, noRewatches: false, forumLinks: true, hideCustomTags: false, shortRomaji: false, replaceNativeTags: true, draw3x3: true, limitProgress8: false, limitProgress10: false, tagIndex: true, ALbuttonReload: true, expandRight: false, timeToCompleteColumn: false, mangaGuess: true, replaceStaffRoles: true, titleLanguage: "Romaji", dubMarkerLanguage: "English" }; var forceRebuildFlag = false; if(localStorageAvailable){ const useScriptsSettings = JSON.parse(localStorage.getItem("hohSettings")); if(useScriptsSettings){ var keys = Object.keys(useScriptsSettings); keys.forEach(function(key){//this is to keep the default settings if the version in local storage is outdated useScripts[key] = useScriptsSettings[key]; }); } localStorage.setItem("hohSettings",JSON.stringify(useScripts)); } var whoAmI = ""; //replace with query selector? try{//use later for some scripts whoAmI = document.getElementById("nav").children[0].children[1].children[1].href.match(/[\w\-]*\/$/)[0].slice(0,-1);//looks at the nav } catch(err){ console.log("could not get username"); } const svgAssets = { envelope : "✉", cross : "✕", frown : ` `, meh : ` `, smile : ` `, star : ` `, //the column sorting arrow angleDown : ` `, view : ` `, reply : ` `, repeat : ` ` }; const distributionColours = { "COMPLETED" : "rgb(104, 214, 57)", "CURRENT" : "rgb( 2, 169, 255)", "PAUSED" : "rgb(247, 121, 164)", "DROPPED" : "rgb(232, 93, 117)", "PLANNING" : "rgb(247, 154, 99)", "REPEATING" : "violet" }; if(useScripts.mangaBrowse){ const navLinks = document.querySelector(".links"); for(var i=0;i .wrap > .footer > .container"); if(colourPickerLocation){ const supportedColours = [ "--color-background", "--color-foreground", "--color-foreground-grey", "--color-foreground-grey-dark", "--color-foreground-blue", "--color-foreground-blue-dark", "--color-background-blue-dark", "--color-overlay", "--color-shadow", "--color-shadow-dark", "--color-text", "--color-text-light", "--color-text-lighter", "--color-text-bright", "--color-blue", "--color-blue-dim", "--color-white", "--color-black", "--color-red", "--color-peach", "--color-orange", "--color-yellow", "--color-green" ]; var colourChanger = function(){ for(var i=0;i a${dataSelect} ,a.title${dataSelect} ,.overlay > a.title${dataSelect} ,.media-preview-card a.title${dataSelect} ,.quick-search-results .el-select-dropdown__item a${dataSelect}> span ,.media-embed${dataSelect} .title ,.status > a.title${dataSelect} ,.role-card a.content${dataSelect} > .name{ visibility: hidden; font-size: 2%; line-height: 0px; } a.title${dataSelect}::before ,.quick-search-results .el-select-dropdown__item a${dataSelect} > span::before ,.role-card a.content${dataSelect} > .name::before ,.title > a${dataSelect}::before ,.home .status > a.title${dataSelect}::before ,.media-embed${dataSelect} .title::before ,.overlay > a.title${dataSelect}::before ,.media-preview-card a.title${dataSelect}::before{ content:'${targetName}' }`; } } const shortRomaji = [ ["/anime/30/","Evangelion"], ["/anime/32/","End of Evangelion"], ["/anime/5114/","FMA:B"], ["/anime/10620/","Mirai Nikki"], ["/anime/1575/","Code Geass"], ["/anime/2904/","Code Geass R2"], ["/anime/21355/","Re:Zero"], ["/anime/2001/","Gurren Lagann"], ["/anime/21202/","Konosuba!"], ["/anime/21699/","Konosuba! 2"], ["/anime/21574/","Konosuba!: Kono Subarashii Choker ni Shufuku wo!"], ["/anime/9756/","Madoka★Magica"], ["/anime/9989/","AnoHana"], ["/anime/20623/","Kiseijuu"], ["/anime/14741/","Chuunibyou!"], ["/anime/18671/","Chuunibyou! 2"], ["/anime/14813/","OreGairu"], ["/anime/20920/","Danmachi"], ["/anime/8074/","HIGHSCHOOL OF THE DEAD"], ["/anime/849/","Haruhi"], ["/anime/4382/","Haruhi (2009)"], ["/anime/19603/","Unlimited Blade Works"], ["/anime/20792/","Unlimited Blade Works 2"], ["/anime/8769/","OreImo"], ["/anime/10020/","OreImo Specials"], ["/anime/13659/","OreImo 2"], ["/anime/18857/","OreImo 2 Specials"], ["/anime/2025/","Darker than BLACK"], ["/anime/20698/","OreGairu 2"], ["/anime/16592/","Danganronpa"], ["/anime/16742/","WataMote"], ["/anime/101291/","Bunny Girl-senpai"], ["/anime/104157/","Bunny Girl-senpai Movie"], ["/anime/19221/","NouKome"], ["/anime/45/","Rurouni Kenshin"], ["/anime/8795/","Panty & Stocking"], ["/anime/21860/","Sukasuka"], ["/anime/33/","Berserk"], ["/anime/97938/","Boruto"], ["/anime/97907/","Death March"], ["/anime/100183/","Gun Gale Online"], ["/anime/20474/","JoJo: Stardust Crusaders"], ["/anime/20799/","JoJo: Stardust Crusaders - Egypt-hen"], ["/anime/21450/","JoJo: Diamond wa Kudakenai"], ["/anime/102883/","JoJo: Ougon no Kaze"], ["/anime/101921/","Kaguya-sama wa Kokuraseta"], ["/anime/101166/","Danmachi: Orion no Ya"], ["/anime/20791/","Heaven’s Feel I. presage flower"], ["/anime/21718/","Heaven’s Feel II. lost butterfly"], ["/anime/21719/","Heaven’s Feel III. spring song"], ["/anime/1089/","Macross: Ai Oboete Imasu ka"], ["/anime/572/","Nausicaa"], ["/anime/513/","Laputa"], ["/anime/44/","Rurouni Kenshin: Tsuioku-hen"], ["/anime/528/","Mewtwo no Gyakushuu"], ["/anime/530/","Sailor Moon"], ["/anime/740/","Sailor Moon R"], ["/anime/532/","Sailor Moon S"], ["/anime/1239/","Sailor Moon SuperS"], ["/anime/996/","Sailor Moon Sailor Stars"], ["/anime/949/","Gunbuster!"], ["/anime/18677/","Yuushibu"], ["/manga/86635/","Kaguya-sama wa Kokurasetai"], ["/anime/17074/","Monogatari Second Season"], ["/anime/20910/","Shimoseka"] ]; let aliasFlag = false; if(useScripts.shortRomaji){ shortRomaji.forEach(createAlias); aliasFlag = true; } if(localStorageAvailable){ const titleAliases = JSON.parse(localStorage.getItem("titleAliases")); if(titleAliases){ aliasFlag = true; titleAliases.forEach(createAlias); } } if(aliasFlag){ moreStyle.textContent += ` a.title::before ,.quick-search-results .el-select-dropdown__item a > span::before{ visibility: visible; font-size: 5000%; line-height: 1.15; margin-right: 2px; } .medialist.table .title > a::before{ visibility: visible; font-size: 1.5rem; margin-right: 2px; } .medialist.compact .title > a::before ,.medialist.cards .title > a::before ,.home .status > a.title::before ,.media-embed .title::before{ visibility: visible; font-size: 1.3rem; margin-right: 2px; } .role-card a.content > .name::before{ visibility: visible; font-size: 1.2rem; } .overlay > a.title::before ,.media-preview-card a.title::before{ visibility: visible; font-size: 1.4rem; line-height: 1.15; }`; } if(useScripts.CSSfavs || useScripts.CSSstudioStats){ /*adds a logo to most favourite studio entries. Add more if needed */ const favStudios = [ [1, "Studio-Pierrot", "https://upload.wikimedia.org/wikipedia/en/thumb/1/10/Studio_Pierrot.jpg/220px-Studio_Pierrot.jpg","studio"], [2, "Kyoto-Animation", "https://upload.wikimedia.org/wikipedia/en/thumb/b/bf/Kyoto_Animation_logo.svg/250px-Kyoto_Animation_logo.svg.png","studio"], [3, "GONZO", "https://upload.wikimedia.org/wikipedia/commons/thumb/8/85/Gonzo_company.png/220px-Gonzo_company.png","studio"], [4, "BONES", "https://i.stack.imgur.com/7pRQn.png","studio"], [6, "Gainax", "https://upload.wikimedia.org/wikipedia/en/thumb/a/a8/Gainax_logo.svg/220px-Gainax_logo.svg.png","studio"], [7, "JC-Staff", "https://upload.wikimedia.org/wikipedia/commons/thumb/f/f5/J.C.Staff_Logo.svg/220px-J.C.Staff_Logo.svg.png","studio"], [8, "Artland", "https://upload.wikimedia.org/wikipedia/en/thumb/a/ae/Artland_logo.gif/200px-Artland_logo.gif","studio"], [10, "Production-IG", "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5a/Production_I.G_Logo.svg/250px-Production_I.G_Logo.svg.png","studio"], [11, "MADHOUSE", "https://upload.wikimedia.org/wikipedia/commons/thumb/4/44/Madhouse_studio_logo.svg/300px-Madhouse_studio_logo.svg.png","studio"], [13, "Studio-4C", "https://upload.wikimedia.org/wikipedia/en/e/ec/Studio_4C_logo.png","studio"], [14, "Sunrise", "https://upload.wikimedia.org/wikipedia/en/thumb/8/8c/Sunrise_company_logo.svg/220px-Sunrise_company_logo.svg.png","studio"], [17, "Aniplex", "https://upload.wikimedia.org/wikipedia/commons/thumb/3/37/Aniplex_logo.svg/220px-Aniplex_logo.svg.png",""], [18, "Toei-Animation", "https://i.stack.imgur.com/AjzVI.png","studio",76,30], [21, "Studio-Ghibli", "https://upload.wikimedia.org/wikipedia/en/thumb/c/ca/Studio_Ghibli_logo.svg/220px-Studio_Ghibli_logo.svg.png","studio",76,30], [22, "Nippon-Animation", "https://upload.wikimedia.org/wikipedia/en/thumb/b/b4/Nippon.png/200px-Nippon.png","studio"], [25, "Milky-Animation-Label", "https://img.fireden.net/a/image/1467/16/1467164781976.png","studio"], [27, "Xebec", "https://upload.wikimedia.org/wikipedia/fr/b/bd/Logo_Xebec.svg","studio"], [28, "Oriental-Light-and-Magic","https://i.stack.imgur.com/Sbllv.png","studio"], [32, "Manglobe", "https://i.imgur.com/W8U74wO.png","studio"], [34, "Hal-Film-Maker", "https://upload.wikimedia.org/wikipedia/commons/thumb/0/09/Hal_film_maker_logo.gif/220px-Hal_film_maker_logo.gif","studio"], [35, "Seven-Arcs", "https://upload.wikimedia.org/wikipedia/en/a/ac/Seven_Arcs_logo.png","studio",76,25], [36, "Studio-Gallop", "https://upload.wikimedia.org/wikipedia/commons/3/37/Studio_Gallop.png","studio"], [37, "Studio-DEEN", "https://upload.wikimedia.org/wikipedia/commons/thumb/4/47/Studio_Deen_logo.svg/220px-Studio_Deen_logo.svg.png","studio"], [38, "Arms", "https://upload.wikimedia.org/wikipedia/commons/thumb/f/f4/Arms_Corporation.png/200px-Arms_Corporation.png","studio"], [41, "Satelight", "https://i.stack.imgur.com/qZVQg.png","studio",76,30], [43, "ufotable", "https://upload.wikimedia.org/wikipedia/en/5/56/Ufotable-Logo.png","studio",76,30], [44, "Shaft", "https://i.stack.imgur.com/tuqhK.png","studio"], [45, "Pink-Pineapple", "https://i.stack.imgur.com/2NMQ0.png","studio"], [47, "Studio-Khara", "https://i.stack.imgur.com/2d1TT.png","studio",76,30], [48, "AIC", "https://upload.wikimedia.org/wikipedia/commons/thumb/6/6b/AIC_logo.png/220px-AIC_logo.png","studio"], [51, "diomeda", "https://i.stack.imgur.com/ZHt3T.jpg","studio"], [53, "Dentsu", "https://upload.wikimedia.org/wikipedia/commons/thumb/1/10/Dentsu_logo.svg/200px-Dentsu_logo.svg.png",""], [58, "Square-Enix", "https://upload.wikimedia.org/wikipedia/commons/thumb/a/af/Square_Enix_logo.svg/230px-Square_Enix_logo.svg.png",""], [65, "Tokyo-Movie-Shinsha", "https://upload.wikimedia.org/wikipedia/en/2/22/Tokyo_Movie_Shinsha.png","studio"], [66, "Key", "https://upload.wikimedia.org/wikipedia/commons/thumb/1/1f/Key_Visual_Arts_Logo.svg/167px-Key_Visual_Arts_Logo.svg.png","",76,25], [68, "Mushi-Productions", "https://i.stack.imgur.com/HmYdT.jpg","studio"], [73, "TMS-Entertainment", "https://upload.wikimedia.org/wikipedia/commons/thumb/b/b9/TMS_Entertainment_logo.svg/220px-TMS_Entertainment_logo.svg.png","studio"], [79, "Genco", "https://www.thefilmcatalogue.com/assets/company-logos/5644/logo_en.png",""], [86, "Group-TAC", "https://upload.wikimedia.org/wikipedia/commons/b/b7/Group_TAC.png","studio"], [91, "feel", "https://upload.wikimedia.org/wikipedia/en/thumb/0/07/Feel_%28company%29_logo.png/220px-Feel_%28company%29_logo.png","studio",76,25], [95, "Doga-Kobo", "https://upload.wikimedia.org/wikipedia/commons/thumb/a/a8/Doga_Kobo_Logo.svg/220px-Doga_Kobo_Logo.svg.png","studio"], [97, "ADV-Films", "https://upload.wikimedia.org/wikipedia/en/4/45/A.D._Vision_%28logo%29.png","licensor"], [102, "FUNimation-Entertainment","https://upload.wikimedia.org/wikipedia/commons/thumb/4/47/Funimation_2016.svg/320px-Funimation_2016.svg.png","licensor"], [103, "Tatsunoko-Production", "https://upload.wikimedia.org/wikipedia/commons/thumb/7/7a/Tatsunoko_2016_logo.png/300px-Tatsunoko_2016_logo.png","studio"], [104, "Lantis", "https://upload.wikimedia.org/wikipedia/commons/3/39/Lantis_logo.png",""], [108, "Media-Factory", "https://i.stack.imgur.com/rR7yU.png","",76,25], [112, "Brains-Base", "https://upload.wikimedia.org/wikipedia/commons/thumb/0/00/Brain%27s_Base_logo.png/200px-Brain%27s_Base_logo.png","studio"], [113, "Kadokawa-Shoten", "https://i.stack.imgur.com/ZsUDR.gif",""], [119, "Viz-Media", "https://upload.wikimedia.org/wikipedia/en/thumb/e/e9/Viz_Media_logo.png/220px-Viz_Media_logo.png","licensor"], [132, "PA-Works", "https://i.stack.imgur.com/7kjSn.png","studio"], [143, "Mainichi-Broadcasting", "https://upload.wikimedia.org/wikipedia/commons/thumb/e/e9/Mainichi_Broadcasting_System_logo.svg/200px-Mainichi_Broadcasting_System_logo.svg.png",""], [144, "Pony-Canyon", "https://i.stack.imgur.com/9kkew.png",""], [145, "TBS", "https://upload.wikimedia.org/wikipedia/commons/thumb/f/f8/TBS_logo.svg/200px-TBS_logo.svg.png",""], [150, "Sanrio", "https://upload.wikimedia.org/wikipedia/en/thumb/4/41/Sanrio_logo.svg/220px-Sanrio_logo.svg.png",""], [159, "Kodansha", "https://upload.wikimedia.org/wikipedia/commons/thumb/4/4c/Kodansha.png/200px-Kodansha.png",""], [166, "Movic", "https://upload.wikimedia.org/wikipedia/commons/f/f3/Movic_logo.png",""], [167, "Sega", "https://upload.wikimedia.org/wikipedia/commons/thumb/6/63/Sega_logo.svg/200px-Sega_logo.svg.png",""], [169, "Fuji-TV", "https://upload.wikimedia.org/wikipedia/en/thumb/e/e9/Fuji_TV_logo.svg/225px-Fuji_TV_logo.svg.png","",76,30], [193, "Idea-Factory", "https://upload.wikimedia.org/wikipedia/en/e/eb/Idea_factory.gif",""], [196, "Production-Reed", "https://upload.wikimedia.org/wikipedia/fr/7/7d/Production_Reed_Logo.png","studio"], [199, "Studio-Nue", "https://i.stack.imgur.com/azzKH.png","studio"], [200, "Tezuka-Productions", "https://upload.wikimedia.org/wikipedia/fr/f/fe/Tezuka_Productions_Logo.png","studio"], [217, "The-Right-Stuf-International","","licensor"], [238, "ATX", "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c6/AT-X_logo.svg/150px-AT-X_logo.svg.png","",76,30], [247, "ShinEi-Animation", "https://i.stack.imgur.com/b2lcL.png","studio"], [250, "Media-Blasters", "","licensor"], [262, "Kadokawa-Pictures-USA", "https://i.stack.imgur.com/ZsUDR.gif",""], [284, "Central-Park-Media", "","licensor"], [287, "David-Production", "https://upload.wikimedia.org/wikipedia/en/thumb/7/75/David_production.jpg/220px-David_production.jpg","studio",76,30], [290, "Kinema-Citrus", "https://upload.wikimedia.org/wikipedia/commons/c/c0/Kinema_Citrus_logo.png","studio",76,25], [291, "CoMix-Wave", "https://upload.wikimedia.org/wikipedia/commons/thumb/8/8d/Cwflogo.png/150px-Cwflogo.png","studio"], [292, "AIC-Plus", "https://upload.wikimedia.org/wikipedia/commons/thumb/6/6b/AIC_logo.png/220px-AIC_logo.png","studio"], [300, "SILVER-LINK", "https://upload.wikimedia.org/wikipedia/commons/thumb/3/3d/Silver_Link_Logo.svg/220px-Silver_Link_Logo.svg.png","studio"], [309, "GoHands", "https://i.stack.imgur.com/pScIZ.jpg","studio"], [314, "White-Fox", "https://i.stack.imgur.com/lwG1T.png","studio",76,30], [333, "TYO-Animations", "https://i.stack.imgur.com/KRqAp.jpg","studio",76,25], [334, "Ordet", "https://i.stack.imgur.com/evr12.png","studio",76,30], [346, "Hoods-Entertainment", "https://i.stack.imgur.com/p7S0I.png","studio"], [352, "Kadokawa-Pictures-Japan","https://i.stack.imgur.com/ZsUDR.gif",""], [365, "PoRO", "https://i.stack.imgur.com/3rlAh.png","studio"], [372, "NIS-America-Inc", "https://upload.wikimedia.org/wikipedia/en/e/e7/Nis.png","licensor"], [376, "Sentai-Filmworks", "https://i.stack.imgur.com/JV8R6.png","licensor",74,30], [397, "Bridge", "https://i.imgur.com/4Qn4EmK.png","studio"], [415, "Warner-Bros", "","licensor"], [417, "Walt-Disney-Studios", "","licensor"], [418, "Studio-Gokumi", "https://i.stack.imgur.com/w1y22.png","studio"], [436, "AIC-Build", "https://upload.wikimedia.org/wikipedia/commons/thumb/6/6b/AIC_logo.png/220px-AIC_logo.png","studio"], [437, "Kamikaze-Douga", "https://img7.anidb.net/pics/anime/178777.jpg",""], [456, "Lerche", "https://i.stack.imgur.com/gRQPc.png","studio"], [459, "Nitroplus", "https://upload.wikimedia.org/wikipedia/en/thumb/0/09/Nitroplus_logo.png/220px-Nitroplus_logo.png",""], [467, "Discotek", "","licensor"], [493, "Aniplex-of-America", "https://upload.wikimedia.org/wikipedia/commons/thumb/3/37/Aniplex_logo.svg/220px-Aniplex_logo.svg.png","licensor"], [499, "The-Pokemon-Company-International","","licensor"], [503, "Nintendo-Co-Ltd", "https://upload.wikimedia.org/wikipedia/commons/thumb/0/0d/Nintendo.svg/220px-Nintendo.svg.png",""], [537, "SANZIGEN", "https://i.stack.imgur.com/CkuqH.png","",76,30], [541, "Seven", "","studio"], [555, "Studio-Chizu", "https://i.stack.imgur.com/h2RuH.gif","studio"], [561, "A1-Pictures", "https://i.stack.imgur.com/nBUYo.png","studio",76,30], [569, "MAPPA", "https://upload.wikimedia.org/wikipedia/commons/thumb/0/06/MAPPA_Logo.svg/220px-MAPPA_Logo.svg.png","studio"], [681, "ASCII-Media-Works", "https://upload.wikimedia.org/wikipedia/commons/thumb/f/f5/ASCII_Media_Works_logo.svg/220px-ASCII_Media_Works_logo.svg.png",""], [803, "Trigger", "https://upload.wikimedia.org/wikipedia/commons/thumb/6/63/Trigger_Logo.svg/220px-Trigger_Logo.svg.png","studio"], [783, "GKids", "https://upload.wikimedia.org/wikipedia/commons/thumb/c/ca/GKIDS_logo.svg/150px-GKIDS_logo.svg.png","licensor"], [829, "Studio-Jack", "","studio"], [839, "LIDENFILMS", "https://upload.wikimedia.org/wikipedia/en/6/6e/LidenFilms.png","studio",76,30], [858, "Wit-Studio", "https://i.stack.imgur.com/o3Rro.png","studio",76,30], [911, "Passione", "https://i.stack.imgur.com/YyEGg.jpg","studio"], [2524,"4Kids-Entertainment", "","licensor"], [4418,"8bit", "https://upload.wikimedia.org/wikipedia/en/e/ea/8-Bit_Animation_Studio.png","studio"], [6069,"Studio-3Hz", "https://i.stack.imgur.com/eD0oe.jpg","studio"], [6071,"Studio-Shuka", "https://upload.wikimedia.org/wikipedia/commons/f/fa/Shuka_studio.jpg","studio"], [6077,"Orange", "https://i.stack.imgur.com/ve9mm.gif","studio"], [6142,"Geno-Studio", "https://upload.wikimedia.org/wikipedia/en/thumb/f/f4/Genostudio.jpg/220px-Genostudio.jpg","",76,25], [6145,"Science-SARU", "https://i.stack.imgur.com/zo9Fx.png","studio"], [6222,"CloverWorks", "https://i.stack.imgur.com/9Fvr7.jpg","studio"], [6235,"SEK-Studio", "https://upload.wikimedia.org/wikipedia/commons/thumb/5/51/Flag_of_North_Korea.svg/125px-Flag_of_North_Korea.svg.png","studio",74,25] ]; let favStudioString = ""; if(useScripts.CSSfavs){ favStudioString += ` .favourites > div > .wrap > div, .favourites > div > .wrap > a{ /*make the spaces in the grid even*/ margin-bottom: 0px!important; margin-right: 0px!important; column-gap: 10px!important; } .user .overview{ grid-template-columns: 460px auto!important; } .favourites > div > .wrap{ padding: 0px!important; display: grid; grid-gap: 10px; column-gap: 10px!important; grid-template-columns: repeat(auto-fill,85px); grid-template-rows: repeat(auto-fill,115px); background: rgb(0,0,0,0) !important; width: 470px; } .favourite.studio{ cursor: pointer; min-height: 115px; font-size: 15px; display: grid; grid-gap: 10px; padding: 2px!important; padding-top: 8px!important; background-color: rgba(var(--color-foreground))!important; text-align: center; align-content: center; } .site-theme-dark .favourite.studio{ background-color: rgb(49,56,68)!important; } .favourite.studio::after{ display: inline-block; background-repeat: no-repeat; content:""; margin-left:5px; background-size: 76px 19px; width: 76px; height: 19px; }`; favStudios.forEach(function(studio){ if(studio[2] !== ""){ favStudioString += `.favourite.studio[href="/studio/${studio[0]}/${studio[1]}"]::after{background-image: url("${studio[2]}");`; if(studio.length === 6){ favStudioString += `background-size: ${studio[4]}px ${studio[5]}px;width: ${studio[4]}px;height: ${studio[5]}px;`; } favStudioString += "}"; } }); } if(useScripts.CSSstudioStats){ favStudios.forEach(function(studio){ if(studio[3] === "studio"){ favStudioString += `.stats-wrap .row a[href="/studio/${studio[0]}/${studio[1]}"],`; } }); favStudioString = favStudioString.replace(/,$/,""); favStudioString += "{color:rgb(var(--color-blue))}"; favStudios.forEach(function(studio){ if(studio[3] === "licensor"){ favStudioString += `.stats-wrap .row a[href="/studio/${studio[0]}/${studio[1]}"],`; } }); favStudioString = favStudioString.replace(/,$/,""); favStudioString += "{color:rgb(var(--color-green))}"; } moreStyle.textContent += favStudioString; } if(useScripts.CSScompactBrowse){ moreStyle.textContent += ` .search-page-unscoped.container{ padding-left: 10px; padding-right: 0px; } .search-page-unscoped .description{ display:none; } body,.search-page-unscoped .preview-section{ counter-reset: ranking; } .search-page-unscoped .data::before { left:2px; opacity:0.4; font-size:70%; position:absolute; counter-increment: ranking; content: counter(ranking); } .search-page-unscoped .media-card{ min-width:150px!important; grid-template-columns: 150px auto!important; height: 297px!important; width: 150px !important; } .search-page-unscoped .cover .overlay{ padding-left:8px!important; padding-right:8px!important; padding-top:4px!important; padding-bottom:14px!important; } .search-page-unscoped .grid-wrap > .media-card{ margin-left:30px; } .search-page-unscoped .media-card .cover{ width:150px; height:215px; margin-top:53px; z-index: 100; } .search-page-unscoped .data{ margin-left: -150px; } .search-page-unscoped .genres{ min-height:29px; z-index: 101; padding: 8px 5px!important; padding-bottom: 2px !important; font-size: 1rem!important; line-height: 1.15; } .search-page-unscoped .list-edit{ z-index: 101; } .search-page-unscoped .airing-countdown{ padding: 5px!important; } .search-page-unscoped .grid-wrap{ grid-template-columns: repeat(auto-fill, 150px) !important; } .search-page-unscoped .media{ grid-template-columns: repeat(auto-fill, 150px) !important; width:100%; } .search-page-unscoped .overlay .studio{ margin-top: 2px!important; margin-bottom: -8px!important; } .search-page-unscoped .list-status{ width: 20px!important; height: 20px!important; } .search-page-unscoped .media-card:nth-child(5){ display: inline-grid!important; } `; } if(useScripts.CSSsubmissionCounter){ moreStyle.textContent += ` .submissions-wrap{ counter-reset: acceptedCount partialCount pendingCount rejectedCount; } .submissions-wrap .submission .status.accepted{ counter-increment: acceptedCount; } .submissions-wrap .submission .status.accepted::after{ content: counter(acceptedCount); } .submissions-wrap .submission .status.pending{ counter-increment: pendingCount; } .submissions-wrap .submission .status.pending::after{ content: counter(pendingCount); } .submissions-wrap .submission .status.partially_accepted{ counter-increment: partialCount; } .submissions-wrap .submission .status.partially_accepted::after{ content: counter(partialCount); } .submissions-wrap .submission .status.rejected{ counter-increment: rejectedCount; } .submissions-wrap .submission .status.rejected::after{ content: counter(rejectedCount); } .submissions-wrap::after{ content: "pending: " counter(pendingCount) ", accepted: " counter(acceptedCount) ", partially accepted: " counter(partialCount) ", rejected: " counter(rejectedCount); } `; } if(useScripts.CSSprofileClutter){ moreStyle.textContent += ` .overview .list-stats > .footer{ display: none; } .overview > .section > .desktop:nth-child(2){ display: none; } .overview > .section > .desktop:nth-child(3){ display: none; } .overview > .section > .desktop.favourites{ display: inherit; } `; } if(useScripts.CSSfollowCounter){ moreStyle.textContent += ` .user-social .user-follow > div.wrap{ grid-template-columns: repeat(auto-fill,75px)!important; grid-template-rows: repeat(auto-fill,75px)!important; } body{ counter-reset: followCount; } .user-social .user-follow .user{ counter-increment: followCount; } .user-social .user-follow .user:nth-child(10n), .user-social .user-follow .user:last-child{ overflow: visible!important; } .user-social .user-follow .user:last-child::after{ content: "Total: " counter(followCount); position: relative; left: 85px; top: -48px; opacity: 0.5; } `; } if(useScripts.CSSgreenManga){ moreStyle.textContent += ` .activity-manga_list > div > div > div > div > .title{ color: rgba(var(--color-green))!important; } .media .relations .cover[href^="/manga/"] + div div{ color: rgba(var(--color-green)); } .media .relations .cover[href^="/anime/"] + div div{ color: rgba(var(--color-blue)); } .media .relations .cover[href^="/manga/"]{ border-bottom-style: solid; border-bottom-color: rgba(var(--color-green)); border-bottom-width: 2px; } .media .relations.small .cover[href^="/manga/"]::after{ position:absolute; left:1px; bottom:3px; content:""; border-style: solid; border-color: rgba(var(--color-green)); border-width: 2px; } .media .relations .cover[href^="/anime/"]{ border-bottom-style: solid; border-bottom-color: rgba(var(--color-blue)); border-bottom-width: 2px; } .media .relations .cover div.image-text{ margin-bottom: 2px!important; border-radius: 0px!important; padding-bottom: 8px!important; padding-top: 8px!important; font-weight: 500!important; } `; } if(useScripts.CSSexpandFeedFilters){ moreStyle.textContent += ` .home .activity-feed-wrap .section-header .el-dropdown-menu { background: none; position: static; display: inline !important; margin-right: 15px; box-shadow: none !important; } .home .activity-feed-wrap .section-header .el-dropdown-menu__item { font-weight: normal; color: rgb(var(--color-text-lighter)); margin-left: -2px !important; display: inline; font-size: 1.2rem; padding: 4px 15px 5px 15px; border-radius: 3px; transition: .2s; } .home .activity-feed-wrap .section-header .el-dropdown-menu__item.active{ background: none!important; color: rgb(var(--color-blue)); } .home .activity-feed-wrap .section-header .el-dropdown-menu__item:hover{ background: none!important; color: rgb(var(--color-blue)); } .home .feed-select .feed-filter{ display: none; } `; } if(useScripts.CSSverticalNav){ moreStyle.textContent += ` .logo{ margin-left: -60px!important; /*the compact layout uses more of the space to the side, so we line up the logo to the left*/ } .footer{ margin-top: 0px !important; /*less space wasted over the footer*/ } .container{ padding-left: 10px; padding-right: 0px; } .hide{ top: 0px!important; /*stop that top bar from jumping all over the place*/ } .notification{ margin-bottom: 10px!important; } /*Dropdown menus are site theme based*/ .quick-search .el-select .el-input .el-input__inner, .quick-search .el-select .el-input.is-focus .el-input__inner, .el-select-dropdown, .el-dropdown-menu, .el-dropdown-menu__item--divided::before{ background: rgba(var(--color-foreground)); } .el-select-dropdown__item.hover, .el-select-dropdown__item:hover{ background: rgba(159, 173, 189, .2); } .el-dropdown-menu__item--divided{ border-color: rgba(var(--color-background)); } .el-select-group__wrap:not(:last-of-type)::after{ background: rgba(var(--color-foreground)); } .el-popper[x-placement^="bottom"] .popper__arrow, .el-popper[x-placement^="bottom"] .popper__arrow::after{ border-bottom-color: rgba(var(--color-foreground)); } .el-popper[x-placement^="top"] .popper__arrow, .el-popper[x-placement^="top"] .popper__arrow::after{ border-top-color: rgba(var(--color-foreground)); } /*Additions to dark theme dropdown*/ .site-theme-dark .quick-search.el-select .el-input.el-input__inner, .site-theme-dark .quick-search .el-select .el-input.is-focus .el-input__inner, .site-theme-dark .el-select-dropdown, .site-theme-dark .el-dropdown-menu, .site-theme-dark .el-dropdown-menu__item--divided::before{ background: rgba(17, 22, 29); } .site-theme-dark .el-select-group__wrap:not(:last-of-type)::after{ background: rgba(17, 22, 29); } .site-theme-dark .el-popper[x-placement^="bottom"] .popper__arrow, .site-theme-dark .el-popper[x-placement^="bottom"] .popper__arrow::after{ border-bottom-color: rgba(17, 22, 29); opacity: 1; } .site-theme-dark .el-popper[x-placement^="top"] .popper__arrow, .site-theme-dark .el-popper[x-placement^="top"] .popper__arrow::after{ border-top-color: rgba(17, 22, 29); opacity: 1; } /*--------------VERTICAL-NAV----------------*/ /*code by Kuwabara: https://userstyles.org/styles/161017/my-little-anilist-theme-can-not-be-this-cute*/ div#nav { width: 65px; height: 100%; position: fixed!important; top: 0!important; left: 0!important; transition: none!important; } div#nav.transparent { background: rgba(var(--color-nav))!important; } .nav .wrap .links { font-size: 1rem; height: 355px; margin-left: 0px; padding-left: 0px; width: 65px; flex-direction: column; } .nav .wrap .links .link { width: 65px; padding: 5px 0px; margin-bottom: 10px; text-align: center; /*color: rgba(var(--color-blue),0.6);*/ transition: 0.3s; } .nav .wrap .links .link:hover { background: rgba(var(--color-blue),0.1); } .nav .wrap .links .link::before { display: block; content: ''; height: 24px; width: 65px; background-size: 24px; margin-left: 0; margin-bottom: 3px; background-repeat: no-repeat; background-position: center; } .nav .link[href="/home"]::before { background: url(); } .nav .link[href*="/user/"]::before { background: url(); } .nav .link[href*="/animelist"]::before { background: url(); } .nav .link[href*="/mangalist"]::before { background: url(); } .nav .link[href="/search/manga"]::before, .nav .link[href="/search/anime"]::before { background: url(); } .nav .link[href*="/forum"]::before { background: url(); } div#nav.transparent { background: #1f2631!important; /*background: rgba(var(--color-nav))!important;*/ } #app { margin-top: 0; padding-left: 65px; } .nav .user { position: fixed; top: 0; display: grid; grid-gap: 40px; width: 65px; grid-template-rows: 50px 20px; } .search .dropdown.el-dropdown { font-size: 10px; } .search .el-dropdown-link svg { width: 65px; height: 23px; padding: 5px 0; background: rgba(0, 0, 0, 0.2); } .nav .search { width: 65px; margin: 0; text-align: center; position: fixed; top: 56px; } .quick-search-results { z-index: 999!important; top: 136px!important; } .user .avatar:hover+.chevron { opacity: 0!important; } .hide { top:0px!important; } /*-------------------*/ ::selection { background: rgba(var(--color-blue),0.4); } ::-webkit-selection { background: rgba(var(--color-blue),0.4); } ::-moz-selection { background: rgba(var(--color-blue),0.4); } ::-webkit-scrollbar { width: 7px; height: 7px; } ::-webkit-scrollbar-thumb { background: #4e4e4e!important; } #app{ overflow:unset; } .user .header-wrap{ position: sticky; top: -332px; z-index: 100; } .list-stats{ margin-bottom:0px!important; } .activity-feed-wrap{ margin-top:25px; } .logo{ position: absolute; margin-bottom: -500px; display:none!important; margin-left: 0px !important; } /*home stuff*/ .reply .header a.name[href="/user/Abyss/"]::after{ content: "Prima Undine"; margin-left:10px; padding:3px; border-radius:2px; animation-duration: 20s; animation-iteration-count: infinite; animation-name: rainbow; animation-timing-function: ease-in-out; color: rgba(var(--color-white)); } .reply .header a.name[href="/user/Taluun/"]::after{ content: "Best Friend"; margin-left:10px; padding:3px; border-radius:2px; animation-duration: 20s; animation-iteration-count: infinite; animation-name: rainbow; animation-timing-function: ease-in-out; color: rgba(var(--color-white)); } .details > .donator-badge{ left:105px!important; padding:2px!important; top: 100%!important; -ms-transform: translate(0px, -34px); -webkit-transform: translate(0px, -34px); transform: translate(0px, -34px); } .activity-text > div > div > div > .donator-badge{ position:relative!important; display:inline-block!important; left:0px!important; top:-10px!important; -ms-transform: translate(0px, 0px); -webkit-transform: translate(0px, 0px); transform: translate(0px, 0px); } .activity-replies{ margin-top:5px!important; margin-left:30px!important; margin-right:0px!important; } .activity-entry{ margin-bottom: 10px!important; } .list-preview{ grid-gap: 10px!important; padding:0px!important; background: rgb(0,0,0,0)!important; } .home{ grid-column-gap: 30px!important; margin-top: 20px!important; grid-template-columns: auto 470px!important; } .activity-feed .reply{ padding:8px!important; margin-bottom: 5px!important; } .list .details{ padding-left:10px!important; padding-top:5px!important; padding: 10px 16px!important; padding-bottom: 7px !important; } .search{ margin-top:0px!important; } .emoji-spinner{ display:none!important; } .wrap{ border-radius: 2px!important; } .name{ margin-left: 0px!important; } .activity-text > div > div > div > .name{ margin-left: 12px!important; } .button{ margin-right: 5px!important; } .actions{ margin-bottom: 5px!important; bottom: 0px!important; } .status{ display: inline-block!important; } .avatar{ display: block!important; } /*https://anilist.co/activity/29333544*/ .activity-entry .header a:nth-child(1){ display: inline-block!important; } .wrap > .list{ min-height: 80px!important; grid-template-columns: 60px auto!important; } .popper__arrow{ display: none!important; } .media-preview{ grid-gap: 10px!important; padding: 0px!important; background: rgb(0,0,0,0)!important; } .media-preview-card{ display: inline-grid!important; } .replies > .count{ color: rgba(var(--color-blue)); } .action.likes{ color: unset; } .like-wrap > .button:hover{ color: rgba(var(--color-red)); } .replies > *:nth-child(2){ color: rgba(var(--color-blue)); } .actions{ cursor: default; } .activity-manga_list > div > div > div > div > .title{ color: rgba(var(--color-green))!important; } .markdown-editor > [title="Image"], .markdown-editor > [title="Youtube Video"], .markdown-editor > [title="WebM Video"]{ color: rgba(var(--color-red)); } .markdown-editor > div > svg{ min-width: 1em!important; } .feed-select .toggle > div.active[data-v-f37b0a84]{ color: rgba(var(--color-blue))!important; } .home .details .status:first-letter, .social .details .status:first-letter { text-transform:lowercase; } .activity-edit .markdown-editor, .activity-edit .input{ margin-bottom: 10px!important; } .activity-edit .actions{ margin-bottom: 25px!important; } .like-wrap .users{ overflow-y: scroll!important; } .page-content .container .home.full-width{ grid-template-columns: unset !important; } .activity-text .text { border-left: solid 5px rgba(var(--color-blue)); } .section-header{ padding-left:0px!important; } .cover[href="/anime/440/Shoujo-Kakumei-Utena/"] + .details{ border-color: #eb609e; border-width: 4px; border-style: solid; border-left-width: 0px; } .sticky .avatar, .sticky .body-preview, .sticky .categories, .sticky .name{ display: none!important; } .search > .filter, .search > .preview{ margin-top: 20px; } `; } if(useScripts.CSSdecimalPoint){ moreStyle.textContent += ` .medialist.POINT_10_DECIMAL .score[score="10"]::after, .medialist.POINT_10_DECIMAL .score[score="9"]::after, .medialist.POINT_10_DECIMAL .score[score="8"]::after, .medialist.POINT_10_DECIMAL .score[score="7"]::after, .medialist.POINT_10_DECIMAL .score[score="6"]::after, .medialist.POINT_10_DECIMAL .score[score="5"]::after, .medialist.POINT_10_DECIMAL .score[score="4"]::after, .medialist.POINT_10_DECIMAL .score[score="3"]::after, .medialist.POINT_10_DECIMAL .score[score="2"]::after, .medialist.POINT_10_DECIMAL .score[score="1"]::after{ margin-left:-4px; content: ".0"; } `; } if(useScripts.CSSsmileyScore){ moreStyle.textContent += ` .fa-frown{ color: red; } .fa-smile{ color: green; } `; } if(useScripts.limitProgress8){ moreStyle.textContent += ` .home:not(.full-width) .media-preview-card:nth-child(n+9){ display:none!important; } `; } else if(useScripts.limitProgress10){ moreStyle.textContent += ` .home:not(.full-width) .media-preview-card:nth-child(n+11){ display:none!important; } `; } if(useScripts.CSS3d){ moreStyle.textContent += ` .logo::after{ background-image: url("https://i.stack.imgur.com/KZoCH.jpg"); } .media-preview-card, .thread-card, .review-card, .activity-entry{ transform: skewX(-15deg); box-shadow: 12px 12px 3px 1px rgba(7, 7, 7, 0.5); border-top-style: solid; border-top-width: 1px; border-left-style: solid; border-left-width: 1px; } .activity-entry{ margin-left: 20px; margin-bottom: 25px!important; border-radius: 10px; } .activity-entry .wrap{ background-image: linear-gradient(to bottom right, rgb(rgb(80,130,123)), rgb(var(--color-foreground-grey)))!important; } .feed-type-toggle .active{ transform: translate(0px,3px); } .title, .embed, .name, .votes, .donator-badge, .status, .avatar, .reply, textarea, .feed-type-toggle, #nav, time{ box-shadow: 5px 5px 3px 1px rgba(7, 7, 7, 0.5); } .activity-entry .cover{ box-shadow: 5px 5px 3px 1px rgba(7, 7, 7, 0.5); transform: translate(3px, -10px); margin-top: 15px; border-top-style: solid; border-top-width: 1px; border-left-style: solid; border-left-width: 1px; } .reply{ margin-right: 10px; margin-bottom: 15px!important; } .action.replies, .links .link, .category, .notification-dot, .like-wrap{ filter: drop-shadow(5px 5px 1px black); } .list-preview, .media-preview{ padding-right: 10px !important; background: none !important; } .content{ z-index: 101!important; } image{ filter: saturate(200%); } `; } document.getElementsByTagName("head")[0].appendChild(moreStyle); const queryMediaList = ` query ($name: String!, $listType: MediaType) { MediaListCollection (userName: $name, type: $listType) { lists { name isCustomList entries { ... mediaListEntry } } } } fragment mediaListEntry on MediaList { mediaId status progress progressVolumes repeat notes startedAt { year month day } media { episodes chapters volumes duration nextAiringEpisode { episode } format title { romaji } tags { name } genres } scoreRaw: score (format: POINT_100) } `; const queryMediaListNotes = ` query ($name: String!, $listType: MediaType) { MediaListCollection (userName: $name, type: $listType) { lists { entries { ... mediaListEntry } } } } fragment mediaListEntry on MediaList { mediaId notes } `; const queryActivity = ` query ($id: Int!) { Activity(id: $id) { ... on TextActivity { id userId type text user { id name avatar { large } } likes { id } replies { text(asHtml: true) user { name } likes { name } } } ... on ListActivity { id userId type status progress user { id name avatar { large } } media { coverImage { large } } likes { id } replies { text(asHtml: true) user { name } likes { name } } } ... on MessageActivity { id type likes { id } replies { text(asHtml: true) user { name } likes { name } } } } } `; var activityCache = {};//reduce API calls even if localStorage is not available. var handleResponse = function(response){//generic handling of API responses return response.json().then(function(json){ return (response.ok ? json : Promise.reject(json)); }); }; var handleError = function(error){ console.error(error);//not much more we can do. As most modules are independent an non-critical, it's better to just log the error and keep stuff running. }; const url = "https://graphql.anilist.co";//Current Anilist API location var listActivityCall = function(query,variables,callback,vars,cache){ /* query, graphql request vars, just, values to pass on to the callback function cache::true, use cached data if available cache::false, allways fetch new data */ let handleData = function(data){ pending[variables.id] = false; if(localStorageAvailable){ localStorage.setItem(variables.id + "",JSON.stringify(data)); aniscriptsUsed.keys.push(variables.id); if(aniscriptsUsed.keys.length > 1000){//don't hog to much of localStorage localStorage.removeItem(aniscriptsUsed.keys[0]); aniscriptsUsed.keys.shift(); } localStorage.setItem("aniscriptsUsed",JSON.stringify(aniscriptsUsed)); } else{ activityCache[variables.id] = data;//still useful even if we don't have localstorage } callback(data,vars); }; let options = {//generic headers provided by API examples method: "POST", headers: { "Content-Type": "application/json", "Accept": "application/json" }, body: JSON.stringify({ "query": query, "variables": variables }) }; if(localStorageAvailable && cache){ let localStorageItem = localStorage.getItem(variables.id + ""); if(!(localStorageItem === null)){ callback(JSON.parse(localStorageItem),vars); return; } } else if(activityCache.hasOwnProperty(variables.id) && cache){ callback(activityCache[variables.id],vars); return; } fetch(url,options).then(handleResponse).then(handleData).catch(handleError); ++document.APIcallsUsed; }; function generalAPIcall(query,variables,callback){//has no cache stuff to worry about, use this for all other calls to the API let handleData = function(data){ callback(data,variables); }; let options = { method: "POST", headers: { "Content-Type": "application/json", "Accept": "application/json" }, body: JSON.stringify({ "query": query, "variables": variables }) }; fetch(url,options).then(handleResponse).then(handleData).catch(handleError); ++document.APIcallsUsed; } function enhanceSocialTab(){//who wrote this trash code? let perform = function(){ if(!document.URL.match(/^https:\/\/anilist\.co\/(anime|manga)\/\d*\/[\w\-]*\/social/)){ return; } var listOfActs = Array.from(document.getElementsByClassName("activity-entry")); listOfActs.forEach(function(act){//compress activities without comments, they are all the same media entry anyway if( !act.hasOwnProperty("marked") && !(act.children[0].children[2].children[0].children.length > 1) ){ act.marked = true; act.children[0].children[0].removeChild(act.children[0].children[0].children[0]);//remove cover image var elements = act.children[0].children[0].children[0].children; elements[2].parentNode.insertBefore(elements[2],elements[0]);//move profile picture to the beginning of the line elements[0].parentNode.parentNode.style.minHeight = "70px"; elements[0].parentNode.classList.add("hohSocialTabActivityCompressedContainer"); elements[0].style.verticalAlign = "bottom"; elements[0].style.marginTop = "0px"; elements[1].classList.add("hohSocialTabActivityCompressedName"); elements[2].classList.add("hohSocialTabActivityCompressedStatus"); act.style.marginBottom = "10px"; } }); /*add average score to social tab*/ var listOfFollowers = Array.from(document.getElementsByClassName("follow")); var averageScore = 0; var averageCount = 0; listOfFollowers.forEach(function(follower){ if( follower.children.length === 4 ){ if(follower.children[3].nodeName != "svg"){ const followScore = follower.children[3].innerText.match(/\d+\.?\d*/g); if(followScore && followScore.length === 2){ averageScore += 100*followScore[0]/followScore[1]; averageCount++; } else if(followScore && followScore.length === 1){//star rating averageScore += (followScore[0]*20 - 10); averageCount++; } } else{//do count smiley scores, but with lower confidence const smileyScore = follower.children[3].dataset.icon; if(smileyScore === "frown"){ averageScore += (45)*0.5; averageCount += 0.5; } else if(smileyScore === "meh"){ averageScore += (60)*0.5; averageCount += 0.5; } else if(smileyScore === "smile"){ averageScore += (85)*0.5; averageCount += 0.5; } } } }); if(averageCount){ averageScore = averageScore/averageCount; var locationForIt = document.getElementById("averageScore"); if(!locationForIt){ locationForIt = document.createElement("span"); locationForIt.id = "averageScore"; document.getElementsByClassName("following")[0].insertBefore( locationForIt, document.getElementsByClassName("following")[0].children[0] ); } locationForIt.innerHTML = "average: " + averageScore.toFixed(1) + "/100";//fix rounding later } /*end average score*/ }; let tryAgain = function(){//loop the module until we leave that page setTimeout(function(){ perform(); if(document.URL.match(/^https:\/\/anilist\.co\/(anime|manga)\/\d*\/[\w\-]*\/social/)){ tryAgain(); } else{ activeScripts.socialTab = false; } },100); }; activeScripts.socialTab = true; perform(); tryAgain(); } function enhanceForum(){//purpose: reddit-style comment three collapse button let perform = function(){ if(!document.URL.match(/^https:\/\/anilist\.co\/forum\/thread\/.*/)){ return; } var comments = Array.from(document.getElementsByClassName("comment-wrap")); comments.forEach(function(comment){ if(!comment.hasOwnProperty("hohVisited")){ comment.hohVisited = true; let hider = document.createElement("span"); hider.innerText = "[-]"; hider.classList.add("hohForumHider"); hider.onclick = function(){ let parentComment = this.parentNode.parentNode; if(this.innerHTML === "[-]"){ this.innerText = "[+]"; parentComment.children[1].style.display = "none"; if(parentComment.parentNode.children.length > 1){ parentComment.parentNode.children[1].style.display = "none"; } } else{ this.innerText = "[-]"; parentComment.children[1].style.display = "block"; if(parentComment.parentNode.children.length > 1){ parentComment.parentNode.children[1].style.display = "block"; } } }; comment.children[0].children[0].insertBefore( hider, comment.children[0].children[0].children[0] ); } }); }; let tryAgain = function(){//loop the forum script until we leave that page setTimeout(function(){ perform(); if(document.URL.match(/^https:\/\/anilist\.co\/forum\/thread\/.*/)){ tryAgain(); } else{ activeScripts.forumComments = false; } },100); }; activeScripts.forumComments = true; perform(); tryAgain(); } function dubMarker(){ if(!document.URL.match(/^https:\/\/anilist\.co\/anime\/.*/)){ return; } if(document.getElementById("dubNotice")){ return; } const variables = { id: document.URL.match(/\/anime\/(\d+)\//)[1], page: 1, language: useScripts.dubMarkerLanguage.toUpperCase() }; const query = ` query ($id: Int!, $type: MediaType, $page: Int = 1, $language: StaffLanguage) { Media(id: $id, type: $type) { characters(page: $page, sort: [ROLE], role: MAIN) { edges { node { id } voiceActors (language: $language) { language } } } } } `; let dubCallback = function(data){ let dubNoticeLocation = document.getElementsByClassName("sidebar"); if(!dubNoticeLocation.length && document.URL.match(/^https:\/\/anilist\.co\/anime\/.*/)){ setTimeout(function(){ dubCallback(data); },200); return; } if(data.data.Media.characters.edges.reduce( (actors,a) => actors + a.voiceActors.length,0 )){//any voice actors for this language? if(document.getElementById("dubNotice")){ return; } let dubNotice = document.createElement("p"); dubNotice.id = "dubNotice"; dubNotice.innerText = useScripts.dubMarkerLanguage + " dub available"; dubNoticeLocation[0].insertBefore(dubNotice,dubNoticeLocation[0].firstChild); } }; generalAPIcall(query,variables,dubCallback); } function enhanceStaff(){//currently only adds a favourite count if(!document.URL.match(/^https:\/\/anilist\.co\/staff\/.*/)){ return; } let filterGroup = document.getElementsByClassName("content"); if(!filterGroup.length){ setTimeout(function(){ enhanceStaff(); },200);//may take some time to load return; } filterGroup = filterGroup[0]; let favCount = document.createElement("span"); favCount.id = "hohFavCount"; favCount.innerText; filterGroup.appendChild(favCount); const variables = {id: document.URL.match(/\/staff\/(\d+)\//)[1]}; const query = "query($id: Int!){Staff(id: $id){favourites}}"; let favCallback = function(data){ let favButton = document.getElementsByClassName("favourite"); if(data.data.Staff.favourites === 0 && favButton[0].classList.contains("isFavourite")){//safe to assume document.getElementById("hohFavCount").innerText = data.data.Staff.favourites+1; } else{ document.getElementById("hohFavCount").innerText = data.data.Staff.favourites; } if(favButton.length){ favButton[0].onclick = function(){ if(this.classList.contains("isFavourite")){ favCount.innerText = Math.max(parseInt(favCount.innerText)-1,0);//0 or above, just to avoid looking silly } else{ favCount.innerText = parseInt(favCount.innerText)+1; } }; } }; generalAPIcall(query,variables,favCallback); } function replaceStaffRoles(){ let URLstuff = document.URL.match(/^https:\/\/anilist\.co\/staff\/(\d+)\/.*/); if(!URLstuff){ return; }; if(document.getElementById("hoh-media-roles")){ return; }; let insertParent = document.querySelector(".media-roles"); if(!insertParent){ setTimeout(replaceStaffRoles,200); return; }; let hohMediaRoles = document.createElement("div"); hohMediaRoles.id = "hoh-media-roles"; let hohMediaRolesAnimeHeader = document.createElement("h4"); hohMediaRolesAnimeHeader.innerText = "Anime"; hohMediaRolesAnimeHeader.style.display = "none"; let hohMediaRolesAnime = document.createElement("div"); hohMediaRolesAnime.setAttribute("data-v-09607311",""); hohMediaRolesAnime.classList.add("grid-wrap"); hohMediaRolesAnime.style.margin = "10px"; let hohMediaRolesMangaHeader = document.createElement("h4"); hohMediaRolesMangaHeader.innerText = "Manga"; hohMediaRolesMangaHeader.style.display = "none"; let hohMediaRolesManga = document.createElement("div"); hohMediaRolesManga.setAttribute("data-v-09607311",""); hohMediaRolesManga.classList.add("grid-wrap"); hohMediaRolesManga.style.margin = "10px"; hohMediaRoles.appendChild(hohMediaRolesAnimeHeader); hohMediaRoles.appendChild(hohMediaRolesAnime); hohMediaRoles.appendChild(hohMediaRolesMangaHeader); hohMediaRoles.appendChild(hohMediaRolesManga); let hohMediaSort = document.createElement("div"); let sortText = document.createElement("span"); sortText.innerText = "Sort "; let sortSelect = document.createElement("select"); hohMediaSort.appendChild(sortText); let sortOptionAlpha = document.createElement("option"); sortOptionAlpha.innerText = "Alphabetical"; sortOptionAlpha.value = "alphabetical"; let sortOptionChrono = document.createElement("option"); sortOptionChrono.innerText = "Chronological"; sortOptionChrono.value = "chronological"; let sortOptionPopularity = document.createElement("option"); sortOptionPopularity.innerText = "Popularity"; sortOptionPopularity.value = "popularity"; let sortOptionLength = document.createElement("option"); sortOptionLength.innerText = "Length"; sortOptionLength.value = "length"; sortSelect.appendChild(sortOptionAlpha); sortSelect.appendChild(sortOptionChrono); sortSelect.appendChild(sortOptionPopularity); sortSelect.appendChild(sortOptionLength); hohMediaSort.appendChild(sortSelect); hohMediaSort.style.marginBottom = "10px"; insertParent.insertBefore(hohMediaRoles,insertParent.children[0]); insertParent.insertBefore(hohMediaSort,insertParent.children[0]); for(var i=2;ia.title.localeCompare(b.title)); mangaRolesList.sort((a,b)=>a.title.localeCompare(b.title)); } else if(sortSelect.value === "chronological"){ animeRolesList.sort(function(a,b){ if(a.startDate.year === b.startDate.year){ if(a.startDate.month === b.startDate.month){ if(a.startDate.day === b.startDate.day){ return 1; } else{ return a.startDate.day - b.startDate.day; }; } else{ return a.startDate.month - b.startDate.month; }; } else{ return a.startDate.year - b.startDate.year; }; }); mangaRolesList.sort(function(a,b){ if(a.startDate.year === b.startDate.year){ if(a.startDate.month === b.startDate.month){ if(a.startDate.day === b.startDate.day){ return 1; } else{ return a.startDate.day - b.startDate.day; }; } else{ return a.startDate.month - b.startDate.month; }; } else{ return a.startDate.year - b.startDate.year; }; }); } else if(sortSelect.value === "popularity"){ animeRolesList.sort((b,a)=>a.popularity > b.popularity); mangaRolesList.sort((b,a)=>a.popularity > b.popularity); } else if(sortSelect.value === "length"){ animeRolesList.sort(function(b,a){ if(a.episodes === b.episodes){ return a.duration - b.duration } else{ return a.episodes - b.episodes }; }); mangaRolesList.sort((b,a)=>a.chapters > b.chapters); }; const randomData = "data-v-2bb4b515"; if(animeRolesList.length){ hohMediaRolesAnimeHeader.style.display = "inline"; } else{ hohMediaRolesAnimeHeader.style.display = "none"; } if(mangaRolesList.length){ hohMediaRolesMangaHeader.style.display = "inline"; } else{ hohMediaRolesMangaHeader.style.display = "none"; } while(hohMediaRolesAnime.childElementCount){ hohMediaRolesAnime.removeChild(hohMediaRolesAnime.lastChild); }; animeRolesList.forEach(function(anime){ let roleCard = document.createElement("div"); roleCard.classList.add("role-card"); roleCard.classList.add("view-media"); roleCard.setAttribute(randomData,""); let media = document.createElement("div"); media.classList.add("media"); media.setAttribute(randomData,""); let cover = document.createElement("a") cover.classList.add("cover"); cover.href = "/anime/" + anime.id + "/" + anime.title.replace(/\s/g,"-"); cover.style.backgroundImage = "url(" + anime.image + ")"; cover.setAttribute(randomData,""); let content = document.createElement("a"); content.classList.add("content"); content.href = "/anime/" + anime.id + "/" + anime.title.replace(/\s/g,"-"); content.setAttribute(randomData,""); let name = document.createElement("div"); name.classList.add("name"); name.innerText = anime.title; if(useScripts.titleLanguage === "Native" && anime.titleNative){ name.innerText = anime.titleNative; } else if(useScripts.titleLanguage === "English" && anime.titleEnglish){ name.innerText = anime.titleEnglish; }; name.setAttribute(randomData,""); let role = document.createElement("div"); role.classList.add("role"); role.innerText = anime.role[0]; for(var i=1;ia.id - b.id); for(var i=1;ia.id - b.id); for(var i=1;i:(","Ew","Ugh","Hm","Ok","Nice","Ooh","Wow","Fave",":D"]; suffix = " " + shuureiSystem[data.data.MediaList.score]; } else if(data.data.MediaList.user.mediaListOptions.scoreFormat === "POINT_100"){ suffix = " " + data.data.MediaList.score + "/100"; } else if( data.data.MediaList.user.mediaListOptions.scoreFormat === "POINT_10_DECIMAL" || data.data.MediaList.user.mediaListOptions.scoreFormat === "POINT_10" ){ suffix = " " + data.data.MediaList.score + "/10"; } else if(data.data.MediaList.user.mediaListOptions.scoreFormat === "POINT_3"){ if(data.data.MediaList.score === 3){ suffix = svgAssets.smile; } else if(data.data.MediaList.score === 2){ suffix = svgAssets.meh; } else if(data.data.MediaList.score === 1){ suffix = svgAssets.frown; }; } else if( data.data.MediaList.user.mediaListOptions.scoreFormat === "POINT_5" ){ suffix = " " + data.data.MediaList.score + svgAssets.star; } if(data.data.MediaList.notes){ var commandMatches = data.data.MediaList.notes.match(/\$({.*})\$/); if(commandMatches){ try{ var noteContent = JSON.parse(commandMatches[1]); if(noteContent.hasOwnProperty("message")){ suffix += " " + noteContent.message; }; } catch(e){ console.log("Unable to parse JSON in list note"); }; }; }; if(data.data.MediaList.repeat > 0){ if(data.data.MediaList.media.type === "ANIME"){ suffix += " [rewatch"; } else{ suffix += " [reread"; } if(data.data.MediaList.repeat === 1){ suffix += "]"; } else{ suffix += " " + data.data.MediaList.repeat + "]"; } }; for(var j=0;j 205){//horrible test, but we have not markup to go from. Assumes the tag dropdown is the only one with more than that number of children bestGuess = i; }; }; if(bestGuess === false){ return; }; if(possibleTagContainers[bestGuess].hasOwnProperty("hohMarked")){ return; } else{ possibleTagContainers[bestGuess].hohMarked = true; }; var superBody = document.getElementsByClassName("el-dialog__body")[0]; var descriptionTarget = document.createElement("span"); descriptionTarget.id = "hohDescription"; superBody.insertBefore(descriptionTarget,superBody.children[2]); for(var i=0;i