/*

  JJMenu by D.J.Jansen @ JDI-ICT
  2007-10-26

*/

function JJMenu (){
  this.Childs = [];
  this.MenuItems = [];
  this.MenuLists = [];
 
  this.Closing = [];
  this.Opening = [];

  this.AnimationOpenTime = 500;
  this.AnimationCloseTime = 250;

  this.minCPUResolution = 15;
 
  this.StandaardOpenTime = 500;

  this.MenuItemUpPostFix = 'Up';
  this.zIndex = 1;
}

function JJMenuItem( menu, element, idToOpen , idToKeepOpen ){
  this.Menu       = menu;
  this.Parent     = null;
  this.Index      = null;
  this.Element    = element;

  this.NormalClass = element.className;

  this.MouseOn     = false;

  this.ParentY    = element.offsetTop;
  this.ParentX    = element.offsetLeft;

  this.ToOpenID   = idToOpen;
  this.ToOpen     = null;
  if ( this.ToOpenID ){
    var List = new JJMenuList( menu, idToOpen, this );
    this.ToOpen     = List;

    if ( this.ToOpen ){

      List.FindElement();

      if ( List.Element ){
        List.Element.onmouseout = function (){
          List.MouseOut();
        }

        List.Element.onmouseover = function (){
          List.MouseOver();
        }
      }
    }

  }
  this.KeepOpenID = idToKeepOpen;
  if ( this.KeepOpenID ){
    this.KeepOpen   = this.Menu.SearchMenuList( this.KeepOpenID );
    this.Parent = this.KeepOpen;
  }

  this.Open = false;
 
  this.Menu.AddMenuItem( this );
}

JJMenuList.prototype.FindElement = function( ){
  if ( this.Element == null ){
    this.Element = document.getElementById( this.IDReference );

    if ( this.Element != null ){
      this.Element.style.display = 'block';
      this.DropDownY = this.Element.offsetHeight;
      this.Element.style.display = 'none';
      this.DropDownX = this.Element.offsetWidth;
//      this.Element.style.left = this.Opener.ParentX + 'px';
//      this.Element.style.top  = ( this.Opener.ParentY - this.DropDownY ) + 'px';
    }
  }
}

JJMenuItem.prototype.UpdateClassName = function( ChildOpen ){
  Class = "";

  if ( ChildOpen ){ 
    Class = this.NormalClass;
    ML = this.Menu.MenuItemUpPostFix.length;
    CL = Class.length;
    if ( Class.substring( CL - ML, CL ) != this.Menu.MenuItemUpPostFix ){ 
      Class += '' + this.Menu.MenuItemUpPostFix;
    }
  } else {
    Class = this.NormalClass;
  }

  if ( this.Element.className != Class ){ 
    this.Element.className = Class;
  }
}

JJMenu.prototype.SearchMenuList = function ( idToSearch ){
  for( idx in this.MenuLists ){  
    MenuList = this.MenuLists[ idx ];
    if ( MenuList.IDReference == idToSearch ){ 
      return MenuList;
    }
  }
  return null;
}

function JJMenuList( menu, idref, opener ){
  this.IDReference = idref;
  this.Opener      = opener;
  this.Menu        = menu;

  this.Childs      = [];
  this.DropDownX   = 0;
  this.DropDownY   = 0;
  this.Open        = false;
  this.Direction   = "open";

  this.MouseOn     = false;

  this.accelOpenConst  = 0.0004;

  this.FindElement();
 
  this.StartTime            = null;
  this.ActionIntervalRunner = null;
  this.AutoCloseTimer       = null;
 
  this.Menu.AddMenuList( this );
}

JJMenu.prototype.RegisterToMenu = function( element, idToOpen, idToKeepOpen ){
  var menuitem = new JJMenuItem( this, element, idToOpen, idToKeepOpen );

  if ( menuitem.ToOpen || menuitem.KeepOpen || true ){ 

    this.AddToMenuOrder( menuitem );

    if ( element.className.substring( 0, 4 ) == 'Menu' ) {
      element.onclick = function (){
        menuitem.MouseMove();
      }
      element.onclick();

      element.onmouseout = function(){
        menuitem.MouseOut();
      }

    } else { 
      element.onmouseover = function (){
        menuitem.MouseMove();
      }
      element.onmouseover();

      element.onmouseout = function(){
        menuitem.MouseOut();
      }
    }

    return true;
  } else {
    element.onmouseover = function(){ };
    return false;
  }
}

