3 function PageAdmin(client
, formateur
, util
)
8 this.formateur
= formateur
12 PageAdmin
.prototype.contenu = function()
14 return '<h1>Trolls</h1>\
15 <p>Chaque semaine un troll est choisit au hasard parmis les trolls proposés et devient le troll de la semaine.</p>\
16 <form id="nouveauTroll"><p>\
17 <input class="troll" name="troll" type="text" maxlength="500" value=""></input>\
18 <button class="return" value="return">poster</button>\
19 </p></form><div id="trolls"></div>'
22 PageAdmin
.prototype.charger = function()
24 $("#page form#nouveauTroll").submit(function(){return false})
28 this.trolls
= new Trolls(this.client
, this.util
, this.formateur
)
29 this.trolls
.rafraichirTrolls()
31 $("#page form#nouveauTroll input.troll").focus()
33 $("#page form#nouveauTroll button.return").click(
36 thisPage
.posterTroll()
41 PageAdmin
.prototype.decharger = function()
43 this.trolls
.pageEvent
.stopAttenteCourante()
46 PageAdmin
.prototype.posterTroll = function()
48 var thisPageAdmin
= this
50 var content
= $("#page form#nouveauTroll input.troll").val()
52 content
= content
.trim()
55 this.util
.messageDialogue("Le troll est vide")
61 "action" : "put_troll",
62 "cookie" : this.client
.cookie
,
66 ;;; dumpObj(dataToSend
)
72 data: this.util
.jsonVersAction(dataToSend
),
78 if (data
["reply"] == "ok")
80 $("#page form#nouveauTroll input.troll").val("")
82 else if (data
["reply"] == "error")
84 thisPageAdmin
.util
.messageDialogue(data
["error_message"])
92 ///////////////////////////////////////////////////////////////////////////////////////////////////
95 function Troll(content
, author
)
97 this.content
= content
102 ///////////////////////////////////////////////////////////////////////////////////////////////////
105 function Trolls(client
, util
, formateur
)
109 this.formateur
= formateur
110 this.dernierTroll
= 0
111 this.pageEvent
= new PageEvent("admin", this.util
)
117 Trolls
.prototype.modifier = function(id
, content
)
119 var thisTrolls
= this
123 "action" : "mod_troll",
124 "cookie" : this.client
.cookie
,
129 ;;; dumpObj(dataToSend
)
135 data: this.util
.jsonVersAction(dataToSend
),
140 if (data
["reply"] == "error")
142 thisTrolls
.util
.messageDialogue(data
["error_message"])
150 * Supprime un troll en fonction de son id.
152 Trolls
.prototype.supprimer = function(id
)
154 var thisTrolls
= this
158 "action" : "del_troll",
159 "cookie" : this.client
.cookie
,
163 ;;; dumpObj(dataToSend
)
169 data: this.util
.jsonVersAction(dataToSend
),
174 if (data
["reply"] == "error")
176 thisTrolls
.util
.messageDialogue(data
["error_message"])
183 Trolls
.prototype.rafraichirTrolls = function()
185 var thisTrolls
= this
187 this.pageEvent
.waitEvent(
188 function() { return { "last_troll" : thisTrolls
.dernierTroll
}},
191 switch (data
["reply"])
195 for (var i
= 0; i
< data
["trolls"].length
; i
++)
197 var troll
= new Troll(data
["trolls"][i
]["content"], data
["trolls"][i
]["author"])
198 var trollId
= data
["trolls"][i
]["troll_id"]
199 thisTrolls
.trolls
[trollId
] = troll
202 '<div id="troll' + trollId
+ '" class="troll">' +
203 '<span class="content">' + thisTrolls
.formateur
.traitementComplet(troll
.content
, troll
.author
) + '</span>' +
204 '<span class="author"> - ' + thisTrolls
.formateur
.traitementComplet(troll
.author
) + '</span>' +
205 (data
["trolls"][i
]["author_id"] == thisTrolls
.client
.id
? '<span class="editTroll">éditer</span><span class="delTroll">Supprimer</span>' : '') +
208 $("#trolls").append(XHTML
)
209 $("#trolls .troll").filter(function(){return parseInt($(this).attr("id").substr(5)) > thisTrolls
.dernierTroll
}).each(
213 var id
= parseInt($(this).attr("id").substr(5))
215 $("a[@rel*=lightbox]", this).lightBox()
220 if (e
.which
== 13) // return
221 $(".modifier", this).click()
224 $(".delTroll", this).click(
227 thisTrolls
.util
.messageDialogue(
228 "Êtes-vous sur de vouloir supprimer le troll \"" + $("#trolls .troll .content").html() + "\" ?",
229 messageType
.question
,
233 thisTrolls
.supprimer(id
)
240 $(".editTroll", this).click(
243 $("span", troll
).css("display", "none")
245 '<form><p><input class="content" type="text" size="50" maxlength="500" value="' +
246 thisTrolls
.trolls
[id
].content
+
247 '"></input><span class="modifier">modifier</span><span class="annuler">annuler</span></p></form>'
249 $("form input.content").focus()
251 var virerLeFormulaire = function()
253 $("form", troll
).remove()
254 $('span', troll
).css("display", "inline")
256 $("span.modifier", troll
).click(
259 var content
= $("form input.content", troll
).val()
261 thisTrolls
.modifier(id
, content
)
264 $("span.annuler", troll
).click( virerLeFormulaire
)
265 $("form", troll
).submit(function(){ return false})
271 if (data
["trolls"].length
> 0)
272 thisTrolls
.dernierTroll
= data
["trolls"][data
["trolls"].length
- 1]["troll_id"]
274 case "troll_modified" :
275 $("#trolls #troll" + data
["troll_id"] + " .content").html(thisTrolls
.formateur
.traitementComplet(data
["content"], thisTrolls
.trolls
[data
["troll_id"]].author
))
276 $("#trolls #troll" + data
["troll_id"] + " a[@rel*=lightbox]").lightBox()
277 thisTrolls
.trolls
[data
["troll_id"]].content
= data
["content"]
279 case "troll_deleted" :
280 $("#trolls #troll"+data
["troll_id"]).remove()
283 thisTrolls
.util
.messageDialogue(data
["error_message"])