////////////////////////////////////////////////////////////////
//
// @method void wOpenURL(url)
//
// @desc Öffnet eine Seite
//
// @return void
//
////////////////////////////////////////////////////////////////

function wOpenURL(url){
  if(location.pathname.indexOf('/weblication/grid5/') != 0){
    top.location.href = url;
  }
}

////////////////////////////////////////////////////////////////
//
// @method void wOpenPopupURL(url, width, height, name)
//
// @desc Öffnet eine Seite in einem Popup
//
// @return void
//
////////////////////////////////////////////////////////////////

function wOpenPopupURL(url, width, height, name){

  var name = name || '';

  if(width == '' || width == ' ' || typeof(width) == 'undefined'){
    width = 786;
  }
  if(height == '' || height == ' ' || typeof(height) == 'undefined'){
    height = 677;
  }

  url = url.replace(/&amp;/g, '&');
  options = ',location=no, menubar=no,toolbar=no,resizable=no,scrollbars=yes,status=no';
  width   = parseInt(width);
  height  = parseInt(height);

  var posLeft = (screen.width / 2)  - (width  / 2);
  var posTop  = (screen.height / 2) - (height / 2);
  //alert(name);
  window.open(url, name, 'top='+posTop+',left='+posLeft+',width='+width+',height='+height+',' + options);
}

////////////////////////////////////////////////////////////////
//
// @method void wSendMailNospam(data)
//
// @desc Öffnet eine E-Mail zum Versenden
//
// @return void
//
////////////////////////////////////////////////////////////////

function wSendMailNospam(data){
  location.href = 'mailto:' + data.replace('|', '@');
}

////////////////////////////////////////////////////////////////
//
// @method void wEmbedNavpoint(id, url, mode)
//
// @desc Öffnet einen eingebetteten Navigationspunkt
//
// @return void
//
////////////////////////////////////////////////////////////////

