Browse Source

Fix merging buttons second time doesn't work (#4243)

Yogev Ben David 6 years ago
parent
commit
ff02494259
No account linked to committer's email address

+ 3
- 0
lib/ios/RNNLeafProtocol.h View File

1
+#import "RNNRootViewCreator.h"
1
 
2
 
2
 typedef void (^RNNReactViewReadyCompletionBlock)(void);
3
 typedef void (^RNNReactViewReadyCompletionBlock)(void);
3
 
4
 
9
 
10
 
10
 - (BOOL)isCustomTransitioned;
11
 - (BOOL)isCustomTransitioned;
11
 
12
 
13
+- (id<RNNRootViewCreator>)creator;
14
+
12
 @end
15
 @end

+ 2
- 2
lib/ios/RNNNavigationButtons.h View File

1
 #import <Foundation/Foundation.h>
1
 #import <Foundation/Foundation.h>
2
 #import <UIKit/UIKit.h>
2
 #import <UIKit/UIKit.h>
3
-#import "RNNRootViewController.h"
4
 #import "RNNButtonOptions.h"
3
 #import "RNNButtonOptions.h"
4
+#import "RNNRootViewCreator.h"
5
 
5
 
6
 @interface RNNNavigationButtons : NSObject
6
 @interface RNNNavigationButtons : NSObject
7
 
7
 
8
--(instancetype)initWithViewController:(RNNRootViewController*)viewController;
8
+-(instancetype)initWithViewController:(UIViewController*)viewController rootViewCreator:(id<RNNRootViewCreator>)creator;
9
 
9
 
10
 -(void)applyLeftButtons:(NSArray*)leftButtons rightButtons:(NSArray*)rightButtons defaultLeftButtonStyle:(RNNButtonOptions *)defaultLeftButtonStyle defaultRightButtonStyle:(RNNButtonOptions *)defaultRightButtonStyle;
10
 -(void)applyLeftButtons:(NSArray*)leftButtons rightButtons:(NSArray*)rightButtons defaultLeftButtonStyle:(RNNButtonOptions *)defaultLeftButtonStyle defaultRightButtonStyle:(RNNButtonOptions *)defaultRightButtonStyle;
11
 
11
 

+ 6
- 4
lib/ios/RNNNavigationButtons.m View File

3
 #import <React/RCTConvert.h>
3
 #import <React/RCTConvert.h>
4
 #import "RCTHelpers.h"
4
 #import "RCTHelpers.h"
5
 #import "UIImage+tint.h"
5
 #import "UIImage+tint.h"
6
+#import "RNNRootViewController.h"
6
 
7
 
7
 @interface RNNNavigationButtons()
8
 @interface RNNNavigationButtons()
8
 
9
 
9
-@property (weak, nonatomic) RNNRootViewController* viewController;
10
+@property (weak, nonatomic) UIViewController* viewController;
10
 @property (strong, nonatomic) RNNButtonOptions* defaultLeftButtonStyle;
11
 @property (strong, nonatomic) RNNButtonOptions* defaultLeftButtonStyle;
11
 @property (strong, nonatomic) RNNButtonOptions* defaultRightButtonStyle;
12
 @property (strong, nonatomic) RNNButtonOptions* defaultRightButtonStyle;
12
-
13
+@property (nonatomic) id<RNNRootViewCreator> creator;
13
 @end
14
 @end
14
 
15
 
15
 @implementation RNNNavigationButtons
16
 @implementation RNNNavigationButtons
16
 
17
 
17
--(instancetype)initWithViewController:(RNNRootViewController*)viewController {
18
+-(instancetype)initWithViewController:(UIViewController*)viewController rootViewCreator:(id<RNNRootViewCreator>)creator {
18
 	self = [super init];
19
 	self = [super init];
19
 	
20
 	
20
 	self.viewController = viewController;
21
 	self.viewController = viewController;
22
+	self.creator = creator;
21
 	
23
 	
22
 	return self;
24
 	return self;
23
 }
25
 }
78
 	
80
 	
79
 	RNNUIBarButtonItem *barButtonItem;
