blob: dd078baba7d808289929b0afa9dbdd872ca227d7 [file] [log] [blame]
Amith Yamasanid7993472010-08-18 13:59:28 -07001/*
2 * Copyright (C) 2010 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.settings;
18
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -070019import android.app.Activity;
Amith Yamasanid7993472010-08-18 13:59:28 -070020import android.app.Dialog;
21import android.app.DialogFragment;
Daisuke Miyakawab5647c52010-09-10 18:04:02 -070022import android.app.Fragment;
Amith Yamasanid7993472010-08-18 13:59:28 -070023import android.content.ContentResolver;
Hung-ying Tyan0ee51e02011-01-25 16:42:14 +080024import android.content.DialogInterface;
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -070025import android.content.Intent;
Amith Yamasanid7993472010-08-18 13:59:28 -070026import android.content.pm.PackageManager;
Amith Yamasanid7993472010-08-18 13:59:28 -070027import android.os.Bundle;
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -070028import android.preference.PreferenceActivity;
Amith Yamasanid7993472010-08-18 13:59:28 -070029import android.preference.PreferenceFragment;
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -070030import android.text.TextUtils;
Amith Yamasanid7993472010-08-18 13:59:28 -070031import android.util.Log;
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -070032import android.view.View;
33import android.view.View.OnClickListener;
34import android.widget.Button;
Amith Yamasanid7993472010-08-18 13:59:28 -070035
Daisuke Miyakawaf58090d2010-09-12 17:27:33 -070036/**
Amith Yamasanid7993472010-08-18 13:59:28 -070037 * Base class for Settings fragments, with some helper functions and dialog management.
38 */
Daisuke Miyakawa21c1abc2010-09-12 15:42:56 -070039public class SettingsPreferenceFragment extends PreferenceFragment
40 implements DialogCreatable {
Amith Yamasanid7993472010-08-18 13:59:28 -070041
42 private static final String TAG = "SettingsPreferenceFragment";
43
44 private SettingsDialogFragment mDialogFragment;
45
Daisuke Miyakawab5647c52010-09-10 18:04:02 -070046 @Override
Amith Yamasanid7993472010-08-18 13:59:28 -070047 public void onActivityCreated(Bundle savedInstanceState) {
48 super.onActivityCreated(savedInstanceState);
Amith Yamasanid7993472010-08-18 13:59:28 -070049 }
50
Daisuke Miyakawab5647c52010-09-10 18:04:02 -070051 /*
52 * The name is intentionally made different from Activity#finish(), so that
53 * users won't misunderstand its meaning.
54 */
55 public final void finishFragment() {
56 getActivity().onBackPressed();
57 }
58
Amith Yamasanid7993472010-08-18 13:59:28 -070059 // Some helpers for functions used by the settings fragments when they were activities
60
61 /**
62 * Returns the ContentResolver from the owning Activity.
63 */
64 protected ContentResolver getContentResolver() {
65 return getActivity().getContentResolver();
66 }
67
68 /**
69 * Returns the specified system service from the owning Activity.
70 */
71 protected Object getSystemService(final String name) {
72 return getActivity().getSystemService(name);
73 }
74
75 /**
Amith Yamasanid7993472010-08-18 13:59:28 -070076 * Returns the PackageManager from the owning Activity.
77 */
78 protected PackageManager getPackageManager() {
79 return getActivity().getPackageManager();
80 }
81
Dianne Hackborn0385cf12011-01-24 16:22:13 -080082 @Override
83 public void onDetach() {
84 if (isRemoving()) {
85 if (mDialogFragment != null) {
86 mDialogFragment.dismiss();
87 mDialogFragment = null;
88 }
89 }
90 super.onDetach();
91 }
92
Amith Yamasanid7993472010-08-18 13:59:28 -070093 // Dialog management
94
95 protected void showDialog(int dialogId) {
96 if (mDialogFragment != null) {
97 Log.e(TAG, "Old dialog fragment not null!");
98 }
99 mDialogFragment = new SettingsDialogFragment(this, dialogId);
Daisuke Miyakawa21c1abc2010-09-12 15:42:56 -0700100 mDialogFragment.show(getActivity().getFragmentManager(), Integer.toString(dialogId));
Amith Yamasanid7993472010-08-18 13:59:28 -0700101 }
102
103 public Dialog onCreateDialog(int dialogId) {
104 return null;
105 }
106
107 protected void removeDialog(int dialogId) {
Hung-ying Tyanadc83d82011-01-24 15:05:27 +0800108 // mDialogFragment may not be visible yet in parent fragment's onResume().
109 // To be able to dismiss dialog at that time, don't check
110 // mDialogFragment.isVisible().
111 if (mDialogFragment != null && mDialogFragment.getDialogId() == dialogId) {
Amith Yamasanid7993472010-08-18 13:59:28 -0700112 mDialogFragment.dismiss();
113 }
114 mDialogFragment = null;
115 }
116
Hung-ying Tyan0ee51e02011-01-25 16:42:14 +0800117 /**
118 * Sets the OnCancelListener of the dialog shown. This method can only be
119 * called after showDialog(int) and before removeDialog(int). The method
120 * does nothing otherwise.
121 */
122 protected void setOnCancelListener(DialogInterface.OnCancelListener listener) {
123 if (mDialogFragment != null) {
124 mDialogFragment.mOnCancelListener = listener;
125 }
126 }
127
128 /**
129 * Sets the OnDismissListener of the dialog shown. This method can only be
130 * called after showDialog(int) and before removeDialog(int). The method
131 * does nothing otherwise.
132 */
133 protected void setOnDismissListener(DialogInterface.OnDismissListener listener) {
134 if (mDialogFragment != null) {
135 mDialogFragment.mOnDismissListener = listener;
136 }
137 }
138
Amith Yamasani43c69782010-12-01 09:04:36 -0800139 public static class SettingsDialogFragment extends DialogFragment {
Svetoslav Ganov749ba652010-12-09 14:53:02 -0800140 private static final String KEY_DIALOG_ID = "key_dialog_id";
141 private static final String KEY_PARENT_FRAGMENT_ID = "key_parent_fragment_id";
142
Amith Yamasanid7993472010-08-18 13:59:28 -0700143 private int mDialogId;
144
Svetoslav Ganov749ba652010-12-09 14:53:02 -0800145 private Fragment mParentFragment;
146
Hung-ying Tyan0ee51e02011-01-25 16:42:14 +0800147 private DialogInterface.OnCancelListener mOnCancelListener;
148 private DialogInterface.OnDismissListener mOnDismissListener;
149
Svetoslav Ganov749ba652010-12-09 14:53:02 -0800150 public SettingsDialogFragment() {
151 /* do nothing */
152 }
Amith Yamasanid7993472010-08-18 13:59:28 -0700153
Amith Yamasani43c69782010-12-01 09:04:36 -0800154 public SettingsDialogFragment(DialogCreatable fragment, int dialogId) {
Amith Yamasanid7993472010-08-18 13:59:28 -0700155 mDialogId = dialogId;
Svetoslav Ganov749ba652010-12-09 14:53:02 -0800156 if (!(fragment instanceof Fragment)) {
157 throw new IllegalArgumentException("fragment argument must be an instance of "
158 + Fragment.class.getName());
159 }
160 mParentFragment = (Fragment) fragment;
161 }
162
163 @Override
164 public void onActivityCreated(Bundle savedInstanceState) {
165 if (savedInstanceState != null) {
166 mDialogId = savedInstanceState.getInt(KEY_DIALOG_ID, 0);
167 int mParentFragmentId = savedInstanceState.getInt(KEY_PARENT_FRAGMENT_ID, -1);
168 if (mParentFragmentId > -1) {
169 mParentFragment = getFragmentManager().findFragmentById(mParentFragmentId);
170 if (!(mParentFragment instanceof DialogCreatable)) {
171 throw new IllegalArgumentException(
172 KEY_PARENT_FRAGMENT_ID + " must implement "
173 + DialogCreatable.class.getName());
174 }
175 }
176 }
177 super.onActivityCreated(savedInstanceState);
178 }
179
180 @Override
181 public void onSaveInstanceState(Bundle outState) {
182 super.onSaveInstanceState(outState);
183 if (mParentFragment != null) {
184 outState.putInt(KEY_DIALOG_ID, mDialogId);
185 outState.putInt(KEY_PARENT_FRAGMENT_ID, mParentFragment.getId());
186 }
Amith Yamasanid7993472010-08-18 13:59:28 -0700187 }
188
189 @Override
190 public Dialog onCreateDialog(Bundle savedInstanceState) {
Svetoslav Ganov749ba652010-12-09 14:53:02 -0800191 return ((DialogCreatable) mParentFragment).onCreateDialog(mDialogId);
Amith Yamasanid7993472010-08-18 13:59:28 -0700192 }
193
Hung-ying Tyan0ee51e02011-01-25 16:42:14 +0800194 @Override
195 public void onCancel(DialogInterface dialog) {
196 super.onCancel(dialog);
197 if (mOnCancelListener != null) {
198 mOnCancelListener.onCancel(dialog);
199 }
200 }
201
202 @Override
203 public void onDismiss(DialogInterface dialog) {
204 super.onDismiss(dialog);
205 if (mOnDismissListener != null) {
206 mOnDismissListener.onDismiss(dialog);
207 }
208 }
Amith Yamasanid7993472010-08-18 13:59:28 -0700209 public int getDialogId() {
210 return mDialogId;
211 }
212 }
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -0700213
214 protected boolean hasNextButton() {
Daisuke Miyakawa79c5fd92011-01-15 14:58:00 -0800215 return ((ButtonBarHandler)getActivity()).hasNextButton();
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -0700216 }
217
218 protected Button getNextButton() {
Daisuke Miyakawa79c5fd92011-01-15 14:58:00 -0800219 return ((ButtonBarHandler)getActivity()).getNextButton();
Daisuke Miyakawa9c8bde52010-08-25 11:58:37 -0700220 }
221
Daisuke Miyakawa6ebf8612010-09-10 09:48:51 -0700222 public void finish() {
223 getActivity().onBackPressed();
224 }
225
Daisuke Miyakawab5647c52010-09-10 18:04:02 -0700226 public boolean startFragment(
227 Fragment caller, String fragmentClass, int requestCode, Bundle extras) {
Daisuke Miyakawa25af1502010-09-24 11:29:31 -0700228 if (getActivity() instanceof PreferenceActivity) {
229 PreferenceActivity preferenceActivity = (PreferenceActivity)getActivity();
Amith Yamasani928e78a2010-11-12 08:51:01 -0800230 preferenceActivity.startPreferencePanel(fragmentClass, extras, 0, null, caller,
231 requestCode);
Daisuke Miyakawa25af1502010-09-24 11:29:31 -0700232 return true;
Daisuke Miyakawab5647c52010-09-10 18:04:02 -0700233 } else {
Daisuke Miyakawa25af1502010-09-24 11:29:31 -0700234 Log.w(TAG, "Parent isn't PreferenceActivity, thus there's no way to launch the "
235 + "given Fragment (name: " + fragmentClass + ", requestCode: " + requestCode
236 + ")");
Daisuke Miyakawab5647c52010-09-10 18:04:02 -0700237 return false;
238 }
239 }
240
Amith Yamasanid7993472010-08-18 13:59:28 -0700241}