/*
////////////////////////////////////////////////////////////////
//
// Allgemeine JavaScript Funktionen
//
// Weblication CMS Strukturdesign Version 5.1.0.0
// erstellt durch Scholl Communications AG, 77694 Kehl, www.scholl.de
// erstellt mit Weblication Content Management Server, www.weblication.de
//
////////////////////////////////////////////////////////////////
*/

////////////////////////////////////////////////////////////////
//
// @method void wOpenURL(url)
//
// @desc Öffnet eine Seite
//
// @return void
//
////////////////////////////////////////////////////////////////

/*
  ShowHideListEntry für Lexikon
*/

function showHideListEntry(liId,divId){
  if(document.getElementById(divId).className == "listEntryDescription"){
    document.getElementById(divId).className = "listEntryDescriptionOpen";
    document.getElementById(liId).className = "listEntryOpen";
  }else{
    document.getElementById(divId).className = "listEntryDescription";
    document.getElementById(liId).className = "listEntry";
  }
}
/*ShowHideListEntry fertig*/

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() - 2;

      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{
      }
    }
  }
}

jQuery.fn.setViewmode = function(viewmode){

  jQuery.each($(this), function(x){
    var hrefNew = this.getAttribute('href');
    var anchor  = '';
    if(/#[^#]+$/.test(hrefNew)){
      anchor  = hrefNew.replace(/.*#/, '');
      hrefNew = hrefNew.replace(/#.*/, '');
    }

    hrefNew = hrefNew.indexOf('?') != -1 ? hrefNew + '&viewmode=' + viewmode: hrefNew + '?viewmode=' + viewmode;

    if(anchor != ''){
      hrefNew += '#' + anchor;
    }

    this.setAttribute('href', hrefNew);
  });
}

jQuery.fn.addAnalytics= function(viewmode){

  jQuery.each($(this), function(x){
    var href= this.getAttribute('href');
    this.setAttribute('onclick', 'pageTracker._trackPageview(\'' + href + '\');');
  });
}

////////////////////////////////////////////////////////////////
//
// Initialisieren der Seite
//
////////////////////////////////////////////////////////////////

jQuery(document).ready(function(){
  if(typeof wInitBrowseEdit == 'function'){
    wInitBrowseEdit();
  }
  if(typeof wEditor == 'undefined'){
    jQuery("a.box").fancybox({"type": "iframe", "width": 560, "height": '80%', "titlePosition": "inside", "transitionIn" : "none", "transitionOut" : "none", "hideOnContentClick": true, "zoomOpacity": true, "zoomSpeedChange": 200, "zoomSpeedIn": 400, "zoomSpeedOut": 400, "overlayShow": false, "overlayOpacity": 1});
    jQuery("a.box").setViewmode('blank');
    if(typeof pageTracker != 'undefined'){
      jQuery("a.pdf, a.download").addAnalytics();
    }
  }
});

////////////////////////////////////////////////////////////////
//
// Navigation: Slide-Effekt
//
////////////////////////////////////////////////////////////////
//document ready
$(document).ready(initialDocumentNavigationSecondLevel);
//$(document).ready(initialDocumentNavigationThirdLevel);

/**
 *
 *Second-LevelNavigation
 *
 **/

/* function initialDocument */
function initialDocumentNavigationSecondLevel()
{
	/* parameters */
	var overDuration = 500;
	var outDuration  = 500;
	var downDuration = 350;
	var upDuration   = 150;

	/* easing definition */
	jQuery.easing.def = "easeOutQuad";
	
	$('#navigationFullLayer > ul > li')
	.find('a')

	.append('<span class="hover" />').each(function ()
  {
	  var $span = $('> ul', this).css('opacity', 0);
    $(this).bind('mouseenter', menuMouseOverManager);
    $(this).parents('ul').bind('mouseleave', menuMouseOutManager);

	  function menuMouseOverManager()
    {
		  $span.stop().fadeTo(overDuration, 1);
	  }

	  function menuMouseOutManager()
    {
		  $span.stop().fadeTo(outDuration, 0);
	  };
  });

	$("#navigationFullLayer > ul > li > ul").css('display', 'block');
	$("#navigationFullLayer > ul > li > ul").hide();

	$("#navigationFullLayer > ul > li").find('a').bind('mouseenter', onMouseOver_menu);
	$("#navigationFullLayer > ul > li").bind('mouseleave', onMouseOut_menu);
  /* For ThirdLevelNavigation */
	$("#navigationFullLayer > ul > li > ul > li").bind('mouseleave', onMouseOut_menu);
	/* For ThirdLevelNavigation END */

	/* function OnMouseOver */
	function onMouseOver_menu(event)
  {
		$(this).parents('li').find('> ul').css("z-index" , "3000");
		$(this).parents('li').find('> ul').slideDown(downDuration);
		//event.stopPropagation();
	}

	/* function OnMouseOut */
	function onMouseOut_menu(event)
  {
		$('> ul', this).stop(true, true).slideUp(upDuration);
		$('> ul > li > ul', this).stop(true, true).slideUp(upDuration);
    /* For ThirdLevelNavigation */
    $('> ul > li > ul', this).stop(true, true).slideUp(upDuration);
		$('> ul > li > ul > li > ul', this).stop(true, true).slideUp(upDuration);
		/* For ThirdLevelNavigation END */
		//event.stopPropagation();
	}
}

/**
 *
 *Third-LevelNavigation
 *
 **/

/* function initialDocument */
function initialDocumentNavigationThirdLevel()
{
	/* parameters */
	var overDuration = 500;
	var outDuration  = 500;
	var downDuration = 350;
	var upDuration   = 150;

	/* easing definition */
	jQuery.easing.def = "easeOutQuad";

	$('#navigationFullLayer > ul > li > ul > li')
	.find('a')

	.append('<span class="hover" />').each(function ()
  {
	  var $span = $('> ul', this).css('opacity', 0);
    $(this).bind('mouseenter', menuMouseOverManager2);
    $(this).parents('ul').bind('mouseleave', menuMouseOutManager2);

	  function menuMouseOverManager2()
    {
		  $span.stop().fadeTo(overDuration, 1);
	  }

	  function menuMouseOutManager2()
    {
		  $span.stop().fadeTo(outDuration, 0);
	  };
  });

	$("#navigationFullLayer > ul > li > ul > li > ul").css('display', 'block');
	$("#navigationFullLayer > ul > li > ul > li > ul").hide();

	$("#navigationFullLayer > ul > li > ul > li").find('a').bind('mouseenter', onMouseOver_menu2);
	$("#navigationFullLayer > ul > li > ul > li").bind('mouseleave', onMouseOut_menu2);

	/* function OnMouseOver */
	function onMouseOver_menu2(event)
  {
		$(this).parents('li').find('> ul').css("z-index" , "3000");
		$(this).parents('li').find('> ul').slideDown(downDuration);
		event.stopPropagation();
	}

	/* function OnMouseOut */
	function onMouseOut_menu2(event)
  {
		$('> ul', this).stop(true, true).slideUp(upDuration);
		//alert($('> ul', this).attr('class'));
		$('> ul > li > ul', this).stop(true, true).slideUp(upDuration);
		event.stopPropagation();
	}
}
