react-native/Libraries/Wrapper/RCTWrapperView.m
Valentin Shergin c0e9936d8e Opensourcing RCTWrapper
Summary:
RCTWrapper is a library that allows turn any UIView/UIViewController-based widget into React Native component
which will respect layout constrains of native (wrapped) view.
So, you don't need to explicitly specify width and hight in styling.

Take a look at examples to see how to use RCTWrapper.

Reviewed By: mmmulani

Differential Revision: D5868763

fbshipit-source-id: 0a503b42be166d547ca6cbf0829eea9c75a8e364
2017-10-09 17:22:35 -07:00

94 lines
1.9 KiB
Objective-C

// Copyright 2004-present Facebook. All Rights Reserved.
#import "RCTWrapperView.h"
#import <React/RCTBridge.h>
#import <React/RCTUIManager.h>
@implementation RCTWrapperView {
__weak RCTBridge *_bridge;
}
- (instancetype)initWithBridge:(RCTBridge *)bridge
{
if (self = [super initWithFrame:CGRectZero]) {
_bridge = bridge;
__weak __typeof(self) weakSelf = self;
_measureBlock = ^(CGSize minimumSize, CGSize maximumSize) {
__typeof(self) strongSelf = weakSelf;
if (!strongSelf) {
return maximumSize;
}
CGSize size = [strongSelf sizeThatFits:maximumSize];
return CGSizeMake(
MAX(size.width, minimumSize.width),
MAX(size.height, minimumSize.height)
);
};
}
return self;
}
#pragma mark - `contentView`
- (nullable UIView *)contentView
{
return self.subviews.firstObject;
}
- (void)setContentView:(UIView *)contentView
{
while (self.subviews.firstObject) {
[self.subviews.firstObject removeFromSuperview];
}
if (!contentView) {
return;
}
[super addSubview:contentView];
contentView.frame = self.bounds;
contentView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
contentView.translatesAutoresizingMaskIntoConstraints = YES;
}
#pragma mark - Layout
- (void)setNeedsLayout
{
[super setNeedsLayout];
[self invalidateIntrinsicContentSize];
}
- (void)invalidateIntrinsicContentSize
{
[super invalidateIntrinsicContentSize];
// Setting `intrinsicContentSize` dirties the Yoga node and
// enfoce Yoga to call `measure` function (backed to `measureBlock`).
[_bridge.uiManager setIntrinsicContentSize:self.intrinsicContentSize forView:self];
}
- (CGSize)intrinsicContentSize
{
return [self sizeThatFits:CGSizeMake(INFINITY, INFINITY)];
}
- (CGSize)sizeThatFits:(CGSize)size
{
UIView *contentView = self.contentView;
if (!contentView) {
return size;
}
return [contentView sizeThatFits:size];
}
@end