aboutsummaryrefslogtreecommitdiffstats
path: root/core/src
diff options
context:
space:
mode:
Diffstat (limited to 'core/src')
-rw-r--r--core/src/OC/dialogs.js2
-rw-r--r--core/src/init.js72
2 files changed, 66 insertions, 8 deletions
diff --git a/core/src/OC/dialogs.js b/core/src/OC/dialogs.js
index e7e5ca4d310..df0794711f1 100644
--- a/core/src/OC/dialogs.js
+++ b/core/src/OC/dialogs.js
@@ -1164,6 +1164,8 @@ const Dialogs = {
self.$fileListHeader.show()
}
+ self.$filelist.empty();
+
$.each(files, function(idx, entry) {
entry.icon = OC.MimeType.getIconUrl(entry.mimetype)
var simpleSize, sizeColor
diff --git a/core/src/init.js b/core/src/init.js
index d2282beb023..b6bb49346bd 100644
--- a/core/src/init.js
+++ b/core/src/init.js
@@ -217,18 +217,74 @@ export const initCore = () => {
$('#app-content').prepend('<div id="app-navigation-toggle" class="icon-menu" style="display:none" tabindex="0"></div>')
- const toggleSnapperOnButton = () => {
- if (snapper.state().state === 'left') {
- snapper.close()
- } else {
- snapper.open('left')
+ // keep track whether snapper is currently animating, and
+ // prevent to call open or close while that is the case
+ // to avoid duplicating events (snap.js doesn't check this)
+ let animating = false
+ snapper.on('animating', () => {
+ // we need this because the trigger button
+ // is also implicitly wired to close by snapper
+ animating = true
+ })
+ snapper.on('animated', () => {
+ animating = false
+ })
+ snapper.on('start', () => {
+ // we need this because dragging triggers that
+ animating = true
+ })
+ snapper.on('end', () => {
+ // we need this because dragging stop triggers that
+ animating = false
+ })
+
+ // These are necessary because calling open or close
+ // on snapper during an animation makes it trigger an
+ // unfinishable animation, which itself will continue
+ // triggering animating events and cause high CPU load,
+ //
+ // Ref https://github.com/jakiestfu/Snap.js/issues/216
+ const oldSnapperOpen = snapper.open
+ const oldSnapperClose = snapper.close
+ const _snapperOpen = () => {
+ if (animating || snapper.state().state !== 'closed') {
+ return
+ }
+ oldSnapperOpen('left')
+ }
+
+ const _snapperClose = () => {
+ if (animating || snapper.state().state === 'closed') {
+ return
+ }
+ oldSnapperClose()
+ }
+
+ // Needs to be deferred to properly catch in-between
+ // events that snap.js is triggering after dragging.
+ //
+ // Skipped when running unit tests as we are not testing
+ // the snap.js workarounds...
+ if (!window.TESTING) {
+ snapper.open = () => {
+ _.defer(_snapperOpen)
+ }
+ snapper.close = () => {
+ _.defer(_snapperClose)
}
}
- $('#app-navigation-toggle').click(toggleSnapperOnButton)
+ $('#app-navigation-toggle').click((e) => {
+ // close is implicit in the button by snap.js
+ if (snapper.state().state !== 'left') {
+ snapper.open()
+ }
+ })
$('#app-navigation-toggle').keypress(e => {
- if (e.which === 13) {
- toggleSnapperOnButton()
+ if (snapper.state().state === 'left') {
+ snapper.close()
+ } else {
+ snapper.open()
}
})