Javascript AJAX interactions

FossilOrigin-Name: e8123356ede23ac260c423e70b6434f79193dff64c106b47735cd6d7e89aed17
This commit is contained in:
nekobit 2022-06-06 05:26:51 +00:00
parent 4c0b6c7859
commit 3dba7538f7
2 changed files with 86 additions and 4 deletions

88
dist/js/main.js vendored
View file

@ -2,6 +2,14 @@ Element.prototype.insertAfter = function(element) {
element.parentNode.insertBefore(this, element.nextSibling);
};
function get_cookie(cookiestr)
{
return document.cookie
.split(';')
.find(row => row.startsWith(cookiestr+'='))
.split('=')[1];
}
function construct_quick_reply_form(replyid)
{
let src = document.createElement("form");
@ -63,13 +71,87 @@ function construct_quick_reply_form(replyid)
return src;
}
function construct_query(query)
{
query_string = "";
let keys = Object.keys(query);
let vals = Object.values(query);
const len = keys.length;
for (let i = 0; i < keys.length; ++i)
{
query_string += keys[i] + "=" + vals[i];
if (i !== keys.length-1)
query_string += "&";
}
return query_string;
}
function send_request(url, query, type, cb, cb_args)
{
let query_str = construct_query(query);
let xhr = new XMLHttpRequest();
xhr.open("POST", url);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.onreadystatechange = function() {
if (this.readyState === XMLHttpRequest.DONE)
cb(this, cb_args);
};
xhr.send(query_str);
}
function change_count_text(val, sum)
{
if (val === "")
val = 0
else
val = parseInt(val);
val += sum;
return val > 0 ? val.toString() : "";
}
function interact_action(xhr, arg)
{
let like = arg.status.querySelector(".like");
let repeat = arg.status.querySelector(".repeat");
let svg;
if (arg.type === "like" || arg.type === "unlike")
svg = [ like ];
else if (arg.type === "repeat" || arg.type === "unrepeat")
svg = [ repeat ];
else if (arg.type === "likeboost")
svg = [ like, repeat ];
svg.forEach(that => {
let label = that.parentNode;
let counter = label.querySelector(".count");
let is_active = that.classList.contains("active");
that.classList.toggle("active");
counter.innerHTML = change_count_text(counter.innerHTML, is_active ? -1 : 1);
});
}
function status_interact_props(e)
{
let interact = e.target.closest(".statbtn");
let type = interact.parentNode.querySelector(".itype");
if (type === null)
return true;
let status = interact.closest(".status");
send_request("/treebird_api/v1/interact",
{
id: status.id,
itype: type.value
},
1,
interact_action,
{ status: status, type: type.value });
e.preventDefault();
let interact = e.target.closest(".statbtn");
let type = interact.target.closest(".itype");
console.log([interact, type]);
return false;
}

View file

@ -678,7 +678,7 @@ void status_interact(struct session* ssn, mastodont_t* api, char** data)
void api_status_interact(struct session* ssn, mastodont_t* api, char** data)
{
if (try_interact_status(ssn, api, keystr(ssn->post.id)))
if (try_interact_status(ssn, api, keystr(ssn->post.id)) == 0)
{
send_result(NULL, "application/json", "{\"status\":\"Success\"}", 0);
}