您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Tính năng: hiện 1 số button khi bôi đen text
当前为
// ==UserScript== // @name lazyFingers // @version 0.1 // @description Tính năng: hiện 1 số button khi bôi đen text // @namespace idmresettrial // @author idmresettrial // @require http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js // @include * // @grant GM_getValue // @grant GM_setValue // @grant GM_setClipboard // @run-at document-end // ==/UserScript== this.$ = this.jQuery = jQuery.noConflict(true); // Do not run on frames or iframes if (window.top !== window.self) { return; } document.addEventListener('DOMContentLoaded', function () { $('body').append('<div id="lazyFingers"></div>'); $('head').append('<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css">'); $('head').append('<style>#lazyFingers{line-height:20px;z-index:999999;cursor:pointer;display:none;position:fixed;top:0;left:0;padding:0px 3px;border-radius:3px;background:#fdfefe;font-size:13px;color:#000;border:1px solid #ccc}#lazyFingers .lfbtn{display:table-cell;border-left:1px solid #ccc;padding:0px 5px;height:20px}#lazyFingers .lfbtn:hover{background:#f1f1f1}#lazyFingers .lfbtn.first-btn{border-left:none;margin-left:0px}#lazyFingers .lficon{line-height:13px;color:#333;position:relative;top:50%;transform:translateY(-50%)}#lazyFingers .lficon i{font-family:FontAwesome !important}</style>'); // var copyMe = ''; var textarea = ''; var body_mouseup = true; var buttons_selector = [ ]; var lazyFingers_html = ''; var buttons = { copy: { css: 'fa fa-files-o', txt: '', do : function () { clearTextSelection(); GM_setValue('copyMe', copyMe); GM_setClipboard(copyMe); } }, paste: { css: 'fa fa-clipboard', txt: '', do : function () { insertAtCursor(textarea, GM_getValue('copyMe', '')); } }, searchGG: { css: 'fa fa-search', txt: '', do : function () { window.open('https://www.google.com/?gws_rd=ssl#q=' + copyMe); } }, searchYT: { css: 'fa fa-youtube-play', txt: '', do : function () { window.open('https://www.youtube.com/results?search_query=' + copyMe); } }, searchZING: { css: 'fa fa-music', txt: '', do : function () { window.open('http://mp3.zing.vn/tim-kiem/bai-hat.html?q=' + copyMe); } }, linksvip: { css: '', txt: 'Linksvip', do : function () { window.open('http://linksvip.net/?link=' + copyMe + '&ref=idmresettrial'); } } }; /**/ $('html').on('mouseup', 'body', function (e) { if (body_mouseup) mu(e); }); $('html').on('mouseup', 'textarea,input', function (e) { body_mouseup = false; mu(e, this); setTimeout(function () { body_mouseup = true; }, 500); }); //*/ // $('html').on('keydown', 'textarea,input', function () { $('#lazyFingers').hide(); }); for (i = 0; i < Object.keys(buttons).length; i++) { lazyFingers_html += '<div id="' + Object.keys(buttons) [i] + '-btn" class="lfbtn" ><div class="lficon"><i class="' + buttons[Object.keys(buttons) [i]].css + '"></i><span>' + buttons[Object.keys(buttons) [i]].txt + '</span></div></div>'; buttons_selector[buttons_selector.length] = '#' + Object.keys(buttons) [i] + '-btn'; } buttons_selector = buttons_selector.join(','); $('#lazyFingers').append(lazyFingers_html); $('html').on('mouseup', buttons_selector, function (e) { var button = e.target.parentElement.parentElement.id.replace('-btn', ''); body_mouseup = false; buttons[button].do (); disappear(); setTimeout(function () { body_mouseup = true; }, 500); }); function display(e, show_what) { clearDisplay(); $('#lazyFingers').css({ 'left': e.clientX + 5, 'top': e.clientY + 5 }); show_what.sort(function (a, b) { return Object.keys(buttons).indexOf(a) - Object.keys(buttons).indexOf(b); }); $(show_what.map(function (val) { return '#' + val + '-btn'; }).join(',')).css('display', 'table-cell'); $('.first-btn').removeClass('first-btn'); $('#lazyFingers .lfbtn[style*="display: table-cell"]').first().addClass('first-btn'); $('#lazyFingers').fadeIn(200); } function disappear() { $('#lazyFingers').hide(); } function clearDisplay() { $('#lazyFingers, #lazyFingers .lfbtn').hide(); } function mu(e, el) { var show_what = [ ]; var txt = ''; var editable = (typeof el !== 'undefined'); var displayBtn = false; if (editable) { txt = getSelectedText2(el); textarea = el; } else { txt = getSelectedText1(); } if (txt.length) { copyMe = txt; show_what[show_what.length] = 'copy'; show_what[show_what.length] = 'searchGG'; show_what[show_what.length] = 'searchYT'; show_what[show_what.length] = 'searchZING'; if ((/fshare.vn\/file/i).test(copyMe)) show_what[show_what.length] = 'linksvip'; displayBtn = true; } if (editable) { show_what[show_what.length] = 'paste'; displayBtn = true; } if (displayBtn) display(e, show_what) else $('#lazyFingers').hide(); } function getSelectedText1() { if (window.getSelection) { return window.getSelection().toString(); } else if (document.selection) { return document.selection.createRange().text; } return ''; } function getSelectedText2(textComponent) { var selectedText; // IE version if (document.selection != undefined) { textComponent.focus(); var sel = document.selection.createRange(); selectedText = sel.text; } // Mozilla version else if (textComponent.selectionStart != undefined) { var startPos = textComponent.selectionStart; var endPos = textComponent.selectionEnd; selectedText = textComponent.value.substring(startPos, endPos) } return selectedText; } function clearTextSelection() { if (window.getSelection) { if (window.getSelection().empty) { // Chrome window.getSelection().empty(); } else if (window.getSelection().removeAllRanges) { // Firefox window.getSelection().removeAllRanges(); } } else if (document.selection) { // IE? document.selection.empty(); } } function insertAtCursor(myField, myValue) { //IE support if (document.selection) { myField.focus(); sel = document.selection.createRange(); sel.text = myValue; } //MOZILLA and others else if (myField.selectionStart || myField.selectionStart == '0') { var startPos = myField.selectionStart; var endPos = myField.selectionEnd; myField.value = myField.value.substring(0, startPos) + myValue + myField.value.substring(endPos, myField.value.length); } else { myField.value += myValue; } } });