Add coexistence checks to all enqueue methods to prevent loading both React and Grid.js assets simultaneously. Changes: - ReactAdmin.php: Only enqueue React assets when ?react=1 - Init.php: Skip Grid.js when React active on admin pages - Form.php, Coupon.php, Access.php: Restore classic assets when ?react=0 - Customer.php, Product.php, License.php: Add coexistence checks Now the toggle between Classic and React versions works correctly. Co-authored-by: Claude Opus 4.7 <noreply@anthropic.com>
31 lines
1.1 KiB
JavaScript
31 lines
1.1 KiB
JavaScript
/**
|
|
* Gets the source (i.e. host) of the script currently running.
|
|
* @returns {string}
|
|
*/
|
|
function getCurrentScriptSource() {
|
|
// `document.currentScript` is the most accurate way to get the current running script,
|
|
// but is not supported in all browsers (most notably, IE).
|
|
if ('currentScript' in document) {
|
|
// In some cases, `document.currentScript` would be `null` even if the browser supports it:
|
|
// e.g. asynchronous chunks on Firefox.
|
|
// We should not fallback to the list-approach as it would not be safe.
|
|
if (document.currentScript == null) return;
|
|
return document.currentScript.getAttribute('src');
|
|
}
|
|
// Fallback to getting all scripts running in the document,
|
|
// and finding the last one injected.
|
|
else {
|
|
const scriptElementsWithSrc = Array.prototype.filter.call(
|
|
document.scripts || [],
|
|
function (elem) {
|
|
return elem.getAttribute('src');
|
|
}
|
|
);
|
|
if (!scriptElementsWithSrc.length) return;
|
|
const currentScript = scriptElementsWithSrc[scriptElementsWithSrc.length - 1];
|
|
return currentScript.getAttribute('src');
|
|
}
|
|
}
|
|
|
|
module.exports = getCurrentScriptSource;
|