blob: 2a99448957cf17860aa9031f146dd3b477c33044 [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
Alexandre Lision6e8931e2013-09-19 16:49:34 -040085 @SuppressWarnings("deprecation")
alisiond9e29442013-04-17 16:10:18 -040086 @Override
87 protected void onCreate(Bundle savedInstanceState) {
88 super.onCreate(savedInstanceState);
89 addPreferencesFromResource(R.xml.account_creation_preferences);
90 mPreferenceManager = getPreferenceManager();
Alexandre Savard68838112012-10-30 11:34:43 -040091
alision5cfc35d2013-07-11 15:11:39 -040092 initEdition();
alisiond9e29442013-04-17 16:10:18 -040093
alisioncc7bb422013-06-06 15:31:39 -040094 getActionBar().setDisplayHomeAsUpEnabled(true);
alision5de91782013-07-10 10:47:30 -040095
alisiond9e29442013-04-17 16:10:18 -040096 requiredFields = new ArrayList<String>();
97 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_ALIAS);
98 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_HOSTNAME);
99 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_USERNAME);
100 requiredFields.add(AccountDetailBasic.CONFIG_ACCOUNT_PASSWORD);
101
102 }
103
alisiond9e29442013-04-17 16:10:18 -0400104 private void initEdition() {
Alexandre Savard68838112012-10-30 11:34:43 -0400105
106 Bundle b = getIntent().getExtras();
107 mAccountID = b.getString("AccountID");
108 ArrayList<String> basicPreferenceList = b.getStringArrayList(AccountDetailBasic.BUNDLE_TAG);
109 ArrayList<String> advancedPreferenceList = b.getStringArrayList(AccountDetailAdvanced.BUNDLE_TAG);
110 ArrayList<String> srtpPreferenceList = b.getStringArrayList(AccountDetailSrtp.BUNDLE_TAG);
111 ArrayList<String> tlsPreferenceList = b.getStringArrayList(AccountDetailTls.BUNDLE_TAG);
alision7f18fc82013-05-01 09:37:33 -0400112
alisiond9e29442013-04-17 16:10:18 -0400113 basicDetails = new AccountDetailBasic(basicPreferenceList);
Alexandre Savard68838112012-10-30 11:34:43 -0400114 advancedDetails = new AccountDetailAdvanced(advancedPreferenceList);
115 srtpDetails = new AccountDetailSrtp(srtpPreferenceList);
116 tlsDetails = new AccountDetailTls(tlsPreferenceList);
117
118 setPreferenceDetails(basicDetails);
Alexandre Savard833616f2012-10-30 16:02:30 -0400119 setPreferenceDetails(advancedDetails);
120 setPreferenceDetails(srtpDetails);
121 setPreferenceDetails(tlsDetails);
122
alisione2a38e12013-04-25 14:20:20 -0400123 addPreferenceListener(basicDetails, changeBasicPreferenceListener);
alision5de91782013-07-10 10:47:30 -0400124 // addPreferenceListener(advancedDetails, changeAdvancedPreferenceListener);
125 // addPreferenceListener(srtpDetails, changeSrtpPreferenceListener);
126 // addPreferenceListener(tlsDetails, changeTlsPreferenceListener);
Alexandre Savard68838112012-10-30 11:34:43 -0400127 }
128
alisiond9e29442013-04-17 16:10:18 -0400129 @Override
130 public boolean onCreateOptionsMenu(Menu menu) {
131 MenuInflater inflater = getMenuInflater();
alision5cfc35d2013-07-11 15:11:39 -0400132 inflater.inflate(R.menu.account_edition, menu);
alisiond9e29442013-04-17 16:10:18 -0400133 return true;
134 }
135
136 @Override
137 public void onBackPressed() {
alision5cfc35d2013-07-11 15:11:39 -0400138
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400139 if (isDifferent) {
140 AlertDialog dialog = createCancelDialog();
141 dialog.show();
142 } else {
143 super.onBackPressed();
144 }
alisiond9e29442013-04-17 16:10:18 -0400145
146 }
147
alisiond9e29442013-04-17 16:10:18 -0400148 @Override
149 public boolean onOptionsItemSelected(MenuItem item) {
150
151 switch (item.getItemId()) {
alisioncc7bb422013-06-06 15:31:39 -0400152 case android.R.id.home:
153 finish();
154 return true;
alisiond9e29442013-04-17 16:10:18 -0400155 case R.id.menuitem_delete:
156 AlertDialog dialog = createDeleteDialog();
157 dialog.show();
158 break;
alisiond9e29442013-04-17 16:10:18 -0400159 case R.id.menuitem_edit:
160 processAccount(result.ACCOUNT_MODIFIED);
161 break;
162
163 }
164
165 return true;
166 }
167
168 private void processAccount(int resultCode) {
169 AlertDialog dialog;
170 ArrayList<String> missingValue = new ArrayList<String>();
171 if (validateAccountCreation(missingValue)) {
172
173 Bundle bundle = new Bundle();
174 bundle.putString("AccountID", mAccountID);
175 HashMap<String, String> accountDetails = new HashMap<String, String>();
176
177 updateAccountDetails(accountDetails, basicDetails);
178 updateAccountDetails(accountDetails, advancedDetails);
179 updateAccountDetails(accountDetails, srtpDetails);
180 updateAccountDetails(accountDetails, tlsDetails);
alision5cfc35d2013-07-11 15:11:39 -0400181
alision5de91782013-07-10 10:47:30 -0400182 accountDetails.put("Account.type", "SIP");
alisiond9e29442013-04-17 16:10:18 -0400183 bundle.putSerializable(AccountDetail.TAG, accountDetails);
184 Intent resultIntent = new Intent();
185 resultIntent.putExtras(bundle);
186
187 setResult(resultCode, resultIntent);
188 finish();
189 } else {
190 dialog = createCouldNotValidateDialog(missingValue);
191 dialog.show();
192 }
193
194 }
195
196 public boolean validateAccountCreation(ArrayList<String> missingValue) {
197 boolean valid = true;
198
199 for (String s : requiredFields) {
200 EditTextPreference pref = (EditTextPreference) mPreferenceManager.findPreference(s);
201 Log.i(TAG, "Looking for " + s);
alisioncc7bb422013-06-06 15:31:39 -0400202 Log.i(TAG, "Value " + pref.getText());
alisiond9e29442013-04-17 16:10:18 -0400203 if (pref.getText().isEmpty()) {
alisiond9e29442013-04-17 16:10:18 -0400204 valid = false;
205 missingValue.add(pref.getTitle().toString());
206 }
207 }
208
209 return valid;
210 }
211
alisiond9e29442013-04-17 16:10:18 -0400212 private void updateAccountDetails(HashMap<String, String> accountDetails, AccountDetail det) {
213 for (AccountDetail.PreferenceEntry p : det.getDetailValues()) {
alision5de91782013-07-10 10:47:30 -0400214
215 Log.i(TAG, "updateAccountDetails: pref " + p.mKey + " value " + det.getDetailString(p.mKey));
216 if (p.isTwoState) {
217 accountDetails.put(p.mKey, det.getDetailString(p.mKey));
218 } else {
alision5cfc35d2013-07-11 15:11:39 -0400219 // if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
220 // accountDetails.put(p.mKey, det.getDetailString(p.mKey));
221 // } else {
222 accountDetails.put(p.mKey, det.getDetailString(p.mKey));
223 // }
alisiond9e29442013-04-17 16:10:18 -0400224 }
alision5de91782013-07-10 10:47:30 -0400225
226 // Preference pref = mPreferenceManager.findPreference(p.mKey);
227 // if (pref != null) {
228 // if (p.isTwoState) {
229 // CheckBoxPreference boxPref = (CheckBoxPreference) pref;
230 // accountDetails.put(p.mKey, boxPref.isChecked() ? "true" : "false");
231 // } else {
232 // if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
233 // ListPreference list = (ListPreference) pref;
234 // accountDetails.put(p.mKey, list.getValue());
235 // } else {
236 // EditTextPreference textPref = (EditTextPreference) pref;
237 // accountDetails.put(p.mKey, textPref.getText());
238 // }
239 // }
240 // }
alisiond9e29442013-04-17 16:10:18 -0400241 }
242 }
243
244 Preference.OnPreferenceChangeListener changeBasicPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000245 @Override
alisiond9e29442013-04-17 16:10:18 -0400246 public boolean onPreferenceChange(Preference preference, Object newValue) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400247
248 isDifferent = true;
alision5de91782013-07-10 10:47:30 -0400249 if (preference instanceof CheckBoxPreference) {
250 if ((Boolean) newValue == true)
251 basicDetails.setDetailString(preference.getKey(), ((Boolean) newValue).toString());
252 } else {
253 preference.setSummary((CharSequence) newValue);
Adrien Béraud9360f242013-09-19 11:07:42 +1000254 Log.i(TAG, "Changing preference value:" + newValue);
alision5de91782013-07-10 10:47:30 -0400255 basicDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
256 }
alisiond9e29442013-04-17 16:10:18 -0400257 return true;
258 }
259 };
alision7f18fc82013-05-01 09:37:33 -0400260
alisione2a38e12013-04-25 14:20:20 -0400261 Preference.OnPreferenceChangeListener changeAdvancedPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000262 @Override
alisione2a38e12013-04-25 14:20:20 -0400263 public boolean onPreferenceChange(Preference preference, Object newValue) {
264 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400265 advancedDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400266 return true;
267 }
268 };
alision7f18fc82013-05-01 09:37:33 -0400269
alisione2a38e12013-04-25 14:20:20 -0400270 Preference.OnPreferenceChangeListener changeTlsPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000271 @Override
alisione2a38e12013-04-25 14:20:20 -0400272 public boolean onPreferenceChange(Preference preference, Object newValue) {
273 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400274 tlsDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400275 return true;
276 }
277 };
alision7f18fc82013-05-01 09:37:33 -0400278
alisione2a38e12013-04-25 14:20:20 -0400279 Preference.OnPreferenceChangeListener changeSrtpPreferenceListener = new Preference.OnPreferenceChangeListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000280 @Override
alisione2a38e12013-04-25 14:20:20 -0400281 public boolean onPreferenceChange(Preference preference, Object newValue) {
282 preference.setSummary((CharSequence) newValue);
alision5de91782013-07-10 10:47:30 -0400283 srtpDetails.setDetailString(preference.getKey(), ((CharSequence) newValue).toString());
alisione2a38e12013-04-25 14:20:20 -0400284 return true;
285 }
286 };
alision7f18fc82013-05-01 09:37:33 -0400287
alisiond9e29442013-04-17 16:10:18 -0400288 private void setPreferenceDetails(AccountDetail details) {
289 for (AccountDetail.PreferenceEntry p : details.getDetailValues()) {
alision7f18fc82013-05-01 09:37:33 -0400290 Log.i(TAG, "setPreferenceDetails: pref " + p.mKey + " value " + p.mValue);
alisiond9e29442013-04-17 16:10:18 -0400291 Preference pref = mPreferenceManager.findPreference(p.mKey);
292 if (pref != null) {
alision7f18fc82013-05-01 09:37:33 -0400293 if (p.mKey == AccountDetailAdvanced.CONFIG_LOCAL_INTERFACE) {
alision73424b62013-04-26 11:49:18 -0400294 ArrayList<CharSequence> entries = new ArrayList<CharSequence>();
295 try {
alision7f18fc82013-05-01 09:37:33 -0400296
alision73424b62013-04-26 11:49:18 -0400297 for (Enumeration<NetworkInterface> list = NetworkInterface.getNetworkInterfaces(); list.hasMoreElements();) {
298 NetworkInterface i = list.nextElement();
299 Log.e("network_interfaces", "display name " + i.getDisplayName());
alision7f18fc82013-05-01 09:37:33 -0400300 if (i.isUp())
alision73424b62013-04-26 11:49:18 -0400301 entries.add(i.getDisplayName());
302 }
303 } catch (SocketException e) {
304 Log.e(TAG, e.toString());
305 }
306 CharSequence[] display = new CharSequence[entries.size()];
307 entries.toArray(display);
308 ((ListPreference) pref).setEntries(display);
309 ((ListPreference) pref).setEntryValues(display);
310 pref.setSummary(p.mValue);
311 continue;
312 }
alisiond9e29442013-04-17 16:10:18 -0400313 if (!p.isTwoState) {
314 ((EditTextPreference) pref).setText(p.mValue);
315 pref.setSummary(p.mValue);
Alexandre Savard68838112012-10-30 11:34:43 -0400316 }
alision73424b62013-04-26 11:49:18 -0400317 } else {
alision7f18fc82013-05-01 09:37:33 -0400318 Log.w(TAG, "pref not found");
Alexandre Savard68838112012-10-30 11:34:43 -0400319 }
320 }
321 }
322
alisione2a38e12013-04-25 14:20:20 -0400323 private void addPreferenceListener(AccountDetail details, OnPreferenceChangeListener listener) {
alisiond9e29442013-04-17 16:10:18 -0400324 for (AccountDetail.PreferenceEntry p : details.getDetailValues()) {
alision5de91782013-07-10 10:47:30 -0400325 Log.i(TAG, "addPreferenceListener: pref " + p.mKey + p.mValue);
Alexandre Savard68838112012-10-30 11:34:43 -0400326 Preference pref = mPreferenceManager.findPreference(p.mKey);
alisiond9e29442013-04-17 16:10:18 -0400327 if (pref != null) {
alision5de91782013-07-10 10:47:30 -0400328
329 pref.setOnPreferenceChangeListener(listener);
330
alision73424b62013-04-26 11:49:18 -0400331 } else {
alision7f18fc82013-05-01 09:37:33 -0400332 Log.w(TAG, "addPreferenceListener: pref not found");
Alexandre Savard68838112012-10-30 11:34:43 -0400333 }
334 }
335 }
336
alisiond9e29442013-04-17 16:10:18 -0400337 /******************************************
338 *
339 * AlertDialogs
340 *
341 ******************************************/
alision7f18fc82013-05-01 09:37:33 -0400342
alisiond9e29442013-04-17 16:10:18 -0400343 private AlertDialog createCouldNotValidateDialog(ArrayList<String> missingValue) {
344 String message = "The following parameters are missing:";
Alexandre Savard833616f2012-10-30 16:02:30 -0400345
alisiond9e29442013-04-17 16:10:18 -0400346 for (String s : missingValue)
347 message += "\n - " + s;
Alexandre Savard833616f2012-10-30 16:02:30 -0400348
alisiond9e29442013-04-17 16:10:18 -0400349 Activity ownerActivity = this;
350 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
351 builder.setMessage(message).setTitle("Missing Parameters").setPositiveButton("Ok", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000352 @Override
alisiond9e29442013-04-17 16:10:18 -0400353 public void onClick(DialogInterface dialog, int whichButton) {
354 /* Nothing to be done */
355 }
356 });
357
358 AlertDialog alertDialog = builder.create();
359 return alertDialog;
Alexandre Savard833616f2012-10-30 16:02:30 -0400360 }
alision7f18fc82013-05-01 09:37:33 -0400361
alisiond9e29442013-04-17 16:10:18 -0400362 private AlertDialog createCancelDialog() {
363 Activity ownerActivity = this;
364 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
Alexandre Lisiona764c682013-09-09 10:02:07 -0400365 builder.setMessage("Modifications will be lost").setTitle("Account Edition").setPositiveButton("Ok", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000366 @Override
alisiond9e29442013-04-17 16:10:18 -0400367 public void onClick(DialogInterface dialog, int whichButton) {
368 Activity activity = ((Dialog) dialog).getOwnerActivity();
369 activity.finish();
370 }
371 }).setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000372 @Override
alisiond9e29442013-04-17 16:10:18 -0400373 public void onClick(DialogInterface dialog, int whichButton) {
374 /* Terminate with no action */
375 }
376 });
Alexandre Savard833616f2012-10-30 16:02:30 -0400377
alisiond9e29442013-04-17 16:10:18 -0400378 AlertDialog alertDialog = builder.create();
379 alertDialog.setOwnerActivity(ownerActivity);
380
381 return alertDialog;
Alexandre Savard5195d922012-10-30 16:58:50 -0400382 }
alision7f18fc82013-05-01 09:37:33 -0400383
alisiond9e29442013-04-17 16:10:18 -0400384 private AlertDialog createDeleteDialog() {
Alexandre Savard645b29c2012-10-30 17:22:26 -0400385 Activity ownerActivity = this;
386 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
alision73424b62013-04-26 11:49:18 -0400387 builder.setMessage("Do you really want to delete this account").setTitle("Delete Account")
Adrien Béraud9360f242013-09-19 11:07:42 +1000388 .setPositiveButton("Ok", new DialogInterface.OnClickListener() {
389 @Override
390 public void onClick(DialogInterface dialog, int whichButton) {
391 Bundle bundle = new Bundle();
392 bundle.putString("AccountID", mAccountID);
Alexandre Savard645b29c2012-10-30 17:22:26 -0400393
Adrien Béraud9360f242013-09-19 11:07:42 +1000394 Intent resultIntent = new Intent();
395 resultIntent.putExtras(bundle);
Alexandre Savard645b29c2012-10-30 17:22:26 -0400396
Adrien Béraud9360f242013-09-19 11:07:42 +1000397 Activity activity = ((Dialog) dialog).getOwnerActivity();
398 activity.setResult(result.ACCOUNT_DELETED, resultIntent);
399 activity.finish();
400 }
401 }).setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
402 @Override
403 public void onClick(DialogInterface dialog, int whichButton) {
404 /* Terminate with no action */
405 }
406 });
Alexandre Savard645b29c2012-10-30 17:22:26 -0400407
408 AlertDialog alertDialog = builder.create();
409 alertDialog.setOwnerActivity(ownerActivity);
410
411 return alertDialog;
412 }
413
Alexandre Savard68838112012-10-30 11:34:43 -0400414}