blob: 53a6c6e7fa6d8ec0eab9881e30325df6ad39ef00 [file] [log] [blame]
alisionf76de3b2013-04-16 15:35:22 -04001/*
alision2ec64f92013-06-17 17:28:58 -04002 * Copyright (C) 2004-2013 Savoir-Faire Linux Inc.
alisionf76de3b2013-04-16 15:35:22 -04003 *
4 * Author: Adrien Beraud <adrien.beraud@gmail.com>
alision11e8e162013-05-28 10:33:14 -04005 * Alexandre Lision <alexandre.lision@savoirfairelinux.com>
alisionf76de3b2013-04-16 15:35:22 -04006 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 *
21 * Additional permission under GNU GPL version 3 section 7:
22 *
23 * If you modify this program, or any covered work, by linking or
24 * combining it with the OpenSSL project's OpenSSL library (or a
25 * modified version of that library), containing parts covered by the
26 * terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
27 * grants you additional permission to convey the resulting work.
28 * Corresponding Source for a non-source form of such a combination
29 * shall include the source code for the parts of OpenSSL used as well
30 * as that of the covered work.
31 */
32package com.savoirfairelinux.sflphone.client;
33
alisionbd45a822013-06-06 17:35:35 -040034import java.util.Timer;
35import java.util.TimerTask;
alision84813a12013-05-27 17:40:39 -040036
alisionf76de3b2013-04-16 15:35:22 -040037import android.app.Activity;
Alexandre Lisionc51ccb12013-09-11 16:00:30 -040038import android.app.AlertDialog;
alisionf76de3b2013-04-16 15:35:22 -040039import android.content.ComponentName;
40import android.content.Context;
Alexandre Lisionc51ccb12013-09-11 16:00:30 -040041import android.content.DialogInterface;
alisionf76de3b2013-04-16 15:35:22 -040042import android.content.Intent;
alision84813a12013-05-27 17:40:39 -040043import android.content.IntentFilter;
alisionf76de3b2013-04-16 15:35:22 -040044import android.content.ServiceConnection;
alisionf57d8a62013-07-02 09:37:12 -040045import android.content.res.Configuration;
alision55c36cb2013-06-14 14:57:38 -040046import android.database.Cursor;
alisionf76de3b2013-04-16 15:35:22 -040047import android.os.Bundle;
48import android.os.IBinder;
alision5f899632013-04-22 17:26:56 -040049import android.os.RemoteException;
alision55c36cb2013-06-14 14:57:38 -040050import android.provider.ContactsContract.CommonDataKinds.Phone;
51import android.provider.ContactsContract.CommonDataKinds.SipAddress;
alision9f7a6ec2013-05-24 16:26:26 -040052import android.support.v4.app.ActionBarDrawerToggle;
53import android.support.v4.view.GravityCompat;
Alexandre Lisionf41a3a82013-09-05 17:15:15 -040054import android.support.v4.view.PagerTabStrip;
alisionf76de3b2013-04-16 15:35:22 -040055import android.support.v4.view.ViewPager;
alision9f7a6ec2013-05-24 16:26:26 -040056import android.support.v4.widget.DrawerLayout;
alisionf76de3b2013-04-16 15:35:22 -040057import android.util.Log;
Alexandre Lisionf41a3a82013-09-05 17:15:15 -040058import android.util.TypedValue;
alision9f7a6ec2013-05-24 16:26:26 -040059import android.view.MenuItem;
60import android.view.View;
alision7297bdb2013-05-21 11:56:55 -040061import android.widget.RelativeLayout;
alision04a00182013-05-10 17:05:29 -040062import android.widget.Toast;
alisionf76de3b2013-04-16 15:35:22 -040063
64import com.savoirfairelinux.sflphone.R;
alision9f7a6ec2013-05-24 16:26:26 -040065import com.savoirfairelinux.sflphone.adapters.SectionsPagerAdapter;
alisionf76de3b2013-04-16 15:35:22 -040066import com.savoirfairelinux.sflphone.fragments.ContactListFragment;
alision7297bdb2013-05-21 11:56:55 -040067import com.savoirfairelinux.sflphone.fragments.DialingFragment;
alisiond9e29442013-04-17 16:10:18 -040068import com.savoirfairelinux.sflphone.fragments.HistoryFragment;
alision55c36cb2013-06-14 14:57:38 -040069import com.savoirfairelinux.sflphone.fragments.HomeFragment;
alision9f7a6ec2013-05-24 16:26:26 -040070import com.savoirfairelinux.sflphone.fragments.MenuFragment;
alision84813a12013-05-27 17:40:39 -040071import com.savoirfairelinux.sflphone.interfaces.CallInterface;
alision2ec64f92013-06-17 17:28:58 -040072import com.savoirfairelinux.sflphone.loaders.LoaderConstants;
alision84813a12013-05-27 17:40:39 -040073import com.savoirfairelinux.sflphone.model.CallContact;
alisiondf1dac92013-06-27 17:35:53 -040074import com.savoirfairelinux.sflphone.model.Conference;
alisionf76de3b2013-04-16 15:35:22 -040075import com.savoirfairelinux.sflphone.model.SipCall;
alisioncc7bb422013-06-06 15:31:39 -040076import com.savoirfairelinux.sflphone.receivers.CallReceiver;
alision84813a12013-05-27 17:40:39 -040077import com.savoirfairelinux.sflphone.service.CallManagerCallBack;
alisionf76de3b2013-04-16 15:35:22 -040078import com.savoirfairelinux.sflphone.service.ISipService;
79import com.savoirfairelinux.sflphone.service.SipService;
alision7297bdb2013-05-21 11:56:55 -040080import com.savoirfairelinux.sflphone.views.CustomSlidingDrawer;
alisionf76de3b2013-04-16 15:35:22 -040081
alision907bde72013-06-20 14:40:37 -040082public class SFLPhoneHomeActivity extends Activity implements DialingFragment.Callbacks, ContactListFragment.Callbacks, HomeFragment.Callbacks,
83 HistoryFragment.Callbacks, CallInterface, MenuFragment.Callbacks {
alisionfde875f2013-05-28 17:01:54 -040084
alision9f7a6ec2013-05-24 16:26:26 -040085 SectionsPagerAdapter mSectionsPagerAdapter = null;
alision84813a12013-05-27 17:40:39 -040086 static final String TAG = "SFLPhoneHomeActivity";
alisionf76de3b2013-04-16 15:35:22 -040087
alision9f7a6ec2013-05-24 16:26:26 -040088 private ContactListFragment mContactsFragment = null;
alision907bde72013-06-20 14:40:37 -040089 private MenuFragment fMenu;
alisionf76de3b2013-04-16 15:35:22 -040090
alision9f7a6ec2013-05-24 16:26:26 -040091 private boolean mBound = false;
92 private ISipService service;
alisionf76de3b2013-04-16 15:35:22 -040093
alision9f7a6ec2013-05-24 16:26:26 -040094 private CharSequence mDrawerTitle;
95 private CharSequence mTitle;
alisionf76de3b2013-04-16 15:35:22 -040096
alision2cb99562013-05-30 17:02:20 -040097 public static final int REQUEST_CODE_PREFERENCES = 1;
alision9f7a6ec2013-05-24 16:26:26 -040098 private static final int REQUEST_CODE_CALL = 2;
alisionf76de3b2013-04-16 15:35:22 -040099
alision0b553832013-05-30 09:31:06 -0400100 RelativeLayout mSliderButton;
alision9f7a6ec2013-05-24 16:26:26 -0400101 CustomSlidingDrawer mDrawer;
alision9f7a6ec2013-05-24 16:26:26 -0400102 private DrawerLayout mDrawerLayout;
alision9f7a6ec2013-05-24 16:26:26 -0400103 private ActionBarDrawerToggle mDrawerToggle;
104 /**
105 * The {@link ViewPager} that will host the section contents.
106 */
107 ViewPager mViewPager;
alisionf76de3b2013-04-16 15:35:22 -0400108
alision58356b72013-06-03 17:13:36 -0400109 CallReceiver callReceiver;
alision84813a12013-05-27 17:40:39 -0400110
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400111 // private TabHost mTabHost;
alisionf76de3b2013-04-16 15:35:22 -0400112
alision9f7a6ec2013-05-24 16:26:26 -0400113 // public SFLPhoneHome extends Activity implements ActionBar.TabListener, OnClickListener
114
115 /* called before activity is killed, e.g. rotation */
116 @Override
117 protected void onSaveInstanceState(Bundle bundle) {
118 super.onSaveInstanceState(bundle);
119 for (int i = 0; i < mSectionsPagerAdapter.getCount(); i++) {
120 try {
121 getFragmentManager().putFragment(bundle, mSectionsPagerAdapter.getClassName(i), mSectionsPagerAdapter.getItem(i));
122 } catch (IllegalStateException e) {
123 Log.e(TAG, "fragment=" + mSectionsPagerAdapter.getItem(i));
124 }
125 }
126
127 getFragmentManager().putFragment(bundle, "ContactsListFragment", mContactsFragment);
128 Log.w(TAG, "onSaveInstanceState()");
129 }
130
131 @Override
132 public void onCreate(Bundle savedInstanceState) {
133 super.onCreate(savedInstanceState);
134
alision58356b72013-06-03 17:13:36 -0400135 callReceiver = new CallReceiver(this);
alision907bde72013-06-20 14:40:37 -0400136
alision2cb99562013-05-30 17:02:20 -0400137 // String libraryPath = getApplicationInfo().dataDir + "/lib";
138 // Log.i(TAG, libraryPath);
alision9f7a6ec2013-05-24 16:26:26 -0400139
alision58356b72013-06-03 17:13:36 -0400140 setContentView(R.layout.activity_sflphone_home);
141
alision9f7a6ec2013-05-24 16:26:26 -0400142 // Bind to LocalService
143 if (!mBound) {
144 Log.i(TAG, "onStart: Binding service...");
145 Intent intent = new Intent(this, SipService.class);
146 bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
147 }
Alexandre Lisionebeb3662013-09-17 16:20:54 -0400148
alision9f7a6ec2013-05-24 16:26:26 -0400149 if (mContactsFragment == null) {
150 mContactsFragment = new ContactListFragment();
151 Log.w(TAG, "Recreated mContactListFragment=" + mContactsFragment);
152 getFragmentManager().beginTransaction().replace(R.id.contacts_frame, mContactsFragment).commit();
153 }
alision2ec64f92013-06-17 17:28:58 -0400154
alision9f7a6ec2013-05-24 16:26:26 -0400155 mDrawer = (CustomSlidingDrawer) findViewById(R.id.custom_sliding_drawer);
alision7297bdb2013-05-21 11:56:55 -0400156
alision84813a12013-05-27 17:40:39 -0400157 mContactsFragment.setHandleView((RelativeLayout) findViewById(R.id.slider_button));
alision7297bdb2013-05-21 11:56:55 -0400158
159 mDrawer.setmTrackHandle(findViewById(R.id.handle_title));
alisionf76de3b2013-04-16 15:35:22 -0400160
alision9f7a6ec2013-05-24 16:26:26 -0400161 // Set up the ViewPager with the sections adapter.
162 mViewPager = (ViewPager) findViewById(R.id.pager);
alision55c36cb2013-06-14 14:57:38 -0400163 mViewPager.setPageTransformer(true, new ZoomOutPageTransformer(0.7f));
Alexandre Lisionebeb3662013-09-17 16:20:54 -0400164 final PagerTabStrip strip = PagerTabStrip.class.cast(mViewPager.findViewById(R.id.pts_main));
165 strip.setDrawFullUnderline(false);
166 strip.setTabIndicatorColor(getResources().getColor(R.color.holo_blue_dark));
167 strip.setBackgroundColor(getResources().getColor(R.color.darker_gray));
168 strip.setNonPrimaryAlpha(0.5f);
169 strip.setTextSpacing(25);
170 strip.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
alisionf76de3b2013-04-16 15:35:22 -0400171
alision9f7a6ec2013-05-24 16:26:26 -0400172 mTitle = mDrawerTitle = getTitle();
173 mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
alisionf76de3b2013-04-16 15:35:22 -0400174
alision0b553832013-05-30 09:31:06 -0400175 // set a custom shadow that overlays the main content when the drawer opens
alision9f7a6ec2013-05-24 16:26:26 -0400176 mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.START);
alisionf76de3b2013-04-16 15:35:22 -0400177
alision9f7a6ec2013-05-24 16:26:26 -0400178 getActionBar().setDisplayHomeAsUpEnabled(true);
179 getActionBar().setHomeButtonEnabled(true);
alisionf76de3b2013-04-16 15:35:22 -0400180
alision9f7a6ec2013-05-24 16:26:26 -0400181 mDrawerToggle = new ActionBarDrawerToggle(this, /* host Activity */
182 mDrawerLayout, /* DrawerLayout object */
183 R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
184 R.string.drawer_open, /* "open drawer" description for accessibility */
185 R.string.drawer_close /* "close drawer" description for accessibility */
186 ) {
alision0b553832013-05-30 09:31:06 -0400187 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400188 public void onDrawerClosed(View view) {
189 getActionBar().setTitle(mTitle);
190 invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu()
191 }
alisionf76de3b2013-04-16 15:35:22 -0400192
alision0b553832013-05-30 09:31:06 -0400193 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400194 public void onDrawerOpened(View drawerView) {
195 getActionBar().setTitle(mDrawerTitle);
196 invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu()
197 }
198 };
alisionf76de3b2013-04-16 15:35:22 -0400199
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400200 // mTabHost = (TabHost) findViewById(android.R.id.tabhost);
alision9f7a6ec2013-05-24 16:26:26 -0400201 mDrawerLayout.setDrawerListener(mDrawerToggle);
alisionf76de3b2013-04-16 15:35:22 -0400202
alision9f7a6ec2013-05-24 16:26:26 -0400203 mViewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
204 @Override
205 public void onPageSelected(int position) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400206 // mTabHost.setCurrentTab(position);
alision9f7a6ec2013-05-24 16:26:26 -0400207 }
208 });
alisionf76de3b2013-04-16 15:35:22 -0400209
alision9f7a6ec2013-05-24 16:26:26 -0400210 }
alisionf76de3b2013-04-16 15:35:22 -0400211
alisionf57d8a62013-07-02 09:37:12 -0400212 @Override
213 protected void onPostCreate(Bundle savedInstanceState) {
214 super.onPostCreate(savedInstanceState);
215 // Sync the toggle state after onRestoreInstanceState has occurred.
216 mDrawerToggle.syncState();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400217
218// Toast.makeText(this, "Mini Buff:"+AudioTrack.getMinBufferSize(8000, AudioFormat.CHANNEL_OUT_STEREO, AudioFormat.ENCODING_PCM_16BIT), Toast.LENGTH_LONG).show();
alisionf57d8a62013-07-02 09:37:12 -0400219 }
alision465ceba2013-07-04 09:24:30 -0400220
alisionf57d8a62013-07-02 09:37:12 -0400221 @Override
222 public void onConfigurationChanged(Configuration newConfig) {
223 super.onConfigurationChanged(newConfig);
224 mDrawerToggle.onConfigurationChanged(newConfig);
225 }
alision3c5c2a92013-05-30 09:50:47 -0400226
alision9f7a6ec2013-05-24 16:26:26 -0400227 @Override
228 protected void onStart() {
229 Log.i(TAG, "onStart");
230 super.onStart();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400231
alision9f7a6ec2013-05-24 16:26:26 -0400232 }
alisionf76de3b2013-04-16 15:35:22 -0400233
alision9f7a6ec2013-05-24 16:26:26 -0400234 /* user gets back to the activity, e.g. through task manager */
235 @Override
236 protected void onRestart() {
237 super.onRestart();
238 }
alisionf76de3b2013-04-16 15:35:22 -0400239
alision9f7a6ec2013-05-24 16:26:26 -0400240 /* activity gets back to the foreground and user input */
241 @Override
242 protected void onResume() {
alision58356b72013-06-03 17:13:36 -0400243 super.onResume();
alision84813a12013-05-27 17:40:39 -0400244 IntentFilter intentFilter = new IntentFilter();
245 intentFilter.addAction(CallManagerCallBack.INCOMING_CALL);
246 intentFilter.addAction(CallManagerCallBack.INCOMING_TEXT);
247 intentFilter.addAction(CallManagerCallBack.CALL_STATE_CHANGED);
alision58356b72013-06-03 17:13:36 -0400248 registerReceiver(callReceiver, intentFilter);
alision907bde72013-06-20 14:40:37 -0400249
alision9f7a6ec2013-05-24 16:26:26 -0400250 }
alision907bde72013-06-20 14:40:37 -0400251
alisionbd45a822013-06-06 17:35:35 -0400252 private boolean isClosing = false;
253 private Timer t = new Timer();
alision907bde72013-06-20 14:40:37 -0400254
alisionbd45a822013-06-06 17:35:35 -0400255 @Override
256 public void onBackPressed() {
alision907bde72013-06-20 14:40:37 -0400257
258 if (getActionBar().getCustomView() != null) {
alision2ec64f92013-06-17 17:28:58 -0400259 getActionBar().setDisplayShowCustomEnabled(false);
260 getActionBar().setCustomView(null);
261 // Display all the contacts again
262 getLoaderManager().restartLoader(LoaderConstants.CONTACT_LOADER, null, mContactsFragment);
263 return;
264 }
alision907bde72013-06-20 14:40:37 -0400265
alisionbd45a822013-06-06 17:35:35 -0400266 if (mDrawer.isOpened()) {
alision55c36cb2013-06-14 14:57:38 -0400267 mDrawer.animateClose();
alisionbd45a822013-06-06 17:35:35 -0400268 return;
269 }
alision2ec64f92013-06-17 17:28:58 -0400270
alisionbd45a822013-06-06 17:35:35 -0400271 if (isClosing) {
272 super.onBackPressed();
273 t.cancel();
274 finish();
275 } else {
276
277 t.schedule(new TimerTask() {
278 @Override
279 public void run() {
280 isClosing = false;
281 }
282 }, 3000);
283 Toast.makeText(this, getResources().getString(R.string.close_msg), Toast.LENGTH_SHORT).show();
284 isClosing = true;
285 }
286 }
alisione2a38e12013-04-25 14:20:20 -0400287
alision9f7a6ec2013-05-24 16:26:26 -0400288 /* activity no more in foreground */
289 @Override
290 protected void onPause() {
291 super.onPause();
alision58356b72013-06-03 17:13:36 -0400292 unregisterReceiver(callReceiver);
alision55c36cb2013-06-14 14:57:38 -0400293 try {
294 service.createNotification();
295
296 } catch (RemoteException e) {
297 Log.e(TAG, e.toString());
298 }
alision2cb99562013-05-30 17:02:20 -0400299
alision9f7a6ec2013-05-24 16:26:26 -0400300 }
alisionf76de3b2013-04-16 15:35:22 -0400301
alision9f7a6ec2013-05-24 16:26:26 -0400302 /* activity is no longer visible */
303 @Override
304 protected void onStop() {
305 super.onStop();
alision2cb99562013-05-30 17:02:20 -0400306
alision9f7a6ec2013-05-24 16:26:26 -0400307 }
alisionf76de3b2013-04-16 15:35:22 -0400308
alision9f7a6ec2013-05-24 16:26:26 -0400309 /* activity finishes itself or is being killed by the system */
310 @Override
311 protected void onDestroy() {
312 /* stop the service, if no other bound user, no need to check if it is running */
313 if (mBound) {
314 Log.i(TAG, "onDestroy: Unbinding service...");
alision907bde72013-06-20 14:40:37 -0400315
alision9f7a6ec2013-05-24 16:26:26 -0400316 unbindService(mConnection);
317 mBound = false;
alision2cb99562013-05-30 17:02:20 -0400318
alision9f7a6ec2013-05-24 16:26:26 -0400319 }
alision371b77e2013-04-23 14:51:26 -0400320
alision9f7a6ec2013-05-24 16:26:26 -0400321 super.onDestroy();
322 }
alision73424b62013-04-26 11:49:18 -0400323
alision55c36cb2013-06-14 14:57:38 -0400324 public void launchCallActivity(SipCall infos) {
alision9f7a6ec2013-05-24 16:26:26 -0400325 Log.i(TAG, "Launch Call Activity");
326 Bundle bundle = new Bundle();
alisiondf1dac92013-06-27 17:35:53 -0400327 Conference tmp = new Conference("-1");
alision465ceba2013-07-04 09:24:30 -0400328
alisiondf1dac92013-06-27 17:35:53 -0400329 tmp.getParticipants().add(infos);
alision465ceba2013-07-04 09:24:30 -0400330
alisiondf1dac92013-06-27 17:35:53 -0400331 bundle.putParcelable("conference", tmp);
alision9f7a6ec2013-05-24 16:26:26 -0400332 Intent intent = new Intent().setClass(this, CallActivity.class);
alisiondf1dac92013-06-27 17:35:53 -0400333 intent.putExtra("resuming", false);
alision9f7a6ec2013-05-24 16:26:26 -0400334 intent.putExtras(bundle);
335 startActivityForResult(intent, REQUEST_CODE_CALL);
alision465ceba2013-07-04 09:24:30 -0400336 overridePendingTransition(R.anim.slide_down, R.anim.slide_up);
alision9f7a6ec2013-05-24 16:26:26 -0400337 }
alisionf76de3b2013-04-16 15:35:22 -0400338
alision9f7a6ec2013-05-24 16:26:26 -0400339 /** Defines callbacks for service binding, passed to bindService() */
340 private ServiceConnection mConnection = new ServiceConnection() {
alision371b77e2013-04-23 14:51:26 -0400341
alision9f7a6ec2013-05-24 16:26:26 -0400342 @Override
343 public void onServiceConnected(ComponentName className, IBinder binder) {
344 service = ISipService.Stub.asInterface(binder);
alisione2a38e12013-04-25 14:20:20 -0400345
alision2cb99562013-05-30 17:02:20 -0400346 try {
alision58356b72013-06-03 17:13:36 -0400347
alision907bde72013-06-20 14:40:37 -0400348 fMenu = new MenuFragment();
349 getFragmentManager().beginTransaction().replace(R.id.left_drawer, fMenu).commit();
alision58356b72013-06-03 17:13:36 -0400350 mSectionsPagerAdapter = new SectionsPagerAdapter(SFLPhoneHomeActivity.this, getFragmentManager());
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400351
Alexandre Lisionebeb3662013-09-17 16:20:54 -0400352
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400353
354 // initialiseTabHost(null);
alisiondf1dac92013-06-27 17:35:53 -0400355 mViewPager.setOffscreenPageLimit(2);
alision58356b72013-06-03 17:13:36 -0400356 mViewPager.setAdapter(mSectionsPagerAdapter);
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400357 mViewPager.setCurrentItem(1);
358 // mTabHost.setCurrentTab(1);
alision2cb99562013-05-30 17:02:20 -0400359 service.destroyNotification();
alision58356b72013-06-03 17:13:36 -0400360 // mAdapter = new AccountSelectionAdapter(SFLPhoneHomeActivity.this, service, new ArrayList<Account>());
361 // spinnerAccounts.setAdapter(mAdapter);
alision2cb99562013-05-30 17:02:20 -0400362 } catch (RemoteException e) {
363 Log.e(TAG, e.toString());
364 }
alision9f7a6ec2013-05-24 16:26:26 -0400365 mBound = true;
alision9f7a6ec2013-05-24 16:26:26 -0400366 Log.d(TAG, "Service connected service=" + service);
alision371b77e2013-04-23 14:51:26 -0400367
alision9f7a6ec2013-05-24 16:26:26 -0400368 }
alision5f899632013-04-22 17:26:56 -0400369
alision9f7a6ec2013-05-24 16:26:26 -0400370 @Override
371 public void onServiceDisconnected(ComponentName arg0) {
alision5f899632013-04-22 17:26:56 -0400372
alision9f7a6ec2013-05-24 16:26:26 -0400373 mBound = false;
374 Log.d(TAG, "Service disconnected service=" + service);
375 }
376 };
alision5f899632013-04-22 17:26:56 -0400377
alision9f7a6ec2013-05-24 16:26:26 -0400378 @Override
379 public boolean onOptionsItemSelected(MenuItem item) {
380 Log.i(TAG, "onOptionsItemSelected " + item.getItemId());
alision5f899632013-04-22 17:26:56 -0400381
alision9f7a6ec2013-05-24 16:26:26 -0400382 if (mDrawerToggle.onOptionsItemSelected(item)) {
383 return true;
384 }
alision5f899632013-04-22 17:26:56 -0400385
alision9f7a6ec2013-05-24 16:26:26 -0400386 return super.onOptionsItemSelected(item);
387 }
alisionf76de3b2013-04-16 15:35:22 -0400388
alision9f7a6ec2013-05-24 16:26:26 -0400389 @Override
390 public void onActivityResult(int requestCode, int resultCode, Intent data) {
391 super.onActivityResult(requestCode, resultCode, data);
alision84813a12013-05-27 17:40:39 -0400392
393 switch (requestCode) {
alision9f7a6ec2013-05-24 16:26:26 -0400394 case REQUEST_CODE_PREFERENCES:
alision907bde72013-06-20 14:40:37 -0400395 Log.w(TAG, "In Activity");
396 fMenu.updateAllAccounts();
alision9f7a6ec2013-05-24 16:26:26 -0400397 break;
398 case REQUEST_CODE_CALL:
alision2cb99562013-05-30 17:02:20 -0400399 Log.w(TAG, "Result out of CallActivity");
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400400 if (resultCode == CallActivity.RESULT_FAILURE) {
401 Log.w(TAG, "CALL FAILEEEED");
402 }
403 // if (mSectionsPagerAdapter != null && mSectionsPagerAdapter.getItem(2) != null)
404 // getLoaderManager().restartLoader(LoaderConstants.HISTORY_LOADER, null, (HistoryFragment) mSectionsPagerAdapter.getItem(2));
alision9f7a6ec2013-05-24 16:26:26 -0400405 break;
406 }
alisionf76de3b2013-04-16 15:35:22 -0400407
alision9f7a6ec2013-05-24 16:26:26 -0400408 }
alisionf76de3b2013-04-16 15:35:22 -0400409
alision9f7a6ec2013-05-24 16:26:26 -0400410 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400411 public ISipService getService() {
412 return service;
413 }
alisionf76de3b2013-04-16 15:35:22 -0400414
alision84813a12013-05-27 17:40:39 -0400415 /**
416 * Interface implemented to handle incoming events
417 */
alision9f7a6ec2013-05-24 16:26:26 -0400418 @Override
alision84813a12013-05-27 17:40:39 -0400419 public void incomingCall(Intent call) {
420 Toast.makeText(this, "New Call incoming", Toast.LENGTH_LONG).show();
alisionfde875f2013-05-28 17:01:54 -0400421 SipCall infos = call.getParcelableExtra("newcall");
alision84813a12013-05-27 17:40:39 -0400422
alision58356b72013-06-03 17:13:36 -0400423 // mCallElementList.addCall(infos);
alisionfde875f2013-05-28 17:01:54 -0400424
alision55c36cb2013-06-14 14:57:38 -0400425 launchCallActivity(infos);
alision84813a12013-05-27 17:40:39 -0400426
427 }
428
429 @Override
430 public void callStateChanged(Intent callState) {
431 Bundle b = callState.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate");
432 String cID = b.getString("CallID");
433 String state = b.getString("State");
434 Log.i(TAG, "callStateChanged" + cID + " " + state);
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400435 mSectionsPagerAdapter.updateHome();
alision84813a12013-05-27 17:40:39 -0400436
437 }
438
439 @Override
440 public void incomingText(Intent msg) {
441 Bundle b = msg.getBundleExtra("com.savoirfairelinux.sflphone.service.newtext");
442 b.getString("CallID");
443 String from = b.getString("From");
444 String mess = b.getString("Msg");
445 Toast.makeText(getApplicationContext(), "text from " + from + " : " + mess, Toast.LENGTH_LONG).show();
446 }
447
448 @Override
alision55c36cb2013-06-14 14:57:38 -0400449 public void onContactSelected(final CallContact c) {
Alexandre Lisionf0b993d2013-09-12 13:25:10 -0400450
451 if (fMenu.getSelectedAccount() == null) {
452 // Toast.makeText(this, "No Account Selected", Toast.LENGTH_SHORT).show();
453 createAccountDialog().show();
454 return;
455 }
alisionfde875f2013-05-28 17:01:54 -0400456
alision55c36cb2013-06-14 14:57:38 -0400457 Thread launcher = new Thread(new Runnable() {
alision907bde72013-06-20 14:40:37 -0400458
alision55c36cb2013-06-14 14:57:38 -0400459 final String[] CONTACTS_PHONES_PROJECTION = new String[] { Phone.NUMBER, Phone.TYPE };
460 final String[] CONTACTS_SIP_PROJECTION = new String[] { SipAddress.SIP_ADDRESS, SipAddress.TYPE };
alision907bde72013-06-20 14:40:37 -0400461
alision55c36cb2013-06-14 14:57:38 -0400462 @Override
463 public void run() {
464 SipCall.SipCallBuilder callBuilder = SipCall.SipCallBuilder.getInstance();
465 try {
Alexandre Lisionf0b993d2013-09-12 13:25:10 -0400466 callBuilder.startCallCreation().setAccountID(fMenu.getSelectedAccount().getAccountID())
alision907bde72013-06-20 14:40:37 -0400467 .setCallType(SipCall.state.CALL_TYPE_OUTGOING);
468 Cursor cPhones = getContentResolver().query(Phone.CONTENT_URI, CONTACTS_PHONES_PROJECTION, Phone.CONTACT_ID + " =" + c.getId(),
469 null, null);
alision55c36cb2013-06-14 14:57:38 -0400470
alision907bde72013-06-20 14:40:37 -0400471 while (cPhones.moveToNext()) {
472 c.addPhoneNumber(cPhones.getString(cPhones.getColumnIndex(Phone.NUMBER)), cPhones.getInt(cPhones.getColumnIndex(Phone.TYPE)));
473 }
474 cPhones.close();
475
476 Cursor cSip = getContentResolver().query(Phone.CONTENT_URI, CONTACTS_SIP_PROJECTION, Phone.CONTACT_ID + "=" + c.getId(), null,
477 null);
478
479 while (cSip.moveToNext()) {
480 c.addSipNumber(cSip.getString(cSip.getColumnIndex(SipAddress.SIP_ADDRESS)), cSip.getInt(cSip.getColumnIndex(SipAddress.TYPE)));
481 }
482 cSip.close();
483 callBuilder.setContact(c);
alision55c36cb2013-06-14 14:57:38 -0400484 launchCallActivity(callBuilder.build());
485 } catch (RemoteException e1) {
486 Log.e(TAG, e1.toString());
487 } catch (Exception e) {
488 Log.e(TAG, e.toString());
489 }
alision907bde72013-06-20 14:40:37 -0400490
alision55c36cb2013-06-14 14:57:38 -0400491 }
492 });
493 launcher.start();
494 mDrawer.close();
alision84813a12013-05-27 17:40:39 -0400495
496 }
497
498 @Override
alision907bde72013-06-20 14:40:37 -0400499 public void onCallDialed(String to) {
alision84813a12013-05-27 17:40:39 -0400500
alisiondf1dac92013-06-27 17:35:53 -0400501 if (fMenu.getSelectedAccount() == null) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400502 // Toast.makeText(this, "No Account Selected", Toast.LENGTH_SHORT).show();
503 createAccountDialog().show();
alisiondf1dac92013-06-27 17:35:53 -0400504 return;
505 }
506
alisionfde875f2013-05-28 17:01:54 -0400507 SipCall.SipCallBuilder callBuilder = SipCall.SipCallBuilder.getInstance();
alision907bde72013-06-20 14:40:37 -0400508 callBuilder.startCallCreation().setAccountID(fMenu.getSelectedAccount().getAccountID()).setCallType(SipCall.state.CALL_TYPE_OUTGOING);
509 callBuilder.setContact(CallContact.ContactBuilder.buildUnknownContact(to));
alision84813a12013-05-27 17:40:39 -0400510
alisionfde875f2013-05-28 17:01:54 -0400511 try {
alision55c36cb2013-06-14 14:57:38 -0400512 launchCallActivity(callBuilder.build());
alisionfde875f2013-05-28 17:01:54 -0400513 } catch (Exception e) {
514 Log.e(TAG, e.toString());
515 }
alision84813a12013-05-27 17:40:39 -0400516
alision9f7a6ec2013-05-24 16:26:26 -0400517 }
alision371b77e2013-04-23 14:51:26 -0400518
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400519 private AlertDialog createAccountDialog() {
520 final Activity ownerActivity = this;
521 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
522
523 builder.setMessage(getResources().getString(R.string.create_new_account_dialog))
524 .setTitle(getResources().getString(R.string.create_new_account_dialog_title))
525 .setPositiveButton(getResources().getString(android.R.string.ok), new DialogInterface.OnClickListener() {
526 public void onClick(DialogInterface dialog, int whichButton) {
527 Intent in = new Intent();
528 in.setClass(ownerActivity, SFLPhonePreferenceActivity.class);
529 ownerActivity.startActivityForResult(in, SFLPhoneHomeActivity.REQUEST_CODE_PREFERENCES);
530 }
531 }).setNegativeButton(getResources().getString(android.R.string.cancel), new DialogInterface.OnClickListener() {
532 public void onClick(DialogInterface dialog, int whichButton) {
533 dialog.dismiss();
534 }
535 });
536
537 AlertDialog alertDialog = builder.create();
538 alertDialog.setOwnerActivity(ownerActivity);
539
540 return alertDialog;
541 }
542
alisiond45da712013-05-30 09:18:49 -0400543 @Override
544 public void onContactDragged() {
545
546 mDrawer.close();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400547 // mTabHost.setCurrentTab(1);
alisiond45da712013-05-30 09:18:49 -0400548
549 }
550
alision58356b72013-06-03 17:13:36 -0400551 @Override
552 public void openDrawer() {
alision55c36cb2013-06-14 14:57:38 -0400553 mDrawer.animateOpen();
alision58356b72013-06-03 17:13:36 -0400554 }
555
alision806e18e2013-06-21 15:30:17 -0400556 @Override
557 public void confCreated(Intent intent) {
558 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400559
alision806e18e2013-06-21 15:30:17 -0400560 }
561
562 @Override
563 public void confRemoved(Intent intent) {
564 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400565
alision806e18e2013-06-21 15:30:17 -0400566 }
567
568 @Override
569 public void confChanged(Intent intent) {
570 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400571
572 }
573
574 @Override
575 public void recordingChanged(Intent intent) {
576 // TODO Auto-generated method stub
577
578 }
579
580 @Override
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400581 public void selectedCall(Conference c) {
alisiondf1dac92013-06-27 17:35:53 -0400582 Intent intent = new Intent().setClass(this, CallActivity.class);
583 intent.putExtra("resuming", true);
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400584 intent.putExtra("conference", c);
alisiondf1dac92013-06-27 17:35:53 -0400585 startActivityForResult(intent, REQUEST_CODE_CALL);
alision806e18e2013-06-21 15:30:17 -0400586 }
587
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400588
alisionf76de3b2013-04-16 15:35:22 -0400589}