usbuis/usbsettingsapp/inc/usbuisettingmodel.h
author hgs
Mon, 17 May 2010 11:03:15 +0300
changeset 52 831068540b07
permissions -rw-r--r--
201019_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
52
831068540b07 201019_1
hgs
parents:
diff changeset
     1
/*
831068540b07 201019_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
831068540b07 201019_1
hgs
parents:
diff changeset
     3
* All rights reserved.
831068540b07 201019_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
831068540b07 201019_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
831068540b07 201019_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
831068540b07 201019_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
831068540b07 201019_1
hgs
parents:
diff changeset
     8
*
831068540b07 201019_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
831068540b07 201019_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
831068540b07 201019_1
hgs
parents:
diff changeset
    11
*
831068540b07 201019_1
hgs
parents:
diff changeset
    12
* Contributors:
831068540b07 201019_1
hgs
parents:
diff changeset
    13
*
831068540b07 201019_1
hgs
parents:
diff changeset
    14
* Description: 
831068540b07 201019_1
hgs
parents:
diff changeset
    15
*
831068540b07 201019_1
hgs
parents:
diff changeset
    16
*/
831068540b07 201019_1
hgs
parents:
diff changeset
    17
831068540b07 201019_1
hgs
parents:
diff changeset
    18
#ifndef USBUISETTINGMODEL_H
831068540b07 201019_1
hgs
parents:
diff changeset
    19
#define USBUISETTINGMODEL_H
831068540b07 201019_1
hgs
parents:
diff changeset
    20
831068540b07 201019_1
hgs
parents:
diff changeset
    21
831068540b07 201019_1
hgs
parents:
diff changeset
    22
#include <e32base.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    23
#include <e32property.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    24
#include <QStringList>
831068540b07 201019_1
hgs
parents:
diff changeset
    25
#include <QAbstractItemModel>
831068540b07 201019_1
hgs
parents:
diff changeset
    26
#include <XQSettingsManager>
831068540b07 201019_1
hgs
parents:
diff changeset
    27
831068540b07 201019_1
hgs
parents:
diff changeset
    28
typedef QList< QMap< int, QVariant > > UsbUiModelDataSource;
831068540b07 201019_1
hgs
parents:
diff changeset
    29
831068540b07 201019_1
hgs
parents:
diff changeset
    30
class RUsb;
831068540b07 201019_1
hgs
parents:
diff changeset
    31
class UsbUiModelActive;
831068540b07 201019_1
hgs
parents:
diff changeset
    32
class QItemSelection;
831068540b07 201019_1
hgs
parents:
diff changeset
    33
class QItemSelectionModel;
831068540b07 201019_1
hgs
parents:
diff changeset
    34
831068540b07 201019_1
hgs
parents:
diff changeset
    35
