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>
29 lines
1.2 KiB
JavaScript
29 lines
1.2 KiB
JavaScript
import { AsyncAction } from './AsyncAction';
|
|
import { animationFrameProvider } from './animationFrameProvider';
|
|
export class AnimationFrameAction extends AsyncAction {
|
|
constructor(scheduler, work) {
|
|
super(scheduler, work);
|
|
this.scheduler = scheduler;
|
|
this.work = work;
|
|
}
|
|
requestAsyncId(scheduler, id, delay = 0) {
|
|
if (delay !== null && delay > 0) {
|
|
return super.requestAsyncId(scheduler, id, delay);
|
|
}
|
|
scheduler.actions.push(this);
|
|
return scheduler._scheduled || (scheduler._scheduled = animationFrameProvider.requestAnimationFrame(() => scheduler.flush(undefined)));
|
|
}
|
|
recycleAsyncId(scheduler, id, delay = 0) {
|
|
var _a;
|
|
if (delay != null ? delay > 0 : this.delay > 0) {
|
|
return super.recycleAsyncId(scheduler, id, delay);
|
|
}
|
|
const { actions } = scheduler;
|
|
if (id != null && id === scheduler._scheduled && ((_a = actions[actions.length - 1]) === null || _a === void 0 ? void 0 : _a.id) !== id) {
|
|
animationFrameProvider.cancelAnimationFrame(id);
|
|
scheduler._scheduled = undefined;
|
|
}
|
|
return undefined;
|
|
}
|
|
}
|
|
//# sourceMappingURL=AnimationFrameAction.js.map
|