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>
30 lines
957 B
JavaScript
30 lines
957 B
JavaScript
'use strict';
|
|
|
|
var $TypeError = require('es-errors/type');
|
|
|
|
var callBound = require('call-bound');
|
|
|
|
var $arrayBufferResizable = callBound('%ArrayBuffer.prototype.resizable%', true);
|
|
var $sharedArrayGrowable = callBound('%SharedArrayBuffer.prototype.growable%', true);
|
|
|
|
var isArrayBuffer = require('is-array-buffer');
|
|
var isSharedArrayBuffer = require('is-shared-array-buffer');
|
|
|
|
// https://262.ecma-international.org/15.0/#sec-isfixedlengtharraybuffer
|
|
|
|
module.exports = function IsFixedLengthArrayBuffer(arrayBuffer) {
|
|
var isAB = isArrayBuffer(arrayBuffer);
|
|
var isSAB = isSharedArrayBuffer(arrayBuffer);
|
|
if (!isAB && !isSAB) {
|
|
throw new $TypeError('Assertion failed: `arrayBuffer` must be an ArrayBuffer or SharedArrayBuffer');
|
|
}
|
|
|
|
if (isAB && $arrayBufferResizable) {
|
|
return !$arrayBufferResizable(arrayBuffer); // step 1
|
|
}
|
|
if (isSAB && $sharedArrayGrowable) {
|
|
return !$sharedArrayGrowable(arrayBuffer); // step 1
|
|
}
|
|
return true; // step 2
|
|
};
|