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>
43 lines
1.2 KiB
JavaScript
43 lines
1.2 KiB
JavaScript
"use strict";
|
|
|
|
const conversions = require("webidl-conversions");
|
|
const utils = require("./utils.js");
|
|
|
|
exports.convert = (globalObject, value, { context = "The provided value" } = {}) => {
|
|
if (typeof value !== "function") {
|
|
throw new globalObject.TypeError(context + " is not a function");
|
|
}
|
|
|
|
function invokeTheCallbackFunction(...args) {
|
|
const thisArg = utils.tryWrapperForImpl(this);
|
|
let callResult;
|
|
|
|
for (let i = 0; i < args.length; i++) {
|
|
args[i] = utils.tryWrapperForImpl(args[i]);
|
|
}
|
|
|
|
callResult = Reflect.apply(value, thisArg, args);
|
|
|
|
callResult = conversions["any"](callResult, { context: context, globals: globalObject });
|
|
|
|
return callResult;
|
|
}
|
|
|
|
invokeTheCallbackFunction.construct = (...args) => {
|
|
for (let i = 0; i < args.length; i++) {
|
|
args[i] = utils.tryWrapperForImpl(args[i]);
|
|
}
|
|
|
|
let callResult = Reflect.construct(value, args);
|
|
|
|
callResult = conversions["any"](callResult, { context: context, globals: globalObject });
|
|
|
|
return callResult;
|
|
};
|
|
|
|
invokeTheCallbackFunction[utils.wrapperSymbol] = value;
|
|
invokeTheCallbackFunction.objectReference = value;
|
|
|
|
return invokeTheCallbackFunction;
|
|
};
|