2015-03-23 13:28:42 -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-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2015-04-23 08:04:16 -07:00
|
|
|
#import "RCTBridge.h"
|
|
|
|
#import "RCTBridgeModule.h"
|
|
|
|
#import "RCTInvalidating.h"
|
|
|
|
#import "RCTViewManager.h"
|
2016-04-20 10:52:25 -07:00
|
|
|
#import "RCTRootView.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2016-05-16 08:01:35 -07:00
|
|
|
/**
|
|
|
|
* UIManager queue
|
|
|
|
*/
|
|
|
|
RCT_EXTERN dispatch_queue_t RCTGetUIManagerQueue(void);
|
|
|
|
|
2016-05-04 06:54:12 -07:00
|
|
|
/**
|
|
|
|
* Default name for the UIManager queue
|
|
|
|
*/
|
|
|
|
RCT_EXTERN char *const RCTUIManagerQueueName;
|
|
|
|
|
2015-07-31 07:37:12 -07:00
|
|
|
/**
|
|
|
|
* Posted right before re-render happens. This is a chance for views to invalidate their state so
|
|
|
|
* next render cycle will pick up updated views and layout appropriately.
|
|
|
|
*/
|
2015-08-06 15:44:15 -07:00
|
|
|
RCT_EXTERN NSString *const RCTUIManagerWillUpdateViewsDueToContentSizeMultiplierChangeNotification;
|
2015-07-31 07:37:12 -07:00
|
|
|
|
2015-08-17 06:11:29 -07:00
|
|
|
/**
|
|
|
|
* Posted whenever a new root view is registered with RCTUIManager. The userInfo property
|
|
|
|
* will contain a RCTUIManagerRootViewKey with the registered root view.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTUIManagerDidRegisterRootViewNotification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Posted whenever a root view is removed from the RCTUIManager. The userInfo property
|
|
|
|
* will contain a RCTUIManagerRootViewKey with the removed root view.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTUIManagerDidRemoveRootViewNotification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Key for the root view property in the above notifications
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTUIManagerRootViewKey;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
@protocol RCTScrollableProtocol;
|
|
|
|
|
2015-03-01 15:33:55 -08:00
|
|
|
/**
|
|
|
|
* The RCTUIManager is the module responsible for updating the view hierarchy.
|
|
|
|
*/
|
2015-02-19 20:10:52 -08:00
|
|
|
@interface RCTUIManager : NSObject <RCTBridgeModule, RCTInvalidating>
|
|
|
|
|
2015-03-01 15:33:55 -08:00
|
|
|
/**
|
2015-04-02 07:33:21 -07:00
|
|
|
* Register a root view with the RCTUIManager.
|
2015-03-24 17:37:03 -07:00
|
|
|
*/
|
2016-04-20 10:52:25 -07:00
|
|
|
- (void)registerRootView:(UIView *)rootView withSizeFlexibility:(RCTRootViewSizeFlexibility)sizeFlexibility;
|
2015-03-24 17:37:03 -07:00
|
|
|
|
2015-06-24 10:14:37 -07:00
|
|
|
/**
|
|
|
|
* Gets the view associated with a reactTag.
|
|
|
|
*/
|
|
|
|
- (UIView *)viewForReactTag:(NSNumber *)reactTag;
|
|
|
|
|
2015-03-24 17:37:03 -07:00
|
|
|
/**
|
2015-07-28 07:31:26 -07:00
|
|
|
* Update the frame of a view. This might be in response to a screen rotation
|
2015-05-26 04:14:31 -07:00
|
|
|
* or some other layout event outside of the React-managed view hierarchy.
|
2015-03-01 15:33:55 -08:00
|
|
|
*/
|
2015-07-28 07:31:26 -07:00
|
|
|
- (void)setFrame:(CGRect)frame forView:(UIView *)view;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2016-03-01 10:13:22 -08:00
|
|
|
/**
|
|
|
|
* Set the natural size of a view, which is used when no explicit size is set.
|
|
|
|
* Use UIViewNoIntrinsicMetric to ignore a dimension.
|
|
|
|
*/
|
|
|
|
- (void)setIntrinsicContentSize:(CGSize)size forView:(UIView *)view;
|
|
|
|
|
2015-05-26 04:14:31 -07:00
|
|
|
/**
|
2016-03-21 03:20:49 -07:00
|
|
|
* Update the background color of a view. The source of truth for
|
|
|
|
* backgroundColor is the shadow view, so if to update backgroundColor from
|
|
|
|
* native code you will need to call this method.
|
2015-05-26 04:14:31 -07:00
|
|
|
*/
|
2016-03-21 03:20:49 -07:00
|
|
|
- (void)setBackgroundColor:(UIColor *)color forView:(UIView *)view;
|
2015-05-26 04:14:31 -07:00
|
|
|
|
2015-03-01 15:33: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;
|
|
|
|
|
2016-08-28 22:46:42 -07:00
|
|
|
/**
|
|
|
|
* Given a reactTag from a component, find its root view, if possible.
|
|
|
|
* Otherwise, this will give back nil.
|
|
|
|
*
|
|
|
|
* @param reactTag the component tag
|
|
|
|
* @param completion the completion block that will hand over the rootView, if any.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
- (void)rootViewForReactTag:(NSNumber *)reactTag withCompletion:(void (^)(UIView *view))completion;
|
|
|
|
|
2015-03-01 15:33:55 -08:00
|
|
|
/**
|
|
|
|
* The view that is currently first responder, according to the JS context.
|
|
|
|
*/
|
2015-02-19 20:10:52 -08:00
|
|
|
+ (UIView *)JSResponder;
|
|
|
|
|
2015-12-02 05:12:17 -08:00
|
|
|
/**
|
|
|
|
* Normally, UI changes are not applied until the complete batch of method
|
|
|
|
* invocations from JavaScript to native has completed.
|
|
|
|
*
|
|
|
|
* Setting this to YES will flush UI changes sooner, which could potentially
|
|
|
|
* result in inconsistent UI updates.
|
|
|
|
*
|
|
|
|
* The default is NO (recommended).
|
|
|
|
*/
|
|
|
|
@property (atomic, assign) BOOL unsafeFlushUIChangesBeforeBatchEnds;
|
|
|
|
|
2015-12-11 06:54:56 -08:00
|
|
|
/**
|
|
|
|
* In some cases we might want to trigger layout from native side.
|
|
|
|
* React won't be aware of this, so we need to make sure it happens.
|
|
|
|
*/
|
|
|
|
- (void)setNeedsLayout;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
@end
|
2015-03-01 15:33: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
|