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>
40 lines
1.7 KiB
JavaScript
40 lines
1.7 KiB
JavaScript
import { parse } from "css-what";
|
|
import { filters } from "./filters.js";
|
|
import { pseudos, verifyPseudoArgs } from "./pseudos.js";
|
|
import { aliases } from "./aliases.js";
|
|
import { subselects } from "./subselects.js";
|
|
export { filters, pseudos, aliases };
|
|
export function compilePseudoSelector(next, selector, options, context, compileToken) {
|
|
var _a;
|
|
const { name, data } = selector;
|
|
if (Array.isArray(data)) {
|
|
if (!(name in subselects)) {
|
|
throw new Error(`Unknown pseudo-class :${name}(${data})`);
|
|
}
|
|
return subselects[name](next, data, options, context, compileToken);
|
|
}
|
|
const userPseudo = (_a = options.pseudos) === null || _a === void 0 ? void 0 : _a[name];
|
|
const stringPseudo = typeof userPseudo === "string" ? userPseudo : aliases[name];
|
|
if (typeof stringPseudo === "string") {
|
|
if (data != null) {
|
|
throw new Error(`Pseudo ${name} doesn't have any arguments`);
|
|
}
|
|
// The alias has to be parsed here, to make sure options are respected.
|
|
const alias = parse(stringPseudo);
|
|
return subselects["is"](next, alias, options, context, compileToken);
|
|
}
|
|
if (typeof userPseudo === "function") {
|
|
verifyPseudoArgs(userPseudo, name, data, 1);
|
|
return (elem) => userPseudo(elem, data) && next(elem);
|
|
}
|
|
if (name in filters) {
|
|
return filters[name](next, data, options, context);
|
|
}
|
|
if (name in pseudos) {
|
|
const pseudo = pseudos[name];
|
|
verifyPseudoArgs(pseudo, name, data, 2);
|
|
return (elem) => pseudo(elem, options, data) && next(elem);
|
|
}
|
|
throw new Error(`Unknown pseudo-class :${name}`);
|
|
}
|
|
//# sourceMappingURL=index.js.map
|