var cursoreffects = function(e) { "use strict"; return e.ghostCursor = function(e) { let t, i, n, o = e && e.element, s = o || document.body, h = window.innerWidth, c = window.innerHeight, l = { x: h / 2, y: h / 2 }, d = [], r = new Image; r.src = ""; const a = window.matchMedia("(prefers-reduced-motion: reduce)"); function A() { if (a.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; t = document.createElement("canvas"), i = t.getContext("2d"), t.style.top = "0px", t.style.left = "0px", t.style.pointerEvents = "none", o ? (t.style.position = "absolute", s.appendChild(t), t.width = s.clientWidth, t.height = s.clientHeight) : (t.style.position = "fixed", document.body.appendChild(t), t.width = h, t.height = c), s.addEventListener("mousemove", g), s.addEventListener("touchmove", m, { passive: !0 }), s.addEventListener("touchstart", m, { passive: !0 }), window.addEventListener("resize", u), p() } function u(e) { h = window.innerWidth, c = window.innerHeight, o ? (t.width = s.clientWidth, t.height = s.clientHeight) : (t.width = h, t.height = c) } function m(e) { if (e.touches.length > 0) for (let t = 0; t < e.touches.length; t++) f(e.touches[t].clientX, e.touches[t].clientY, r) } function g(e) { if (o) { const t = s.getBoundingClientRect(); l.x = e.clientX - t.left, l.y = e.clientY - t.top } else l.x = e.clientX, l.y = e.clientY; f(l.x, l.y, r) } function f(e, t, i) { d.push(new w(e, t, i)) } function p() { ! function() { if (0 != d.length) { i.clearRect(0, 0, h, c); for (let e = 0; e < d.length; e++) d[e].update(i); for (let e = d.length - 1; e >= 0; e--) d[e].lifeSpan < 0 && d.splice(e, 1); 0 == d.length && i.clearRect(0, 0, h, c) } }(), n = requestAnimationFrame(p) } function y() { t.remove(), cancelAnimationFrame(n), s.removeEventListener("mousemove", g), s.removeEventListener("touchmove", m), s.removeEventListener("touchstart", m), window.addEventListener("resize", u) } function w(e, t, i) { this.initialLifeSpan = 40, this.lifeSpan = 40, this.position = { x: e, y: t }, this.image = i, this.update = function(e) { this.lifeSpan--; const t = Math.max(this.lifeSpan / this.initialLifeSpan, 0); e.globalAlpha = t, e.drawImage(this.image, this.position.x, this.position.y) } } return a.onchange = () => { a.matches ? y() : A() }, A(), { destroy: y } }, Object.defineProperty(e, "__esModule", { value: !0 }), e }({});