您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Checks if the blogs you're following also follow you
当前为
- // ==UserScript==
- // @name DashPlus - Follow Back Checker
- // @namespace http://www.dashpl.us/
- // @description Checks if the blogs you're following also follow you
- // @include *www.tumblr.com/following
- // @include *www.tumblr.com/following/*
- // @version 2.0.2
- // @grant none
- // @run-at document-end
- // ==/UserScript==
- //var check_img = "";
- //var check_img = "%2F0tjP3zPked%2BrHcey1M3x9zoNNMPxHnSo4gLlqgEUH2P2HGGMK7HARgj6Qcdj8Bi5BDcRiCBSMoGucgyMJMgbAujEVOIrdSvAevMpdCcwYcy6CDXAM7kBTeym2ACJzk4vglajL2ThYUjMDV8EnuWPdPkEWLIPJ1obaTWmqgw393qMH8vsZuAYfoFNpzuoeL0mQYmVtjJQOO3gDTsG7DkIRLNp1SxJkXR7UxUizxaE%2FUVcZI2AV5JPKZQt2a0OvRqKimpV1nQdgDUz8dBDsp9DNoJ7O9C%2FAodYZpTmnGnppBBn9YFTrupyGOqsboOu3cWgVZNfGlJ4v1zmwpbr6roKh6liUm7xea4U0YkbgWbNmCs3uboMVucqlHP6acciB3gMv1kWmPO0g9gj2v9%2FY7f4L%2BBJgAK%2B%2FTCvBclH%2BAAAAAElFTkSuQmCC";
- //var question_img = "%2B1%2FcYJm6uTw4ps773f%2B2m4qu66IlTfCYwLfwdSDnCS8h7iEZevgDRraB7%2BlCwVeWUtvucI2s1VdJQmQYUo79qVaNZLwA9BqaoASAUrKiF%2F8ByhFgMlUfoC1X4K0wYxUpw%2Bk9gpwZRjZYgZoQcuzdawtGFs8F2lYBVlobI1l9ELC0dxqwmNtMhQDbHoxaZjcVIF1AC6ZcMB%2BFCqDTnCPjAmr4lZqc1y53xbhKrs2J4bF2KZTRwuYCJlyqaZfUZw0bqmjki0PzBWA%2B4hqjkGA38yDQNDMisfQv4C3AAHp3Vn27XeuSAAAAAElFTkSuQmCC";
- var idPrefix = "dashplus_follow_back_";
- var classPrefix = idPrefix;
- var followBackCss = '.'+classPrefix+'status{ float: left; font-family: tumblr-icons; font-size: 30px !important; font-weight: normal; height: 27px !important; margin: 4px 11px 4px 0; padding: 0 10px 0 6px !important; text-align: center; width: 13px; } .follower .info{ width: 358px; } .viewhide{ visibility: hidden; } .'+classPrefix+'sideblog{ padding: 0 14px 0 1px !important } .follower .poptica_header.popover_standalone{ margin-left: 42px; } .'+classPrefix+'status ~ .poptica_header.popover_standalone{ margin-left: 0px; }';
- function run(){
- document.getElementsByTagName('head')[0].insertAdjacentHTML('beforeend','<style type="text/css">' + followBackCss + '</style>');
- blogTabs = document.querySelectorAll('.tab_blogs .tab_blog:not(.tab_dashboard)');
- blogs = new Array();
- Array.prototype.forEach.call(blogTabs, function(blogTab){
- blogs.push(blogTab.getAttribute('id').slice(9));
- });
- me = blogs[0]; //Use the first blog from the user's sidebar by default
- drop_down_menu(blogs,me);
- run_check(me);
- }
- function drop_down_menu(blogs,me){
- //Construct a link
- var blogLink = document.createElement('div');
- blogLink.insertAdjacentHTML('beforeend', '<a href="//www.tumblr.com/blog/'+me+'">'+me+'</a>');
- //Create a container for the text and the link
- container = document.createElement('div');
- container.insertAdjacentHTML('beforeend',
- 'You are seeing blogs that follow ' + blogLink.outerHTML
- );
- //And put that container in another box
- div = document.createElement('div');
- div.insertAdjacentHTML('beforeend',container.outerHTML);
- div.className += ' grey_note';
- div.style.overflow = 'hidden';
- div.style.marginTop = '20px';
- div.setAttribute('id',idPrefix + 'sidebar_box');
- //And then add it to the sidebar
- document.getElementById('right_column').insertAdjacentHTML('beforeend',div.outerHTML);
- }
- function run_check(me){
- followerDivs = document.querySelectorAll('div#following div.follower');
- Array.prototype.forEach.call(followerDivs, function(followerDiv){
- if(followerDiv.className.indexOf(classPrefix + "checked") < 0){
- followerDiv.className += " " + classPrefix + "checked";
- var nameLink = followerDiv.querySelector('.info .name > a');
- if(nameLink !== null && 'null' !== nameLink){ //Because JavaScript fails at having a "continue" operator.
- var name = nameLink.innerHTML;
- console.log(name);
- if(name !== null && name !== ''){
- //Okay, now let's do an Ajax POST request
- var xhr = new XMLHttpRequest();
- xhr.open('GET',encodeURI('/svc/blog/followed_by?' + encodeURI('tumblelog='+me+'&query='+name)));
- xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
- xhr.onload = function(){
- var icon = document.createElement('div');
- icon.className += " " + classPrefix + "status";
- //The response has finished, let's check the response
- if(xhr.status == 200){ //If the response status is OK
- var data = JSON.parse(xhr.responseText); //Parse the JSON response
- //console.log(data);
- var followerRow = followerDiv.querySelector('.info');
- if(data.response.is_friend == 1){
- //The user is following back
- icon.className += " chrome green big";
- icon.innerHTML = "";
- }
- else{
- //The user is not following back
- icon.className += " chrome red big";
- icon.innerHTML = "";
- }
- }
- else if(xhr.status == 400){
- //The blog in question is a side-blog, and therefore cannot follow back.
- icon.className += " chrome big viewhide";
- icon.innerHTML = "";
- }
- else{ //If the response is anything other than OK.
- console.log("DashPlus Follow Back: Error fetching follow-back status.");
- console.log(xhr);
- }
- followerDiv.querySelector('.info').insertAdjacentHTML('afterend',icon.outerHTML);
- }
- xhr.send();
- }
- }
- }
- });
- }
- run();