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>
55 lines
1.3 KiB
JavaScript
55 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
const url = require('../../utils/url.cjs');
|
|
const string = require('../../utils/string.cjs');
|
|
const types = require('../../tokenizer/types.cjs');
|
|
|
|
const name = 'Url';
|
|
const structure = {
|
|
value: String
|
|
};
|
|
|
|
// <url-token> | <function-token> <string> )
|
|
function parse() {
|
|
const start = this.tokenStart;
|
|
let value;
|
|
|
|
switch (this.tokenType) {
|
|
case types.Url:
|
|
value = url.decode(this.consume(types.Url));
|
|
break;
|
|
|
|
case types.Function:
|
|
if (!this.cmpStr(this.tokenStart, this.tokenEnd, 'url(')) {
|
|
this.error('Function name must be `url`');
|
|
}
|
|
|
|
this.eat(types.Function);
|
|
this.skipSC();
|
|
value = string.decode(this.consume(types.String));
|
|
this.skipSC();
|
|
if (!this.eof) {
|
|
this.eat(types.RightParenthesis);
|
|
}
|
|
break;
|
|
|
|
default:
|
|
this.error('Url or Function is expected');
|
|
}
|
|
|
|
return {
|
|
type: 'Url',
|
|
loc: this.getLocation(start, this.tokenStart),
|
|
value
|
|
};
|
|
}
|
|
|
|
function generate(node) {
|
|
this.token(types.Url, url.encode(node.value));
|
|
}
|
|
|
|
exports.generate = generate;
|
|
exports.name = name;
|
|
exports.parse = parse;
|
|
exports.structure = structure;
|