var form_vars = {}; function post_link(event) { event.preventDefault(); var form_action = $(event.target).closest('a').attr("href"); //console.log("Form Action: " + form_action); $.ajax({ url: form_action, type: "POST", dataType: "json", data: {js: "1"} }); } function load_alerts(menu_alerts) { menu_alerts.find(".alert_counter").text(""); $.ajax({ type: 'get', dataType: 'json', url:'/api/?action=get&module=alerts&format=json', success: function(data) { if("errmsg" in data) { console.log(data.errmsg); menu_alerts.find(".alertList").html("
"+data.errmsg+"
"); return; } var alist = ""; for(var i in data.msgs) { var msg = data.msgs[i]; var mmsg = msg.msg; if("sub" in msg) { for(var i = 0; i < msg.sub.length; i++) { mmsg = mmsg.replace("\{"+i+"\}", msg.sub[i]); console.log("Sub #" + i); console.log(msg.sub[i]); } } if(mmsg.length > 46) mmsg = mmsg.substring(0,43) + "..."; else if(mmsg.length > 35) size_dial = " smaller"; //9px else size_dial = ""; // 10px if("avatar" in msg) { alist += "
"+mmsg+"
"; console.log(msg.avatar); } else { alist += "
"+mmsg+"
"; } console.log(msg); //console.log(mmsg); } if(alist == "") { alist = "
You don't have any alerts
" } menu_alerts.find(".alertList").html(alist); if(data.msgs.length != 0) { menu_alerts.find(".alert_counter").text(data.msgs.length); } }, error: function(magic,theStatus,error) { try { var data = JSON.parse(magic.responseText); if("errmsg" in data) { console.log(data.errmsg); errtxt = data.errmsg; } else errtxt = "Unable to get the alerts" } catch(e) { errtxt = "Unable to get the alerts"; } menu_alerts.find(".alertList").html("
"+errtxt+"
"); } }); } $(document).ready(function(){ function SplitN(data,ch,n) { var out = [] if(data.length == 0) { return out } var lastIndex = 0 var j = 0 var lastN = 1 for(var i = 0; i < data.length; i++) { if(data[i] == ch) { out[j++] = data.substring(lastIndex,i) lastIndex = i if(lastN == n) { break } lastN++ } } if(data.length > lastIndex) { out[out.length - 1] += data.substring(lastIndex) } return out } if(window["WebSocket"]) { conn = new WebSocket("ws://" + document.location.host + "/ws/") conn.onopen = function() { conn.send("page " + document.location.pathname + '\r') } conn.onclose = function() { conn = false } conn.onmessage = function(event) { //console.log("WS_Message:") //console.log(event.data) var messages = event.data.split('\r') for(var i = 0; i < messages.length; i++) { //console.log("Message:") //console.log(messages[i]) if(messages[i].startsWith("set ")) { //msgblocks = messages[i].split(' ',3) msgblocks = SplitN(messages[i]," ",3) if(msgblocks.length < 3) { continue } document.querySelector(msgblocks[1]).innerHTML = msgblocks[2] } else if(messages[i].startsWith("set-class ")) { msgblocks = SplitN(messages[i]," ",3) if(msgblocks.length < 3) { continue } document.querySelector(msgblocks[1]).className = msgblocks[2] } } } } else { conn = false } $(".open_edit").click(function(event){ //console.log("Clicked on edit"); event.preventDefault(); $(".hide_on_edit").hide(); $(".show_on_edit").show(); }); $(".topic_item .submit_edit").click(function(event){ event.preventDefault(); $(".topic_name").html($(".topic_name_input").val()); $(".topic_content").html($(".topic_content_input").val()); $(".topic_status_e:not(.open_edit)").html($(".topic_status_input").val()); $(".hide_on_edit").show(); $(".show_on_edit").hide(); var topic_name_input = $('.topic_name_input').val(); var topic_status_input = $('.topic_status_input').val(); var topic_content_input = $('.topic_content_input').val(); var form_action = $(this).closest('form').attr("action"); //console.log("New Topic Name: " + topic_name_input); //console.log("New Topic Status: " + topic_status_input); //console.log("Form Action: " + form_action); $.ajax({ url: form_action, data: { topic_name: topic_name_input, topic_status: topic_status_input, topic_content: topic_content_input, topic_js: 1 }, type: "POST", dataType: "json" }); }); $(".delete_item").click(function(event) { post_link(event); var block = $(this).closest('.deletable_block'); block.remove(); }); $(".edit_item").click(function(event) { event.preventDefault(); var block_parent = $(this).closest('.editable_parent'); var block = block_parent.find('.editable_block').eq(0); block.html("
"); $(".submit_edit").click(function(event) { event.preventDefault(); var block_parent = $(this).closest('.editable_parent'); var block = block_parent.find('.editable_block').eq(0); var newContent = block.find('textarea').eq(0).val(); block.html(newContent); var form_action = $(this).closest('a').attr("href"); //console.log("Form Action: " + form_action); $.ajax({ url: form_action, type: "POST", dataType: "json", data: { is_js: "1", edit_item: newContent } }); }); }); $(".edit_field").click(function(event) { event.preventDefault(); var block_parent = $(this).closest('.editable_parent'); var block = block_parent.find('.editable_block').eq(0); block.html(""); $(".submit_edit").click(function(event) { event.preventDefault(); var block_parent = $(this).closest('.editable_parent'); var block = block_parent.find('.editable_block').eq(0); var newContent = block.find('input').eq(0).val(); block.html(newContent); var form_action = $(this).closest('a').attr("href"); //console.log("Form Action: " + form_action); $.ajax({ url: form_action + "?session=" + session, type: "POST", dataType: "json", data: {is_js: "1",edit_item: newContent} }); }); }); $(".edit_fields").click(function(event) { event.preventDefault(); var block_parent = $(this).closest('.editable_parent'); block_parent.find('.hide_on_edit').hide(); block_parent.find('.editable_block').show(); block_parent.find('.editable_block').each(function(){ var field_name = this.getAttribute("data-field"); var field_type = this.getAttribute("data-type"); if(field_type=="list") { var field_value = this.getAttribute("data-value"); if(field_name in form_vars) var it = form_vars[field_name]; else var it = ['No','Yes']; var itLen = it.length; var out = ""; for (var i = 0; i < itLen; i++){ if(field_value==i) sel = "selected "; else sel = ""; out += ""; } this.innerHTML = ""; } else this.innerHTML = ""; }); block_parent.find('.show_on_edit').eq(0).show(); $(".submit_edit").click(function(event) { event.preventDefault(); var out_data = {is_js: "1"} var block_parent = $(this).closest('.editable_parent'); var block = block_parent.find('.editable_block').each(function(){ var field_name = this.getAttribute("data-field"); var field_type = this.getAttribute("data-type"); if(field_type == "list") var newContent = $(this).find('select :selected').text(); else var newContent = $(this).find('input').eq(0).val(); this.innerHTML = newContent; out_data[field_name] = newContent }); var form_action = $(this).closest('a').attr("href"); //console.log("Form Action: " + form_action); //console.log(out_data); $.ajax({ url: form_action + "?session=" + session, type:"POST", dataType:"json", data: out_data }); block_parent.find('.hide_on_edit').show(); block_parent.find('.show_on_edit').hide(); }); }); $(".ip_item").each(function(){ var ip = this.textContent; //console.log("IP: " + ip); if(ip.length > 10){ this.innerHTML = "Show IP"; this.onclick = function(event){ event.preventDefault(); this.textContent = ip; }; } }); $(this).click(function() { $(".selectedAlert").removeClass("selectedAlert"); }); $(".menu_alerts").ready(function(){ load_alerts($(this)); }); $(".menu_alerts").click(function(event) { event.stopPropagation(); if($(this).hasClass("selectedAlert")) return; this.className += " selectedAlert"; load_alerts($(this)); }); this.onkeyup = function(event){ if(event.which == 37) this.querySelectorAll("#prevFloat a")[0].click(); if(event.which == 39) this.querySelectorAll("#nextFloat a")[0].click(); }; });