define(['components/paperdialoghelper', 'paper-dialog', 'paper-fab'], function (paperDialogHelper) { var currentItemId; var currentFile; var currentDeferred; var hasChanges = false; function onFileReaderError(evt) { Dashboard.hideLoadingMsg(); switch (evt.target.error.code) { case evt.target.error.NOT_FOUND_ERR: Dashboard.alert(Globalize.translate('MessageFileNotFound')); break; case evt.target.error.ABORT_ERR: break; // noop default: Dashboard.alert(Globalize.translate('MessageFileReadError')); break; }; } function setFiles(page, files) { var file = files[0]; if (!file || !file.type.match('image.*')) { $('#imageOutput', page).html(''); $('#fldUpload', page).hide(); currentFile = null; return; } currentFile = file; var reader = new FileReader(); reader.onerror = onFileReaderError; reader.onloadstart = function () { $('#fldUpload', page).hide(); }; reader.onabort = function () { Dashboard.hideLoadingMsg(); Logger.log('File read cancelled'); }; // Closure to capture the file information. reader.onload = (function (theFile) { return function (e) { // Render thumbnail. var html = [''].join(''); $('#imageOutput', page).html(html); $('#fldUpload', page).show(); }; })(file); // Read in the image file as a data URL. reader.readAsDataURL(file); } function processImageChangeResult(page) { hasChanges = true; history.back(); } function onSubmit() { var file = currentFile; if (!file) { return false; } if (file.type != "image/png" && file.type != "image/jpeg" && file.type != "image/jpeg") { return false; } Dashboard.showLoadingMsg(); var page = $(this).parents('paper-dialog'); var imageType = $('#selectImageType', page).val(); ApiClient.uploadItemImage(currentItemId, imageType, file).then(function () { $('#uploadImage', page).val('').trigger('change'); Dashboard.hideLoadingMsg(); processImageChangeResult(page); }); return false; } function initEditor(page) { $('form', page).off('submit', onSubmit).on('submit', onSubmit); $('#uploadImage', page).on("change", function () { setFiles(page, this.files); }); $("#imageDropZone", page).on('dragover', function (e) { e.preventDefault(); e.originalEvent.dataTransfer.dropEffect = 'Copy'; return false; }).on('drop', function (e) { e.preventDefault(); setFiles(page, e.originalEvent.dataTransfer.files); return false; }); } function showEditor(itemId, options) { options = options || {}; var xhr = new XMLHttpRequest(); xhr.open('GET', 'components/imageuploader/imageuploader.template.html', true); xhr.onload = function (e) { var template = this.response; currentItemId = itemId; var dlg = paperDialogHelper.createDialog({ theme: options.theme }); var html = ''; html += '

'; html += ''; html += '
' + Globalize.translate('HeaderUploadImage') + '
'; html += '

'; html += '
'; html += Globalize.translateDocument(template); html += '
'; dlg.innerHTML = html; document.body.appendChild(dlg); // Has to be assigned a z-index after the call to .open() $(dlg).on('iron-overlay-closed', onDialogClosed); paperDialogHelper.open(dlg); var editorContent = dlg.querySelector('.editorContent'); initEditor(editorContent); $('.btnCloseDialog', dlg).on('click', function () { paperDialogHelper.close(dlg); }); } xhr.send(); } function onDialogClosed() { $(this).remove(); Dashboard.hideLoadingMsg(); currentDeferred.resolveWith(null, [hasChanges]); } return { show: function (itemId, options) { var deferred = DeferredBuilder.Deferred(); currentDeferred = deferred; hasChanges = false; showEditor(itemId, options); return deferred.promise(); } }; });