diff options
author | John Molakvoæ <skjnldsv@protonmail.com> | 2023-06-25 11:46:53 +0200 |
---|---|---|
committer | John Molakvoæ <skjnldsv@protonmail.com> | 2023-06-25 15:39:32 +0200 |
commit | adff75d559f660dfa7c088ab0846829fd586ab4a (patch) | |
tree | 8d4dcc7798788d4d42b6368de4a8192daadc5330 /core/src/OC | |
parent | e5245da74aa1cd314c81309e9a82ca9565de54a0 (diff) | |
download | nextcloud-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.js | 135 | ||||
-rw-r--r-- | core/src/OC/index.js | 3 |
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, |