From 699fa6712d56c843695fd39c08ffb0df230ff5fe Mon Sep 17 00:00:00 2001 From: colymba Date: Sun, 6 Apr 2014 19:55:25 +0300 Subject: [PATCH] Implement editAll + bulkManager requirement check --- .../javascript/GridFieldBulkManager.js | 8 +++- bulkUpload/code/GridFieldBulkUpload.php | 29 ++++++++------ bulkUpload/javascript/GridFieldBulkUpload.js | 39 +++++++++++-------- 3 files changed, 45 insertions(+), 31 deletions(-) diff --git a/bulkManager/javascript/GridFieldBulkManager.js b/bulkManager/javascript/GridFieldBulkManager.js index 6a6c6fd..e3085fc 100644 --- a/bulkManager/javascript/GridFieldBulkManager.js +++ b/bulkManager/javascript/GridFieldBulkManager.js @@ -150,11 +150,15 @@ return; } - if ( $btn.hasClass('ss-ui-action-destructive') ) + //if ( $btn.hasClass('ss-ui-action-destructive') ) + if ( config[action]['isDestructive'] ) { if( !confirm(ss.i18n._t('GridFieldBulkManager.CONFIRM_DESTRUCTIVE_ACTION')) ) { - e.preventDefault(); + if ( callbackFunction && callbackContext ) + { + callbackFunction.call(callbackContext, false); + } return false; } } diff --git a/bulkUpload/code/GridFieldBulkUpload.php b/bulkUpload/code/GridFieldBulkUpload.php index f8cccc2..fe16703 100644 --- a/bulkUpload/code/GridFieldBulkUpload.php +++ b/bulkUpload/code/GridFieldBulkUpload.php @@ -265,31 +265,36 @@ class GridFieldBulkUpload implements GridField_HTMLProvider, GridField_URLHandle return array(); } + // check BulkManager exists + $bulkManager = $gridField->getConfig()->getComponentsByType('GridFieldBulkManager'); + // upload management buttons $finishButton = FormAction::create('Finish', _t('GridFieldBulkTools.FINISH_BTN_LABEL', 'Finish')) ->addExtraClass('bulkUploadFinishButton') ->setAttribute('data-icon', 'accept') ->setUseButtonTag(true); - $cancelButton = FormAction::create('Cancel', _t('GridFieldBulkTools.CANCEL_BTN_LABEL', 'Cancel')) - ->addExtraClass('bulkUploadCancelButton ss-ui-action-destructive') - ->setAttribute('data-icon', 'decline') - ->setAttribute('data-url', $gridField->Link('bulkupload/cancel')) - ->setUseButtonTag(true); - $clearErrorButton = FormAction::create('ClearError', _t('GridFieldBulkTools.CLEAR_ERROR_BTN_LABEL', 'Clear errors')) ->addExtraClass('bulkUploadClearErrorButton') ->setAttribute('data-icon', 'arrow-circle-double') ->setUseButtonTag(true); - if ( $gridField->getConfig()->getComponentsByType('GridFieldBulkManager') ) + if ( !$bulkManager ) { + $cancelButton = FormAction::create('Cancel', _t('GridFieldBulkTools.CANCEL_BTN_LABEL', 'Cancel')) + ->addExtraClass('bulkUploadCancelButton ss-ui-action-destructive') + ->setAttribute('data-icon', 'decline') + ->setAttribute('data-url', $gridField->Link('bulkupload/cancel')) + ->setUseButtonTag(true); + $editAllButton = FormAction::create('EditAll', _t('GridFieldBulkTools.EDIT_ALL_BTN_LABEL', 'Edit all')) - ->addExtraClass('bulkUploadEditButton') - ->setAttribute('data-icon', 'pencil') - ->setAttribute('data-url', $gridField->Link('bulkupload/edit')) - ->setUseButtonTag(true); - }else{ + ->addExtraClass('bulkUploadEditButton') + ->setAttribute('data-icon', 'pencil') + ->setAttribute('data-url', $gridField->Link('bulkupload/edit')) + ->setUseButtonTag(true); + } + else{ + $cancelButton = ''; $editAllButton = ''; } diff --git a/bulkUpload/javascript/GridFieldBulkUpload.js b/bulkUpload/javascript/GridFieldBulkUpload.js index 7fd236f..fb99026 100644 --- a/bulkUpload/javascript/GridFieldBulkUpload.js +++ b/bulkUpload/javascript/GridFieldBulkUpload.js @@ -199,21 +199,26 @@ { var $bulkUpload = this.parents('.bulkUpload'), $li = $bulkUpload.find('li.ss-uploadfield-item'), - ids = data.records + ids ; + if ( data ) + { + ids = data.records; + + $li.each(function(index, Element){ + var $this = $(this), + recordID = parseInt( $this.data('recordid') ) + ; + + if ( ids.indexOf(recordID) !== -1 ) + { + $this.remove(); + } + }); + } + this.removeClass('loading'); - - $li.each(function(index, Element){ - var $this = $(this), - recordID = parseInt( $this.data('recordid') ) - ; - - if ( ids.indexOf(recordID) !== -1 ) - { - $this.remove(); - } - }); } }); @@ -228,10 +233,12 @@ $li = $bulkUpload.find('li.ss-uploadfield-item') ; + this.addClass('loading'); $li.each(function(index, Element){ // skip in progress $(this).remove(); }); + this.removeClass('loading'); } }); @@ -251,16 +258,14 @@ if ( $doBulkActionButton.length > 0 ) { + this.addClass('loading'); + recordsID = $records.map(function() { return parseInt( $(this).data('recordid') ) }).get(); - $doBulkActionButton.doBulkAction('edit', recordsID, this.editCallback); + $doBulkActionButton.doBulkAction('bulkedit', recordsID); } - }, - editCallback: function(response) - { - } });