blob: 14934204c5439f7ece9dce149623f267d910f5ee [file] [log] [blame]
Alexandre Savard14323be2012-10-24 10:02:13 -04001/*
alisionb1763882013-06-18 17:30:51 -04002 * Copyright (C) 2004-2013 Savoir-Faire Linux Inc.
Alexandre Savard14323be2012-10-24 10:02:13 -04003 *
4 * Author: Alexandre Savard <alexandre.savard@savoirfairelinux.com>
Adrien Béraud71b2f812013-04-26 18:51:02 +10005 * Author: Adrien Béraud <adrien.beraud@savoirfairelinux.com>
alisionfde875f2013-05-28 17:01:54 -04006 * Author: Alexandre Lision <alexandre.lision@savoirfairelinux.com>
Alexandre Savard14323be2012-10-24 10:02:13 -04007 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 *
22 * Additional permission under GNU GPL version 3 section 7:
23 *
24 * If you modify this program, or any covered work, by linking or
25 * combining it with the OpenSSL project's OpenSSL library (or a
26 * modified version of that library), containing parts covered by the
27 * terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
28 * grants you additional permission to convey the resulting work.
29 * Corresponding Source for a non-source form of such a combination
30 * shall include the source code for the parts of OpenSSL used as well
31 * as that of the covered work.
32 */
33
Alexandre Lision064e1e02013-10-01 16:18:42 -040034package org.sflphone.client;
Alexandre Savard14323be2012-10-24 10:02:13 -040035
alision85704182013-05-29 15:23:03 -040036import java.util.HashMap;
Adrien Béraud33268882013-05-18 03:41:15 +100037
Alexandre Lision064e1e02013-10-01 16:18:42 -040038import org.sflphone.R;
39import org.sflphone.fragments.CallFragment;
40import org.sflphone.fragments.CallListFragment;
41import org.sflphone.interfaces.CallInterface;
Alexandre Lisiond588bff2013-10-08 12:43:01 -040042import org.sflphone.model.Account;
Alexandre Lision064e1e02013-10-01 16:18:42 -040043import org.sflphone.model.CallContact;
44import org.sflphone.model.Conference;
45import org.sflphone.model.SipCall;
46import org.sflphone.model.SipCall.state;
47import org.sflphone.receivers.CallReceiver;
48import org.sflphone.service.CallManagerCallBack;
49import org.sflphone.service.ISipService;
50import org.sflphone.service.SipService;
51import org.sflphone.views.CallPaneLayout;
52
Alexandre Savard14323be2012-10-24 10:02:13 -040053import android.app.Activity;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040054import android.content.ComponentName;
alision17052d42013-04-22 10:39:38 -040055import android.content.Context;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040056import android.content.Intent;
alision84813a12013-05-27 17:40:39 -040057import android.content.IntentFilter;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040058import android.content.ServiceConnection;
Alexandre Lision0edf18c2013-09-23 17:35:50 -040059import android.graphics.PixelFormat;
alision55c36cb2013-06-14 14:57:38 -040060import android.net.Uri;
Alexandre Savard14323be2012-10-24 10:02:13 -040061import android.os.Bundle;
Alexandre Lision0c384512013-09-17 17:15:57 -040062import android.os.Handler;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040063import android.os.IBinder;
alision85992112013-05-29 12:18:08 -040064import android.os.RemoteException;
Alexandre Lision0c384512013-09-17 17:15:57 -040065import android.os.SystemClock;
alisionfde875f2013-05-28 17:01:54 -040066import android.support.v4.widget.SlidingPaneLayout;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040067import android.util.Log;
Alexandre Lision64dc8c02013-09-25 15:32:25 -040068import android.view.KeyEvent;
alisionfde875f2013-05-28 17:01:54 -040069import android.view.View;
Alexandre Lision0edf18c2013-09-23 17:35:50 -040070import android.view.Window;
Adrien Béraud33268882013-05-18 03:41:15 +100071import android.widget.Toast;
Alexandre Savard14323be2012-10-24 10:02:13 -040072
alisionfde875f2013-05-28 17:01:54 -040073public class CallActivity extends Activity implements CallInterface, CallFragment.Callbacks, CallListFragment.Callbacks {
alision55c36cb2013-06-14 14:57:38 -040074 static final String TAG = "CallActivity";
75 private ISipService service;
alision84813a12013-05-27 17:40:39 -040076
alision55c36cb2013-06-14 14:57:38 -040077 CallReceiver receiver;
alision85992112013-05-29 12:18:08 -040078
alision55c36cb2013-06-14 14:57:38 -040079 CallPaneLayout slidingPaneLayout;
Adrien Béraud33268882013-05-18 03:41:15 +100080
Alexandre Lision0edf18c2013-09-23 17:35:50 -040081 // CallListFragment mCallsFragment;
alision55c36cb2013-06-14 14:57:38 -040082 CallFragment mCurrentCallFragment;
Alexandre Lision0edf18c2013-09-23 17:35:50 -040083 // private boolean fragIsChanging;
Alexandre Lision1a9e3b12013-09-16 11:06:07 -040084
Alexandre Lisionf1850c02013-09-23 14:19:34 -040085 /* result code sent in case of call failure */
Alexandre Lisionc51ccb12013-09-11 16:00:30 -040086 public static int RESULT_FAILURE = -10;
Alexandre Savard4f42ade2012-10-24 18:03:31 -040087
alision55c36cb2013-06-14 14:57:38 -040088 @Override
89 protected void onCreate(Bundle savedInstanceState) {
90 super.onCreate(savedInstanceState);
91 setContentView(R.layout.activity_call_layout);
Alexandre Savard4f42ade2012-10-24 18:03:31 -040092
alision55c36cb2013-06-14 14:57:38 -040093 receiver = new CallReceiver(this);
Adrien Béraud33268882013-05-18 03:41:15 +100094
Alexandre Lision0edf18c2013-09-23 17:35:50 -040095 // mCallsFragment = new CallListFragment();
Adrien Béraud33268882013-05-18 03:41:15 +100096
Alexandre Lision0edf18c2013-09-23 17:35:50 -040097 // getFragmentManager().beginTransaction().replace(R.id.calllist_pane, mCallsFragment).commit();
alision85992112013-05-29 12:18:08 -040098
alision55c36cb2013-06-14 14:57:38 -040099 slidingPaneLayout = (CallPaneLayout) findViewById(R.id.slidingpanelayout);
alisiondf1dac92013-06-27 17:35:53 -0400100
alision55c36cb2013-06-14 14:57:38 -0400101 slidingPaneLayout.setPanelSlideListener(new SlidingPaneLayout.PanelSlideListener() {
alision84813a12013-05-27 17:40:39 -0400102
alision55c36cb2013-06-14 14:57:38 -0400103 @Override
104 public void onPanelSlide(View view, float offSet) {
105 }
alisionfde875f2013-05-28 17:01:54 -0400106
alision55c36cb2013-06-14 14:57:38 -0400107 @Override
108 public void onPanelOpened(View view) {
alisionfde875f2013-05-28 17:01:54 -0400109
alision55c36cb2013-06-14 14:57:38 -0400110 switch (view.getId()) {
111 case R.id.calllist_pane:
112 // getFragmentManager().findFragmentById(R.id.calllist_pane).setHasOptionsMenu(true);
113 // getFragmentManager().findFragmentById(R.id.ongoingcall_pane).setHasOptionsMenu(false);
114 break;
115 default:
116 break;
117 }
118 }
alisionfde875f2013-05-28 17:01:54 -0400119
alision55c36cb2013-06-14 14:57:38 -0400120 @Override
121 public void onPanelClosed(View view) {
alisionfde875f2013-05-28 17:01:54 -0400122
alision55c36cb2013-06-14 14:57:38 -0400123 }
124 });
alisionfde875f2013-05-28 17:01:54 -0400125
alision55c36cb2013-06-14 14:57:38 -0400126 Intent intent = new Intent(this, SipService.class);
127 bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
alision55c36cb2013-06-14 14:57:38 -0400128 }
alisiond45da712013-05-30 09:18:49 -0400129
alision55c36cb2013-06-14 14:57:38 -0400130 /* activity gets back to the foreground and user input */
131 @Override
132 protected void onResume() {
133 Log.i(TAG, "onResume");
134 IntentFilter intentFilter = new IntentFilter();
135 intentFilter.addAction(CallManagerCallBack.INCOMING_CALL);
136 intentFilter.addAction(CallManagerCallBack.INCOMING_TEXT);
137 intentFilter.addAction(CallManagerCallBack.CALL_STATE_CHANGED);
alisiondf1dac92013-06-27 17:35:53 -0400138 intentFilter.addAction(CallManagerCallBack.CONF_CREATED);
139 intentFilter.addAction(CallManagerCallBack.CONF_REMOVED);
140 intentFilter.addAction(CallManagerCallBack.CONF_CHANGED);
141 intentFilter.addAction(CallManagerCallBack.RECORD_STATE_CHANGED);
alision55c36cb2013-06-14 14:57:38 -0400142 registerReceiver(receiver, intentFilter);
Alexandre Lision0c384512013-09-17 17:15:57 -0400143
alision55c36cb2013-06-14 14:57:38 -0400144 super.onResume();
145 }
alisiond45da712013-05-30 09:18:49 -0400146
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400147 @Override
148 public void onAttachedToWindow() {
149 super.onAttachedToWindow();
150 Window window = getWindow();
151 window.setFormat(PixelFormat.RGBA_8888);
152 }
153
Alexandre Lision0c384512013-09-17 17:15:57 -0400154 private Handler mHandler = new Handler();
155 private Runnable mUpdateTimeTask = new Runnable() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000156 @Override
Alexandre Lision0c384512013-09-17 17:15:57 -0400157 public void run() {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400158 if (mCurrentCallFragment != null)
Alexandre Lisionfd7a88f2013-09-18 10:03:17 -0400159 mCurrentCallFragment.updateTime();
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400160 // mCallsFragment.update();
Alexandre Lision0c384512013-09-17 17:15:57 -0400161
Adrien Béraud9360f242013-09-19 11:07:42 +1000162 mHandler.postAtTime(this, SystemClock.uptimeMillis() + 1000);
Alexandre Lision0c384512013-09-17 17:15:57 -0400163 }
164 };
165
alision55c36cb2013-06-14 14:57:38 -0400166 /* activity no more in foreground */
167 @Override
168 protected void onPause() {
169 super.onPause();
Alexandre Lision0c384512013-09-17 17:15:57 -0400170 mHandler.removeCallbacks(mUpdateTimeTask);
alision55c36cb2013-06-14 14:57:38 -0400171 }
Alexandre Lision40954dc2013-10-09 15:24:03 -0400172
Alexandre Lision64dc8c02013-09-25 15:32:25 -0400173 @Override
174 public boolean onKeyUp(int keyCode, KeyEvent event) {
Alexandre Lision40954dc2013-10-09 15:24:03 -0400175
176 if (keyCode == KeyEvent.KEYCODE_BACK) {
Alexandre Lision31f46fc2013-09-26 11:19:54 -0400177 return super.onKeyUp(keyCode, event);
178 }
Alexandre Lision64dc8c02013-09-25 15:32:25 -0400179 mCurrentCallFragment.onKeyUp(keyCode, event);
180 return true;
181 }
Alexandre Savard6d54bbc2012-10-24 11:04:23 -0400182
alision55c36cb2013-06-14 14:57:38 -0400183 @Override
184 protected void onDestroy() {
alision55c36cb2013-06-14 14:57:38 -0400185 unregisterReceiver(receiver);
alision55c36cb2013-06-14 14:57:38 -0400186 unbindService(mConnection);
alision55c36cb2013-06-14 14:57:38 -0400187 super.onDestroy();
188 }
Adrien Béraud33268882013-05-18 03:41:15 +1000189
alision55c36cb2013-06-14 14:57:38 -0400190 /** Defines callbacks for service binding, passed to bindService() */
191 private ServiceConnection mConnection = new ServiceConnection() {
192 @Override
193 public void onServiceConnected(ComponentName className, IBinder binder) {
194 service = ISipService.Stub.asInterface(binder);
alisiondf1dac92013-06-27 17:35:53 -0400195
alision55c36cb2013-06-14 14:57:38 -0400196 mCurrentCallFragment = new CallFragment();
Adrien Béraud9360f242013-09-19 11:07:42 +1000197
alision55c36cb2013-06-14 14:57:38 -0400198 Uri u = getIntent().getData();
199 if (u != null) {
200 CallContact c = CallContact.ContactBuilder.buildUnknownContact(u.getSchemeSpecificPart());
201 try {
202 service.destroyNotification();
Alexandre Lisionee2494d2013-10-09 17:14:00 -0400203
204 String accountID = (String)service.getAccountList().get(1);
205 Account acc= new Account(accountID, (HashMap<String, String>) service.getAccountDetails(accountID));
206
alision907bde72013-06-20 14:40:37 -0400207 SipCall call = SipCall.SipCallBuilder.getInstance().startCallCreation().setContact(c)
Alexandre Lisionee2494d2013-10-09 17:14:00 -0400208 .setAccount(acc).setCallType(SipCall.state.CALL_TYPE_OUTGOING).build();
alisiondf1dac92013-06-27 17:35:53 -0400209 Conference tmp = new Conference("-1");
210 tmp.getParticipants().add(call);
alision55c36cb2013-06-14 14:57:38 -0400211 Bundle b = new Bundle();
alisiondf1dac92013-06-27 17:35:53 -0400212 b.putParcelable("conference", tmp);
alision1005ba12013-06-19 13:52:44 -0400213 Log.i(TAG, "Arguments set");
alision55c36cb2013-06-14 14:57:38 -0400214 mCurrentCallFragment.setArguments(b);
215 } catch (RemoteException e) {
alision55c36cb2013-06-14 14:57:38 -0400216 e.printStackTrace();
217 } catch (Exception e) {
alision55c36cb2013-06-14 14:57:38 -0400218 e.printStackTrace();
219 }
alision55c36cb2013-06-14 14:57:38 -0400220 } else {
alisiondf1dac92013-06-27 17:35:53 -0400221 if (getIntent().getBooleanExtra("resuming", false)) {
222
223 Bundle b = new Bundle();
Adrien Béraud9360f242013-09-19 11:07:42 +1000224 b.putParcelable("conference", getIntent().getParcelableExtra("conference"));
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400225 mCurrentCallFragment.setArguments(b);
226
alisiondf1dac92013-06-27 17:35:53 -0400227 } else {
228 mCurrentCallFragment.setArguments(getIntent().getExtras());
229 }
230
alision55c36cb2013-06-14 14:57:38 -0400231 }
Alexandre Savard6d54bbc2012-10-24 11:04:23 -0400232
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400233 // slidingPaneLayout.setCurFragment(mCurrentCallFragment);
alision55c36cb2013-06-14 14:57:38 -0400234 getIntent().getExtras();
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400235 // mCallsFragment.update();
alision55c36cb2013-06-14 14:57:38 -0400236 getFragmentManager().beginTransaction().replace(R.id.ongoingcall_pane, mCurrentCallFragment).commit();
alisiond8c83882013-05-17 17:00:42 -0400237
alision55c36cb2013-06-14 14:57:38 -0400238 }
Adrien Béraud6bbce912013-05-24 00:48:13 +1000239
alision55c36cb2013-06-14 14:57:38 -0400240 @Override
241 public void onServiceDisconnected(ComponentName arg0) {
242 }
243 };
Adrien Béraud6bbce912013-05-24 00:48:13 +1000244
alision55c36cb2013-06-14 14:57:38 -0400245 @Override
246 public void incomingCall(Intent call) {
Alexandre Savarde41f5212012-10-26 14:23:50 -0400247
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400248 // mCallsFragment.update();
Alexandre Savarddf544262012-10-25 14:24:08 -0400249
alision55c36cb2013-06-14 14:57:38 -0400250 }
alision84813a12013-05-27 17:40:39 -0400251
alision55c36cb2013-06-14 14:57:38 -0400252 @Override
253 public void callStateChanged(Intent callState) {
alision84813a12013-05-27 17:40:39 -0400254
alision55c36cb2013-06-14 14:57:38 -0400255 Bundle b = callState.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate");
256 processCallStateChangedSignal(b.getString("CallID"), b.getString("State"));
alision84813a12013-05-27 17:40:39 -0400257
alision55c36cb2013-06-14 14:57:38 -0400258 }
alision84813a12013-05-27 17:40:39 -0400259
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400260 @SuppressWarnings("unchecked")
261 // No proper solution with HashMap runtime cast
alision55c36cb2013-06-14 14:57:38 -0400262 public void processCallStateChangedSignal(String callID, String newState) {
263 /*
264 * Bundle bundle = intent.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate"); String callID = bundle.getString("CallID"); String
265 * newState = bundle.getString("State");
266 */
267 // CallFragment fr = mCurrentCallFragment;
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400268
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400269 // mCallsFragment.update();
alision84813a12013-05-27 17:40:39 -0400270
Alexandre Lisiona764c682013-09-09 10:02:07 -0400271 if (mCurrentCallFragment != null)
272 mCurrentCallFragment.changeCallState(callID, newState);
Adrien Béraud29556042013-04-26 17:35:43 +1000273
alision55c36cb2013-06-14 14:57:38 -0400274 try {
alisiondf1dac92013-06-27 17:35:53 -0400275 HashMap<String, SipCall> callMap = (HashMap<String, SipCall>) service.getCallList();
276 HashMap<String, Conference> confMap = (HashMap<String, Conference>) service.getConferenceList();
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400277
alision34673e62013-06-25 14:40:07 -0400278 if (callMap.size() == 0 && confMap.size() == 0) {
alision34673e62013-06-25 14:40:07 -0400279 finish();
alision55c36cb2013-06-14 14:57:38 -0400280 }
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400281
282 if (callMap.size() > 0) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400283 // ArrayList<SipCall> calls = new ArrayList<SipCall>(callMap.values());
284 // HashMap<String, String> details = (HashMap<String, String>) service.getCallDetails(calls.get(0).getCallId());
Alexandre Lision0c384512013-09-17 17:15:57 -0400285
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400286 }
alision55c36cb2013-06-14 14:57:38 -0400287 } catch (RemoteException e) {
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400288
alision55c36cb2013-06-14 14:57:38 -0400289 Log.e(TAG, e.toString());
290 }
Adrien Béraud29556042013-04-26 17:35:43 +1000291
alision55c36cb2013-06-14 14:57:38 -0400292 Log.w(TAG, "processCallStateChangedSignal " + newState);
Adrien Béraud71b2f812013-04-26 18:51:02 +1000293
alision55c36cb2013-06-14 14:57:38 -0400294 }
295
296 @Override
297 public void incomingText(Intent msg) {
298 Bundle b = msg.getBundleExtra("com.savoirfairelinux.sflphone.service.newtext");
299
alisiona2a2da12013-06-05 15:58:39 -0400300 Toast.makeText(this, b.getString("From") + " : " + b.getString("Msg"), Toast.LENGTH_LONG).show();
Adrien Béraud71b2f812013-04-26 18:51:02 +1000301
alision55c36cb2013-06-14 14:57:38 -0400302 }
alision7f18fc82013-05-01 09:37:33 -0400303
alision55c36cb2013-06-14 14:57:38 -0400304 @Override
305 public ISipService getService() {
306 return service;
307 }
alision04a00182013-05-10 17:05:29 -0400308
alision55c36cb2013-06-14 14:57:38 -0400309 @Override
alisiondf1dac92013-06-27 17:35:53 -0400310 public void onCallSelected(Conference conf) {
alision85992112013-05-29 12:18:08 -0400311
Alexandre Lisiona764c682013-09-09 10:02:07 -0400312 if (mCurrentCallFragment == null || mCurrentCallFragment.getBubbleView() == null) {
alisiondf1dac92013-06-27 17:35:53 -0400313 return;
314 }
Alexandre Lision6e8931e2013-09-19 16:49:34 -0400315 mHandler.removeCallbacks(mUpdateTimeTask);
alisiondf1dac92013-06-27 17:35:53 -0400316 mCurrentCallFragment.getBubbleView().stopThread();
alision55c36cb2013-06-14 14:57:38 -0400317 mCurrentCallFragment = new CallFragment();
318 Bundle b = new Bundle();
alision34673e62013-06-25 14:40:07 -0400319
alisiondf1dac92013-06-27 17:35:53 -0400320 b.putParcelable("conference", conf);
alision55c36cb2013-06-14 14:57:38 -0400321 mCurrentCallFragment.setArguments(b);
alision85992112013-05-29 12:18:08 -0400322
alisiondf1dac92013-06-27 17:35:53 -0400323 // if (calls.size() == 1) {
324 // onCallResumed(calls.get(0));
325 // }
326
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400327 // slidingPaneLayout.setCurFragment(mCurrentCallFragment);
alision55c36cb2013-06-14 14:57:38 -0400328 slidingPaneLayout.closePane();
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400329 // fragIsChanging = true;
alision85992112013-05-29 12:18:08 -0400330
alision55c36cb2013-06-14 14:57:38 -0400331 }
alision85992112013-05-29 12:18:08 -0400332
alision55c36cb2013-06-14 14:57:38 -0400333 @Override
334 public void callContact(SipCall call) {
335 try {
336 service.placeCall(call);
337 } catch (RemoteException e) {
338 Log.e(TAG, "Cannot call service method", e);
339 }
alision85992112013-05-29 12:18:08 -0400340
alision55c36cb2013-06-14 14:57:38 -0400341 }
alision85992112013-05-29 12:18:08 -0400342
alision55c36cb2013-06-14 14:57:38 -0400343 @Override
344 public void onCallAccepted(SipCall call) {
345 int callState = call.getCallStateInt();
346 if (callState != state.CALL_STATE_RINGING && callState != state.CALL_STATE_NONE) {
347 return;
348 }
alision85992112013-05-29 12:18:08 -0400349
alision55c36cb2013-06-14 14:57:38 -0400350 try {
351 service.accept(call.getCallId());
352 } catch (RemoteException e) {
353 Log.e(TAG, "Cannot call service method", e);
354 }
alision85992112013-05-29 12:18:08 -0400355
alision55c36cb2013-06-14 14:57:38 -0400356 }
alision85992112013-05-29 12:18:08 -0400357
alision55c36cb2013-06-14 14:57:38 -0400358 @Override
359 public void onCallRejected(SipCall call) {
360 try {
361 if (call.getCallStateInt() == state.CALL_STATE_RINGING) {
362 service.refuse(call.getCallId());
363 return;
364 }
365 } catch (RemoteException e) {
366 Log.e(TAG, "Cannot call service method", e);
367 }
368 }
alision85992112013-05-29 12:18:08 -0400369
alision55c36cb2013-06-14 14:57:38 -0400370 @Override
371 public void onCallEnded(SipCall call) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400372
373 if (call.getContact().isUser()) {
374 Conference displayed = mCurrentCallFragment.getConference();
375 try {
Alexandre Lision40954dc2013-10-09 15:24:03 -0400376 if (displayed.hasMultipleParticipants())
377 service.hangUpConference(displayed.getId());
378 else
379 service.hangUp(displayed.getParticipants().get(0).getCallId());
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400380 } catch (RemoteException e) {
381 e.printStackTrace();
382 }
383 }
alision55c36cb2013-06-14 14:57:38 -0400384 try {
385 if (call.getCallStateInt() == state.CALL_STATE_NONE || call.getCallStateInt() == state.CALL_STATE_CURRENT
386 || call.getCallStateInt() == state.CALL_STATE_HOLD) {
387 service.hangUp(call.getCallId());
388 return;
alision85992112013-05-29 12:18:08 -0400389
alision55c36cb2013-06-14 14:57:38 -0400390 } else if (call.getCallStateInt() == state.CALL_STATE_RINGING) {
391 if (call.getCallType() == state.CALL_TYPE_INCOMING) {
392 service.refuse(call.getCallId());
393 return;
394 } else if (call.getCallType() == state.CALL_TYPE_OUTGOING) {
395 service.hangUp(call.getCallId());
396 return;
397 }
398 }
399 } catch (RemoteException e) {
400 Log.e(TAG, "Cannot call service method", e);
401 }
402 }
alision85992112013-05-29 12:18:08 -0400403
alision55c36cb2013-06-14 14:57:38 -0400404 @Override
405 public void onCallSuspended(SipCall call) {
406 try {
407 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
408 service.hold(call.getCallId());
409 return;
410 }
411 } catch (RemoteException e) {
412 Log.e(TAG, "Cannot call service method", e);
413 }
414 }
alision85992112013-05-29 12:18:08 -0400415
alision55c36cb2013-06-14 14:57:38 -0400416 @Override
417 public void onCallResumed(SipCall call) {
418 try {
419 if (call.getCallStateInt() == state.CALL_STATE_HOLD) {
420 service.unhold(call.getCallId());
421 return;
422 }
423 } catch (RemoteException e) {
424 Log.e(TAG, "Cannot call service method", e);
425 }
alision85992112013-05-29 12:18:08 -0400426
alision55c36cb2013-06-14 14:57:38 -0400427 }
alision85992112013-05-29 12:18:08 -0400428
alision55c36cb2013-06-14 14:57:38 -0400429 @Override
430 public void onCalltransfered(SipCall call, String to) {
431 try {
432 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
433 service.transfer(call.getCallId(), to);
434 }
435 } catch (RemoteException e) {
436 Log.e(TAG, "Cannot call service method", e);
437 }
alision85992112013-05-29 12:18:08 -0400438
alision55c36cb2013-06-14 14:57:38 -0400439 }
alision85992112013-05-29 12:18:08 -0400440
alision55c36cb2013-06-14 14:57:38 -0400441 @Override
442 public void onRecordCall(SipCall call) {
alisiondf1dac92013-06-27 17:35:53 -0400443
Alexandre Lision40954dc2013-10-09 15:24:03 -0400444 try {
445 Conference displayed = mCurrentCallFragment.getConference();
446 if (displayed.hasMultipleParticipants()) {
447 service.toggleRecordingCall(displayed.getId());
448 } else {
449 service.toggleRecordingCall(displayed.getParticipants().get(0).getCallId());
450 }
Alexandre Lisiona764c682013-09-09 10:02:07 -0400451
alision55c36cb2013-06-14 14:57:38 -0400452 } catch (RemoteException e) {
Alexandre Lision40954dc2013-10-09 15:24:03 -0400453 e.printStackTrace();
alision55c36cb2013-06-14 14:57:38 -0400454 }
alision85992112013-05-29 12:18:08 -0400455
alision55c36cb2013-06-14 14:57:38 -0400456 }
alision85992112013-05-29 12:18:08 -0400457
alision55c36cb2013-06-14 14:57:38 -0400458 @Override
459 public void onBackPressed() {
460 super.onBackPressed();
461 Intent launchHome = new Intent(this, SFLPhoneHomeActivity.class);
462 launchHome.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
463 startActivity(launchHome);
464 }
alision85992112013-05-29 12:18:08 -0400465
alision55c36cb2013-06-14 14:57:38 -0400466 @Override
467 public void onSendMessage(SipCall call, String msg) {
468 try {
469 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
470 service.sendTextMessage(call.getCallId(), msg, "Me");
471 }
472 } catch (RemoteException e) {
473 Log.e(TAG, "Cannot call service method", e);
474 }
alisiond45da712013-05-30 09:18:49 -0400475
alision55c36cb2013-06-14 14:57:38 -0400476 }
alisiond45da712013-05-30 09:18:49 -0400477
alision806e18e2013-06-21 15:30:17 -0400478 @Override
479 public void confCreated(Intent intent) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400480 // mCallsFragment.update();
alision34673e62013-06-25 14:40:07 -0400481
alision806e18e2013-06-21 15:30:17 -0400482 }
483
484 @Override
485 public void confRemoved(Intent intent) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400486 // mCallsFragment.update();
alision806e18e2013-06-21 15:30:17 -0400487 }
488
489 @Override
490 public void confChanged(Intent intent) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400491 // mCallsFragment.update();
alision806e18e2013-06-21 15:30:17 -0400492 }
493
494 @Override
495 public void onCallsTerminated() {
alisiondf1dac92013-06-27 17:35:53 -0400496
497 }
498
499 @Override
500 public void recordingChanged(Intent intent) {
Alexandre Lision0edf18c2013-09-23 17:35:50 -0400501 // mCallsFragment.update();
alisiondf1dac92013-06-27 17:35:53 -0400502 }
503
504 @Override
505 public void replaceCurrentCallDisplayed() {
Alexandre Lision6e8931e2013-09-19 16:49:34 -0400506 mHandler.removeCallbacks(mUpdateTimeTask);
alisiondf1dac92013-06-27 17:35:53 -0400507 mCurrentCallFragment.getBubbleView().stopThread();
508 getFragmentManager().beginTransaction().remove(mCurrentCallFragment).commit();
alision465ceba2013-07-04 09:24:30 -0400509 mCurrentCallFragment = null;
alision34673e62013-06-25 14:40:07 -0400510
alision806e18e2013-06-21 15:30:17 -0400511 }
512
Alexandre Lision0c384512013-09-17 17:15:57 -0400513 @Override
514 public void startTimer() {
515 mHandler.postDelayed(mUpdateTimeTask, 0);
516 }
517
Alexandre Lision40954dc2013-10-09 15:24:03 -0400518 public void onCallSuspended() {
519 try {
520 if (mCurrentCallFragment.getConference().hasMultipleParticipants()) {
521 service.holdConference(mCurrentCallFragment.getConference().getId());
522 } else {
523 service.hold(mCurrentCallFragment.getConference().getParticipants().get(0).getCallId());
524 }
525 } catch (RemoteException e) {
526 // TODO Bloc catch généré automatiquement
527 e.printStackTrace();
528 }
529 }
Alexandre Savard14323be2012-10-24 10:02:13 -0400530}