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>
30 lines
1.1 KiB
JavaScript
30 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = extractValueFromBindExpression;
|
|
/**
|
|
* Extractor function for a BindExpression type value node.
|
|
* A bind expression looks like `::this.foo`
|
|
* This will return `this.foo.bind(this)` as the value to indicate its existence,
|
|
* since we can not execute the function this.foo.bind(this) in a static environment.
|
|
*
|
|
* @param - value - AST Value object with type `BindExpression`
|
|
* @returns - The extracted value converted to correct type.
|
|
*/
|
|
function extractValueFromBindExpression(value) {
|
|
// eslint-disable-next-line global-require
|
|
var getValue = require('.').default;
|
|
var callee = getValue(value.callee);
|
|
|
|
// If value.object === null, the callee must be a MemberExpression.
|
|
// https://github.com/babel/babylon/blob/master/ast/spec.md#bindexpression
|
|
var object = value.object === null ? getValue(value.callee.object) : getValue(value.object);
|
|
|
|
if (value.object && value.object.property) {
|
|
return object + '.' + callee + '.bind(' + object + ')';
|
|
}
|
|
|
|
return callee + '.bind(' + object + ')';
|
|
} |