diff --git a/bio/Pixel.ttf b/bio/Pixel.ttf new file mode 100644 index 0000000..dcca687 Binary files /dev/null and b/bio/Pixel.ttf differ diff --git a/bio/README.md b/bio/README.md new file mode 100644 index 0000000..ee3294e --- /dev/null +++ b/bio/README.md @@ -0,0 +1 @@ +fuck the haters :middlefinger: \ No newline at end of file diff --git a/bio/audio.js b/bio/audio.js new file mode 100644 index 0000000..18149c9 --- /dev/null +++ b/bio/audio.js @@ -0,0 +1,138 @@ +const songs = [ + { + title: "Bladee & Ecco2k - Bleach", + src: "https://easyfiles.cc/2024/9/4ac37ab2-20d7-4fd8-863b-3dcee1c418cd/BLADEE%20&%20ECCO2K%20-%20BLEACH%20-%20drain%20gang%20(720p50,%20h264)(1).mp4" , + duration: 153 + }, + + { + title: "woody - Heaven & Hell", + src: "https://easyfiles.cc/2024/9/20fa08a2-8212-4212-93b7-9c62fc563505/woody%20heaven%20&%20hell%20prod.%201mint%20-%20real1woody%20(1080p,%20h264)(1).mp4" , + duration: 142 + }, + + + { + title: "woody - God Said I Was Good", + src: "https://easyfiles.cc/2024/8/9cafa851-0405-4009-b639-08ff5e029dc3/youtube_Z4IF2ujq1Xk_1280x720_h264(1).mp4" , + duration: 135 + }, + + { + title: "SmokeTeam6 - PackistanFlashback", + src: "file:///C:/Users/Fabio/Downloads/SmokeTeam6%20-%20PackistanFlashback%20(VEVO%20Official%20Music%20Video)%20-%20benwbush%20(1080p,%20h264)(1).mp4" , + duration: 92 + }, + + { + title: "sniper2004 - la ny", + src: "https://easyfiles.cc/2024/8/b8332c2a-e70b-4ec0-9ba8-acc7e5449db7/youtube_mkmn3QZSZUM_874x720_h264(1).mp4" , + duration: 87 + }, + + { + title: "Joeyy - PR Package", + src: "https://easyfiles.cc/2024/8/7c649f45-6573-4665-9675-4d869ea1332a/youtube_ZvphwrKo52s_1280x720_h264(1).mp4" , + duration: 111 + }, + + { + title: "woody - Paint Thinner", + src: "https://easyfiles.cc/2024/8/2110cfc6-d700-4c42-bc66-bafa5799c1fc/youtube_rhaFMuU1_qw_1280x720_h264(1).mp4" , + duration: 100 + }, + +]; + +let currentSongIndex = 0; +let isPlaying = false; + +const main = document.getElementById("player") +const videoPlayer = document.getElementById("videoPlayer"); +const playPauseButton = document.getElementById("playPause"); +const songInfo = document.getElementById("songInfo"); +const progressBar = document.getElementById("progressBar"); +const volumeSlider = document.getElementById('volumeSlider'); +const volumePercent = document.getElementById('volumePercent') +const currentDuration = document.getElementById("current-duration"); +const totalDuration = document.getElementById("total-duration"); + +videoPlayer.addEventListener("timeupdate", () => { + let value = (videoPlayer.currentTime / videoPlayer.duration) * 100; + progressBar.value = value; + updateSliderBackground(progressBar, value); + currentDuration.innerText = formatTime(videoPlayer.currentTime); + totalDuration.innerText = formatTime(songs[currentSongIndex].duration); +}); + +progressBar.addEventListener('wheel', function (event) { + event.preventDefault(); +}); + +document.getElementById("prev").addEventListener("click", () => { + currentSongIndex = (currentSongIndex - 1 + songs.length) % songs.length; + loadSong(currentSongIndex); + if (isPlaying) { + videoPlayer.play(); + } +}); + +document.getElementById("next").addEventListener("click", () => { + currentSongIndex = (currentSongIndex + 1) % songs.length; + loadSong(currentSongIndex); + if (isPlaying) { + videoPlayer.play(); + } +}); + +playPauseButton.addEventListener("click", () => { + if (isPlaying) { + videoPlayer.pause(); + playPauseButton.innerHTML = "►"; + } else { + videoPlayer.play(); + playPauseButton.innerHTML = "❚❚"; + } + isPlaying =!isPlaying; +}); + +videoPlayer.addEventListener("ended", () => { + currentSongIndex = (currentSongIndex + 1) % songs.length; + loadSong(currentSongIndex); + videoPlayer.play(); +}); + +function updateSliderBackground(slider, value) { + slider.style.background = `linear-gradient(to right, #ffffff 0%, #ffffff ${value}%, #cbcbcb ${value}%, #cbcbcb 100%)`; +} + +function loadSong(index) { + videoPlayer.src = songs[index].src; + songInfo.innerText = songs[index].title; + progressBar.value = 0; + totalDuration.innerText = formatTime(songs[index].duration); + videoPlayer.load(); + videoPlayer.play(); +} + +videoPlayer.volume = volumeSlider.value / 100; +volumePercent.innerText = `${volumeSlider.value}%`; +updateVolumeSliderBackground(volumeSlider, volumeSlider.value); + +volumeSlider.addEventListener('input', function () { + videoPlayer.volume = volumeSlider.value / 100; + volumePercent.innerText = `${volumeSlider.value}%`; + updateVolumeSliderBackground(volumeSlider, volumeSlider.value); +}); + +function updateVolumeSliderBackground(slider, value) { + slider.style.background = `linear-gradient(to right, #ffffff 0%, #ffffff ${value}%, #cbcbcb ${value}%, #cbcbcb 100%)`; +} + +function formatTime(time) { + const minutes = Math.floor(time / 60); + const seconds = Math.floor(time % 60); + return `${minutes}:${seconds.toString().padStart(2, "0")}`; +} + +loadSong(0); \ No newline at end of file diff --git a/bio/disable-devtool@latest b/bio/disable-devtool@latest new file mode 100644 index 0000000..f71219f --- /dev/null +++ b/bio/disable-devtool@latest @@ -0,0 +1 @@ +!function (e, t) { "object" == typeof exports && "undefined" != typeof module ? module.exports = t() : "function" == typeof define && define.amd ? define(t) : (e = "undefined" != typeof globalThis ? globalThis : e || self).DisableDevtool = t() }(this, function () { "use strict"; function o(e) { return (o = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (e) { return typeof e } : function (e) { return e && "function" == typeof Symbol && e.constructor === Symbol && e !== Symbol.prototype ? "symbol" : typeof e })(e) } function i(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function r(e, t) { for (var n = 0; n < t.length; n++) { var i = t[n]; i.enumerable = i.enumerable || !1, i.configurable = !0, "value" in i && (i.writable = !0), Object.defineProperty(e, i.key, i) } } function u(e, t, n) { t && r(e.prototype, t), n && r(e, n), Object.defineProperty(e, "prototype", { writable: !1 }) } function e(e, t, n) { t in e ? Object.defineProperty(e, t, { value: n, enumerable: !0, configurable: !0, writable: !0 }) : e[t] = n } function n(e, t) { if ("function" != typeof t && null !== t) throw new TypeError("Super expression must either be null or a function"); e.prototype = Object.create(t && t.prototype, { constructor: { value: e, writable: !0, configurable: !0 } }), Object.defineProperty(e, "prototype", { writable: !1 }), t && a(e, t) } function c(e) { return (c = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (e) { return e.__proto__ || Object.getPrototypeOf(e) })(e) } function a(e, t) { return (a = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (e, t) { return e.__proto__ = t, e })(e, t) } function H(e, t) { if (t && ("object" == typeof t || "function" == typeof t)) return t; if (void 0 !== t) throw new TypeError("Derived constructors may only return object or undefined"); t = e; if (void 0 === t) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return t } function l(n) { var i = function () { if ("undefined" == typeof Reflect || !Reflect.construct) return !1; if (Reflect.construct.sham) return !1; if ("function" == typeof Proxy) return !0; try { return Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () { })), !0 } catch (e) { return !1 } }(); return function () { var e, t = c(n); return H(this, i ? (e = c(this).constructor, Reflect.construct(t, arguments, e)) : t.apply(this, arguments)) } } function f(e, t) { (null == t || t > e.length) && (t = e.length); for (var n = 0, i = new Array(t); n < t; n++)i[n] = e[n]; return i } function s(e, t) { var n, i = "undefined" != typeof Symbol && e[Symbol.iterator] || e["@@iterator"]; if (!i) { if (Array.isArray(e) || (i = function (e, t) { if (e) { if ("string" == typeof e) return f(e, t); var n = Object.prototype.toString.call(e).slice(8, -1); return "Map" === (n = "Object" === n && e.constructor ? e.constructor.name : n) || "Set" === n ? Array.from(e) : "Arguments" === n || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n) ? f(e, t) : void 0 } }(e)) || t && e && "number" == typeof e.length) return i && (e = i), n = 0, { s: t = function () { }, n: function () { return n >= e.length ? { done: !0 } : { done: !1, value: e[n++] } }, e: function (e) { throw e }, f: t }; throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.") } var o, r = !0, u = !1; return { s: function () { i = i.call(e) }, n: function () { var e = i.next(); return r = e.done, e }, e: function (e) { u = !0, o = e }, f: function () { try { r || null == i.return || i.return() } finally { if (u) throw o } } } } function t() { if (d.url) window.location.href = d.url; else if (d.rewriteHTML) try { document.documentElement.innerHTML = d.rewriteHTML } catch (e) { document.documentElement.innerText = d.rewriteHTML } else { try { window.opener = null, window.open("", "_self"), window.close(), window.history.back() } catch (e) { console.log(e) } setTimeout(function () { window.location.href = d.timeOutUrl || "https://theajack.github.io/disable-devtool/404.html?h=".concat(encodeURIComponent(location.host)) }, 500) } } var d = { md5: "", ondevtoolopen: t, ondevtoolclose: null, url: "", timeOutUrl: "", tkName: "ddtk", interval: 500, disableMenu: !0, stopIntervalTime: 5e3, clearIntervalWhenDevOpenTrigger: !1, detectors: [0, 1, 3, 4, 5, 6, 7], clearLog: !0, disableSelect: !1, disableCopy: !1, disableCut: !1, disablePaste: !1, ignore: null, disableIframeParents: !0, seo: !0, rewriteHTML: "" }, U = ["detectors", "ondevtoolclose", "ignore"]; function q(e) { var t, n = 0 < arguments.length && void 0 !== e ? e : {}; for (t in d) { var i = t; void 0 === n[i] || o(d[i]) !== o(n[i]) && -1 === U.indexOf(i) || (d[i] = n[i]) } "function" == typeof d.ondevtoolclose && !0 === d.clearIntervalWhenDevOpenTrigger && (d.clearIntervalWhenDevOpenTrigger = !1, console.warn("【DISABLE-DEVTOOL】clearIntervalWhenDevOpenTrigger 在使用 ondevtoolclose 时无效")) } function v() { return (new Date).getTime() } function z(e) { var t = v(); return e(), v() - t } function B(n, i) { function e(t) { return function () { n && n(); var e = t.apply(void 0, arguments); return i && i(), e } } var t = window.alert, o = window.confirm, r = window.prompt; try { window.alert = e(t), window.confirm = e(o), window.prompt = e(r) } catch (e) { } } var p = { iframe: !1, pc: !1, qqBrowser: !1, firefox: !1, macos: !1, edge: !1, oldEdge: !1, ie: !1, iosChrome: !1, iosEdge: !1, chrome: !1, seoBot: !1, mobile: !1 }; function W() { function e(e) { return -1 !== t.indexOf(e) } var t = navigator.userAgent.toLowerCase(), n = function () { var e = navigator, t = e.platform, e = e.maxTouchPoints; if ("number" == typeof e) return 1 < e; if ("string" == typeof t) { e = t.toLowerCase(); if (/(mac|win)/i.test(e)) return !1; if (/(android|iphone|ipad|ipod|arch)/i.test(e)) return !0 } return /(iphone|ipad|ipod|ios|android)/i.test(navigator.userAgent.toLowerCase()) }(), i = !!window.top && window !== window.top, o = !n, r = e("qqbrowser"), u = e("firefox"), c = e("macintosh"), a = e("edge"), l = a && !e("chrome"), f = l || e("trident") || e("msie"), s = e("crios"), d = e("edgios"), v = e("chrome") || s, h = !n && /(googlebot|baiduspider|bingbot|applebot|petalbot|yandexbot|bytespider|chrome\-lighthouse|moto g power)/i.test(t); Object.assign(p, { iframe: i, pc: o, qqBrowser: r, firefox: u, macos: c, edge: a, oldEdge: l, ie: f, iosChrome: s, iosEdge: d, chrome: v, seoBot: h, mobile: n }) } function M() { for (var e = function () { for (var e = {}, t = 0; t < 500; t++)e["".concat(t)] = "".concat(t); return e }(), t = [], n = 0; n < 50; n++)t.push(e); return t } var h, y, K, b = window.console || { log: function () { }, table: function () { }, clear: function () { } }; function w() { d.clearLog && K() } var V = "", F = !1; function X() { var e = d.ignore; if (e) { if ("function" == typeof e) return e(); if (0 !== e.length) { var t = location.href; if (V === t) return F; V = t; var n, i = !1, o = s(e); try { for (o.s(); !(n = o.n()).done;) { var r = n.value; if ("string" == typeof r) { if (-1 !== t.indexOf(r)) { i = !0; break } } else if (r.test(t)) { i = !0; break } } } catch (e) { o.e(e) } finally { o.f() } return F = i } } } var N = function () { return !1 }; function g(n) { var t, e, i = 74, o = 73, r = 85, u = 83, c = 123, a = p.macos ? function (e, t) { return e.metaKey && e.altKey && (t === o || t === i) } : function (e, t) { return e.ctrlKey && e.shiftKey && (t === o || t === i) }, l = p.macos ? function (e, t) { return e.metaKey && e.altKey && t === r || e.metaKey && t === u } : function (e, t) { return e.ctrlKey && (t === u || t === r) }; n.addEventListener("keydown", function (e) { var t = (e = e || n.event).keyCode || e.which; if (t === c || a(e, t) || l(e, t)) return T(n, e) }, !0), t = n, d.disableMenu && t.addEventListener("contextmenu", function (e) { if ("touch" !== e.pointerType) return T(t, e) }), e = n, d.disableSelect && m(e, "selectstart"), e = n, d.disableCopy && m(e, "copy"), e = n, d.disableCut && m(e, "cut"), e = n, d.disablePaste && m(e, "paste") } function m(t, e) { t.addEventListener(e, function (e) { return T(t, e) }) } function T(e, t) { if (!X() && !N()) return (t = t || e.event).returnValue = !1, t.preventDefault(), !1 } var O, D = !1, S = {}; function $(e) { S[e] = !1 } function G() { for (var e in S) if (S[e]) return D = !0; return D = !1 } (_ = O = O || {})[_.Unknown = -1] = "Unknown", _[_.RegToString = 0] = "RegToString", _[_.DefineId = 1] = "DefineId", _[_.Size = 2] = "Size", _[_.DateToString = 3] = "DateToString", _[_.FuncToString = 4] = "FuncToString", _[_.Debugger = 5] = "Debugger", _[_.Performance = 6] = "Performance", _[_.DebugLib = 7] = "DebugLib"; var k = function () { function n(e) { var t = e.type, e = e.enabled, e = void 0 === e || e; i(this, n), this.type = O.Unknown, this.enabled = !0, this.type = t, this.enabled = e, this.enabled && (t = this, Z.push(t), this.init()) } return u(n, [{ key: "onDevToolOpen", value: function () { var e; console.warn("You don't have permission to use DEVTOOL!【type = ".concat(this.type, "】")), d.clearIntervalWhenDevOpenTrigger && ne(), window.clearTimeout(Q), d.ondevtoolopen(this.type, t), e = this.type, S[e] = !0 } }, { key: "init", value: function () { } }]), n }(), Y = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.DebugLib }) } return u(t, [{ key: "init", value: function () { } }, { key: "detect", value: function () { var e; (!0 === (null == (e = null == (e = window.eruda) ? void 0 : e._devTools) ? void 0 : e._isShow) || window._vcOrigConsole && window.document.querySelector("#__vconsole.vc-toggle")) && this.onDevToolOpen() } }], [{ key: "isUsing", value: function () { return !!window.eruda || !!window._vcOrigConsole } }]), t }(), J = 0, Q = 0, Z = [], ee = 0; function te(o) { function e() { l = !0 } function t() { l = !1 } var n, i, r, u, c, a, l = !1; function f() { (a[u] === r ? i : n)() } B(e, t), n = t, i = e, void 0 !== (a = document).hidden ? (r = "hidden", c = "visibilitychange", u = "visibilityState") : void 0 !== a.mozHidden ? (r = "mozHidden", c = "mozvisibilitychange", u = "mozVisibilityState") : void 0 !== a.msHidden ? (r = "msHidden", c = "msvisibilitychange", u = "msVisibilityState") : void 0 !== a.webkitHidden && (r = "webkitHidden", c = "webkitvisibilitychange", u = "webkitVisibilityState"), a.removeEventListener(c, f, !1), a.addEventListener(c, f, !1), J = window.setInterval(function () { if (!(o.isSuspend || l || X())) { var e, t, n = s(Z); try { for (n.s(); !(e = n.n()).done;) { var i = e.value; $(i.type), i.detect(ee++) } } catch (e) { n.e(e) } finally { n.f() } w(), "function" == typeof d.ondevtoolclose && (t = D, !G() && t && d.ondevtoolclose()) } }, d.interval), Q = setTimeout(function () { p.pc || Y.isUsing() || ne() }, d.stopIntervalTime) } function ne() { window.clearInterval(J) } var P = 8; function ie(e) { for (var t = function (e, t) { e[t >> 5] |= 128 << t % 32, e[14 + (t + 64 >>> 9 << 4)] = t; for (var n = 1732584193, i = -271733879, o = -1732584194, r = 271733878, u = 0; u < e.length; u += 16) { var c = n, a = i, l = o, f = r; n = E(n, i, o, r, e[u + 0], 7, -680876936), r = E(r, n, i, o, e[u + 1], 12, -389564586), o = E(o, r, n, i, e[u + 2], 17, 606105819), i = E(i, o, r, n, e[u + 3], 22, -1044525330), n = E(n, i, o, r, e[u + 4], 7, -176418897), r = E(r, n, i, o, e[u + 5], 12, 1200080426), o = E(o, r, n, i, e[u + 6], 17, -1473231341), i = E(i, o, r, n, e[u + 7], 22, -45705983), n = E(n, i, o, r, e[u + 8], 7, 1770035416), r = E(r, n, i, o, e[u + 9], 12, -1958414417), o = E(o, r, n, i, e[u + 10], 17, -42063), i = E(i, o, r, n, e[u + 11], 22, -1990404162), n = E(n, i, o, r, e[u + 12], 7, 1804603682), r = E(r, n, i, o, e[u + 13], 12, -40341101), o = E(o, r, n, i, e[u + 14], 17, -1502002290), i = E(i, o, r, n, e[u + 15], 22, 1236535329), n = j(n, i, o, r, e[u + 1], 5, -165796510), r = j(r, n, i, o, e[u + 6], 9, -1069501632), o = j(o, r, n, i, e[u + 11], 14, 643717713), i = j(i, o, r, n, e[u + 0], 20, -373897302), n = j(n, i, o, r, e[u + 5], 5, -701558691), r = j(r, n, i, o, e[u + 10], 9, 38016083), o = j(o, r, n, i, e[u + 15], 14, -660478335), i = j(i, o, r, n, e[u + 4], 20, -405537848), n = j(n, i, o, r, e[u + 9], 5, 568446438), r = j(r, n, i, o, e[u + 14], 9, -1019803690), o = j(o, r, n, i, e[u + 3], 14, -187363961), i = j(i, o, r, n, e[u + 8], 20, 1163531501), n = j(n, i, o, r, e[u + 13], 5, -1444681467), r = j(r, n, i, o, e[u + 2], 9, -51403784), o = j(o, r, n, i, e[u + 7], 14, 1735328473), i = j(i, o, r, n, e[u + 12], 20, -1926607734), n = I(n, i, o, r, e[u + 5], 4, -378558), r = I(r, n, i, o, e[u + 8], 11, -2022574463), o = I(o, r, n, i, e[u + 11], 16, 1839030562), i = I(i, o, r, n, e[u + 14], 23, -35309556), n = I(n, i, o, r, e[u + 1], 4, -1530992060), r = I(r, n, i, o, e[u + 4], 11, 1272893353), o = I(o, r, n, i, e[u + 7], 16, -155497632), i = I(i, o, r, n, e[u + 10], 23, -1094730640), n = I(n, i, o, r, e[u + 13], 4, 681279174), r = I(r, n, i, o, e[u + 0], 11, -358537222), o = I(o, r, n, i, e[u + 3], 16, -722521979), i = I(i, o, r, n, e[u + 6], 23, 76029189), n = I(n, i, o, r, e[u + 9], 4, -640364487), r = I(r, n, i, o, e[u + 12], 11, -421815835), o = I(o, r, n, i, e[u + 15], 16, 530742520), i = I(i, o, r, n, e[u + 2], 23, -995338651), n = L(n, i, o, r, e[u + 0], 6, -198630844), r = L(r, n, i, o, e[u + 7], 10, 1126891415), o = L(o, r, n, i, e[u + 14], 15, -1416354905), i = L(i, o, r, n, e[u + 5], 21, -57434055), n = L(n, i, o, r, e[u + 12], 6, 1700485571), r = L(r, n, i, o, e[u + 3], 10, -1894986606), o = L(o, r, n, i, e[u + 10], 15, -1051523), i = L(i, o, r, n, e[u + 1], 21, -2054922799), n = L(n, i, o, r, e[u + 8], 6, 1873313359), r = L(r, n, i, o, e[u + 15], 10, -30611744), o = L(o, r, n, i, e[u + 6], 15, -1560198380), i = L(i, o, r, n, e[u + 13], 21, 1309151649), n = L(n, i, o, r, e[u + 4], 6, -145523070), r = L(r, n, i, o, e[u + 11], 10, -1120210379), o = L(o, r, n, i, e[u + 2], 15, 718787259), i = L(i, o, r, n, e[u + 9], 21, -343485551), n = C(n, c), i = C(i, a), o = C(o, l), r = C(r, f) } return Array(n, i, o, r) }(function (e) { for (var t = Array(), n = (1 << P) - 1, i = 0; i < e.length * P; i += P)t[i >> 5] |= (e.charCodeAt(i / P) & n) << i % 32; return t }(e), e.length * P), n = "0123456789abcdef", i = "", o = 0; o < 4 * t.length; o++)i += n.charAt(t[o >> 2] >> o % 4 * 8 + 4 & 15) + n.charAt(t[o >> 2] >> o % 4 * 8 & 15); return i } function x(e, t, n, i, o, r) { return C((t = C(C(t, e), C(i, r))) << o | t >>> 32 - o, n) } function E(e, t, n, i, o, r, u) { return x(t & n | ~t & i, e, t, o, r, u) } function j(e, t, n, i, o, r, u) { return x(t & i | n & ~i, e, t, o, r, u) } function I(e, t, n, i, o, r, u) { return x(t ^ n ^ i, e, t, o, r, u) } function L(e, t, n, i, o, r, u) { return x(n ^ (t | ~i), e, t, o, r, u) } function C(e, t) { var n = (65535 & e) + (65535 & t); return (e >> 16) + (t >> 16) + (n >> 16) << 16 | 65535 & n } var _ = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.RegToString, enabled: p.qqBrowser || p.firefox }) } return u(t, [{ key: "init", value: function () { var t = this; this.lastTime = 0, this.reg = /./, h(this.reg), this.reg.toString = function () { var e; return p.qqBrowser ? (e = (new Date).getTime(), t.lastTime && e - t.lastTime < 100 ? t.onDevToolOpen() : t.lastTime = e) : p.firefox && t.onDevToolOpen(), "" } } }, { key: "detect", value: function () { h(this.reg) } }]), t }(), oe = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.DefineId }) } return u(t, [{ key: "init", value: function () { var e = this; this.div = document.createElement("div"), this.div.__defineGetter__("id", function () { e.onDevToolOpen() }), Object.defineProperty(this.div, "id", { get: function () { e.onDevToolOpen() } }) } }, { key: "detect", value: function () { h(this.div) } }]), t }(), re = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.Size, enabled: !p.iframe && !p.edge }) } return u(t, [{ key: "init", value: function () { var e = this; this.checkWindowSizeUneven(), window.addEventListener("resize", function () { setTimeout(function () { e.checkWindowSizeUneven() }, 100) }, !0) } }, { key: "detect", value: function () { } }, { key: "checkWindowSizeUneven", value: function () { var e = function () { if (ue(window.devicePixelRatio)) return window.devicePixelRatio; var e = window.screen; return !(ue(e) || !e.deviceXDPI || !e.logicalXDPI) && e.deviceXDPI / e.logicalXDPI }(); if (!1 !== e) { var t = 200 < window.outerWidth - window.innerWidth * e, e = 300 < window.outerHeight - window.innerHeight * e; if (t || e) return this.onDevToolOpen(), !1; $(this.type) } return !0 } }]), t }(); function ue(e) { return null != e } var A, ce = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.DateToString, enabled: !p.iosChrome && !p.iosEdge }) } return u(t, [{ key: "init", value: function () { var e = this; this.count = 0, this.date = new Date, this.date.toString = function () { return e.count++, "" } } }, { key: "detect", value: function () { this.count = 0, h(this.date), w(), 2 <= this.count && this.onDevToolOpen() } }]), t }(), ae = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.FuncToString, enabled: !p.iosChrome && !p.iosEdge }) } return u(t, [{ key: "init", value: function () { var e = this; this.count = 0, this.func = function () { }, this.func.toString = function () { return e.count++, "" } } }, { key: "detect", value: function () { this.count = 0, h(this.func), w(), 2 <= this.count && this.onDevToolOpen() } }]), t }(), le = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.Debugger, enabled: p.iosChrome || p.iosEdge }) } return u(t, [{ key: "detect", value: function () { var e = v(); 100 < v() - e && this.onDevToolOpen() } }]), t }(), fe = function () { n(t, k); var e = l(t); function t() { return i(this, t), e.call(this, { type: O.Performance, enabled: p.chrome || !p.mobile }) } return u(t, [{ key: "init", value: function () { this.maxPrintTime = 0, this.largeObjectArray = M() } }, { key: "detect", value: function () { var e = this, t = z(function () { y(e.largeObjectArray) }), n = z(function () { h(e.largeObjectArray) }); if (this.maxPrintTime = Math.max(this.maxPrintTime, n), w(), 0 === t || 0 === this.maxPrintTime) return !1; t > 10 * this.maxPrintTime && this.onDevToolOpen() } }]), t }(), se = (e(A = {}, O.RegToString, _), e(A, O.DefineId, oe), e(A, O.Size, re), e(A, O.DateToString, ce), e(A, O.FuncToString, ae), e(A, O.Debugger, le), e(A, O.Performance, fe), e(A, O.DebugLib, Y), A); var R = Object.assign(function (e) { function t() { var e = 0 < arguments.length && void 0 !== arguments[0] ? arguments[0] : ""; return { success: !e, reason: e } } if (R.isRunning) return t("already running"); if (W(), K = p.ie ? (h = function () { return b.log.apply(b, arguments) }, y = function () { return b.table.apply(b, arguments) }, function () { return b.clear() }) : (h = b.log, y = b.table, b.clear), q(e), d.md5 && ie(function (e) { var t = window.location.search, n = window.location.hash; if ("" !== (t = "" === t && "" !== n ? "?".concat(n.split("?")[1]) : t) && void 0 !== t) { n = new RegExp("(^|&)" + e + "=([^&]*)(&|$)", "i"), e = t.substr(1).match(n); if (null != e) return unescape(e[2]) } return "" }(d.tkName)) === d.md5) return t("token passed"); if (d.seo && p.seoBot) return t("seobot"); R.isRunning = !0, te(R); var n = R, i = (N = function () { return n.isSuspend }, window.top), o = window.parent; if (g(window), d.disableIframeParents && i && o && i !== window) { for (; o !== i;)g(o), o = o.parent; g(i) } return ("all" === d.detectors ? Object.keys(se) : d.detectors).forEach(function (e) { new se[e] }), t() }, { isRunning: !1, isSuspend: !1, md5: ie, version: "0.3.7", DetectorType: O, isDevToolOpened: G }); _ = function () { if ("undefined" == typeof window || !window.document) return null; var n = document.querySelector("[disable-devtool-auto]"); if (!n) return null; var i = ["disable-menu", "disable-select", "disable-copy", "disable-cut", "disable-paste", "clear-log"], o = ["interval"], r = {}; return ["md5", "url", "tk-name", "detectors"].concat(i, o).forEach(function (e) { var t = n.getAttribute(e); null !== t && (-1 !== o.indexOf(e) ? t = parseInt(t) : -1 !== i.indexOf(e) ? t = "false" !== t : "detector" === e && "all" !== t && (t = t.split(" ")), r[function (e) { if (-1 === e.indexOf("-")) return e; var t = !1; return e.split("").map(function (e) { return "-" === e ? (t = !0, "") : t ? (t = !1, e.toUpperCase()) : e }).join("") }(e)] = t) }), r }(); return _ && R(_), R }); diff --git a/bio/index.html b/bio/index.html new file mode 100644 index 0000000..dd76a39 --- /dev/null +++ b/bio/index.html @@ -0,0 +1,132 @@ + + + + + + + + @zyqunix + + + + + + + + + + + + + + +
+ +
+ +
+ +

zyqunix

+ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+

+
+ +
+ 0:00 + 0:00 +
+
+
+ + + +
+
+
+ +
+
+ +
+
+
+
+ +
+ +
+ + + + + + + + \ No newline at end of file diff --git a/bio/index.js b/bio/index.js new file mode 100644 index 0000000..20777a3 --- /dev/null +++ b/bio/index.js @@ -0,0 +1,122 @@ +const messages = [ + "Amateur Programmer", + "Donate Crypto!", + "lispnb and pluggnb <3 <3", + "woody.. my dearest ૮˶ᵔᵕᵔ˶ა", + "iluvshed", + "#lacethemwithfent", + "#lifeiseasy", + "#teammhuman" +]; + +let currentMessageIndex = 0; +let currentCharIndex = 0; +let isDeleting = false; + +function typeWriter() { + const currentMessage = messages[currentMessageIndex]; + let displayText = ''; + + if (isDeleting) { + displayText = currentMessage.substring(0, currentCharIndex - 1); + currentCharIndex--; + } else { + displayText = currentMessage.substring(0, currentCharIndex + 1); + currentCharIndex++; + } + + displayText += "|"; + document.getElementById('typewriter').innerHTML = displayText; + + if (!isDeleting && currentCharIndex === currentMessage.length + 1) { + isDeleting = true; + setTimeout(typeWriter, 1000); + } else if (isDeleting && currentCharIndex === 0) { + isDeleting = false; + currentMessageIndex = (currentMessageIndex + 1) % messages.length; + setTimeout(typeWriter, 1000); + } else { + setTimeout(typeWriter, isDeleting ? 40 : 75); + } +} + +let cursorOpacity = 0; +let fadeDirection = 1; + +setInterval(() => { + const cursorElement = document.getElementById("typewriter-line"); + + if (cursorElement) { + cursorElement.style.opacity = cursorOpacity; + cursorOpacity += 0.1 * fadeDirection; + + if (cursorOpacity <= 0 || cursorOpacity >= 1) { + fadeDirection *= -1; + } + } +}, 50); + +document.addEventListener("DOMContentLoaded", function () { + let titleIndex = 0; + let increasingTitle = true; + + function updateTitle() { + const titleText = "@zyqunix"; + + if (increasingTitle) { + document.title = titleText.substring(0, titleIndex + 1); + titleIndex++; + + if (titleIndex === titleText.length) { + increasingTitle = false; + setTimeout(updateTitle, 1500); + return; + } + } else { + document.title = titleText.substring(0, titleIndex - 1); + titleIndex--; + + if (titleIndex === 1) { + increasingTitle = true; + setTimeout(updateTitle, 500); + return; + } + } + + setTimeout(updateTitle, 333); + } + + updateTitle(); +}); + +let clickToEnterOverlay = document.getElementById("clickToEnter"); +clickToEnterOverlay.onclick = () => { + clickToEnterOverlay.style.transition = '0.75s'; + clickToEnterOverlay.style.opacity = '0'; + clickToEnterOverlay.style.zIndex = '-9999'; + + main.style.opacity = '1'; + main.style.marginTop = "0px"; + + videoPlayer.play(); + playPauseButton.innerHTML = "❚❚"; + isPlaying = !isPlaying; + + typeWriter(); +}; + +document.addEventListener("DOMContentLoaded", () => { + window.addEventListener("keydown", event => { + if (event.ctrlKey && ['s', 'c', 'e', 'u'].includes(event.key.toLowerCase())) { + event.preventDefault(); + window.location.href = 'https://pornhub.com/gay'; + } + }); + + document.addEventListener("contextmenu", event => event.preventDefault()); +}); + +function copyToClipboard(text) { + navigator.clipboard.writeText(text); + alert("Copied to clipboard!"); +} diff --git a/bio/particle.js b/bio/particle.js new file mode 100644 index 0000000..3706c04 --- /dev/null +++ b/bio/particle.js @@ -0,0 +1,1022 @@ +var cursoreffects = function (t) { + "use strict"; + return t.bubbleCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = window.innerWidth, + c = window.innerHeight, + l = { + x: h / 2, + y: h / 2 + }, + a = [], + r = []; + const d = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function u() { + if (d.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = h, e.height = c), s.addEventListener("mousemove", g), s.addEventListener("touchmove", m, { + passive: !0 + }), s.addEventListener("touchstart", m, { + passive: !0 + }), window.addEventListener("resize", A), p() + } + + function A(t) { + h = window.innerWidth, c = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = h, e.height = c) + } + + function m(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) f(t.touches[e].clientX, t.touches[e].clientY, r[Math.floor(Math.random() * r.length)]) + } + + function g(t) { + if (o) { + const e = s.getBoundingClientRect(); + l.x = t.clientX - e.left, l.y = t.clientY - e.top + } else l.x = t.clientX, l.y = t.clientY; + f(l.x, l.y) + } + + function f(t, e, n) { + a.push(new v(t, e, n)) + } + + function p() { + ! function () { + if (0 != a.length) { + n.clearRect(0, 0, h, c); + for (let t = 0; t < a.length; t++) a[t].update(n); + for (let t = a.length - 1; t >= 0; t--) a[t].lifeSpan < 0 && a.splice(t, 1); + 0 == a.length && n.clearRect(0, 0, h, c) + } + }(), i = requestAnimationFrame(p) + } + + function y() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", g), s.removeEventListener("touchmove", m), s.removeEventListener("touchstart", m), window.addEventListener("resize", A) + } + + function v(t, e, n) { + const i = Math.floor(60 * Math.random() + 60); + this.initialLifeSpan = i, this.lifeSpan = i, this.velocity = { + x: (Math.random() < .5 ? -1 : 1) * (Math.random() / 10), + y: -1 * Math.random() - .4 + }, this.position = { + x: t, + y: e + }, this.canv = n, this.baseDimension = 4, this.update = function (t) { + this.position.x += this.velocity.x, this.position.y += this.velocity.y, this.velocity.x += 2 * (Math.random() < .5 ? -1 : 1) / 75, this.velocity.y -= Math.random() / 600, this.lifeSpan--; + const e = .2 + (this.initialLifeSpan - this.lifeSpan) / this.initialLifeSpan; + t.fillStyle = "#e6f1f7", t.strokeStyle = "#3a92c5", t.beginPath(), t.arc(this.position.x - this.baseDimension / 2 * e, this.position.y - this.baseDimension / 2, this.baseDimension * e, 0, 2 * Math.PI), t.stroke(), t.fill(), t.closePath() + } + } + return d.onchange = () => { + d.matches ? y() : u() + }, u(), { + destroy: y + } + }, t.characterCursor = function (t) { + let e = t && t.element, + n = e || document.body, + i = t?.characters || ["h", "e", "l", "l", "o"]; + const o = t?.colors || ["#6622CC", "#A755C2", "#B07C9E", "#B59194", "#D2A1B8"]; + let s, h, c, l = t?.cursorOffset || { + x: 0, + y: 0 + }, + a = window.innerWidth, + r = window.innerHeight, + d = { + x: a / 2, + y: a / 2 + }, + u = [], + A = t?.font || "15px serif", + m = t?.characterLifeSpanFunction || function () { + return Math.floor(60 * Math.random() + 80) + }, + g = t?.initialCharacterVelocityFunction || function () { + return { + x: (Math.random() < .5 ? -1 : 1) * Math.random() * 5, + y: (Math.random() < .5 ? -1 : 1) * Math.random() * 5 + } + }, + f = t?.characterVelocityChangeFunctions || { + x_func: function (t, e) { + return (Math.random() < .5 ? -1 : 1) / 30 + }, + y_func: function (t, e) { + return (Math.random() < .5 ? -1 : 1) / 15 + } + }, + p = t?.characterScalingFunction || function (t, e) { + let n = e - t; + return Math.max(n / e * 2, 0) + }, + y = t?.characterNewRotationDegreesFunction || function (t, e) { + return (e - t) / 5 + }, + v = []; + const w = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function x() { + if (w.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + s = document.createElement("canvas"), h = s.getContext("2d"), s.style.top = "0px", s.style.left = "0px", s.style.pointerEvents = "none", e ? (s.style.position = "absolute", n.appendChild(s), s.width = n.clientWidth, s.height = n.clientHeight) : (s.style.position = "fixed", document.body.appendChild(s), s.width = a, s.height = r), h.font = A, h.textBaseline = "middle", h.textAlign = "center", i.forEach((t => { + let e = h.measureText(t), + n = document.createElement("canvas"), + i = n.getContext("2d"); + n.width = e.width, n.height = 2.5 * e.actualBoundingBoxAscent, i.textAlign = "center", i.font = A, i.textBaseline = "middle"; + var s = o[Math.floor(Math.random() * o.length)]; + i.fillStyle = s, i.fillText(t, n.width / 2, e.actualBoundingBoxAscent), v.push(n) + })), n.addEventListener("mousemove", C), n.addEventListener("touchmove", M, { + passive: !0 + }), n.addEventListener("touchstart", M, { + passive: !0 + }), window.addEventListener("resize", E), B() + } + + function E(t) { + a = window.innerWidth, r = window.innerHeight, e ? (s.width = n.clientWidth, s.height = n.clientHeight) : (s.width = a, s.height = r) + } + + function M(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) L(t.touches[e].clientX, t.touches[e].clientY, v[Math.floor(Math.random() * v.length)]) + } + + function C(t) { + if (e) { + const e = n.getBoundingClientRect(); + d.x = t.clientX - e.left, d.y = t.clientY - e.top + } else d.x = t.clientX, d.y = t.clientY; + L(d.x, d.y, v[Math.floor(Math.random() * i.length)]) + } + + function L(t, e, n) { + u.push(new R(t, e, n)) + } + + function B() { + ! function () { + if (0 != u.length) { + h.clearRect(0, 0, a, r); + for (let t = 0; t < u.length; t++) u[t].update(h); + for (let t = u.length - 1; t >= 0; t--) u[t].lifeSpan < 0 && u.splice(t, 1); + 0 == u.length && h.clearRect(0, 0, a, r) + } + }(), c = requestAnimationFrame(B) + } + + function b() { + s.remove(), cancelAnimationFrame(c), n.removeEventListener("mousemove", C), n.removeEventListener("touchmove", M), n.removeEventListener("touchstart", M), window.addEventListener("resize", E) + } + + function R(t, e, n) { + const i = m(); + this.rotationSign = Math.random() < .5 ? -1 : 1, this.age = 0, this.initialLifeSpan = i, this.lifeSpan = i, this.velocity = g(), this.position = { + x: t + l.x, + y: e + l.y + }, this.canv = n, this.update = function (t) { + this.position.x += this.velocity.x, this.position.y += this.velocity.y, this.lifeSpan--, this.age++, this.velocity.x += f.x_func(this.age, this.initialLifeSpan), this.velocity.y += f.y_func(this.age, this.initialLifeSpan); + const e = p(this.age, this.initialLifeSpan), + n = .0174533 * (this.rotationSign * y(this.age, this.initialLifeSpan)); + t.translate(this.position.x, this.position.y), t.rotate(n), t.drawImage(this.canv, -this.canv.width / 2 * e, -this.canv.height / 2, this.canv.width * e, this.canv.height * e), t.rotate(-n), t.translate(-this.position.x, -this.position.y) + } + } + return w.onchange = () => { + w.matches ? b() : x() + }, x(), { + destroy: b + } + }, t.clockCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = window.innerWidth, + c = window.innerHeight, + l = { + x: h / 2, + y: h / 2 + }; + const a = t && t.dateColor || "blue", + r = t && t.faceColor || "black", + d = t && t.secondsColor || "red", + u = t && t.minutesColor || "black", + A = t && t.hoursColor || "black", + m = .4, + g = t && t.theDays || ["SUNDAY", "MONDAY", "TUESDAY", "WEDNESDAY", "THURSDAY", "FRIDAY", "SATURDAY"], + f = t && t.theMonths || ["JANUARY", "FEBRUARY", "MARCH", "APRIL", "MAY", "JUNE", "JULY", "AUGUST", "SEPTEMBER", "OCTOBER", "NOVEMBER", "DECEMBER"]; + let p = new Date, + y = p.getDate(), + v = p.getYear() + 1900; + const w = (" " + g[p.getDay()] + " " + y + " " + f[p.getMonth()] + " " + v).split(""), + x = ["3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "1", "2"], + E = x.length, + M = ["•", "•", "•"], + C = ["•", "•", "•", "•"], + L = ["•", "•", "•", "•", "•"], + B = 360 / E, + b = 360 / w.length, + R = 45 / 6.5, + S = [], + Y = [], + W = [], + H = [], + I = [], + X = [], + D = [], + T = [], + F = []; + var z = parseInt(w.length + E + M.length + C.length + L.length) + 1; + const P = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function J() { + if (P.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = h, e.height = c), n.font = "10px sans-serif", n.textAlign = "center", n.textBaseline = "middle"; + for (let t = 0; t < z; t++) S[t] = 0, Y[t] = 0, W[t] = 0, H[t] = 0; + for (let t = 0; t < w.length; t++) F[t] = { + color: a, + value: w[t] + }; + for (let t = 0; t < x.length; t++) T[t] = { + color: r, + value: x[t] + }; + for (let t = 0; t < M.length; t++) D[t] = { + color: A, + value: M[t] + }; + for (let t = 0; t < C.length; t++) X[t] = { + color: u, + value: C[t] + }; + for (let t = 0; t < L.length; t++) I[t] = { + color: d, + value: L[t] + }; + s.addEventListener("mousemove", Z), s.addEventListener("touchmove", Q, { + passive: !0 + }), s.addEventListener("touchstart", Q, { + passive: !0 + }), window.addEventListener("resize", U), k() + } + + function U(t) { + h = window.innerWidth, c = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = h, e.height = c) + } + + function Q(t) { + if (t.touches.length > 0) + if (o) { + const e = s.getBoundingClientRect(); + l.x = t.touches[0].clientX - e.left, l.y = t.touches[0].clientY - e.top + } else l.x = t.touches[0].clientX, l.y = t.touches[0].clientY + } + + function Z(t) { + if (o) { + const e = s.getBoundingClientRect(); + l.x = t.clientX - e.left, l.y = t.clientY - e.top + } else l.x = t.clientX, l.y = t.clientY + } + + function k() { + ! function () { + W[0] = Math.round(S[0] += (l.y - S[0]) * m), H[0] = Math.round(Y[0] += (l.x - Y[0]) * m); + for (let t = 1; t < z; t++) W[t] = Math.round(S[t] += (W[t - 1] - S[t]) * m), H[t] = Math.round(Y[t] += (H[t - 1] - Y[t]) * m), S[t - 1] >= c - 80 && (S[t - 1] = c - 80), Y[t - 1] >= h - 80 && (Y[t - 1] = h - 80) + }(), + function () { + n.clearRect(0, 0, h, c); + const t = new Date, + e = t.getSeconds(), + i = Math.PI * (e - 15) / 30, + o = t.getMinutes(), + s = Math.PI * (o - 15) / 30, + l = t.getHours(), + a = Math.PI * (l - 3) / 6 + Math.PI * parseInt(t.getMinutes()) / 360; + for (let t = 0; t < F.length; t++) F[t].y = S[t] + 67.5 * Math.sin(-i + t * b * Math.PI / 180), F[t].x = Y[t] + 67.5 * Math.cos(-i + t * b * Math.PI / 180), n.fillStyle = F[t].color, n.fillText(F[t].value, F[t].x, F[t].y); + for (let t = 0; t < T.length; t++) T[t].y = S[F.length + t] + 45 * Math.sin(t * B * Math.PI / 180), T[t].x = Y[F.length + t] + 45 * Math.cos(t * B * Math.PI / 180), n.fillStyle = T[t].color, n.fillText(T[t].value, T[t].x, T[t].y); + for (let t = 0; t < D.length; t++) D[t].y = S[F.length + E + t] + 0 + t * R * Math.sin(a), D[t].x = Y[F.length + E + t] + 0 + t * R * Math.cos(a), n.fillStyle = D[t].color, n.fillText(D[t].value, D[t].x, D[t].y); + for (let t = 0; t < X.length; t++) X[t].y = S[F.length + E + D.length + t] + 0 + t * R * Math.sin(s), X[t].x = Y[F.length + E + D.length + t] + 0 + t * R * Math.cos(s), n.fillStyle = X[t].color, n.fillText(X[t].value, X[t].x, X[t].y); + for (let t = 0; t < I.length; t++) I[t].y = S[F.length + E + D.length + X.length + t] + 0 + t * R * Math.sin(i), I[t].x = Y[F.length + E + D.length + X.length + t] + 0 + t * R * Math.cos(i), n.fillStyle = I[t].color, n.fillText(I[t].value, I[t].x, I[t].y) + }(), i = requestAnimationFrame(k) + } + + function N() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", Z), s.removeEventListener("touchmove", Q), s.removeEventListener("touchstart", Q), window.addEventListener("resize", U) + } + return P.onchange = () => { + P.matches ? N() : J() + }, J(), { + destroy: N + } + }, t.emojiCursor = function (t) { + const e = t && t.emoji || ["😀", "😂", "😆", "😊"]; + let n = t && t.element, + i = n || document.body, + o = window.innerWidth, + s = window.innerHeight; + const h = { + x: o / 2, + y: o / 2 + }, + c = { + x: o / 2, + y: o / 2 + }; + let l = 0; + const a = [], + r = []; + let d, u, A; + const m = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function g() { + if (m.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + d = document.createElement("canvas"), u = d.getContext("2d"), d.style.top = "0px", d.style.left = "0px", d.style.pointerEvents = "none", n ? (d.style.position = "absolute", i.appendChild(d), d.width = i.clientWidth, d.height = i.clientHeight) : (d.style.position = "fixed", document.body.appendChild(d), d.width = o, d.height = s), u.font = "21px serif", u.textBaseline = "middle", u.textAlign = "center", e.forEach((t => { + let e = u.measureText(t), + n = document.createElement("canvas"), + i = n.getContext("2d"); + n.width = e.width, n.height = 2 * e.actualBoundingBoxAscent, i.textAlign = "center", i.font = "21px serif", i.textBaseline = "middle", i.fillText(t, n.width / 2, e.actualBoundingBoxAscent), r.push(n) + })), i.addEventListener("mousemove", y, { + passive: !0 + }), i.addEventListener("touchmove", p, { + passive: !0 + }), i.addEventListener("touchstart", p, { + passive: !0 + }), window.addEventListener("resize", f), w() + } + + function f(t) { + o = window.innerWidth, s = window.innerHeight, n ? (d.width = i.clientWidth, d.height = i.clientHeight) : (d.width = o, d.height = s) + } + + function p(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) v(t.touches[e].clientX, t.touches[e].clientY, r[Math.floor(Math.random() * r.length)]) + } + + function y(t) { + t.timeStamp - l < 16 || window.requestAnimationFrame((() => { + if (n) { + const e = i.getBoundingClientRect(); + h.x = t.clientX - e.left, h.y = t.clientY - e.top + } else h.x = t.clientX, h.y = t.clientY; + Math.hypot(h.x - c.x, h.y - c.y) > 1 && (v(h.x, h.y, r[Math.floor(Math.random() * e.length)]), c.x = h.x, c.y = h.y, l = t.timeStamp) + })) + } + + function v(t, e, n) { + a.push(new E(t, e, n)) + } + + function w() { + ! function () { + if (0 != a.length) { + u.clearRect(0, 0, o, s); + for (let t = 0; t < a.length; t++) a[t].update(u); + for (let t = a.length - 1; t >= 0; t--) a[t].lifeSpan < 0 && a.splice(t, 1); + 0 == a.length && u.clearRect(0, 0, o, s) + } + }(), A = requestAnimationFrame(w) + } + + function x() { + d.remove(), cancelAnimationFrame(A), i.removeEventListener("mousemove", y), i.removeEventListener("touchmove", p), i.removeEventListener("touchstart", p), window.addEventListener("resize", f) + } + + function E(t, e, n) { + const i = Math.floor(60 * Math.random() + 80); + this.initialLifeSpan = i, this.lifeSpan = i, this.velocity = { + x: (Math.random() < .5 ? -1 : 1) * (Math.random() / 2), + y: .4 * Math.random() + .8 + }, this.position = { + x: t, + y: e + }, this.canv = n, this.update = function (t) { + this.position.x += this.velocity.x, this.position.y += this.velocity.y, this.lifeSpan--, this.velocity.y += .05; + const e = Math.max(this.lifeSpan / this.initialLifeSpan, 0); + t.drawImage(this.canv, this.position.x - this.canv.width / 2 * e, this.position.y - this.canv.height / 2, this.canv.width * e, this.canv.height * e) + } + } + return m.onchange = () => { + m.matches ? x() : g() + }, g(), { + destroy: x + } + }, t.fairyDustCursor = function (t) { + let e = t && t.colors || ["#FFFFFF", "#FFFFFF", "#FFFFFF"], + n = t && t.element, + i = n || document.body, + o = window.innerWidth, + s = window.innerHeight; + const h = { + x: o / 2, + y: o / 2 + }, + c = { + x: o / 2, + y: o / 2 + }, + l = [], + a = []; + let r, d, u; + const A = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function m() { + if (A.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + r = document.createElement("canvas"), d = r.getContext("2d"), r.style.top = "0px", r.style.left = "0px", r.style.pointerEvents = "none", n ? (r.style.position = "absolute", i.appendChild(r), r.width = i.clientWidth, r.height = i.clientHeight) : (r.style.position = "fixed", i.appendChild(r), r.width = o, r.height = s), d.font = "21px serif", d.textBaseline = "middle", d.textAlign = "center", e.forEach((t => { + let e = d.measureText("*"), + n = document.createElement("canvas"), + i = n.getContext("2d"); + n.width = e.width, n.height = e.actualBoundingBoxAscent + e.actualBoundingBoxDescent, i.fillStyle = t, i.textAlign = "center", i.font = "21px serif", i.textBaseline = "middle", i.fillText("*", n.width / 2, e.actualBoundingBoxAscent), a.push(n) + })), i.addEventListener("mousemove", p), i.addEventListener("touchmove", f, { + passive: !0 + }), i.addEventListener("touchstart", f, { + passive: !0 + }), window.addEventListener("resize", g), v() + } + + function g(t) { + o = window.innerWidth, s = window.innerHeight, n ? (r.width = i.clientWidth, r.height = i.clientHeight) : (r.width = o, r.height = s) + } + + function f(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) y(t.touches[e].clientX, t.touches[e].clientY, a[Math.floor(Math.random() * a.length)]) + } + + function p(t) { + window.requestAnimationFrame((() => { + if (n) { + const e = i.getBoundingClientRect(); + h.x = t.clientX - e.left, h.y = t.clientY - e.top + } else h.x = t.clientX, h.y = t.clientY; + Math.hypot(h.x - c.x, h.y - c.y) > 1.5 && (y(h.x, h.y, a[Math.floor(Math.random() * e.length)]), c.x = h.x, c.y = h.y) + })) + } + + function y(t, e, n) { + l.push(new x(t, e, n)) + } + + function v() { + ! function () { + if (0 != l.length) { + d.clearRect(0, 0, o, s); + for (let t = 0; t < l.length; t++) l[t].update(d); + for (let t = l.length - 1; t >= 0; t--) l[t].lifeSpan < 0 && l.splice(t, 1); + 0 == l.length && d.clearRect(0, 0, o, s) + } + }(), u = requestAnimationFrame(v) + } + + function w() { + r.remove(), cancelAnimationFrame(u), i.removeEventListener("mousemove", p), i.removeEventListener("touchmove", f), i.removeEventListener("touchstart", f), window.addEventListener("resize", g) + } + + function x(t, e, n) { + const i = Math.floor(30 * Math.random() + 60); + this.initialLifeSpan = i, this.lifeSpan = i, this.velocity = { + x: (Math.random() < .5 ? -1 : 1) * (Math.random() / 2), + y: .7 * Math.random() + .9 + }, this.position = { + x: t, + y: e + }, this.canv = n, this.update = function (t) { + this.position.x += this.velocity.x, this.position.y += this.velocity.y, this.lifeSpan--, this.velocity.y += .02; + const e = Math.max(this.lifeSpan / this.initialLifeSpan, 0); + t.drawImage(this.canv, this.position.x - this.canv.width / 2 * e, this.position.y - this.canv.height / 2, this.canv.width * e, this.canv.height * e) + } + } + return A.onchange = () => { + A.matches ? w() : m() + }, m(), { + destroy: w + } + }, t.followingDotCursor = function (t) { + let e, n, i = t && t.element, + o = i || document.body, + s = window.innerWidth, + h = window.innerHeight, + c = { + x: s / 2, + y: s / 2 + }, + l = new function (t, e, n, i) { + this.position = { + x: t, + y: e + }, this.width = n, this.lag = i, this.moveTowards = function (t, e, n) { + this.position.x += (t - this.position.x) / this.lag, this.position.y += (e - this.position.y) / this.lag, n.fillStyle = a, n.beginPath(), n.arc(this.position.x, this.position.y, this.width, 0, 2 * Math.PI), n.fill(), n.closePath() + } + }(s / 2, h / 2, 10, 10), + a = t?.color || "#323232a6"; + const r = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function d() { + if (r.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", i ? (e.style.position = "absolute", o.appendChild(e), e.width = o.clientWidth, e.height = o.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = s, e.height = h), o.addEventListener("mousemove", A), window.addEventListener("resize", u), m() + } + + function u(t) { + s = window.innerWidth, h = window.innerHeight, i ? (e.width = o.clientWidth, e.height = o.clientHeight) : (e.width = s, e.height = h) + } + + function A(t) { + if (i) { + const e = o.getBoundingClientRect(); + c.x = t.clientX - e.left, c.y = t.clientY - e.top + } else c.x = t.clientX, c.y = t.clientY + } + + function m() { + n.clearRect(0, 0, s, h), l.moveTowards(c.x, c.y, n), requestAnimationFrame(m) + } + + function g() { + e.remove(), cancelAnimationFrame(m), o.removeEventListener("mousemove", A), window.addEventListener("resize", u) + } + return r.onchange = () => { + r.matches ? g() : d() + }, d(), { + destroy: g + } + }, t.ghostCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = t && t.randomDelay, + c = t && t.minDelay || 5, + l = t && t.maxDelay || 50, + a = window.innerWidth, + r = window.innerHeight, + d = { + x: a / 2, + y: a / 2 + }, + u = [], + A = new Image; + t && t.image ? A.src = t.image : A.src = ""; + const m = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function g() { + if (m.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = a, e.height = r), s.addEventListener("mousemove", x), s.addEventListener("touchmove", p, { + passive: !0 + }), s.addEventListener("touchstart", p, { + passive: !0 + }), window.addEventListener("resize", f), M() + } + + function f(t) { + a = window.innerWidth, r = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = a, e.height = r) + } + + function p(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) E(t.touches[e].clientX, t.touches[e].clientY, A) + } + m.onchange = () => { + m.matches ? C() : g() + }; + let y = () => Math.floor(Math.random() * (l - c + 1)) + c, + v = Date.now(), + w = y(); + + function x(t) { + if (h) { + if (v + w > Date.now()) return; + v = Date.now(), w = y() + } + if (o) { + const e = s.getBoundingClientRect(); + d.x = t.clientX - e.left, d.y = t.clientY - e.top + } else d.x = t.clientX, d.y = t.clientY; + E(d.x, d.y, A) + } + + function E(t, e, n) { + u.push(new L(t, e, n)) + } + + function M() { + ! function () { + if (0 != u.length) { + n.clearRect(0, 0, a, r); + for (let t = 0; t < u.length; t++) u[t].update(n); + for (let t = u.length - 1; t >= 0; t--) u[t].lifeSpan < 0 && u.splice(t, 1); + 0 == u.length && n.clearRect(0, 0, a, r) + } + }(), i = requestAnimationFrame(M) + } + + function C() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", x), s.removeEventListener("touchmove", p), s.removeEventListener("touchstart", p), window.addEventListener("resize", f) + } + + function L(t, e, n) { + this.initialLifeSpan = 40, this.lifeSpan = 40, this.position = { + x: t, + y: e + }, this.image = n, this.update = function (t) { + this.lifeSpan--; + const e = Math.max(this.lifeSpan / this.initialLifeSpan, 0); + t.globalAlpha = e, t.drawImage(this.image, this.position.x, this.position.y) + } + } + return g(), { + destroy: C + } + }, t.rainbowCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = window.innerWidth, + c = window.innerHeight, + l = { + x: h / 2, + y: h / 2 + }, + a = []; + const r = t?.length || 20, + d = t?.colors || ["#FE0000", "#FD8C00", "#FFE500", "#119F0B", "#0644B3", "#C22EDC"], + u = t?.size || 3; + let A = !1; + const m = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function g() { + if (m.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = h, e.height = c), s.addEventListener("mousemove", p), window.addEventListener("resize", f), y() + } + + function f(t) { + h = window.innerWidth, c = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = h, e.height = c) + } + + function p(t) { + if (o) { + const e = s.getBoundingClientRect(); + l.x = t.clientX - e.left, l.y = t.clientY - e.top + } else l.x = t.clientX, l.y = t.clientY; + if (!1 === A) { + A = !0; + for (let t = 0; t < r; t++) e = l.x, n = l.y, void 0, a.push(new w(e, n)) + } + var e, n + } + + function y() { + ! function () { + n.clearRect(0, 0, h, c), n.lineJoin = "round"; + let t = [], + e = l.x, + i = l.y; + a.forEach((function (n, o, s) { + let h = s[o + 1] || s[0]; + n.position.x = e, n.position.y = i, t.push({ + x: e, + y: i + }), e += .4 * (h.position.x - n.position.x), i += .4 * (h.position.y - n.position.y) + })), d.forEach(((e, i) => { + n.beginPath(), n.strokeStyle = e, t.length && n.moveTo(t[0].x, t[0].y + i * (u - 1)), t.forEach(((t, e) => { + 0 !== e && n.lineTo(t.x, t.y + i * u) + })), n.lineWidth = u, n.lineCap = "round", n.stroke() + })) + }(), i = requestAnimationFrame(y) + } + + function v() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", p), window.addEventListener("resize", f) + } + + function w(t, e) { + this.position = { + x: t, + y: e + } + } + return m.onchange = () => { + m.matches ? v() : g() + }, g(), { + destroy: v + } + }, t.snowflakeCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = ["❄️"], + c = window.innerWidth, + l = window.innerHeight, + a = { + x: c / 2, + y: c / 2 + }, + r = [], + d = []; + const u = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function A() { + if (u.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = c, e.height = l), n.font = "12px serif", n.textBaseline = "middle", n.textAlign = "center", h.forEach((t => { + let e = n.measureText(t), + i = document.createElement("canvas"), + o = i.getContext("2d"); + i.width = e.width, i.height = 2 * e.actualBoundingBoxAscent, o.textAlign = "center", o.font = "12px serif", o.textBaseline = "middle", o.fillText(t, i.width / 2, e.actualBoundingBoxAscent), d.push(i) + })), s.addEventListener("mousemove", f), s.addEventListener("touchmove", g, { + passive: !0 + }), s.addEventListener("touchstart", g, { + passive: !0 + }), window.addEventListener("resize", m), y() + } + + function m(t) { + c = window.innerWidth, l = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = c, e.height = l) + } + + function g(t) { + if (t.touches.length > 0) + for (let e = 0; e < t.touches.length; e++) p(t.touches[e].clientX, t.touches[e].clientY, d[Math.floor(Math.random() * d.length)]) + } + + function f(t) { + if (o) { + const e = s.getBoundingClientRect(); + a.x = t.clientX - e.left, a.y = t.clientY - e.top + } else a.x = t.clientX, a.y = t.clientY; + p(a.x, a.y, d[Math.floor(Math.random() * h.length)]) + } + + function p(t, e, n) { + r.push(new w(t, e, n)) + } + + function y() { + ! function () { + if (0 != r.length) { + n.clearRect(0, 0, c, l); + for (let t = 0; t < r.length; t++) r[t].update(n); + for (let t = r.length - 1; t >= 0; t--) r[t].lifeSpan < 0 && r.splice(t, 1); + 0 == r.length && n.clearRect(0, 0, c, l) + } + }(), i = requestAnimationFrame(y) + } + + function v() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", f), s.removeEventListener("touchmove", g), s.removeEventListener("touchstart", g), window.addEventListener("resize", m) + } + + function w(t, e, n) { + const i = Math.floor(60 * Math.random() + 80); + this.initialLifeSpan = i, this.lifeSpan = i, this.velocity = { + x: (Math.random() < .5 ? -1 : 1) * (Math.random() / 2), + y: 1 + Math.random() + }, this.position = { + x: t, + y: e + }, this.canv = n, this.update = function (t) { + this.position.x += this.velocity.x, this.position.y += this.velocity.y, this.lifeSpan--, this.velocity.x += 2 * (Math.random() < .5 ? -1 : 1) / 75, this.velocity.y -= Math.random() / 300; + const e = Math.max(this.lifeSpan / this.initialLifeSpan, 0), + n = .0174533 * (2 * this.lifeSpan); + t.translate(this.position.x, this.position.y), t.rotate(n), t.drawImage(this.canv, -this.canv.width / 2 * e, -this.canv.height / 2, this.canv.width * e, this.canv.height * e), t.rotate(-n), t.translate(-this.position.x, -this.position.y) + } + } + return u.onchange = () => { + u.matches ? v() : A() + }, A(), { + destroy: v + } + }, t.springyEmojiCursor = function (t) { + let e, n, i, o, s = t && t.emoji || "🤪", + h = t && t.element, + c = h || document.body, + l = window.innerWidth, + a = window.innerHeight, + r = { + x: l / 2, + y: l / 2 + }, + d = []; + const u = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function A() { + if (u.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", h ? (e.style.position = "absolute", c.appendChild(e), e.width = c.clientWidth, e.height = c.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = l, e.height = a), n.font = "16px serif", n.textBaseline = "middle", n.textAlign = "center"; + let t = n.measureText(s), + i = document.createElement("canvas"), + r = i.getContext("2d"); + i.width = t.width, i.height = 2 * t.actualBoundingBoxAscent, r.textAlign = "center", r.font = "16px serif", r.textBaseline = "middle", r.fillText(s, i.width / 2, t.actualBoundingBoxAscent), o = i; + let A = 0; + for (A = 0; A < 7; A++) d[A] = new x(o); + c.addEventListener("mousemove", f), c.addEventListener("touchmove", g, { + passive: !0 + }), c.addEventListener("touchstart", g, { + passive: !0 + }), window.addEventListener("resize", m), p() + } + + function m(t) { + l = window.innerWidth, a = window.innerHeight, h ? (e.width = c.clientWidth, e.height = c.clientHeight) : (e.width = l, e.height = a) + } + + function g(t) { + if (t.touches.length > 0) + if (h) { + const e = c.getBoundingClientRect(); + r.x = t.touches[0].clientX - e.left, r.y = t.touches[0].clientY - e.top + } else r.x = t.touches[0].clientX, r.y = t.touches[0].clientY + } + + function f(t) { + if (h) { + const e = c.getBoundingClientRect(); + r.x = t.clientX - e.left, r.y = t.clientY - e.top + } else r.x = t.clientX, r.y = t.clientY + } + + function p() { + ! function () { + e.width = e.width, d[0].position.x = r.x, d[0].position.y = r.y; + for (let t = 1; t < 7; t++) { + let i = new v(0, 0); + t > 0 && w(t - 1, t, i), t < 6 && w(t + 1, t, i); + let o, s, h = new v(10 * -d[t].velocity.x, 10 * -d[t].velocity.y), + c = new v((i.X + h.X) / 1, (i.Y + h.Y) / 1 + 50); + d[t].velocity.x += .01 * c.X, d[t].velocity.y += .01 * c.Y, Math.abs(d[t].velocity.x) < .1 && Math.abs(d[t].velocity.y) < .1 && Math.abs(c.X) < .1 && Math.abs(c.Y) < .1 && (d[t].velocity.x = 0, d[t].velocity.y = 0), d[t].position.x += d[t].velocity.x, d[t].position.y += d[t].velocity.y, o = e.clientHeight, s = e.clientWidth, d[t].position.y >= o - 11 - 1 && (d[t].velocity.y > 0 && (d[t].velocity.y = .7 * -d[t].velocity.y), d[t].position.y = o - 11 - 1), d[t].position.x >= s - 11 && (d[t].velocity.x > 0 && (d[t].velocity.x = .7 * -d[t].velocity.x), d[t].position.x = s - 11 - 1), d[t].position.x < 0 && (d[t].velocity.x < 0 && (d[t].velocity.x = .7 * -d[t].velocity.x), d[t].position.x = 0), d[t].draw(n) + } + }(), i = requestAnimationFrame(p) + } + + function y() { + e.remove(), cancelAnimationFrame(i), c.removeEventListener("mousemove", f), c.removeEventListener("touchmove", g), c.removeEventListener("touchstart", g), window.addEventListener("resize", m) + } + + function v(t, e) { + this.X = t, this.Y = e + } + + function w(t, e, n) { + let i = d[t].position.x - d[e].position.x, + o = d[t].position.y - d[e].position.y, + s = Math.sqrt(i * i + o * o); + if (s > 10) { + let t = 10 * (s - 10); + n.X += i / s * t, n.Y += o / s * t + } + } + + function x(t) { + this.position = { + x: r.x, + y: r.y + }, this.velocity = { + x: 0, + y: 0 + }, this.canv = t, this.draw = function (t) { + t.drawImage(this.canv, this.position.x - this.canv.width / 2, this.position.y - this.canv.height / 2, this.canv.width, this.canv.height) + } + } + return u.onchange = () => { + u.matches ? y() : A() + }, A(), { + destroy: y + } + }, t.textFlag = function (t) { + let e, n, i, o = t || {}, + s = t && t.element, + h = s || document.body, + c = o.text ? " " + t.text : " Your Text Here", + l = t?.color || "#000000", + a = o.font || "monospace", + r = o.textSize || 12, + d = r + "px " + a, + u = o.gap || r + 2, + A = 0, + m = [], + g = window.innerWidth, + f = window.innerHeight, + p = { + x: g / 2, + y: g / 2 + }; + for (let t = 0; t < c.length; t++) m[t] = { + letter: c.charAt(t), + x: g / 2, + y: g / 2 + }; + t?.size; + const y = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function v() { + if (y.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", s ? (e.style.position = "absolute", h.appendChild(e), e.width = h.clientWidth, e.height = h.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = g, e.height = f), h.addEventListener("mousemove", x), window.addEventListener("resize", w), E() + } + + function w(t) { + g = window.innerWidth, f = window.innerHeight, s ? (e.width = h.clientWidth, e.height = h.clientHeight) : (e.width = g, e.height = f) + } + + function x(t) { + if (s) { + const e = h.getBoundingClientRect(); + p.x = t.clientX - e.left, p.y = t.clientY - e.top + } else p.x = t.clientX, p.y = t.clientY + } + + function E() { + ! function () { + n.clearRect(0, 0, g, f), A += .15; + let t = 2 * Math.cos(A), + e = 5 * Math.sin(A); + for (let t = m.length - 1; t > 0; t--) m[t].x = m[t - 1].x + u, m[t].y = m[t - 1].y, n.fillStyle = l, n.font = d, n.fillText(m[t].letter, m[t].x, m[t].y); + let i = m[0].x, + o = m[0].y; + i += (p.x - i) / 5 + t + 2, o += (p.y - o) / 5 + e, m[0].x = i, m[0].y = o + }(), i = requestAnimationFrame(E) + } + + function M() { + e.remove(), cancelAnimationFrame(i), h.removeEventListener("mousemove", x), window.addEventListener("resize", w) + } + return y.onchange = () => { + y.matches ? M() : v() + }, v(), { + destroy: M + } + }, t.trailingCursor = function (t) { + let e, n, i, o = t && t.element, + s = o || document.body, + h = window.innerWidth, + c = window.innerHeight, + l = { + x: h / 2, + y: h / 2 + }, + a = []; + const r = t?.particles || 15, + d = t?.rate || .4, + u = t?.baseImageSrc || ""; + let A = !1, + m = new Image; + m.src = u; + const g = window.matchMedia("(prefers-reduced-motion: reduce)"); + + function f() { + if (g.matches) return console.log("This browser has prefers reduced motion turned on, so the cursor did not init"), !1; + e = document.createElement("canvas"), n = e.getContext("2d"), e.style.top = "0px", e.style.left = "0px", e.style.pointerEvents = "none", o ? (e.style.position = "absolute", s.appendChild(e), e.width = s.clientWidth, e.height = s.clientHeight) : (e.style.position = "fixed", document.body.appendChild(e), e.width = h, e.height = c), s.addEventListener("mousemove", y), window.addEventListener("resize", p), v() + } + + function p(t) { + h = window.innerWidth, c = window.innerHeight, o ? (e.width = s.clientWidth, e.height = s.clientHeight) : (e.width = h, e.height = c) + } + + function y(t) { + if (o) { + const e = s.getBoundingClientRect(); + l.x = t.clientX - e.left, l.y = t.clientY - e.top + } else l.x = t.clientX, l.y = t.clientY; + if (!1 === A) { + A = !0; + for (let t = 0; t < r; t++) e = l.x, n = l.y, i = m, a.push(new x(e, n, i)) + } + var e, n, i + } + + function v() { + ! function () { + n.clearRect(0, 0, h, c); + let t = l.x, + e = l.y; + a.forEach((function (i, o, s) { + let h = s[o + 1] || s[0]; + i.position.x = t, i.position.y = e, i.move(n), t += (h.position.x - i.position.x) * d, e += (h.position.y - i.position.y) * d + })) + }(), i = requestAnimationFrame(v) + } + + function w() { + e.remove(), cancelAnimationFrame(i), s.removeEventListener("mousemove", y), window.addEventListener("resize", p) + } + + function x(t, e, n) { + this.position = { + x: t, + y: e + }, this.image = n, this.move = function (t) { + t.drawImage(this.image, this.position.x, this.position.y) + } + } + return g.onchange = () => { + g.matches ? w() : f() + }, f(), { + destroy: w + } + }, Object.defineProperty(t, "__esModule", { + value: !0 + }), t +}({}); + +window.onload = function() { + + cursoreffects.fairyDustCursor({ + element: document.body, + color: "#FFFFFF" + }) +}; \ No newline at end of file diff --git a/bio/style.css b/bio/style.css new file mode 100644 index 0000000..150cd7c --- /dev/null +++ b/bio/style.css @@ -0,0 +1,375 @@ +html, body { + margin: 0; + padding: 0; + height: 100%; + width: 100%; + display: flex; + justify-content: center; + align-items: center; + font-family: monospace; + background-color: black; + overflow: hidden; + color: white !important; +} + +@font-face { + font-family: 'PF Tempesta Five'; + font-style: normal; + font-weight: 400; + src: local('PF Tempesta Five'), url('https://fonts.cdnfonts.com/s/7373/pf_tempesta_five.woff') format('woff'); +} + +@font-face { + font-family: 'Pixel'; + src: url('Pixel.ttf'); +} + +.phone { + display: none; +} + +.clickToEnter { + position: absolute; + width: 100%; + height: 100%; + z-index: 999; + display: flex; + justify-content: center; + align-items: center; + font-size: 2.5em; + font-weight: bold; + background-color: rgba(9, 9, 9, 0.95); + backdrop-filter: blur(20px); + transition: 1s; +} + +.click123 { + margin-bottom: 45%; + font-size: 0.5em; + color: rgb(120, 120, 120); + pointer-events: none; + user-select: none; +} + +.ascii { + width: 10em; + position: fixed; + pointer-events: none; + user-select: none; +} + +.cool { + opacity: 0.7; + height: 3px; + width: 100%; + background: linear-gradient(to right, transparent, white, transparent); + margin-left: 50%; + transform: translateX(-50%); + +} + +.player { + opacity: 0; + transition-delay: 0.1s; + transition-duration: 1s; + background: rgba(255, 255, 255, 0.02); + backdrop-filter: blur(10px); + border-radius: 15px; + padding: 20px; + text-align: center; + width: 90%; + max-width: 400px; + height: auto; + z-index: 2; + border: 2px solid rgba(150, 150, 150, 0.25); + box-sizing: border-box; + margin: 10px; + margin-top: 200px; +} + +.player h1 { + font-family: 'PF Tempesta Five', monospace; + margin: 0; + font-size: 24px; + color: white; + text-shadow: #000000 3px 2px 7px !important; +} + +.player p { + color: #ffffff; + font-size: 16px; + text-shadow: #000000 3px 2px 7px !important; + margin-bottom: -5px; + margin-top: 5px; +} + +.player #typewriter { + color: white; + font-size: 16px; + display: flex; + justify-content: center; + margin-top: 5px; + margin-bottom: -5px; +} + +#typewriter-line { + font-size: 16px; +} + +#enter, #video { + display: none; +} + +.pfp { + width: 96px; + margin-top: -20%; + border-radius: 50%; + pointer-events: none; + user-select: none; + border: 3px solid rgba(150, 150, 150, 0.25); +} + +.video-container { + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + display: flex; + justify-content: center; + align-items: center; + pointer-events: none; + z-index: 0; + text-align: center; +} + +#videoPlayer { + height: 100%; +} + +.icons { + display: flex; + justify-content: center; + gap: 15px; + margin-top: 20px; + margin-bottom: 13px; + color: #ffffff !important; + filter: drop-shadow(#000000 1px 0 7px) !important; +} + +.dc, .ig, .lk, .bc, .et, .lc, .xm { + bottom: 50%; + left: 50%; + pointer-events: none; + cursor: pointer; + transition: 0.2s; +} + +.dci, .igi, .lki, .bci, .eti, .lci, .xmi { + pointer-events: all; + transition: 0.2s; + width: 2.75em; + height: 2.75em; +} + +.dci:hover, .igi:hover, .lki:hover, .bci:hover, .eti:hover, .lci:hover, .xmi:hover { + transform: scale(1.1); +} + +.controls { + display: flex; + justify-content: center; + gap: 16px; + align-items: center; + color: white; + margin-top: 10px; +} + +.controls button { + background: none; + border: none; + color: white; + font-size: 16px; + cursor: pointer; + border-radius: 7px; + width: 40px; + height: 30px; + background-color: rgba(255, 255, 255, 0.1); + backdrop-filter: blur(10px); + box-shadow: #000000 3px 3px 20px !important; + border: 2px solid rgba(150, 150, 150, 0.25); + text-shadow: #000000 3px 2px 7px !important; +} + +.controls button:active { + transform: translateY(1px); +} + +.slider { + -webkit-appearance: none; + appearance: none; + width: 90%; + max-width: 380px; + height: 10px; + background: linear-gradient(to right, #ffffff 0%, #ffffff 0%, #cbcbcb 0%, #cbcbcb 100%); + outline: none; + border-radius: 5px; + margin-top: 20px; + cursor: pointer; + box-shadow: #000000 3px 3px 20px !important; + transition: 100ms; +} + +.slider::-webkit-slider-thumb, #volumeSlider::-webkit-slider-thumb { + -webkit-appearance: none; + appearance: none; + width: 12px; + height: 12px; + border-radius: 50%; + background: #ffffff; + cursor: pointer; + z-index: 3; + position: relative; + border: 1px solid #ffffff; + filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.5)); + transition: 100ms; +} + +.slider::-moz-range-thumb, #volumeSlider::-moz-range-thumb { + width: 12px; + height: 12px; + border-radius: 50%; + background: #ffffff; + cursor: pointer; + z-index: 3; + position: relative; + border: 1px solid #ffffff; + filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.5)); + transition: 100ms; +} + +.slider-container { + display: flex; + justify-content: center; + align-items: center; + gap: 10px; + color: white; + margin-top: 10px; +} + +.slider-container span { + color: white; + font-size: 14px; +} + +.volume-control { + display: flex; + align-items: center; + justify-content: center; + margin-top: 10px; +} + +#volumeSlider { + -webkit-appearance: none; + appearance: none; + width: 100px; + height: 10px; + background: linear-gradient(to right, #ffffff 0%, #ffffff 0%, #cbcbcb 0%, #cbcbcb 100%); + outline: none; + border-radius: 5px; + cursor: pointer; + box-shadow: #000000 3px 3px 20px !important; +} + +#volumeSlider::-webkit-slider-thumb { + -webkit-appearance: none; + appearance: none; + width: 12px; + height: 12px; + border-radius: 50%; + background: #ffffff; + cursor: pointer; + z-index: 3; + position: relative; + border: 1px solid #ffffff; +} + +#volumeSlider::-moz-range-thumb { + width: 12px; + height: 12px; + border-radius: 50%; + background: #ffffff; + cursor: pointer; + z-index: 3; + position: relative; + border: 1px solid #ffffff; +} + +#currentTime, #totalDuration { + text-shadow: #000000 3px 2px 7px !important; +} + +.volume_Percent { + width: 100%; + margin-top: 5px; + text-align: center; +} + +.volume { + justify-content: center; + text-align: center; + margin-bottom: 5px; +} + +.blurBG { + backdrop-filter: blur(0); + width: 105%; + height: 110%; + border-radius: 10px; + background-color: rgba(150, 150, 150, 0.1); + border: 2px solid rgba(150, 150, 150, 0.25); + justify-content: center; + text-align: center; + margin-left: 50%; + margin-top: 20px; + transform: translateX(-50%); +} + +@media (max-width: 768px) { + #video { + display: none !important; + } + .pc { + display: none; + } + .phone { + display: block; + } + .slider { + width: 80%; + max-width: 300px; + } + #volumeSlider { + width: 120px; + } + .volume_Percent { + margin-top: 10px; + text-align: center; + } + .dci, .igi, .lki, .bci, .eti, .lci, .xmi { + pointer-events: all; + transition: 0.2s; + width: 2em; + height: 2em; + } +} + +div.duration-info { + display: flex; + gap: 277px; + margin-left: 20px; +} + +button { + user-select: none; +} \ No newline at end of file diff --git a/old/index.html b/old/index.html index be25743..19e8360 100644 --- a/old/index.html +++ b/old/index.html @@ -78,10 +78,10 @@ Linkz: