fepstub/UiPlugins/AknFepUiInterface/inc/AknFepCandidatePopup.h
author hgs
Wed, 23 Jun 2010 04:57:58 +0800
changeset 24 fc42a86c98e3
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0""
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:             A non-focusing popup menu to show candidates.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#ifndef __AKN_FEP_CANDIDATE_POPUP_H
hgs
parents:
diff changeset
    30
#define __AKN_FEP_CANDIDATE_POPUP_H
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// MACROS
hgs
parents:
diff changeset
    33
//To congigure the number of candidates in list
hgs
parents:
diff changeset
    34
const TInt KPredictiveListCandidateMax = 16; 
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// CLASS DECLARATION
hgs
parents:
diff changeset
    37
class MAknFepCandidatePopup
hgs
parents:
diff changeset
    38
    {
hgs
parents:
diff changeset
    39
public: // methods
hgs
parents:
diff changeset
    40
	
hgs
parents:
diff changeset
    41
	/**
hgs
parents:
diff changeset
    42
	 * destructor
hgs
parents:
diff changeset
    43
	 */
hgs
parents:
diff changeset
    44
    virtual ~MAknFepCandidatePopup() = 0;
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
    /**
hgs
parents:
diff changeset
    47
    * Getter for the currently active word
hgs
parents:
diff changeset
    48
    * @return   The currently active word as pointer descriptor
hgs
parents:
diff changeset
    49
    */
hgs
parents:
diff changeset
    50
    virtual TPtrC ActiveWord() const = 0;
hgs
parents:
diff changeset
    51
    
hgs
parents:
diff changeset
    52
    /**
hgs
parents:
diff changeset
    53
    * Getter for the exact word (the word with ordinal 0)
hgs
parents:
diff changeset
    54
    * @return   The exact word as pointer descriptor.
hgs
parents:
diff changeset
    55
    */
hgs
parents:
diff changeset
    56
    virtual TPtrC ExactWord() const = 0;
hgs
parents:
diff changeset
    57
    
hgs
parents:
diff changeset
    58
    /**
hgs
parents:
diff changeset
    59
    * Makes the pop-up selection list visible and blocks until the dialog has been dismissed.
hgs
parents:
diff changeset
    60
    * @param    aInlineEditorRect   Tells the place of the inline editor. If possible, the popup is opened
hgs
parents:
diff changeset
    61
    *                               so that it does not hide the inline editor.
hgs
parents:
diff changeset
    62
    * @param    aSelectedIdx        Output argument for the selected index.
hgs
parents:
diff changeset
    63
    * @param    aLastKeyEvent       The last key event received by the popup. On return this is the event
hgs
parents:
diff changeset
    64
    *                               which closed the popup.
hgs
parents:
diff changeset
    65
    * @param    aRightToLeftLanguage Direction of the candidate language.ETrue is right to left. EFalse otherwise
hgs
parents:
diff changeset
    66
    * @param    aKeyboard           Keyboard type in use (TPtiKeyboardType)
hgs
parents:
diff changeset
    67
    *
hgs
parents:
diff changeset
    68
    * @return   The command id used to close the window. EAknFepSoftkeySpell, EAknSoftkeyCancel, or EAknSoftkeySelect
hgs
parents:
diff changeset
    69
    */
hgs
parents:
diff changeset
    70
    virtual TInt ExecutePopupL( const TRect& aInlineEditorRect, TInt& aSelectedIdx, TKeyEvent& aLastKeyEvent, TBool aRightToLeftLanguage, TInt aKeyboard ) = 0;
hgs
parents:
diff changeset
    71
    
hgs
parents:
diff changeset
    72
    /**
hgs
parents:
diff changeset
    73
    * Function called when the dialog is dismissed. Among other things, this hides the dialog
hgs
parents:
diff changeset
    74
    * and deblocks the thread. Unlike in the base class, the instance is not destroyed here. 
hgs
parents:
diff changeset
    75
    * The same popup instance can be reused by calling ExecutePopupL() again. 
hgs
parents:
diff changeset
    76
    * @param    aAccept     EFalse  if the dialog was cancelled.
hgs
parents:
diff changeset
    77
    *                       ETrue   otherwise.
hgs
parents:
diff changeset
    78
    */
hgs
parents:
diff changeset
    79
    virtual void AttemptExitL(TBool aAccept) = 0;
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
    /**
hgs
parents:
diff changeset
    82
    * Removes the focus from the candidate list and makes the editor to be in focus.
hgs
parents:
diff changeset
    83
    */
hgs
parents:
diff changeset
    84
    virtual void UnFocus() = 0;
hgs
parents:
diff changeset
    85
    /**
hgs
parents:
diff changeset
    86
    * Changes the position where the candidate list is shown. The position of the candidate list is choosen by the
hgs
parents:
diff changeset
    87
    * candidate list itself but can be controlled by the inline text rectangle.
hgs
parents:
diff changeset
    88
    * @param    aRect  The inline text rect.
hgs
parents:
diff changeset
    89
    */
hgs
parents:
diff changeset
    90
    virtual void ShowAtNewPosition(TRect aRect) = 0;
hgs
parents:
diff changeset
    91
    
hgs
parents:
diff changeset
    92
    /**
hgs
parents:
diff changeset
    93
     *  Revert back the candidate focus, and add the candidate list to the control stack reducing
hgs
parents:
diff changeset
    94
     *  the control priority. Usually, this function can be called after void UnFocus().
hgs
parents:
diff changeset
    95
     */
hgs
parents:
diff changeset
    96
    virtual void SetFocusAddStackReducePriorityL() = 0;
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
       
hgs
parents:
diff changeset
    99
    };
hgs
parents:
diff changeset
   100
    
hgs
parents:
diff changeset
   101
#endif // __AKN_FEP_CANDIDATE_POPUP_ H
hgs
parents:
diff changeset
   102