JJMenu.prototype.GetNewZIndex = function (){
  this.zIndex++;
  return this.zIndex;
}

JJMenu.prototype.AddMenuItem = function ( MenuItem ){
  var index = ( this.MenuItems.push( MenuItem ) ) - 1;
  MenuItem.Index = index;
}

JJMenu.prototype.AddMenuList = function ( MenuList ){
  var index = ( this.MenuLists.push( MenuList ) ) - 1;
  this.Closing[ index ] = false;
  this.Opening[ index ] = false;
  MenuList.Index = index;
}

JJMenu.prototype.AddToMenuOrder = function ( MenuItem ){

  ChildIndex = null;

  if ( MenuItem.KeepOpen ){ 
    for( var i in this.Childs ){ 
      if ( ChildIndex == null && this.Childs[ i ].ToOpen ){
        ChildIndex = this.Childs[ i ].ToOpen.AddToMenuOrder( MenuItem );
      }
    }
  } else { 
    ChildIndex = ( this.Childs.push( MenuItem ) ) - 1;
  }

  if ( ChildIndex ){
    this.MenuItems[ MenuItem.Index ].ChildIndex = ChildIndex;
  }

}

JJMenuList.prototype.AddToMenuOrder = function( MenuItem ){
  ChildIndex = null;
  if ( this.ToOpen == MenuItem.KeepOpen ){ 
    MenuItem.Parent = this;
    return this.Childs.push( MenuItem );
  }
  for( var i in this.Childs ){
    ChildIndex = this.Childs[ i ].AddToMenuOrder( MenuItem );
    if ( ChildIndex ){ 
      return ChildIndex;
    }
  }
  return null;
}


JJMenuList.prototype.MouseOut = function(){
  this.MouseOn     = false;
  this.CheckPossibleClose();
}

JJMenuList.prototype.MouseOver = function(){
  this.MouseOn     = true;
  this.CheckPossibleClose();
}

JJMenuItem.prototype.MouseOut = function( ){
  this.MouseOn     = false;
  if ( this.ToOpen ){
    this.ToOpen.CheckPossibleClose();
  }
}

JJMenuItem.prototype.MouseMove = function ( ){ 

  this.MouseOn     = true;

  if ( this.ToOpen != null ){
    this.ToOpen.StartOpenMenu();
  }

  if ( this.KeepOpen != null && this.Menu.Closing[ this.KeepOpen.Index ] == false ){
    this.KeepOpen.StartOpenMenu();
  }
}

JJMenu.prototype.CloseOtherThanMe = function( index ){
  for( var idx in this.Childs ){ 
    MenuItem = this.Childs[ idx ];
    cIndex = MenuItem.Index;
    if ( cIndex != index ){
      if ( MenuItem.ToOpen ){
        lIndex = MenuItem.ToOpen.Index;
        if ( this.Closing[ lIndex ] == false && ( MenuItem.ToOpen.Open || this.Opening[ lIndex ] == true ) ){ 
          MenuItem.ToOpen.StartCloseMenuList();
        } 
      }
    }
  }
}

JJMenuItem.prototype.CloseOtherThanMe = function( Index ){
  if ( this.Parent ) { 
    for( var idx in this.Childs ){ 
      MenuList = this.Childs[ idx ];
      if ( MenuList.Index != Index ){ 
        MenuList.StartCloseMenuList();
      }
    }
  } else {
     this.Menu.CloseOtherThanMe( this.Index );
  }
}

JJMenuList.prototype.StartOpenMenu = function () {

  this.FindElement();

  this.Opener.CloseOtherThanMe( this.Index );

  this.Element.style.zIndex = this.Menu.GetNewZIndex();

  if ( this.Menu.Opening[ this.Index ] == true ){
    return;
  }

  if ( this.Open == false || this.Menu.Closing[ this.Index ] == true ){ 

    this.StartTime = (new Date()).getTime();

    this.Opener.UpdateClassName( true );

//    this.Element.style.top  = ( this.Opener.ParentY - this.DropDownY ) + 'px';

    this.Element.style.display = 'block';

    this.Menu.Closing[ this.Index ] = false;
    this.Menu.Opening[ this.Index ] = true;
    this.Direction = "open";

    this.EndOpenMenuList();
  } else { 
    if ( this.Open == true ){
      this.ResetCloseTimer();
    }
  }
}

JJMenu_SlideMenuList = function ( index ){
  if ( Menu.MenuLists[ index ] ){ 
    Menu.MenuLists[ index ].SlideMenuList();
  }
}

