| /*! webfan (C) Till Wehowski, Webfan.de - All rights reserved. */
/*! @ frdl.Frdlweb.js.Compiler.es6 : no */
/*! @ frdl.Frdlweb.js.Compiler.defaultPlugin : frdlcjs */
define(function(require, exports, module){
"use strict";
    let webfan = frdl.webfan;
    frdl.Device();
  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'),
          pushStateEnabled : frdl.route('jQueryMobile.pushStateEnabled'), 
          ajaxEnabled: frdl.route('jQueryMobile.ajaxEnabled'),
          linkBindingEnabled : frdl.route('jQueryMobile.linkBindingEnabled'),
          hashListeningEnabled : frdl.route('jQueryMobile.hashListeningEnabled')
 	 };    
  
 var DBPFX= 'frdl/WebfanDesktop/';
  		
				  
let UI  = frdl.extend( {
 	 o :{
 	 	 
 	 	 DBPFX : DBPFX,
 	 	 LOCAL_MACHINE_CURRENT_USER : (JSON.parse( frdl.base64_decode(
		   	                                     localStorage.getItem(DBPFX + 'LOCAL_MACHINE_CURRENT_USER/')
		   	                                   )) || 'anonymous'),
	 	                                   
	 	 Main : {
  	                 StatusBarStyle : 'lightblue'
                },
         jQueryMobile : {
  	    	o: $.extend({
                  loadingMessage : 'Loading...',
                  pageLoadErrorMessage : 'Error Loading Page',
                  allowCrossDomainPages : true,
                  defaultPageTransition : 'fade',
                  overlayTheme: "d",
                  theme : 'd',
                  pageLoadErrorMessageTheme : 'e'		
	          }, jQueryMobile)
	    },
	    jQueryUI : {
			req : function(callback, args){
				return reqUI(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  = {};
										 try{
 	 	var c = frdl.explode('\/', component);
         s._TOK_ = '*[data-frdl-component$="'+((2===c.length) ? c[0]+'\\/'+c[1] : component)+'"]';
  
         s.Url = new frdl.Url(file);
         s.__DIR__ = s.Url.getScheme() + '://' + s.Url.getHost() + '/' + s.Url.getDirectory();	
										 }catch(er){
										   console.warn(err);
										 }
         return s;	
     },
     
     
     browse : function(url, title){
     	   var jDialogBox = frdl.$q('*[id="wd-dialogs-box"]', false);
     	
	 		if('function'===typeof window.Tabs){
			   window.Tabs().addTab((title || ''),  url, null, 'browser', true, undefined, true);  
			}else if('function'===typeof window.top.Tabs && 'function'===typeof window.top.Tabs().addTab){
				    window.top.Tabs().addTab((title || ''),  url, null, 'browser', true, undefined, true);  						
			     }else if(null!==jDialogBox){
				    $(jDialogBox).wd_dialogs({loadUrl : url, title : (title || '')});							
			     }else{
				 	 webfan['$win open'](url);
				 }
	 },
	 
	 
	 
	 fetchAngularFrdlForm : function(id, scopeOffset){
	 	//<frdl-form frdl-form-id="newproject"><select ng-model="newproject.type">
        var  Form = {};
        frdl.each(frdl.$q('*[ng-model]', true, frdl.$q('*[frdl-form-id="'+id+'"]', false)), function(i, el){
        	        var a = el.getAttribute('ng-model');
               		var m = frdl.explode('.',a);
        	 		if(null!==m && !isNaN(scopeOffset) && scopeOffset>0){
        	 			m.slice(0, scopeOffset);
        	 		}
					var s = (null!==m) ? m.join('.') : a; 
					 	
        	 if('SELECT'===$(el).prop('tagName')){
        
        	 	try{
					Form[s]=el.options[el.selectedIndex].value || null;
				}catch(err){
					try{
					  Form[s]=el.options[0].value || null;	
					}catch(err2){
						Form[s]=null;
					}
				}
        	 	
			 	return true;
			 }
			 
			 
        	 Form[s]=el.value || null;
        }); 
       return Form;  
	 }
     
 }, new frdl.EventEmitter() );
  
(function() {	
    'use strict';
      	  
  	 var is_on = true; 
  	  
  	   var Bootstrap = {
  	   switchOn : function(a, old){
  	   	
	     if(a !== is_on){
	    	this.since = new Date().getTime();
	
		   this.timerName = setInterval(this.check, 8);
	     }
	
	     if(true===a){
			is_on=true;
	    }else if(false===a){
			is_on=false;
	    }
	
	   if(true===old){
  	     if(true===a){
	 	    window.name = frdl.str_replace(__TOK_DEFER__, '', window.name);
	     }else if(false===a){
	  	    window.name = __TOK_DEFER__  +  frdl.str_replace(__TOK_DEFER__, '', window.name);
	    }
  	   is_on= (window.name !==frdl.str_replace(__TOK_DEFER__, '', window.name)) ? false : true;		
	  }
	
	 return is_on;
    },
   
  	   since : new Date().getTime(),
  	   timeout : 10000,
  	   check : function(){
	   	  if(true === is_on){
		  	clearInterval(this.timerName);
		  }else{
		  	if(new Date().getTime() - 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 UI.Compile()');
				}
				this.switchOn(true);
				UI.Compile(1);
			}
		  }
	   },
	   timerName : 'frdl://Bootstrap.check/' + frdl.microtime() + frdl.mt_rand(1000,9999)
	   
	 };
	 
  
 var loaded$UI=false;
 var reqUI = 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);
 };
 UI.defer(); 
 UI.emitter=new frdl.EventEmitter();
 document.addEventListener('readystatechange', function(ev){
    Bootstrap.since=frdl.time();
 }) ;  
 document.addEventListener("mobileinit", function(){
    $.extend(  $.mobile , UI.o.jQueryMobile.o);
});   
  
  
  
  
   $.fn.getAngularApp = function(el, isolateFrdlTag){ 
  	 var at = 'ng-flows', n;
 	  if(el && 'boolean'!==typeof el){
	 	n = el;
	  }else{
		n = this;
	  } 
	  
	  if('boolean'!==typeof isolateFrdlTag && 'boolean'===typeof el){
	  	var isolateFrdlTag = el;
	  }
	  
	  if(true===isolateFrdlTag && 'FRDL' === $(n).prop("tagName")){
	  	var _flows = $(n).getAngularApp(false);
	  	var _has = $(n).attr('ng-flows');
	  	$(n).data('$injector', '');
	  	if('string'!==typeof _has || ''=== _has){
	  		frdl.$j(n).attrAdd('ng-flows',_flows.flows||'webfan.gui');
		}
	  }
	  var flows = $(n).attr(at);
	  if('string' ===typeof flows && '' !== flows){
	  	 return {
	  	    element : n,
	  	   	flows : flows
	  	 };
	  }
	  
	 if('HTML' === $(n).prop("tagName")){ return false;}
	 return $(n).parent().getAngularApp(isolateFrdlTag);
 };
 
 
 
 
  
}());
 
 
 
(function(){
 frdl.hasScope = function(element){
 	 return ($(element).hasClass('ng-scope')) ? true : false;
 };
  
  
 
 
  
  
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(){	
  'use strict';
  
var obs = frdl.watchFor('frdl').every(function(el){
  el.setAttribute('ng-non-bindable', 'non-bindable');
});
}());
(function(){	
  'use strict';
frdl.watchFor('*[resizable]').every(function(el){
  UI.o.jQueryUI.req(function(e){
  	 $(e).resizable();   
   }, el);
});
}());
(function(){	
 'use strict';
 function cmd_webfan(cmd){
 	
 	    frdl.c(cmd, function(err, data){
 	               if(err){ 	 	
	 	             frdl.alert.error(err);
	 	            return;
	                }
	                    var util = require('util');      
		                frdl.alert.log('<div>'+util.inspect(data)+'</div>');
	 
       }, true, frdl); 
 }	
 
frdl.watchFor('*[flow-mod="command-line"]:not([data-flow-prepared*="listeners"])').every(function(el){
   frdl.$j(el).attrAdd('data-flow-prepared', 'listeners');
   var _onKeySubmit = function(event){
   	
   	 if(event.which === 13) {
   	  event.preventDefault();
   	  event.stopPropagation();
   	  frdl.each(['http', 'https', 'filesystem:'], function(i, scheme){
   	    if(scheme===el.value.substr(0,scheme.length)){
   	   	   UI.browse(el.value,new frdl.Url(el.value).getHost() );
   	   	   el.value='';
	   	  return false;
	    }	  	
	  });	
       if('string'===typeof el.value && ''!==el.value.trim()){
  	     cmd_webfan(el.value); 
  	     el.setAttribute('placeholder', el.value);
   	     el.value='';
	     return false; 	 	
	   }
       return false; 
     }
   }; 
   
   el.addEventListener('keydown', _onKeySubmit);
   el.addEventListener('keypress', _onKeySubmit);
});
}());
 
   
/* browse : function(url, title)
(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(){	
'use strict';	
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;}
		    if(el.hasAttribute('target') && '_blank' === el.getAttribute('target')){return true;}
		  
		  
		     if(el.hasAttribute('onclick') || 'javascript:;'===el.getAttribute('href')){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();
				
			 var __p =false;							 
			 try{ 	
				 
				// if( uHost.getPath() !== location.path ){						 
					frdl.webfan.gui.progress.start();
			         __p =true;
			//	 }						 
				}catch(err){
					 __p =false;					 
				}						 
								 
               
             if(true === frdl.Device().isMobile || true === frdl.Device().isTablet){
               	 $.mobile.loading( 'show' );   
             }  
               
             var dest=null;
             var destMeta=document.querySelector('meta[name="frdl-ajax-link-boddystripped.destination"]');
             if(null!==destMeta){
			 	dest= destMeta.getAttribute('content') ;
			 }
										 
				if(null === dest){
				      dest = document.querySelector( 'body *[role="page"]');
				};		
										 
				if(null === dest){
				      dest = document.querySelector( 'body *[role="main"]');
				};		
										 
				if(null === dest){
				      dest = document.querySelector( 'body .content');
				};		
										 
				if(null === dest){
				      dest = document.querySelector( 'body .content, .ui-content');
				};		
										 
				if(null === dest){
				      dest = document.querySelector( 'body section[role^="nav"]');
				};					 
										 
							
										 
				if(null === dest){
				      dest = document.querySelector( 'body section');
				};								 
			 
						
										 
				if(null === dest){
				      dest = document.querySelector( 'body div');
				};								 
			 
										 
										 
             			
                          		 var OnUnload = function(e){
                             		    e.preventDefault();
                             	     
                             		    return false;
                             		 };
                             		 window.addEventListener('beforeunload', OnUnload);      
									 el.addEventListener('click', 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).children().data('$injector', '');
								//	 $(dest).children().remove();
									  $(dest).html('');	 
										 
									 $(dest).html(html);
   
                             	    	 var newTitle=frdl.explode('-', $('title').text() )[0];
                             		 
                             	
                             		 	  try{
									           newTitle=$(dest).find('meta[name="document.title"]').getAttribute('content');
     								 	  }catch(err){
     								 	       newTitle=document.querySelector('meta[name="document.title"]').getAttribute('content');
									       }
									       
									 	 if('undefined'!==typeof newTitle){
									 	 	$(document.querySelector('title')).text(newTitle);  
									      }
 
									 	 try{
									 	    $(document).scrollTop(0);
									 	 }catch(err){
									 
									       }
									       
								
                                        
									 	 
									 	   if(true === frdl.Device().isMobile || true === frdl.Device().isTablet){
									 	  
	                                     
	                                           $(dest).trigger('create');
	                                     
	                                                
                                                $.mobile.loading( 'hide' );   
	                                       }    
										 
										 
										 ev.stopPropagation();  
										 
										 var newState = {		
										    name : url + '#'+newTitle,		
										    url : url,
                             		    	title : newTitle,
                             		    	sha1 : frdl.Sha1.hash(html),                             		    	
                             		    	l : html.toString().length,
                             		    	fromState : history.state
                             		    };
										 
	                                      // 	 window.history.replaceState({
										 
										 if(history.state && 'undefined' !== typeof history.state.url  && url !== history.state.url ){
										     history.replaceState(newState, newTitle, url); 
										 }else{
										     history.pushState(newState, newTitle, url); 
										 }
                             		   
										                          	
										 
                             		   // ev.stopPropagation();  
										   if(!!__p)frdl.webfan.gui.progress.complete();
                                          $(document).trigger('readystatechange');  
										 
                                         frdl.UI.Compile(1);
										 
                                         webfan.$Async(frdl.inX.translate);
										 
                                       
                             		
								 
                             	
                             }).fail(function(jqXHR, textStatus) {
                             	var str = 'Cannot frdl-ajax-link-boddystripped: ' + url + ' ' + jqXHR.status+ ' '+textStatus;
                                    if(1 < frdl.debug.mode() && frdl.alert)frdl.alert.error(str,  5); 
                                    console.warn(str);
                                    location.href=url;
                             }).always(function() {
                                     window.removeEventListener('beforeunload', OnUnload); 
                             		 el.removeEventListener('click', OnUnload); 
                                        frdl.UI.Compile(1);
										 
                                         webfan.$Async(function(){  
                                           frdl.inX.translate();
                                         },1);         
                            });	
                            
                            
                return false;						     	
	  });
 
     $(element).on('touch', function(ev){
			 $(element).trigger('click', ev ) ;							 
	 });
			
});
 
(function(){	
'use strict';	
(function(){
	
	var scriptNodes = {};
	
  
function ky(src, inline){
  return   src.toString().length 
         + '.'
         + inline.length
         + '.'
         + frdl.Sha1.hash(src.toString() + inline);
}
function emitState(type, error, state,  k, stateId, stateTag,  module, moduleStateTag, scriptNode){
 
 var _state = {
 	state : state,  
 	error : error,
    'id ts s' : k,
      stateTag : {
  	     'id ts c' : stateId,  
 	     error : error,
 	     moduleStateTag : module  
    }	
 };
 
 var State = {
 	type : type,
    state : _state,
 	scriptNode : scriptNode   	
 };	
	
 UI.emit(State); 	
 
 UI.emit('html-tag-typescript', type, State); 
}
function compileTypeScriptElement(){
	var el = arguments[0];
	
		
	 if('true' === el.getAttribute('data-flow-prepared'))return;
  	 if('true' === el.getAttribute('data-flow-parsed'))return;
	 
	   
    el.setAttribute('data-flow-prepared', 'true');  
    el.setAttribute('data-flow-parsed', 'true');  
   console.log('compileTypeScriptElement()');
   
 	var src = (el.hasAttribute('src') ) ? el.getAttribute('src') : false; 
    if(''===el.innerHTML && false ===src){
	  if(0< frdl.debug.mode())console.notice('Empty typescript tag ignored');
	  return;
	} 	
 	
 	var k = ky(src, el.innerHTML);
  
    if('undefined'===typeof scriptNodes[k])scriptNodes[k] = [];
    var scriptNode = {
    	hash : k,
    	'id ts s' : k,
    	element : el 
    };
    scriptNodes[k].push(scriptNode); 
       
  	 emitState('html-tag-typescript before compile', false,'pending', k,  ky(location.href, el.innerHTML), 'state before', '@hidden', 'global scope', scriptNode);
  	 
  	 
  	   var compiler = require.getCompiler('application/typescript');
  	   
  	   
       var AnchorPrefix = '#@ts!'; 
  	   
       var module = new frdl.Registry.Types.Classes.TModule(frdl.main);
       module.sourceURL = (false===src) ? location.href : src;
 
   
 var inlinecode = el.innerHTML;
 //var hc =  require('webfan/frdl.d.ts.txt', false, require.getCompiler('text/plain'), 'text/plain'); 
 require('webfan/frdl.d.ts.txt', function(hc){
 var headercode = hc.content;
	
   	
  if(false ===src){
    (function(){
	   	  	 var module = new frdl.Registry.Types.Classes.TModule(location.href);
	   	  	 module.descriptor =  module.resolve(location.href);	
	   	  	 module.parent = arguments[0];   	  
  	         module.sourceURL = location.href + AnchorPrefix +k;	 
  	         module.source = compiler('\n' + headercode + '\n' +inlinecode, module);
  	         
  	        
      try{	
	  module = eval(module.source);
	  var error = false;
	  var state = 'resolved';
    }catch(err) {
    	module = undefined;
	    console.error(err);
	    var error = err;
	    var state = 'rejected';
    }	
  	         
  	         emitState('html-tag-typescript after finaly', error, state, k, ky(location.href + '#@' + module.sourceURL, inlinecode), 'state after', module, 'module exports : Void', scriptNode);
 	       	         
  	         		
	}(frdl.main)); 	
 }else{
	 module.require('5:'+src, function(){
	   	  	 var module = new frdl.Registry.Types.Classes.TModule(location.href);
	   	  	 module.descriptor =  module.resolve(location.href);	
	   	  	 module.parent = arguments[0];   	  
  	         module.sourceURL = location.href + AnchorPrefix +k;	 
  	         module.source = compiler('\n' + headercode + '\n' + inlinecode, module);
      try{	
	  module = eval(module.source);
	  var error = false;
	  var state = 'resolved';
    }catch(err) {
    	module = undefined;
	    console.error(err);
	    var error = err;
	    var state = 'rejected';
    }	
  	         
  	         emitState('html-tag-typescript after finaly', error, state,  k, ky(location.href + '#@' + module.sourceURL, arguments[0].source + inlinecode), 'state after', module, 'module exports : Void', scriptNode);
 	     
	}, compiler, 'application/typescript');
 }
 
 }, require.getCompiler('text/plain'), 'text/plain');  
 
}
(function o(){
	 frdl.each(frdl.$q('script[type*="typescript"]:not([data-flow-parsed="true"])'), function(i, el){
			 compileTypeScriptElement(el);
	 });	
	webfan.$Async(function(){
       o();
	},10000);
}());
var obs = frdl.watchFor('script[type*="typescript"]:not([data-flow-parsed="true"])').every(function(el){
 compileTypeScriptElement(el);
});
}());
}());
(function(){
'use strict';	
	
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', 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(1===2&&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);
*/	
 frdl.watchFor('body:not([flow-read-header-metadata="true"])').every(function(el){
	el.setAttribute('flow-read-header-metadata', 'true');
   	headerMetadata(document);
}).destroy();
if(null !== frdl.$q('link[rel="manifest"]', false)){
	UI.isWebApp = true;
}else{
	UI.isWebApp = false;
}
}());	
	
	
  
   
   
   
     
  
  
  
  
  
  
  
  
  
(function LoadAngularGUIModule() {
 'use strict';	
function b(){
/*!*
 * Binds a TinyMCE widget to <textarea> elements.
 https://github.com/angular-ui/ui-tinymce/blob/master/LICENSE
 */
frdl.a.module('ui.tinymce', [])
  .value('uiTinymceConfig', {})
  .directive('uiTinymce', ['$rootScope', '$compile', '$timeout', '$window', '$sce', 'uiTinymceConfig', 'uiTinymceService', function($rootScope, $compile, $timeout, $window, $sce, uiTinymceConfig, uiTinymceService) {
    uiTinymceConfig = uiTinymceConfig || {};
    if (uiTinymceConfig.baseUrl) {
      tinymce.baseURL = uiTinymceConfig.baseUrl;
    }
    return {
      require: ['ngModel', '^?form'],
      priority: 599,
      link: function(scope, element, attrs, ctrls) {
        if (!$window.tinymce) {
          return;
        }
        var ngModel = ctrls[0],
          form = ctrls[1] || null;
        var expression, options = {
          debounce: true
        }, tinyInstance,
          updateView = function(editor) {
            var content = editor.getContent({format: options.format}).trim();
            content = $sce.trustAsHtml(content);
            ngModel.$setViewValue(content);
            if (!$rootScope.$$phase) {
              scope.$digest();
            }
          };
        function toggleDisable(disabled) {
          if (disabled) {
            ensureInstance();
            if (tinyInstance) {
              tinyInstance.getBody().setAttribute('contenteditable', false);
            }
          } else {
            ensureInstance();
            if (tinyInstance && !tinyInstance.settings.readonly && tinyInstance.getDoc()) {
              tinyInstance.getBody().setAttribute('contenteditable', true);
            }
          }
        }
        // fetch a unique ID from the service
        var uniqueId = uiTinymceService.getUniqueId();
        attrs.$set('id', uniqueId);
        expression = {};
        frdl.a.extend(expression, scope.$eval(attrs.uiTinymce));
        //Debounce update and save action
        var debouncedUpdate = (function(debouncedUpdateDelay) {
          var debouncedUpdateTimer;
          return function(ed) {
	        $timeout.cancel(debouncedUpdateTimer);
	         debouncedUpdateTimer = $timeout(function() {
              return (function(ed) {
                if (ed.isDirty()) {
                  ed.save();
                  updateView(ed);
                }
              })(ed);
            }, debouncedUpdateDelay);
          };
        })(400);
        var setupOptions = {
          // Update model when calling setContent
          // (such as from the source editor popup)
          setup: function(ed) {
            ed.on('init', function() {
              ngModel.$render();
              ngModel.$setPristine();
                ngModel.$setUntouched();
              if (form) {
                form.$setPristine();
              }
            });
            // Update model when:
            // - a button has been clicked [ExecCommand]
            // - the editor content has been modified [change]
            // - the node has changed [NodeChange]
            // - an object has been resized (table, image) [ObjectResized]
            ed.on('ExecCommand change NodeChange ObjectResized', function() {
              if (!options.debounce) {
                ed.save();
                updateView(ed);
              	return;
              }
              debouncedUpdate(ed);
            });
            ed.on('blur', function() {
              element[0].blur();
              ngModel.$setTouched();
              if (!$rootScope.$$phase) {
                scope.$digest();
              }
            });
            ed.on('remove', function() {
              element.remove();
            });
            if (uiTinymceConfig.setup) {
              uiTinymceConfig.setup(ed, {
                updateView: updateView
              });
            }
            if (expression.setup) {
              expression.setup(ed, {
                updateView: updateView
              });
            }
          },
          format: expression.format || 'html',
          selector: '#' + attrs.id
        };
        // extend options with initial uiTinymceConfig and
        // options from directive attribute value
        frdl.a.extend(options, uiTinymceConfig, expression, setupOptions);
        // Wrapped in $timeout due to $tinymce:refresh implementation, requires
        // element to be present in DOM before instantiating editor when
        // re-rendering directive
        $timeout(function() {
          if (options.baseURL){
            tinymce.baseURL = options.baseURL;
          }
          var maybeInitPromise = tinymce.init(options);
          if(maybeInitPromise && typeof maybeInitPromise.then === 'function') {
            maybeInitPromise.then(function() {
              toggleDisable(scope.$eval(attrs.ngDisabled));
            });
          } else {
            toggleDisable(scope.$eval(attrs.ngDisabled));
          }
        });
        ngModel.$formatters.unshift(function(modelValue) {
          return modelValue ? $sce.trustAsHtml(modelValue) : '';
        });
        ngModel.$parsers.unshift(function(viewValue) {
          return viewValue ? $sce.getTrustedHtml(viewValue) : '';
        });
        ngModel.$render = function() {
          ensureInstance();
          var viewValue = ngModel.$viewValue ?
            $sce.getTrustedHtml(ngModel.$viewValue) : '';
          // instance.getDoc() check is a guard against null value
          // when destruction & recreation of instances happen
          if (tinyInstance &&
            tinyInstance.getDoc()
          ) {
            tinyInstance.setContent(viewValue);
            // Triggering change event due to TinyMCE not firing event &
            // becoming out of sync for change callbacks
            tinyInstance.fire('change');
          }
        };
        attrs.$observe('disabled', toggleDisable);
        // This block is because of TinyMCE not playing well with removal and
        // recreation of instances, requiring instances to have different
        // selectors in order to render new instances properly
        var unbindEventListener = scope.$on('$tinymce:refresh', function(e, id) {
          var eid = attrs.id;
          if (frdl.a.isUndefined(id) || id === eid) {
            var parentElement = element.parent();
            var clonedElement = element.clone();
            clonedElement.removeAttr('id');
            clonedElement.removeAttr('style');
            clonedElement.removeAttr('aria-hidden');
            tinymce.execCommand('mceRemoveEditor', false, eid);
            parentElement.append($compile(clonedElement)(scope));
            unbindEventListener();
          }
        });
        scope.$on('$destroy', function() {
          ensureInstance();
          if (tinyInstance) {
            tinyInstance.remove();
            tinyInstance = null;
          }
        });
        function ensureInstance() {
          if (!tinyInstance) {
            tinyInstance = tinymce.get(attrs.id);
          }
        }
      }
    };
  }])
  .service('uiTinymceService', [
    /**
     * A service is used to create unique ID's, this prevents duplicate ID's if there are multiple editors on screen.
     */
    function() {
      var UITinymceService = function() {
   	    var ID_ATTR = 'ui-tinymce';
    	// uniqueId keeps track of the latest assigned ID
    	var uniqueId = 0;
        // getUniqueId returns a unique ID
    	var getUniqueId = function() {
          uniqueId ++;
          return ID_ATTR + '-' + uniqueId;
        };
        // return the function as a public method of the service
        return {
        	getUniqueId: getUniqueId
        };
      };
      // return a new instance of the service
      return new UITinymceService();
    }
]);	
/*
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;  
                    }, 1);
                };
            }
        };
}); 
 
 frdl.a.module(__APP_NS__, ['frdl']);
 
frdl.a.module(__GUID_ND__, [__APP_NS__ , 'ngTouch', 'csrf-cross-domain', 'oc.lazyLoad', 'ui.router', 'ui.tinymce'])
 .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
	  };
   };
 }])
*/
//http://jsfiddle.net/bYUa3/2/
//http://stackoverflow.com/questions/15417125/submit-form-on-pressing-enter-with-angularjs
/**
    $scope.keylog = [];
    $scope.keyCount= 0;
    
    $scope.handleKeypress = function(key) {
        $scope.keylog.push(key);
    };
    
     <h3>detect key in controller</h3>
    <input on-keyup-fn="handleKeypress">
    <br />Key Log: {{keylog}}
    <hr />
    <h3>detect key in directive</h3>
    <!--27,13 = escape, enter-->
    <input on-keyup="keyCount = keyCount+1" keys="[27,13]">
    <br />Times escape or enter pressed: {{keyCount}}
       
*/    
  .directive('onKeyupFn', function() {
    return function(scope, elm, attrs) {
        //Evaluate the variable that was passed
        //In this case we're just passing a variable that points
        //to a function we'll call each keyup
        var keyupFn = scope.$eval(attrs.onKeyupFn);
        elm.bind('keyup', function(evt) {
            //$apply makes sure that angular knows 
            //we're changing something
            scope.$apply(function() {
                keyupFn.call(scope, evt.which);
            });
        });
    };
  })
 .directive('onKeyup', function() {
    return function(scope, elm, attrs) {
        function applyKeyup() {
          scope.$apply(attrs.onKeyup);
        };           
        
        var allowedKeys = scope.$eval(attrs.keys);
        elm.bind('keyup', function(evt) {
            //if no key restriction specified, always fire
            if (!allowedKeys || allowedKeys.length == 0) {
                applyKeyup();
            } else {
                angular.forEach(allowedKeys, function(key) {
                    if (key == evt.which) {
                        applyKeyup();
                    }
                });
            }
        });
    };
  })
 ;
}//eo b() 
  
       if('undefined'!== typeof frdl.a && 'function'===typeof frdl.a.module && 'function'===typeof frdl.a.bootstrap ){
	       b();
       }else{
 
                 webfan.$Async(function(){
                   	 LoadAngularGUIModule();
				},3);
  
      
      }	
 // webfan.$Async(function(){
  //   b();
 // },1);
}());  
(function() {
 function initNgFlows(element) {
  	var delay = 1000;
  	if(true !== frdl.angularBootstrapable())return UI.Compile(delay);
  
     	// var moduleElements = frdl.$q('*[ng-flows]:not([flow-bootstrap-value="stop"])', true, element);
      var moduleElements = frdl.$q('*[ng-flows]', true, element);
      if(0===moduleElements.length)return;
      
    for(var i = 0; i < moduleElements.length; i++) {
          var moduleElement = moduleElements[i];
          
          if(true !== frdl.angularBootstrapable())return 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 = frdl.str_replace(' ', '', moduleElement.getAttribute('ng-flows'));
          if(''===_m)continue;
          
          
          
          
          if( /* frdl.hasScope(moduleElement) 
               || */ 
                  (
                          moduleElement.hasAttribute('ng-bootstrapped') 
                     &&   frdl.str_replace(' ', '',  moduleElement.getAttribute('ng-bootstrapped') ).length >= _m.length
                  )
               ) {
				 continue;
			}          
          
          
        //  var already =frdl.str_replace(' ', '',  moduleElement.getAttribute('ng-bootstrapped') ).split(","); 
        var already =(true===moduleElement.hasAttribute('ng-bootstrapped'))?moduleElement.getAttribute('ng-bootstrapped').split(/\s+|,/):[]; 
        /*  var module = moduleElement.getAttribute('ng-flows').replace(/ /g,'').split(","); */
          var mods = ('string'===typeof _m) ? _m.split(/\s+|,/) : [],
                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){
             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')  */) 
               {
               	  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', frdl.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;
  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() 
  	// || true!==frdl.fs5.polyfill.ready 
  	 ){
     	Func(function(){
     		frdl.ready(UI.Compile);
  	    }, delay + c); 		
  		return;
  	}	
  	
  	Func(function(){
      frdl.ready(function(){
        frdl.a.element(document).ready(function() {
               initNgFlows(document);
        });
     });   		
  	}, delay + 1);
 	
 };
 
  
}()); 
  
 
   
/*
(function(){
	'use strict';	
	
function defaultComponents(){
	
    var w = document.createElement('webfan-widget');
    w.setAttribute('data-frdl-component', frdl.requirejs.s.contexts._.config.paths.components + '/webfan');
    document.querySelector('body').append(w);	
}	
	
 frdl.ready(function(){
 	  frdl.require.nextTick(function(){
 	  	      try{
			       if('undefined'===typeof frdl.Slim.classOf('frdl-web')  || 'undefined'===typeof frdl.de.webfan.cdn.frdl.flow.components.webfan){
				   	  defaultComponents();
				   }else{
				   	
				   }	
			  }catch(err){
			  	     defaultComponents();
			  }
 	  });	
 });
}());
*/
/*
(function(){
	'use strict';	
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(){
	'use strict';
  if('undefined'===typeof frdl.Slim.classOf('webfan-module') ){
     var link = document.createElement('link');
     link.href = frdl.requirejs.s.contexts._.config.paths.components + '/webfan/import-webfan-components.html';
     link.rel = 'import';
     link.async = true;
     document.querySelector('head').append(link); 	
  }
 var uiwidgets = [];     
					
					
					
											 
											 
 
 UI.getWidget = function(id){
    var w = null;
     
    if(!isNaN(parseInt(id))){
      frdl.each(uiwidgets, function(i,wgt) {
    	 if(parseInt(id)===wgt.getID()){
		 	w = wgt;
		 	return false;
		 }
      });		
	}else if('string'===typeof id){
		
      frdl.each(uiwidgets, function(i,wgt) {
      	var c = wgt.config;
    	 if( 
    	 
    	      id===c.id 
    	   || wgt.GUID===id
    	   || c.widget._id===id
    	   || id===c.widget.name._short 
    	   || id===c.widget.name.__text 
    	   || id===c.name
    	){
		 	w = wgt;
		 	return false;
		 }
      });		
	}else if('object' === typeof id || 'function'===typeof id){
		
      w = uiwidgets[uiwidgets.indexOf(id)] || null;
     
     if(null===w){
      frdl.each(uiwidgets, function(i,wgt) {
    	 if(id===wgt.getElement()){
			w = wgt;
			return false;
	   	}
      });		 	
	 } 
			
	 
	}
    return w;
 };
 
 
 
 
 /*
   UI.widget -> methods (if invoked without argument)  
   
   UI.widget('<div></div>','frdl/webfan', $('body'), true);
   */
 var _widget = {
        createHtmlWrap : function(el, _link, dest, invokeIfExistsAlready){
        	
    //   invokeIfExistsAlready=false;
  	 var u = new frdl.Url(_link);
     var tok = u.getScheme() + '://components/', widgetLoaded = false, eLoaded = false;	
     var url = u.urlMakeNew();
  	 var component = frdl.str_replace(tok,'',url); 
  	 
     component = frdl.str_replace( u.getScheme() + '://example.com/','',component); 
     component = frdl.str_replace( 'widget://','',component);       	
     
     if(true===invokeIfExistsAlready){
     	
	 	var widget = 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 = 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);	 
			
		},
		
     getPostdata : function(){
	 	var d = {
				       method : 'POST',
				       sendData : {
				       /*	 specialcontext : 'UI.widgetengine.widget' */
				       }	
			  };
			  
	   return d;		  
	 } 			
 };
  
  
  
 
UI.getWidgetLinks = function(uri){
     var u2 = new frdl.Url(uri);
  	 var u = new frdl.Url(uri);
     var tok = u.getScheme() + '://components/';	
     var url = u.urlMakeNew();
  	 var component = frdl.str_replace(tok,'',url); 
  	 var isExtern = ('components'!==u2.getHost() && 'example.com'!==u2.getHost() 
  	                   && ('http' === u2.getScheme() || 'https' === u2.getScheme() )
  	                 ) ? true : false;
    
     component = frdl.str_replace( 'widget://example.com/','',component); 
     component = frdl.str_replace( u.getScheme() + '://example.com/','',component); 
     component = frdl.str_replace( 'widget://','',component); 
     	 
      
     if(!!isExtern) {
	 	url = component;
	 		 	
	 }else if('components'===u.getHost() || 'example.com'===u.getHost()){
	   // url = frdl.route('WIDGET_STORE_URL', undefined, './'+component, undefined);
	     url = frdl.requirejs.s.contexts._.config.paths.components + '/' + component;
	  }else{
	  	 u.setScheme('http');
	  	 url = u.urlMakeNew();
	  }
	 
     u = new frdl.Url(url);  
	 if('http:'===location.protocol || 'https:'===location.protocol || 'web+'===location.protocol.substr(0,4)
	   || 'filesystem:'===location.protocol.substr(0,'filesystem:'.length)
	 ){
	 	u.setScheme( location.protocol.substr(0,location.protocol.length-1) );
	 }
     url = u.urlMakeNew();
 	 var widget_dir = url;
	  
	  if('/' !== url.substr(-1)){
	  	 url += '/';
	  }
	  
  return {
  	  url : widget_dir,
  	  root : url,
  	  component : component,
  	  config : url + 'config.xml',
  	  isExtern : isExtern
  	  
  };	  
};
 
 
 
   
  var _rewriteUrlCss = function(c, base, ___URL){
  	                             var urlMatchingRegex = /[:,\s]\s*url\s*\(\s*(?:'(\S*?)'|"(\S*?)"?|((?:\\\s|\\\)|\\\"|\\\'|\S)*?))\s*\)/gi;
                                    c = c.replace(urlMatchingRegex, function(fullMatch, url) {
                                        var n = str_replace('"', "'", fullMatch);
                                        return n;
                                    });
                                    c = c.replace(urlMatchingRegex, function(fullMatch, url) {
                                       /// var __U = require('url');
                                       var __U = ___URL;
                                        if ('undefined' === typeof url) {
                                            var _u = frdl.explode('(', fullMatch, 2)[1];
                                            var url = _u.substr(0, _u.length - 1);
                                        }
                                        if ('data:' === url.substr(0, 'data:'.length)) {
                                            return fullMatch;
                                        }
                                        try {
                                            var nu = __U.parse(base).resolve(url);
                                        } catch (err) {
                                            var nu = (base) + url;
                                            if (1 < frdl.debug.mode())
                                                console.warn(err);
                                        }
                                        var nt = str_replace(url, nu, fullMatch);
                                        return nt;
								});
	return c;							
  };
  
  
  
  
  
  
  
  
  
  UI.widget = function(el,_link, dest, invokeIfExistsAlready){
 	
  	if('object'===typeof el  && null!==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);
	 } else if('string'===typeof el && '>' === el.substr(-1)){
	 	return _widget.createHtmlWrap(el, _link, dest, invokeIfExistsAlready);
	 }  
   
   
     var WidgetLinks = UI.getWidgetLinks(('string'===typeof _link) ? _link : el.getAttribute('data-frdl-component'));
 
 	  var url = WidgetLinks.root;
	  
	          
     var url_config = WidgetLinks.config;
	 var component = WidgetLinks.component;
	 var widget_dir = WidgetLinks.url;	
     var isExtern = WidgetLinks.isExtern;
     
     if(true===invokeIfExistsAlready){
	 	var ___widget = UI.getWidget(component);   
	 	if(null!==___widget && 'object'===typeof ___widget){
	 	//	$(___widget.element).trigger('run', ___widget.$scope);
	 	     ___widget.state.emit('run', [___widget]); 
			return ___widget;
		}
	 }
     
   		 
  	 if('true' === el.getAttribute('data-frdl-component-initiated') ){
	 	 return;
	 }	 
	           
   el.setAttribute('data-frdl-component-initiated', 'true');
    
        
	 
	 
	 
	 
	 
	 	  	 
 	 var createWidgetLink = true, widgetLoaded = false, eLoaded = false;
      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;
	  	    });
	  }	  
	  
	 
	 	   
	  UI.defer();		   
			   
	      //  frdl.alert.error('@ToDo: Load Widgets: e.g. '+WidgetLinks.config);
              
            //  require(['frdlcjs!'+WidgetLinks.config], function(Widget){
            //  	           alert(JSON.stringify(Widget));
            //  });
            /*
                let WidgetUrl = new frdl.Url(url) ;
	          //   alert(JSON.stringify(WidgetUrl.getHost()));
	            var host = WidgetUrl.getHost();
	            if(
	             'example.com'===host
	                || 'components' === host 
	            ){
					 WidgetUrl.setHost('webfan.de');
					 WidgetUrl.urlMakeNew();
				}
			*/	
			//	alert(JSON.stringify(WidgetLinks));
			
              require(['require', 'exports', 'module', 'loadXML!'+WidgetLinks.config], function(require, exports, module,widgetXMLObject){
              	           //alert(JSON.stringify(widgetXMLObject));
              	          // console.log('Widget', widgetXMLObject);
              	   
              	   UI.defer();
                	
                	
                	
                	if(!widgetXMLObject.json){
						var str = 'Cannot loadXML '+ url_config + JSON.stringify(widgetXMLObject);
								// alert(str);
						console.error(str);
						console.dir(widgetXMLObject);
								  
						if(0<frdl.debug.mode() && frdl.alert)frdl.alert.error(str);
						return;
					}
                					              	
                // var module = new frdl.Registry.Types.Classes.TModule(url);
                   //var module = new frdl.Registry.Types.Classes.TModule(url_config);
                  
                    // module.sourceURL = url_config + '#';
					
	                if('undefined'===typeof widgetXMLObject.json.widget){
						((0 === frdl.debug.mode()) ? console.warn : console.error)('Cannot get config file of '+component);
						return false;
					}      				
					
					
					widgetXMLObject.json.directory = url;
					widgetXMLObject.json.element = el;					
					var config = widgetXMLObject.json;
                    var Widget = new frdl.Widget(widgetXMLObject); 
                  //  module.Widget = Widget;
                       el.setAttribute('data-frdl-component-widget-id', Widget.id);
                       
                       
      			
			         Object.defineProperty(module, 'Widget', {
			                 'get' : function(){
			                     return Widget;
			                 }
			         });
			          
				     Object.defineProperty(module, 'directory', {
			                 'get' : function(){
			                     return Widget.directory;
			                 }
			         });
			          
                     
                 if(!config.widget.content.length){
				 	config.widget.content=[config.widget.content];
				 }
   
                var c=0;
                var _state = new frdl.EventEmitter;
              var _req = _state.required(['prepared'], function(states){
                	 
			         Widget.boot();    
			           
			         var context={
			         
              	            frdl : frdl,
              	            Widget : Widget,
              	            module : module,
				            exports : new Function(""),
			
			                WebApp : frdl.webfan.myWebApp
                     };
			
			         Widget = Widget.With(context).Widget;
			
			}, Widget, false);
     
               frdl.each(config.widget.content, function(i, content){
                    	c=++c;
                    	UI.defer();
                    
	                  
	                    var _url = (''!==new frdl.Url(content._src).getScheme()) ? '' : url;	
                        var t = frdl.explode('/', content._type);
                        var file = url + 'config.xml#'+c;
                        
                        
					    if(false !== frdl.strpos(t[1], 'script') ){
					    				     if('undefined'!==typeof  content.__cdata){
					    				     	Widget.js({filename: file, js: content.toString()});
											 }	
											 
											if('string'===typeof  content._src){
												   _req.add('loaded ' + content._src );
												    require(['loadPlain!'+WidgetLinks.root + content._src], function(js){
												           	Widget.js({filename: WidgetLinks.root + content._src, js: js.content});
												          // 	alert(JSON.stringify(Widget.js()));
												          _state.emit('loaded ' + content._src, {content:js.content} );
													});
											}		
					    	
					    //	console.log('content', content);
						}else if(false !==  frdl.strpos(t[1], 'html')){
							
							
					  	  if('undefined'!==typeof  content.__cdata){
					  	     Widget.html(content.toString());
  		  				  }
						  	
						
				   	      if('string'===typeof  content._src){
				   	      	       _req.add('loaded ' + content._src );
	                           	  require(['loadPlain!'+WidgetLinks.root + content._src], function(html){
										 Widget.html( html.content );
										 _state.emit('loaded ' + content._src, {content:html.content} );
                            	      
								  });     	        	
				   	  				   	         									
						  }
					  		
 
					  }else if(false !==  frdl.strpos(t[1], 'css') ){
					  			  	
					  	  
							  if('undefined'!==typeof  content.__cdata){
						   	  	 Widget.css(content.toString());
  		  				      }
  		  				      
  		  				  
  		  				  		
			    		  	 if('string'===typeof  content._src){
    					              _req.add('loaded ' + content._src );    
					               require(['loadPlain!'+WidgetLinks.root + content._src], function(css){
									   require(['webfan/bootcache!url'], function(___URL){
												 Widget.css( _rewriteUrlCss(css.content, WidgetLinks.root, ___URL) );   
												  _state.emit('loaded ' + content._src, {content:css.content} );  
									  });
								   });   
								  						   		      	 
    					  	 } 
    					  	 
						  	 				
					   }
			  });
				 
 
                    
                  	el.setAttribute('data-frdl-component-initiated', 'true');
                            
                   
      
                    el.widget = function(){
                    	  throw 'Element.widget() setting method on DOMElement here maybe deprecated';
	                };
    
                                                              
                         
                    	  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]); 	  	 
	                      } 
	          
	          
	            Widget.state.once('loaded', function(){
	            	var widget = arguments[0].widget;
                    UI.emitter.emit('widget.loaded', [widget]); 
                    //widget.element.setAttribute('data-flow-widget', 'config.loaded');
                              UI.load(); 
                              UI.Compile(10);
                              UI.Compile(100);
                              UI.load(); 
                              UI.Compile(1000);
                              
                              webfan.$Async(function(){   
                                 UI.load(); 
                       		     widget.state.emit('run', [widget]); 
                       		     $(document).trigger('readystatechange')	
                       		  },500);  	            	
	            	
	            });
	          
	          
	                _state.emit('prepared', {Widget:Widget} );  
              });//require config.xml (WIDGET)			
	          
};
  
  
 
