-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathemoji-pop.js
126 lines (108 loc) · 3.16 KB
/
emoji-pop.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
class Fountain {
constructor() {
this.limit = 35;
this.particles = [];
this.autoAddParticle = false;
this.height = document.documentElement.clientHeight;
this.sizes = [15, 20, 25, 35, 45];
this.variants = ["🧟", "🧟"];
this.addHandlers();
this.loop();
}
loop() {
if (this.autoAddParticle && this.particles.length < this.limit) {
// if (document.getElementById("field-email") === document.activeElement) {
// this.variants = ["🧟"];
// } else {
// this.variants = ["🧟"];
// }
this.createParticle();
}
this.updateParticles();
requestAnimationFrame(this.loop.bind(this));
}
addHandlers() {
const isTouchInteraction =
"ontouchstart" in window || navigator.msMaxTouchPoints;
const tap = isTouchInteraction ? "touchstart" : "mousedown";
const tapEnd = isTouchInteraction ? "touchend" : "mouseup";
const move = isTouchInteraction ? "touchmove" : "mousemove";
document.addEventListener(
move,
(e) => {
this.mouseX = e.pageX || e.touches[0].pageX;
this.mouseY = e.pageY || e.touches[0].pageY;
},
{ passive: false }
);
document.addEventListener(tap, (e) => {
this.mouseX = e.pageX || e.touches[0].pageX;
this.mouseY = e.pageY || e.touches[0].pageY;
this.autoAddParticle = true;
});
document.addEventListener(tapEnd, () => {
this.autoAddParticle = false;
});
document.addEventListener("mouseleave", () => {
this.autoAddParticle = false;
});
}
createParticle() {
const size = this.sizes[Math.floor(Math.random() * this.sizes.length)];
const speedHorz = Math.random() * 10;
const speedUp = Math.random() * 25;
const spinVal = Math.random() * 360;
const spinSpeed = Math.random() * 35 * (Math.random() <= 0.5 ? -1 : 1);
const top = this.mouseY - size / 2;
const left = this.mouseX - size / 2;
const direction = Math.random() <= 0.5 ? -1 : 1;
const particle = document.createElement("span");
particle.innerHTML = this.variants[
Math.floor(Math.random() * this.variants.length)
];
particle.classList.add("particle");
particle.setAttribute(
"style",
`
font-size: ${size}px;
top: ${top}px;
left: ${left}px;
transform: rotate(${spinVal}deg);
`
);
document.getElementById("content").appendChild(particle);
this.particles.push({
element: particle,
size,
speedHorz,
speedUp,
spinVal,
spinSpeed,
top,
left,
direction,
});
}
updateParticles() {
this.particles.forEach((p) => {
p.left = p.left - p.speedHorz * p.direction;
p.top = p.top - p.speedUp;
p.speedUp = Math.min(p.size, p.speedUp - 1);
p.spinVal = p.spinVal + p.spinSpeed;
if (p.top >= this.height + p.size) {
this.particles = this.particles.filter((o) => o !== p);
p.element.remove();
}
p.element.setAttribute(
"style",
`
top: ${p.top}px;
left: ${p.left}px;
font-size: ${p.size}px;
transform:rotate(${p.spinVal}deg);
`
);
});
}
}
new Fountain();