275 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			275 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|     <div :id="'dropzone-' + _uid" class="dropzone mb-3 dz-clickable" :class="[preview == 'single' ? 'dropzone-single': 'dropzone-multiple']">
 | |
|         <div class="fallback">
 | |
|             <div class="custom-file">
 | |
|                 <input type="file" class="custom-file-input" :id="'projectCoverUploads' + _uid" :multiple="multiple">
 | |
| 
 | |
|                 <label class="custom-file-label" :for="'projectCoverUploads' + _uid">{{ textChooseFile }}</label>
 | |
|             </div>
 | |
|         </div>
 | |
| 
 | |
|         <div v-if="preview == 'single'" class="dz-preview dz-preview-single" :class="previewClasses" ref="previewSingle">
 | |
|             <div class="dz-preview-cover">
 | |
|                 <img class="dz-preview-img" data-dz-thumbnail>
 | |
|                 <i class="fas fa-file-image display-3 fa-2x mt-2 d-none" data-dz-thumbnail-image></i>
 | |
|                 <i class="far fa-file-pdf display-3 fa-2x mt-2 d-none" data-dz-thumbnail-pdf></i>
 | |
|                 <i class="far fa-file-word fa-2x mt-2 d-none" data-dz-thumbnail-word></i>
 | |
|                 <i class="far fa-file-excel fa-2x mt-2 d-none" data-dz-thumbnail-excel></i>
 | |
|                 <span class="mb-1 d-none" data-dz-name>...</span>
 | |
|             </div>
 | |
|         </div>
 | |
| 
 | |
|         <ul v-else class="dz-preview dz-preview-multiple list-group list-group-lg list-group-flush" :class="previewClasses" ref="previewMultiple">
 | |
|             <li class="list-group-item px-0">
 | |
|                 <div class="row align-items-center">
 | |
|                     <div class="col-auto">
 | |
|                         <div class="avatar">
 | |
|                             <img class="avatar-img rounded" data-dz-thumbnail>
 | |
|                             <i class="fas fa-file-image display-3 d-none" data-dz-thumbnail-image></i>
 | |
|                             <i class="far fa-file-pdf display-3 d-none" data-dz-thumbnail-pdf></i>
 | |
|                             <i class="far fa-file-word d-none" data-dz-thumbnail-word></i>
 | |
|                             <i class="far fa-file-excel d-none" data-dz-thumbnail-excel></i>
 | |
|                         </div>
 | |
|                     </div>
 | |
| 
 | |
|                     <div class="col ml--3">
 | |
|                         <h4 class="mb-1" data-dz-name>...</h4>
 | |
| 
 | |
|                         <p class="small text-muted mb-0" data-dz-size>...</p>
 | |
|                     </div>
 | |
| 
 | |
|                     <div class="col-auto">
 | |
|                         <button data-dz-remove="true" class="btn btn-danger btn-sm">
 | |
|                             <i class="fas fa-trash"></i>
 | |
|                         </button>
 | |
|                         <a href="#" type="button" class="btn btn-sm btn-info text-white d-none" data-dz-download>
 | |
|                             <i class="fas fa-file-download"></i>
 | |
|                         </a>
 | |
|                     </div>
 | |
|                 </div>
 | |
|             </li>
 | |
|         </ul>
 | |
|     </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import Dropzone from 'dropzone';
 | |
| 
 | |
| Dropzone.autoDiscover = false;
 | |
| 
 | |