JJMenu_AutoCloseMenu = function ( index ){
  if ( Menu.MenuItems[ index ] ){
    Menu.MenuLists[ index ].StartCloseMenuList();
  }
}

JJMenuList.prototype.EndOpenMenuList = function(){
  this.Open = true;
 //  this.Element.style.top  = this.Opener.ParentY + 'px';

  this.Menu.Opening[ this.Index ] = false;
  this.ResetCloseTimer( false );
}

JJMenuList.prototype.CheckPossibleClose = function(){

  this.FindElement();

  if ( this.MouseOn == true ) {
    this.ClearCloseTimer();
    return false;
  }

  if ( this.Opener != null && this.Opener.MouseOn == true ){
    this.ClearCloseTimer();
    return false;
  }

  this.ResetCloseTimer();

  return true;
}

JJMenuList.prototype.ClearCloseTimer = function ( ToKidsTo ){
  if ( this.AutoCloseTimer ){
    clearInterval( this.AutoCloseTimer );
  }
}

JJMenuList.prototype.ResetCloseTimer = function ( ToKidsTo ){
  clearInterval( this.AutoCloseTimer );
  this.AutoCloseTimer = setTimeout( "JJMenu_AutoCloseMenu( " + this.Index + " )", this.Menu.StandaardOpenTime );
  if ( ToKidsTo ){ 
    HasKids = false;
    for( var idx in Childs ){ 
      MenuItem = Childs[ idx ];
      if ( MenuItem.ToOpen ){  
        if ( MenuItem.ToOpen.Open ){
          MenuItem.ToOpen.ResetCloseTimer( ToKidsTo );
          ToKidsTo = true;
        }
      }
    }
    ToKidsTo = HasKids;
  }
  if ( ! ToKidsTo ){
    if ( this.Opener.Parent ){ 
      this.Opener.Parent.ResetCloseTimer( false );
    }
  }
}

JJMenuList.prototype.StartCloseMenuList = function () {

  if ( ! this.CheckPossibleClose() ){
    return;
  }

  for( var idx in this.Childs ){
    MenuItem = this.Childs[ idx ].ToOpen;
    if ( MenuItem.ToOpen ){
      MenuItem.ToOpen.StartCloseMenuList();
    }
  }

  clearTimeout( this.AutoCloseTimer );
  if ( this.Open || this.Menu.Opening[ this.Index ] == true ) {
    this.StartTime = (new Date()).getTime();

    this.Direction  = "close";
    this.Menu.Closing[ this.Index ] = true;
    this.Menu.Opening[ this.Index ] = false;
    this.EndCloseMenuList();
  }
}

JJMenuList.prototype.EndCloseMenuList = function(){
  clearInterval( this.ActionIntervalRunner );
  this.Open = false;
  this.Opener.UpdateClassName( false );
  this.Element.style.display = 'none';
  this.Menu.Closing[ this.Index ] = false;
}

Menu = new JJMenu();

var IC_Photo_DarkLayer = null;
var IC_Photo_Popup_referer = null;

var IC_Photo_Settings = {
  MarginToBorders: 10,
  Title: 'Klik hier om te sluiten',
  CloseTitle: 'x',
  UseAltTag: true,
  UseCloseTag: true,
  UseDarkLayer: true,
  Padding: 15
};

