Remove the weekly troll.
[euphorik.git] / js / chat / conversations.js
index 3f9fe2d..ea7e742 100644 (file)
@@ -15,7 +15,7 @@
 //\r
 // 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
+\r
 /*jslint laxbreak:true */\r
 \r
 /**\r
@@ -26,16 +26,14 @@ euphorik.Conversations = function(client, formater, util, communication, fragmen
    this.formater = formater;\r
    this.util = util;\r
    this.fragment = fragment;\r
-   \r
+\r
    // un ensemble des messages (id) auquel l'utilisateur répond (vider après l'envoie du message courant)\r
    this.messagesRepond = {};\r
-   \r
+\r
    this.conversations = []; // les conversations, la première représente la conversation principale\r
-   \r
+\r
    this.nouvelleConversation(0);\r
-   \r
-   this.trollIdCourant = 0;\r
-   \r
+\r
    this.comet = communication.createCometConnection("chat");\r
 };\r
 \r
@@ -47,13 +45,13 @@ euphorik.Conversations.prototype.prefixIdMessage = "rep";
   * Permet de définir un message comme étant ou n'étant plus un message auquel l'utilisateur\r
   * répond.\r
   */\r
-euphorik.Conversations.prototype.toggleMessageRepond = function(mess) {   \r
+euphorik.Conversations.prototype.toggleMessageRepond = function(mess) {\r
    // est-ce que l'on répond déjà à ce message ? si oui alors on l'enlève de la liste\r
    if (mess.id in this.messagesRepond) {\r
       this.enleverMessageRepond(mess);\r
       return;\r
    }\r
-   \r
+\r
    this.ajouterMessageRepond(mess);\r
 };\r
 \r
@@ -74,11 +72,11 @@ euphorik.Conversations.prototype.mettreAJourFragment = function() {
   */\r
 euphorik.Conversations.prototype.enleverMessagesRepond = function() {\r
    var thisConversations = this;\r
-   \r
+\r
    objectEach(this.messagesRepond, function(messId, mess) {\r
       thisConversations.enleverMessageRepond(mess);\r
    });\r
-    \r
+\r
    // on réinitialise pour être sur que tout est bien enlevé\r
    this.messagesRepond = {};\r
    $("#conversations .message").removeClass("repondEnEvidence");\r
@@ -100,7 +98,7 @@ euphorik.Conversations.prototype.enleverMessageRepond = function(mess) {
   */\r
 euphorik.Conversations.prototype.ajouterMessageRepond = function(mess) {\r
    var thisConversations = this;\r
-    \r
+\r
    // est-ce que le message fait partie de la même conversation que les autres messages ?\r
    // TODO : solution plus élégante pour prendre un mess parmis messagesRepond !?\r
    var mess2;\r
@@ -110,19 +108,19 @@ euphorik.Conversations.prototype.ajouterMessageRepond = function(mess) {
          break;\r
       }\r
    }\r
-   \r
+\r
    if (mess2 && mess2.racineId !== mess.racineId) {\r
       this.util.messageDialog("Impossible de répondre à deux messages ne faisant pas partie de la même conversation");\r
       return;\r
    }\r
-   \r
+\r
    $("form#posterMessage #repondA .messages").append(mess.XHTML(undefined, this.prefixIdMessage));\r
    this.messagesRepond[mess.id] = mess;\r
-   \r
+\r
    // ajout la classe 'repondEnEvidence' au message. comme il peut se trouver potentiellement dans\r
    // chaque conversation on construit tous les id potentiels\r
    $(mess.getId(this.prefixIdMessage) + ", " + this.exprIdsPotentiels(mess)).addClass("repondEnEvidence");\r
-   \r
+\r
    $("#" + mess.getId(this.prefixIdMessage)).click(\r
       function() {\r
          $(this).fadeOut("normal", function() {\r
@@ -152,9 +150,9 @@ euphorik.Conversations.prototype.exprIdsPotentiels = function(mess) {
 euphorik.Conversations.prototype.rafraichireNombreMessagesRepond = function() {\r
    // TODO : ya pas mieux pour trouver le nombre d'objet ?\r
    var nb = objectMemberCount(this.messagesRepond);\r
-   \r
+\r
    $("#posterMessage #repondA .nb").text(nb);\r
-   \r
+\r
    var boite = $("#posterMessage #repondA");\r
    if (nb > 0) {\r
       boite.show();\r
@@ -182,22 +180,21 @@ euphorik.Conversations.prototype.getJSONrafraichirMessages = function() {
    var mess =  {\r
       "message_count" : euphorik.conf.nbMessageAffiche,\r
       "main_page" : this.client.mainConversationPage,\r
-      "conversations" : this.getJSONConversations(),\r
-      "troll_id" : this.trollIdCourant\r
+      "conversations" : this.getJSONConversations()\r
    };\r
-   \r
+\r
    if (this.client.cookie) {\r
       mess.cookie = this.client.cookie;\r
    }\r
    mess.last_message_id = this.conversations[0].idDernierMessageAffiche;\r
-   \r
+\r
    return mess;\r
 };\r
 \r
 euphorik.Conversations.prototype.getJSONConversations = function() {\r
    var thisConversations = this;\r
    var clientConv = [];\r
-   \r
+\r
    this.client.conversations.each(function(i, conv) {\r
       clientConv.push({\r
          root : conv.root,\r
@@ -218,7 +215,7 @@ euphorik.Conversations.prototype.ajouterMessages = function(elements, numConvers
    if (!elements.messages.length) {\r
       return this.conversations[numConversation] !== undefined;\r
    }\r
-   \r
+\r
    for (var i = 0; i < elements.messages.length; i++) {\r
       if (this.ajouterMessage(elements.messages[i], numConversation)) {\r
          // si une nouvelle conversation a été créée alors on lui donne la racine\r
@@ -227,15 +224,15 @@ euphorik.Conversations.prototype.ajouterMessages = function(elements, numConvers
          this.mettreAJourFragment();\r
       }\r
    }\r
-         \r
+\r
    this.flush(numConversation);\r
-   \r
+\r
    // renseigne la conversation sur la page courante et si c'est la dernière\r
    this.conversations[numConversation].setPage(\r
       numConversation === 0 ? this.client.mainConversationPage : this.client.conversations[numConversation - 1].page,\r
       elements.last_page\r
    );\r
-   \r
+\r
    return true;\r
 };\r
 \r
@@ -246,16 +243,16 @@ euphorik.Conversations.prototype.ajouterMessages = function(elements, numConvers
   * @param numConversation le numéro de la conversation, 0 = principale\r
   * @return true si une nouvelle conversation a été créée sinon false\r
   */\r
-euphorik.Conversations.prototype.ajouterMessage = function(element, numConversation) {   \r
-   var message = \r
+euphorik.Conversations.prototype.ajouterMessage = function(element, numConversation) {\r
+   var message =\r
       new euphorik.Message(\r
          this.client,\r
          this.formater,\r
          element\r
       );\r
-   \r
+\r
    var nouvelleConversation = false;\r
-   \r
+\r
    if (!this.conversations[numConversation]) {\r
       nouvelleConversation = true;\r
       this.nouvelleConversation(numConversation);\r
@@ -269,7 +266,7 @@ euphorik.Conversations.prototype.nouvelleConversation = function(num) {
    var thisConversations = this;\r
 \r
    this.conversations[num] = new euphorik.Conversation(this, num);\r
-      \r
+\r
    this.conversations[num].setFunPage(\r
       function(num) { // page suivante\r
          thisConversations.client.nextPage(num - 1);\r
@@ -285,7 +282,7 @@ euphorik.Conversations.prototype.nouvelleConversation = function(num) {
          }\r
       }\r
    );\r
-   \r
+\r
    this.ajusterLargeurConversations();\r
 };\r
 \r
@@ -297,7 +294,7 @@ euphorik.Conversations.prototype.supprimerConversation = function(num) {
       return; // la numéro 0 ne peut être supprimé\r
    }\r
    this.conversations[num].supprimer();\r
-   \r
+\r
    // les numéros sont réassigné\r
    for (var i = num; i < this.conversations.length - 1; i++) {\r
       this.conversations[i] = this.conversations[i+1];\r
@@ -305,9 +302,9 @@ euphorik.Conversations.prototype.supprimerConversation = function(num) {
    }\r
    this.conversations.pop();\r
    this.ajusterLargeurConversations();\r
-      \r
+\r
    this.client.supprimerConversation(num - 1);\r
-      \r
+\r
    this.rafraichirMessages(true);\r
    this.mettreAJourFragment();\r
 };\r
@@ -322,7 +319,7 @@ euphorik.Conversations.prototype.ajusterLargeurConversations = function() {
    // le "- 0.01" evite que IE se chie dessus lamentablement et affiche les conversations les unes au dessus des autres\r
    //if($.browser["msie"])\r
    //    largeurPourcent -= 0.05\r
-   \r
+\r
    $("#conversations td").css("width", largeurPourcent + "%");\r
 };\r
 \r
@@ -338,10 +335,10 @@ euphorik.Conversations.prototype.flushAll = function() {
 /**\r
   * Demande à une conversation de se flusher.\r
   */\r
-euphorik.Conversations.prototype.flush = function(numConv) {   \r
+euphorik.Conversations.prototype.flush = function(numConv) {\r
    this.conversations[numConv].flush();\r
 };\r
-  \r
+\r
 euphorik.Conversations.prototype.ouvrirConversation = function(racine) {\r
    if (this.client.ajouterConversation(racine)) {\r
       this.rafraichirMessages(true);\r
@@ -363,38 +360,26 @@ euphorik.Conversations.prototype.viderMessages = function() {
   */\r
 euphorik.Conversations.prototype.rafraichirMessages = function(vider) {\r
    var thisConversations = this;\r
-   \r
+\r
    vider = vider || false;\r
-   \r
+\r
    if (vider) {\r
       this.conversations.each(function(i, conv) {\r
          conv.idDernierMessageAffiche = 0;\r
       });\r
    }\r
-   
-   thisConversations.util.showWaitBar(); // pour faire patienter le user :)
-   \r
+\r
+   thisConversations.util.showWaitBar(); // pour faire patienter le user :)\r
+\r
    this.comet.waitEvent(\r
-      function() { return thisConversations.getJSONrafraichirMessages(); },\r
       {\r
-         "new_troll" :\r
-            function(data) {\r
-               thisConversations.trollIdCourant = data.troll_id;\r
-               $("#trollCourant .troll").html(thisConversations.formater.completeProcessing(data.content)).unbind("click").click(\r
-                  function() {\r
-                     thisConversations.ouvrirConversation(data.message_id);\r
-                  }\r
-               );\r
-               \r
-               $("#trollCourant .troll a[@rel*=lightbox]").lightBox();\r
-            },\r
          "new_messages" :\r
-            function(data) {
-               \r
+            function(data) {\r
+\r
                if (vider) {\r
                   thisConversations.viderMessages();\r
                }\r
-               \r
+\r
                // ajoute les messages reçus à leur conversation respective\r
                data.conversations.each(function(numConv, conv) {\r
                   if (!thisConversations.ajouterMessages(conv, numConv)) {\r
@@ -402,15 +387,16 @@ euphorik.Conversations.prototype.rafraichirMessages = function(vider) {
                      thisConversations.client.supprimerConversation(numConv - 1);\r
                   }\r
                });\r
-               \r
+\r
                if (vider) {\r
                   thisConversations.afficherMessagesRepondConversations();\r
                }\r
-               \r
-               vider = false;
-               
+\r
+               vider = false;\r
+\r
                thisConversations.util.hideWaitBar();\r
             }\r
-      }\r
+      },\r
+      function() { return thisConversations.getJSONrafraichirMessages(); }\r
    );\r
 };\r