X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=js%2FpageMinichat%2Fmessage.js;h=417f33030946e7d93bd10bab08229f2c6ad11334;hp=3afb8b5196d13fb2c5b8b729777be14bb144ff89;hb=351623b2a00432ae5b690476c68b8fb05cc8dd03;hpb=ed281cb4331777625994d23a6e424fb7c5b5d2c9 diff --git a/js/pageMinichat/message.js b/js/pageMinichat/message.js index 3afb8b5..417f330 100644 --- a/js/pageMinichat/message.js +++ b/js/pageMinichat/message.js @@ -39,6 +39,10 @@ euphorik.Message = function(client, formateur, element) { this.login = element.login; this.contenu = element.content; + // l'ensemble des id des messages qui reponde à ce message, exemple : {45:true, 32:true} (le 'true' ne sert à rien ^_^) + // mis à jour au fur à mesure que des messages sont ajoutés aux conversations + this.estReponduPar = {}; + this.appartientAuClient = element.owner; this.clientARepondu = element.answered; this.estUneReponse = element.is_a_reply; @@ -78,30 +82,26 @@ euphorik.Message.prototype.getConversation = function(messages) { // les messages faisant partie de la conversation var messagesEnEvidence = {}; - messagesEnEvidence[this.id] = 1; - // recherche les réponses (O(n)) - messages.messages.each(function(i, mess) { - if (mess.repondA.hasOwnProperty(thisMessage.id)) { - messagesEnEvidence[mess.id] = 2; - } - }); - - // parcours en largeur - var f = function(tabIds, premierNiveau) { - objectEach(tabIds, function(id) { - // si le message (id) a déjà été traité - if (messagesEnEvidence[id] || premierNiveau) { + // parcours en profondeur + var f = function(ids, premierNiveau, ensemble, evidence) { + objectEach(ids, function(id) { + if (!messagesEnEvidence[id] || premierNiveau) { var message = messages.messagesParId[id]; - if (!message) { - messagesEnEvidence[id] = premierNiveau ? 3 : (message.auteurId === thisMessage.auteurId ? 1 : 0); - f (message.repondA, false); + if (message) { + messagesEnEvidence[id] = premierNiveau ? evidence : (message.auteurId === thisMessage.auteurId ? 1 : 0); + f(message[ensemble], false, ensemble, evidence); } } }); }; - f(this.repondA, true); + + // remonte le temps + f(this.estReponduPar, true, "estReponduPar", 2); + + // descent le temps + f(this.repondA, true, "repondA", 3); return messagesEnEvidence; }; @@ -111,7 +111,9 @@ euphorik.Message.prototype.getConversation = function(messages) { * Aucun callback n'est affecté. */ euphorik.Message.prototype.XHTML = function(messagePair, pre) { - messagePair = messagePair || true; + if (messagePair === undefined) { + messagePair = true; + } pre = pre || ""; thisMessage = this; @@ -142,9 +144,11 @@ euphorik.Message.prototype.XHTML = function(messagePair, pre) { (this.systeme ? " systeme" : "") + (this.ekMaster ? " ekMaster" + this.degreeOstentatoire : "") + "\">" + - "
" + - "[" + this.date + "]" + - "" + this.auteurId + "" + identifiant + "" + + "" + + "[" + this.date + "]" + + "" + this.auteurId + "" + identifiant + "" + + "" + + "" + XHTMLrepondA + "" + this.formateur.traitementComplet(this.contenu, this.pseudo) + "" + "";