From cac8102cfd38835d5c2f8fcbd93031c9b9512cac Mon Sep 17 00:00:00 2001 From: Forms Dev Date: Thu, 19 Oct 2023 10:29:05 +0530 Subject: [PATCH] copy and paste support for file and image upload --- resources/js/components/forms/FileInput.vue | 20 ++++++++++----- resources/js/components/forms/ImageInput.vue | 27 +++++++++++++++----- 2 files changed, 35 insertions(+), 12 deletions(-) diff --git a/resources/js/components/forms/FileInput.vue b/resources/js/components/forms/FileInput.vue index d5197cd8b..b0ac5b73a 100644 --- a/resources/js/components/forms/FileInput.vue +++ b/resources/js/components/forms/FileInput.vue @@ -115,9 +115,9 @@ class="font-semibold text-nt-blue hover:text-nt-blue-dark focus:outline-none focus:underline transition duration-150 ease-in-out" @click="openFileUpload" > - Upload {{ multiple ? 'file(s)' : 'a file' }} + Upload {{ multiple ? 'file(s)' : 'a file' }}, - or drag and drop + use drag and drop or paste it

Up to {{ mbLimit }}mb @@ -198,6 +198,10 @@ export default { if(this.disabled){ this.showUploadModal = false } + document.removeEventListener('paste', this.onUploadPasteEvent) + if(this.showUploadModal){ + document.addEventListener("paste", this.onUploadPasteEvent) + } } }, files: { @@ -237,11 +241,15 @@ export default { onUploadDropEvent (e) { this.uploadDragoverEvent = false this.uploadDragoverTracking = false - this.droppedFiles(e) + this.droppedFiles(e.dataTransfer.files) }, - droppedFiles (e) { - const droppedFiles = e.dataTransfer.files - + onUploadPasteEvent (e) { + if(!this.showUploadModal) return + this.uploadDragoverEvent = false + this.uploadDragoverTracking = false + this.droppedFiles(e.clipboardData.files) + }, + droppedFiles (droppedFiles) { if (!droppedFiles) return for (let i = 0; i < droppedFiles.length; i++) { diff --git a/resources/js/components/forms/ImageInput.vue b/resources/js/components/forms/ImageInput.vue index 11de7c4bc..3020f1b4a 100644 --- a/resources/js/components/forms/ImageInput.vue +++ b/resources/js/components/forms/ImageInput.vue @@ -86,9 +86,9 @@ class="font-semibold text-nt-blue hover:text-nt-blue-dark focus:outline-none focus:underline transition duration-150 ease-in-out" @click="openFileUpload" > - Upload your image + Upload your image, - or drag and drop + use drag and drop or paste it

.jpg, .jpeg, .png, .bmp, .gif, .svg up to 5mb @@ -130,6 +130,17 @@ export default { } }, + watch: { + showUploadModal: { + handler (val) { + document.removeEventListener('paste', this.onUploadPasteEvent) + if(this.showUploadModal){ + document.addEventListener("paste", this.onUploadPasteEvent) + } + } + } + }, + methods: { clearUrl () { this.$set(this.form, this.name, null) @@ -141,11 +152,15 @@ export default { onUploadDropEvent (e) { this.uploadDragoverEvent = false this.uploadDragoverTracking = false - this.droppedFiles(e) + this.droppedFiles(e.dataTransfer.files) }, - droppedFiles (e) { - const droppedFiles = e.dataTransfer.files - + onUploadPasteEvent (e) { + if(!this.showUploadModal) return + this.uploadDragoverEvent = false + this.uploadDragoverTracking = false + this.droppedFiles(e.clipboardData.files) + }, + droppedFiles (droppedFiles) { if (!droppedFiles) return this.file = droppedFiles[0]