Switch auto time setting to use APIs
Switch auto time setting to use TimeManager APIs instead of low-level direct settings access. This makes the AutoTimePreferenceController approach the same as AutoTimeZonePreferenceController. Most of the logic about what to display and whether toggles are enabled is moved to the service. This change has the side effect of adding support in SettingsUI for devices with no auto time detection mechanism configured at all, i.e. the auto time toggle will stop being shown in SettingsUI. There are no known devices that require this currently, but it is a theoretical possibility if config.xml is configured in particular ways. Bug: 172891783 Test: Manual testing with different settings for "time origin priorities" (i.e. empty, non-empty) Test: m ROBOTEST_FILTER=com.android.settings.datetime RunSettingsRoboTests -j40 Change-Id: I4112fb51adb0d06a1dbc39a44ea109d6df899153
This commit is contained in:
@@ -16,17 +16,22 @@
|
||||
|
||||
package com.android.settings.datetime;
|
||||
|
||||
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.TimeCapabilities;
|
||||
import android.app.time.TimeCapabilitiesAndConfig;
|
||||
import android.app.time.TimeConfiguration;
|
||||
import android.app.time.TimeManager;
|
||||
import android.content.Context;
|
||||
import android.os.UserHandle;
|
||||
import android.os.UserManager;
|
||||
import android.provider.Settings;
|
||||
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.SwitchPreference;
|
||||
|
||||
import com.android.internal.annotations.VisibleForTesting;
|
||||
import com.android.settings.core.PreferenceControllerMixin;
|
||||
import com.android.settingslib.RestrictedLockUtils;
|
||||
import com.android.settingslib.RestrictedLockUtilsInternal;
|
||||
import com.android.settingslib.RestrictedSwitchPreference;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
|
||||
public class AutoTimePreferenceController extends AbstractPreferenceController
|
||||
@@ -34,27 +39,39 @@ public class AutoTimePreferenceController extends AbstractPreferenceController
|
||||
|
||||
private static final String KEY_AUTO_TIME = "auto_time";
|
||||
private final UpdateTimeAndDateCallback mCallback;
|
||||
private final TimeManager mTimeManager;
|
||||
|
||||
public AutoTimePreferenceController(Context context, UpdateTimeAndDateCallback callback) {
|
||||
super(context);
|
||||
mTimeManager = context.getSystemService(TimeManager.class);
|
||||
mCallback = callback;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isAvailable() {
|
||||
return true;
|
||||
TimeCapabilities timeCapabilities =
|
||||
getTimeCapabilitiesAndConfig().getCapabilities();
|
||||
int capability = timeCapabilities.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
|
||||
public void updateState(Preference preference) {
|
||||
if (!(preference instanceof RestrictedSwitchPreference)) {
|
||||
if (!(preference instanceof SwitchPreference)) {
|
||||
return;
|
||||
}
|
||||
if (!((RestrictedSwitchPreference) preference).isDisabledByAdmin()) {
|
||||
((RestrictedSwitchPreference) preference).setDisabledByAdmin(
|
||||
getEnforcedAdminProperty());
|
||||
}
|
||||
((RestrictedSwitchPreference) preference).setChecked(isEnabled());
|
||||
((SwitchPreference) preference).setChecked(isEnabled());
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -64,21 +81,24 @@ public class AutoTimePreferenceController extends AbstractPreferenceController
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
boolean autoEnabled = (Boolean) newValue;
|
||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME,
|
||||
autoEnabled ? 1 : 0);
|
||||
boolean autoTimeEnabled = (Boolean) newValue;
|
||||
TimeConfiguration configuration = new TimeConfiguration.Builder()
|
||||
.setAutoDetectionEnabled(autoTimeEnabled)
|
||||
.build();
|
||||
boolean result = mTimeManager.updateTimeConfiguration(configuration);
|
||||
|
||||
mCallback.updateTimeAndDateDisplay(mContext);
|
||||
return true;
|
||||
return result;
|
||||
}
|
||||
|
||||
/** Returns whether the preference should be "checked", i.e. set to the "on" position. */
|
||||
@VisibleForTesting
|
||||
public boolean isEnabled() {
|
||||
return Settings.Global.getInt(mContext.getContentResolver(),
|
||||
Settings.Global.AUTO_TIME, 0) > 0;
|
||||
TimeConfiguration config = getTimeCapabilitiesAndConfig().getConfiguration();
|
||||
return config.isAutoDetectionEnabled();
|
||||
}
|
||||
|
||||
private RestrictedLockUtils.EnforcedAdmin getEnforcedAdminProperty() {
|
||||
return RestrictedLockUtilsInternal.checkIfRestrictionEnforced(
|
||||
mContext, UserManager.DISALLOW_CONFIG_DATE_TIME,
|
||||
UserHandle.myUserId());
|
||||
private TimeCapabilitiesAndConfig getTimeCapabilitiesAndConfig() {
|
||||
return mTimeManager.getTimeCapabilitiesAndConfig();
|
||||
}
|
||||
}
|
||||
|
@@ -16,8 +16,12 @@
|
||||
|
||||
package com.android.settings.datetime;
|
||||
|
||||
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.DatePickerDialog;
|
||||
import android.app.time.TimeCapabilities;
|
||||
import android.app.time.TimeManager;
|
||||
import android.app.timedetector.ManualTimeSuggestion;
|
||||
import android.app.timedetector.TimeDetector;
|
||||
import android.content.Context;
|
||||
@@ -46,13 +50,12 @@ public class DatePreferenceController extends AbstractPreferenceController
|
||||
private static final String KEY_DATE = "date";
|
||||
|
||||
private final DatePreferenceHost mHost;
|
||||
private final AutoTimePreferenceController mAutoTimePreferenceController;
|
||||
private final TimeManager mTimeManager;
|
||||
|
||||
public DatePreferenceController(Context context, DatePreferenceHost host,
|
||||
AutoTimePreferenceController autoTimePreferenceController) {
|
||||
public DatePreferenceController(Context context, DatePreferenceHost host) {
|
||||
super(context);
|
||||
mHost = host;
|
||||
mAutoTimePreferenceController = autoTimePreferenceController;
|
||||
mTimeManager = context.getSystemService(TimeManager.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -68,7 +71,8 @@ public class DatePreferenceController extends AbstractPreferenceController
|
||||
final Calendar now = Calendar.getInstance();
|
||||
preference.setSummary(DateFormat.getLongDateFormat(mContext).format(now.getTime()));
|
||||
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||
preference.setEnabled(!mAutoTimePreferenceController.isEnabled());
|
||||
boolean enableManualDateSelection = isEnabled();
|
||||
preference.setEnabled(enableManualDateSelection);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -126,4 +130,16 @@ public class DatePreferenceController extends AbstractPreferenceController
|
||||
timeDetector.suggestManualTime(manualTimeSuggestion);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether selecting the preference should prompt for the user to enter the date
|
||||
* manually. Exposed as public so that the time controller can easily share the same logic as
|
||||
* the rules are identical for time.
|
||||
*/
|
||||
public boolean isEnabled() {
|
||||
TimeCapabilities timeZoneCapabilities =
|
||||
mTimeManager.getTimeCapabilitiesAndConfig().getCapabilities();
|
||||
int suggestManualTimeCapability = timeZoneCapabilities.getSuggestManualTimeCapability();
|
||||
return suggestManualTimeCapability == CAPABILITY_POSSESSED;
|
||||
}
|
||||
}
|
||||
|
@@ -69,27 +69,28 @@ public class DateTimeSettings extends DashboardFragment implements
|
||||
final Intent intent = activity.getIntent();
|
||||
final boolean isFromSUW = intent.getBooleanExtra(EXTRA_IS_FROM_SUW, false);
|
||||
|
||||
final AutoTimeZonePreferenceController autoTimeZonePreferenceController =
|
||||
new AutoTimeZonePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW);
|
||||
final AutoTimePreferenceController autoTimePreferenceController =
|
||||
new AutoTimePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */);
|
||||
controllers.add(autoTimePreferenceController);
|
||||
DatePreferenceController datePreferenceController = new DatePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */);
|
||||
controllers.add(datePreferenceController);
|
||||
controllers.add(new TimePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, datePreferenceController));
|
||||
|
||||
final AutoTimeZonePreferenceController autoTimeZonePreferenceController =
|
||||
new AutoTimeZonePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW);
|
||||
controllers.add(autoTimeZonePreferenceController);
|
||||
controllers.add(new TimeZonePreferenceController(activity));
|
||||
|
||||
final AutoTimeFormatPreferenceController autoTimeFormatPreferenceController =
|
||||
new AutoTimeFormatPreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */);
|
||||
|
||||
controllers.add(autoTimeZonePreferenceController);
|
||||
controllers.add(autoTimePreferenceController);
|
||||
controllers.add(autoTimeFormatPreferenceController);
|
||||
|
||||
controllers.add(new TimeFormatPreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
||||
controllers.add(new TimeZonePreferenceController(activity));
|
||||
controllers.add(new TimePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
||||
controllers.add(new DatePreferenceController(
|
||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
||||
return controllers;
|
||||
}
|
||||
|
||||
|
@@ -44,16 +44,16 @@ public class TimePreferenceController extends AbstractPreferenceController
|
||||
|
||||
private static final String KEY_TIME = "time";
|
||||
|
||||
private final AutoTimePreferenceController mAutoTimePreferenceController;
|
||||
private final DatePreferenceController mDatePreferenceController;
|
||||
private final TimePreferenceHost mHost;
|
||||
|
||||
|
||||
public TimePreferenceController(Context context,
|
||||
TimePreferenceHost callback,
|
||||
AutoTimePreferenceController autoTimePreferenceController) {
|
||||
DatePreferenceController datePreferenceController) {
|
||||
super(context);
|
||||
mHost = callback;
|
||||
mAutoTimePreferenceController = autoTimePreferenceController;
|
||||
mDatePreferenceController = datePreferenceController;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -69,7 +69,8 @@ public class TimePreferenceController extends AbstractPreferenceController
|
||||
final Calendar now = Calendar.getInstance();
|
||||
preference.setSummary(DateFormat.getTimeFormat(mContext).format(now.getTime()));
|
||||
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||
preference.setEnabled(!mAutoTimePreferenceController.isEnabled());
|
||||
boolean enableManualTimeSelection = mDatePreferenceController.isEnabled();
|
||||
preference.setEnabled(enableManualTimeSelection);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user