diff options
author | Ferdinand Thiessen <opensource@fthiessen.de> | 2024-07-11 01:44:00 +0200 |
---|---|---|
committer | Ferdinand Thiessen <opensource@fthiessen.de> | 2024-07-15 11:34:05 +0200 |
commit | 841efff3fb2e386ad020ca832f8906d738cbbe64 (patch) | |
tree | 9396cac83316fbf1d3e87a6b29913aa448eedfdd | |
parent | b05e963f15d33502c6dafc435d3d3435d844ab2a (diff) | |
download | nextcloud-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.vue | 3 | ||||
-rw-r--r-- | apps/files/src/views/Sidebar.vue | 2 | ||||
-rw-r--r-- | apps/files_sharing/src/files_sharing_tab.js | 8 | ||||
-rw-r--r-- | cypress.config.ts | 2 | ||||
-rw-r--r-- | cypress/e2e/files/files-sidebar.cy.ts | 57 |
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}`) |