require(['feature!vm'], function(vm){
 var _a_bootstrapped = [];
 
 
var _i = -1;    
(function(baseObj, funcName) {
 
  funcName = funcName || "Widget";
  
  
customElements.whenDefined('webfan-module').then(function() {
	
	        
  frdl.Slim.plugin('create', element => {
    if (element.localName === 'webfan-widget') {
        element.model = Widget.prototype;
    }
  });	      
   frdl.Slim.tag('webfan-widget',
        `
       <frdl></frdl>
              <slot></slot>
        `,
     class extends frdl.Slim {
           
      attributeChangedCallback(name, oldValue, newValue) {
      	     super.attributeChangedCallback(name, oldValue, newValue);
      	
             if(0< frdl.debug.mode() )  console.log('attributeChangedCallback',arguments);
             
             if(oldValue !== newValue){
			 	  this._updateRendering('attributeChangedCallback', name, oldValue, newValue);
			 }
             
           
       }
  
  
  
      _updateRendering(eventChangeName, name, oldValue, newValue) {
          // Left as an exercise for the reader. But, you'll probably want to
          // check this.ownerDocument.defaultView to see if we've been
          // inserted into a document with a browsing context, and avoid
          // doing any work if not.
            if(0< frdl.debug.mode() ) console.log('_updateRendering',this);
       
          		    if(true!== this.initiated){
						this.tryInit();
					}     
     }
  
  
  
  
            onBeforeCreated() {
               // this.initiated = false;
                
                 //ERROR IN constructor   this.setAttribute('data-role', 'component');
                 //  this.setAttribute('role', 'widget');
            }    
          
    	
           	tryInit(el){
        		    if(true=== this.initiated){
						return;
					}
        		
        		
        		if(!el)el=this;
        		
        		
	                if(el.hasAttribute('data-frdl-component-loaded-script') && 'true'===el.getAttribute('data-frdl-component-loaded-script')){
                         return;
                    }
                   if('true' === el.getAttribute('data-frdl-component-initiated') ){
                          return;
                   }	
                   
                   
                   if(!el.hasAttribute('data-frdl-component') ){
                   	   if(el.dataFrdlComponent){
					   	 el.setAttribute('data-frdl-component', el.dataFrdlComponent);
					   }else if(this.dataFrdlComponent || this.hasAttribute('data-frdl-component')){
					   	  el.setAttribute('data-frdl-component', this.dataFrdlComponent || this.getAttribute('data-frdl-component'));
					   }
				   }
                   
                   this.dataFrdlComponent = el.getAttribute('data-frdl-component');
                   
                   
                   
                    this.initiated = true;
                    this.debug = (el.hasAttribute('debug') && ('true'===  el.getAttribute('debug') || '1'===  el.getAttribute('debug') || 'yes'===  el.getAttribute('debug')  ) ) ? true : false;
                   	UI.widget( 
                     //	$(el).find('slot') 
                      el
                   	);		
			}
            
            onAdded(){
                   this.setAttribute('data-role', 'component');
                   this.setAttribute('role', 'widget');       
                   this.dataset.role = "component";    	
				   this.tryInit();
			}
			
               get useShadow() {
                 return false;
               }			
			
        });//webfan-widget
        
        
});//whenDefined webfan-module        
      
      
    
      
      
   
function Widget(widgetXMLObject){
	
 var data = {};
 var id = id=++_i;
 this.state = 	new frdl.EventEmitter();
 
 this.state.emit('init', {id:id});
 var WidgetXMLObject = widgetXMLObject;
 var c = WidgetXMLObject.json;
 var config;
 
 var __getConfig = function () {
 	var c = config;
 	
    return c;
 };
   
 var _html = [];
 var modules = {};
 
 var _css = [];
 
 var _js = [];
 var _Script = false;
				 
 var __setConfig = function (val) {
 	var _new = val, _old = config;
 	
 //	console.warn('Changing widget config is not supported yet (ToDo)');
 throw 'Changing widget config is not supported yet (ToDo)';
    
    var merged = $.extend(_old, _new);
    /* e.g. config = merged ; */
 };
   
   
 
 var ReadOnly = function(v){
    throw 'Trying to set readonly Widget property FAILED: ' + v;	
 };
 	
	
      Object.defineProperty(this, 'Script', {
           get : function(){ return _Script; },
           set : function(s){ 
				if(false!==_Script){ 
                   throw 'Script of Widget already defined!';
				}
				 
				_Script=s; 
          } 
      }); 
       
	
  config = c;
 var settings = {};
  
       Object.defineProperty(this, 'settings', {
           get : function(){ return settings; }
      });  
       Object.defineProperty(this, 'config', {
           get : function(){ return __getConfig(); }
      });  
      
        Object.defineProperty(this, 'id', {
           get : function(){return id;},
           set : function(val){ return ReadOnly(val); } 
      });
      
           
       Object.defineProperty(this, 'modules', {
           get : function(){return modules;},
           set : function(val){ 
           throw 'Unexpected set of Widget.modules from external';
           //modules = val; 
          } 
      }); 
      
      Object.defineProperty(this, 'XMLDom', {
           get : function(){ return WidgetXMLObject.dom; }
      });      
       
       
       
            
      Object.defineProperty(this, 'directory', {
           get : function(){ return config.directory; }
      });   
      
        Object.defineProperty(this, 'widget', {
           get : function(){ return __getConfig(); }/*,
           set : function(val){ return __setConfig(val); } */
      });
      
         
      Object.defineProperty(this, 'element', {
           get : function(){ return config.element; },
           set : function(val){  config.element=val; }
      });    
      
       Object.defineProperty(this, 'name', {
           get : function(){ return __getConfig().widget.name._short; },
           set : function(val){ 
              throw 'Illegal set of Widget.name '+val;
           } 
      });                 		
	
 	
 
  
  
 
 this.angular = {
   boot : function(THAT){
 
 
 
          //   var $app = frdl.a.module(THAT.GUID, [__APP_NS__]);
           //    var $app = frdl.a.module(THAT.GUID, frdl.a.modules);
        var $app = frdl.a.module(THAT.GUID, ['webfan.gui']);
	        Object.defineProperty(THAT.angular, '$app', {
                 get : function(){ 
                     return $app; 
                 }
            });
            
            
  	
      UI.defer();
  	
  	
  	  if(0 === THAT.angular.modules.length){
	
	
	  	if(0 < THAT.angular.blocks.config.length
	  	 || 0 < THAT.angular.blocks.controller.length
	  	 || 0 < THAT.angular.blocks.run.length
	  	 || 0 < THAT.angular.blocks.provider.length
	  	){
		//	console.warn('Widget angular blocks defined but no parent ng-flows found');
		  if(null===frdl.$q('*[ng-flows]', false, THAT.element)){
		//	var appname = 'WidgetApp_' + THAT.id;
		//	frdl.a.module(appname, ['webfan.gui']);
		//	THAT.angular.modules.push(appname);		  	
		  }else{
		  	// $(config.element).data('$injector', '');
		  }
		}else{
		  	
		  		return UI.load();
		  }
		  
	  
	  }
	
	
     (function(THAT){
       function b(THAT){
       //	if( !!frdl.hasScope(config.element) )return;
       var b = true;
       
       if(0===THAT.angular.blocks.config.length
	   	 && 0===THAT.angular.blocks.controller.length
	   	 && 0===THAT.angular.blocks.run.length
	   	 && 0===THAT.angular.blocks.provider.length){
        	return UI.load();
	   }
	   
     // if(0===THAT.angular.modules.length){
	 //    THAT.angular.modules.push('webfan.gui');	
	    //  return;
 	 // }  
       
 	 // var app = THAT.angular.modules[THAT.angular.modules.length-1];  
 	//  var app = THAT.angular.modules[0];  
 	        
    //  if(-1!== _a_bootstrapped.indexOf(config.widget._id + '___' + app)) b = false;     
   //   _a_bootstrapped.push(config.widget._id + '___' + app);
       var app = THAT.angular.$app.name;
        if(-1!== _a_bootstrapped.indexOf(app)) b = false;     
          _a_bootstrapped.push(app);
          
 //b=true;
// console.dir(app);
  
	   if(!!b){
			 
        frdl.each(THAT.angular.blocks.provider, function(i, block){
  	        frdl.a.module(app).provider(block);
        });  	  		
		 
        frdl.each(THAT.angular.blocks.config, function(i, block){
  	        frdl.a.module(app).config(block);
        });  	  
        frdl.each(THAT.angular.blocks.controller, function(i, block){
  	       frdl.a.module(app).controller(block[0], block[1]);
        }); 
        frdl.each(THAT.angular.blocks.run, function(i, block){
  	       frdl.a.module(app).run(block);
        });        	
      }
       
         $(THAT.element).data('$injector', '');
     //    config.element.setAttribute('ng-flows', THAT.angular.modules.join(','));
    //      THAT.element.setAttribute('ng-bootstrapped', frdl.htmlentities(THAT.angular.modules.join(','))); 
         frdl.a.bootstrap(THAT.element, THAT.angular.modules);    
         UI.load();	 
         
          THAT.state.emit('agularify', {
  	          agularify: THAT.angular,
  	          app : frdl.a.module(app)
          });  
       }	
       
       
       b(THAT);
    }(THAT));
  
  },
  	     modules : [],
  	     element : false,
  	     blocks : {
		 	provider : [],
		 	config : [],
		 	controller : [],
		 	run : []
		 },
		 provider : function(block){
		 	THAT.angular.blocks.provider.push(block);
		 	return THAT.angular;
		 },
		 config : function(block){
		 	THAT.angular.blocks.config.push(block);
		 	return THAT.angular;
		 },
		 controller : function(name, block){
		 	THAT.angular.blocks.controller.push([name, block]);
		 	return THAT.angular;
		 },
		 run : function(block){
		 	THAT.angular.blocks.run.push(block);
		 	return THAT.angular;
		 },
		 flow : function(app){
		 	THAT.angular.modules.unshift(app);
		 	var args = Array.prototype.slice.call(arguments);
     (function(){
       function c(){
          frdl.a.module.apply(frdl.a, args);
       }	
      c();
  
      
    }());		 	
    
    
		 	return THAT.angular;
		 }
 };
  
  
  
  
  
  var THAT = this;
  //var _angularApp = $(config.element).getAngularApp(true);
  var _angularApp = $(config.element).getAngularApp(false);
  // console.dir(_angularApp);
  
  if(false !== _angularApp){
    this.angular.element =  _angularApp.element;
    var _appstr = _angularApp.flows;
    if(
    1=== 0 &&
    
    false !== _appstr){
      frdl.each(_appstr.split(/s+|,/), function(i, appname){
  	     appname = appname.trim();
  	     THAT.angular.modules.push(appname);
      });  	
    }  	
    
    
    
 }else{
   //	 this.angular.element = config.element;
 }
   this.state.emit('agularify.init', {
  	agularify: this.angular
  });
 
    this.css = function(str){
  	 if(!arguments || 0 === Array.prototype.slice.call(arguments).length)return _css;
  	 _css.push(str);
  	 this.state.emit('css.append', {
      	css: str
     });
  	 return this;
  };
    
    this.js = function(str){
  	 if(!arguments || 0 === Array.prototype.slice.call(arguments).length)return _js;
  	 _js.push(str);
  	 this.state.emit('js.append', {
      	js: str
     });
  	 return this;
  };
    
  
 
  
  this.html = function(str){
  	 if(!arguments || 0 === Array.prototype.slice.call(arguments).length)return _html;
  	 _html.push(str);
  	 this.state.emit('html.append', {
      	html: str
     });
  	 return this;
  };
    
  
  this.modul =  function(){
     var args = Array.prototype.slice.call(arguments);
  	 if(0 === args.length || 2 < args.length) throw 'WebApp.modul() expects 1 or 2 arguments!';
  	 
  	
  	 if(1===args.length){
	 	return modules[args[0]];
	 }else if(2  === args.length){
	 	modules[args[0]] = args[1];
         this.state.emit('modul', {
      	   modul: modules[args[0]]
          });	
  		 	
	 	return this;
	 }
  	 return this;
  };
  
 this.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;
	 }
	
};	
 
 this.Config = function(){
 var args = Array.prototype.slice.call(arguments),
       n = false;
 if(0<args.length && 'string' === typeof args[0]){
  n = THAT.settings[args[0]];
 	
 	
 	if(false !== frdl.strpos(args[0], '.')){
		var p = frdl.explode('.', args[0]);
		n = THAT.settings;
		frdl.each(p, function(i, seg){
			 if('undefined'===typeof n[seg]){
			 	 n[seg] = (2 === args.length && i === p.length-1) ? args[1] : {};
			 }
			 
			 n = n[seg];
		});
	}
 }
 
 //console.log('n', n);
 
 
 
	 if(1 === args.length && 'object' === typeof args[0]){
      	for(var k in args[0]){
		   THAT.settings[k]=args[0][k];
	    }
	 	return this;
	 }else if(1 === args.length && 'string' === typeof args[0]){
	 	return n;
	 }else if(2 === args.length && 'string' === typeof args[0]){
	 	n = args[1];
	 	return this;
	 }else if(0 === args.length){
	 	return settings;
	 }else{
	 	return undefined;
	 }
	
};	
  
  
  
 if('undefined'===typeof config.widget.preference_asArray){
   config.widget.preference_asArray = [];
}
 frdl.each(config.widget.preference_asArray,function(k,preference){
 	
    var n = preference._name;
 	var _n = THAT.settings;
 	var Value =  preference._value;
		var p = frdl.explode('.', n);
		_n = THAT.settings;
		frdl.each(p, function(i, seg){
			
			/*
			 if('undefined'===typeof _n[seg]){
			 	 _n[seg] = (i === p.length-1) 
			 	 
			 	 ? new (class {
			 	 	get () {
						return Value;
					}
			 	 	
			 	 }) 
			 	 
			 	 : {};
			 }
			 */
			 if('undefined'===typeof _n[seg]){
			 	 _n[seg] = (i === p.length-1) 
			 	 
			 	 ? Value
			 	 
			 	 : {};
			 }
			 
			 
			 _n = _n[seg];
		});
	
  //  settings[preference._name]=preference._value;
 });	
   
       Object.defineProperty(this, 'Plugin', {
           get : function(){ 
                  var Plugin = frdl.ns.plugin(THAT.config.widget._id);
                  
                  
                       if('undefined'===typeof Plugin.Widget){
                            Object.defineProperty(Plugin, 'Widget', {
                              get : function(){
                            	 return THAT;
                             }
                            }); 				  	
				       }                 
                  
                  return Plugin;
           },
           
           set : function(newPluginContext){ 
                frdl.ns.plugin(THAT.config.widget._id, newPluginContext);
           }         
      });    
      
       
   /*
   var widget=frdl.a;frdl.ns.plugin('test.com', function Widget(TEST2){TEST2.hello='world';debug('Plugin', Plugin);debug('TEST2', TEST2.hello);}).exec(function(){Plugin.hest=TEST2;extend(Widget);debug('Plugin', Plugin);debug('Context', widget);}).Widget = widget;
   */
   
   
     frdl.ns.plugin(THAT.config.widget._id, function $Component(){
               //     	  extend(THAT);
               //   debug('context', context);
               
           extend(Plugin.Widget);     
               
     }, THAT)
     
     .exec(function(Component){
        	 extend(Component);     
      }); 
      
      
     
     
     
      /*                 
      this.Plugin.exec(function(Component){
        	debug('Plugin', Plugin);
        	debug('{$}Component', Component);
        	debug('context', context);
        	debug('this', this);
      });    
   
   */
   
  
       Object.defineProperty(this, 'GUID', {
           get : function(){ 
                 return frdl.ns.plugin(THAT.config.widget._id).id;
           }      
      }); 				  
				  
				  
  uiwidgets.push(this);	      
}
Widget.prototype.boot = function(){
       	var THAT = this;
      	UI.defer();
      	
    
					 function compile_after(code){
 	                     return code;	
	                 }
	     		
      		
          THAT.state.emit('boot', {
  	          widget: THAT
          });  
         //UI.defer();
       	
       	
  	
   // const webfanWidgetElement = document.createElement('webfan-widget');
  //  const shadowRoot = webfanWidgetElement.attachShadow({mode: 'open'});   	
       	
    //   	console.log('webfanWidgetElement', webfanWidgetElement);
   //    	webfanWidgetElement.setAttribute('test', 'widget-test...');
       	
       	
       	
		 var _js = '';									 
     	 frdl.each(THAT.js(), function(i, JS){
  	         //eval(js);
			 _js+= '\n';								 
             _js+=JS.js;
			 _js+= '\n';	
											 
         });          	 
											 
						 
            THAT.Script = vm.createScript(_js, {
                  filename :  THAT.directory + '#*.js',
                  compile : compile_after
            });
            	 
											 
       
	        Object.defineProperty(THAT, 'With', {
                 get : function(){
                 	 var Widget = this; 
                     return function(ctx){
                     	
                      	
    			       var appname = Widget.angular.$app.name + '.$' + Widget.id;
			          // frdl.a.module(appname, ['webfan.gui']);
			           var $app=frdl.a.module(appname, frdl.a.modules);
			           Widget.angular.modules.push(appname);	                 	
                     	
                     	ctx.Widget=Widget;
                     //	ctx.$app=Widget.angular.$app;
                     	ctx.App=$app;
                     	
                     	
                     	//ctx.global=global;
                    // 	ctx.window=window;
                     //	ctx.angular=frdl.a;
                     	
                     	
                     	ctx.Plugin=Widget.Plugin;
                     	
                     	
						if(!Widget.Script)throw 'Widget.With : Script is not prepared';
						
						
						  var HTML = '';
												
					    frdl.each(Widget.css(), function(i, css){
                                HTML += '<style type="text/css">'+css +'</style>';
                        });							  
						  
					      frdl.each(Widget.html(), function(i, html){
				    	 	//var htm = frdl.ns.org.startpad.string.format(html, ctx);
				    	 	 HTML += html;
		                 });  		
	  	      /*           				
		 if(null===frdl.$q('*[ng-flows], *[ng-app], *[ng-module], *[ng-modules], *[ng-flow]', false, Widget.element)
		   && !Widget.element.hasAttribute('ng-flows')
		 ){
			var appname = 'WidgetApp_' + Widget.id;
			frdl.a.module(appname, ['webfan.gui']);
			Widget.angular.modules.push(appname);		  	
		  }else{
		  	
		  	 $( Widget.widget.element ).data('$injector', '');
		     $( Widget.widget.element ).children().data('$injector', '');
		  	
		  }				
*/
				  $( Widget.widget.element ).data('$injector', '');
		          $( Widget.widget.element ).children().data('$injector', '');
				 $( Widget.widget.element ).html('');		
				 
						var appname = 'WidgetApp_' + Widget.id;
						
	
                         var MyHTML = $(HTML);
	  	                 //, *[ng-app], *[ng-module], *[ng-modules], *[ng-flow]  initNgFlows(element)
	  	                 var $flows = $(MyHTML).find('*[ng-flows], *[ng-app], *[ng-module], *[ng-modules], *[ng-flow], *[frdl-bind-context], frdl-bind-context');
	  	                
	  	                 var _context = ctx; 
	  	                     frdl.each( $flows, function(i, $flow){
	  	                        var $binds = $($flow).find('*[frdl-bind-context], frdl-bind-context'); 
			  	               	 if($flow.hasAttribute('frdl-bind-context')){
								 	if('undefined'!==typeof global[$bind.getAttribute('frdl-bind-context')]){
										_context = global[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  frdl[$bind.getAttribute('frdl-bind-context')]){
										_context = frdl[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  ctx[$bind.getAttribute('frdl-bind-context')]){
										_context = ctx[$bind.getAttribute('frdl-bind-context')];
									}
								 }  	                        
	  	                     	 		 
  	                         	 $($flow).attr('ng-flows', frdl.ns.org.startpad.string.format($($flow).attr('ng-flows'), _context) );
  	                         	 $($flow).attr('ng-flows', frdl.ns.org.startpad.string.format($($flow).attr('ng-flows'), ctx) );
  	                         });							
								
						   var $binds = $(MyHTML).find('*[frdl-bind-context], frdl-bind-context');		
		  	                  frdl.each($binds, function(i, $bind){
		  	                  	 var _context = ctx;
		  	                  	 if($bind.hasAttribute('frdl-bind-context')){
								 	if('undefined'!==typeof global[$bind.getAttribute('frdl-bind-context')]){
										_context = global[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  frdl[$bind.getAttribute('frdl-bind-context')]){
										_context = frdl[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  ctx[$bind.getAttribute('frdl-bind-context')]){
										_context = ctx[$bind.getAttribute('frdl-bind-context')];
									}
								 }
								 
								 $($bind).html( frdl.ns.org.startpad.string.format( $($bind).html(), _context)  );
  	                       //  	 $($bind).html( frdl.ns.org.startpad.string.format( $($bind).html(), _context) );
  	                         });								
									
		
						
								
								
      	
						 var WidgetContext = Widget.Script.runInContext(vm.createContext(ctx));						
                        if(Widget.widget.element.hasAttribute('ng-flows')){
							 Widget.widget.element.setAttribute('ng-flows',
							        frdl.ns.org.startpad.string.format(Widget.widget.element.getAttribute('ng-flows'), ctx)
							 ) ;
							 
						
						}
						
						
				 frdl.UI.defer();	
			
						$(Widget.widget.element).append(MyHTML);	
	  	                 var $flows = $(Widget.widget.element).find('*[ng-flows], *[ng-app], *[ng-module], *[ng-modules], *[ng-flow], *[frdl-bind-context], frdl-bind-context');
	  	                
	  	                 var _context = ctx; 
	  	                     frdl.each( $flows, function(i, $flow){
	  	                        var $binds = $($flow).find('*[frdl-bind-context], frdl-bind-context'); 
			  	               	 if($flow.hasAttribute('frdl-bind-context')){
								 	if('undefined'!==typeof global[$bind.getAttribute('frdl-bind-context')]){
										_context = global[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  frdl[$bind.getAttribute('frdl-bind-context')]){
										_context = frdl[$bind.getAttribute('frdl-bind-context')];
									}else if('undefined'!==typeof  ctx[$bind.getAttribute('frdl-bind-context')]){
										_context = ctx[$bind.getAttribute('frdl-bind-context')];
									}
								 }  	                        
	  	                     	 		 
  	                         	 $($flow).attr('ng-flows', frdl.ns.org.startpad.string.format($($flow).attr('ng-flows'), _context) );
  	                         	 $($flow).attr('ng-flows', frdl.ns.org.startpad.string.format($($flow).attr('ng-flows'), ctx) );
  	                         });							
															
						//vm.createContext(ctx)	 
						
				       frdl.UI.load();
	                   frdl.ready(function(){
	                   	  frdl.webfan.$Async(function(){
						  		frdl.UI.Compile(32);
						  },32);
	                  });		  
				       return WidgetContext; 	
				     }; 
                 }
            }); 										 
											 
  											 
  
         	   UI.defer();
         	   THAT.angular.boot(THAT); 	
         	 //  UI.load();
                THAT.state.emit('loaded', {
  	                 widget: THAT
                });         	   
 	
            
        
        
        
 
            
                   
 return this;
};
               
Widget.prototype.on = function(){
	this.state.on.call(this, arguments);
	return this;
};	
Widget.prototype.once = function(){
	this.state.once.call(this, arguments);
	return this;
};
Widget.prototype.emit = function(){
	this.state.emit.call(this, arguments);
	return this;
};
Widget.prototype.dependency = function(){
	return this.state.required.apply(this, arguments);
};
Widget.prototype.getElement = function(){
	return this.element;
};	
Widget.prototype.getID = function(){
	return this.id;
};
Widget.prototype.getWidget = function(tok){
	return UI.getWidget(tok);
};	
	
baseObj[funcName]=Widget;	
}(frdl, 'Widget'));
 
});//require(['feature!vm'], function(vm){
					
					
					
(function(){
	'use strict';	
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');  
	 var n = el.getAttribute('name');
	 if(''=== new frdl.Url(n).getScheme()){
	 	$(el).html('<div data-frdl-component="widget://example.com/'+el.getAttribute('name')+'"></div>') ;
	 }else{
	 	$(el).html('<div data-frdl-component="'+el.getAttribute('name')+'"></div>') ;
	 }
      	
        
    //    $(document).trigger('readystatechange');      
   
  
   return true;	
});
	
frdl.watchFor('*[data-frdl-component^="flow:\/\/"]:not([data-frdl-component-initiated="true"])').every(function(el){
 console.deprecated('The widgets flow:// protocol is deprecated! ('+el.getAttribute('data-frdl-component')+')');
 el.setAttribute('data-frdl-component', frdl.str_replace('flow://components/', 'widget://example.com/', el.getAttribute('data-frdl-component')) );
 el.setAttribute('data-frdl-component', frdl.str_replace('flow://', 'widget://', el.getAttribute('data-frdl-component')) );
});	
	
	
	
	
	
customElements.whenDefined('webfan-widget').then(function() {
  
 frdl.watchFor('*[data-frdl-component*=":"]:not([data-frdl-component-initiated="true"])').every(function(el){
 	if(el.hasAttribute('data-frdl-component-initiated'))return;
 	if('webfan-widget'===el.tagName.toLowerCase())return;
 
     let widgetComponent = document.createElement('webfan-widget');
     widgetComponent.setAttribute('is', 'webfan-widget');
     widgetComponent.setAttribute('data-frdl-component', el.getAttribute('data-frdl-component'));
     
     el.append(widgetComponent);
     
 });	
});
	
}());
//WIDGETS?
}()); 
  
  
  
  
  
  
  
  
  
  
  
  (function(baseObj, funcName, mutex) {
	
	'use strict';
 
 function _getManifestUrl(){
 	var manifestMetaTag = frdl.$q('link[rel="manifest"]', false);
 	return (null!==manifestMetaTag)
 	            ? manifestMetaTag.getAttribute('href')
 	            : false
 	           ;
 }
 
 
 function WebApp(){
 	
 	
 	
   var _fetchedFromUrl = false;	
   var _manifestUrl = false;
   var args = Array.prototype.slice.call(arguments);
   
   
   var load = function (){
 	 var args = Array.prototype.slice.call(arguments);
 	 if(0===args.length){
	 	return load.apply(this, [_getManifestUrl()]);
	 }else if(1 === args.length && 'string' === typeof args[0]){
	 	    _manifestUrl = ('string'===typeof args[0]) ? args[0] : undefined;
	 	 	return new Promise(function(resolve, reject){
	 	 		
	 	 	  if('string' !==typeof _manifestUrl){
			  	 _fetchedFromUrl = false;
			  	 _manifestUrl = undefined;
			  	 reject(false);
			  	return;
			  }	
	 	 		
              $.ajax( {
		   	            url:  _manifestUrl,     
                        crossDomain: true,
                        cache:false,
                        headers: {
                        	        'X-Requested-With': 'XMLHttpRequest'
                                 }, 
                        type: 'GET',  
                        dataType: 'JSON',
                        data: {
                        	
                        }  
                } )
                .done(function(response) {
                	    _fetchedFromUrl = true;
                	   resolve(response);
                })
               .fail(function(jqXHR, textStatus) {
                	 _fetchedFromUrl = true;
               	     reject(false);
				 	 if(1<frdl.debug.mode()) frdl.alert.error('Could not get manifest: ' +  jqXHR.status); 
               })
              .always(function() {
                _manifestUrl = args[0];
              }); 		
 		
            });
	 }else if(1 === args.length && null !== args[0] && 'object' === typeof args[0]){
	 	//@ToDo: validate manifest...
	 	 _fetchedFromUrl = false;
	 	return args[0];
	 }
	 
 };
 
 var manifest = load.apply(this, args);
 if(true === manifest instanceof Promise){
 	manifest.then( function(result) {
       manifest = result;
   }, function(errResult){
   	  if(1<frdl.debug.mode()) console.log('No WebApp Manifest file: '+errResult);
   	  manifest = errResult;
   } );    	
 }
 this.getManifest = function(){
 	return manifest;
 };
 	
 
     Object.defineProperty(this, 'manifest', {
           get : function(){ 
              return manifest; 
           },
           set : function(val){ 
              //  manifest=val; 
              console.deprecated('Do not set WebApp.manifest manually!');
            }
      });    
                   		
 
     Object.defineProperty(this, 'manifestUrl', {
           get : function(){ 
              return {
              	 onPageUrl : _getManifestUrl(),
              	 fetched :  _fetchedFromUrl,
                 fetchedFrom : _manifestUrl,
                 inManifest : 	manifest.manifestUrl
              }; 
           },
           set : function(val){ 
              //  manifest=val; 
              console.deprecated('Do not set WebApp.manifestUrl manually!');
            }
      }); 
      
        
}
  
  
  
  
  
WebApp.prototype.getManifestUrl = function(){
 	return this.manifestUrl;
 };
 
var myWebApp = new WebApp(); 
 try{
 
     Object.defineProperty(mutex, 'myWebApp', {
           get : function(){ 
              return myWebApp; 
           },
           set : function(val){ 
              console.deprecated('Do not set WebApp.myWebApp manually!');
            }
      });    
                   		
 
      
      
 	
  }catch(err){
   if(Object.prototype.__defineGetter__ && Object.prototype.__defineSetter__) {
     mutex.__defineGetter__('myWebApp', function(){
      	return myWebApp; 
      } );     
      mutex.__defineSetter__('myWebApp', function(val){ 
           console.deprecated('Do not set WebApp.myWebApp manually!');
      } ); 
      
    
      
   }else{
  	  console.deprecated('Missing Object.defineProperty and Object.prototype.__defineGetter__ - Fallback to UNSAFE configuration readable!');
      mutex.myWebApp = myWebApp;
   }   
 }
 
  
	
baseObj[funcName || "WebApp"]=WebApp;	
}(frdl, 'WebApp', frdl.webfan));
 
 				 
				 
 
(function(){
 
 'use strict';
 
  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-'+ frdl.str_replace('.', '-', new frdl.Url().getHost()) + '-' + frdl.Sha1.hash(new frdl.Url().urlMakeNew()) + '-' + Sha1.hash(document.title) +'" style="top:0px;left:0px;right:0px;bottom:0px;height:auto;width:auto;"></div>' );
	   }    	
	 
   
    console.log('Prepare for jqm');
     
      if(true===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){ 
         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]').every(function(el){
          	
              setTimeout(function(){
              	 frdl.$j(el).attrAdd('data-flow-prepared', 'true');  
                 $(el).attr('href',  frdl.str_replace('##', '#',$(el).attr('href'))).attr('href',  frdl.str_replace('##', '#',$(el).attr('href'))).attr('href',  frdl.str_replace('##', '#',$(el).attr('href'))).attr('href',  frdl.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);
          
          UI.isMobileTheme = true;                     
          
  	
	},
	  
	  
	  
   '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
* @jquery.inputsearch : 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(){
	 
  
	}
	  	 
	  	  
  };
  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 UI;
  };  
  
  
 }());   
  
  
  
   
   
   
   
