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>
57 lines
1.3 KiB
JavaScript
57 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
const SyntaxError = require('./SyntaxError.cjs');
|
|
|
|
const TAB = 9;
|
|
const N = 10;
|
|
const F = 12;
|
|
const R = 13;
|
|
const SPACE = 32;
|
|
|
|
class Tokenizer {
|
|
constructor(str) {
|
|
this.str = str;
|
|
this.pos = 0;
|
|
}
|
|
charCodeAt(pos) {
|
|
return pos < this.str.length ? this.str.charCodeAt(pos) : 0;
|
|
}
|
|
charCode() {
|
|
return this.charCodeAt(this.pos);
|
|
}
|
|
nextCharCode() {
|
|
return this.charCodeAt(this.pos + 1);
|
|
}
|
|
nextNonWsCode(pos) {
|
|
return this.charCodeAt(this.findWsEnd(pos));
|
|
}
|
|
findWsEnd(pos) {
|
|
for (; pos < this.str.length; pos++) {
|
|
const code = this.str.charCodeAt(pos);
|
|
if (code !== R && code !== N && code !== F && code !== SPACE && code !== TAB) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
return pos;
|
|
}
|
|
substringToPos(end) {
|
|
return this.str.substring(this.pos, this.pos = end);
|
|
}
|
|
eat(code) {
|
|
if (this.charCode() !== code) {
|
|
this.error('Expect `' + String.fromCharCode(code) + '`');
|
|
}
|
|
|
|
this.pos++;
|
|
}
|
|
peek() {
|
|
return this.pos < this.str.length ? this.str.charAt(this.pos++) : '';
|
|
}
|
|
error(message) {
|
|
throw new SyntaxError.SyntaxError(message, this.str, this.pos);
|
|
}
|
|
}
|
|
|
|
exports.Tokenizer = Tokenizer;
|