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>
49 lines
1.4 KiB
JavaScript
49 lines
1.4 KiB
JavaScript
// Process html entity - {, ¯, ", ...
|
|
|
|
'use strict';
|
|
|
|
var entities = require('../common/entities');
|
|
var has = require('../common/utils').has;
|
|
var isValidEntityCode = require('../common/utils').isValidEntityCode;
|
|
var fromCodePoint = require('../common/utils').fromCodePoint;
|
|
|
|
|
|
var DIGITAL_RE = /^&#((?:x[a-f0-9]{1,6}|[0-9]{1,7}));/i;
|
|
var NAMED_RE = /^&([a-z][a-z0-9]{1,31});/i;
|
|
|
|
|
|
module.exports = function entity(state, silent) {
|
|
var ch, code, match, pos = state.pos, max = state.posMax;
|
|
|
|
if (state.src.charCodeAt(pos) !== 0x26/* & */) { return false; }
|
|
|
|
if (pos + 1 < max) {
|
|
ch = state.src.charCodeAt(pos + 1);
|
|
|
|
if (ch === 0x23 /* # */) {
|
|
match = state.src.slice(pos).match(DIGITAL_RE);
|
|
if (match) {
|
|
if (!silent) {
|
|
code = match[1][0].toLowerCase() === 'x' ? parseInt(match[1].slice(1), 16) : parseInt(match[1], 10);
|
|
state.pending += isValidEntityCode(code) ? fromCodePoint(code) : fromCodePoint(0xFFFD);
|
|
}
|
|
state.pos += match[0].length;
|
|
return true;
|
|
}
|
|
} else {
|
|
match = state.src.slice(pos).match(NAMED_RE);
|
|
if (match) {
|
|
if (has(entities, match[1])) {
|
|
if (!silent) { state.pending += entities[match[1]]; }
|
|
state.pos += match[0].length;
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!silent) { state.pending += '&'; }
|
|
state.pos++;
|
|
return true;
|
|
};
|