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 18, 2020
1 parent 1729957 commit d5fae61
Show file tree
Hide file tree
Showing 5 changed files with 85 additions and 22 deletions.
2 changes: 1 addition & 1 deletion client/dist/js/bundle.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion client/dist/styles/bundle.css

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions client/lang/src/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
"Admin.CONFIRMUNSAVED": "Are you sure you want to navigate away from this page?\n\nWARNING: Your changes have not been saved.\n\nPress OK to continue, or Cancel to stay on the current page.",
"Admin.CONFIRMUNSAVEDSHORT": "WARNING: Your changes have not been saved.",
"Admin.VALIDATIONERROR": "Validation Error",
"Admin.VALIDATION_ERRORS_IN_TAB": "This tab contains validation errors.",
"Admin.VALIDATION_ERRORS_ON_PAGE": "There are validation errors on this page, please fix them before saving or publishing.",
"Admin.NONE": "None",
"Admin.EDIT": "Edit",
"Admin.ANY": "Any",
Expand Down
82 changes: 62 additions & 20 deletions client/src/legacy/LeftAndMain.EditForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -110,27 +110,69 @@ $.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 = 'font-icon-attention-1 tab-attention';
const iconTitle = ss.i18n._t(
'VALIDATION_ERRORS_IN_TAB',
'This tab contains validation errors.'
);
const alertMessageText = ss.i18n._t(
'Admin.VALIDATION_ERRORS_ON_PAGE',
'There are validation errors on this page, please fix them before saving or publishing.'
);
const toastNotificationMessage = ss.i18n._t(
'Admin.VALIDATIONERROR',
'Validation Error'
);

// Remove any existing invalid tab icons
this.find(`.${iconClass.split(' ').join('.')}`).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}" title="${iconTitle}" aria-hidden="true"></i>`);
$tabLi.append($icon);
});

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

// Legacy fallback behaviour - show a toast notification
if (!this.getValidationErrorShown()) {
errorMessage(toastNotificationMessage);
// Ensure that this error message popup won't be added more than once
this.setValidationErrorShown(true);
}
}
},
Expand Down
19 changes: 19 additions & 0 deletions client/src/styles/legacy/_style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -687,6 +687,25 @@ html, body {
}
}

.validationerror .panel--padded .ui-tabs-nav {
margin-top: -$panel-padding-y / 2;

.nav-item {
display: flex;
}

.nav-link {
align-self: flex-end;
}

.tab-attention {
color: $state-draft;
align-self: flex-start;
margin-top: 12px;
margin-left: -4px;
}
}

// -------------------------------------------------------
// Loading Interface
// ------------------------------------------------------- */
Expand Down

0 comments on commit d5fae61

Please sign in to comment.