blob: cd6e59286b2c1af92adf1baf06f02f56e2e96842 [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 }
148
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));
alisionf76de3b2013-04-16 15:35:22 -0400164
alision9f7a6ec2013-05-24 16:26:26 -0400165 mTitle = mDrawerTitle = getTitle();
166 mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
alisionf76de3b2013-04-16 15:35:22 -0400167
alision0b553832013-05-30 09:31:06 -0400168 // set a custom shadow that overlays the main content when the drawer opens
alision9f7a6ec2013-05-24 16:26:26 -0400169 mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.START);
alisionf76de3b2013-04-16 15:35:22 -0400170
alision9f7a6ec2013-05-24 16:26:26 -0400171 getActionBar().setDisplayHomeAsUpEnabled(true);
172 getActionBar().setHomeButtonEnabled(true);
alisionf76de3b2013-04-16 15:35:22 -0400173
alision9f7a6ec2013-05-24 16:26:26 -0400174 mDrawerToggle = new ActionBarDrawerToggle(this, /* host Activity */
175 mDrawerLayout, /* DrawerLayout object */
176 R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
177 R.string.drawer_open, /* "open drawer" description for accessibility */
178 R.string.drawer_close /* "close drawer" description for accessibility */
179 ) {
alision0b553832013-05-30 09:31:06 -0400180 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400181 public void onDrawerClosed(View view) {
182 getActionBar().setTitle(mTitle);
183 invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu()
184 }
alisionf76de3b2013-04-16 15:35:22 -0400185
alision0b553832013-05-30 09:31:06 -0400186 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400187 public void onDrawerOpened(View drawerView) {
188 getActionBar().setTitle(mDrawerTitle);
189 invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu()
190 }
191 };
alisionf76de3b2013-04-16 15:35:22 -0400192
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400193 // mTabHost = (TabHost) findViewById(android.R.id.tabhost);
alision9f7a6ec2013-05-24 16:26:26 -0400194 mDrawerLayout.setDrawerListener(mDrawerToggle);
alisionf76de3b2013-04-16 15:35:22 -0400195
alision9f7a6ec2013-05-24 16:26:26 -0400196 mViewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
197 @Override
198 public void onPageSelected(int position) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400199 // mTabHost.setCurrentTab(position);
alision9f7a6ec2013-05-24 16:26:26 -0400200 }
201 });
alisionf76de3b2013-04-16 15:35:22 -0400202
alision9f7a6ec2013-05-24 16:26:26 -0400203 }
alisionf76de3b2013-04-16 15:35:22 -0400204
alisionf57d8a62013-07-02 09:37:12 -0400205 @Override
206 protected void onPostCreate(Bundle savedInstanceState) {
207 super.onPostCreate(savedInstanceState);
208 // Sync the toggle state after onRestoreInstanceState has occurred.
209 mDrawerToggle.syncState();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400210
211// 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 -0400212 }
alision465ceba2013-07-04 09:24:30 -0400213
alisionf57d8a62013-07-02 09:37:12 -0400214 @Override
215 public void onConfigurationChanged(Configuration newConfig) {
216 super.onConfigurationChanged(newConfig);
217 mDrawerToggle.onConfigurationChanged(newConfig);
218 }
alision3c5c2a92013-05-30 09:50:47 -0400219
alision9f7a6ec2013-05-24 16:26:26 -0400220 @Override
221 protected void onStart() {
222 Log.i(TAG, "onStart");
223 super.onStart();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400224
alision9f7a6ec2013-05-24 16:26:26 -0400225 }
alisionf76de3b2013-04-16 15:35:22 -0400226
alision9f7a6ec2013-05-24 16:26:26 -0400227 /* user gets back to the activity, e.g. through task manager */
228 @Override
229 protected void onRestart() {
230 super.onRestart();
231 }
alisionf76de3b2013-04-16 15:35:22 -0400232
alision9f7a6ec2013-05-24 16:26:26 -0400233 /* activity gets back to the foreground and user input */
234 @Override
235 protected void onResume() {
alision58356b72013-06-03 17:13:36 -0400236 super.onResume();
alision84813a12013-05-27 17:40:39 -0400237 IntentFilter intentFilter = new IntentFilter();
238 intentFilter.addAction(CallManagerCallBack.INCOMING_CALL);
239 intentFilter.addAction(CallManagerCallBack.INCOMING_TEXT);
240 intentFilter.addAction(CallManagerCallBack.CALL_STATE_CHANGED);
alision58356b72013-06-03 17:13:36 -0400241 registerReceiver(callReceiver, intentFilter);
alision907bde72013-06-20 14:40:37 -0400242
alision9f7a6ec2013-05-24 16:26:26 -0400243 }
alision907bde72013-06-20 14:40:37 -0400244
alisionbd45a822013-06-06 17:35:35 -0400245 private boolean isClosing = false;
246 private Timer t = new Timer();
alision907bde72013-06-20 14:40:37 -0400247
alisionbd45a822013-06-06 17:35:35 -0400248 @Override
249 public void onBackPressed() {
alision907bde72013-06-20 14:40:37 -0400250
251 if (getActionBar().getCustomView() != null) {
alision2ec64f92013-06-17 17:28:58 -0400252 getActionBar().setDisplayShowCustomEnabled(false);
253 getActionBar().setCustomView(null);
254 // Display all the contacts again
255 getLoaderManager().restartLoader(LoaderConstants.CONTACT_LOADER, null, mContactsFragment);
256 return;
257 }
alision907bde72013-06-20 14:40:37 -0400258
alisionbd45a822013-06-06 17:35:35 -0400259 if (mDrawer.isOpened()) {
alision55c36cb2013-06-14 14:57:38 -0400260 mDrawer.animateClose();
alisionbd45a822013-06-06 17:35:35 -0400261 return;
262 }
alision2ec64f92013-06-17 17:28:58 -0400263
alisionbd45a822013-06-06 17:35:35 -0400264 if (isClosing) {
265 super.onBackPressed();
266 t.cancel();
267 finish();
268 } else {
269
270 t.schedule(new TimerTask() {
271 @Override
272 public void run() {
273 isClosing = false;
274 }
275 }, 3000);
276 Toast.makeText(this, getResources().getString(R.string.close_msg), Toast.LENGTH_SHORT).show();
277 isClosing = true;
278 }
279 }
alisione2a38e12013-04-25 14:20:20 -0400280
alision9f7a6ec2013-05-24 16:26:26 -0400281 /* activity no more in foreground */
282 @Override
283 protected void onPause() {
284 super.onPause();
alision58356b72013-06-03 17:13:36 -0400285 unregisterReceiver(callReceiver);
alision55c36cb2013-06-14 14:57:38 -0400286 try {
287 service.createNotification();
288
289 } catch (RemoteException e) {
290 Log.e(TAG, e.toString());
291 }
alision2cb99562013-05-30 17:02:20 -0400292
alision9f7a6ec2013-05-24 16:26:26 -0400293 }
alisionf76de3b2013-04-16 15:35:22 -0400294
alision9f7a6ec2013-05-24 16:26:26 -0400295 /* activity is no longer visible */
296 @Override
297 protected void onStop() {
298 super.onStop();
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 finishes itself or is being killed by the system */
303 @Override
304 protected void onDestroy() {
305 /* stop the service, if no other bound user, no need to check if it is running */
306 if (mBound) {
307 Log.i(TAG, "onDestroy: Unbinding service...");
alision907bde72013-06-20 14:40:37 -0400308
alision9f7a6ec2013-05-24 16:26:26 -0400309 unbindService(mConnection);
310 mBound = false;
alision2cb99562013-05-30 17:02:20 -0400311
alision9f7a6ec2013-05-24 16:26:26 -0400312 }
alision371b77e2013-04-23 14:51:26 -0400313
alision9f7a6ec2013-05-24 16:26:26 -0400314 super.onDestroy();
315 }
alision73424b62013-04-26 11:49:18 -0400316
alision55c36cb2013-06-14 14:57:38 -0400317 public void launchCallActivity(SipCall infos) {
alision9f7a6ec2013-05-24 16:26:26 -0400318 Log.i(TAG, "Launch Call Activity");
319 Bundle bundle = new Bundle();
alisiondf1dac92013-06-27 17:35:53 -0400320 Conference tmp = new Conference("-1");
alision465ceba2013-07-04 09:24:30 -0400321
alisiondf1dac92013-06-27 17:35:53 -0400322 tmp.getParticipants().add(infos);
alision465ceba2013-07-04 09:24:30 -0400323
alisiondf1dac92013-06-27 17:35:53 -0400324 bundle.putParcelable("conference", tmp);
alision9f7a6ec2013-05-24 16:26:26 -0400325 Intent intent = new Intent().setClass(this, CallActivity.class);
alisiondf1dac92013-06-27 17:35:53 -0400326 intent.putExtra("resuming", false);
alision9f7a6ec2013-05-24 16:26:26 -0400327 intent.putExtras(bundle);
328 startActivityForResult(intent, REQUEST_CODE_CALL);
alision465ceba2013-07-04 09:24:30 -0400329 overridePendingTransition(R.anim.slide_down, R.anim.slide_up);
alision9f7a6ec2013-05-24 16:26:26 -0400330 }
alisionf76de3b2013-04-16 15:35:22 -0400331
alision9f7a6ec2013-05-24 16:26:26 -0400332 /** Defines callbacks for service binding, passed to bindService() */
333 private ServiceConnection mConnection = new ServiceConnection() {
alision371b77e2013-04-23 14:51:26 -0400334
alision9f7a6ec2013-05-24 16:26:26 -0400335 @Override
336 public void onServiceConnected(ComponentName className, IBinder binder) {
337 service = ISipService.Stub.asInterface(binder);
alisione2a38e12013-04-25 14:20:20 -0400338
alision2cb99562013-05-30 17:02:20 -0400339 try {
alision58356b72013-06-03 17:13:36 -0400340
alision907bde72013-06-20 14:40:37 -0400341 fMenu = new MenuFragment();
342 getFragmentManager().beginTransaction().replace(R.id.left_drawer, fMenu).commit();
alision58356b72013-06-03 17:13:36 -0400343 mSectionsPagerAdapter = new SectionsPagerAdapter(SFLPhoneHomeActivity.this, getFragmentManager());
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400344
Alexandre Lisionf41a3a82013-09-05 17:15:15 -0400345 final PagerTabStrip strip = PagerTabStrip.class.cast(mViewPager.findViewById(R.id.pts_main));
346 strip.setDrawFullUnderline(false);
347 strip.setTabIndicatorColor(getResources().getColor(R.color.holo_blue_dark));
Alexandre Lisiona764c682013-09-09 10:02:07 -0400348 strip.setBackgroundColor(getResources().getColor(R.color.darker_gray));
Alexandre Lisionf41a3a82013-09-05 17:15:15 -0400349 strip.setNonPrimaryAlpha(0.5f);
350 strip.setTextSpacing(25);
351 strip.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400352
353 // initialiseTabHost(null);
alisiondf1dac92013-06-27 17:35:53 -0400354 mViewPager.setOffscreenPageLimit(2);
alision58356b72013-06-03 17:13:36 -0400355 mViewPager.setAdapter(mSectionsPagerAdapter);
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400356 mViewPager.setCurrentItem(1);
357 // mTabHost.setCurrentTab(1);
alision2cb99562013-05-30 17:02:20 -0400358 service.destroyNotification();
alision58356b72013-06-03 17:13:36 -0400359 // mAdapter = new AccountSelectionAdapter(SFLPhoneHomeActivity.this, service, new ArrayList<Account>());
360 // spinnerAccounts.setAdapter(mAdapter);
alision2cb99562013-05-30 17:02:20 -0400361 } catch (RemoteException e) {
362 Log.e(TAG, e.toString());
363 }
alision9f7a6ec2013-05-24 16:26:26 -0400364 mBound = true;
alision9f7a6ec2013-05-24 16:26:26 -0400365 Log.d(TAG, "Service connected service=" + service);
alision371b77e2013-04-23 14:51:26 -0400366
alision9f7a6ec2013-05-24 16:26:26 -0400367 }
alision5f899632013-04-22 17:26:56 -0400368
alision9f7a6ec2013-05-24 16:26:26 -0400369 @Override
370 public void onServiceDisconnected(ComponentName arg0) {
alision5f899632013-04-22 17:26:56 -0400371
alision9f7a6ec2013-05-24 16:26:26 -0400372 mBound = false;
373 Log.d(TAG, "Service disconnected service=" + service);
374 }
375 };
alision5f899632013-04-22 17:26:56 -0400376
alision9f7a6ec2013-05-24 16:26:26 -0400377 @Override
378 public boolean onOptionsItemSelected(MenuItem item) {
379 Log.i(TAG, "onOptionsItemSelected " + item.getItemId());
alision5f899632013-04-22 17:26:56 -0400380
alision9f7a6ec2013-05-24 16:26:26 -0400381 if (mDrawerToggle.onOptionsItemSelected(item)) {
382 return true;
383 }
alision5f899632013-04-22 17:26:56 -0400384
alision9f7a6ec2013-05-24 16:26:26 -0400385 return super.onOptionsItemSelected(item);
386 }
alisionf76de3b2013-04-16 15:35:22 -0400387
alision9f7a6ec2013-05-24 16:26:26 -0400388 @Override
389 public void onActivityResult(int requestCode, int resultCode, Intent data) {
390 super.onActivityResult(requestCode, resultCode, data);
alision84813a12013-05-27 17:40:39 -0400391
392 switch (requestCode) {
alision9f7a6ec2013-05-24 16:26:26 -0400393 case REQUEST_CODE_PREFERENCES:
alision907bde72013-06-20 14:40:37 -0400394 Log.w(TAG, "In Activity");
395 fMenu.updateAllAccounts();
alision9f7a6ec2013-05-24 16:26:26 -0400396 break;
397 case REQUEST_CODE_CALL:
alision2cb99562013-05-30 17:02:20 -0400398 Log.w(TAG, "Result out of CallActivity");
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400399 if (resultCode == CallActivity.RESULT_FAILURE) {
400 Log.w(TAG, "CALL FAILEEEED");
401 }
402 // if (mSectionsPagerAdapter != null && mSectionsPagerAdapter.getItem(2) != null)
403 // getLoaderManager().restartLoader(LoaderConstants.HISTORY_LOADER, null, (HistoryFragment) mSectionsPagerAdapter.getItem(2));
alision9f7a6ec2013-05-24 16:26:26 -0400404 break;
405 }
alisionf76de3b2013-04-16 15:35:22 -0400406
alision9f7a6ec2013-05-24 16:26:26 -0400407 }
alisionf76de3b2013-04-16 15:35:22 -0400408
alision9f7a6ec2013-05-24 16:26:26 -0400409 @Override
alision9f7a6ec2013-05-24 16:26:26 -0400410 public ISipService getService() {
411 return service;
412 }
alisionf76de3b2013-04-16 15:35:22 -0400413
alision84813a12013-05-27 17:40:39 -0400414 /**
415 * Interface implemented to handle incoming events
416 */
alision9f7a6ec2013-05-24 16:26:26 -0400417 @Override
alision84813a12013-05-27 17:40:39 -0400418 public void incomingCall(Intent call) {
419 Toast.makeText(this, "New Call incoming", Toast.LENGTH_LONG).show();
alisionfde875f2013-05-28 17:01:54 -0400420 SipCall infos = call.getParcelableExtra("newcall");
alision84813a12013-05-27 17:40:39 -0400421
alision58356b72013-06-03 17:13:36 -0400422 // mCallElementList.addCall(infos);
alisionfde875f2013-05-28 17:01:54 -0400423
alision55c36cb2013-06-14 14:57:38 -0400424 launchCallActivity(infos);
alision84813a12013-05-27 17:40:39 -0400425
426 }
427
428 @Override
429 public void callStateChanged(Intent callState) {
430 Bundle b = callState.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate");
431 String cID = b.getString("CallID");
432 String state = b.getString("State");
433 Log.i(TAG, "callStateChanged" + cID + " " + state);
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400434 mSectionsPagerAdapter.updateHome();
alision84813a12013-05-27 17:40:39 -0400435
436 }
437
438 @Override
439 public void incomingText(Intent msg) {
440 Bundle b = msg.getBundleExtra("com.savoirfairelinux.sflphone.service.newtext");
441 b.getString("CallID");
442 String from = b.getString("From");
443 String mess = b.getString("Msg");
444 Toast.makeText(getApplicationContext(), "text from " + from + " : " + mess, Toast.LENGTH_LONG).show();
445 }
446
447 @Override
alision55c36cb2013-06-14 14:57:38 -0400448 public void onContactSelected(final CallContact c) {
Alexandre Lisionf0b993d2013-09-12 13:25:10 -0400449
450 if (fMenu.getSelectedAccount() == null) {
451 // Toast.makeText(this, "No Account Selected", Toast.LENGTH_SHORT).show();
452 createAccountDialog().show();
453 return;
454 }
alisionfde875f2013-05-28 17:01:54 -0400455
alision55c36cb2013-06-14 14:57:38 -0400456 Thread launcher = new Thread(new Runnable() {
alision907bde72013-06-20 14:40:37 -0400457
alision55c36cb2013-06-14 14:57:38 -0400458 final String[] CONTACTS_PHONES_PROJECTION = new String[] { Phone.NUMBER, Phone.TYPE };
459 final String[] CONTACTS_SIP_PROJECTION = new String[] { SipAddress.SIP_ADDRESS, SipAddress.TYPE };
alision907bde72013-06-20 14:40:37 -0400460
alision55c36cb2013-06-14 14:57:38 -0400461 @Override
462 public void run() {
463 SipCall.SipCallBuilder callBuilder = SipCall.SipCallBuilder.getInstance();
464 try {
Alexandre Lisionf0b993d2013-09-12 13:25:10 -0400465 callBuilder.startCallCreation().setAccountID(fMenu.getSelectedAccount().getAccountID())
alision907bde72013-06-20 14:40:37 -0400466 .setCallType(SipCall.state.CALL_TYPE_OUTGOING);
467 Cursor cPhones = getContentResolver().query(Phone.CONTENT_URI, CONTACTS_PHONES_PROJECTION, Phone.CONTACT_ID + " =" + c.getId(),
468 null, null);
alision55c36cb2013-06-14 14:57:38 -0400469
alision907bde72013-06-20 14:40:37 -0400470 while (cPhones.moveToNext()) {
471 c.addPhoneNumber(cPhones.getString(cPhones.getColumnIndex(Phone.NUMBER)), cPhones.getInt(cPhones.getColumnIndex(Phone.TYPE)));
472 }
473 cPhones.close();
474
475 Cursor cSip = getContentResolver().query(Phone.CONTENT_URI, CONTACTS_SIP_PROJECTION, Phone.CONTACT_ID + "=" + c.getId(), null,
476 null);
477
478 while (cSip.moveToNext()) {
479 c.addSipNumber(cSip.getString(cSip.getColumnIndex(SipAddress.SIP_ADDRESS)), cSip.getInt(cSip.getColumnIndex(SipAddress.TYPE)));
480 }
481 cSip.close();
482 callBuilder.setContact(c);
alision55c36cb2013-06-14 14:57:38 -0400483 launchCallActivity(callBuilder.build());
484 } catch (RemoteException e1) {
485 Log.e(TAG, e1.toString());
486 } catch (Exception e) {
487 Log.e(TAG, e.toString());
488 }
alision907bde72013-06-20 14:40:37 -0400489
alision55c36cb2013-06-14 14:57:38 -0400490 }
491 });
492 launcher.start();
493 mDrawer.close();
alision84813a12013-05-27 17:40:39 -0400494
495 }
496
497 @Override
alision907bde72013-06-20 14:40:37 -0400498 public void onCallDialed(String to) {
alision84813a12013-05-27 17:40:39 -0400499
alisiondf1dac92013-06-27 17:35:53 -0400500 if (fMenu.getSelectedAccount() == null) {
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400501 // Toast.makeText(this, "No Account Selected", Toast.LENGTH_SHORT).show();
502 createAccountDialog().show();
alisiondf1dac92013-06-27 17:35:53 -0400503 return;
504 }
505
alisionfde875f2013-05-28 17:01:54 -0400506 SipCall.SipCallBuilder callBuilder = SipCall.SipCallBuilder.getInstance();
alision907bde72013-06-20 14:40:37 -0400507 callBuilder.startCallCreation().setAccountID(fMenu.getSelectedAccount().getAccountID()).setCallType(SipCall.state.CALL_TYPE_OUTGOING);
508 callBuilder.setContact(CallContact.ContactBuilder.buildUnknownContact(to));
alision84813a12013-05-27 17:40:39 -0400509
alisionfde875f2013-05-28 17:01:54 -0400510 try {
alision55c36cb2013-06-14 14:57:38 -0400511 launchCallActivity(callBuilder.build());
alisionfde875f2013-05-28 17:01:54 -0400512 } catch (Exception e) {
513 Log.e(TAG, e.toString());
514 }
alision84813a12013-05-27 17:40:39 -0400515
alision9f7a6ec2013-05-24 16:26:26 -0400516 }
alision371b77e2013-04-23 14:51:26 -0400517
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400518 private AlertDialog createAccountDialog() {
519 final Activity ownerActivity = this;
520 AlertDialog.Builder builder = new AlertDialog.Builder(ownerActivity);
521
522 builder.setMessage(getResources().getString(R.string.create_new_account_dialog))
523 .setTitle(getResources().getString(R.string.create_new_account_dialog_title))
524 .setPositiveButton(getResources().getString(android.R.string.ok), new DialogInterface.OnClickListener() {
525 public void onClick(DialogInterface dialog, int whichButton) {
526 Intent in = new Intent();
527 in.setClass(ownerActivity, SFLPhonePreferenceActivity.class);
528 ownerActivity.startActivityForResult(in, SFLPhoneHomeActivity.REQUEST_CODE_PREFERENCES);
529 }
530 }).setNegativeButton(getResources().getString(android.R.string.cancel), new DialogInterface.OnClickListener() {
531 public void onClick(DialogInterface dialog, int whichButton) {
532 dialog.dismiss();
533 }
534 });
535
536 AlertDialog alertDialog = builder.create();
537 alertDialog.setOwnerActivity(ownerActivity);
538
539 return alertDialog;
540 }
541
alisiond45da712013-05-30 09:18:49 -0400542 @Override
543 public void onContactDragged() {
544
545 mDrawer.close();
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400546 // mTabHost.setCurrentTab(1);
alisiond45da712013-05-30 09:18:49 -0400547
548 }
549
alision58356b72013-06-03 17:13:36 -0400550 @Override
551 public void openDrawer() {
alision55c36cb2013-06-14 14:57:38 -0400552 mDrawer.animateOpen();
alision58356b72013-06-03 17:13:36 -0400553 }
554
alision806e18e2013-06-21 15:30:17 -0400555 @Override
556 public void confCreated(Intent intent) {
557 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400558
alision806e18e2013-06-21 15:30:17 -0400559 }
560
561 @Override
562 public void confRemoved(Intent intent) {
563 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400564
alision806e18e2013-06-21 15:30:17 -0400565 }
566
567 @Override
568 public void confChanged(Intent intent) {
569 // TODO Auto-generated method stub
alisiondf1dac92013-06-27 17:35:53 -0400570
571 }
572
573 @Override
574 public void recordingChanged(Intent intent) {
575 // TODO Auto-generated method stub
576
577 }
578
579 @Override
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400580 public void selectedCall(Conference c) {
alisiondf1dac92013-06-27 17:35:53 -0400581 Intent intent = new Intent().setClass(this, CallActivity.class);
582 intent.putExtra("resuming", true);
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400583 intent.putExtra("conference", c);
alisiondf1dac92013-06-27 17:35:53 -0400584 startActivityForResult(intent, REQUEST_CODE_CALL);
alision806e18e2013-06-21 15:30:17 -0400585 }
586
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400587
alisionf76de3b2013-04-16 15:35:22 -0400588}