diff --git a/res/xml/language_and_region_settings.xml b/res/xml/language_and_region_settings.xml
index d631748fab8..1d59532d3e2 100644
--- a/res/xml/language_and_region_settings.xml
+++ b/res/xml/language_and_region_settings.xml
@@ -44,6 +44,12 @@
android:name="classname"
android:value="com.android.settings.applications.appinfo.AppLocaleDetails" />
+
supportedLanguageList = Arrays.asList(
+ mContext.getResources().getStringArray(
+ R.array.terms_of_address_supported_languages));
+ final List notSupportedLocaleList = Arrays.asList(
+ mContext.getResources().getStringArray(
+ R.array.terms_of_address_unsupported_locales));
+
+ final Locale locale = localeInfo.getLocale().stripExtensions();
+ final String language = locale.getLanguage();
+ final String localeTag = locale.toLanguageTag();
+
+ // Supported locales:
+ // 1. All French is supported except fr-CA.
+ // 2. QA language en-XA (LTR pseudo locale), ar_XB (RTL pseudo locale).
+ if ((supportedLanguageList.contains(language)
+ && !notSupportedLocaleList.contains(localeTag))
+ || LocaleList.isPseudoLocale(locale)) {
+ return AVAILABLE;
+ }
+
+ return CONDITIONALLY_UNAVAILABLE;
+ }
+}
diff --git a/src/com/android/settings/localepicker/TermsOfAddressCategoryController.java b/src/com/android/settings/localepicker/TermsOfAddressCategoryController.java
index 01168c7ff7b..1e2fbef7e83 100644
--- a/src/com/android/settings/localepicker/TermsOfAddressCategoryController.java
+++ b/src/com/android/settings/localepicker/TermsOfAddressCategoryController.java
@@ -20,7 +20,6 @@ import static com.android.settings.flags.Flags.termsOfAddressEnabled;
import android.content.Context;
import android.os.LocaleList;
-import android.text.TextUtils;
import android.util.Log;
import androidx.preference.PreferenceCategory;
@@ -28,6 +27,7 @@ import androidx.preference.PreferenceScreen;
import com.android.internal.app.LocaleStore;
import com.android.settings.R;
+import com.android.settings.flags.Flags;
import com.android.settings.widget.PreferenceCategoryController;
import java.util.Arrays;
@@ -64,6 +64,9 @@ public class TermsOfAddressCategoryController extends PreferenceCategoryControll
@Override
public int getAvailabilityStatus() {
+ if (Flags.regionalPreferencesApiEnabled()) {
+ return CONDITIONALLY_UNAVAILABLE;
+ }
if (!termsOfAddressEnabled()) {
return CONDITIONALLY_UNAVAILABLE;
diff --git a/tests/unit/src/com/android/settings/localepicker/TermsOfAddressCategoryControllerTest.java b/tests/unit/src/com/android/settings/localepicker/TermsOfAddressCategoryControllerTest.java
index b025abdf06a..4728c4541ef 100644
--- a/tests/unit/src/com/android/settings/localepicker/TermsOfAddressCategoryControllerTest.java
+++ b/tests/unit/src/com/android/settings/localepicker/TermsOfAddressCategoryControllerTest.java
@@ -24,12 +24,17 @@ import static org.mockito.Mockito.spy;
import android.content.Context;
import android.os.Looper;
+import android.platform.test.annotations.DisableFlags;
+import android.platform.test.flag.junit.SetFlagsRule;
import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4;
+import com.android.settings.flags.Flags;
+
import org.junit.After;
import org.junit.Before;
+import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
@@ -45,6 +50,8 @@ public class TermsOfAddressCategoryControllerTest {
private TermsOfAddressCategoryController mTermsOfAddressCategoryController;
private Locale mCacheLocale;
+ @Rule public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
+
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
@@ -65,6 +72,7 @@ public class TermsOfAddressCategoryControllerTest {
}
@Test
+ @DisableFlags(Flags.FLAG_REGIONAL_PREFERENCES_API_ENABLED)
public void getAvailabilityStatus_returnAvailable() {
Locale.setDefault(Locale.forLanguageTag("fr-FR"));