2019-10-15 23:42:47 -03:00
|
|
|
<head>
|
|
|
|
<title>Level Search</title>
|
|
|
|
<meta charset="utf-8">
|
2021-07-04 15:50:49 -04:00
|
|
|
<link href="../assets/css/browser.css" type="text/css" rel="stylesheet">
|
2019-10-15 23:42:47 -03:00
|
|
|
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-135255146-3"></script><script>window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);}gtag('js', new Date());gtag('config', 'UA-135255146-3');</script>
|
|
|
|
<link rel="icon" href="../assets/coin.png">
|
|
|
|
<meta id="meta-title" property="og:title" content="Level Search">
|
|
|
|
<meta id="meta-desc" property="og:description" content="Search for Geometry Dash levels, and filter by length, difficulty, song + more!">
|
|
|
|
<meta id="meta-image" name="og:image" itemprop="image" content="https://gdbrowser.com/assets/coin.png">
|
2021-01-21 22:28:04 -03:00
|
|
|
<meta name="twitter:card" content="summary">
|
2019-10-15 23:42:47 -03:00
|
|
|
</head>
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
<body class="levelBG" onbeforeunload="saveFilters(); saveUrl()">
|
2019-10-15 23:42:47 -03:00
|
|
|
|
|
|
|
<div id="everything">
|
|
|
|
|
|
|
|
<div id="filters" class="popup">
|
2019-10-21 12:40:56 -03:00
|
|
|
<div id="filterStuff" class="brownBox bounce center supercenter" style="width: 101vh; height: 50%; padding-top: 0.3%; padding-bottom: 3.5%; padding-left: 1%">
|
2019-10-15 23:42:47 -03:00
|
|
|
<img class="gdButton" src="../assets/close.png" width="9%" style="position: absolute; top: -8.5%; left: -5.5vh" onclick="$('#filters').hide()">
|
|
|
|
<h1 style="margin-bottom: 4%">Advanced Options</h1><br>
|
2019-12-18 21:37:21 -03:00
|
|
|
<div><h1><input type="checkbox" id="box-featured" url="&featured"><label for="box-featured" class="gdcheckbox gdButton"></label>Featured</h1></div>
|
|
|
|
<div><h1><input type="checkbox" id="box-epic" url="&epic"><label for="box-epic" class="gdcheckbox gdButton"></label>Epic</h1></div>
|
|
|
|
<div style="margin-bottom: 6%"><h1><input type="checkbox" id="box-nostar" url="&noStar"><label for="box-nostar" class="gdcheckbox gdButton"></label>No Star</h1></div>
|
|
|
|
<div><h1><input type="checkbox" id="box-original" url="&original"><label for="box-original" class="gdcheckbox gdButton"></label>Original</h1></div>
|
|
|
|
<div><h1><input type="checkbox" id="box-2player" url="&twoPlayer"><label for="box-2player" class="gdcheckbox gdButton"></label>2-Player</h1></div>
|
2021-02-01 16:30:40 -03:00
|
|
|
<div style="margin-bottom: 5%"><h1><input type="checkbox" id="box-coins" url="&coins"><label for="box-coins" class="gdcheckbox gdButton"></label>Coins</h1></div>
|
2019-10-15 23:42:47 -03:00
|
|
|
<h1 class="smallerer lessSpaced">Song</h1>
|
2021-02-01 16:30:40 -03:00
|
|
|
<img id="normalSong" class="gdButton inline gray" style="margin-right: 0.5%" src="../assets/song-normal.png" height="8%">
|
|
|
|
<img id="customSong" class="gdButton inline" style="margin-left: 0.5%" src="../assets/song-custom.png" height="8%">
|
|
|
|
<br>
|
2021-11-16 21:47:14 -03:00
|
|
|
<input id="songID" type="number" placeholder="Custom Song ID" style="height: 15%; width: 70%; text-align: center; margin-top: 2%">
|
2021-02-01 16:30:40 -03:00
|
|
|
<div id="songSelect" style="width: 100%; display: none; margin-top: 3%; text-align: center">
|
|
|
|
<img style="width: 4%" id="songDown" class="gdButton inline valign songChange" jump="-1" src="../assets/whitearrow-left.png">
|
|
|
|
<h1 class="inline valign smallerer center" id="songName" style="min-width: 60%"></h1>
|
|
|
|
<img style="width: 4%" id="songUp" class="gdButton inline valign songChange" jump="1" id="nextSong" src="../assets/whitearrow-right.png">
|
|
|
|
</div>
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2020-11-02 02:40:33 -03:00
|
|
|
<div id="customlist" class="popup">
|
|
|
|
<div class="brownBox bounce center supercenter" style="width: 100vh; height: 56%; padding-top: 0.3%; padding-bottom: 3.5%; padding-left: 1%">
|
2020-11-02 13:16:35 -03:00
|
|
|
<img class="gdButton" src="../assets/close.png" width="9%" style="position: absolute; top: -8.5%; left: -5.5vh" onclick="$('#customlist').hide()">
|
2020-11-02 02:40:33 -03:00
|
|
|
<h1>Custom List</h1><br>
|
2021-02-03 15:50:19 -03:00
|
|
|
<p id="listInfo" style="margin-top: 1%; margin-bottom: 1.5%">Paste a <cy>comma-separated</cy> list of <ca>Level IDs</ca> to create a custom list!</p>
|
2020-11-02 02:40:33 -03:00
|
|
|
<textarea id="listLevels" placeholder="18025697, 23189196, 27786218, 27728679, 25706351" style="margin-bottom: 2%; font-size: 2.5vh"></textarea>
|
|
|
|
|
|
|
|
<div class="inline" style="width: 60%">
|
|
|
|
<h1 class="smaller lessSpaced">List Name</h1>
|
|
|
|
<input id="listName" type="text" placeholder="Custom List" style="font-size: 4vh; height: 13%; width: 90%; text-align: center;" maxlength="32">
|
|
|
|
</div>
|
|
|
|
<div class="inline" style="width: 39%; margin-bottom: 3%">
|
|
|
|
<h1 class="smaller lessSpaced">Page Size</h1>
|
|
|
|
<input id="pageSize" type="number" value="10" style="font-size: 4vh; height: 13%; width: 45%; text-align: center;">
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<a id="listLink"><img src="../assets/btn-submit.png" type="submit" height=12.5%; class="disabled gdButton" style="margin-left: 1%" id="createList"></a>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2019-10-15 23:42:47 -03:00
|
|
|
<div style="position:absolute; bottom: 0%; left: 0%; width: 100%">
|
2019-10-18 17:48:33 -03:00
|
|
|
<img class="cornerPiece" src="../assets/corner.png" width=7%;>
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="position:absolute; bottom: 0%; right: 0%; width: 100%; text-align: right;">
|
2021-10-03 13:01:52 -03:00
|
|
|
<img class="cornerPiece" src="../assets/corner.png" width=7%; style="transform: scaleX(-1); pointer-events: none">
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
2020-03-13 22:07:54 -03:00
|
|
|
<div class="transparentBox center" style="width: 115vh; height: 9%; margin: 1.5% auto 1% auto; padding-bottom: 0.2%">
|
2019-10-15 23:42:47 -03:00
|
|
|
<div>
|
2019-11-02 02:20:23 -03:00
|
|
|
<input type="text" id="levelName" placeholder="Enter a level, user, or ID" maxlength=20>
|
2019-10-15 23:42:47 -03:00
|
|
|
<img search="0" src="../assets/search.png" id="searchBtn" width="20%" class="valign gdButton levelSearch" style="margin-left: 1%; margin-bottom: 2.2%">
|
|
|
|
<img id="userSearch" src="../assets/search-user.png" width="9.6%" class="valign gdButton" style="margin-left: 1%; margin-bottom: 2.2%">
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="center">
|
|
|
|
<h1 class="smaller">Quick Search</h1>
|
|
|
|
</div>
|
|
|
|
|
2020-03-13 22:07:54 -03:00
|
|
|
<div class="transparentBox center" style="width: 115vh; height: 35%; margin: 0.5% auto 1% auto; padding-top: 1.1%">
|
|
|
|
<img src="../assets/btn-top.png" height="27%" class="valign gdButton spaced levelSearch" search="mostdownloaded">
|
2019-12-17 22:20:06 -03:00
|
|
|
<span style="margin-right: 3%"></span>
|
2020-03-13 22:07:54 -03:00
|
|
|
<img src="../assets/btn-liked.png" height="27%" class="valign gdButton spaced levelSearch" search="mostliked">
|
2019-12-17 22:20:06 -03:00
|
|
|
<br>
|
2020-03-13 22:07:54 -03:00
|
|
|
<img src="../assets/btn-trending.png" height="27%" class="valign gdButton spaced levelSearch" search="trending">
|
|
|
|
<img src="../assets/btn-recent.png" height="27%" class="valign gdButton spaced levelSearch" search="recent" style="margin-left: 2%; margin-right: 2%">
|
|
|
|
<img src="../assets/btn-magic.png" height="27%" class="valign gdButton spaced levelSearch" search="magic">
|
|
|
|
<br>
|
|
|
|
<img src="../assets/btn-awarded.png" height="27%" class="valign gdButton levelSearch" search="awarded">
|
|
|
|
<img src="../assets/btn-featured.png" height="27%" class="valign gdButton levelSearch" search="featured" style="margin: 0% 2%">
|
2021-01-18 23:54:18 -03:00
|
|
|
<img src="../assets/btn-followed.png" height="27%" id="followedSearch" class="valign gdButton levelSearch" search="followed">
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="center">
|
|
|
|
<h1 class="smaller">Filters</h1>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div id="difficulties" class="transparentBox center" style="width: 115vh; height: 12%; margin: 0.5% auto 1% auto; padding-top: 1%; padding-bottom: 1%;">
|
2021-01-04 12:21:58 -03:00
|
|
|
<div class="diffDiv gdButton" diff="-1"><img src="../assets/difficulties/unrated.png"><h3 class="mini">N/A</h3></div>
|
|
|
|
<div class="diffDiv gdButton" diff=1><img src="../assets/difficulties/easy.png"><h3 class="mini">Easy</h3></div>
|
|
|
|
<div class="diffDiv gdButton" diff=2><img src="../assets/difficulties/normal.png"><h3 class="mini">Normal</h3></div>
|
|
|
|
<div class="diffDiv gdButton" diff=3><img src="../assets/difficulties/hard.png"><h3 class="mini">Hard</h3></div>
|
|
|
|
<div class="diffDiv gdButton" diff=4><img src="../assets/difficulties/harder.png"><h3 class="mini">Harder</h3></div>
|
|
|
|
<div class="diffDiv gdButton" diff=5><img src="../assets/difficulties/insane.png"><h3 class="mini">Insane</h3></div>
|
|
|
|
|
2021-01-18 23:54:18 -03:00
|
|
|
<div class="diffDiv gdButton" id="demonBtn" diff=-2><img src="../assets/difficulties/demon.png" style="width: 85%"><h3 class="mini">Demon</h3></div>
|
2021-01-04 12:21:58 -03:00
|
|
|
|
2021-01-18 23:54:18 -03:00
|
|
|
<!-- <div class="diffDiv gdButton" style="filter: brightness(100%)" id="demonBtn" diff=-2><img class="darkDiff" src="../assets/difficulties/demon.png" style="width: 85%"><h3 class="darkDiff mini">Demon</h3> -->
|
|
|
|
<!-- <img src="../assets/exclamation.png" style="position: absolute; width: 19%; left: 86%; bottom: 68%"></div> -->
|
2021-01-04 12:21:58 -03:00
|
|
|
|
|
|
|
<div class="diffDiv gdButton" diff=-3><img src="../assets/difficulties/auto.png"><h3 class="mini">Auto</h3></div>
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
2021-01-04 12:21:58 -03:00
|
|
|
<div id="demons" class="transparentBox" style="display: none; width: 115vh; height: 12%; margin: 0.5% auto 1% auto; padding-top: 0.6%; padding-bottom: 1.4%;">
|
|
|
|
<div class="diffDiv gdButton demonDiff" diff=1 style="margin-left: 3.5%"><img src="../assets/difficulties/demon-easy.png" style="width: 90%"><h3 class="mini center">Easy</h3></div>
|
|
|
|
<div class="diffDiv gdButton demonDiff" diff=2><img src="../assets/difficulties/demon-medium.png" style="width: 90%"><h3 class="mini center smallTextWoo">Medium</h3></div>
|
|
|
|
<div class="diffDiv gdButton demonDiff" diff=3><img src="../assets/difficulties/demon-hard.png" style="width: 90%"><h3 class="mini center">Hard</h3></div>
|
|
|
|
<div class="diffDiv gdButton demonDiff" diff=4><img src="../assets/difficulties/demon-insane.png" style="width: 95%"><h3 class="mini center smallTextWoo">Insane</h3></div>
|
|
|
|
<div class="diffDiv gdButton demonDiff" diff=5><img src="../assets/difficulties/demon-extreme.png" style="width: 100%"><h3 class="mini center smallTextWoo">Extreme</h3></div>
|
|
|
|
<div class="diffDiv gdButton goBack" diff=-2 style="margin-left: 2.3%; filter: none"><img src="../assets/difficulties/demon.png" style="width: 90%"><h3 class="mini">Demon</h3></div>
|
2021-01-21 19:15:31 -03:00
|
|
|
<a id="demonList" style="display: none" href="./search/*?type=demonlist"><div class="gdButton diffDiv" style="filter: none"><img src="../assets/trophy2.png" style="width: 95%"><h3 class="yellow mini center">List</h3></div></a>
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="transparentBox center" style="width: 115vh; height: 6%; margin: 0.5% auto 1% auto; padding-top: 1%; padding-bottom: 0.5%;">
|
2021-10-07 11:19:43 -03:00
|
|
|
<!-- <div class="lengthDiv" style="pointer-events: none" len=0><h1 class="gdButton smaller" style="pointer-events: none"><img src="../assets/time.png" height="90%" style="pointer-events: none"></h1></div> -->
|
2019-10-15 23:42:47 -03:00
|
|
|
<div class="lengthDiv" len=0><h1 class="gdButton smaller">Tiny</h1></div>
|
|
|
|
<div class="lengthDiv" len=1><h1 class="gdButton smaller">Short</h1></div>
|
|
|
|
<div class="lengthDiv" len=2><h1 class="gdButton smaller">Medium</h1></div>
|
|
|
|
<div class="lengthDiv" len=3><h1 class="gdButton smaller">Long</h1></div>
|
|
|
|
<div class="lengthDiv" len=4><h1 class="gdButton smaller">XL</h1></div>
|
|
|
|
<div class="lengthDiv" id="starCheck"><img src="../assets/star.png" class="gdButton" height="90%"></div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="position:absolute; top: 2%; left: 1.5%; width: 10%; height: 25%; pointer-events: none">
|
|
|
|
<img class="gdButton yesClick" id="backButton" src="../assets/back.png" height="30%" onclick="backButton()">
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="position:absolute; top: 2%; right: 1.5%; width: 10%; text-align: right">
|
2021-11-16 21:47:14 -03:00
|
|
|
<img class="gdButton" style="margin-bottom: 12%" src="../assets/close.png" width="60%" onclick="clearFilters()">
|
|
|
|
<img class="gdButton" style="margin-bottom: 12%" id="showFilters" src="../assets/plus.png" width="60%" onclick="$('#filters').show()">
|
2020-11-02 02:40:33 -03:00
|
|
|
<img class="gdButton" src="../assets/listbutton.png" width="60%" onclick="$('#customlist').show()">
|
2019-10-15 23:42:47 -03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</body>
|
2019-10-21 12:20:25 -03:00
|
|
|
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
|
2021-01-18 23:54:18 -03:00
|
|
|
<script type="text/javascript" src="../sizecheck.js?"></script>
|
2019-10-15 23:42:47 -03:00
|
|
|
<script>
|
|
|
|
|
|
|
|
let filters = []
|
|
|
|
let demons = []
|
2021-02-01 16:30:40 -03:00
|
|
|
let demonMode = false
|
|
|
|
let customSong = true
|
|
|
|
let officialSong = 1
|
2019-10-15 23:42:47 -03:00
|
|
|
|
2020-11-02 02:40:33 -03:00
|
|
|
function undupe(array) {
|
|
|
|
if (!Array.isArray(array)) return array
|
|
|
|
else return array.filter((x, y) => array.indexOf(x) == y)
|
|
|
|
}
|
|
|
|
|
2019-10-15 23:42:47 -03:00
|
|
|
$('#userSearch').click(function() {
|
2020-10-03 23:01:14 -03:00
|
|
|
let query = encodeURIComponent($('#levelName').val()).replace(/%2F/gi, "")
|
2020-09-29 22:42:18 -03:00
|
|
|
if (query) window.location.href = "./u/" + query
|
2019-10-15 23:42:47 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
$('.levelSearch').click(function() {
|
|
|
|
|
|
|
|
let url = "./search/" + (encodeURIComponent($('#levelName').val()) || "*") + "?type=" + $(this).attr('search')
|
2020-03-15 23:18:54 -03:00
|
|
|
if ($(this).attr('search') == "featured") return window.location.href = url
|
2019-10-15 23:42:47 -03:00
|
|
|
|
|
|
|
// === DIFFICULTY === //
|
|
|
|
let difficulties = []
|
|
|
|
$('.diffDiv').each(function() {if ($(this).hasClass('selectedFilter')) difficulties.push($(this).attr('diff'))})
|
|
|
|
demonFilter = demonMode && difficulties[0] > 0
|
|
|
|
|
|
|
|
if (!difficulties.length) url += ""
|
2021-11-16 21:47:14 -03:00
|
|
|
else if (!demonFilter) url += "&diff=" + undupe(difficulties).join(",")
|
2019-10-15 23:42:47 -03:00
|
|
|
else url += "&diff=-2&demonFilter=" + difficulties[0]
|
|
|
|
|
|
|
|
// === LENGTH === //
|
|
|
|
let lengths = []
|
|
|
|
$('.lengthDiv').each(function() {if ($(this).hasClass('selectedFilter') && $(this).attr('len')) lengths.push($(this).attr('len'))})
|
|
|
|
if (lengths.length) url += "&length=" + lengths.join(",")
|
|
|
|
if ($('#starCheck').hasClass('selectedFilter')) url += "&starred"
|
|
|
|
|
|
|
|
// === CHECKBOXES === //
|
|
|
|
$("input:checked").each(function () {
|
|
|
|
url += $(this).attr('url')})
|
|
|
|
|
|
|
|
// === SONG === //
|
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
let selectedOfficial = customSong ? null : officialSong
|
2021-11-16 21:47:14 -03:00
|
|
|
let selectedCustom = customSong && $('#songID').val() ? $('#songID').val().slice(0, 16) : null
|
2021-02-01 16:30:40 -03:00
|
|
|
let selectedSong = selectedCustom || selectedOfficial
|
2019-10-15 23:42:47 -03:00
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
if (selectedSong) {
|
|
|
|
url += "&songID=" + selectedSong
|
|
|
|
if (customSong) url += "&customSong"
|
2019-10-15 23:42:47 -03:00
|
|
|
}
|
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
// === FINISHING UP === //
|
2019-10-19 01:47:00 -03:00
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
if (url.endsWith('?type=0')) url = url.slice(0, -7)
|
2019-10-21 00:33:01 -03:00
|
|
|
window.location.href = url.replace(/\?type=0&/, "?")
|
2019-10-15 23:42:47 -03:00
|
|
|
|
|
|
|
})
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
function getDiffFilters() {
|
|
|
|
return $('.diffDiv.selectedFilter').map(function() { return $(this).attr('diff') }).toArray()
|
|
|
|
}
|
|
|
|
|
|
|
|
function showDemonDiffs() {
|
|
|
|
$('#difficulties').hide();
|
|
|
|
$('#demons').show();
|
|
|
|
demonMode = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function hideDemonDiffs() {
|
|
|
|
$('#difficulties').show();
|
|
|
|
$('#demons').hide();
|
|
|
|
demonMode = false;
|
|
|
|
}
|
|
|
|
|
2019-10-15 23:42:47 -03:00
|
|
|
$('.diffDiv').click(function() {
|
|
|
|
|
|
|
|
if ($(this).hasClass('goBack')) {
|
2021-11-16 21:47:14 -03:00
|
|
|
|
2019-10-15 23:42:47 -03:00
|
|
|
$('#demonBtn').removeClass('selectedFilter')
|
|
|
|
$('.demonDiff').removeClass('selectedFilter')
|
2021-11-16 21:47:14 -03:00
|
|
|
savedFilters.demonDiff = false
|
|
|
|
savedFilters.diff = []
|
|
|
|
return hideDemonDiffs()
|
2019-10-15 23:42:47 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
$(this).toggleClass('selectedFilter')
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
filters = getDiffFilters()
|
2019-10-15 23:42:47 -03:00
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
let minusCheck = filters.filter(x => x < 0)
|
2019-10-15 23:42:47 -03:00
|
|
|
if (minusCheck.length || $(this).hasClass('demonDiff')) {
|
|
|
|
filters = minusCheck
|
|
|
|
$('.diffDiv').removeClass('selectedFilter')
|
|
|
|
$(this).addClass('selectedFilter')
|
|
|
|
}
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
savedFilters.diff = getDiffFilters()
|
|
|
|
savedFilters.demonDiff = demonMode
|
|
|
|
|
|
|
|
if ($(this).attr('diff') == -2) showDemonDiffs()
|
|
|
|
|
2019-10-15 23:42:47 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
$('.lengthDiv').click(function() {
|
|
|
|
$(this).toggleClass('selectedFilter')
|
2021-11-16 21:47:14 -03:00
|
|
|
savedFilters.len = $('.lengthDiv.selectedFilter').map(function() { return $(this).attr('len') }).toArray()
|
|
|
|
savedFilters.starred = $('#starCheck').hasClass('selectedFilter')
|
|
|
|
if (!savedFilters.starred) delete savedFilters.starred
|
2019-10-15 23:42:47 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
$(document).keydown(function(k) {
|
2021-06-24 19:24:08 -04:00
|
|
|
let searchFocus = $(':focus-visible').length == 1 && $(':focus-visible').first().attr('id') == "levelName"
|
|
|
|
if ((!$(':focus-visible').length || searchFocus) && k.which == 13) { // enter
|
2020-11-02 02:40:33 -03:00
|
|
|
if (!$('#customlist').is(':hidden')) k.preventDefault();
|
2021-05-28 13:23:59 -04:00
|
|
|
else if ($('#filters').is(':hidden')) $('#searchBtn').trigger('click')
|
2020-11-02 02:40:33 -03:00
|
|
|
}
|
2019-10-22 20:54:19 -03:00
|
|
|
});
|
|
|
|
|
2020-11-02 02:40:33 -03:00
|
|
|
$('#pageSize').on('input blur', function (event) {
|
2020-11-07 21:20:44 -03:00
|
|
|
var x = +$(this).val(); var max = 250; var min = 1
|
2020-11-02 02:40:33 -03:00
|
|
|
if (event.type == "input") { if (x > max || x < min) $(this).addClass('red'); else $(this).removeClass('red')}
|
|
|
|
else {
|
|
|
|
$(this).val(Math.max(Math.min(Math.floor(x), max), min));
|
|
|
|
$(this).removeClass('red')
|
|
|
|
}
|
|
|
|
$('#listLevels').trigger('input')
|
|
|
|
})
|
|
|
|
|
|
|
|
let listMsg = $('#listInfo').html()
|
|
|
|
$('#listLevels, #listName').on('input blur', function (event) {
|
|
|
|
let levels = $('#listLevels').val().replace(/\n| /g, ",").split(",").map(x => x.replace(/[^0-9]/g, "")).filter(x => +x > 0 && +x < 100000000000)
|
|
|
|
levels = undupe(levels)
|
|
|
|
|
|
|
|
if (levels.length > 1 && levels.length <= 100) {
|
2021-02-03 15:50:19 -03:00
|
|
|
$('#listInfo').html(`A list of <cy>${levels.length}</cy> levels will be created.`)
|
2020-11-02 13:16:35 -03:00
|
|
|
$('#listLink').attr('href', `../search/${levels.join(",")}?list&count=${+$('#pageSize').val()}${$('#listName').val().length ? `&header=${encodeURIComponent($('#listName').val())}` : ""}`)
|
2020-11-02 02:40:33 -03:00
|
|
|
$('#createList').removeClass('disabled')
|
|
|
|
}
|
|
|
|
|
|
|
|
else {
|
|
|
|
$('#createList').addClass('disabled')
|
|
|
|
if (levels.length > 100) $('#listInfo').html('Custom lists have a max of 100 levels!')
|
|
|
|
else if (levels.length == 1) $('#listInfo').html("Please enter more than one level!")
|
|
|
|
else $('#listInfo').html(listMsg)
|
|
|
|
}
|
2019-10-22 20:54:19 -03:00
|
|
|
|
2020-11-02 02:40:33 -03:00
|
|
|
})
|
2019-10-15 23:42:47 -03:00
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
$(document).on('change', 'input[url]', function () {
|
|
|
|
savedFilters.checked = $('input[url]:checked').map(function() { return $(this).attr('id').slice(4) }).toArray()
|
|
|
|
checkExtraFilters()
|
|
|
|
})
|
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
$('#normalSong').click(function() {
|
|
|
|
customSong = false
|
2021-11-16 21:47:14 -03:00
|
|
|
savedFilters.defaultSong = true
|
|
|
|
savedFilters.song = officialSong
|
2021-02-01 16:30:40 -03:00
|
|
|
$('#customSong').addClass('gray')
|
|
|
|
$('#normalSong').removeClass('gray')
|
|
|
|
$('#songSelect').show()
|
|
|
|
$('#songID').hide()
|
2021-11-16 21:47:14 -03:00
|
|
|
checkExtraFilters()
|
2021-02-01 16:30:40 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
$('#customSong').click(function() {
|
|
|
|
customSong = true
|
2021-11-16 21:47:14 -03:00
|
|
|
delete savedFilters.defaultSong
|
|
|
|
savedFilters.song = Number($('#songID').val().slice(0, 16)) || 0
|
2021-02-01 16:30:40 -03:00
|
|
|
$('#normalSong').addClass('gray')
|
|
|
|
$('#customSong').removeClass('gray')
|
|
|
|
$('#songID').show()
|
|
|
|
$('#songSelect').hide()
|
2021-11-16 21:47:14 -03:00
|
|
|
checkExtraFilters()
|
2021-02-01 16:30:40 -03:00
|
|
|
})
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
$('#songID').on('input change blur', function() {
|
|
|
|
savedFilters.song = Number($(this).val().slice(0, 16))
|
|
|
|
checkExtraFilters()
|
|
|
|
})
|
|
|
|
|
|
|
|
function saveFilters() {
|
|
|
|
localStorage.filters = JSON.stringify(savedFilters)
|
|
|
|
}
|
|
|
|
|
|
|
|
function clearFilters() {
|
|
|
|
$('.selectedFilter').removeClass('selectedFilter')
|
|
|
|
$('input[url]').prop('checked', false)
|
|
|
|
$('#songID').val("")
|
2021-12-03 18:30:58 -03:00
|
|
|
$('#levelName').val("")
|
2021-11-16 21:47:14 -03:00
|
|
|
$('#customSong').click()
|
|
|
|
hideDemonDiffs()
|
|
|
|
officialSong = 1
|
|
|
|
savedFilters = { diff: [], len: [], checked: [] }
|
|
|
|
delete localStorage.saveFilters
|
|
|
|
checkExtraFilters()
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkExtraFilters() {
|
|
|
|
let hasExtra = savedFilters.checked.length || savedFilters.defaultSong || savedFilters.song > 0
|
|
|
|
$('#showFilters').attr('src', `../assets/plus${hasExtra ? "_blue" : ""}.png`)
|
|
|
|
}
|
|
|
|
|
|
|
|
let savedFilters = JSON.parse(localStorage.filters || "{}")
|
|
|
|
$('input[url]').prop('checked', false)
|
|
|
|
|
|
|
|
if (!savedFilters.diff) savedFilters.diff = []
|
|
|
|
else if (savedFilters.demonDiff) { showDemonDiffs(); $(`.demonDiff[diff=${savedFilters.diff}]`).trigger('click') }
|
|
|
|
else if (savedFilters.diff[0] == -2) { $('.diffDiv[diff=-2]').first().addClass('selectedFilter'); showDemonDiffs() }
|
|
|
|
else (savedFilters.diff.forEach(x => $(`.diffDiv:not(.demonDiff)[diff=${x}]`).addClass('selectedFilter')))
|
|
|
|
|
|
|
|
if (!savedFilters.len) savedFilters.len = []
|
|
|
|
else (savedFilters.len.forEach(x => $(`.lengthDiv[len=${x}]`).addClass('selectedFilter')))
|
|
|
|
|
|
|
|
if (savedFilters.starred) $('#starCheck').addClass('selectedFilter')
|
|
|
|
|
|
|
|
if (!savedFilters.checked) savedFilters.checked = []
|
|
|
|
else (savedFilters.checked.forEach(x => $(`input[id=box-${x}]`).prop('checked', true)))
|
|
|
|
|
|
|
|
let hadDefaultSong = savedFilters.defaultSong
|
|
|
|
if (savedFilters.defaultSong) {
|
|
|
|
officialSong = +savedFilters.song || 1
|
|
|
|
$('#normalSong').trigger('click')
|
|
|
|
}
|
|
|
|
else if (+savedFilters.song && +savedFilters.song > 0) $('#songID').val(savedFilters.song)
|
|
|
|
|
|
|
|
checkExtraFilters()
|
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
Fetch(`../api/music`).then(music => {
|
|
|
|
|
|
|
|
$('#songName').html("1: " + music[1][0])
|
|
|
|
|
|
|
|
$(document).on('click', '.songChange', function () {
|
|
|
|
officialSong += Number($(this).attr('jump'))
|
|
|
|
if (officialSong < 1) officialSong = 1
|
|
|
|
$('#songName').html(`${officialSong}: ${music[officialSong] ? music[officialSong][0] : officialSong == 69 ? "Nice" : "Unknown"}`)
|
2021-11-16 21:47:14 -03:00
|
|
|
savedFilters.song = officialSong
|
|
|
|
savedFilters.defaultSong = true
|
|
|
|
checkExtraFilters()
|
2021-02-01 16:30:40 -03:00
|
|
|
})
|
|
|
|
|
2021-11-16 21:47:14 -03:00
|
|
|
if (hadDefaultSong) {
|
|
|
|
checkExtraFilters()
|
|
|
|
$('.songChange').trigger('click')
|
|
|
|
}
|
|
|
|
|
2021-02-01 16:30:40 -03:00
|
|
|
$(document).keydown(function(k) {
|
|
|
|
if (customSong) return;
|
|
|
|
if (k.which == 37) $('#songDown').trigger('click') // left
|
|
|
|
if (k.which == 39) $('#songUp').trigger('click') // right
|
|
|
|
});
|
|
|
|
|
2021-01-18 23:54:18 -03:00
|
|
|
if (onePointNine) {
|
|
|
|
$('#userSearch').hide()
|
|
|
|
$('#followedSearch').addClass('menuDisabled')
|
|
|
|
$('#levelName').css('width', '76%')
|
|
|
|
}
|
2021-02-01 16:30:40 -03:00
|
|
|
|
|
|
|
if (gdps) Fetch(`../api/gdps?current=1`).then(res => { if (res.demonList) $('#demonList').show() })
|
|
|
|
else $('#demonList').show()
|
2021-01-18 23:54:18 -03:00
|
|
|
})
|
|
|
|
|
2021-10-03 10:54:24 -03:00
|
|
|
</script>
|