blob: ded776c39927b43908ab6c95c29f7ab7f765c1ef [file] [log] [blame]
Alexandre Savard68838112012-10-30 11:34:43 -04001/*
2 * Copyright (C) 2004-2012 Savoir-Faire Linux Inc.
3 *
4 * Author: Alexandre Savard <alexandre.savard@savoirfairelinux.com>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 *
20 * Additional permission under GNU GPL version 3 section 7:
21 *
22 * If you modify this program, or any covered work, by linking or
23 * combining it with the OpenSSL project's OpenSSL library (or a
24 * modified version of that library), containing parts covered by the
25 * terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
26 * grants you additional permission to convey the resulting work.
27 * Corresponding Source for a non-source form of such a combination
28 * shall include the source code for the parts of OpenSSL used as well
29 * as that of the covered work.
30 */
31
32package com.savoirfairelinux.sflphone.client;
33
alision73424b62013-04-26 11:49:18 -040034import java.net.NetworkInterface;
35import java.net.SocketException;
alisiond9e29442013-04-17 16:10:18 -040036import java.util.ArrayList;
alision73424b62013-04-26 11:49:18 -040037import java.util.Enumeration;
alisiond9e29442013-04-17 16:10:18 -040038import java.util.HashMap;
39
Alexandre Savard68838112012-10-30 11:34:43 -040040import android.app.Activity;
Alexandre Savard645b29c2012-10-30 17:22:26 -040041import android.app.AlertDialog;
42import android.app.Dialog;
Alexandre Savard645b29c2012-10-30 17:22:26 -040043import android.content.DialogInterface;
Alexandre Savard68838112012-10-30 11:34:43 -040044import android.content.Intent;
45import android.os.Bundle;
alisiond9e29442013-04-17 16:10:18 -040046import android.preference.CheckBoxPreference;
47import android.preference.EditTextPreference;
alision73424b62013-04-26 11:49:18 -040048import android.preference.ListPreference;
Alexandre Savard68838112012-10-30 11:34:43 -040049import android.preference.Preference;
alisione2a38e12013-04-25 14:20:20 -040050import android.preference.Preference.OnPreferenceChangeListener;
Alexandre Savard68838112012-10-30 11:34:43 -040051import android.preference.PreferenceActivity;
52import android.preference.PreferenceManager;
Alexandre Savard68838112012-10-30 11:34:43 -040053import android.util.Log;
Alexandre Savard5195d922012-10-30 16:58:50 -040054import android.view.Menu;
alisiond9e29442013-04-17 16:10:18 -040055import android.view.MenuInflater;
Alexandre Savard5195d922012-10-30 16:58:50 -040056import android.view.MenuItem;
Alexandre Savard68838112012-10-30 11:34:43 -040057
58import com.savoirfairelinux.sflphone.R;
alisionf76de3b2013-04-16 15:35:22 -040059import com.savoirfairelinux.sflphone.account.AccountDetail;
60import com.savoirfairelinux.sflphone.account.AccountDetailAdvanced;
61import com.savoirfairelinux.sflphone.account.AccountDetailBasic;
62import com.savoirfairelinux.sflphone.account.AccountDetailSrtp;
63import com.savoirfairelinux.sflphone.account.AccountDetailTls;
Alexandre Savard68838112012-10-30 11:34:43 -040064
alisiond9e29442013-04-17 16:10:18 -040065public class AccountPreferenceActivity extends PreferenceActivity {
Alexandre Savard68838112012-10-30 11:34:43 -040066 private static final String TAG = "AccoutPreferenceActivity";
alisiond9e29442013-04-17 16:10:18 -040067
68 public static final String KEY_MODE = "mode";
69
alisiond9e29442013-04-17 16:10:18 -040070 public interface result {
alisiond9e29442013-04-17 16:10:18 -040071 static final int ACCOUNT_MODIFIED = Activity.RESULT_FIRST_USER + 1;
72 static final int ACCOUNT_DELETED = Activity.RESULT_FIRST_USER + 2;
73 }
Alexandre Savard68838112012-10-30 11:34:43 -040074
Alexandre Savard833616f2012-10-30 16:02:30 -040075 private AccountDetailBasic basicDetails = null;
76 private AccountDetailAdvanced advancedDetails = null;
77 private AccountDetailSrtp srtpDetails = null;
78 private AccountDetailTls tlsDetails = null;
Alexandre Savard68838112012-10-30 11:34:43 -040079 private PreferenceManager mPreferenceManager;
Alexandre Savard68838112012-10-30 11:34:43 -040080 private String mAccountID;
alisiond9e29442013-04-17 16:10:18 -040081 private ArrayList<String> requiredFields = null;
Alexandre Savard68838112012-10-30 11:34:43 -040082
Alexandre Lisionc51ccb12013-09-11 16:00:30 -040083 private boolean isDifferent = false;
84
alisiond9e29442013-04-17 16:10:18 -040085 @Override
86 protected void onCreate(Bundle savedInstanceState) {
87 super.onCreate(savedInstanceState);
88 addPreferencesFromResource(R.xml.account_creation_preferences);
89 mPreferenceManager = getPreferenceManager();
Alexandre Savard68838112012-10-30 11:34:43 -040090
alision5cfc35d2013-07-11 15:11:39 -040091 initEdition();
alisiond9e29442013-04-17 16:10:18 -040092
alisioncc7bb422013-06-06 15:31:39 -040093 getActionBar().setDisplayHomeAsUpEnabled(true);
alision5de91782013-07-10 10:47:30 -040094
alisiond9e29442013-04-17 16:10:18 -040095 requiredFields = new ArrayList<String>();
96 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_ALIAS);
97 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_HOSTNAME);
98 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_USERNAME);
99 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_PASSWORD);
100
101 }
102
alisiond9e29442013-04-17 16:10:18 -0400103 private void initEdition() {
Alexandre Savard68838112012-10-30 11:34:43 -0400104
105 Bundle b = getIntent().getExtras();
106 mAccountID = b.getString("AccountID");
107 ArrayList<String> basicPreferenceList = b.getStringArrayList(AccountDetailBasic.BUNDLE_TAG);
108 ArrayList<String> advancedPreferenceList = b.getStringArrayList(AccountDetailAdvanced.BUNDLE_TAG);
109 ArrayList<String> srtpPreferenceList = b.getStringArrayList(AccountDetailSrtp.BUNDLE_TAG);
110 ArrayList<String> tlsPreferenceList = b.getStringArrayList(AccountDetailTls.BUNDLE_TAG);
alision7f18fc82013-05-01 09:37:33 -0400111
alisiond9e29442013-04-17 16:10:18 -0400112 basicDetails = new AccountDetailBasic(basicPreferenceList);
Alexandre Savard68838112012-10-30 11:34:43 -0400113 advancedDetails = new AccountDetailAdvanced(advancedPreferenceList);
114 srtpDetails = new AccountDetailSrtp(srtpPreferenceList);
115 tlsDetails = new AccountDetailTls(tlsPreferenceList);
116
117 setPreferenceDetails(basicDetails);
Alexandre Savard833616f2012-10-30 16:02:30 -0400118 setPreferenceDetails(advancedDetails);
119 setPreferenceDetails(srtpDetails);
120 setPreferenceDetails(tlsDetails);
121
alisione2a38e12013-04-25 14:20:20 -0400122 addPreferenceListener(basicDetails, changeBasicPreferenceListener);
alision5de91782013-07-10 10:47:30 -0400123 // addPreferenceListener(advancedDetails, changeAdvancedPreferenceListener);
124 // addPreferenceListener(srtpDetails, changeSrtpPreferenceListener);
125 // addPreferenceListener(tlsDetails, changeTlsPreferenceListener);
Alexandre Savard68838112012-10-30 11:34:43 -0400126 }
127
alisiond9e29442013-04-17 16:10:18 -0400128 @Override
129 public boolean onCreateOptionsMenu(Menu menu) {
130 MenuInflater inflater = getMenuInflater();
alision5cfc35d2013-07-11 15:11:39 -0400131 inflater.inflate(R.menu.account_edition, menu);
alisiond9e29442013-04-17 16:10:18 -0400132 return true;
133 }
134
135 @Override
136 public void onBackPressed() {
alision5cfc35d2013-07-11 15:11:39 -0400137
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400138 if (isDifferent) {
139 AlertDialog dialog = createCancelDialog();
140 dialog.show();
141 } else {
142 super.onBackPressed();
143 }
alisiond9e29442013-04-17 16:10:18 -0400144
145 }
146
alisiond9e29442013-04-17 16:10:18 -0400147 @Override
148 public boolean onOptionsItemSelected(MenuItem item) {
149
150 switch (item.getItemId()) {
alisioncc7bb422013-06-06 15:31:39 -0400151 case android.R.id.home:
152 finish();
153 return true;
alisiond9e29442013-04-17 16:10:18 -0400154 case R.id.menuitem_delete:
155 AlertDialog dialog = createDeleteDialog();
156 dialog.show();
157 break;
alisiond9e29442013-04-17 16:10:18 -0400158 case R.id.menuitem_edit:
159 processAccount(result.ACCOUNT_MODIFIED);
160 break;
161
162 }
163
164 return true;
165 }
166
167 private void processAccount(int resultCode) {
168 AlertDialog dialog;
169 ArrayList<String> missingValue = new ArrayList<String>();
170 if (validateAccountCreation(missingValue)) {
171
172 Bundle bundle = new Bundle();
173 bundle.putString("AccountID", mAccountID);
174 HashMap<String, String> accountDetails = new HashMap<String, String>();
175
176 updateAccountDetails(accountDetails, basicDetails);
177 updateAccountDetails(accountDetails, advancedDetails);
178 updateAccountDetails(accountDetails, srtpDetails);
179 updateAccountDetails(accountDetails, tlsDetails);
alision5cfc35d2013-07-11 15:11:39 -0400180
alision5de91782013-07-10 10:47:30 -0400181 accountDetails.put("Account.type", "SIP");
alisiond9e29442013-04-17 16:10:18 -0400182 bundle.putSerializable(AccountDetail.TAG, accountDetails);
183 Intent resultIntent = new Intent();
184 resultIntent.putExtras(bundle);
185
186 setResult(resultCode, resultIntent);
187 finish();
188 } else {
189 dialog = createCouldNotValidateDialog(missingValue);
190 dialog.show();
191 }
192
193 }
194
195 public boolean validateAccountCreation(ArrayList<String> missingValue) {
196 boolean valid = true;
197
198 for (String s : requiredFields) {
199 EditTextPreference pref = (EditTextPreference) mPreferenceManager.findPreference(s);
200 Log.i(TAG, "Looking for " + s);
alisioncc7bb422013-06-06 15:31:39 -0400201 Log.i(TAG, "Value " + pref.getText());
alisiond9e29442013-04-17 16:10:18 -0400202 if (pref.getText().isEmpty()) {
alisiond9e29442013-04-17 16:10:18 -0400203 valid = false;
204 missingValue.add(pref.getTitle().toString());
205 }
206 }
207
208 return valid;
209 }
210
alisiond9e29442013-04-17 16:10:18 -0400211 private void updateAccountDetails(HashMap<String, String> accountDetails, AccountDetail det) {
212 for (AccountDetail.PreferenceEntry p : det.getDetailValues()) {
alision5de91782013-07-10 10:47:30 -0400213
214 Log.i(TAG, "updateAccountDetails: pref " + p.mKey + " value " + det.getDetailString(p.mKey));
215 if (p.isTwoState) {
216 accountDetails.put(p.mKey, det.getDetailString(p.mKey));
217 } else {
alision5cfc35d2013-07-11 15:11:39 -0400218 // if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
219 // accountDetails.put(p.mKey, det.getDetailString(p.mKey));
220 // } else {
221 accountDetails.put(p.mKey, det.getDetailString(p.mKey));
222 // }
alisiond9e29442013-04-17 16:10:18 -0400223 }
alision5de91782013-07-10 10:47:30 -0400224
225 // Preference pref = mPreferenceManager.findPreference(p.mKey);
226 // if (pref != null) {
227 // if (p.isTwoState) {
228 // CheckBoxPreference boxPref = (CheckBoxPreference) pref;
229 // accountDetails.put(p.mKey, boxPref.isChecked() ? "true" : "false");
230 // } else {
231 // if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
232 // ListPreference list = (ListPreference) pref;
233 // accountDetails.put(p.mKey, list.getValue());
234 // } else {
235 // EditTextPreference textPref = (EditTextPreference) pref;
236 // accountDetails.put(p.mKey, textPref.getText());
237 // }
238 // }
239 // }
alisiond9e29442013-04-17 16:10:18 -0400240 }
241 }
242
243 Preference.OnPreferenceChangeListener changeBasicPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000244 @Override
alisiond9e29442013-04-17 16:10:18 -0400245 public boolean onPreferenceChange(Preference preference, Object newValue) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400246
247 isDifferent = true;
alision5de91782013-07-10 10:47:30 -0400248 if (preference instanceof CheckBoxPreference) {
249 if ((Boolean) newValue == true)
250 basicDetails.setDetailString(preference.getKey(), ((Boolean) newValue).toString());
251 } else {
252 preference.setSummary((CharSequence) newValue);
Adrien Béraud9360f242013-09-19 11:07:42 +1000253 Log.i(TAG, "Changing preference value:" + newValue);
alision5de91782013-07-10 10:47:30 -0400254 basicDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
255 }
alisiond9e29442013-04-17 16:10:18 -0400256 return true;
257 }
258 };
alision7f18fc82013-05-01 09:37:33 -0400259
alisione2a38e12013-04-25 14:20:20 -0400260 Preference.OnPreferenceChangeListener changeAdvancedPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000261 @Override
alisione2a38e12013-04-25 14:20:20 -0400262 public boolean onPreferenceChange(Preference preference, Object newValue) {
263 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400264 advancedDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400265 return true;
266 }
267 };
alision7f18fc82013-05-01 09:37:33 -0400268
alisione2a38e12013-04-25 14:20:20 -0400269 Preference.OnPreferenceChangeListener changeTlsPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000270 @Override
alisione2a38e12013-04-25 14:20:20 -0400271 public boolean onPreferenceChange(Preference preference, Object newValue) {
272 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400273 tlsDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400274 return true;
275 }
276 };
alision7f18fc82013-05-01 09:37:33 -0400277
alisione2a38e12013-04-25 14:20:20 -0400278 Preference.OnPreferenceChangeListener changeSrtpPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000279 @Override
alisione2a38e12013-04-25 14:20:20 -0400280 public boolean onPreferenceChange(Preference preference, Object newValue) {
281 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400282 srtpDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400283 return true;
284 }
285 };
alision7f18fc82013-05-01 09:37:33 -0400286
alisiond9e29442013-04-17 16:10:18 -0400287 private void setPreferenceDetails(AccountDetail details) {
288 for (AccountDetail.PreferenceEntry p : details.getDetailValues()) {
alision7f18fc82013-05-01 09:37:33 -0400289 Log.i(TAG, "setPreferenceDetails: pref " + p.mKey + " value " + p.mValue);
alisiond9e29442013-04-17 16:10:18 -0400290 Preference pref = mPreferenceManager.findPreference(p.mKey);
291 if (pref != null) {
alision7f18fc82013-05-01 09:37:33 -0400292 if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
alision73424b62013-04-26 11:49:18 -0400293 ArrayList<CharSequence> entries = new ArrayList<CharSequence>();
294 try {
alision7f18fc82013-05-01 09:37:33 -0400295
alision73424b62013-04-26 11:49:18 -0400296 for (Enumeration<NetworkInterface> list = NetworkInterface.getNetworkInterfaces(); list.hasMoreElements();) {
297 NetworkInterface i = list.nextElement();
298 Log.e("network_interfaces", "display name " + i.getDisplayName());
alision7f18fc82013-05-01 09:37:33 -0400299 if (i.isUp())
alision73424b62013-04-26 11:49:18 -0400300 entries.add(i.getDisplayName());
301 }
302 } catch (SocketException e) {
303 Log.e(TAG, e.toString());
304 }
305 CharSequence[] display = new CharSequence[entries.size()];
306 entries.toArray(display);
307 ((ListPreference) pref).setEntries(display);
308 ((ListPreference) pref).setEntryValues(display);
309 pref.setSummary(p.mValue);
310 continue;
311 }
alisiond9e29442013-04-17 16:10:18 -0400312 if (!p.isTwoState) {
313 ((EditTextPreference) pref).setText(p.mValue);
314 pref.setSummary(p.mValue);
Alexandre Savard68838112012-10-30 11:34:43 -0400315 }
alision73424b62013-04-26 11:49:18 -0400316 } else {
alision7f18fc82013-05-01 09:37:33 -0400317 Log.w(TAG, "pref not found");
Alexandre Savard68838112012-10-30 11:34:43 -0400318 }
319 }
320 }
321
alisione2a38e12013-04-25 14:20:20 -0400322 private void addPreferenceListener(AccountDetail details, OnPreferenceChangeListener listener) {
alisiond9e29442013-04-17 16:10:18 -0400323 for (AccountDetail.PreferenceEntry p : details.getDetailValues()) {
alision5de91782013-07-10 10:47:30 -0400324 Log.i(TAG, "addPreferenceListener: pref " + p.mKey + p.mValue);
Alexandre Savard68838112012-10-30 11:34:43 -0400325 Preference pref = mPreferenceManager.findPreference(p.mKey);
alisiond9e29442013-04-17 16:10:18 -0400326 if (pref != null) {
alision5de91782013-07-10 10:47:30 -0400327
328 pref.setOnPreferenceChangeListener(listener);
329
alision73424b62013-04-26 11:49:18 -0400330 } else {
alision7f18fc82013-05-01 09:37:33 -0400331 Log.w(TAG, "addPreferenceListener: pref not found");
Alexandre Savard68838112012-10-30 11:34:43 -0400332 }
333 }
334 }
335
alisiond9e29442013-04-17 16:10:18 -0400336 /******************************************
337 *
338 * AlertDialogs
339 *
340 ******************************************/
alision7f18fc82013-05-01 09:37:33 -0400341
alisiond9e29442013-04-17 16:10:18 -0400342 private AlertDialog createCouldNotValidateDialog(ArrayList<String> missingValue) {
343 String message = "The following parameters are missing:";
Alexandre Savard833616f2012-10-30 16:02:30 -0400344
alisiond9e29442013-04-17 16:10:18 -0400345 for (String s : missingValue)
346 message += "\n - " + s;
Alexandre Savard833616f2012-10-30 16:02:30 -0400347
alisiond9e29442013-04-17 16:10:18 -0400348 Activity ownerActivity = this;
349 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
350 builder.setMessage(message).setTitle("Missing Parameters").setPositiveButton("Ok", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000351 @Override
alisiond9e29442013-04-17 16:10:18 -0400352 public void onClick(DialogInterface dialog, int whichButton) {
353 /* Nothing to be done */
354 }
355 });
356
357 AlertDialog alertDialog = builder.create();
358 return alertDialog;
Alexandre Savard833616f2012-10-30 16:02:30 -0400359 }
alision7f18fc82013-05-01 09:37:33 -0400360
alisiond9e29442013-04-17 16:10:18 -0400361 private AlertDialog createCancelDialog() {
362 Activity ownerActivity = this;
363 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
Alexandre Lisiona764c682013-09-09 10:02:07 -0400364 builder.setMessage("Modifications will be lost").setTitle("Account Edition").setPositiveButton("Ok", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000365 @Override
alisiond9e29442013-04-17 16:10:18 -0400366 public void onClick(DialogInterface dialog, int whichButton) {
367 Activity activity = ((Dialog) dialog).getOwnerActivity();
368 activity.finish();
369 }
370 }).setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000371 @Override
alisiond9e29442013-04-17 16:10:18 -0400372 public void onClick(DialogInterface dialog, int whichButton) {
373 /* Terminate with no action */
374 }
375 });
Alexandre Savard833616f2012-10-30 16:02:30 -0400376
alisiond9e29442013-04-17 16:10:18 -0400377 AlertDialog alertDialog = builder.create();
378 alertDialog.setOwnerActivity(ownerActivity);
379
380 return alertDialog;
Alexandre Savard5195d922012-10-30 16:58:50 -0400381 }
alision7f18fc82013-05-01 09:37:33 -0400382
alisiond9e29442013-04-17 16:10:18 -0400383 private AlertDialog createDeleteDialog() {
Alexandre Savard645b29c2012-10-30 17:22:26 -0400384 Activity ownerActivity = this;
385 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
alision73424b62013-04-26 11:49:18 -0400386 builder.setMessage("Do you really want to delete this account").setTitle("Delete Account")
Adrien Béraud9360f242013-09-19 11:07:42 +1000387 .setPositiveButton("Ok", new DialogInterface.OnClickListener() {
388 @Override
389 public void onClick(DialogInterface dialog, int whichButton) {
390 Bundle bundle = new Bundle();
391 bundle.putString("AccountID", mAccountID);
Alexandre Savard645b29c2012-10-30 17:22:26 -0400392
Adrien Béraud9360f242013-09-19 11:07:42 +1000393 Intent resultIntent = new Intent();
394 resultIntent.putExtras(bundle);
Alexandre Savard645b29c2012-10-30 17:22:26 -0400395
Adrien Béraud9360f242013-09-19 11:07:42 +1000396 Activity activity = ((Dialog) dialog).getOwnerActivity();
397 activity.setResult(result.ACCOUNT_DELETED, resultIntent);
398 activity.finish();
399 }
400 }).setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
401 @Override
402 public void onClick(DialogInterface dialog, int whichButton) {
403 /* Terminate with no action */
404 }
405 });
Alexandre Savard645b29c2012-10-30 17:22:26 -0400406
407 AlertDialog alertDialog = builder.create();
408 alertDialog.setOwnerActivity(ownerActivity);
409
410 return alertDialog;
411 }
412
Alexandre Savard68838112012-10-30 11:34:43 -0400413}