function IC_Photo_Popup( Link, URL, Width, Height, Alt ){
  var Body = document.getElementsByTagName( 'body' ).item( 0 );
  var Html = document.getElementsByTagName( 'html' ).item( 0 );

  if ( ! IC_Photo_DarkLayer && IC_Photo_Settings.UseDarkLayer ){
    IC_Photo_DarkLayer = document.createElement( 'div' );
    IC_Photo_DarkLayer.id = 'IC_Photo_DarkLayer';
    Body.appendChild( IC_Photo_DarkLayer );
  }

  if ( IC_Photo_Popup_referer == null ){
    IC_Photo_Popup_referer = document.createElement( 'a' );
    IC_Photo_Popup_referer.id = 'IC_Photo_Popup_Holder';
    IC_Photo_Popup_referer.onclick = IC_Photo_Popup_Close;
    IC_Photo_Popup_referer.href = '#';
    IC_Photo_Popup_referer.title = IC_Photo_Settings.Title;

    if ( IC_Photo_Settings.UseAltTag ){
      var AltTag = document.createElement( 'span' );
      AltTag.className = 'AltLabel';
      AltTag.appendChild( document.createTextNode( Alt ) );
      IC_Photo_Popup_referer.appendChild( AltTag );
      IC_Photo_Popup_referer.Label = AltTag;
    }

    if ( IC_Photo_Settings.UseCloseTag ){
      var ATag = document.createElement( 'a' );
      ATag.className = 'CloseButton';
      ATag.href = '#';
      ATag.appendChild( document.createTextNode( IC_Photo_Settings.CloseTitle ) );
      IC_Photo_Popup_referer.appendChild( ATag );
    }
    Body.appendChild( IC_Photo_Popup_referer );
  }
  if ( IC_Photo_Popup_referer != null ) {
    IC_Photo_Popup_referer.style.display = 'block';

    IC_Photo_Popup_referer.style.height = ( Height + IC_Photo_Settings.Padding * 2 ) + 'px';
    IC_Photo_Popup_referer.style.width = ( Width + 30 ) + 'px';

    LabelHeight = 0;

    if ( IC_Photo_Settings.UseAltTag ){
      IC_Photo_Popup_referer.Label.innerHTML = Alt;

      if ( Alt != '' ){
        LabelHeight = IC_Photo_Popup_referer.Label.offsetHeight;

        IC_Photo_Popup_referer.style.height = ( Height + LabelHeight + IC_Photo_Settings.Padding * 2 ) + 'px';
      }
    }

    IC_Photo_Popup_referer.style.backgroundPosition = 'center ' + ( IC_Photo_Settings.Padding + LabelHeight ) + 'px';

    IC_Photo_Popup_referer.style.backgroundImage = 'url(' + URL + ')';

    IC_Image = null;
    for( i=0; i<Link.childNodes.length; i++ ){
      if ( Link.childNodes[ i ].tagName.toUpperCase() == 'IMG' ){
        IC_Image = Link.childNodes[ i ];
      }
    }
    if ( IC_Image ){
      Position = getPositionFrom( IC_Image );

      Left = ( Position.left + IC_Image.offsetWidth / 2 ) - IC_Photo_Popup_referer.offsetWidth / 2;

      Left = Math.min( Left, Body.offsetWidth - IC_Photo_Popup_referer.offsetWidth - IC_Photo_Settings.MarginToBorders );
      Left = Math.max( Left, IC_Photo_Settings.MarginToBorders );

      Top = ( Position.top + IC_Image.offsetHeight / 2 ) - IC_Photo_Popup_referer.offsetHeight / 2;
      WindowMax = Math.max( Body.offsetHeight, Html.offsetHeight );
      Top = Math.min( Top, WindowMax - IC_Photo_Popup_referer.offsetHeight - IC_Photo_Settings.MarginToBorders );
      Top = Math.max( Top, IC_Photo_Settings.MarginToBorders );

      IC_Photo_Popup_referer.style.top = Top + 'px';
      IC_Photo_Popup_referer.style.left = Left + 'px';

      if ( IC_Photo_Settings.UseDarkLayer ){
        IC_Photo_DarkLayer.style.display = 'block';
        DLHeight = Math.max( Body.offsetHeight, Html.offsetHeight, Top + IC_Photo_Popup_referer.offsetHeight );

        IC_Photo_DarkLayer.style.height = DLHeight + 'px';

      }
    }
  }
}


function IC_Photo_Popup_Close(){
  if ( IC_Photo_Popup_referer != null ){
    IC_Photo_Popup_referer.style.display = 'none';
  }
  if ( IC_Photo_Settings.UseDarkLayer && IC_Photo_DarkLayer != null ){
    IC_Photo_DarkLayer.style.display = 'none';
  }
  return false;
}

function getPositionFrom(element) {
  var Pos = {top:0,left:0};
  var absoluteAncestor = false;

  while ( element.offsetParent ) {

    Pos.top += element.offsetTop - element.scrollTop;
    Pos.left += element.offsetLeft - element.scrollLeft;

    element = element.offsetParent;

    if ( element.nodeName.toLowerCase() != 'html' ) {
      if ( element.currentStyle ) {
        if (element.currentStyle[ 'position' ] == 'absolute')
          absoluteAncestor = true;
      } else {
        if ( window.getComputedStyle ){
          if ( document.defaultView.getComputedStyle(element,null).getPropertyValue( 'position' ) == 'absolute' ){
            absoluteAncestor = true;
          }
        }
      }
    }
  }

  if ( ! absoluteAncestor ){
    var Body = document.getElementsByTagName( 'BODY' ).item( 0 );
    Pos.top += Body.offsetTop;
    Pos.left += Body.offsetLeft;
  }

  return Pos;
}



