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>
25 lines
1.4 KiB
JavaScript
25 lines
1.4 KiB
JavaScript
'use strict';
|
|
const path = require('path');
|
|
const {fileURLToPath} = require('url');
|
|
const resolveCwd = require('resolve-cwd');
|
|
const pkgDir = require('pkg-dir');
|
|
|
|
module.exports = filename => {
|
|
const normalizedFilename = filename.startsWith('file://') ? fileURLToPath(filename) : filename;
|
|
const globalDir = pkgDir.sync(path.dirname(normalizedFilename));
|
|
const relativePath = path.relative(globalDir, normalizedFilename);
|
|
const pkg = require(path.join(globalDir, 'package.json'));
|
|
const localFile = resolveCwd.silent(path.join(pkg.name, relativePath));
|
|
const localNodeModules = path.join(process.cwd(), 'node_modules');
|
|
|
|
const filenameInLocalNodeModules = !path.relative(localNodeModules, normalizedFilename).startsWith('..') &&
|
|
// On Windows, if `localNodeModules` and `normalizedFilename` are on different partitions, `path.relative()` returns the value of `normalizedFilename`, resulting in `filenameInLocalNodeModules` incorrectly becoming `true`.
|
|
path.parse(localNodeModules).root === path.parse(normalizedFilename).root;
|
|
|
|
// Use `path.relative()` to detect local package installation,
|
|
// because __filename's case is inconsistent on Windows
|
|
// Can use `===` when targeting Node.js 8
|
|
// See https://github.com/nodejs/node/issues/6624
|
|
return !filenameInLocalNodeModules && localFile && path.relative(localFile, normalizedFilename) !== '' && require(localFile);
|
|
};
|