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"] = hasAccessibleChild;
|
|
var _jsxAstUtils = require("jsx-ast-utils");
|
|
var _isHiddenFromScreenReader = _interopRequireDefault(require("./isHiddenFromScreenReader"));
|
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
function hasAccessibleChild(node, elementType) {
|
|
return node.children.some(function (child) {
|
|
switch (child.type) {
|
|
case 'Literal':
|
|
return !!child.value;
|
|
// $FlowFixMe JSXText is missing in ast-types-flow
|
|
case 'JSXText':
|
|
return !!child.value;
|
|
case 'JSXElement':
|
|
return !(0, _isHiddenFromScreenReader["default"])(elementType(child.openingElement), child.openingElement.attributes);
|
|
case 'JSXExpressionContainer':
|
|
if (child.expression.type === 'Identifier') {
|
|
return child.expression.name !== 'undefined';
|
|
}
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}) || (0, _jsxAstUtils.hasAnyProp)(node.openingElement.attributes, ['dangerouslySetInnerHTML', 'children']);
|
|
}
|
|
module.exports = exports.default; |