mirror of
https://github.com/status-im/react-native.git
synced 2025-01-14 11:34:23 +00:00
Cleanup
This commit is contained in:
parent
b807c51bbe
commit
1fb26d4319
@ -62,7 +62,7 @@
|
|||||||
[_reactSubviews removeObject:subview];
|
[_reactSubviews removeObject:subview];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (NSMutableArray *)reactSubviews
|
- (NSArray *)reactSubviews
|
||||||
{
|
{
|
||||||
return _reactSubviews;
|
return _reactSubviews;
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,7 @@ extern NSString *const RCTContentDidAppearNotification;
|
|||||||
/**
|
/**
|
||||||
* The backing view controller of the root view.
|
* The backing view controller of the root view.
|
||||||
*/
|
*/
|
||||||
@property (nonatomic, weak) UIViewController *backingViewController;
|
@property (nonatomic, weak) UIViewController *reactViewController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The React-managed contents view of the root view.
|
* The React-managed contents view of the root view.
|
||||||
|
@ -110,9 +110,9 @@ RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
|||||||
_contentView.backgroundColor = backgroundColor;
|
_contentView.backgroundColor = backgroundColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)reactViewController
|
||||||
{
|
{
|
||||||
return _backingViewController ?: [super backingViewController];
|
return _reactViewController ?: [super reactViewController];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)canBecomeFirstResponder
|
- (BOOL)canBecomeFirstResponder
|
||||||
|
@ -73,7 +73,7 @@ RCT_NOT_IMPLEMENTED(-initWithFrame:(CGRect)frame)
|
|||||||
[super didMoveToSuperview];
|
[super didMoveToSuperview];
|
||||||
|
|
||||||
if (self.superview) {
|
if (self.superview) {
|
||||||
[self.backingViewController presentViewController:_modalViewController animated:self.animated completion:nil];
|
[self.reactViewController presentViewController:_modalViewController animated:self.animated completion:nil];
|
||||||
} else {
|
} else {
|
||||||
[_modalViewController dismissViewControllerAnimated:self.animated completion:nil];
|
[_modalViewController dismissViewControllerAnimated:self.animated completion:nil];
|
||||||
}
|
}
|
||||||
|
@ -322,7 +322,7 @@ RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
|||||||
_navigationController.delegate = nil;
|
_navigationController.delegate = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)reactViewController
|
||||||
{
|
{
|
||||||
return _navigationController;
|
return _navigationController;
|
||||||
}
|
}
|
||||||
@ -444,7 +444,7 @@ RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
|||||||
{
|
{
|
||||||
// we can't hook up the VC hierarchy in 'init' because the subviews aren't
|
// we can't hook up the VC hierarchy in 'init' because the subviews aren't
|
||||||
// hooked up yet, so we do it on demand here
|
// hooked up yet, so we do it on demand here
|
||||||
[self addControllerToClosestParent:_navigationController];
|
[self reactAddControllerToClosestParent:_navigationController];
|
||||||
|
|
||||||
NSUInteger viewControllerCount = _navigationController.viewControllers.count;
|
NSUInteger viewControllerCount = _navigationController.viewControllers.count;
|
||||||
// The "react count" is the count of views that are visible on the navigation
|
// The "react count" is the count of views that are visible on the navigation
|
||||||
|
@ -63,8 +63,6 @@ RCT_EXPORT_VIEW_PROPERTY(contentInset, UIEdgeInsets)
|
|||||||
RCT_EXPORT_VIEW_PROPERTY(scrollIndicatorInsets, UIEdgeInsets)
|
RCT_EXPORT_VIEW_PROPERTY(scrollIndicatorInsets, UIEdgeInsets)
|
||||||
RCT_REMAP_VIEW_PROPERTY(contentOffset, scrollView.contentOffset, CGPoint)
|
RCT_REMAP_VIEW_PROPERTY(contentOffset, scrollView.contentOffset, CGPoint)
|
||||||
|
|
||||||
RCT_DEPRECATED_VIEW_PROPERTY(throttleScrollCallbackMS, scrollEventThrottle)
|
|
||||||
|
|
||||||
- (NSDictionary *)constantsToExport
|
- (NSDictionary *)constantsToExport
|
||||||
{
|
{
|
||||||
return @{
|
return @{
|
||||||
|
@ -67,37 +67,34 @@ typedef void (^RCTApplierBlock)(RCTSparseArray *viewRegistry);
|
|||||||
/**
|
/**
|
||||||
* Border. Defaults to { 0, 0, 0, 0 }.
|
* Border. Defaults to { 0, 0, 0, 0 }.
|
||||||
*/
|
*/
|
||||||
|
@property (nonatomic, assign) CGFloat borderWidth;
|
||||||
@property (nonatomic, assign) CGFloat borderTopWidth;
|
@property (nonatomic, assign) CGFloat borderTopWidth;
|
||||||
@property (nonatomic, assign) CGFloat borderLeftWidth;
|
@property (nonatomic, assign) CGFloat borderLeftWidth;
|
||||||
@property (nonatomic, assign) CGFloat borderBottomWidth;
|
@property (nonatomic, assign) CGFloat borderBottomWidth;
|
||||||
@property (nonatomic, assign) CGFloat borderRightWidth;
|
@property (nonatomic, assign) CGFloat borderRightWidth;
|
||||||
|
|
||||||
- (void)setBorderWidth:(CGFloat)value;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Margin. Defaults to { 0, 0, 0, 0 }.
|
* Margin. Defaults to { 0, 0, 0, 0 }.
|
||||||
*/
|
*/
|
||||||
|
@property (nonatomic, assign) CGFloat margin;
|
||||||
|
@property (nonatomic, assign) CGFloat marginVertical;
|
||||||
|
@property (nonatomic, assign) CGFloat marginHorizontal;
|
||||||
@property (nonatomic, assign) CGFloat marginTop;
|
@property (nonatomic, assign) CGFloat marginTop;
|
||||||
@property (nonatomic, assign) CGFloat marginLeft;
|
@property (nonatomic, assign) CGFloat marginLeft;
|
||||||
@property (nonatomic, assign) CGFloat marginBottom;
|
@property (nonatomic, assign) CGFloat marginBottom;
|
||||||
@property (nonatomic, assign) CGFloat marginRight;
|
@property (nonatomic, assign) CGFloat marginRight;
|
||||||
|
|
||||||
- (void)setMargin:(CGFloat)margin;
|
|
||||||
- (void)setMarginVertical:(CGFloat)margin;
|
|
||||||
- (void)setMarginHorizontal:(CGFloat)margin;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Padding. Defaults to { 0, 0, 0, 0 }.
|
* Padding. Defaults to { 0, 0, 0, 0 }.
|
||||||
*/
|
*/
|
||||||
|
@property (nonatomic, assign) CGFloat padding;
|
||||||
|
@property (nonatomic, assign) CGFloat paddingVertical;
|
||||||
|
@property (nonatomic, assign) CGFloat paddingHorizontal;
|
||||||
@property (nonatomic, assign) CGFloat paddingTop;
|
@property (nonatomic, assign) CGFloat paddingTop;
|
||||||
@property (nonatomic, assign) CGFloat paddingLeft;
|
@property (nonatomic, assign) CGFloat paddingLeft;
|
||||||
@property (nonatomic, assign) CGFloat paddingBottom;
|
@property (nonatomic, assign) CGFloat paddingBottom;
|
||||||
@property (nonatomic, assign) CGFloat paddingRight;
|
@property (nonatomic, assign) CGFloat paddingRight;
|
||||||
|
|
||||||
- (void)setPadding:(CGFloat)padding;
|
|
||||||
- (void)setPaddingVertical:(CGFloat)padding;
|
|
||||||
- (void)setPaddingHorizontal:(CGFloat)padding;
|
|
||||||
|
|
||||||
- (UIEdgeInsets)paddingAsInsets;
|
- (UIEdgeInsets)paddingAsInsets;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,7 +47,7 @@
|
|||||||
RCT_NOT_IMPLEMENTED(-initWithFrame:(CGRect)frame)
|
RCT_NOT_IMPLEMENTED(-initWithFrame:(CGRect)frame)
|
||||||
RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
||||||
|
|
||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)reactViewController
|
||||||
{
|
{
|
||||||
return _tabController;
|
return _tabController;
|
||||||
}
|
}
|
||||||
@ -92,13 +92,13 @@ RCT_NOT_IMPLEMENTED(-initWithCoder:(NSCoder *)aDecoder)
|
|||||||
{
|
{
|
||||||
// we can't hook up the VC hierarchy in 'init' because the subviews aren't
|
// we can't hook up the VC hierarchy in 'init' because the subviews aren't
|
||||||
// hooked up yet, so we do it on demand here whenever a transaction has finished
|
// hooked up yet, so we do it on demand here whenever a transaction has finished
|
||||||
[self addControllerToClosestParent:_tabController];
|
[self reactAddControllerToClosestParent:_tabController];
|
||||||
|
|
||||||
if (_tabsChanged) {
|
if (_tabsChanged) {
|
||||||
|
|
||||||
NSMutableArray *viewControllers = [NSMutableArray array];
|
NSMutableArray *viewControllers = [NSMutableArray array];
|
||||||
for (RCTTabBarItem *tab in [self reactSubviews]) {
|
for (RCTTabBarItem *tab in [self reactSubviews]) {
|
||||||
UIViewController *controller = tab.backingViewController;
|
UIViewController *controller = tab.reactViewController;
|
||||||
if (!controller) {
|
if (!controller) {
|
||||||
controller = [[RCTWrapperViewController alloc] initWithContentView:tab
|
controller = [[RCTWrapperViewController alloc] initWithContentView:tab
|
||||||
eventDispatcher:_eventDispatcher];
|
eventDispatcher:_eventDispatcher];
|
||||||
|
@ -82,9 +82,9 @@
|
|||||||
_barItem.badgeValue = oldItem.badgeValue;
|
_barItem.badgeValue = oldItem.badgeValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)reactViewController
|
||||||
{
|
{
|
||||||
return self.superview.backingViewController;
|
return self.superview.reactViewController;
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -229,7 +229,7 @@ RCT_NOT_IMPLEMENTED(-initWithCoder:unused)
|
|||||||
+ (UIEdgeInsets)contentInsetsForView:(UIView *)view
|
+ (UIEdgeInsets)contentInsetsForView:(UIView *)view
|
||||||
{
|
{
|
||||||
while (view) {
|
while (view) {
|
||||||
UIViewController *controller = view.backingViewController;
|
UIViewController *controller = view.reactViewController;
|
||||||
if (controller) {
|
if (controller) {
|
||||||
return (UIEdgeInsets){
|
return (UIEdgeInsets){
|
||||||
controller.topLayoutGuide.length, 0,
|
controller.topLayoutGuide.length, 0,
|
||||||
|
@ -21,6 +21,11 @@
|
|||||||
|
|
||||||
typedef void (^RCTViewManagerUIBlock)(RCTUIManager *uiManager, RCTSparseArray *viewRegistry);
|
typedef void (^RCTViewManagerUIBlock)(RCTUIManager *uiManager, RCTSparseArray *viewRegistry);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Underlying implementation of RCT_EXPORT_XXX macros. Ignore this.
|
||||||
|
*/
|
||||||
|
RCT_EXTERN void RCTSetViewProperty(NSString *, NSString *, SEL, id, id, id);
|
||||||
|
|
||||||
@interface RCTViewManager : NSObject <RCTBridgeModule>
|
@interface RCTViewManager : NSObject <RCTBridgeModule>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -110,18 +115,12 @@ typedef void (^RCTViewManagerUIBlock)(RCTUIManager *uiManager, RCTSparseArray *v
|
|||||||
*/
|
*/
|
||||||
#define RCT_REMAP_VIEW_PROPERTY(name, keyPath, type) \
|
#define RCT_REMAP_VIEW_PROPERTY(name, keyPath, type) \
|
||||||
RCT_CUSTOM_VIEW_PROPERTY(name, type, UIView) { \
|
RCT_CUSTOM_VIEW_PROPERTY(name, type, UIView) { \
|
||||||
if ((json && !RCTSetProperty(view, @#keyPath, @selector(type:), json)) || \
|
RCTSetViewProperty(@#name, @#keyPath, @selector(type:), view, defaultView, json); \
|
||||||
(!json && !RCTCopyProperty(view, defaultView, @#keyPath))) { \
|
|
||||||
RCTLogError(@"%@ does not have setter for `%s` property", [view class], #name); \
|
|
||||||
} \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define RCT_REMAP_SHADOW_PROPERTY(name, keyPath, type) \
|
#define RCT_REMAP_SHADOW_PROPERTY(name, keyPath, type) \
|
||||||
RCT_CUSTOM_SHADOW_PROPERTY(name, type, RCTShadowView) { \
|
RCT_CUSTOM_SHADOW_PROPERTY(name, type, RCTShadowView) { \
|
||||||
if ((json && !RCTSetProperty(view, @#keyPath, @selector(type:), json)) || \
|
RCTSetViewProperty(@#name, @#keyPath, @selector(type:), view, defaultView, json); \
|
||||||
(!json && !RCTCopyProperty(view, defaultView, @#keyPath))) { \
|
|
||||||
RCTLogError(@"%@ does not have setter for `%s` property", [view class], #name); \
|
|
||||||
} \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -137,29 +136,4 @@ RCT_CUSTOM_SHADOW_PROPERTY(name, type, RCTShadowView) { \
|
|||||||
+ (NSString *)getPropConfigShadow_##name { return @#type; } \
|
+ (NSString *)getPropConfigShadow_##name { return @#type; } \
|
||||||
- (void)set_##name:(id)json forShadowView:(viewClass *)view withDefaultView:(viewClass *)defaultView
|
- (void)set_##name:(id)json forShadowView:(viewClass *)view withDefaultView:(viewClass *)defaultView
|
||||||
|
|
||||||
/**
|
|
||||||
* These are useful in cases where the module's superclass handles a
|
|
||||||
* property, but you wish to "unhandle" it, so it will be ignored.
|
|
||||||
*/
|
|
||||||
#define RCT_IGNORE_VIEW_PROPERTY(name) \
|
|
||||||
- (void)set_##name:(id)value forView:(id)view withDefaultView:(id)defaultView {}
|
|
||||||
|
|
||||||
#define RCT_IGNORE_SHADOW_PROPERTY(name) \
|
|
||||||
- (void)set_##name:(id)value forShadowView:(id)view withDefaultView:(id)defaultView {}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Used for when view property names change. Will log an error when used.
|
|
||||||
*/
|
|
||||||
#define RCT_DEPRECATED_VIEW_PROPERTY(oldName, newName) \
|
|
||||||
- (void)set_##oldName:(id)json forView:(id)view withDefaultView:(id)defaultView { \
|
|
||||||
RCTLogError(@"Property '%s' has been replaced by '%s'.", #oldName, #newName); \
|
|
||||||
[self set_##newName:json forView:view withDefaultView:defaultView]; \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define RCT_DEPRECATED_SHADOW_PROPERTY(oldName, newName) \
|
|
||||||
- (void)set_##oldName:(id)json forShadowView:(id)view withDefaultView:(id)defaultView { \
|
|
||||||
RCTLogError(@"Property '%s' has been replaced by '%s'.", #oldName, #newName); \
|
|
||||||
[self set_##newName:json forView:view withDefaultView:defaultView]; \
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -43,6 +43,15 @@ RCT_MULTI_ENUM_CONVERTER(UIAccessibilityTraits, (@{
|
|||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
void RCTSetViewProperty(NSString *name, NSString *keyPath, SEL type,
|
||||||
|
id view, id defaultView, id json)
|
||||||
|
{
|
||||||
|
if ((json && !RCTSetProperty(view, keyPath, type, json)) ||
|
||||||
|
(!json && !RCTCopyProperty(view, defaultView, keyPath))) {
|
||||||
|
RCTLogError(@"%@ does not have setter for `%@` property", [view class], name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@implementation RCTViewManager
|
@implementation RCTViewManager
|
||||||
|
|
||||||
@synthesize bridge = _bridge;
|
@synthesize bridge = _bridge;
|
||||||
@ -144,19 +153,9 @@ RCT_CUSTOM_VIEW_PROPERTY(removeClippedSubviews, BOOL, RCTView)
|
|||||||
}
|
}
|
||||||
RCT_CUSTOM_VIEW_PROPERTY(borderRadius, CGFloat, RCTView) {
|
RCT_CUSTOM_VIEW_PROPERTY(borderRadius, CGFloat, RCTView) {
|
||||||
if ([view respondsToSelector:@selector(setBorderRadius:)]) {
|
if ([view respondsToSelector:@selector(setBorderRadius:)]) {
|
||||||
if (json) {
|
view.borderRadius = json ? [RCTConvert CGFloat:json] : defaultView.borderRadius;
|
||||||
view.borderRadius = [RCTConvert CGFloat:json];
|
|
||||||
} else if ([view respondsToSelector:@selector(borderRadius)]) {
|
|
||||||
view.borderRadius = [defaultView borderRadius];
|
|
||||||
} else {
|
} else {
|
||||||
view.borderRadius = defaultView.layer.cornerRadius;
|
view.layer.cornerRadius = json ? [RCTConvert CGFloat:json] : defaultView.layer.cornerRadius;
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (json) {
|
|
||||||
view.layer.cornerRadius = [RCTConvert CGFloat:json];
|
|
||||||
} else {
|
|
||||||
view.layer.cornerRadius = defaultView.layer.cornerRadius;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RCT_CUSTOM_VIEW_PROPERTY(borderColor, CGColor, RCTView)
|
RCT_CUSTOM_VIEW_PROPERTY(borderColor, CGColor, RCTView)
|
||||||
@ -245,9 +244,7 @@ RCT_EXPORT_SHADOW_PROPERTY(borderTopWidth, CGFloat)
|
|||||||
RCT_EXPORT_SHADOW_PROPERTY(borderRightWidth, CGFloat)
|
RCT_EXPORT_SHADOW_PROPERTY(borderRightWidth, CGFloat)
|
||||||
RCT_EXPORT_SHADOW_PROPERTY(borderBottomWidth, CGFloat)
|
RCT_EXPORT_SHADOW_PROPERTY(borderBottomWidth, CGFloat)
|
||||||
RCT_EXPORT_SHADOW_PROPERTY(borderLeftWidth, CGFloat)
|
RCT_EXPORT_SHADOW_PROPERTY(borderLeftWidth, CGFloat)
|
||||||
RCT_CUSTOM_SHADOW_PROPERTY(borderWidth, CGFloat, __unused RCTShadowView) {
|
RCT_EXPORT_SHADOW_PROPERTY(borderWidth, CGFloat)
|
||||||
[view setBorderWidth:[RCTConvert CGFloat:json]];
|
|
||||||
}
|
|
||||||
|
|
||||||
RCT_EXPORT_SHADOW_PROPERTY(marginTop, CGFloat)
|
RCT_EXPORT_SHADOW_PROPERTY(marginTop, CGFloat)
|
||||||
RCT_EXPORT_SHADOW_PROPERTY(marginRight, CGFloat)
|
RCT_EXPORT_SHADOW_PROPERTY(marginRight, CGFloat)
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
|
|
||||||
- (void)insertReactSubview:(id<RCTViewNodeProtocol>)subview atIndex:(NSInteger)atIndex;
|
- (void)insertReactSubview:(id<RCTViewNodeProtocol>)subview atIndex:(NSInteger)atIndex;
|
||||||
- (void)removeReactSubview:(id<RCTViewNodeProtocol>)subview;
|
- (void)removeReactSubview:(id<RCTViewNodeProtocol>)subview;
|
||||||
- (NSMutableArray *)reactSubviews;
|
- (NSArray *)reactSubviews;
|
||||||
- (id<RCTViewNodeProtocol>)reactSuperview;
|
- (id<RCTViewNodeProtocol>)reactSuperview;
|
||||||
- (NSNumber *)reactTagAtPoint:(CGPoint)point;
|
- (NSNumber *)reactTagAtPoint:(CGPoint)point;
|
||||||
|
|
||||||
@ -36,6 +36,7 @@
|
|||||||
|
|
||||||
// TODO: this is kinda dumb - let's come up with a
|
// TODO: this is kinda dumb - let's come up with a
|
||||||
// better way of identifying root React views please!
|
// better way of identifying root React views please!
|
||||||
static inline BOOL RCTIsReactRootView(NSNumber *reactTag) {
|
static inline BOOL RCTIsReactRootView(NSNumber *reactTag)
|
||||||
|
{
|
||||||
return reactTag.integerValue % 10 == 1;
|
return reactTag.integerValue % 10 == 1;
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,12 @@
|
|||||||
|
|
||||||
#import "RCTView.h"
|
#import "RCTView.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Special scheme used to pass messages to the injectedJavaScript
|
||||||
|
* code without triggering a page load. Usage:
|
||||||
|
*
|
||||||
|
* window.location.href = RCTJSNavigationScheme + '://hello'
|
||||||
|
*/
|
||||||
extern NSString *const RCTJSNavigationScheme;
|
extern NSString *const RCTJSNavigationScheme;
|
||||||
|
|
||||||
@class RCTEventDispatcher;
|
@class RCTEventDispatcher;
|
||||||
|
@ -18,11 +18,6 @@
|
|||||||
#import "RCTView.h"
|
#import "RCTView.h"
|
||||||
#import "UIView+React.h"
|
#import "UIView+React.h"
|
||||||
|
|
||||||
// Special scheme that allow JS to notify the WebView to emit
|
|
||||||
// navigation event.
|
|
||||||
//
|
|
||||||
// JavaScript Example:
|
|
||||||
// window.location.href = 'react-js-navigation://hello'
|
|
||||||
NSString *const RCTJSNavigationScheme = @"react-js-navigation";
|
NSString *const RCTJSNavigationScheme = @"react-js-navigation";
|
||||||
|
|
||||||
@interface RCTWebView () <UIWebViewDelegate, RCTAutoInsetsProtocol>
|
@interface RCTWebView () <UIWebViewDelegate, RCTAutoInsetsProtocol>
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
/**
|
/**
|
||||||
* This method finds and returns the containing view controller for the view.
|
* This method finds and returns the containing view controller for the view.
|
||||||
*/
|
*/
|
||||||
- (UIViewController *)backingViewController;
|
- (UIViewController *)reactViewController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method attaches the specified controller as a child of the
|
* This method attaches the specified controller as a child of the
|
||||||
@ -37,7 +37,7 @@
|
|||||||
* controller is found (which may happen if the view is not currently
|
* controller is found (which may happen if the view is not currently
|
||||||
* attached to the view hierarchy).
|
* attached to the view hierarchy).
|
||||||
*/
|
*/
|
||||||
- (void)addControllerToClosestParent:(UIViewController *)controller;
|
- (void)reactAddControllerToClosestParent:(UIViewController *)controller;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Responder overrides - to be deprecated.
|
* Responder overrides - to be deprecated.
|
||||||
|
@ -87,7 +87,7 @@
|
|||||||
self.backgroundColor = inheritedBackgroundColor;
|
self.backgroundColor = inheritedBackgroundColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)reactViewController
|
||||||
{
|
{
|
||||||
id responder = [self nextResponder];
|
id responder = [self nextResponder];
|
||||||
while (responder) {
|
while (responder) {
|
||||||
@ -99,14 +99,14 @@
|
|||||||
return nil;
|
return nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)addControllerToClosestParent:(UIViewController *)controller
|
- (void)reactAddControllerToClosestParent:(UIViewController *)controller
|
||||||
{
|
{
|
||||||
if (!controller.parentViewController) {
|
if (!controller.parentViewController) {
|
||||||
UIView *parentView = (UIView *)self.reactSuperview;
|
UIView *parentView = (UIView *)self.reactSuperview;
|
||||||
while (parentView) {
|
while (parentView) {
|
||||||
if (parentView.backingViewController) {
|
if (parentView.reactViewController) {
|
||||||
[parentView.backingViewController addChildViewController:controller];
|
[parentView.reactViewController addChildViewController:controller];
|
||||||
[controller didMoveToParentViewController:parentView.backingViewController];
|
[controller didMoveToParentViewController:parentView.reactViewController];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
parentView = (UIView *)parentView.reactSuperview;
|
parentView = (UIView *)parentView.reactSuperview;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user