X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2FpageAdmin.js;h=a0b8d6830ff27280b49d6bc62811469582cdf057;hb=d5325d38a2655d2368aa576d6390cb766ce6cc06;hp=1611ecc5e68c05c3bd74fe4931ea81dc84d21066;hpb=81b3e94e62dd60087d71efc42004f8222d9e1e7a;p=euphorik.git diff --git a/js/pageAdmin.js b/js/pageAdmin.js index 1611ecc..a0b8d68 100644 --- a/js/pageAdmin.js +++ b/js/pageAdmin.js @@ -12,8 +12,9 @@ function PageAdmin(client, formateur, util) PageAdmin.prototype.contenu = function() { return '

Trolls

\ -

Nouveau troll\ - \ +

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

\ +

\ + \ \

' } @@ -24,17 +25,264 @@ PageAdmin.prototype.charger = function() var thisPage = this + this.trolls = new Trolls(this.client, this.util, this.formateur) + this.trolls.rafraichirTrolls() + + $("#page form#nouveauTroll input.troll").focus() + $("#page form#nouveauTroll button.return").click( function() - { - + { + thisPage.posterTroll() } ) } +PageAdmin.prototype.decharger = function() +{ + this.trolls.pageEvent.stopAttenteCourante() +} + +PageAdmin.prototype.posterTroll = function() +{ + var thisPageAdmin = this + + var content = $("#page form#nouveauTroll input.troll").val() + + content = content.trim() + if (content == "") + { + this.util.messageDialogue("Le troll est vide") + return + } + + var dataToSend = + { + "action" : "put_troll", + "cookie" : this.client.cookie, + "content" : content + } + + ;;; dumpObj(dataToSend) + jQuery.ajax( + { + type: "POST", + url: "request", + dataType: "json", + data: this.util.jsonVersAction(dataToSend), + success: + function(data) + { + ;;; dumpObj(data) + + if (data["reply"] == "ok") + { + $("#page form#nouveauTroll input.troll").val("") + } + else if (data["reply"] == "error") + { + thisPageAdmin.util.messageDialogue(data["error_message"]) + } + } + } + ) +} + + +/////////////////////////////////////////////////////////////////////////////////////////////////// + + +function Troll(content, author) +{ + this.content = content + this.author = author +} + + /////////////////////////////////////////////////////////////////////////////////////////////////// -function Trolls() + +function Trolls(client, util, formateur) { + this.client = client + this.util = util + 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", + "cookie" : this.client.cookie, + "troll_id" : id, + "content" : content + } + + ;;; dumpObj(dataToSend) + jQuery.ajax( + { + type: "POST", + url: "request", + dataType: "json", + data: this.util.jsonVersAction(dataToSend), + success: + function(data) + { + ;;; dumpObj(data) + if (data["reply"] == "error") + { + thisTrolls.util.messageDialogue(data["error_message"]) + } + } + } + ) +} + +/** + * Supprime un troll en fonction de son id. + */ +Trolls.prototype.supprimer = function(id) +{ + var thisTrolls = this + + var dataToSend = + { + "action" : "del_troll", + "cookie" : this.client.cookie, + "troll_id" : id + } + + ;;; dumpObj(dataToSend) + jQuery.ajax( + { + type: "POST", + url: "request", + dataType: "json", + data: this.util.jsonVersAction(dataToSend), + success: + function(data) + { + ;;; dumpObj(data) + if (data["reply"] == "error") + { + thisTrolls.util.messageDialogue(data["error_message"]) + } + } + } + ) +} + +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 "error" : + thisTrolls.util.messageDialogue(data["error_message"]) + break + } + } + ) } \ No newline at end of file