(function(){   
'use strict';
var _DEF = navigator.language;
var langs = ['de', 'en', 'fr', 'de_DE', 'en_GB', 'en_US', 'en_EN', 'fr_FR'];
 if (langs.indexOf(navigator.language) !== -1 && '_' !== _DEF) {
 	_DEF = navigator.language;
    if(2 > frdl.explode('_', _DEF).length){
	  _DEF = _DEF + '_' + _DEF.toUpperCase()
	}	
 } 
   
   
var LanguageOptionSelectors = [];
var _loaded=false;
var widgetsSelector = '*[data-frdl-component$="locale"] > ul[data-frdl-component-id*="locale"]';
 frdl.langGetClassSelector = function(){
     return widgetsSelector;
 }; 
 
frdl.getLanguageOptionSelectors = function(){
   return LanguageOptionSelectors; 	
};
frdl.addLanguageOptionSelector = function(id){
   LanguageOptionSelectors.push(id);
   return this; 	
};
frdl.removeLanguageOptionSelector = function(id){
   LanguageOptionSelectors = frdl.filter(LanguageOptionSelectors, function(v,i){
   	  if(v !== id)return true;
   	  return false;
   	}, false);
   return this; 	
};
frdl.isLanguageOptionSelector = function(id){
 var found = false;
  frdl.getLanguageOptionSelectors()
     .forEach(function(element, ix, array){
     	  if(id===array[ix]){
     	     found=true;
     	     return false;	
     	  }
     });
   return found;  
};
 
   
   
   
frdl.localeUrl = function(m, lang){
   if(null === lang || 'undefined' === typeof lang){
 	   lang = frdl.getLang();
   }
   
   
        if('function'===typeof m){
			return m(lang);
		}else if('string' === typeof m){
			return '/locale/'+m+'/'+frdl.getLang()+'/'+frdl.getLang()+'.properties';
		}else{
			return '/locale/'+frdl.getLang()+'/'+frdl.getLang()+'.properties';
		}	
};
                    
 frdl.langDefault=function(lang,trans){
 	
 if (langs.indexOf(frdl.Device().language) !== -1 && '_' !== _DEF) {
 	_DEF = navigator.language;
    if(2 > frdl.explode('_', _DEF).length){
	  _DEF = _DEF + '_' + _DEF.toUpperCase()
	}	
 } 
        
    return _DEF;  
};	
	
	
frdl.getLang = function(){
       var l = frdl.langDefault();
       
       if(null !== typeof frdl.WebfanReadCookie('lang.user.selected')){
			l = frdl.WebfanReadCookie('lang.user.selected');
		}
		
	    l = frdl.str_replace('-','_',l);
	
        if(2 > frdl.explode('_', l).length && 'default' !== l && '_' !== l){
			l = l + '_' + l.toUpperCase()
		}
		
	if('en_EN' === l || 'en_US' === l )l='en_GB';
				 
	return l;	 	
};
frdl.langstr = function(modul){
 var url = frdl.route('API_TRANSLATION_MAIN', null, null, modul);
   frdl.getScript(url, function(){
     	
  },false, false);	
};
frdl.lang = function(langStrings){
	var allSelectors=true, registeredSelectors=true;
    var languageStrings = langStrings,l = frdl.getLang();
    
   if(false!==registeredSelectors){
     frdl.getLanguageOptionSelectors()
     .forEach(function(element, ix, array){
      
	    	   	try{
	    	  		 $(array[ix]).locale('loadLangs', languageStrings) ; 
			   }catch(err){
			     console.error(err);	
		       }	
	
					
       	
	 });	
  }
  
  if(true===allSelectors){
	    	$(frdl.langGetClassSelector()).locale('loadLangs', languageStrings) ; 
	    	
  }
   frdl.translate();
};
frdl.translate = function(lang, allSelectors, registeredSelectors){
	try{  
  
    if('undefined' === typeof allSelectors)var allSelectors=false;
     if('undefined' === typeof registeredSelectors)var  registeredSelectors=true;
      
   if( !lang ){
 	   var l = frdl.getLang();
   }else{
 	   var l = lang;
   }
  	
  	if('default' !== l && '_' !== l)   {
		if(true===frdl.Dom.isVisible('desktop') &&'function'===typeof $.WebfanDesktop.save){
			$.WebfanDesktop.Registry.User.lang =  l;
			$.WebfanDesktop.save('user');     	
		}
		
		frdl.WebfanCreateCookie('lang.user.selected',l,31);  		
	}else if('_' === l){
		return;
	}
			    
 //  wUser.lang = l;
  
	   
      
      
  
   var url = frdl.localeUrl(null,l);
   var pfx = '';
     
   if(null!==frdl.$q('base', false)){
   	var base = frdl.$q('base', false).getAttribute('href');
   	 pfx  += new frdl.Url(base).getScheme() + '://' + new frdl.Url(base).getHost() + '/' + new frdl.Url(base).getDirectory();
   	 if('/' === pfx.substr(pfx.length-1,pfx.length) && true === navigator['-webkit-webfan'])pfx = pfx.substr(0,pfx.length-1);
   	 url = pfx  + url;
   }
 
     if( null === document.querySelector('link[href="'+url+'"]')){
     
        $(document.head).append('<link type="application/l10n" lang="'+l+'" href="'+url+'"></link>'); 
     }   
 
 
   if(false!==registeredSelectors){
     frdl.getLanguageOptionSelectors()
     .forEach(function(element, ix, array){
	    	   	try{
	    	  		 $(array[ix]).locale('translate', l);
			   }catch(err){
			     console.warn(err);	
		       }	
	 });	
   }
      if(true===allSelectors){
  
	    	  		$(frdl.langGetClassSelector()).locale('translate', l);	  	
	  
	    	
	  }	
 
	
 
      	
  
 webfan.$Async(function(){
   	
    frdl.inX.translate();
 
  
 }, 500); 
 	
 }catch(err){
	 console.warn(err);	
 }	 
};  
    
}());         
          
          
    
  
 
   
   
               
               
  
  
  
window.addEventListener("online", function() {
   console.log('Welcome back online...!');
   try{
   	frdl.alert.sucess('ONline');
   }catch(err){
   	
   }
}, true);
 
 
window.addEventListener("offline", function() {
  try{
   	frdl.alert.error('OFFline');
   }catch(err){
   	
   }
	
 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() {
   UI.emit('exit');
}, true);
window.addEventListener("reload", function() {
   UI.emit('exit');
}, true);
               
window.addEventListener('close', function(){
  UI.emit('exit');
});
UI.once('exit', function(){
	try{
          var debugmode =  frdl.debug.mode();	
          if(null===debugmode || undefined=== debugmode || isNaN(debugmode))debugmode=0;
      //    frdl.$DB.save('settings/debugmode',  frdl.debug.mode().toString());		
			localStorage.setItem('frdl.debug.mode()', frdl.debug.mode());
	}catch(err){
		
	}	
});    
UI.on('exit', sendStateBeacons);    
function getBeacondata(){
  return frdl.$getBeacondata(frdl.plug('DOCUMENT.SESSION.BEACON'));			
}
			
function sendStateBeacons(){
	frdl.state.emit('Session:sendBeacon', getBeacondata() );		
}
(function(){
frdl.watchFor('img[flow-image-load-url]:not([src]), img[data-flow-image-load-url]:not([src])').every(function(el){
 if(el.hasAttribute('data-flow-image-load-url') && !el.hasAttribute('flow-image-load-url') ){
 	el.setAttribute('flow-image-load-url', el.getAttribute('data-flow-image-load-url'));
 	el.removeAttribute('data-flow-image-load-url');
 }	
 
   var url = el.getAttribute('flow-image-load-url');
   if('data:' === url.substr(0,'data:'.length)){
   	 el.setAttribute('src', url);
   	return;
   }
   
   var p = frdl.getImageDataUri(url);
    p.then(function(r){
         el.setAttribute('src', r.uri);        	
     }, function(err){
      	  console.error(err);
     }); 
});		
}());	
(function(){
'use strict';		
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);
             frdl.$j(el).attrAdd('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(){	
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.watchFor('a[frdl-browse-to]:not([data-flow-prepared*="frdl-browse-to"])').every(function(el){
    frdl.$j(el).attrAdd('data-flow-prepared', 'frdl-browse-to'); 
    el.addEventListener('click', function(ev){
         ev.stopPropagation();
         ev.preventDefault();
         UI.browse(this.getAttribute('frdl-browse-to'), (this.hasAttribute('title')) ? this.getAttribute('title') : frdl.strip_tags(this.innerHTML));	
    });
    el.setAttribute('href', 'javascript:;');
 });	
}());	
(function(){
frdl.watchFor('textarea[class="ed"]').every(function(el){
   require('webfan/navigator/bbeditor', function(ed){
   	      ed.edToolbar(el.getAttribute('id'));
   });
});		
}());	
(function(){
  var Hash = frdl.Hash;									 
 function h(){
   if('undefined'===typeof frdl.Hash || 'function'!==typeof frdl.Hash.pushState){
	  setTimeout(function(){
			h();						 
	  },1);
		return;							 
   }									 
   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.ready(function(){
 	        webfan.$Async(function(){
   	            frdl.wd(true);
            }, 750); 
 	   }); 	 
 	    
   });	
 }	
if(frdl.Hash){
	h();
}else{
  require.state.once('resolved frdl.Hash', function(){
    h();
  });	
}	
}());
 
	
	