/*
function wEmbedNavpoint(id, url, mode){

  if(typeof wEditor == 'object'){
    return false;
  }

  if($('#navpoint_' + id).data('hasLoaded') == '1'){
    $('#navEmbed_' + id).show();
  }
  else{
    if(mode == 'embed'){
      url = url.indexOf('?') == -1 ? url + '?viewmode=embed' : url + '&viewmode=embed';
      url = url.replace('[URL]', location.pathname + location.search);
      $.ajax({
        type: "GET",
        url: url,
        success: function(result){

          result = result.replace(/\n/g, '_wNL-').replace(/\s+id="[^"]+"/gim, '').replace(/_wNL-/g, "\n");

          $('#navpoint_' + id).data('hasLoaded', '1');
          $('#navEmbed_' + id).html(result);

          var navpointLeft = $('#navpoint_' + id).offset().left;

          $('#navEmbed_' + id).show();

          var layerLeft = $('#navEmbed_' + id).offset().left;

          var blockMainRight = $('#blockMain').offset().left + $('#blockMain').width();

          if(layerLeft < navpointLeft){
            $('#navEmbed_' + id).css('left', String(navpointLeft - layerLeft - 6) + 'px');
          }

          var layerRight = $('#navEmbed_' + id).offset().left + $('#navEmbed_' + id).width();

          if(layerRight > blockMainRight){
            $('#navEmbed_' + id).css('left', String(parseInt($('#navEmbed_' + id).css('left')) - (layerRight - blockMainRight)) + 'px');
          }

          jQuery('#navpoint_' + id).mouseout(function(){
            $('#navEmbed_' + id).hide();
          });

          jQuery('#navEmbed_' + id).mouseover(function(){
            $('#navEmbed_' + id).show();
          });

          jQuery('#navEmbed_' + id).mouseout(function(){
            $('#navEmbed_' + id).hide();
          });
        }
      });
    }
    else{
      url = url.indexOf('?') == -1 ? url + '?viewmode=blank&parentIframeId=navEmbedIframe_'+id : url + '&viewmode=blank&parentIframeId=navEmbedIframe_'+id;
      url = url.replace('[URL]', location.pathname + location.search);
      $('#navpoint_' + id).data('hasLoaded', '1');

      var iframeEmbed    = document.createElement('iframe');

      iframeEmbed.id        = 'navEmbedIframe_' + id;
      iframeEmbed.className = 'navLevel1Embed';
      iframeEmbed.frameBorder = '0';
      iframeEmbed.scrolling   = 'no';
      iframeEmbed.src       = url;

      var embedContainer = document.getElementById('navEmbed_' + id);
      embedContainer.appendChild(iframeEmbed);

      var navpointLeft = $('#navpoint_' + id).offset().left;

      $('#navEmbed_' + id).show();

      var layerLeft = $('#navEmbed_' + id).offset().left;

      var blockMainRight = $('#blockMain').offset().left + $('#blockMain').width();

      if(layerLeft < navpointLeft){
        $('#navEmbed_' + id).css('left', String(navpointLeft - layerLeft - 6) + 'px');
      }

      var layerRight = $('#navEmbed_' + id).offset().left + $('#navEmbed_' + id).width();

      if(layerRight > blockMainRight){
        $('#navEmbed_' + id).css('left', String(parseInt($('#navEmbed_' + id).css('left')) - (layerRight - blockMainRight)) + 'px');
      }

      jQuery('#navpoint_' + id).mouseout(function(){
        $('#navEmbed_' + id).hide();
      });

      jQuery('#navEmbed_' + id).mouseover(function(){
        $('#navEmbed_' + id).show();
      });

      jQuery('#navEmbed_' + id).mouseout(function(){
        $('#navEmbed_' + id).hide();
      });

      //jQuery('.blockContentEmbed').attr('id', 'blockContent');
      //jQuery('.blockContentEmbedInner').attr('id', 'blockContentInner');
    }
  }
}
*/
////////////////////////////////////////////////////////////////
//
// @method void wShowLayerBookmarklet()
//
// @desc Schlägt vor, diese Webseite als App abzulegen
//
// @return void
//
////////////////////////////////////////////////////////////////

