2015-03-23 15:07:33 -07:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2015-01-29 17:10:49 -08:00
|
|
|
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2015-03-02 11:36:55 -08:00
|
|
|
#import "RCTBridge.h"
|
2015-02-06 15:43:59 -08:00
|
|
|
#import "RCTBridgeModule.h"
|
2015-01-29 17:10:49 -08:00
|
|
|
#import "RCTInvalidating.h"
|
2015-03-02 11:36:55 -08:00
|
|
|
#import "RCTViewManager.h"
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-02-03 16:02:36 -08:00
|
|
|
@protocol RCTScrollableProtocol;
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-03-02 11:36:55 -08:00
|
|
|
/**
|
|
|
|
* The RCTUIManager is the module responsible for updating the view hierarchy.
|
|
|
|
*/
|
2015-02-06 15:43:59 -08:00
|
|
|
@interface RCTUIManager : NSObject <RCTBridgeModule, RCTInvalidating>
|
2015-01-29 17:10:49 -08:00
|
|
|
|
|
|
|
@property (nonatomic, weak) id<RCTScrollableProtocol> mainScrollView;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allows native environment code to respond to "the main scroll view" events.
|
|
|
|
* see `RCTUIManager`'s `setMainScrollViewTag`.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readwrite, weak) id<UIScrollViewDelegate> nativeMainScrollDelegate;
|
|
|
|
|
2015-03-02 11:36:55 -08:00
|
|
|
/**
|
|
|
|
* Register a root view with the RCTUIManager. Theoretically, a single manager
|
2015-03-24 19:34:12 -07:00
|
|
|
* can support multiple root views, however this feature is not currently exposed.
|
|
|
|
*/
|
|
|
|
- (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.
|
2015-03-02 11:36:55 -08:00
|
|
|
*/
|
2015-03-24 19:34:12 -07:00
|
|
|
- (void)setFrame:(CGRect)frame forRootView:(UIView *)rootView;
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-03-02 11:36:55 -08:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2015-01-29 17:10:49 -08:00
|
|
|
+ (UIView *)JSResponder;
|
|
|
|
|
|
|
|
@end
|
2015-03-02 11:36:55 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|