81
 	RNNUIBarButtonItem *barButtonItem;
80
 	if (component) {
82
 	if (component) {
81
-		RCTRootView *view = (RCTRootView*)[self.viewController.creator createCustomReactView:component[@"name"] rootViewId:component[@"componentId"]];
83
+		RCTRootView *view = (RCTRootView*)[self.creator createCustomReactView:component[@"name"] rootViewId:component[@"componentId"]];
82
 		barButtonItem = [[RNNUIBarButtonItem alloc] init:buttonId withCustomView:view];
84
 		barButtonItem = [[RNNUIBarButtonItem alloc] init:buttonId withCustomView:view];
83
 	} else if (iconImage) {
85
 	} else if (iconImage) {
84
 		barButtonItem = [[RNNUIBarButtonItem alloc] init:buttonId withIcon:iconImage];
86
 		barButtonItem = [[RNNUIBarButtonItem alloc] init:buttonId withIcon:iconImage];

+ 1
- 1
lib/ios/RNNRootViewController.m View File

37
 	
37
 	
38
 	self.eventEmitter = eventEmitter;
38
 	self.eventEmitter = eventEmitter;
39
 	self.presenter = presenter;
39
 	self.presenter = presenter;
40
-	[self.presenter bindViewController:self];
40
+	[self.presenter bindViewController:self viewCreator:self.creator];
41
 	self.options = options;
41
 	self.options = options;
42
 	self.defaultOptions = defaultOptions;
42
 	self.defaultOptions = defaultOptions;
43
 	
43
 	

+ 0
- 57
lib/ios/RNNTopBarOptions.m View File

61
 	return self;
61
 	return self;
62
 }
62
 }
63
 
63
 
64
-- (void)applyOn:(UIViewController*)viewController {
65
-	if (self.rightButtons || self.leftButtons) {
66
-		_navigationButtons = [[RNNNavigationButtons alloc] initWithViewController:(RNNRootViewController*)viewController];
67
-		[_navigationButtons applyLeftButtons:self.leftButtons rightButtons:self.rightButtons defaultLeftButtonStyle:self.leftButtonStyle defaultRightButtonStyle:self.rightButtonStyle];
68
-	}
69
-	
70
-	self.rightButtons = nil;
71
-	self.leftButtons = nil;
72
-}
73
-
74
-//- (void)setRightButtonColor:(NSNumber *)rightButtonColor {
75
-//	_rightButtonColor = rightButtonColor;
76
-//	_rightButtonStyle.color = rightButtonColor;
77
-//}
78
-//
79
-//- (void)setRightButtonDisabledColor:(NSNumber *)rightButtonDisabledColor {
80
-//	_rightButtonDisabledColor = rightButtonDisabledColor;
81
-//	_rightButtonStyle.disabledColor = rightButtonDisabledColor;
82
-//}
83
-//
84
-//- (void)setLeftButtonColor:(NSNumber *)leftButtonColor {
85
-//	_leftButtonColor = leftButtonColor;
86
-//	_leftButtonStyle.color = leftButtonColor;
87
-//}
88
-//
89
-//- (void)setLeftButtonDisabledColor:(NSNumber *)leftButtonDisabledColor {
90
-//	_leftButtonDisabledColor = leftButtonDisabledColor;
91
-//	_leftButtonStyle.disabledColor = leftButtonDisabledColor;
92
-//}
93
-
94
-//- (void)setRightButtons:(id)rightButtons {
95
-//	if ([rightButtons isKindOfClass:[NSArray class]]) {
96
-//		_rightButtons = rightButtons;
97
-//	} else if ([rightButtons isKindOfClass:[NSDictionary class]]) {
98
-//		if (rightButtons[@"id"]) {
99
-//			_rightButtons = @[rightButtons];
100
-//		} else {
101
-//			[_rightButtonStyle mergeWith:rightButtons];
102
-//		}
103
-//	} else {
104
-//		_rightButtons = rightButtons;
105
-//	}
106
-//}
107
-//
108
-//- (void)setLeftButtons:(id)leftButtons {
109
-//	if ([leftButtons isKindOfClass:[NSArray class]]) {
110
-//		_leftButtons = leftButtons;
111
-//	} else if ([leftButtons isKindOfClass:[NSDictionary class]]) {
112
-//		if (leftButtons[@"id"]) {
113
-//			_leftButtons = @[leftButtons];
114
-//		} else {
115
-//			[_leftButtonStyle mergeWith:leftButtons];
116
-//		}
117
-//	} else {
118
-//		_leftButtons = leftButtons;
119
-//	}
120
-//}
121
 
