{
if (!thisUtil.bulleActive)
return
-
+
var m = $("#messageBulle")
var f = $("#flecheBulle")
+ // remplie le paragraphe de la bulle avec le message
$("p", m).html(message)
-
+
+ // réinitialise la position, évite le cas ou la boite est collé à droite et remplie avec un texte la faisant dépassé
+ // dans ce cas la hauteur n'est pas calculé correctement
+ m.css("top", 0).css("left", 0)
+
var positionFleche = {
left : element.offset().left + element.width() / 2 - f.width() / 2,
top : element.offset().top - f.height()
return
this.css = css
- $("link#cssPrincipale").attr("href", this.css)
- this.majMenu()\r
- \r
+ $("link#cssPrincipale").attr("href", this.css)\r
if (this.autoflush) this.flush(true)
}
this.conversations = data["conversations"]
this.majBulle()
+ this.majCssSelectionee()
}
}
Client.prototype.majMenu = function()
{
- // TODO : à virer : ne plus changer de style de display ... spa beau .. ou trouver une autre méthode
- // var displayType = this.css == "css/3/euphorik.css" ? "block" : "inline" //this.client
displayType = "block"
$("#menu .admin").css("display", this.ekMaster ? displayType : "none")
this.util.bulleActive = this.viewTooltips
}
+/**
+ * Met à jour la css sélectionnée, lors du chargement des données.
+ */
+Client.prototype.majCssSelectionee = function()
+{
+ // extraction du numéro de la css courante
+ var numCssCourante = this.css.match(/^.*?\/(\d)\/.*$/)
+ if (numCssCourante[1] != undefined)
+ {
+ $("#menuCss option").removeAttr("selected")
+ $("#menuCss option[value=" + numCssCourante[1]+ "]").attr("selected", "selected")
+ }
+}
+
Client.prototype.slap = function(userId, raison)
{
var thisClient = this
/**
* classe permettant de gérer les événements (push serveur).
+ * l'information envoyé est sous la forme :
+ * {
+ * "action" : "wait_event"
+ * "page" : <page>
+ * [..]
+ * }
+ * l'information reçu est sous la forme :
+ * {
+ * "reply" : <reply>
+ * }
* @page la page
*/
function PageEvent(page, util)
/**
* Attend un événement lié à la page.
* @funSend une fonction renvoyant les données json à envoyer
- * @funReceive une fonction qui accepte un paramètre correspondant au données reçues
+ * @funsReceive est un objet comprenant les fonctions à appeler en fonction du "reply"
+ * les fonctions acceptent un paramètre correspondant au données reçues.
+ * exemple : {"new_message" : function(data){ ... }}
*/
-PageEvent.prototype.waitEvent = function(funSend, funReceive)
+PageEvent.prototype.waitEvent = function(funSend, funsReceive)
{
this.stopAttenteCourante()
this.attenteCourante = jQuery.ajax({
type: "POST",
url: "request",
- dataType: "json",
+ dataType: "json",\r
+ // Obsolète (voir TODO)\r
+ //timeout: 300000, // timeout de 5min. Gros HACK pas beau. FIXME problème décrit ici : http://groups.google.com/group/jquery-en/browse_thread/thread/8724e64af3333a76
data: this.util.jsonVersAction(dataToSend),
success:
function(data)
{
;; dumpObj(data)
- funReceive(data)
+ funsReceive[data["reply"]](data)
// rappel de la fonction dans 100 ms
- setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funReceive) }, 100)
+ setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funsReceive) }, 100)
},
error:
function(XMLHttpRequest, textStatus, errorThrown)
{
- setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funReceive) }, 1000)
+ ;; console.log("Connexion perdue dans waitEvent")
+ setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funsReceive) }, 1000)
}
})
}
/**
* Si un stopAttenteCourante survient un peu n'importe quand il faut imédiatement arreter de boucler.
*/
-PageEvent.prototype.waitEvent2 = function(funSend, funReceive)
+PageEvent.prototype.waitEvent2 = function(funSend, funsReceive)
{
if (this.stop)
return
- this.waitEvent(funSend, funReceive)
+ this.waitEvent(funSend, funsReceive)
}
///////////////////////////////////////////////////////////////////////////////////////////////////