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>
38 lines
901 B
JavaScript
Executable File
38 lines
901 B
JavaScript
Executable File
'use strict';
|
|
|
|
const internals = {
|
|
maxTimer: 2 ** 31 - 1 // ~25 days
|
|
};
|
|
|
|
|
|
module.exports = function (timeout, returnValue, options) {
|
|
|
|
if (typeof timeout === 'bigint') {
|
|
timeout = Number(timeout);
|
|
}
|
|
|
|
if (timeout >= Number.MAX_SAFE_INTEGER) { // Thousands of years
|
|
timeout = Infinity;
|
|
}
|
|
|
|
if (typeof timeout !== 'number' && timeout !== undefined) {
|
|
throw new TypeError('Timeout must be a number or bigint');
|
|
}
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
const _setTimeout = options ? options.setTimeout : setTimeout;
|
|
|
|
const activate = () => {
|
|
|
|
const time = Math.min(timeout, internals.maxTimer);
|
|
timeout -= time;
|
|
_setTimeout(() => (timeout > 0 ? activate() : resolve(returnValue)), time);
|
|
};
|
|
|
|
if (timeout !== Infinity) {
|
|
activate();
|
|
}
|
|
});
|
|
};
|