// ==UserScript== // @name sciDownload // @namespace http://tampermonkey.net/ // @version 1.1 // @description 优化sciencedirect // @author Polygon // @icon  // @match *://*/* // @grant unsafeWindow // @grant GM_xmlhttpRequest // @grant GM_download // @grant GM_addStyle // @grant GM_setValue // @grant GM_getValue // @grant GM_openInTab // @grant unsafeWindow // @connect * // @run-at document-end // @downloadURL none // ==/UserScript== (function() { 'use strict' const utils = { // api: 'https://service-1w9dk4gw-1307434782.hk.apigw.tencentcs.com/release/sciDownload', api: 'http://muise.icu:5000/sciDownload', doiRegex: new RegExp(/10\.\d{4,9}\/[-\._;\(\)\/:A-z0-9]+/), timeout: 25, autoMax: {b: true, time: 1}, // 如果缩小状态下,sciState内容改变是否自动最大化以及弹出后自动收回的时间 // 这个b会自动记忆,如果最后一次运行状态是min,下次自动min get switchState() { return GM_getValue('sciDownload-state', 'max') }, set switchState(value) { GM_setValue('sciDownload-state', value) }, color: { success: '#e74c3c', flash: '#00b894', fail: '#2c3e50' }, svg: { doi: ``, pdf: ``, switch: `` }, style() { let div = document.createElement('div') div.innerHTML = this.svg.doi div.style.opacity = '0' document.body.appendChild(div) this.progressTotaLength = div.querySelector('.progress').getTotalLength() document.body.removeChild(div) return ` #sciDownloadBox { display: flex; position: fixed; height: 40px; bottom: 75px; font-family: NexusSans,Arial,Helvetica,Lucida Sans Unicode,Microsoft Sans Serif,Segoe UI Symbol,STIXGeneral,Cambria Math,Arial Unicode MS,sans-serif; font-size: 18px; cursor: pointer; box-shadow: 0px 0px 20px rgba(0, 0, 0, .1); transition: left .23s ease-out, opacity .23s, right .23s ease-out; z-index: 9999999999; } #sciDownloadBox * { box-sizing: border-box; } #sciContent { position: relative; overflow: hidden; box-sizing: border-box; display: flex; height: 40px; align-items: center; justify-content: space-around; vertical-align: middle; white-space: nowrap; color: white; background-color: ${this.color.fail}; opacity: 0.72; transition: width .23s ease-out, opacity .23s, background-color .23s; } #sciContent[loading] #sciState .progress { opacity: 0; } #sciContent[loading]::before { content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0; background-color: white; z-index: -1; animation: loading 2.3s linear infinite; } @keyframes loading { from { opacity: 0; } 50% { opacity: 0.3; } to { opacity: 0; } } #sciSwitch { width: 40px; height: 40px; color: white; background-color: #00b894; opacity: 0.72; transition: width .23s ease-out, opacity .23s; z-index: 1; } #sciContent #sciState { position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; opacity: 1; } #sciContent #sciText { position: relative; overflow: hidden; height: 100%; display: flex; align-items: center; justify-content: center; color: white; padding-left: 5px; padding-right: 10px; opacity: 1; text-decoration: none; transition: width .23s ease-out; } #sciContent:hover { opacity: 0.99 !important; } #sciSwitch:hover { opacity: 1 !important; } /* left svg progress */ #sciContent #sciState .progressBox { transform: rotate(-90deg); } #sciContent #sciState .progress { stroke-dasharray: ${this.progressTotaLength}; stroke-dashoffset: ${this.progressTotaLength}; transition: stroke-dashoffset .23s linear; } #sciContent[progress] #sciState .progress { animation: progressOffset ${this.timeout}s linear forwards; } @keyframes rotator { from { transform: rotate(-90deg); } to { transform: rotate(180deg); } } #sciContent[download-noprogress] #sciState .progressBox { animation: rotator 2.3s linear infinite; } @keyframes dash { from { stroke-dashoffset: ${this.progressTotaLength}; } 50% { stroke-dashoffset: ${this.progressTotaLength / 4}; transform:rotate(135deg); } to { stroke-dashoffset: ${this.progressTotaLength}; transform:rotate(450deg); } } #sciContent[download-noprogress] #sciState .progress { stroke-dashoffset: 0; transform-origin: center; animation: dash 2.3s ease-in-out infinite; } @keyframes progressOffset { from { stroke-dashoffset: ${this.progressTotaLength}; } to { stroke-dashoffset: 0; } } @keyframes progressRecover { to { stroke-dashoffset: ${this.progressTotaLength}; } } /* progress animation */ @keyframes progress { to { width: 100%; } } /* switch button animation */ #sciSwitch svg .switch { transform: rotate(0deg); transform-origin: center center; transition: transform .23s ease-out .15s; } /* ripple effect */ #sciDownloadBox .ripple { position: absolute; background: #fff; transform: translate(-50%, -50%); pointer-events: none; border-radius: 50%; animation: ripple 1s linear; } @keyframes ripple{ from { width: 0px; height: 0px; opacity: 0.5; } to { width: 500px; height: 500px; opacity: 0; } } ` }, initBox(doi) { let createBox = () => { this.sciDownloadBox = document.createElement('div') this.sciDownloadBox.setAttribute('id', 'sciDownloadBox') this.sciDownloadBox.innerHTML = `