summaryrefslogtreecommitdiffstats
path: root/core/src/OC
diff options
context:
space:
mode:
authorJohn Molakvoæ <skjnldsv@protonmail.com>2023-06-25 11:46:53 +0200
committerJohn Molakvoæ <skjnldsv@protonmail.com>2023-06-25 15:39:32 +0200
commitadff75d559f660dfa7c088ab0846829fd586ab4a (patch)
tree8d4dcc7798788d4d42b6368de4a8192daadc5330 /core/src/OC
parente5245da74aa1cd314c81309e9a82ca9565de54a0 (diff)
downloadnextcloud-server-adff75d559f660dfa7c088ab0846829fd586ab4a.tar.gz
nextcloud-server-adff75d559f660dfa7c088ab0846829fd586ab4a.zip
fix: restore AppsSlideToggle feature
Signed-off-by: John Molakvoæ <skjnldsv@protonmail.com> Signed-off-by: nextcloud-command <nextcloud-command@users.noreply.github.com>
Diffstat (limited to 'core/src/OC')
-rw-r--r--core/src/OC/apps.js135
-rw-r--r--core/src/OC/index.js3
2 files changed, 137 insertions, 1 deletions
diff --git a/core/src/OC/apps.js b/core/src/OC/apps.js
new file mode 100644
index 00000000000..bbda177409e
--- /dev/null
+++ b/core/src/OC/apps.js
@@ -0,0 +1,135 @@
+/**
+ * @copyright Bernhard Posselt 2014
+ *
+ * @author Christoph Wurst <christoph@winzerhof-wurst.at>
+ * @author John Molakvoæ <skjnldsv@protonmail.com>
+ *
+ * @license AGPL-3.0-or-later
+ *
+ * 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'
+
+let dynamicSlideToggleEnabled = false
+
+const Apps = {
+ enableDynamicSlideToggle() {
+ dynamicSlideToggleEnabled = true
+ },
+}
+
+/**
+ * Shows the #app-sidebar and add .with-app-sidebar to subsequent siblings
+ *
+ * @param {object} [$el] sidebar element to show, defaults to $('#app-sidebar')
+ */
+Apps.showAppSidebar = function($el) {
+ const $appSidebar = $el || $('#app-sidebar')
+ $appSidebar.removeClass('disappear').show()
+ $('#app-content').trigger(new $.Event('appresized'))
+}
+
+/**
+ * Shows the #app-sidebar and removes .with-app-sidebar from subsequent
+ * siblings
+ *
+ * @param {object} [$el] sidebar element to hide, defaults to $('#app-sidebar')
+ */
+Apps.hideAppSidebar = function($el) {
+ const $appSidebar = $el || $('#app-sidebar')
+ $appSidebar.hide().addClass('disappear')
+ $('#app-content').trigger(new $.Event('appresized'))
+}
+
+/**
+ * Provides a way to slide down a target area through a button and slide it
+ * up if the user clicks somewhere else. Used for the news app settings and
+ * add new field.
+ *
+ * Usage:
+ * <button data-apps-slide-toggle=".slide-area">slide</button>
+ * <div class=".slide-area" class="hidden">I'm sliding up</div>
+ */
+export const registerAppsSlideToggle = () => {
+ let buttons = $('[data-apps-slide-toggle]')
+
+ if (buttons.length === 0) {
+ $('#app-navigation').addClass('without-app-settings')
+ }
+
+ $(document).click(function(event) {
+
+ if (dynamicSlideToggleEnabled) {
+ buttons = $('[data-apps-slide-toggle]')
+ }
+
+ buttons.each(function(index, button) {
+
+ const areaSelector = $(button).data('apps-slide-toggle')
+ const area = $(areaSelector)
+
+ /**
+ *
+ */
+ function hideArea() {
+ area.slideUp(OC.menuSpeed * 4, function() {
+ area.trigger(new $.Event('hide'))
+ })
+ area.removeClass('opened')
+ $(button).removeClass('opened')
+ }
+
+ /**
+ *
+ */
+ function showArea() {
+ area.slideDown(OC.menuSpeed * 4, function() {
+ area.trigger(new $.Event('show'))
+ })
+ area.addClass('opened')
+ $(button).addClass('opened')
+ const input = $(areaSelector + ' [autofocus]')
+ if (input.length === 1) {
+ input.focus()
+ }
+ }
+
+ // do nothing if the area is animated
+ if (!area.is(':animated')) {
+
+ // button toggles the area
+ if ($(button).is($(event.target).closest('[data-apps-slide-toggle]'))) {
+ if (area.is(':visible')) {
+ hideArea()
+ } else {
+ showArea()
+ }
+
+ // all other areas that have not been clicked but are open
+ // should be slid up
+ } else {
+ const closest = $(event.target).closest(areaSelector)
+ if (area.is(':visible') && closest[0] !== area[0]) {
+ hideArea()
+ }
+ }
+ }
+ })
+
+ })
+}
+
+export default Apps
diff --git a/core/src/OC/index.js b/core/src/OC/index.js
index 18fec8af8ed..becaabe6e21 100644
--- a/core/src/OC/index.js
+++ b/core/src/OC/index.js
@@ -29,6 +29,7 @@ import {
processAjaxError,
registerXHRForErrorProcessing,
} from './xhr-error.js'
+import Apps from './apps.js'
import { AppConfig, appConfig } from './appconfig.js'
import appswebroots from './appswebroots.js'
import Backbone from './backbone.js'
@@ -135,7 +136,7 @@ export default {
* @deprecated 17.0.0
*/
fileIsBlacklisted: file => !!(file.match(Config.blacklist_files_regex)),
-
+ Apps,
AppConfig,
appConfig,
appswebroots,