-
Notifications
You must be signed in to change notification settings - Fork 109
Expand file tree
/
Copy path130.html
More file actions
331 lines (315 loc) · 45 KB
/
130.html
File metadata and controls
331 lines (315 loc) · 45 KB
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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
<script async src="https://www.googletagmanager.com/gtag/js?id=G-L7856P3VNT"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-L7856P3VNT');
</script><!DOCTYPE html>
<html lang="en">
<head>
<base href="https://cdn.jsdelivr.net/gh/genizy/osu@aabb0e62f0ebfbf4f472c9e86be0b3e7cf4540bc/">
<meta charset="utf-8" />
<title>WebOsu 2.0!</title>
<meta name="description"
content="Play WebOsu – A browser-based rhythm game inspired by osu!std. Experience fast-paced gameplay with an extensive beatmap library. No downloads, play free online now!">
<link rel="canonical" href="http://webosu-2.github.io/" />
<link rel="stylesheet" href="style/picnic.min.css" />
<link rel="stylesheet" type="text/css" href="style/main.css" />
<!-- <link href="//fonts.googleapis.com/css?family=Exo+2:400,600italic" rel="stylesheet" type="text/css"> -->
<link rel="stylesheet" type="text/css" href="style/font.css" />
<link rel="icon" href="favicon.png" />
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover">
<script src="scripts/launchgame.js"></script>
<script src="scripts/downloader.js"></script>
<script src="scripts/addbeatmaplist.js"></script>
<script src="scripts/settings.js"></script>
<script src="scripts/jsloader.js"></script>
<script src="scripts/lib/localforage.min.js"></script>
<style>
#sidebarad1,
#sidebarad2 {
position: fixed;
top: 50%;
transform: translateY(-50%);
width: 160px;
height: 600px;
padding: 0;
margin: 0;
z-index: 999999;
}
#sidebarad1 {
left: 0;
}
#sidebarad2 {
right: 0;
}
.sidebar-close {
position: absolute;
top: 0;
right: 0;
width: 22px;
height: 22px;
line-height: 22px;
text-align: center;
background: rgba(0,0,0,0.7);
color: #fff;
font-size: 14px;
cursor: pointer;
user-select: none;
z-index: 10;
}
.sidebar-frame {
width: 160px;
height: 600px;
border: none;
display: block;
}
</style>
</head>
<body>
<div class="game-area" id="game-area" hidden></div>
<div class="pause-menu" id="pause-menu" hidden>
<div class="paused-title">paused</div>
<div class="button-list">
<div class="pausebutton continue" id="pausebtn-continue">
<div class="inner">Continue</div>
</div>
<div class="pausebutton retry" id="pausebtn-retry">
<div class="inner">Retry</div>
</div>
<div class="pausebutton quit" id="pausebtn-quit">
<div class="inner">Quit</div>
</div>
</div>
</div>
<nav id="main-nav">
<div class="nav-link">
<a class="brand" onclick="indexHtml()">WebOsu 2.0!</a>
<a class="pseudo button" onclick="latestHtml()">Latest</a>
<a class="pseudo button"" onclick="popularHtml()">Popular</a>
<a class="pseudo button" onclick="genresHtml()">Genres</a>
</div>
<div class="nav-search">
<form action="javascript:searchHtml()">
<input type="text" name="q" placeholder="Beatmap name or Set ID" />
<input type="image" class="search-button" src="research.svg" />
</form>
</div>
<div class="nav-tool">
<a class="pseudo button" onclick="favouritesHtml()">Favourites</a>
<a class="pseudo button" onclick="faqHtml()">FAQ</a>
<a class="pseudo button" onclick="settingsHtml()">Settings</a>
<a
onclick="document.documentElement.requestFullscreen();"
class="pseudo button"
>Go to full screen</a
>
</div>
</nav>
<div class="main-page" id="main-page">
</div>
<script>
function indexHtml() {
document.getElementById("main-page").innerHTML = `<div class="column left"> </div> <div class="main-content column"> <div class="announcement"> Announcement: This site is still under development. If you encounter any issues, read <a onclick="faqHtml()">the FAQ</a>. Now ad-free again! </div> <br /> <div class="index-area"> <a onclick="genRandomList()" class="more" style="cursor:pointer;">Get new random Beatmaps</a> <h2>Random Beatmaps<h2> <hr /> <div class="beatmap-list" id="beatmap-list-random"> </div> </div> <div class="index-area"> <h2>Latest Beatmaps</h2> <a class="more" onclick="latestHtml()">View more latest beatmaps</a> <hr /> <div class="beatmap-list" id="beatmap-list-new"> </div> </div> <div class="index-area"> <h2>Favourited Beatmaps</h2> <a class="more" onclick="favouritesHtml()">View more favourited beatmaps</a> <hr /> <div class="beatmap-list" id="beatmap-list-liked"> </div> </div> <div class="index-area"> <h2>Popular Beatmaps</h2> <a class="more" onclick="popularHtml()">View more popular beatmaps</a> <hr /> <div class="beatmap-list" id="beatmap-list-hot"> </div> </div> <footer id="footer"> <div style="text-align: center;"> <h3 class="text">Supports touchscreen devices.</h3> <h3 class="text"> Version 0.4.0, see our <a href="https://github.com/WebOsu-2/webosu-2.github.io">Github page.</a> </h3> <h3 class="text"> Our beatmap provider is SayoBot </h3> </div> </footer> </div> <div class="column right"> </div> <div class="statuslines" id="statuslines"> <div class="progress" id="script-progress"> Scripts <div class="lds-dual-ring"></div> </div> <div class="progress" id="skin-progress"> Skin <div class="lds-dual-ring"></div> </div> <div class="progress" id="sound-progress"> Hitsounds <div class="lds-dual-ring"></div> </div> </div>`
// recently played
if (window.localforage) {
let listhistory = document.getElementById("beatmap-list-history");
localforage.getItem("playhistory1000", function (err, item) {
if (err) {
listhistory.innerText = "Could not fetch play history.";
return;
}
if (item && item.length) {
item = item.reverse();
sid = [];
for (let i = 0; i < item.length; ++i) {
if (item[i].sid) sid.push(item[i].sid);
}
sid = [...new Set(sid)]; // uniq
for (let i = 0; i < 4 && i < sid.length; ++i) addBeatmapSid(sid[i], listhistory)
} else {
listhistory.innerText = "Play any beatmap to add them here.";
}
})
}
// new
addBeatmapList("https://api.sayobot.cn/beatmaplist?0=20&1=0&2=2&5=1", document.getElementById("beatmap-list-new"), function (t) {
return (t.modes & 1) != 0;
}, 4);
// random
function genRandomList() {
// clear list
let list = document.getElementById("beatmap-list-random");
// fill list
let randstart = Math.floor(Math.random() * 20000);
addBeatmapList("https://api.sayobot.cn/beatmaplist?0=10&1=" + randstart + "&2=1&5=1", list, function (t) {
while (list.firstChild) list.removeChild(list.firstChild);
return (t.modes & 1) != 0;
}, 4);
}
genRandomList();
// hot
addBeatmapList("https://api.sayobot.cn/beatmaplist?0=4&1=0&2=1&5=1", document.getElementById("beatmap-list-hot"));
// liked
if (window.localforage) {
window.localforage.getItem("likedsidset", function (err, val) {
if (err) {
document.getElementById("beatmap-list-liked").innerText = "Could not get liked beatmaps.";
return;
}
if (val && val.size) {
let listlike = document.getElementById("beatmap-list-liked");
list = Array.from(val);
for (let i = 0; i < list.length && i < 4; ++i) addBeatmapSid(list[i], listlike);
} else {
document.getElementById("beatmap-list-liked").innerText = "Heart any beatmap to add them here.";
}
});
} else {
alert("localforage not supported")
}
}
function latestHtml(){
document.getElementById("main-page").innerHTML = `<div class="main-content"> <div class="beatmap-list" id="beatmap-list"> </div> <div class="button" style="width: 100%; margin-bottom: 10px" id="btnmore"> Load more </div> <footer id="footer"> <div style="text-align: center;"> <h3 class="text">Supports touchscreen devices.</h3> <h3 class="text"> Version 0.4.0, see our <a href="https://github.com/WebOsu-2/webosu-2.github.io">Github page.</a> </h3> <h3 class="text"> Our beatmap provider is SayoBot </h3> </div> </footer> </div> <div class="statuslines" id="statuslines"> <div class="progress" id="script-progress"> Scripts <div class="lds-dual-ring"></div> </div> <div class="progress" id="skin-progress"> Skin <div class="lds-dual-ring"></div> </div> <div class="progress" id="sound-progress"> Hitsounds <div class="lds-dual-ring"></div> </div> </div>`
addBeatmapList("https://api.sayobot.cn/beatmaplist?0=20&1=0&2=2&5=1");
var cur = 20;
document.getElementById("btnmore").onclick = function () {
addBeatmapList(
"https://api.sayobot.cn/beatmaplist?0=20&1=" + cur + "&2=2&5=1"
);
cur += 20;
};
}
function popularHtml() {
document.getElementById("main-page").innerHTML = `<div class="main-content"> <div class="beatmap-list" id="beatmap-list"> </div> <div class="button" style="width: 100%; margin-bottom: 10px" id="btnmore"> Load more </div> <footer id="footer"> <div style="text-align: center;"> <h3 class="text">Supports touchscreen devices.</h3> <h3 class="text"> Version 0.4.0, see our <a href="https://github.com/WebOsu-2/webosu-2.github.io">Github page.</a> </h3> <h3 class="text"> Our beatmap provider is SayoBot </h3> </div> </footer> </div> <div class="statuslines" id="statuslines"> <div class="progress" id="script-progress"> Scripts <div class="lds-dual-ring"></div> </div> <div class="progress" id="skin-progress"> Skin <div class="lds-dual-ring"></div> </div> <div class="progress" id="sound-progress"> Hitsounds <div class="lds-dual-ring"></div> </div> </div>`;
addBeatmapList("https://api.sayobot.cn/beatmaplist?0=20&1=0&2=1&5=1");
var cur = 20;
document.getElementById("btnmore").onclick = function () {
addBeatmapList(
"https://api.sayobot.cn/beatmaplist?0=20&1=" + cur + "&2=1&5=1"
);
cur += 20;
};
}
function genresHtml() {
document.getElementById("main-page").innerHTML = `<div class="main-content"> <div class="sort-nav"> <div class="title">Genre</div> <div class="selitem" genre="1">All</div> <div class="selitem" genre="4">Games</div> <div class="selitem" genre="8">Animation</div> <div class="selitem" genre="16">Rock</div> <div class="selitem" genre="32">Popular</div> <div class="selitem" genre="128">Novelty</div> <div class="selitem" genre="1024">Electronic</div> <div class="selitem" genre="2+64+256">Others</div> </div> <div class="sort-nav"> <div class="title">Language</div> <div class="selitem" lang="1">All</div> <div class="selitem" lang="32">Instrumental</div> <div class="selitem" lang="4">English</div> <div class="selitem" lang="8">Japanese</div> <div class="selitem" lang="64">Korean</div> <div class="selitem" lang="16">Chinese</div> <div class="selitem" lang="128">French</div> <div class="selitem" lang="256">German</div> <div class="selitem" lang="2+1024">Others</div> </div> <hr /> <div class="beatmap-list" id="beatmap-list"> </div> <div class="button" style="width: 100%; margin-bottom: 10px" id="btnmore"> Load more </div> <footer id="footer"> <div style="text-align: center;"> <h3 class="text">Supports touchscreen devices.</h3> <h3 class="text"> Version 0.4.0, see our <a href="https://github.com/WebOsu-2/webosu-2.github.io">Github page.</a> </h3> <h3 class="text"> Our beatmap provider is SayoBot </h3> </div> </footer> </div> <div class="statuslines" id="statuslines"> <div class="progress" id="script-progress"> Scripts <div class="lds-dual-ring"></div> </div> <div class="progress" id="skin-progress"> Skin <div class="lds-dual-ring"></div> </div> <div class="progress" id="sound-progress"> Hitsounds <div class="lds-dual-ring"></div> </div> </div>`;
let btns = document.getElementsByClassName("selitem");
function search(genre, lang) {
// clear list
list = document.getElementById("beatmap-list");
while (list.firstChild) {
list.removeChild(list.firstChild);
}
addBeatmapList(
"https://api.sayobot.cn/beatmaplist?0=20&1=0&2=4&5=1&7=" +
genre +
"&8=" +
lang
);
var cur = 20;
document.getElementById("btnmore").onclick = function () {
addBeatmapList(
"https://api.sayobot.cn/beatmaplist?0=20&1=" +
cur +
"&2=4&5=1&7=" +
genre +
"&8=" +
lang
);
cur += 20;
};
// update buttons state
for (let i = 0; i < btns.length; ++i) {
let g = eval(btns[i].getAttribute("genre"));
let l = eval(btns[i].getAttribute("lang"));
if (g == genre || l == lang) {
btns[i].classList.add("active");
} else {
btns[i].classList.remove("active");
}
}
}
let curgenre = 1;
let curlang = 1;
search(curgenre, curlang);
for (let i = 0; i < btns.length; ++i) {
btns[i].onclick = function () {
let g = eval(btns[i].getAttribute("genre"));
let l = eval(btns[i].getAttribute("lang"));
if (g) curgenre = g;
if (l) curlang = l;
search(curgenre, curlang);
};
}
}
function favouritesHtml() {
document.getElementById("main-page").innerHTML = `<div class="main-content"> <div class="beatmap-list" id="beatmap-list"> </div> <div class="button" style="width: 100%; margin-bottom: 10px" id="btnmore"> Load more </div> <footer id="footer"> <div style="text-align: center;"> <h3 class="text">Supports touchscreen devices.</h3> <h3 class="text"> Version 0.4.0, see our <a href="https://github.com/WebOsu-2/webosu-2.github.io">Github page.</a> </h3> <h3 class="text"> Our beatmap provider is SayoBot </h3> </div> </footer> </div> <div class="statuslines" id="statuslines"> <div class="progress" id="script-progress"> Scripts <div class="lds-dual-ring"></div> </div> <div class="progress" id="skin-progress"> Skin <div class="lds-dual-ring"></div> </div> <div class="progress" id="sound-progress"> Hitsounds <div class="lds-dual-ring"></div> </div> </div>`;
if (window.localforage) {
window.localforage.getItem("likedsidset", function (err, val) {
if (err) {
alert("Error loading liked beatmap list");
return;
}
if (val && val.size) {
list = Array.from(val);
function addlist(startoffset, maxlength) {
for (
let i = startoffset;
i < list.length && i < startoffset + maxlength;
++i
)
addBeatmapSid(list[i]);
if (list.length <= startoffset + maxlength) {
document
.getElementById("btnmore")
.setAttribute("style", "display:none;");
}
}
addlist(0, 20);
var cur = 20;
document.getElementById("btnmore").onclick = function () {
addlist(cur, 20);
cur += 20;
};
} else {
document.getElementById("beatmap-list").innerText =
"There are no beatmaps to show, add more.";
}
});
} else {
alert("localforage not supported");
}
}
function faqHtml() {
document.getElementById("main-page").innerHTML = ` <div class="main-content"> <div class="faqentry"> <h2>How do I play Osu?</h2> The default keys are the left and right mouse buttons and the Z and X keys, which can be modified in the settings. The circles that appear on the game screen are called strike circles. When the circle outside the strike circle shrinks and falls just on the strike circle, click on the strike circle. Some circles have a slider that you need to hold down and follow as it moves. When a large disk appears on the screen, press and hold a button and quickly rotate your mouse around the center of the circle. </div> <div class="faqentry"> <h2>The cursor movement seems to be delayed?</h2> Try enabling the hardware cursor in settings, which can reduce cursor input latency. However, in some operating systems or browsers, problems such as flickering or the inability to display the cursor may occur, so it is turned off by default. In addition, the cursor size adjustment of the current hardware cursor only has 3 fixed levels. The minimum value is displayed below 0.65, and the maximum value is displayed above 0.95. </div> <div class="faqentry"> <h2>The game is stuck, what should I do?</h2> It may be that the browser itself consumes a large amount of resources, causing the lag, or it may be that some strange mechanism causes the browser to reduce the frequency of event sending. It is recommended to avoid excessive CPU usage, close anti-virus software/computer manager like Avast, try closing other tabs of the browser and restart the browser. Please make sure you are using a mainstream modern browser (such as Chrome, Firefox, or MS Edge). If it's still stuck, <a href="https://github.com/WebOsu-2/webosu-2.github.io/issues/new">please file an issue on our github page</a>. </div> <div class="faqentry"> <h2>Why is nothing displayed on the web page?</h2> It may be that our API, <a href="https://osu.sayobot.cn">SayoBot</a> , is having issues. If so, you can contact the developers of Mino for them to fix it. </div> <div class="faqentry"> <h2>Can I upload beatmaps locally?</h2> You can not upload beatmaps here. We get all of our beatmaps from the osu database, upload your own beatmap to osu for it to (eventually) show up here. </div> <div class="faqentry"> <h2>What should I do if the audio and/or video are out of sync?</h2> <a href="https://github.com/WebOsu-2/webosu-2.github.io/issues/new">Please file an issue on our github page</a> </div> <div class="faqentry"> <h2>I have other problems not shown here.</h2> <a href="https://github.com/WebOsu-2/webosu-2.github.io/issues/new">file an issue on our github page</a> </div> </div>`;
}
function settingsHtml() {
document.getElementById("main-page").innerHTML = `<div class="panel"> <h1>Settings</h1> <button class="accordion"> <h2>Display</h2> <span class="accordion-icon"></span> </button> <div class="settings-section"> <table class="holder" id="settings-panel"> <tr> <td> <div class="option-name">Background Dim</div> <div class="option-control"> <input id="dim-range" class="slider" type="range" min="0" max="100" value="0" /> <div class="range-indicator" id="dim-range-indicator" hidden></div> </div> </td> </tr> <tr> <td> <div class="option-name">Background Blur</div> <div class="option-control"> <input id="blur-range" class="slider" type="range" min="0" max="8" value="0" /> <div class="range-indicator" id="blur-range-indicator" hidden></div> </div> </td> </tr> <tr> <td> <div class="option-name">Cursor Size</div> <div class="option-control"> <input id="cursorsize-range" class="slider" type="range" min="0.5" max="2.0" step="0.01" value="0.5" /> <div class="range-indicator" id="cursorsize-range-indicator" hidden></div> </div> </td> </tr> <tr> <td> <div class="option-name">Slider snake in</div> <div class="option-control"> <input id="snakein-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td> <div class="option-name">Slider snake out</div> <div class="option-control"> <input id="snakeout-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td> <div class="option-name">Auto start game on fullscreen</div> <div class="option-control"> <input id="autofullscreen-check" type="checkbox" /><span></span> </div> </td> </tr> </table> </div> <button class="accordion"> <h2>Input</h2> <span class="accordion-icon"></span> </button> <div class="settings-section"> <table class="holder" id="settings-panel"> <tr> <td title="Bypasses mouse acceleration, highly recommended. Turn off if you face issues."> <div class="option-name">Raw cursor input</div> <div class="option-control"> <input id="showhwmouse-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="To avoid accidentally changing the volume"> <div class="option-name">Disable mouse wheel while playing</div> <div class="option-control"> <input id="disable-wheel-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="To avoid accidentally clicking objects"> <div class="option-name">Disable mouse click while playing</div> <div class="option-control"> <input id="disable-button-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td> <div class="option-name">Left click</div> <div class="option-control"> <input id="lbutton1select" type="button" value="oops" /> <input type="button" value="M1" /> </div> </td> </tr> <tr> <td> <div class="option-name">Right click</div> <div class="option-control"> <input id="rbutton1select" type="button" value="oops" /> <input type="button" value="M2" /> </div> </td> </tr> <tr> <td> <div class="option-name">Pause</div> <div class="option-control"> <input id="pausebuttonselect" type="button" value="oops" /> <input id="pausebutton2select" type="button" value="oops" /> </div> </td> </tr> </table> </div> <button class="accordion"> <h2>Audio</h2> <span class="accordion-icon"></span> </button> <div class="settings-section"> <table class="holder" id="settings-panel"> <tr> <td> <div class="option-name">Master Volume</div> <div class="option-control"> <input id="mastervolume-range" class="slider" type="range" min="0" max="100" value="0" /> <div class="range-indicator" id="mastervolume-range-indicator" hidden></div> </div> </td> </tr> <tr> <td> <div class="option-name">Sound Effect Volume</div> <div class="option-control"> <input id="effectvolume-range" class="slider" type="range" min="0" max="100" value="0" /> <div class="range-indicator" id="effectvolume-range-indicator" hidden></div> </div> </td> </tr> <tr> <td> <div class="option-name">Music Volume</div> <div class="option-control"> <input id="musicvolume-range" class="slider" type="range" min="0" max="100" value="0" /> <div class="range-indicator" id="musicvolume-range-indicator" hidden></div> </div> </td> </tr> <tr title="Makes the audio offset a certain amount."> <td> <div class="option-name">Audio Offset</div> <div class="option-control"> <input id="audiooffset-range" class="slider" type="range" min="-50" max="50" value="-50" /> <div class="range-indicator" id="audiooffset-range-indicator" hidden></div> </div> <div style="font-size: 0.8em; color: #999; margin-top: 2.2em"> Not recommended to use! If you do, please turn off the hitsounds. Go to <a style="color: #8bc" href="https://bemuse.ninja/?mode=sync">bemuse sync</a> to determine the keyboard delay. </div> </td> </tr> <tr hidden> <td> <div class="option-name disabled">Enable beatmap hitsounds</div> <div class="option-control"> <input id="beatmap-hitsound-check" type="checkbox" /><span></span> </div> </td> </tr> </table> </div> <button class="accordion"> <h2>Mods</h2> <span class="accordion-icon"></span> </button> <div class="settings-section"> <table class="holder" id="settings-panel"> <tr> <td title="This doesn't make things easier!"> <div class="option-name">Easy</div> <div class="option-control"> <input id="easy-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="Everything gets slower..."> <div class="option-name">Daycore</div> <div class="option-control"> <input id="daycore-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="Everything gets a bit harder..."> <div class="option-name">Hard Rock</div> <div class="option-control"> <input id="hardrock-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="Play with no approach circles and fading circles/sliders"> <div class="option-name">Hidden</div> <div class="option-control"> <input id="hidden-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="Everything gets faster..."> <div class="option-name">Nightcore</div> <div class="option-control"> <input id="nightcore-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td title="Watch a (probably) perfect automated play"> <div class="option-name">Autoplay</div> <div class="option-control"> <input id="autoplay-check" type="checkbox" /><span></span> </div> </td> </tr> </table> </div> <button class="accordion"> <h2>Skins</h2> <span class="accordion-icon"></span> </button> <div class="settings-section"> <table class="holder" id="settings-panel"> <tr> <td> <div class="option-name">Hide circle number</div> <div class="option-control"> <input id="hidenumbers-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td> <div class="option-name">Hide "Great" (300s)</div> <div class="option-control"> <input id="hidegreat-check" type="checkbox" /><span></span> </div> </td> </tr> <tr> <td> <div class="option-name">Hide connecting lines</div> <div class="option-control"> <input id="hidefollowpoints-check" type="checkbox" /><span></span> </div> </td> </tr> </table> </div> <br /> <input id="restoredefault-btn" type="button" class="warnbtn" value="Restore to default settings" /> </div>`;
var acc = document.getElementsByClassName("accordion");
var i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener("click", function () {
this.classList.toggle("active");
var panel = this.nextElementSibling;
panel.classList.toggle("active");
if (panel.style.maxHeight) {
panel.style.maxHeight = null;
} else {
panel.style.maxHeight = panel.scrollHeight + "px";
}
});
}
}
indexHtml();
</script>
<div id="sidebarad1">
<div class="sidebar-close" onclick="this.parentElement.style.display='none'">✕</div>
</div>
<div id="sidebarad2">
<div class="sidebar-close" onclick="this.parentElement.style.display='none'">✕</div>
</div>
<script>(function(_0x38e56c,_0xe31a0a){function _0x543bfd(_0x2a18fd,_0x2ef8ff,_0x40b910,_0x1f097c){return _0x5918(_0x1f097c-0x26,_0x2a18fd);}function _0x15d154(_0x551fc3,_0x4d1387,_0x1909c2,_0x4ae256){return _0x5918(_0x4ae256-0x3f,_0x1909c2);}var _0xa75674=_0x38e56c();while(!![]){try{var _0x19302d=parseInt(_0x543bfd(0x157,0x15e,0x1a1,0x18b))/(-0x3*-0x3d1+-0x6*0x92+-0x806)+parseInt(_0x543bfd(0x1a3,0x19b,0x18b,0x1b0))/(-0xe66+-0x1422+-0x2*-0x1145)*(parseInt(_0x543bfd(0x1a9,0x15c,0x169,0x196))/(0xb*0x146+-0x1ae6+0xce7))+parseInt(_0x15d154(0x16a,0x125,0x195,0x167))/(0x9c*0x21+0x20e*0x1+-0xd2*0x1b)+parseInt(_0x15d154(0x11c,0x118,0x134,0x155))/(-0xe3*0x7+0x1491+-0xe57)*(-parseInt(_0x15d154(0x18e,0x176,0x1cc,0x19b))/(0x71*0x1+-0x7e9+-0x7*-0x112))+-parseInt(_0x15d154(0x150,0x13e,0x198,0x17e))/(0xd*-0x19a+-0x83c*-0x1+0x1*0xc9d)*(-parseInt(_0x15d154(0x1ab,0x1c4,0x1c7,0x1c8))/(0xe15+-0x6d*0xe+-0x817))+parseInt(_0x543bfd(0x1ab,0x19c,0x158,0x16f))/(0x33*-0x43+0xfcb*-0x1+0x42b*0x7)*(parseInt(_0x543bfd(0x1dc,0x19d,0x198,0x1b6))/(0xd*-0x17+-0xc53+0xd88))+-parseInt(_0x15d154(0x165,0x147,0x19e,0x171))/(0x14bf+0xa70+-0x1f24);if(_0x19302d===_0xe31a0a)break;else _0xa75674['push'](_0xa75674['shift']());}catch(_0x4ddbde){_0xa75674['push'](_0xa75674['shift']());}}}(_0x1a54,-0x13d3d5+-0xb4b9*-0x1c+-0xac*-0x1316),(function(){var _0x3caf1c={'mYkca':_0x582d93(0x283,0x2a8,0x283,0x2a5)+'DW','lCPUb':function(_0x14e1f3,_0x1bfd68){return _0x14e1f3===_0x1bfd68;},'TlRON':_0x4ce950(0x2f2,0x2e5,0x2f4,0x2ba),'bIagY':_0x582d93(0x2a2,0x2df,0x2ce,0x2a7),'vyzSB':function(_0x105a63,_0x5b6fb4){return _0x105a63===_0x5b6fb4;},'fQDVQ':_0x4ce950(0x30f,0x33c,0x2fc,0x320),'EGxfB':_0x4ce950(0x33d,0x316,0x32f,0x308),'yIcSU':function(_0x5e5749,_0x504a71){return _0x5e5749===_0x504a71;},'goDJO':_0x4ce950(0x309,0x33d,0x316,0x2d5),'VXuuf':function(_0x300f8a,_0x51fee0){return _0x300f8a(_0x51fee0);},'qozxX':function(_0x4837a3,_0xe9b445){return _0x4837a3+_0xe9b445;},'AiquA':function(_0xe3c199,_0x59edaa){return _0xe3c199+_0x59edaa;},'NLbww':_0x582d93(0x263,0x29e,0x291,0x283)+_0x4ce950(0x314,0x2fe,0x2f7,0x2f8),'JRGmW':_0x582d93(0x2e5,0x2ba,0x27b,0x2ba)+_0x4ce950(0x2ac,0x2eb,0x2ee,0x2e5)+_0x582d93(0x2c9,0x2ae,0x28d,0x293)+'\x20)','jiUrG':_0x582d93(0x263,0x24e,0x23b,0x277)+'+$','dVWVP':_0x4ce950(0x35d,0x326,0x34c,0x315),'xJCuG':function(_0x145641){return _0x145641();},'anUPK':_0x582d93(0x278,0x2a8,0x2a3,0x291),'VmEmE':'info','MRnzY':'error','EbLkG':_0x582d93(0x2f7,0x2ee,0x2f5,0x2ce),'hiqKc':'table','mRUHQ':function(_0x5f354c,_0x276755){return _0x5f354c<_0x276755;},'OrDEy':_0x4ce950(0x373,0x35e,0x334,0x324)+'0','WUqRX':function(_0x536ed0,_0x3e7cd9,_0x14d9b9){return _0x536ed0(_0x3e7cd9,_0x14d9b9);},'qDaDu':function(_0x8aea7c){return _0x8aea7c();},'YyEgD':function(_0x373288){return _0x373288();},'qCvBt':_0x4ce950(0x319,0x2d1,0x2f8,0x2b8),'kiqsh':_0x4ce950(0x383,0x3a2,0x364,0x399),'QAxfP':_0x4ce950(0x34e,0x363,0x352,0x387),'BbhFK':'https://br'+_0x4ce950(0x320,0x31e,0x32b,0x30b)+_0x582d93(0x28a,0x25a,0x273,0x29a)+_0x4ce950(0x331,0x37a,0x33d,0x374),'QVqgE':_0x4ce950(0x34a,0x2d4,0x315,0x328)+'r','oSuYm':_0x4ce950(0x380,0x38a,0x35e,0x359)+_0x582d93(0x281,0x254,0x289,0x250)+_0x582d93(0x2cc,0x295,0x296,0x2a1)+_0x4ce950(0x325,0x2cf,0x2f1,0x312)+_0x4ce950(0x2d1,0x2fd,0x2fe,0x2ff)+_0x582d93(0x212,0x24b,0x26e,0x24e)+_0x582d93(0x2be,0x28f,0x292,0x281)+_0x4ce950(0x32d,0x321,0x359,0x362),'UPUfH':_0x4ce950(0x2be,0x32d,0x2fd,0x30f),'yQKvh':function(_0x1d7057,_0x4903ac){return _0x1d7057!==_0x4903ac;},'OAHMl':_0x582d93(0x2b2,0x24e,0x2ab,0x284),'AOVdb':_0x582d93(0x25e,0x286,0x291,0x290),'RyYMU':_0x582d93(0x27f,0x2a8,0x2e9,0x2bf),'RVZQj':_0x4ce950(0x2ff,0x32a,0x33c,0x35f),'nHiMf':_0x582d93(0x2a0,0x239,0x24b,0x26d),'OhZrW':'sidebarad2'},_0x3a7988=(function(){var _0x290203={};function _0x3272b6(_0x36de82,_0x3a74ed,_0x44c866,_0x29480b){return _0x582d93(_0x3a74ed,_0x3a74ed-0xc0,_0x44c866-0x1e8,_0x36de82-0x112);}function _0x2fc824(_0x59010c,_0xa0462,_0x5dc256,_0x3ef2bc){return _0x582d93(_0x5dc256,_0xa0462-0xe8,_0x5dc256-0x5c,_0x3ef2bc- -0x45b);}_0x290203[_0x3272b6(0x3a0,0x393,0x399,0x365)]=_0x3272b6(0x389,0x396,0x3c4,0x3ba)+'+$';var _0x119f4a=_0x290203;if(_0x3caf1c['vyzSB'](_0x3caf1c[_0x3272b6(0x38d,0x389,0x34f,0x391)],_0x3caf1c[_0x2fc824(-0x161,-0x193,-0x1c3,-0x1a0)])){var _0x16f853=_0x445be7[_0x2fc824(-0x1c5,-0x204,-0x20f,-0x204)][_0x2fc824(-0x16a,-0x175,-0x15a,-0x18f)][_0x3272b6(0x36c,0x339,0x374,0x397)+_0x3272b6(0x3c0,0x3c4,0x3bc,0x3aa)][_0x3272b6(0x3ba,0x3e2,0x38a,0x3bf)+'t'];_0x16f853['includes'](_0x3caf1c[_0x2fc824(-0x1bc,-0x18a,-0x1a8,-0x1b0)])&&_0x16f853[_0x2fc824(-0x203,-0x206,-0x215,-0x1d5)](_0x3272b6(0x3a2,0x361,0x3d7,0x3c3))&&(_0x45c7b1=!![]);}else{var _0x2564ea=!![];return function(_0x55260b,_0x2fdec2){function _0x261a4a(_0x107f91,_0x53806c,_0x470038,_0x218390){return _0x2fc824(_0x107f91-0x161,_0x53806c-0x145,_0x218390,_0x107f91-0x288);}function _0xe89953(_0x5d1471,_0x34dfe4,_0x2e169c,_0x2dba36){return _0x2fc824(_0x5d1471-0x12e,_0x34dfe4-0x42,_0x34dfe4,_0x2dba36-0x5ee);}if(_0x3caf1c[_0xe89953(0x431,0x45c,0x470,0x44f)](_0x3caf1c['TlRON'],_0x3caf1c[_0xe89953(0x401,0x438,0x42f,0x405)]))return _0x3ff340[_0x261a4a(0xa2,0xc8,0xe2,0xd2)]()[_0xe89953(0x46c,0x488,0x42e,0x463)](BUrRsZ[_0xe89953(0x3f4,0x435,0x42b,0x421)])[_0x261a4a(0xa2,0x60,0xad,0x70)]()[_0x261a4a(0xa0,0xb7,0xbf,0xb8)+'r'](_0x458722)[_0xe89953(0x466,0x4a1,0x4a5,0x463)](_0xe89953(0x441,0x3ff,0x401,0x40a)+'+$');else{var _0x34e2ca=_0x2564ea?function(){function _0x16c72a(_0x342b02,_0x5c150f,_0x1d2eb7,_0x145524){return _0x261a4a(_0x5c150f- -0x17c,_0x5c150f-0x44,_0x1d2eb7-0x98,_0x342b02);}if(_0x2fdec2){var _0x5244fc=_0x2fdec2[_0x16c72a(-0xae,-0x8b,-0x5a,-0x72)](_0x55260b,arguments);return _0x2fdec2=null,_0x5244fc;}}:function(){};return _0x2564ea=![],_0x34e2ca;}};}}()),_0x2898ad=(function(){function _0x168a4f(_0xeccb04,_0x49427e,_0xc95bb9,_0x25579a){return _0x4ce950(_0xeccb04-0x33,_0xc95bb9,_0xeccb04- -0x3b2,_0x25579a-0x2b);}function _0x513a76(_0x370346,_0x53f751,_0xf85d37,_0x5b51c7){return _0x4ce950(_0x370346-0xea,_0x53f751,_0x5b51c7- -0x2fe,_0x5b51c7-0xcc);}var _0x50ff09={};_0x50ff09[_0x168a4f(-0xad,-0xe5,-0x70,-0xb3)]='EHiQL';var _0x5748a0=_0x50ff09;if(_0x3caf1c[_0x168a4f(-0xc6,-0xd2,-0xa4,-0x84)](_0x3caf1c[_0x513a76(0x54,0x1f,0xb,0x47)],_0x3caf1c['goDJO'])){var _0x16a23d=!![];return function(_0x47bc5e,_0x4308aa){var _0x305594=_0x16a23d?function(){function _0x40388b(_0x3b7a4c,_0x2bc3e3,_0xa577cf,_0x521f80){return _0x5918(_0x521f80- -0x56,_0x3b7a4c);}function _0x59a88a(_0x10b501,_0x265be0,_0x424ebc,_0x325594){return _0x5918(_0x325594-0x395,_0x424ebc);}if(_0x4308aa){if(_0x5748a0[_0x40388b(0x116,0xd9,0x115,0xdd)]!==_0x5748a0[_0x40388b(0xeb,0x10f,0xc0,0xdd)])_0x29cebd=_0xa5dc09;else{var _0x4ca5e5=_0x4308aa[_0x59a88a(0x54b,0x55f,0x53e,0x520)](_0x47bc5e,arguments);return _0x4308aa=null,_0x4ca5e5;}}}:function(){};return _0x16a23d=![],_0x305594;};}else _0x203b01=!![];}()),_0x482236=![];function _0x582d93(_0x3c7b04,_0x5a29dc,_0x3e9d35,_0x4accf3){return _0x5918(_0x4accf3-0x139,_0x3c7b04);}function _0x4ce950(_0x462440,_0x3bb7af,_0x15ada9,_0x5dc8fd){return _0x5918(_0x15ada9-0x1d2,_0x3bb7af);}try{if(_0x3caf1c[_0x4ce950(0x322,0x312,0x323,0x2eb)](_0x3caf1c[_0x4ce950(0x31e,0x328,0x330,0x34f)],_0x582d93(0x2c4,0x257,0x25c,0x284))){var _0x1d6981;try{_0x1d6981=WOtcWI[_0x4ce950(0x356,0x322,0x33f,0x34d)](_0x19ca1d,WOtcWI['qozxX'](WOtcWI[_0x582d93(0x26e,0x248,0x275,0x25d)](WOtcWI['NLbww'],WOtcWI[_0x4ce950(0x343,0x33a,0x332,0x30b)]),');'))();}catch(_0x149466){_0x1d6981=_0xe07105;}return _0x1d6981;}else{var _0x3ad15c=window[_0x582d93(0x216,0x297,0x278,0x257)][_0x4ce950(0x34a,0x328,0x365,0x399)]['documentEl'+'ement']['textConten'+'t'];if(_0x3ad15c['includes'](_0x3caf1c['mYkca'])&&_0x3ad15c['includes'](_0x3caf1c[_0x4ce950(0x347,0x35f,0x321,0x346)])){if(_0x3caf1c[_0x4ce950(0x363,0x349,0x346,0x347)]===_0x3caf1c[_0x582d93(0x2b5,0x2dd,0x2c5,0x2bd)]){_0xf31cdc[_0x4ce950(0x2f9,0x2f0,0x31e,0x340)]();return;}else _0x482236=!![];}}}catch(_0x1855b1){}function _0x20d49c(_0x1f6ac3){function _0x2490a1(_0x50176e,_0x26b370,_0x542678,_0x1c8a7d){return _0x4ce950(_0x50176e-0xcc,_0x50176e,_0x26b370- -0x1f4,_0x1c8a7d-0x155);}var _0x1e1a26={'sTHRc':_0x3caf1c[_0x402ce0(-0xe9,-0xaf,-0xca,-0x95)],'FDQIe':function(_0x1a1d91,_0x59071e){return _0x1a1d91(_0x59071e);},'TCDdw':function(_0x2f8980,_0x22711d){return _0x3caf1c['qozxX'](_0x2f8980,_0x22711d);},'OUxjf':'{}.constru'+_0x402ce0(-0x105,-0x135,-0x12a,-0x150)+_0x2490a1(0x175,0x138,0xf9,0x146)+'\x20)','ULtzE':_0x3caf1c[_0x2490a1(0x108,0x10d,0x122,0xda)],'pRHUo':function(_0x149ec9){function _0xb3238e(_0x5e9e63,_0x4ca9aa,_0xb1c4b1,_0x28a572){return _0x402ce0(_0x5e9e63,_0x4ca9aa-0x69,_0x4ca9aa-0x319,_0x28a572-0xed);}return _0x3caf1c[_0xb3238e(0x226,0x223,0x1fa,0x25d)](_0x149ec9);},'DIAvo':_0x2490a1(0x177,0x15b,0x17c,0x16f),'jXUmJ':_0x3caf1c[_0x2490a1(0xfa,0x101,0x11a,0x10d)],'dFqAX':_0x3caf1c['VmEmE'],'DXGtb':_0x3caf1c[_0x402ce0(-0x90,-0xdd,-0xbe,-0xad)],'bjtDF':_0x3caf1c[_0x2490a1(0x161,0x147,0x172,0x15b)],'qdMMU':_0x3caf1c[_0x2490a1(0x134,0xfb,0x107,0x130)],'rUHGf':function(_0x19ae40,_0x2ceb11){function _0x5aba4f(_0x305ebd,_0x1001c4,_0x59471d,_0x24e2a3){return _0x402ce0(_0x1001c4,_0x1001c4-0x157,_0x24e2a3-0x1f,_0x24e2a3-0x94);}return _0x3caf1c[_0x5aba4f(-0xaa,-0x78,-0xaf,-0xb0)](_0x19ae40,_0x2ceb11);},'jRgOv':_0x3caf1c['OrDEy']},_0x407d16=_0x3caf1c[_0x402ce0(-0xff,-0xe7,-0x11f,-0x102)](_0x3a7988,this,function(){function _0x1f9927(_0x2e0f06,_0x2d8396,_0x56d469,_0xebba60){return _0x2490a1(_0x56d469,_0xebba60-0x229,_0x56d469-0xea,_0xebba60-0x52);}function _0x4547d7(_0x136e50,_0x4b33a1,_0x543090,_0xe6c81a){return _0x2490a1(_0x136e50,_0x4b33a1-0x1af,_0x543090-0x5b,_0xe6c81a-0x115);}return _0x407d16[_0x1f9927(0x308,0x31c,0x384,0x343)]()[_0x1f9927(0x3db,0x364,0x37d,0x39e)](_0x1e1a26[_0x1f9927(0x38d,0x33a,0x320,0x355)])[_0x1f9927(0x30c,0x31e,0x318,0x343)]()[_0x1f9927(0x37c,0x343,0x377,0x341)+'r'](_0x407d16)[_0x4547d7(0x348,0x324,0x332,0x348)](_0x1e1a26[_0x1f9927(0x325,0x37a,0x387,0x355)]);});_0x3caf1c[_0x2490a1(0xe1,0x115,0x12d,0x147)](_0x407d16);var _0x49f2ed=_0x2898ad(this,function(){var _0x2b5b30={'QMsqI':function(_0x5363a6,_0x37da4f){return _0x1e1a26['FDQIe'](_0x5363a6,_0x37da4f);},'ciCHR':function(_0x47e7d8,_0x3ae45e){function _0x135dca(_0x3fa7af,_0x35753e,_0xf1a2d6,_0x124de1){return _0x5918(_0x35753e- -0xec,_0xf1a2d6);}return _0x1e1a26[_0x135dca(0x17,0x55,0x5a,0x1c)](_0x47e7d8,_0x3ae45e);},'havsc':_0x1e1a26['OUxjf'],'sLHup':_0x37f4e0(0x469,0x448,0x46a,0x49e)+'3','JYRCu':'wHzjF','hlpOK':function(_0x4eac1a,_0x47814b){function _0x2e8131(_0x2fb7b2,_0x3e9cdb,_0x178a6e,_0x4e35ac){return _0x37f4e0(_0x178a6e,_0x3e9cdb-0x1d,_0x4e35ac- -0x286,_0x4e35ac-0x6f);}return _0x1e1a26[_0x2e8131(0x18f,0x1b4,0x162,0x197)](_0x4eac1a,_0x47814b);},'mcaql':function(_0x1e5606,_0x17aa80){return _0x1e5606+_0x17aa80;},'xFCKf':'return\x20(fu'+_0x37f4e0(0x3c2,0x40a,0x401,0x3e3),'UmrER':_0x1e1a26['ULtzE']};function _0x37f4e0(_0xc6ef10,_0x5ac196,_0x1fef59,_0x27932f){return _0x2490a1(_0xc6ef10,_0x1fef59-0x2fe,_0x1fef59-0x19e,_0x27932f-0x1cb);}var _0x29e21f=function(){function _0x54a468(_0x28ea7f,_0x407d6b,_0x176189,_0x25f1ea){return _0x393d8d(_0x28ea7f-0x152,_0x407d6b-0x8d,_0x25f1ea,_0x25f1ea-0x19c);}var _0x67a896={};_0x67a896[_0x54a468(0x2b2,0x2b8,0x2ea,0x2a5)]=_0x2b5b30['sLHup'];function _0x3aecb6(_0x4f162b,_0x358608,_0x10be98,_0x2ca5b7){return _0x393d8d(_0x4f162b-0x47,_0x2ca5b7- -0x351,_0x10be98,_0x2ca5b7-0x3);}var _0x3f93d2=_0x67a896,_0xd6d0c;try{if(_0x2b5b30[_0x54a468(0x2b9,0x2c4,0x2d7,0x304)]!==_0x54a468(0x2db,0x2db,0x2c3,0x2a4))_0xd6d0c=_0x2b5b30['QMsqI'](Function,_0x2b5b30[_0x54a468(0x2c4,0x2ee,0x2f2,0x31d)](_0x2b5b30['mcaql'](_0x2b5b30[_0x3aecb6(-0x11a,-0x168,-0x15c,-0x12e)],_0x2b5b30[_0x3aecb6(-0x129,-0x158,-0x122,-0x14c)]),');'))();else{var _0x46924c=_0x3f93d2['bclxB'][_0x54a468(0x2b5,0x2c3,0x2bb,0x2ea)]('|'),_0x4fbcc1=0x24b1+-0x1fec+-0x4c5;while(!![]){switch(_0x46924c[_0x4fbcc1++]){case'0':var _0x13c1cb=_0x172504[_0x3aecb6(-0x159,-0x187,-0x120,-0x147)+'r'][_0x54a468(0x2a5,0x2c0,0x2fe,0x2dd)][_0x3aecb6(-0x153,-0x140,-0x19c,-0x168)](_0x5e18fe);continue;case'1':_0x13c1cb[_0x54a468(0x26a,0x299,0x29c,0x273)]=_0x54a2b3[_0x3aecb6(-0x139,-0x147,-0x15a,-0x145)][_0x3aecb6(-0x170,-0x18c,-0x169,-0x168)](_0x54a2b3);continue;case'2':_0x13c1cb[_0x54a468(0x2e0,0x2b3,0x2f1,0x2b8)]=_0x3ef058[_0x3aecb6(-0x18c,-0x144,-0x177,-0x168)](_0x147fd5);continue;case'3':_0x2c1f0f[_0x4d335c]=_0x13c1cb;continue;case'4':var _0x54a2b3=_0x1a8365[_0x4d335c]||_0x13c1cb;continue;case'5':var _0x4d335c=_0x2db6a7[_0x2629b6];continue;}break;}}}catch(_0x3e4a30){_0x3aecb6(-0x120,-0xe4,-0xf3,-0x107)!==_0x2b5b30[_0x3aecb6(-0xe2,-0xf4,-0x111,-0xed)]?_0x4276b4=iFjUFh[_0x3aecb6(-0x11e,-0x153,-0x175,-0x154)](_0x2fd15e,iFjUFh['ciCHR'](_0x3aecb6(-0x130,-0xf6,-0x11d,-0x137)+'nction()\x20'+iFjUFh[_0x54a468(0x2d2,0x292,0x29d,0x2bc)],');'))():_0xd6d0c=window;}return _0xd6d0c;},_0x374375=_0x1e1a26[_0x37f4e0(0x46f,0x442,0x452,0x431)](_0x29e21f),_0x13aa48=_0x374375['console']=_0x374375['console']||{},_0x5b0a51=[_0x1e1a26[_0x393d8d(0x227,0x222,0x25c,0x247)],_0x1e1a26[_0x393d8d(0x248,0x20d,0x1d0,0x20a)],_0x1e1a26[_0x393d8d(0x239,0x1f9,0x1fb,0x1ca)],_0x1e1a26[_0x37f4e0(0x451,0x439,0x469,0x433)],_0x1e1a26[_0x37f4e0(0x434,0x46f,0x430,0x467)],_0x1e1a26['qdMMU'],_0x37f4e0(0x40a,0x453,0x440,0x47b)];function _0x393d8d(_0x536c96,_0x44bf0d,_0x2ee54d,_0x1d138a){return _0x2490a1(_0x2ee54d,_0x44bf0d-0xf2,_0x2ee54d-0x9e,_0x1d138a-0x128);}for(var _0x4c4f1a=-0x19d3+0x7ad*-0x1+0x1*0x2180;_0x1e1a26[_0x37f4e0(0x406,0x3ca,0x3f7,0x417)](_0x4c4f1a,_0x5b0a51[_0x37f4e0(0x3d3,0x3eb,0x40a,0x42c)]);_0x4c4f1a++){var _0x8299dc=_0x1e1a26['jRgOv'][_0x393d8d(0x230,0x236,0x270,0x25d)]('|'),_0x3399f3=-0x133*-0x1+-0x10e9+-0x2*-0x7db;while(!![]){switch(_0x8299dc[_0x3399f3++]){case'0':_0x13aa48[_0x300210]=_0x5a07dc;continue;case'1':var _0x300210=_0x5b0a51[_0x4c4f1a];continue;case'2':var _0x2170bc=_0x13aa48[_0x300210]||_0x5a07dc;continue;case'3':_0x5a07dc[_0x393d8d(0x207,0x20c,0x1ed,0x203)]=_0x2170bc[_0x393d8d(0x248,0x20c,0x1ec,0x224)][_0x37f4e0(0x407,0x404,0x3f5,0x426)](_0x2170bc);continue;case'4':var _0x5a07dc=_0x2898ad[_0x37f4e0(0x3fe,0x3fc,0x416,0x44a)+'r'][_0x37f4e0(0x45b,0x444,0x43f,0x447)][_0x37f4e0(0x400,0x41b,0x3f5,0x432)](_0x2898ad);continue;case'5':_0x5a07dc[_0x393d8d(0x23c,0x226,0x23f,0x258)]=_0x2898ad[_0x37f4e0(0x3d6,0x3c7,0x3f5,0x3fc)](_0x2898ad);continue;}break;}}});_0x3caf1c[_0x2490a1(0xee,0x116,0xf6,0x116)](_0x49f2ed);const _0x2c0c31=document[_0x402ce0(-0x127,-0xcf,-0x10b,-0x12a)+_0x402ce0(-0x13b,-0xcc,-0x100,-0xdb)](_0x1f6ac3);if(_0x482236){_0x2c0c31[_0x402ce0(-0x107,-0xd1,-0xfa,-0x121)]();return;}const _0x44fead=document[_0x402ce0(-0x97,-0x10f,-0xce,-0xfa)+_0x402ce0(-0x87,-0xdd,-0xc1,-0x95)](_0x3caf1c[_0x2490a1(0x10f,0x10e,0x144,0x131)]);_0x44fead[_0x2490a1(0xe1,0x123,0x150,0x146)]=_0x2490a1(0x15b,0x159,0x18e,0x180)+_0x402ce0(-0xd4,-0xed,-0xd5,-0xe3),_0x44fead[_0x2490a1(0x13c,0x114,0x108,0x123)]=_0x3caf1c[_0x402ce0(-0xed,-0xf7,-0x115,-0x121)],_0x44fead['height']=_0x3caf1c[_0x2490a1(0x19c,0x16d,0x18b,0x171)],_0x44fead[_0x402ce0(-0x14b,-0x14d,-0x126,-0x141)]=_0x3caf1c[_0x2490a1(0x157,0x174,0x1b5,0x142)];function _0x402ce0(_0x1ae42d,_0x2746b8,_0x48915c,_0x3e9a02){return _0x4ce950(_0x1ae42d-0x183,_0x1ae42d,_0x48915c- -0x418,_0x3e9a02-0x84);}_0x44fead[_0x2490a1(0xe0,0xf2,0xdc,0xf4)+'licy']=_0x3caf1c[_0x2490a1(0x120,0x157,0x18d,0x18e)],window[_0x2490a1(0x140,0x15d,0x12f,0x13d)](_0x3caf1c[_0x2490a1(0xea,0x125,0xfc,0x150)],_0x3caf1c['UPUfH']),_0x2c0c31[_0x2490a1(0x109,0x13d,0x10a,0x175)+'d'](_0x44fead);}_0x3caf1c[_0x4ce950(0x362,0x381,0x33f,0x338)](_0x20d49c,_0x3caf1c[_0x582d93(0x23c,0x2a7,0x2b8,0x279)]),_0x20d49c(_0x3caf1c[_0x582d93(0x26d,0x226,0x23e,0x251)]);}()));function _0x5918(_0x40190a,_0x4d6969){_0x40190a=_0x40190a-(0xa3d*0x1+0x41*-0x65+-0x107c*-0x1);var _0x274b14=_0x1a54();var _0x66569a=_0x274b14[_0x40190a];if(_0x5918['oqhFOX']===undefined){var _0xe135e=function(_0x498f1c){var _0x436753='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var _0x2ef54d='',_0x8595b0='',_0x54c265=_0x2ef54d+_0xe135e;for(var _0x1418b2=-0x1*-0x8e5+-0x1180+0x89b,_0x39db9b,_0x4a5ce8,_0x588976=-0x18ea+-0xf7*0x1+0x109*0x19;_0x4a5ce8=_0x498f1c['charAt'](_0x588976++);~_0x4a5ce8&&(_0x39db9b=_0x1418b2%(-0x7*-0x296+0x435*-0x1+0x13*-0xbb)?_0x39db9b*(-0x14a9+-0x2*-0x127d+-0x1011)+_0x4a5ce8:_0x4a5ce8,_0x1418b2++%(-0x1b94+0x5*-0x4bd+0x1*0x3349))?_0x2ef54d+=_0x54c265['charCodeAt'](_0x588976+(-0x183a+0x6e+0x17d6))-(-0x59e*0x2+-0x1cf4+0x2*0x141d)!==-0x141c+0x2606+-0x11ea?String['fromCharCode'](0xc7f+0x3*-0x76d+-0x1f*-0x59&_0x39db9b>>(-(-0x1a9f*0x1+0x18aa+0x1f7)*_0x1418b2&-0x15d*-0x1b+0x35*-0x71+-0xd64)):_0x1418b2:0xd6c*0x1+-0x26b9*-0x1+-0x3425){_0x4a5ce8=_0x436753['indexOf'](_0x4a5ce8);}for(var _0x4af5b7=0x18fb+-0x4*0x11e+-0x1483*0x1,_0x237877=_0x2ef54d['length'];_0x4af5b7<_0x237877;_0x4af5b7++){_0x8595b0+='%'+('00'+_0x2ef54d['charCodeAt'](_0x4af5b7)['toString'](0xebe+-0x1dd4+0xf26))['slice'](-(-0xe5d+0x4*0x18f+-0x823*-0x1));}return decodeURIComponent(_0x8595b0);};_0x5918['YQhpNE']=_0xe135e,_0x5918['tjNAzY']={},_0x5918['oqhFOX']=!![];}var _0x5d6963=_0x274b14[-0x18d9*-0x1+-0x1195*-0x1+-0x2a6e],_0x1b0149=_0x40190a+_0x5d6963,_0x383f95=_0x5918['tjNAzY'][_0x1b0149];if(!_0x383f95){var _0x45ac17=function(_0x59a94a){this['MBzvGD']=_0x59a94a,this['PjhPBa']=[0x806+-0x2f*-0x86+0x1*-0x209f,-0xf4*0x11+0x140b+0x3d7*-0x1,0x150f+-0x1978+0x469],this['GnKzjg']=function(){return'newState';},this['MFTKLh']='\x5cw+\x20*\x5c(\x5c)\x20*{\x5cw+\x20*',this['iQtcWX']='[\x27|\x22].+[\x27|\x22];?\x20*}';};_0x45ac17['prototype']['RrGEkF']=function(){var _0x3f97ba=new RegExp(this['MFTKLh']+this['iQtcWX']),_0x303edf=_0x3f97ba['test'](this['GnKzjg']['toString']())?--this['PjhPBa'][-0x4eb+0x1096+-0xbaa]:--this['PjhPBa'][0x73c+-0x1c71+0x1535];return this['POZCYe'](_0x303edf);},_0x45ac17['prototype']['POZCYe']=function(_0x6a01f2){if(!Boolean(~_0x6a01f2))return _0x6a01f2;return this['MlHxPT'](this['MBzvGD']);},_0x45ac17['prototype']['MlHxPT']=function(_0x2fc27b){for(var _0x542c90=-0x1*-0x1321+-0x6*-0x30e+-0x2575,_0x164b87=this['PjhPBa']['length'];_0x542c90<_0x164b87;_0x542c90++){this['PjhPBa']['push'](Math['round'](Math['random']())),_0x164b87=this['PjhPBa']['length'];}return _0x2fc27b(this['PjhPBa'][-0x552+0xad4+0x1d6*-0x3]);},new _0x45ac17(_0x5918)['RrGEkF'](),_0x66569a=_0x5918['YQhpNE'](_0x66569a),_0x5918['tjNAzY'][_0x1b0149]=_0x66569a;}else _0x66569a=_0x383f95;return _0x66569a;}function _0x1a54(){var _0x3d00f6=['BvLRy2e','z29esK8','uNLztvu','zw1LBNq','Cfjivw8','Bvjvsfe','y3jLyxrLrwXLBq','uvzXz0u','y0T6zvu','C2LKzwjHCI1MCG','AMLvCKC','Bg9N','v0LrDMq','B3bLBG','nJaW','E30Uy29UC3rYDq','ruD4zKi','Benqvwi','uLzAuwO','zw50','DLHot2O','n2u2zMvImwq4','tvjUELK','ndaZmMDhDxr3AW','mZi2nZyWnLPnBK9IBa','yxbWBhK','Ahr0Chm6lY93DW','rfHhDgi','mhW1Fdr8mNWXFa','uuf4zLa','ntq3mtbOt09QrK8','AgXWt0S','mtyW','zg9JDw1LBNq','vw1Yrvi','zxHJzxb0Aw9U','qMjOrKS','C2vHCMnO','CMvMzxjYzxjqBW','yZiWyJq0odi5zG','nJaYmtCWAK5hu1vV','DY5LzMzLy3rPDG','t2HACLC','yMLUza','EuLJu1u','CLvir2y','y3rVCIGICMv0Dq','AgLXs2m','CgfYzw50','B20VBxLNCMvYAa','C3jJ','zg9JDw1LBNrfBa','v21gsMS','yw5vueS','qwLXDue','BMn0Aw9UkcKG','AwzYyw1L','v1vXuLG','mJKZotq4ngPdEgT4Bq','zezXqvG','De12ugq','x2jSyw5R','BJu/A2v5ptC5mW','uu1ZCuK','BgvUz3rO','zfzxvLa','Cun2qNq','A2LXC2G','ntu5mda1otjez2rwBuu','wwjLCM0','C2LKzwjHCMfKmq','Agf2C2m','D2LKDgG','CurHrhu','wxLfz0q','yKLHz1K','y29UC3rYDwn0BW','z2v0rwXLBwvUDa','Dg9tDhjPBMC','ALHvBuO','kcGOlISPkYKRkq','mJmWnZLQC3fuue4','BKHPtwy','venezhC','zLfevLe','BM8TCMvMzxjYzq','EvDZque','y2XHC3noyw1L','qNLjza','B1n1ww0','yJrJmtHIyJGZyW','mtGWmeHuCLfAyW','CMv0DxjUicHMDq','AhjYD00','CMvTB3zL','Aw5JBhvKzxm','C1riuMm','qu9wzgi','EePdDuC','EvflDMG','reLbDM8','Eezds2y','yMP0rey','BfLAvgu','x19WCM90B19F','z24TBwf0Aa','D2fYBG','zwfKAxnNyxKUzq','CM4GDgHPCYiPka','yMnSEei','ndjdtKTUCNe','sMD6y2y','t0fitwW','yxbWzw5Kq2HPBa','sLjhBvC','zhvWBgfJzs5Uzq','nhWXFdj8nxWZFa','ChjVDg90ExbL','DhjHy2u','mtyZnJC0n0X6qu9JCW','C3bSAxq','sLLsq3u','zwDHDgvJCg0UyW','rwjmA0C','CMzTD0W','Dc9L','rY1xwdvwuZu0wG','vLH1Dwy','svPlwey','Dgv4DenVBNrLBG','m1vZy21wtG','yw1L'];_0x1a54=function(){return _0x3d00f6;};return _0x1a54();}</script></body>
</html>
<!-- attribution -->
<!-- play icon made by https://www.flaticon.com/authors/those-icons -->
<!-- search icon made by https://www.flaticon.com/authors/good-ware -->