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>
72 lines
1.7 KiB
JavaScript
72 lines
1.7 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const LocalModule = require("./LocalModule");
|
|
|
|
/** @typedef {import("../javascript/JavascriptParser").JavascriptParserState} JavascriptParserState */
|
|
|
|
/**
|
|
* Returns resolved module.
|
|
* @param {string} parent parent module
|
|
* @param {string} mod module to resolve
|
|
* @returns {string} resolved module
|
|
*/
|
|
const lookup = (parent, mod) => {
|
|
if (mod.charAt(0) !== ".") return mod;
|
|
|
|
const path = parent.split("/");
|
|
const segments = mod.split("/");
|
|
path.pop();
|
|
|
|
for (let i = 0; i < segments.length; i++) {
|
|
const seg = segments[i];
|
|
if (seg === "..") {
|
|
path.pop();
|
|
} else if (seg !== ".") {
|
|
path.push(seg);
|
|
}
|
|
}
|
|
|
|
return path.join("/");
|
|
};
|
|
|
|
/**
|
|
* Returns local module.
|
|
* @param {JavascriptParserState} state parser state
|
|
* @param {string} name name
|
|
* @returns {LocalModule} local module
|
|
*/
|
|
module.exports.addLocalModule = (state, name) => {
|
|
if (!state.localModules) {
|
|
state.localModules = [];
|
|
}
|
|
const m = new LocalModule(name, state.localModules.length);
|
|
state.localModules.push(m);
|
|
return m;
|
|
};
|
|
|
|
/**
|
|
* Returns local module or null.
|
|
* @param {JavascriptParserState} state parser state
|
|
* @param {string} name name
|
|
* @param {string=} namedModule named module
|
|
* @returns {LocalModule | null} local module or null
|
|
*/
|
|
module.exports.getLocalModule = (state, name, namedModule) => {
|
|
if (!state.localModules) return null;
|
|
if (namedModule) {
|
|
// resolve dependency name relative to the defining named module
|
|
name = lookup(namedModule, name);
|
|
}
|
|
for (let i = 0; i < state.localModules.length; i++) {
|
|
if (state.localModules[i].name === name) {
|
|
return state.localModules[i];
|
|
}
|
|
}
|
|
return null;
|
|
};
|