bluetoothengine/btui/btuimodel/btuimodelsortfilter.cpp
author hgs
Mon, 17 May 2010 11:06:23 +0300
changeset 31 a0ea99b6fa53
child 40 997690c3397a
child 42 b72428996822
permissions -rw-r--r--
201019_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     1
/*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     3
* All rights reserved.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     8
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    11
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    12
* Contributors:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    13
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    14
* Description: 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    15
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    16
*/
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    17
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    18
#include <btuimodelsortfilter.h>
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    19
#include <btdevicemodel.h>
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    20
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    21
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    22
    Constructor.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    23
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    24
BtuiModelSortFilter::BtuiModelSortFilter( QObject *parent )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    25
    : QSortFilterProxyModel( parent )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    26
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    27
    setDynamicSortFilter( true );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    28
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    29
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    30
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    31
    Destructor.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    32
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    33
BtuiModelSortFilter::~BtuiModelSortFilter()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    34
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    35
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    36
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    37
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    38
    Replace current filter values for filtering on major device class with
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    39
    the specified. This Model will not reset itself for performance reason, 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    40
    the caller shall call reset after all filters have been set.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    41
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    42
void BtuiModelSortFilter::setDeviceMajorFilter( int filter, FilterMode mode )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    43
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    44
    mFilters.clear();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    45
    addDeviceMajorFilter( filter, mode );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    46
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    47
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    48
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    49
    Add the specified filter value for filtering on major device class 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    50
    if the specified filter doesn't exist when this function is called.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    51
    This Model will not reset itself for performance reason, 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    52
    the caller shall call reset after all filters have been set.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    53
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    54
void BtuiModelSortFilter::addDeviceMajorFilter( int filter, FilterMode mode )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    55
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    56
    FilterItem f(filter, mode);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    57
    if ( mFilters.indexOf(f) == -1 ) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    58
        mFilters.append( f );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    59
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    60
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    61
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    62
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    63
    Clear the specified filter value for filtering on major device class from this model.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    64
    This Model will not reset itself for performance reason, 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    65
    the caller shall call reset after all filters have been set.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    66
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    67
void BtuiModelSortFilter::clearDeviceMajorFilter( int filter, FilterMode mode )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    68
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    69
    FilterItem f(filter, mode);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    70
    int i = mFilters.indexOf(f);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    71
    if ( i > -1 ) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    72
        mFilters.removeAt( i );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    73
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    74
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    75
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    76
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    77
    clear all filters for filtering on major device class.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    78
    This Model will not reset itself for performance reason, 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    79
    the caller shall call reset after all filters have been set.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    80
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    81
void BtuiModelSortFilter::clearDeviceMajorFilters()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    82
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    83
    // model reset is needed if there are filters :
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    84
    bool shReset = ( mFilters.size() > 0 );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    85
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    86
    if ( shReset ) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    87
        reset();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    88
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    89
    mFilters.clear();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    90
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    91
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    92
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    93
    return true if the specified filter exists; return false otherwise.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    94
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    95
bool BtuiModelSortFilter::hasFilter( int filter, FilterMode mode )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    96
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    97
    FilterItem f(filter, mode);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    98
    return mFilters.indexOf(f) > -1 ;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    99
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   100
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   101
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   102
    \reimp
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   103
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   104
bool BtuiModelSortFilter::filterAcceptsRow(
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   105
    int sourceRow, const QModelIndex &sourceParent) const 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   106
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   107
    bool accepted (false );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   108
    // Get the device name from the model
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   109
    QModelIndex index = sourceModel()->index(sourceRow, 0, sourceParent);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   110
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   111
    // the row shall pass all filters:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   112
    for (int i = 0; i < mFilters.size(); i++ ) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   113
        if ( mFilters.at(i).mFilter == BtDeviceModel::NullProperty ) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   114
            accepted = true;    // There is no filter, we accept all
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   115
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   116
        else {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   117
            int majorProperty = 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   118
                    sourceModel()->data(index, BtDeviceModel::MajorPropertyRole).toInt();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   119
            switch (mFilters.at(i).mMode) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   120
                case ExactMatch:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   121
                    // Accept if the match is spot-on
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   122
                    accepted = majorProperty == mFilters.at(i).mFilter ;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   123
                    break;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   124
                case AtLeastMatch:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   125
                    // accept if it matches all specified filters:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   126
                    accepted = ( mFilters.at(i).mFilter == 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   127
                        ( majorProperty & mFilters.at(i).mFilter ) );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   128
                    break;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   129
                case RoughMatch:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   130
                    // Accept if it matches one of specified filters:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   131
                    accepted = (majorProperty & mFilters.at(i).mFilter) != 0;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   132
                    break;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   133
                case Exclusive:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   134
                    // Accept if this is not one that we want to filter out
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   135
                    accepted = (majorProperty & mFilters.at(i).mFilter) == 0;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   136
                    break;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   137
                default:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   138
                    accepted = false;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   139
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   140
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   141
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   142
    if (accepted) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   143
        // emit signal to inform a row has been accepted by fitler,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   144
        // currently this is only needed by search view
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   145
        emit const_cast<BtuiModelSortFilter*>(this)->deviceAcceptedByFilter( sourceRow );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   146
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   147
    return accepted;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   148
}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   149
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   150
/*!
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   151
    \reimp
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   152
 */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   153
bool BtuiModelSortFilter::lessThan(
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   154
        const QModelIndex &left, const QModelIndex &right) const
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   155
{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   156
    Q_UNUSED( left );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   157
    Q_UNUSED( right );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   158
    if (sortRole() == BtDeviceModel::NameAliasRole ||
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   159
        sortRole() == BtDeviceModel::LastUsedTimeRole ||
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   160
        sortRole() == BtDeviceModel::RssiRole) {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   161
        // base class provides sorting for these types already:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   162
        return QSortFilterProxyModel::lessThan(left, right);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   163
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   164
    // no custom sort supported yet.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   165
    return true;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   166
}