2019-10-15 22:42:47 -04:00
< head >
< title > [[USERNAME]]'s Profile< / title >
< meta charset = "utf-8" >
2019-10-23 18:40:31 -04:00
< link href = "../css/browser.css" type = "text/css" rel = "stylesheet" >
2019-10-15 22:42:47 -04: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 = "../icon/[[USERNAME]]" >
< meta id = "meta-title" property = "og:title" content = "[[USERNAME]]'s profile" >
< meta id = "meta-desc" property = "og:description" content = "Stars: [[STARS]] | Diamonds: [[DIAMONDS]] | Coins: [[COINS]] | User Coins: [[USERCOINS]] | Demons: [[DEMONS]] | CP: [[CP]]" >
< meta id = "meta-image" name = "og:image" itemprop = "image" content = "https://gdbrowser.com/icon/[[USERNAME]]" >
< / head >
2019-10-23 02:54:19 +03:00
< body class = "levelBG" onbeforeunload = "saveUrl()" >
2019-10-15 22:42:47 -04:00
< div id = "everything" >
2019-12-15 19:11:35 -05:00
< div class = "popup" id = "leavePost" >
< div class = "brownbox bounce center supercenter" style = "height: 68%; width: 110vh" >
< p style = "position:absolute; right: 1vh; margin-top: 0; text-align: left" id = "charcount" > 180< / p >
< h1 class = "smaller center" style = "font-size: 5.5vh" > Post Update< / h1 >
< textarea placeholder = "Insert comment" id = "content" maxlength = "180" style = "margin: 2% 0%" > < / textarea > < br >
< form action = "nothing lol" >
< h3 class = "center" style = "margin-top: 2%" > GD Password< / h3 >
< input type = "password" id = "password" maxlength = "50" style = "height: 8vh; width: 90%; text-align: center; margin-top: 0.5%" >
< / form >
< div style = "min-height: 20%; max-height: 20%" >
< p id = "message" style = "padding: 0% 10%; margin-top: 2%" > < / p >
< / div >
< img src = "../assets/btn-cancel.png" height = 11%; class = "postButton gdButton center" style = "margin-right: 1%" onclick = "$('#leavePost').hide(); $('textarea').val('')" >
< img src = "../assets/btn-submit.png" type = "submit" height = 11%; class = "postButton gdButton center" style = "margin-left: 1%" id = "submitComment" >
< / div >
< / div >
< div class = "popup" id = "likeComment" >
< div class = "brownbox bounce center supercenter" style = "height: 75%; width: 100vh" >
< h1 class = "smaller center" style = "font-size: 5.5vh" > Vote< / h1 >
< img src = "../assets/smashLike.png" id = "likebtn" class = "inline gdButton likeButton" > <!--
-->< img src = "../assets/smashDislike.png" id = "dislikebtn" class = "inline gdButton likeButton youAreNotTheOne" >
< form action = "nothing lol" >
< h3 class = "center" > GD Username< / h3 >
< input type = "text" name = "gdbrowser" id = "like-username" maxlength = "50" style = "height: 8vh; width: 90%; text-align: center; margin-top: 0.5%" >
< h3 class = "center" style = "margin-top: 2%" > GD Password< / h3 >
< input type = "password" id = "like-password" maxlength = "50" style = "height: 8vh; width: 90%; text-align: center; margin-top: 0.5%" >
< / form >
< div style = "min-height: 18%; max-height: 18%" >
< p id = "likeMessage" style = "padding: 0% 10%; margin-top: 2.5%" > < / p >
< / div >
< img src = "../assets/btn-cancel.png" height = 10%; class = "postButton gdButton center" style = "margin-right: 1%" onclick = "$('#likeComment').hide(); $('#likebtn').trigger('click');" >
< img src = "../assets/btn-submit.png" type = "submit" height = 10%; class = "postButton gdButton center" style = "margin-left: 1%" id = "submitVote" >
< / div >
< / div >
2019-10-15 22:42:47 -04:00
< div class = "popup" id = "settingsDiv" >
2019-10-21 11:40:56 -04:00
< div class = "fancybox bounce center supercenter" >
2019-10-15 22:42:47 -04:00
< h2 class = "smaller center" style = "font-size: 5.5vh" > User Info< / h2 >
< p class = "bigger center" id = "userInfo" style = "line-height: 5vh; margin-top: 1.5vh;" >
Friend Requests: [[REQS]]< br >
Private Messages: [[DMS]]< br >
Comment History: [[COMMENTS]]< br >
< / p >
< img src = "../assets/ok.png" width = 20%; class = "gdButton center" onclick = "$('#settingsDiv').hide()" >
< / div >
< / div >
< div style = "position:absolute; bottom: 0%; left: 0%; width: 100%" >
2019-10-18 16:48:33 -04:00
< img class = "cornerPiece" src = "../assets/corner.png" width = 7%; >
2019-10-15 22:42:47 -04:00
< / div >
< div style = "position:absolute; bottom: 0%; right: 0%; width: 100%; text-align: right;" >
2019-10-18 16:48:33 -04:00
< img class = "cornerPiece" src = "../assets/corner.png" width = 7%; style = "transform: scaleX(-1)" >
2019-10-15 22:42:47 -04:00
< / 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 class = "brownBox center supercenter" style = "width: 135vh; height: 82%; margin-top: -0.7%" >
< h1 class = "veryBig inline" >
< img class = "inline valign" id = "modBadge1" style = "display: none; height: 7%; margin-right: -6%; cursor:help" src = "../assets/mod.png" title = "[[USERNAME]] is a moderator!" >
< img class = "inline valign" id = "modBadge2" style = "display: none; height: 7%; margin-right: -6%; cursor:help" src = "../assets/mod-elder.png" title = "[[USERNAME]] is an elder moderator!" >
[[USERNAME]]
< / h1 >
< hr style = "margin-bottom: 2%" >
< h3 id = "collectibles" >
2020-04-23 00:56:19 -04:00
< span id = "stars" > [[STARS]]< / span > < img class = "valign" src = "../assets/star.png" style = "cursor: help" title = "Stars" >
< span id = "diamonds" > [[DIAMONDS]]< / span > < img class = "valign" src = "../assets/diamond.png" style = "cursor: help" title = "Diamonds" >
< span id = "coins" > [[COINS]]< / span > < img class = "valign" src = "../assets/coin.png" style = "cursor: help" title = "Secret Coins" >
2019-10-15 22:42:47 -04:00
[[USERCOINS]] < img class = "valign" src = "../assets/silvercoin.png" style = "cursor: help" title = "User Coins" >
[[DEMONS]] < img class = "valign" src = "../assets/demon.png" style = "cursor: help" title = "Demons" >
[[CP]] < img class = "valign" src = "../assets/cp.png" style = "cursor: help" title = "Creator Points" >
< / h3 >
< div class = "lightBox center" id = "iconsDiv" style = "margin: 2% auto; width: 105vh" >
2019-12-21 14:33:32 -05:00
< img src = "../icon/[[USERNAME]]?form=cube" title = "Cube [[ICON]]" >
< img src = "../icon/[[USERNAME]]?form=ship" title = "Ship [[SHIP]]" style = "height: 8%" >
< img src = "../icon/[[USERNAME]]?form=ball" title = "Ball [[BALL]]" >
2020-06-22 22:07:13 -04:00
< img src = "../icon/[[USERNAME]]?form=ufo" title = "UFO [[UFO]]" >
2019-12-21 14:33:32 -05:00
< img src = "../icon/[[USERNAME]]?form=wave" title = "Wave [[WAVE]]" style = "height: 7%" >
< img src = "../icon/[[USERNAME]]?form=robot" title = "Robot [[ROBOT]]" >
< img src = "../icon/[[USERNAME]]?form=spider" title = "Spider [[SPIDER]]" >
2019-12-21 22:16:18 -05:00
< img src = "../deatheffects/[[DEATHEFFECT]].png" title = "Death Effect [[DEATHEFFECT]]" id = "deatheffect" >
2019-10-15 22:42:47 -04:00
< / div >
< div class = "lightBox center dragscroll" id = "statusDiv" style = "margin: 2% auto; width: 105vh; height: 35vh; background-color: #BE6F3F" >
< / div >
2019-12-15 19:11:35 -05:00
< div class = "center" style = "margin: 1.5% auto 2.5% auto;" >
2019-12-29 18:59:29 -05:00
< a id = "msgA" target = "_blank" > < img src = "../assets/messages.png" height = "10%" id = "msgButton" class = "sideSpace gdButton" onclick = "$('#settingsDiv').show()" > < / a >
2019-10-15 22:42:47 -04:00
< img src = "../assets/friends.png" height = "10%" id = "friendButton" class = "sideSpace gdButton" onclick = "$('#settingsDiv').show()" >
2020-02-20 20:09:40 -05:00
< / div >
2020-03-13 21:07:54 -04:00
< div style = "position: absolute; bottom: 0%; left: 12%" >
2020-02-20 20:09:40 -05:00
< p style = "text-align: left; font-size: 2.2vh; color: rgba(0, 0, 0, 0.5)" > Account ID: [[ACCOUNTID]]< br > Player ID: [[PLAYERID]]< / p >
2019-10-15 22:42:47 -04:00
< / div >
2020-03-13 21:07:54 -04:00
< img src = "../assets/follow-off.png" id = "followOff" class = "gdButton" style = "position: absolute; left: 4.5%; bottom: 1%; width: 6%" >
< img src = "../assets/follow-on.png" id = "followOn" class = "gdButton" style = "position: absolute; left: 4.5%; bottom: 1%; width: 6%; display: none" >
2019-12-15 19:11:35 -05:00
2019-10-15 22:42:47 -04:00
< a id = "commentA" > < img src = "../assets/comments.png" class = "gdButton" id = "commentButton" style = "position: absolute; right: 0.5%; bottom: 50%; width: 6%" onclick = "$('#settingsDiv').show()" > < / a >
2020-02-20 20:09:40 -05:00
< a href = "../search/[[USERNAME]]?user" > < img src = "../assets/levels.png" class = "gdButton" style = "position: absolute; right: 0.5%; bottom: 1%; width: 6%" > < / a >
2019-10-15 22:42:47 -04:00
< div style = "position: absolute; right: 0.5%; top: 0%; width: 6%" >
< a id = "youtube" style = "display: none" target = "_blank" href = "https://youtube.com/channel/[[YOUTUBE]]" > < img src = "../assets/youtube.png" class = "gdButton socialButton" > < / a >
< a id = "twitter" style = "display: none" target = "_blank" href = "https://twitter.com/[[TWITTER]]" > < img src = "../assets/twitter.png" class = "gdButton socialButton" > < / a >
< a id = "twitch" style = "display: none" target = "_blank" href = "https://twitch.tv/[[TWITCH]]" > < img src = "../assets/twitch.png" class = "gdButton socialButton" > < / a >
< / div >
< div id = "globalrank0" style = "position: absolute; left: 0.3%; top: 1.5%; width: 25%; text-align: left" >
< p style = "margin: 0;" > < img src = "../assets/trophy.png" class = "inline valign" width = "18%" style = "cursor: help" title = "Global Rank" > [[RANK]]< / p >
< / div >
< div class = "supercenter" id = "pageDown" style = "left: 5%; top: 65%; height: 10%; display: none;" >
< img class = "gdButton" src = "../assets/arrow-left.png" height = "95%" onclick = "page -= 1; appendComments()" >
< / div >
< div class = "supercenter" id = "pageUp" style = "left: 95%; top: 65%; height: 10%;" >
< img class = "gdButton" src = "../assets/arrow-right.png" height = "95%" onclick = "page += 1; appendComments()" >
< / div >
2020-02-20 20:09:40 -05:00
< div id = "postButton" style = "position:absolute; bottom: 0%; left: 0%; width: 14%; text-align: left; transform: translate(-35%, 40%);" >
2019-12-15 19:11:35 -05:00
< img class = "gdButton" src = "../assets/comment.png" width = "60%" onclick = "$('#content').trigger('input'); $('#leavePost').show();" >
< / div >
2019-10-15 22:42:47 -04:00
< / div >
< / div >
< / body >
2019-10-21 08:20:25 -07:00
< script type = "text/javascript" src = "https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js" > < / script >
< script async type = "text/javascript" src = "../assets/sizecheck.js" > < / script >
2019-10-24 19:27:09 -07:00
< script type = "text/javascript" src = "../assets/dragscroll.js" > < / script >
2019-10-15 22:42:47 -04:00
< script >
2020-05-13 09:55:57 -04:00
function clean(text) {return text.replace(/& /g, "& ").replace(/< /g, "< ").replace(/>/g, "> ").replace(/=/g, "= ").replace(/"/g, "" ").replace(/'/g, "' ")}
2020-01-03 17:15:49 -05:00
let messageText = 'Your < span style = "color: yellow" > Geometry Dash password< / span > will < span style = "color: lime" > not be stored< / span > anywhere on the site, both < span style = "color:rgb(113, 234, 255)" > locally and server-side.< / span > You can view the code used for profile posts < a class = "menuLink" target = "_blank" href = "https://github.com/GDColon/GDBrowser/blob/master/api/post/postProfileComment.js" > here< / a > .'
2019-12-15 19:11:35 -05:00
$('#message').html(messageText)
$('#likeMessage').html(messageText.replace("profile posts", "liking posts").replace("postProfileComment", "like"))
2019-11-02 01:28:24 -04:00
$('#collectibles').html($('#collectibles').html().split(' 0 < img class = "valign" src = "../assets/cp')[0])
2019-10-15 22:42:47 -04:00
$('#modBadge[[MODERATOR]]').show()
$('#globalrank[[RANK]]').hide()
2020-03-13 21:07:54 -04:00
let followed = localStorage.followed ? JSON.parse(localStorage.followed) : []
if (followed.includes([[ACCOUNTID]])) {$('#followOff').hide(); $('#followOn').show()}
$('#followOff').click(function() {
2020-03-14 11:12:31 -04:00
followed = localStorage.followed ? JSON.parse(localStorage.followed) : []
2020-03-13 21:07:54 -04:00
followed.push([[ACCOUNTID]])
localStorage.followed = JSON.stringify(followed)
$('#followOff').hide()
$('#followOn').show()
})
$('#followOn').click(function() {
2020-03-14 11:12:31 -04:00
followed = localStorage.followed ? JSON.parse(localStorage.followed) : []
2020-03-13 21:07:54 -04:00
localStorage.followed = JSON.stringify(followed.filter(x => x != [[ACCOUNTID]]))
$('#followOff').show()
$('#followOn').hide()
})
2019-10-15 22:42:47 -04:00
if (`[[YOUTUBE]]` != "null") $('#youtube').show()
if (`[[TWITTER]]` != "null") $('#twitter').show()
if (`[[TWITCH]]` != "null") $('#twitch').show()
2019-12-21 22:16:18 -05:00
if (`[[DEATHEFFECT]]` == "undefined") $('#deatheffect').hide()
2019-10-15 22:42:47 -04:00
let messages = "[[MESSAGES]]"
let commenthistory = "[[COMMENTHISTORY]]"
2019-10-25 20:08:54 -07:00
let reqMode = [[FRIENDREQUESTS]] ? "< span style = 'color:lime' > Enabled< / span > " : "< span style = 'color:red' > Disabled< / span > "
let dmMode = messages == "all" ? "< span style = 'color:lime' > Public< / span > " : messages == "friends" ? "< span style = 'color:yellow' > Friends Only< / span > " : "< span style = 'color:red' > Disabled< / span > "
let commentMode = commenthistory == "all" ? "< span style = 'color:lime' > Public< / span > " : commenthistory == "friends" ? "< span style = 'color:yellow' > Friends Only< / span > " : "< span style = 'color:red' > Disabled< / span > "
2019-10-15 22:42:47 -04:00
if (commenthistory == "friends") $('#commentButton').attr('src', '../assets/comments-yellow.png')
else if (commenthistory == "off") $('#commentButton').attr('src', '../assets/comments-grey.png')
else {
$('#commentButton').attr('src', '../assets/comments.png').attr('onclick', '')
$('#commentA').attr('href', '../comments/[[USERNAME]]')
}
2019-12-29 18:59:29 -05:00
if (messages == "all") {
$('#msgButton').attr('onclick', '')
$('#msgA').attr('href', '../messages?sendTo=[[USERNAME]]')
}
2019-10-15 22:42:47 -04:00
if (messages == "friends") $('#msgButton').attr('src', '../assets/messages-yellow.png')
else if (messages == "off") $('#msgButton').attr('src', '../assets/messages-grey.png')
if (![[FRIENDREQUESTS]]) $('#friendButton').attr('src', '../assets/friends-grey.png')
$('#userInfo').html($('#userInfo').html()
.replace("[[REQS]]", reqMode)
.replace("[[DMS]]", dmMode)
2019-12-29 18:59:29 -05:00
.replace("[[COMMENTS]]", commentMode) + (messages == "friends" ? "< br style = 'line-height: 69%' > < span style = 'color: lime' class = 'youCanClickThis2' > < a target = '_blank' href = '../messages?sendTo=[[USERNAME]]' > Send message< / a > < / span > < br > (if friended)" : ""))
2019-10-15 22:42:47 -04:00
function appendComments() {
if (loadingComments) return;
else loadingComments = true;
$('#statusDiv').html(`< div class = "supercenter" id = "loading" style = "height: 12%; top: 62%;" > < img class = "spin noSelect" src = "../assets/loading.png" height = "105%" > < / div > `)
if (page == 0) $('#pageDown').hide()
else $('#pageDown').show()
fetch(`../api/comments/[[ACCOUNTID]]?type=profile& page=${page}`).then(res => res.json()).then(res => {
if (res.length != 10) $('#pageUp').hide()
else $('#pageUp').show()
if (res == "-1") return $('#loading').hide()
res.forEach(x => {
$('#statusDiv').append(`
< div class = "commentBG" >
< div class = "comment" >
< h2 > [[USERNAME]]< / h2 >
< div class = "commentAlign" >
2020-05-13 09:55:57 -04:00
< p class = "commentText" style = "color: rgb(${" [ [ USERNAME ] ] " = = " RobTop " ? " 50 , 255 , 255 " : " [ [ MODERATOR ] ] " = = " 2 " ? " 75 , 255 , 75 " : x . browserColor ? " 255 , 180 , 255 " : " 255 , 255 , 255 " } ) " > ${clean(x.content)}< / p >
2019-10-15 22:42:47 -04:00
< / div >
< / div >
< p class = "commentDate" > ${x.date}< / p >
< div class = "commentLikes" >
2019-12-15 19:11:35 -05:00
< img id = "likeImg" class = "likeComment gdButton inline" commentID = "${x.ID}" $ { x . likes < 0 ? " style = 'transform: translateY(25%)' " : " " } src = "../assets/${x.likes < 0 ? " dis " : " " } like . png " height = 20% style = "margin-right: 0.4%" >
2019-10-15 22:42:47 -04:00
< h3 class = "inline" > ${x.likes}< / h3 > < br >
< / div >
< / div > `)
})
$('.commentText').each(function() {
if ($(this).text().length > 100) {
let overflow = ($(this).text().length - 100) * 0.01
$(this).css('font-size', (3.5 - (overflow)) + 'vh')
}
});
$('#loading').hide()
})
loadingComments = false;
}
let page = 0
let loadingComments = false
appendComments()
2019-12-15 19:11:35 -05:00
$('#content').on('input', function() {
let remaining = 180-$('#content').val().length
$('#charcount').text(remaining)
})
2020-04-23 00:56:19 -04:00
if ([[DIAMONDS]] >= 65535) $('#diamonds').addClass('blue')
if ([[COINS]] >= 149) $('#coins').addClass('yellow')
if ([[STARS]] >= 100000) $('#stars').addClass('yellow')
2019-12-15 19:11:35 -05:00
$('#submitComment').click(function () {
let comment = $('#content').val()
let username = '[[USERNAME]]'
let password = $('#password').val()
let accountID = '[[ACCOUNTID]]'
if (!comment || !password || loadingComments) return $('#leavePost').hide()
$('#message').text("Posting...")
$('.postbutton').hide()
allowEsc = false
$.post("../postProfileComment", { comment, username, password, accountID, color: true })
.done(x => {
$('#content').val("")
$('#leavePost').hide()
$('.postbutton').show()
$('#message').html(messageText)
allowEsc = true
page = 0
appendComments()
})
.fail(e => { allowEsc = true; $('.postbutton').show(); $('#message').text(e.responseText.includes("DOCTYPE") ? "Something went wrong..." : e.responseText) })
})
let commentID = 0;
let likeCount, likeImg;
let likedComments;
let like = true;
$('#likebtn').click(function() {
$('#likebtn').removeClass('youAreNotTheOne')
$('#dislikebtn').addClass('youAreNotTheOne')
like = true
})
$('#dislikebtn').click(function() {
$('#likebtn').addClass('youAreNotTheOne')
$('#dislikebtn').removeClass('youAreNotTheOne')
like = false
})
$(document).on('click', '.likeComment', function(cmnt) {
commentID = $(this).attr('commentID')
likedComments = localStorage.likedComments ? JSON.parse(localStorage.likedComments) : []
if (likedComments.includes(commentID)) return;
lvID = $(this).attr('levelID') || 0
likeImg = $(this).find('img')
likeCount = $(this).parent().find('h3:not(.gold)')
$('#likeComment').show()
})
$('#submitVote').click(function() {
if (likedComments.includes(commentID)) return $('#likeMessage').text("You've already liked/disliked this comment!");
let ID = commentID
let username = $('#like-username').val()
let password = $('#like-password').val()
let extraID = lvID || window.location.pathname.split('/')[2]
let accountID = 0
let likeType = like ? "1" : "0"
if (!ID || !username || !password || loadingComments) return $('#postComment').hide()
$('#likeMessage').text(like ? "Liking..." : "Disliking... :(")
$('.postbutton').hide()
allowEsc = false
fetch(`../api/profile/${username}`).then(res => res.json()).then(res => {
if (!res || res == "-1") {allowEsc = true; $('.postbutton').show(); return $('#likeMessage').text("The username you provided doesn't exist!")}
else accountID = res.accountID
$.post("../like", { ID, accountID, password, like: likeType, type: 3, extraID: "[[ACCOUNTID]]" })
.done(x => {
let newCount = parseInt(likeCount.text()) + (like ? 1 : -1)
likeCount.text(newCount)
if (newCount < 0 ) likeImg . attr ( ' src ' , ' . . / assets / dislike . png ' ) . css ( ' transform ' , compact ? ' translateY ( 15 % ) ' : ' translateY ( 25 % ) ' )
else likeImg.attr('src', '../assets/like.png').removeAttr('style')
$('#likeComment').hide()
$('#likebtn').trigger('click')
$('.postbutton').show()
$('#likeMessage').html(messageText.replace("profile posts", "liking posts").replace("postProfileComment", "like"))
allowEsc = true
likedComments.push(commentID)
localStorage.setItem('likedComments', JSON.stringify(likedComments))
})
.fail(e => {allowEsc = true; $('.postbutton').show();$('#likeMessage').text(e.responseText.includes("DOCTYPE") ? "Something went wrong..." : e.responseText)})
})
})
2019-12-29 18:59:29 -05:00
$('#leavePost').on("change keyup keydown paste click", "textarea", function () {
$('#content').val($('#content').val().replace(/[^\S ]+/g, ""))
})
$(document).keydown(function(k) {
if ($('#content').is(':visible')) {
if (k.which == 13) k.preventDefault() //enter
}
2019-12-21 14:33:32 -05:00
})
2019-10-23 02:54:19 +03:00
2019-11-10 16:18:52 -05:00
< / script >