FreeCalypso > hg > tcs211-l1-reconst
comparison g23m/condat/ms/src/bmi/MmiServices.c @ 0:509db1a7b7b8
initial import: leo2moko-r1
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Mon, 01 Jun 2015 03:24:05 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:509db1a7b7b8 |
---|---|
1 /******************************************************************************* | |
2 | |
3 CONDAT (UK) | |
4 | |
5 ******************************************************************************** | |
6 | |
7 This software product is the property of Condat (UK) Ltd and may not be | |
8 disclosed to any third party without the express permission of the owner. | |
9 | |
10 ******************************************************************************** | |
11 | |
12 $Project name: Basic MMI | |
13 $Project code: BMI (6349) | |
14 $Module: Supplementary services | |
15 $File: MmiServices.c | |
16 $Revision: 1.0 | |
17 | |
18 $Author: Condat(UK) | |
19 $Date: 25/10/00 | |
20 | |
21 ******************************************************************************** | |
22 | |
23 Description | |
24 | |
25 This module provides the supplementary services functionality | |
26 | |
27 | |
28 ******************************************************************************** | |
29 $History: MmiServices.c | |
30 | |
31 Dec 07, 2005 REF: OMAPS00050087 x0039928 | |
32 Description: Deactivated is displayed while activate Hide Id option is selected | |
33 Solution: String "Not Activated" is displayed if the Hide Id activation fails. | |
34 | |
35 July 09, 2005 REF : MMI-22565 - a0876501 | |
36 Description: IMEI CD byte calculation added | |
37 Solution: Increased the IMEI_LEN from 15 to 17 for displaying the Cd byte. | |
38 | |
39 Jun 16, 2005 REF: CRR 31543 x0021334 | |
40 Issue: SATK: cannot get TR for send ussd command | |
41 Solution: When the user presses "Hang up" key when the SAT USSD session is in progress, | |
42 a call is made to function 'sAT_end_ussd()' to end the USSD session. | |
43 | |
44 May 12, 2005 REF: CRR 30892 x0021334 | |
45 Bug: MMI doesn't handle 2nd Interogation of "CW for basic services" using USSD *#43#. | |
46 Fix: Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
47 | |
48 May 02, 2005 REF : LOCOSTO-ENH-30818 - xpradipg | |
49 Description: IMEI retreival by posting a call to ACI sAT_xx API | |
50 Solution: The direct call to cl_get_imeisv() is replaced with the | |
51 call to the mmi_imei_store() which inturn calls sAT_Dn() and | |
52 retrieves the IMEI info and stores it onto the global | |
53 variable "imei" | |
54 | |
55 Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
56 Bug : Unable to compose a one or two digit number | |
57 Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
58 The read only editor with the service provider message that comes up when a one or two digit is dialled | |
59 was not handled properly. So altered the editor handling to cater for the long message. | |
60 | |
61 Oct 20, 2004 REF: CRR 25772 Deepa M.D | |
62 Bug: Not displaying proper RSK name in call divert edit screens | |
63 Fix: The RSK name will be changed based on whether the editor content is empty or not. | |
64 | |
65 Jul 23, 2004 REF: CRR 16107 xvilliva | |
66 Bug: (Call Barring) - MMI response overlayes partially background images. | |
67 Fix: Alert being displayed is altered. | |
68 | |
69 Jun 21,2004 CRR:13650 xpradipg - SASKEN | |
70 | |
71 Jul 16, 2004 REF: CRR 18409 xvilliva | |
72 Bug: CHW : message "Deactivated" when it should be "Activated". | |
73 Fix: The alert displayed depends on the status code received. If we | |
74 receive the status as zero or 0xFF, we now show an alert saying | |
75 "unknown status" instead of "Deactivated". | |
76 | |
77 | |
78 Jun 21,2004 CRR:13650 xpradipg - SASKEN | |
79 | |
80 Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
81 Solution: The CF state is maintained in flash. During bootup the CF icon in the idle screen | |
82 is displayed depending upon its state in the ffs | |
83 | |
84 Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
85 Solution: The condition for which Call Forward is activated/deactivated or its staus is checked, | |
86 is displayed in the message along with the activation/deactivation message | |
87 | |
88 Jun 21,2004 CRR:13650 xpradipg - SASKEN | |
89 Description: CBA : no basic service sent when using the menu | |
90 Fix: Basic service code 10(All teleservices) is sent for activation and deactivation thru menus | |
91 | |
92 | |
93 | |
94 Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
95 Description: CFO interrogation display : Timer to long | |
96 Fix: Timer is enabled for the information dialog. It times out after 5 seconds from the last key | |
97 press. | |
98 | |
99 Jun 03, 2004 CRR:13649 - xpradipg-SASKEN | |
100 subject: CBA : Management of password | |
101 solution: password is promted on selecting activation/deactivation option as against the previous | |
102 case where it was shown up on selecting CallBarring option in the Network Services | |
103 | |
104 | |
105 Issue Number : SPR#12882 on 29/03/04 by VadiRaj | |
106 | |
107 25/10/00 Original Condat(UK) BMI version. | |
108 | |
109 $End | |
110 | |
111 *******************************************************************************/ | |
112 | |
113 | |
114 /****************************************************************************** | |
115 | |
116 Include Files | |
117 | |
118 *******************************************************************************/ | |
119 | |
120 #define BUGS 0 | |
121 | |
122 #define ENTITY_MFW | |
123 | |
124 /* includes */ | |
125 #include <string.h> | |
126 #include <stdio.h> | |
127 #include <stdlib.h> | |
128 | |
129 #if defined (NEW_FRAME) | |
130 | |
131 #include "typedefs.h" | |
132 #include "vsi.h" | |
133 #include "pei.h" | |
134 #include "custom.h" | |
135 #include "gsm.h" | |
136 | |
137 #else | |
138 | |
139 #include "STDDEFS.H" | |
140 #include "custom.h" | |
141 #include "gsm.h" | |
142 #include "vsi.h" | |
143 | |
144 #endif | |
145 #include "prim.h" | |
146 | |
147 | |
148 #include "mfw_sys.h" | |
149 #include "mfw_mfw.h" | |
150 #include "mfw_win.h" | |
151 #include "mfw_kbd.h" | |
152 /* SPR#1428 - SH - New Editor changes */ | |
153 #ifndef NEW_EDITOR | |
154 #include "mfw_edt.h" | |
155 #endif /* NEW_EDITOR */ | |
156 #include "mfw_lng.h" | |
157 #include "mfw_icn.h" | |
158 #include "mfw_tim.h" | |
159 #include "mfw_mnu.h" | |
160 #include "mfw_phb.h" | |
161 #include "mfw_sat.h" | |
162 #include "mfw_ffs.h" | |
163 #include "ksd.h" | |
164 #include "psa.h" | |
165 #include "mfw_sms.h" | |
166 #include "mfw_sim.h" | |
167 #include "mfw_nm.h" | |
168 #include "mfw_cm.h" | |
169 #include "mfw_ss.h" | |
170 #include "dspl.h" | |
171 #include "MmiMmi.h" | |
172 #include "MmiDummy.h" | |
173 #include "MmiDialogs.h" | |
174 #include "MmiLists.h" | |
175 #include "MmiMain.h" | |
176 #include "MmiStart.h" | |
177 #include "MmiPins.h" | |
178 #include "MmiIdle.h" | |
179 #include "MmiMenu.h" | |
180 #include "MmiSoftKeys.h" | |
181 #include "Mmiicons.h" | |
182 #include "mmiCall.h" | |
183 #include "MmiServices.h" | |
184 /* SPR#1428 - SH - New Editor changes */ | |
185 #ifdef NEW_EDITOR | |
186 #include "ATBCommon.h" | |
187 #include "ATBDisplay.h" | |
188 #include "ATBEditor.h" | |
189 #include "AUIEditor.h" | |
190 #include "AUITextEntry.h" | |
191 #else /* NEW_EDITOR */ | |
192 #include "MmiEditor.h" | |
193 #endif /* NEW_EDITOR */ | |
194 | |
195 #include "MmiCPHS.h" | |
196 | |
197 | |
198 #include "MmiBookUtils.h" | |
199 #include "MmiBookShared.h " // MZ 26/02/01 | |
200 #include "cus_aci.h" | |
201 | |
202 #include "prim.h" | |
203 #ifndef PCM_2_FFS | |
204 #include "pcm.h" | |
205 #endif | |
206 | |
207 | |
208 #include "mmiColours.h" | |
209 #include "aci_cmh.h" // Marcus: Issue 1494: 18/12/2002: for MAX_USSD_LEN | |
210 | |
211 //gprads CQ-16432 | |
212 #include "AUIEditor_i.h" | |
213 extern void msgsGetVoiceAddress(CHAR *Buffer); | |
214 extern void InfoDialogTimRestart(T_MFW_HND win); | |
215 | |
216 static void (*show) (void); | |
217 | |
218 static void showWait (T_MFW_HND win); | |
219 static void showOk (T_MFW_HND win); | |
220 static void showFailed (T_MFW_HND win); | |
221 static void showError (T_MFW_HND win, T_MFW_SS_ERROR ss_error); | |
222 static void showCLIStatus (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf ); | |
223 static void showSSNotify (T_MFW_HND win, T_MFW_SS_NOTIFY * ss_notify); | |
224 | |
225 | |
226 | |
227 static void showIMEI2 (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf); | |
228 static void showUSSDREQ (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf); | |
229 static void showUSSDCNF (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf); | |
230 static void showUSSDEnter (void); | |
231 static void showUSSDFull (T_MFW_HND win); | |
232 static void sendUSSD (T_MFW_SS_PARA *ussd_senddata); | |
233 static int servicesSendCallDivert(char * divert_number); | |
234 int servicesUSSDEdit(struct MfwMnuTag* m, struct MfwMnuItemTag* i); | |
235 int servicesUSSDDelete(struct MfwMnuTag* m, struct MfwMnuItemTag* i); | |
236 static void servicesShowUSSDMenu(void); | |
237 static void servicesStoreUSSD(void); | |
238 | |
239 static void ServicesGetOtherNumber(T_MFW_HND win); | |
240 static void servicesStoreVoiceMailNumber( void ); | |
241 #ifdef NEW_EDITOR | |
242 static void services_get_voice_number_cb(T_MFW_HND win, USHORT identifier, SHORT reason); | |
243 #else /* NEW_EDITOR */ | |
244 static void services_get_voice_number_cb(T_MFW_HND win, USHORT reason); | |
245 #endif /* NEW_EDITOR */ | |
246 | |
247 typedef struct | |
248 { | |
249 T_MMI_CONTROL mmi_control; | |
250 T_MFW_HND parent_win; | |
251 T_MFW_HND info_win; | |
252 T_MFW_HND info_tim; | |
253 T_MFW_HND info_kbd; | |
254 T_MFW_HND info_kbd_long; | |
255 USHORT LeftSoftKey; /* used for Ok */ | |
256 USHORT RightSoftKey; /* Used for Back */ | |
257 ULONG Time; | |
258 T_MFW_EVENT KeyEvents; | |
259 USHORT TextId1; /* Line 1 */ | |
260 USHORT TextId2; /* Line 2 */ | |
261 char * TextString4; | |
262 USHORT Identifier; | |
263 T_VOID_FUNC Callback; | |
264 } T_dialog_ext_info; | |
265 | |
266 T_MFW_HND dialog_ext_info_dialog (T_MFW_HND parent_win, | |
267 T_dialog_ext_info * display_info); | |
268 | |
269 static MfwHnd lastFocus; /* store old focus */ | |
270 static MfwHnd win; /* our window */ | |
271 static MfwHnd kbd; /* our keyboard handler */ | |
272 static MfwHnd times; /* timeout */ | |
273 | |
274 static MmiState nextState; /* next state when finished */ | |
275 static int servicesState; /* current state of module */ | |
276 | |
277 | |
278 static T_MFW_SS_PARA *ss_cnf; /* union container for all SS confirmations */ | |
279 | |
280 /* decode service type - tele/bearer */ | |
281 static unsigned int serviceGetServiceType( UBYTE ss_telecom_type, UBYTE ss_telecom_service); | |
282 static unsigned int serviceGetCategory( T_MFW_SS_CATEGORY cat ); | |
283 static unsigned int serviceGetType( T_MFW_SS_CODES type ); | |
284 static unsigned int ServiceGetStatus( UBYTE pStatus); | |
285 static unsigned int serviceGetError( T_MFW_SS_ERROR ss_error); | |
286 | |
287 | |
288 | |
289 #define SS_STAT_NONE 0 //xvilliva 18409, not registered, not active, | |
290 //not provisioned,not quiescent | |
291 | |
292 | |
293 | |
294 #define CB_PSW_LEN 4 | |
295 //June 17, 2004 - CRR:13650 - CBA : no basic service sent when using the menu | |
296 //basic service code for "all teleservices" | |
297 #define BASIC_SERVICE_CODE "10" | |
298 int ss_Code; | |
299 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
300 // ss_Code-- This holds the current CF code for which the activation/deactivation or the staus is being checked | |
301 // This would be used while displaying the status or activation/deactivation message | |
302 | |
303 | |
304 typedef enum | |
305 { | |
306 CFBusy = 0, | |
307 CFNoReach, | |
308 CFNoReply, | |
309 CFAllConditional, | |
310 CFUnconditional, | |
311 CFAllCalls | |
312 } SERVICE_CF_TYPE; | |
313 | |
314 typedef enum | |
315 { | |
316 CBAllOutgoing = 0, | |
317 CBInternational, | |
318 CBInternationalHome, | |
319 CBAllIncoming, | |
320 CBIncomingRoaming | |
321 } SERVICE_CB_TYPE; | |
322 | |
323 | |
324 | |
325 typedef enum | |
326 { | |
327 CFVoice = 0, | |
328 CFAuxVoice, /*MC, ALS line 2*/ | |
329 CFFax, | |
330 CFData, | |
331 CFAll | |
332 } SERVICE_CF_SERVICE; | |
333 | |
334 typedef enum | |
335 { | |
336 CFActivate = 0, | |
337 CFDeactivate, | |
338 CFCheck | |
339 } SERVICE_CF_ACTION; | |
340 | |
341 typedef enum | |
342 { | |
343 CBActivate = 0, | |
344 CBDeactivate, | |
345 CBCheck, | |
346 CBCheckPassword, | |
347 CBNewPassword, | |
348 CBConfirmNewPassword, | |
349 //Jun 02, 2004 CRR:13649 - xpradipg-SASKEN | |
350 //added for holding the state for callbarring service | |
351 //CQ-13649:start | |
352 CBCancelAll, | |
353 CBActionNone, | |
354 //CQ-13649:end | |
355 //CQ-16432 start | |
356 CBEnterSatPassword | |
357 //CQ-16432 end | |
358 } SERVICE_CB_ACTION; | |
359 | |
360 | |
361 | |
362 /* NOTE that these are needed in new architecture */ | |
363 static SERVICE_CF_TYPE CFType; /* Type of Call Forwarding */ | |
364 static SERVICE_CF_SERVICE CFService; /* basic service for Call Forwarding */ | |
365 static SERVICE_CF_ACTION CFAction; /* action for Call Forwarding */ | |
366 static SERVICE_CB_TYPE CBType; /* Type of Call Barring */ | |
367 static SERVICE_CB_ACTION CBAction; /* action for Call Barring */ | |
368 //Jun 02, 2004 CRR:13649 - xpradipg-SASKEN | |
369 //new enum added to indicate the action to be taken in the callback function for password | |
370 static SERVICE_CB_ACTION CBFlag; /*to indicate the action after retriving the password*/ | |
371 //CRR:13649 | |
372 static char CFNumber[MAX_LEN]; /* number to forward calls to */ | |
373 | |
374 | |
375 | |
376 /* end of bits for USSD */ | |
377 | |
378 | |
379 | |
380 #define CF_ACTIVE_STATUS 1 | |
381 #define CF_INACTIVE_STATUS 2 | |
382 /* Marcus: Issue 1652: 03/02/2003 */ | |
383 #define CF_PROVISIONED_STATUS 3 | |
384 #define CF_UNKNOWN_STATUS 4 | |
385 | |
386 #define MAX_SS_CF_NUM_LEN 16 | |
387 | |
388 typedef struct | |
389 { | |
390 USHORT service; | |
391 USHORT status; | |
392 char forwarded_to_number[MAX_SS_CF_NUM_LEN]; | |
393 } T_ss_feature_cf_data; | |
394 | |
395 typedef struct | |
396 { | |
397 T_ss_feature_cf_data ss[MFW_MAX_FEAT_NR]; | |
398 } T_ss_feature_cf; | |
399 | |
400 | |
401 typedef struct | |
402 { | |
403 USHORT service; | |
404 } T_ss_feature_cw_data; | |
405 | |
406 typedef struct | |
407 { | |
408 USHORT status; | |
409 T_ss_feature_cw_data ss[MFW_MAX_FEAT_NR]; | |
410 } T_ss_feature_cw; | |
411 | |
412 typedef struct | |
413 { | |
414 USHORT service; | |
415 USHORT status; | |
416 } T_ss_feature_cb_data; | |
417 | |
418 typedef struct | |
419 { | |
420 T_ss_feature_cb_data ss[MFW_MAX_FEAT_NR]; | |
421 } T_ss_feature_cb; | |
422 | |
423 typedef struct | |
424 { | |
425 T_MMI_CONTROL mmi_control; | |
426 T_MFW_HND win; // window handle | |
427 T_MFW_HND ss_handle; /* MFW services handler */ | |
428 T_MFW_HND kbd; | |
429 T_MFW_HND kbd_long; | |
430 // T_MFW_CM_AOC_INFO aocInfo; | |
431 T_MFW_HND info_win; /* handle to info dialog */ | |
432 T_MFW_HND info_wait; /* handle to wait dialog */ | |
433 T_MFW_HND cb_menu_win; /* handle to ussd number dialog */ | |
434 T_MFW_HND input_number_win; /* handle to call forward dialog */ | |
435 | |
436 USHORT event; | |
437 char edt_buf_name[MAX_ALPHA_LEN];/*MC SPR 1257*/ | |
438 char edt_buf_number[PHB_MAX_LEN]; | |
439 char edt_buf_cb_password[CB_PSW_LEN+1]; | |
440 char edt_buf_cb_new_password[CB_PSW_LEN+1]; | |
441 char edt_buf_cb_conf_new_password[CB_PSW_LEN+1]; | |
442 #ifndef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - no longer required */ | |
443 MfwEdtAttr edt_attr_name; | |
444 MfwEdtAttr edt_attr_number; | |
445 #endif /* ifndef NEW_EDITOR */ | |
446 T_ss_feature_cf * mfw_ss_cf; | |
447 T_ss_feature_cw * mfw_ss_cw; | |
448 T_ss_feature_cb * mfw_ss_cb; | |
449 UBYTE current_feature; | |
450 UBYTE max_feature; | |
451 UBYTE dcs; /* need it for sending ussd to mfw */ | |
452 | |
453 /* | |
454 ** NDH : 28/08/2003 | |
455 ** | |
456 ** cfu_services is a binary flag to determine which (if any) of the Call Frwd Uncond | |
457 ** services are active. The map is as follows : | |
458 ** bit 0 : Voice Calls ( & 0x01) | |
459 ** bit 1 : Fax Calls ( & 0x02) | |
460 ** bit 2 : Data Calls ( & 0x04) | |
461 ** bit 3 : SMS ( & 0x08) | |
462 ** bit 4 : unused - for future expansion | |
463 ** bit 5 : unused - for future expansion | |
464 ** bit 6 : unused - for future expansion | |
465 ** bit 7 : unused - for future expansion | |
466 */ | |
467 UBYTE cfu_services; | |
468 } T_ss; | |
469 | |
470 #define MFW_CFU_VOICE_ACTIVE 0x01 | |
471 #define MFW_CFU_FAX_ACTIVE 0x02 | |
472 #define MFW_CFU_DATA_ACTIVE 0x04 | |
473 #define MFW_CFU_SMS_ACTIVE 0x08 | |
474 | |
475 #define MFW_CFU_ALL_SERVICES_ACTIVE (MFW_CFU_VOICE_ACTIVE | MFW_CFU_FAX_ACTIVE | MFW_CFU_DATA_ACTIVE | MFW_CFU_SMS_ACTIVE) | |
476 #define MFW_CFU_ALL_BASIC_SERVICES_ACTIVE (MFW_CFU_VOICE_ACTIVE | MFW_CFU_FAX_ACTIVE | MFW_CFU_DATA_ACTIVE) | |
477 | |
478 T_ss ss_data = {0}; | |
479 char satPassword[10]={0};//CQ-16432 | |
480 | |
481 static void srv_empty_list_result (UBYTE ss_category, USHORT event, UBYTE ss_status, UBYTE ss_code); /* Marcus: Issue 1652: 03/02/2002 */ | |
482 static void showCFStatus (T_MFW_HND win , T_ss * data ); | |
483 static UBYTE srv_copy_feature_list_cf (T_ss_feature_cf * out_list, T_MFW_SS_CF_CNF * in_list); | |
484 static void srv_get_forwarded_to_number ( char * textString, | |
485 char * forwarded_to_number, | |
486 UBYTE max_chars); | |
487 static UBYTE srv_get_service_type ( USHORT * textId, | |
488 UBYTE ss_telecom_type, UBYTE ss_telecom_service); | |
489 static void srv_get_status (USHORT *textId, UBYTE pStatus); | |
490 static UBYTE srv_check_CF_telephony_status (T_MFW_SS_CF_CNF * in_list); | |
491 | |
492 static void showCWStatus (T_MFW_HND win, T_ss * data ); | |
493 static UBYTE srv_copy_feature_list_cw (T_ss_feature_cw * out_list, T_MFW_SS_CW_CNF * in_list); | |
494 | |
495 static void showCBStatus (T_MFW_HND win, T_ss * data ); | |
496 static UBYTE srv_copy_feature_list_cb (T_ss_feature_cb * out_list, T_MFW_SS_CB_CNF * in_list); | |
497 | |
498 | |
499 static int services_win_cb(T_MFW_EVENT e, T_MFW_SS_PARA * para); | |
500 static int services_ss_cb(T_MFW_EVENT e, T_MFW_HND para); | |
501 | |
502 static int services_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reason); | |
503 | |
504 | |
505 static void srv_display_status (UBYTE ss_status); | |
506 | |
507 | |
508 | |
509 typedef struct | |
510 { | |
511 int text; | |
512 #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes */ | |
513 T_ED_ATTR *editor_attr_input; | |
514 #else /* NEW_EDITOR */ | |
515 MfwEdtAttr* edt_attr_input; | |
516 #endif /* NEW_EDITOR */ | |
517 int left_soft_key; | |
518 int right_soft_key; | |
519 short abc; /* numeric or alpha? */ | |
520 #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes */ | |
521 T_AUI_EDIT_CB callback; | |
522 #else /* NEW_EDITOR */ | |
523 void (* callback)(T_MFW_HND win,USHORT reason); | |
524 #endif /* NEW_EDITOR */ | |
525 } T_input_properties; | |
526 | |
527 | |
528 | |
529 | |
530 typedef struct | |
531 { | |
532 T_MMI_CONTROL mmi_control; | |
533 T_MFW_HND parent_win; | |
534 T_MFW_HND win; | |
535 T_MFW_HND kbd; | |
536 T_MFW_HND kbd_long; | |
537 #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes */ | |
538 T_MFW_HND edit_win; | |
539 #else /* NEW_EDITOR */ | |
540 T_MFW_HND edt_input; | |
541 #endif /* NEW_EDITOR */ | |
542 T_input_properties properties; | |
543 } T_services_input; | |
544 | |
545 /* SPR#1428 - SH - New Editor changes - no longer required*/ | |
546 #ifndef NEW_EDITOR | |
547 void services_number_input_cb(T_MFW_HND win, UBYTE identifier, USHORT reason); | |
548 #endif | |
549 | |
550 | |
551 | |
552 static T_MFW_HND services_input_create (MfwHnd parent); | |
553 static void services_input_destroy (MfwHnd window); | |
554 static MfwHnd services_input_start(MfwHnd parent,T_input_properties *properties); | |
555 void services_input (T_MFW_HND win, USHORT event, SHORT value, void * parameter); | |
556 static int services_input_win_cb(MfwEvt e, MfwWin *w); | |
557 | |
558 /* SPR#1428 - SH - New Editor changes - no longer required*/ | |
559 #ifndef NEW_EDITOR | |
560 static int services_input_kbd_cb(MfwEvt e, MfwKbd *k); | |
561 static int services_input_kbd_long_cb(MfwEvt e, MfwKbd *k); | |
562 #endif | |
563 | |
564 | |
565 | |
566 /* editor */ | |
567 //GW Moved editor definitions to MmiResources.h | |
568 #define SAT_EDITOR_COLOR 0 | |
569 #define SAT_EDITOR_FONT 0 | |
570 #define SAT_EDITOR_CONTROLS 0 | |
571 #define SAT_EDITOR_BUFFER_SIZE 32 | |
572 /* */ | |
573 | |
574 // May 02, 2005 REF : LOCOSTO-ENH-30818 - xpradipg | |
575 #ifdef FF_MMI_ATC_MIGRATION | |
576 #define IMEI_LEN 15 | |
577 #endif | |
578 | |
579 /******************************************************************************* | |
580 | |
581 $Function: servicesInit | |
582 | |
583 $Description: | |
584 | |
585 $Returns: | |
586 | |
587 $Arguments: | |
588 | |
589 *******************************************************************************/ | |
590 | |
591 | |
592 | |
593 T_MFW_HND servicesInit (T_MFW_HND parent) | |
594 { | |
595 | |
596 TRACE_FUNCTION("servicesInit function"); | |
597 | |
598 /* | |
599 * Initialise MFW | |
600 */ | |
601 ss_mfw_init(); | |
602 /* | |
603 * Create any other handler | |
604 */ | |
605 //16432 | |
606 //Changed ss_create(0,0xFFFF,....) | |
607 ss_data.ss_handle = ss_create (0, | |
608 0xFFFF, | |
609 (T_MFW_CB)services_ss_cb); | |
610 | |
611 ss_data.win = 0; | |
612 return (services_create (0)); | |
613 | |
614 | |
615 } | |
616 | |
617 | |
618 /******************************************************************************* | |
619 | |
620 $Function: servicesExit | |
621 | |
622 $Description: exit services handling | |
623 | |
624 $Returns: | |
625 | |
626 $Arguments: | |
627 | |
628 *******************************************************************************/ | |
629 | |
630 | |
631 | |
632 void servicesExit (void) | |
633 { | |
634 TRACE_FUNCTION("servicesExit"); | |
635 | |
636 ss_delete(ss_data.win); | |
637 ss_exit(); | |
638 } | |
639 | |
640 | |
641 /******************************************************************************* | |
642 | |
643 $Function: services_create | |
644 | |
645 $Description: Creation of an instance for the Services dialog. | |
646 | |
647 $Returns: | |
648 | |
649 $Arguments: | |
650 | |
651 *******************************************************************************/ | |
652 | |
653 | |
654 T_MFW_HND services_create (T_MFW_HND parent_window) | |
655 { | |
656 T_ss * data = &ss_data; | |
657 T_MFW_WIN * win; | |
658 | |
659 TRACE_FUNCTION("services_create"); | |
660 | |
661 data->win = win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)services_win_cb); | |
662 | |
663 if (data->win EQ 0) | |
664 return 0; | |
665 | |
666 /* | |
667 * Create window handler | |
668 */ | |
669 data->mmi_control.dialog = (T_DIALOG_FUNC)services; | |
670 data->mmi_control.data = data; | |
671 win = ((T_MFW_HDR *)data->win)->data; | |
672 win->user = (void *) data; | |
673 | |
674 /* | |
675 * Create any other handler | |
676 */ | |
677 data->info_win = 0; | |
678 data->info_wait = 0; | |
679 data->cb_menu_win = 0; | |
680 | |
681 /* SPR#1428 - SH - New Editor changes - this editor never used */ | |
682 #if 0 | |
683 data->ussd_num_win = 0; | |
684 data->ussd_name_win = 0; | |
685 #endif | |
686 | |
687 data->input_number_win = 0; | |
688 memset(data->edt_buf_name,'\0',sizeof(data->edt_buf_name)); | |
689 memset(data->edt_buf_number,'\0',sizeof(data->edt_buf_number)); | |
690 memset(data->edt_buf_cb_password,'\0',sizeof(data->edt_buf_number)); | |
691 /* SPR#1428 - SH - New Editor changes - no longer required*/ | |
692 #ifndef NEW_EDITOR | |
693 bookSetEditAttributes(SERVICE_CREATE_EDITOR,COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)data->edt_buf_name,PHB_MAX_LEN,&data->edt_attr_name); | |
694 bookSetEditAttributes(SERVICE_CREATE_EDITOR,COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)data->edt_buf_number,PHB_MAX_LEN,&data->edt_attr_number); | |
695 #endif /* ifndef NEW_EDITOR */ | |
696 | |
697 /* NDH : 28/08/2003 : Intialise cfu_services to "ALL Inactive" */ | |
698 data->cfu_services = 0; | |
699 | |
700 winShow (data->win); | |
701 | |
702 /* | |
703 * return window handle | |
704 */ | |
705 return data->win; | |
706 } | |
707 | |
708 | |
709 /******************************************************************************* | |
710 | |
711 $Function: services_destroy | |
712 | |
713 $Description: | |
714 | |
715 $Returns: | |
716 | |
717 $Arguments: | |
718 | |
719 *******************************************************************************/ | |
720 | |
721 | |
722 void services_destroy (T_MFW_HND own_window) | |
723 { | |
724 // T_MFW_WIN * win; // RAVI | |
725 T_ss * data = &ss_data; | |
726 | |
727 TRACE_FUNCTION("=== services_destroy"); | |
728 | |
729 if (data) | |
730 { | |
731 /* | |
732 * Delete WIN Handler | |
733 */ | |
734 | |
735 if (data->info_win) | |
736 { | |
737 SEND_EVENT(data->info_win, DIALOG_DESTROY, 0, 0); | |
738 data->info_win=0; | |
739 } | |
740 if (ss_data.info_wait) | |
741 { | |
742 TRACE_FUNCTION("destroying the wait screen b"); | |
743 SEND_EVENT(ss_data.info_wait, DIALOG_DESTROY, 0, 0); | |
744 ss_data.info_wait = 0; | |
745 } | |
746 | |
747 | |
748 if (data->input_number_win) | |
749 { | |
750 TRACE_FUNCTION("killing input number win"); | |
751 services_input_destroy( data->input_number_win ); | |
752 data->input_number_win=0; | |
753 } | |
754 } | |
755 } | |
756 | |
757 /******************************************************************************* | |
758 | |
759 $Function: services_win_cb | |
760 | |
761 $Description: | |
762 | |
763 $Returns: | |
764 | |
765 $Arguments: | |
766 | |
767 *******************************************************************************/ | |
768 | |
769 static int services_win_cb(T_MFW_EVENT e, T_MFW_SS_PARA * para) | |
770 { | |
771 /* | |
772 * Top Window has no output | |
773 */ | |
774 TRACE_FUNCTION ("services_win_cb()"); | |
775 switch (e) | |
776 { | |
777 case MfwWinVisible: | |
778 break; | |
779 default: | |
780 return 0; | |
781 } | |
782 return 1; | |
783 | |
784 } | |
785 | |
786 /******************************************************************************* | |
787 | |
788 $Function: destroyInfoWindow | |
789 | |
790 $Description: | |
791 | |
792 $Returns: | |
793 | |
794 $Arguments: | |
795 | |
796 *******************************************************************************/ | |
797 | |
798 static void destroyInfoWindow( void) | |
799 { | |
800 TRACE_FUNCTION("destroyInfoWindow"); | |
801 | |
802 /* kill info win if there */ | |
803 if (ss_data.info_wait) | |
804 { | |
805 TRACE_FUNCTION("destroying the wait screen a"); | |
806 SEND_EVENT(ss_data.info_wait, DIALOG_DESTROY, 0, 0); | |
807 ss_data.info_wait = 0; | |
808 } | |
809 if (ss_data.input_number_win) | |
810 { | |
811 TRACE_FUNCTION("destroying input window!!!"); | |
812 SEND_EVENT(ss_data.input_number_win, SERVICES_INPUT_DESTROY, 0, 0); | |
813 ss_data.input_number_win = 0; | |
814 } | |
815 | |
816 } | |
817 /******************************************************************************* | |
818 | |
819 $Function: services_ss_cb | |
820 | |
821 $Description: | |
822 | |
823 $Returns: | |
824 | |
825 $Arguments: | |
826 | |
827 *******************************************************************************/ | |
828 | |
829 | |
830 static int services_ss_cb(T_MFW_EVENT e, T_MFW_HND para) | |
831 { | |
832 | |
833 TRACE_FUNCTION ("services_ss_cb()"); | |
834 | |
835 { | |
836 // T_MFW_WIN * win; // RAVI | |
837 // win = (T_MFW_WIN *) ((T_MFW_HDR *)ss_data.win)->data; // RAVI | |
838 } | |
839 | |
840 switch (e) | |
841 { | |
842 case E_SS_RES: | |
843 if (!ss_data.info_wait) | |
844 { | |
845 TRACE_FUNCTION ("show the wait screen"); | |
846 showWait( ss_data.win ); | |
847 } | |
848 /* | |
849 * ignore the event | |
850 */ | |
851 break; | |
852 | |
853 case E_SS_NOTIFY: | |
854 if(!ss_data.info_win) | |
855 SEND_EVENT(ss_data.win,E_SS_NOTIFY,0, para); | |
856 | |
857 destroyInfoWindow(); | |
858 break; | |
859 | |
860 case E_SS_CF_CNF: | |
861 | |
862 if(!ss_data.info_win) | |
863 SEND_EVENT(ss_data.win,E_SS_CF_CNF,0, para); | |
864 | |
865 destroyInfoWindow(); | |
866 break; | |
867 | |
868 case E_SS_CF_ICN_UPD: | |
869 | |
870 if(!ss_data.info_win) | |
871 SEND_EVENT(ss_data.win,E_SS_CF_ICN_UPD,0, para); | |
872 | |
873 destroyInfoWindow(); | |
874 break; | |
875 | |
876 case E_SS_CW_CNF: | |
877 if(!ss_data.info_win) | |
878 SEND_EVENT(ss_data.win,E_SS_CW_CNF,0, para); | |
879 | |
880 destroyInfoWindow(); | |
881 break; | |
882 | |
883 case E_SS_CLI_CNF: | |
884 if(!ss_data.info_win) | |
885 SEND_EVENT(ss_data.win,E_SS_CLI_CNF,0, para); | |
886 | |
887 destroyInfoWindow(); | |
888 break; | |
889 | |
890 case E_SS_CB_CNF: | |
891 if(!ss_data.info_win) | |
892 SEND_EVENT(ss_data.win,E_SS_CB_CNF,0, para); | |
893 | |
894 destroyInfoWindow(); | |
895 break; | |
896 | |
897 /* we must display the ussd info and then edit and send a user ussd */ | |
898 case E_SS_USSD_REQ: | |
899 | |
900 if(!ss_data.info_win) | |
901 SEND_EVENT(ss_data.win,E_SS_USSD_REQ,0, para); | |
902 | |
903 destroyInfoWindow(); | |
904 break; | |
905 | |
906 /* just display the ussd info */ | |
907 case E_SS_USSD_CNF: | |
908 | |
909 if(!ss_data.info_win) | |
910 SEND_EVENT(ss_data.win,E_SS_USSD_CNF,0, para); | |
911 | |
912 destroyInfoWindow(); | |
913 break; | |
914 | |
915 case E_SS_IMEI: | |
916 | |
917 if(!ss_data.info_win) | |
918 SEND_EVENT(ss_data.win,E_SS_IMEI,0, para); | |
919 | |
920 destroyInfoWindow(); | |
921 break; | |
922 | |
923 | |
924 case E_SS_GET_PW: | |
925 | |
926 if(!ss_data.info_win) | |
927 SEND_EVENT(ss_data.win,E_SS_GET_PW,0, para); | |
928 | |
929 destroyInfoWindow(); | |
930 break; | |
931 //CQ-16432 - start | |
932 case E_SS_SAT_CPWD: | |
933 TRACE_EVENT("Received event E_SS_SAT_CPWD in BMI"); | |
934 if(!ss_data.info_win) | |
935 SEND_EVENT(ss_data.win,E_SS_SAT_CPWD,0, para); | |
936 destroyInfoWindow(); | |
937 break; | |
938 //CQ-16432 - end | |
939 default: | |
940 break; | |
941 } | |
942 | |
943 return 1; /* consumed */ | |
944 } | |
945 | |
946 | |
947 /******************************************************************************* | |
948 | |
949 $Function: services | |
950 | |
951 $Description: | |
952 | |
953 $Returns: | |
954 | |
955 $Arguments: | |
956 | |
957 *******************************************************************************/ | |
958 | |
959 void services (T_MFW_HND win, USHORT event, SHORT value, void * parameter) | |
960 { | |
961 T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; | |
962 T_ss * data = (T_ss *)win_data->user; | |
963 | |
964 T_MFW_SS_PARA * ss_cnf = (T_MFW_SS_PARA *)parameter; | |
965 | |
966 // unsigned int i = 0; // RAVI | |
967 | |
968 // char line[MAX_LINE]; // RAVI | |
969 | |
970 TRACE_FUNCTION ("services()"); | |
971 | |
972 switch (event) | |
973 { | |
974 | |
975 | |
976 case ServicesError: | |
977 TRACE_FUNCTION ("ServicesError"); | |
978 showError(win, ss_cnf->cb_cnf.ss_error); | |
979 break; | |
980 | |
981 case ServicesFailed: | |
982 TRACE_FUNCTION ("ServicesFailed"); | |
983 showFailed(win); | |
984 break; | |
985 | |
986 case ServicesOtherNumber: | |
987 TRACE_FUNCTION("ServicesOtherNumber"); | |
988 ServicesGetOtherNumber(win); | |
989 break; | |
990 | |
991 case ServicesOk: | |
992 TRACE_FUNCTION ("ServicesOk"); | |
993 showOk(win); | |
994 break; | |
995 | |
996 case ServicesUSSDEnter: | |
997 { | |
998 #ifdef NEW_EDITOR | |
999 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */ | |
1000 #else | |
1001 T_EDITOR_DATA editor_data; | |
1002 #endif /* NEW_EDITOR */ | |
1003 | |
1004 TRACE_FUNCTION("ServicesUSSDEnter"); | |
1005 | |
1006 memset(ss_data.edt_buf_number,'\0',PHB_MAX_LEN); | |
1007 | |
1008 /* SPR#1428 - SH - New Editor changes */ | |
1009 #ifdef NEW_EDITOR /* NEW_EDITOR */ | |
1010 AUI_edit_SetDefault(&editor_data); | |
1011 AUI_edit_SetDisplay(&editor_data, ZONE_FULL_SK_TITLE, COLOUR_EDITOR_XX, EDITOR_FONT); | |
1012 AUI_edit_SetMode(&editor_data, 0, ED_CURSOR_UNDERLINE); | |
1013 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_number, MAX_USSD_LEN); | |
1014 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtEntAnw, NULL); | |
1015 AUI_edit_SetAltTextStr(&editor_data, 1, TxtNull, FALSE, TxtNull); | |
1016 AUI_edit_SetEvents(&editor_data, ServicesUSSDEnter, TRUE, FOREVER, (T_AUI_EDIT_CB)services_info_cb); | |
1017 | |
1018 AUI_edit_Start(ss_data.win, &editor_data); /* start the editor */ | |
1019 #else /* NEW_EDITOR */ | |
1020 editor_data.editor_attr.win.px = 6; | |
1021 editor_data.editor_attr.win.py = 12; | |
1022 editor_data.editor_attr.win.sx = 80; | |
1023 editor_data.editor_attr.win.sy = 20; | |
1024 editor_data.editor_attr.edtCol = COLOUR_EDITOR_XX, | |
1025 editor_data.editor_attr.font = 0; | |
1026 editor_data.editor_attr.mode = edtCurBar1; | |
1027 editor_data.editor_attr.controls = 0; | |
1028 editor_data.hide = FALSE; | |
1029 | |
1030 editor_data.editor_attr.text = (char*)ss_data.edt_buf_number; | |
1031 | |
1032 editor_data.editor_attr.size = sizeof(ss_data.edt_buf_number); | |
1033 editor_data.LeftSoftKey = TxtSoftOK; | |
1034 editor_data.RightSoftKey = TxtSoftBack; | |
1035 editor_data.AlternateLeftSoftKey = TxtNull; | |
1036 editor_data.TextString = '\0'; | |
1037 editor_data.TextId = TxtEntAnw; | |
1038 editor_data.Identifier = ServicesUSSDEnter; | |
1039 editor_data.mode = DIGITS_MODE; | |
1040 editor_data.timeout = FOREVER; | |
1041 editor_data.min_enter = 1; | |
1042 editor_data.Callback = (T_EDIT_CB)services_info_cb; | |
1043 editor_data.destroyEditor = TRUE; | |
1044 | |
1045 | |
1046 /* create the dialog handler */ | |
1047 editor_start(ss_data.win, &editor_data); /* start the editor */ | |
1048 #endif /* NEW_EDITOR */ | |
1049 } | |
1050 break; | |
1051 | |
1052 case SERVICES_DO_CALL_VOICE_DIVERT: | |
1053 servicesStoreVoiceMailNumber(); | |
1054 servicesSendCallDivert(0); | |
1055 break; | |
1056 case ServicesDoCallDivert: | |
1057 servicesSendCallDivert(0); | |
1058 break; | |
1059 | |
1060 case E_SS_RES: | |
1061 /* | |
1062 * event is ignored | |
1063 */ | |
1064 break; | |
1065 case E_SS_NOTIFY: | |
1066 TRACE_FUNCTION(" E_SS_NOTIFY"); | |
1067 showSSNotify( win, (T_MFW_SS_NOTIFY*) parameter ); /* all short ss-related notfications */ | |
1068 break; | |
1069 | |
1070 case E_SS_CF_ICN_UPD: | |
1071 TRACE_FUNCTION("E_SS_CF_ICN_UPD"); | |
1072 | |
1073 if ((ss_cnf->cf_cnf.ss_code == SS_CF_CFU) || | |
1074 (ss_cnf->cf_cnf.ss_code == SS_CF_ALL)) | |
1075 { | |
1076 /* | |
1077 * Update icons for idle screen if CFU and telephony | |
1078 */ | |
1079 switch (srv_check_CF_telephony_status ( &ss_cnf->cf_cnf )) | |
1080 { | |
1081 case CF_ACTIVE_STATUS: | |
1082 iconsSetState(iconIdCallFor); | |
1083 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1084 // Setting the Current state of CF in Flash | |
1085 FFS_flashData.CFState=TRUE; | |
1086 break; | |
1087 | |
1088 case CF_INACTIVE_STATUS: | |
1089 iconsDeleteState(iconIdCallFor); | |
1090 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1091 // Setting the Current state of CF in Flash | |
1092 FFS_flashData.CFState=FALSE; | |
1093 break; | |
1094 } | |
1095 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1096 // Writng the Current state of CF into ffs | |
1097 flash_write(); | |
1098 idleEvent(IdleUpdate); | |
1099 } | |
1100 break; | |
1101 /* | |
1102 * modified handling for results taking lists in account | |
1103 */ | |
1104 case E_SS_CF_CNF: | |
1105 /* | |
1106 * check whether we received data what was requested / consistent | |
1107 */ | |
1108 switch(ss_cnf->cf_cnf.ss_code) | |
1109 { | |
1110 case SS_CODES_UNKNOWN: | |
1111 /* Marcus: Issue 1652: 03/02/2003: Start */ | |
1112 TRACE_EVENT("SS_CODES_UNKNOWN"); | |
1113 { | |
1114 T_DISPLAY_DATA display_info; | |
1115 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtNull, TxtExecuted, COLOUR_STATUS); | |
1116 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_CLEAR | KEY_LEFT ); | |
1117 display_info.Identifier = E_SS_CF_CNF; // can be used also for CF and CW | |
1118 | |
1119 /* | |
1120 * Call Info Screen | |
1121 */ | |
1122 | |
1123 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
1124 } | |
1125 /* Marcus: Issue 1652: 03/02/2003: End */ | |
1126 break; | |
1127 case SS_CF_CFU: | |
1128 case SS_CF_ALL: | |
1129 TRACE_EVENT("SS_CF_CFU/SS_CF_ALL"); | |
1130 /* | |
1131 * Update icons for idle screen if CFU and telephony | |
1132 */ | |
1133 switch (srv_check_CF_telephony_status ( &ss_cnf->cf_cnf )) | |
1134 { | |
1135 case CF_ACTIVE_STATUS: | |
1136 iconsSetState(iconIdCallFor); | |
1137 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1138 // Setting the Current state of CF in Flash | |
1139 FFS_flashData.CFState=TRUE; | |
1140 break; | |
1141 | |
1142 case CF_INACTIVE_STATUS: | |
1143 iconsDeleteState(iconIdCallFor); | |
1144 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1145 // Setting the Current state of CF in Flash | |
1146 FFS_flashData.CFState=FALSE; | |
1147 break; | |
1148 } | |
1149 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1150 // Writng the Current state of CF into ffs | |
1151 flash_write(); | |
1152 /* | |
1153 * no break | |
1154 */ | |
1155 case SS_CLIR: | |
1156 case SS_CF_ALL_COND: | |
1157 case SS_CF_CFNRy: | |
1158 case SS_CF_CFNR: | |
1159 case SS_CF_CFB: | |
1160 switch(ss_cnf->cf_cnf.ss_error) | |
1161 { | |
1162 case MFW_SS_NO_ERROR: | |
1163 /* | |
1164 * now store the MFW data under the SS window | |
1165 */ | |
1166 data->mfw_ss_cf = (T_ss_feature_cf *)ALLOC_MEMORY (sizeof (T_ss_feature_cf)); | |
1167 | |
1168 /* | |
1169 * copy all interesting feature entries | |
1170 */ | |
1171 data->max_feature = srv_copy_feature_list_cf (data->mfw_ss_cf, &ss_cnf->cf_cnf); | |
1172 data->current_feature = /*CFService*/0; | |
1173 | |
1174 | |
1175 if (data->max_feature EQ 0) | |
1176 { | |
1177 /* Marcus: Issue 1652: 03/02/2003: Start */ | |
1178 if (ss_cnf->cf_cnf.ss_feature_count) | |
1179 { | |
1180 T_MFW_FEATURE *temp = ss_cnf->cf_cnf.ss_feature_list; | |
1181 srv_empty_list_result (ss_cnf->cf_cnf.ss_category, event, temp->ss_status, ss_cnf->cf_cnf.ss_code); | |
1182 } | |
1183 else | |
1184 { | |
1185 srv_empty_list_result (ss_cnf->cf_cnf.ss_category, event, 0, ss_cnf->cf_cnf.ss_code); | |
1186 } | |
1187 /* Marcus: Issue 1651: 03/02/2003: End */ | |
1188 FREE_MEMORY ((void *)data->mfw_ss_cf, sizeof (T_ss_feature_cf)); | |
1189 data->mfw_ss_cf = NULL; | |
1190 } | |
1191 else | |
1192 { | |
1193 /* | |
1194 * now display status | |
1195 */ | |
1196 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
1197 // ss_Code-- This holds the current CF code for which the activation/deactivation or the staus is being checked | |
1198 // This would be used while displaying the status or activation/deactivation message | |
1199 ss_Code=ss_cnf->cf_cnf.ss_code; | |
1200 showCFStatus(win, data); | |
1201 } | |
1202 break; | |
1203 | |
1204 default: | |
1205 TRACE_FUNCTION("ERROR in CFU,INTERROGATION"); | |
1206 showError(win, ss_cnf->cf_cnf.ss_error); | |
1207 break; | |
1208 } | |
1209 break; | |
1210 | |
1211 default: | |
1212 break; | |
1213 } /* end switch(ss_cnf->cf_cnf.ss_code) */ | |
1214 break; | |
1215 | |
1216 | |
1217 case E_SS_CW_CNF: | |
1218 if (ss_cnf->cw_cnf.ss_error == MFW_SS_NO_ERROR) | |
1219 { | |
1220 /* | |
1221 * now store the MFW data under the SS window | |
1222 */ | |
1223 data->mfw_ss_cw = (T_ss_feature_cw *)ALLOC_MEMORY (sizeof (T_ss_feature_cw)); | |
1224 | |
1225 /* | |
1226 * copy all interesting feature entries | |
1227 */ | |
1228 data->max_feature = srv_copy_feature_list_cw (data->mfw_ss_cw, &ss_cnf->cw_cnf); | |
1229 data->current_feature = 0; | |
1230 | |
1231 if (data->max_feature EQ 0) | |
1232 { | |
1233 | |
1234 | |
1235 if (ss_cnf->cw_cnf.ss_status NEQ 0xFF AND ss_cnf->cw_cnf.ss_status NEQ 0x00) | |
1236 srv_display_status (ss_cnf->cw_cnf.ss_status); | |
1237 else | |
1238 srv_empty_list_result (ss_cnf->cw_cnf.ss_category, event, ss_cnf->cw_cnf.ss_status, ss_cnf->cf_cnf.ss_code); /* Marcus: Issue 1588: 23/01/2003 */ | |
1239 FREE_MEMORY ((void *)data->mfw_ss_cw, sizeof (T_ss_feature_cw)); | |
1240 data->mfw_ss_cw = NULL; | |
1241 } | |
1242 else | |
1243 { | |
1244 /* | |
1245 * now display status | |
1246 */ | |
1247 if ((ss_cnf->cw_cnf.ss_status EQ SS_STAT_UNKNOWN) OR | |
1248 (ss_cnf->cw_cnf.ss_status EQ SS_STAT_NONE)) | |
1249 { | |
1250 //SPR18409 xvilliva, If we receive the status as zero or 0xFF, | |
1251 //we show an alert saying "unknown status". | |
1252 info_screen(win, TxtUnknown, TxtStatus, NULL); | |
1253 } | |
1254 else | |
1255 { | |
1256 showCWStatus(win, data); | |
1257 } | |
1258 } | |
1259 } | |
1260 else | |
1261 { | |
1262 showError(win, ss_cnf->cw_cnf.ss_error); | |
1263 } | |
1264 break; | |
1265 | |
1266 case E_SS_CLI_CNF: | |
1267 TRACE_FUNCTION(" E_SS_CLI_CNF"); | |
1268 | |
1269 if (ss_cnf->cli_cnf.ss_error == MFW_SS_NO_ERROR) | |
1270 { | |
1271 showCLIStatus(win, ss_cnf); | |
1272 } | |
1273 else | |
1274 { | |
1275 showError(win, ss_cnf->cli_cnf.ss_error); | |
1276 } | |
1277 break; | |
1278 | |
1279 | |
1280 case E_SS_CB_CNF: | |
1281 switch(ss_cnf->cb_cnf.ss_error) | |
1282 { | |
1283 case MFW_SS_NO_ERROR: | |
1284 /* | |
1285 * now store the MFW data under the SS window | |
1286 */ | |
1287 data->mfw_ss_cb = (T_ss_feature_cb *)ALLOC_MEMORY (sizeof (T_ss_feature_cb)); | |
1288 | |
1289 /* | |
1290 * copy all interesting feature entries | |
1291 */ | |
1292 data->max_feature = srv_copy_feature_list_cb (data->mfw_ss_cb, &ss_cnf->cb_cnf); | |
1293 data->current_feature = 0; | |
1294 | |
1295 if (data->max_feature EQ 0) | |
1296 { | |
1297 srv_empty_list_result (ss_cnf->cb_cnf.ss_category, event, 0, ss_cnf->cf_cnf.ss_code); /* Marcus: Issue 1588: 23/01/2003 */ | |
1298 FREE_MEMORY ((void *)data->mfw_ss_cb, sizeof (T_ss_feature_cb)); | |
1299 data->mfw_ss_cb = NULL; | |
1300 } | |
1301 else | |
1302 { | |
1303 /* | |
1304 * now display status | |
1305 */ | |
1306 showCBStatus(win, data); | |
1307 } | |
1308 break; | |
1309 | |
1310 default: | |
1311 showError(win, ss_cnf->cb_cnf.ss_error); | |
1312 break; | |
1313 } | |
1314 break; | |
1315 | |
1316 case E_SS_IMEI: /* present IMEI */ | |
1317 /* T_MFW_IMEI imei_cnf;*/ | |
1318 TRACE_FUNCTION(" E_SS_IMEI"); | |
1319 | |
1320 switch(ss_cnf->imei_info.error) | |
1321 { | |
1322 case MFW_SS_NO_ERROR: | |
1323 TRACE_FUNCTION( "Handling IMEI no error" ); | |
1324 // May 02, 2005 REF : LOCOSTO-ENH-30818 - xpradipg | |
1325 // copy the IMEI onto the global variable and display the information | |
1326 #ifdef FF_MMI_ATC_MIGRATION | |
1327 memset(imei,0x00,IMEI_LEN+1); | |
1328 memcpy(imei, ss_cnf->imei_info.imei_number, IMEI_LEN); | |
1329 showIMEI(win,(char*)imei); | |
1330 #else | |
1331 showIMEI2(win, ss_cnf); | |
1332 #endif | |
1333 break; | |
1334 | |
1335 default: | |
1336 TRACE_FUNCTION("ERROR in IMEI"); | |
1337 showError(win, (T_MFW_SS_ERROR)ss_cnf->imei_info.error); | |
1338 break; | |
1339 } | |
1340 break; | |
1341 | |
1342 /* we must display the ussd info and then edit and send a user ussd */ | |
1343 case E_SS_USSD_REQ: | |
1344 TRACE_FUNCTION(" E_SS_USSD_REQ"); | |
1345 | |
1346 switch(ss_cnf->ussd_info.error) | |
1347 { | |
1348 case MFW_SS_NO_ERROR: | |
1349 TRACE_FUNCTION( "Handling USSD_REQ no error" ); | |
1350 showUSSDREQ(win, ss_cnf ); | |
1351 break; | |
1352 | |
1353 default: | |
1354 TRACE_FUNCTION("ERROR in USSD REQ"); | |
1355 showError(win, (T_MFW_SS_ERROR)ss_cnf->ussd_info.error); | |
1356 break; | |
1357 } | |
1358 | |
1359 break; | |
1360 | |
1361 /* just display the ussd info */ | |
1362 case E_SS_USSD_CNF: | |
1363 TRACE_FUNCTION(" E_SS_USSD_CNF"); | |
1364 switch(ss_cnf->ussd_info.error) | |
1365 { | |
1366 case MFW_SS_NO_ERROR: | |
1367 TRACE_FUNCTION( "Handling USSD_CNF no error" ); | |
1368 showUSSDCNF(win, ss_cnf ); | |
1369 break; | |
1370 | |
1371 default: | |
1372 TRACE_FUNCTION("ERROR in USSD_CNF"); | |
1373 showError(win, (T_MFW_SS_ERROR)ss_cnf->ussd_info.error); | |
1374 break; | |
1375 } | |
1376 break; | |
1377 case E_SS_GET_PW: | |
1378 if (ss_cnf->pw_cnf.ss_error == MFW_SS_NO_ERROR) | |
1379 { | |
1380 showOk(win); | |
1381 strncpy((char*)ss_data.edt_buf_cb_password, | |
1382 (char*)ss_cnf->pw_cnf.ss_new_pwd,CB_PSW_LEN); | |
1383 } | |
1384 else | |
1385 { | |
1386 showError(win, ss_cnf->pw_cnf.ss_error); | |
1387 } | |
1388 break; | |
1389 //CQ-16432 start | |
1390 case E_SS_SAT_CPWD: | |
1391 TRACE_EVENT("E_SS_SAT_CPWD"); | |
1392 requestSatCBPassword(); | |
1393 break; | |
1394 //CQ-16432 end | |
1395 default: | |
1396 return; | |
1397 } | |
1398 | |
1399 } | |
1400 | |
1401 | |
1402 /******************************************************************************* | |
1403 | |
1404 $Function: srv_check_CF_telephony_status | |
1405 | |
1406 $Description: | |
1407 | |
1408 $Returns: | |
1409 | |
1410 $Arguments: | |
1411 | |
1412 *******************************************************************************/ | |
1413 | |
1414 /* | |
1415 ** NDH : 28/08/2003 : I am modifying the functionality of this routine so that will simply return | |
1416 ** CF_ACTIVE_STATUS if there is an active Call Forwarding Service and CF_INACTIVE_STATUS | |
1417 ** otherwise. This function is currently used in only one place and this change would be in line | |
1418 ** with the required functionality at that point. | |
1419 */ | |
1420 | |
1421 static UBYTE srv_check_CF_telephony_status (T_MFW_SS_CF_CNF * in_list) | |
1422 { | |
1423 UBYTE i; | |
1424 UBYTE retStat = CF_INACTIVE_STATUS; | |
1425 | |
1426 TRACE_EVENT("srv_check_CF_telephony_status"); | |
1427 | |
1428 if (in_list->ss_error == MFW_SS_NO_ERROR) | |
1429 { | |
1430 if (in_list->ss_feature_count) | |
1431 { | |
1432 for (i=0;i<in_list->ss_feature_count;i++) | |
1433 { | |
1434 T_MFW_FEATURE * pFeature = &in_list->ss_feature_list[i]; | |
1435 | |
1436 if (pFeature->ss_telecom_type == MFW_BST_TELE) | |
1437 { | |
1438 switch(pFeature->ss_telecom_service) | |
1439 { | |
1440 case MFW_TS_ALL_SPCH: | |
1441 case MFW_TS_TLPHNY: | |
1442 case MFW_TS_EMRGNCY: | |
1443 | |
1444 TRACE_EVENT("Speech Tele Service"); | |
1445 | |
1446 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1447 ss_data.cfu_services |= MFW_CFU_VOICE_ACTIVE; | |
1448 else | |
1449 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_VOICE_ACTIVE); | |
1450 break; | |
1451 | |
1452 case MFW_TS_ALL_FAX: | |
1453 case MFW_TS_FAX3_ALT_SPCH: | |
1454 case MFW_TS_FAX3_AUTO: | |
1455 case MFW_TS_FAX4: | |
1456 | |
1457 TRACE_EVENT("Fax Tele Service"); | |
1458 | |
1459 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1460 ss_data.cfu_services |= MFW_CFU_FAX_ACTIVE; | |
1461 else | |
1462 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_FAX_ACTIVE); | |
1463 break; | |
1464 | |
1465 case MFW_TS_ALL_DATA: | |
1466 | |
1467 TRACE_EVENT("Data Tele Service"); | |
1468 | |
1469 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1470 ss_data.cfu_services |= MFW_CFU_DATA_ACTIVE; | |
1471 else | |
1472 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_DATA_ACTIVE); | |
1473 break; | |
1474 | |
1475 case MFW_TS_ALL_SMS: | |
1476 case MFW_TS_SMS_MO: | |
1477 case MFW_TS_SMS_MT: | |
1478 | |
1479 TRACE_EVENT("SMS Tele Service"); | |
1480 | |
1481 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1482 ss_data.cfu_services |= MFW_CFU_SMS_ACTIVE; | |
1483 else | |
1484 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_SMS_ACTIVE); | |
1485 break; | |
1486 | |
1487 case MFW_TS_ALL_XCPT_SMS: | |
1488 | |
1489 TRACE_EVENT("All Except SMS Tele Service"); | |
1490 | |
1491 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1492 ss_data.cfu_services |= (MFW_CFU_VOICE_ACTIVE | | |
1493 MFW_CFU_FAX_ACTIVE | | |
1494 MFW_CFU_DATA_ACTIVE); | |
1495 else | |
1496 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - | |
1497 (MFW_CFU_VOICE_ACTIVE | | |
1498 MFW_CFU_FAX_ACTIVE | | |
1499 MFW_CFU_DATA_ACTIVE)); | |
1500 break; | |
1501 | |
1502 case MFW_TS_ALL_TS: | |
1503 | |
1504 TRACE_EVENT("All Tele Services"); | |
1505 | |
1506 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1507 ss_data.cfu_services |= MFW_CFU_ALL_SERVICES_ACTIVE; | |
1508 else | |
1509 ss_data.cfu_services = 0; | |
1510 break; | |
1511 | |
1512 default: | |
1513 break; | |
1514 } | |
1515 } | |
1516 else if (pFeature->ss_telecom_type == MFW_BST_BEARER) | |
1517 { | |
1518 | |
1519 TRACE_EVENT("Bearer Service Type"); | |
1520 | |
1521 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1522 ss_data.cfu_services |= MFW_CFU_DATA_ACTIVE; | |
1523 else | |
1524 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_DATA_ACTIVE); | |
1525 break; | |
1526 } | |
1527 else | |
1528 { | |
1529 /* MFW_BST_UNKNOWN */ | |
1530 | |
1531 TRACE_EVENT("Unknown Service Type"); | |
1532 | |
1533 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1534 ss_data.cfu_services |= MFW_CFU_ALL_BASIC_SERVICES_ACTIVE; | |
1535 else | |
1536 ss_data.cfu_services = 0; | |
1537 break; | |
1538 } | |
1539 | |
1540 } | |
1541 } | |
1542 else if ((in_list->ss_category == SS_REGISTRATION) || | |
1543 (in_list->ss_category == SS_ACTIVATION)) | |
1544 { | |
1545 ss_data.cfu_services |= MFW_CFU_ALL_BASIC_SERVICES_ACTIVE; | |
1546 } | |
1547 else if ((in_list->ss_category == SS_ERASURE) || | |
1548 (in_list->ss_category == SS_DEACTIVATION)) | |
1549 { | |
1550 ss_data.cfu_services &= (MFW_CFU_ALL_SERVICES_ACTIVE - MFW_CFU_ALL_BASIC_SERVICES_ACTIVE); | |
1551 } | |
1552 } | |
1553 | |
1554 TRACE_EVENT_P1("cfu_services flag is : %8lx", ss_data.cfu_services); | |
1555 | |
1556 if (ss_data.cfu_services) | |
1557 retStat = CF_ACTIVE_STATUS; | |
1558 | |
1559 return retStat; | |
1560 } | |
1561 | |
1562 | |
1563 /******************************************************************************* | |
1564 | |
1565 $Function: srv_check_CF_telephony_status | |
1566 | |
1567 $Description: copies only the interesting parts of the call forwarding | |
1568 feature list. | |
1569 | |
1570 $Returns: | |
1571 | |
1572 $Arguments: | |
1573 | |
1574 *******************************************************************************/ | |
1575 | |
1576 static UBYTE srv_copy_feature_list_cf (T_ss_feature_cf * out_list, T_MFW_SS_CF_CNF * in_list) | |
1577 { | |
1578 UBYTE found_entries = 0; | |
1579 UBYTE i, j; | |
1580 | |
1581 TRACE_EVENT_P1("ss_feature_count %d",in_list->ss_feature_count); | |
1582 | |
1583 if (in_list->ss_feature_count == 0) | |
1584 out_list->ss[0].service = TxtCallDivert; | |
1585 | |
1586 for (i=0;i<in_list->ss_feature_count;i++) | |
1587 { //MC got rid of pointer arithmetic | |
1588 | |
1589 T_MFW_FEATURE * pFeature = &in_list->ss_feature_list[i]; //SPR#1081 - DS - Removed mem allocation. Uses assignment instead. | |
1590 T_ss_feature_cf_data * cf_data = &out_list->ss[found_entries]; | |
1591 UBYTE srvFound; | |
1592 | |
1593 TRACE_EVENT_P2("Telecom type:%d, service: %d ",pFeature->ss_telecom_type, pFeature->ss_telecom_service); | |
1594 /* | |
1595 * first check teleservice | |
1596 */ | |
1597 if (srv_get_service_type (&cf_data->service, pFeature->ss_telecom_type/*CFService*/, | |
1598 pFeature->ss_telecom_service)) | |
1599 { | |
1600 | |
1601 if (cf_data->service == TxtNull) | |
1602 cf_data->service = TxtCallDivert; | |
1603 | |
1604 /* | |
1605 ** If there is more than one entry of a given type, ensure that an information | |
1606 ** screen is displayed only once | |
1607 */ | |
1608 srvFound = FALSE; | |
1609 | |
1610 for (j=0; j<found_entries && !srvFound; j++) | |
1611 { | |
1612 if (cf_data->service == out_list->ss[j].service) | |
1613 srvFound = TRUE; | |
1614 } | |
1615 | |
1616 if (!srvFound) | |
1617 { | |
1618 /* | |
1619 * second set status | |
1620 */ | |
1621 srv_get_status (&cf_data->status, pFeature->ss_status); | |
1622 | |
1623 if ((ss_cnf->cf_cnf.ss_code==SS_CF_CFU)||(ss_cnf->cf_cnf.ss_code==SS_CF_ALL)){ | |
1624 if (pFeature->ss_status & SS_STAT_ACTIVE) | |
1625 { | |
1626 iconsSetState(iconIdCallFor); | |
1627 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1628 // Setting the Current state of CF in Flash | |
1629 FFS_flashData.CFState=TRUE; | |
1630 } | |
1631 /* Marcus: Issue 1652: 03/02/2003: Start */ | |
1632 else if (pFeature->ss_status & SS_STAT_PROVISIONED) | |
1633 { | |
1634 iconsSetState(iconIdCallFor); | |
1635 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1636 // Setting the Current state of CF in Flash | |
1637 FFS_flashData.CFState=TRUE; | |
1638 } | |
1639 /* Marcus: Issue 1652: 03/02/2003: End */ | |
1640 else | |
1641 { | |
1642 iconsDeleteState(iconIdCallFor); | |
1643 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1644 // Setting the Current state of CF in Flash | |
1645 FFS_flashData.CFState=FALSE; | |
1646 } | |
1647 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
1648 // Writng the Current state of CF into ffs | |
1649 flash_write(); | |
1650 | |
1651 } | |
1652 | |
1653 /* | |
1654 * third set forwarded to number | |
1655 * If the TON is International, add a '+' to the beginning of the number | |
1656 */ | |
1657 if ((pFeature->ss_numbering_type == TON_International) && | |
1658 (pFeature->ss_forwarded_to_number[0] != '+')) | |
1659 { | |
1660 cf_data->forwarded_to_number[0] = '+'; | |
1661 srv_get_forwarded_to_number (&cf_data->forwarded_to_number[1], | |
1662 (char *)pFeature->ss_forwarded_to_number, | |
1663 MAX_SS_CF_NUM_LEN-1); | |
1664 } | |
1665 else | |
1666 { | |
1667 srv_get_forwarded_to_number ((char *)cf_data->forwarded_to_number, | |
1668 (char *)pFeature->ss_forwarded_to_number, | |
1669 MAX_SS_CF_NUM_LEN); | |
1670 } | |
1671 | |
1672 TRACE_EVENT_P1("ss_forwarded_to_number %s", (CHAR *)pFeature->ss_forwarded_to_number); | |
1673 found_entries++; | |
1674 } | |
1675 } | |
1676 | |
1677 } | |
1678 | |
1679 /* | |
1680 * return the number of interesting entries | |
1681 */ | |
1682 return found_entries; | |
1683 } | |
1684 | |
1685 | |
1686 /******************************************************************************* | |
1687 | |
1688 $Function: srv_get_forwarded_to_number | |
1689 | |
1690 $Description: sets the forwarded to number if available. | |
1691 | |
1692 $Returns: | |
1693 | |
1694 $Arguments: | |
1695 | |
1696 *******************************************************************************/ | |
1697 | |
1698 | |
1699 | |
1700 static void srv_get_forwarded_to_number ( char * textString, | |
1701 char * forwarded_to_number, | |
1702 UBYTE max_chars) | |
1703 { | |
1704 TRACE_FUNCTION("srv_get_forwarded_to_number"); | |
1705 | |
1706 memset (textString, 0, max_chars); | |
1707 strncpy (textString, forwarded_to_number, max_chars-1); | |
1708 } | |
1709 | |
1710 | |
1711 /******************************************************************************* | |
1712 | |
1713 $Function: srv_get_service_type | |
1714 | |
1715 $Description: checks if the service is interesting or not. | |
1716 | |
1717 $Returns: | |
1718 | |
1719 $Arguments: | |
1720 | |
1721 $History: | |
1722 | |
1723 //SPR#0776 - DS - Added default value for textId. Changed references from TxtNotImplemented | |
1724 to TxtNull. | |
1725 | |
1726 *******************************************************************************/ | |
1727 | |
1728 | |
1729 static UBYTE srv_get_service_type ( USHORT * textId, | |
1730 UBYTE ss_telecom_type, UBYTE ss_telecom_service) | |
1731 { | |
1732 TRACE_FUNCTION("srv_get_service_type"); | |
1733 | |
1734 TRACE_EVENT_P1("ss_telecom_type: %x", ss_telecom_type); | |
1735 TRACE_EVENT_P1("ss_telecom_service: %x", ss_telecom_service); | |
1736 | |
1737 *textId = TxtNull; //Set to TxtNull in case no match found below. | |
1738 | |
1739 switch ( ss_telecom_type ) | |
1740 { | |
1741 case MFW_BST_UNKNOWN: | |
1742 break; | |
1743 | |
1744 case MFW_BST_TELE: | |
1745 switch ( ss_telecom_service ) | |
1746 { | |
1747 case MFW_TS_ALL_TS: | |
1748 *textId = TxtAllCalls; | |
1749 return TRUE; | |
1750 | |
1751 case MFW_TS_ALL_SPCH: /* All speech transmission services */ | |
1752 case MFW_TS_TLPHNY: /* telephony */ | |
1753 case MFW_TS_PLMN1: /*MC, this is returned for auxiliary telephony status, 742*/ | |
1754 *textId = TxtVoice; | |
1755 return TRUE; | |
1756 | |
1757 case MFW_TS_ALL_SMS: | |
1758 case MFW_TS_SMS_MO: | |
1759 case MFW_TS_SMS_MT: | |
1760 *textId = TxtSMS; | |
1761 return TRUE; | |
1762 | |
1763 case MFW_TS_EMRGNCY: | |
1764 case MFW_TS_ALL_XCPT_SMS: | |
1765 case MFW_TS_ALL_PSSS: /* all PLMN specific TS */ | |
1766 case MFW_TS_PLMN2: /* PLMN specific TS 2 */ | |
1767 case MFW_TS_PLMN3: /* PLMN specific TS 3 */ | |
1768 case MFW_TS_PLMN4: /* PLMN specific TS 4 */ | |
1769 case MFW_TS_PLMN5: /* PLMN specific TS 5 */ | |
1770 case MFW_TS_PLMN6: /* PLMN specific TS 6 */ | |
1771 case MFW_TS_PLMN7: /* PLMN specific TS 7 */ | |
1772 case MFW_TS_PLMN8: /* PLMN specific TS 8 */ | |
1773 case MFW_TS_PLMN9: /* PLMN specific TS 9 */ | |
1774 case MFW_TS_PLMNA: /* PLMN specific TS A */ | |
1775 case MFW_TS_PLMNB: /* PLMN specific TS B */ | |
1776 case MFW_TS_PLMNC: /* PLMN specific TS C */ | |
1777 case MFW_TS_PLMND: /* PLMN specific TS D */ | |
1778 case MFW_TS_PLMNE: /* PLMN specific TS E */ | |
1779 case MFW_TS_PLMNF: /* PLMN specific TS F */ | |
1780 *textId = TxtNull; | |
1781 return TRUE; | |
1782 | |
1783 case MFW_TS_ALL_DATA: | |
1784 *textId = TxtData; | |
1785 return TRUE; | |
1786 | |
1787 case MFW_TS_ALL_FAX: | |
1788 case MFW_TS_FAX3_ALT_SPCH: | |
1789 case MFW_TS_FAX3_AUTO: | |
1790 case MFW_TS_FAX4: | |
1791 *textId = TxtFax; | |
1792 return TRUE; | |
1793 } | |
1794 | |
1795 break; | |
1796 | |
1797 case MFW_BST_BEARER: | |
1798 switch ( ss_telecom_service ) | |
1799 { | |
1800 case MFW_BS_ALL_BS: | |
1801 *textId = TxtData; //SPR#933 - DS - Changed TxtNull to TxtData. | |
1802 return TRUE; | |
1803 | |
1804 case MFW_BS_ALL_DATA_CDA: //SPR#933 - DS - Added so MMI displays correct info to user. | |
1805 *textId = TxtData; | |
1806 return TRUE; | |
1807 | |
1808 default: | |
1809 break; | |
1810 } | |
1811 break; | |
1812 } | |
1813 | |
1814 return FALSE; | |
1815 } | |
1816 | |
1817 /******************************************************************************* | |
1818 | |
1819 $Function: srv_get_status | |
1820 | |
1821 $Description: | |
1822 | |
1823 $Returns: | |
1824 | |
1825 $Arguments: | |
1826 | |
1827 *******************************************************************************/ | |
1828 | |
1829 | |
1830 static void srv_get_status (USHORT *textId, UBYTE pStatus) | |
1831 { | |
1832 TRACE_FUNCTION("srv_get_status"); | |
1833 TRACE_EVENT_P1("Call Forwarding status: %d", pStatus); | |
1834 | |
1835 if (pStatus & SS_STAT_ACTIVE) // handles also the case of invalid status | |
1836 *textId = TxtActivated; | |
1837 /* Marcus: Issue 1652: 03/02/2003: Removed NDH 10/06/03 */ | |
1838 else | |
1839 *textId = TxtDeActivated; | |
1840 } | |
1841 | |
1842 | |
1843 /******************************************************************************* | |
1844 | |
1845 $Function: srv_copy_feature_list_cw | |
1846 | |
1847 $Description: copies only the interesting parts of the call waiting | |
1848 service list. | |
1849 | |
1850 $Returns: | |
1851 | |
1852 $Arguments: | |
1853 | |
1854 *******************************************************************************/ | |
1855 | |
1856 static UBYTE srv_copy_feature_list_cw (T_ss_feature_cw * out_list, T_MFW_SS_CW_CNF * in_list) | |
1857 { | |
1858 UBYTE found_entries = 0; | |
1859 UBYTE i, j; | |
1860 | |
1861 if (in_list->ss_service_count == 0) | |
1862 out_list->ss[0].service = TxtCallWaiting; | |
1863 | |
1864 for (i=0;i<in_list->ss_service_count;i++) | |
1865 { | |
1866 T_MFW_SRV_GROUP * pFeature = &in_list->ss_service_list[i]; | |
1867 T_ss_feature_cw_data * cw_data = &out_list->ss[found_entries]; | |
1868 UBYTE srvFound; | |
1869 /* | |
1870 * first check teleservice | |
1871 */ | |
1872 if (srv_get_service_type (&cw_data->service, pFeature->ss_telecom_type, | |
1873 pFeature->ss_telecom_service)) | |
1874 { | |
1875 | |
1876 if (cw_data->service == TxtNull) | |
1877 cw_data->service = TxtCallWaiting; | |
1878 | |
1879 /* | |
1880 ** If there is more than one entry of a given type, ensure that an information | |
1881 ** screen is displayed only once | |
1882 */ | |
1883 srvFound = FALSE; | |
1884 | |
1885 for (j=0; j<found_entries && !srvFound; j++) | |
1886 { | |
1887 if (cw_data->service == out_list->ss[j].service) | |
1888 srvFound = TRUE; | |
1889 } | |
1890 | |
1891 if (!srvFound) | |
1892 { | |
1893 /* | |
1894 * second set status | |
1895 */ | |
1896 srv_get_status (&out_list->status, in_list->ss_status); | |
1897 found_entries++; | |
1898 } | |
1899 } | |
1900 } | |
1901 | |
1902 /* | |
1903 * return the number of interesting entries | |
1904 */ | |
1905 return found_entries; | |
1906 } | |
1907 | |
1908 /******************************************************************************* | |
1909 | |
1910 $Function: srv_copy_feature_list_cb | |
1911 | |
1912 $Description: | |
1913 | |
1914 $Returns: | |
1915 | |
1916 $Arguments: | |
1917 | |
1918 *******************************************************************************/ | |
1919 | |
1920 static UBYTE srv_copy_feature_list_cb (T_ss_feature_cb * out_list, T_MFW_SS_CB_CNF * in_list) | |
1921 { | |
1922 UBYTE found_entries = 0; | |
1923 UBYTE i, j; | |
1924 | |
1925 USHORT textId = 0; // RAVI | |
1926 | |
1927 /* | |
1928 * SPR #1878 NDH - Determine which text is to be displayed depending on what request | |
1929 * was initially sent. | |
1930 */ | |
1931 switch(in_list->ss_category) | |
1932 { | |
1933 case SS_REGISTRATION: | |
1934 case SS_ACTIVATION: | |
1935 case SS_INTERROGATION: | |
1936 /* | |
1937 * Interrogation returns only those services which are active | |
1938 */ | |
1939 textId = TxtActivated; | |
1940 break; | |
1941 | |
1942 case SS_ERASURE: | |
1943 case SS_DEACTIVATION: | |
1944 textId = TxtDeActivated; | |
1945 break; | |
1946 } | |
1947 | |
1948 if (in_list->ss_telecom_count == 0) | |
1949 out_list->ss[0].service = TxtCallBarringAll; | |
1950 | |
1951 for (i=0;i<in_list->ss_telecom_count;i++) | |
1952 { | |
1953 T_MFW_TELECOM * pFeature = &in_list->ss_telecom_list[i]; | |
1954 T_ss_feature_cb_data * cb_data = &out_list->ss[found_entries]; | |
1955 UBYTE srvFound; | |
1956 /* | |
1957 * first check teleservice | |
1958 */ | |
1959 if (srv_get_service_type (&cb_data->service, pFeature->ss_telecom_type, | |
1960 pFeature->ss_telecom_service)) | |
1961 { | |
1962 if (cb_data->service == TxtNull) | |
1963 cb_data->service = TxtCallBarringAll; | |
1964 | |
1965 cb_data->status = textId; | |
1966 | |
1967 /* | |
1968 ** If there is more than one entry of a given type, ensure that an information | |
1969 ** screen is displayed only once | |
1970 */ | |
1971 srvFound = FALSE; | |
1972 | |
1973 for (j=0; j<found_entries && !srvFound; j++) | |
1974 { | |
1975 if (cb_data->service == out_list->ss[j].service) | |
1976 srvFound = TRUE; | |
1977 } | |
1978 | |
1979 if (!srvFound) | |
1980 found_entries++; | |
1981 } | |
1982 } | |
1983 | |
1984 /* | |
1985 * return the number of interesting entries | |
1986 */ | |
1987 return found_entries; | |
1988 } | |
1989 | |
1990 | |
1991 | |
1992 /******************************************************************************* | |
1993 | |
1994 $Function: services_info_cb | |
1995 | |
1996 $Description: Callback function from information dialog. | |
1997 | |
1998 $Returns: | |
1999 | |
2000 $Arguments: | |
2001 | |
2002 *******************************************************************************/ | |
2003 | |
2004 | |
2005 | |
2006 static int services_info_cb(T_MFW_HND win, USHORT identifier, UBYTE reason) | |
2007 { | |
2008 | |
2009 T_DISPLAY_DATA display_info; // Jun 16, 2005 REF: CRR 31543 x0021334 | |
2010 // UBYTE PWD; // RAVI | |
2011 T_MFW_SS_RETURN sat_result_hangup; // Jun 16, 2005 REF: CRR 31543 x0021334 | |
2012 | |
2013 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
2014 //Bug : Unable to compose a one or two digit number | |
2015 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
2016 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
2017 //was not handled properly. So altered the editor handling to cater for the long message. | |
2018 T_MFW_WIN *win_data; | |
2019 T_ss *data = NULL; // RAVI - Assigned NULL. | |
2020 | |
2021 TRACE_EVENT_P1("Service Info CB %d", win); | |
2022 | |
2023 ss_data.info_wait = 0; | |
2024 | |
2025 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
2026 //Bug : Unable to compose a one or two digit number | |
2027 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
2028 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
2029 //was not handled properly. So altered the editor handling to cater for the long message. | |
2030 if(win) | |
2031 { | |
2032 win_data = ((T_MFW_HDR *)win)->data; | |
2033 if(win_data) | |
2034 data = (T_ss * )win_data->user; | |
2035 } | |
2036 | |
2037 /* | |
2038 * Who has initiated the information screen | |
2039 */ | |
2040 switch (identifier) | |
2041 { | |
2042 case SS_WAIT: | |
2043 | |
2044 break; | |
2045 case E_SS_IMEI:/* present IMEI */ | |
2046 case ServicesOk: | |
2047 case ServicesFailed: | |
2048 case ServicesCheckCLI_OK: | |
2049 case ServicesCheckCW_OK: | |
2050 case ServicesIMEI_OK: | |
2051 case ServicesError: | |
2052 case ServicesUSSD_CNF_OK: | |
2053 #if 0 | |
2054 case ServicesUSSDAlreadyFull: /* already full message screen */ | |
2055 #endif | |
2056 case ServicesCFU_OK: | |
2057 case ServicesCB_OK: | |
2058 | |
2059 case E_SS_NOTIFY: | |
2060 case E_SS_CLI_CNF: | |
2061 case E_SS_USSD_CNF: | |
2062 switch (reason) | |
2063 { | |
2064 case INFO_TIMEOUT: | |
2065 /* info dialog timed out, where to now? */ | |
2066 /* no break; */ | |
2067 case INFO_KCD_HUP: | |
2068 /* clear key in info dialog, where to now? */ | |
2069 /* no break;*/ | |
2070 case INFO_KCD_LEFT: | |
2071 /* left soft key in info dialog, where to now? */ | |
2072 /* no break;*/ | |
2073 case INFO_KCD_RIGHT: | |
2074 /* right soft key in info dialog, where to now? */ | |
2075 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
2076 //Bug : Unable to compose a one or two digit number | |
2077 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
2078 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
2079 //was not handled properly. So altered the editor handling to cater for the long message. | |
2080 if(data) | |
2081 { | |
2082 if(data->info_win) | |
2083 { | |
2084 AUI_edit_Destroy(data->info_win); | |
2085 data->info_win=NULL; | |
2086 } | |
2087 } | |
2088 services_destroy(win); | |
2089 break; | |
2090 } | |
2091 // May 12, 2005 REF: CRR 30892 x0021334 | |
2092 // Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
2093 ss_data.info_win = NULL; | |
2094 break; | |
2095 | |
2096 case E_SS_CB_CNF: | |
2097 { | |
2098 T_MFW_WIN * win_data; | |
2099 T_ss * data; | |
2100 | |
2101 win_data = ((T_MFW_HDR *)win)->data; | |
2102 data = (T_ss *)win_data->user; | |
2103 | |
2104 switch (reason) | |
2105 { | |
2106 case INFO_TIMEOUT: | |
2107 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2108 //Timer is introduced for the information dialog, we are handling the time_out event | |
2109 case INFO_KCD_HUP: | |
2110 case INFO_KCD_LEFT: | |
2111 /* | |
2112 * stop the display of the results | |
2113 */ | |
2114 if (data->mfw_ss_cb) | |
2115 { | |
2116 FREE_MEMORY ((void *)data->mfw_ss_cb, sizeof (T_ss_feature_cb)); | |
2117 data->mfw_ss_cb = NULL; | |
2118 data->current_feature = 0; | |
2119 | |
2120 TRACE_EVENT_P2("SS_data.win %d %d",ss_data.win, data); | |
2121 } | |
2122 break; | |
2123 | |
2124 case INFO_KCD_RIGHT: | |
2125 if ((data->mfw_ss_cb) && (data->max_feature > 1)) | |
2126 { | |
2127 if (data->max_feature > data->current_feature + 1) | |
2128 data->current_feature++; | |
2129 else | |
2130 data->current_feature = 0; | |
2131 | |
2132 showCBStatus (win, data); | |
2133 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2134 //Restart the timer if the key was pressed. We handle only right key since left key destroys | |
2135 //the information dialog | |
2136 InfoDialogTimRestart(win); | |
2137 } | |
2138 break; | |
2139 | |
2140 default: | |
2141 break; | |
2142 } | |
2143 // May 12, 2005 REF: CRR 30892 x0021334 | |
2144 // Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
2145 ss_data.info_win = NULL; | |
2146 } | |
2147 break; | |
2148 | |
2149 case E_SS_CW_CNF: | |
2150 { | |
2151 T_MFW_WIN * win_data; | |
2152 T_ss * data; | |
2153 | |
2154 win_data = ((T_MFW_HDR *)win)->data; | |
2155 data = (T_ss *)win_data->user; | |
2156 | |
2157 switch (reason) | |
2158 { | |
2159 case INFO_TIMEOUT: | |
2160 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2161 //Timer is introduced for the information dialog, we are handling the time_out event | |
2162 case INFO_KCD_HUP: | |
2163 case INFO_KCD_LEFT: | |
2164 /* | |
2165 * stop the display of the results | |
2166 */ | |
2167 if (data->mfw_ss_cw) | |
2168 { | |
2169 FREE_MEMORY ((void *)data->mfw_ss_cw, sizeof (T_ss_feature_cw)); | |
2170 data->mfw_ss_cw = NULL; | |
2171 data->current_feature = 0; | |
2172 } | |
2173 break; | |
2174 | |
2175 case INFO_KCD_RIGHT: | |
2176 if ((data->mfw_ss_cw) && (data->max_feature > 1)) | |
2177 { | |
2178 if (data->max_feature > data->current_feature + 1) | |
2179 data->current_feature++; | |
2180 else | |
2181 data->current_feature = 0; | |
2182 | |
2183 showCWStatus (win, data); | |
2184 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2185 //Restart the timer if the key was pressed. We handle only right key since left key destroys | |
2186 //the information dialog | |
2187 InfoDialogTimRestart(win); | |
2188 | |
2189 } | |
2190 break; | |
2191 | |
2192 default: | |
2193 break; | |
2194 } | |
2195 // May 12, 2005 REF: CRR 30892 x0021334 | |
2196 // Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
2197 ss_data.info_win = NULL; | |
2198 } | |
2199 break; | |
2200 case E_SS_CF_CNF: | |
2201 { | |
2202 T_MFW_WIN * win_data; | |
2203 T_ss * data; | |
2204 | |
2205 win_data = ((T_MFW_HDR *)win)->data; | |
2206 data = (T_ss *)win_data->user; | |
2207 | |
2208 switch (reason) | |
2209 { | |
2210 case INFO_TIMEOUT: | |
2211 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2212 //Timer is introduced for the information dialog, we are handling the time_out event | |
2213 case INFO_KCD_HUP: | |
2214 case INFO_KCD_LEFT: | |
2215 /* | |
2216 * stop the display of the results | |
2217 */ | |
2218 if (data->mfw_ss_cf) | |
2219 { | |
2220 FREE_MEMORY ((void *)data->mfw_ss_cf, sizeof (T_ss_feature_cf)); | |
2221 data->mfw_ss_cf = NULL; | |
2222 data->current_feature = 0; | |
2223 } | |
2224 break; | |
2225 | |
2226 case INFO_KCD_RIGHT: | |
2227 if ((data->mfw_ss_cf) && (data->max_feature > 1)) | |
2228 { | |
2229 if (data->max_feature > data->current_feature + 1) | |
2230 data->current_feature++; | |
2231 else | |
2232 data->current_feature = 0; | |
2233 | |
2234 showCFStatus (win, data); | |
2235 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2236 //Restart the timer if the key was pressed. We handle only right key since left key destroys | |
2237 //the information dialog | |
2238 InfoDialogTimRestart(win); | |
2239 } | |
2240 break; | |
2241 | |
2242 default: | |
2243 break; | |
2244 } | |
2245 // May 12, 2005 REF: CRR 30892 x0021334 | |
2246 // Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
2247 ss_data.info_win = NULL; | |
2248 break; | |
2249 } | |
2250 case ServicesUSSD_REQ_OK: | |
2251 switch (reason) | |
2252 { | |
2253 case INFO_KCD_HUP: | |
2254 // Jun 16, 2005 REF: CRR 31543 x0021334 | |
2255 // Hangup key is pressed. End the USSD session. | |
2256 sat_result_hangup = satHangup (CMD_SRC_LCL); | |
2257 if (sat_result_hangup == MFW_SS_OK) | |
2258 { | |
2259 dlg_initDisplayData_TextId(&display_info, NULL, NULL, TxtCancelled, TxtNull, COLOUR_STATUS); | |
2260 dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT | KEY_RIGHT); | |
2261 info_dialog (NULL, &display_info); | |
2262 } | |
2263 else | |
2264 { | |
2265 TRACE_ERROR("Error in SAT USSD abort"); | |
2266 } | |
2267 // no break; | |
2268 case INFO_TIMEOUT: | |
2269 /* info dialog timed out, where to now? */ | |
2270 // no break; | |
2271 case INFO_KCD_RIGHT: | |
2272 /* right soft key in info dialog, where to now? | |
2273 all above mean cancelled so go back to whatever was before (idle?)*/ | |
2274 services_destroy(win); | |
2275 break; | |
2276 | |
2277 case INFO_KCD_LEFT: | |
2278 /* left soft key in info dialog, where to now? | |
2279 This means confirm, so now go to USSD entry screen */ | |
2280 SEND_EVENT(ss_data.win,ServicesUSSDEnter,0,0); | |
2281 break; | |
2282 default: | |
2283 break; | |
2284 } | |
2285 // May 12, 2005 REF: CRR 30892 x0021334 | |
2286 // Set ss_data.info_win to NULL to pass the check in services_ss_cb() for notification | |
2287 ss_data.info_win = NULL; | |
2288 break; | |
2289 | |
2290 case ServicesUSSDEnter: | |
2291 { | |
2292 T_MFW_SS_PARA ussd_data; | |
2293 | |
2294 | |
2295 ussd_data.ussd_info.len = strlen((char*)ss_data.edt_buf_number); | |
2296 ussd_data.ussd_info.dcs = ss_data.dcs; | |
2297 ussd_data.ussd_info.error = MFW_SS_NO_ERROR; | |
2298 | |
2299 memcpy(ussd_data.ussd_info.ussd, ss_data.edt_buf_number, ussd_data.ussd_info.len); | |
2300 | |
2301 | |
2302 sendUSSD (&ussd_data); | |
2303 } | |
2304 break; | |
2305 | |
2306 } | |
2307 return 1; | |
2308 } | |
2309 | |
2310 | |
2311 /******************************************************************************* | |
2312 | |
2313 $Function: servicesNumbers | |
2314 | |
2315 $Description: | |
2316 | |
2317 $Returns: | |
2318 | |
2319 $Arguments: | |
2320 | |
2321 *******************************************************************************/ | |
2322 | |
2323 | |
2324 int servicesNumbers(MfwMnu* m, MfwMnuItem* i){ | |
2325 CFAction = CFActivate; | |
2326 servicesDoOtherNumber(); | |
2327 | |
2328 // ADDED BY RAVI - 28-11-2005 | |
2329 return 1; | |
2330 //END RAVI - 28-11-2005 | |
2331 } | |
2332 | |
2333 | |
2334 /******************************************************************************* | |
2335 | |
2336 $Function: servicesInfraRed | |
2337 | |
2338 $Description: | |
2339 | |
2340 $Returns: | |
2341 | |
2342 $Arguments: | |
2343 | |
2344 *******************************************************************************/ | |
2345 | |
2346 | |
2347 int servicesInfraRed(void){return 11;} | |
2348 | |
2349 | |
2350 /******************************************************************************* | |
2351 | |
2352 $Function: servicesExec | |
2353 | |
2354 $Description: | |
2355 | |
2356 $Returns: | |
2357 | |
2358 $Arguments: | |
2359 | |
2360 *******************************************************************************/ | |
2361 | |
2362 void servicesExec (int reason, MmiState next) | |
2363 { | |
2364 // UBYTE PWD; // RAVI | |
2365 T_MFW_HND win = mfw_parent(mfw_header()); | |
2366 // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI | |
2367 | |
2368 nextState = next; | |
2369 | |
2370 | |
2371 if (!winIsFocussed(win)) | |
2372 lastFocus = winFocus(win); | |
2373 | |
2374 servicesState = reason; /* save reason now !! */ | |
2375 | |
2376 switch (reason) | |
2377 { | |
2378 case ServicesIdle: /* giving back control to last module*/ | |
2379 winFocus(lastFocus); | |
2380 winShow(lastFocus); | |
2381 lastFocus = 0; | |
2382 return; /* return from module */ | |
2383 | |
2384 case ServicesOk: | |
2385 TRACE_FUNCTION("Service OK"); | |
2386 winShow(win); | |
2387 timStart(times); /* start timer to go back in the submenu */ | |
2388 break; | |
2389 | |
2390 case ServicesFailed: | |
2391 TRACE_FUNCTION("Service Failed"); | |
2392 winShow(win); | |
2393 timStart(times); /* start timer to go back in the submenu */ | |
2394 break; | |
2395 | |
2396 case ServicesError: | |
2397 TRACE_FUNCTION("Service Error"); | |
2398 winShow(win); | |
2399 timStart(times); /* start timer to go back in the submenu */ | |
2400 break; | |
2401 | |
2402 case ServicesExecCF: /* all Call forwarding from menu */ | |
2403 case ServicesActCF: /* show "Please Wait" screen/animation */ | |
2404 case ServicesDeactCF: | |
2405 case ServicesCheckCF: | |
2406 case ServicesActCW: | |
2407 case ServicesDeactCW: | |
2408 case ServicesCheckCW: | |
2409 case ServicesActCLIR: | |
2410 case ServicesDeactCLIR: | |
2411 case ServicesCheckCLIR: | |
2412 winShow(win); | |
2413 timStart(times); /* start timer to go back in the submenu */ | |
2414 break; | |
2415 | |
2416 case ServicesCheckCW_OK: | |
2417 TRACE_FUNCTION(" ServicesCheckCW_OK"); | |
2418 winShow(win); | |
2419 timStart(times); /* start timer to go back in the submenu */ | |
2420 break; | |
2421 | |
2422 case ServicesCheckCLI_OK: | |
2423 TRACE_FUNCTION("ServicesCheckCLI_OK"); | |
2424 winShow(win); | |
2425 timStart(times); | |
2426 break; | |
2427 | |
2428 case ServicesIMEI_OK: | |
2429 TRACE_FUNCTION("ServicesIMEI_OK"); | |
2430 winShow(win); | |
2431 timStart(times); | |
2432 break; | |
2433 case ServicesResShow: | |
2434 TRACE_FUNCTION("ServicesResShow"); | |
2435 winShow(win); | |
2436 timStart(times); | |
2437 break; | |
2438 | |
2439 case ServicesCB_OK: | |
2440 TRACE_FUNCTION("ServicesCB_OK"); | |
2441 lastFocus = winFocus(win); | |
2442 winShow(win); | |
2443 timStart(times); | |
2444 break; | |
2445 | |
2446 case ServicesCFU_OK: | |
2447 TRACE_FUNCTION("ServicesCFUShow"); | |
2448 lastFocus = winFocus(win); | |
2449 winShow(win); | |
2450 timStart(times); | |
2451 break; | |
2452 | |
2453 case ServicesDoCallDivert: | |
2454 servicesSendCallDivert(0); | |
2455 break; | |
2456 | |
2457 case PIN2_ABORT: | |
2458 TRACE_FUNCTION("ServicesPin2_Abort"); | |
2459 break; | |
2460 default: | |
2461 break; | |
2462 } | |
2463 } | |
2464 | |
2465 | |
2466 | |
2467 | |
2468 /******************************************************************************* | |
2469 | |
2470 $Function: showWait | |
2471 | |
2472 $Description: | |
2473 | |
2474 $Returns: | |
2475 | |
2476 $Arguments: | |
2477 | |
2478 *******************************************************************************/ | |
2479 | |
2480 static void showWait (T_MFW_HND win) | |
2481 { | |
2482 | |
2483 T_DISPLAY_DATA display_info; | |
2484 | |
2485 TRACE_FUNCTION("showWait"); | |
2486 | |
2487 dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtRequesting, TxtNull, COLOUR_STATUS); | |
2488 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_HUP| KEY_LEFT ); | |
2489 display_info.Identifier = SS_WAIT; | |
2490 | |
2491 /* | |
2492 * Call Info Screen | |
2493 */ | |
2494 | |
2495 ss_data.info_wait = info_dialog (win, &display_info); | |
2496 } | |
2497 | |
2498 | |
2499 /******************************************************************************* | |
2500 | |
2501 $Function: showOk | |
2502 | |
2503 $Description: | |
2504 | |
2505 $Returns: | |
2506 | |
2507 $Arguments: | |
2508 | |
2509 *******************************************************************************/ | |
2510 | |
2511 static void showOk (T_MFW_HND win) | |
2512 { | |
2513 | |
2514 T_DISPLAY_DATA display_info; | |
2515 | |
2516 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtDone, TxtNull, COLOUR_STATUS); | |
2517 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_HUP| KEY_LEFT ); | |
2518 display_info.Identifier = ServicesOk; | |
2519 | |
2520 /* | |
2521 * Call Info Screen | |
2522 */ | |
2523 | |
2524 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2525 | |
2526 } | |
2527 | |
2528 /******************************************************************************* | |
2529 | |
2530 $Function: showFailed | |
2531 | |
2532 $Description: | |
2533 | |
2534 $Returns: | |
2535 | |
2536 $Arguments: | |
2537 | |
2538 *******************************************************************************/ | |
2539 | |
2540 static void showFailed (T_MFW_HND win) | |
2541 { | |
2542 | |
2543 T_DISPLAY_DATA display_info; | |
2544 | |
2545 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtFailed, TxtNull, COLOUR_STATUS); | |
2546 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_HUP| KEY_LEFT ); | |
2547 display_info.Identifier = ServicesFailed; | |
2548 | |
2549 /* | |
2550 * Call Info Screen | |
2551 */ | |
2552 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2553 } | |
2554 | |
2555 /******************************************************************************* | |
2556 | |
2557 $Function: showError | |
2558 | |
2559 $Description: | |
2560 | |
2561 $Returns: | |
2562 | |
2563 $Arguments: | |
2564 | |
2565 *******************************************************************************/ | |
2566 | |
2567 static void showError (T_MFW_HND win, T_MFW_SS_ERROR ss_error) | |
2568 { | |
2569 | |
2570 T_DISPLAY_DATA display_info; | |
2571 | |
2572 TRACE_FUNCTION("showError"); | |
2573 | |
2574 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtFailed, serviceGetError(ss_error), COLOUR_STATUS); | |
2575 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_HUP| KEY_LEFT ); | |
2576 display_info.Identifier = ServicesError; | |
2577 | |
2578 /* | |
2579 * Call Info Screen | |
2580 */ | |
2581 | |
2582 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2583 | |
2584 } | |
2585 | |
2586 | |
2587 /******************************************************************************* | |
2588 | |
2589 $Function: showSSNotify | |
2590 | |
2591 $Description: Show result from E_SS_NOTIFY being returned. Short ss-related | |
2592 notification window. | |
2593 | |
2594 $Returns: | |
2595 | |
2596 $Arguments: | |
2597 | |
2598 *******************************************************************************/ | |
2599 | |
2600 static void showSSNotify (T_MFW_HND win, T_MFW_SS_NOTIFY * ss_notify) | |
2601 { | |
2602 | |
2603 T_DISPLAY_DATA display_info; | |
2604 USHORT TxtId1,TxtId2; | |
2605 | |
2606 TRACE_FUNCTION("++ showSSNotify"); | |
2607 | |
2608 TxtId1 = TxtNull; | |
2609 TxtId2 = TxtNull; | |
2610 | |
2611 switch (ss_notify->code) | |
2612 { | |
2613 case MFW_SS_MO_unconFORWARD: /* CFU activated */ | |
2614 { | |
2615 iconsSetState(iconIdCallFor); | |
2616 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
2617 // Storing the Current state of CF in Flash | |
2618 FFS_flashData.CFState=TRUE; | |
2619 flash_write(); | |
2620 } | |
2621 | |
2622 /* Activate the CFU icon */ | |
2623 /* break; */ /***** NO BREAK ******/ | |
2624 case MFW_SS_MO_conFORWARD: /* Conditional CF active */ | |
2625 TxtId1 = TxtForward; | |
2626 TxtId2 = TxtActivated; | |
2627 break; | |
2628 case MFW_SS_MT_FORWARDED: /* incoming call fowarded */ | |
2629 TxtId1 = TxtIncomingCall; | |
2630 TxtId2 = TxtForwarded; | |
2631 break; | |
2632 | |
2633 case MFW_SS_MO_FORWARDED: /* our call is being forwarded */ | |
2634 TxtId1 = TxtSoftCall; | |
2635 TxtId2 = TxtForwarded; | |
2636 | |
2637 break; | |
2638 | |
2639 case MFW_SS_MO_WAITING: /* outgoing call is waiting signal received */ | |
2640 TxtId1 = TxtSoftCall; | |
2641 TxtId2 = TxtWaiting; | |
2642 break; | |
2643 | |
2644 case MFW_SS_MO_moBARRED: /* outgoing calls barred */ | |
2645 TxtId1 = TxtOutgoingCalls; | |
2646 TxtId2 = TxtBarred; | |
2647 break; | |
2648 | |
2649 case MFW_SS_MO_mtBARRED: /* incoming calls barred */ | |
2650 TxtId1 = TxtIncomingCall; | |
2651 TxtId2 = TxtBarred; | |
2652 break; | |
2653 | |
2654 case MFW_SS_MO_DEFLECTED: /* incoming call diverted */ | |
2655 TxtId1 = TxtIncomingCall; | |
2656 TxtId2 = TxtCallDivert; | |
2657 break; | |
2658 | |
2659 default: | |
2660 break; | |
2661 } | |
2662 | |
2663 if (TxtId1 != TxtNull ) | |
2664 { | |
2665 | |
2666 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtId1, TxtId2, COLOUR_STATUS); | |
2667 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, THREE_SECS, KEY_CLEAR| KEY_LEFT ); | |
2668 display_info.Identifier = E_SS_NOTIFY; | |
2669 | |
2670 /* | |
2671 * Call Info Screen | |
2672 */ | |
2673 | |
2674 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2675 } | |
2676 } | |
2677 | |
2678 /******************************************************************************* | |
2679 | |
2680 $Function: srv_display_status | |
2681 | |
2682 $Description: Indicate a sensefull response to the user if only the . | |
2683 | |
2684 $Returns: | |
2685 | |
2686 $Arguments: | |
2687 | |
2688 *******************************************************************************/ | |
2689 | |
2690 | |
2691 static void srv_display_status (UBYTE ss_status) | |
2692 { | |
2693 T_DISPLAY_DATA display_info; | |
2694 USHORT TxtId2; | |
2695 TRACE_FUNCTION("srv_display_status()"); | |
2696 | |
2697 | |
2698 //GW Swapped text strings over | |
2699 if (ss_status & SS_STAT_ACTIVE) | |
2700 TxtId2 = TxtActivated; | |
2701 /* Marcus: Issue 1652: 03/02/2003: Removed NDH 10/06/03 */ | |
2702 else | |
2703 TxtId2 = TxtDeActivated; | |
2704 | |
2705 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtNull, TxtId2, COLOUR_STATUS); | |
2706 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2707 //Timer value changed from FOREVER to FIVE_SECS | |
2708 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT ); | |
2709 display_info.Identifier = E_SS_CB_CNF; // can be used also for CF and CW | |
2710 | |
2711 /* | |
2712 * Call Info Screen | |
2713 */ | |
2714 | |
2715 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2716 } | |
2717 | |
2718 /******************************************************************************* | |
2719 | |
2720 $Function: ysrv_empty_list_result | |
2721 | |
2722 $Description: Indicate a sensefull response to the user if an | |
2723 activation / deactivation or interrogation leads to an | |
2724 empty list. | |
2725 | |
2726 $Returns: | |
2727 | |
2728 $Arguments: | |
2729 | |
2730 *******************************************************************************/ | |
2731 | |
2732 | |
2733 static void srv_empty_list_result (UBYTE ss_category, USHORT event, UBYTE ss_status, UBYTE ss_code) /* Marcus: Issue 1652: 03/02/2002 */ | |
2734 { | |
2735 T_DISPLAY_DATA display_info; | |
2736 USHORT TxtId1; | |
2737 USHORT TxtId2 = TxtNull; | |
2738 TRACE_FUNCTION("srv_empty_list_result"); | |
2739 | |
2740 switch (event) | |
2741 { | |
2742 case E_SS_CB_CNF: | |
2743 TxtId1 = TxtCallBarringAll; | |
2744 break; | |
2745 | |
2746 case E_SS_CW_CNF: | |
2747 TxtId1 = TxtCallWaiting; | |
2748 break; | |
2749 | |
2750 case E_SS_CF_CNF: | |
2751 TxtId1 = TxtCallDivert; | |
2752 break; | |
2753 | |
2754 default: | |
2755 TxtId1 = TxtNull; | |
2756 } | |
2757 | |
2758 /* Marcus: Issue 1652: 03/02/2002: Start */ | |
2759 TRACE_EVENT_P3("ss_category %d, event %d, ss_status %d", ss_category, event, ss_status); | |
2760 switch (ss_category) | |
2761 { | |
2762 case SS_ACTIVATION: | |
2763 case SS_REGISTRATION: | |
2764 TRACE_FUNCTION ("ACTIVATED !"); | |
2765 TxtId2 = TxtActivated; | |
2766 break; | |
2767 /* Marcus: Issue 1588: 23/01/2003: Start */ | |
2768 case SS_INTERROGATION: | |
2769 if ((event == E_SS_CW_CNF) || (event == E_SS_CF_CNF)) | |
2770 { | |
2771 if (ss_status & SS_STAT_ACTIVE) | |
2772 { | |
2773 TRACE_EVENT ("INTERROGATION:ACTIVATED !"); | |
2774 TxtId2 = TxtActivated; | |
2775 } | |
2776 else /* Marcus: Issue 1651: 30/01/2003: Removed NDH 10/06/03 */ | |
2777 { | |
2778 TRACE_EVENT ("INTERROGATION:DEACTIVATED !"); | |
2779 TxtId2 = TxtDeActivated; | |
2780 } | |
2781 } | |
2782 else | |
2783 { | |
2784 TRACE_EVENT ("DEACTIVATED !"); | |
2785 TxtId2 = TxtDeActivated; | |
2786 } | |
2787 break; | |
2788 | |
2789 case SS_ERASURE: | |
2790 case SS_DEACTIVATION: | |
2791 TRACE_FUNCTION ("DEACTIVATED !"); | |
2792 TxtId2 = TxtDeActivated; | |
2793 break; | |
2794 default: | |
2795 TxtId2 = TxtNull; | |
2796 break; | |
2797 } | |
2798 /* Marcus: Issue 1652: 03/02/2002: End */ | |
2799 | |
2800 if (TxtId2 != TxtNull ) | |
2801 { | |
2802 /*CQ10690 - API - 23/06/03 - Set the icon state to show on this return */ | |
2803 if ( (TxtId2 == TxtActivated) && | |
2804 ( (ss_code == SS_CF_CFU) || (ss_code == SS_CF_ALL) ) ) | |
2805 { | |
2806 iconsSetState(iconIdCallFor); | |
2807 // Jun 23, 2004 REF: CRR MMI-SPR-13599 Rashmi C N(Sasken) | |
2808 // Storing the Current state of CF in Flash | |
2809 FFS_flashData.CFState=TRUE; | |
2810 flash_write(); | |
2811 } | |
2812 /*CQ10690 - END*/ | |
2813 if(event==E_SS_CF_CNF) | |
2814 { | |
2815 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
2816 // We are now passing the type of CF as the first stringID for the dialog info screen | |
2817 // serviceGetType(ss_Code) this function would return the string id for the ss_code being passed | |
2818 | |
2819 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, serviceGetType((T_MFW_SS_CODES)ss_code), TxtId2, COLOUR_STATUS); | |
2820 } | |
2821 else | |
2822 { | |
2823 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtId1, TxtId2, COLOUR_STATUS); | |
2824 } | |
2825 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2826 //Timer value changed from FOREVER to FIVE_SECS | |
2827 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT ); | |
2828 display_info.Identifier = E_SS_CB_CNF; // can be used also for CF and CW | |
2829 | |
2830 /* | |
2831 * Call Info Screen | |
2832 */ | |
2833 | |
2834 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2835 } | |
2836 } | |
2837 | |
2838 | |
2839 /******************************************************************************* | |
2840 | |
2841 $Function: showCWState | |
2842 | |
2843 $Description: display CW state | |
2844 | |
2845 $Returns: | |
2846 | |
2847 $Arguments: | |
2848 | |
2849 *******************************************************************************/ | |
2850 | |
2851 | |
2852 static void showCWStatus (T_MFW_HND win , T_ss * data) | |
2853 | |
2854 { | |
2855 T_DISPLAY_DATA display_info; | |
2856 T_ss_feature_cw_data * pFeature; | |
2857 | |
2858 TRACE_FUNCTION("showCWStatus"); | |
2859 | |
2860 //MC got rid of dodgy pointer arithmetic | |
2861 pFeature = &data->mfw_ss_cw->ss[data->current_feature]; | |
2862 | |
2863 if (data->max_feature == 1) | |
2864 { | |
2865 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, pFeature->service, data->mfw_ss_cw->status, COLOUR_STATUS); | |
2866 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2867 //Timer value changed from FOREVER to FIVE_SECS | |
2868 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT); | |
2869 } | |
2870 else | |
2871 { | |
2872 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtSoftNext, pFeature->service, data->mfw_ss_cw->status, COLOUR_STATUS); | |
2873 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
2874 //Timer value changed from FOREVER to FIVE_SECS | |
2875 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT | KEY_RIGHT ); | |
2876 } | |
2877 | |
2878 display_info.Identifier = E_SS_CW_CNF; | |
2879 | |
2880 /* | |
2881 * Call Info Screen | |
2882 */ | |
2883 | |
2884 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
2885 | |
2886 if (ss_data.info_win EQ NULL) | |
2887 { | |
2888 TRACE_FUNCTION("NOT ENOUGH RESOURCES TO CREATE EXT INFO DIALOG"); | |
2889 } | |
2890 } | |
2891 | |
2892 /******************************************************************************* | |
2893 | |
2894 $Function: showCLIStatus | |
2895 | |
2896 $Description: | |
2897 | |
2898 $Returns: | |
2899 | |
2900 $Arguments: | |
2901 | |
2902 *******************************************************************************/ | |
2903 | |
2904 | |
2905 static void showCLIStatus(T_MFW_HND win, T_MFW_SS_PARA * ss_cnf) | |
2906 { | |
2907 | |
2908 T_DISPLAY_DATA display_info; | |
2909 | |
2910 TRACE_FUNCTION("showCLIStatus()"); | |
2911 | |
2912 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, serviceGetType(ss_cnf->cli_cnf.ss_code), TxtNull , COLOUR_STATUS); | |
2913 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_CLEAR | KEY_LEFT ); | |
2914 display_info.Identifier = ServicesCheckCLI_OK; | |
2915 | |
2916 if (ss_cnf->cli_cnf.ss_status == SS_STAT_UNKNOWN) | |
2917 { | |
2918 // Unknown status. By defaut say that the id is sent | |
2919 display_info.TextId2 = TxtActivated; | |
2920 } | |
2921 else if (ss_cnf->cli_cnf.ss_status & SS_STAT_ACTIVE) | |
2922 { | |
2923 switch (ss_cnf->cli_cnf.ss_clir_option) | |
2924 { | |
2925 // By defaut the caller id is not sent | |
2926 case MFW_CL_TEMP_DEF_REST: | |
2927 switch (CFAction) | |
2928 { | |
2929 // ActivateCLIR, so deactivate the sending of caller id | |
2930 case CFActivate: | |
2931 // By defaut the caller id is not sent | |
2932 display_info.TextId2 = TxtActivated; | |
2933 // No CLIR suppress or invoke | |
2934 cm_mo_prefix(0x04); | |
2935 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
2936 // Maintaing the CLIR status in the flash. | |
2937 FFS_flashData.CLIR=TRUE; | |
2938 flash_write(); | |
2939 break; | |
2940 // Deactivate CLIR, so activate the sending of caller id | |
2941 case CFDeactivate: | |
2942 // By defaut the caller id is not sent | |
2943 display_info.TextId2 = TxtDeActivated; | |
2944 // CLIR suppress needed | |
2945 cm_mo_prefix(0x08); | |
2946 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
2947 // Maintaing the CLIR status in the flash. | |
2948 FFS_flashData.CLIR=FALSE; | |
2949 flash_write(); | |
2950 break; | |
2951 case CFCheck: | |
2952 default: | |
2953 /* // Check if CLIR suppress is activated: caller id sent | |
2954 if ((cm_mo_prefix(0) & 0x0c) == 0x08) | |
2955 display_info.TextId2 = TxtDeActivated; | |
2956 // By defaut the caller id is not sent | |
2957 else | |
2958 display_info.TextId2 = TxtActivated;*/ | |
2959 // Check if CLIR suppress is activated: caller id sent | |
2960 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
2961 // Using the CLIR status maintained in the flash, when the status is checked | |
2962 if (!FFS_flashData.CLIR) | |
2963 { | |
2964 display_info.TextId2 = TxtDeActivated; | |
2965 } | |
2966 // By defaut the caller id is not sent | |
2967 else | |
2968 { | |
2969 display_info.TextId2 = TxtActivated; | |
2970 } | |
2971 | |
2972 break; | |
2973 } | |
2974 break; | |
2975 // By defaut the caller id is sent | |
2976 case MFW_CL_TEMP_DEF_ALLOWED: | |
2977 switch (CFAction) | |
2978 { | |
2979 // ActivateCLIR, so deactivate the sending of caller id | |
2980 case CFActivate: | |
2981 // By defaut the caller id is sent | |
2982 display_info.TextId2 =TxtActivated; | |
2983 // CLIR invoke needed | |
2984 cm_mo_prefix(0x0c); | |
2985 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
2986 // Maintaing the CLIR status in the flash. | |
2987 FFS_flashData.CLIR=TRUE; | |
2988 flash_write(); | |
2989 break; | |
2990 // Deactivate CLIR, so activate the sending of caller id | |
2991 case CFDeactivate: | |
2992 // By defaut the caller id is sent | |
2993 display_info.TextId2 = TxtDeActivated; | |
2994 // No CLIR suppress or invoke | |
2995 cm_mo_prefix(0x04); | |
2996 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
2997 // Maintaing the CLIR status in the flash. | |
2998 FFS_flashData.CLIR=FALSE; | |
2999 flash_write(); | |
3000 break; | |
3001 case CFCheck: | |
3002 default: | |
3003 /* // Check if CLIR invoke is activated: caller id not sent | |
3004 if ((cm_mo_prefix(0) & 0x0c) == 0x0c) | |
3005 display_info.TextId2 = TxtActivated; | |
3006 // By defaut the caller id is sent | |
3007 else | |
3008 display_info.TextId2 = TxtDeActivated;*/ | |
3009 // Check if CLIR invoke is activated: caller id not sent | |
3010 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
3011 // Using the CLIR status maintained in the flash, when the status is checked | |
3012 if (FFS_flashData.CLIR) | |
3013 { | |
3014 display_info.TextId2 = TxtActivated; | |
3015 } | |
3016 // By defaut the caller id is sent | |
3017 else | |
3018 { | |
3019 display_info.TextId2 = TxtDeActivated; | |
3020 } | |
3021 | |
3022 } | |
3023 break; | |
3024 case MFW_CL_PERM: | |
3025 // No CLIR suppress or invoke | |
3026 cm_mo_prefix(0x04); | |
3027 // No break | |
3028 case MFW_CL_UNKNOWN: | |
3029 default: | |
3030 // The CLIR is active and permanent the caller id is not sent | |
3031 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
3032 // Maintaing the CLIR status in the flash. | |
3033 FFS_flashData.CLIR=TRUE; | |
3034 flash_write(); | |
3035 display_info.TextId2 = TxtActivated; | |
3036 break; | |
3037 } | |
3038 } | |
3039 // CLIR service is not activated: The caller id is sent | |
3040 else | |
3041 { | |
3042 // Dec 07, 2005 REF: OMAPS00050087 x0039928 | |
3043 // Fix: String "Not Activated" is displayed if the network doesn't permit CLIR | |
3044 switch(CFAction) | |
3045 { | |
3046 case CFActivate: | |
3047 display_info.TextId2 = TxtNotActivated; | |
3048 break; | |
3049 case CFDeactivate: | |
3050 case CFCheck: | |
3051 default: | |
3052 display_info.TextId2 = TxtDeActivated; | |
3053 break; | |
3054 } | |
3055 // No CLIR suppress or invoke | |
3056 // Apr 22, 2004 REF: CRR MMI-SPR-16873 Rashmi C N(Sasken) | |
3057 // Maintaing the CLIR status in the flash. | |
3058 FFS_flashData.CLIR=FALSE; | |
3059 flash_write(); | |
3060 cm_mo_prefix(0x04); | |
3061 } | |
3062 | |
3063 // Call Info Screen | |
3064 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
3065 | |
3066 } | |
3067 | |
3068 | |
3069 | |
3070 /******************************************************************************* | |
3071 | |
3072 $Function: showIMEI2 | |
3073 | |
3074 $Description: | |
3075 | |
3076 $Returns: | |
3077 | |
3078 $Arguments: | |
3079 | |
3080 *******************************************************************************/ | |
3081 | |
3082 static void showIMEI2 (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf) | |
3083 { | |
3084 T_DISPLAY_DATA display_info; | |
3085 | |
3086 // July 09, 2005 REF : MMI-22565 - a0876501 | |
3087 // Increased the IMEI_LEN from 15 to 17 for displaying the Cd byte & SW version. | |
3088 #define IMEI_LEN 17 /* IMEI + check digit = 15, IMEI + SW version = 16, IMEI + check digit + SW version = 17*/ | |
3089 static char imei_array[IMEI_LEN+1]; | |
3090 //GW IMEI number is 26 chars long! | |
3091 memset(imei_array,0x00,IMEI_LEN+1); | |
3092 memcpy(imei_array, ss_cnf->imei_info.imei_number, IMEI_LEN); | |
3093 | |
3094 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull,TxtIMEI, TxtNull , COLOUR_STATUS); | |
3095 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_CLEAR | KEY_LEFT ); | |
3096 display_info.TextString2 = imei_array; | |
3097 /* | |
3098 * Call Info Screen | |
3099 */ | |
3100 | |
3101 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
3102 | |
3103 } | |
3104 | |
3105 /******************************************************************************* | |
3106 | |
3107 $Function: showUSSDInfo | |
3108 | |
3109 $Description: this is used for both USSD types (confirm and request). | |
3110 The USSD request is keep going after "showUSSDInfo" | |
3111 function and open the editor to enter the string. | |
3112 | |
3113 $Returns: | |
3114 | |
3115 $Arguments: | |
3116 | |
3117 *******************************************************************************/ | |
3118 | |
3119 | |
3120 | |
3121 static void showUSSDInfo (T_MFW_HND win, USHORT ident, T_MFW_SS_PARA * ss_cnf, USHORT sk1, USHORT sk2) | |
3122 { | |
3123 #ifdef NEW_EDITOR | |
3124 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */ | |
3125 #else | |
3126 T_EDITOR_DATA editor_data; | |
3127 #endif | |
3128 | |
3129 TRACE_FUNCTION("showUSSDInfo"); | |
3130 | |
3131 | |
3132 /* keep the dcs; need it later for sending */ | |
3133 ss_data.dcs = ss_cnf->ussd_info.dcs; | |
3134 | |
3135 /* SPR#1428 - SH - New Editor changes */ | |
3136 | |
3137 #ifdef NEW_EDITOR | |
3138 AUI_edit_SetDefault(&editor_data); | |
3139 AUI_edit_SetDisplay(&editor_data, ZONE_FULL_SK_TITLE, COLOUR_EDITOR_XX, EDITOR_FONT); | |
3140 AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE); | |
3141 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_cnf->ussd_info.ussd, MAX_USSD_LEN); | |
3142 if (ident EQ ServicesUSSD_REQ_OK) | |
3143 { | |
3144 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtSsMsg, NULL); | |
3145 } | |
3146 else | |
3147 { | |
3148 AUI_edit_SetTextStr(&editor_data, TxtNull, TxtSoftBack, TxtSsMsg, NULL); | |
3149 } | |
3150 AUI_edit_SetEvents(&editor_data, ident, TRUE, FOREVER, (T_AUI_EDIT_CB)services_info_cb); | |
3151 | |
3152 AUI_edit_Start(ss_data.win, &editor_data); /* start the editor */ | |
3153 #else /* NEW_EDITOR */ | |
3154 editor_data.editor_attr.win.px = 6; | |
3155 editor_data.editor_attr.win.py = 12; | |
3156 editor_data.editor_attr.win.sx = 80; | |
3157 editor_data.editor_attr.win.sy = 20; | |
3158 editor_data.editor_attr.edtCol = COLOUR_EDITOR_XX, | |
3159 editor_data.editor_attr.font = 0; | |
3160 editor_data.editor_attr.mode = edtCurNone; | |
3161 editor_data.editor_attr.controls = 0; | |
3162 | |
3163 editor_data.hide = FALSE; | |
3164 editor_data.editor_attr.text = (char*)ss_cnf->ussd_info.ussd; | |
3165 editor_data.editor_attr.size = sizeof(ss_cnf->ussd_info.ussd); | |
3166 | |
3167 if (ident EQ ServicesUSSD_REQ_OK) | |
3168 { | |
3169 editor_data.LeftSoftKey = TxtSoftOK; | |
3170 editor_data.RightSoftKey = TxtSoftBack; | |
3171 } | |
3172 else | |
3173 { | |
3174 editor_data.LeftSoftKey = TxtNull; | |
3175 editor_data.RightSoftKey = TxtSoftBack; | |
3176 } | |
3177 | |
3178 editor_data.AlternateLeftSoftKey = TxtNull; | |
3179 editor_data.TextString = TxtNull; | |
3180 editor_data.TextId = TxtSsMsg; | |
3181 editor_data.Identifier = ident; | |
3182 editor_data.mode = READ_ONLY_MODE; | |
3183 editor_data.timeout = FOREVER; | |
3184 editor_data.min_enter = 1; | |
3185 editor_data.Callback = (T_EDIT_CB)services_info_cb; | |
3186 editor_data.destroyEditor = TRUE; | |
3187 | |
3188 /* create the dialog handler */ | |
3189 editor_start(ss_data.win, &editor_data); /* start the editor */ | |
3190 #endif /* NEW_EDITOR */ | |
3191 | |
3192 } | |
3193 | |
3194 | |
3195 /******************************************************************************* | |
3196 | |
3197 $Function: showUSSDREQ | |
3198 | |
3199 $Description: show USSD info from Request, and then allow user to enter a response. | |
3200 | |
3201 $Returns: | |
3202 | |
3203 $Arguments: | |
3204 | |
3205 *******************************************************************************/ | |
3206 | |
3207 | |
3208 static void showUSSDREQ (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf) | |
3209 { | |
3210 TRACE_FUNCTION("showUSSDREQ"); | |
3211 | |
3212 showUSSDInfo(win, ServicesUSSD_REQ_OK, ss_cnf, TxtSoftOK, TxtSoftBack); | |
3213 | |
3214 } | |
3215 | |
3216 | |
3217 | |
3218 /******************************************************************************* | |
3219 | |
3220 $Function: showUSSDCNF | |
3221 | |
3222 $Description: display USSD message | |
3223 | |
3224 $Returns: | |
3225 | |
3226 $Arguments: | |
3227 | |
3228 *******************************************************************************/ | |
3229 | |
3230 | |
3231 static void showUSSDCNF (T_MFW_HND win, T_MFW_SS_PARA * ss_cnf) | |
3232 { | |
3233 | |
3234 T_DISPLAY_DATA display_info; | |
3235 int nPixels = 0; | |
3236 int nchar = 0; | |
3237 | |
3238 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
3239 //Bug : Unable to compose a one or two digit number | |
3240 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
3241 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
3242 //was not handled properly. So altered the editor handling to cater for the long message. | |
3243 T_MFW_WIN *win_data; | |
3244 T_ss *data = NULL; | |
3245 T_AUI_EDITOR_DATA display_editor_info; | |
3246 | |
3247 TRACE_FUNCTION("showUSSDCNF"); | |
3248 /* API - 09-07-03 - CQ10728 - Add this check to use either the editor or the bubble depending | |
3249 on the size of the returned string */ | |
3250 /* API - 27-08-03 - CQ10728 - Update, calculate the length of the string in number of pixels */ | |
3251 | |
3252 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
3253 //Bug : Unable to compose a one or two digit number | |
3254 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
3255 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
3256 //was not handled properly. So altered the editor handling to cater for the long message. | |
3257 if(win) | |
3258 { | |
3259 win_data = ((T_MFW_HDR *)win)->data; | |
3260 if(win_data) | |
3261 data = (T_ss * )win_data->user; | |
3262 } | |
3263 | |
3264 nchar = strlen((char *)ss_cnf->ussd_info.ussd); | |
3265 nPixels = dspl_GetTextExtent( (char *)ss_cnf->ussd_info.ussd, nchar); | |
3266 /* API - 27-08-03 - CQ10728 - END */ | |
3267 | |
3268 if (nPixels >= SCREEN_SIZE_X) | |
3269 { | |
3270 //Feb 17, 2005 REF : CRR 17657 x0012850 Divya.P.V | |
3271 //Bug : Unable to compose a one or two digit number | |
3272 //Fix : This bug is reproducible when a very long message is sent by the service provider when an invalid one or two digit number is dialled. | |
3273 //The read only editor with the service provider message that comes up when a one or two digit is dialled | |
3274 //was not handled properly. So altered the editor handling to cater for the long message. | |
3275 AUI_edit_SetDefault(&display_editor_info); | |
3276 AUI_edit_SetMode(&display_editor_info, ED_MODE_READONLY, ED_CURSOR_UNDERLINE); | |
3277 AUI_edit_SetBuffer(&display_editor_info, ATB_DCS_ASCII, (UBYTE*)ss_cnf->ussd_info.ussd, (USHORT)ss_cnf->ussd_info.len); | |
3278 AUI_edit_SetTextStr(&display_editor_info, TxtNull, TxtSoftBack,TxtNull,NULL); | |
3279 AUI_edit_SetEvents(&display_editor_info, 0, FALSE, FOREVER, (T_AUI_EDIT_CB)services_info_cb); | |
3280 display_editor_info.Identifier = ServicesUSSD_CNF_OK; | |
3281 data->info_win = AUI_edit_Start(data->win, &display_editor_info); | |
3282 } | |
3283 else | |
3284 { | |
3285 if (strlen((char *)ss_cnf->ussd_info.ussd) == 0) | |
3286 { | |
3287 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtCommand, TxtCompleted, COLOUR_STATUS); | |
3288 } | |
3289 else | |
3290 { | |
3291 dlg_initDisplayData_TextStr(&display_info, TxtSoftOK, TxtNull, (char *)ss_cnf->ussd_info.ussd, NULL, COLOUR_STATUS); | |
3292 } | |
3293 | |
3294 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FOREVER, KEY_HUP| KEY_LEFT); | |
3295 display_info.Identifier = ServicesUSSD_CNF_OK; | |
3296 | |
3297 /* | |
3298 * Display Dialog Info Screen | |
3299 */ | |
3300 | |
3301 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
3302 } | |
3303 /*API - 09-07-03 CQ10728- END*/ | |
3304 } | |
3305 | |
3306 | |
3307 /******************************************************************************* | |
3308 | |
3309 $Function: sendUSSD | |
3310 | |
3311 $Description: Send USSD message | |
3312 | |
3313 $Returns: | |
3314 | |
3315 $Arguments: | |
3316 | |
3317 *******************************************************************************/ | |
3318 | |
3319 static void sendUSSD (T_MFW_SS_PARA *ussd_senddata) | |
3320 { | |
3321 | |
3322 // unsigned int tLen = ussd_senddata->ussd_info.len; // RAVI | |
3323 | |
3324 ss_cnf = ussd_senddata; | |
3325 | |
3326 if (ss_send_ussd( (T_MFW_SS_USSD *) ss_cnf ) == MFW_SS_FAIL) | |
3327 { | |
3328 /* ussd data is wrong */ | |
3329 showFailed( ss_data.win ); | |
3330 } | |
3331 else | |
3332 if (servicesState == ServicesUSSDSendEdit) | |
3333 servicesExec(ServicesUSSDSendEdit_Ok, 0); | |
3334 else | |
3335 servicesExec(ServicesUSSDEnter_Send, 0); | |
3336 } | |
3337 | |
3338 | |
3339 /******************************************************************************* | |
3340 | |
3341 $Function: showCFStatus | |
3342 | |
3343 $Description: display CFU state | |
3344 | |
3345 $Returns: | |
3346 | |
3347 $Arguments: | |
3348 | |
3349 *******************************************************************************/ | |
3350 | |
3351 | |
3352 static void showCFStatus (T_MFW_HND win , T_ss * data) | |
3353 { | |
3354 T_DISPLAY_DATA display_info; | |
3355 T_ss_feature_cf_data * pFeature; | |
3356 static char str[50]; | |
3357 | |
3358 | |
3359 TRACE_FUNCTION("showCFStatus"); | |
3360 | |
3361 //MC got rid of dodgy pointer arithmetic | |
3362 pFeature = &data->mfw_ss_cf->ss[data->current_feature]; | |
3363 | |
3364 if (data->max_feature == 1) | |
3365 { | |
3366 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
3367 // We are now passing the type of CF as the first stringID for the dialog info screen | |
3368 // serviceGetType(ss_Code) this function would return the string id for the ss_code being passed | |
3369 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, serviceGetType((T_MFW_SS_CODES)ss_Code), TxtNull, COLOUR_STATUS); | |
3370 | |
3371 // Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
3372 //the time parameter is changed from FOREVER to FIVE_SECS | |
3373 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT); | |
3374 } | |
3375 else | |
3376 { | |
3377 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
3378 // We are now passing the type of CF as the first stringID for the dialog info screen | |
3379 // serviceGetType(ss_Code) this function would return the string id for the ss_code being passed | |
3380 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtSoftNext, serviceGetType((T_MFW_SS_CODES)ss_Code), TxtNull, COLOUR_STATUS); | |
3381 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
3382 //the time parameter is changed from FOREVER to FIVE_SECS | |
3383 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT | KEY_RIGHT ); | |
3384 } | |
3385 | |
3386 display_info.Identifier = E_SS_CF_CNF; | |
3387 memset(str, 0, 50); | |
3388 //Only show the number when activating call diverts | |
3389 if (pFeature->status == TxtActivated) | |
3390 { | |
3391 // Jun 10, 2004 REF: CRR MMI-SPR-13614 Rashmi C N(Sasken) | |
3392 // When call forward is activated, the service(i.e voice, fax or data) and the number to which it is forwarded | |
3393 // is passed as the second string for the dialog display. Only two strings or string IDs can be given for a | |
3394 //dialog info screen. Hence, we are adding the service and the number into one string. | |
3395 strcat(str,(char*)MmiRsrcGetText(pFeature->service)); | |
3396 strcat(str," "); | |
3397 strcat(str,pFeature->forwarded_to_number); | |
3398 display_info.TextString2=str; | |
3399 } | |
3400 else /* SPR#2252 - DS - Show status */ | |
3401 { | |
3402 display_info.TextId2 = pFeature->status; | |
3403 } | |
3404 | |
3405 /* | |
3406 * Call Info Screen | |
3407 */ | |
3408 | |
3409 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
3410 | |
3411 if (ss_data.info_win EQ NULL) | |
3412 { | |
3413 TRACE_FUNCTION("NOT ENOUGH RESOURCES TO CREATE EXT INFO DIALOG"); | |
3414 } | |
3415 } | |
3416 | |
3417 | |
3418 /******************************************************************************* | |
3419 | |
3420 $Function: showCBStatus | |
3421 | |
3422 $Description: display CB state | |
3423 | |
3424 $Returns: | |
3425 | |
3426 $Arguments: | |
3427 | |
3428 *******************************************************************************/ | |
3429 | |
3430 | |
3431 | |
3432 static void showCBStatus (T_MFW_HND win , T_ss * data) | |
3433 { | |
3434 T_DISPLAY_DATA display_info; | |
3435 T_ss_feature_cb_data * pFeature; | |
3436 | |
3437 TRACE_FUNCTION("showCBStatus"); | |
3438 | |
3439 //MC got rid of dodgy pointer arithmetic | |
3440 pFeature = &data->mfw_ss_cb->ss[data->current_feature]; | |
3441 | |
3442 if (data->max_feature == 1) | |
3443 { | |
3444 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, pFeature->service, pFeature->status, COLOUR_STATUS); | |
3445 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
3446 //Timer value changed from FOREVER to FIVE_SECS | |
3447 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT); | |
3448 } | |
3449 else | |
3450 { | |
3451 dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtSoftNext, pFeature->service, pFeature->status, COLOUR_STATUS); | |
3452 //Jun 04,2004 CRR:13601 xpradipg - SASKEN | |
3453 //Timer value changed from FOREVER to FIVE_SECS | |
3454 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, FIVE_SECS, KEY_CLEAR| KEY_LEFT | KEY_RIGHT ); | |
3455 } | |
3456 display_info.Identifier = E_SS_CB_CNF; // can be used also for CF and CW | |
3457 | |
3458 /* | |
3459 * Call Info Screen | |
3460 */ | |
3461 | |
3462 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
3463 | |
3464 if (ss_data.info_win EQ NULL) | |
3465 { | |
3466 TRACE_FUNCTION("NOT ENOUGH RESOURCES TO CREATE EXT INFO DIALOG"); | |
3467 } | |
3468 } | |
3469 | |
3470 /******************************************************************************* | |
3471 | |
3472 $Function: getCFAction | |
3473 | |
3474 $Description: To return a string corresponding to call forwarding action. | |
3475 | |
3476 $Returns: | |
3477 | |
3478 $Arguments: | |
3479 | |
3480 *******************************************************************************/ | |
3481 | |
3482 | |
3483 static void getCFAction(char * pSSstring) | |
3484 { | |
3485 switch (CFAction) | |
3486 { | |
3487 case CFActivate: | |
3488 strcpy(pSSstring, "**"); | |
3489 break; | |
3490 case CFDeactivate: | |
3491 strcpy(pSSstring, "##"); | |
3492 break; | |
3493 case CFCheck: | |
3494 strcpy(pSSstring, "*#"); | |
3495 break; | |
3496 default: | |
3497 break; | |
3498 } | |
3499 | |
3500 } | |
3501 | |
3502 | |
3503 /******************************************************************************* | |
3504 | |
3505 $Function: getCFType | |
3506 | |
3507 $Description: To return a string corresponding to call forwarding type: | |
3508 CFU, CFNRy, CFU, etc. | |
3509 | |
3510 $Returns: | |
3511 | |
3512 $Arguments: | |
3513 | |
3514 *******************************************************************************/ | |
3515 | |
3516 | |
3517 static void getCFType(char* pSSstring) | |
3518 { | |
3519 switch (CFType) | |
3520 { | |
3521 case CFBusy: | |
3522 strcat(pSSstring, "67*"); | |
3523 break; | |
3524 case CFNoReply: | |
3525 strcat(pSSstring, "61*"); | |
3526 break; | |
3527 case CFNoReach: | |
3528 strcat(pSSstring, "62*"); | |
3529 break; | |
3530 case CFUnconditional: | |
3531 strcat(pSSstring, "21*"); | |
3532 break; | |
3533 case CFAllConditional: | |
3534 strcat(pSSstring, "004*"); | |
3535 break; | |
3536 case CFAllCalls: | |
3537 strcat(pSSstring, "002*"); | |
3538 break; | |
3539 default: | |
3540 break; | |
3541 } | |
3542 } | |
3543 | |
3544 | |
3545 | |
3546 | |
3547 /******************************************************************************* | |
3548 | |
3549 $Function: getCFNumber | |
3550 | |
3551 $Description: | |
3552 | |
3553 $Returns: | |
3554 | |
3555 $Arguments: | |
3556 | |
3557 *******************************************************************************/ | |
3558 | |
3559 static void getCFNumber(char * pSSstring) | |
3560 { | |
3561 | |
3562 strcat(pSSstring, ss_data.edt_buf_number); | |
3563 } | |
3564 | |
3565 | |
3566 | |
3567 /******************************************************************************* | |
3568 | |
3569 $Function: getCFService | |
3570 | |
3571 $Description: | |
3572 | |
3573 $Returns: | |
3574 | |
3575 $Arguments: | |
3576 | |
3577 *******************************************************************************/ | |
3578 | |
3579 | |
3580 static void getCFService(char * pSSstring) | |
3581 { | |
3582 | |
3583 switch (CFService) | |
3584 { | |
3585 case CFVoice: | |
3586 strcat(pSSstring, "*11"); //SPR#0776 - DS -changed from 10 to 11 | |
3587 break; | |
3588 /*MC SPR 742, handle line 2, auxiliary telephony*/ | |
3589 case CFAuxVoice: | |
3590 strcat(pSSstring, "*89"); | |
3591 break; | |
3592 case CFFax: | |
3593 strcat(pSSstring, "*13"); | |
3594 break; | |
3595 case CFData: | |
3596 strcat(pSSstring, "*20"); | |
3597 break; | |
3598 default: | |
3599 break; | |
3600 } | |
3601 } | |
3602 | |
3603 | |
3604 | |
3605 /******************************************************************************* | |
3606 | |
3607 $Function: servicesSendCallDivert | |
3608 | |
3609 $Description: Send out Call Divert String to MFW according to static variables. | |
3610 | |
3611 $Returns: | |
3612 | |
3613 $Arguments: | |
3614 | |
3615 *******************************************************************************/ | |
3616 | |
3617 | |
3618 | |
3619 static int servicesSendCallDivert( char * divert_number) | |
3620 { | |
3621 char SS_string[60] = {'\0'}; | |
3622 | |
3623 /* build up SS string according to menu selections */ | |
3624 getCFAction(SS_string); | |
3625 getCFType(SS_string); | |
3626 if (divert_number) | |
3627 strcat(SS_string, divert_number); | |
3628 else | |
3629 getCFNumber(SS_string); | |
3630 getCFService(SS_string); | |
3631 strcat(SS_string, "#"); | |
3632 | |
3633 { //save the status to SIM | |
3634 if (CFAction == CFActivate && CFType == CFUnconditional || CFType == CFAllCalls) | |
3635 switch (CFService) | |
3636 { | |
3637 case (CFVoice): /*MC SPR 742, handle line 2, auxiliary telephony*/ | |
3638 case CFAuxVoice: | |
3639 | |
3640 if (GetAlsLine() == MFW_SERV_LINE1) | |
3641 cphs_set_divert_status(MFW_CFLAG_SET,0,0,0); | |
3642 else | |
3643 cphs_set_divert_status(0,MFW_CFLAG_SET,0,0); | |
3644 break; | |
3645 case (CFData): cphs_set_divert_status(0,0,0,MFW_CFLAG_SET);break; | |
3646 case (CFFax): cphs_set_divert_status(0,0,MFW_CFLAG_SET,0);break; | |
3647 case (CFAll): if (GetAlsLine() == MFW_SERV_LINE1) | |
3648 cphs_set_divert_status(MFW_CFLAG_SET,0,MFW_CFLAG_SET,MFW_CFLAG_SET); | |
3649 else | |
3650 cphs_set_divert_status(0,MFW_CFLAG_SET,MFW_CFLAG_SET,MFW_CFLAG_SET); | |
3651 break; | |
3652 } | |
3653 if (CFAction == CFDeactivate && CFType == CFUnconditional || CFType == CFAllCalls) | |
3654 switch (CFService) | |
3655 { | |
3656 case (CFVoice): | |
3657 /*MC SPR 742, handle line 2, auxiliary telephony*/ | |
3658 case CFAuxVoice: | |
3659 | |
3660 if (GetAlsLine() == MFW_SERV_LINE1) | |
3661 cphs_set_divert_status(MFW_CFLAG_NOTSet,0,0,0); | |
3662 else | |
3663 cphs_set_divert_status(0,MFW_CFLAG_NOTSet,0,0); | |
3664 break; | |
3665 case (CFData): cphs_set_divert_status(0,0,0,MFW_CFLAG_NOTSet);break; | |
3666 case (CFFax): cphs_set_divert_status(0,0,MFW_CFLAG_NOTSet,0);break; | |
3667 case (CFAll): if (GetAlsLine() == MFW_SERV_LINE1) | |
3668 cphs_set_divert_status(MFW_CFLAG_NOTSet,0,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet); | |
3669 else | |
3670 cphs_set_divert_status(0,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet); | |
3671 break; | |
3672 } | |
3673 } | |
3674 | |
3675 | |
3676 TRACE_FUNCTION(SS_string); | |
3677 | |
3678 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
3679 { | |
3680 showFailed( ss_data.win ); | |
3681 } | |
3682 return 0; | |
3683 } | |
3684 | |
3685 | |
3686 | |
3687 /******************************************************************************* | |
3688 | |
3689 $Function: servicesActivateCLIR | |
3690 | |
3691 $Description: activate CLIR | |
3692 | |
3693 $Returns: | |
3694 | |
3695 $Arguments: | |
3696 | |
3697 *******************************************************************************/ | |
3698 | |
3699 int servicesActivateCLIR(MfwMnu* m, MfwMnuItem* i) { | |
3700 char actstr[8]; | |
3701 | |
3702 CFAction = CFActivate; | |
3703 strcpy(actstr, "#31#"); | |
3704 | |
3705 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3706 showFailed( ss_data.win ); | |
3707 else | |
3708 { | |
3709 strcpy(actstr, "*#31#"); | |
3710 | |
3711 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3712 showFailed( ss_data.win ); | |
3713 } | |
3714 | |
3715 | |
3716 return 0; | |
3717 } | |
3718 | |
3719 | |
3720 /******************************************************************************* | |
3721 | |
3722 $Function: servicesSuppressCLIR | |
3723 | |
3724 $Description: suppress CLIR | |
3725 | |
3726 $Returns: | |
3727 | |
3728 $Arguments: | |
3729 | |
3730 *******************************************************************************/ | |
3731 | |
3732 | |
3733 int servicesDeactivateCLIR(MfwMnu* m, MfwMnuItem* i) { | |
3734 char actstr[8]; | |
3735 | |
3736 CFAction = CFDeactivate; | |
3737 strcpy(actstr, "*31#"); | |
3738 | |
3739 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3740 showFailed( ss_data.win ); | |
3741 else | |
3742 { | |
3743 strcpy(actstr, "*#31#"); | |
3744 | |
3745 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3746 showFailed( ss_data.win ); | |
3747 } | |
3748 | |
3749 return 0; | |
3750 } | |
3751 | |
3752 /******************************************************************************* | |
3753 | |
3754 $Function: servicesCheckCLIR | |
3755 | |
3756 $Description: | |
3757 | |
3758 $Returns: | |
3759 | |
3760 $Arguments: | |
3761 | |
3762 *******************************************************************************/ | |
3763 | |
3764 | |
3765 | |
3766 int servicesCheckCLIR(MfwMnu* m, MfwMnuItem* i) { | |
3767 char actstr[8]; | |
3768 | |
3769 CFAction = CFCheck; | |
3770 | |
3771 strcpy(actstr, "*#31#"); | |
3772 | |
3773 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3774 showFailed( ss_data.win ); | |
3775 | |
3776 return 0; | |
3777 } | |
3778 | |
3779 | |
3780 /******************************************************************************* | |
3781 | |
3782 $Function: servicesCheckCWaiting | |
3783 | |
3784 $Description: | |
3785 | |
3786 $Returns: | |
3787 | |
3788 $Arguments: | |
3789 | |
3790 *******************************************************************************/ | |
3791 | |
3792 int servicesCheckCWaiting(MfwMnu* m, MfwMnuItem* i) { | |
3793 char actstr[8]; | |
3794 | |
3795 strcpy(actstr, "*#43#"); | |
3796 | |
3797 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3798 showFailed( ss_data.win ); | |
3799 | |
3800 return 0; | |
3801 } | |
3802 | |
3803 | |
3804 /******************************************************************************* | |
3805 | |
3806 $Function: servicesActivateCWaiting | |
3807 | |
3808 $Description: activate CallWaiting functionality | |
3809 | |
3810 $Returns: | |
3811 | |
3812 $Arguments: | |
3813 | |
3814 *******************************************************************************/ | |
3815 | |
3816 | |
3817 int servicesActivateCWaiting(MfwMnu* m, MfwMnuItem* i) { | |
3818 char actstr[8]; | |
3819 | |
3820 | |
3821 /* JVJ #1586 Changed *43*10# to *43*# */ | |
3822 strcpy(actstr, "*43*#"); | |
3823 | |
3824 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3825 showFailed( ss_data.win ); | |
3826 | |
3827 return MFW_EVENT_CONSUMED; | |
3828 } | |
3829 | |
3830 | |
3831 /******************************************************************************* | |
3832 | |
3833 $Function: servicesDeactivateCWaiting | |
3834 | |
3835 $Description: deactivate CallWaiting functionality | |
3836 | |
3837 $Returns: | |
3838 | |
3839 $Arguments: | |
3840 | |
3841 *******************************************************************************/ | |
3842 | |
3843 | |
3844 | |
3845 int servicesDeactivateCWaiting(MfwMnu* m, MfwMnuItem* i) { | |
3846 char actstr[8]; | |
3847 | |
3848 /* JVJ #1586 Changed #43*10# to #43# */ | |
3849 strcpy(actstr, "#43#"); | |
3850 | |
3851 if (ss_execute_transaction((UBYTE*)actstr, 0) == MFW_SS_FAIL) | |
3852 showFailed( ss_data.win ); | |
3853 | |
3854 return MFW_EVENT_CONSUMED; | |
3855 } | |
3856 | |
3857 | |
3858 | |
3859 | |
3860 /******************************************************************************* | |
3861 | |
3862 $Function: servicesInterCFU | |
3863 | |
3864 $Description: Interrogate the CFU functionality | |
3865 | |
3866 $Returns: | |
3867 | |
3868 $Arguments: | |
3869 | |
3870 *******************************************************************************/ | |
3871 | |
3872 | |
3873 | |
3874 | |
3875 int servicesInterCFU(void) | |
3876 { | |
3877 char actstr[8]; | |
3878 | |
3879 strcpy(actstr, "*#21#"); | |
3880 | |
3881 ss_execute_transaction((UBYTE*)actstr, 0); | |
3882 | |
3883 return 0; | |
3884 } | |
3885 | |
3886 | |
3887 | |
3888 | |
3889 | |
3890 | |
3891 | |
3892 | |
3893 | |
3894 | |
3895 /******************************************************************************* | |
3896 | |
3897 $Function: ServiceGetStatus | |
3898 | |
3899 $Description: return the code for the MMI text string for the service status. | |
3900 | |
3901 $Returns: | |
3902 | |
3903 $Arguments: | |
3904 | |
3905 *******************************************************************************/ | |
3906 | |
3907 | |
3908 unsigned int ServiceGetStatus( UBYTE pStatus) | |
3909 { | |
3910 unsigned int strStatusCode = 0; | |
3911 | |
3912 TRACE_FUNCTION("++ ServiceGetStatus"); | |
3913 | |
3914 if (pStatus & SS_STAT_ACTIVE) | |
3915 strStatusCode = TxtActivated; | |
3916 /* Marcus: Issue 1652: 03/02/2003: Removed NDH 10/06/03 */ | |
3917 else | |
3918 strStatusCode = TxtDeActivated; | |
3919 return strStatusCode; | |
3920 } | |
3921 | |
3922 | |
3923 /******************************************************************************* | |
3924 | |
3925 $Function: serviceGetServiceType | |
3926 | |
3927 $Description: return the code for the MMI text string for the service type. | |
3928 | |
3929 $Returns: | |
3930 | |
3931 $Arguments: | |
3932 | |
3933 *******************************************************************************/ | |
3934 | |
3935 | |
3936 unsigned int serviceGetServiceType( UBYTE ss_telecom_type, UBYTE ss_telecom_service) | |
3937 { | |
3938 unsigned int strServCode = 0; | |
3939 | |
3940 TRACE_FUNCTION("++ serviceGetServiceType"); | |
3941 switch ( ss_telecom_type ) | |
3942 { | |
3943 case MFW_BST_UNKNOWN: | |
3944 break; | |
3945 | |
3946 case MFW_BST_TELE: | |
3947 switch ( ss_telecom_service ) | |
3948 { | |
3949 case MFW_TS_ALL_TS: strServCode = TxtAllCalls; break;/* all teleservices */ | |
3950 case MFW_TS_ALL_SPCH: /* All speech transmission services */ | |
3951 case MFW_TS_TLPHNY: /* telephony */ | |
3952 case MFW_TS_EMRGNCY: /* emergency calls */ | |
3953 strServCode = TxtVoice; | |
3954 break; | |
3955 case MFW_TS_ALL_SMS: /* all SMS services */ | |
3956 case MFW_TS_SMS_MT: /* SMS MT PP */ | |
3957 case MFW_TS_SMS_MO: /* SMS MO PP */ | |
3958 /*strServCode = TxtSMS;*/ | |
3959 break; | |
3960 case MFW_TS_ALL_FAX: /* all FAX transmission services */ | |
3961 case MFW_TS_FAX3_ALT_SPCH: /* FAX group 3 alter. speech */ | |
3962 case MFW_TS_FAX3_AUTO: /* FAX group 3 automatic */ | |
3963 case MFW_TS_FAX4: /* FAX group 4 */ | |
3964 strServCode = TxtFax; | |
3965 break; | |
3966 case MFW_TS_ALL_DATA: strServCode = TxtData; break;/* all FAX and SMS services */ | |
3967 case MFW_TS_ALL_XCPT_SMS: strServCode = TxtNotImplemented; | |
3968 TRACE_FUNCTION("all x SMS"); break;/* all FAX and speech services */ | |
3969 case MFW_TS_ALL_PSSS: strServCode = 0; break;/* all PLMN specific TS */ | |
3970 case MFW_TS_PLMN1: /* PLMN specific TS 1 */ | |
3971 case MFW_TS_PLMN2: /* PLMN specific TS 2 */ | |
3972 case MFW_TS_PLMN3: /* PLMN specific TS 3 */ | |
3973 case MFW_TS_PLMN4: /* PLMN specific TS 4 */ | |
3974 case MFW_TS_PLMN5: /* PLMN specific TS 5 */ | |
3975 case MFW_TS_PLMN6: /* PLMN specific TS 6 */ | |
3976 case MFW_TS_PLMN7: /* PLMN specific TS 7 */ | |
3977 case MFW_TS_PLMN8: /* PLMN specific TS 8 */ | |
3978 case MFW_TS_PLMN9: /* PLMN specific TS 9 */ | |
3979 case MFW_TS_PLMNA: /* PLMN specific TS A */ | |
3980 case MFW_TS_PLMNB: /* PLMN specific TS B */ | |
3981 case MFW_TS_PLMNC: /* PLMN specific TS C */ | |
3982 case MFW_TS_PLMND: /* PLMN specific TS D */ | |
3983 case MFW_TS_PLMNE: /* PLMN specific TS E */ | |
3984 case MFW_TS_PLMNF: /* PLMN specific TS F */ | |
3985 strServCode = 0; | |
3986 break; | |
3987 | |
3988 default: break; | |
3989 | |
3990 } | |
3991 break; | |
3992 | |
3993 /* NOTE that we are returning "Data" for all Bearer services until otherwise spec'ed */ | |
3994 case MFW_BST_BEARER: | |
3995 switch ( ss_telecom_service ) | |
3996 { | |
3997 case MFW_BS_ALL_BS : strServCode = TxtNotImplemented; /* strServCode = TxtAllServices; */ break; /* all bearer services */ | |
3998 case MFW_BS_ALL_DATA_CDA : /* all data CDA services */ | |
3999 case MFW_BS_CDA_300 : /* data CDA 300 bps */ | |
4000 case MFW_BS_CDA_1200 : /* data CDA 1200 bps */ | |
4001 case MFW_BS_CDA_1200_75 : /* data CDA 1200/75 bps */ | |
4002 case MFW_BS_CDA_2400 : /* data CDA 2400 bps */ | |
4003 case MFW_BS_CDA_4800 : /* data CDA 4800 bps */ | |
4004 case MFW_BS_CDA_9600 : /* data CDA 9600 bps */ | |
4005 case MFW_BS_ALL_DATA_CDS : /* all data CDS services */ | |
4006 case MFW_BS_CDS_1200 : /* data CDS 1200 bps */ | |
4007 case MFW_BS_CDS_2400 : /* data CDS 2400 bps */ | |
4008 case MFW_BS_CDS_4800 : /* data CDS 4800 bps */ | |
4009 case MFW_BS_CDS_9600 : /* data CDS 9600 bps */ | |
4010 case MFW_BS_ALL_DATA_PAD : /* all data PAD services */ | |
4011 case MFW_BS_PAD_300 : /* data PAD 300 bps */ | |
4012 case MFW_BS_PAD_1200 : /* data PAD 1200 bps */ | |
4013 case MFW_BS_PAD_1200_75 : /* data PAD 1200/75 bps */ | |
4014 case MFW_BS_PAD_2400 : /* data PAD 2400 bps */ | |
4015 case MFW_BS_PAD_4800 : /* data PAD 4800 bps */ | |
4016 case MFW_BS_PAD_9600 : /* data PAD 9600 bps */ | |
4017 case MFW_BS_ALL_DATA_PDS : /* all data PDS services */ | |
4018 case MFW_BS_PDS_2400 : /* data PDS 2400 bps */ | |
4019 case MFW_BS_PDS_4800 : /* data PDS 4800 bps */ | |
4020 case MFW_BS_PDS_9600 : /* data PDS 9600 bps */ | |
4021 case MFW_BS_SPCH_ALT_CDA : /* all data CDA alter. speech */ | |
4022 case MFW_BS_SPCH_ALT_CDS : /* all data CDS alter. speech */ | |
4023 case MFW_BS_SPCH_FLD_CDA : /* all data speech followed CDA */ | |
4024 case MFW_BS_SPCH_FLD_CDS : /* all data speech followed CDA */ | |
4025 case MFW_BS_ALL_DC_ASYN : /* all data circuit asynchronous */ | |
4026 case MFW_BS_ALL_ASYN : /* all asynchronous services */ | |
4027 case MFW_BS_ALL_DC_SYN : /* all data circuit synchronous */ | |
4028 case MFW_BS_ALL_SYN : /* all synchronous services */ | |
4029 case MFW_BS_ALL_PSSS : /* all PLMN specific BS */ | |
4030 case MFW_BS_PLMN1 : /* PLMN specific 1 */ | |
4031 case MFW_BS_PLMN2 : /* PLMN specific 2 */ | |
4032 case MFW_BS_PLMN3 : /* PLMN specific 3 */ | |
4033 case MFW_BS_PLMN4 : /* PLMN specific 4 */ | |
4034 case MFW_BS_PLMN5 : /* PLMN specific 5 */ | |
4035 case MFW_BS_PLMN6 : /* PLMN specific 6 */ | |
4036 case MFW_BS_PLMN7 : /* PLMN specific 7 */ | |
4037 case MFW_BS_PLMN8 : /* PLMN specific 8 */ | |
4038 case MFW_BS_PLMN9 : /* PLMN specific 9 */ | |
4039 case MFW_BS_PLMNA : /* PLMN specific A */ | |
4040 case MFW_BS_PLMNB : /* PLMN specific B */ | |
4041 case MFW_BS_PLMNC : /* PLMN specific C */ | |
4042 case MFW_BS_PLMND : /* PLMN specific D */ | |
4043 case MFW_BS_PLMNE : /* PLMN specific E */ | |
4044 case MFW_BS_PLMNF : /* PLMN specific F */ | |
4045 strServCode = 0; break; | |
4046 | |
4047 default: break; | |
4048 | |
4049 } | |
4050 break; | |
4051 | |
4052 default: | |
4053 break; | |
4054 } | |
4055 return strServCode; | |
4056 } | |
4057 | |
4058 | |
4059 /******************************************************************************* | |
4060 | |
4061 $Function: serviceGetError | |
4062 | |
4063 $Description: | |
4064 | |
4065 $Returns: | |
4066 | |
4067 $Arguments: | |
4068 | |
4069 *******************************************************************************/ | |
4070 | |
4071 | |
4072 | |
4073 static unsigned int serviceGetError( T_MFW_SS_ERROR ss_error ) | |
4074 { | |
4075 unsigned int errStrCode = TxtNotAvailable; | |
4076 TRACE_FUNCTION("serviceGetError"); | |
4077 | |
4078 switch (ss_error) | |
4079 { | |
4080 case MFW_SS_ERR_UNKNOWN: | |
4081 errStrCode=TxtErrUnknown; | |
4082 break; | |
4083 case MFW_SS_ERROR: | |
4084 errStrCode=TxtSSErr; | |
4085 break; | |
4086 case MFW_SS_ERR_UNKNOWN_SUBSCRIBER: | |
4087 errStrCode=TxtUnknownSub; | |
4088 break; | |
4089 case MFW_SS_ERR_ILLEGAL_SUBSCRIBER: | |
4090 errStrCode=TxtIllSub; | |
4091 break; | |
4092 case MFW_SS_ERR_BEARER_SVC_NOT_PROV: | |
4093 case MFW_SS_ERR_TELE_SVC_NOT_PROV: | |
4094 errStrCode = TxtNotSubscribed; | |
4095 break; | |
4096 case MFW_SS_ERR_ILLEGAL_EQUIPMENT: | |
4097 errStrCode = TxtIllEqip; | |
4098 break; | |
4099 case MFW_SS_ERR_CALL_BARRED: | |
4100 errStrCode = TxtBarred; | |
4101 break; | |
4102 case MFW_SS_ERR_ILLEGAL_SS_OPERATION: | |
4103 errStrCode = TxtIllOp; | |
4104 break; | |
4105 case MFW_SS_ERR_SS_ERR_STATUS: | |
4106 errStrCode = TxtCheckStatus; | |
4107 break; | |
4108 case MFW_SS_ERR_SS_NOT_AVAIL: | |
4109 errStrCode = TxtNotAvailable; | |
4110 break; | |
4111 case MFW_SS_ERR_SS_SUBS_VIOLATION: | |
4112 errStrCode = TxtSubVil; | |
4113 break; | |
4114 case MFW_SS_ERR_SS_INCOMP: | |
4115 errStrCode = TxtInComp; | |
4116 break; | |
4117 case MFW_SS_ERR_FAC_NOT_SUPPORTED: | |
4118 errStrCode = TxtFacNoSup; | |
4119 break; | |
4120 case MFW_SS_ERR_ABSENT_SUBS: | |
4121 errStrCode = TxtAbsSub; | |
4122 break; | |
4123 case MFW_SS_ERR_SYSTEM_FAIL: | |
4124 errStrCode = TxtSysFail; | |
4125 break; | |
4126 case MFW_SS_ERR_DATA_MISSING: | |
4127 errStrCode = TxtMissDta; | |
4128 break; | |
4129 case MFW_SS_ERR_UNEXPECT_DATA: | |
4130 case MFW_SS_ERR_PROB_UNEXP_ERR: | |
4131 case MFW_SS_RES_PROB_RET_RES_UNEXP: | |
4132 case MFW_SS_ERR_PROB_RET_ERR_UNEXP: | |
4133 case MFW_SS_INV_PROB_LNK_RES_UNEXP: | |
4134 case MFW_SS_INV_PROB_UNEXP_LNK_OP: | |
4135 errStrCode = TxtUnexDta; | |
4136 break; | |
4137 case MFW_SS_ERR_PWD_REG_FAIL: | |
4138 errStrCode = TxtPwdErr; | |
4139 break; | |
4140 case MFW_SS_ERR_NEG_PWD_CHECK: | |
4141 errStrCode = TxtCodeInc; | |
4142 break; | |
4143 case MFW_SS_ERR_NUM_PWD_VIOLATION: | |
4144 errStrCode = TxtBlckPerm; | |
4145 break; | |
4146 case MFW_SS_ERR_UNKNOWN_ALPHA: | |
4147 errStrCode = TxtUnkAlph; | |
4148 break; | |
4149 case MFW_SS_ERR_USSD_BUSY: | |
4150 errStrCode = TxtNetworkBusy; | |
4151 break; | |
4152 case MFW_SS_ERR_MAX_NUM_MPTY_EXCEED: | |
4153 errStrCode = TxtMaxMpty; | |
4154 break; | |
4155 case MFW_SS_ERR_RESOURCE_NOT_AVAIL: | |
4156 errStrCode = TxtOperationNotAvail; | |
4157 break; | |
4158 case MFW_SS_RES_PROB_UNRECOG_INV_ID: | |
4159 case MFW_SS_INV_PROB_UNRECOG_LNK_ID: | |
4160 case MFW_SS_ERR_PROB_UNRECOG_INV_ID: | |
4161 case MFW_SS_GEN_PROB_UNRECOG_CMP: | |
4162 case MFW_SS_INV_PROB_UNRECOG_OP: | |
4163 case MFW_SS_ERR_PROB_UNRECOG_ERR: | |
4164 errStrCode = TxtUnRec; | |
4165 break; | |
4166 case MFW_SS_RES_PROB_MISTYPED_PAR: | |
4167 case MFW_SS_GEN_PROB_MISTYPED_CMP: | |
4168 case MFW_SS_INV_PROB_MISTYPED_PAR: | |
4169 case MFW_SS_ERR_PROB_MISTYPED_PAR: | |
4170 errStrCode = TxtMisTyp; | |
4171 break; | |
4172 case MFW_SS_GEN_PROB_BAD_STRUCT_CMP: | |
4173 errStrCode = TxtBadStruct; | |
4174 break; | |
4175 case MFW_SS_INV_PROB_DUPL_INV_ID: | |
4176 errStrCode = TxtDupInv; | |
4177 break; | |
4178 case MFW_SS_INV_PROB_RESOURCE_LIM: | |
4179 errStrCode = TxtResLim; | |
4180 break; | |
4181 case MFW_SS_INV_PROB_INIT_RELEASE: | |
4182 errStrCode = TxtIniRel; | |
4183 break; | |
4184 case MFW_SS_ERR_FATAL_INV_RESULT: | |
4185 case MFW_SS_ERR_FATAL_CCD_DEC: | |
4186 case MFW_SS_ERR_FATAL_SS_ENT: | |
4187 errStrCode = TxtFatRes; | |
4188 break; | |
4189 default: | |
4190 break; | |
4191 } | |
4192 return errStrCode; | |
4193 } | |
4194 | |
4195 /******************************************************************************* | |
4196 | |
4197 $Function: serviceGetType | |
4198 | |
4199 $Description: Return code of text string that indicates the SS Type | |
4200 CW, CF, CFU, etc | |
4201 | |
4202 $Returns: | |
4203 | |
4204 $Arguments: | |
4205 | |
4206 *******************************************************************************/ | |
4207 | |
4208 | |
4209 unsigned int serviceGetType( T_MFW_SS_CODES type ) | |
4210 { | |
4211 unsigned int strTypeCode = 0; | |
4212 | |
4213 TRACE_FUNCTION("++ serviceGetType"); | |
4214 | |
4215 switch (type) | |
4216 { | |
4217 case SS_CODES_UNKNOWN: | |
4218 /* Marcus: Issue 1652: 03/02/2003: Start */ | |
4219 TRACE_EVENT("SS_CODES_UNKNOWN"); | |
4220 strTypeCode = TxtUnknown; | |
4221 /* Marcus: Issue 1652: 03/02/2003: End */ | |
4222 break; | |
4223 | |
4224 case SS_CF_ALL: | |
4225 strTypeCode = TxtAllDivert; | |
4226 break; | |
4227 | |
4228 case SS_CF_ALL_COND: | |
4229 strTypeCode = TxtCondDivert; | |
4230 break; | |
4231 | |
4232 case SS_CF_CFU: | |
4233 strTypeCode = TxtAllCallsDivert; | |
4234 break; | |
4235 | |
4236 case SS_CF_CFNRy: | |
4237 strTypeCode = TxtNoAnsDivert ; | |
4238 break; | |
4239 | |
4240 case SS_CF_CFNR: | |
4241 strTypeCode = TxtNoReachDivert; | |
4242 break; | |
4243 | |
4244 case SS_CF_CFB: | |
4245 strTypeCode = TxtBusyDivert; | |
4246 break; | |
4247 | |
4248 case SS_CB_BAOC: | |
4249 strTypeCode = TxtCallBAOC; | |
4250 break; | |
4251 case SS_CB_BAOIC: | |
4252 strTypeCode = TxtCallBAOIC; | |
4253 break; | |
4254 case SS_CB_BAOICexH: | |
4255 strTypeCode = TxtCallBAOICexH; | |
4256 break; | |
4257 case SS_CB_BAIC: | |
4258 strTypeCode = TxtCallBAIC; | |
4259 break; | |
4260 case SS_CB_BAICroam: | |
4261 strTypeCode = TxtCallBAICroam; | |
4262 break; | |
4263 case SS_CB_ALL: | |
4264 strTypeCode = TxtCallBarringAll; | |
4265 break; | |
4266 case SS_CB_ALL_BAOC: | |
4267 strTypeCode = TxtCallBAOCAll; | |
4268 break; | |
4269 case SS_CB_ALL_BAIC: | |
4270 strTypeCode = TxtCallBAICAll; | |
4271 break; | |
4272 | |
4273 case SS_CW: | |
4274 strTypeCode = TxtCallWaiting; | |
4275 break; | |
4276 | |
4277 case SS_CCBS: | |
4278 break; | |
4279 | |
4280 case SS_CLIP: | |
4281 strTypeCode = TxtCLIP; | |
4282 break; | |
4283 case SS_CLIR: | |
4284 strTypeCode = TxtSendID; | |
4285 break; | |
4286 | |
4287 case SS_COLP: | |
4288 strTypeCode = TxtCOLP; | |
4289 break; | |
4290 case SS_COLR: | |
4291 strTypeCode = TxtCOLR; | |
4292 break; | |
4293 | |
4294 case SS_PIN1: | |
4295 case SS_PIN2: | |
4296 break; | |
4297 | |
4298 default: | |
4299 break; | |
4300 } | |
4301 return strTypeCode; | |
4302 } | |
4303 | |
4304 | |
4305 /******************************************************************************* | |
4306 | |
4307 $Function: serviceGetCategory | |
4308 | |
4309 $Description: return the code for the MMI text string for the service category. | |
4310 | |
4311 $Returns: | |
4312 | |
4313 $Arguments: | |
4314 | |
4315 *******************************************************************************/ | |
4316 | |
4317 unsigned int serviceGetCategory( T_MFW_SS_CATEGORY cat ) | |
4318 { | |
4319 unsigned int strCatCode = 0; | |
4320 | |
4321 TRACE_FUNCTION("++ serviceGetCategory"); | |
4322 | |
4323 switch ( cat ) | |
4324 { | |
4325 case SS_CTG_UNKNOWN: | |
4326 break; | |
4327 | |
4328 case SS_REGISTRATION: | |
4329 case SS_ACTIVATION: | |
4330 strCatCode = TxtActivated; | |
4331 break; | |
4332 | |
4333 case SS_ERASURE: | |
4334 case SS_DEACTIVATION: | |
4335 strCatCode = TxtDeActivated; | |
4336 break; | |
4337 | |
4338 case SS_INTERROGATION: | |
4339 TRACE_FUNCTION("SS Interrogation"); | |
4340 break; | |
4341 | |
4342 default: | |
4343 break; | |
4344 } | |
4345 return strCatCode; | |
4346 } | |
4347 | |
4348 | |
4349 /******************************************************************************* | |
4350 | |
4351 $Function: servicesDivertActivate | |
4352 | |
4353 $Description: | |
4354 | |
4355 $Returns: | |
4356 | |
4357 $Arguments: | |
4358 | |
4359 *******************************************************************************/ | |
4360 | |
4361 | |
4362 | |
4363 void servicesDivertActivate(void) | |
4364 { | |
4365 TRACE_FUNCTION("servicesDivertActivate"); | |
4366 CFAction = CFActivate; | |
4367 } | |
4368 | |
4369 /******************************************************************************* | |
4370 | |
4371 $Function: servicesDivertCheck | |
4372 | |
4373 $Description: | |
4374 | |
4375 $Returns: | |
4376 | |
4377 $Arguments: | |
4378 | |
4379 $History: | |
4380 | |
4381 //SPR#0776 - DS -Now takes service type into account by calling getCFServiceCheck. | |
4382 | |
4383 *******************************************************************************/ | |
4384 | |
4385 | |
4386 void servicesDivertCheck(void) | |
4387 { | |
4388 char SS_string[60] = {'\0'}; | |
4389 /* | |
4390 * Interrogate Call Divert | |
4391 */ | |
4392 TRACE_FUNCTION("servicesDivertCheck"); | |
4393 | |
4394 CFAction = CFCheck; | |
4395 | |
4396 getCFAction(SS_string); | |
4397 getCFType(SS_string); | |
4398 getCFService(SS_string); //SPR#929 - DS - Changed from getCFServiceCheck. | |
4399 strcat(SS_string, "#"); | |
4400 | |
4401 TRACE_FUNCTION(SS_string); | |
4402 | |
4403 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
4404 showFailed( ss_data.win ); | |
4405 | |
4406 } | |
4407 | |
4408 /******************************************************************************* | |
4409 | |
4410 $Function: servicesDivertDeactivate | |
4411 | |
4412 $Description: | |
4413 | |
4414 $Returns: | |
4415 | |
4416 $Arguments: | |
4417 | |
4418 $History | |
4419 | |
4420 //SPR#0776 - DS -Now takes service type into account by calling getCFServiceCheck. | |
4421 | |
4422 *******************************************************************************/ | |
4423 | |
4424 | |
4425 | |
4426 void servicesDivertDeactivate(void) | |
4427 { | |
4428 char SS_string[60] = {'\0'}; | |
4429 /* | |
4430 * Deactivate Call Divert | |
4431 */ | |
4432 TRACE_FUNCTION("servicesDivertDeactivate"); | |
4433 | |
4434 CFAction = CFDeactivate; | |
4435 | |
4436 getCFAction(SS_string); | |
4437 getCFType(SS_string); | |
4438 getCFService(SS_string); //SPR#929 - DS - Changed from getCFServiceCheck. | |
4439 SS_string[strlen(SS_string)] = '#'; | |
4440 | |
4441 TRACE_FUNCTION(SS_string); | |
4442 if (CFAction == CFDeactivate && CFType == CFUnconditional || CFType == CFAllCalls) | |
4443 switch (CFService) | |
4444 { | |
4445 case (CFVoice): | |
4446 /*MC SPR 742, handle line 2, auxiliary telephony*/ | |
4447 case CFAuxVoice: | |
4448 | |
4449 if (GetAlsLine() == MFW_SERV_LINE1) | |
4450 cphs_set_divert_status(MFW_CFLAG_NOTSet,0,0,0); | |
4451 else | |
4452 cphs_set_divert_status(0,MFW_CFLAG_NOTSet,0,0); | |
4453 break; | |
4454 case (CFData): cphs_set_divert_status(0,0,0,MFW_CFLAG_NOTSet);break; | |
4455 case (CFFax): cphs_set_divert_status(0,0,MFW_CFLAG_NOTSet,0);break; | |
4456 case (CFAll): | |
4457 if (GetAlsLine() == MFW_SERV_LINE1) | |
4458 cphs_set_divert_status(MFW_CFLAG_NOTSet,0,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet); | |
4459 else | |
4460 cphs_set_divert_status(0,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet,MFW_CFLAG_NOTSet); | |
4461 break; | |
4462 } | |
4463 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
4464 showFailed( ss_data.win ); | |
4465 | |
4466 } | |
4467 | |
4468 /******************************************************************************* | |
4469 | |
4470 $Function: servicesDivertVoice | |
4471 | |
4472 $Description: | |
4473 | |
4474 $Returns: | |
4475 | |
4476 $Arguments: | |
4477 | |
4478 *******************************************************************************/ | |
4479 | |
4480 | |
4481 | |
4482 void servicesDivertVoice(void) | |
4483 { | |
4484 TRACE_FUNCTION("servicesDivertVoice"); | |
4485 /*mc SPR 742 check if line2 is the current line*/ | |
4486 if (!ALSPresent(NULL, NULL, NULL) && GetAlsLine() == MFW_SERV_LINE2/*FFS_flashData.als_selLine == MFW_SERV_LINE2*/) | |
4487 CFService = CFAuxVoice; | |
4488 else /*mc end*/ | |
4489 CFService = CFVoice; | |
4490 } | |
4491 | |
4492 /******************************************************************************* | |
4493 | |
4494 $Function: servicesDivertFax | |
4495 | |
4496 $Description: | |
4497 | |
4498 $Returns: | |
4499 | |
4500 $Arguments: | |
4501 | |
4502 *******************************************************************************/ | |
4503 | |
4504 | |
4505 | |
4506 void servicesDivertFax(void) | |
4507 { | |
4508 TRACE_FUNCTION("servicesDivertFax"); | |
4509 CFService = CFFax; | |
4510 } | |
4511 | |
4512 | |
4513 /******************************************************************************* | |
4514 | |
4515 $Function: servicesDivertData | |
4516 | |
4517 $Description: | |
4518 | |
4519 $Returns: | |
4520 | |
4521 $Arguments: | |
4522 | |
4523 *******************************************************************************/ | |
4524 | |
4525 | |
4526 void servicesDivertData(void) | |
4527 { | |
4528 TRACE_FUNCTION("servicesDivertData"); | |
4529 CFService = CFData; | |
4530 } | |
4531 | |
4532 /******************************************************************************* | |
4533 | |
4534 $Function: servicesDivertActionAll | |
4535 | |
4536 $Description: | |
4537 | |
4538 $Returns: | |
4539 | |
4540 $Arguments: | |
4541 | |
4542 *******************************************************************************/ | |
4543 | |
4544 | |
4545 | |
4546 void servicesDivertActionAll(void) | |
4547 { | |
4548 TRACE_FUNCTION("servicesDivertActionAll"); | |
4549 CFService = CFAll; | |
4550 } | |
4551 | |
4552 | |
4553 /******************************************************************************* | |
4554 | |
4555 $Function: servicesDivertBusy | |
4556 | |
4557 $Description: | |
4558 | |
4559 $Returns: | |
4560 | |
4561 $Arguments: | |
4562 | |
4563 *******************************************************************************/ | |
4564 | |
4565 | |
4566 void servicesDivertBusy(void) | |
4567 { | |
4568 TRACE_FUNCTION("servicesDivertBusy"); | |
4569 CFType = CFBusy; | |
4570 } | |
4571 | |
4572 /******************************************************************************* | |
4573 | |
4574 $Function: servicesDivertNoAnswer | |
4575 | |
4576 $Description: | |
4577 | |
4578 $Returns: | |
4579 | |
4580 $Arguments: | |
4581 | |
4582 *******************************************************************************/ | |
4583 | |
4584 | |
4585 void servicesDivertNoAnswer(void) | |
4586 { | |
4587 TRACE_FUNCTION("servicesDivertNoAnswer"); | |
4588 CFType = CFNoReply; | |
4589 } | |
4590 | |
4591 /******************************************************************************* | |
4592 | |
4593 $Function: servicesDivertNotReachable | |
4594 | |
4595 $Description: | |
4596 | |
4597 $Returns: | |
4598 | |
4599 $Arguments: | |
4600 | |
4601 *******************************************************************************/ | |
4602 | |
4603 | |
4604 void servicesDivertNotReachable(void) | |
4605 { | |
4606 TRACE_FUNCTION("servicesDivertNotReachable"); | |
4607 CFType = CFAllConditional; | |
4608 } | |
4609 | |
4610 /******************************************************************************* | |
4611 | |
4612 $Function: servicesDivertNoService | |
4613 | |
4614 $Description: | |
4615 | |
4616 $Returns: | |
4617 | |
4618 $Arguments: | |
4619 | |
4620 *******************************************************************************/ | |
4621 | |
4622 | |
4623 void servicesDivertNoService(void) | |
4624 { | |
4625 TRACE_FUNCTION("servicesDivertNoService"); | |
4626 CFType = CFNoReach; | |
4627 } | |
4628 | |
4629 | |
4630 /******************************************************************************* | |
4631 | |
4632 $Function: servicesDivertAllCalls | |
4633 | |
4634 $Description: | |
4635 | |
4636 $Returns: | |
4637 | |
4638 $Arguments: | |
4639 | |
4640 *******************************************************************************/ | |
4641 | |
4642 | |
4643 void servicesDivertAllCalls(void) | |
4644 { | |
4645 TRACE_FUNCTION("servicesDivertAllCalls"); | |
4646 CFType = CFUnconditional; | |
4647 } | |
4648 | |
4649 /******************************************************************************* | |
4650 | |
4651 $Function: servicesDivertCancelAll | |
4652 | |
4653 $Description: | |
4654 | |
4655 $Returns: | |
4656 | |
4657 $Arguments: | |
4658 | |
4659 *******************************************************************************/ | |
4660 | |
4661 | |
4662 void servicesDivertCancelAll(void) | |
4663 { | |
4664 TRACE_FUNCTION("servicesDivertCancelAll"); | |
4665 CFType = CFAllCalls; | |
4666 CFAction = CFDeactivate; | |
4667 CFService = CFAll; | |
4668 servicesSendCallDivert(0); | |
4669 } | |
4670 | |
4671 /******************************************************************************* | |
4672 | |
4673 $Function: servicesBarringAllOutgoing | |
4674 | |
4675 $Description: | |
4676 | |
4677 $Returns: | |
4678 | |
4679 $Arguments: | |
4680 | |
4681 *******************************************************************************/ | |
4682 | |
4683 | |
4684 void servicesBarringAllOutgoing(void) | |
4685 { | |
4686 TRACE_FUNCTION("servicesBarringAllOutgoing"); | |
4687 CBType = CBAllOutgoing; | |
4688 } | |
4689 | |
4690 /******************************************************************************* | |
4691 | |
4692 $Function: servicesBarringInternational | |
4693 | |
4694 $Description: | |
4695 | |
4696 $Returns: | |
4697 | |
4698 $Arguments: | |
4699 | |
4700 *******************************************************************************/ | |
4701 | |
4702 | |
4703 | |
4704 void servicesBarringInternational(void) | |
4705 { | |
4706 TRACE_FUNCTION("servicesBarringInternational"); | |
4707 CBType = CBInternational; | |
4708 } | |
4709 | |
4710 /******************************************************************************* | |
4711 | |
4712 $Function: servicesBarringInternationalHome | |
4713 | |
4714 $Description: | |
4715 | |
4716 $Returns: | |
4717 | |
4718 $Arguments: | |
4719 | |
4720 *******************************************************************************/ | |
4721 | |
4722 | |
4723 void servicesBarringInternationalHome(void) | |
4724 { | |
4725 TRACE_FUNCTION("servicesBarringInternationalHome"); | |
4726 CBType = CBInternationalHome; | |
4727 } | |
4728 | |
4729 | |
4730 /******************************************************************************* | |
4731 | |
4732 $Function: servicesBarringAllIncoming | |
4733 | |
4734 $Description: | |
4735 | |
4736 $Returns: | |
4737 | |
4738 $Arguments: | |
4739 | |
4740 *******************************************************************************/ | |
4741 | |
4742 | |
4743 | |
4744 void servicesBarringAllIncoming(void) | |
4745 { | |
4746 TRACE_FUNCTION("servicesBarringAllIncoming"); | |
4747 CBType = CBAllIncoming; | |
4748 } | |
4749 | |
4750 /******************************************************************************* | |
4751 | |
4752 $Function: servicesBarringIncomingRoaming | |
4753 | |
4754 $Description: | |
4755 | |
4756 $Returns: | |
4757 | |
4758 $Arguments: | |
4759 | |
4760 *******************************************************************************/ | |
4761 | |
4762 | |
4763 void servicesBarringIncomingRoaming(void) | |
4764 { | |
4765 TRACE_FUNCTION("servicesBarringIncomingRoaming"); | |
4766 CBType = CBIncomingRoaming; | |
4767 } | |
4768 | |
4769 | |
4770 /******************************************************************************* | |
4771 | |
4772 $Function: services_get_voice_number_cb | |
4773 | |
4774 $Description: callback function for the enter voicemail number window | |
4775 | |
4776 $Returns: | |
4777 | |
4778 $Arguments: | |
4779 | |
4780 *******************************************************************************/ | |
4781 | |
4782 | |
4783 #ifdef NEW_EDITOR | |
4784 static void services_get_voice_number_cb(T_MFW_HND win, USHORT identifier, SHORT reason) | |
4785 { | |
4786 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
4787 T_services_input * data = (T_services_input *)win_data->user; | |
4788 | |
4789 TRACE_FUNCTION("services_get_voice_number_cb"); | |
4790 | |
4791 switch (reason) | |
4792 { | |
4793 case INFO_KCD_LEFT: | |
4794 TRACE_FUNCTION("SERVICES_INPUT_LEFT"); | |
4795 services_input_destroy(ss_data.input_number_win); | |
4796 /* send number if one has been entered */ | |
4797 if (strlen(ss_data.edt_buf_number) > 0 ) | |
4798 SEND_EVENT(data->parent_win, SERVICES_DO_CALL_VOICE_DIVERT, 0, 0); | |
4799 break; | |
4800 | |
4801 case INFO_KCD_ALTERNATELEFT: | |
4802 TRACE_FUNCTION("SERVICES_INPUT_ALTERNATELEFT"); | |
4803 /* Go to phone book */ | |
4804 if (bookPhoneBookLoading()==BOOK_SUCCESS) | |
4805 { | |
4806 // T_MFW_HND phbk_win; // RAVI | |
4807 bookPhonebookStart(win,PhbkFromDivert); // RAVI - Removed Assignment phbk_win = . | |
4808 } | |
4809 | |
4810 break; | |
4811 | |
4812 case INFO_KCD_HUP: | |
4813 case INFO_KCD_RIGHT: | |
4814 TRACE_FUNCTION("SERVICES_INPUT_RIGHT/HUP"); | |
4815 services_input_destroy(ss_data.input_number_win); | |
4816 break; | |
4817 default: | |
4818 break; | |
4819 } | |
4820 } | |
4821 | |
4822 #else /* NEW_EDITOR */ | |
4823 static void services_get_voice_number_cb(T_MFW_HND win, USHORT reason) | |
4824 { | |
4825 TRACE_FUNCTION("services_get_voice_number_cb"); | |
4826 | |
4827 switch (reason){ | |
4828 case SERVICES_INPUT_LEFT: | |
4829 TRACE_FUNCTION("SERVICES_INPUT_LEFT"); | |
4830 /* send number if one has been entered */ | |
4831 if (strlen(ss_data.edt_buf_number) > 0 ) | |
4832 SEND_EVENT(win, SERVICES_DO_CALL_VOICE_DIVERT, 0, 0); | |
4833 break; | |
4834 default: | |
4835 break; | |
4836 } | |
4837 } | |
4838 #endif /* NEW_EDITOR */ | |
4839 | |
4840 | |
4841 /******************************************************************************* | |
4842 | |
4843 $Function: servicesDoVoiceMailNumber | |
4844 | |
4845 $Description: this function should access voicemail number if it is already | |
4846 entered, otherwise allow access to voicemail editing window | |
4847 | |
4848 $Returns: | |
4849 | |
4850 $Arguments: | |
4851 | |
4852 *******************************************************************************/ | |
4853 | |
4854 | |
4855 | |
4856 | |
4857 void servicesDoVoiceMailNumber(void) | |
4858 { | |
4859 char voiceNum[30] = {'\0'}; | |
4860 | |
4861 TRACE_FUNCTION("servicesDoVoiceMailNumber"); | |
4862 | |
4863 //JVJEmsgsGetVoiceAddress(voiceNum); | |
4864 | |
4865 /* instead of the above we should use something like: */ | |
4866 if ( strlen(voiceNum) > 0) | |
4867 { | |
4868 servicesSendCallDivert(voiceNum); | |
4869 } | |
4870 else | |
4871 { | |
4872 T_ss * data = &ss_data; | |
4873 T_input_properties input; | |
4874 | |
4875 memset(data->edt_buf_number,'\0',PHB_MAX_LEN); | |
4876 input.abc = FALSE; | |
4877 input.text = TxtEnterNumber; | |
4878 /* SPR#1428 - SH - New Editor changes - no longer required */ | |
4879 #ifndef NEW_EDITOR | |
4880 input.edt_attr_input = &data->edt_attr_number; | |
4881 #endif /* ifndef NEW_EDITOR */ | |
4882 input.left_soft_key = TxtSoftOK; | |
4883 input.right_soft_key = TxtSoftBack; | |
4884 input.callback = services_get_voice_number_cb; | |
4885 data->input_number_win = services_input_start(data->win,&input); | |
4886 | |
4887 } | |
4888 | |
4889 } | |
4890 | |
4891 | |
4892 /******************************************************************************* | |
4893 | |
4894 $Function: services_get_number_cb | |
4895 | |
4896 $Description: callback function for the enter other number window | |
4897 | |
4898 $Returns: | |
4899 | |
4900 $Arguments: | |
4901 | |
4902 *******************************************************************************/ | |
4903 | |
4904 #ifdef NEW_EDITOR | |
4905 static void services_get_number_cb(T_MFW_HND win, USHORT identifier, SHORT reason) | |
4906 { | |
4907 // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI | |
4908 // T_services_input * data = (T_services_input *)win_data->user; // RAVI | |
4909 | |
4910 TRACE_FUNCTION("services_get_voice_number_cb"); | |
4911 | |
4912 switch (reason) | |
4913 { | |
4914 case INFO_KCD_LEFT: | |
4915 TRACE_FUNCTION("SERVICES_INPUT_LEFT"); | |
4916 /* send number if one has been entered */ | |
4917 SEND_EVENT(ss_data.win, ServicesDoCallDivert, 0, 0); | |
4918 services_input_destroy(ss_data.input_number_win); | |
4919 ss_data.input_number_win = NULL; | |
4920 break; | |
4921 | |
4922 case INFO_KCD_ALTERNATELEFT: | |
4923 TRACE_FUNCTION("SERVICES_INPUT_ALTERNATELEFT"); | |
4924 /* Go to phone book */ | |
4925 if (bookPhoneBookLoading()==BOOK_SUCCESS) | |
4926 { | |
4927 //T_MFW_HND phbk_win; // RAVI | |
4928 bookPhonebookStart(win,PhbkFromDivert); // RAVI - Removed assignment phbk_win = | |
4929 } | |
4930 | |
4931 break; | |
4932 | |
4933 case INFO_KCD_HUP: | |
4934 case INFO_KCD_RIGHT: | |
4935 TRACE_FUNCTION("SERVICES_INPUT_RIGHT/HUP"); | |
4936 services_input_destroy(ss_data.input_number_win); | |
4937 ss_data.input_number_win = NULL; | |
4938 break; | |
4939 default: | |
4940 break; | |
4941 } | |
4942 } | |
4943 | |
4944 #else /* NEW_EDITOR */ | |
4945 static void services_get_number_cb(T_MFW_HND win,USHORT reason) | |
4946 { | |
4947 TRACE_FUNCTION("services_get_number_cb"); | |
4948 | |
4949 switch (reason){ | |
4950 case SERVICES_INPUT_LEFT: | |
4951 TRACE_FUNCTION("SERVICES_INPUT_LEFT"); | |
4952 SEND_EVENT(win, ServicesDoCallDivert, 0, 0); | |
4953 break; | |
4954 case SERVICES_INPUT_RIGHT: | |
4955 TRACE_FUNCTION("SERVICES_INPUT_RIGHT"); | |
4956 SEND_EVENT(win, ServicesDoCallDivert, 0, 0); | |
4957 break; | |
4958 default: | |
4959 break; | |
4960 } | |
4961 } | |
4962 #endif /* NEW_EDITOR */ | |
4963 | |
4964 /******************************************************************************* | |
4965 | |
4966 $Function: servicesGetOtherNumber | |
4967 | |
4968 $Description: Sets up an editor for entering another number. | |
4969 | |
4970 $Returns: | |
4971 | |
4972 $Arguments: | |
4973 | |
4974 *******************************************************************************/ | |
4975 | |
4976 | |
4977 | |
4978 | |
4979 static void ServicesGetOtherNumber(T_MFW_HND win) | |
4980 { | |
4981 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
4982 T_ss * data = (T_ss *)win_data->user; | |
4983 | |
4984 T_input_properties input; | |
4985 | |
4986 TRACE_EVENT("ServicesGetOtherNumber"); | |
4987 | |
4988 memset(data->edt_buf_number,'\0',PHB_MAX_LEN); | |
4989 input.abc = FALSE; | |
4990 input.text = TxtEnterNumber; | |
4991 /* SPR#1428 - SH - New Editor changes - no longer required */ | |
4992 #ifndef NEW_EDITOR | |
4993 input.edt_attr_input = &data->edt_attr_number; | |
4994 #endif /* ifndef NEW_EDITOR */ | |
4995 input.left_soft_key = TxtSoftOK; | |
4996 //Oct 20, 2004 REF: CRR 25772 Deepa M.D | |
4997 //The RSK name has been set to Delete. | |
4998 input.right_soft_key = TxtDelete; | |
4999 input.callback = services_get_number_cb; | |
5000 data->input_number_win = services_input_start(win,&input); | |
5001 } | |
5002 | |
5003 /******************************************************************************* | |
5004 | |
5005 $Function: servicesDoOtherNumber | |
5006 | |
5007 $Description: | |
5008 | |
5009 $Returns: | |
5010 | |
5011 $Arguments: | |
5012 | |
5013 *******************************************************************************/ | |
5014 | |
5015 | |
5016 void servicesDoOtherNumber(void) | |
5017 { | |
5018 | |
5019 TRACE_FUNCTION("servicesDoOtherNumber"); | |
5020 | |
5021 SEND_EVENT(ss_data.win, ServicesOtherNumber, 0, 0); | |
5022 | |
5023 | |
5024 /* this is function called from menu, it will also send a signal to start | |
5025 window being displayed for editing or calling phonebook */ | |
5026 /* set up and show edit field */ | |
5027 } | |
5028 | |
5029 | |
5030 /******************************************************************************* | |
5031 | |
5032 $Function: servicesStoreVoiceMailNumber | |
5033 | |
5034 $Description: Store number to Voicemail number (currently in SMS, should be in PCM?) | |
5035 | |
5036 $Returns: | |
5037 | |
5038 $Arguments: | |
5039 | |
5040 *******************************************************************************/ | |
5041 | |
5042 static void servicesStoreVoiceMailNumber( void ) | |
5043 { | |
5044 char voiceNum[30] = {'\0'}; | |
5045 TRACE_FUNCTION("servicesStoreVoiceMailNumber"); | |
5046 | |
5047 getCFNumber(voiceNum); | |
5048 | |
5049 } | |
5050 | |
5051 | |
5052 | |
5053 /******************************************************************************* | |
5054 | |
5055 $Function: servicesStoreUSSD | |
5056 | |
5057 $Description: Store selected USSD to NVM. | |
5058 | |
5059 $Returns: | |
5060 | |
5061 $Arguments: | |
5062 | |
5063 *******************************************************************************/ | |
5064 | |
5065 | |
5066 | |
5067 static void servicesStoreUSSD(void) | |
5068 { | |
5069 TRACE_FUNCTION("servicesStoreUSSD"); | |
5070 } | |
5071 | |
5072 /******************************************************************************* | |
5073 | |
5074 $Function: servicesActivateIRDA | |
5075 | |
5076 $Description: | |
5077 | |
5078 $Returns: | |
5079 | |
5080 $Arguments: | |
5081 | |
5082 *******************************************************************************/ | |
5083 | |
5084 | |
5085 int servicesActivateIRDA(MfwMnu* m, MfwMnuItem* i) | |
5086 { | |
5087 // ADDED BY RAVI - 28-11-2005 | |
5088 return 1; | |
5089 // END RAVI - 28-11-2005 | |
5090 } | |
5091 | |
5092 /******************************************************************************* | |
5093 | |
5094 $Function: servicesDeactivateIRDA | |
5095 | |
5096 $Description: | |
5097 | |
5098 $Returns: | |
5099 | |
5100 $Arguments: | |
5101 | |
5102 *******************************************************************************/ | |
5103 | |
5104 | |
5105 int servicesDeactivateIRDA(MfwMnu* m, MfwMnuItem* i) | |
5106 { | |
5107 // ADDED BY RAVI - 28-11-2005 | |
5108 return 1; | |
5109 // END RAVI - 28-11-2005 | |
5110 } | |
5111 | |
5112 | |
5113 static T_MFW_HND dialog_ext_info_create (T_MFW_HND parent_win); | |
5114 static void dialog_ext_info_destroy (T_MFW_HND own_window); | |
5115 void dialog_ext_info (T_MFW_HND win, | |
5116 USHORT event, SHORT value, void * parameter); | |
5117 static int dialog_ext_info_win_cb (T_MFW_EVENT event, T_MFW_WIN * win); | |
5118 static T_MFW_CB dialog_ext_info_tim_cb (T_MFW_EVENT event, T_MFW_TIM * tc); | |
5119 static int dialog_ext_info_kbd_cb (T_MFW_EVENT event, T_MFW_KBD * keyboard); | |
5120 static int dialog_ext_info_kbd_long_cb (T_MFW_EVENT e, T_MFW_KBD *k); | |
5121 | |
5122 | |
5123 /******************************************************************************* | |
5124 | |
5125 $Function: dialog_ext_info_dialog | |
5126 | |
5127 $Description: | |
5128 | |
5129 $Returns: | |
5130 | |
5131 $Arguments: | |
5132 | |
5133 *******************************************************************************/ | |
5134 | |
5135 | |
5136 T_MFW_HND dialog_ext_info_dialog (T_MFW_HND parent_win, | |
5137 T_dialog_ext_info * display_info) | |
5138 { | |
5139 T_MFW_HND win; | |
5140 | |
5141 win = dialog_ext_info_create (parent_win); | |
5142 | |
5143 if (win NEQ NULL) | |
5144 { | |
5145 SEND_EVENT (win, DIALOG_INIT, 0, display_info); | |
5146 } | |
5147 return win; | |
5148 } | |
5149 | |
5150 | |
5151 /******************************************************************************* | |
5152 | |
5153 $Function: dialog_ext_info_create | |
5154 | |
5155 $Description: | |
5156 | |
5157 $Returns: | |
5158 | |
5159 $Arguments: | |
5160 | |
5161 *******************************************************************************/ | |
5162 | |
5163 | |
5164 static T_MFW_HND dialog_ext_info_create (T_MFW_HND parent_win) | |
5165 { | |
5166 T_MFW_WIN * win_data; | |
5167 T_dialog_ext_info * data = (T_dialog_ext_info *)ALLOC_MEMORY (sizeof (T_dialog_ext_info)); | |
5168 | |
5169 TRACE_FUNCTION ("dialog_ext_info_create()"); | |
5170 | |
5171 if (data EQ 0) | |
5172 { | |
5173 TRACE_FUNCTION("NOT ENOUGH RESOURCES FOR DATA"); | |
5174 return 0; | |
5175 } | |
5176 data->info_win = win_create (parent_win, 0, E_WIN_VISIBLE, (T_MFW_CB)dialog_ext_info_win_cb); | |
5177 | |
5178 if (data->info_win EQ 0) | |
5179 { | |
5180 TRACE_FUNCTION("NOT ENOUGH RESOURCES FOR 4 line INFO WIN"); | |
5181 return 0; | |
5182 } | |
5183 | |
5184 /* | |
5185 * Create window handler | |
5186 */ | |
5187 data->mmi_control.dialog = (T_DIALOG_FUNC)dialog_ext_info; | |
5188 data->mmi_control.data = data; | |
5189 data->parent_win = parent_win; | |
5190 win_data = ((T_MFW_HDR *)data->info_win)->data; | |
5191 win_data->user = (void *)data; | |
5192 | |
5193 | |
5194 win_show(data->info_win); | |
5195 /* | |
5196 * return window handle | |
5197 */ | |
5198 return data->info_win; | |
5199 } | |
5200 | |
5201 /******************************************************************************* | |
5202 | |
5203 $Function: dialog_ext_info_destroy | |
5204 | |
5205 $Description: | |
5206 | |
5207 $Returns: | |
5208 | |
5209 $Arguments: | |
5210 | |
5211 *******************************************************************************/ | |
5212 | |
5213 | |
5214 static void dialog_ext_info_destroy (T_MFW_HND own_window) | |
5215 { | |
5216 T_MFW_WIN * win = ((T_MFW_HDR *)own_window)->data; | |
5217 T_dialog_ext_info * data = (T_dialog_ext_info *)win->user; | |
5218 | |
5219 TRACE_FUNCTION ("dialog_ext_info_destroy()"); | |
5220 | |
5221 if (own_window == NULL) | |
5222 { | |
5223 TRACE_EVENT ("Error : Called with NULL Pointer"); | |
5224 return; | |
5225 } | |
5226 | |
5227 if (data) | |
5228 { | |
5229 /* | |
5230 * Exit TIMER & KEYBOARD Handle | |
5231 */ | |
5232 kbd_delete (data->info_kbd); | |
5233 kbd_delete (data->info_kbd_long); | |
5234 tim_delete (data->info_tim); | |
5235 | |
5236 /* | |
5237 * Delete WIN Handler | |
5238 */ | |
5239 win_delete (data->info_win); | |
5240 /* | |
5241 * Free Memory | |
5242 */ | |
5243 FREE_MEMORY ((void *)data, sizeof (T_dialog_ext_info)); | |
5244 } | |
5245 } | |
5246 | |
5247 /******************************************************************************* | |
5248 | |
5249 $Function: dialog_ext_info | |
5250 | |
5251 $Description: | |
5252 | |
5253 $Returns: | |
5254 | |
5255 $Arguments: | |
5256 | |
5257 *******************************************************************************/ | |
5258 | |
5259 void dialog_ext_info (T_MFW_HND win, USHORT event, SHORT value, void * parameter) | |
5260 { | |
5261 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5262 T_dialog_ext_info * data = (T_dialog_ext_info *)win_data->user; | |
5263 T_dialog_ext_info * display_info = (T_dialog_ext_info *)parameter; | |
5264 | |
5265 TRACE_FUNCTION ("dialog_ext_info()"); | |
5266 | |
5267 switch (event) | |
5268 { | |
5269 case DIALOG_INIT: | |
5270 /* | |
5271 * Initialize dialog | |
5272 */ | |
5273 /* | |
5274 * Store any other data | |
5275 */ | |
5276 data->LeftSoftKey = display_info->LeftSoftKey; | |
5277 data->RightSoftKey = display_info->RightSoftKey; | |
5278 data->Time = display_info->Time; | |
5279 data->KeyEvents = display_info->KeyEvents; | |
5280 data->TextId1 = display_info->TextId1; | |
5281 data->TextId2 = display_info->TextId2; | |
5282 data->TextString4 = display_info->TextString4; | |
5283 data->Identifier = display_info->Identifier; | |
5284 data->Callback = display_info->Callback; | |
5285 /* | |
5286 * Create timer and keyboard handler | |
5287 */ | |
5288 data->info_tim = tim_create (win, display_info->Time, (T_MFW_CB)dialog_ext_info_tim_cb); | |
5289 data->info_kbd = kbd_create (win, KEY_ALL, (T_MFW_CB)dialog_ext_info_kbd_cb); | |
5290 data->info_kbd_long = kbd_create (win, KEY_ALL|KEY_LONG, (T_MFW_CB)dialog_ext_info_kbd_long_cb); | |
5291 | |
5292 if (display_info->Time NEQ FOREVER) | |
5293 tim_start (data->info_tim); | |
5294 win_show(win); | |
5295 break; | |
5296 | |
5297 case DIALOG_DESTROY: | |
5298 dialog_ext_info_destroy(win); | |
5299 break; | |
5300 } | |
5301 } | |
5302 | |
5303 /******************************************************************************* | |
5304 | |
5305 $Function: dialog_ext_info_win_cb | |
5306 | |
5307 $Description: | |
5308 | |
5309 $Returns: | |
5310 | |
5311 $Arguments: | |
5312 | |
5313 *******************************************************************************/ | |
5314 | |
5315 | |
5316 | |
5317 static int dialog_ext_info_win_cb (T_MFW_EVENT event, T_MFW_WIN * win) | |
5318 { | |
5319 T_dialog_ext_info * data = (T_dialog_ext_info *)win->user; | |
5320 | |
5321 TRACE_FUNCTION ("dialog_ext_info_win_cb()"); | |
5322 | |
5323 if (data EQ 0) | |
5324 return 1; | |
5325 | |
5326 switch (event) | |
5327 { | |
5328 case E_WIN_VISIBLE: | |
5329 /* | |
5330 * Print the information dialog | |
5331 */ | |
5332 | |
5333 /* | |
5334 * Clear Screen | |
5335 */ | |
5336 dspl_ClearAll(); | |
5337 /* | |
5338 * Print softkeys | |
5339 */ | |
5340 displaySoftKeys(data->LeftSoftKey, data->RightSoftKey); | |
5341 /* | |
5342 * Print information | |
5343 */ | |
5344 if (data->TextId1 NEQ 0) | |
5345 { | |
5346 displayAlignedText(CENTER, Mmi_layout_line(1), 0, GET_TEXT(data->TextId1)); | |
5347 } | |
5348 | |
5349 if (data->TextId2 NEQ 0) | |
5350 { | |
5351 displayAlignedText(CENTER, Mmi_layout_line(2), 0, GET_TEXT(data->TextId2)); | |
5352 } | |
5353 | |
5354 if (data->TextString4) | |
5355 { | |
5356 displayAlignedText(CENTER, Mmi_layout_line(3), 0, data->TextString4); | |
5357 } | |
5358 break; | |
5359 | |
5360 default: | |
5361 return 0; | |
5362 } | |
5363 return 1; | |
5364 } | |
5365 | |
5366 | |
5367 /******************************************************************************* | |
5368 | |
5369 $Function: dialog_ext_info_tim_cb | |
5370 | |
5371 $Description: | |
5372 | |
5373 $Returns: | |
5374 | |
5375 $Arguments: | |
5376 | |
5377 *******************************************************************************/ | |
5378 | |
5379 | |
5380 static T_MFW_CB dialog_ext_info_tim_cb (T_MFW_EVENT event, T_MFW_TIM *tc) | |
5381 { | |
5382 T_MFW_HND win = mfw_parent (mfw_header()); | |
5383 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5384 T_dialog_ext_info * data = (T_dialog_ext_info *)win_data->user; | |
5385 | |
5386 T_MFW_HND parent_win = data->parent_win; | |
5387 USHORT Identifier = data->Identifier; | |
5388 void (* Callback)() = data->Callback; | |
5389 | |
5390 dialog_ext_info_destroy (win); | |
5391 | |
5392 if (Callback) | |
5393 (Callback) (parent_win, Identifier, INFO_TIMEOUT); | |
5394 | |
5395 return 0; | |
5396 } | |
5397 | |
5398 /******************************************************************************* | |
5399 | |
5400 $Function: dialog_ext_info_kbd_cb | |
5401 | |
5402 $Description: | |
5403 | |
5404 $Returns: | |
5405 | |
5406 $Arguments: | |
5407 | |
5408 *******************************************************************************/ | |
5409 | |
5410 static int dialog_ext_info_kbd_cb (T_MFW_EVENT event, T_MFW_KBD *keyboard) | |
5411 { | |
5412 T_MFW_HND win = mfw_parent (mfw_header()); | |
5413 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5414 T_dialog_ext_info * data = (T_dialog_ext_info *)win_data->user; | |
5415 T_MFW_HND parent_win = data->parent_win; | |
5416 USHORT Identifier = data->Identifier; | |
5417 void (* Callback)() = data->Callback; | |
5418 | |
5419 TRACE_FUNCTION("dialog_ext_info_kbd_cb"); | |
5420 | |
5421 switch (keyboard->code) | |
5422 { | |
5423 case KCD_LEFT: | |
5424 if (data->KeyEvents & KEY_LEFT) | |
5425 { | |
5426 dialog_ext_info_destroy (win); | |
5427 if (Callback) | |
5428 (Callback) (parent_win, Identifier, INFO_KCD_LEFT); | |
5429 } | |
5430 break; | |
5431 | |
5432 case KCD_RIGHT: | |
5433 if (data->KeyEvents & KEY_RIGHT) | |
5434 { | |
5435 dialog_ext_info_destroy (win); | |
5436 if (Callback) | |
5437 (Callback) (parent_win, Identifier, INFO_KCD_RIGHT); | |
5438 } | |
5439 break; | |
5440 | |
5441 case KCD_HUP: | |
5442 if (data->KeyEvents & KEY_CLEAR) | |
5443 { | |
5444 dialog_ext_info_destroy (win); | |
5445 if (Callback) | |
5446 (Callback) (parent_win, Identifier, INFO_KCD_HUP); | |
5447 } | |
5448 break; | |
5449 dialog_ext_info_destroy (win); | |
5450 | |
5451 case KCD_MNUUP: | |
5452 dialog_ext_info_destroy (win); | |
5453 if (Callback) | |
5454 (Callback) (parent_win, Identifier, INFO_KCD_UP); | |
5455 break; | |
5456 | |
5457 case KCD_MNUDOWN: | |
5458 dialog_ext_info_destroy (win); | |
5459 if (Callback) | |
5460 (Callback) (parent_win, Identifier, INFO_KCD_DOWN); | |
5461 break; | |
5462 | |
5463 default: | |
5464 return MFW_EVENT_PASSED; | |
5465 } | |
5466 return MFW_EVENT_CONSUMED; | |
5467 } | |
5468 | |
5469 /******************************************************************************* | |
5470 | |
5471 $Function: dialog_ext_info_kbd_long_cb | |
5472 | |
5473 $Description: | |
5474 | |
5475 $Returns: | |
5476 | |
5477 $Arguments: | |
5478 | |
5479 *******************************************************************************/ | |
5480 | |
5481 | |
5482 | |
5483 | |
5484 | |
5485 | |
5486 static int dialog_ext_info_kbd_long_cb (T_MFW_EVENT e, T_MFW_KBD *k) | |
5487 { | |
5488 T_MFW_HND win = mfw_parent (mfw_header()); | |
5489 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5490 T_dialog_ext_info * data = (T_dialog_ext_info *)win_data->user; | |
5491 T_MFW_HND parent_win = data->parent_win; | |
5492 USHORT Identifier = data->Identifier; | |
5493 void (* Callback)() = data->Callback; | |
5494 | |
5495 TRACE_FUNCTION("dialog_ext_info_kbd_long_cb"); | |
5496 | |
5497 switch (k->code) | |
5498 { | |
5499 case KCD_MNUUP: | |
5500 dialog_ext_info_destroy (win); | |
5501 if (Callback) | |
5502 (Callback) (parent_win, Identifier, INFO_KCD_UP); | |
5503 break; | |
5504 | |
5505 case KCD_MNUDOWN: | |
5506 dialog_ext_info_destroy (win); | |
5507 if (Callback) | |
5508 (Callback) (parent_win, Identifier, INFO_KCD_DOWN); | |
5509 break; | |
5510 } | |
5511 /* | |
5512 * Consume all long key presses | |
5513 */ | |
5514 return MFW_EVENT_CONSUMED; | |
5515 | |
5516 } | |
5517 | |
5518 /******************************************************************************* | |
5519 | |
5520 $Function: services_input_create | |
5521 | |
5522 $Description: | |
5523 | |
5524 $Returns: | |
5525 | |
5526 $Arguments: | |
5527 | |
5528 *******************************************************************************/ | |
5529 | |
5530 | |
5531 | |
5532 | |
5533 static T_MFW_HND services_input_create(MfwHnd parent){ | |
5534 | |
5535 | |
5536 T_MFW_WIN * win_data; | |
5537 T_services_input * data = (T_services_input *)ALLOC_MEMORY (sizeof (T_services_input)); | |
5538 | |
5539 | |
5540 | |
5541 TRACE_FUNCTION ("services_input_create()"); | |
5542 | |
5543 data->win = win_create (parent, 0, E_WIN_VISIBLE, (T_MFW_CB)services_input_win_cb); | |
5544 | |
5545 if (data->win EQ 0) | |
5546 return 0; | |
5547 | |
5548 /* | |
5549 * Create window handler | |
5550 */ | |
5551 data->mmi_control.dialog = (T_DIALOG_FUNC)services_input; | |
5552 data->mmi_control.data = data; | |
5553 win_data = ((T_MFW_HDR *)data->win)->data; | |
5554 win_data->user = (void *)data; | |
5555 | |
5556 /* | |
5557 * return window handle | |
5558 */ | |
5559 | |
5560 /* SPR#1428 - SH - New Editor changes - no longer required */ | |
5561 #ifndef NEW_EDITOR | |
5562 data->kbd = kbdCreate(data->win,KEY_ALL,(MfwCb)services_input_kbd_cb); | |
5563 data->kbd_long = kbdCreate(data->win,KEY_ALL|KEY_LONG,(MfwCb)services_input_kbd_long_cb); | |
5564 #endif /* ifndef NEW_EDITOR */ | |
5565 | |
5566 data->parent_win = parent; | |
5567 | |
5568 return data->win; | |
5569 | |
5570 } | |
5571 | |
5572 | |
5573 /******************************************************************************* | |
5574 | |
5575 $Function: services_input_destroy | |
5576 | |
5577 $Description: | |
5578 | |
5579 $Returns: | |
5580 | |
5581 $Arguments: | |
5582 | |
5583 *******************************************************************************/ | |
5584 | |
5585 | |
5586 | |
5587 | |
5588 | |
5589 static void services_input_destroy(MfwHnd window){ | |
5590 T_MFW_WIN * win = ((T_MFW_HDR *)window)->data; | |
5591 T_services_input * data = (T_services_input *)win->user; | |
5592 | |
5593 TRACE_FUNCTION ("services_input_destroy()"); | |
5594 | |
5595 if (window == NULL) | |
5596 { | |
5597 TRACE_EVENT ("Error : Called with NULL Pointer"); | |
5598 return; | |
5599 } | |
5600 | |
5601 if (data) | |
5602 { | |
5603 /* SPR#1428 - SH - Destroy new editor */ | |
5604 #ifdef NEW_EDITOR | |
5605 AUI_edit_Destroy(data->edit_win); | |
5606 #else /* NEW_EDITOR */ | |
5607 editDeactivate(); | |
5608 #endif /* NEW_EDITOR */ | |
5609 | |
5610 winDelete (data->win); | |
5611 /* * Free Memory | |
5612 */ | |
5613 FREE_MEMORY ((void *)data, sizeof (T_services_input)); | |
5614 } | |
5615 } | |
5616 | |
5617 | |
5618 /******************************************************************************* | |
5619 | |
5620 $Function: services_input_start | |
5621 | |
5622 $Description: | |
5623 | |
5624 $Returns: | |
5625 | |
5626 $Arguments: | |
5627 | |
5628 *******************************************************************************/ | |
5629 | |
5630 | |
5631 static MfwHnd services_input_start(MfwHnd parent,T_input_properties *properties) | |
5632 { | |
5633 | |
5634 T_MFW_HND win; | |
5635 TRACE_FUNCTION ("services_input_start()"); | |
5636 | |
5637 win = services_input_create (parent); | |
5638 | |
5639 if (win NEQ NULL) | |
5640 { | |
5641 SEND_EVENT (win, SERVICES_INPUT_INIT, 0, properties); | |
5642 } | |
5643 return win; | |
5644 } | |
5645 | |
5646 | |
5647 /******************************************************************************* | |
5648 | |
5649 $Function: services_input | |
5650 | |
5651 $Description: | |
5652 | |
5653 $Returns: | |
5654 | |
5655 $Arguments: | |
5656 | |
5657 *******************************************************************************/ | |
5658 | |
5659 | |
5660 void services_input (T_MFW_HND win, USHORT event, SHORT value, void * parameter) | |
5661 { | |
5662 T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; | |
5663 T_services_input * data = (T_services_input *)win_data->user; | |
5664 | |
5665 T_input_properties* properties = (T_input_properties*) parameter; | |
5666 #ifdef NEW_EDITOR | |
5667 T_AUI_EDITOR_DATA editor_data; | |
5668 #endif /* NEW_EDITOR */ | |
5669 | |
5670 TRACE_FUNCTION ("T_services_input()"); | |
5671 | |
5672 switch (event) | |
5673 { | |
5674 case SERVICES_INPUT_INIT: | |
5675 /* SPR#1428 - SH - New Editor changes - replace old custom editor | |
5676 * with a standard AUI Editor */ | |
5677 #ifdef NEW_EDITOR | |
5678 AUI_edit_SetDefault(&editor_data); | |
5679 AUI_edit_SetTextStr(&editor_data, properties->left_soft_key, properties->right_soft_key, properties->text, NULL); | |
5680 AUI_edit_SetEvents(&editor_data, 0, FALSE, FOREVER, properties->callback); | |
5681 //Oct 20, 2004 REF: CRR 25772 Deepa M.D | |
5682 //The alternate text string when the editor content is empty is set and | |
5683 //the change_rsk_on_empty flag is set to true. | |
5684 AUI_edit_SetAltTextStr(&editor_data, 1, TxtNames, TRUE, TxtSoftBack); | |
5685 AUI_edit_SetDisplay(&editor_data, SERVICE_CREATE_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); | |
5686 | |
5687 if (properties->abc) | |
5688 { | |
5689 AUI_edit_SetMode(&editor_data, ED_MODE_ALPHA, ED_CURSOR_BAR); | |
5690 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_name, sizeof(ss_data.edt_buf_name)); | |
5691 } | |
5692 else | |
5693 { | |
5694 AUI_edit_SetMode(&editor_data, 0, ED_CURSOR_UNDERLINE); | |
5695 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_number, sizeof(ss_data.edt_buf_number)); | |
5696 | |
5697 } | |
5698 TRACE_EVENT("SERVICES_INPUT_INIT"); | |
5699 | |
5700 data->edit_win = AUI_edit_Start(data->win, &editor_data); | |
5701 | |
5702 #else /*NEW_EDITOR*/ | |
5703 | |
5704 data->properties.abc = properties->abc; | |
5705 data->properties.text = properties->text; | |
5706 data->properties.edt_attr_input = properties->edt_attr_input; | |
5707 data->properties.left_soft_key = properties->left_soft_key; | |
5708 data->properties.right_soft_key = properties->right_soft_key; | |
5709 data->properties.callback = properties->callback; | |
5710 data->edt_input = edtCreate(data->win,data->properties.edt_attr_input,0,0); | |
5711 editDeactivate(); | |
5712 editActivate (data->edt_input,properties->abc); | |
5713 edtUnhide(data->edt_input); | |
5714 winShow(data->win); | |
5715 #endif /* NEW_EDITOR */ | |
5716 break; | |
5717 | |
5718 case SERVICES_INPUT_DESTROY: | |
5719 TRACE_FUNCTION("SERVICES_INPUT_DESTROY"); | |
5720 services_input_destroy(data->win); | |
5721 break; | |
5722 | |
5723 case DIVERT_PHBK_NUMBER: | |
5724 /* SPR#1428 - SH - New Editor changes - buffer changed, send event to | |
5725 * update editors */ | |
5726 #ifdef NEW_EDITOR | |
5727 { | |
5728 T_ATB_TEXT text; | |
5729 text.dcs = ATB_DCS_ASCII; | |
5730 text.data = (UBYTE *)parameter; | |
5731 text.len = ATB_string_Length(&text); | |
5732 SEND_EVENT(data->edit_win, E_ED_INSERT, 0, (void *)&text); | |
5733 } | |
5734 #else /* NEW_EDITOR */ | |
5735 strncpy(ss_data.edt_buf_number, (char *)parameter, strlen((char *)parameter)+1); | |
5736 #endif /* NEW_EDITOR */ | |
5737 break; | |
5738 default: | |
5739 return; | |
5740 } | |
5741 | |
5742 } | |
5743 | |
5744 | |
5745 /******************************************************************************* | |
5746 | |
5747 $Function: services_input_win_cb | |
5748 | |
5749 $Description: | |
5750 | |
5751 $Returns: | |
5752 | |
5753 $Arguments: | |
5754 | |
5755 *******************************************************************************/ | |
5756 | |
5757 static int services_input_win_cb (MfwEvt e, MfwWin *w){ | |
5758 | |
5759 T_services_input * data = (T_services_input *)w->user; | |
5760 | |
5761 //int i =0; // RAVI | |
5762 | |
5763 TRACE_FUNCTION ("services_input_win_cb()"); | |
5764 | |
5765 /* SPR#1428 - SH - New Editor changes - this window is now | |
5766 * invisible, AUI editor sits on top*/ | |
5767 #ifdef NEW_EDITOR | |
5768 return 0; | |
5769 #else /* NEW_EDITOR */ | |
5770 switch (e) | |
5771 { | |
5772 case MfwWinVisible: | |
5773 edtShow(data->edt_input); | |
5774 PROMPT(menuArea.px,menuArea.py,0,data->properties.text); | |
5775 displaySoftKeys(data->properties.left_soft_key,data->properties.right_soft_key); | |
5776 break; | |
5777 default: | |
5778 return 0; | |
5779 } | |
5780 #endif /* NEW_EDITOR */ | |
5781 | |
5782 return 1; | |
5783 | |
5784 } | |
5785 | |
5786 | |
5787 /* SPR#1428 - SH - New Editor changes - no longer required*/ | |
5788 #ifndef NEW_EDITOR | |
5789 /******************************************************************************* | |
5790 | |
5791 $Function: services_input_kbd_cb | |
5792 | |
5793 $Description: | |
5794 | |
5795 $Returns: | |
5796 | |
5797 $Arguments: | |
5798 | |
5799 *******************************************************************************/ | |
5800 | |
5801 static int services_input_kbd_cb (MfwEvt e, MfwKbd *k){ | |
5802 | |
5803 | |
5804 T_MFW_HND win = mfwParent(mfw_header()); | |
5805 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5806 T_services_input * data = (T_services_input *)win_data->user; | |
5807 | |
5808 TRACE_FUNCTION ("services_input_kbd_cb()"); | |
5809 | |
5810 if (activeEditor() NEQ data->edt_input) | |
5811 editActivate(data->edt_input,data->properties.abc); | |
5812 | |
5813 switch (k->code) | |
5814 { | |
5815 case KCD_MNUUP: | |
5816 edtChar(data->edt_input,ecRight); | |
5817 break; | |
5818 | |
5819 case KCD_MNUDOWN: | |
5820 edtChar(data->edt_input,ecLeft); | |
5821 break; | |
5822 | |
5823 case KCD_LEFT: | |
5824 TRACE_FUNCTION("left key pressed"); | |
5825 data->properties.callback(data->parent_win,SERVICES_INPUT_LEFT); | |
5826 break; | |
5827 | |
5828 case KCD_HUP: | |
5829 /* if edit field is empty then exit, else delete one char */ | |
5830 data->properties.callback(data->parent_win,SERVICES_INPUT_CLEAR); | |
5831 | |
5832 if (strlen(data->properties.edt_attr_input->text) > 0) | |
5833 { | |
5834 edtChar(data->edt_input,ecBack); | |
5835 if(strlen(data->properties.edt_attr_input->text) == 0) | |
5836 data->properties.right_soft_key=TxtContacts; | |
5837 else | |
5838 data->properties.right_soft_key=TxtDelete; | |
5839 winShow(data->win); | |
5840 } | |
5841 else | |
5842 services_input_destroy(data->win); | |
5843 break; | |
5844 | |
5845 case KCD_RIGHT: | |
5846 // Check if there is a digit in the edit buffer softkey should be delete. | |
5847 if (strlen(data->properties.edt_attr_input->text) > 0) | |
5848 { | |
5849 edtChar(data->edt_input,ecBack); | |
5850 if(strlen(data->properties.edt_attr_input->text) == 0) | |
5851 { | |
5852 data->properties.right_soft_key=TxtContacts; | |
5853 winShow(data->win); | |
5854 } | |
5855 } | |
5856 else | |
5857 { | |
5858 // MZ 26/02/01 services_input_destroy(data->win); | |
5859 // Activate phone book . | |
5860 if (bookPhoneBookLoading()==BOOK_SUCCESS) | |
5861 { | |
5862 T_MFW_HND phbk_win; | |
5863 phbk_win = bookPhonebookStart(data->win,PhbkFromDivert); | |
5864 } | |
5865 | |
5866 } | |
5867 | |
5868 break; | |
5869 default: | |
5870 editEventKey (e,k); | |
5871 if(strlen(data->properties.edt_attr_input->text) > 0) | |
5872 data->properties.right_soft_key=TxtDelete; | |
5873 else | |
5874 data->properties.right_soft_key=TxtContacts; | |
5875 winShow(data->win); | |
5876 | |
5877 break; | |
5878 } | |
5879 return MFW_EVENT_CONSUMED; | |
5880 } | |
5881 | |
5882 | |
5883 /******************************************************************************* | |
5884 | |
5885 $Function: services_input_kbd_long_cb | |
5886 | |
5887 $Description: | |
5888 | |
5889 $Returns: | |
5890 | |
5891 $Arguments: | |
5892 | |
5893 *******************************************************************************/ | |
5894 | |
5895 | |
5896 | |
5897 | |
5898 static int services_input_kbd_long_cb (MfwEvt e, MfwKbd *k){ | |
5899 | |
5900 T_MFW_HND win = mfwParent(mfw_header()); | |
5901 T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; | |
5902 T_services_input * data = (T_services_input *)win_data->user; | |
5903 | |
5904 | |
5905 if ((e & KEY_CLEAR) && (e & KEY_LONG)) | |
5906 { | |
5907 edtClear(data->edt_input); | |
5908 services_input_destroy(data->win); | |
5909 return MFW_EVENT_CONSUMED; | |
5910 } | |
5911 return MFW_EVENT_CONSUMED; | |
5912 } | |
5913 | |
5914 | |
5915 /******************************************************************************* | |
5916 | |
5917 $Function: services_number_input_cb | |
5918 | |
5919 $Description: | |
5920 | |
5921 $Returns: | |
5922 | |
5923 $Arguments: | |
5924 | |
5925 *******************************************************************************/ | |
5926 | |
5927 void services_number_input_cb(T_MFW_HND win, UBYTE identifier, USHORT reason){ | |
5928 | |
5929 switch(reason){ | |
5930 | |
5931 case SERVICES_INPUT_LEFT: | |
5932 break; | |
5933 case SERVICES_INPUT_RIGHT: | |
5934 break; | |
5935 case SERVICES_INPUT_CLEAR: | |
5936 break; | |
5937 default: | |
5938 return; | |
5939 } | |
5940 } | |
5941 | |
5942 #endif /* ifndef NEW_EDITOR */ | |
5943 | |
5944 | |
5945 /******************************************************************************* | |
5946 | |
5947 $Function: servicesCallBarringCheck | |
5948 | |
5949 $Description: | |
5950 | |
5951 $Returns: | |
5952 | |
5953 $Arguments: | |
5954 | |
5955 *******************************************************************************/ | |
5956 | |
5957 | |
5958 void servicesCallBarringCheck(void) | |
5959 { | |
5960 char SS_string[60] = {'\0'}; | |
5961 | |
5962 TRACE_FUNCTION("servicesCallBarringCheck"); | |
5963 | |
5964 CBAction = CBCheck; | |
5965 | |
5966 getCBAction(SS_string); | |
5967 getCBType(SS_string); | |
5968 SS_string[strlen(SS_string)-1] = '#'; | |
5969 | |
5970 TRACE_FUNCTION(SS_string); | |
5971 | |
5972 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
5973 showFailed( ss_data.win ); | |
5974 | |
5975 } | |
5976 | |
5977 /******************************************************************************* | |
5978 | |
5979 $Function: servicesCallBarringDeactivate | |
5980 | |
5981 $Description: | |
5982 | |
5983 $Returns: | |
5984 | |
5985 $Arguments: | |
5986 | |
5987 *******************************************************************************/ | |
5988 | |
5989 | |
5990 | |
5991 void servicesCallBarringDeactivate(void) | |
5992 { | |
5993 char SS_string[60] = {'\0'}; | |
5994 | |
5995 TRACE_FUNCTION("servicesCallBarringDeactivate"); | |
5996 | |
5997 CBAction = CBDeactivate; | |
5998 | |
5999 getCBAction(SS_string); | |
6000 getCBType(SS_string); | |
6001 getCBPassword(SS_string); | |
6002 //June 21, 2004 - CRR:13650 - CBA : no basic service sent when using the menu | |
6003 //Adding the basic service code 10(all teleservices) to the SS string during deactivation | |
6004 strcat(SS_string,BASIC_SERVICE_CODE); | |
6005 SS_string[strlen(SS_string)] = '#'; | |
6006 | |
6007 TRACE_FUNCTION(SS_string); | |
6008 | |
6009 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
6010 showFailed( ss_data.win ); | |
6011 | |
6012 | |
6013 } | |
6014 | |
6015 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6016 /******************************************************************************* | |
6017 | |
6018 $Function: servicesCallBarringDeactivatePassword | |
6019 | |
6020 $Description: Sets the flag for deactivating the selected barring service and prompts for the password | |
6021 | |
6022 $Returns: | |
6023 | |
6024 $Arguments: | |
6025 | |
6026 *******************************************************************************/ | |
6027 | |
6028 void servicesCallBarringDeactivatePassword(void) | |
6029 { | |
6030 | |
6031 CBFlag=CBDeactivate; | |
6032 requestCBPassword(); | |
6033 } | |
6034 | |
6035 /******************************************************************************* | |
6036 | |
6037 $Function: servicesCallBarringActivate | |
6038 | |
6039 $Description: | |
6040 | |
6041 $Returns: | |
6042 | |
6043 $Arguments: | |
6044 | |
6045 *******************************************************************************/ | |
6046 | |
6047 | |
6048 void servicesCallBarringActivate(void) | |
6049 { | |
6050 char SS_string[60] = {'\0'}; | |
6051 | |
6052 TRACE_FUNCTION("servicesCallBarringActivate"); //SPR#1038 - DS - Changed from DeActivate to Activate. | |
6053 | |
6054 CBAction = CBActivate; | |
6055 | |
6056 getCBAction(SS_string); | |
6057 getCBType(SS_string); | |
6058 getCBPassword(SS_string); | |
6059 //June 21, 2004 - CRR:13650 - CBA : no basic service sent when using the menu | |
6060 //Adding the basic service code 10(all teleservices) to the SS string during activation | |
6061 strcat(SS_string,BASIC_SERVICE_CODE); | |
6062 SS_string[strlen(SS_string)] = '#'; | |
6063 | |
6064 TRACE_FUNCTION(SS_string); | |
6065 | |
6066 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
6067 showFailed( ss_data.win ); | |
6068 | |
6069 } | |
6070 | |
6071 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6072 /******************************************************************************* | |
6073 | |
6074 $Function: servicesCallBarringActivatePassword | |
6075 | |
6076 $Description: Sets the flag for activating the selected barring service and prompts for the password | |
6077 | |
6078 $Returns: | |
6079 | |
6080 $Arguments: | |
6081 | |
6082 *******************************************************************************/ | |
6083 | |
6084 void servicesCallBarringActivatePassword(void) | |
6085 { | |
6086 | |
6087 CBFlag=CBActivate; | |
6088 requestCBPassword(); | |
6089 } | |
6090 | |
6091 | |
6092 /******************************************************************************* | |
6093 | |
6094 $Function: servicesCallBarringCancelAll | |
6095 | |
6096 $Description: | |
6097 | |
6098 $Returns: | |
6099 | |
6100 $Arguments: | |
6101 | |
6102 *******************************************************************************/ | |
6103 | |
6104 | |
6105 void servicesCallBarringCancelAll(void) | |
6106 { | |
6107 char SS_string[60] = {'\0'}; | |
6108 | |
6109 TRACE_FUNCTION("servicesCallBarringCancelAll"); | |
6110 | |
6111 | |
6112 strcat(SS_string, "#330*"); | |
6113 getCBPassword(SS_string); | |
6114 SS_string[strlen(SS_string)-1] = '#'; | |
6115 | |
6116 TRACE_FUNCTION(SS_string); | |
6117 | |
6118 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
6119 showFailed( ss_data.win ); | |
6120 | |
6121 } | |
6122 | |
6123 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6124 /******************************************************************************* | |
6125 | |
6126 $Function: servicesCallBarringCancelAllPassword | |
6127 | |
6128 $Description: Sets the flag for cancelling all barring service and prompts for the password | |
6129 | |
6130 $Returns: | |
6131 | |
6132 $Arguments: | |
6133 | |
6134 *******************************************************************************/ | |
6135 void servicesCallBarringCancelAllPassword(void) | |
6136 { | |
6137 CBFlag=CBCancelAll; | |
6138 requestCBPassword(); | |
6139 } | |
6140 | |
6141 | |
6142 /******************************************************************************* | |
6143 | |
6144 $Function: getCBAction | |
6145 | |
6146 $Description: | |
6147 | |
6148 $Returns: | |
6149 | |
6150 $Arguments: | |
6151 | |
6152 *******************************************************************************/ | |
6153 | |
6154 | |
6155 static void getCBAction(char * pSSstring) | |
6156 { | |
6157 switch (CBAction) | |
6158 { | |
6159 case CBActivate: | |
6160 strcpy(pSSstring, "*"); | |
6161 break; | |
6162 case CBDeactivate: | |
6163 strcpy(pSSstring, "#"); | |
6164 break; | |
6165 case CBCheck: | |
6166 strcpy(pSSstring, "*#"); | |
6167 break; | |
6168 default: | |
6169 break; | |
6170 } | |
6171 } | |
6172 | |
6173 /******************************************************************************* | |
6174 | |
6175 $Function: getCBType | |
6176 | |
6177 $Description: | |
6178 | |
6179 $Returns: | |
6180 | |
6181 $Arguments: | |
6182 | |
6183 *******************************************************************************/ | |
6184 | |
6185 | |
6186 static void getCBType(char* pSSstring) | |
6187 { | |
6188 | |
6189 | |
6190 switch (CBType) | |
6191 { | |
6192 case CBAllOutgoing: | |
6193 strcat(pSSstring, "33*"); | |
6194 break; | |
6195 case CBInternational: | |
6196 strcat(pSSstring, "331*"); | |
6197 break; | |
6198 case CBAllIncoming: | |
6199 strcat(pSSstring, "35*"); | |
6200 break; | |
6201 case CBInternationalHome: | |
6202 strcat(pSSstring, "332*"); | |
6203 break; | |
6204 case CBIncomingRoaming: | |
6205 strcat(pSSstring, "351*"); | |
6206 break; | |
6207 default: | |
6208 break; | |
6209 } | |
6210 } | |
6211 | |
6212 /******************************************************************************* | |
6213 | |
6214 $Function: getCBPassword | |
6215 | |
6216 $Description: | |
6217 | |
6218 $Returns: | |
6219 | |
6220 $Arguments: | |
6221 | |
6222 *******************************************************************************/ | |
6223 | |
6224 | |
6225 static void getCBPassword(char* pSSstring) | |
6226 { | |
6227 TRACE_FUNCTION("getCBPassword"); | |
6228 strcat(pSSstring, (char*)ss_data.edt_buf_cb_password); | |
6229 strcat(pSSstring, "*"); | |
6230 } | |
6231 | |
6232 //CQ-16432 start | |
6233 /******************************************************************************* | |
6234 | |
6235 $Function: requestSatCBPassword | |
6236 | |
6237 $Description: | |
6238 | |
6239 $Returns: | |
6240 | |
6241 $Arguments: | |
6242 | |
6243 *******************************************************************************/ | |
6244 | |
6245 | |
6246 | |
6247 void requestSatCBPassword(void) | |
6248 { | |
6249 | |
6250 | |
6251 #ifdef NEW_EDITOR | |
6252 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor changes */ | |
6253 #else /* NEW_EDITOR */ | |
6254 T_EDITOR_DATA editor_data; | |
6255 #endif /* NEW_EDITOR */ | |
6256 T_MFW_HND win = mfw_parent(mfw_header()); | |
6257 T_MFW_HND satPswdWin; | |
6258 TRACE_FUNCTION("requestSatCBPassword"); | |
6259 //SPR#1014 - DS - Reset editor data | |
6260 memset(&editor_data, '\0', sizeof(editor_data)); | |
6261 | |
6262 /* | |
6263 * Setup an editor to display a string | |
6264 */ | |
6265 | |
6266 memset(satPassword,'\0',sizeof(satPassword)); | |
6267 | |
6268 /* SPR#1428 - SH - New Editor changes */ | |
6269 #ifdef NEW_EDITOR | |
6270 TRACE_FUNCTION("New editor is defined"); | |
6271 AUI_edit_SetDefault(&editor_data); | |
6272 AUI_edit_SetDisplay(&editor_data, RPWD_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); | |
6273 AUI_edit_SetMode(&editor_data, ED_MODE_HIDDEN, ED_CURSOR_UNDERLINE); | |
6274 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)satPassword, CB_PSW_LEN+1); | |
6275 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtPassword, NULL); | |
6276 AUI_edit_SetAltTextStr(&editor_data, CB_PSW_LEN, TxtNull, FALSE, TxtNull); | |
6277 AUI_edit_SetEvents(&editor_data, CBEnterSatPassword, TRUE, FOREVER, (T_AUI_EDIT_CB)CB_password_cb); | |
6278 satPswdWin = AUI_edit_Start(win, &editor_data); /* start the editor */ | |
6279 TRACE_EVENT_P1("satPassword contents: %s",satPassword); | |
6280 #else /* NEW_EDITOR */ | |
6281 TRACE_FUNCTION("New editor is not defined"); | |
6282 bookSetEditAttributes( RPWD_EDITOR, COLOUR_EDITOR_XX, 0, edtCurBar1, 0, | |
6283 (char*)ss_data.edt_buf_cb_password,CB_PSW_LEN+1, &editor_data.editor_attr ); | |
6284 editor_data.LeftSoftKey = TxtSoftOK; | |
6285 editor_data.AlternateLeftSoftKey = TxtNull; | |
6286 editor_data.RightSoftKey = TxtSoftBack; | |
6287 editor_data.hide = TRUE; | |
6288 editor_data.mode = DIGITS_MODE; | |
6289 editor_data.timeout = FOREVER; | |
6290 editor_data.Identifier = CBCheckPassword; | |
6291 editor_data.destroyEditor = TRUE; | |
6292 editor_data.Callback = (T_EDIT_CB)CB_password_cb; | |
6293 editor_data.TextId = TxtPassword; | |
6294 editor_data.TextString = NULL; | |
6295 editor_data.min_enter = CB_PSW_LEN; | |
6296 editor_data.destroyEditor = TRUE; | |
6297 ss_data.info_win = editor_start(ss_data.win, &editor_data); | |
6298 #endif /* NEW_EDITOR */ | |
6299 | |
6300 } | |
6301 //CQ-16432 end | |
6302 | |
6303 /******************************************************************************* | |
6304 | |
6305 $Function: requestCBPassword | |
6306 | |
6307 $Description: | |
6308 | |
6309 $Returns: | |
6310 | |
6311 $Arguments: | |
6312 | |
6313 *******************************************************************************/ | |
6314 | |
6315 | |
6316 | |
6317 void requestCBPassword(void) | |
6318 { | |
6319 #ifdef NEW_EDITOR | |
6320 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor changes */ | |
6321 #else /* NEW_EDITOR */ | |
6322 T_EDITOR_DATA editor_data; | |
6323 #endif /* NEW_EDITOR */ | |
6324 TRACE_FUNCTION("requestCBPassword"); | |
6325 //SPR#1014 - DS - Reset editor data | |
6326 memset(&editor_data, '\0', sizeof(editor_data)); | |
6327 | |
6328 /* | |
6329 * Setup an editor to display a string | |
6330 */ | |
6331 | |
6332 memset(ss_data.edt_buf_cb_password,'\0',sizeof(ss_data.edt_buf_cb_password)); | |
6333 | |
6334 /* SPR#1428 - SH - New Editor changes */ | |
6335 #ifdef NEW_EDITOR | |
6336 TRACE_FUNCTION("NEW_EDITOR"); | |
6337 AUI_edit_SetDefault(&editor_data); | |
6338 AUI_edit_SetDisplay(&editor_data, RPWD_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); | |
6339 AUI_edit_SetMode(&editor_data, ED_MODE_HIDDEN, ED_CURSOR_UNDERLINE); | |
6340 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_cb_password, CB_PSW_LEN+1); | |
6341 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtPassword, NULL); | |
6342 AUI_edit_SetAltTextStr(&editor_data, CB_PSW_LEN, TxtNull, FALSE, TxtNull); | |
6343 AUI_edit_SetEvents(&editor_data, CBCheckPassword, TRUE, FOREVER, (T_AUI_EDIT_CB)CB_password_cb); | |
6344 | |
6345 ss_data.info_win = AUI_edit_Start(ss_data.win, &editor_data); /* start the editor */ | |
6346 #else /* NEW_EDITOR */ | |
6347 TRACE_FUNCTION("Old_editor"); | |
6348 bookSetEditAttributes( RPWD_EDITOR, COLOUR_EDITOR_XX, 0, edtCurBar1, 0, | |
6349 (char*)ss_data.edt_buf_cb_password,CB_PSW_LEN+1, &editor_data.editor_attr ); | |
6350 editor_data.LeftSoftKey = TxtSoftOK; | |
6351 editor_data.AlternateLeftSoftKey = TxtNull; | |
6352 editor_data.RightSoftKey = TxtSoftBack; | |
6353 editor_data.hide = TRUE; | |
6354 editor_data.mode = DIGITS_MODE; | |
6355 editor_data.timeout = FOREVER; | |
6356 editor_data.Identifier = CBCheckPassword; | |
6357 editor_data.destroyEditor = TRUE; | |
6358 editor_data.Callback = (T_EDIT_CB)CB_password_cb; | |
6359 editor_data.TextId = TxtPassword; | |
6360 editor_data.TextString = NULL; | |
6361 editor_data.min_enter = CB_PSW_LEN; | |
6362 editor_data.destroyEditor = TRUE; | |
6363 ss_data.info_win = editor_start(ss_data.win, &editor_data); | |
6364 #endif /* NEW_EDITOR */ | |
6365 } | |
6366 | |
6367 /******************************************************************************* | |
6368 | |
6369 $Function: CB_password_cb | |
6370 | |
6371 $Description: | |
6372 | |
6373 $Returns: | |
6374 | |
6375 $Arguments: | |
6376 | |
6377 *******************************************************************************/ | |
6378 | |
6379 | |
6380 | |
6381 static void CB_password_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason) | |
6382 { | |
6383 //16432 | |
6384 TRACE_FUNCTION("CB_password_cb"); | |
6385 switch (identifier) | |
6386 { | |
6387 case CBCheckPassword: | |
6388 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6389 //keyevents right and hangup are handled initially | |
6390 switch (reason) | |
6391 { | |
6392 case INFO_KCD_HUP: | |
6393 // Change by Sasken ( VadiRaj) on March 29th 2004 | |
6394 // Issue Number : MMI-SPR-12882 | |
6395 // Subject: No functionality for the right softkey. | |
6396 // Bug : No functionality for the right softkey | |
6397 // Solution : Added functionality for the right "BACK" softeky | |
6398 case INFO_KCD_RIGHT: | |
6399 ss_data.info_win = 0; | |
6400 CBFlag=CBActionNone;; | |
6401 break; | |
6402 default: | |
6403 break; | |
6404 } | |
6405 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6406 //depending on the action selected by the user the respective functions are invoked | |
6407 switch(CBFlag) | |
6408 { | |
6409 case CBDeactivate: | |
6410 CBFlag=CBActionNone; //reset the flag | |
6411 servicesCallBarringDeactivate(); //initiates the callbarring deactivation for the selected service | |
6412 break; | |
6413 case CBActivate: | |
6414 CBFlag=CBActionNone; //reset the flag | |
6415 servicesCallBarringActivate(); //initiates the callbarring activation for the selected service | |
6416 break; | |
6417 case CBCancelAll: | |
6418 CBFlag=CBActionNone; //reset the flag | |
6419 servicesCallBarringCancelAll(); //initiates the cancelling of all barring services | |
6420 break; | |
6421 case CBNewPassword: | |
6422 CBFlag=CBActionNone; //reset the flag | |
6423 enterNewCBPassword(); //prompt for the new password | |
6424 break; | |
6425 default: | |
6426 CBFlag=CBActionNone;; | |
6427 break; | |
6428 } | |
6429 ss_data.info_win = 0; | |
6430 break; | |
6431 case CBNewPassword: | |
6432 ss_data.info_win = 0; | |
6433 switch (reason) | |
6434 { | |
6435 case INFO_KCD_LEFT: | |
6436 confirmNewCBPassword(); | |
6437 break; | |
6438 default: | |
6439 break; | |
6440 } | |
6441 break; | |
6442 case CBConfirmNewPassword: | |
6443 ss_data.info_win = 0; | |
6444 switch (reason) | |
6445 { | |
6446 case INFO_KCD_LEFT: | |
6447 changeCBPassword(); | |
6448 break; | |
6449 default: | |
6450 break; | |
6451 } | |
6452 break; | |
6453 //CQ-16432 start | |
6454 case CBEnterSatPassword: | |
6455 ss_set_clck(CLCK_FAC_Ox, CLCK_MOD_NotPresent, satPassword, CLASS_NotPresent, MFW_MODUL_UNKNOWN); | |
6456 //CQ-16432 end | |
6457 break; | |
6458 default: | |
6459 break; | |
6460 } | |
6461 } | |
6462 | |
6463 //Jun 02,2004 CRR:13649 xpradipg-SASKEN | |
6464 /******************************************************************************* | |
6465 | |
6466 $Function: enterOldCBPassword | |
6467 | |
6468 $Description: sets flag for changing the barring password and prompts to enter the current | |
6469 barring password | |
6470 $Returns: | |
6471 | |
6472 $Arguments: | |
6473 | |
6474 *******************************************************************************/ | |
6475 | |
6476 void enterOldCBPassword(void) | |
6477 { | |
6478 CBFlag=CBNewPassword; | |
6479 requestCBPassword(); | |
6480 } | |
6481 | |
6482 /******************************************************************************* | |
6483 | |
6484 $Function: enterNewCBPassword | |
6485 | |
6486 $Description: | |
6487 | |
6488 $Returns: | |
6489 | |
6490 $Arguments: | |
6491 | |
6492 *******************************************************************************/ | |
6493 | |
6494 | |
6495 void enterNewCBPassword(void) | |
6496 { | |
6497 #ifdef NEW_EDITOR | |
6498 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */ | |
6499 #else | |
6500 T_EDITOR_DATA editor_data; | |
6501 #endif | |
6502 | |
6503 //SPR#1014 - DS - Reset editor data | |
6504 memset(&editor_data, '\0', sizeof(editor_data)); | |
6505 memset(ss_data.edt_buf_cb_new_password,'\0',sizeof(ss_data.edt_buf_cb_new_password)); | |
6506 | |
6507 /* SPR#1428 - SH - New Editor changes */ | |
6508 #ifdef NEW_EDITOR | |
6509 AUI_edit_SetDefault(&editor_data); | |
6510 AUI_edit_SetDisplay(&editor_data, RPWD_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); | |
6511 AUI_edit_SetMode(&editor_data, ED_MODE_HIDDEN, ED_CURSOR_UNDERLINE); | |
6512 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_cb_new_password, CB_PSW_LEN+1); | |
6513 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtNewPassword, NULL); | |
6514 AUI_edit_SetAltTextStr(&editor_data, CB_PSW_LEN, TxtNull, FALSE, TxtNull); | |
6515 AUI_edit_SetEvents(&editor_data, CBNewPassword, TRUE, FOREVER, (T_AUI_EDIT_CB)CB_password_cb); | |
6516 | |
6517 ss_data.info_win = AUI_edit_Start(ss_data.win, &editor_data); /* start the editor */ | |
6518 #else /* NEW_EDITOR */ | |
6519 bookSetEditAttributes( RPWD_EDITOR, 0, 0, edtCurBar1, 0, | |
6520 (char*)ss_data.edt_buf_cb_new_password,CB_PSW_LEN+1, &editor_data.editor_attr ); | |
6521 editor_data.LeftSoftKey = TxtSoftOK; | |
6522 editor_data.AlternateLeftSoftKey = TxtNull; | |
6523 editor_data.RightSoftKey = TxtDelete; | |
6524 editor_data.hide = TRUE; | |
6525 editor_data.mode = DIGITS_MODE; | |
6526 editor_data.timeout = FOREVER; | |
6527 editor_data.Identifier = CBNewPassword; | |
6528 editor_data.destroyEditor = TRUE; | |
6529 editor_data.Callback = (T_EDIT_CB)CB_password_cb; | |
6530 editor_data.TextId = TxtNewPassword; | |
6531 editor_data.TextString = NULL; | |
6532 editor_data.min_enter = CB_PSW_LEN; | |
6533 editor_data.destroyEditor = TRUE; | |
6534 ss_data.info_win = editor_start(ss_data.win, &editor_data); | |
6535 #endif /* NEW_EDITOR */ | |
6536 } | |
6537 | |
6538 /******************************************************************************* | |
6539 | |
6540 $Function: confirmNewCBPassword | |
6541 | |
6542 $Description: | |
6543 | |
6544 $Returns: | |
6545 | |
6546 $Arguments: | |
6547 | |
6548 *******************************************************************************/ | |
6549 | |
6550 | |
6551 void confirmNewCBPassword(void) | |
6552 { | |
6553 #ifdef NEW_EDITOR | |
6554 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */ | |
6555 #else | |
6556 T_EDITOR_DATA editor_data; | |
6557 #endif | |
6558 | |
6559 //SPR#1014 - DS - Reset editor data. | |
6560 memset(&editor_data, '\0', sizeof(editor_data)); | |
6561 | |
6562 memset(ss_data.edt_buf_cb_conf_new_password,'\0',sizeof(ss_data.edt_buf_cb_conf_new_password)); | |
6563 | |
6564 /* SPR#1428 - SH - New Editor changes */ | |
6565 #ifdef NEW_EDITOR | |
6566 AUI_edit_SetDefault(&editor_data); | |
6567 AUI_edit_SetDisplay(&editor_data, RPWD_EDITOR, COLOUR_EDITOR_XX, EDITOR_FONT); | |
6568 AUI_edit_SetMode(&editor_data, ED_MODE_HIDDEN, ED_CURSOR_UNDERLINE); | |
6569 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ss_data.edt_buf_cb_conf_new_password, CB_PSW_LEN+1); | |
6570 AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtSoftBack, TxtConfirmPassword, NULL); | |
6571 AUI_edit_SetAltTextStr(&editor_data, CB_PSW_LEN, TxtNull, FALSE, TxtNull); | |
6572 AUI_edit_SetEvents(&editor_data, CBConfirmNewPassword, TRUE, FOREVER, (T_AUI_EDIT_CB)CB_password_cb); | |
6573 | |
6574 ss_data.info_win = AUI_edit_Start(ss_data.win, &editor_data); /* start the editor */ | |
6575 #else /* NEW_EDITOR */ | |
6576 bookSetEditAttributes( RPWD_EDITOR, 0, 0, edtCurBar1, 0, | |
6577 (char*)ss_data.edt_buf_cb_conf_new_password,CB_PSW_LEN+1, &editor_data.editor_attr ); | |
6578 editor_data.LeftSoftKey = TxtSoftOK; | |
6579 editor_data.AlternateLeftSoftKey = TxtNull; | |
6580 editor_data.RightSoftKey = TxtDelete; | |
6581 editor_data.hide = TRUE; | |
6582 editor_data.mode = DIGITS_MODE; | |
6583 editor_data.timeout = FOREVER; | |
6584 editor_data.Identifier = CBConfirmNewPassword; | |
6585 editor_data.destroyEditor = TRUE; | |
6586 editor_data.Callback = (T_EDIT_CB)CB_password_cb; | |
6587 editor_data.TextId = TxtConfirmPassword; | |
6588 editor_data.TextString = NULL; | |
6589 editor_data.min_enter = CB_PSW_LEN; | |
6590 editor_data.destroyEditor = TRUE; | |
6591 ss_data.info_win = editor_start(ss_data.win, &editor_data); | |
6592 #endif /* NEW_EDITOR */ | |
6593 | |
6594 } | |
6595 | |
6596 /******************************************************************************* | |
6597 | |
6598 $Function: changeCBPassword | |
6599 | |
6600 $Description: | |
6601 | |
6602 $Returns: | |
6603 | |
6604 $Arguments: | |
6605 | |
6606 *******************************************************************************/ | |
6607 | |
6608 | |
6609 void changeCBPassword(void){ | |
6610 | |
6611 char SS_string[60] = {'\0'}; | |
6612 T_DISPLAY_DATA display_info; | |
6613 | |
6614 TRACE_FUNCTION("changeCBPassword"); | |
6615 | |
6616 if (strcmp((char*)ss_data.edt_buf_cb_new_password, (char*)ss_data.edt_buf_cb_conf_new_password)) | |
6617 { | |
6618 /* | |
6619 ** The New and Confirm Passwords do not match, restart the process and display a dialog to | |
6620 ** explain. (The dialog is done second so that it will display on top of the new prompt) | |
6621 */ | |
6622 enterNewCBPassword(); | |
6623 | |
6624 // Jul 23, 2004 REF: CRR 16107 xvilliva | |
6625 dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtPasswords, TxtMismatch, COLOUR_STATUS); | |
6626 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)services_info_cb, THREE_SECS, 0); | |
6627 display_info.Identifier = ServicesFailed; | |
6628 | |
6629 /* | |
6630 * Call Info Screen | |
6631 */ | |
6632 ss_data.info_win = info_dialog (ss_data.win, &display_info); | |
6633 } | |
6634 else | |
6635 { | |
6636 strcat(SS_string, "**03*330*"); | |
6637 strcat(SS_string,(char*)ss_data.edt_buf_cb_password); | |
6638 strcat(SS_string,"*"); | |
6639 strcat(SS_string,(char*)ss_data.edt_buf_cb_new_password); | |
6640 strcat(SS_string,"*"); | |
6641 strcat(SS_string,(char*)ss_data.edt_buf_cb_conf_new_password); | |
6642 strcat(SS_string,"#"); | |
6643 | |
6644 TRACE_FUNCTION(SS_string); | |
6645 | |
6646 if (ss_execute_transaction((UBYTE*)SS_string, 0) == MFW_SS_FAIL) | |
6647 showFailed( ss_data.win ); | |
6648 } | |
6649 | |
6650 | |
6651 } | |
6652 | |
6653 | |
6654 /******************************************************************************* | |
6655 | |
6656 $Function: featurePlaceholder | |
6657 | |
6658 $Description: Display screen dialog for not-yet-implemented features | |
6659 | |
6660 $Returns: None | |
6661 | |
6662 $Arguments: None | |
6663 | |
6664 //SPR#1113 - DS - Created function. | |
6665 | |
6666 *******************************************************************************/ | |
6667 | |
6668 void featurePlaceholder(void){ | |
6669 | |
6670 T_DISPLAY_DATA display_info ; | |
6671 | |
6672 TRACE_FUNCTION("featurePlaceholder"); | |
6673 | |
6674 display_info.LeftSoftKey = TxtSoftOK; | |
6675 display_info.RightSoftKey = 0; | |
6676 display_info.TextId = 0; | |
6677 display_info.TextId2 = 0; | |
6678 display_info.TextString = "Feature"; | |
6679 display_info.TextString2 = "Not Available"; | |
6680 display_info.Time = THREE_SECS; | |
6681 display_info.Identifier = 0; | |
6682 display_info.Callback = NULL; | |
6683 display_info.KeyEvents = KEY_CLEAR | KEY_LEFT | KEY_MNUUP | KEY_MNUDOWN; | |
6684 | |
6685 /* | |
6686 * Call Info Screen | |
6687 */ | |
6688 | |
6689 info_dialog(win, &display_info); | |
6690 | |
6691 } |