// ==UserScript== // @name PasteImage // @namespace http://tampermonkey.net/ // @version 0.1 // @description 全网粘贴图片为图床链接 // @author Polygon // @match *://*/* // @icon  // @grant GM_xmlhttpRequest // @grant GM_addStyle // @downloadURL none // ==/UserScript== (function() { 'use strict'; const notification = (function() { 'use strict'; GM_addStyle(` #notification { box-sizing: border-box; position: fixed; left: calc(50% - 365.65px / 2); display: flex; flex-direction: row; align-items: center; justify-content: center; height: 50px; background-color: #ff7675; border-radius: 50px; padding: 0 0px 0px 20px; top: -50px; transition: top .5s ease-out; z-index: 9999999999; font-family: Arial; } #notification .content { display: flex; align-items: center; justify-content: center; color: white; font-size: 25px; } #notification .closeBox { margin: 0 10px; transform: rotate(90deg); cursor: pointer; } #notification .closeBox .progress { margin: 0 10px; cursor: pointer; } #notification .closeBox .progress .circle { stroke-dasharray: 100; animation: progressOffset 0s linear; } @keyframes progressOffset { from { stroke-dashoffset: 100; } to { stroke-dashoffset: 0; } } `) return { open(info, timeout, autoClose=true) { let eles = document.querySelectorAll('#notification') for (let i=0;i ` document.body.appendChild(this.box) this.box.querySelector('.content').innerHTML = info let width = getComputedStyle(this.box).width this.box.style.left = `clac(50%-${width}/2)` this.box.querySelector('.closeBox .progress .circle').style['animation-duration'] = `${timeout}s` this.box.style.top = '100px' this.box.querySelector('.closeBox .progress').addEventListener('click', () => { console.log('you close...') this.close() console.log('you clear...') }) if (autoClose) { setTimeout(() => { console.log('timeout close...') this.close() console.log('timeout clear ...') }, timeout * 1000) } }, close(ele=null) { if (!ele) {ele=this.box} ele.style['transition-duration'] = '.23s' ele.style['transition-timing-function'] = 'eaer-out' ele.style.top = '-50px' setTimeout(() => { try { document.body.removeChild(this.box) } catch { console.log('clear') } }, 233) } } })() document.addEventListener('paste', function(event) { var items = (event.clipboardData && event.clipboardData.items) || []; var file = null; function insertText(obj, str) { obj.focus() if(document.selection) { var sel = document.selection.createRange(); sel.text = str; } else if(typeof obj.selectionStart === 'number' && typeof obj.selectionEnd === 'number') { var startPos = obj.selectionStart, endPos = obj.selectionEnd, cursorPos = startPos, tmpStr = obj.value; obj.value = tmpStr.substring(0, startPos) + str + tmpStr.substring(endPos, tmpStr.length); cursorPos += str.length; obj.selectionStart = obj.selectionEnd = cursorPos; } else { obj.value += str; } } if (items && items.length) { for (var i = 0; i < items.length; i++) { if (items[i].type.indexOf('image') !== -1) { notification.open('upload image...', 1) let fileObj = items[i].getAsFile(); console.log(fileObj) // https://www.cnblogs.com/hg-hsd/p/5999472.html var form = new FormData() form.append("image", fileObj) console.log(form) GM_xmlhttpRequest({ method: 'POST', url: 'https://yh-pic.ihcloud.net/api/jd.php', responseType: 'json', data: form, onload: function (res) { let imgURL = res.response.data.url console.log(imgURL) navigator.clipboard.writeText(imgURL) insertText(document.activeElement, imgURL) notification.open('success~', 1) } }) break; } } } }); })();