Files
formipay/node_modules/ajv-errors/index.js
dwindown e8fbfb14c1 fix: prevent asset conflicts between React and Grid.js versions
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>
2026-04-18 17:02:14 +07:00

49 lines
1.3 KiB
JavaScript

'use strict';
module.exports = function (ajv, options) {
if (!ajv._opts.allErrors) throw new Error('ajv-errors: Ajv option allErrors must be true');
if (!ajv._opts.jsonPointers) {
console.warn('ajv-errors: Ajv option jsonPointers changed to true');
ajv._opts.jsonPointers = true;
}
ajv.addKeyword('errorMessage', {
inline: require('./lib/dotjs/errorMessage'),
statements: true,
valid: true,
errors: 'full',
config: {
KEYWORD_PROPERTY_PARAMS: {
required: 'missingProperty',
dependencies: 'property'
},
options: options || {}
},
metaSchema: {
'type': ['string', 'object'],
properties: {
properties: {$ref: '#/definitions/stringMap'},
items: {$ref: '#/definitions/stringList'},
required: {$ref: '#/definitions/stringOrMap'},
dependencies: {$ref: '#/definitions/stringOrMap'}
},
additionalProperties: {'type': 'string'},
definitions: {
stringMap: {
'type': ['object'],
additionalProperties: {'type': 'string'}
},
stringOrMap: {
'type': ['string', 'object'],
additionalProperties: {'type': 'string'}
},
stringList: {
'type': ['array'],
items: {'type': 'string'}
}
}
}
});
return ajv;
};