X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=js%2FpageAdmin.js;h=cb7f51e2a74e58e7a07b8d6c49feda2a33805cc0;hp=9091d6dc238090f8513e55637c15c01de1f3208b;hb=327c3bd99f586f3cf3af55f9adb10a71eb78cdd4;hpb=696cf94315883382f4057fda2bff8b9deca70287 diff --git a/js/pageAdmin.js b/js/pageAdmin.js index 9091d6d..cb7f51e 100644 --- a/js/pageAdmin.js +++ b/js/pageAdmin.js @@ -8,6 +8,8 @@ function PageAdmin(client, formateur, util) this.formateur = formateur this.util = util + this.pageEvent = new PageEvent("admin", this.util) + this.timeoutIDmajIPs = null } @@ -15,7 +17,7 @@ PageAdmin.prototype.contenu = function() { return '

Trolls

\

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.

\ +

Chaque semaine untrolls troll est choisit au hasard parmis les trolls proposés et devient le troll de la semaine.

\
\

\ \ @@ -34,7 +36,7 @@ PageAdmin.prototype.charger = function() var thisPage = this this.trolls = new Trolls(this.client, this.util, this.formateur) - this.trolls.rafraichirTrolls() + this.waitEvent() this.majIPs() @@ -50,7 +52,7 @@ PageAdmin.prototype.charger = function() PageAdmin.prototype.decharger = function() { - this.trolls.pageEvent.stopAttenteCourante() + this.pageEvent.stopAttenteCourante() } PageAdmin.prototype.posterTroll = function() @@ -98,7 +100,6 @@ PageAdmin.prototype.posterTroll = function() ) } - /** * Met à jour la liste des IP bannies. */ @@ -155,11 +156,11 @@ PageAdmin.prototype.majIPs = function() $(".ban").each( function() { - var ip = $(".ip").html() + var ip = $(".ip", this).html() $(".deban", this).click( function() { - thisPageAdmin.util.messageDialogue("Êtes-vous sur de vouloir débannir l'IP " + ip + " ?", messageType.question, + thisPageAdmin.util.messageDialogue("Êtes-vous sur de vouloir débannir l'IP ''" + ip + "'' ?", messageType.question, {"Oui" : function() { thisPageAdmin.deban(ip) @@ -213,7 +214,8 @@ PageAdmin.prototype.deban = function(ip) thisPageAdmin.util.messageDialogue(data["error_message"]) break case "ok" : - thisPageAdmin.majIPs() + // obsolète : plus besoin + /* thisPageAdmin.majIPs() */ break } } @@ -221,6 +223,36 @@ PageAdmin.prototype.deban = function(ip) ) } +PageAdmin.prototype.waitEvent = function() +{ + var thisPageAdmin = this + + this.pageEvent.waitEvent( + function() { return { "last_troll" : thisPageAdmin.trolls.dernierTroll }}, + function(data) + { + switch (data["reply"]) + { + case "troll_added" : + thisPageAdmin.trolls.ajouterTrollEvent(data) + break + case "troll_modified" : + thisPageAdmin.trolls.modifierTrollEvent(data) + break + case "troll_deleted" : + thisPageAdmin.trolls.supprimerTrollEvent(data) + break + case "banned_ips_refresh" : + thisPageAdmin.majIPs() + break + case "error" : + thisTrolls.util.messageDialogue(data["error_message"]) + break + } + } + ) +} + /////////////////////////////////////////////////////////////////////////////////////////////////// @@ -240,11 +272,107 @@ function Trolls(client, util, formateur) this.util = util this.formateur = formateur this.dernierTroll = 0 - this.pageEvent = new PageEvent("admin", this.util) this.trolls = {} } +Trolls.prototype.ajouterTrollEvent = function(data) +{ + var thisTrolls = this + + 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 += + '

' + + '' + thisTrolls.formateur.traitementComplet(troll.content, troll.author) + '' + + ' - ' + thisTrolls.formateur.traitementComplet(troll.author) + '' + + (data["trolls"][i]["author_id"] == thisTrolls.client.id ? 'éditerSupprimer' : '') + + '
' + } + $("#trolls").append(XHTML) + $("#trolls .troll").filter(function(){return parseInt($(this).attr("id").substr(5)) > thisTrolls.dernierTroll}).each( + function() + { + var troll = this + var id = parseInt($(this).attr("id").substr(5)) + + $("a[@rel*=lightbox]", this).lightBox() + + $(this).keypress( + function(e) + { + if (e.which == 13) // return + $(".modifier", this).click() + } + ) + $(".delTroll", this).click( + function() + { + thisTrolls.util.messageDialogue( + "Êtes-vous sur de vouloir supprimer le troll \"" + thisTrolls.trolls[id].content + "\" ?", + messageType.question, + { + "oui" : function() + { + thisTrolls.supprimer(id) + }, + "non" : function(){} + } + ) + } + ) + $(".editTroll", this).click( + function() + { + $("span", troll).css("display", "none") + $(troll).append( + '

modifierannuler

' + ) + $("form input.content").focus() + + var virerLeFormulaire = function() + { + $('form', troll).remove() + $('span', troll).css("display", "inline") + } + $("span.modifier", troll).click( + function() + { + var content = $("form input.content", troll).val() + virerLeFormulaire() + thisTrolls.modifier(id, content) + } + ) + $("span.annuler", troll).click( virerLeFormulaire ) + $("form", troll).submit(function(){ return false}) + } + ) + } + ) + + if (data["trolls"].length > 0) + thisTrolls.dernierTroll = data["trolls"][data["trolls"].length - 1]["troll_id"] +} + +Trolls.prototype.modifierTrollEvent = function(data) +{ + var thisTrolls = this + $("#trolls #troll" + data["troll_id"] + " .content").html(thisTrolls.formateur.traitementComplet(data["content"], thisTrolls.trolls[data["troll_id"]].author)) + $("#trolls #troll" + data["troll_id"] + " a[@rel*=lightbox]").lightBox() + thisTrolls.trolls[data["troll_id"]].content = data["content"] +} + +Trolls.prototype.supprimerTrollEvent = function(data) +{ + $("#trolls #troll"+data["troll_id"]).remove() +} Trolls.prototype.modifier = function(id, content) { @@ -311,114 +439,3 @@ Trolls.prototype.supprimer = function(id) } ) } - -Trolls.prototype.rafraichirTrolls = function() -{ - var thisTrolls = this - - this.pageEvent.waitEvent( - function() { return { "last_troll" : thisTrolls.dernierTroll }}, - function(data) - { - switch (data["reply"]) - { - case "troll_added" : - 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 += - '
' + - '' + thisTrolls.formateur.traitementComplet(troll.content, troll.author) + '' + - ' - ' + thisTrolls.formateur.traitementComplet(troll.author) + '' + - (data["trolls"][i]["author_id"] == thisTrolls.client.id ? 'éditerSupprimer' : '') + - '
' - } - $("#trolls").append(XHTML) - $("#trolls .troll").filter(function(){return parseInt($(this).attr("id").substr(5)) > thisTrolls.dernierTroll}).each( - function() - { - var troll = this - var id = parseInt($(this).attr("id").substr(5)) - - $("a[@rel*=lightbox]", this).lightBox() - - $(this).keypress( - function(e) - { - if (e.which == 13) // return - $(".modifier", this).click() - } - ) - $(".delTroll", this).click( - function() - { - thisTrolls.util.messageDialogue( - "Êtes-vous sur de vouloir supprimer le troll \"" + $("#trolls .troll .content").html() + "\" ?", - messageType.question, - { - "oui" : function() - { - thisTrolls.supprimer(id) - }, - "non" : function(){} - } - ) - } - ) - $(".editTroll", this).click( - function() - { - $("span", troll).css("display", "none") - $(troll).append( - '

modifierannuler

' - ) - $("form input.content").focus() - - var virerLeFormulaire = function() - { - $("form", troll).remove() - $('span', troll).css("display", "inline") - } - $("span.modifier", troll).click( - function() - { - var content = $("form input.content", troll).val() - virerLeFormulaire() - thisTrolls.modifier(id, content) - } - ) - $("span.annuler", troll).click( virerLeFormulaire ) - $("form", troll).submit(function(){ return false}) - } - ) - } - ) - - if (data["trolls"].length > 0) - thisTrolls.dernierTroll = data["trolls"][data["trolls"].length - 1]["troll_id"] - break - case "troll_modified" : - $("#trolls #troll" + data["troll_id"] + " .content").html(thisTrolls.formateur.traitementComplet(data["content"], thisTrolls.trolls[data["troll_id"]].author)) - $("#trolls #troll" + data["troll_id"] + " a[@rel*=lightbox]").lightBox() - thisTrolls.trolls[data["troll_id"]].content = data["content"] - break - case "troll_deleted" : - $("#trolls #troll"+data["troll_id"]).remove() - break - case "majIPs" : - // TODO : mettre l'attente au niveau de la page et pas au niveau des trolls - // thisPageAdmin.majIPs() - break - case "error" : - thisTrolls.util.messageDialogue(data["error_message"]) - break - } - } - ) -} \ No newline at end of file