X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2Feuphorik.js;h=901915a7889d0cde63b5964d48ecea8633713f82;hb=39d4d474dc011f29b3060729f7ff09f446093070;hp=3a9b0d767a57635c7a6ec52fcd4b3a25461f2d2b;hpb=1676c1bd20cb3e8e1b0f98d18df88c4520dcae6d;p=euphorik.git diff --git a/js/euphorik.js b/js/euphorik.js index 3a9b0d7..901915a 100755 --- a/js/euphorik.js +++ b/js/euphorik.js @@ -1,4 +1,4 @@ -// coding: utf-8 +// coding: utf-8 // Copyright 2008 Grégory Burri // // This file is part of Euphorik. @@ -158,12 +158,17 @@ Util.prototype.infoBulle = function(message, element) { 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() @@ -252,19 +257,16 @@ Util.prototype.replaceSelection = function(input, replaceString) { this.setCaretToPos(input, selectionStart + replaceString.length) } else if (document.selection) - { - var range = document.selection.createRange(); + { + input.focus() + var range = document.selection.createRange() if (range.parentElement() == input) { var isCollapsed = range.text == '' range.text = replaceString if (!isCollapsed) - { - // there has been a selection - // it appears range.select() should select the newly - // inserted text but that fails with IE + { range.moveStart('character', -replaceString.length); - range.select(); } } } @@ -568,9 +570,7 @@ Client.prototype.setCss = function(css) return this.css = css - $("link#cssPrincipale").attr("href", this.css) - this.majMenu() - + $("link#cssPrincipale").attr("href", this.css) if (this.autoflush) this.flush(true) } @@ -718,14 +718,16 @@ Client.prototype.delCookie = function() document.cookie = "cookie=; max-age=0" } -Client.prototype.setCookie = function(cookie) +Client.prototype.setCookie = function() { - if (this.cookie == null) + if (this.cookie == null || this.cookie == undefined) return - document.cookie = - "cookie="+this.cookie+ - "; max-age=" + (60 * 60 * 24 * 365) + // ne fonctionne pas sous IE.... + /*document.cookie = "cookie=" + this.cookie + "; max-age=" + (60 * 60 * 24 * 365) */ + + document.cookie = + "cookie="+this.cookie+"; expires=" + new Date(new Date().getTime() + 1000 * 60 * 60 * 24 * 365).toUTCString() } Client.prototype.authentifie = function() @@ -849,6 +851,7 @@ Client.prototype.chargerDonnees = function(data) this.conversations = data["conversations"] this.majBulle() + this.majCssSelectionee() } } @@ -898,8 +901,6 @@ Client.prototype.flush = function(async) 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") @@ -933,6 +934,20 @@ Client.prototype.majBulle = function() 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 @@ -995,6 +1010,16 @@ Client.prototype.kick = function(userId, raison) /** * classe permettant de gérer les événements (push serveur). + * l'information envoyé est sous la forme : + * { + * "action" : "wait_event" + * "page" : + * [..] + * } + * l'information reçu est sous la forme : + * { + * "reply" : + * } * @page la page */ function PageEvent(page, util) @@ -1025,9 +1050,11 @@ PageEvent.prototype.stopAttenteCourante = function() /** * 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() @@ -1051,22 +1078,25 @@ PageEvent.prototype.waitEvent = function(funSend, funReceive) this.attenteCourante = jQuery.ajax({ type: "POST", url: "request", - dataType: "json", + dataType: "json", + // Obsolète (voir TODO) + //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) } }) } @@ -1074,11 +1104,11 @@ PageEvent.prototype.waitEvent = function(funSend, funReceive) /** * 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) } ///////////////////////////////////////////////////////////////////////////////////////////////////