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>
37 lines
985 B
JavaScript
37 lines
985 B
JavaScript
'use strict';
|
|
|
|
module.exports = function defFunc(ajv) {
|
|
defFunc.definition = {
|
|
type: 'number',
|
|
macro: function (schema, parentSchema) {
|
|
var min = schema[0]
|
|
, max = schema[1]
|
|
, exclusive = parentSchema.exclusiveRange;
|
|
|
|
validateRangeSchema(min, max, exclusive);
|
|
|
|
return exclusive === true
|
|
? {exclusiveMinimum: min, exclusiveMaximum: max}
|
|
: {minimum: min, maximum: max};
|
|
},
|
|
metaSchema: {
|
|
type: 'array',
|
|
minItems: 2,
|
|
maxItems: 2,
|
|
items: { type: 'number' }
|
|
}
|
|
};
|
|
|
|
ajv.addKeyword('range', defFunc.definition);
|
|
ajv.addKeyword('exclusiveRange');
|
|
return ajv;
|
|
|
|
function validateRangeSchema(min, max, exclusive) {
|
|
if (exclusive !== undefined && typeof exclusive != 'boolean')
|
|
throw new Error('Invalid schema for exclusiveRange keyword, should be boolean');
|
|
|
|
if (min > max || (exclusive && min == max))
|
|
throw new Error('There are no numbers in range');
|
|
}
|
|
};
|