aboutsummaryrefslogtreecommitdiffstats
path: root/core/src
diff options
context:
space:
mode:
authorJohn Molakvoæ <skjnldsv@users.noreply.github.com>2019-05-15 10:10:29 +0200
committerGitHub <noreply@github.com>2019-05-15 10:10:29 +0200
commitb5fed5981295eacd8a78b4aefa0c2309357fc44c (patch)
treea0831c677b3c9e9abaef9d97751107dd0ce1a3a0 /core/src
parent1cfc59c3ad4be637dcfc5e80cc96491d25d2e84d (diff)
parent07699c199d02a41afa165a1dac0c2e5a1e8761fd (diff)
downloadnextcloud-server-b5fed5981295eacd8a78b4aefa0c2309357fc44c.tar.gz
nextcloud-server-b5fed5981295eacd8a78b4aefa0c2309357fc44c.zip
Move OC.appSettings to the bundle and deprecate it (#15533)
Move OC.appSettings to the bundle and deprecate it
Diffstat (limited to 'core/src')
-rw-r--r--core/src/OC/appsettings.js93
-rw-r--r--core/src/OC/index.js2
2 files changed, 95 insertions, 0 deletions
diff --git a/core/src/OC/appsettings.js b/core/src/OC/appsettings.js
new file mode 100644
index 00000000000..b62af5c592a
--- /dev/null
+++ b/core/src/OC/appsettings.js
@@ -0,0 +1,93 @@
+/*
+ * @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
+ *
+ * @author 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program 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 program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+import $ from 'jquery'
+import {filePath} from './routing'
+
+/**
+ * Opens a popup with the setting for an app.
+ * @param {string} appid The ID of the app e.g. 'calendar', 'contacts' or 'files'.
+ * @param {boolean|string} loadJS 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 {boolean} [cache] If true the javascript file won't be forced refreshed. Defaults to true.
+ * @param {string} [scriptName] The name of the PHP file to load. Defaults to 'settings.php' in
+ * the root of the app directory hierarchy.
+ *
+ * @deprecated 17.0.0 this method is unused and will be removed with Nextcloud 18
+ */
+export const appSettings = args => {
+ console.warn('OC.appSettings is deprecated and will be removed with Nextcloud 18')
+
+ if (typeof args === 'undefined' || typeof args.appid === 'undefined') {
+ 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.'
+ }
+ }
+ var popup = $('#appsettings_popup')
+ if (popup.length === 0) {
+ $('body').prepend('<div class="popup hidden" id="appsettings_popup"></div>')
+ popup = $('#appsettings_popup')
+ popup.addClass(settings.hasClass('topright') ? 'topright' : 'bottomleft')
+ }
+ if (popup.is(':visible')) {
+ popup.hide().remove()
+ } else {
+ const arrowclass = settings.hasClass('topright') ? 'up' : 'left'
+ $.get(filePath(props.appid, '', props.scriptName), function (data) {
+ popup.html(data).ready(function () {
+ popup.prepend('<span class="arrow ' + arrowclass + '"></span><h2>' + t('core', 'Settings') + '</h2><a class="close"></a>').show()
+ popup.find('.close').bind('click', function () {
+ popup.remove()
+ })
+ 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(filePath(props.appid, 'js', scriptname))
+ .fail(function (jqxhr, settings, e) {
+ throw e
+ })
+ }
+ }).show()
+ }, 'html')
+ }
+}
diff --git a/core/src/OC/index.js b/core/src/OC/index.js
index 4a2f2c3d803..7fd718e17c4 100644
--- a/core/src/OC/index.js
+++ b/core/src/OC/index.js
@@ -22,6 +22,7 @@
import {addScript, addStyle} from './legacy-loader'
import Apps from './apps'
import {AppConfig, appConfig} from './appconfig'
+import {appSettings} from './appsettings'
import appswebroots from './appswebroots'
import Backbone from './backbone'
import {
@@ -129,6 +130,7 @@ export default {
Apps,
AppConfig,
appConfig,
+ appSettings,
appswebroots,
Backbone,
ContactsMenu,