import $ from 'jquery'; import Dropzone from 'dropzone'; import { config, translations } from 'grav-form'; let request = {}; // translations const Dictionary = { dictCancelUpload: translations.PLUGIN_FORM.DROPZONE_CANCEL_UPLOAD, dictCancelUploadConfirmation: translations.PLUGIN_FORM.DROPZONE_CANCEL_UPLOAD_CONFIRMATION, dictDefaultMessage: translations.PLUGIN_FORM.DROPZONE_DEFAULT_MESSAGE, dictFallbackMessage: translations.PLUGIN_FORM.DROPZONE_FALLBACK_MESSAGE, dictFallbackText: translations.PLUGIN_FORM.DROPZONE_FALLBACK_TEXT, dictFileTooBig: translations.PLUGIN_FORM.DROPZONE_FILE_TOO_BIG, dictInvalidFileType: translations.PLUGIN_FORM.DROPZONE_INVALID_FILE_TYPE, dictMaxFilesExceeded: translations.PLUGIN_FORM.DROPZONE_MAX_FILES_EXCEEDED, dictRemoveFile: translations.PLUGIN_FORM.DROPZONE_REMOVE_FILE, dictRemoveFileConfirmation: translations.PLUGIN_FORM.DROPZONE_REMOVE_FILE_CONFIRMATION, dictResponseError: translations.PLUGIN_FORM.DROPZONE_RESPONSE_ERROR }; Dropzone.autoDiscover = false; const DropzoneMediaConfig = { createImageThumbnails: { thumbnailWidth: 150 }, addRemoveLinks: false, dictDefaultMessage: Dictionary.dictDefaultMessage, dictRemoveFileConfirmation: Dictionary.dictRemoveFileConfirmation, previewTemplate: `
${translations.PLUGIN_FORM.FILE_ERROR_UPLOAD} ${file.name}
${response.message}` }); } onDropzoneComplete(file) { if (!file.accepted && !file.rejected) { let data = { status: 'error', message: `${translations.PLUGIN_FORM.FILE_UNSUPPORTED}: ${file.name.match(/\..+/).join('')}` }; return this.handleError({ file, data, mode: 'removeFile', msg: `
${translations.PLUGIN_FORM.FILE_ERROR_ADD} ${file.name}
${data.message}` }); } if (this.options.reloadPage) { global.location.reload(); } } onDropzoneRemovedFile(file, ...extra) { if (!file.accepted || file.rejected) { return; } let url = file.removeUrl || this.urls.delete; let path = (url || '').match(/path:(.*)\//); let body = { filename: file.name }; if (file.sessionParams) { body.task = 'filessessionremove'; body.session = file.sessionParams; } request(url, { method: 'post', body }, () => { if (!path) { return; } path = global.atob(path[1]); let input = this.container.find('[name][type="hidden"]'); let data = JSON.parse(input.val() || '{}'); delete data[path]; input.val(JSON.stringify(data)); }); } onDropzoneError(file, response, xhr) { let message = xhr && response.error ? response.error.message : response; $(file.previewElement).find('[data-dz-errormessage]').html(message); return this.handleError({ file, data: { status: 'error' }, msg: `
${message}` }); } handleError(options) { return true; /* let { file, data, mode, msg } = options; if (data.status !== 'error' && data.status !== 'unauthorized') { return; } switch (mode) { case 'addBack': if (file instanceof File) { this.dropzone.addFile.call(this.dropzone, file); } else { this.dropzone.files.push(file); this.dropzone.options.addedfile.call(this.dropzone, file); this.dropzone.options.thumbnail.call(this.dropzone, file, file.extras.url); } break; case 'removeFile': default: if (~this.dropzone.files.indexOf(file)) { file.rejected = true; this.dropzone.removeFile.call(this.dropzone, file, { silent: true }); } break; } let modal = $('[data-remodal-id="generic"]'); modal.find('.error-content').html(msg); $.remodal.lookup[modal.data('remodal')].open(); */ } } export function UriToMarkdown(uri) { uri = uri.replace(/@3x|@2x|@1x/, ''); uri = uri.replace(/\(/g, '%28'); uri = uri.replace(/\)/g, '%29'); return uri.match(/\.(jpe?g|png|gif|svg)$/i) ? `![](${uri})` : `[${decodeURI(uri)}](${uri})`; } let instances = []; let cache = $(); const onAddedNodes = (event, target/* , record, instance */) => { let files = $(target).find('.dropzone.files-upload'); if (!files.length) { return; } files.each((index, file) => { file = $(file); if (!~cache.index(file)) { addNode(file); } }); }; const addNode = (container) => { container = $(container); let input = container.find('input[type="file"]'); let settings = container.data('grav-file-settings') || {}; if (settings.accept && ~settings.accept.indexOf('*')) { settings.accept = ['']; } let options = { url: container.data('file-url-add') || (container.closest('form').attr('action') || config.current_url) + '.json', paramName: settings.paramName || 'file', dotNotation: settings.name || 'file', acceptedFiles: settings.accept ? settings.accept.join(',') : input.attr('accept') || container.data('media-types'), maxFilesize: settings.filesize || 256, maxFiles: settings.limit || null }; cache = cache.add(container); container = container[0]; instances.push(new FilesField({ container, options })); }; export let Instances = (() => { $('.dropzone.files-upload').each((i, container) => addNode(container)); $('body').on('mutation._grav', onAddedNodes); return instances; })();