您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
jkでタイムラインをスクロール
当前为
- // ==UserScript==
- // @name Heello Keyboard Shortcuts
- // @namespace http://userstyles.org
- // @description jkでタイムラインをスクロール
- // @author kawau
- // @match http://heello.com/*
- // @match https://heello.com/*
- // @version 0.7
- // ==/UserScript==
- // Navigation
- //
- // j: Next Ping
- // k: Previous Ping
- // gg: Scroll to top
- // shift+g: Scroll to bottom
- //
- // Actions
- //
- // e: Echo
- /****************************************************************
- * http://www.openjs.com/scripts/events/keyboard_shortcuts/
- * Version : 2.01.B
- * By Binny V A
- * License : BSD
- */
- shortcut = {
- 'all_shortcuts':{},//All the shortcuts are stored in this array
- 'add': function(shortcut_combination,callback,opt) {
- //Provide a set of default options
- var default_options = {
- 'type':'keydown',
- 'propagate':false,
- 'disable_in_input':true,
- '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
- var func = function(e) {
- 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(var i=0; k=keys[i],i<keys.length; 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;
- }
- };
- /**********************************************************/
- /* End of "shorcut.js" */
- /**********************************************************/
- // Add class name
- function add_class_name(obj,add_classes){
- var tmp_hash = new Array();
- var new_class_names = new Array();
- var class_names = obj.className.split(" ").concat(add_classes.split(" "));
- for(var i in class_names){if(class_names[i] != ""){tmp_hash[class_names[i]] = 0;}}
- for(var key in tmp_hash){new_class_names.push(key);}
- obj.className = new_class_names.join(" ");
- }
- // Delete class name
- function delete_class_name(obj,delete_classes){
- var new_class_names = new Array();
- var class_names = obj.className.split(" ");
- var delete_class_names = delete_classes.split(" ");
- for(var i in class_names){
- var flag = true;
- for(var j in delete_class_names){
- if(class_names[i] == delete_class_names[j]){flag = false;break;};
- }
- if(flag){new_class_names.push(class_names[i])}
- }
- obj.className = new_class_names.join(" ");
- }
- /*
- // Send Ping
- function shortPing(content) {
- var obj = new XMLHttpRequest();
- obj.open('POST', "https://heello.com/pings.json", true);
- obj.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
- obj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
- obj.send("text="+encodeURIComponent(content));
- }
- // Echo
- function shortEcho(id) {
- var obj = new XMLHttpRequest();
- obj.open('POST', "https://heello.com/pings/" + id + "/echo", true);
- obj.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
- obj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
- obj.send('');
- }
- // Like
- function shortLike(id) {
- var obj = new XMLHttpRequest();
- obj.open('POST', "https://heello.com/pings/" + id + "/like.json", true);
- obj.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
- obj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
- obj.send('');
- }
- // Button
- function clickPing(){
- var forms = document.getElementsByTagName('form');
- if (forms[0].getElementsByTagName('textarea')[0].value){
- document.querySelector('div.modal-buttons input[type="button"].grey-button').click();
- }
- if (forms[1]) {
- if (forms[1].getElementsByTagName('textarea')[0].value){
- forms[1].querySelector('input[type="button"].grey-button').click();
- }
- }
- document.activeElement.blur();
- }
- */
- // Scroll window
- function scrollStream(elm) {
- var body = document.body;
- var html = document.documentElement;
- var rect = elm.getBoundingClientRect();
- var pos = {
- "left": rect.left + (body.scrollLeft || html.scrollLeft),
- "top" : rect.top + (body.scrollTop || html.scrollTop) - (html.clientHeight)/2 + 90
- }
- window.scrollTo(body.scrollLeft || html.scrollLeft, pos.top);
- }
- // Initialization
- var userprofile = document.querySelector('ul#nav-buttons.nav-pills li.dropdown ul.dropdown-menu li a').href;
- var username = userprofile.replace('https://heello.com/', '');
- // Background-color of selected Ping
- var sh = document.styleSheets[0];
- sh.insertRule("div.hovered-stream-item {background-color: #eff8ff;}", sh.cssRules.length);
- var pnt = null;
- var cmf = false;
- var elements = document.getElementById('timeline');
- //var newPing = document.querySelector('span#nav-compose.black-button img');
- var click = function(n) {
- var e = document.createEvent('MouseEvents');
- e.initMouseEvent("click",true,true,window,0,0,0,0,0,false,false,false,false,0,null);
- n.dispatchEvent(e);
- };
- // Keyboard shortcuts
- // Navigation
- //
- // j: Next Ping
- shortcut.add('j', function() {
- var hov = elements.querySelector('div.hovered-stream-item');
- if (pnt === null) {
- add_class_name(elements.querySelector('div[data-id]'), 'hovered-stream-item');
- pnt = 0;
- } else if (pnt >= 0 && pnt < elements.querySelectorAll('div[data-id]').length-1) {
- delete_class_name(hov, 'hovered-stream-item');
- add_class_name(elements.querySelectorAll('div[data-id]')[pnt+1], 'hovered-stream-item');
- pnt++;
- }
- var hov2 = elements.querySelector('div.hovered-stream-item');
- if (hov2) {
- scrollStream(hov2);
- }
- });
- // k: Previous Ping
- shortcut.add('k', function() {
- var hov = elements.querySelector('div.hovered-stream-item');
- if (pnt === 0) {
- delete_class_name(hov, 'hovered-stream-item');
- pnt = null;
- } else if (pnt > 0) {
- delete_class_name(hov, 'hovered-stream-item');
- add_class_name(elements.querySelectorAll('div[data-id]')[pnt-1], 'hovered-stream-item');
- pnt--;
- }
- var hov2 = elements.querySelector('div.hovered-stream-item');
- if (hov2) {
- scrollStream(hov2);
- }
- });
- // shift+g: scroll to bottom
- shortcut.add('shift+g', function() {
- var hov = elements.querySelector('div.hovered-stream-item');
- var pings = elements.querySelectorAll('div[data-id]');
- if (pnt !== null && pnt < pings.length-1) {
- delete_class_name(hov, 'hovered-stream-item');
- }
- pnt = pings.length-1;
- add_class_name(pings[pnt], 'hovered-stream-item');
- scrollStream(pings[pnt]);
- });
- // Actions
- //
- // e: Echo
- shortcut.add('e', function() {
- // var id;
- var echolink;
- var hov = elements.querySelector('div.hovered-stream-item');
- if (hov) {
- echolink = hov.querySelector('a[href$="echo"]');
- // id = hov.getAttribute('data-id');
- } else {
- // id = elements.querySelector('div[data-id]').getAttribute('data-id');
- echolink = elements.querySelector('div[data-id] a[href$="echo"]');
- }
- // shortEcho(id);
- click(echolink);
- });
- /*
- // c: Repeat
- shortcut.add('c', function() {
- var content;
- var hov = elements.querySelector('div.hovered-stream-item');
- if (hov) {
- content = hov.querySelector('div.ping-text').textContent;
- } else {
- content = elements.querySelector('div.ping-text').textContent;
- }
- shortPing(content);
- });
- */
- // enter: Open Ping details
- shortcut.add('enter', function() {
- window.location.href = elements.querySelector('div.hovered-stream-item h3 small a').href;
- });
- /*
- // n: New Ping
- shortcut.add('n', function() {
- click(newPing);
- });
- // shift + enter: Send Ping
- // ctrl + enter : Send Ping
- shortcut.add('shift+enter', function() {
- clickPing();
- }, { 'disable_in_input': false});
- shortcut.add('ctrl+enter', function() {
- clickPing();
- }, { 'disable_in_input': false});
- */
- // Timelines
- //
- // g: Timeline Commands Flag ON
- // g g: Scroll to top
- shortcut.add('g', function() {
- if (cmf) {
- cmf = false;
- var hov = elements.querySelector('div.hovered-stream-item');
- if (hov) {
- delete_class_name(hov, 'hovered-stream-item');
- }
- pnt = null;
- window.scrollTo(document.body.scrollLeft || document.documentElement.scrollLeft, 0);
- } else {
- cmf = true;
- }
- });
- /*
- // g h: Home
- shortcut.add('h', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/';
- }
- });
- // r: Reply
- // g r: Replies
- shortcut.add('r', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/replies';
- } else {
- click(elements.querySelector('div.hovered-stream-item span.ping-reply img'));
- }
- });
- // g l: What's Happening?
- shortcut.add('l', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/live';
- }
- });
- // g p: Profile
- shortcut.add('p', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/' + username;
- }
- });
- // g s: Settings
- shortcut.add('s', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/account/settings';
- }
- });
- // f: Like
- // g f: Likes
- shortcut.add('f', function() {
- if (cmf) {
- cmf = false;
- window.location.href = '/' + username + '/likes';
- } else {
- var hov = elements.querySelector('div.hovered-stream-item');
- if (hov) {
- id = hov.getAttribute('data-id');
- shortLike(id);
- }
- }
- });
- //
- // esc: Close modal windows
- shortcut.add('esc', function() {
- cmf = false;
- var closeButtons = document.querySelectorAll("div.modal-title div.modal-title-close");
- for (var i=0; i<closeButtons.length; i++) {
- click(closeButtons[i]);
- }
- document.activeElement.blur();
- }, {'disable_in_input': false});
- */
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址