From 805efbea4edf46d00791ca02b0fec3da6f7dad32 Mon Sep 17 00:00:00 2001 From: Cagatay Civici Date: Fri, 14 May 2021 12:08:46 +0300 Subject: [PATCH] Fixed #1013 - Event for file remove in FileUpload --- src/components/fileupload/FileUpload.d.ts | 1 + src/components/fileupload/FileUpload.vue | 8 +- src/views/fileupload/FileUploadDoc.vue | 112 ++++++++++++---------- 3 files changed, 66 insertions(+), 55 deletions(-) diff --git a/src/components/fileupload/FileUpload.d.ts b/src/components/fileupload/FileUpload.d.ts index c41fc199b2..1e53b833d1 100755 --- a/src/components/fileupload/FileUpload.d.ts +++ b/src/components/fileupload/FileUpload.d.ts @@ -30,6 +30,7 @@ declare class FileUpload { $emit(eventName: 'error', e: { originalEvent: Event, files: any }): this; $emit(eventName: 'before-send', e: { xhr: XMLHttpRequest, formData: any }): this; $emit(eventName: 'clear'): this; + $emit(eventName: 'remove', e: { file: File, files: File[] }): this; } export default FileUpload; diff --git a/src/components/fileupload/FileUpload.vue b/src/components/fileupload/FileUpload.vue index 22d5fced65..bbd4cf3ca1 100755 --- a/src/components/fileupload/FileUpload.vue +++ b/src/components/fileupload/FileUpload.vue @@ -48,7 +48,7 @@ import Ripple from 'primevue/ripple'; export default { name: 'FileUpload', - emits: ['select', 'uploader', 'before-upload', 'progress', 'upload', 'error', 'before-send', 'clear'], + emits: ['select', 'uploader', 'before-upload', 'progress', 'upload', 'error', 'before-send', 'clear', 'remove'], props: { name: { type: String, @@ -357,8 +357,12 @@ export default { }, remove(index) { this.clearInputElement(); - this.files.splice(index, 1); + let removedFile = this.files.splice(index, 1)[0]; this.files = [...this.files]; + this.$emit('remove', { + file: removedFile, + files: this.files + }); }, clearInputElement() { this.$refs.fileInput.value = ''; diff --git a/src/views/fileupload/FileUploadDoc.vue b/src/views/fileupload/FileUploadDoc.vue index 418670b458..3d060f22bf 100755 --- a/src/views/fileupload/FileUploadDoc.vue +++ b/src/views/fileupload/FileUploadDoc.vue @@ -223,61 +223,67 @@ myUploader(event) {
- - - - - + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameParametersDescription
NameParametersDescription
before-uploadevent.xhr: XmlHttpRequest instance.
- event.formData: FormData object.
Callback to invoke before file upload begins to customize the request - such as post parameters before the files.
before-sendevent.xhr: XmlHttpRequest instance.
- event.formData: FormData object.
Callback to invoke before file send begins to customize the request - such as adding headers.
uploadevent.xhr: XmlHttpRequest instance.
- event.files: Uploaded files.
Callback to invoke when file upload is complete.
errorevent.xhr: XmlHttpRequest instance.
- event.files: Files that are not uploaded.
Callback to invoke if file upload fails.
clear-.Callback to invoke when files in queue are removed without uploading.
selectevent.originalEvent: Original browser event.
- event.files: List of selected files.
Callback to invoke when file upload is complete.
progressevent.originalEvent: Original browser event.
- event.progress: Calculated progress value.
Callback to invoke when files are selected.
uploaderevent.files: List of selected files.Callback to invoke to implement a custom upload.
before-uploadevent.xhr: XmlHttpRequest instance.
+ event.formData: FormData object.
Callback to invoke before file upload begins to customize the request + such as post parameters before the files.
before-sendevent.xhr: XmlHttpRequest instance.
+ event.formData: FormData object.
Callback to invoke before file send begins to customize the request + such as adding headers.
uploadevent.xhr: XmlHttpRequest instance.
+ event.files: Uploaded files.
Callback to invoke when file upload is complete.
errorevent.xhr: XmlHttpRequest instance.
+ event.files: Files that are not uploaded.
Callback to invoke if file upload fails.
clear-.Callback to invoke when files in queue are removed without uploading.
selectevent.originalEvent: Original browser event.
+ event.files: List of selected files.
Callback to invoke when file upload is complete.
progressevent.originalEvent: Original browser event.
+ event.progress: Calculated progress value.
Callback to invoke when files are selected.
uploaderevent.files: List of selected files.Callback to invoke to implement a custom upload.
removeevent.file: Remove filed
+ event.files: Remaining files to be uploaded.
Callback to invoke when a singe file is removed from the list.