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>
53 lines
1.7 KiB
JavaScript
53 lines
1.7 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const ast_1 = require("../utils/ast");
|
|
function isStepCall(node) {
|
|
const inner = node.type === 'CallExpression' ? node.callee : node;
|
|
if (inner.type !== 'MemberExpression') {
|
|
return false;
|
|
}
|
|
return (0, ast_1.isPropertyAccessor)(inner, 'step');
|
|
}
|
|
exports.default = {
|
|
create(context) {
|
|
const stack = [];
|
|
function pushStepCallback(node) {
|
|
if (node.parent.type !== 'CallExpression' || !isStepCall(node.parent)) {
|
|
return;
|
|
}
|
|
stack.push(0);
|
|
if (stack.length > 1) {
|
|
context.report({
|
|
messageId: 'noNestedStep',
|
|
node: node.parent.callee,
|
|
});
|
|
}
|
|
}
|
|
function popStepCallback(node) {
|
|
const { parent } = node;
|
|
if (parent.type === 'CallExpression' && isStepCall(parent)) {
|
|
stack.pop();
|
|
}
|
|
}
|
|
return {
|
|
ArrowFunctionExpression: pushStepCallback,
|
|
'ArrowFunctionExpression:exit': popStepCallback,
|
|
FunctionExpression: pushStepCallback,
|
|
'FunctionExpression:exit': popStepCallback,
|
|
};
|
|
},
|
|
meta: {
|
|
docs: {
|
|
category: 'Best Practices',
|
|
description: 'Disallow nested `test.step()` methods',
|
|
recommended: true,
|
|
url: 'https://github.com/playwright-community/eslint-plugin-playwright/tree/main/docs/rules/no-nested-step.md',
|
|
},
|
|
messages: {
|
|
noNestedStep: 'Do not nest `test.step()` methods.',
|
|
},
|
|
schema: [],
|
|
type: 'problem',
|
|
},
|
|
};
|