function wShowLayerBookmarklet(){

  if(/iPhone|iPod/.test(window.navigator.userAgent)){
    if(window.localStorage){
      if(typeof(window.localStorage['numberBookmarketShown']) == 'undefined' || Number(window.localStorage['numberBookmarketShown']) < 2){
        window.localStorage['numberBookmarketShown'] = String(Number(window.localStorage['numberBookmarketShown'] || 0) + 1);
        var bookmarkletInfo = document.createElement('div');

        bookmarkletInfo.id             = 'wBookmarkletInfo';
        bookmarkletInfo.style.width    = '100%';
        bookmarkletInfo.style.position = 'absolute';
        bookmarkletInfo.style.bottom   = '0';

        var bookmarkletInfoInner = document.createElement('div');
        bookmarkletInfoInner.style.color      = '#ffffff';
        bookmarkletInfoInner.style.border     = 'solid 4px #ffffff';
        bookmarkletInfoInner.style.margin     = '20px';
        bookmarkletInfoInner.style.padding    = '8px';
        bookmarkletInfoInner.style.overflow   = 'hidden';
        bookmarkletInfoInner.style.position   = 'relative';
        bookmarkletInfoInner.style.background = '#cddcf3 -webkit-gradient(linear, left top, left bottom, from(#B5C9D9), to(#6886B0)) no-repeat bottom';
        bookmarkletInfoInner.style.WebkitBorderRadius = '8px';
        bookmarkletInfoInner.style.WebkitBoxShadow    = '0 4px 6px #a0a0a0';

        bookmarkletInfo.appendChild(bookmarkletInfoInner);

        var bookmarkletInfoIcon = document.createElement('img');
        bookmarkletInfoIcon.style.margin = '8px';
        bookmarkletInfoIcon.style.position = 'absolute';

        var linkTags = document.getElementsByTagName('link');
        for(var i = 0; i != linkTags.length; i++){
          if(linkTags[i].getAttribute('rel') == 'apple-touch-icon'){
            bookmarkletInfoIcon.src = linkTags[i].getAttribute('href');
          }
        }

        bookmarkletInfoInner.appendChild(bookmarkletInfoIcon);

        var bookmarkletInfoCloser = document.createElement('img');
        bookmarkletInfoCloser.src = '/weblication/grid5/gui/images/style/bookmarklet_close.png';
        bookmarkletInfoCloser.style.margin = '-4px';
        bookmarkletInfoCloser.style.padding = '2px';
        bookmarkletInfoCloser.style.background = '#ffffff';
        bookmarkletInfoCloser.style.border = 'solid 1px #c0c0c0';
        bookmarkletInfoCloser.style.float  = 'right';

        bookmarkletInfoCloser.onclick = function(){document.getElementById('wBookmarkletInfo').parentNode.removeChild(document.getElementById('wBookmarkletInfo'));window.localStorage['numberBookmarketShown'] = '99'};
        bookmarkletInfoInner.appendChild(bookmarkletInfoCloser);

        var bookmarkletInfoText = document.createElement('div');
        bookmarkletInfoText.style.margin = '8px 8px 8px 100px';
        bookmarkletInfoText.style.position  = 'left';
        bookmarkletInfoText.style.backgroundColor  = 'none';
        bookmarkletInfoText.innerHTML    = 'Klicken Sie unten auf das "+" Zeichen und dann auf "Zum Home-Bildschirm hinzufügen", um diese Seiten als App abzulegen.';

        bookmarkletInfoInner.appendChild(bookmarkletInfoText);

        var bookmarkletArrow = document.createElement('div');
        bookmarkletArrow.style.height             = '23px';
        bookmarkletArrow.style.width              = '100%';
        bookmarkletArrow.style.marginTop          = '-23px';
        bookmarkletArrow.style.position           = 'absolute';
        bookmarkletArrow.style.zIndex             = '10';
        bookmarkletArrow.style.backgroundRepeat   = 'no-repeat';
        bookmarkletArrow.style.backgroundPosition = 'center';
        bookmarkletArrow.style.backgroundImage    = 'url(/weblication/grid5/gui/images/style/arrow_bookmarklet.png)';

        bookmarkletInfo.appendChild(bookmarkletArrow);

        document.body.appendChild(bookmarkletInfo);
      }
      else{
      }
    }
  }
}

////////////////////////////////////////////////////////////////
//
// Initialisieren der Seite
//
////////////////////////////////////////////////////////////////

