forked from Ivasoft/mattermost-mobile
160 lines
7.5 KiB
Diff
160 lines
7.5 KiB
Diff
diff --git a/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/react/NavigationModule.java b/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/react/NavigationModule.java
|
|
index 3eb6609..68a68bf 100644
|
|
--- a/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/react/NavigationModule.java
|
|
+++ b/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/react/NavigationModule.java
|
|
@@ -33,6 +33,8 @@ import java.util.ArrayList;
|
|
|
|
import static com.reactnativenavigation.utils.UiUtils.pxToDp;
|
|
|
|
+import android.app.Activity;
|
|
+
|
|
public class NavigationModule extends ReactContextBaseJavaModule {
|
|
private static final String NAME = "RNNBridgeModule";
|
|
|
|
@@ -56,20 +58,30 @@ public class NavigationModule extends ReactContextBaseJavaModule {
|
|
@Override
|
|
public void onHostPause() {
|
|
super.onHostPause();
|
|
- navigator().onHostPause();
|
|
+ Navigator navigator = navigator();
|
|
+ if (navigator != null) {
|
|
+ navigator().onHostPause();
|
|
+ }
|
|
}
|
|
|
|
@Override
|
|
public void onHostResume() {
|
|
- eventEmitter = new EventEmitter(reactContext);
|
|
- navigator().setEventEmitter(eventEmitter);
|
|
- layoutFactory.init(
|
|
- activity(),
|
|
- eventEmitter,
|
|
- navigator().getChildRegistry(),
|
|
- ((NavigationApplication) activity().getApplication()).getExternalComponents()
|
|
- );
|
|
- navigator().onHostResume();
|
|
+ try {
|
|
+ eventEmitter = new EventEmitter(reactContext);
|
|
+ Navigator navigator = navigator();
|
|
+ if (navigator != null) {
|
|
+ navigator().setEventEmitter(eventEmitter);
|
|
+ layoutFactory.init(
|
|
+ activity(),
|
|
+ eventEmitter,
|
|
+ navigator().getChildRegistry(),
|
|
+ ((NavigationApplication) activity().getApplication()).getExternalComponents()
|
|
+ );
|
|
+ navigator().onHostResume();
|
|
+ }
|
|
+ } catch (ClassCastException e) {
|
|
+ // The most current activity is not a NavigationActivity
|
|
+ }
|
|
}
|
|
});
|
|
}
|
|
@@ -206,7 +218,11 @@ public class NavigationModule extends ReactContextBaseJavaModule {
|
|
}
|
|
|
|
private Navigator navigator() {
|
|
- return activity().getNavigator();
|
|
+ if (activity() instanceof NavigationActivity) {
|
|
+ NavigationActivity activity = (NavigationActivity) activity();
|
|
+ return activity.getNavigator();
|
|
+ }
|
|
+ return null;
|
|
}
|
|
|
|
private Options parse(@Nullable ReadableMap mergeOptions) {
|
|
@@ -217,21 +233,26 @@ public class NavigationModule extends ReactContextBaseJavaModule {
|
|
|
|
protected void handle(Runnable task) {
|
|
UiThread.post(() -> {
|
|
- if (getCurrentActivity() != null && !activity().isFinishing()) {
|
|
- task.run();
|
|
+ try {
|
|
+ if (getCurrentActivity() != null && !activity().isFinishing()) {
|
|
+ task.run();
|
|
+ }
|
|
+ } catch (ClassCastException e) {
|
|
+ // The most current activity is not a NavigationActivity)
|
|
}
|
|
});
|
|
}
|
|
|
|
- protected NavigationActivity activity() {
|
|
- return (NavigationActivity) getCurrentActivity();
|
|
+ protected Activity activity() {
|
|
+ return getCurrentActivity();
|
|
}
|
|
|
|
@Override
|
|
public void onCatalystInstanceDestroy() {
|
|
- final NavigationActivity navigationActivity = activity();
|
|
- if (navigationActivity != null) {
|
|
- navigationActivity.onCatalystInstanceDestroy();
|
|
+ final Activity navigationActivity = activity();
|
|
+ if (navigationActivity != null && navigationActivity instanceof NavigationActivity) {
|
|
+ NavigationActivity activity = (NavigationActivity)navigationActivity;
|
|
+ activity.onCatalystInstanceDestroy();
|
|
}
|
|
super.onCatalystInstanceDestroy();
|
|
}
|
|
diff --git a/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/viewcontrollers/component/ComponentViewController.java b/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/viewcontrollers/component/ComponentViewController.java
|
|
index 51837db..14a5828 100644
|
|
--- a/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/viewcontrollers/component/ComponentViewController.java
|
|
+++ b/node_modules/react-native-navigation/lib/android/app/src/main/java/com/reactnativenavigation/viewcontrollers/component/ComponentViewController.java
|
|
@@ -4,6 +4,7 @@ import android.app.Activity;
|
|
import android.content.res.Configuration;
|
|
import android.view.View;
|
|
|
|
+import com.reactnativenavigation.options.params.NullBool;
|
|
import com.reactnativenavigation.viewcontrollers.viewcontroller.ScrollEventListener;
|
|
import com.reactnativenavigation.options.Options;
|
|
import com.reactnativenavigation.viewcontrollers.viewcontroller.Presenter;
|
|
@@ -148,7 +149,7 @@ public class ComponentViewController extends ChildController<ComponentLayout> {
|
|
|
|
@Override
|
|
public void destroy() {
|
|
- final boolean blurOnUnmount = options != null && options.modal.blurOnUnmount.isTrue();
|
|
+ final boolean blurOnUnmount = options != null && (options.modal.blurOnUnmount.isTrue() || options.overlayOptions.interceptTouchOutside instanceof NullBool);
|
|
if (blurOnUnmount) {
|
|
blurActivityFocus();
|
|
}
|
|
diff --git a/node_modules/react-native-navigation/lib/ios/RNNOverlayWindow.m b/node_modules/react-native-navigation/lib/ios/RNNOverlayWindow.m
|
|
index 934e7e7..19169a3 100644
|
|
--- a/node_modules/react-native-navigation/lib/ios/RNNOverlayWindow.m
|
|
+++ b/node_modules/react-native-navigation/lib/ios/RNNOverlayWindow.m
|
|
@@ -1,6 +1,8 @@
|
|
#import "RNNOverlayWindow.h"
|
|
#import "RNNReactView.h"
|
|
#import <React/RCTModalHostView.h>
|
|
+#import <react-native-safe-area-context/RNCSafeAreaView.h>
|
|
+#import <react-native-safe-area-context/RNCSafeAreaProvider.h>
|
|
|
|
@implementation RNNOverlayWindow
|
|
|
|
@@ -9,6 +11,8 @@
|
|
|
|
if ([hitTestResult isKindOfClass:[UIWindow class]] ||
|
|
[hitTestResult.subviews.firstObject isKindOfClass:RNNReactView.class] ||
|
|
+ [hitTestResult isKindOfClass:[RNCSafeAreaView class]] ||
|
|
+ [hitTestResult isKindOfClass:[RNCSafeAreaProvider class]] ||
|
|
[hitTestResult isKindOfClass:[RCTModalHostView class]]) {
|
|
return nil;
|
|
}
|
|
diff --git a/node_modules/react-native-navigation/lib/ios/RNNViewLocation.m b/node_modules/react-native-navigation/lib/ios/RNNViewLocation.m
|
|
index 2e60123..56830c8 100644
|
|
--- a/node_modules/react-native-navigation/lib/ios/RNNViewLocation.m
|
|
+++ b/node_modules/react-native-navigation/lib/ios/RNNViewLocation.m
|
|
@@ -21,8 +21,8 @@
|
|
self.toBounds = [self convertViewBounds:toElement];
|
|
self.fromCenter = [self convertViewCenter:fromElement];
|
|
self.toCenter = [self convertViewCenter:toElement];
|
|
- self.fromPath = [self resolveViewPath:fromElement withSuperView:fromElement.superview];
|
|
- self.toPath = [self resolveViewPath:toElement withSuperView:toElement.superview];
|
|
+ self.fromPath = fromElement.bounds;
|
|
+ self.toPath = toElement.bounds;
|
|
|
|
return self;
|
|
}
|