// along with Euphorik. If not, see <http://www.gnu.org/licenses/>.
//
// La page d'administation, ne peut être accédée que par les ekMaster (admins)
+\r
+/*jslint laxbreak:true */\r
+\r
-function PageAdmin(client, formateur, util)
-{
- this.nom = "admin"
+euphorik.PageAdmin = function(client, formateur, util) {
+ this.nom = "admin";
- this.client = client
- this.formateur = formateur
- this.util = util
+ this.client = client;
+ this.formateur = formateur;
+ this.util = util;
- this.pageEvent = new euphorik.PageEvent("admin", this.util)
+ this.pageEvent = new euphorik.PageEvent("admin", this.util);
// le timer qui rappelle periodiquement le rafraichissement des IP bannies
- this.timeoutIDmajIPs = null
-}
+ this.timeoutIDmajIPs = null;
+};
/**
* Interface des pages.
*/
-PageAdmin.prototype.contenu = function()
-{
- return '\
- <h1>Trolls</h1>\
- <p>Un troll est un sujet à débat, en général une question, affiché sur la page principale.</p>\
- <p>Chaque semaine un troll est choisi au hasard parmis les trolls proposés et devient le troll de la semaine.</p>\
- <form action="" id="nouveauTroll">\
- <p>\
- <input class="troll" name="troll" type="text" maxlength="500" value=""></input>\
- <button class="return" value="return">poster</button>\
- </p>\
- </form>\
- <div id="trolls"></div>\
- <h1>IPs bannies</h1>\
- <div id="ips"></div>'
-}
+euphorik.PageAdmin.prototype.contenu = function() {
+ return '<h1>Trolls</h1>' +
+ '<p>Un troll est un sujet à débat, en général une question, affiché sur la page principale.</p>' +
+ '<p>Chaque semaine un troll est choisi au hasard parmis les trolls proposés et devient le troll de la semaine.</p>' +
+ '<form action="" id="nouveauTroll">' +
+ ' <p>' +
+ ' <input class="troll" name="troll" type="text" maxlength="500" value=""></input>' +
+ ' <button class="return" value="return">poster</button>' +
+ ' </p>' +
+ '</form>' +
+ '<div id="trolls"></div>' +
+ '<h1>IPs bannies</h1>' +
+ '<div id="ips"></div>';
+};
/**
* Interface des pages.
*/
-PageAdmin.prototype.charger = function()
-{
- $("#page form#nouveauTroll").submit(function(){return false})
+euphorik.PageAdmin.prototype.charger = function() {
+ $("#page form#nouveauTroll").submit(function(){ return false; });
- var thisPage = this
+ var thisPage = this;
// la liste des trolls proposés par les ekMasters
- this.trolls = new Trolls(this.client, this.util, this.formateur)
+ this.trolls = new euphorik.Trolls(this.client, this.util, this.formateur);
- this.waitEvent()
+ this.waitEvent();
- this.majIPs()
+ this.majIPs();
- $("#page form#nouveauTroll input.troll").focus()
+ $("#page form#nouveauTroll input.troll").focus();
$("#page form#nouveauTroll button.return").click(
- function()
- {
- thisPage.posterTroll()
+ function() {
+ thisPage.posterTroll();
}
- )
-}
+ );
+};
/**
* Interface des pages.
*/
-PageAdmin.prototype.decharger = function()
-{
- this.pageEvent.stopAttenteCourante()
+euphorik.PageAdmin.prototype.decharger = function() {
+ this.pageEvent.stopAttenteCourante();
// supprime le rafraichissement période des ips
- if (this.timeoutIDmajIPs)
- clearTimeout(this.timeoutIDmajIPs)
-}
+ if (this.timeoutIDmajIPs) {
+ clearTimeout(this.timeoutIDmajIPs);\r
+ }
+};
/**
* Post un troll, le contenu est lu à partir de "input.troll".
*/
-PageAdmin.prototype.posterTroll = function()
-{
- var thisPageAdmin = this
+euphorik.PageAdmin.prototype.posterTroll = function() {
+ var thisPageAdmin = this;
- var content = $("#page form#nouveauTroll input.troll").val()
+ var content = $("#page form#nouveauTroll input.troll").val();
- content = content.trim()
- if (content == "")
- {
- this.util.messageDialogue("Le troll est vide")
- return
+ content = content.trim();
+ if (content === "") {
+ this.util.messageDialogue("Le troll est vide");
+ return;
}
- var dataToSend =
- {
- "header" : { "action" : "put_troll", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.client.cookie,
- "content" : content
- }
+ var dataToSend = {
+ "header" : { "action" : "put_troll", "version" : euphorik.conf.versionProtocole },
+ "cookie" : this.client.cookie,
+ "content" : content
+ };
- jQuery.ajax(
- {
- type: "POST",
- url: "request",
- dataType: "json",
- data: this.util.jsonVersAction(dataToSend),
- success:
- function(data)
- {
- if (data["reply"] == "ok")
- {
- $("#page form#nouveauTroll input.troll").val("")
- }
- else if (data["reply"] == "error")
- {
- thisPageAdmin.util.messageDialogue(data["error_message"])
- }
+ jQuery.ajax({
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(data){
+ if (data.reply === "ok") {
+ $("#page form#nouveauTroll input.troll").val("");
+ } else if (data.reply === "error") {
+ thisPageAdmin.util.messageDialogue(data.error_message);
}
- }
- )
-}
+ }
+ });
+};
/**
* Met à jour la liste des IP bannies.
*/
-PageAdmin.prototype.majIPs = function()
-{
- if (this.timeoutIDmajIPs)
- clearTimeout(this.timeoutIDmajIPs)
+euphorik.PageAdmin.prototype.majIPs = function() {
+ if (this.timeoutIDmajIPs) {
+ clearTimeout(this.timeoutIDmajIPs);\r
+ }
- var thisPageAdmin = this
+ var thisPageAdmin = this;
- var dataToSend =
- {
- "header" : { "action" : "list_banned_ips", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.client.cookie
- }
+ var dataToSend = {
+ "header" : { "action" : "list_banned_ips", "version" : euphorik.conf.versionProtocole },
+ "cookie" : this.client.cookie
+ };
- jQuery.ajax(
- {
- type: "POST",
- url: "request",
- dataType: "json",
- data: this.util.jsonVersAction(dataToSend),
- success:
- function(data)
- {
- if (data["reply"] == "list_banned_ips")
- {
- var XHTML = ""
- for(var i = 0; i < data["list"].length; i++)
- {
- var ip = data["list"][i]
- XHTML += '<div class="ban"><span class="ip">' + ip["ip"] + '</span>|' +
- '<span class="temps">' +
- ip["remaining_time"] +
- '</span>|'
- for(var j = 0; j < ip["users"].length; j++)
- {
- var user = ip["users"][j]
- XHTML += (j > 0 ? ", " : "") +
- '<span class="pseudo">' + thisPageAdmin.formateur.traitementComplet(user["nick"]) + '</span>' +
- (user["login"] == "" ? "" : '<span class="login">(' + thisPageAdmin.formateur.traitementComplet(user["login"]) + ')</span>')
- }
- XHTML += '<span class="deban">débannir</span></div>'
- }
-
- if (data["list"].length == 0)
- XHTML += '<p>Aucune IP bannie</p>'
-
- $("#ips").html(XHTML)
+ jQuery.ajax({
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(data) {
+ if (data.reply === "list_banned_ips") {
+ var XHTML = "";\r
+ data.list.each(function(ip) {
+ XHTML += '<div class="ban"><span class="ip">' + ip.ip + '</span>|' +
+ '<span class="temps">' +
+ ip.remaining_time +
+ '</span>|';\r
+ ip.users.each(function(user) {
+ XHTML += (j > 0 ? ", " : "") +
+ '<span class="pseudo">' + thisPageAdmin.formateur.traitementComplet(user.nick) + '</span>' +
+ (user.login === "" ? "" : '<span class="login">(' + thisPageAdmin.formateur.traitementComplet(user.login) + ')</span>');
+ });
+ XHTML += '<span class="deban">débannir</span></div>';
+ });
+
+ if (data.list.length === 0) {
+ XHTML += '<p>Aucune IP bannie</p>';\r
+ }
- $(".ban").each(
- function()
- {
- var ip = $(".ip", this).html()
- $(".deban", this).click(
- function()
- {
- thisPageAdmin.util.messageDialogue("Êtes-vous sur de vouloir débannir l'IP ''" + ip + "'' ?", euphorik.Util.messageType.question,
- {"Oui" : function()
- {
- thisPageAdmin.deban(ip)
- },
- "Non" : function(){}
- }
- )
+ $("#ips").html(XHTML);
+
+ $(".ban").each(function() {
+ var ip = $(".ip", this).html();
+ $(".deban", this).click(
+ function() {
+ thisPageAdmin.util.messageDialogue("Êtes-vous sur de vouloir débannir l'IP ''" + ip + "'' ?", euphorik.Util.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 être fait du coté client
- thisPageAdmin.timeoutIDmajIPs = setTimeout(function(){ thisPageAdmin.majIPs() }, 60 * 1000)
+ );
+ });
+ } 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 être fait du coté client
+ thisPageAdmin.timeoutIDmajIPs = setTimeout(function(){ thisPageAdmin.majIPs(); }, 60 * 1000);
+ }
+ });
+};
/**
* Débannie une ip donnée.
*/
-PageAdmin.prototype.deban = function(ip)
-{
- var thisPageAdmin = this
+euphorik.PageAdmin.prototype.deban = function(ip) {
+ var thisPageAdmin = this;
- var dataToSend =
- {
- "header" : { "action" : "unban", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.client.cookie,
- "ip" : ip
- }
+ var dataToSend = {
+ "header" : { "action" : "unban", "version" : euphorik.conf.versionProtocole },
+ "cookie" : this.client.cookie,
+ "ip" : ip
+ };
- jQuery.ajax(
- {
- type: "POST",
- url: "request",
- dataType: "json",
- data: this.util.jsonVersAction(dataToSend),
- success:
- function(data)
- {
- if(data["reply"] == "error")
- thisPageAdmin.util.messageDialogue(data["error_message"])
+ jQuery.ajax({
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(data){
+ if(data.reply === "error") {
+ thisPageAdmin.util.messageDialogue(data.error_message);\r
}
- }
- )
-}
+ }
+ });
+};
/**
* Attente d'événement de la part du serveur.
*/
-PageAdmin.prototype.waitEvent = function()
-{
- var thisPageAdmin = this
+euphorik.PageAdmin.prototype.waitEvent = function() {
+ var thisPageAdmin = this;
this.pageEvent.waitEvent(
- function() { return { "last_troll" : thisPageAdmin.trolls.dernierTroll }},
+ function() { return { "last_troll" : thisPageAdmin.trolls.dernierTroll }; },
{
- "troll_added" : function(data){ thisPageAdmin.trolls.ajouterTrollEvent(data) },
- "troll_modified" : function(data){ thisPageAdmin.trolls.modifierTrollEvent(data) },
- "troll_deleted" : function(data){ thisPageAdmin.trolls.supprimerTrollEvent(data) },
- "banned_ips_refresh" : function(data){ thisPageAdmin.majIPs() },
+ "troll_added" : function(data){ thisPageAdmin.trolls.ajouterTrollEvent(data); },
+ "troll_modified" : function(data){ thisPageAdmin.trolls.modifierTrollEvent(data); },
+ "troll_deleted" : function(data){ thisPageAdmin.trolls.supprimerTrollEvent(data); },
+ "banned_ips_refresh" : function(data){ thisPageAdmin.majIPs(); },
"error" :
- function(data)
- {
- thisTrolls.util.messageDialogue(data["error_message"])
+ function(data) {
+ thisTrolls.util.messageDialogue(data.error_message);
}
}
- )
-}
+ );
+};
///////////////////////////////////////////////////////////////////////////////////////////////////
/**
* Représente un troll, pas grand chose finalement.
*/
-function Troll(content, author)
-{
- this.content = content
- this.author = author
-}
-
+euphorik.Troll = function(content, author) {
+ this.content = content;
+ this.author = author;
+};
///////////////////////////////////////////////////////////////////////////////////////////////////
-
-function Trolls(client, util, formateur)
-{
- this.client = client
- this.util = util
- this.formateur = formateur
- this.dernierTroll = 0
+euphorik.Trolls = function(client, util, formateur) {
+ this.client = client;
+ this.util = util;
+ this.formateur = formateur;
+ this.dernierTroll = 0;
- this.trolls = {}
-}
+ this.trolls = {};
+};
-Trolls.prototype.ajouterTrollEvent = function(data)
-{
- var thisTrolls = this
+euphorik.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
+ var XHTML = "";\r
+ data.trolls.each(function(trollData) {
+ var troll = new euphorik.Troll(trollData.content, trollData.author);
+ var trollId = trollData.troll_id;
+ thisTrolls.trolls[trollId] = troll;
XHTML +=
'<div id="troll' + trollId + '" class="troll">' +
'<span class="content">' + thisTrolls.formateur.traitementComplet(troll.content, troll.author) + '</span>' +
'<span class="author"> - ' + thisTrolls.formateur.traitementComplet(troll.author) + '</span>' +
- (data["trolls"][i]["author_id"] == thisTrolls.client.id ? '<span class="editTroll">éditer</span><span class="delTroll">Supprimer</span>' : '') +
- '</div>'
- }
- $("#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))
+ (trollData.author_id === thisTrolls.client.id ? '<span class="editTroll">éditer</span><span class="delTroll">Supprimer</span>' : '') +
+ '</div>';
+ });
+ $("#trolls").append(XHTML);
+ $("#trolls .troll").filter(function() { return parseInt($(this).attr("id").substr(5), 10) > thisTrolls.dernierTroll; }).each(
+ function() {
+ var troll = this;
+ var id = parseInt($(this).attr("id").substr(5), 10);
- $("a[@rel*=lightbox]", this).lightBox()
+ $("a[@rel*=lightbox]", this).lightBox();
$(this).keypress(
- function(e)
- {
- if (e.which == 13) // return
- $(".modifier", this).click()
+ function(e) {
+ if (e.which === 13) { // return
+ $(".modifier", this).click();\r
+ }
}
- )
+ );\r
+
$(".delTroll", this).click(
- function()
- {
+ function() {
thisTrolls.util.messageDialogue(
"Êtes-vous sur de vouloir supprimer le troll \"" + thisTrolls.trolls[id].content + "\" ?",
euphorik.Util.messageType.question,
{
- "oui" : function()
- {
- thisTrolls.supprimer(id)
+ "oui" : function() {
+ thisTrolls.supprimer(id);
},
"non" : function(){}
}
- )
+ );
}
- )
+ );\r
+
$(".editTroll", this).click(
- function()
- {
- $("span", troll).css("display", "none")
- $(troll).append(
+ function() {
+ $("span", troll).css("display", "none");
+ $(troll).append(\r
'<form><p><input class="content" type="text" size="50" maxlength="500" value="' +
thisTrolls.trolls[id].content +
'"></input><span class="modifier">modifier</span><span class="annuler">annuler</span></p></form>'
- )
- $("form input.content").focus()
+ );
+ $("form input.content").focus();
- var virerLeFormulaire = function()
- {
- $('form', troll).remove()
- $('span', troll).css("display", "inline")
- }
+ 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)
+ function() {
+ var content = $("form input.content", troll).val();
+ virerLeFormulaire();
+ thisTrolls.modifier(id, content);
}
- )
- $("span.annuler", troll).click( virerLeFormulaire )
- $("form", troll).submit(function(){ return false})
- }
- )
+ );
+ $("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"]
-}
+ if (data.trolls.length > 0) {
+ thisTrolls.dernierTroll = data.trolls[data.trolls.length - 1].troll_id;\r
+ }
+};
-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"]
-}
+euphorik.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.supprimerTrollEvent = function(data) {
+ $("#trolls #troll" + data.troll_id).remove();
+};
-Trolls.prototype.modifier = function(id, content)
-{
- var thisTrolls = this
+Trolls.prototype.modifier = function(id, content) {
+ var thisTrolls = this;
- var dataToSend =
- {
- "header" : { "action" : "mod_troll", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.client.cookie,
- "troll_id" : id,
- "content" : content
- }
+ var dataToSend = {
+ "header" : { "action" : "mod_troll", "version" : euphorik.conf.versionProtocole },
+ "cookie" : this.client.cookie,
+ "troll_id" : id,
+ "content" : content
+ };
- jQuery.ajax(
- {
- type: "POST",
- url: "request",
- dataType: "json",
- data: this.util.jsonVersAction(dataToSend),
- success:
- function(data)
- {
- if (data["reply"] == "error")
- {
- thisTrolls.util.messageDialogue(data["error_message"])
- }
+ jQuery.ajax({
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(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
+euphorik.Trolls.prototype.supprimer = function(id) {
+ var thisTrolls = this;
- var dataToSend =
- {
- "header" : { "action" : "del_troll", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.client.cookie,
- "troll_id" : id
- }
+ var dataToSend = {
+ "header" : { "action" : "del_troll", "version" : euphorik.conf.versionProtocole },
+ "cookie" : this.client.cookie,
+ "troll_id" : id
+ };
- jQuery.ajax(
- {
- type: "POST",
- url: "request",
- dataType: "json",
- data: this.util.jsonVersAction(dataToSend),
- success:
- function(data)
- {
- if (data["reply"] == "error")
- {
- thisTrolls.util.messageDialogue(data["error_message"])
- }
+ jQuery.ajax({
+ type: "POST",
+ url: "request",
+ dataType: "json",
+ data: this.util.jsonVersAction(dataToSend),
+ success:
+ function(data) {
+ if (data.reply === "error") {
+ thisTrolls.util.messageDialogue(data.error_message);
}
- }
- )
-}
+ }
+ });
+};
// You should have received a copy of the GNU General Public License\r
// along with Euphorik. If not, see <http://www.gnu.org/licenses/>.\r
\r
-function PageProfile(client, formateur, util)\r
-{\r
- this.nom = "profile"\r
+euphorik.PageProfile = function(client, formateur, util) {\r
+ this.nom = "profile";\r
\r
- this.client = client\r
- this.formateur = formateur\r
- this.util = util\r
-}\r
+ this.client = client;\r
+ this.formateur = formateur;\r
+ this.util = util;\r
+};\r
\r
-PageProfile.prototype.contenu = function()\r
-{\r
+euphorik.PageProfile.prototype.contenu = function() {\r
// pourquoi ?\r
- return ""\r
-}\r
+ return "";\r
+};\r
\r
-PageProfile.prototype.charger = function()\r
-{\r
- $("#page").html(this.getHTML())\r
+euphorik.PageProfile.prototype.charger = function() {\r
+ $("#page").html(this.getHTML());\r
\r
// en fonction du statut\r
- if (this.client.authentifie())\r
- this.chargerProfile()\r
- else\r
- this.chargerLogin()\r
+ if (this.client.authentifie()) {\r
+ this.chargerProfile();\r
+ } else {\r
+ this.chargerLogin();\r
+ }\r
\r
- $("#page form#profile").submit(function(){return false})\r
-}\r
+ $("#page form#profile").submit(function(){ return false; });\r
+};\r
\r
-PageProfile.prototype.chargerProfile = function()\r
-{ \r
- var thisPage = this\r
+euphorik.PageProfile.prototype.chargerProfile = function() { \r
+ var thisPage = this;\r
\r
- $("form#profile input.login").val(this.client.login)\r
- $("form#profile input.pseudo").val(this.client.pseudo)\r
- $("form#profile input.email").val(this.client.email)\r
- $("form#profile input#viewTooltips").attr("checked", this.client.viewTooltips)\r
- $("form#profile input#viewTimes").attr("checked", this.client.viewTimes)\r
+ $("form#profile input.login").val(this.client.login);\r
+ $("form#profile input.pseudo").val(this.client.pseudo);\r
+ $("form#profile input.email").val(this.client.email);\r
+ $("form#profile input#viewTooltips").attr("checked", this.client.viewTooltips);\r
+ $("form#profile input#viewTimes").attr("checked", this.client.viewTimes);\r
\r
- $("form#profile select#chatOrder option").removeAttr("selected")\r
- $("form#profile select#chatOrder option[value=" + this.client.chatOrder + "]").attr("selected", "selected")\r
+ $("form#profile select#chatOrder option").removeAttr("selected");\r
+ $("form#profile select#chatOrder option[value=" + this.client.chatOrder + "]").attr("selected", "selected");\r
\r
- $("form#profile select#affichagePseudo option").removeAttr("selected")\r
- $("form#profile select#affichagePseudo option[value=" + this.client.nickFormat + "]").attr("selected", "selected")\r
+ $("form#profile select#affichagePseudo option").removeAttr("selected");\r
+ $("form#profile select#affichagePseudo option[value=" + this.client.nickFormat + "]").attr("selected", "selected");\r
\r
- if (this.client.ostentatiousMaster)\r
- {\r
- $("form#profile select#degreeOstentatoire option").removeAttr("selected")\r
- $("form#profile select#degreeOstentatoire option[value=" + this.client.ostentatiousMaster + "]").attr("selected", "selected") \r
+ if (this.client.ostentatiousMaster) {\r
+ $("form#profile select#degreeOstentatoire option").removeAttr("selected");\r
+ $("form#profile select#degreeOstentatoire option[value=" + this.client.ostentatiousMaster + "]").attr("selected", "selected");\r
}\r
\r
$("form#profile button").click(\r
- function()\r
- {\r
- thisPage.client.pseudo = thisPage.formateur.filtrerInputPseudo($("form#profile input.pseudo").val())\r
- thisPage.client.email = $("form#profile input.email").val()\r
- thisPage.client.chatOrder = $("form#profile select#chatOrder option:selected").attr("value") \r
- thisPage.client.nickFormat = $("form#profile select#affichagePseudo option:selected").attr("value") \r
- if (thisPage.client.ekMaster)\r
- thisPage.client.ostentatiousMaster = $("form#profile select#degreeOstentatoire option:selected").attr("value") \r
- thisPage.client.viewTooltips = $("form#profile input#viewTooltips").attr("checked")\r
- thisPage.client.viewTimes = $("form#profile input#viewTimes").attr("checked")\r
+ function() {\r
+ thisPage.client.pseudo = thisPage.formateur.filtrerInputPseudo($("form#profile input.pseudo").val());\r
+ thisPage.client.email = $("form#profile input.email").val();\r
+ thisPage.client.chatOrder = $("form#profile select#chatOrder option:selected").attr("value");\r
+ thisPage.client.nickFormat = $("form#profile select#affichagePseudo option:selected").attr("value");\r
+ if (thisPage.client.ekMaster) {\r
+ thisPage.client.ostentatiousaster = $("form#profile select#degreeOstentatoire option:selected").attr("value");\r
+ }\r
+ thisPage.client.viewTooltips = $("form#profile input#viewTooltips").attr("checked");\r
+ thisPage.client.viewTimes = $("form#profile input#viewTimes").attr("checked");\r
\r
- var password = $("form#profile input.password").val()\r
- var passwordRe = $("form#profile input.passwordRe").val() \r
- if (password != "" || passwordRe != "")\r
- {\r
- if (password != passwordRe)\r
- { \r
- thisPage.util.messageDialogue("Les mots de passes ne correspondent pas")\r
- return\r
+ var password = $("form#profile input.password").val();\r
+ var passwordRe = $("form#profile input.passwordRe").val();\r
+ if (password !== "" || passwordRe !== "") {\r
+ if (password !== passwordRe) { \r
+ thisPage.util.messageDialogue("Les mots de passes ne correspondent pas");\r
+ return;\r
}\r
- thisPage.client.password = thisPage.util.md5(password)\r
+ thisPage.client.password = thisPage.util.md5(password);\r
}\r
\r
- if(!thisPage.client.flush())\r
- thisPage.util.messageDialogue("Impossible de mettre à jour votre profile, causes inconnues", euphorik.Util.messageType.erreur)\r
- else\r
- {\r
- thisPage.util.messageDialogue("Votre profile a été mis à jour")\r
- thisPage.pages.afficherPage("minichat")\r
+ if(!thisPage.client.flush()) {\r
+ thisPage.util.messageDialogue("Impossible de mettre à jour votre profile, causes inconnues", euphorik.Util.messageType.erreur);\r
+ } else { \r
+ thisPage.util.messageDialogue("Votre profile a été mis à jour");\r
+ thisPage.pages.afficherPage("minichat");\r
}\r
}\r
- )\r
-}\r
+ );\r
+};\r
\r
-PageProfile.prototype.chargerLogin = function()\r
-{ \r
- var thisPage = this\r
+euphorik.PageProfile.prototype.chargerLogin = function() { \r
+ var thisPage = this;\r
\r
$("#page form#profile button").click(\r
- function()\r
- {\r
- if(thisPage.client.connexionLogin($("form#profile input.login").val(), thisPage.util.md5($("form#profile input.password").val())))\r
- {\r
+ function() {\r
+ if(thisPage.client.connexionLogin($("form#profile input.login").val(), thisPage.util.md5($("form#profile input.password").val()))) {\r
// TODO afficher un message "ok"\r
- thisPage.pages.afficherPage("minichat")\r
+ thisPage.pages.afficherPage("minichat");\r
}\r
}\r
- )\r
-}\r
-\r
-PageProfile.prototype.getHTML = function()\r
-{\r
-return '\\r
-<form action="" id="profile" >\\r
- <table>\\r
- <tr>\\r
- <td>login</td>\\r
- <td><input class="login" type="text" size="20" maxlength="20" ' + (this.client.authentifie() ? 'readonly="readonly"' : '') + ' /></td>\\r
- </tr>\\r
- <tr>\\r
- <td>password</td>\\r
- <td><input class="password" type="password" size="20" maxlength="20"/></td>\\r
- </tr>' + \r
- (this.client.authentifie() ? '\\r
- <tr>\\r
- <td>password re</td>\\r
- <td><input class="passwordRe" type="password" size="20" maxlength="20"/></td>\\r
- </tr>\\r
- <tr>\\r
- <td>pseudo</td>\\r
- <td><input class="pseudo" type="text" size="40" maxlength="20"/></td>\\r
- </tr>\\r
- <tr>\\r
- <td>e-mail</td>\\r
- <td><input class="email" type="text" size="40" maxlength="100"/></td>\\r
- </tr>\\r
- <tr>\\r
- <td>Ordre des messages</td>\\r
- <td>\\r
- <select id="chatOrder">\\r
- <option value="chrono">Chronologique</option>\\r
- <option value="reverse">Anti-chronologique</option>\\r
- </select>\\r
- </td>\\r
- </tr>\\r
- <tr>' +\r
- (this.client.ekMaster ? '<td>Degrée d\'ostentation</td>\\r
- <td>\\r
- <select id="degreeOstentatoire">\\r
- <option value="invisible">Nul</option>\\r
- <option value="light">Faible</option>\\r
- <option value="heavy">Élevé</option>\\r
- </select>\\r
- </td>' : '') +\r
- '</tr>\\r
- <tr>\\r
- <td>Affichage des identifiants</td>\\r
- <td>\\r
- <select id="affichagePseudo">\\r
- <option value="nick">Pseudo</option>\\r
- <option value="login">Login</option>\\r
- <option value="nick_login">Pseudo(Login)</option>\\r
- </select>\\r
- </td>\\r
- </tr>\\r
- <tr>\\r
- <td>Afficher les infos bulles</td>\\r
- <td><input type="checkbox" id="viewTooltips" /></td>\\r
- </tr>\\r
- <tr>\\r
- <td>Afficher les dates</td>\\r
- <td><input type="checkbox" id="viewTimes" /></td>\\r
- </tr>' : '') + '\\r
- <tr>\\r
- <td></td>\\r
- <td><button>Valider</button>\\r
- </tr>\\r
- </table>\\r
-</form>' \r
-}\r
+ );\r
+};\r
\r
+euphorik.PageProfile.prototype.getHTML = function() {\r
+ return '<form action="" id="profile" >' +\r
+ ' <table>' +\r
+ ' <tr>' +\r
+ ' <td>login</td>' +\r
+ ' <td><input class="login" type="text" size="20" maxlength="20" ' + (this.client.authentifie() ? 'readonly="readonly"' : '') + ' /></td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>password</td>' +\r
+ ' <td><input class="password" type="password" size="20" maxlength="20"/></td>' +\r
+ ' </tr>' + \r
+ (this.client.authentifie() ? '' +\r
+ ' <tr>' +\r
+ ' <td>password re</td>' +\r
+ ' <td><input class="passwordRe" type="password" size="20" maxlength="20"/></td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>pseudo</td>' +\r
+ ' <td><input class="pseudo" type="text" size="40" maxlength="20"/></td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>e-mail</td>' +\r
+ ' <td><input class="email" type="text" size="40" maxlength="100"/></td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>Ordre des messages</td>' +\r
+ ' <td>' +\r
+ ' <select id="chatOrder">' +\r
+ ' <option value="chrono">Chronologique</option>' +\r
+ ' <option value="reverse">Anti-chronologique</option>' +\r
+ ' </select>' +\r
+ ' </td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ (this.client.ekMaster ? '' +\r
+ ' <td>Degrée d' +'ostentation</td>' +\r
+ ' <td>' +\r
+ ' <select id="degreeOstentatoire">' +\r
+ ' <option value="invisible">Nul</option>' +\r
+ ' <option value="light">Faible</option>' +\r
+ ' <option value="heavy">Élevé</option>' +\r
+ ' </select>' +\r
+ ' </td>' : '') +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>Affichage des identifiants</td>' +\r
+ ' <td>' +\r
+ ' <select id="affichagePseudo">' +\r
+ ' <option value="nick">Pseudo</option>' +\r
+ ' <option value="login">Login</option>' +\r
+ ' <option value="nick_login">Pseudo(Login)</option>' +\r
+ ' </select>' +\r
+ ' </td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>Afficher les infos bulles</td>' +\r
+ ' <td><input type="checkbox" id="viewTooltips" /></td>' +\r
+ ' </tr>' +\r
+ ' <tr>' +\r
+ ' <td>Afficher les dates</td>' +\r
+ ' <td><input type="checkbox" id="viewTimes" /></td>' +\r
+ ' </tr>' : '') +\r
+ ' <tr>' +\r
+ ' <td></td>' +\r
+ ' <td><button>Valider</button>' +\r
+ ' </tr>' +\r
+ ' </table>' +\r
+ '</form>';\r
+};\r