From f47383f52e885ec526da7a5649e8d6e9a1d97294 Mon Sep 17 00:00:00 2001 From: Damian Mooyman Date: Thu, 20 Jun 2013 15:21:18 +1200 Subject: [PATCH] BUG Fixed issue where file upload via the HTML Editor media dialogue would not prompt users to overwrite existing files --- admin/css/screen.css | 2 +- admin/scss/_style.scss | 11 ++++++++--- forms/HtmlEditorField.php | 2 -- javascript/HtmlEditorField.js | 5 +++-- javascript/UploadField.js | 13 +++++++++++-- 5 files changed, 23 insertions(+), 10 deletions(-) diff --git a/admin/css/screen.css b/admin/css/screen.css index 141d99b45..3d62db2fb 100644 --- a/admin/css/screen.css +++ b/admin/css/screen.css @@ -668,7 +668,7 @@ body.cms-dialog { overflow: auto; background: url("../images/textures/bg_cms_mai .htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield h4 { float: left; margin-top: 4px; margin-bottom: 0; } .htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield .middleColumn { margin-top: 16px; margin-left: 184px; } .htmleditorfield-mediaform .htmleditorfield-from-cms .ss-uploadfield .field.treedropdown { border-bottom: 0; padding: 0; } -.htmleditorfield-mediaform .ss-uploadfield-editandorganize { display: none; } +.htmleditorfield-mediaform .ss-assetuploadfield .ss-uploadfield-editandorganize .ss-uploadfield-files .ss-uploadfield-item-info { background-color: #9e9e9e; background-image: url(''); background-size: 100%; background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #9e9e9e), color-stop(8%, #9d9d9d), color-stop(50%, #878787), color-stop(54%, #868686), color-stop(96%, #6b6b6b), color-stop(100%, #6c6c6c)); background-image: -webkit-linear-gradient(top, #9e9e9e 0%, #9d9d9d 8%, #878787 50%, #868686 54%, #6b6b6b 96%, #6c6c6c 100%); background-image: -moz-linear-gradient(top, #9e9e9e 0%, #9d9d9d 8%, #878787 50%, #868686 54%, #6b6b6b 96%, #6c6c6c 100%); background-image: -o-linear-gradient(top, #9e9e9e 0%, #9d9d9d 8%, #878787 50%, #868686 54%, #6b6b6b 96%, #6c6c6c 100%); background-image: linear-gradient(top, #9e9e9e 0%, #9d9d9d 8%, #878787 50%, #868686 54%, #6b6b6b 96%, #6c6c6c 100%); } /** -------------------------------------------- Search forms (used in AssetAdmin, ModelAdmin, etc) -------------------------------------------- */ .cms-search-form { margin-bottom: 16px; } diff --git a/admin/scss/_style.scss b/admin/scss/_style.scss index 07c9ef271..1bd85cfaf 100644 --- a/admin/scss/_style.scss +++ b/admin/scss/_style.scss @@ -1535,9 +1535,14 @@ body.cms-dialog { } } - .ss-uploadfield-editandorganize { - display: none; - } + .ss-assetuploadfield .ss-uploadfield-editandorganize { + .ss-uploadfield-files { + .ss-uploadfield-item-info { + background-color: grayscale(#5db4df); + @include background-image(linear-gradient(top, grayscale(#5db4df) 0%, grayscale(#5db1dd) 8%, grayscale(#439bcb) 50%, grayscale(#3f99cd) 54%, grayscale(#207db6) 96%, grayscale(#1e7cba) 100%)); + } + } + } } /** -------------------------------------------- diff --git a/forms/HtmlEditorField.php b/forms/HtmlEditorField.php index c2e87f102..c5a9fc1a3 100644 --- a/forms/HtmlEditorField.php +++ b/forms/HtmlEditorField.php @@ -428,8 +428,6 @@ class HtmlEditorField_Toolbar extends RequestHandler { $computerUploadField->removeExtraClass('ss-uploadfield'); $computerUploadField->setTemplate('HtmlEditorField_UploadField'); $computerUploadField->setFolderName(Config::inst()->get('Upload', 'uploads_folder')); - // @todo - Remove this once this field supports display and recovery of file upload validation errors - $computerUploadField->setOverwriteWarning(false); $tabSet = new TabSet( "MediaFormInsertMediaTabs", diff --git a/javascript/HtmlEditorField.js b/javascript/HtmlEditorField.js index dc6c443b9..055160ebc 100644 --- a/javascript/HtmlEditorField.js +++ b/javascript/HtmlEditorField.js @@ -808,7 +808,7 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; }); ed.repaint(); - }) + }); this.getDialog().close(); return false; @@ -926,8 +926,9 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE; var uploadedFiles = $('.ss-uploadfield-files', this).children('.ss-uploadfield-item'); uploadedFiles.each(function(){ var uploadedID = $(this).data('fileid'); - if ($.inArray(uploadedID, editFieldIDs) == -1) { + if (uploadedID && $.inArray(uploadedID, editFieldIDs) == -1) { //trigger the detail view for filling out details about the file we are about to insert into TinyMCE + $(this).remove(); // Remove successfully added item from the queue form.showFileView(uploadedID); } }); diff --git a/javascript/UploadField.js b/javascript/UploadField.js index 92362c3a6..1d6715732 100644 --- a/javascript/UploadField.js +++ b/javascript/UploadField.js @@ -64,13 +64,16 @@ .addClass('ui-state-warning-text'); data.context.find('.ss-uploadfield-item-progress').hide(); data.context.find('.ss-uploadfield-item-overwrite').show(); - data.context.find('.ss-uploadfield-item-overwrite-warning').on('click', function(){ + data.context.find('.ss-uploadfield-item-overwrite-warning').on('click', function(e){ data.context.find('.ss-uploadfield-item-progress').show(); data.context.find('.ss-uploadfield-item-overwrite').hide(); data.context.find('.ss-uploadfield-item-status') .removeClass('ui-state-warning-text'); //upload only if the "overwrite" button is clicked $.blueimpUI.fileupload.prototype._onSend.call(that, e, data); + + e.preventDefault(); // Avoid a form submit + return false; }); } else { //regular file upload return $.blueimpUI.fileupload.prototype._onSend.call(that, e, data); @@ -319,12 +322,14 @@ $('div.ss-upload .ss-uploadfield-startall').entwine({ onclick: function(e) { this.closest('.ss-upload').find('.ss-uploadfield-item-start button').click(); + e.preventDefault(); // Avoid a form submit return false; } }); $('div.ss-upload .ss-uploadfield-item-cancelfailed').entwine({ onclick: function(e) { this.closest('.ss-uploadfield-item').remove(); + e.preventDefault(); // Avoid a form submit return false; } }); @@ -349,6 +354,7 @@ fileupload._trigger('destroy', e, {context: item}); } + e.preventDefault(); // Avoid a form submit return false; } }); @@ -371,6 +377,7 @@ } e.preventDefault(); // Avoid a form submit + return false; } }); $( 'div.ss-upload:not(.disabled):not(.readonly) .ss-uploadfield-item-edit').entwine({ @@ -403,6 +410,7 @@ editform.toggleEditForm(); } e.preventDefault(); // Avoid a form submit + return false; } }); @@ -486,8 +494,9 @@ }); $('div.ss-upload .ss-uploadfield-fromfiles').entwine({ onclick: function(e) { - e.preventDefault(); this.getUploadField().openSelectDialog(this.closest('.ss-uploadfield-item')); + e.preventDefault(); // Avoid a form submit + return false; } }); });