rDrama/files/assets/js/comments+submission_listing.js
2022-05-16 11:53:24 -05:00

196 lines
6.1 KiB
JavaScript

function timestamp(str, ti) {
date = new Date(ti*1000);
document.getElementById(str).setAttribute("data-bs-original-title", date.toString());
};
function pinned_timestamp(id) {
const el = document.getElementById(id)
const time = new Date(parseInt(el.dataset.timestamp)*1000)
const pintooltip = el.getAttribute("data-bs-original-title")
if (!pintooltip.includes('until')) el.setAttribute("data-bs-original-title", `${pintooltip} until ${time}`)
}
function popclick(author) {
setTimeout(() => {
let popover = document.getElementsByClassName("popover")
popover = popover[popover.length-1]
let badges = ''
for (const x of author["badges"]) {
badges += `<img alt="badge" width="32" loading="lazy" src="${x}?v=1016">`
}
popover.getElementsByClassName('pop-banner')[0].src = author["bannerurl"]
popover.getElementsByClassName('pop-picture')[0].src = author["profile_url"]
popover.getElementsByClassName('pop-username')[0].innerHTML = author["username"]
popover.getElementsByClassName('pop-bio')[0].innerHTML = author["bio_html"]
popover.getElementsByClassName('pop-postcount')[0].innerHTML = author["post_count"]
popover.getElementsByClassName('pop-commentcount')[0].innerHTML = author["comment_count"]
popover.getElementsByClassName('pop-coins')[0].innerHTML = author["coins"]
popover.getElementsByClassName('pop-viewmore')[0].href = author["url"]
popover.getElementsByClassName('pop-badges')[0].innerHTML = badges
; }, 1);
}
function fillnote(user,post,comment) {
let dialog = document.getElementById("modal-1");
let table = "";
for(let i = 0; i < user.notes.length; ++i){
let note_id = "note_" + i;
let note = user.notes[i];
let date = new Date(parseInt(note.created) * 1000);
let date_str = date.toLocaleDateString();
let time_str = date.toLocaleTimeString();
let tag = "None";
switch(note.tag){
case 0: tag = "Quality"; break;
case 1: tag = "Good" ; break;
case 2: tag = "Comment"; break;
case 3: tag = "Warning"; break;
case 4: tag = "Tempban"; break;
case 5: tag = "Permban"; break;
case 6: tag = "Spam" ; break;
case 7: tag = "Bot" ; break;
}
table += "" +
"<div class=\"table_note\" id=\"" + note_id + "\" data-id=\"" + note.id + "\">" +
"<div class=\"table_note_author\">" +
note.author_name + "<br/>" +
"<a class=\"table_note_date\" href=\"" + note.reference + "\">" + date_str + ", " + time_str + "</a>" +
"</div>" +
"<div class=\"table_note_message\">" + note.note + "</div>" +
"<div class=\"table_note_tag\">" + tag + "</div>" +
"<div class=\"table_note_delete\"><span onclick=\"delete_note('" + note_id + "','" + user.url + "')\">Delete</span></div>" +
"</div>\n"
}
dialog.getElementsByClassName('notes_target')[0].innerText = user.username;
dialog.getElementsByClassName('table_content')[0].innerHTML = table;
dialog.dataset.context = JSON.stringify({
'url': user.url,
'post': post,
'comment': comment,
'user': user.id,
});
}
function delete_note(element,url) {
let note = document.getElementById(element);
let id = note.dataset.id;
const xhr = new XMLHttpRequest();
xhr.open("POST", url + "/delete_note/" + id);
xhr.setRequestHeader('xhr', 'xhr');
xhr.responseType = 'json';
xhr.onload = function() {
if(xhr.status === 200) {
console.log(xhr.response);
location.reload();
}
}
var form = new FormData()
form.append("formkey", formkey());
xhr.send(form);
}
function send_note() {
let dialog = document.getElementById("modal-1");
let context = JSON.parse(dialog.dataset.context);
let note = document.querySelector("#modal-1 textarea").value;
let tag = document.querySelector("#modal-1 #usernote_tag").value;
const xhr = new XMLHttpRequest();
xhr.open("POST", context.url + "/create_note");
xhr.setRequestHeader('xhr', 'xhr');
xhr.responseType = 'json';
var form = new FormData()
form.append("formkey", formkey());
form.append("data", JSON.stringify({
'note': note,
'post': context.post,
'comment': context.comment,
'user': context.user,
'tag': tag
}));
xhr.onload = function() {
if(xhr.status === 200) {
console.log(xhr.response);
location.reload();
}
}
xhr.send(form);
}
document.addEventListener("click", function(){
active = document.activeElement.getAttributeNode("class");
if (active && active.nodeValue == "user-name text-decoration-none"){
pops = document.getElementsByClassName('popover')
if (pops.length > 1) pops[0].remove()
}
else document.querySelectorAll('.popover').forEach(e => e.remove());
});
function post(url) {
const xhr = new XMLHttpRequest();
xhr.open("POST", url);
xhr.setRequestHeader('xhr', 'xhr');
var form = new FormData()
form.append("formkey", formkey());
xhr.send(form);
};
function poll_vote(cid, parentid) {
for(let el of document.getElementsByClassName('presult-'+parentid)) {
el.classList.remove('d-none');
}
var type = document.getElementById(cid).checked;
var scoretext = document.getElementById('poll-' + cid);
var score = Number(scoretext.textContent);
if (type == true) scoretext.textContent = score + 1;
else scoretext.textContent = score - 1;
post('/vote/poll/' + cid + '?vote=' + type);
}
function choice_vote(cid, parentid) {
for(let el of document.getElementsByClassName('presult-'+parentid)) {
el.classList.remove('d-none');
}
let curr = document.getElementById(`current-${parentid}`)
if (curr && curr.value)
{
var scoretext = document.getElementById('choice-' + curr.value);
var score = Number(scoretext.textContent);
scoretext.textContent = score - 1;
}
var scoretext = document.getElementById('choice-' + cid);
var score = Number(scoretext.textContent);
scoretext.textContent = score + 1;
post('/vote/choice/' + cid);
curr.value = cid
}
function bet_vote(cid) {
for(let el of document.getElementsByClassName('bet')) {
el.disabled = true;
}
for(let el of document.getElementsByClassName('cost')) {
el.classList.add('d-none')
}
var scoretext = document.getElementById('bet-' + cid);
var score = Number(scoretext.textContent);
scoretext.textContent = score + 1;
post('/bet/' + cid);
document.getElementById("user-coins-amount").innerText = parseInt(document.getElementById("user-coins-amount").innerText) - 200;
}