64
 
122
 @end
65
 @end

+ 5
- 0
lib/ios/RNNViewControllerPresenter.h View File

1
 #import "RNNBasePresenter.h"
1
 #import "RNNBasePresenter.h"
2
+#import "RNNNavigationButtons.h"
2
 
3
 
3
 @interface RNNViewControllerPresenter : RNNBasePresenter
4
 @interface RNNViewControllerPresenter : RNNBasePresenter
4
 
5
 
6
+@property (nonatomic, strong) RNNNavigationButtons* navigationButtons;
7
+
8
+- (void)bindViewController:(UIViewController *)bindedViewController viewCreator:(id<RNNRootViewCreator>)creator;
9
+
5
 @end
10
 @end

+ 5
- 8
lib/ios/RNNViewControllerPresenter.m View File

1
 #import "RNNViewControllerPresenter.h"
1
 #import "RNNViewControllerPresenter.h"
2
 #import "UIViewController+RNNOptions.h"
2
 #import "UIViewController+RNNOptions.h"
3
 #import "UITabBarController+RNNOptions.h"
3
 #import "UITabBarController+RNNOptions.h"
4
-#import "RNNNavigationButtons.h"
5
 #import "RCTConvert+Modal.h"
4
 #import "RCTConvert+Modal.h"
6
 #import "RNNReactView.h"
5
 #import "RNNReactView.h"
7
 
6
 
8
-@interface RNNViewControllerPresenter()
9
-@property (nonatomic, strong) RNNNavigationButtons* navigationButtons;
10
-@end
11
-
12
 @implementation RNNViewControllerPresenter
7
 @implementation RNNViewControllerPresenter
13
 
8
 
9
+- (void)bindViewController:(UIViewController *)bindedViewController viewCreator:(id<RNNRootViewCreator>)creator {
10
+	self.bindedViewController = bindedViewController;
11
+	_navigationButtons = [[RNNNavigationButtons alloc] initWithViewController:self.bindedViewController rootViewCreator:creator];
12
+}
14
 
13
 
15
 - (void)applyOptions:(RNNNavigationOptions *)options {
14
 - (void)applyOptions:(RNNNavigationOptions *)options {
16
 	[super applyOptions:options];
15
 	[super applyOptions:options];
33
 		[viewController rnn_setSearchBarWithPlaceholder:[options.topBar.searchBarPlaceholder getWithDefaultValue:@""]];
32
 		[viewController rnn_setSearchBarWithPlaceholder:[options.topBar.searchBarPlaceholder getWithDefaultValue:@""]];
34
 	}
33
 	}
35
 	
34
 	
36
-	if ((options.topBar.leftButtons || options.topBar.rightButtons) && !_navigationButtons) {
37
-		_navigationButtons = [[RNNNavigationButtons alloc] initWithViewController:(RNNRootViewController*)viewController];
35
+	if ((options.topBar.leftButtons || options.topBar.rightButtons)) {
38
 		[_navigationButtons applyLeftButtons:options.topBar.leftButtons rightButtons:options.topBar.rightButtons defaultLeftButtonStyle:options.topBar.leftButtonStyle defaultRightButtonStyle:options.topBar.rightButtonStyle];
36
 		[_navigationButtons applyLeftButtons:options.topBar.leftButtons rightButtons:options.topBar.rightButtons defaultLeftButtonStyle:options.topBar.leftButtonStyle defaultRightButtonStyle:options.topBar.rightButtonStyle];
39
 	}
37
 	}
40
 }
38
 }
112
 	
110
 	
