diff --git a/res/drawable-hdpi/ic_menu_3d_globe.png b/res/drawable-hdpi/ic_menu_3d_globe.png
deleted file mode 100644
index 1b55f0913fc..00000000000
Binary files a/res/drawable-hdpi/ic_menu_3d_globe.png and /dev/null differ
diff --git a/res/drawable-mdpi/ic_menu_3d_globe.png b/res/drawable-mdpi/ic_menu_3d_globe.png
deleted file mode 100644
index 6755d5e6f2d..00000000000
Binary files a/res/drawable-mdpi/ic_menu_3d_globe.png and /dev/null differ
diff --git a/res/drawable-xhdpi/ic_menu_3d_globe.png b/res/drawable-xhdpi/ic_menu_3d_globe.png
deleted file mode 100644
index 1fda0a26bf0..00000000000
Binary files a/res/drawable-xhdpi/ic_menu_3d_globe.png and /dev/null differ
diff --git a/res/values/strings.xml b/res/values/strings.xml
index 67c564ed98e..3830f89f492 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -762,16 +762,8 @@
Search region
Region
-
- Time Zone
-
- Time zones in %1$s
Select UTC offset
-
- Sort alphabetically
-
- Sort by time zone
%1$s starts on %2$s.
diff --git a/res/xml/date_time_prefs.xml b/res/xml/date_time_prefs.xml
index 511b39fea48..edda1ba66d9 100644
--- a/res/xml/date_time_prefs.xml
+++ b/res/xml/date_time_prefs.xml
@@ -56,7 +56,7 @@
settings:userRestriction="no_config_date_time" />
> sortedList = ZoneGetter.getZonesList(context);
- Collections.sort(sortedList, comparator);
- final SimpleAdapter adapter = new SimpleAdapter(context,
- sortedList,
- layoutId,
- from,
- to);
- adapter.setViewBinder(new TimeZoneViewBinder());
- return adapter;
- }
-
- private static class TimeZoneViewBinder implements SimpleAdapter.ViewBinder {
-
- /**
- * Set the text to the given {@link CharSequence} as is, instead of calling toString, so
- * that additional information stored in the CharSequence is, like spans added to a
- * {@link android.text.SpannableString} are preserved.
- */
- @Override
- public boolean setViewValue(View view, Object data, String textRepresentation) {
- TextView textView = (TextView) view;
- textView.setText((CharSequence) data);
- return true;
- }
- }
-
- /**
- * Searches {@link TimeZone} from the given {@link SimpleAdapter} object, and returns
- * the index for the TimeZone.
- *
- * @param adapter SimpleAdapter constructed by
- * {@link #constructTimezoneAdapter(Context, boolean)}.
- * @param tz TimeZone to be searched.
- * @return Index for the given TimeZone. -1 when there's no corresponding list item.
- * returned.
- */
- public static int getTimeZoneIndex(SimpleAdapter adapter, TimeZone tz) {
- final String defaultId = tz.getID();
- final int listSize = adapter.getCount();
- for (int i = 0; i < listSize; i++) {
- // Using HashMap induces unnecessary warning.
- final HashMap,?> map = (HashMap,?>)adapter.getItem(i);
- final String id = (String)map.get(ZoneGetter.KEY_ID);
- if (defaultId.equals(id)) {
- // If current timezone is in this list, move focus to it
- return i;
- }
- }
- return -1;
- }
-
- @Override
- public int getMetricsCategory() {
- return MetricsProto.MetricsEvent.ZONE_PICKER;
- }
-
- @Override
- public void onActivityCreated(Bundle savedInstanceState) {
- super.onActivityCreated(savedInstanceState);
-
- final Activity activity = getActivity();
- mTimezoneSortedAdapter = constructTimezoneAdapter(activity, false);
- mAlphabeticalAdapter = constructTimezoneAdapter(activity, true);
-
- // Sets the adapter
- setSorting(true);
- setHasOptionsMenu(true);
- activity.setTitle(R.string.date_time_set_timezone);
- }
-
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- mVisibilityLoggerMixin = new VisibilityLoggerMixin(getMetricsCategory(),
- FeatureFactory.getFactory(getContext()).getMetricsFeatureProvider());
- }
-
- @Override
- public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- final View view = super.onCreateView(inflater, container, savedInstanceState);
- final ListView list = view.findViewById(android.R.id.list);
- prepareCustomPreferencesList(list);
- return view;
- }
-
- @Override
- public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
- menu.add(0, MENU_ALPHABETICAL, 0, R.string.zone_list_menu_sort_alphabetically)
- .setIcon(android.R.drawable.ic_menu_sort_alphabetically);
- menu.add(0, MENU_TIMEZONE, 0, R.string.zone_list_menu_sort_by_timezone)
- .setIcon(R.drawable.ic_menu_3d_globe);
- super.onCreateOptionsMenu(menu, inflater);
- }
-
- @Override
- public void onPrepareOptionsMenu(Menu menu) {
- if (mSortedByTimezone) {
- menu.findItem(MENU_TIMEZONE).setVisible(false);
- menu.findItem(MENU_ALPHABETICAL).setVisible(true);
- } else {
- menu.findItem(MENU_TIMEZONE).setVisible(true);
- menu.findItem(MENU_ALPHABETICAL).setVisible(false);
- }
- }
-
- @Override
- public void onResume() {
- super.onResume();
- mVisibilityLoggerMixin.onResume();
- }
-
- @Override
- public boolean onOptionsItemSelected(MenuItem item) {
- switch (item.getItemId()) {
-
- case MENU_TIMEZONE:
- setSorting(true);
- return true;
-
- case MENU_ALPHABETICAL:
- setSorting(false);
- return true;
-
- default:
- return false;
- }
- }
-
- static void prepareCustomPreferencesList(ListView list) {
- list.setScrollBarStyle(View.SCROLLBARS_OUTSIDE_OVERLAY);
- list.setClipToPadding(false);
- list.setDivider(null);
- }
-
- private void setSorting(boolean sortByTimezone) {
- final SimpleAdapter adapter =
- sortByTimezone ? mTimezoneSortedAdapter : mAlphabeticalAdapter;
- setListAdapter(adapter);
- mSortedByTimezone = sortByTimezone;
- final int defaultIndex = getTimeZoneIndex(adapter, TimeZone.getDefault());
- if (defaultIndex >= 0) {
- setSelection(defaultIndex);
- }
- }
-
- @Override
- public void onListItemClick(ListView listView, View v, int position, long id) {
- // Ignore extra clicks
- if (!isResumed()) return;
- final Map, ?> map = (Map, ?>)listView.getItemAtPosition(position);
- final String tzId = (String) map.get(ZoneGetter.KEY_ID);
-
- // Update the system timezone value
- final Activity activity = getActivity();
- final AlarmManager alarm = (AlarmManager) activity.getSystemService(Context.ALARM_SERVICE);
- alarm.setTimeZone(tzId);
-
- getActivity().onBackPressed();
-
- }
-
- @Override
- public void onPause() {
- super.onPause();
- mVisibilityLoggerMixin.onPause();
- }
-
- @VisibleForTesting
- static class MyComparator implements Comparator