X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;ds=inline;f=js%2FpageAdmin.js;h=9091d6dc238090f8513e55637c15c01de1f3208b;hb=696cf94315883382f4057fda2bff8b9deca70287;hp=4c34f58c43341c750c865ec4d797c8456d69ef2c;hpb=a2f6d159387e456847fb4e7607b4663ab8fa94fc;p=euphorik.git diff --git a/js/pageAdmin.js b/js/pageAdmin.js index 4c34f58..9091d6d 100644 --- a/js/pageAdmin.js +++ b/js/pageAdmin.js @@ -7,16 +7,24 @@ function PageAdmin(client, formateur, util) this.client = client this.formateur = formateur this.util = util + + this.timeoutIDmajIPs = null } PageAdmin.prototype.contenu = function() { return '
Un troll est un sujet à débat, en général une question.
\Chaque semaine un troll est choisit au hasard parmis les trolls proposés et devient le troll de la semaine.
\ - ' + \ + \ +Aucune IP bannie
' + + $("#ips").html(XHTML) + + $(".ban").each( + function() + { + var ip = $(".ip").html() + $(".deban", this).click( + function() + { + thisPageAdmin.util.messageDialogue("Ãtes-vous sur de vouloir débannir l'IP " + ip + " ?", messageType.question, + {"Oui" : function() + { + thisPageAdmin.deban(ip) + }, + "Non" : function(){} + } + ) + } + ) + } + ) + } + else if (data["reply"] == "error") + { + thisPageAdmin.util.messageDialogue(data["error_message"]) + } + + // rafraichissement toutes les minutes (je sais c'est mal) + // le problème est le rafraichissement des temps restant de bannissement qui doit êtrew fait du coté client + thisPageAdmin.timeoutIDmajIPs = setTimeout(function(){ thisPageAdmin.majIPs() }, 60 * 1000) + } + } + ) +} + +PageAdmin.prototype.deban = function(ip) +{ + var thisPageAdmin = this + + var dataToSend = + { + "action" : "unban", + "cookie" : this.client.cookie, + "ip" : ip + } + + ;;; dumpObj(dataToSend) + jQuery.ajax( + { + type: "POST", + url: "request", + dataType: "json", + data: this.util.jsonVersAction(dataToSend), + success: + function(data) + { + ;;; dumpObj(data) + switch(data["reply"]) + { + case "error" : + thisPageAdmin.util.messageDialogue(data["error_message"]) + break + case "ok" : + thisPageAdmin.majIPs() + break + } + } + } + ) +} + +/////////////////////////////////////////////////////////////////////////////////////////////////// + + +function Troll(content, author) +{ + this.content = content + this.author = author +} + + /////////////////////////////////////////////////////////////////////////////////////////////////// + function Trolls(client, util, formateur) { this.client = client @@ -95,11 +241,15 @@ function Trolls(client, util, formateur) this.formateur = formateur this.dernierTroll = 0 this.pageEvent = new PageEvent("admin", this.util) + + this.trolls = {} } Trolls.prototype.modifier = function(id, content) { + var thisTrolls = this + var dataToSend = { "action" : "mod_troll", @@ -121,7 +271,7 @@ Trolls.prototype.modifier = function(id, content) ;;; dumpObj(data) if (data["reply"] == "error") { - thisPageAdmin.util.messageDialogue(data["error_message"]) + thisTrolls.util.messageDialogue(data["error_message"]) } } } @@ -133,6 +283,8 @@ Trolls.prototype.modifier = function(id, content) */ Trolls.prototype.supprimer = function(id) { + var thisTrolls = this + var dataToSend = { "action" : "del_troll", @@ -153,7 +305,7 @@ Trolls.prototype.supprimer = function(id) ;;; dumpObj(data) if (data["reply"] == "error") { - thisPageAdmin.util.messageDialogue(data["error_message"]) + thisTrolls.util.messageDialogue(data["error_message"]) } } } @@ -174,10 +326,14 @@ Trolls.prototype.rafraichirTrolls = function() var XHTML = "" for (var i = 0; i < data["trolls"].length; i++) { + var troll = new Troll(data["trolls"][i]["content"], data["trolls"][i]["author"]) + var trollId = data["trolls"][i]["troll_id"] + thisTrolls.trolls[trollId] = troll + XHTML += - '