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
939 B
JavaScript
30 lines
939 B
JavaScript
'use strict';
|
|
|
|
exports.__esModule = true;
|
|
|
|
const pattern = /(^|[;})])\s*(export|import)((\s+\w)|(\s*[{*=]))|import\(/m;
|
|
/**
|
|
* detect possible imports/exports without a full parse.
|
|
*
|
|
* A negative test means that a file is definitely _not_ a module.
|
|
* A positive test means it _could_ be.
|
|
*
|
|
* Not perfect, just a fast way to disqualify large non-ES6 modules and
|
|
* avoid a parse.
|
|
* @type {import('./unambiguous').test}
|
|
*/
|
|
exports.test = function isMaybeUnambiguousModule(content) {
|
|
return pattern.test(content);
|
|
};
|
|
|
|
// future-/Babel-proof at the expense of being a little loose
|
|
const unambiguousNodeType = /^(?:(?:Exp|Imp)ort.*Declaration|TSExportAssignment)$/;
|
|
|
|
/**
|
|
* Given an AST, return true if the AST unambiguously represents a module.
|
|
* @type {import('./unambiguous').isModule}
|
|
*/
|
|
exports.isModule = function isUnambiguousModule(ast) {
|
|
return ast.body && ast.body.some((node) => unambiguousNodeType.test(node.type));
|
|
};
|