MOD avancement dans la Grande Restructuration
authorGreg Burri <greg.burri@gmail.com>
Mon, 21 Jul 2008 10:35:05 +0000 (10:35 +0000)
committerGreg Burri <greg.burri@gmail.com>
Mon, 21 Jul 2008 10:35:05 +0000 (10:35 +0000)
js/euphorik.js
js/pageAbout.js
js/pageAdmin.js
js/pageProfile.js
js/pageRegister.js

index 1f3dc01..93058a1 100755 (executable)
@@ -171,10 +171,10 @@ $(document).ready(
       $("#footer .conditions").click(function(){ pages.afficherPage("conditions_utilisation") })
 
       pages.ajouterPage(new PageMinichat(client, formateur, util))
-      pages.ajouterPage(new PageAdmin(client, formateur, util))
-      pages.ajouterPage(new PageProfile(client, formateur, util))
-      pages.ajouterPage(new PageRegister(client, formateur, util))
-      pages.ajouterPage(new PageAbout(client, formateur, util))
+      pages.ajouterPage(new euphorik.PageAdmin(client, formateur, util))
+      pages.ajouterPage(new euphorik.PageProfile(client, formateur, util))
+      pages.ajouterPage(new euphorik.PageRegister(client, formateur, util))
+      pages.ajouterPage(new euphorik.PageAbout(client, formateur, util))
       pages.ajouterPage("conditions_utilisation")
       
       pages.afficherPage("minichat")
index 4ed1bd0..362f857 100644 (file)
 // You should have received a copy of the GNU General Public License\r
 // along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.
 
-function PageAbout(client, formateur, util)
-{
-   this.nom = "about"
+euphorik.PageAbout = function(client, formateur, util) {
+   this.nom = "about";
    
-   this.client = client
-   this.formateur = formateur
-   this.util = util
-}
+   this.client = client;
+   this.formateur = formateur;
+   this.util = util;
+};
 
-PageAbout.prototype.contenu = function()
-{
-   var contenu = ""
-   $.ajax({async: false, url: "pages/about.html", success : function(page) { contenu += page }})
+euphorik.PageAbout.prototype.contenu = function() {
+   var contenu = "";
+   $.ajax({async: false, url: "pages/about.html", success : function(page) { contenu += page; }});
    
-   var email = this.util.rot13("znvygb:tert.oheev@tznvy.pbz")
-   return contenu.replace("{EMAIL}", "<a href=\"" + email+ "\">" + email + "</a>").replace("{EMAIL_LIEN}", email)
-}
+   var email = this.util.rot13("znvygb:tert.oheev@tznvy.pbz");
+   return contenu.replace("{EMAIL}", "<a href=\"" + email+ "\">" + email + "</a>").replace("{EMAIL_LIEN}", email);
+};
 
-PageAbout.prototype.charger = function()
-{
-}
+euphorik.PageAbout.prototype.charger = function() {
+};
index ab91eec..2a6cbc1 100644 (file)
 // 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);
             }
-      }
-   )
-}
+         }
+   });
+};
index b666643..d7c4e62 100755 (executable)
 // 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
index ca1ddb3..b422f5d 100755 (executable)
 // You should have received a copy of the GNU General Public License\r
 // along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.
 
-function PageRegister(client, formateur, util)
-{
-   this.nom = "register"
+euphorik.PageRegister = function(client, formateur, util) {
+   this.nom = "register";
    
-   this.client = client
-   this.formateur = formateur
-   this.util = util
-}
+   this.client = client;
+   this.formateur = formateur;
+   this.util = util;
+};
 
-PageRegister.prototype.contenu = function()
-{
-   return '\
-<form action="" id="register" >\
- <table>\
-  <tr>\
-   <td>login</td>\
-   <td><input class="login" type="text" size="20" maxlength="20"/><input class="captcha" name="captcha" type="text" size="12"></input></td>\
-  </tr>\
-  <tr>\
-   <td>password</td>\
-   <td><input class="password" type="password" size="20" maxlength="20"/></td>\
-  </tr>\
-  <tr>\
-   <td>password re</td>\
-   <td><input class="passwordRe" type="password" size="20" maxlength="20"/></td>\
-  </tr>\
-  <tr>\
-  <td></td>\
-  <td><button>valider</button>\
-  </tr>\
- </table>\
-</form>'
-}
+euphorik.PageRegister.prototype.contenu = function() {
+   return '<form action="" id="register" >' +
+      ' <table>' +
+      '  <tr>' +
+      '   <td>login</td>' +
+      '   <td><input class="login" type="text" size="20" maxlength="20"/><input class="captcha" name="captcha" type="text" size="12"></input></td>' +
+      '  </tr>' +
+      '  <tr>' +
+      '   <td>password</td>' +
+      '   <td><input class="password" type="password" size="20" maxlength="20"/></td>' +
+      '  </tr>' +
+      '  <tr>' +
+      '   <td>password re</td>' +
+      '   <td><input class="passwordRe" type="password" size="20" maxlength="20"/></td>' +
+      '  </tr>' +
+      '  <tr>' +
+      '  <td></td>' +
+      '  <td><button>valider</button>' +
+      '  </tr>' +
+      ' </table>' +
+      '</form>';
+};
 
-PageRegister.prototype.charger = function()
-{      
-   $("#page form#register").submit(function(){return false})
+euphorik.PageRegister.prototype.charger = function() {      
+   $("#page form#register").submit(function(){ return false; });
       
-   var thisPage = this
+   var thisPage = this;
    
    $("#page form#register button").click(
-      function()
-      {         \r
-         if ($("#page form#register input.captcha").val() != "") return\r
+      function() {         \r
+         if ($("#page form#register input.captcha").val() !== "") {\r
+            return;\r
+         }\r
          
-         var login = $("#page form#register input.login").val().trim()
-         var password = $("#page form#register input.password").val()
-         var passwordRe = $("#page form#register input.passwordRe").val()         
+         var login = $("#page form#register input.login").val().trim();
+         var password = $("#page form#register input.password").val();
+         var passwordRe = $("#page form#register input.passwordRe").val();
          
-         if (login == "")
-            thisPage.util.messageDialogue("Le login ne doit pas être vide")
-         else if (password == "" && passwordRe == "")
-            thisPage.util.messageDialogue("Un mot de passe est obligatoire")
-         else if (password != passwordRe)
-            thisPage.util.messageDialogue("Les mots de passes ne correspondent pas")
-         else if(thisPage.client.enregistrement(login, thisPage.util.md5(password)))
-         {   
-            thisPage.util.messageDialogue("Enregistrement réussi")
-            thisPage.pages.afficherPage("minichat")
+         if (login === "") {
+            thisPage.util.messageDialogue("Le login ne doit pas être vide");
+         } else if (password === "" && passwordRe === "") {
+            thisPage.util.messageDialogue("Un mot de passe est obligatoire");
+         } else if (password !== passwordRe) {
+            thisPage.util.messageDialogue("Les mots de passes ne correspondent pas");
+         } else if(thisPage.client.enregistrement(login, thisPage.util.md5(password))) {   
+            thisPage.util.messageDialogue("Enregistrement réussi");
+            thisPage.pages.afficherPage("minichat");
          }
       }
-   )
-}
\ No newline at end of file
+   );
+};\r