2016-05-31 04:56:49 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2016-05-31 04:56:49 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
|
|
|
|
extern NSString *const RCTBundleURLProviderUpdatedNotification;
|
|
|
|
|
2016-07-15 05:35:15 -07:00
|
|
|
extern const NSUInteger kRCTBundleURLProviderDefaultPort;
|
|
|
|
|
2016-07-13 16:39:21 -07:00
|
|
|
@interface RCTBundleURLProvider : NSObject
|
|
|
|
|
2016-05-31 04:56:49 -07:00
|
|
|
/**
|
|
|
|
* Set default settings on NSUserDefaults.
|
|
|
|
*/
|
|
|
|
- (void)setDefaults;
|
|
|
|
|
2016-06-09 07:01:42 -07:00
|
|
|
/**
|
|
|
|
* Reset every settings to default.
|
|
|
|
*/
|
|
|
|
- (void)resetToDefaults;
|
|
|
|
|
2017-10-16 16:55:01 -07:00
|
|
|
/**
|
|
|
|
* Returns the jsBundleURL for a given bundle entrypoint and
|
|
|
|
* the fallback offline JS bundle if the packager is not running.
|
|
|
|
* if resourceName or extension are nil, "main" and "jsbundle" will be
|
|
|
|
* used, respectively.
|
|
|
|
*/
|
|
|
|
- (NSURL *)jsBundleURLForBundleRoot:(NSString *)bundleRoot
|
|
|
|
fallbackResource:(NSString *)resourceName
|
|
|
|
fallbackExtension:(NSString *)extension;
|
|
|
|
|
2016-05-31 04:56:49 -07:00
|
|
|
/**
|
|
|
|
* Returns the jsBundleURL for a given bundle entrypoint and
|
|
|
|
* the fallback offline JS bundle if the packager is not running.
|
|
|
|
*/
|
|
|
|
- (NSURL *)jsBundleURLForBundleRoot:(NSString *)bundleRoot
|
|
|
|
fallbackResource:(NSString *)resourceName;
|
|
|
|
|
2017-11-03 14:15:19 -07:00
|
|
|
/**
|
|
|
|
* Returns the jsBundleURL for a given bundle entrypoint and
|
|
|
|
* the fallback offline JS bundle. If resourceName or extension
|
|
|
|
* are nil, "main" and "jsbundle" will be used, respectively.
|
|
|
|
*/
|
|
|
|
- (NSURL *)jsBundleURLForFallbackResource:(NSString *)resourceName
|
|
|
|
fallbackExtension:(NSString *)extension;
|
|
|
|
|
2016-10-20 11:38:40 -07:00
|
|
|
/**
|
|
|
|
* Returns the resourceURL for a given bundle entrypoint and
|
|
|
|
* the fallback offline resource file if the packager is not running.
|
|
|
|
*/
|
|
|
|
- (NSURL *)resourceURLForResourceRoot:(NSString *)root
|
|
|
|
resourceName:(NSString *)name
|
|
|
|
resourceExtension:(NSString *)extension
|
|
|
|
offlineBundle:(NSBundle *)offlineBundle;
|
|
|
|
|
2016-05-31 04:56:49 -07:00
|
|
|
/**
|
|
|
|
* The IP address or hostname of the packager.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, copy) NSString *jsLocation;
|
|
|
|
|
|
|
|
@property (nonatomic, assign) BOOL enableLiveReload;
|
|
|
|
@property (nonatomic, assign) BOOL enableMinification;
|
|
|
|
@property (nonatomic, assign) BOOL enableDev;
|
|
|
|
|
|
|
|
+ (instancetype)sharedSettings;
|
2016-07-13 16:39:22 -07:00
|
|
|
|
|
|
|
/**
|
2016-07-15 05:35:15 -07:00
|
|
|
Given a hostname for the packager and a bundle root, returns the URL to the js bundle. Generally you should use the
|
|
|
|
instance method -jsBundleURLForBundleRoot:fallbackResource: which includes logic to guess if the packager is running
|
|
|
|
and fall back to a pre-packaged bundle if it is not.
|
2016-07-13 16:39:22 -07:00
|
|
|
*/
|
2016-07-15 05:35:15 -07:00
|
|
|
+ (NSURL *)jsBundleURLForBundleRoot:(NSString *)bundleRoot
|
|
|
|
packagerHost:(NSString *)packagerHost
|
|
|
|
enableDev:(BOOL)enableDev
|
|
|
|
enableMinification:(BOOL)enableMinification;
|
2016-07-13 16:39:22 -07:00
|
|
|
|
2016-10-20 11:38:40 -07:00
|
|
|
/**
|
|
|
|
* Given a hostname for the packager and a resource path (including "/"), return the URL to the resource.
|
|
|
|
* In general, please use the instance method to decide if the packager is running and fallback to the pre-packaged
|
|
|
|
* resource if it is not: -resourceURLForResourceRoot:resourceName:resourceExtension:offlineBundle:
|
|
|
|
*/
|
|
|
|
+ (NSURL *)resourceURLForResourcePath:(NSString *)path
|
|
|
|
packagerHost:(NSString *)packagerHost
|
|
|
|
query:(NSString *)query;
|
|
|
|
|
2016-05-31 04:56:49 -07:00
|
|
|
@end
|