Merge "Fix logic used for auto time zone settings"
This commit is contained in:
@@ -16,14 +16,22 @@
|
||||
|
||||
package com.android.settings.datetime;
|
||||
|
||||
import android.content.Context;
|
||||
import android.provider.Settings;
|
||||
import static android.app.time.Capabilities.CAPABILITY_NOT_ALLOWED;
|
||||
import static android.app.time.Capabilities.CAPABILITY_NOT_APPLICABLE;
|
||||
import static android.app.time.Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||
|
||||
import android.app.time.TimeManager;
|
||||
import android.app.time.TimeZoneCapabilities;
|
||||
import android.app.time.TimeZoneCapabilitiesAndConfig;
|
||||
import android.app.time.TimeZoneConfiguration;
|
||||
import android.content.Context;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.SwitchPreference;
|
||||
|
||||
import com.android.settings.core.PreferenceControllerMixin;
|
||||
import com.android.settingslib.Utils;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
|
||||
public class AutoTimeZonePreferenceController extends AbstractPreferenceController
|
||||
@@ -33,17 +41,37 @@ public class AutoTimeZonePreferenceController extends AbstractPreferenceControll
|
||||
|
||||
private final boolean mIsFromSUW;
|
||||
private final UpdateTimeAndDateCallback mCallback;
|
||||
private final TimeManager mTimeManager;
|
||||
|
||||
public AutoTimeZonePreferenceController(Context context, UpdateTimeAndDateCallback callback,
|
||||
boolean isFromSUW) {
|
||||
super(context);
|
||||
mTimeManager = context.getSystemService(TimeManager.class);
|
||||
mCallback = callback;
|
||||
mIsFromSUW = isFromSUW;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isAvailable() {
|
||||
return !(Utils.isWifiOnly(mContext) || mIsFromSUW);
|
||||
if (mIsFromSUW) {
|
||||
return false;
|
||||
}
|
||||
|
||||
TimeZoneCapabilities timeZoneCapabilities =
|
||||
getTimeZoneCapabilitiesAndConfig().getCapabilities();
|
||||
int capability = timeZoneCapabilities.getConfigureAutoDetectionEnabledCapability();
|
||||
|
||||
// The preference only has two states: present and not present. The preference is never
|
||||
// present but disabled.
|
||||
if (capability == CAPABILITY_NOT_SUPPORTED
|
||||
|| capability == CAPABILITY_NOT_ALLOWED
|
||||
|| capability == CAPABILITY_NOT_APPLICABLE) {
|
||||
return false;
|
||||
} else if (capability == CAPABILITY_POSSESSED) {
|
||||
return true;
|
||||
} else {
|
||||
throw new IllegalStateException("Unknown capability=" + capability);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -62,14 +90,22 @@ public class AutoTimeZonePreferenceController extends AbstractPreferenceControll
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
boolean autoZoneEnabled = (Boolean) newValue;
|
||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME_ZONE,
|
||||
autoZoneEnabled ? 1 : 0);
|
||||
TimeZoneConfiguration configuration = new TimeZoneConfiguration.Builder()
|
||||
.setAutoDetectionEnabled(autoZoneEnabled)
|
||||
.build();
|
||||
boolean result = mTimeManager.updateTimeZoneConfiguration(configuration);
|
||||
|
||||
mCallback.updateTimeAndDateDisplay(mContext);
|
||||
return true;
|
||||
return result;
|
||||
}
|
||||
|
||||
public boolean isEnabled() {
|
||||
return isAvailable() && Settings.Global.getInt(mContext.getContentResolver(),
|
||||
Settings.Global.AUTO_TIME_ZONE, 0) > 0;
|
||||
@VisibleForTesting
|
||||
boolean isEnabled() {
|
||||
TimeZoneConfiguration config = getTimeZoneCapabilitiesAndConfig().getConfiguration();
|
||||
return config.isAutoDetectionEnabled();
|
||||
}
|
||||
|
||||
private TimeZoneCapabilitiesAndConfig getTimeZoneCapabilitiesAndConfig() {
|
||||
return mTimeManager.getTimeZoneCapabilitiesAndConfig();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -85,8 +85,7 @@ public class DateTimeSettings extends DashboardFragment implements
|
||||
|
||||
controllers.add(new TimeFormatPreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
||||
controllers.add(new TimeZonePreferenceController(
|
||||
activity, autoTimeZonePreferenceController));
|
||||
controllers.add(new TimeZonePreferenceController(activity));
|
||||
controllers.add(new TimePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
||||
controllers.add(new DatePreferenceController(
|
||||
|
||||
@@ -16,6 +16,10 @@
|
||||
|
||||
package com.android.settings.datetime;
|
||||
|
||||
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||
|
||||
import android.app.time.TimeManager;
|
||||
import android.app.time.TimeZoneCapabilities;
|
||||
import android.content.Context;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
@@ -33,12 +37,11 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
||||
|
||||
private static final String KEY_TIMEZONE = "timezone";
|
||||
|
||||
private final AutoTimeZonePreferenceController mAutoTimeZonePreferenceController;
|
||||
private final TimeManager mTimeManager;
|
||||
|
||||
public TimeZonePreferenceController(Context context,
|
||||
AutoTimeZonePreferenceController autoTimeZonePreferenceController) {
|
||||
public TimeZonePreferenceController(Context context) {
|
||||
super(context);
|
||||
mAutoTimeZonePreferenceController = autoTimeZonePreferenceController;
|
||||
mTimeManager = context.getSystemService(TimeManager.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -47,8 +50,9 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
||||
return;
|
||||
}
|
||||
preference.setSummary(getTimeZoneOffsetAndName());
|
||||
if( !((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||
preference.setEnabled(!mAutoTimeZonePreferenceController.isEnabled());
|
||||
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||
boolean enableManualTimeZoneSelection = shouldEnableManualTimeZoneSelection();
|
||||
preference.setEnabled(enableManualTimeZoneSelection);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -68,4 +72,12 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
||||
return ZoneGetter.getTimeZoneOffsetAndName(mContext,
|
||||
now.getTimeZone(), now.getTime());
|
||||
}
|
||||
|
||||
private boolean shouldEnableManualTimeZoneSelection() {
|
||||
TimeZoneCapabilities timeZoneCapabilities =
|
||||
mTimeManager.getTimeZoneCapabilitiesAndConfig().getCapabilities();
|
||||
int suggestManualTimeZoneCapability =
|
||||
timeZoneCapabilities.getSuggestManualTimeZoneCapability();
|
||||
return suggestManualTimeZoneCapability == CAPABILITY_POSSESSED;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user