PushSwitch.c 12.2 KB
/*****************************************************************************
*  Copyright Statement:
*  --------------------
*  This software is protected by Copyright and the information contained
*  herein is confidential. The software may not be copied and the information
*  contained herein may not be used or disclosed except with the written
*  permission of MediaTek Inc. (C) 2005
*
*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. 
*
*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/

/*****************************************************************************
 *
 * Filename:
 * ---------
 * PushSwitch.c
 *
 * Project:
 * --------
 * MAUI
 *
 * Description:
 * ------------
 *  
 *
 * Author:
 * -------
 * -------
 *
 *============================================================================
 *             HISTORY
 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *------------------------------------------------------------------------------
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 *
 *------------------------------------------------------------------------------
 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *============================================================================
 ****************************************************************************/

#include "MMI_features.h"
#ifdef __MMI_PUSH_TURN_ON_OFF_SWITCH__

#include "kal_general_types.h"
#include "MMIDataType.h"
#include "GlobalResDef.h"
#include "wgui_categories_util.h"
#include "menucuigprot.h"
#include "mmi_frm_scenario_gprot.h"
#include "CommonScreensResDef.h"
#include "AlertScreen.h"
#include "mmi_rp_app_push_switch_def.h"
#include "PushSwitchSrvGprot.h"


/*****************************************************************************
 * Declarations
 *****************************************************************************/
