/* Script "z'experts" : http://perso.wanadoo.fr/coin.des.experts/
   délivre sans aucune garantie, ni des auteurs, ni du gouvernement. 
   Diffusion libre, mais merci de conserver cette signature :-)  */
   
/* Attention au doctype : si vous en mettez un (c'est quand même mieux) et si voulez que ca fonctionne avec IE6 il faut un HTLM 4 transitional **SANS URL** (cf ci-dessus), c.a.d. IE6 doit rester dans son mode "microsoft". Toujours à cause des bugs de IE6, n'essayez pas de permuter les tests sur document.all et sur document.getElementById */

/* Les bulles doivent avoir été préparées dans autant de calques séparés en position:absolute (sans qu'il soit nécessaire de préciser de top ou left) que l'on rendra invisible (visibility:hidden). Il est important d'avoir fixé la largeur et la hauteur de ces calques-bulles EN PIXELS. */

 /* La fonction bullepop() qui ouvre la bulle d'aide doit être appelée avec 2 arguments:
   - le premier est l'identificateur (ID) du calque à faire apparaître. 
   - LE DEUXIEME EST OBLIGATOIREMENT "event" (sans les guillemets) c.a.d. un mot clé du javascript.
  */

var bulleStyle=null
if (!document.layers && !document.all && !document.getElementById)
   event="chut";			//pour apaiser NN3 et autres antiquités

function bullepop(idd,evt){
    
 var xfenetre,yfenetre,xpage,ypage,element=null;
 var offset= 20;			// décalage par défaut
 var bulleWidth=600;		// largeur par défaut 
 var hauteur=50;			// hauteur par défaut
 bulleStyle=null;

  if (document.layers) {
    bulleStyle=document.layers[idd];
    xpage = evt.pageX ; ypage  = evt.pageY;
    xfenetre = xpage ;yfenetre = ypage ;		
  } else if (document.all) {
    element=document.all[idd]
    xfenetre = evt.x ;yfenetre = evt.y ;
    xpage=xfenetre ; ypage=yfenetre	;	
    if (document.body.scrollLeft) xpage = xfenetre + document.body.scrollLeft ; 
    if (document.body.scrollTop) ypage = yfenetre + document.body.scrollTop;
  } else if (document.getElementById) {
	  element=document.getElementById(idd)
    xfenetre = evt.clientX ; yfenetre = evt.clientY ;
    xpage=xfenetre ; ypage=yfenetre	;	
    if(evt.pageX) xpage = evt.pageX ;
    if(evt.pageY) ypage  = evt.pageY ;
  }
    
  if(element)  bulleStyle=element.style;
		 	
  if(bulleStyle) {
   
     var yp0=ypage;
		 var yf0=yfenetre;
		 
     /* tests incongrus à cause d'Opéra5 */
     if(bulleStyle.width) bulleWidth = parseFloat(bulleStyle.width);
     if(bulleStyle.height) hauteur = parseFloat(bulleStyle.height);

     /* on met la bulle à gauche du pointeur (si c'est possible) et en haut du pointeur si on est assez bas dans l'écran */
				
     if (xfenetre > bulleWidth+offset) xpage=xpage-bulleWidth-offset;
     else {
         if (xfenetre >0.5*bulleWidth+offset) xpage=xpage-0.5*bulleWidth-offset;
				 else xpage=xpage+15;}
     if ( yfenetre > hauteur+offset ) ypage=ypage-hauteur-offset
		 else ypage=ypage+offset;

		/* a cause des débilités d'Opéra5 il faut rectifier 'ypage' pour éviter que la bulle ne s'ouvre par-dessus la souris. La bulle s'ouvrira TOUJOURS en bas avec Opéra5. Dernière vacherie : il faut faire le test sur bulleStyle.width pour se protéger des distraits qui n'auront pas rempli bulleStyle.height */
			 
		 if (!bulleStyle.width)	ypage=yfenetre+offset;
		 if(typeof(bulleStyle.left)=='string') {
				 bulleStyle.left=xpage+'px'; bulleStyle.top=ypage+'px';  
		} else {
				bulleStyle.left=xpage     ; bulleStyle.top=ypage ; }
     bulleStyle.visibility="visible"; 
     bulleStyle.zIndex="99";}
}

function couic(){
  if(bulleStyle)  bulleStyle.visibility="hidden";
}