(function(){
	
frdl.watchFor('*[name="frdl.inX.dictonary-file"]:not([frdl-processed="true"])').every(function(el){
    if(!el.hasAttribute('content'))return true;
    el.setAttribute('frdl-processed', 'true');
     frdl.ready(function(){         
   	            var lang = frdl.getLang();
	            if('_'===lang){
		          lang='de_DE';
	            }
	            
	           var uri = el.getAttribute('content');
	           var url = frdl.str_replace('{{PROTOCOL}}',  location.protocol, uri );
	           url = frdl.str_replace('{{HOST}}',  location.host, url );
	           url = frdl.str_replace('{{LANG}}', lang, url );
	           
	           require(['frdlcjs!' + url], function(dictonary){    
	              frdl.ready(function(){
	              	  frdl.inX.start();
	              	  frdl.inX.translate();
	              });	
	           });	 
	});	           
});		
}());	
	
	
	
	
	
(function(){	
	
frdl.ready(function(){	
webfan.$Async(function(){                            
 UI.load(); 
 UI.Compile(500);
}, 1); 	 
 
 document.addEventListener('readystatechange', function(){
 	if('complete'!==document.readyState)return true;
 /*
 	frdl.each(frdl.$q('*[data-frdl-component*=":"]:not([data-frdl-component-initiated="true"])'), function(i, el){
 		webfan.$Async(function(){
 		   if(el.hasAttribute('data-frdl-component-initiated'))return;
 		   UI.widget(el);
 		}, 1);  
 	});
 	*/
 	webfan.$Async(function(){
 		 UI.load(); 
 	     UI.Compile(250);
 	}, 1); 
 }) ; 
 	  		
});
 $( window ).on( "mobileinit", function() {
      $.extend(  $.mobile , UI.o.jQueryMobile.o);
 });  	
	
$(document).ready(function(){
 if(true===UI.reduced()){
     UI.rendering('forMinimal');
 }else{
	    UI.rendering('forFullscreen');
	 }    
 
  if( 
  	   
  	    true === frdl.Device().isMobile 
  	   || true === frdl.Device().isTablet 
  	   /*  || true === navigator.isMobile 
  	   || true === navigator.isTablet 
  	  
  	   !!require('modernizr').Modernizr.pointerevents && !!require('modernizr').Modernizr.touchevents
*/
  	){
	           UI.rendering('forMobile');
        }
});
	
}());	
 
// Copyright 1999-2017. Parallels IP Holdings GmbH. All Rights Reserved.
/* responsive.js */
$(document).ready(function(){
    //http://v4.thewatchmakerproject.com/blog/how-to-fix-the-broken-ipad-form-label-click-issue/
    if (navigator.userAgent.match(/(iPad|iPhone|iPod)/i)) {
        $('label[for]').each(function(label) {
            label.observe('click', function() {
                var el = $(this).readAttribute('for');
                var type = $(el).readAttribute('type');
                if ('radio' == type || 'checkbox' == type) {
                    $(el).writeAttribute('selected', !$(el).readAttribute('selected'));
                } else {
                    $(el).focus();
                }
            });
        });
    }
    if (navigator.userAgent.match(/IEMobile\/10\.0/)) {
        var msViewportStyle = document.createElement("style");
        msViewportStyle.appendChild(
            document.createTextNode(
                "@-ms-viewport{width:auto!important}"
            )
        );
        document.getElementsByTagName("head")[0].
            appendChild(msViewportStyle);
    }
});
return UI;
});
 |