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
1.1 KiB
JavaScript
38 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
var $TypeError = require('es-errors/type');
|
|
|
|
var IsArray = require('./IsArray');
|
|
var IsInteger = require('./IsInteger');
|
|
|
|
var every = require('../helpers/every');
|
|
var regexTester = require('safe-regex-test');
|
|
|
|
var isChar = function isChar(c) {
|
|
return typeof c === 'string' && c.length === 1;
|
|
};
|
|
|
|
var isWordCharacter = regexTester(/^[a-zA-Z0-9_]$/);
|
|
|
|
// https://262.ecma-international.org/6.0/#sec-runtime-semantics-iswordchar-abstract-operation
|
|
|
|
// note: prior to ES2023, this AO erroneously omitted the latter of its arguments.
|
|
module.exports = function IsWordChar(e, InputLength, Input) {
|
|
if (!IsInteger(e)) {
|
|
throw new $TypeError('Assertion failed: `e` must be an integer');
|
|
}
|
|
if (!IsInteger(InputLength)) {
|
|
throw new $TypeError('Assertion failed: `InputLength` must be an integer');
|
|
}
|
|
if (!IsArray(Input) || !every(Input, isChar)) {
|
|
throw new $TypeError('Assertion failed: `Input` must be a List of characters');
|
|
}
|
|
if (e === -1 || e === InputLength) {
|
|
return false; // step 1
|
|
}
|
|
|
|
var c = Input[e]; // step 2
|
|
|
|
return isWordCharacter(c); // steps 3-4
|
|
};
|