jQuery(document).ready(function(){
  if(typeof wInitBrowseEdit == 'function'){
    wInitBrowseEdit();
  }

  //Bar-Navigation
  if(jQuery('ul#navigationBar').length > 0) {
    var liIdActive = 'barNav1';
    jQuery('ul#navigationBar li').each(function(){
      if(jQuery(this).hasClass('act')) {
        if(jQuery(this).prev()) {
          jQuery(this).prev().addClass('none');
        }
      }
    });

    jQuery('ul#navigationBar li').mouseover(function(){
      jQuery('ul#navigationBar li').each(function(){
        jQuery(this).removeClass('act');
        jQuery(this).removeClass('none');
      });

      jQuery(this).addClass('act');
      if(jQuery(this).prev()) {
        jQuery(this).prev().addClass('none');
      }
      if(jQuery(this).parent().find('.sel')) {
        jQuery(this).parent().find('.sel').removeClass('sel');
      }
      jQuery(this).addClass('sel');

      var liId = jQuery(this).attr('id');
      if(jQuery('#'+liId+'Cont')) {
        jQuery('#'+liId+'Cont').toggle();
        jQuery('#'+liIdActive+'Cont').toggle();
        liIdActive = liId;
      }
    });

    jQuery('#navigationBar li').mouseout(function(){
      if(jQuery(this).prev() && !jQuery(this).hasClass('sel')) {//
        jQuery(this).prev().removeClass('none');
      }
      jQuery(this).removeClass('act');
    });
  }

  //Bilder bei Teaserblöcken wechseln
  if(jQuery('img.teaserBlockPicture').length > 0) {
    jQuery('img.teaserBlockPicture').mouseover(function(){
      var iId = jQuery(this).attr('id');
      if(jQuery('#'+iId+'_inp_n') && jQuery('#'+iId+'_inp_mo')) {
        jQuery(this).attr('src', jQuery('#'+iId+'_inp_mo').attr('value'));
      }
    });
    jQuery('img.teaserBlockPicture').mouseout(function(){
      var iId = jQuery(this).attr('id');
      if(jQuery('#'+iId+'_inp_n') && jQuery('#'+iId+'_inp_mo')) {
        jQuery(this).attr('src', jQuery('#'+iId+'_inp_n').attr('value'));
      }
    });
  }

  /* Im IE7 das Problem mit der Navi beheben... */
  if(jQuery.browser.msie && isInEditor == false) {
    if(parseInt(jQuery.browser.version) == 7) {
      var zIndexNumber = 1000;
      jQuery('div').each(function() {
        var did     = jQuery(this).attr('id');
        var dclass   = jQuery(this).attr('class');
        if(did.indexOf("bePanel") < 0 && did.indexOf("beButton") < 0 && dclass.indexOf("beButton") < 0 && dclass.indexOf("wglButton") < 0) {
          jQuery(this).css('zIndex', zIndexNumber);
          zIndexNumber -= 10;
        }
      });
    }// if
  }// if

  /* Im IE6 das Problem mit der Navi beheben... */
  if(jQuery.browser.msie) {
    if(parseInt(jQuery.browser.version) == 6) {
      jQuery('#navigationTop li.lvl1').mouseenter(function(){
        jQuery(this).find('ul.nav2Cont').css('display', 'block');
      });
      jQuery('#navigationTop li.lvl1').mouseleave(function(){
        jQuery(this).find('ul.nav2Cont').css('display', 'none');
      });
      jQuery('#navigationTop li.lvl2').mouseenter(function(){
        jQuery(this).find('ul.nav3Cont').css('display', 'block');
      });
      jQuery('#navigationTop li.lvl2').mouseleave(function(){
        jQuery(this).find('ul.nav3Cont').css('display', 'none');
      });
    }// if
  }// if


});

//Layerfunktionen für Nährwerttabellen

function mainOver() {
  setLayerPositions();

  if (hide_timer) {
    window.clearTimeout(hide_timer);
  }

  if (lyr_visible != null && lyr_visible != main_over) {
    hideLayer();
  }

  if (hasLayer()) {
    showLayer();
  }
}

function mainOut() {
  if (lyr_visible) {
    hide_timer = window.setTimeout("hideLayer()", 500);
  }

  main_over = null;
}

function hasLayer() {
  for (var i in layers) {
    if (layers[i] == main_over) {
      return true;
    }
  }

  return false;
}

function showLayer() {
  $('#lyr'+main_over).css('display', 'block');
  lyr_visible = main_over;
}

function hideLayer() {
  if (lyr_visible != main_over) {
    $('#lyr'+lyr_visible).css('display', 'none');
    lyr_visible = null;
  }
}

function layerOver() {
  if (hide_timer) {
    window.clearTimeout(hide_timer);
  }
}

function layerOut() {
  hide_timer = window.setTimeout("hideLayer()", 500);
}

function setLayerPositions() {
  var top_pos = $('#top').offset();
  var mm_pos = $('#mainmenu').position();

  for (var i in layers) {
    var mma_pos = $('#mma'+layers[i]).position();
    var lyr_left = top_pos['left'] + mm_pos['left'] + mma_pos['left'] - 10;
    $('#lyr'+layers[i]).css('left', lyr_left+'px');
  }
}

