aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFerdinand Thiessen <opensource@fthiessen.de>2024-07-11 01:44:00 +0200
committerFerdinand Thiessen <opensource@fthiessen.de>2024-07-15 11:34:05 +0200
commit841efff3fb2e386ad020ca832f8906d738cbbe64 (patch)
tree9396cac83316fbf1d3e87a6b29913aa448eedfdd
parentb05e963f15d33502c6dafc435d3d3435d844ab2a (diff)
downloadnextcloud-server-841efff3fb2e386ad020ca832f8906d738cbbe64.tar.gz
nextcloud-server-841efff3fb2e386ad020ca832f8906d738cbbe64.zip
fix(files): Close the sidebar on navigation
Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
-rw-r--r--apps/files/src/views/FilesList.vue3
-rw-r--r--apps/files/src/views/Sidebar.vue2
-rw-r--r--apps/files_sharing/src/files_sharing_tab.js8
-rw-r--r--cypress.config.ts2
-rw-r--r--cypress/e2e/files/files-sidebar.cy.ts57
5 files changed, 65 insertions, 7 deletions
diff --git a/apps/files/src/views/FilesList.vue b/apps/files/src/views/FilesList.vue
index 2f09bc73080..4fe33c61375 100644
--- a/apps/files/src/views/FilesList.vue
+++ b/apps/files/src/views/FilesList.vue
@@ -473,6 +473,9 @@ export default defineComponent({
// TODO: preserve selection on browsing?
this.selectionStore.reset()
this.triggerResetSearch()
+ if (window.OCA.Files.Sidebar?.close) {
+ window.OCA.Files.Sidebar.close()
+ }
this.fetchContent()
// Scroll to top, force virtual scroller to re-render
diff --git a/apps/files/src/views/Sidebar.vue b/apps/files/src/views/Sidebar.vue
index 1facff4642d..5eab07ca862 100644
--- a/apps/files/src/views/Sidebar.vue
+++ b/apps/files/src/views/Sidebar.vue
@@ -93,7 +93,7 @@ import { emit, subscribe, unsubscribe } from '@nextcloud/event-bus'
import { File, Folder, formatFileSize } from '@nextcloud/files'
import { encodePath } from '@nextcloud/paths'
import { generateRemoteUrl, generateUrl } from '@nextcloud/router'
-import { Type as ShareTypes } from '@nextcloud/sharing'
+import { ShareTypes } from '@nextcloud/sharing'
import { mdiStar, mdiStarOutline } from '@mdi/js'
import axios from '@nextcloud/axios'
import $ from 'jquery'
diff --git a/apps/files_sharing/src/files_sharing_tab.js b/apps/files_sharing/src/files_sharing_tab.js
index 5ecca06a69d..b7225bc96b8 100644
--- a/apps/files_sharing/src/files_sharing_tab.js
+++ b/apps/files_sharing/src/files_sharing_tab.js
@@ -55,12 +55,16 @@ window.addEventListener('DOMContentLoaded', function() {
await TabInstance.update(fileInfo)
TabInstance.$mount(el)
},
+
update(fileInfo) {
TabInstance.update(fileInfo)
},
+
destroy() {
- TabInstance.$destroy()
- TabInstance = null
+ if (TabInstance) {
+ TabInstance.$destroy()
+ TabInstance = null
+ }
},
}))
}
diff --git a/cypress.config.ts b/cypress.config.ts
index 2c91c6256d5..8c35f354735 100644
--- a/cypress.config.ts
+++ b/cypress.config.ts
@@ -54,6 +54,8 @@ export default defineConfig({
// Disable session isolation
testIsolation: false,
+ requestTimeout: 30000,
+
// We've imported your old cypress plugins here.
// You may want to clean this up later by importing these.
async setupNodeEvents(on, config) {
diff --git a/cypress/e2e/files/files-sidebar.cy.ts b/cypress/e2e/files/files-sidebar.cy.ts
index a5dd9399c50..f5c4205c462 100644
--- a/cypress/e2e/files/files-sidebar.cy.ts
+++ b/cypress/e2e/files/files-sidebar.cy.ts
@@ -5,6 +5,7 @@
import type { User } from '@nextcloud/cypress'
import { getRowForFile, navigateToFolder, triggerActionForFile } from './FilesUtils'
+import { assertNotExistOrNotVisible } from '../settings/usersUtils'
describe('Files: Sidebar', { testIsolation: true }, () => {
let user: User
@@ -26,7 +27,10 @@ describe('Files: Sidebar', { testIsolation: true }, () => {
triggerActionForFile('file', 'details')
- cy.get('[data-cy-sidebar]').should('be.visible')
+ cy.get('[data-cy-sidebar]')
+ .should('be.visible')
+ .findByRole('heading', { name: 'file' })
+ .should('be.visible')
})
it('changes the current fileid', () => {
@@ -39,20 +43,63 @@ describe('Files: Sidebar', { testIsolation: true }, () => {
cy.url().should('contain', `apps/files/files/${fileId}`)
})
- it('closes the sidebar on delete', () => {
+ it('changes the sidebar content on other file', () => {
cy.visit('/apps/files')
getRowForFile('file').should('be.visible')
+ triggerActionForFile('file', 'details')
+
+ cy.get('[data-cy-sidebar]')
+ .should('be.visible')
+ .findByRole('heading', { name: 'file' })
+ .should('be.visible')
+
+ triggerActionForFile('folder', 'details')
+ cy.get('[data-cy-sidebar]')
+ .should('be.visible')
+ .findByRole('heading', { name: 'folder' })
+ .should('be.visible')
+ })
+
+ it('closes the sidebar on navigation', () => {
+ cy.visit('/apps/files')
+
+ getRowForFile('file').should('be.visible')
+ getRowForFile('folder').should('be.visible')
+
// open the sidebar
triggerActionForFile('file', 'details')
// validate it is open
- cy.get('[data-cy-sidebar]').should('be.visible')
+ cy.get('[data-cy-sidebar]')
+ .should('be.visible')
+
+ // if we navigate to the folder
+ navigateToFolder('folder')
+ // the sidebar should not be visible anymore
+ cy.get('[data-cy-sidebar]')
+ .should(assertNotExistOrNotVisible)
+ })
+ it('closes the sidebar on delete', () => {
+ cy.intercept('DELETE', `**/remote.php/dav/files/${user.userId}/file`).as('deleteFile')
+ // visit the files app
+ cy.visit('/apps/files')
+ getRowForFile('file').should('be.visible')
+ // open the sidebar
+ triggerActionForFile('file', 'details')
+ // validate it is open
+ cy.get('[data-cy-sidebar]').should('be.visible')
+ // delete the file
triggerActionForFile('file', 'delete')
- cy.get('[data-cy-sidebar]').should('not.exist')
+ cy.wait('@deleteFile', { timeout: 10000 })
+ // see the sidebar is closed
+ cy.get('[data-cy-sidebar]')
+ .should(assertNotExistOrNotVisible)
})
it('changes the fileid on delete', () => {
+ cy.intercept('DELETE', `**/remote.php/dav/files/${user.userId}/folder/other`).as('deleteFile')
+
cy.uploadContent(user, new Blob([]), 'text/plain', '/folder/other').then((response) => {
const otherFileId = Number.parseInt(response.headers['oc-fileid'] ?? '0')
cy.login(user)
@@ -69,6 +116,8 @@ describe('Files: Sidebar', { testIsolation: true }, () => {
cy.url().should('contain', `apps/files/files/${otherFileId}`)
triggerActionForFile('other', 'delete')
+ cy.wait('@deleteFile')
+
cy.get('[data-cy-sidebar]').should('not.exist')
// Ensure the URL is changed
cy.url().should('not.contain', `apps/files/files/${otherFileId}`)