113
 	if (newOptions.topBar.leftButtons || newOptions.topBar.rightButtons) {
111
 	if (newOptions.topBar.leftButtons || newOptions.topBar.rightButtons) {
114
 		RNNNavigationOptions* buttonsResolvedOptions = [(RNNNavigationOptions *)[currentOptions overrideOptions:newOptions] withDefault:defaultOptions];
112
 		RNNNavigationOptions* buttonsResolvedOptions = [(RNNNavigationOptions *)[currentOptions overrideOptions:newOptions] withDefault:defaultOptions];
115
-		_navigationButtons = [[RNNNavigationButtons alloc] initWithViewController:(RNNRootViewController*)viewController];
116
 		[_navigationButtons applyLeftButtons:newOptions.topBar.leftButtons rightButtons:newOptions.topBar.rightButtons defaultLeftButtonStyle:buttonsResolvedOptions.topBar.leftButtonStyle defaultRightButtonStyle:buttonsResolvedOptions.topBar.rightButtonStyle];
113
 		[_navigationButtons applyLeftButtons:newOptions.topBar.leftButtons rightButtons:newOptions.topBar.rightButtons defaultLeftButtonStyle:buttonsResolvedOptions.topBar.leftButtonStyle defaultRightButtonStyle:buttonsResolvedOptions.topBar.rightButtonStyle];
117
 	}
114
 	}
118
 	
115
 	

+ 9
- 1
lib/ios/ReactNativeNavigationTests/RNNViewControllerPresenterTest.m View File

3
 #import "RNNViewControllerPresenter.h"
3
 #import "RNNViewControllerPresenter.h"
4
 #import "UIViewController+RNNOptions.h"
4
 #import "UIViewController+RNNOptions.h"
5
 #import "RNNReactView.h"
5
 #import "RNNReactView.h"
6
+#import "RNNRootViewController.h"
6
 
7
 
7
 @interface RNNViewControllerPresenterTest : XCTestCase
8
 @interface RNNViewControllerPresenterTest : XCTestCase
8
 
9
 
17
 - (void)setUp {
18
 - (void)setUp {
18
     [super setUp];
19
     [super setUp];
19
 	self.uut = [[RNNViewControllerPresenter alloc] init];
20
 	self.uut = [[RNNViewControllerPresenter alloc] init];
20
-	self.bindedViewController = [OCMockObject partialMockForObject:[UIViewController new]];
21
+	self.bindedViewController = [OCMockObject partialMockForObject:[RNNRootViewController new]];
21
 	[self.uut bindViewController:self.bindedViewController];
22
 	[self.uut bindViewController:self.bindedViewController];
22
 	self.options = [[RNNNavigationOptions alloc] initEmptyOptions];
23
 	self.options = [[RNNNavigationOptions alloc] initEmptyOptions];
23
 }
24
 }
67
     [(id)self.bindedViewController verify];
68
     [(id)self.bindedViewController verify];
68
 }
69
 }
69
 
70
 
71
+- (void)testBindViewControllerShouldCreateNavigationButtonsCreator {
72
+	RNNViewControllerPresenter* presenter = [[RNNViewControllerPresenter alloc] init];
73
+	[presenter bindViewController:self.bindedViewController viewCreator:nil];
74
+	XCTAssertNotNil(presenter.navigationButtons);
75
+}
76
+
70
 - (void)testApplyOptionsOnInit_shouldSetModalPresentetionStyleWithDefault {
77
 - (void)testApplyOptionsOnInit_shouldSetModalPresentetionStyleWithDefault {
71
 	[[(id)self.bindedViewController expect] rnn_setModalPresentationStyle:UIModalPresentationFullScreen];
78
 	[[(id)self.bindedViewController expect] rnn_setModalPresentationStyle:UIModalPresentationFullScreen];
72
 	[self.uut applyOptionsOnInit:self.options];
79
 	[self.uut applyOptionsOnInit:self.options];
125
     [(id)self.bindedViewController verify];
132
     [(id)self.bindedViewController verify];
126
 }
133
 }
127
 
134
 
135
+
128
 @end
136
 @end