summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Tanghus <thomas@tanghus.net>2012-07-31 16:03:08 +0200
committerThomas Tanghus <thomas@tanghus.net>2012-07-31 16:03:08 +0200
commit8837576ce7de7d60cddf40b0b540d81294463043 (patch)
tree041db3a8fe5510254a31f5fe5283470de15d219e
parent5eed59bd54c7ef6525ea142ca84a6e615d5b4818 (diff)
downloadnextcloud-server-8837576ce7de7d60cddf40b0b540d81294463043.tar.gz
nextcloud-server-8837576ce7de7d60cddf40b0b540d81294463043.zip
Added some more options to OC.appSettings().
-rw-r--r--core/js/js.js35
1 files changed, 33 insertions, 2 deletions
diff --git a/core/js/js.js b/core/js/js.js
index f1d7e864a1a..006cd920503 100644
--- a/core/js/js.js
+++ b/core/js/js.js
@@ -156,22 +156,53 @@ OC={
var ret = date.getDate()+'.'+(date.getMonth()+1)+'.'+date.getFullYear()+', '+date.getHours()+':'+date.getMinutes();
return ret;
},
+ /**
+ * Opens a popup with the setting for an app.
+ * @param appid String. The ID of the app e.g. 'calendar', 'contacts' or 'files'.
+ * @param loadJS boolean or String. If true 'js/settings.js' is loaded. If it's a string
+ * it will attempt to load a script by that name in the 'js' directory.
+ * @param cache boolean. If true the javascript file won't be forced refreshed. Defaults to true.
+ * @param scriptName String. The name of the PHP file to load. Defaults to 'settings.php' in
+ * the root of the app directory hierarchy.
+ */
appSettings:function(args) {
if(typeof args === 'undefined' || typeof args.appid === 'undefined') {
- throw { name: 'MissingParameter', message: 'The parameter appid is missing' }
+ throw { name: 'MissingParameter', message: 'The parameter appid is missing' };
}
+ var props = {scriptName:'settings.php', cache:true};
+ $.extend(props, args);
var settings = $('#appsettings');
+ if(settings.length == 0) {
+ throw { name: 'MissingDOMElement', message: 'There has be be an element with id "appsettings" for the popup to show.' };
+ }
if(settings.is(':visible')) {
settings.hide().find('.arrow').hide();
} else {
if($('#journal.settings').length == 0) {
var arrowclass = settings.hasClass('topright') ? 'up' : 'left';
- var jqxhr = $.get(OC.linkTo(args.appid, 'settings.php'), function(data) {
+ var jqxhr = $.get(OC.filePath(props.appid, '', 'settings.php'), function(data) {
$('#appsettings').html(data).ready(function() {
settings.prepend('<span class="arrow '+arrowclass+'"></span><h2>'+t('core', 'Settings')+'</h2><a class="close svg"></a>').show();
settings.find('.close').bind('click', function() {
settings.hide();
})
+ if(typeof props.loadJS !== 'undefined') {
+ var scriptname;
+ if(props.loadJS === true) {
+ scriptname = 'settings.js';
+ } else if(typeof props.loadJS === 'string') {
+ scriptname = props.loadJS;
+ } else {
+ throw { name: 'InvalidParameter', message: 'The "loadJS" parameter must be either boolean or a string.' };
+ }
+ if(props.cache) {
+ $.ajaxSetup({cache: true});
+ }
+ $.getScript(OC.filePath(props.appid, 'js', scriptname))
+ .fail(function(jqxhr, settings, exception) {
+ settings.append('<span>'+t('core', 'Error loading script for the settings')+'</span>');
+ });
+ }
});
}, 'html');
} else {