From 07cc9d3f6212c9bad59767e0a12ae9243de126f7 Mon Sep 17 00:00:00 2001 From: Yogev Ben David Date: Wed, 2 Jan 2019 16:55:58 +0200 Subject: [PATCH] Fix sideMenu intuitive side width - #4527 (#4528) --- lib/ios/RNNSideMenuChildVC.h | 2 ++ lib/ios/RNNSideMenuChildVC.m | 6 ++++ lib/ios/RNNSideMenuController.m | 2 ++ .../project.pbxproj | 4 +++ .../RNNSideMenuControllerTest.m | 32 +++++++++++++++++++ .../RNNSideMenuPresenterTest.m | 3 -- 6 files changed, 46 insertions(+), 3 deletions(-) create mode 100644 lib/ios/ReactNativeNavigationTests/RNNSideMenuControllerTest.m diff --git a/lib/ios/RNNSideMenuChildVC.h b/lib/ios/RNNSideMenuChildVC.h index a10a7c10453..29417245065 100644 --- a/lib/ios/RNNSideMenuChildVC.h +++ b/lib/ios/RNNSideMenuChildVC.h @@ -20,4 +20,6 @@ typedef NS_ENUM(NSInteger, RNNSideMenuChildType) { - (instancetype)initWithLayoutInfo:(RNNLayoutInfo *)layoutInfo childViewControllers:(NSArray *)childViewControllers options:(RNNNavigationOptions *)options defaultOptions:(RNNNavigationOptions *)defaultOptions presenter:(RNNViewControllerPresenter *)presenter type:(RNNSideMenuChildType)type; +- (void)setWidth:(CGFloat)width; + @end diff --git a/lib/ios/RNNSideMenuChildVC.m b/lib/ios/RNNSideMenuChildVC.m index 5866d79f427..4a7e3c55c4d 100644 --- a/lib/ios/RNNSideMenuChildVC.m +++ b/lib/ios/RNNSideMenuChildVC.m @@ -60,6 +60,12 @@ - (void)bindChildViewController:(UIViewController*)child { [self.view bringSubviewToFront:self.child.view]; } +- (void)setWidth:(CGFloat)width { + CGRect frame = self.child.view.frame; + frame.size.width = width; + self.child.view.frame = frame; +} + - (UIViewController *)getCurrentChild { return self.child; } diff --git a/lib/ios/RNNSideMenuController.m b/lib/ios/RNNSideMenuController.m index dc2e619a009..5927f21c45a 100644 --- a/lib/ios/RNNSideMenuController.m +++ b/lib/ios/RNNSideMenuController.m @@ -76,9 +76,11 @@ - (void)side:(MMDrawerSide)side width:(double)width { switch (side) { case MMDrawerSideRight: self.maximumRightDrawerWidth = width; + [self.right setWidth:width]; break; case MMDrawerSideLeft: self.maximumLeftDrawerWidth = width; + [self.left setWidth:width]; default: break; } diff --git a/lib/ios/ReactNativeNavigation.xcodeproj/project.pbxproj b/lib/ios/ReactNativeNavigation.xcodeproj/project.pbxproj index 3abbf5cc6bb..ebe1de68908 100644 --- a/lib/ios/ReactNativeNavigation.xcodeproj/project.pbxproj +++ b/lib/ios/ReactNativeNavigation.xcodeproj/project.pbxproj @@ -204,6 +204,7 @@ 507F43F81FF525B500D9425B /* RNNSegmentedControl.h in Headers */ = {isa = PBXBuildFile; fileRef = 507F43F61FF525B500D9425B /* RNNSegmentedControl.h */; }; 507F43F91FF525B500D9425B /* RNNSegmentedControl.m in Sources */ = {isa = PBXBuildFile; fileRef = 507F43F71FF525B500D9425B /* RNNSegmentedControl.m */; }; 507F44201FFA8A8800D9425B /* RNNParentProtocol.h in Headers */ = {isa = PBXBuildFile; fileRef = 507F441F1FFA8A8800D9425B /* RNNParentProtocol.h */; }; + 5085DD2D21DCF75A0032E64B /* RNNSideMenuControllerTest.m in Sources */ = {isa = PBXBuildFile; fileRef = 5085DD2C21DCF75A0032E64B /* RNNSideMenuControllerTest.m */; }; 50887C1520ECC5C200D06111 /* RNNButtonOptions.h in Headers */ = {isa = PBXBuildFile; fileRef = 50887C1320ECC5C200D06111 /* RNNButtonOptions.h */; }; 50887C1620ECC5C200D06111 /* RNNButtonOptions.m in Sources */ = {isa = PBXBuildFile; fileRef = 50887C1420ECC5C200D06111 /* RNNButtonOptions.m */; }; 50887CA920F26BFE00D06111 /* RNNOverlayWindow.m in Sources */ = {isa = PBXBuildFile; fileRef = 50887CA720F26BFD00D06111 /* RNNOverlayWindow.m */; }; @@ -526,6 +527,7 @@ 507F43F61FF525B500D9425B /* RNNSegmentedControl.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = RNNSegmentedControl.h; sourceTree = ""; }; 507F43F71FF525B500D9425B /* RNNSegmentedControl.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = RNNSegmentedControl.m; sourceTree = ""; }; 507F441F1FFA8A8800D9425B /* RNNParentProtocol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = RNNParentProtocol.h; sourceTree = ""; }; + 5085DD2C21DCF75A0032E64B /* RNNSideMenuControllerTest.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = RNNSideMenuControllerTest.m; sourceTree = ""; }; 50887C1320ECC5C200D06111 /* RNNButtonOptions.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = RNNButtonOptions.h; sourceTree = ""; }; 50887C1420ECC5C200D06111 /* RNNButtonOptions.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = RNNButtonOptions.m; sourceTree = ""; }; 50887CA720F26BFD00D06111 /* RNNOverlayWindow.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = RNNOverlayWindow.m; sourceTree = ""; }; @@ -1017,6 +1019,7 @@ 509B258E2178BE7A00C83C23 /* RNNNavigationControllerPresenterTest.m */, 502F0E172179C39900367CC3 /* RNNTabBarPresenterTest.m */, 50CE8502217C6C9B00084EBF /* RNNSideMenuPresenterTest.m */, + 5085DD2C21DCF75A0032E64B /* RNNSideMenuControllerTest.m */, 50206A6C21AFE75400B7BB1A /* RNNSideMenuParserTest.m */, 502F0E152178D09600367CC3 /* RNNBasePresenterTest.m */, 5038A378216D01F6009280BC /* RNNBottomTabOptionsTest.m */, @@ -1398,6 +1401,7 @@ 50206A6D21AFE75400B7BB1A /* RNNSideMenuParserTest.m in Sources */, 509B258F2178BE7A00C83C23 /* RNNNavigationControllerPresenterTest.m in Sources */, 7B49FECD1E95098500DEB3EA /* RNNModalManagerTest.m in Sources */, + 5085DD2D21DCF75A0032E64B /* RNNSideMenuControllerTest.m in Sources */, E83BAD791F27416B00A9F3DD /* RNNRootViewControllerTest.m in Sources */, 50CE8503217C6C9B00084EBF /* RNNSideMenuPresenterTest.m in Sources */, E8DA243D1F973C1900CD552B /* RNNTransitionStateHolderTest.m in Sources */, diff --git a/lib/ios/ReactNativeNavigationTests/RNNSideMenuControllerTest.m b/lib/ios/ReactNativeNavigationTests/RNNSideMenuControllerTest.m new file mode 100644 index 00000000000..0eb1a4072a4 --- /dev/null +++ b/lib/ios/ReactNativeNavigationTests/RNNSideMenuControllerTest.m @@ -0,0 +1,32 @@ +#import +#import "RNNSideMenuController.h" +#import "RNNRootViewController.h" + +@interface RNNSideMenuControllerTest : XCTestCase +@property (nonatomic, strong) RNNSideMenuController *uut; +@property (nonatomic, strong) RNNSideMenuChildVC *centerVC; +@property (nonatomic, strong) RNNSideMenuChildVC *leftVC; +@property (nonatomic, strong) RNNSideMenuChildVC *rightVC; +@end + +@implementation RNNSideMenuControllerTest + +- (void)setUp { + [super setUp]; + _leftVC = [[RNNSideMenuChildVC alloc] initWithLayoutInfo:nil childViewControllers:@[[RNNRootViewController new]] options:nil defaultOptions:nil presenter:nil type:RNNSideMenuChildTypeLeft]; + _rightVC = [[RNNSideMenuChildVC alloc] initWithLayoutInfo:nil childViewControllers:@[[RNNRootViewController new]] options:nil defaultOptions:nil presenter:nil type:RNNSideMenuChildTypeRight]; + _centerVC = [[RNNSideMenuChildVC alloc] initWithLayoutInfo:nil childViewControllers:@[[RNNRootViewController new]] options:nil defaultOptions:nil presenter:nil type:RNNSideMenuChildTypeCenter]; + self.uut = [[RNNSideMenuController alloc] initWithLayoutInfo:nil childViewControllers:@[_leftVC, _centerVC, _rightVC] options:[[RNNNavigationOptions alloc] initEmptyOptions] defaultOptions:nil presenter:nil]; +} + +- (void)testSetSideMenuWidthShouldUpdateLeftReactViewFrameWidth { + [self.uut side:MMDrawerSideLeft width:100]; + XCTAssertEqual(self.uut.left.child.view.frame.size.width, 100.f); +} + +- (void)testSetSideMenuWidthShouldUpdateRightReactViewFrameWidth { + [self.uut side:MMDrawerSideRight width:150]; + XCTAssertEqual(self.uut.right.child.view.frame.size.width, 150.f); +} + +@end diff --git a/lib/ios/ReactNativeNavigationTests/RNNSideMenuPresenterTest.m b/lib/ios/ReactNativeNavigationTests/RNNSideMenuPresenterTest.m index a127c2edfd1..54e73ac466c 100644 --- a/lib/ios/ReactNativeNavigationTests/RNNSideMenuPresenterTest.m +++ b/lib/ios/ReactNativeNavigationTests/RNNSideMenuPresenterTest.m @@ -82,7 +82,4 @@ - (void)testApplyOptionsOnInitShouldSetBezelDrawerGestureMode { [self.bindedViewController verify]; } - - - @end