Skip to content

Commit

Permalink
Merge branch '2.1' into 2
Browse files Browse the repository at this point in the history
  • Loading branch information
github-actions[bot] committed Feb 27, 2024
2 parents 41f8bd3 + 0f5eefb commit d6d71df
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 11 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/src/legacy/LeftAndMain.EditForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -202,7 +202,7 @@ $.entwine('ss', function($){
'Admin.VALIDATIONERROR',
'Validation Error'
);

errorMessage(toastNotificationMessage);
// Ensure that this error message popup won't be added more than once
this.setValidationErrorShown(true);
Expand Down
41 changes: 33 additions & 8 deletions client/src/legacy/LeftAndMain.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,21 @@ window.ss.debounce = function (func, wait, immediate) {
* The URL to use for saving and loading tab state
*/
window.ss.tabStateUrl = function() {
return window.location.href
return window.ss.formatTabStateUrl(window.location.href);
};

/**
* Helper function to format URL that is used for saving and loading tab state
*
* @param url {string} URL to format
* @returns {*}
*/
window.ss.formatTabStateUrl = function(url) {
return url
.replace(/\?.*/, '')
.replace(/#.*/, '')
.replace(new RegExp(`^${escapeRegExp($('base').attr('href'))}/?`), '');
},
};

$(window).on('resize.leftandmain', function(e) {
$('.cms-container').trigger('windowresize');
Expand Down Expand Up @@ -401,7 +411,9 @@ $.entwine('ss', function($) {
return;
}

this.saveTabState();
// Clear tab state for current browser URL, and save state for new panel to load
this.clearTabState(window.ss.tabStateUrl());
this.saveTabState(window.ss.formatTabStateUrl(url), true);

data.__forceReferer = forceReferer;

Expand Down Expand Up @@ -486,7 +498,7 @@ $.entwine('ss', function($) {
formData.push({ name: 'BackURL', value: document.URL.replace(/\/$/, '') });

// Save tab selections so we can restore them later
this.saveTabState();
this.saveTabState(window.ss.tabStateUrl(), false);

// Standard Pjax behaviour is to replace the submitted form with new content.
// The returned view isn't always decided upon when the request
Expand Down Expand Up @@ -878,11 +890,18 @@ $.entwine('ss', function($) {
/**
* Save tab selections in order to reconstruct them later.
* Requires HTML5 sessionStorage support.
*
* Parameters:
* (String) url used for session storage key
* (Boolean) resetTab true force selected tab to first, else current active
*/
saveTabState: function() {
saveTabState: function(url, resetTab) {
if(typeof(window.sessionStorage)=="undefined" || window.sessionStorage === null) return;
if (url === undefined) {
const url = window.ss.tabStateUrl();
}

var selectedTabs = [], url = window.ss.tabStateUrl();
var selectedTabs = [];
this.find('.cms-tabset,.ss-tabset').each(function(i, el) {
var id = $(el).attr('id');
if(!id) return; // we need a unique reference
Expand All @@ -891,7 +910,7 @@ $.entwine('ss', function($) {
// Allow opt-out via data element or entwine property.
if($(el).data('ignoreTabState') || $(el).getIgnoreTabState()) return;

selectedTabs.push({id:id, selected:$(el).tabs('option', 'active')});
selectedTabs.push({id:id, selected:resetTab ? 0 : $(el).tabs('option', 'active')});
});

if(selectedTabs) {
Expand Down Expand Up @@ -1508,7 +1527,13 @@ $.entwine('ss', function($) {
});
});

function decodeEntities(text) {
const textarea = document.createElement('textarea');
textarea.innerHTML = text;
return textarea.innerText;
}

var statusMessage = function(text, type) {
text = jQuery('<div/>').text(text).html(); // Escape HTML entities in text
text = decodeEntities(text);
jQuery.noticeAdd({text: text, type: type, stayTime: 5000, inEffect: {left: '0', opacity: 'show'}});
};
2 changes: 1 addition & 1 deletion code/ModelAdmin.php
Original file line number Diff line number Diff line change
Expand Up @@ -556,7 +556,7 @@ public function getModelImporters()
$importers = [];
foreach ($importerClasses as $modelClass => $importerClass) {
$tab = $modelClass;
if (isset($models[$modelClass])) {
if (isset($models[$modelClass]['dataClass'])) {
$modelClass = $models[$modelClass]['dataClass'];
}
$importer = new $importerClass($modelClass);
Expand Down

0 comments on commit d6d71df

Please sign in to comment.