SetupWizard: Use SettingsLib for Timezones
* Currently we are storing a copy of timezones.xml ourselves and parsing it manually * Use ZoneGetter from SettingsLib instead to get the list of TimeZones * That way we have less code to maintain and updates to the list are easier as well * Also simplify constructTimezoneAdapter -> we never sort by name Change-Id: Ifd690ed28c6fbecaee895b4063137e86c059e314
This commit is contained in:
committed by
Timi Rautamäki
parent
d23252fbc2
commit
8dc3cf8f47
@@ -1,104 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (C) 2013 The CyanogenMod Project
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
<timezones>
|
|
||||||
<timezone id="Pacific/Majuro">Marshall Islands</timezone>
|
|
||||||
<timezone id="Pacific/Midway">Midway Island</timezone>
|
|
||||||
<timezone id="Pacific/Honolulu">Hawaii</timezone>
|
|
||||||
<timezone id="America/Anchorage">Alaska</timezone>
|
|
||||||
<timezone id="America/Los_Angeles">Pacific Time</timezone>
|
|
||||||
<timezone id="America/Tijuana">Tijuana</timezone>
|
|
||||||
<timezone id="America/Phoenix">Arizona</timezone>
|
|
||||||
<timezone id="America/Chihuahua">Chihuahua</timezone>
|
|
||||||
<timezone id="America/Denver">Mountain Time</timezone>
|
|
||||||
<timezone id="America/Costa_Rica">Central America</timezone>
|
|
||||||
<timezone id="America/Chicago">Central Time</timezone>
|
|
||||||
<timezone id="America/Mexico_City">Mexico City</timezone>
|
|
||||||
<timezone id="America/Regina">Saskatchewan</timezone>
|
|
||||||
<timezone id="America/Bogota">Bogota</timezone>
|
|
||||||
<timezone id="America/New_York">Eastern Time</timezone>
|
|
||||||
<timezone id="America/Caracas">Venezuela</timezone>
|
|
||||||
<timezone id="America/Barbados">Atlantic Time (Barbados)</timezone>
|
|
||||||
<timezone id="America/Halifax">Atlantic Time (Canada)</timezone>
|
|
||||||
<timezone id="America/Manaus">Manaus</timezone>
|
|
||||||
<timezone id="America/Santiago">Santiago</timezone>
|
|
||||||
<timezone id="America/St_Johns">Newfoundland</timezone>
|
|
||||||
<timezone id="America/Sao_Paulo">Brasilia</timezone>
|
|
||||||
<timezone id="America/Argentina/Buenos_Aires">Buenos Aires</timezone>
|
|
||||||
<timezone id="America/Godthab">Greenland</timezone>
|
|
||||||
<timezone id="America/Montevideo">Montevideo</timezone>
|
|
||||||
<timezone id="Atlantic/South_Georgia">Mid-Atlantic</timezone>
|
|
||||||
<timezone id="Atlantic/Azores">Azores</timezone>
|
|
||||||
<timezone id="Atlantic/Cape_Verde">Cape Verde Islands</timezone>
|
|
||||||
<timezone id="Africa/Casablanca">Casablanca</timezone>
|
|
||||||
<timezone id="Europe/London">London, Dublin</timezone>
|
|
||||||
<timezone id="Europe/Amsterdam">Amsterdam, Berlin</timezone>
|
|
||||||
<timezone id="Europe/Belgrade">Belgrade</timezone>
|
|
||||||
<timezone id="Europe/Brussels">Brussels</timezone>
|
|
||||||
<timezone id="Europe/Sarajevo">Sarajevo</timezone>
|
|
||||||
<timezone id="Africa/Windhoek">Windhoek</timezone>
|
|
||||||
<timezone id="Africa/Brazzaville">W. Africa Time</timezone>
|
|
||||||
<timezone id="Asia/Amman">Amman, Jordan</timezone>
|
|
||||||
<timezone id="Europe/Athens">Athens, Istanbul</timezone>
|
|
||||||
<timezone id="Asia/Beirut">Beirut, Lebanon</timezone>
|
|
||||||
<timezone id="Africa/Cairo">Cairo</timezone>
|
|
||||||
<timezone id="Europe/Helsinki">Helsinki</timezone>
|
|
||||||
<timezone id="Asia/Jerusalem">Jerusalem</timezone>
|
|
||||||
<timezone id="Europe/Minsk">Minsk</timezone>
|
|
||||||
<timezone id="Africa/Harare">Harare</timezone>
|
|
||||||
<timezone id="Asia/Baghdad">Baghdad</timezone>
|
|
||||||
<timezone id="Europe/Moscow">Moscow</timezone>
|
|
||||||
<timezone id="Europe/Kiev">Kiev</timezone>
|
|
||||||
<timezone id="Asia/Kuwait">Kuwait</timezone>
|
|
||||||
<timezone id="Africa/Nairobi">Nairobi</timezone>
|
|
||||||
<timezone id="Asia/Tehran">Tehran</timezone>
|
|
||||||
<timezone id="Asia/Baku">Baku</timezone>
|
|
||||||
<timezone id="Asia/Tbilisi">Tbilisi</timezone>
|
|
||||||
<timezone id="Asia/Yerevan">Yerevan</timezone>
|
|
||||||
<timezone id="Asia/Dubai">Dubai</timezone>
|
|
||||||
<timezone id="Asia/Kabul">Kabul</timezone>
|
|
||||||
<timezone id="Asia/Karachi">Islamabad, Karachi</timezone>
|
|
||||||
<timezone id="Asia/Oral">Ural'sk</timezone>
|
|
||||||
<timezone id="Asia/Yekaterinburg">Yekaterinburg</timezone>
|
|
||||||
<timezone id="Asia/Calcutta">Kolkata</timezone>
|
|
||||||
<timezone id="Asia/Colombo">Sri Lanka</timezone>
|
|
||||||
<timezone id="Asia/Katmandu">Kathmandu</timezone>
|
|
||||||
<timezone id="Asia/Almaty">Astana</timezone>
|
|
||||||
<timezone id="Asia/Rangoon">Yangon</timezone>
|
|
||||||
<timezone id="Asia/Krasnoyarsk">Krasnoyarsk</timezone>
|
|
||||||
<timezone id="Asia/Bangkok">Bangkok</timezone>
|
|
||||||
<timezone id="Asia/Jakarta">Jakarta</timezone>
|
|
||||||
<timezone id="Asia/Shanghai">Beijing</timezone>
|
|
||||||
<timezone id="Asia/Hong_Kong">Hong Kong</timezone>
|
|
||||||
<timezone id="Asia/Irkutsk">Irkutsk</timezone>
|
|
||||||
<timezone id="Asia/Kuala_Lumpur">Kuala Lumpur</timezone>
|
|
||||||
<timezone id="Australia/Perth">Perth</timezone>
|
|
||||||
<timezone id="Asia/Taipei">Taipei</timezone>
|
|
||||||
<timezone id="Asia/Seoul">Seoul</timezone>
|
|
||||||
<timezone id="Asia/Tokyo">Tokyo, Osaka</timezone>
|
|
||||||
<timezone id="Asia/Yakutsk">Yakutsk</timezone>
|
|
||||||
<timezone id="Australia/Adelaide">Adelaide</timezone>
|
|
||||||
<timezone id="Australia/Darwin">Darwin</timezone>
|
|
||||||
<timezone id="Australia/Brisbane">Brisbane</timezone>
|
|
||||||
<timezone id="Australia/Hobart">Hobart</timezone>
|
|
||||||
<timezone id="Australia/Sydney">Sydney, Canberra</timezone>
|
|
||||||
<timezone id="Asia/Vladivostok">Vladivostok</timezone>
|
|
||||||
<timezone id="Pacific/Guam">Guam</timezone>
|
|
||||||
<timezone id="Asia/Magadan">Magadan</timezone>
|
|
||||||
<timezone id="Pacific/Auckland">Auckland</timezone>
|
|
||||||
<timezone id="Pacific/Fiji">Fiji</timezone>
|
|
||||||
<timezone id="Pacific/Tongatapu">Tonga</timezone>
|
|
||||||
</timezones>
|
|
@@ -26,7 +26,6 @@ import android.content.BroadcastReceiver;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.content.res.XmlResourceParser;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.text.format.DateFormat;
|
import android.text.format.DateFormat;
|
||||||
@@ -39,15 +38,13 @@ import android.widget.Spinner;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.TimePicker;
|
import android.widget.TimePicker;
|
||||||
|
|
||||||
|
import com.android.settingslib.datetime.ZoneGetter;
|
||||||
|
|
||||||
import org.lineageos.setupwizard.util.SetupWizardUtils;
|
import org.lineageos.setupwizard.util.SetupWizardUtils;
|
||||||
|
|
||||||
import org.xmlpull.v1.XmlPullParserException;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
@@ -85,7 +82,7 @@ public class DateTimeActivity extends BaseSetupWizardActivity implements
|
|||||||
setNextText(R.string.next);
|
setNextText(R.string.next);
|
||||||
|
|
||||||
final Spinner spinner = (Spinner) findViewById(R.id.timezone_list);
|
final Spinner spinner = (Spinner) findViewById(R.id.timezone_list);
|
||||||
final SimpleAdapter adapter = constructTimezoneAdapter(this, false);
|
final SimpleAdapter adapter = constructTimezoneAdapter(this);
|
||||||
mCurrentTimeZone = TimeZone.getDefault();
|
mCurrentTimeZone = TimeZone.getDefault();
|
||||||
View dateView = findViewById(R.id.date_item);
|
View dateView = findViewById(R.id.date_item);
|
||||||
dateView.setOnClickListener((view) -> showDatePicker());
|
dateView.setOnClickListener((view) -> showDatePicker());
|
||||||
@@ -203,14 +200,12 @@ public class DateTimeActivity extends BaseSetupWizardActivity implements
|
|||||||
mDateTextView.setText(shortDateFormat.format(now.getTime()));
|
mDateTextView.setText(shortDateFormat.format(now.getTime()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SimpleAdapter constructTimezoneAdapter(Context context,
|
private static SimpleAdapter constructTimezoneAdapter(Context context) {
|
||||||
boolean sortedByName) {
|
|
||||||
final String[] from = new String[] {KEY_DISPLAYNAME, KEY_GMT};
|
final String[] from = new String[] {KEY_DISPLAYNAME, KEY_GMT};
|
||||||
final int[] to = new int[] {android.R.id.text1, android.R.id.text2};
|
final int[] to = new int[] {android.R.id.text1, android.R.id.text2};
|
||||||
|
|
||||||
final String sortKey = (sortedByName ? KEY_DISPLAYNAME : KEY_OFFSET);
|
final TimeZoneComparator comparator = new TimeZoneComparator(KEY_OFFSET);
|
||||||
final TimeZoneComparator comparator = new TimeZoneComparator(sortKey);
|
final List<Map<String, Object>> sortedList = ZoneGetter.getZonesList(context);
|
||||||
final List<HashMap<String, Object>> sortedList = getZones(context);
|
|
||||||
Collections.sort(sortedList, comparator);
|
Collections.sort(sortedList, comparator);
|
||||||
final SimpleAdapter adapter = new SimpleAdapter(context,
|
final SimpleAdapter adapter = new SimpleAdapter(context,
|
||||||
sortedList,
|
sortedList,
|
||||||
@@ -221,81 +216,11 @@ public class DateTimeActivity extends BaseSetupWizardActivity implements
|
|||||||
return adapter;
|
return adapter;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static List<HashMap<String, Object>> getZones(Context context) {
|
|
||||||
final List<HashMap<String, Object>> myData = new ArrayList();
|
|
||||||
final long date = Calendar.getInstance().getTimeInMillis();
|
|
||||||
try {
|
|
||||||
XmlResourceParser xrp = context.getResources().getXml(R.xml.timezones);
|
|
||||||
while (xrp.next() != XmlResourceParser.START_TAG)
|
|
||||||
continue;
|
|
||||||
xrp.next();
|
|
||||||
while (xrp.getEventType() != XmlResourceParser.END_TAG) {
|
|
||||||
while (xrp.getEventType() != XmlResourceParser.START_TAG) {
|
|
||||||
if (xrp.getEventType() == XmlResourceParser.END_DOCUMENT) {
|
|
||||||
return myData;
|
|
||||||
}
|
|
||||||
xrp.next();
|
|
||||||
}
|
|
||||||
if (xrp.getName().equals(XMLTAG_TIMEZONE)) {
|
|
||||||
String id = xrp.getAttributeValue(0);
|
|
||||||
String displayName = xrp.nextText();
|
|
||||||
addItem(myData, id, displayName, date);
|
|
||||||
}
|
|
||||||
while (xrp.getEventType() != XmlResourceParser.END_TAG) {
|
|
||||||
xrp.next();
|
|
||||||
}
|
|
||||||
xrp.next();
|
|
||||||
}
|
|
||||||
xrp.close();
|
|
||||||
} catch (XmlPullParserException xppe) {
|
|
||||||
Log.e(TAG, "Ill-formatted timezones.xml file");
|
|
||||||
} catch (java.io.IOException ioe) {
|
|
||||||
Log.e(TAG, "Unable to read timezones.xml file");
|
|
||||||
}
|
|
||||||
|
|
||||||
return myData;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void addItem(
|
|
||||||
List<HashMap<String, Object>> myData, String id, String displayName, long date) {
|
|
||||||
final HashMap<String, Object> map = new HashMap();
|
|
||||||
map.put(KEY_ID, id);
|
|
||||||
map.put(KEY_DISPLAYNAME, displayName);
|
|
||||||
final TimeZone tz = TimeZone.getTimeZone(id);
|
|
||||||
final int offset = tz.getOffset(date);
|
|
||||||
final int p = Math.abs(offset);
|
|
||||||
final StringBuilder name = new StringBuilder();
|
|
||||||
name.append("GMT");
|
|
||||||
|
|
||||||
if (offset < 0) {
|
|
||||||
name.append('-');
|
|
||||||
} else {
|
|
||||||
name.append('+');
|
|
||||||
}
|
|
||||||
|
|
||||||
name.append(p / (HOURS_1));
|
|
||||||
name.append(':');
|
|
||||||
|
|
||||||
int min = p / 60000;
|
|
||||||
min %= 60;
|
|
||||||
|
|
||||||
if (min < 10) {
|
|
||||||
name.append('0');
|
|
||||||
}
|
|
||||||
name.append(min);
|
|
||||||
|
|
||||||
map.put(KEY_GMT, name.toString());
|
|
||||||
map.put(KEY_OFFSET, offset);
|
|
||||||
|
|
||||||
myData.add(map);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static int getTimeZoneIndex(SimpleAdapter adapter, TimeZone tz) {
|
private static int getTimeZoneIndex(SimpleAdapter adapter, TimeZone tz) {
|
||||||
final String defaultId = tz.getID();
|
final String defaultId = tz.getID();
|
||||||
final int listSize = adapter.getCount();
|
final int listSize = adapter.getCount();
|
||||||
for (int i = 0; i < listSize; i++) {
|
for (int i = 0; i < listSize; i++) {
|
||||||
// Using HashMap<String, Object> induces unnecessary warning.
|
final Map<?,?> map = (Map<?,?>)adapter.getItem(i);
|
||||||
final HashMap<?,?> map = (HashMap<?,?>)adapter.getItem(i);
|
|
||||||
final String id = (String)map.get(KEY_ID);
|
final String id = (String)map.get(KEY_ID);
|
||||||
if (defaultId.equals(id)) {
|
if (defaultId.equals(id)) {
|
||||||
// If current timezone is in this list, move focus to it
|
// If current timezone is in this list, move focus to it
|
||||||
@@ -332,7 +257,7 @@ public class DateTimeActivity extends BaseSetupWizardActivity implements
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class TimeZoneComparator implements Comparator<HashMap<?, ?>> {
|
private static class TimeZoneComparator implements Comparator<Map<?, ?>> {
|
||||||
private String mSortingKey;
|
private String mSortingKey;
|
||||||
|
|
||||||
public TimeZoneComparator(String sortingKey) {
|
public TimeZoneComparator(String sortingKey) {
|
||||||
@@ -343,7 +268,7 @@ public class DateTimeActivity extends BaseSetupWizardActivity implements
|
|||||||
mSortingKey = sortingKey;
|
mSortingKey = sortingKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int compare(HashMap<?, ?> map1, HashMap<?, ?> map2) {
|
public int compare(Map<?, ?> map1, Map<?, ?> map2) {
|
||||||
Object value1 = map1.get(mSortingKey);
|
Object value1 = map1.get(mSortingKey);
|
||||||
Object value2 = map2.get(mSortingKey);
|
Object value2 = map2.get(mSortingKey);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user