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-14 10:52:40 -07:00
|
|
|
#import "RCTBridge.h"
|
|
|
|
|
2015-04-03 08:38:06 -07:00
|
|
|
extern NSString *const RCTJavaScriptDidLoadNotification;
|
|
|
|
extern NSString *const RCTReloadNotification;
|
|
|
|
extern NSString *const RCTReloadViewsNotification;
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-04-03 08:38:06 -07:00
|
|
|
@interface RCTRootView : UIView <RCTInvalidating>
|
|
|
|
|
2015-04-07 18:26:09 -07:00
|
|
|
/**
|
|
|
|
* - Designated initializer -
|
|
|
|
*/
|
2015-04-03 08:38:06 -07:00
|
|
|
- (instancetype)initWithBridge:(RCTBridge *)bridge
|
|
|
|
moduleName:(NSString *)moduleName NS_DESIGNATED_INITIALIZER;
|
2015-03-25 20:09:04 -07:00
|
|
|
|
2015-02-06 15:43:59 -08:00
|
|
|
/**
|
2015-04-03 08:38:06 -07:00
|
|
|
* - Convenience initializer -
|
|
|
|
* A bridge will be created internally.
|
|
|
|
* This initializer is intended to be used when the app has a single RCTRootView,
|
|
|
|
* otherwise create an `RCTBridge` and pass it in via `initWithBridge:moduleName:`
|
|
|
|
* to all the instances.
|
2015-02-06 15:43:59 -08:00
|
|
|
*/
|
2015-04-03 08:38:06 -07:00
|
|
|
- (instancetype)initWithBundleURL:(NSURL *)bundleURL
|
|
|
|
moduleName:(NSString *)moduleName
|
|
|
|
launchOptions:(NSDictionary *)launchOptions;
|
2015-02-06 15:43:59 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The name of the JavaScript module to execute within the
|
|
|
|
* specified scriptURL (required). Setting this will not have
|
|
|
|
* any immediate effect, but it must be done prior to loading
|
|
|
|
* the script.
|
|
|
|
*/
|
2015-03-25 20:09:04 -07:00
|
|
|
@property (nonatomic, copy, readonly) NSString *moduleName;
|
2015-02-06 15:43:59 -08:00
|
|
|
|
2015-04-07 18:26:09 -07:00
|
|
|
/**
|
|
|
|
* The bridge used by the root view. Bridges can be shared between multiple
|
|
|
|
* root views, so you can use this property to initialize another RCTRootView.
|
|
|
|
*/
|
2015-04-03 08:38:06 -07:00
|
|
|
@property (nonatomic, strong, readonly) RCTBridge *bridge;
|
2015-03-14 10:52:40 -07:00
|
|
|
|
2015-02-06 15:43:59 -08:00
|
|
|
/**
|
|
|
|
* The default properties to apply to the view when the script bundle
|
|
|
|
* is first loaded. Defaults to nil/empty.
|
|
|
|
*/
|
2015-01-29 17:10:49 -08:00
|
|
|
@property (nonatomic, copy) NSDictionary *initialProperties;
|
2015-02-06 15:43:59 -08:00
|
|
|
|
2015-03-14 10:52:40 -07:00
|
|
|
/**
|
2015-02-06 15:43:59 -08:00
|
|
|
* The class of the RCTJavaScriptExecutor to use with this view.
|
|
|
|
* If not specified, it will default to using RCTContextExecutor.
|
|
|
|
* Changes will take effect next time the bundle is reloaded.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, strong) Class executorClass;
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-03-25 18:19:28 -07:00
|
|
|
/**
|
|
|
|
* If YES will watch for shake gestures and show development menu
|
|
|
|
* with options like "Reload", "Enable Debugging", etc.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, assign) BOOL enableDevMenu;
|
|
|
|
|
2015-01-29 17:10:49 -08:00
|
|
|
/**
|
|
|
|
* Reload this root view, or all root views, respectively.
|
|
|
|
*/
|
|
|
|
- (void)reload;
|
|
|
|
+ (void)reloadAll;
|
|
|
|
|
2015-04-03 08:38:06 -07:00
|
|
|
@property (nonatomic, weak) UIViewController *backingViewController;
|
|
|
|
|
|
|
|
@property (nonatomic, strong, readonly) UIView *contentView;
|
|
|
|
|
2015-03-02 10:52:16 -08:00
|
|
|
- (void)startOrResetInteractionTiming;
|
|
|
|
- (NSDictionary *)endAndResetInteractionTiming;
|
|
|
|
|
2015-01-29 17:10:49 -08:00
|
|
|
@end
|