//---------------------------------------------------------
//  Nom Document : gf_scroll_div.js
//  Auteur       : G.Ferraz
//  Objet        : menu flottant
//  Creation     : 01.01.2007
//---------------------------------------------------------
//  Mise à Jour  : 01.11.2007
//---------------------------------------------------------
// OUTILS /////////////////////////////
//---------------------------------------------
function Add_Event( obj_, event_, func_, mode_){
  if( obj_.addEventListener)
    obj_.addEventListener( event_, func_, mode_? mode_:false);
  else
    obj_.attachEvent( 'on'+event_, func_);
}
//----------------------
function GetScrollPage(){
  var Left;
  var Top;
  var DocRef;

  if( window.innerWidth){
    with( window){
      Left   = pageXOffset;
      Top    = pageYOffset;
    }
  }
  else{ // Cas Explorer a part
    if( document.documentElement && document.documentElement.clientWidth)
      DocRef = document.documentElement;
    else
      DocRef = document.body;

    with( DocRef){
      Left   = scrollLeft;
      Top    = scrollTop;
    }
  }
//    if (ie) 
//	{
//	    Top = document.body.scrollTop;
//	    Left = document.body.scrollLeft;
//	}
//    else 
//	{
//	    Top = window.pageYOffset;
//	    Left = window.pageXOffset;
//	}

  return({top:Top, left:Left});
}
//---------------------------
function ObjGetPosition(obj_){
  var PosX = 0;
  var PosY = 0;
  //-- suivant type en parametre
  if( typeof(obj_)=='object')
    var Obj  = obj_;
  else
    var Obj  = document.getElementById( obj_);
  //-- Si l'objet existe
  if( Obj){
    //-- Recup. Position Objet
    PosX = Obj.offsetLeft; /// Différent pour IE 6...
    PosY = Obj.offsetTop;
    //-- Si propriete existe
    if( Obj.offsetParent){
      //-- Tant qu'un parent existe
      while( Obj = Obj.offsetParent){
        if( Obj.offsetParent){ // on ne prend pas le BODY
          //-- Ajout position Parent
          if(!ie)
          {
            PosX += Obj.offsetLeft;
          }
          PosY += Obj.offsetTop;
        }
      }
    }
  }
  //-- Retour des positions
  if(!ie || ie8)
  {
    return({left:PosX, top:PosY});
  }
  else if(ie6 || ie7)
  {
    PosX =0;
    return({left:PosX, top:PosY});
  }
}
//-------------------------------------
// MENU FLOTTANT //////////////////////
//-------------------------------------
var IdTimer_1;
var IdTimer_2;
var O_DivScroll;
var Rapport = 1.0/20.0;  // On divise par 20
var Mini = 2* Rapport;
var ie = (navigator.appName == 'Microsoft Internet Explorer')?1:0;
var ie6 = (navigator.appName == 'Microsoft Internet Explorer'&& navigator.appVersion.indexOf('MSIE 6') != -1) ? 1:0;
var ie7 = (navigator.appName == 'Microsoft Internet Explorer'&& navigator.appVersion.indexOf('MSIE 7') != -1) ? 1:0;
var ie8 = (navigator.appName == 'Microsoft Internet Explorer'&& navigator.appVersion.indexOf('MSIE 8') != -1) ? 1:0;
var chrome = (navigator.appName == 'Netscape'&& navigator.appVersion.indexOf('Chrome') != -1) ? 1:0;
//-----------------------
function DIV_Scroll( id_){
  var Obj = document.getElementById( id_);
  this.Obj = Obj;
  if( Obj){
    Obj.style.position = "absolute"; // IMPERATIF
    //-- Recup position de depart
    var Pos   = ObjGetPosition( id_);
    this.PosX = Pos.left;
    this.PosY = Pos.top;
    if(!ie && !chrome)
    {
        this.DebY = this.PosY -30;
        this.DebX = this.PosX;
    }
    else if (ie)
    {
        this.DebY = this.PosY-280;
        this.DebX = this.PosX +10;
    }
    else if(chrome)
    {
        this.DebY = this.PosY-270;
    }
    this.NewX = 0;
    this.NewY = 0;
    this.Move = DIV_Deplace;
    
  }
}
//---------------------------
function DIV_Deplace( x_, y_){
var Scroll  = GetScrollPage();
//if(this.PosY> this.DebY-3)

      if( arguments[0] != null){
        this.PosX = x_;
       if(ie)
            this.Obj.style.left = parseInt(x_) +"px";
        
      }
      if( arguments[1] != null){
        this.PosY = y_;

            if(y_ > this.DebY-3){
                this.Obj.style.top = parseInt(y_) +"px";  
            }     
      }
  
}
//---------------------------
function DIV_Replace( x_, y_){
  //-- Calcul Delta deplacement
  var Delta_X = (x_ -O_DivScroll.PosX) *Rapport;
  var Delta_Y = (y_ -O_DivScroll.PosY) *Rapport;
  //-- Test si fin deplacement
  if((( Delta_Y < Mini)&&( Delta_Y > -Mini))&&
     (( Delta_X < Mini)&&( Delta_X > -Mini))){
    clearInterval( IdTimer_1);
    O_DivScroll.Move( x_, y_);
  }
  else{
    O_DivScroll.Move( O_DivScroll.PosX +Delta_X, O_DivScroll.PosY +Delta_Y);
  }
}
//------------------------
function DIV_CheckScroll(){
  var Scroll  = GetScrollPage();
  //-- New position  du menu
  // Ici on veut qu notre menu soit toujours en haut, on ne rajoute donc pas la position initiale
//  O_DivScroll.NewX = Scroll.left + O_DivScroll.DebX;
//  O_DivScroll.NewY = Scroll.top  + O_DivScroll.DebY;
  O_DivScroll.NewX = Scroll.left ;
  if(!ie && !chrome)
    O_DivScroll.NewY = Scroll.top  ;
  else if(ie)
    O_DivScroll.NewY = Scroll.top - 180 ;
  else if(chrome)
    O_DivScroll.NewY = Scroll.top - 230 ;
  
  //-- Si pas la bonne Position
  if(( O_DivScroll.PosY != O_DivScroll.NewY)||( O_DivScroll.PosX != O_DivScroll.NewX)){
    //-- Clear l'encours
    clearInterval( IdTimer_1);
    IdTimer_1 = setInterval("DIV_Replace(" + O_DivScroll.NewX +"," + O_DivScroll.NewY +")", 10);
  }
  return( true);
}
//-----------------------
function DIV_InitScroll(){
  //-- Recup position Objet
  O_DivScroll  = new DIV_Scroll('DIV_MOVE');
  //-- Lance inspection si existe
  if( O_DivScroll.Obj)
    IdTimer_2 = setInterval('DIV_CheckScroll()',100);
         
     if((ie || chrome) && document.getElementById('DIV_MOVE'))
     {
        document.getElementById('DIV_MOVE').style.display='none';
        setTimeout("affichetoi(document.getElementById('DIV_MOVE'))",1000);
     }
     //alert(navigator.appName+' '+navigator.appVersion);
}
function affichetoi(obj_)
{
    obj_.style.display='block';
}
//========================================
Add_Event( window, 'load', DIV_InitScroll);
//-- EOF --

