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