diff options
author | Georg Ehrke <dev@georgswebsite.de> | 2012-01-31 11:58:40 +0100 |
---|---|---|
committer | Georg Ehrke <dev@georgswebsite.de> | 2012-01-31 11:58:40 +0100 |
commit | 538618df624176dce2b750a07328f6d3ece47daf (patch) | |
tree | 6ba5b4d9f0bb6652ffa7f894412af3575f014d84 /core | |
parent | fc70c7094a32be06329e1674339a4d6d7329db65 (diff) | |
parent | 6a1121ab2e91a362ed1e13e18c44fca40761f97a (diff) | |
download | nextcloud-server-538618df624176dce2b750a07328f6d3ece47daf.tar.gz nextcloud-server-538618df624176dce2b750a07328f6d3ece47daf.zip |
Merge branch 'master' into calendar
Diffstat (limited to 'core')
-rw-r--r-- | core/js/eventsource.js | 99 | ||||
-rw-r--r-- | core/js/setup.js | 12 | ||||
-rw-r--r-- | core/templates/installation.php | 3 |
3 files changed, 114 insertions, 0 deletions
diff --git a/core/js/eventsource.js b/core/js/eventsource.js new file mode 100644 index 00000000000..30b942f59e8 --- /dev/null +++ b/core/js/eventsource.js @@ -0,0 +1,99 @@ +/** + * ownCloud + * + * @author Robin Appelman + * @copyright 2012 Robin Appelman icewind1991@gmail.com + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU AFFERO GENERAL PUBLIC LICENSE for more details. + * + * You should have received a copy of the GNU Affero General Public + * License along with this library. If not, see <http://www.gnu.org/licenses/>. + * + */ + +/** + * wrapper for server side events (http://en.wikipedia.org/wiki/Server-sent_events) + * includes a fallback for older browsers and IE + * + * use server side events with causion, to many open requests can hang the server + */ + +OC.EventSource=function(src){ + if(!this.useFallBack && typeof EventSource !='undefined'){ + this.source=new EventSource(src); + this.source.onmessage=function(e){ + for(var i=0;i<this.typelessListeners.length;i++){ + this.typelessListeners[i](JSON.parse(e.data)); + } + } + }else{ + iframeId='oc_eventsource_iframe_'+OC.EventSource.iframeCount; + OC.EventSource.fallBackSources[OC.EventSource.iframeCount]=this; + this.iframe=$('<iframe/>'); + this.iframe.attr('id',iframeId); + this.iframe.hide(); + this.iframe.attr('src',src+'?fallback=true&fallback_id='+OC.EventSource.iframeCount); + $('body').append(this.iframe); + this.useFallBack=true; + OC.EventSource.iframeCount++ + } + //add close listener + this.listen('__internal__',function(data){ + if(data=='close'){ + this.close(); + } + }.bind(this)); +} +OC.EventSource.fallBackSources=[]; +OC.EventSource.iframeCount=0;//number of fallback iframes +OC.EventSource.fallBackCallBack=function(id,type,data){ + OC.EventSource.fallBackSources[id].fallBackCallBack(type,JSON.parse(data)); +} +OC.EventSource.prototype={ + typelessListeners:[], + iframe:null, + listeners:{},//only for fallback + useFallBack:false, + fallBackCallBack:function(type,data){ + if(type){ + for(var i=0;i<this.listeners[type].length;i++){ + this.listeners[type][i](data); + } + }else{ + for(var i=0;i<this.typelessListeners.length;i++){ + this.typelessListeners[i](data); + } + } + }, + lastLength:0,//for fallback + listen:function(type,callback){ + if(callback && callback.call){ + + if(type){ + if(this.useFallBack){ + if(!this.listeners[type]){ + this.listeners[type]=[]; + } + this.listeners[type].push(callback); + }else{ + this.source.addEventListener(type,function(e){ + callback(JSON.parse(e.data)); + },false); + } + }else{ + typelessListeners.push(callback); + } + } + }, + close:function(){ + this.source.close(); + } +} diff --git a/core/js/setup.js b/core/js/setup.js index 94097785e42..6e056cc90d1 100644 --- a/core/js/setup.js +++ b/core/js/setup.js @@ -1,4 +1,11 @@ +var dbtypes $(document).ready(function() { + dbtypes={ + sqlite:!!$('#hasSQLite').val(), + mysql:!!$('#hasMySQL').val(), + postgresql:!!$('#hasPostgreSQL').val(), + } + $('#selectDbType').buttonset(); $('#datadirContent').hide(250); $('#databaseField').hide(250); @@ -60,4 +67,9 @@ $(document).ready(function() { form.submit(); return false; }); + + if(!dbtypes.sqlite){ + $('#showAdvanced').click(); + $('input[type="radio"]').first().click(); + } }); diff --git a/core/templates/installation.php b/core/templates/installation.php index f1cde6b3904..4558f97bc08 100644 --- a/core/templates/installation.php +++ b/core/templates/installation.php @@ -1,3 +1,6 @@ +<input type='hidden' id='hasMySQL' value='<?php echo $_['hasMySQL'] ?>'></input> +<input type='hidden' id='hasSQLite' value='<?php echo $_['hasSQLite'] ?>'></input> +<input type='hidden' id='hasPostgreSQL' value='<?php echo $_['hasPostgreSQL'] ?>'></input> <form action="index.php" method="post"> <input type="hidden" name="install" value="true" /> |