// ==UserScript==
// @name div cursor demo🔧
// @description div follow cursor demo
// @namespace div_cursor
// @author Covenant
// @version 1.0.6
// @license MIT
// @homepage
// @match *://*/*
// @exclude file:///*
// @icon 
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_registerMenuCommand
// @connect
// @run-at document-body
// @noframes
// ==/UserScript==
var style_div_cursor;
var ary_div=[];
var timeoutID_1;
var timeoutID_2;
function create_style(textContent,id,class_name){
let style=create_node("style",class_name,true,document.body);
style.type='text/css';
style.id=id;
style.textContent=textContent;
return style;
}
if(document.body!=null){
style_div_cursor=create_style("","gm_user_css_div_cursor",["user_gm_css","css_div_cursor"]);
style_div_cursor.textContent+=`
.gm_cursor1, .gm_cursor2, .gm_cursor3{position:fixed;border-radius:50%;transform:translateX(-50%) translateY(-50%);pointer-events:none;left:-100px;top:50%;mix-blend-mode:difference;transition:all 300ms linear;z-index:9999999;cursor:pointer;color: #212529}
.gm_cursor1{background-color:#ffffff;height:0;width:0;z-index:9999999;border:8px solid;}
.gm_cursor2, .gm_cursor3{height:36px;width:36px;z-index:99998;transition:all .3s ease-out;}
.gm_cursor2.hover, .gm_cursor3.hover{transform:scale(2) translateX(-25%) translateY(-25%);border:none;}
.gm_cursor2{border:2px solid #ffffff;box-shadow:0 0 12px rgba(255,255,255,.2);}
.gm_cursor2.hover{background:white;box-shadow:0 0 0 rgba(255,255,255,.2);}\n`;
}
function create_div(class_name,is_appendChild,node,refNode){
let div=create_node("div",class_name,is_appendChild,node,refNode);
div.style.backgroundSize='contain';
div.style.backgroundRepeat='no-repeat';
div.lang='ja';
return div;
}
function create_node(tagname,class_name,is_appendChild,node,refNode){
let element=document.createElement(tagname);
element.id="";
/*if(Array.isArray(tagname)){
element=document.createElement(tagname[0]);
element.id=tagname[1];
}else if(typeof tagname==='string'){element=document.createElement(tagname);}//*/
if(Array.isArray(class_name)){
for(let i=0; i<class_name.length; i++){element.classList.add(class_name[i]);}
}else if(typeof class_name==='string'){element.classList.add(class_name);}
if(is_appendChild){node.appendChild(element);}else{node.insertBefore(element, refNode);}
return element;
}
//console.log("break");
function main_01(){
if(style_div_cursor.parentNode==undefined){
console.log("style_div_cursor undefined");
document.body.appendChild(style_div_cursor);
document.body.appendChild(ary_div[0]);
document.body.appendChild(ary_div[1]);
document.body.appendChild(ary_div[2]);
window.clearInterval(timeoutID_1);
}
}
function main_02(){
let anchor=document.querySelectorAll('a');
let div_cursor=document.querySelectorAll('.hover-target');
for(let i = 0; i < anchor.length; i++){
for(let j = 0; j < div_cursor.length; j++){
anchor[i].addEventListener('mouseenter', function(){div_cursor[j].classList.add('hover');});
anchor[i].addEventListener('mouseleave', function(){div_cursor[j].classList.remove('hover');});
}
}
}
(function() {
'use strict';
if(document.body==null)return;
if(document.querySelectorAll("#index_cursor1").length==0){
ary_div[0]=create_div("gm_cursor1",true,document.body);
ary_div[1]=create_div(["gm_cursor2","hover-target"],true,document.body);
ary_div[2]=create_div(["gm_cursor3","hover-target"],true,document.body);
let div_c1=ary_div[0];
let div_c2=ary_div[1];
let div_c3=ary_div[2];
div_c1.id="gm_cursor1";
div_c2.id="gm_cursor2";
div_c3.id="gm_cursor3";
timeoutID_1=window.setInterval(( () => main_01()), 1000);
//move
var x, y;
// On mousemove use event.clientX and event.clientY to set the location of the div to the location of the cursor:
window.addEventListener('mousemove', function(event){
x = event.clientX;
y = event.clientY;
if ( typeof x !== 'undefined' ){
div_c1.style.left=x+"px";div_c2.style.left=x+"px";div_c3.style.left=x+"px";
div_c1.style.top=y+"px";div_c2.style.top=y+"px";div_c3.style.top=y+"px";
}
}, false);
//anchor
//document.addEventListener('DOMContentLoaded', function() {console.log("DOMContentLoaded div_cursor");main_02();});
timeoutID_2=window.setInterval(( () => main_02() ), 1000);//bak
window.setTimeout(( () => window.clearInterval(timeoutID_2) ), 30000);
}
/*jshint multistr: true */
})();