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>
46 lines
1.3 KiB
JavaScript
46 lines
1.3 KiB
JavaScript
var closest = require('../src/closest');
|
|
|
|
describe('closest', function() {
|
|
before(function() {
|
|
var html = '<div id="a">' +
|
|
'<div id="b">' +
|
|
'<div id="c"></div>' +
|
|
'</div>' +
|
|
'</div>';
|
|
|
|
document.body.innerHTML += html;
|
|
|
|
global.a = document.querySelector('#a');
|
|
global.b = document.querySelector('#b');
|
|
global.c = document.querySelector('#c');
|
|
});
|
|
|
|
after(function() {
|
|
document.body.innerHTML = '';
|
|
});
|
|
|
|
it('should return the closest parent based on the selector', function() {
|
|
assert.ok(closest(global.c, '#b'), global.b);
|
|
assert.ok(closest(global.c, '#a'), global.a);
|
|
assert.ok(closest(global.b, '#a'), global.a);
|
|
});
|
|
|
|
it('should return itself if the same selector is passed', function() {
|
|
assert.ok(closest(document.body, 'body'), document.body);
|
|
});
|
|
|
|
it('should not throw on elements without matches()', function() {
|
|
var fakeElement = {
|
|
nodeType: -1, // anything but DOCUMENT_NODE_TYPE
|
|
parentNode: null,
|
|
matches: undefined // undefined to emulate Elements without this function
|
|
};
|
|
|
|
try {
|
|
closest(fakeElement, '#a')
|
|
} catch (err) {
|
|
assert.fail();
|
|
}
|
|
});
|
|
});
|