CurrentMenuOpen = null;
function MenuOpenList( ID ) {
  Element = document.getElementById( ID );
  if ( Element ){

    if ( CurrentMenuOpen ){
      CurrentMenuOpen.style.display = 'none';
    }

    Element.style.display = 'block';
    CurrentMenuOpen = Element;
  }
}


var DarkLayer = null;
OpenPictureNext = null;
OpenPicturePrev = null;
function OpenAfbeelding( idx ){
  if ( idx != null){
    url = Images[ idx ];
  }
  if ( url ){
    bodys = document.getElementsByTagName( 'body' );
    body = bodys[ 0 ];
    phj = document.getElementById( 'PopupHolder' );

    phjFoto = document.getElementById( 'PopupFoto' );

    phjSluiten = document.getElementById( 'Sluiten' );

    pvol = document.getElementById( 'PopupVolgende' );
    pvor = document.getElementById( 'PopupVorige' );

    if ( body && phj && phjFoto && pvol && pvor && phjSluiten ){


      if ( ! DarkLayer ){

        DarkLayer = document.createElement( 'div' );
        DarkLayer.className = 'DarkLayer';
        DarkLayer.style.height = GetWindowHeight() + 'px';
      }

      body.appendChild( DarkLayer );
      phj.style.display = 'block';
      phjFoto.style.backgroundImage = 'url(' + url + ')';

      pvor.style.display = Images[ idx - 1 ] ? 'block' : 'none';
      pvol.style.display = Images[ idx + 1 ] ? 'block' : 'none';

      phjSluiten.href = '#foto' + idx;

      OpenPictureNext = idx + 1;
      OpenPicturePrev = idx - 1;
    }
  }
}

function ClosePicture () {
  bodys = document.getElementsByTagName( 'body' );
  body = bodys[ 0 ];
  body.removeChild( DarkLayer );
  phj = document.getElementById( 'PopupHolder' );
  if ( phj ){
    phj.style.display = 'none';
  }
}
function GetWindowHeight() {
  var myWidth = 0, myHeight = 0;
  if( typeof( window.innerWidth ) == 'number' ) {
    //Non-IE
    myHeight = window.innerHeight;
  } else if( document.documentElement && ( document.documentElement.clientWidth || document.documentElement.clientHeight ) ) {
    //IE 6+ in 'standards compliant mode'
    myHeight = document.documentElement.clientHeight + 1;
  } else if( document.body && ( document.body.clientWidth || document.body.clientHeight ) ) {
    myHeight = document.body.clientHeight + 2;
  }
  return myHeight;
}

CurrentOpen = null;

function GenerateLabel( ElementLink, Label, URL ){
  LinkClose( );

  var holder = document.createElement( 'span' );

  holder.className = 'Holder';

  ElementLink.MouseOn = true;
  ElementLink.SpanMouseOut = false;
  ElementLink.SpanSpanMouseOut = false;

  ElementLink.onmouseout = function(){
    ElementLink.MouseOn = false;
    window.setTimeout( 'CheckClose();', 200 );
  }

  holder.onmouseover = function(){
    ElementLink.SpanMouseOut = true;
  }

  holder.onmouseout = function(){
    ElementLink.SpanMouseOut = false;
    window.setTimeout( 'CheckClose();', 200 );
      LinkClose( );
  }

  if ( URL ){
    var t_element = document.createElement( 'a' );
    t_element.href = URL;
  } else {
    var t_element = document.createElement( 'span' );
  }

  t_element.appendChild( document.createTextNode( Label ) );
  t_element.onmouseout = function(){
    ElementLink.SpanSpanMouseOut = true;
      LinkClose( );
  }
  t_element.onmouseout = function(){
    ElementLink.SpanSpanMouseOut = false;
    window.setTimeout( 'CheckClose();', 200 );
      LinkClose( );
  }

  holder.appendChild( t_element );

  ElementLink.parentNode.appendChild( holder );
  holder.style.left = ElementLink.style.left;

  CurrentOpen = holder;

  ElementLink.MouseOn = true;
}

function CheckClose( ){
  ElementLink = CurrentOpen;
  if ( ElementLink && ( ElementLink.MouseOn == false && ElementLink.SpanMouseOut == false && ElementLink.SpanSpanMouseOut == false ) ) {
    LinkClose( );
  }
}

function LinkClose(  ){
  if ( CurrentOpen ){
    CurrentOpen.parentNode.removeChild( CurrentOpen );
    CurrentOpen = null;
  }
}
