您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Fast reading of the micro blog!
// ==UserScript== // @name O Antagonista - Speed Reading // @namespace http://oantagonista.com/speedread // @version 0.9.3 // @description Fast reading of the micro blog! // @author ViZeke // @match https://www.oantagonista.com/ // @match http://www.oantagonista.com/ // @match https://www.oantagonista.com/pagina/* // @match http://www.oantagonista.com/pagina/* // @grant none // @require https://code.jquery.com/jquery-2.1.4.min.js // ==/UserScript== (function($) { 'use strict'; /** * http://www.openjs.com/scripts/events/keyboard_shortcuts/ * Version : 2.01.B * By Binny V A * License : BSD */ let shortcut = { 'all_shortcuts': {}, //All the shortcuts are stored in this array 'add': function(shortcut_combination, callback, opt) { //Provide a set of default options let default_options = { 'type': 'keydown', 'propagate': false, 'disable_in_input': false, 'target': document, 'keycode': false }; if (!opt) opt = default_options; else { for (var dfo in default_options) { if (typeof opt[dfo] == 'undefined') opt[dfo] = default_options[dfo]; } } var ele = opt.target; if (typeof opt.target == 'string') ele = document.getElementById(opt.target); var ths = this; shortcut_combination = shortcut_combination.toLowerCase(); //The function to be called at keypress let func = function(e) { let code; e = e || window.event; if (opt['disable_in_input']) { //Don't enable shortcut keys in Input, Textarea fields var element; if (e.target) element = e.target; else if (e.srcElement) element = e.srcElement; if (element.nodeType == 3) element = element.parentNode; if (element.tagName == 'INPUT' || element.tagName == 'TEXTAREA') return; } //Find Which key is pressed if (e.keyCode) code = e.keyCode; else if (e.which) code = e.which; var character = String.fromCharCode(code).toLowerCase(); if (code == 188) character = ","; //If the user presses , when the type is onkeydown if (code == 190) character = "."; //If the user presses , when the type is onkeydown var keys = shortcut_combination.split("+"); //Key Pressed - counts the number of valid keypresses - if it is same as the number of keys, the shortcut function is invoked var kp = 0; //Work around for stupid Shift key bug created by using lowercase - as a result the shift+num combination was broken var shift_nums = { "`": "~", "1": "!", "2": "@", "3": "#", "4": "$", "5": "%", "6": "^", "7": "&", "8": "*", "9": "(", "0": ")", "-": "_", "=": "+", ";": ":", "'": "\"", ",": "<", ".": ">", "/": "?", "\\": "|" }; //Special Keys - and their codes var special_keys = { 'esc': 27, 'escape': 27, 'tab': 9, 'space': 32, 'return': 13, 'enter': 13, 'backspace': 8, 'scrolllock': 145, 'scroll_lock': 145, 'scroll': 145, 'capslock': 20, 'caps_lock': 20, 'caps': 20, 'numlock': 144, 'num_lock': 144, 'num': 144, 'pause': 19, 'break': 19, 'insert': 45, 'home': 36, 'delete': 46, 'end': 35, 'pageup': 33, 'page_up': 33, 'pu': 33, 'pagedown': 34, 'page_down': 34, 'pd': 34, 'left': 37, 'up': 38, 'right': 39, 'down': 40, 'f1': 112, 'f2': 113, 'f3': 114, 'f4': 115, 'f5': 116, 'f6': 117, 'f7': 118, 'f8': 119, 'f9': 120, 'f10': 121, 'f11': 122, 'f12': 123 }; var modifiers = { shift: { wanted: false, pressed: false }, ctrl: { wanted: false, pressed: false }, alt: { wanted: false, pressed: false }, meta: { wanted: false, pressed: false } //Meta is Mac specific }; if (e.ctrlKey) modifiers.ctrl.pressed = true; if (e.shiftKey) modifiers.shift.pressed = true; if (e.altKey) modifiers.alt.pressed = true; if (e.metaKey) modifiers.meta.pressed = true; for (let i = 0; i < keys.length; i++) { let k = keys[i]; //Modifiers if (k == 'ctrl' || k == 'control') { kp++; modifiers.ctrl.wanted = true; } else if (k == 'shift') { kp++; modifiers.shift.wanted = true; } else if (k == 'alt') { kp++; modifiers.alt.wanted = true; } else if (k == 'meta') { kp++; modifiers.meta.wanted = true; } else if (k.length > 1) { //If it is a special key if (special_keys[k] == code) kp++; } else if (opt['keycode']) { if (opt['keycode'] == code) kp++; } else { //The special keys did not match if (character == k) kp++; else { if (shift_nums[character] && e.shiftKey) { //Stupid Shift key bug created by using lowercase character = shift_nums[character]; if (character == k) kp++; } } } } if (kp == keys.length && modifiers.ctrl.pressed == modifiers.ctrl.wanted && modifiers.shift.pressed == modifiers.shift.wanted && modifiers.alt.pressed == modifiers.alt.wanted && modifiers.meta.pressed == modifiers.meta.wanted) { callback(e); if (!opt['propagate']) { //Stop the event //e.cancelBubble is supported by IE - this will kill the bubbling process. e.cancelBubble = true; e.returnValue = false; //e.stopPropagation works in Firefox. if (e.stopPropagation) { e.stopPropagation(); e.preventDefault(); } return false; } } }; this.all_shortcuts[shortcut_combination] = { 'callback': func, 'target': ele, 'event': opt['type'] }; //Attach the function with the event if (ele.addEventListener) ele.addEventListener(opt['type'], func, false); else if (ele.attachEvent) ele.attachEvent('on' + opt['type'], func); else ele['on' + opt['type']] = func; }, //Remove the shortcut - just specify the shortcut and I will remove the binding 'remove': function(shortcut_combination) { shortcut_combination = shortcut_combination.toLowerCase(); var binding = this.all_shortcuts[shortcut_combination]; delete(this.all_shortcuts[shortcut_combination]); if (!binding) return; var type = binding.event; var ele = binding.target; var callback = binding.callback; if (ele.detachEvent) ele.detachEvent('on' + type, callback); else if (ele.removeEventListener) ele.removeEventListener(type, callback, false); else ele['on' + type] = false; } }; let addGlobalStyle = (css) => { var head, style; head = document.getElementsByTagName('head')[0]; if (!head) { return; } style = document.createElement('style'); style.type = 'text/css'; style.innerHTML = css; head.appendChild(style); }; function procArticles($articles){ $articles.each( (i, itemPost) => { let url = $(itemPost).first().find('.article_link').first().attr('href'); if(document.location.href.indexOf('https') === -1){ url = url.replace('https://', 'http://'); } $.get(url).success( response => { let $content = $(response).find('article.post .entry-content > p, article.post .entry-content > :not(div.container-banner-single)'); console.log($content); $(itemPost).attr('processed', 1); $(itemPost).find('p').remove(); $(itemPost).find('.readmore').parent().remove(); $(itemPost).find('iframe').remove(); $(itemPost).find('.fav').remove(); $(itemPost).find('.article_link').append($content); }); }); } let cleanAds = () => { $('div.banner').remove(); $('aside').remove(); $('ins').remove(); $('div.ob-widget').remove(); $('#div-gpt-leaderboard').remove(); $('.banners_content_home').remove(); $('article.post.sponsorship').remove(); }; let procArticle = true; let procClean = true; $(document).scroll( () => { if ( procArticle ){ setTimeout( () => { procArticles($('article.post[processed!=1]')); procArticle = true; }, 1000); } if ( procClean ){ setTimeout( () => { cleanAds(); procClean = true; }, 2000); } procArticle = false; procClean = false; }); function goToNextPost(){ console.log('j'); let headerHeight = 109; let scrollTop = $(document).scrollTop() + headerHeight; let $articles = $("article.post"); for(let i = 0; i < $articles.length; i++) { let $item = $($articles[i]); let itemTop = parseInt($item.position().top); if( scrollTop < itemTop - 1 ){ $(document).scrollTop( itemTop - headerHeight ); break; } } } //Init //Configurando Atalhos shortcut.add( "j", function () { goToNextPost(); return false; }); addGlobalStyle('#boxpost article.post { width: auto !important; }'); addGlobalStyle('article.post > div { display: flex; flex-direction: row-reverse; justify-content: space-between; }'); addGlobalStyle('body .page article.post a.share-alt { position: relative; bottom: inherit; right: inherit; flex: 1 1 20px; }'); addGlobalStyle('#boxpost article.post a.article_link { flex: 100 1 400px; }'); addGlobalStyle('#player-ao-vivo.playerfixo { margin: 0 780px; width: auto !important; min-height: 300px; min-width: 31%; }'); addGlobalStyle('.page .container > div { width: 100%; }'); cleanAds(); procArticles($('article.post[processed!=1]')); })(jQuery); //Init on global context $(document).ready( () => { //specific site function in case of overlay adds if (dclk_hide_overlay) { dclk_hide_overlay(); } });