-}
-
-/**
- *
- */
-Conversation.prototype.enleverMiseEnEvidence = function()
-{
- $("#conversations .message").removeClass("cache")
-}
-
-Conversation.prototype.colorerEntetes = function()
-{
- var messagesReponse = ""
- var messagesRepondu = ""
- var messagesProprietaire = ""
- for (var i = 0; i < this.messages.length; i++)
- {
- if (this.messages[i].appartientAuClient)
- messagesProprietaire += "#mess" + this.messages[i].id.toString(36) + ","
- else if (this.messages[i].estUneReponse)
- messagesReponse += "#mess" + this.messages[i].id.toString(36) + ","
- else if (this.messages[i].clientARepondu)
- messagesRepondu += "#mess" + this.messages[i].id.toString(36) + ","
- }
- $(messagesReponse).addClass("reponse")
- $(messagesRepondu).addClass("repondu")
- $(messagesProprietaire).addClass("proprietaire")
-}
-
-Conversation.prototype.decolorerEntetes = function()
-{
- $("#" + this.getId() + " .message")
- .removeClass("reponse")
- .removeClass("repondu")
- .removeClass("proprietaire")
-}
-
-/**
- * Défini la page courante et s'il l'on se trouve sur la dernière page.
- * @pageCourante la page courante
- * @dernierePage true si c'est la dernière page sinon false
- */
-Conversation.prototype.setPage = function(pageCourante, dernierePage)
-{
- $("#conversations #" + this.getId() + " .numPage").text(pageCourante)
- $("#conversations #" + this.getId() + " .next").css("display", pageCourante == 1 ? "none" : "inline")
- $("#conversations #" + this.getId() + " .prev").css("display", dernierePage ? "none" : "inline")
-}
-
-/**
- * Evenement déclanché lors de l'insertion du lien de la conversation dans le message courant.
- */
-Conversation.prototype.eventLien = function(fun)
-{
- var thisConversation = this
-
- $("#conversations #" + this.getId() + " .titre .lien").click(
- function()
- {
- fun(thisConversation.num)
- }
- )
-}
-
-/**
- * Evenement déclanché lors de la fermeture de la conversation.
- */
-Conversation.prototype.eventFermer = function(fun)
-{
- var thisConversation = this
-
- $("#conversations #" + this.getId() + " .titre .fermer").click(
- function()
- {
- fun(thisConversation.num)
- }
- )
-}
-
-/**
- * @funNext appelé lorsque l'on passe à la page suivante (de 2 à 1 par exemple)
- * @funPrev appelé lorsque l'on passe à la page précédente (de 1 à 2 par exemple)
- * @funReset appelé lorsque l'on souhaite revenir à la page une
- */
-Conversation.prototype.setFunPage = function(funNext, funPrev, funReset)
-{
- var thisConversation = this
-
- $("#conversations #" + this.getId() + " .next").click(
- function() { funNext(thisConversation.num) }
- )
- $("#conversations #" + this.getId() + " .prev").click(
- function() { funPrev(thisConversation.num) }
- )
- $("#conversations #" + this.getId() + " .numPage").click(
- function() { funReset(thisConversation.num) }
- )
-}
-
-/**
- * Retourne l'id de la conversation sous la forme (par exemple) "conv3".
- */
-Conversation.prototype.getId = function()
-{
- return "conv" + this.id
-}
-
-Conversation.prototype.ajouterMessage = function(message)
-{
- this.messages.push(message)
- this.messagesParId[message.id] = message
- if (this.messages.length > this.nbMessageMax)
- delete this.messagesParId[this.messages.shift().id]
-}
-
-/**
- * FIXME : méthode très lourde. ne serait-ce pas mieux de virer d'un coup l'élément conversation et d'en remettre un vide ?
- */
-Conversation.prototype.viderMessages = function()
-{
- this.messages = new Array()
- this.idDernierMessageAffiche = 0
- $("#conversations #" + this.getId() + " .message").remove()
-}
-
-/**
- * Après l'ajout d'un ou plusieurs message cette méthode est appelée afin
- * d'afficher les messages non-affichés.
- * FIXME : méthode super lourde, à optimiser.
- * @param funClickExtract fonction (fun(numMess)) appellée lors du clic sur un bouton "extraire"
- */
-Conversation.prototype.flush = function(funClickOuvrirConv)
-{
- var thisConversation = this
-
- // est-ce que le prochain message est pair ? (permet d'alterner le style des messages)
- var messagePair = (this.idDernierMessageAffiche == 0 ? true :
- ($("#conversations #" + this.getId() + " div:first").attr("class").search("messagePair") == -1)
- )
-
- // construction de l'XHTML des messages
- var XHTML = ""
- for (var i = 0; i < this.messages.length; i++)
- if (this.messages[i].id > this.idDernierMessageAffiche)
- {
- var message = this.messages[i]
-
- // construit l'identifiant de la personne
- var identifiant =
- this.client.nickFormat == "nick" || message.login == "" ? this.formateur.traitementComplet(message.pseudo) :
- (this.client.nickFormat == "login" ? this.formateur.traitementComplet(message.login) :
- this.formateur.traitementComplet(message.pseudo) + "<span class=\"login\">(" + this.formateur.traitementComplet(message.login) +")</span>" )
-
- var XHTMLrepondA = ""
- var debut = true
- for (var id in message.repondA)
- {
- if (!debut) XHTMLrepondA += ", "
- ;; dumpObj(message.repondA.count)
- XHTMLrepondA += this.formateur.traitementComplet(message.repondA[id].pseudo)
- debut = false
- }
- if (XHTMLrepondA != "")
- XHTMLrepondA = "<span class=\"repondA\">" + XHTMLrepondA + "</span><span class=\"delimitationRepondA\"></span>"
-
- XHTML +=
- "<div id=\"mess" + message.id.toString(36) + "\" class=\"" + (messagePair ? "messagePair" : "messageImpair") + " message" +
- (this.messages[i].appartientAuClient ? " proprietaire" : "") +
- (this.messages[i].clientARepondu ? " repondu" : "") +
- (this.messages[i].estUneReponse ? " reponse" : "") +
- (this.messages[i].systeme ? " systeme" : "") +
- (this.messages[i].ekMaster ? " ekMaster" : "") +
- "\">" +
- "<div class=\"extraire\"></div><span class=\"entete\">" +
- "<span class=\"dateComplete\">[<span class=\"date\">" + message.date + "</span>]</span>" +
- "<span class=\"pseudo\"><span class=\"id\" style=\"display: none\">" + message.auteurId + "</span class=\"ident\">" + identifiant + "</span></span><span class=\"delimitationEntete\"></span>" +
- XHTMLrepondA +
- "<span class=\"contenu\">" + this.formateur.traitementComplet(message.contenu, message.pseudo) + "</span>" +
- "</div>"
-
- messagePair = !messagePair
- }