From 5b825a1339ebf3bdb2609bcaf24eaeee88034835 Mon Sep 17 00:00:00 2001 From: deeppandya Date: Thu, 12 Dec 2024 12:16:47 -0500 Subject: [PATCH 1/3] Add feature flag for new onboarding --- android/java/org/chromium/base/BraveFeatureList.java | 1 + browser/brave_browser_features.cc | 5 +++++ browser/brave_browser_features.h | 1 + 3 files changed, 7 insertions(+) diff --git a/android/java/org/chromium/base/BraveFeatureList.java b/android/java/org/chromium/base/BraveFeatureList.java index 69e4e9aebedb..5667c4c1fecf 100644 --- a/android/java/org/chromium/base/BraveFeatureList.java +++ b/android/java/org/chromium/base/BraveFeatureList.java @@ -33,6 +33,7 @@ public abstract class BraveFeatureList { public static final String BRAVE_SHOW_STRICT_FINGERPRINTING_MODE = "BraveShowStrictFingerprintingMode"; public static final String BRAVE_DAY_ZERO_EXPERIMENT = "BraveDayZeroExperiment"; + public static final String BRAVE_NEW_ANDROID_ONBOARDING = "NewAndroidOnboarding"; public static final String BRAVE_FALLBACK_DOH_PROVIDER = "BraveFallbackDoHProvider"; public static final String BRAVE_BLOCK_ALL_COOKIES_TOGGLE = "BlockAllCookiesToggle"; public static final String BRAVE_SHIELDS_ELEMENT_PICKER = "BraveShieldsElementPicker"; diff --git a/browser/brave_browser_features.cc b/browser/brave_browser_features.cc index 6bf68d23a30b..25f58316c6c5 100644 --- a/browser/brave_browser_features.cc +++ b/browser/brave_browser_features.cc @@ -46,6 +46,11 @@ BASE_FEATURE(kBraveDayZeroExperiment, "BraveDayZeroExperiment", base::FEATURE_DISABLED_BY_DEFAULT); +// Enable new onabording on android +BASE_FEATURE(kNewAndroidOnboarding, + "NewAndroidOnboarding", + base::FEATURE_DISABLED_BY_DEFAULT); + // The variant of the "day zero" experiment. i.e. A, B, C, D, etc. const base::FeatureParam kBraveDayZeroExperimentVariant{ &kBraveDayZeroExperiment, diff --git a/browser/brave_browser_features.h b/browser/brave_browser_features.h index eb582810c206..efe7b1525e33 100644 --- a/browser/brave_browser_features.h +++ b/browser/brave_browser_features.h @@ -19,6 +19,7 @@ BASE_DECLARE_FEATURE(kBraveCopyCleanLinkFromJs); BASE_DECLARE_FEATURE(kBraveOverrideDownloadDangerLevel); BASE_DECLARE_FEATURE(kBraveWebViewRoundedCorners); BASE_DECLARE_FEATURE(kBraveDayZeroExperiment); +BASE_DECLARE_FEATURE(kNewAndroidOnboarding); extern const base::FeatureParam kBraveDayZeroExperimentVariant; From ecfbbb979ae6e0ba14ea64cdb224957111c4e136 Mon Sep 17 00:00:00 2001 From: deeppandya Date: Thu, 12 Dec 2024 14:35:15 -0500 Subject: [PATCH 2/3] Removing dayzero changes and update onboarding with new flag --- .../firstrun/WelcomeOnboardingActivity.java | 14 +++++++++----- browser/brave_browser_features.cc | 2 +- .../browser/flags/android/chrome_feature_list.cc | 4 +++- 3 files changed, 13 insertions(+), 7 deletions(-) diff --git a/android/java/org/chromium/chrome/browser/firstrun/WelcomeOnboardingActivity.java b/android/java/org/chromium/chrome/browser/firstrun/WelcomeOnboardingActivity.java index 54e4526e0c40..91f8c3b761f5 100644 --- a/android/java/org/chromium/chrome/browser/firstrun/WelcomeOnboardingActivity.java +++ b/android/java/org/chromium/chrome/browser/firstrun/WelcomeOnboardingActivity.java @@ -35,6 +35,7 @@ import com.android.installreferrer.api.InstallReferrerStateListener; import com.android.installreferrer.api.ReferrerDetails; +import org.chromium.base.BraveFeatureList; import org.chromium.base.BravePreferenceKeys; import org.chromium.base.Log; import org.chromium.base.ThreadUtils; @@ -42,7 +43,7 @@ import org.chromium.chrome.browser.BraveLocalState; import org.chromium.chrome.browser.back_press.SecondaryActivityBackPressUma.SecondaryActivity; import org.chromium.chrome.browser.customtabs.CustomTabActivity; -import org.chromium.chrome.browser.day_zero.DayZeroHelper; +import org.chromium.chrome.browser.flags.ChromeFeatureList; import org.chromium.chrome.browser.metrics.ChangeMetricsReportingStateCalledFrom; import org.chromium.chrome.browser.metrics.UmaSessionStats; import org.chromium.chrome.browser.onboarding.OnboardingPrefManager; @@ -231,7 +232,11 @@ private void onClickViews() { } private boolean shouldForceDefaultBrowserPrompt() { - return !DayZeroHelper.getDayZeroExptFlag() && !isDefaultBrowser(); + return isNewOnboardingEnabled() && !isDefaultBrowser(); + } + + private boolean isNewOnboardingEnabled() { + return ChromeFeatureList.isEnabled(BraveFeatureList.BRAVE_NEW_ANDROID_ONBOARDING); } private void setDefaultBrowserAndProceedToNextStep() { @@ -260,7 +265,7 @@ private void nextOnboardingStep() { if (mCurrentStep == 0) { showIntroPage(); } else if (mCurrentStep == 1) { - if (DayZeroHelper.getDayZeroExptFlag() + if (!isNewOnboardingEnabled() || !BraveSetDefaultBrowserUtils.supportsDefaultRoleManager()) { showBrowserSelectionPage(); } else if (!isDefaultBrowser()) { @@ -317,8 +322,7 @@ public void run() { }, 200); - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU - && DayZeroHelper.getDayZeroExptFlag()) { + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU && !isNewOnboardingEnabled()) { mRequestPermissionLauncher.launch(Manifest.permission.POST_NOTIFICATIONS); } else { startTimer(3000); diff --git a/browser/brave_browser_features.cc b/browser/brave_browser_features.cc index 25f58316c6c5..41ca71a5fdbd 100644 --- a/browser/brave_browser_features.cc +++ b/browser/brave_browser_features.cc @@ -46,7 +46,7 @@ BASE_FEATURE(kBraveDayZeroExperiment, "BraveDayZeroExperiment", base::FEATURE_DISABLED_BY_DEFAULT); -// Enable new onabording on android +// Enable new onboarding on Android BASE_FEATURE(kNewAndroidOnboarding, "NewAndroidOnboarding", base::FEATURE_DISABLED_BY_DEFAULT); diff --git a/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc b/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc index 09b2d9be3680..ff791611da13 100644 --- a/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc +++ b/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc @@ -6,6 +6,7 @@ #include "base/feature_override.h" #include "brave/browser/android/background_video/features.h" #include "brave/browser/android/safe_browsing/features.h" +#include "brave/browser/brave_browser_features.h" #include "brave/components/ai_chat/core/common/features.h" #include "brave/components/brave_news/common/features.h" #include "brave/components/brave_rewards/common/features.h" @@ -46,7 +47,8 @@ &brave_shields::features::kBraveShowStrictFingerprintingMode, \ &brave_shields::features::kBraveLocalhostAccessPermission, \ &brave_shields::features::kBlockAllCookiesToggle, \ - &brave_shields::features::kBraveShieldsElementPicker + &brave_shields::features::kBraveShieldsElementPicker, \ + &features::kNewAndroidOnboarding, // clang-format on From 333abe02304b8d5adf42d849d660d08315eaccdb Mon Sep 17 00:00:00 2001 From: deeppandya Date: Tue, 17 Dec 2024 10:57:54 -0700 Subject: [PATCH 3/3] Add android exception --- browser/brave_browser_features.cc | 2 ++ browser/brave_browser_features.h | 2 ++ .../chrome/browser/flags/android/chrome_feature_list.cc | 2 +- 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/browser/brave_browser_features.cc b/browser/brave_browser_features.cc index 41ca71a5fdbd..85c244faad08 100644 --- a/browser/brave_browser_features.cc +++ b/browser/brave_browser_features.cc @@ -46,10 +46,12 @@ BASE_FEATURE(kBraveDayZeroExperiment, "BraveDayZeroExperiment", base::FEATURE_DISABLED_BY_DEFAULT); +#if BUILDFLAG(IS_ANDROID) // Enable new onboarding on Android BASE_FEATURE(kNewAndroidOnboarding, "NewAndroidOnboarding", base::FEATURE_DISABLED_BY_DEFAULT); +#endif // BUILDFLAG(IS_ANDROID) // The variant of the "day zero" experiment. i.e. A, B, C, D, etc. const base::FeatureParam kBraveDayZeroExperimentVariant{ diff --git a/browser/brave_browser_features.h b/browser/brave_browser_features.h index efe7b1525e33..ad30895a251e 100644 --- a/browser/brave_browser_features.h +++ b/browser/brave_browser_features.h @@ -19,7 +19,9 @@ BASE_DECLARE_FEATURE(kBraveCopyCleanLinkFromJs); BASE_DECLARE_FEATURE(kBraveOverrideDownloadDangerLevel); BASE_DECLARE_FEATURE(kBraveWebViewRoundedCorners); BASE_DECLARE_FEATURE(kBraveDayZeroExperiment); +#if BUILDFLAG(IS_ANDROID) BASE_DECLARE_FEATURE(kNewAndroidOnboarding); +#endif // BUILDFLAG(IS_ANDROID) extern const base::FeatureParam kBraveDayZeroExperimentVariant; diff --git a/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc b/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc index ff791611da13..8cc98935e6b1 100644 --- a/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc +++ b/chromium_src/chrome/browser/flags/android/chrome_feature_list.cc @@ -48,7 +48,7 @@ &brave_shields::features::kBraveLocalhostAccessPermission, \ &brave_shields::features::kBlockAllCookiesToggle, \ &brave_shields::features::kBraveShieldsElementPicker, \ - &features::kNewAndroidOnboarding, + &features::kNewAndroidOnboarding // clang-format on