| 
									
										
										
										
											2018-11-10 05:17:35 +08:00
										 |  |  | import DropZone from "dropzone"; | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const template = `
 | 
					
						
							|  |  |  |     <div class="dropzone-container"> | 
					
						
							|  |  |  |         <div class="dz-message">{{placeholder}}</div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  | `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const props = ['placeholder', 'uploadUrl', 'uploadedTo']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // TODO - Remove jQuery usage
 | 
					
						
							|  |  |  | function mounted() { | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |    const container = this.$el; | 
					
						
							|  |  |  |    const _this = this; | 
					
						
							| 
									
										
										
										
											2018-03-19 02:08:37 +08:00
										 |  |  |    this._dz = new DropZone(container, { | 
					
						
							| 
									
										
										
										
											2018-11-18 02:52:08 +08:00
										 |  |  |         addRemoveLinks: true, | 
					
						
							|  |  |  |         dictRemoveFile: trans('components.image_upload_remove'), | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |         timeout: Number(window.uploadTimeout) || 60000, | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |         url: function() { | 
					
						
							|  |  |  |             return _this.uploadUrl; | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         init: function () { | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |             const dz = this; | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |             dz.on('sending', function (file, xhr, data) { | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |                 const token = window.document.querySelector('meta[name=token]').getAttribute('content'); | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |                 data.append('_token', token); | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |                 const uploadedTo = typeof _this.uploadedTo === 'undefined' ? 0 : _this.uploadedTo; | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |                 data.append('uploaded_to', uploadedTo); | 
					
						
							| 
									
										
										
										
											2018-11-18 02:52:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 xhr.ontimeout = function (e) { | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |                     dz.emit('complete', file); | 
					
						
							|  |  |  |                     dz.emit('error', file, trans('errors.file_upload_timeout')); | 
					
						
							| 
									
										
										
										
											2018-11-18 02:52:08 +08:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             dz.on('success', function (file, data) { | 
					
						
							|  |  |  |                 _this.$emit('success', {file, data}); | 
					
						
							|  |  |  |                 $(file.previewElement).fadeOut(400, function () { | 
					
						
							|  |  |  |                     dz.removeFile(file); | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             dz.on('error', function (file, errorMessage, xhr) { | 
					
						
							|  |  |  |                 _this.$emit('error', {file, errorMessage, xhr}); | 
					
						
							| 
									
										
										
										
											2018-03-24 22:54:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |                 function setMessage(message) { | 
					
						
							|  |  |  |                     $(file.previewElement).find('[data-dz-errormessage]').text(message); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-22 23:45:13 +08:00
										 |  |  |                 if (xhr && xhr.status === 413) { | 
					
						
							|  |  |  |                     setMessage(trans('errors.server_upload_limit')) | 
					
						
							|  |  |  |                 } else if (errorMessage.file) { | 
					
						
							|  |  |  |                     setMessage(errorMessage.file); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-03-24 22:54:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |             }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |    }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function data() { | 
					
						
							| 
									
										
										
										
											2018-03-19 02:08:37 +08:00
										 |  |  |     return {}; | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 02:08:37 +08:00
										 |  |  | const methods = { | 
					
						
							|  |  |  |     onClose: function () { | 
					
						
							|  |  |  |         this._dz.removeAllFiles(true); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-10 05:17:35 +08:00
										 |  |  | export default { | 
					
						
							| 
									
										
										
										
											2017-08-10 04:33:00 +08:00
										 |  |  |     template, | 
					
						
							|  |  |  |     props, | 
					
						
							|  |  |  |     mounted, | 
					
						
							|  |  |  |     data, | 
					
						
							| 
									
										
										
										
											2018-03-19 02:08:37 +08:00
										 |  |  |     methods | 
					
						
							| 
									
										
										
										
											2018-03-18 21:14:11 +08:00
										 |  |  | }; |