Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[full-ci] Resolve upload existing folder conflict dialog #7504

Merged
merged 29 commits into from
Sep 12, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
6973a0c
It aint much but it kinda works
lookacat Aug 22, 2022
af74fba
Implement "keep both"
lookacat Aug 23, 2022
21143ab
Add changelog
lookacat Aug 23, 2022
f08b9f8
remove dev leftover
lookacat Aug 23, 2022
7b71a91
Fix folder name
lookacat Aug 23, 2022
133cc2b
Add isFolder
lookacat Aug 26, 2022
81c53f1
Make file conflict dialog work
lookacat Aug 31, 2022
9994412
Linting
lookacat Aug 31, 2022
1380d73
Fix folder keep both
lookacat Aug 31, 2022
21ace2c
Check for folder to already exist
lookacat Aug 31, 2022
9c43891
remove dev leftover
lookacat Aug 31, 2022
50b67f3
Address PR issues
lookacat Sep 2, 2022
20f72fb
Use store
lookacat Sep 5, 2022
9d98ed1
Provide existing files with function parameter
lookacat Sep 5, 2022
5f772f5
Add type to interface
lookacat Sep 5, 2022
f3649d5
Refactor resolve file & folder conflicts
lookacat Sep 6, 2022
fa29985
Refactor conflict dialog
lookacat Sep 6, 2022
d2408cd
Bugfix, remove dev leftover
lookacat Sep 6, 2022
1f217ca
Simplify conflict-array structure
JammingBen Sep 6, 2022
fade050
Fix folder upload
JammingBen Sep 6, 2022
dc7615d
Add merge to folders
lookacat Sep 6, 2022
c040bdd
Ignore existing folder errors for now
lookacat Sep 6, 2022
9179c7e
Make Merge reappear if "do for all" ticked
lookacat Sep 7, 2022
4511d5b
Address PR issues
lookacat Sep 7, 2022
afedbd7
Add unittests
lookacat Sep 7, 2022
9a0d3e2
Add more unittests
lookacat Sep 7, 2022
d79fe54
Fix e2e upload version
lookacat Sep 7, 2022
b4fe000
Fix file overwrite acceptance tests
lookacat Sep 8, 2022
4ac0d5a
Address PR issues
lookacat Sep 9, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion changelog/unreleased/bugfix-resolve-upload-existing-folder
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Bugfix: Resolve upload existing folder

We've added an conflict dialog when uploading files and folders
We've added a conflict dialog which handles name clashes when uploading files and folders.

https://github.com/owncloud/web/pull/7504
https://github.com/owncloud/web/issues/6996
39 changes: 22 additions & 17 deletions packages/web-app-files/src/components/AppBar/CreateAndUpload.vue
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,8 @@ import {
resolveFileExists,
ResolveStrategy,
ResolveConflict,
resolveFileNameDuplicate
resolveFileNameDuplicate,
FileExistsResolver
} from '../../helpers/resource/copyMove'

export default defineComponent({
Expand Down Expand Up @@ -800,7 +801,11 @@ export default defineComponent({
this.$uppyService.uploadFiles(files)
},

async displayOverwriteDialog(files: UppyResource[], conflicts, resolveFileExistsMethod) {
async displayOverwriteDialog(
files: UppyResource[],
conflicts,
resolveFileExistsMethod: FileExistsResolver
) {
let count = 0
const allConflictsCount = conflicts.length
const resolvedFileConflicts = []
Expand Down Expand Up @@ -839,7 +844,7 @@ export default defineComponent({
false,
isFolder
)
count += 1
count++
if (resolvedConflict.doForAllConflicts) {
if (isFolder) {
doForAllConflictsFolders = true
Expand All @@ -858,25 +863,28 @@ export default defineComponent({
const filesToSkip = resolvedFileConflicts
.filter((e) => e.strategy === ResolveStrategy.SKIP)
.map((e) => e.name)
const filesToKeepBoth = resolvedFileConflicts
.filter((e) => e.strategy === ResolveStrategy.KEEP_BOTH)
const foldersToSkip = resolvedFolderConflicts
.filter((e) => e.strategy === ResolveStrategy.SKIP)
.map((e) => e.name)

for (const fileName of filesToKeepBoth) {
const file = files.find((e) => e.name === fileName && !e.meta.relativeFolder)
const extension = extractExtensionFromFile({ name: fileName } as Resource)
file.name = resolveFileNameDuplicate(fileName, extension, this.files)
}

files = files.filter((e) => !filesToSkip.includes(e.name))
JammingBen marked this conversation as resolved.
Show resolved Hide resolved
lookacat marked this conversation as resolved.
Show resolved Hide resolved
files = files.filter(
(file) =>
!foldersToSkip.some((folderName) => file.meta.relativeFolder.split('/')[1] === folderName)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please include the condition in line 870. Doesn't make much sense iterating twice for filtering, when you can do all the filtering in one iteration.

Filter should look like this:

files = files.filter(
        (file) =>
          !filesToSkip.includes(file.name) &&
          !foldersToSkip.some((folderName) => file.meta.relativeFolder.split('/')[1] === folderName)
      )

)

const foldersToSkip = resolvedFolderConflicts
.filter((e) => e.strategy === ResolveStrategy.SKIP)
const filesToKeepBoth = resolvedFileConflicts
.filter((e) => e.strategy === ResolveStrategy.KEEP_BOTH)
.map((e) => e.name)
const foldersToKeepBoth = resolvedFolderConflicts
.filter((e) => e.strategy === ResolveStrategy.KEEP_BOTH)
.map((e) => e.name)

for (const fileName of filesToKeepBoth) {
const file = files.find((e) => e.name === fileName && !e.meta.relativeFolder)
const extension = extractExtensionFromFile({ name: fileName } as Resource)
file.name = resolveFileNameDuplicate(fileName, extension, this.files)
}
for (const folder of foldersToKeepBoth) {
const filesInFolder = files.filter((e) => e.meta.relativeFolder.split('/')[1] === folder)
for (const file of filesInFolder) {
Expand All @@ -895,10 +903,7 @@ export default defineComponent({
file.meta.routeItem = `/${newFolderName}`
}
}
files = files.filter(
(file) =>
!foldersToSkip.some((folderName) => file.meta.relativeFolder.split('/')[1] === folderName)
)

if (files.length === 0) return
this.handleUppyFileUpload(files)
}
Expand Down
13 changes: 13 additions & 0 deletions packages/web-app-files/src/helpers/resource/copyMove.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,19 @@ interface FileConflict {
strategy?: ResolveStrategy
}

export interface FileExistsResolver {
(
createModal: void,
hideModal: void,
resource: Resource,
conflictCount: number,
$gettext: void,
$gettextInterpolate: void,
isSingleConflict: boolean,
suggestMerge: boolean
)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The return type is missing 🤔

}

export const resolveFileExists = (
createModal,
hideModal,
Expand Down