| export default {
 | |
|     name: 'akaunting-dropzone-file-upload',
 | |
| 
 | |
|     props: {
 | |
|         textDropFile: {
 | |
|             type: String,
 | |
|             default: 'Drop files here to upload',
 | |
|             description: 'Drop file text'
 | |
|         },
 | |
|         textChooseFile: {
 | |
|             type: String,
 | |
|             default: 'Choose File',
 | |
|             description: 'Choose file text'
 | |
|         },
 | |
|         options: {
 | |
|             type: Object,
 | |
|             default: () => ({})
 | |
|         },
 | |
|         value: [String, Object, Array, File],
 | |
|         url: {
 | |
|             type: String,
 | |
|             default: 'http:'
 | |
|         },
 | |
|         multiple: {
 | |
|             type: Boolean,
 | |
|             default: false,
 | |
|             description: 'Multiple file Upload'
 | |
|         },
 | |
|         previewClasses: [String, Object, Array],
 | |
|         preview: {
 | |
|             type: String,
 | |
|             default: function () {
 | |
|                 return this.multiple ? 'multiple' : 'single'
 | |
|             },
 | |
|         },
 | |
|         attachments: {
 | |
|             type: Array,
 | |
|             default: () => ([])
 | |
|         },
 | |
|     },
 | |
| 
 | |
|     model: {
 | |
|         prop: 'value',
 | |
|         event: 'change'
 | |
|     },
 | |
| 
 | |
|     data() {
 | |
|         return {
 | |
|             files: [],
 | |
|             configurations: this.options,
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     methods: {
 | |
|         async initDropzone() {
 | |
|             let self = this;
 | |
|             let preview = this.preview == 'single' ? this.$refs.previewSingle : this.$refs.previewMultiple;
 | |
| 
 | |
|             if (this.configurations.maxFiles === undefined && this.multiple == false) {
 | |
|                 this.configurations.maxFiles = 1;
 | |
|             }
 | |
| 
 | |
|             if (this.configurations.acceptedFiles === undefined) {
 | |
|                 this.configurations.acceptedFiles = 'image/*';
 | |
|             }
 | |
| 
 | |
|             let finalOptions = {
 | |
|                 ...self.configurations,
 | |
|                 url: this.url,
 | |
|                 previewsContainer: preview,
 | |
|                 previewTemplate: preview.innerHTML,
 | |
|                 dictDefaultMessage: this.textDropFile,
 | |
|                 autoProcessQueue: false,
 | |
| 
 | |
|                 init: function () {
 | |
|                     let dropzone = this;
 | |
| 
 | |
|                     dropzone.on('addedfile', function (file) {
 | |
|                         self.files.push(file);
 | |
| 
 | |
|                         if (self.configurations.maxFiles == 1) {
 | |
|                             self.$emit('change', file);
 | |
|                         } else {
 | |
|                             self.$emit('change', self.files);
 | |
|                         }
 | |
| 
 | |
|                         if (file.type.indexOf("image") == -1) {
 | |
|                             let ext = file.name.split('.').pop();
 | |
| 
 | |
|                             file.previewElement.querySelector("[data-dz-thumbnail]").classList.add("d-none");
 | |
|                             file.previewElement.querySelector("[data-dz-name]").classList.remove("d-none");
 | |
| 
 | |
|                             if (ext == "pdf") {
 | |
|                                 file.previewElement.querySelector("[data-dz-thumbnail-pdf]").classList.remove("d-none");
 | |
|                             } else if ((ext.indexOf("doc") != -1) || (ext.indexOf("docx") != -1)) {
 | |
|                                 file.previewElement.querySelector("[data-dz-thumbnail-word]").classList.remove("d-none");
 | |
|                             } else if ((ext.indexOf("xls") != -1) || (ext.indexOf("xlsx") != -1)) {
 | |
|                                 file.previewElement.querySelector("[data-dz-thumbnail-excel]").classList.remove("d-none");
 | |
|                             } else {
 | |
|                                 file.previewElement.querySelector("[data-dz-thumbnail-image]").classList.remove("d-none");
 | |
|                             }
 | |
|                         }
 | |
|                     }),
 | |
|  
 | |
|                     dropzone.on('removedfile', function (file) {
 | |
|                         let index = self.files.findIndex(f => f.name === file.name)
 | |
| 
 | |
|                         if (index !== -1) {
 | |
|                             self.files.splice(index, 1);
 | |
|                         }
 | |
| 
 | |
|                         self.$emit('change', self.files);
 | |
| 
 | |
|                         if (self.multiple) {
 | |
|                             this.enable();
 | |
|                         }
 | |
|                     }),
 | |
| 
 | |
|                     dropzone.on('maxfilesexceeded', function(file) {
 | |
|                         this.removeAllFiles('notCancel');
 | |
|                         this.addFile(file);
 | |
|                     }),
 | |
| 
 | |
|                     dropzone.on('maxfilesreached', function(file) {
 | |
|                         if (self.multiple) {
 | |
|                             this.disable();
 | |
|                         }
 | |
|                     })
 | |
| 
 | |
|                     if (self.attachments.length) {
 | |
|                         setTimeout(() => {
 | |
|                             self.attachments.forEach(async (attachment) => {
 | |
|                                 var mockFile = {
 | |
|                                     id: attachment.id,
 | |
|                                     name: attachment.name,
 | |
|                                     size: attachment.size,
 | |
|                                     type: attachment.type,
 | |
|                                     download: attachment.downloadPath,
 | |
|                                     dropzone: 'edit',
 | |
|                                 };
 | |
| 
 | |
|                                 dropzone.emit("addedfile", mockFile);
 | |
|                                 dropzone.options.thumbnail.call(dropzone, mockFile, attachment.path);
 | |
| 
 | |
|                                 // Make sure that there is no progress bar, etc...
 | |
|                                 dropzone.emit("complete", mockFile);
 | |
|                             });
 | |
| 
 | |
|                             self.files.forEach(async (attachment) => {
 | |
|                                 if (attachment.download) {
 | |
|                                     attachment.previewElement.querySelector("[data-dz-download]").href = attachment.download;
 | |
|                                     attachment.previewElement.querySelector("[data-dz-download]").classList.remove("d-none");
 | |
|                                 }
 | |
|                             });
 | |
| 
 | |
|                             if (self.preview == 'single' && self.attachments.length == 1) {
 | |
|                                 self.$nextTick(() => {
 | |
|                                     document.querySelector("#dropzone-" + self._uid).classList.add("dz-max-files-reached");
 | |
|                                 });
 | |
|                             }
 | |
|                         }, 100);
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|             this.dropzone = new Dropzone(this.$el, finalOptions);
 | |
| 
 | |
|             preview.innerHTML = '';
 | |
|         },
 | |
|     },
 | |
| 
 | |
|     async mounted() {
 | |
|         this.initDropzone();
 | |
|     },
 | |
|     
 | |
|     watch: {
 | |
|     attachments: function (attachments) {
 | |
|       attachments.forEach((attachment) => {
 | |
|           if(attachment.length != undefined) {
 | |
|               var mockFile = {
 | |
|                 id: attachment[0].id,
 | |
|                 name: attachment[0].name,
 | |
|                 size: attachment[0].size,
 | |
|                 type: attachment[0].type,
 | |
|                 download: attachment[0].downloadPath,
 | |
|                 dropzone: 'edit',
 | |
|             };
 | |
|             this.dropzone.emit("addedfile", mockFile);
 | |
|             this.dropzone.options.thumbnail.call(this.dropzone, mockFile, attachment[0].path);
 | |
| 
 | |
|             // Make sure that there is no progress bar, etc...
 | |
|             this.dropzone.emit("complete", mockFile);
 | |
| 
 | |
|             this.files.forEach(async (attachment) => {
 | |
|                 if (attachment.download) {
 | |
|                     attachment.previewElement.querySelector("[data-dz-download]").href = attachment.download;
 | |
|                     attachment.previewElement.querySelector("[data-dz-download]").classList.remove("d-none");
 | |
|                 }
 | |
|         });
 | |
| 
 | |
|         if (this.preview == 'single' && attachments.length == 1) {
 | |
|             this.$nextTick(() => {
 | |
|                 document.querySelector("#dropzone-" + this._uid).classList.add("dz-max-files-reached");
 | |
|             });
 | |
|         }
 | |
|           }
 | |
|         }, this);
 | |
| 
 | |
|     },
 | |
|   },
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style>
 | |
| </style>
 |