From b13c13f48aa2d89127a87f73868e704ee940838a Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Fri, 10 Nov 2023 14:46:24 -0800 Subject: [PATCH 1/6] Fix UI takeover behavior - The UI takeover setting was incorrectly implemented on Android. Taps occurring outside of the in-app webview were dismissing the message if ui takeover was disabled. This pr updates the behavior to allow the taps to interact with the UI if ui takeover is disabled. Additionally, the decor view background will not be dimmed if ui takeover is disabled. --- .../mobile/services/ui/MessageFragment.java | 102 +++++++++++------- .../services/ui/WebViewGestureListener.java | 13 +-- .../services/ui/MessageFragmentTests.java | 43 -------- .../ui/WebViewGestureListenerTests.java | 16 --- 4 files changed, 65 insertions(+), 109 deletions(-) diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java index 817dc45a4..d879f95a2 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java @@ -11,6 +11,7 @@ package com.adobe.marketing.mobile.services.ui; +import android.app.Activity; import android.app.Dialog; import android.app.FragmentTransaction; import android.content.Context; @@ -25,6 +26,7 @@ import android.view.ViewGroup; import android.webkit.WebView; import android.widget.FrameLayout; +import androidx.annotation.NonNull; import androidx.annotation.VisibleForTesting; import androidx.cardview.widget.CardView; import androidx.fragment.app.DialogFragment; @@ -172,7 +174,55 @@ public void onCreate(final Bundle savedInstanceState) { .getApplicationContext(), webViewGestureListener); - setStyle(DialogFragment.STYLE_NORMAL, android.R.style.Theme_Translucent_NoTitleBar); + setStyle(DialogFragment.STYLE_NO_FRAME, android.R.style.Theme_Translucent_NoTitleBar); + } + + @Override + public Dialog onCreateDialog(final Bundle savedInstanceState) { + final Activity parentActivity = getActivity(); + final int fragmentTheme = getTheme(); + final Dialog defaultDialog = super.onCreateDialog(savedInstanceState); + + if (parentActivity == null || message == null) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "%s (%s), returning a default Dialog object.", + parentActivity == null ? "Parent Activity" : "Message", + UNEXPECTED_NULL_VALUE); + return defaultDialog; + } + + final MessageSettings messageSettings = message.getMessageSettings(); + if (messageSettings == null) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "%s (MessageSettings), returning a default Dialog object.", + UNEXPECTED_NULL_VALUE); + return defaultDialog; + } + + final boolean uiTakeoverEnabled = messageSettings.getUITakeover(); + return new Dialog(parentActivity, fragmentTheme) { + @Override + public boolean onTouchEvent(@NonNull final MotionEvent motionEvent) { + if (!uiTakeoverEnabled) { + // only log action up or down events as this logging can get quite spammy + if (motionEvent.getAction() == MotionEvent.ACTION_DOWN + || motionEvent.getAction() == MotionEvent.ACTION_UP) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "UI takeover is false, passing the %s event to the parent" + + " activity.", + MotionEvent.actionToString(motionEvent.getAction())); + } + parentActivity.dispatchTouchEvent(motionEvent); + } + return super.onTouchEvent(motionEvent); + } + }; } @Override @@ -234,13 +284,14 @@ public void onDetach() { @Override public boolean onTouch(final View view, final MotionEvent motionEvent) { + final String viewName = view.getClass().getSimpleName(); if (message == null) { Log.debug( ServiceConstants.LOG_TAG, TAG, "%s (AEPMessage), unable to handle the touch event on %s.", UNEXPECTED_NULL_VALUE, - view.getClass().getSimpleName()); + viewName); return true; } @@ -251,7 +302,7 @@ public boolean onTouch(final View view, final MotionEvent motionEvent) { TAG, "%s (WebView), unable to handle the touch event on %s.", UNEXPECTED_NULL_VALUE, - view.getClass().getSimpleName()); + viewName); return true; } @@ -266,36 +317,6 @@ public boolean onTouch(final View view, final MotionEvent motionEvent) { return true; } - final int motionEventAction = motionEvent.getAction(); - - // determine if the tap occurred outside the webview - if ((motionEventAction == MotionEvent.ACTION_DOWN - || motionEventAction == MotionEvent.ACTION_BUTTON_PRESS) - && view.getId() != webView.getId()) { - Log.trace( - ServiceConstants.LOG_TAG, - TAG, - "Detected tap on %s", - view.getClass().getSimpleName()); - - final boolean uiTakeoverEnabled = messageSettings.getUITakeover(); - - // if ui takeover is false, dismiss the message - if (!uiTakeoverEnabled) { - Log.trace( - ServiceConstants.LOG_TAG, - TAG, - "UI takeover is false, dismissing the message."); - webViewGestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); - // perform the tap to allow interaction with ui elements outside the webview - return view.onTouchEvent(motionEvent); - } - - // ui takeover is true, consume the tap and ignore it - Log.trace(ServiceConstants.LOG_TAG, TAG, "UI takeover is true, ignoring the tap."); - return true; - } - // determine if the tapped view is the webview if (view.getId() == webView.getId()) { // if we have no gestures just pass the touch event to the webview @@ -343,10 +364,6 @@ private void addListeners() { final Dialog dialog = getDialog(); if (dialog != null) { - // set this fragment onTouchListener to dismiss the IAM if a touch occurs on the decor - // view - dialog.getWindow().getDecorView().setOnTouchListener(this); - // handle on back pressed to dismiss the message dialog.setOnKeyListener( (dialogInterface, keyCode, event) -> { @@ -368,7 +385,6 @@ private void removeListeners() { final Dialog dialog = getDialog(); if (dialog != null) { - dialog.getWindow().getDecorView().setOnTouchListener(null); dialog.setOnKeyListener(null); } } @@ -395,6 +411,16 @@ private void applyBackdropColor() { return; } + final boolean uiTakeoverEnabled = messageSettings.getUITakeover(); + // we don't want to dim the background if ui takeover is disabled + if (!uiTakeoverEnabled) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "Not applying background alpha, ui takeover is disabled."); + return; + } + final Dialog dialog = getDialog(); if (dialog != null) { diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java index 6cdce77a8..4d1f9e58e 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java @@ -19,7 +19,6 @@ import androidx.cardview.widget.CardView; import com.adobe.marketing.mobile.services.Log; import com.adobe.marketing.mobile.services.ServiceConstants; -import com.adobe.marketing.mobile.services.ui.MessageSettings.MessageAnimation; import com.adobe.marketing.mobile.services.ui.MessageSettings.MessageGesture; import com.adobe.marketing.mobile.util.StringUtils; @@ -116,22 +115,12 @@ public boolean onFling( /** * Generates a dismiss animation using the {@link ObjectAnimator}. The {@link * androidx.cardview.widget.CardView} frame will be dismissed at the direction of the detected - * swipe {@link MessageGesture}. If the in-app message was dismissed via a {@code - * MessageGesture.BACKGROUND_TAP} then the {@code CardView} will be dismissed using the - * dismissal {@link MessageAnimation} specified in the {@link MessageSettings}. + * swipe {@link MessageGesture}. * * @param gesture The detected swipe {@code MessageGesture} that occurred. */ public void handleGesture(final MessageGesture gesture) { - if (gesture.equals(MessageSettings.MessageGesture.BACKGROUND_TAP)) { - // we are handling a background tap. message will be dismissed via the dismiss animation - // specified in the MessageSettings. - dismissMessage(gesture, false); - return; - } - final AEPMessage message = parentFragment.getAEPMessage(); - if (message == null) { Log.debug( ServiceConstants.LOG_TAG, diff --git a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/MessageFragmentTests.java b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/MessageFragmentTests.java index bd6f71f0d..b8bdbaff6 100644 --- a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/MessageFragmentTests.java +++ b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/MessageFragmentTests.java @@ -148,47 +148,4 @@ public void testOnTouchListener_MessageIsNull_ThenTouchEventIsIgnored() { ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); Assert.assertTrue(eventProcessed); } - - @Test - public void - testOnTouchListener_TouchOccurredOutsideWebview_And_UITakeoverFalse_ThenMessageDismissed() { - // setup - messageFragment.webViewGestureListener = mockWebViewGestureListener; - messageFragment.gestureDetector = mockGestureDetector; - Mockito.when(mockAEPMessageSettings.getUITakeover()).thenReturn(false); - Mockito.when(mockWebView.getId()).thenReturn(12345); - Mockito.when(mockViewGroup.getId()).thenReturn(67890); - Mockito.when(mockAEPMessage.getWebView()).thenReturn(mockWebView); - // call onCreate to setup the gestures - messageFragment.onCreate(mockSavedInstanceState); - // test - boolean eventProcessed = messageFragment.onTouch(mockViewGroup, mockMotionEvent); - // verify - Mockito.verify(mockFullscreenMessageDelegate, Mockito.times(1)) - .overrideUrlLoad( - ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); - // expect false because the touch event was handled by the rootview - Assert.assertFalse(eventProcessed); - } - - @Test - public void - testOnTouchListener_TouchOccurredOutsideWebview_And_UITakeoverTrue_ThenMessageNotDismissed() { - // setup - messageFragment.webViewGestureListener = mockWebViewGestureListener; - messageFragment.gestureDetector = mockGestureDetector; - Mockito.when(mockAEPMessageSettings.getUITakeover()).thenReturn(true); - Mockito.when(mockWebView.getId()).thenReturn(12345); - Mockito.when(mockViewGroup.getId()).thenReturn(67890); - Mockito.when(mockAEPMessage.getWebView()).thenReturn(mockWebView); - // call onCreate to setup the gestures - messageFragment.onCreate(mockSavedInstanceState); - // test - boolean eventProcessed = messageFragment.onTouch(mockViewGroup, mockMotionEvent); - // verify - Mockito.verify(mockFullscreenMessageDelegate, Mockito.times(0)) - .overrideUrlLoad( - ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); - Assert.assertTrue(eventProcessed); - } } diff --git a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java index 856e29c37..fbd13f0e2 100644 --- a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java +++ b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java @@ -246,20 +246,4 @@ public void testOnFling_VerticalSwipeDown_And_FlingVelocityOverThreshold_Then_Me .overrideUrlLoad( ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); } - - @Test - public void testHandleGesture_BackgroundTap_Then_MessageDismissed() { - // setup - Mockito.when(mockMotionEvent.getX()).thenReturn(0f); - Mockito.when(mockMotionEvent2.getX()).thenReturn(0f); - Mockito.when(mockMotionEvent.getY()).thenReturn(0f); - Mockito.when(mockMotionEvent2.getY()).thenReturn(-300.0f); - // test - gestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); - // verify - Assert.assertFalse(mockMessageFragment.isDismissedWithGesture()); - Mockito.verify(mockFullscreenMessageDelegate, Mockito.times(1)) - .overrideUrlLoad( - ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); - } } From c3ae4ec68b6ef83ebd4ff32b8856c4ca4a398d71 Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Mon, 13 Nov 2023 17:29:24 -0800 Subject: [PATCH 2/6] fix MessageGesture enum, fix background tap behavior - fix the background tap MessageGesture value - if a gesture is defined for background taps, load the defined behavior url string using the FullscreenMessageDelegate#overrideUrlLoad. --- .../mobile/services/ui/MessageSettings.java | 2 +- .../mobile/services/ui/MessageFragment.java | 12 +++++-- .../services/ui/WebViewGestureListener.java | 19 ++++++++-- .../ui/WebViewGestureListenerTests.java | 36 +++++++++++++++++++ 4 files changed, 63 insertions(+), 6 deletions(-) diff --git a/code/core/src/main/java/com/adobe/marketing/mobile/services/ui/MessageSettings.java b/code/core/src/main/java/com/adobe/marketing/mobile/services/ui/MessageSettings.java index 410b9d28c..4103875d3 100644 --- a/code/core/src/main/java/com/adobe/marketing/mobile/services/ui/MessageSettings.java +++ b/code/core/src/main/java/com/adobe/marketing/mobile/services/ui/MessageSettings.java @@ -65,7 +65,7 @@ public enum MessageGesture { SWIPE_DOWN("swipeDown"), SWIPE_LEFT("swipeLeft"), SWIPE_RIGHT("swipeRight"), - BACKGROUND_TAP("backgroundTap"); + BACKGROUND_TAP("tapBackground"); private String name; private static final Map gestureStringToGestureEnumMap; diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java index d879f95a2..ad7a4feaf 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java @@ -208,7 +208,8 @@ public Dialog onCreateDialog(final Bundle savedInstanceState) { @Override public boolean onTouchEvent(@NonNull final MotionEvent motionEvent) { if (!uiTakeoverEnabled) { - // only log action up or down events as this logging can get quite spammy + // only log action up or down events as this logging can get quite + // spammy if (motionEvent.getAction() == MotionEvent.ACTION_DOWN || motionEvent.getAction() == MotionEvent.ACTION_UP) { Log.trace( @@ -219,8 +220,15 @@ public boolean onTouchEvent(@NonNull final MotionEvent motionEvent) { MotionEvent.actionToString(motionEvent.getAction())); } parentActivity.dispatchTouchEvent(motionEvent); + return false; } - return super.onTouchEvent(motionEvent); + + // load any behavior url strings on action up only as a touch consists of + // two motion events: an action down and an action up event + if (motionEvent.getAction() == MotionEvent.ACTION_UP) { + webViewGestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); + } + return false; } }; } diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java index 4d1f9e58e..94d37c765 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java @@ -113,9 +113,10 @@ public boolean onFling( } /** - * Generates a dismiss animation using the {@link ObjectAnimator}. The {@link + * Generates a dismiss animation if needed using the {@link ObjectAnimator}. The {@link * androidx.cardview.widget.CardView} frame will be dismissed at the direction of the detected - * swipe {@link MessageGesture}. + * swipe {@link MessageGesture}. Background tap gestures will not dismiss the message but any + * associated behavior will be * * @param gesture The detected swipe {@code MessageGesture} that occurred. */ @@ -152,7 +153,19 @@ public void handleGesture(final MessageGesture gesture) { webViewFrame.getTop(), -message.parentViewHeight); break; - default: // default, dismiss to bottom if not a background tap + case BACKGROUND_TAP: + animation = null; + // we are handling a background tap. handle the background tap interaction event + // specified (if any). + final String behavior = + parentFragment.gestures == null + ? null + : parentFragment.gestures.get(gesture); + if (!StringUtils.isNullOrEmpty(behavior)) { + message.listener.overrideUrlLoad(message, behavior); + } + break; + default: // default, dismiss to bottom animation = ObjectAnimator.ofFloat( webViewFrame, "y", webViewFrame.getTop(), message.parentViewHeight); diff --git a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java index fbd13f0e2..6e9a52030 100644 --- a/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java +++ b/code/core/src/test/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListenerTests.java @@ -246,4 +246,40 @@ public void testOnFling_VerticalSwipeDown_And_FlingVelocityOverThreshold_Then_Me .overrideUrlLoad( ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); } + + @Test + public void + testHandleGesture_BackgroundTap_BackgroundTapBehaviorDefined_Then_MessageDismissed() { + // setup + Mockito.when(mockMotionEvent.getX()).thenReturn(0f); + Mockito.when(mockMotionEvent2.getX()).thenReturn(0f); + Mockito.when(mockMotionEvent.getY()).thenReturn(0f); + Mockito.when(mockMotionEvent2.getY()).thenReturn(-300.0f); + // test + gestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); + // verify + Assert.assertFalse(mockMessageFragment.isDismissedWithGesture()); + Mockito.verify(mockFullscreenMessageDelegate, Mockito.times(1)) + .overrideUrlLoad( + ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); + } + + @Test + public void + testHandleGesture_BackgroundTap_BackgroundTapBehaviorNotDefined_Then_MessageNotDismissed() { + // setup + gestureMap.remove(MessageGesture.BACKGROUND_TAP); + mockMessageFragment.gestures = gestureMap; + Mockito.when(mockMotionEvent.getX()).thenReturn(0f); + Mockito.when(mockMotionEvent2.getX()).thenReturn(0f); + Mockito.when(mockMotionEvent.getY()).thenReturn(0f); + Mockito.when(mockMotionEvent2.getY()).thenReturn(-300.0f); + // test + gestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); + // verify + Assert.assertFalse(mockMessageFragment.isDismissedWithGesture()); + Mockito.verify(mockFullscreenMessageDelegate, Mockito.times(0)) + .overrideUrlLoad( + ArgumentMatchers.any(AEPMessage.class), ArgumentMatchers.anyString()); + } } From c056a34e2da4b11b16c5f5550f48896eeb525241 Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Tue, 14 Nov 2023 08:34:43 -0800 Subject: [PATCH 3/6] clarify comments regarding iam background tap behavior --- .../adobe/marketing/mobile/services/ui/MessageFragment.java | 2 +- .../marketing/mobile/services/ui/WebViewGestureListener.java | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java index ad7a4feaf..14717dc61 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java @@ -321,7 +321,7 @@ public boolean onTouch(final View view, final MotionEvent motionEvent) { TAG, "%s (MessageSettings), unable to handle the touch event on %s.", UNEXPECTED_NULL_VALUE, - view.getClass().getSimpleName()); + viewName); return true; } diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java index 94d37c765..ad74350f2 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/WebViewGestureListener.java @@ -155,8 +155,10 @@ public void handleGesture(final MessageGesture gesture) { break; case BACKGROUND_TAP: animation = null; - // we are handling a background tap. handle the background tap interaction event + // we are handling a background tap. handle the background tap interaction behavior // specified (if any). + // if we have no defined background tap behavior then we do not want to dismiss the + // message. final String behavior = parentFragment.gestures == null ? null From 503d73a49a453c4bbf858f422a712f32f30d5159 Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Tue, 14 Nov 2023 09:21:53 -0800 Subject: [PATCH 4/6] add log message regarding a background tap occurring when uitakeover is true --- .../adobe/marketing/mobile/services/ui/MessageFragment.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java index 14717dc61..997751f6e 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java @@ -226,6 +226,11 @@ public boolean onTouchEvent(@NonNull final MotionEvent motionEvent) { // load any behavior url strings on action up only as a touch consists of // two motion events: an action down and an action up event if (motionEvent.getAction() == MotionEvent.ACTION_UP) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "UI takeover is true, parent activity UI is inaccessible. Processing" + + " defined background tap behaviors."); webViewGestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); } return false; From e1043d6484139a9b59b221b0ee133366ec21d2c8 Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Tue, 14 Nov 2023 11:28:46 -0800 Subject: [PATCH 5/6] Update core.api --- code/core/api/core.api | 1 + 1 file changed, 1 insertion(+) diff --git a/code/core/api/core.api b/code/core/api/core.api index 5ab422d6d..1067b479b 100644 --- a/code/core/api/core.api +++ b/code/core/api/core.api @@ -910,6 +910,7 @@ public class com/adobe/marketing/mobile/services/ui/MessageFragment : android/ap public fun onActivityCreated (Landroid/os/Bundle;)V public fun onAttach (Landroid/content/Context;)V public fun onCreate (Landroid/os/Bundle;)V + public fun onCreateDialog (Landroid/os/Bundle;)Landroid/app/Dialog; public fun onDestroyView ()V public fun onDetach ()V public fun onTouch (Landroid/view/View;Landroid/view/MotionEvent;)Z From 4e9c1e5a8edb150a8ef0ef42b73d9b34f14e230d Mon Sep 17 00:00:00 2001 From: Ryan Morales Date: Tue, 14 Nov 2023 13:48:14 -0800 Subject: [PATCH 6/6] fix dialog on touch event logic --- .../mobile/services/ui/MessageFragment.java | 36 +++++++++---------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java index 997751f6e..9ead536af 100644 --- a/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java +++ b/code/core/src/phone/java/com/adobe/marketing/mobile/services/ui/MessageFragment.java @@ -210,30 +210,28 @@ public boolean onTouchEvent(@NonNull final MotionEvent motionEvent) { if (!uiTakeoverEnabled) { // only log action up or down events as this logging can get quite // spammy - if (motionEvent.getAction() == MotionEvent.ACTION_DOWN - || motionEvent.getAction() == MotionEvent.ACTION_UP) { + if (motionEvent.getAction() == MotionEvent.ACTION_UP) { Log.trace( ServiceConstants.LOG_TAG, TAG, - "UI takeover is false, passing the %s event to the parent" - + " activity.", - MotionEvent.actionToString(motionEvent.getAction())); + "UI takeover is false, passing the touch event to the parent" + + " activity."); + } + return parentActivity.dispatchTouchEvent(motionEvent); + } else { + // load any behavior url strings on action up only as a touch consists of + // two motion events: an action down and an action up event + if (motionEvent.getAction() == MotionEvent.ACTION_UP) { + Log.trace( + ServiceConstants.LOG_TAG, + TAG, + "UI takeover is true, parent activity UI is inaccessible." + + " Processing defined background tap behaviors."); + webViewGestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); + return true; } - parentActivity.dispatchTouchEvent(motionEvent); - return false; - } - - // load any behavior url strings on action up only as a touch consists of - // two motion events: an action down and an action up event - if (motionEvent.getAction() == MotionEvent.ACTION_UP) { - Log.trace( - ServiceConstants.LOG_TAG, - TAG, - "UI takeover is true, parent activity UI is inaccessible. Processing" - + " defined background tap behaviors."); - webViewGestureListener.handleGesture(MessageGesture.BACKGROUND_TAP); } - return false; + return super.onTouchEvent(motionEvent); } }; }