File indexing completed on 2024-05-12 05:09:50

0001 /***************************************************************************
0002     Copyright (C) 2008-2009 Robby Stephenson <robby@periapsis.org>
0003  ***************************************************************************/
0004 
0005 /***************************************************************************
0006  *                                                                         *
0007  *   This program is free software; you can redistribute it and/or         *
0008  *   modify it under the terms of the GNU General Public License as        *
0009  *   published by the Free Software Foundation; either version 2 of        *
0010  *   the License or (at your option) version 3 or any later version        *
0011  *   accepted by the membership of KDE e.V. (or its successor approved     *
0012  *   by the membership of KDE e.V.), which shall act as a proxy            *
0013  *   defined in Section 14 of version 3 of the license.                    *
0014  *                                                                         *
0015  *   This program is distributed in the hope that it will be useful,       *
0016  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
0017  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
0018  *   GNU General Public License for more details.                          *
0019  *                                                                         *
0020  *   You should have received a copy of the GNU General Public License     *
0021  *   along with this program.  If not, see <http://www.gnu.org/licenses/>. *
0022  *                                                                         *
0023  ***************************************************************************/
0024 
0025 #include "abstractsortmodel.h"
0026 
0027 using Tellico::AbstractSortModel;
0028 
0029 AbstractSortModel::AbstractSortModel(QObject* parent) : QSortFilterProxyModel(parent)
0030     , m_sortColumn(-1), m_secondarySortColumn(-1), m_tertiarySortColumn(-1), m_sortOrder(Qt::AscendingOrder) {
0031 }
0032 
0033 AbstractSortModel::~AbstractSortModel() {
0034 }
0035 
0036 int AbstractSortModel::sortColumn() const {
0037   return m_sortColumn;
0038 }
0039 
0040 int AbstractSortModel::secondarySortColumn() const {
0041   return m_secondarySortColumn;
0042 }
0043 
0044 int AbstractSortModel::tertiarySortColumn() const {
0045   return m_tertiarySortColumn;
0046 }
0047 
0048 void AbstractSortModel::setSortColumn(int col) {
0049   m_sortColumn = col;
0050 }
0051 
0052 void AbstractSortModel::setSecondarySortColumn(int col) {
0053   m_secondarySortColumn = col;
0054 }
0055 
0056 void AbstractSortModel::setTertiarySortColumn(int col) {
0057   m_tertiarySortColumn = col;
0058 }
0059 
0060 Qt::SortOrder AbstractSortModel::sortOrder() const {
0061   return m_sortOrder;
0062 }
0063 
0064 void AbstractSortModel::setSortOrder(Qt::SortOrder order_) {
0065   if(order_ != m_sortOrder) {
0066     sort(m_sortColumn, order_);
0067   }
0068 }
0069 
0070 void AbstractSortModel::sort(int col_, Qt::SortOrder order_) {
0071   if(col_ != m_sortColumn) {
0072     m_tertiarySortColumn = m_secondarySortColumn;
0073     m_secondarySortColumn = m_sortColumn;
0074     m_sortColumn = col_;
0075   }
0076   m_sortOrder = order_;
0077   QSortFilterProxyModel::sort(col_, order_);
0078 }