-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontent.js
147 lines (126 loc) · 4.67 KB
/
content.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/**
* Watching Eyes script - By Kurt ([email protected])
* Script featured on Dynamic Drive
* Visit http://www.dynamicdrive.com for this script and more
*
* Updated for modern browsers by Jan Chaloupka <[email protected]>
*/
function enable(){
/**
* Eyeballs element
* @type {HTMLImageElement}
*/
const eyeball = document.createElement("img");
eyeball.src = "";
eyeball.style.cssText = `
position: fixed;
z-index: 100000;
top: 0;
left: 0;
pointer-events: none;
opacity: 0;
transition: opacity 500ms;
`;
/**
* Left pupil element
* @type {HTMLImageElement}
*/
const leftPupil = document.createElement("img");
leftPupil.src = "";
leftPupil.style.cssText = `
position: fixed;
z-index: 100000;
top: 0;
left: 0;
pointer-events: none;
opacity: 0;
transition: opacity 500ms;
`;
/**
* Right pupil element
* @type {HTMLImageElement}
*/
const rightPupil = leftPupil.cloneNode();
document.body.appendChild(eyeball);
document.body.appendChild(leftPupil);
document.body.appendChild(rightPupil);
// Main logic starts here -----------------------------------------------------
let mouseX = 0;
let mouseY = 0;
let targetEyeX = 0;
let targetEyeY = 0;
let firstTime = true;
/**
* Calculate new pupil position
*
* @param {HTMLElement} pupilEl Image of pupil
* @param {number} centerX Horizontal center of eyeball
* @param {number} centerY Vertical center of eyeball
*/
function updatePupilPos(pupilEl, centerX, centerY){
const dx = mouseX - centerX;
const dy = mouseY - centerY;
const angle = Math.atan2(dy, dx) * 180 / Math.PI;
const centerDist = Math.min(Math.sqrt(dy * dy + dx * dx), 17);
const dv = 1.7;
const pupilX = centerX - 6 + centerDist / dv * Math.cos(angle * Math.PI / 180);
const pupilY = centerY - 6 + centerDist / dv * Math.sin(angle * Math.PI / 180);
pupilEl.style.transform = `translate(${pupilX}px, ${pupilY}px)`;
}
/**
* Calculate new eye and pupils positions
*/
function updateEyePos() {
if(firstTime){
targetEyeX = mouseX;
targetEyeY = mouseY;
firstTime = false;
eyeball.style.opacity = 1;
leftPupil.style.opacity = 1;
rightPupil.style.opacity = 1;
}else{
targetEyeX += (mouseX - targetEyeX) * 0.12;
targetEyeY += (mouseY - targetEyeY) * 0.12 - 2;
}
const wx = window.innerWidth;
const wy = window.innerHeight;
// Restrict eye pos to browser window and center
let eyeX = Math.floor(targetEyeX - 34);
if(eyeX <= 0) eyeX = 0;
else if(eyeX >= wx - 69) eyeX = wx - 69;
let eyeY = Math.floor(targetEyeY - 34);
if(eyeY <= 0) eyeY = 0;
else if(eyeY >= wy - 34) eyeY = wy - 34;
eyeball.style.transform = `translate(${eyeX}px, ${eyeY}px)`;
updatePupilPos(leftPupil, eyeX + 17, eyeY + 17);
updatePupilPos(rightPupil, eyeX + 52, eyeY + 17);
requestAnimationFrame(updateEyePos);
}
window.addEventListener("mousemove", e => {
mouseX = e.clientX;
mouseY = e.clientY;
if(firstTime) updateEyePos();
});
}
// Test whether eyes should be enabled on this page ---------------------------
const mainMatch = /^https?:\/\/www\.fit\.vut(br)?\.cz/;
const emMatch = /^https?:\/\/www\.fit\.vut(br)?\.cz\/~eysselt/;
const wisMatch = /^https?:\/\/wis\.fit\.vut(br)?\.cz/;
const merlinMatch = /^https?:\/\/merlin\.fit\.vut(br)?\.cz/;
const evaMatch = /^https?:\/\/eva\.fit\.vut(br)?\.cz/;
chrome.storage.local.get({
everywhere: false,
main: false,
em: true,
wis: true,
merlin: false,
eva: false
}, items => {
if( (items.everywhere) ||
(items.main && mainMatch.test(location.href)) ||
(items.em && emMatch.test(location.href)) ||
(items.wis && wisMatch.test(location.href)) ||
(items.merlin && merlinMatch.test(location.href)) ||
(items.eva && evaMatch.test(location.href))
) enable();
});