X-Git-Url: http://git.euphorik.ch/index.cgi?a=blobdiff_plain;ds=inline;f=js%2FpageAdmin.js;h=d7d735a5de5fc3a719b292ec6103e3b24b02d252;hb=cd30bb86848bd5b52c46b8a0ff40cea6398de60e;hp=fd1ddd46c665860ade0012916b574499afa5a3ac;hpb=8bec0dac79e750d0040de8a009c6ae864479642e;p=euphorik.git
diff --git a/js/pageAdmin.js b/js/pageAdmin.js
index fd1ddd4..d7d735a 100644
--- a/js/pageAdmin.js
+++ b/js/pageAdmin.js
@@ -12,11 +12,17 @@ function PageAdmin(client, formateur, util)
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.
\
- '
+ \
+ \
+ IPs bannies
\
+ '
}
PageAdmin.prototype.charger = function()
@@ -28,6 +34,10 @@ PageAdmin.prototype.charger = function()
this.trolls = new Trolls(this.client, this.util, this.formateur)
this.trolls.rafraichirTrolls()
+ this.majIPs()
+
+ $("#page form#nouveauTroll input.troll").focus()
+
$("#page form#nouveauTroll button.return").click(
function()
{
@@ -86,8 +96,75 @@ PageAdmin.prototype.posterTroll = function()
)
}
+
+/**
+ * Met à jour la liste des IP bannies.
+ */
+PageAdmin.prototype.majIPs = function()
+{
+ var thisPageAdmin = this
+
+ var dataToSend =
+ {
+ "action" : "list_banned_ips",
+ "cookie" : this.client.cookie
+ }
+
+ ;;; dumpObj(dataToSend)
+ jQuery.ajax(
+ {
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(data)
+ {
+ ;;; dumpObj(data)
+
+ if (data["reply"] == "list_banned_ips")
+ {
+ var XHTML = ""
+ for(var i = 0; i < data["list"].length; i++)
+ {
+ var ip = data["list"][i]
+ XHTML += '' + ip["ip"] + '' +
+ '' +
+ ip["remaining_time"] +
+ '['
+ for(var j = 0; j < ip["users"].length; j++)
+ {
+ var user = ip["users"][j]
+ XHTML += (j > 0 ? ", " : "") +
+ '' + thisPageAdmin.formateur.traitementComplet(user["nick"]) + '' +
+ (user["login"] == "" ? "" : '(' + thisPageAdmin.formateur.traitementComplet(user["login"]) + ')')
+ }
+ XHTML += ']'
+ }
+ $("#ips").html(XHTML)
+ }
+ else if (data["reply"] == "error")
+ {
+ thisPageAdmin.util.messageDialogue(data["error_message"])
+ }
+ }
+ }
+ )
+}
+
+///////////////////////////////////////////////////////////////////////////////////////////////////
+
+
+function Troll(content, author)
+{
+ this.content = content
+ this.author = author
+}
+
+
///////////////////////////////////////////////////////////////////////////////////////////////////
+
function Trolls(client, util, formateur)
{
this.client = client
@@ -95,11 +172,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 +202,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 +214,8 @@ Trolls.prototype.modifier = function(id, content)
*/
Trolls.prototype.supprimer = function(id)
{
+ var thisTrolls = this
+
var dataToSend =
{
"action" : "del_troll",
@@ -153,7 +236,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 +257,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 +=
- '' +
- '
' + thisTrolls.formateur.traitementComplet(data["trolls"][i]["content"], data["trolls"][i]["author"]) + '' +
- '
' + thisTrolls.formateur.traitementComplet(data["trolls"][i]["author"]) + '' +
+ '
' +
+ '' + thisTrolls.formateur.traitementComplet(troll.content, troll.author) + '' +
+ ' - ' + thisTrolls.formateur.traitementComplet(troll.author) + '' +
(data["trolls"][i]["author_id"] == thisTrolls.client.id ? 'éditerSupprimer' : '') +
'
'
}
@@ -187,6 +274,16 @@ Trolls.prototype.rafraichirTrolls = 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()
{
@@ -209,9 +306,11 @@ Trolls.prototype.rafraichirTrolls = function()
$("span", troll).css("display", "none")
$(troll).append(
'
'
)
+ $("form input.content").focus()
+
var virerLeFormulaire = function()
{
$("form", troll).remove()
@@ -236,12 +335,16 @@ Trolls.prototype.rafraichirTrolls = function()
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"], $("#trolls #troll" + data["troll_id"] + " .author").html()))
- $("#trolls #troll" + data["troll_id"] + " .contentPasFormat").html(data["content"])
+ $("#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
}
}
)