- this.timeoutMessageDialogue = setTimeout(fermer, euphorik.conf.tempsAffichageMessageDialogue);
-};
-
-euphorik.Util.positionTypeX = {gauche: 0, gaucheRecouvrement: 1, centre: 2, droiteRecouvrement: 3, droite: 4};
-euphorik.Util.positionTypeY = {haut: 0, hautRecouvrement: 1, centre: 2, basRecouvrement: 3, bas: 4};
+ if (time !== -1) {\r
+ this.timeoutMessageDialog = setTimeout(close, time || euphorik.conf.tooltipDisplayDefaultTime);
+ }\r
+};\r
+\r
+euphorik.Util.positionTypeX = {gauche: 0, gaucheRecouvrement: 1, centre: 2, droiteRecouvrement: 3, droite: 4};\r
+euphorik.Util.positionTypeY = {haut: 0, hautRecouvrement: 1, centre: 2, basRecouvrement: 3, bas: 4};\r
+\r
+/**\r
+ * Afficher une boite flottante (élément) par rapport à une cible.\r
+ * La boite est affichée de manière à ne pas dépasser de la fenêtre.\r
+ * @boite l'élément à afficher\r
+ * @cible l'élément sur lequel est affiché la boite\r
+ * @positionX de type positionTypeX\r
+ * @positionY de type positionTypeY\r
+ */\r
+euphorik.Util.prototype.afficherBoite = function(boite, cible, positionX, positionY) {\r
+ var positionCible = cible.offset();\r
+ var positionBoite = {\r
+ left : positionX === euphorik.Util.positionTypeX.gauche ? positionCible.left - boite.width() :\r
+ (positionX === euphorik.Util.positionTypeX.gaucheRecouvrement ? positionCible.left - boite.width() + cible.width() : \r
+ (positionX === euphorik.Util.positionTypeX.droitelsRecouvrement ? positionCible.left :\r
+ (positionX === euphorik.Util.positionTypeX.droite ? positionCible.left + cible.width() :\r
+ positionCible.left + cible.width() / 2 - boite.width() / 2 ))), // centre\r
+ top : positionY === euphorik.Util.positionTypeY.haut ? positionCible.top - boite.height() :\r
+ (positionY === euphorik.Util.positionTypeY.hautRecouvrement ? positionCible.top - boite.height() + cible.height() : \r
+ (positionY === euphorik.Util.positionTypeY.basRecouvrement ? positionCible.top :\r
+ (positionY === euphorik.Util.positionTypeY.bas ? positionCible.top + cible.height() :\r
+ positionCible.top + cible.height() / 2 - boite.height() / 2 ))) // centre\r
+ };\r
+ \r
+ // calcul les décalages en x et en y pour éviter que la boite ne sorte de la fenêtre, tient compte de la position des barres de défilement\r
+ var marge = 10; \r
+ positionBoite.left = positionBoite.left < marge + window.pageXOffset ? marge + window.pageXOffset :\r
+ (boite.width() - $(window).width() + (positionBoite.left - window.pageXOffset) + marge > 0 ? $(window).width() - boite.width() - marge + window.pageXOffset : positionBoite.left);\r
+ positionBoite.top = positionBoite.top < marge + window.pageYOffset ? marge + window.pageYOffset :\r
+ (boite.height() - $(window).height() + (positionBoite.top - window.pageYOffset) + marge > 0 ? $(window).height() - boite.height() - marge + window.pageYOffset : positionBoite.top);\r
+ \r
+ boite.css("top", positionBoite.top).css("left", positionBoite.left).show();\r
+};\r
+\r
+euphorik.Util.positionBulleType = {haut : 0, droite : 1, bas : 2, gauche : 3};\r