X-Git-Url: http://git.euphorik.ch/index.cgi?a=blobdiff_plain;f=js%2Feuphorik.js;h=1b78ba8294365fa1a2cf0e6dbc9cae9e5cd7fd73;hb=874434add86031d5f23991e78fb2072eac996458;hp=a3b0acf28da31646d5e3d260ecc1abc43c776bd6;hpb=877597872b6660f717aaf54aa1f3001df59b501d;p=euphorik.git
diff --git a/js/euphorik.js b/js/euphorik.js
index a3b0acf..1b78ba8 100755
--- a/js/euphorik.js
+++ b/js/euphorik.js
@@ -134,6 +134,49 @@ Util.prototype.messageDialogue = function(message, type, boutons, formate)
this.timeoutMessageDialogue = setTimeout(fermer, conf.tempsAffichageMessageDialogue)
}
+/**
+ * Affiche un info bulle lorsque le curseur survole l'élément donné.
+ * FIXME : le width de element ne tient pas compte du padding !?
+ */
+Util.prototype.infoBulle = function(message, element)
+{
+ var virerMess = function()
+ {
+ $("#flecheBulle").remove()
+ $("#messageBulle").remove()
+ }
+
+ element.click(virerMess)
+
+ element.hover(
+ function(e)
+ {
+ f = $('
').appendTo("body")
+ m = $('').appendTo("body")
+ var positionFleche = {
+ left : element.offset().left + element.width() / 2 - f.width() / 2,
+ top : element.offset().top - f.height()
+ }
+ var positionMessage = {
+ left : element.offset().left + element.width() / 2 - m.width() / 2,
+ top : element.offset().top - f.height() - m.height()
+ }
+ var depassementDroit = (positionMessage.left + m.width()) - $("body").width()
+ if (depassementDroit > 0)
+ positionMessage.left -= depassementDroit
+ else
+ {
+ if (positionMessage.left < 0)
+ positionMessage.left = 0
+ }
+
+ m.css("top", positionMessage.top).css("left", positionMessage.left).show()
+ f.css("top", positionFleche.top).css("left", positionFleche.left).show()
+ },
+ virerMess
+ )
+}
+
/**
* Utilisé pour l'envoie de donnée avec la méthode ajax de jQuery.
*/
@@ -465,6 +508,9 @@ function Client(util)
this.resetDonneesPersonnelles()
this.setStatut(statutType.deconnected)
+
+ // si true alors chaque modification du client est mémorisé sur le serveur
+ this.autoflush = $.browser["opera"]
}
Client.prototype.resetDonneesPersonnelles = function()
@@ -494,7 +540,9 @@ Client.prototype.setCss = function(css)
this.css = css
$("link#cssPrincipale").attr("href", this.css)
- this.majMenu()
+ this.majMenu()
+
+ if (this.autoflush) this.flush(true)
}
Client.prototype.pageSuivante = function(numConv)
@@ -547,7 +595,10 @@ Client.prototype.ajouterConversation = function(racine)
if (this.conversations[i].root == racine)
return false
- this.conversations.push({root : racine, page : 1})
+ this.conversations.push({root : racine, page : 1})
+
+ if (this.autoflush) this.flush(true)
+
return true
}
@@ -558,7 +609,9 @@ Client.prototype.supprimerConversation = function(num)
// décalage TODO : supprimer le dernier élément
for (var i = num; i < this.conversations.length - 1; i++)
this.conversations[i] = this.conversations[i+1]
- this.conversations.pop()
+ this.conversations.pop()
+
+ if (this.autoflush) this.flush(true)
}
Client.prototype.getJSONLogin = function(login, password)
@@ -904,6 +957,9 @@ function PageEvent(page, util)
// l'objet JSONHttpRequest représentant la connexion d'attente
this.attenteCourante = null
+
+ // le multhreading du pauvre, merci javascript de m'offrire autant de primitives pour la gestion de la concurrence...
+ this.stop = false
}
/**
@@ -911,8 +967,12 @@ function PageEvent(page, util)
*/
PageEvent.prototype.stopAttenteCourante = function()
{
+ this.stop = true
+
if (this.attenteCourante != null)
+ {
this.attenteCourante.abort()
+ }
}
/**
@@ -922,11 +982,13 @@ PageEvent.prototype.stopAttenteCourante = function()
*/
PageEvent.prototype.waitEvent = function(funSend, funReceive)
{
- var thisPageEvent = this
-
this.stopAttenteCourante()
+
+ this.stop = false
+
+ var thisPageEvent = this
- // on doit conserver l'ordre des valeurs de l'objet JSON (le serveur les veux dans l'ordre définit dans le protocole)
+ // on doit conserver l'ordre des valeurs de l'objet JSON (le serveur les veut dans l'ordre définit dans le protocole)
// TODO : ya pas mieux ?
var dataToSend =
{
@@ -938,6 +1000,7 @@ PageEvent.prototype.waitEvent = function(funSend, funReceive)
dataToSend[v] = poulpe[v]
;;; dumpObj(dataToSend)
+
this.attenteCourante = jQuery.ajax({
type: "POST",
url: "request",
@@ -951,15 +1014,24 @@ PageEvent.prototype.waitEvent = function(funSend, funReceive)
funReceive(data)
// rappel de la fonction dans 100 ms
- setTimeout(function(){ thisPageEvent.waitEvent(funSend, funReceive) }, 100);
+ setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funReceive) }, 100)
},
error:
function(XMLHttpRequest, textStatus, errorThrown)
{
- setTimeout(function(){ thisPageEvent.waitEvent(funSend, funReceive) }, 1000);
+ setTimeout(function(){ thisPageEvent.waitEvent2(funSend, funReceive) }, 1000)
}
})
+}
+/**
+ * Si un stopAttenteCourante survient un peu n'importe quand il faut imédiatement arreter de boucler.
+ */
+PageEvent.prototype.waitEvent2 = function(funSend, funReceive)
+{
+ if (this.stop)
+ return
+ this.waitEvent(funSend, funReceive)
}
///////////////////////////////////////////////////////////////////////////////////////////////////