Files
formipay/node_modules/webpack/lib/DllPlugin.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

75 lines
2.0 KiB
JavaScript

/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
"use strict";
const DllEntryPlugin = require("./DllEntryPlugin");
const FlagAllModulesAsUsedPlugin = require("./FlagAllModulesAsUsedPlugin");
const LibManifestPlugin = require("./LibManifestPlugin");
/** @typedef {import("../declarations/plugins/DllPlugin").DllPluginOptions} DllPluginOptions */
/** @typedef {import("./Compiler")} Compiler */
/** @typedef {import("./DllEntryPlugin").Entries} Entries */
/** @typedef {import("./DllEntryPlugin").Options} Options */
const PLUGIN_NAME = "DllPlugin";
class DllPlugin {
/**
* Creates an instance of DllPlugin.
* @param {DllPluginOptions} options options object
*/
constructor(options) {
/** @type {DllPluginOptions} */
this.options = options;
}
/**
* Applies the plugin by registering its hooks on the compiler.
* @param {Compiler} compiler the compiler instance
* @returns {void}
*/
apply(compiler) {
compiler.hooks.validate.tap(PLUGIN_NAME, () => {
compiler.validate(
() => require("../schemas/plugins/DllPlugin.json"),
this.options,
{
name: "Dll Plugin",
baseDataPath: "options"
},
(options) => require("../schemas/plugins/DllPlugin.check")(options)
);
});
const entryOnly = this.options.entryOnly !== false;
compiler.hooks.entryOption.tap(PLUGIN_NAME, (context, entry) => {
if (typeof entry !== "function") {
for (const name of Object.keys(entry)) {
/** @type {Options} */
const options = { name };
new DllEntryPlugin(
context,
/** @type {Entries} */
(entry[name].import),
options
).apply(compiler);
}
} else {
throw new Error(
`${PLUGIN_NAME} doesn't support dynamic entry (function) yet`
);
}
return true;
});
new LibManifestPlugin({ ...this.options, entryOnly }).apply(compiler);
if (!entryOnly) {
new FlagAllModulesAsUsedPlugin(PLUGIN_NAME).apply(compiler);
}
}
}
module.exports = DllPlugin;