2015-01-30 01:10:49 +00:00
|
|
|
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
|
|
|
#import "RCTJavaScriptExecutor.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Uses an embedded web view merely for the purpose of being able to reuse the
|
|
|
|
* existing webkit debugging tools. Fulfills the role of a very constrained
|
|
|
|
* `JSContext`, which we call `RCTJavaScriptExecutor`.
|
|
|
|
*
|
|
|
|
* TODO: To ensure production-identical execution, scrub the window
|
|
|
|
* environment. And ensure main thread operations are actually added to a queue
|
|
|
|
* instead of being executed immediately if already on the main thread.
|
|
|
|
*/
|
2015-02-06 23:43:59 +00:00
|
|
|
@interface RCTWebViewExecutor : NSObject<RCTJavaScriptExecutor>
|
2015-01-30 01:10:49 +00:00
|
|
|
|
|
|
|
// Only one callback stored - will only be invoked for the latest issued
|
|
|
|
// application script request.
|
2015-02-06 23:43:59 +00:00
|
|
|
@property (nonatomic, copy) RCTJavaScriptCompleteBlock onApplicationScriptLoaded;
|
2015-01-30 01:10:49 +00:00
|
|
|
|
2015-02-06 23:43:59 +00:00
|
|
|
/**
|
|
|
|
* Instantiate with a specific webview instance
|
|
|
|
*/
|
|
|
|
- (instancetype)initWithWebView:(UIWebView *)webView NS_DESIGNATED_INITIALIZER;
|
2015-01-30 01:10:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoke this to reclaim the web view for reuse. This is necessary in order to
|
|
|
|
* allow debuggers to remain open, when creating a new `RCTWebViewExecutor`.
|
|
|
|
* This guards against the web view being invalidated, and makes sure the
|
|
|
|
* `delegate` is cleared first.
|
|
|
|
*/
|
|
|
|
- (UIWebView *)invalidateAndReclaimWebView;
|
|
|
|
|
|
|
|
@end
|