Skip to content

Commit

Permalink
Fix modal and alert dismissal bugs on iOS (facebook#22237)
Browse files Browse the repository at this point in the history
  • Loading branch information
sryze committed Oct 13, 2019
1 parent 6376951 commit 7d720d5
Show file tree
Hide file tree
Showing 5 changed files with 46 additions and 15 deletions.
17 changes: 12 additions & 5 deletions React/Modules/RCTAlertManager.m
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ @interface RCTAlertManager()
@implementation RCTAlertManager
{
NSHashTable *_alertControllers;
UIWindow *_window;
}

RCT_EXPORT_MODULE()
Expand Down Expand Up @@ -90,11 +91,16 @@ - (void)invalidate
}
}

UIViewController *presentingController = RCTPresentedViewController();
if (presentingController == nil) {
RCTLogError(@"Tried to display alert view but there is no application window. args: %@", args);
return;
}
CGSize screenSize = [UIScreen mainScreen].bounds.size;
self->_window = [[UIWindow alloc] initWithFrame:CGRectMake(0, 0, screenSize.width, screenSize.height)];
#if TARGET_OS_TV
self->_window.windowLevel = UIWindowLevelNormal + 1;
#else
self->_window.windowLevel = UIWindowLevelStatusBar + 1;
#endif
UIViewController *presentingController = [UIViewController new];
self->_window.rootViewController = presentingController;
self->_window.hidden = NO;

UIAlertController *alertController = [UIAlertController
alertControllerWithTitle:title
Expand Down Expand Up @@ -152,6 +158,7 @@ - (void)invalidate
[alertController addAction:[UIAlertAction actionWithTitle:buttonTitle
style:buttonStyle
handler:^(__unused UIAlertAction *action) {
self->_window = nil;
switch (type) {
case RCTAlertViewStylePlainTextInput:
case RCTAlertViewStyleSecureTextInput:
Expand Down
9 changes: 7 additions & 2 deletions React/Views/RCTModalHostView.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,12 @@

@protocol RCTModalHostViewInteractor <NSObject>

- (void)presentModalHostView:(RCTModalHostView *)modalHostView withViewController:(RCTModalHostViewController *)viewController animated:(BOOL)animated;
- (void)dismissModalHostView:(RCTModalHostView *)modalHostView withViewController:(RCTModalHostViewController *)viewController animated:(BOOL)animated;
- (void)presentModalHostView:(RCTModalHostView *)modalHostView
withViewController:(RCTModalHostViewController *)viewController
animated:(BOOL)animated;
- (void)dismissModalHostView:(RCTModalHostView *)modalHostView
withViewController:(RCTModalHostViewController *)viewController
animated:(BOOL)animated
completion:(void (^)(void))completionHandler;

@end
8 changes: 6 additions & 2 deletions React/Views/RCTModalHostView.m
Original file line number Diff line number Diff line change
Expand Up @@ -159,8 +159,12 @@ - (void)didUpdateReactSubviews
- (void)dismissModalViewController
{
if (_isPresented) {
[_delegate dismissModalHostView:self withViewController:_modalViewController animated:[self hasAnimationType]];
_isPresented = NO;
[_delegate dismissModalHostView:self
withViewController:_modalViewController
animated:[self hasAnimationType]
completion:^{
self->_isPresented = NO;
}];
}
}

Expand Down
1 change: 0 additions & 1 deletion React/Views/RCTModalHostViewController.m
Original file line number Diff line number Diff line change
Expand Up @@ -72,5 +72,4 @@ - (UIInterfaceOrientationMask)supportedInterfaceOrientations
#endif // RCT_DEV
#endif // !TARGET_OS_TV


@end
26 changes: 21 additions & 5 deletions React/Views/RCTModalHostViewManager.m
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,9 @@ - (UIView *)view
return view;
}

- (void)presentModalHostView:(RCTModalHostView *)modalHostView withViewController:(RCTModalHostViewController *)viewController animated:(BOOL)animated
- (void)presentModalHostView:(RCTModalHostView *)modalHostView
withViewController:(RCTModalHostViewController *)viewController
animated:(BOOL)animated
{
dispatch_block_t completionBlock = ^{
if (modalHostView.onShow) {
Expand All @@ -74,20 +76,34 @@ - (void)presentModalHostView:(RCTModalHostView *)modalHostView withViewControlle
if (_presentationBlock) {
_presentationBlock([modalHostView reactViewController], viewController, animated, completionBlock);
} else {
[[modalHostView reactViewController] presentViewController:viewController animated:animated completion:completionBlock];
[[modalHostView reactViewController]
presentViewController:viewController animated:animated completion:completionBlock];
}
}

- (void)dismissModalHostView:(RCTModalHostView *)modalHostView withViewController:(RCTModalHostViewController *)viewController animated:(BOOL)animated
- (void)dismissModalHostView:(RCTModalHostView *)modalHostView
withViewController:(RCTModalHostViewController *)viewController
animated:(BOOL)animated
completion:(void (^)(void))completionHandler
{
dispatch_block_t completionBlock = ^{
if (modalHostView.identifier) {
[[self.bridge moduleForClass:[RCTModalManager class]] modalDismissed:modalHostView.identifier];
}
};
if (_dismissalBlock) {
_dismissalBlock([modalHostView reactViewController], viewController, animated, nil);
} else {
[viewController.presentingViewController dismissViewControllerAnimated:animated completion:nil];
if (viewController.presentedViewController && viewController.presentingViewController) {
// Ask the presenting view controller to dismiss any view controllers presented on top of the modal host
// together with the host itself.
[viewController.presentingViewController dismissViewControllerAnimated:animated completion:completionHandler];
} else {
[viewController dismissViewControllerAnimated:animated completion:completionHandler];
}
}
}


- (RCTShadowView *)shadowView
{
return [RCTModalHostShadowView new];
Expand Down

0 comments on commit 7d720d5

Please sign in to comment.