Files
formipay/node_modules/stylelint/lib/rules/atRuleNameSpaceChecker.js
dwindown e8fbfb14c1 fix: prevent asset conflicts between React and Grid.js versions
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>
2026-04-18 17:02:14 +07:00

56 lines
1.2 KiB
JavaScript

'use strict';
const isStandardSyntaxAtRule = require('../utils/isStandardSyntaxAtRule');
const report = require('../utils/report');
/**
* @param {{
* root: import('postcss').Root,
* locationChecker: (opts: { source: string, index: number, err: (msg: string) => void, errTarget: string }) => void,
* result: import('stylelint').PostcssResult,
* checkedRuleName: string,
* fix?: ((atRule: import('postcss').AtRule) => void) | null,
* }} options
*/
module.exports = function atRuleNameSpaceChecker(options) {
options.root.walkAtRules((atRule) => {
if (!isStandardSyntaxAtRule(atRule)) {
return;
}
checkColon(
`@${atRule.name}${atRule.raws.afterName || ''}${atRule.params}`,
atRule.name.length,
atRule,
);
});
/**
* @param {string} source
* @param {number} index
* @param {import('postcss').AtRule} node
*/
function checkColon(source, index, node) {
options.locationChecker({
source,
index,
err: (m) => {
if (options.fix) {
options.fix(node);
return;
}
report({
message: m,
node,
index,
result: options.result,
ruleName: options.checkedRuleName,
});
},
errTarget: `@${node.name}`,
});
}
};