class UsbUiSettingModel : public QAbstractItemModel
831068540b07 201019_1
hgs
parents:
diff changeset
    36
{
831068540b07 201019_1
hgs
parents:
diff changeset
    37
    Q_OBJECT
831068540b07 201019_1
hgs
parents:
diff changeset
    38
    friend class TestUsbUiModelActive;
831068540b07 201019_1
hgs
parents:
diff changeset
    39
 
831068540b07 201019_1
hgs
parents:
diff changeset
    40
public:
831068540b07 201019_1
hgs
parents:
diff changeset
    41
    UsbUiSettingModel( QObject *parent = 0);
831068540b07 201019_1
hgs
parents:
diff changeset
    42
    virtual ~UsbUiSettingModel();
831068540b07 201019_1
hgs
parents:
diff changeset
    43
831068540b07 201019_1
hgs
parents:
diff changeset
    44
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    45
     *  Returns the index of the item in the model specified by the given row, column and parent index.
831068540b07 201019_1
hgs
parents:
diff changeset
    46
     *  @param row is the row number of the specified item
831068540b07 201019_1
hgs
parents:
diff changeset
    47
     *  @param column is the column number of the specified item
831068540b07 201019_1
hgs
parents:
diff changeset
    48
     *  @param parent QModelIndex parent
831068540b07 201019_1
hgs
parents:
diff changeset
    49
     */   
831068540b07 201019_1
hgs
parents:
diff changeset
    50
    virtual QModelIndex index( int row, int column, const QModelIndex &parent = QModelIndex() ) const;
831068540b07 201019_1
hgs
parents:
diff changeset
    51
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    52
     * Returns QModelIndex() because this model item has no parent
831068540b07 201019_1
hgs
parents:
diff changeset
    53
     * @param child is the index of item model, the parent of which is going to be returned
831068540b07 201019_1
hgs
parents:
diff changeset
    54
     * @param child is not used in here
831068540b07 201019_1
hgs
parents:
diff changeset
    55
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    56
    virtual QModelIndex parent( const QModelIndex &child ) const;
831068540b07 201019_1
hgs
parents:
diff changeset
    57
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    58
     * Returns the number of rows under the given parent
831068540b07 201019_1
hgs
parents:
diff changeset
    59
     * @param parent QModelIndex parent
831068540b07 201019_1
hgs
parents:
diff changeset
    60
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    61
    virtual int rowCount( const QModelIndex &parent = QModelIndex() ) const;
831068540b07 201019_1
hgs
parents:
diff changeset
    62
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    63
     * Returns the number of columns for the children of the given parent.
831068540b07 201019_1
hgs
parents:
diff changeset
    64
     * @param parent QModelIndex parent
831068540b07 201019_1
hgs
parents:
diff changeset
    65
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    66
    virtual int columnCount( const QModelIndex &parent = QModelIndex() ) const;
831068540b07 201019_1
hgs
parents:
diff changeset
    67
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    68
     *Returns the data stored under the given role for the item referred to by the index. 
831068540b07 201019_1
hgs
parents:
diff changeset
    69
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    70
    virtual QVariant data( const QModelIndex &index, int role = Qt::DisplayRole ) const;
831068540b07 201019_1
hgs
parents:
diff changeset
    71
831068540b07 201019_1
hgs
parents:
diff changeset
    72
    const QModelIndex* sourceData() const;
831068540b07 201019_1
hgs
parents:
diff changeset
    73
   
831068540b07 201019_1
hgs
parents:
diff changeset
    74
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    75
     * informs the model of the changes in selectionModel and the new mode 
831068540b07 201019_1
hgs
parents:
diff changeset
    76
     * will be Handeled by the Model
831068540b07 201019_1
hgs
parents:
diff changeset
    77
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    78
    void  setSelectionModel(QItemSelectionModel *selectionModel);
831068540b07 201019_1
hgs
parents:
diff changeset
    79
831068540b07 201019_1
hgs
parents:
diff changeset
    80
public slots:
831068540b07 201019_1
hgs
parents:
diff changeset
    81
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    82
     * Provides notification of changes in selected usb mode
831068540b07 201019_1
hgs
parents:
diff changeset
    83
     * @param key is not used 
831068540b07 201019_1
hgs
parents:
diff changeset
    84
     * @param value is the value read from cenrep key 
831068540b07 201019_1
hgs
parents:
diff changeset
    85
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    86
    void cenrepChanged( const XQSettingsKey &key, const QVariant &value );
831068540b07 201019_1
hgs
parents:
diff changeset
    87
    
831068540b07 201019_1
hgs
parents:
diff changeset
    88
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
    89
     * it checks the response from usbwatcher to see if the new mode change has been successful
831068540b07 201019_1
hgs
parents:
diff changeset
    90
     * it will go back to the previous personality if it has not been successful
831068540b07 201019_1
hgs
parents:
diff changeset
    91
     * @param status is the error code returned from usbwatcher
831068540b07 201019_1
hgs
parents:
diff changeset
    92
     */
831068540b07 201019_1
hgs
parents:
diff changeset
    93
    void personalitySetCompleted (int status );
831068540b07 201019_1
hgs
parents:
diff changeset
    94
    
831068540b07 201019_1
hgs
parents:
diff changeset
    95
    /**
831068540b07 201019_1
hgs
parents:
diff changeset
    96
     * This slot handles selection change from the selection model.
831068540b07 201019_1
hgs
parents:
diff changeset
    97
     * The personality is set according to the selection.
831068540b07 201019_1
hgs
parents:
diff changeset
    98
     * @param selected Item selection of selected items
831068540b07 201019_1
hgs
parents:
diff changeset
    99
     * @param deselected Item selection of deselected items
831068540b07 201019_1
hgs
parents:
diff changeset
   100
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   101
    void handleSelectionChange(const QItemSelection &selected, 
831068540b07 201019_1
hgs
parents:
diff changeset
   102
            const QItemSelection &deselected );
831068540b07 201019_1
hgs
parents:
diff changeset
   103
    
831068540b07 201019_1
hgs
parents:
diff changeset
   104
private:
831068540b07 201019_1
hgs
parents:
diff changeset
   105
	/*
831068540b07 201019_1
hgs
parents:
diff changeset
   106
	 * Get the translated mode name
831068540b07 201019_1
hgs
parents:
diff changeset
   107
	 * @param friendlyName is the usb personality friendly name
831068540b07 201019_1
hgs
parents:
diff changeset
   108
	 */   
831068540b07 201019_1
hgs
parents:
diff changeset
   109
    QString modeName( QString &friendlyName );
831068540b07 201019_1
hgs
parents:
diff changeset
   110
831068540b07 201019_1
hgs
parents:
diff changeset
   111
    /*
831068540b07 201019_1
hgs
parents:
diff changeset
   112
     * Get the current USB personality ID
831068540b07 201019_1
hgs
parents:
diff changeset
   113
     * Returns 0, if the key is missing or the value cannot be converted 
831068540b07 201019_1
hgs
parents:
diff changeset
   114
     * to integer.
831068540b07 201019_1
hgs
parents:
diff changeset
   115
     * @return The current personality id
831068540b07 201019_1
hgs
parents:
diff changeset
   116
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   117
    int currentMode(); 
831068540b07 201019_1
hgs
parents:
diff changeset
   118
831068540b07 201019_1
hgs
parents:
diff changeset
   119
    /**
831068540b07 201019_1
hgs
parents:
diff changeset
   120
     * Initialize the model data
831068540b07 201019_1
hgs
parents:
diff changeset
   121
     * @param modeId The current mode ID
831068540b07 201019_1
hgs
parents:
diff changeset
   122
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   123
    void initializeModelData( int modeId );
831068540b07 201019_1
hgs
parents:
diff changeset
   124
831068540b07 201019_1
hgs
parents:
diff changeset
   125
    /**
831068540b07 201019_1
hgs
parents:
diff changeset
   126
     * Update the selection model
831068540b07 201019_1
hgs
parents:
diff changeset
   127
     * @param newPersonality is the new personality id
831068540b07 201019_1
hgs
parents:
diff changeset
   128
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   129
    void updateSelectionModel(int newPersonality);
831068540b07 201019_1
hgs
parents:
diff changeset
   130
	
831068540b07 201019_1
hgs
parents:
diff changeset
   131
    /**
831068540b07 201019_1
hgs
parents:
diff changeset
   132
     * Check from the USB Manager if the USB personality is hidden.
831068540b07 201019_1
hgs
parents:
diff changeset
   133
     * @param usbman Already opened USB Manager session
831068540b07 201019_1
hgs
parents:
diff changeset
   134
     * @param personalityId The ID of the personality to be checked.
831068540b07 201019_1
hgs
parents:
diff changeset
   135
     * @return For hidden personality, true is returned.
831068540b07 201019_1
hgs
parents:
diff changeset
   136
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   137
    bool isPersonalityHidden(RUsb &usbman, TInt personalityId);
831068540b07 201019_1
hgs
parents:
diff changeset
   138
    
831068540b07 201019_1
hgs
parents:
diff changeset
   139
    /**
831068540b07 201019_1
hgs
parents:
diff changeset
   140
     * Get the personality friendly name from USB Manager
831068540b07 201019_1
hgs
parents:
diff changeset
   141
     * The friendly name can be used in text IDs.
831068540b07 201019_1
hgs
parents:
diff changeset
   142
     * @param usbman The open USB Manager session
831068540b07 201019_1
hgs
parents:
diff changeset
   143
     * @param personalityId The ID of the personality
831068540b07 201019_1
hgs
parents:
diff changeset
   144
     * @return Friendly name for personality
831068540b07 201019_1
hgs
parents:
diff changeset
   145
     */
831068540b07 201019_1
hgs
parents:
diff changeset
   146
    QString getFriendlyName(RUsb &usbman, TInt personalityId);
831068540b07 201019_1
hgs
parents:
diff changeset
   147
    
831068540b07 201019_1
hgs
parents:
diff changeset
   148
private:
831068540b07 201019_1
hgs
parents:
diff changeset
   149
       
831068540b07 201019_1
hgs
parents:
diff changeset
   150
    UsbUiModelDataSource mSettingsList;
831068540b07 201019_1
hgs
parents:
diff changeset
   151
 
831068540b07 201019_1
hgs
parents:
diff changeset
   152
    // current USB personality
831068540b07 201019_1
hgs
parents:
diff changeset
   153
    int mCurrentMode;
831068540b07 201019_1
hgs
parents:
diff changeset
   154
831068540b07 201019_1
hgs
parents:
diff changeset
   155
    //variable to access central repository
831068540b07 201019_1
hgs
parents:
diff changeset
   156
    XQSettingsManager mSettingsManager;
831068540b07 201019_1
hgs
parents:
diff changeset
   157
    
831068540b07 201019_1
hgs
parents:
diff changeset
   158
    QList<int> mPersonalityIds;
831068540b07 201019_1
hgs
parents:
diff changeset
   159
    //owned by the class
831068540b07 201019_1
hgs
parents:
diff changeset
   160
    // modelactive is used for the interaction with the usbwatcher
831068540b07 201019_1
hgs
parents:
diff changeset
   161
    UsbUiModelActive *mModelActive;
831068540b07 201019_1
hgs
parents:
diff changeset
   162
    
831068540b07 201019_1
hgs
parents:
diff changeset
   163
    QItemSelectionModel *mSelectionModel;
831068540b07 201019_1
hgs
parents:
diff changeset
   164
};
831068540b07 201019_1
hgs
parents:
diff changeset
   165
831068540b07 201019_1
hgs
parents:
diff changeset
   166
#endif // USBUISETTINGMODEL_H