rDrama/files/assets/js/award_modal.js

189 lines
6.0 KiB
JavaScript
Raw Normal View History

2022-07-16 21:00:02 +00:00
// TODO: Refactor this ugly shit who wrote this lmao
function vote(type, id, dir) {
2022-07-16 21:00:02 +00:00
const upvotes = document.getElementsByClassName(type + '-' + id + '-up');
const downvotes = document.getElementsByClassName(type + '-' + id + '-down');
const scoretexts = document.getElementsByClassName(type + '-score-' + id);
for (let i=0; i<upvotes.length; i++) {
2022-09-04 23:15:37 +00:00
2022-07-16 21:00:02 +00:00
const upvote = upvotes[i]
const downvote = downvotes[i]
const scoretext = scoretexts[i]
const score = Number(scoretext.textContent);
if (dir == "1") {
if (upvote.classList.contains('active')) {
upvote.classList.remove('active')
upvote.classList.remove('active-anim')
scoretext.textContent = score - 1
votedirection = "0"
} else if (downvote.classList.contains('active')) {
upvote.classList.add('active')
upvote.classList.add('active-anim')
downvote.classList.remove('active')
downvote.classList.remove('active-anim')
scoretext.textContent = score + 2
votedirection = "1"
} else {
upvote.classList.add('active')
upvote.classList.add('active-anim')
scoretext.textContent = score + 1
votedirection = "1"
}
if (upvote.classList.contains('active')) {
scoretext.classList.add('score-up')
scoretext.classList.add('score-up-anim')
scoretext.classList.remove('score-down')
scoretext.classList.remove('score')
} else if (downvote.classList.contains('active')) {
scoretext.classList.add('score-down')
scoretext.classList.remove('score-up')
scoretext.classList.remove('score-up-anim');
scoretext.classList.remove('score')
} else {
scoretext.classList.add('score')
scoretext.classList.remove('score-up')
scoretext.classList.remove('score-up-anim');
scoretext.classList.remove('score-down')
}
}
else {
if (downvote.classList.contains('active')) {
downvote.classList.remove('active')
downvote.classList.remove('active-anim')
scoretext.textContent = score + 1
votedirection = "0"
} else if (upvote.classList.contains('active')) {
downvote.classList.add('active')
downvote.classList.add('active-anim')
upvote.classList.remove('active')
upvote.classList.remove('active-anim')
scoretext.textContent = score - 2
votedirection = "-1"
} else {
downvote.classList.add('active')
downvote.classList.add('active-anim')
scoretext.textContent = score - 1
votedirection = "-1"
}
if (upvote.classList.contains('active')) {
scoretext.classList.add('score-up')
scoretext.classList.add('score-up-anim')
scoretext.classList.remove('score-down')
scoretext.classList.remove('score')
} else if (downvote.classList.contains('active')) {
scoretext.classList.add('score-down')
scoretext.classList.remove('score-up-anim')
scoretext.classList.remove('score-up')
scoretext.classList.remove('score')
} else {
scoretext.classList.add('score')
scoretext.classList.remove('score-up')
scoretext.classList.remove('score-down')
scoretext.classList.remove('score-up-anim')
}
}
}
2023-01-01 11:36:20 +00:00
const xhr = createXhrWithFormKey("/vote/" + type.replace('-mobile','') + "/" + id + "/" + votedirection);
xhr[0].send(xhr[1]);
2022-07-16 21:00:02 +00:00
}
let global_price;
2022-12-30 15:16:49 +00:00
function pick(kind, price, coins, marseybux) {
global_price = price;
2023-01-01 02:34:12 +00:00
price = parseInt(price)
2023-01-01 02:35:08 +00:00
coins = parseInt(coins)
marseybux = parseInt(marseybux)
2023-01-01 02:32:37 +00:00
const buy1 = document.getElementById('buy1')
2023-01-04 19:06:00 +00:00
if (marseybux >= price && kind != "grass")
buy1.disabled=false;
else
buy1.disabled=true;
const buy2 = document.getElementById('buy2')
2023-01-04 19:06:00 +00:00
if (coins >= price && kind != "benefactor")
buy2.disabled=false;
else
buy2.disabled=true;
2022-07-16 21:00:02 +00:00
let ownednum = Number(document.getElementById(`${kind}-owned`).textContent);
document.getElementById('giveaward').disabled = (ownednum == 0);
document.getElementById('kind').value=kind;
if (document.getElementsByClassName('picked').length > 0) {
document.getElementsByClassName('picked')[0].classList.toggle('picked');
}
2022-07-16 21:00:02 +00:00
document.getElementById(kind).classList.toggle('picked')
if (kind == "flairlock") {
document.getElementById('notelabel').innerHTML = "New flair:";
document.getElementById('note').placeholder = "Insert new flair here, or leave empty to add 1 day to the duration of the current flair. 100 characters max.";
document.getElementById('note').maxLength = 100;
}
else {
document.getElementById('notelabel').innerHTML = "Note (optional):";
document.getElementById('note').placeholder = "Note to include in award notification";
document.getElementById('note').maxLength = 200;
}
}
function buy(mb) {
const kind = document.getElementById('kind').value;
url = `/buy/${kind}`
if (mb) url += "?mb=true"
const xhr = createXhrWithFormKey(url);
xhr[0].onload = function() {
2022-07-16 21:00:02 +00:00
let data
try {data = JSON.parse(xhr[0].response)}
catch(e) {console.error(e)}
success = xhr[0].status >= 200 && xhr[0].status < 300;
showToast(success, getMessageFromJsonData(success, data), true);
if (success) {
2022-12-19 16:32:13 +00:00
if (kind != "lootbox")
{
document.getElementById('giveaward').disabled=false;
let owned = document.getElementById(`${kind}-owned`)
let ownednum = Number(owned.textContent) + 1;
2023-01-01 11:36:20 +00:00
owned.textContent = ownednum
2022-12-19 16:32:13 +00:00
}
const currency = mb ? "bux" : "coins";
document.getElementById(`user-${currency}-amount`).innerText = parseInt(document.getElementById(`user-${currency}-amount`).innerText) - global_price;
2022-07-16 21:00:02 +00:00
}
};
xhr[0].send(xhr[1]);
2022-07-16 21:00:02 +00:00
}
function giveaward(t) {
const kind = document.getElementById('kind').value;
postToast(t, t.dataset.action,
{
"kind": kind,
"note": document.getElementById('note').value
},
2022-11-03 19:07:08 +00:00
() => {
let owned = document.getElementById(`${kind}-owned`)
let ownednum = Number(owned.textContent) - 1;
owned.textContent = ownednum
if (ownednum == 0)
document.getElementById('giveaward').disabled=true;
2023-01-01 11:36:20 +00:00
}
);
}
2022-12-30 12:14:18 +00:00
2023-02-25 19:40:15 +00:00
const awardtabs = document.getElementsByClassName('award-tab');
const awardsections = document.getElementsByClassName('award-section');
function switchAwardTab() {
for (const element of awardtabs)
element.classList.toggle('active')
for (const element of awardsections)
element.classList.toggle('d-none')
}