phonebookui/cntcommonui/core/cntviewnavigator.h
author hgs
Fri, 15 Oct 2010 12:24:46 +0300
changeset 81 640d30f4fb64
parent 72 6abfb1094884
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 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:  
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef CNTVIEWNAVIGATOR_H_
hgs
parents:
diff changeset
    19
#define CNTVIEWNAVIGATOR_H_
hgs
parents:
diff changeset
    20
#include <QObject>
hgs
parents:
diff changeset
    21
#include <QStack>
hgs
parents:
diff changeset
    22
#include <hbnamespace.h>
hgs
parents:
diff changeset
    23
#include "cntglobal.h"
hgs
parents:
diff changeset
    24
/*!
hgs
parents:
diff changeset
    25
 * Navigator keeps track on view history, the path that user has
hgs
parents:
diff changeset
    26
 * gone throug. If back() is called, one step back view id
hgs
parents:
diff changeset
    27
 * given, unless exception is set to current view id. In case of
hgs
parents:
diff changeset
    28
 * exception, navigator goes back in history until the exception 
hgs
parents:
diff changeset
    29
 * value is found. Note the difference between "back with exeception" vs.
hgs
parents:
diff changeset
    30
 * "launching given view id" (next()). 
hgs
parents:
diff changeset
    31
 *
hgs
parents:
diff changeset
    32
 * Next goes one step forward and stores history. 
hgs
parents:
diff changeset
    33
 * Navigator is implemented as stack of view ids.
hgs
parents:
diff changeset
    34
 *
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
class QTPBK_EXPORT CntViewNavigator : public QObject
hgs
parents:
diff changeset
    37
{
hgs
parents:
diff changeset
    38
    Q_OBJECT
hgs
parents:
diff changeset
    39
    friend class T_NavigatorTest;
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
public:
hgs
parents:
diff changeset
    42
    CntViewNavigator( QObject* aParent );
hgs
parents:
diff changeset
    43
    ~CntViewNavigator();
hgs
parents:
diff changeset
    44
    
hgs
parents:
diff changeset
    45
public:
hgs
parents:
diff changeset
    46
    /*!
hgs
parents:
diff changeset
    47
     * Next view puts the given id as current view
hgs
parents:
diff changeset
    48
     */
hgs
parents:
diff changeset
    49
    void next( const int& aId, QFlags<Hb::ViewSwitchFlag> &flags );
hgs
parents:
diff changeset
    50
    
hgs
parents:
diff changeset
    51
    /*!
hgs
parents:
diff changeset
    52
     * Back view returns the previous view
hgs
parents:
diff changeset
    53
     */
hgs
parents:
diff changeset
    54
    const int& back( QFlags<Hb::ViewSwitchFlag> &flags, bool toRoot );
hgs
parents:
diff changeset
    55
    
hgs
parents:
diff changeset
    56
    /*!
hgs
parents:
diff changeset
    57
     * Add exceptions to next/back mechanism. Function will use the aBack argument
hgs
parents:
diff changeset
    58
     * for previous view when aCurrent is the active view.
hgs
parents:
diff changeset
    59
     */
hgs
parents:
diff changeset
    60
    void addException( const int& aCurrent, const int& aBack );
hgs
parents:
diff changeset
    61
    void removeException( const int& aCurrent );
hgs
parents:
diff changeset
    62
    
hgs
parents:
diff changeset
    63
    /*!
hgs
parents:
diff changeset
    64
     * Add special view switching effects for some of the views. 
hgs
parents:
diff changeset
    65
     */
hgs
parents:
diff changeset
    66
    void addEffect( const int& aCurrent, const int& aBack );
hgs
parents:
diff changeset
    67
    void removeEffect( const int& aCurrent );
hgs
parents:
diff changeset
    68
    
hgs
parents:
diff changeset
    69
    /*!
hgs
parents:
diff changeset
    70
     * Set a view as a root view.
hgs
parents:
diff changeset
    71
     */
hgs
parents:
diff changeset
    72
    void addRoot( const int& aCurrent );
81
hgs
parents: 72
diff changeset
    73
        
hgs
parents: 72
diff changeset
    74
    /*!
hgs
parents: 72
diff changeset
    75
     * Internalize view data. Returns the previous view id.
hgs
parents: 72
diff changeset
    76
     */
hgs
parents: 72
diff changeset
    77
    int internalize(QDataStream &stream);
hgs
parents: 72
diff changeset
    78
    
hgs
parents: 72
diff changeset
    79
    /*!
hgs
parents: 72
diff changeset
    80
     * Externalize view data.
hgs
parents: 72
diff changeset
    81
     */
hgs
parents: 72
diff changeset
    82
    void externalize(QDataStream &stream);
hgs
parents: 72
diff changeset
    83
    
hgs
parents: 72
diff changeset
    84
    /*!
hgs
parents: 72
diff changeset
    85
     * Clear view stack.
hgs
parents: 72
diff changeset
    86
     */
hgs
parents: 72
diff changeset
    87
    void clearViewStack();
72
hgs
parents:
diff changeset
    88
    
hgs
parents:
diff changeset
    89
private:
81
hgs
parents: 72
diff changeset
    90
    QStack<int> mViewStack;
hgs
parents: 72
diff changeset
    91
    QMap< int, int > mExceptions;
hgs
parents: 72
diff changeset
    92
    QMap< int, int > mEffects;
hgs
parents: 72
diff changeset
    93
    QList<int> mRoots;
hgs
parents: 72
diff changeset
    94
    int mTop;
hgs
parents: 72
diff changeset
    95
    int mPreviousViewId;
72
hgs
parents:
diff changeset
    96
};
hgs
parents:
diff changeset
    97
#endif /* CNTVIEWNAVIGATOR_H_ */