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>
47 lines
1.0 KiB
JavaScript
47 lines
1.0 KiB
JavaScript
'use strict';
|
|
|
|
var $Map = typeof Map === 'function' && Map.prototype ? Map : null;
|
|
var $Set = typeof Set === 'function' && Set.prototype ? Set : null;
|
|
|
|
var exported;
|
|
|
|
if (!$Set) {
|
|
/** @type {import('.')} */
|
|
// eslint-disable-next-line no-unused-vars
|
|
exported = function isSet(x) {
|
|
// `Set` is not present in this environment.
|
|
return false;
|
|
};
|
|
}
|
|
|
|
var $mapHas = $Map ? Map.prototype.has : null;
|
|
var $setHas = $Set ? Set.prototype.has : null;
|
|
if (!exported && !$setHas) {
|
|
/** @type {import('.')} */
|
|
// eslint-disable-next-line no-unused-vars
|
|
exported = function isSet(x) {
|
|
// `Set` does not have a `has` method
|
|
return false;
|
|
};
|
|
}
|
|
|
|
/** @type {import('.')} */
|
|
module.exports = exported || function isSet(x) {
|
|
if (!x || typeof x !== 'object') {
|
|
return false;
|
|
}
|
|
try {
|
|
$setHas.call(x);
|
|
if ($mapHas) {
|
|
try {
|
|
$mapHas.call(x);
|
|
} catch (e) {
|
|
return true;
|
|
}
|
|
}
|
|
// @ts-expect-error TS can't figure out that $Set is always truthy here
|
|
return x instanceof $Set; // core-js workaround, pre-v2.5.0
|
|
} catch (e) {}
|
|
return false;
|
|
};
|