mirror of
https://github.com/status-im/react-native.git
synced 2025-01-20 06:18:57 +00:00
46c02b6ae5
Summary: This diff refactors the view update process into two stages: 1. The `reactSubviews` array is set, whose order matches the order of the JS components and shadowView components, as specified by the UIManager. 2. The `didUpdateReactSubviews` method is called, which actually inserts the reactSubviews into the view hierarchy. This simplifies a lot of the hacks we had for special-case treatment of subviews: In many cases we don't want to actually insert `reactSubviews` into the parentView, and we had a bunch of component-specific solutions for that (typically overriding all of the reactSubviews methods to store views in an array). Now, we can simply override the `didUpdateReactSubviews` method for those views to do nothing, or do something different. Reviewed By: wwjholmes Differential Revision: D3396594 fbshipit-source-id: 92fc56fd31db0cfc66aac3d1634a4d4ae3903085
73 lines
2.0 KiB
Objective-C
73 lines
2.0 KiB
Objective-C
/**
|
|
* 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.
|
|
*/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
@class RCTShadowView;
|
|
|
|
#import "RCTComponent.h"
|
|
|
|
//TODO: let's try to eliminate this category if possible
|
|
|
|
@interface UIView (React) <RCTComponent>
|
|
|
|
/**
|
|
* RCTComponent interface.
|
|
*/
|
|
- (NSArray<UIView *> *)reactSubviews NS_REQUIRES_SUPER;
|
|
- (UIView *)reactSuperview NS_REQUIRES_SUPER;
|
|
- (void)insertReactSubview:(UIView *)subview atIndex:(NSInteger)atIndex NS_REQUIRES_SUPER;
|
|
- (void)removeReactSubview:(UIView *)subview NS_REQUIRES_SUPER;
|
|
|
|
/**
|
|
* Updates the subviews array based on the reactSubviews. Default behavior is
|
|
* to insert the reactSubviews into the UIView.
|
|
*/
|
|
- (void)didUpdateReactSubviews;
|
|
|
|
/**
|
|
* Used by the UIIManager to set the view frame.
|
|
* May be overriden to disable animation, etc.
|
|
*/
|
|
- (void)reactSetFrame:(CGRect)frame;
|
|
|
|
/**
|
|
* Used to improve performance when compositing views with translucent content.
|
|
*/
|
|
- (void)reactSetInheritedBackgroundColor:(UIColor *)inheritedBackgroundColor;
|
|
|
|
/**
|
|
* This method finds and returns the containing view controller for the view.
|
|
*/
|
|
- (UIViewController *)reactViewController;
|
|
|
|
/**
|
|
* This method attaches the specified controller as a child of the
|
|
* the owning view controller of this view. Returns NO if no view
|
|
* controller is found (which may happen if the view is not currently
|
|
* attached to the view hierarchy).
|
|
*/
|
|
- (void)reactAddControllerToClosestParent:(UIViewController *)controller;
|
|
|
|
/**
|
|
* Responder overrides - to be deprecated.
|
|
*/
|
|
- (void)reactWillMakeFirstResponder;
|
|
- (void)reactDidMakeFirstResponder;
|
|
- (BOOL)reactRespondsToTouch:(UITouch *)touch;
|
|
|
|
/**
|
|
Tools for debugging
|
|
*/
|
|
#if RCT_DEV
|
|
@property (nonatomic, strong, setter=_DEBUG_setReactShadowView:) RCTShadowView *_DEBUG_reactShadowView;
|
|
#endif
|
|
|
|
@end
|