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>
47 lines
1.2 KiB
JavaScript
47 lines
1.2 KiB
JavaScript
/**
|
|
* adds a bindGlobal method to Mousetrap that allows you to
|
|
* bind specific keyboard shortcuts that will still work
|
|
* inside a text input field
|
|
*
|
|
* usage:
|
|
* Mousetrap.bindGlobal('ctrl+s', _saveChanges);
|
|
*/
|
|
/* global Mousetrap:true */
|
|
(function(Mousetrap) {
|
|
if (! Mousetrap) {
|
|
return;
|
|
}
|
|
var _globalCallbacks = {};
|
|
var _originalStopCallback = Mousetrap.prototype.stopCallback;
|
|
|
|
Mousetrap.prototype.stopCallback = function(e, element, combo, sequence) {
|
|
var self = this;
|
|
|
|
if (self.paused) {
|
|
return true;
|
|
}
|
|
|
|
if (_globalCallbacks[combo] || _globalCallbacks[sequence]) {
|
|
return false;
|
|
}
|
|
|
|
return _originalStopCallback.call(self, e, element, combo);
|
|
};
|
|
|
|
Mousetrap.prototype.bindGlobal = function(keys, callback, action) {
|
|
var self = this;
|
|
self.bind(keys, callback, action);
|
|
|
|
if (keys instanceof Array) {
|
|
for (var i = 0; i < keys.length; i++) {
|
|
_globalCallbacks[keys[i]] = true;
|
|
}
|
|
return;
|
|
}
|
|
|
|
_globalCallbacks[keys] = true;
|
|
};
|
|
|
|
Mousetrap.init();
|
|
}) (typeof Mousetrap !== "undefined" ? Mousetrap : undefined);
|