static void mmi_push_switch_launch(void);
static mmi_ret mmi_push_switch_proc(mmi_event_struct *evt);
static void mmi_push_switch_entry_main(void);
static mmi_ret mmi_push_switch_nofify_confirm_proc(mmi_event_struct *evt);


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_highlight_hdlr
 * DESCRIPTION
 *  highlight hdlr for MENU_ID_PUSH_SWITCH
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
void mmi_push_switch_highlight_hdlr(void)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    ChangeLeftSoftkey(STR_GLOBAL_OK, 0);
    ChangeRightSoftkey(STR_GLOBAL_BACK, 0);
    SetLeftSoftkeyFunction(mmi_push_switch_launch, KEY_EVENT_UP);
    SetRightSoftkeyFunction(mmi_frm_scrn_close_active_id, KEY_EVENT_UP);
    ChangeCenterSoftkey(0, IMG_GLOBAL_COMMON_CSK);
    SetCenterSoftkeyFunction(mmi_push_switch_launch, KEY_EVENT_UP);
}


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_launch
 * DESCRIPTION
 *  launch push switch application
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
static void mmi_push_switch_launch(void)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    if (!srv_push_switch_check_service_ready())
    {
        mmi_popup_display(
            (WCHAR*)GetString(STR_GLOBAL_CURRENTLY_NOT_AVAILABLE),
            MMI_EVENT_FAILURE,
            NULL);
        return;
    }
    
    if (mmi_frm_group_is_present(GRP_ID_PUSH_SWITCH))
    {
        mmi_frm_group_close(GRP_ID_PUSH_SWITCH);
    }
    mmi_frm_group_create(GRP_ID_ROOT, GRP_ID_PUSH_SWITCH, mmi_push_switch_proc, NULL);
    mmi_frm_group_enter(GRP_ID_PUSH_SWITCH, MMI_FRM_NODE_SMART_CLOSE_FLAG);
    mmi_push_switch_entry_main();
}


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_proc
 * DESCRIPTION
 *  proc for push switch
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
static mmi_ret mmi_push_switch_proc(mmi_event_struct *evt)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/
    srv_push_switch_mode_enum mode;
    mmi_menu_id highlight_menu;
    cui_menu_event_struct *menu_event;

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    menu_event = (cui_menu_event_struct*)evt;
    switch (evt->evt_id)
    {
        case EVT_ID_CUI_MENU_LIST_ENTRY:
            if (menu_event->parent_menu_id == MENU_ID_PUSH_SWITCH)
            {
                mode = srv_push_switch_get_mode();
                if (mode == SRV_PUSH_SWITCH_MODE_ON)
                {
                    highlight_menu = MENU_ID_PUSH_SWITCH_ON;
                }
                else
                {
                    highlight_menu = MENU_ID_PUSH_SWITCH_OFF;
                }
                cui_menu_set_currlist_highlighted_id(menu_event->sender_id, highlight_menu);
            }
            break;

        case EVT_ID_CUI_MENU_ITEM_SELECT:
        case EVT_ID_CUI_MENU_ITEM_CSK_SELECT:
            if (menu_event->highlighted_menu_id == MENU_ID_PUSH_SWITCH_ON)
            {
                mode = SRV_PUSH_SWITCH_MODE_ON;
            }
            else
            {
                mode = SRV_PUSH_SWITCH_MODE_OFF;
            }
            if (srv_push_switch_set_mode(mode))
            {
                mmi_popup_display(
                    (WCHAR*)GetString(STR_GLOBAL_DONE),
                    MMI_EVENT_SUCCESS,
                    NULL);
            }
            cui_menu_close(menu_event->sender_id);
            break;

        case EVT_ID_CUI_MENU_CLOSE_REQUEST:
            cui_menu_close(menu_event->sender_id);
            break;
            
        default:
            break;
    }
    return MMI_RET_OK;
}


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_entry_main
 * DESCRIPTION
 *  entry main screen of push switch
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
static void mmi_push_switch_entry_main(void)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/
    mmi_id menu_cui_id;

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    menu_cui_id = cui_menu_create(
                    GRP_ID_PUSH_SWITCH,
                    CUI_MENU_SRC_TYPE_RESOURCE,
                    CUI_MENU_TYPE_APPMAIN,
                    MENU_ID_PUSH_SWITCH,
                    MMI_TRUE,
                    NULL);
    cui_menu_set_default_left_softkey(menu_cui_id, (WCHAR*)GetString(STR_GLOBAL_OK));
    cui_menu_set_default_title_string(menu_cui_id, (WCHAR*)GetString(STR_ID_PUSH_SWITCH));
    cui_menu_run(menu_cui_id);
}


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_nofify_confirm_proc
 * DESCRIPTION
 *  push switch notify confirm proc
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
static mmi_ret mmi_push_switch_nofify_confirm_proc(mmi_event_struct *evt)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    if (evt->evt_id == EVT_ID_ALERT_QUIT)
    {
        mmi_alert_result_evt_struct *confirm_evt = (mmi_alert_result_evt_struct*)evt;
        switch (confirm_evt->result)
	    {
            case MMI_ALERT_CNFM_YES:
            case MMI_ALERT_CNFM_CANCEL:
            	srv_push_switch_set_mode(SRV_PUSH_SWITCH_MODE_ON);
                break;
                
            case MMI_ALERT_CNFM_NO:
                srv_push_switch_set_mode(SRV_PUSH_SWITCH_MODE_OFF);
                break;

            default:
                break;
        }
    }

    return MMI_RET_OK;
}


/*****************************************************************************
 * FUNCTION
 *  mmi_push_switch_notify_hdlr
 * DESCRIPTION
 *  event hdlr for EVT_ID_SRV_PUSH_SWITCH_NOTIFY
 * PARAMETERS
 *  
 * RETURNS
 *  
 *****************************************************************************/
mmi_ret mmi_push_switch_notify_hdlr(mmi_event_struct *evt)
{
    /*----------------------------------------------------------------*/
    /* Local Variables                                                */
    /*----------------------------------------------------------------*/
    mmi_confirm_property_struct confirm_arg;

    /*----------------------------------------------------------------*/
    /* Code Body                                                      */
    /*----------------------------------------------------------------*/
    mmi_confirm_property_init(&confirm_arg, CNFM_TYPE_YESNO);
    confirm_arg.callback = (mmi_proc_func)mmi_push_switch_nofify_confirm_proc;
    confirm_arg.f_enter_history = MMI_TRUE;
    mmi_confirm_display(
        (WCHAR*)get_string(STR_ID_PUSH_SWITCH_PROMPT), 
        MMI_EVENT_QUERY, 
        &confirm_arg);
    return MMI_RET_OK;
}

#endif /* __MMI_PUSH_TURN_ON_OFF_SWITCH__ */