| (function(global) {
 "use strict";
             
  var __TOK_DEFER__ = 'NG_DEFER_BOOTSTRAP!';
  frdl.$q('html', false, document).setAttribute('ng-csp', 'no-inline-style;no-unsafe-eval');  
   frdl.$q('html', false, document).setAttribute('ng-non-bindable', 'non-bindable'); /*  !important   http://stackoverflow.com/questions/18184617/angularjs-how-to-nest-applications-within-an-angular-app */
  
  
  var __WIDGET_REL__ = 'widget';
  
  
  var __APP_NS__ = 'webfan';
  var __GUID_ND__ = __APP_NS__ + '.gui';
 var preferences = {
 URL_SERACHENGINE_PLUGIN : frdl.route('FRDL.URL.SERACHENGINE.PLUGIN'),
 URL__MANIFEST_WEBAPP_WEBFAN_MAIN : frdl.route('FRDL.URL.MANIFEST.WEBAPP.WEBFAN.MY')
};     
       
 var jQueryMobile = {
    	  autoInitializePage : frdl.route('jQueryMobile.autoInitializePage'), 
          ajaxEnabled: frdl.route('jQueryMobile.ajaxEnabled'),
          linkBindingEnabled : frdl.route('jQueryMobile.linkBindingEnabled'),
          hashListeningEnabled : frdl.route('jQueryMobile.hashListeningEnabled'),
          pushStateEnabled : frdl.route('jQueryMobile.pushStateEnabled')	
 	 };    
  
 var DBPFX= 'frdl/WebfanDesktop/';
  
  
  
  
  
(function(){	
  var Bootstrap = (new function(){
  	  
  	 var _on = true; 
  	  
  	 return Object.create(  {
  	   switchOn : function(a, old){
  	   	
	     if(a !== _on){
	    	this.since = frdl.time();
		    frdl.cron.add(this.timerName, this.check);
	     }
	
	     if(true===a){
			_on=true;
	    }else if(false===a){
			_on=false;
	    }
	
	   if(true===old){
  	     if(true===a){
	 	    window.name = str_replace(__TOK_DEFER__, '', window.name);
	     }else if(false===a){
	  	    window.name = __TOK_DEFER__  +  str_replace(__TOK_DEFER__, '', window.name);
	    }
  	   _on= (window.name !== str_replace(__TOK_DEFER__, '', window.name)) ? false : true;		
	  }
	
	 return _on;
    },
   
  	   since : frdl.time(),
  	   timeout : 10000,
  	   check : function(){
	   	  if(true === _on){
		  	frdl.cron.remove(this.timerName);
		  }else{
		  	if(frdl.time() - this.since >= this.timeout){
				if(0<frdl.debug.mode()){
					console.log('Forcing angularBootstrapable(true) due to timeout while sleeping.'+"\n"+'Please refactor the use of frdl.UI.Compile()');
				}
				this.switchOn(true);
				frdl.UI.Compile(1);
			}
		  }
	   },
	   timerName : 'frdl://Bootstrap.check/' + frdl.microtime() + mt_rand(1000,9999)
	   
	 });
	 
});
  
 var loaded$UI=false;
 var require$UI = function(callback, args){
 	            if(false!==loaded$UI)return;
 	            loaded$UI=true;
 	
				if('object' !== typeof $.ui && false===$.ui instanceof Promise
				  && null === frdl.$q('style[src$="jquery-ui.js"]', false)
				  && null === frdl.$q('style[src$="jquery-ui.min.js"]', false)
				){
					if(	 null === frdl.$q('link[href$="jquery-ui.css"]', false)
				      && null === frdl.$q('link[href$="jquery-ui.min.css"]', false)){
					  	frdl.getCSS('http://'+frdl.route('HOST_CDN_PUBLIC_FRDL')+'/cdn/frdl/flow/libraries/jquery/ui/jquery-ui.min.css');
					  }
					frdl.getScript('http://'+frdl.route('HOST_CDN_PUBLIC_FRDL')+'/cdn/frdl/flow/libraries/jquery/ui/jquery-ui.min.js', function(){
						callback(args);
					});
				}else{
					callback(args);
				}
			};
 frdl.angularBootstrapable = function(a, old){
	return Bootstrap.switchOn(a, old);
 };
 frdl.UI=frdl.$({
 	 o :{
 	 	 
 	 	 DBPFX : DBPFX,
 	 	 LOCAL_MACHINE_CURRENT_USER : (JSON.parse( base64_decode(
		   	                                     localStorage.getItem(DBPFX + 'LOCAL_MACHINE_CURRENT_USER/')
		   	                                   )) || 'anonymous'),
	 	                                   
	 	 Main : {
  	                 StatusBarStyle : 'lightblue'
                },
         jQueryMobile : {
  	    	o: {
                  loadingMessage : 'Loading...',
                  pageLoadErrorMessage : 'Error Loading Page',
                  allowCrossDomainPages : true,
                  defaultPageTransition : 'fade',
                  overlayTheme: "d",
                  theme : 'd',
                  pageLoadErrorMessageTheme : 'e',
                  
                  
    	          autoInitializePage : frdl.route('jQueryMobile.autoInitializePage'), 
                  ajaxEnabled: frdl.route('jQueryMobile.ajaxEnabled'),
                  linkBindingEnabled : frdl.route('jQueryMobile.linkBindingEnabled'),
                  hashListeningEnabled : frdl.route('jQueryMobile.hashListeningEnabled'),
                  pushStateEnabled : frdl.route('jQueryMobile.pushStateEnabled')			
	          }
	    },
	    jQueryUI : {
			require : function(callback, args){
				return require$UI(callback, args);
			}
		}
	 },
	 defer : function(){
  	   this.$$run('startdefer');
  	   frdl.angularBootstrapable(false, false);
  	   return this;
     },
     load : function(){
       this.$$run('enddefer');
  	   frdl.angularBootstrapable(true, false);
  	   return this;
  	 },
  	 
  	 widgetAppData : function(file, component){
 	 	var s  = {};
 	 	var c = explode('\/', component);
         s._TOK_ = '*[data-frdl-component$="'+((2===c.length) ? c[0]+'\\/'+c[1] : component)+'"]';
        /* s.__FILE__ = file; */
         s.Url = new frdl.Url(file);
         s.__DIR__ = s.Url.getScheme() + '://' + s.Url.getHost() + '/' + s.Url.getDirectory();	
         return s;	
     }
 }).defer(); 
 frdl.UI.emitter=new frdl.EventEmitter();
 document.addEventListener('readystatechange', function(ev){
    Bootstrap.since=frdl.time();
 }) ;  
 document.addEventListener("mobileinit", function(){
    $.extend(  $.mobile , frdl.UI.o.jQueryMobile.o);
});   
  
  
}());
 
 
 
(function(){
 frdl.hasScope = function(element){
 	 return ($(element).hasClass('ng-scope')) ? true : false;
 };
  
  
 
 
  
  
frdl.UI.reduced = function(){
  	   return (
  	       true===frdl.Dom.isFramed() 
  	    || true === frdl.Device().isMobile 
  	    || true === frdl.Device().isTablet
  	    || true === frdl.Device().isTouchable 
  	   || true === frdl.Device().isApp 
  	   /*  || true === frdl.Device().frdlApp*/
  	   )
  	    ? true: false;
};
}());  
(function(){	
var obs = frdl.watchFor('frdl').every(function(el){
  el.setAttribute('ng-non-bindable', 'non-bindable');
});
}());
/*
(function(){	
var obs = frdl.watchFor('*[draggable]').every(function(el){
   frdl.UI.o.jQueryUI.require(function(e){
  	 $(e).draggable();   
   }, el);
});
}());
*/
(function(){	
frdl.watchFor('*[resizable]').every(function(el){
  frdl.UI.o.jQueryUI.require(function(e){
  	 $(e).resizable();   
   }, el);
});
}());
 
   
/*
(function(){	
var obs = frdl.watchFor('.webfan-blue').every(function(el){
	try{
		 frdl.getScript('http://webfan.de/site/site_css/webfan/style.webfan.global.css');
		 obs.destroy();	
	}catch(err){
		cosnole.warn(err);
	}
});
}());
*/
(function(){
	
function canonicalAttributes(el){
  var j = 0,
   names = ['ng-app', 'ng-modules', 'ng-module', 'data-ng-modules', 'data-ng-module', 'ng-flow', 'data-ng-flow', 'data-ng-flows'],
   a =  el.attributes
  ;
   if(!!a) {
     for( j = 0; j < a.length; j++) {
         var attr = a[j];
         if (names.indexOf(attr.name.toLowerCase()) !== -1) {
             if('ng-flows' !== attr.name)el.removeAttribute(attr.name);
             el.setAttribute('ng-flows', attr.value);
         }
    }
  }
  
  return true;
}
var obs = frdl.watchFor('[ng-app], [ng-modules], [ng-module], [data-ng-modules], [data-ng-module], [ng-flow], [data-ng-flow], [data-ng-flows]')
              .every(canonicalAttributes);
}());
(function(){
var obs = frdl.watchFor('intent:not([data-flow-prepared="true"])').every(function(el){
	if(!!window.webfanIntent || null !== frdl.$q('intent[data-flow-prepared*="true"]', false) )return true;
	
	   frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
	 
    frdl.getScript('http://frdl.webfan.de/cdn/frdl/flow/components/frdl/intent/webintents.js'
      , function(){ 
      
          console.log('webfanIntents script loaded');  
          obs.destroy();
        
    }, true, false); 
   
   return true;	
});
}());
	
	
	
(function(){
	var _cloaded = false, obs;
obs = frdl.watchFor(
       '*[href^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     + ', *[src^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     
     + ', *[data-src^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     + ', *[ng-src^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     
     + ', *[data-href^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     + ', *[ng-href^="web\+fan\:"]:not([data-flow-prepared*="true"])'
     
     )
     .every(function(el){
	 frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
   
     if(!!_cloaded || null !== frdl.$q('iframe[id="IFRAME.webfan_proxy"]',false))return;
 
      var iframe = frdl.Dom.create("iframe");
      iframe.setAttribute('frdl-nwtrusted', true);
      iframe.style.display = "none";
      iframe.setAttribute('id', "IFRAME.webfan_proxy");
      iframe.setAttribute('src', "http://webfan.de/proxy");
      frdl.Dom.add(iframe, frdl.$q('head',false));
      
      _cloaded = true; 
   return true;	
});
}());
(function(){
var obs = frdl.watchFor('webfan[type="widget"]:not([data-flow-prepared*="true"]), *[type^="application/vnd.frdl.flow.widget."]:not([data-flow-prepared*="true"]), *[type$=".wgt"]:not([data-flow-prepared*="true"])').every(function(el){
	 frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
      	$(el).html('<div data-frdl-component="widget://example.com/'+el.getAttribute('name')+'"></div>') ;
        
        $(document).trigger('readystatechange');      
   
  
   return true;	
});
}());
	
	
(function(){	
var obs = frdl.watchFor('*[webfan-tempelement]').every(function(el){
  var duration = el.getAttribute('webfan-tempelement');
  if(!isNaN(parseInt(duration))){
  	 setTimeout(function(){
  	 	  $(el).hide();
  	 	  $(el).remove();
  	 },duration);
  }
});
}());
(function(){	
var obs = frdl.watchFor('*[webfan-fadeout]').every(function(el){
try{
  var duration = el.getAttribute('webfan-fadeout');
  if(!isNaN(parseInt(duration))){
  	 setTimeout(function(){
  	 	  $(el).fadeOut('slow');
  	 },duration);
  }
}catch(err){
  console.warn(err);
}
});
}());
frdl.watchFor('*[flow-nav-horizontal]:not([data-flow-prepared*="true"]), *[flow-nav-horizontal]:not([data-flow-prepared*="true"]) > *, *[flow-nav-horizontal]:not([data-flow-prepared*="true"]) > * > *').every(function(el){
		     el.style.display='inline';
		        frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
});
 
frdl.watchFor('a[frdl-ajax-link-boddystripped]:not([data-flow-prepared*="true"])').every(function(element){
	    frdl.$j(element).attrAdd('data-flow-prepared', 'true');  
 
	 $(element).on('click', function(ev){
	 	var el = ev.target;
	  
	 	    
	 	    if(!el.hasAttribute('href'))return true;
	 	
		   	if('undefined'===window.history.pushState)return true;
		     	
             var url = el.getAttribute('href');
             var uHost =  new frdl.Url(url).getHost();
             if( '' !== uHost && new frdl.Url().getHost() !==  uHost)return true;
             ev.preventDefault();
               
             if(true === frdl.Device().isMobile || true === frdl.Device().isTablet){
               	 $.mobile.loading( 'show' );   
             }  
               
             var dest = 'body';
             var destMeta=document.querySelector('meta[name="frdl-ajax-link-boddystripped.destination"]');
             if(null!==destMeta){
			 	dest=destMeta.getAttribute('content');
			 }
             			
                          		 var OnUnload = function(e){
                             		    e.preventDefault();
                             	     
                             		    return false;
                             		 };
                             		 window.addEventListener('beforeunload', OnUnload);            		
             					  
						     $.ajax({
                                      url: url,     
                                      crossDomain:true,
                                      cache:true,
                                      headers: {'X-Requested-With': 'XMLHttpRequest'
                                                , 'X-Flow-Ajax-Link-Boddystripped': 'destination="'+dest+'";'
                                               },  
                                      type: 'GET',
                                      dataType:'html'
                             })
                             .done(function( html ) {
                             	
                             	
                             		 $(dest).html(html);
                             		 window.removeEventListener('beforeunload', OnUnload); 
   
                             		
                             		setTimeout(function(){
                             		 	  try{
     								 	      var newTitle=document.querySelector('meta[name="document.title"]').getAttribute('content');
     								 	  }catch(err){
									 
									       }
									 	 if('undefined'!==typeof newTitle)$('title').html(newTitle);     
 
									 	 try{
									 	    $(document).scrollTop(0);
									 	 }catch(err){
									 
									       }
									       
									 	 $(document).trigger('readystatechange');  
									 	 
									 	   if(true === frdl.Device().isMobile || true === frdl.Device().isTablet){
									 	  
	                                     
	                                           $(dest).trigger('create');
	                                     
	                                                
                                                $.mobile.loading( 'hide' );   
	                                       }    
	                                     
                             		    window.history.pushState({
                             		    	name : newTitle,
                             		    	sha1 : Sha1.hash(html),                             		    	
                             		    	l : html.toString().length
                             		    }, newTitle, url);  
                             		    ev.stopPropagation();            		 		
                             		 },1);
								 
                             	
                             }).fail(function(jqXHR, textStatus) {
                                    frdl.alert.error('Error: ' + url + ' ' + jqXHR.status+ ' '+textStatus);
                                    window.location.href=url;
                             }).always(function() {
                             		 
                            });	
                            
                            
                return false;						     	
	  });
});
 
(function(){
var _done_HeaderMetadata = false;	
	
var headerMetadata=function(doc){
 	var meta, Tags;
 	if(true===_done_HeaderMetadata)return;
 	_done_HeaderMetadata=true;
 	
   	  if('undefined' === typeof doc)doc = document;
   	  /*
   	    Tags = frdl.$q('html[manifest]', false, doc);
   	    if(null === Tags){
   	    	frdl.$q('html', false, doc).setAttribute('meta', 'http://webfan.de/cdn/frdl/flow/components/frdl/intent/manifest-minimum.appcache');
		}
   	  */
   	    Tags = frdl.$q('meta[name="flow.component.frdl.webfan.api.url.demo"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'flow.component.frdl.webfan.api.url.demo');
			meta.setAttribute('content', frdl.route('DEMO_API_CLIENT_URL'));
   	        frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}
   	  
   	    Tags = frdl.$q('meta[name="flow.component.frdl.webfan.api.url.demo.alt"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'flow.component.frdl.webfan.api.url.demo.alt');
			meta.setAttribute('content', frdl.route('DEMO_API_CLIENT_URL_ALT'));
   	        frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}
		
				   	   
   	  
   	    Tags = frdl.$q('meta[name="apple-mobile-web-app-capable"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'apple-mobile-web-app-capable');
			meta.setAttribute('content', 'yes');
   	        frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}
   	   
        Tags = frdl.$q('meta[name="application-name"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'application-name');
			meta.setAttribute('content', (null!==document.querySelector('title')) ? document.querySelector('title').innerHTML : location);
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}	  	   
   	   
   	    Tags = frdl.$q('meta[name="apple-mobile-web-app-status-bar-style"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'apple-mobile-web-app-status-bar-style');
			meta.setAttribute('content', frdl.UI.o.Main.StatusBarStyle);
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}		
		
   	   
   	   
   	    Tags = frdl.$q('meta[name="HandheldFriendly"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'HandheldFriendly');
			meta.setAttribute('content', 'true');
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}	
   	   
   	    Tags = frdl.$q('meta[name="MobileOptimized"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'MobileOptimized');
			meta.setAttribute('content', '320');
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}	
		
   	    Tags = frdl.$q('meta[name="viewport"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('name', 'viewport');
			meta.setAttribute('content', 'width=device-width, initial-scale=1.0, user-scalable=yes');
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}			
		
   	    Tags = frdl.$q('meta[http-equiv="http-equiv"]', true, doc);
   	    if(0 === Tags.length){
			meta = frdl.Dom.create('meta');
			meta.setAttribute('http-equiv', 'http-equiv');
			meta.setAttribute('content', 'IE=11');
			frdl.Dom.add(meta, frdl.Dom.getTagNames('head')[0]);
		}	
		
   var lnk;
  if(0 === frdl.$q('link[type="application/manifest+json"]', true, doc).length
          && ('www.webfan.de'=== new frdl.Url().getHost() 
                || 'webfan.de'=== new frdl.Url().getHost()
                || 'webfan' === explode('.', new frdl.Url().getHost()).reverse()[1]  
             )){
 	lnk = frdl.Dom.create('link');
	lnk.setAttribute('rel', 'manifest');
	lnk.setAttribute('type', 'application/manifest+json');
	lnk.setAttribute('href', preferences.URL__MANIFEST_WEBAPP_WEBFAN_MAIN);
	frdl.Dom.add(lnk, frdl.Dom.getTagNames('head')[0]);  	    	
  }
  
  /* "\n<link rel=\"search\" type=\"application/opensearchdescription+xml\" href=\"$this->xml_url\" title=\"$title\" />\n";*/
  if(0 === frdl.$q('link[type="application/opensearchdescription+xml"]', true, doc).length){
 	lnk = frdl.Dom.create('link');
	lnk.setAttribute('rel', 'search');
	lnk.setAttribute('title', 'Webfan: Search');
	lnk.setAttribute('type', 'application/opensearchdescription+xml');
	lnk.setAttribute('href', preferences.URL_SERACHENGINE_PLUGIN);
	frdl.Dom.add(lnk, frdl.Dom.getTagNames('head')[0]);  	    	
  } 		
		
		console.log('Setup MetaData');
};  
frdl.whenEver(function(){
	   return (null!== frdl.$q('body',false)) ? true : false;
	}, headerMetadata, document, 1);
if(null !== frdl.$q('link[type="application/manifest+json"]', false)){
	frdl.UI.isWebApp = true;
}else{
	frdl.UI.isWebApp = false;
}
}());	
	
	
	
  
   
   
   
     
  
  
  
  
  
  
  
  
  
 
 frdl.ready(function(){
/*
http://stackoverflow.com/questions/22548610/can-i-use-one-ng-app-inside-another-one-in-angularjs
  "compile" : function( $compile,  $element, $attrs, $rootScope) { 
    angular.module("ng").directive("ngIsolateApp", function() {
        return {
            "scope" : {},
            "restrict" : "AEC",
            "compile" : function(element, attrs) {
               
                var html = element.html();
                element.html('');
                return function(scope, element) {
                   
                    scope.$destroy();
                    
                    setTimeout(function() {
                        
                        var newRoot = document.createElement("div");
                        newRoot.innerHTML = html;
                       
                         angular.bootstrap(newRoot, [attrs["ngIsolateApp"]]); 
                       
                        element.append(newRoot);
                    });
                }
            }
        }
    });  
 */ 
 frdl.a.module('frdl', ['ng'])
 
 .directive("frdl", function() {
        return {
            "scope" : {},
            "restrict" : "E",
            "compile" : function($compile, element, attrs) {
               
                var html = element.innerHTML;
                element.innerHTML='';
                
                if('function'===typeof element.setAttribute){
				  element.setAttribute('ng-non-bindable', 'non-bindable');  
				}
              
                  
                return function($scope, $element) {
                   
                    $scope = $element.isolateScope();
                    
                    setTimeout(function() {
                       $element.innerHTML=html;    
                    }, 1500);
                }
            }
        }
})
; 
 
 frdl.a.module(__APP_NS__, ['frdl']);
 
frdl.a.module(__GUID_ND__, [__APP_NS__ , 'ngTouch', 'csrf-cross-domain', 'oc.lazyLoad', 'ui.router'])
/* IE https://github.com/angular/angular.js/issues/6976 
* http://plnkr.co/edit/EHfYEeONdOFa6Xu4owUx?p=preview
*/
/*
  .config(function ($provide) {
    $provide.decorator('$browser', function ($delegate, $log) {
    var _url = $delegate.url;
    $delegate.url = function () {
      if (arguments[0]) {
        $log.log('Navgiating to ', arguments[0], arguments[1]);
      }
      return _url.apply($delegate, arguments);
    };
    return $delegate;
   })
 })
 
.config(['$locationProvider', function ($locationProvider) {
  $locationProvider.html5Mode({
        enabled: false,
        requireBase: false
    });
}])
 
;
frdl.a.module(__GUID_ND__) */
 .config(['$compileProvider',
  function($compileProvider) {
    $compileProvider.imgSrcSanitizationWhitelist(/^\s*((https?|ftp|file|blob|chrome-extension|webfan|frdl|frdlweb|frdl-webkit|app|intent|webfan-intent|wpjct|widget|frdl-css|webkit-webfan|user|webfan-user|help|cli|frdl-cli|filesystem|webfan-sdk|frdl-sdk|webfan-api|frdl-api|api|web+fan|about|debug):|data:image\/)/);
    $compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|ftp|mailto|tel|file:chrome-extension|webfan|frdl|frdlweb|frdl-webkit|app|intent|webfan-intent|wpjct|widget|frdl-css|webkit-webfan|user|webfan-user|help|cli|frdl-cli|filesystem|webfan-sdk|frdl-sdk|webfan-api|frdl-api|api|web+fan|about|debug):/);
  }])
   .config(['$ocLazyLoadProvider', '$stateProvider', function($ocLazyLoadProvider, $stateProvider) {
      $ocLazyLoadProvider.config({
            debug: true,
            events : true,
            
            serie: false,
            cache: true,
            rerun: false,
            reconfig: false , 
                                           
            modules: [ 
              
              
              {
               name: __GUID_ND__+'.sdk',
               files: [ 'http://api.webfan.de/api-d/4/js-api/library.js?plugin=sdk']
              },
              
              
     
              {
               name: 'ui.codemirror',
               serie: true,
               files: [ 
                    'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/lib/codemirror.css'
                  /* , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/theme/eclipse.css'  */
                     , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/theme/blackboard.css'  
                     
                     
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/lib/codemirror.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/addon/selection/selection-pointer.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/xml/xml.js'
                  
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/javascript/javascript.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/css/css.js'
                 , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/vbscript/vbscript.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/htmlmixed/htmlmixed.js'
                 /*   , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/lib/util/http_codemirror.net_2_lib_util_multiplex.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/lib/util/overlay.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/lib/util/foldcode.js'  */
                  
                  /*
                      additonal... php, sql ?
                      
                      change mode
                      $('#mode').change(function(){
   editor.setOption("mode", $(this).val() );
});
                 
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/php/php.js'
                  , 'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/mode/sql/sql.js'
                 */  
                  
                 ,  'http://webfan.de/cdn/frdl/flow/components/codemirror/codemirror/ui-codemirror/src/ui-codemirror.js'
               ]
              }
              
           ]
    });
 }]) 
 
 .factory('widgetElement', function() {
   return function widgetElement(element, token){
	  return $(element).closest(token);
   };
 })
 .directive('draggable', function($document) {
  return function(scope, element, attr) {
    var startX = 0, startY = 0, x = 0, y = 0;
    element.css({
     position: 'relative',
     cursor: 'pointer'
    });
    element.on('mousedown', function(event) {
      startX = event.screenX - x;
      startY = event.screenY - y;
      $document.on('mousemove', mousemove);
      $document.on('mouseup', mouseup);
    });
    element.children().on('mousedown', function(event) {
	   	
       if( 'A'===this.tagName || 'INPUT'===this.tagName  || 'TEXT'===this.tagName  || 'BUTTON'===this.tagName  || 'SELECT'===this.tagName  || 'PRE'===this.tagName  ){
        event.stopPropagation();  
        try{
          this.removeEventListener('mousemove', mousemove);
          this.removeEventListener('mouseup', mouseup);			
		}catch(err){
			 console.warn(err); 
		}
	
       }
    });
    
    function mousemove(event) {
      y = event.screenY - startY;
      x = event.screenX - startX;
      element.css({
        top: y + 'px',
        left:  x + 'px'
      });
    }
    function mouseup() {
      $document.off('mousemove', mousemove);
      $document.off('mouseup', mouseup);
    }
  };
 })
/**
* try, http://plnkr.co/edit/HL9zaSlApLNMzN6OQlgg?p=preview
modules.json
 [{
   "name": "applications1",
    "url": "^/templates/applications1",
    "parent": "authenticated",
    "abstract": false,
     "views": [{
     "name": "",
     "templateUrl": "html/templates/basicLayout.html"
   }, 
   {
      "name": "header@applications1",
      "templateUrl": "html/templates/header.html"
  }
  ]},
   {
   "name": "login",
   "url": "/login",
   "abstract": false,
   "views": [{
     "name": "",
     "templateUrl": "html/admin/loginForm.html"
   }]
 }]
 .provider('$frdlSMAddState', ['$stateProvider', function $frdlSMAddStateProvider( $stateProvider ) {
    this.$get =  function ($state, $stateParams, $rootScope){
       var newState = $state;	
       try{
   	   var getExistingState =$stateProvider.get(newState.name);
   	      if(getExistingState !== null){
            return getExistingState; 
          }	   	
	   }catch(err){
	   	
	   }
   	  
            var state = {
            name : newState.name,	
            "url": newState.url,
            "parent": newState.parent,
            "abstract": newState.abstract,
            "views": {}
          }; 	  
   	  
   	   frdl.a.forEach(state.views, function(view) {
            state.views[view.name] = {
              templateUrl: view.templateUrl,
            };
      });
   	  
   	  $stateProvider.state( $.extend(state, newState));
   	  
	  return {
	   state,
	   $stateParams,
	   $rootScope
	  };
   };
 }])
*/
 ;
 
 
(function() {
 function initNgFlows(element) {
  	var delay = 1000;
  	if(true !== frdl.angularBootstrapable())return frdl.UI.Compile(delay);
  	
      var moduleElements = frdl.$q('*[ng-flows]:not([flow-bootstrap-value="stop"])', true, element);
      if(0===moduleElements.length)return;
      
    for(var i = 0; i < moduleElements.length; i++) {
          var moduleElement = moduleElements[i];
          
          if(true !== frdl.angularBootstrapable())return frdl.UI.Compile(delay + 250);
          
          if(moduleElement.hasAttribute('flow-bootstrap-value')){
          	  if(new Date().getTime() - 30 * 1000 < parseInt(moduleElement.getAttribute('flow-bootstrap-value'))){
			  	continue;
			  }
  
  
              if(new Date().getTime() - 60 * 1000 > parseInt(moduleElement.getAttribute('flow-bootstrap-value'))){
              	if(moduleElement.getAttribute('ng-flows')  === moduleElement.getAttribute('ng-bootstrapped')){
					 moduleElement.setAttribute('flow-bootstrap-value', 'stop' );
					 moduleElement.setAttribute('flow-bootstrap-stopped', new Date().getTime() );
					continue;	
				}
              	
			  
			  }   
              	if(moduleElement.getAttribute('ng-flows')  === moduleElement.getAttribute('ng-bootstrapped')){
					continue;	
				}			  
			       	
	 	  }  
          
          
          
          if(moduleElement.hasAttribute('ng-flow')){
		  	  moduleElement.setAttribute('ng-flows', ((moduleElement.hasAttribute('ng-flows')) ? moduleElement.getAttribute('ng-flows') + ',' : '') + moduleElement.getAttribute('ng-flow'));
		  	  continue;
		  }
           
          if(moduleElement.hasAttribute('ng-app')){
		  	  moduleElement.setAttribute('ng-flows', ((moduleElement.hasAttribute('ng-flows')) ? moduleElement.getAttribute('ng-flows') + ',' : '') + moduleElement.getAttribute('ng-app'));
		      continue;
		  }         
		  
          if(!moduleElement.hasAttribute('ng-flows'))continue;
          
          
          var _m = str_replace(' ', '', moduleElement.getAttribute('ng-flows'));
          if(''===_m)continue;
          
          
          
          
          if( /* frdl.hasScope(moduleElement) 
               || */ 
                  (
                          moduleElement.hasAttribute('ng-bootstrapped') 
                     &&   str_replace(' ', '',  moduleElement.getAttribute('ng-bootstrapped') ).length >= _m.length
                  )
               ) {
				 continue;
			}          
          
          
          var already =str_replace(' ', '',  moduleElement.getAttribute('ng-bootstrapped') ).split(","); 
        /*  var module = moduleElement.getAttribute('ng-flows').replace(/ /g,'').split(","); */
          var mods = _m.split(","),
                module = [];
          
             
          var f = true, guiFound = false;
          frdl.each(mods, function(i,m){
          	   if(''===m)return true;
          	   if(__GUID_ND__ === m)guiFound=true;
          	try{
				if('object'!==typeof frdl.a.module(m))f=false;
			}catch(err){
				f=false;
				if(1 < frdl.debug.mode())console.log('AngularJS Module "'+m+'" not loaded yet, skipping bootstrap...');
			}
			
			  if(true === f && -1 === already.indexOf(m)){
			  	 module.push(m);  
			  }
          });   
          if(false===f){
             frdl.UI.Compile(delay);
          	continue;       
          }
           if(false === guiFound){
           	 if(-1 === mods.indexOf(__GUID_ND__)){
			 	 moduleElement.setAttribute('ng-flows', moduleElement.getAttribute('ng-flows') + ',' + __GUID_ND__);
			 	 if(-1 === module.indexOf(__GUID_ND__))module.push(__GUID_ND__);  
			 }
		   	 
		   }
          	  if( /* frdl.hasScope(moduleElement)  || */ true !== frdl.angularBootstrapable()
             /*      || moduleElement.hasAttribute('ng-bootstrapped')  */) 
               {
               	  frdl.UI.Compile(delay +250);
				  continue;
			   }
			   
               var b = (moduleElement.hasAttribute('ng-bootstrapped')) ? html_entity_decode(moduleElement.getAttribute('ng-bootstrapped') )+ ',' : '';
               $(moduleElement).trigger('beforebootstrap', [module, mods, already]);
               moduleElement.setAttribute('ng-bootstrapped', htmlentities(b + module.join(','))); 
               frdl.a.bootstrap(moduleElement, module);
                  moduleElement.setAttribute('flow-bootstrap-value', new Date().getTime() );
                  
                if(moduleElement.getAttribute('ng-flows')  === moduleElement.getAttribute('ng-bootstrapped')){
                	
					 moduleElement.setAttribute('flow-bootstrap-value', 'stop' );
					 moduleElement.setAttribute('flow-bootstrap-stopped', new Date().getTime() );
				}
				
               $(moduleElement).trigger('bootstrapped', [module, mods, already]);
   
     }     	
     
  }
  var c = 100;
  frdl.UI.Compile = function(delay){
  	
  	var Func = ('undefined' !== typeof webfan && 'function' === typeof webfan.$Async && false === webfan.$Async instanceof Promise)        
  	              ? webfan.$Async
  	              : setTimeout;
  	  
  	
  	if(!!isNaN(delay))var delay=100;
  	c =  c + 10;
  	if(100 > c)c=100;
  	if(5000 < c)c=5000;
  	if('complete'!==document.readyState || true !== frdl.angularBootstrapable()){
     	Func(function(){
     		frdl.ready(frdl.UI.Compile);
  	    }, delay + c); 		
  		return;
  	}	
  	
  	Func(function(){
      frdl.ready(function(){
        frdl.a.element(document).ready(function() {
               initNgFlows(document);
        });
     });   		
  	}, delay + 1);
 	
 };
 
  
}()); 
});   
  
 
   
   
 
 
  
   
     
   
(function(){
	'use strict';
  
frdl.UI.widgets = [];  
var _i = -1;    
(function(baseObj, funcName) {
 
  funcName = funcName || "Widget";
  
   
   
   
function Widget(c){
	
 var data = {};
 var id = id=++_i;
/* 	
function Widget(config){
	this.id=++_i;
	return this.__construct(config);
}
Widget.prototype.__construct = function(config){
  this.config = config;
  return this;
};	
*/
 var config;
 var __getConfig = function () {
 	var c = config;
 	
    return c;
 };
   
 var __setConfig = function (val) {
 	var _new = val, _old = config;
 	
 	console.warn('Changing widget config is not supported yet (ToDo)');
    
    var merged = $.extend(_old, _new);
    /* e.g. config = merged ; */
 };
   
   
 
 var ReadOnly = function(v){
    console.warn('Trying to set readonly Widget property FAILED: ' + v);	
 };
 	
	
	/* this.instantiated = true;
	return this.__construct(config); */
	
  config = c;
  var defProp = false;
  
  
  if(Object.defineProperty) {
      defProp = true;
  }else if(Object.prototype.__defineGetter__) {
      this.__defineGetter__('config', function(){
      	 return __getConfig(); 
      } );
  }else{
  	  console.warn('Missing Object.defineProperty and Object.prototype.__defineGetter__ - Fallback to UNSAFE configuration readable!');
  	  this.config = config;
  }  
  
  
  
  if(Object.defineProperty) {
       defProp = true;
  }else if(Object.prototype.__defineSetter__) {
      this.__defineSetter__('config', function(val){ 
          return __setConfig(val); 
      } );
  }else{
  	  console.warn('Missing Object.defineProperty and Object.prototype.__defineSetter__ - Fallback to UNSAFE configuration writeable!');
  	  this.config = config;
  }  
    
    
  if(true === defProp){
      Object.defineProperty(this, 'config', {
           get : function(){ return __getConfig(); },
           set : function(val){ return __setConfig(val); } 
      });  
      
      
       Object.defineProperty(this, 'id', {
           get : function(){return id;},
           set : function(val){ return ReadOnly(val); } 
      });       
      	
  }else{
  	 this.id = id; 
  }  
  	
}
             
 	
Widget.prototype.getElement = function(){
	return config.element;
};	
Widget.prototype.getID = function(){
	return this.id;
};
Widget.prototype.deploy = function(){
	
};	
Widget.prototype.data = function(){
 var args = Array.prototype.slice.call(arguments);
	 if(1 === args.length && 'object' === typeof args[0]){
      	for(var k in args[0]){
		   data[k]=args[0][k];
	    }
	 	return this;
	 }else if(1 === args.length && 'string' === typeof args[0]){
	 	return data[args[0]];
	 }else if(2 === args.length && 'string' === typeof args[0]){
	 	data[args[0]] = args[1];
	 	return this;
	 }else if(0 === args.length){
	 	return data;
	 }else{
	 	return undefined;
	 }
	
};	
/*
Widget.prototype.instantiate = function(){
	
};	
Widget.prototype.config = function(){
	
};	
Widget.prototype.create = function(){
	
};	
  .$$on(run)
Widget.prototype.run = function(ev, data){
	if(frdl.debug.mode() >0 )console.log(JSON.stringify(ev) +JSON.stringify(data) );
};	
Widget.prototype.intent = function(){
	
};	
Widget.prototype.flow = function(){
	
};	
*/
	
baseObj[funcName]=Widget;	
}(frdl, 'Widget'));
 
 
 
 frdl.UI.getWidget = function(id){
    var w = null;
 
 /*   
    frdl.UI.widgets = frdl.filter(frdl.UI.widgets, function(w){
    	  return 'undefined' !== typeof w;
    }, false);
    */
    
    if(!isNaN(parseInt(id))){
      frdl.each(frdl.UI.widgets, function(i,wgt) {
    	 if(parseInt(id)===wgt.getID()){
		 	w = wgt;
		 	return false;
		 }
      });		
	}else if('string'===typeof id){
		
      frdl.each(frdl.UI.widgets, function(i,wgt) {
      	var c = wgt.config;
    	 if(  id===c.widget.name._short 
    	   || id===c.id
    	   || id===c.widget.name.__text 
    	   || c.widget._id===id){
		 	w = wgt;
		 	return false;
		 }
      ;})		
	}else if('object' === typeof id || 'function'===typeof id){
		
      w = frdl.UI.widgets[frdl.UI.widgets.indexOf(id)] || null;
     
     if(null===w){
      frdl.each(frdl.UI.widgets, function(i,wgt) {
    	 if(id===wgt.getElement()){
			w = wgt;
			return false;
	   	}
      });		 	
	 } 
			
	 
	}
    return w;
 };
 
 
 
 
}()); 
 
 
 /*
   frdl.UI.widget -> methods (if invoked without argument)  
   
   frdl.UI.widget('<div></div>','frdl/webfan', $('body'), true);
   */
 var _widget = {
        createHtmlWrap : function(el, _link, dest, invokeIfExistsAlready){
        	
      
  	 var u = new frdl.Url(_link);
     var tok = u.getScheme() + '://components/', widgetLoaded = false, eLoaded = false;	
     var url = u.urlMakeNew();
  	 var component = str_replace(tok,'',url); 
  	 
     component = str_replace( u.getScheme() + '://example.com/','',component); 
     component = str_replace( 'widget://','',component);       	
     
     if(true===invokeIfExistsAlready){
     	/*
	 	var widget = frdl.UI.getWidget(component);   
	 	if(null!== widget && 'object'===typeof widget){
	 		$(widget.element).trigger('run', widget.$scope);
			return widget;
		}	 	
	 	*/
	 	var widgetFound = [];
	 	frdl.each(document.querySelectorAll('*[data-frdl-component$="'+component+'"]'),function(i,widgetElement){
	 		var widget = frdl.UI.getWidget(widgetElement.getAttribute('data-frdl-component-widget-id'));
	 		if(null!==widget){
				widgetFound.push(widget);
				$(widgetElement).trigger('run', widget.$scope);
			}
	 	});
	 	if(0<widgetFound.length){
			return widgetFound;
		}
	 }
     
			if('undefined'===typeof dest)var dest = document.body/*querySelector('body')*/;
			el = $(el)
			  /*   .wrapAll('<frdl></frdl>')  */
			     .attr('data-frdl-component', _link)
			     .attr('data-frdl-desktop-widget', _link)
			     .prependTo($(dest))
			 ;
		  setTimeout(function(){
		  	$(document).trigger('readystatechange');
		  },1);	 
			
		}	
 };
  
  frdl.UI.widget = function(el,_link, dest, invokeIfExistsAlready){
  	
  	/* todo : move this to event-state !!! */
  	if('undefined' === typeof jQuery || 'undefined' === typeof $){
	     setTimeout(function(){
 	  	    frdl.UI.widget(el,_link, dest, invokeIfExistsAlready);    
 	    },125);
 	    console.warn('jQuery still undefined in frdl.UI.widget()');
 	    return  _widget;
	}
 	
 	
  	if('object'===typeof el  && el.hasAttribute('data-frdl-component-loaded-script') && 'true'===el.getAttribute('data-frdl-component-loaded-script')){
		return;
	}
  	
  	if('undefined'===typeof el && 'undefined'===typeof _link && 'undefined'===typeof dest ){
	 	return _widget;
	 }
	 if('string'===typeof el && '>' !== el.substr(-1)){
	 	el = document.querySelector(el);
	 	 /*	if('object'!==typeof el){
		
			    
			
			 console.error('Cannot create widget');
			 return;
		} */
	 } else if('string'===typeof el && '>' === el.substr(-1)){
	 	return _widget.createHtmlWrap(el, _link, dest, invokeIfExistsAlready);
	 }  
  		 
  	 if('true' === el.getAttribute('data-frdl-component-initiated') ){
	 	 return;
	 }	 
    
  	 var u = ('string'===typeof _link) ? new frdl.Url(_link) : new frdl.Url(el.getAttribute('data-frdl-component'));
     var tok = u.getScheme() + '://components/', widgetLoaded = false, eLoaded = false;	
     var url = u.urlMakeNew();
  	 var component = str_replace(tok,'',url); 
  	 
     component = str_replace( u.getScheme() + '://example.com/','',component); 
     component = str_replace( 'widget://','',component); 
     	 
      
     if(true===invokeIfExistsAlready){
	 	var widget = frdl.UI.getWidget(component);   
	 	if(null!==widget && 'object'===typeof widget){
	 		$(widget.element).trigger('run', widget.$scope);
			return widget;
		}
	 }
                
      el.setAttribute('data-frdl-component-initiated', 'true');
      	 
     if('components'===u.getHost() || 'example.com'===u.getHost()){
	    url = frdl.route('API_COMPONENT_MAIN', null, null, component);
	    url =  str_replace('/app.js', '', url);
	  }else{
	  	 u.setScheme('http');
	  	 url = u.urlMakeNew();
	  }
	 
	 url = str_replace( 'widget://','http://',url); 
	 
	 
	 if('function'===typeof frdl_webfan_flow_advertising_external_linking){
	 	frdl_webfan_flow_advertising_external_linking(new frdl.Url(url).getHost());
	 }
	 
	 
	 	  	 
 	 var widget_dir = url, createWidgetLink = true;
      if(null === frdl.$q('*[href="'+widget_dir+'"]', false)){
	    	createWidgetLink =true;
      }else{
	  	    
	  	    frdl.each(frdl.$q('*[href="'+widget_dir+'"]'), function(i,el){
	  	    	 if(__WIDGET_REL__ !== el.getAttribute('rel'))return true;
	  	    	 createWidgetLink=false;
	  	    	 return false;
	  	    });
	  }	  
	  
	  
	  if('/' !== url.substr(-1)){
	  	 url += '/';
	  }
	  
	      
        
              frdl.UI.defer();
    
	           $.ajax( {
		   	            url: url + 'config.xml',     
                        crossDomain: true,
                        cache:true,
                        headers: {'X-Requested-With': 'XMLHttpRequest'/*,
                                  'Origin' : new frdl.Url().getScheme() + '://' + new frdl.Url().getHost() */
                                  }, 
                        type: 'GET',  
                        dataType: 'XML',
                        data: {}  
                } )
                .done(function(response) {
                	frdl.UI.defer();
                    var module = module || global;
                	var config = module.widget = wjslX2JS.xml2json(response);
                    if('undefined'===typeof config.widget){
						console.error('Cannot get config file of '+component);
						return false;
					}
					config.directory = url;
				  /*	
                 $( frdl.UI ).trigger( 'flow:widget:instantiate', [ el, component, config ] );
                 var widget = frdl.UI.getWidget(el.getAttribute('data-frdl-component-widget-id'));
                
                 
                 $(el).on('run', {
                 	          widget:widget
                 	   }, function( event, data){
                 	   if(1<parseInt(frdl.debug.mode()))	console.log('widgetElement run event...' + JSON.stringify(data));
                 });
                  */      
              
                 if(!config.widget.content.length){
				 	config.widget.content=[config.widget.content];
				 }
                 
                 var c=0;
                 
                
                 
               frdl.each(config.widget.content, function(i, content){
               	
                
                    	c++;
                    	frdl.UI.defer();
                        eLoaded=false;
                        var _url = (''!==new frdl.Url(content._src).getScheme()) ? '' : url;	
  
 
					    if('text/javascript' === content._type || 'application/javascript' === content._type
					      || 'application/x-javascript' === content._type ){
  					    
  					     if('undefined'!==typeof  content.__cdata){
 					       webfan.$Async(function(){   
  					       	 try{
  					       	 	  module.sourceUrl = url + 'config.xml#'+c;
							 	  eval(content.toString());
							 	   if(c===config.widget.content.length)eLoaded=true;
							  }catch(err){
							 	console.error(err);
							 }
						   },1);
  		  				 }
  		  				 	    
  					     if('string'===typeof  content._src){
  					     	
  					     /*
                           frdl.getScript(_url + content._src, function(){
          	                    
          	                     if(c===config.widget.content.length)eLoaded=true;
                            }, (('once'===content['_data-frdl-require'])?true:false), false);	
                          */ 	 
                            
                            require('5:'+_url + content._src, function(mod) {
	                             if(c===config.widget.content.length)eLoaded=true;
                            }, null, 'application/x-javascript');  
                                         
                         }   
                               	
                                    
    					  	
						}else if('text/html' === content._type ){
						  	
							
						  if('undefined'!==typeof  content.__cdata){
						     webfan.$Async(function(){   	
						  		 $( el ).append( content.toString() );
					          },250);
  		  				  }
						  	
						
				   	        if('string'===typeof  content._src){
				   	        	
				   	        	
							require('5:'+_url + content._src, function(html) {
	                              $( el ).append( html.content );
                             	 if(c===config.widget.content.length) eLoaded=true;
                            }, null, 'text/html');     	        	
				   	        	
				   	        	
						   									
							}else{
								if(c===config.widget.content.length) eLoaded=true;
							}
					  		
                         
					  }else if('text/css' === content._type ){
							  if('undefined'!==typeof  content.__cdata){
  					       	       $( el ).append( '<style type="text/css">'+content.toString() +'</style>');
  		  				      }
  		  				  
			    		  	 if('string'===typeof  content._src){
						  	  
						  	   
						  	  require('5:'+_url + content._src, function(css) {
	                            if(c===config.widget.content.length)eLoaded=true; 
	                            
	                             		try
		                                    {
			                                    var blob = new Blob([css.content], {type: 'text/css'});
		                                    } catch (e) {
		                                        	var bb = new (window.WebKitBlobBuilder || window.MozBlobBuilder);
			                                        bb.append(css.content);
			                                        var blob = bb.getBlob('text/css');
		                                      }
                                         var src = (window.webkitURL || window.URL).createObjectURL(blob);
                                         
                                     frdl.getCSS( src, el, (('once'===content['_data-frdl-require'])?true:false) );
                                          
                              }, null, 'text/css');  
						  	   
						  	 } 
						  	 
						     if(c===config.widget.content.length)eLoaded=true;								
					   }
				    
				    
				  	  
				 });
				  
				 widgetLoaded=true;
				  
				
				 
				  
                 $( frdl.UI ).trigger( 'flow:widget:instantiate', [ el, component, config ] );
                 var widget = frdl.UI.getWidget(el.getAttribute('data-frdl-component-widget-id'));
                                
                 $(el).on('run', {
                 	          widget:widget
                 	   }, function( event, data){
                 	   if(1<parseInt(frdl.debug.mode()))	console.log('widgetElement run event...' + JSON.stringify(data));
                 });  
                     
                     
                     
                     
                     
                     
                         
                    	  if(true===createWidgetLink){
	  	                     var lnk = frdl.Dom.create('link');
	                        lnk.setAttribute('rel', __WIDGET_REL__);
	                        lnk.setAttribute('href', widget_dir);
	                        frdl.Dom.add(lnk, frdl.Dom.getTagNames('head')[0]); 	  	 
	                      } 
	          
                         frdl.addReadyCheck(function(){
  	                            return (true===widgetLoaded && true === eLoaded) ? true : false;
                          });   
                              
                           
                  frdl.ready(function(){
                       		
                   		/* el.setAttribute('data-frdl-component-loaded-script', 'true');	 */
                        el.setAttribute('data-flow-widget', 'config.loaded');
                              frdl.UI.load(); 
                              frdl.UI.Compile(500);
                              frdl.UI.Compile(1500);
                              frdl.UI.load(); 
                              frdl.UI.Compile(5000);
                              
                              webfan.$Async(function(){   
                       		    $(el).trigger('run', [widget]); 
                       		     $(document).trigger('readystatechange')	
                       		  },1500);           	
                      
                 
                     });
                  
                   
                         
       
                })
               .fail(function(jqXHR, textStatus) {
                    console.error('Error: ' +  url + 'config.xml ' + jqXHR.status); 
               })
              .always(function() {
                     if(1<parseInt(frdl.debug.mode()))console.log('Loading widget "' + component+'"...'); 
                    widgetLoaded=true; 
              }); 	 
  };
  
 
 
frdl.ready(function(){	
$( frdl.UI ).on( 'flow:widget:instantiate', {
    engine : {
    	 origin : new frdl.Url(frdl.__FILE__()).getScheme() + '://' + new frdl.Url(frdl.__FILE__()).getHost(),
    	 state : 'dev'
    },
    site : {
    	 origin : new frdl.Url().getScheme() + '://' + new frdl.Url().getHost(),
    	 state : 'dev'
    }
    
}, function( event,  el, component, config ) {
	config.element = el;
	config.element.setAttribute('data-frdl-component-initiated', 'true');
	/* var widget = f$(config); /* .flow...
	if(true===frdl.wd().o.debug)alert(JSON.stringify(widget ));
*/
    var Widget = new frdl.Widget(config);
    frdl.$(Widget);
    frdl.UI.widgets.push(Widget);	                
    config.element.setAttribute('data-frdl-component-widget-id', Widget.id);
      
    el.widget = function(){
	   return frdl.UI.getWidget(el.getAttribute('data-frdl-component-widget-id'));	
	};
    
    $(el).on('run', function(ev, data){
    	 Widget.$$run(ev, data);
    });
   /* 	
    if('undefined'!==typeof frdl.wd() && 'undefined'!==typeof frdl.wd().o && true===frdl.wd().o.debug)console.log('Loading widget://'+JSON.stringify(Widget));
                       
    $( config.element ).trigger( 'flow:widget:create', [ component, Widget, event.data ] );   
    
  console.log('Test trigger widget event 1'); */ 
});
});
  
  
  
  
  var renderFuncs = {
  	
  	
  	
  	'forMobile' : function(){
  	   var initialPageWrap = frdl.$q('body *[data-role="page"]');
	   if(0 === initialPageWrap.length){
				$('body' ).wrapInner( '<div data-dom-cache="false" data-role="page" data-frdl-mod="nodesktop" id="nodesktop-'+ str_replace('.', '-', new frdl.Url().getHost()) + '-' + Sha1.hash(new frdl.Url().urlMakeNew()) + '-' + Sha1.hash(document.title) +'" style="top:0px;left:0px;right:0px;bottom:0px;height:auto;width:auto;"></div>' );
	   }    	
	  	try{
   
    console.log('Prepare for jqm');
     
      if(true===frdl.UI.isMobileTheme){
	  	 console.warn('REDUNDANT: Prepare for jqm');
	  	return;
	  }
     
        frdl.watchFor('a[href*=":\/\/"]:not([data-flow-prepared-frdl-ajax-link-boddystripped*="true"]):not([frdl-ajax-link-boddystripped])').every(function(el){ 
     /* frdl.watchFor('a[href]:not([data-flow-prepared="true"]):not([frdl-ajax-link-boddystripped])').every(function(el){*/
         el.setAttribute('data-flow-prepared-frdl-ajax-link-boddystripped', 'true');  
         $(el).attr('rel', 'external');
      });
      
     	  webfan.$Async(function(){
     	  	$.mobile.pushStateEnabled = false;	
     	    $.mobile.hashListeningEnabled = false;
          /*  frdl.watchFor('a[ui-sref]:not([data-flow-prepared-ui-sref="true"]):not([frdl-ajax-link-boddystripped])').every(function(el){ */
 
        
           frdl.watchFor('a[ui-sref]').every(function(el){
          	
              setTimeout(function(){
              	 frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
                $(el)
                   .attr('href',  str_replace('##', '#',$(el).attr('href')))
                   .attr('href',  str_replace('##', '#',$(el).attr('href')))
                   .attr('href',  str_replace('##', '#',$(el).attr('href')))
                   .attr('href',  str_replace('#', '',$(el).attr('href')))
                   .attr('href',  '#'+$(el).attr('href'))
                ;
               },750);  
               
           });      	  	
     	  },250);
   
     
          
       	  $('*[data-role="page"]').page({
                         create: function( event, ui ) {
                               $.mobile.pushStateEnabled = false;
                               $.mobile.hashListeningEnabled = false;
                               $.mobile.initializePage();      
                        	   $.mobile.loading( 'hide' ); 
                         }
           });  
                    
                
                    
                         
            $('*[data-role="page"]').trigger('create'); 
/**/         
          setTimeout(function(){
            $.mobile.pushStateEnabled = false;
             $.mobile.hashListeningEnabled = false;	
          },800);
        
          
          frdl.UI.isMobileTheme = true;                     
          
		}catch(err){
			console.error(err);
		}	  	
	},
	  
	  
	  
   'forMinimal' : function(){
   	/* Deprecated   data-mod-framed   !!! */
	        $('*[data-mod-framed="no"]').hide();
		 	$('*[data-mod-framed="yes"]').show();
		 	
		 	$('*[data-wd-onreduce="hide"]').hide();
	  },	  
	  
	  
   'forFullscreen' : function(){
   		/* Deprecated   data-mod-framed   !!! */
		 	$('*[data-mod-framed="no"]').show();
		 	$('*[data-mod-framed="yes"]').hide();  	
    },
    
    /*
     Roko C. Buljan
     http://stackoverflow.com/questions/6258521/clear-icon-inside-input-text
    */
    'addClearableInputs' : function(){
    	console.deprecated('Using the jQuery plugin is prefered instead of addClearableInputs fn!');
    	frdl.Dom.createCSSClass('.flow-clearable', "background: #fff url('') no-repeat right -10px center;  border: 1px solid #999;  padding: 3px 18px 3px 4px;   border-radius: 3px; transition: background 0.4s;");
    	frdl.Dom.createCSSClass('.flow-clearable.x', "background-position: right 5px center;");
    	frdl.Dom.createCSSClass('.flow-clearable.onX', "cursor: pointer;");
    	frdl.Dom.createCSSClass('.flow-clearable.-ms-clear', "display: none; width:0; height:0;");
    	
		function tog(v){return v?'addClass':'removeClass';} 
        $(document).on('input', '.flow-clearable', function(){
             $(this)[tog(this.value)]('x');
        }).on('mousemove', '.x', function( e ){
             $(this)[tog(this.offsetWidth-18 < e.clientX-this.getBoundingClientRect().left)]('onX');
        }).on('touchstart click', '.onX, .x', function( ev ){
              ev.preventDefault();
             $(this).removeClass('x onX').val('').change();
        });
      
         $('*[data-clear-btn="true"]').addClass("flow-clearable"); 
      	 $('.flow-clearable').trigger("input"); 
	},
	'inputSearchPolyfill':function(){
/*
* https://github.com/dwiyatci/jquery-inputsearch
* License: WTFPL https://raw.githubusercontent.com/dwiyatci/jquery-inputsearch/master/WTFPL-LICENSE.txt
            DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
                    Version 2, December 2004
 Copyright (C) 2004 Sam Hocevar <sam@hocevar.net>
 Everyone is permitted to copy and distribute verbatim or modified
 copies of this license document, and changing it is allowed as long
 as the name is changed.
            DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
  0. You just DO WHAT THE FUCK YOU WANT TO.
*/
/**
 * jQuery plugin for automagically transforming `input[type="text"]` elements
 * into `input[type="search"]`-like elements.
 * @author Glenn Dwiyatcita
 * @date 20.08.2015
 * @version 0.2.0
 */
(function ($) {
    $.fn.inputSearch = function (options) {
        var elements          = this,
            searchIconImgData = '' +
                                'AAABAAAAAQCAQAAAC1+jfqAAAASklEQVR42mNwZcAPGe' +
                                'itQMn1PxwqYVMAktAHQxALqwJ9V15XDiDWx62AA0hzYF' +
                                'egjt8ESajjcLhBCsn9WH0BEdTBHQ4gackBigsAp89pbW' +
                                'KQMm4AAAAASUVORK5CYII=',
            clearIconImgData  = '' +
                                'AAABAAAAAQCAQAAAC1+jfqAAAAdklEQVR42pWRPQ7AIA' +
                                'iFuVknFk9hwuxZXBwdvCkFa9X607R5Azzel6gICO+C74' +
                                'DBhFyUxA2Aq+Et1wNmilWmATEPSDqtIJ3W2AAugUb0nP' +
                                'QAl5CqnwCbnd0BV2hXR4TlJUMDcPlM7BdFU0zjqg/0Nf' +
                                'Ti/n/WRic9QaXT/imcNgAAAABJRU5ErkJggg==';
        options = $.extend({
            searchIconVisible: true,
            onClear          : $.noop
        }, options);
        var observer = null;
        if (window.MutationObserver) {
            observer = new MutationObserver(function (mutations) {
                mutations.forEach(function (mutation) {
                    $(mutation.target).data()
                        .refreshWrapperVisibility();
                });
            });
        }
        return elements
            .filter('input')
            .each(function () {
                var wrapper = $('<div>')
                        .addClass('jis-input-wrapper')
                        .css({
                            display : 'inline-block',
                            position: 'relative'
                        });
                    var icon    = $('<img>')
                        .attr({
                            src    : searchIconImgData,
                            'class': 'jis-icon-search'
                        })
                        .css({
                            position  : 'absolute',
                            width     : 16,
                            height    : 16,
                            visibility: options.searchIconVisible ?
                                        'visible' : 'hidden'
                        })
                        .on('click', function () {
                            if ($(this).hasClass('jis-icon-clear')) {
                                i
                                    .val('')
                                    .focus()
                                    .triggerHandler('input');
                                options.onClear();
                            }
                        });
                   var i   = $(this)
                        .data({
                            refreshWrapperVisibility: function () {
                                i.parent('.jis-input-wrapper').css({
                                    display   : i.css('display'),
                                    visibility: i.css('visibility'),
                                    opacity   : i.css('opacity')
                                });
                            }
                        })
                        .on('input', function () {
                            var query = $(this).val(),
                                src   = icon.attr('src');
                            if (query.length > 0) {
                                if (src !== clearIconImgData) {
                                    icon
                                        .attr('src', clearIconImgData)
                                        .toggleClass('jis-icon-search', false)
                                        .toggleClass('jis-icon-clear', true)
                                        .css({
                                            cursor    : 'pointer',
                                            visibility: 'visible'
                                        });
                                }
                            } else {
                                if (src !== searchIconImgData) {
                                    icon
                                        .attr('src', searchIconImgData)
                                        .toggleClass('jis-icon-search', true)
                                        .toggleClass('jis-icon-clear', false)
                                        .css({
                                            cursor    : 'auto',
                                            visibility: options.searchIconVisible ?
                                                        'visible' : 'hidden'
                                        });
                                }
                            }
                        })
                        .wrap(wrapper)
                        .after(icon);
                var visible = i.is(':visible');
                i.show();
                var gutter        = 4,
                    paddingRight  = icon.outerWidth() + gutter,
                    width         = parseFloat(i.css('width')),
                    adjustedWidth = width - paddingRight,
                    position      = i.position();
                i.css({
                    width       : adjustedWidth,
                    paddingRight: paddingRight
                });
                icon.css({
                    top : position.top + (gutter / 2),
                    left: position.left + adjustedWidth + gutter
                });
                /*if (null!==observer) { 
                	try{
						 observer.observe(i, { attributeFilter: ['style'] });
					}catch(err){
						 if(0<frdl.debug.mode()){
						 	console.error(err);
						 }else{
						 	console.warn(err);
						 }
					}
                   
               } else { */
                 var _I =function () {
                 	  try{
					    if('function'===typeof i.data().refreshWrapperVisibility) i.data().refreshWrapperVisibility();	
					  }catch(err){
					  	clearInterval(_I);
					  }
                   }; 
               
                    setInterval(_I, 200);
                 /*}*/
                if (!visible) {
                    i.hide();
                }
                i.triggerHandler('input');
            });
    };
}(jQuery));
      frdl.watchFor('*[data-search-btn="true"]:not([data-flow-prepared*="true"])').every(function(el){
      	 frdl.$j(el).attrAdd('data-flow-prepared', 'true'); 
         $(el).inputSearch({ searchIconVisible: true});
      });
      frdl.watchFor('*[data-clear-btn="true"]:not([data-flow-prepared*="true"])').every(function(el){
      	 frdl.$j(el).attrAdd('data-flow-prepared', 'true'); 
         $(el).inputSearch({ searchIconVisible: false});
      });
	}
/*eo inputSearchPolyfill */	
	,'default' : function(){
	 
  
	}
	  	 
	  	  
  };
  frdl.UI.rendering = function(o){
  	
   
  	
  	 if('string' === typeof o){
	 	o = {
		   action : o 	
		};
	 }else if('function' === typeof renderFuncs[o.action]){
	 	o=o;
	 }else  {
	 	o = {
		   action : 'default' 	
		}; 	
	 }
	 
	  renderFuncs[o.action]();
	 return frdl.UI;
  };  
  
  
  
  
  
  
  frdl.ready(function(){
  	  frdl.UI.rendering('inputSearchPolyfill');  
  });
   
   
   
   
   
   
   
 if('function' !== typeof frdl.lang){ 
     	frdl.lang = function(langStrings, allSelectors, registeredSelectors){
          frdl.getScript(frdl.route('API_COMPONENT_MAIN', null, null, 'locale'), function(){
          	 frdl.ready(function(){
          	 	frdl.lang(langStrings, allSelectors, registeredSelectors);
          	 });  
          	   
          	   
          }, true, false);
        }; 	
  
 }
        
 if('function' !== typeof frdl.translate){
 	
   frdl.translate = function(lang, allSelectors, registeredSelectors){
  
         frdl.getScript(frdl.route('API_COMPONENT_MAIN', null, null, 'locale'), function(){
          	 frdl.ready(function(){
          	 	frdl.translate(lang, allSelectors, registeredSelectors);
          	 });  
          	   
          	   
          }, true, false);
   }; 	
        
 }              
        
        
 if('function' !== typeof frdl.langstr){
   frdl.langstr = function(modul){
   	
         frdl.getScript(frdl.route('API_COMPONENT_MAIN', null, null, 'locale'), function(){
          	frdl.ready(function(){
          	 	 frdl.langstr(modul);
          	 });  
          	   
          	   
          }, true, false);
   }; 	
        
 }   
 
          
          
          
          
    
  
 
   
   
               
               
  
  
  
window.addEventListener("online", function() {
/*    */
  console.log('Welcome back online...!');
}, true);
 
 
window.addEventListener("offline", function() {
 var str = 	"You're now offline. The application may not work as expected until you go online again.";
  if(0<parseInt(frdl.debug.mode())){
  	alert(str);
  }
  console.log(str);
}, true);
  
  
  
window.addEventListener("beforeunload", function() {
var debugmode =  frdl.debug.mode();	
if(null===debugmode || undefined=== debugmode || isNaN(debugmode))debugmode=0;
  if('undefined'!==typeof frdl && 'undefined'!==typeof frdl.$DB)frdl.$DB.save('settings/debugmode',  parseInt(frdl.debug.mode()));
}, true);
(function(){
 frdl.ready(function(){
  webfan.$Async(function(){
	var debugmode =  frdl.$DB.load('settings/debugmode');
	if(null===debugmode || undefined=== debugmode || isNaN(debugmode))debugmode=0;
	if(!isNaN(debugmode)){
		  frdl.debug.mode(parseInt(debugmode));  
		  if(0<parseInt(debugmode)){
		  	$(document).ready(function(){
		  	  frdl.alert.log('DEBUG ENABLED ('+frdl.debug.mode()+')');	
		  	});
		  }
	}  	
  	
  },250);	
 });	 
}());
               
               
       /*        
 
frdl.addReadyCheck(function(){
  	     return ('complete' === document.readyState) ? true : false;
});   
    */
    
(function(){
	
frdl.watchFor('iframe:not([frdl-nwtrusted])').every(function(el){
	 frdl.$j(el).attrAdd('data-flow-prepared', 'true'); 
     $(el)  
           
           .attr('nwdisable', 'true')
	       .attr('nwfaketop', 'true')
	       ;
 });		
	
	
frdl.ready(function(){		
 var obs = frdl.watchFor('*[data-frdl-component*=":"]:not([data-frdl-component-initiated="true"])').every(function(el){
    frdl.UI.widget(el);
	
 });	
});
/* frdl.UI.rendering('default'); 
	
document.addEventListener("mobileinit", function(){
      $.extend(  $.mobile , frdl.UI.o.jQueryMobile.o);
});*/ 
     $( window ).one( "mobileinit", function() {
         $.extend(  $.mobile , frdl.UI.o.jQueryMobile.o);
     });  	
	
frdl.ready(function(){	
 frdl.UI.load();
  var loadComponents = function(opts){
      
 
	      
     frdl.each(frdl.$q('*[data-frdl-component*=":"]:not([data-frdl-component-initiated="true"])'),  function(i,el){
     	if('true'===el.getAttribute('data-frdl-component-initiated') || 'config.loaded'===el.getAttribute('data-flow-widget')
     	  || 'true'===el.getAttribute('data-frdl-component-loaded-script') ){
			return;
		}
	 	
 
     
         var url = null;
         var u = new frdl.Url(el.getAttribute('data-frdl-component'));
  	     var tok = u.getScheme() + '://components/';	
  	     var component = str_replace(tok,'',el.getAttribute('data-frdl-component')); 
    	  
     	 var version = el.getAttribute('data-frdl-component-version');
          if('string' === typeof version && '' !== version && '*' !== version && 'master' !== version && 'dev-master' !== version)component += '/' + version;
         var version_query = el.getAttribute('data-frdl-component-version_query');
         
          	/*  <a rel="widget"
   href="http://example.org/exampleWidget">
   The Example Widget
</a>  
       
         $( el ).wrapAll( "<frdl></frdl>" );
      */   
         
      if(''===u.getScheme()){
	     url = component + (2>(explode('.',u.getFile()).length) ? '/app.js' : '');
	  }else if('flow' === u.getScheme()){
	  	 url = frdl.route('API_COMPONENT_MAIN', null, null, component);
	  }	else if('widget' === u.getScheme()){
	  	return  frdl.UI.widget(el);
	  }	
	  console.log('You SHOULD use the widget:// flow as the flow:// scheme has limited functionallity! ('+url+')');
    
	  
	  
	  var widget_dir = str_replace('/app.js', '', url), createWidgetLink = true;
      if(0 === document.querySelectorAll('*[href="'+widget_dir+'"]').length){
	    	createWidgetLink =true;
      }else{
	  	    
	  	    frdl.each(frdl.$q('*[href="'+widget_dir+'"]'), function(i,el){
	  	    	 if(__WIDGET_REL__ !== el.getAttribute('rel'))return true;
	  	    	 createWidgetLink=false;
	  	    	 return false;
	  	    });
	  }	  
	  
	  if(true===createWidgetLink){
	  	 var lnk = frdl.Dom.create('link');
	     lnk.setAttribute('rel', __WIDGET_REL__);
	     lnk.setAttribute('href', widget_dir);
	     frdl.Dom.add(lnk, frdl.Dom.getTagNames('head')[0]); 	  	 
	  }
 	  
	  
	  
	  
	  
      if('string' === typeof version_query && '' !== version_query){
        	var u=new frdl.Url(url);
        	u.setParam('version', version_query);
        	url=u.urlMakeNew();
      }
     
       if(null!==url){
          frdl.getScript(url, function(){
          	   el.setAttribute('data-frdl-component-loaded-script', 'true');
          	   frdl.ready(function(){frdl.UI.Compile(100)}); 
 
                
          }, false, false);	   	
	   }
          
     });
  };
  
  /*
   	setTimeout(function(){
 		loadComponents({});    
 	},1);
  */
 
frdl.Hash.pushState(false);	 
frdl.Hash.on('/app=([A-Za-z0-9_-]+)', function(path, parts) {  
 	if(frdl.debug.mode() >1 )console.log('Loading workspace, app: '+ parts[1]);  
 	frdl.wd(true);
 });	
	
	
frdl.ready(function(){	
 frdl.UI.Compile(500);
 document.addEventListener('readystatechange', frdl.UI.Compile) ; 
	
   	setTimeout(function(){
 		loadComponents({});    
 	},250);
 	
 document.addEventListener('readystatechange', function(){
 	setTimeout(function(){
 			frdl.ready(loadComponents);
 	},100);
 
 }) ;  
	
 	  		
});	
});
/*
 window.addEventListener("hashchange", function(){
 	setTimeout(function(){
 	  $(document).trigger('readystatechange')	;
 	},1);
 });
*/
/* frdl.ready(function(){ */
	
$(document).ready(function(){
 if(true===frdl.UI.reduced()){
     frdl.UI.rendering('forMinimal');
 }else{
	    frdl.UI.rendering('forFullscreen');
	 }    
 
  if(  /*    false === frdl.Device().isDesktop
  	    || true === frdl.Device().frdlApp
  	  || true === frdl.Device().isApp*/
  	      (true === frdl.Device().isTouchable && 'Explorer' !== frdl.Device().browser)
  	   || true === frdl.Device().isMobile 
  	   || true === frdl.Device().isTablet 
  	   || true === navigator.isMobile 
  	   || true === navigator.isTablet 
  	  /* ||  false === frdl.Device().isDesktop */
  	){
	           frdl.UI.rendering('forMobile');
        }
});
 
/* }); */
		
}());	
 
 frdl.UI.emitter.once('boot gui components', function(){
	console.log('boot gui components');
	console.dir(this);
	console.dir(arguments);
	
	
	frdl.ready(function(){
	 webfan.$Async(function(){
	  if('undefined' === typeof frdl.UI.progress){
		 $('body').prepend('<webfan name="webfan/progressbar" type="widget"></webfan>');
	  }		 	
	},500);	 		
   });
});
(function(){
  'use strict';
 var _clean_frdl = frdl;
 var _clean_webfan = frdl.overload(webfan);
 
frdl.noConflict = function() {
  return _clean_frdl;
};
webfan.noConflict = function() {
  return _clean_webfan;
};
}());
  	
require.state.emit('resolved', {
	identifier : 'frdl.UI',
	module : frdl.UI
});
require.state.emit('resolved frdl.UI', {
	identifier : 'frdl.UI',
	module : frdl.UI
});
		    
}(typeof exports !== 'undefined' ? global : (typeof this !== 'undefined' ? this : window)));
 |