--- /dev/null
+// coding: utf-8\r
+// Copyright 2008 Grégory Burri\r
+//\r
+// This file is part of Euphorik.\r
+//\r
+// Euphorik is free software: you can redistribute it and/or modify\r
+// it under the terms of the GNU General Public License as published by\r
+// the Free Software Foundation, either version 3 of the License, or\r
+// (at your option) any later version.\r
+//\r
+// Euphorik is distributed in the hope that it will be useful,\r
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
+// but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+// GNU General Public License for more details.\r
+//\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
+euphorik.Reponse = function(id, pseudo, login) {\r
+ this.id = id;\r
+ this.pseudo = pseudo;\r
+ this.login = login;\r
+ this.pseudo = pseudo || "";\r
+ this.login = login || "";\r
+};\r
+\r
+/**\r
+ * Représente un message.\r
+ */\r
+euphorik.Message = function(client, formater, element) {\r
+ this.client = client;\r
+ this.formater = formater;\r
+ \r
+ this.id = element.id;\r
+ this.auteurId = element.user_id;\r
+ this.racineId = element.root;\r
+ this.date = element.date;\r
+ this.pseudo = element.nick;\r
+ this.login = element.login;\r
+ this.contenu = element.content;\r
+ \r
+ // l'ensemble des id des messages qui reponde à ce message, exemple : {45:true, 32:true} (le 'true' ne sert à rien ^_^)\r
+ // mis à jour au fur à mesure que des messages sont ajoutés aux conversations\r
+ this.estReponduPar = {};\r
+ \r
+ this.appartientAuClient = element.owner;\r
+ this.clientARepondu = element.answered;\r
+ this.estUneReponse = element.is_a_reply;\r
+ this.systeme = element.system; // est-ce un message 'système' ?\r
+ this.setRepondA(element.answer_to); // un ensemble de reponse (voir Reponse) indexé par l'id du message de la reponses\r
+ this.ekMaster = element.ek_master;\r
+ this.degreeOstentatoire = element.ostentatious_master;\r
+};\r
+\r
+/**\r
+ * @param pre est un prefix permettant de créer un Id différent pour deux mêmes messages.\r
+ * Cela est utile pour afficher plusieurs mêmes messages au sein d'un document XHTML.\r
+ * voir également la fonction 'XHTML()'.\r
+ */\r
+euphorik.Message.prototype.getId = function(pre) {\r
+ pre = pre || "";\r
+ return pre + "mess" + this.id.toString(36);\r
+};\r
+\r
+euphorik.Message.prototype.setRepondA = function(repondAJSON) {\r
+ var thisMessage = this;\r
+ this.repondA = {};\r
+ \r
+ repondAJSON.each(function(i, reponse) {\r
+ thisMessage.repondA[reponse.id] = new euphorik.Reponse(reponse.id, reponse.nick, reponse.login);\r
+ });\r
+};\r
+\r
+/**\r
+ * Renvoie les messages faisant partie d'une conversation.\r
+ * @param messages l'ensemble des messages de la conversation\r
+ * @return les id des messages qui ont été mis en evidence sous la forme\r
+ * d'un hash (object) {id => 0 | 1 | 2 | 3}. 1 : proprietaire, 2 : reponse directe, 3 : message repondu\r
+ */\r
+euphorik.Message.prototype.getConversation = function(messages) {\r
+ var thisMessage = this;\r
+\r
+ // les messages faisant partie de la conversation\r
+ var messagesEnEvidence = {};\r
+ messagesEnEvidence[this.id] = 1;\r
+ \r
+ // parcours en profondeur\r
+ var f = function(ids, premierNiveau, ensemble, evidence) {\r
+ objectEach(ids, function(id) {\r
+ if (!messagesEnEvidence[id] || premierNiveau) {\r
+ var message = messages.messagesParId[id];\r
+ if (message) {\r
+ messagesEnEvidence[id] = premierNiveau ? evidence : (message.auteurId === thisMessage.auteurId ? 1 : 0);\r
+ f(message[ensemble], false, ensemble, evidence);\r
+ }\r
+ }\r
+ });\r
+ };\r
+ \r
+ // remonte le temps\r
+ f(this.estReponduPar, true, "estReponduPar", 2);\r
+ \r
+ // descent le temps\r
+ f(this.repondA, true, "repondA", 3); \r
+ \r
+ return messagesEnEvidence;\r
+};\r
+\r
+/**\r
+ * Renvoie le message sous la forme de code XHTML (string) prêt à être inséré dans un document.\r
+ * Aucun callback n'est affecté.\r
+ */\r
+euphorik.Message.prototype.XHTML = function(messagePair, pre) {\r
+ if (messagePair === undefined) {\r
+ messagePair = true;\r
+ }\r
+ pre = pre || "";\r
+ \r
+ thisMessage = this;\r
+ \r
+ // construit l'identifiant de la personne\r
+ var identifiant = \r
+ this.client.nickFormat === "nick" || this.login === "" ? this.formater.traitementComplet(this.pseudo) : \r
+ (this.client.nickFormat === "login" ? this.formater.traitementComplet(this.login) : \r
+ this.formater.traitementComplet(this.pseudo) + "<span class=\"login\">(" + this.formater.traitementComplet(this.login) +")</span>" );\r
+\r
+ var XHTMLrepondA = "";\r
+ var debut = true;\r
+ objectEach(this.repondA, function(id, rep) {\r
+ if (!debut) {\r
+ XHTMLrepondA += ", ";\r
+ }\r
+ XHTMLrepondA += thisMessage.formater.traitementComplet(rep.pseudo);\r
+ debut = false;\r
+ });\r
+ if (XHTMLrepondA) {\r
+ XHTMLrepondA = "<span class=\"repondA\">" + XHTMLrepondA + "</span><span class=\"delimitationRepondA\"></span>";\r
+ }\r
+ \r
+ return "<div id=\"" + this.getId(pre) + "\" class=\"" + (messagePair ? "messagePair" : "messageImpair") + " message" +\r
+ (this.appartientAuClient ? " proprietaire" : "") +\r
+ (this.clientARepondu ? " repondu" : "") +\r
+ (this.estUneReponse ? " reponse" : "") +\r
+ (this.systeme ? " systeme" : "") +\r
+ (this.ekMaster ? " ekMaster" + this.degreeOstentatoire : "") +\r
+ "\">" +\r
+ "<span class=\"entete\">" +\r
+ "<span class=\"dateComplete\">[<span class=\"date\">" + this.date + "</span>]</span>" +\r
+ "<span class=\"pseudo\"><span class=\"id\" style=\"display: none\">" + this.auteurId + "</span><span class=\"ident\">" + identifiant + "</span></span>" +\r
+ "</span>" + \r
+ "<span class=\"delimitationEntete\"></span>" +\r
+ XHTMLrepondA +\r
+ "<span class=\"contenu\">" + this.formater.traitementComplet(this.contenu, this.pseudo) + "</span>" +\r
+ "</div>";\r
+};\r