/** * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. */ #import #import "../Base/RCTBridge.h" #import "../Base/RCTBridgeModule.h" #import "../Base/RCTInvalidating.h" #import "../Views/RCTViewManager.h" @protocol RCTScrollableProtocol; /** * The RCTUIManager is the module responsible for updating the view hierarchy. */ @interface RCTUIManager : NSObject @property (nonatomic, weak) id mainScrollView; /** * Allows native environment code to respond to "the main scroll view" events. * see `RCTUIManager`'s `setMainScrollViewTag`. */ @property (nonatomic, readwrite, weak) id nativeMainScrollDelegate; /** * Register a root view with the RCTUIManager. */ - (void)registerRootView:(UIView *)rootView; /** * Update the frame of a root view. This might be in response to a screen rotation * or some other layout event outsde of the React-managed view hierarchy. */ - (void)setFrame:(CGRect)frame forRootView:(UIView *)rootView; /** * Schedule a block to be executed on the UI thread. Useful if you need to execute * view logic after all currently queued view updates have completed. */ - (void)addUIBlock:(RCTViewManagerUIBlock)block; /** * The view that is currently first responder, according to the JS context. */ + (UIView *)JSResponder; @end /** * This category makes the current RCTUIManager instance available via the * RCTBridge, which is useful for RCTBridgeModules or RCTViewManagers that * need to access the RCTUIManager. */ @interface RCTBridge (RCTUIManager) @property (nonatomic, readonly) RCTUIManager *uiManager; @end