Skip to content

Commit

Permalink
NEW Show icons on tabs with invalid form field values
Browse files Browse the repository at this point in the history
  • Loading branch information
emteknetnz committed Sep 17, 2020
1 parent f88e70c commit 9842494
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 21 deletions.
2 changes: 1 addition & 1 deletion client/dist/js/bundle.js

Large diffs are not rendered by default.

71 changes: 51 additions & 20 deletions client/src/legacy/LeftAndMain.EditForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -110,27 +110,58 @@ $.entwine('ss', function($){
},
'from .cms-tabset': {
onafterredrawtabs: function () {
// Show validation errors if necessary
if(this.hasClass('validationerror')) {
// Ensure the first validation error is visible
var tabError = this.find('.message.validation, .message.required').first().closest('.tab');
$('.cms-container').clearCurrentTabState(); // clear state to avoid override later on

// Attempt #1: Look for nearest .ss-tabset (usually nested deeper underneath a .cms-tabset).
var $tabSet = tabError.closest('.ss-tabset');

// Attempt #2: Next level in tab-ception, try to select the tab within this higher level .cms-tabset if possible
if (!$tabSet.length) {
$tabSet = tabError.closest('.cms-tabset');
}

if ($tabSet.length) {
$tabSet.tabs('option', 'active', tabError.index('.tab'));
} else if (!this.getValidationErrorShown()) {
// Ensure that this error message popup won't be added more than once
this.setValidationErrorShown(true);
errorMessage(ss.i18n._t('Admin.VALIDATIONERROR', 'Validation Error'));
}
// This function will:
// - Add an invalid icon on each tab that contains form fields than failed validation
// - Set an alert message in the edit form error banner
// - In some edge cases, fallback to a legacy behaviour of showing a toast notification
const iconClass = 'invalid-tab-icon';

// Remove any existing invalid tab icons
this.find(`.${iconClass}`).remove();

// Reset the edit form banner
const $editFormErrorBanner = $("#Form_EditForm_error");
$editFormErrorBanner.attr('class', 'alert');
$editFormErrorBanner.html('');
$editFormErrorBanner.hide();

// Check if there are any form validation errors
if(!this.hasClass('validationerror')) {
return;
}

// Find tab-pane's with decedent validation .alert's
const $invalidTabPanes = this.find('.tab-pane .alert').closest('.tab-pane');
if (!$invalidTabPanes.length) {
return;
}

// Get the surrounding ss-tabset
const $ssTabSet = $invalidTabPanes.closest('.tab-content').closest('.ss-tabset');
if ($ssTabSet.length) {

// Add invalid icons to tabs
$invalidTabPanes.each((i) => {
const invalidTabPaneId = $invalidTabPanes.eq(i).attr('id');
const $tabLi = $ssTabSet.find(`#tab-${invalidTabPaneId}`).closest('li');
const $icon = $(`<i class="${iconClass}">@</i>`);
$tabLi.append($icon);
});

// Set an alert message in the edit form error banner
const messageText = 'lorem ipsum';
$editFormErrorBanner.attr('class', 'alert alert-danger');
$editFormErrorBanner.html(messageText);
$editFormErrorBanner.show();
return;
}

// Legacy fallback behaviour - show a toast notification
if (!this.getValidationErrorShown()) {
errorMessage(ss.i18n._t('Admin.VALIDATIONERROR', 'Validation Error'));
// Ensure that this error message popup won't be added more than once
this.setValidationErrorShown(true);
}
}
},
Expand Down

0 comments on commit 9842494

Please sign in to comment.