diff --git a/res/values/strings.xml b/res/values/strings.xml
index e61a6e231f3..a2543542e1f 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -2458,6 +2458,8 @@
Explore
Free up space
+
+ Manage storage
USB computer connection
@@ -7637,4 +7639,16 @@
%1$s
+
+ Automatic
+
+
+ Manual
+
+
+ Free space now
+
+
+ Storage manager
+
diff --git a/res/xml/automatic_storage_management_settings.xml b/res/xml/automatic_storage_management_settings.xml
index 78606fb1e09..282f89aa596 100644
--- a/res/xml/automatic_storage_management_settings.xml
+++ b/res/xml/automatic_storage_management_settings.xml
@@ -18,18 +18,32 @@
xmlns:settings="http://schemas.android.com/apk/res-auto"
android:title="@string/automatic_storage_manager_settings" >
-
+
-
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/com/android/settings/deletionhelper/AutomaticStorageManagerSettings.java b/src/com/android/settings/deletionhelper/AutomaticStorageManagerSettings.java
index 1112eb10e44..bb9972546ae 100644
--- a/src/com/android/settings/deletionhelper/AutomaticStorageManagerSettings.java
+++ b/src/com/android/settings/deletionhelper/AutomaticStorageManagerSettings.java
@@ -21,6 +21,7 @@ import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Switch;
+import android.support.v14.preference.SwitchPreference;
import android.support.v7.preference.DropDownPreference;
import android.support.v7.preference.Preference;
import android.support.v7.preference.Preference.OnPreferenceChangeListener;
@@ -38,11 +39,14 @@ import com.android.settings.widget.SwitchBar.OnSwitchChangeListener;
* automatic storage manager.
*/
public class AutomaticStorageManagerSettings extends SettingsPreferenceFragment implements
- OnSwitchChangeListener, OnPreferenceChangeListener {
+ OnPreferenceChangeListener, Preference.OnPreferenceClickListener {
private static final String KEY_DAYS = "days";
+ private static final String KEY_DELETION_HELPER = "deletion_helper";
+ private static final String KEY_STORAGE_MANAGER_SWITCH = "storage_manager_active";
- private SwitchBar mSwitchBar;
private DropDownPreference mDaysToRetain;
+ private Preference mDeletionHelper;
+ private SwitchPreference mStorageManagerSwitch;
@Override
public void onCreate(Bundle savedInstanceState) {
@@ -53,33 +57,34 @@ public class AutomaticStorageManagerSettings extends SettingsPreferenceFragment
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
- Activity activity = getActivity();
- mSwitchBar = ((SettingsActivity) activity).getSwitchBar();
- mSwitchBar.show();
- mSwitchBar.addOnSwitchChangeListener(this);
- // TODO: Initialize the switch bar position based on if the storage manager is active.
-
mDaysToRetain = (DropDownPreference) findPreference(KEY_DAYS);
mDaysToRetain.setOnPreferenceChangeListener(this);
+
+ mDeletionHelper = findPreference(KEY_DELETION_HELPER);
+ mDeletionHelper.setOnPreferenceClickListener(this);
+
+ mStorageManagerSwitch = (SwitchPreference) findPreference(KEY_STORAGE_MANAGER_SWITCH);
+ mStorageManagerSwitch.setOnPreferenceChangeListener(this);
}
@Override
public void onResume() {
super.onResume();
- // TODO: Initialize the switch bar position based on if the storage manager is active.
- maybeShowDayDropdown(mSwitchBar.isChecked());
- }
-
- @Override
- public void onSwitchChanged(Switch switchView, boolean isChecked) {
- // TODO: Flip a setting which controls if the storage manager should run.
- maybeShowDayDropdown(isChecked);
+ mDaysToRetain.setEnabled(mStorageManagerSwitch.isChecked());
}
@Override
public boolean onPreferenceChange(Preference preference, Object newValue) {
- // TODO: Configure a setting which controls how many days of data the storage manager
- // should retain.
+ switch (preference.getKey()) {
+ case KEY_STORAGE_MANAGER_SWITCH:
+ boolean checked = (boolean) newValue;
+ mDaysToRetain.setEnabled(checked);
+ break;
+ case KEY_DAYS:
+ // TODO: Configure a setting which controls how many days of data the storage manager
+ // should retain.
+ break;
+ }
return true;
}
@@ -88,12 +93,12 @@ public class AutomaticStorageManagerSettings extends SettingsPreferenceFragment
return MetricsEvent.STORAGE_MANAGER_SETTINGS;
}
- private void maybeShowDayDropdown(boolean shouldShow) {
- PreferenceScreen screen = getPreferenceScreen();
- if (shouldShow) {
- screen.addPreference(mDaysToRetain);
- } else {
- screen.removePreference(mDaysToRetain);
+ @Override
+ public boolean onPreferenceClick(Preference preference) {
+ if (KEY_DELETION_HELPER.equals(preference.getKey())) {
+ startFragment(this, DeletionHelperFragment.class.getCanonicalName(),
+ R.string.deletion_helper_title, 0, null);
}
+ return true;
}
}
diff --git a/src/com/android/settings/deviceinfo/PrivateVolumeSettings.java b/src/com/android/settings/deviceinfo/PrivateVolumeSettings.java
index 7c427bd1803..c2628062581 100644
--- a/src/com/android/settings/deviceinfo/PrivateVolumeSettings.java
+++ b/src/com/android/settings/deviceinfo/PrivateVolumeSettings.java
@@ -170,7 +170,7 @@ public class PrivateVolumeSettings extends SettingsPreferenceFragment {
mCurrentUser = mUserManager.getUserInfo(UserHandle.myUserId());
mExplore = buildAction(R.string.storage_menu_explore);
- mAutomaticStorageManagement = buildAction(R.string.storage_settings);
+ mAutomaticStorageManagement = buildAction(R.string.storage_menu_manage);
mNeedsUpdate = true;
@@ -485,7 +485,7 @@ public class PrivateVolumeSettings extends SettingsPreferenceFragment {
case R.string.storage_menu_explore: {
intent = mSharedVolume.buildBrowseIntent();
} break;
- case R.string.storage_settings: {
+ case R.string.storage_menu_manage: {
startFragment(this, AutomaticStorageManagerSettings.class.getCanonicalName(),
R.string.automatic_storage_manager_settings, 0, null);
return true;