mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-23 10:22:50 +00:00
63 lines
2.1 KiB
C++
63 lines
2.1 KiB
C++
/*
|
|
Copyright (c) 2009 Volker Krause <vkrause@kde.org>
|
|
|
|
This library is free software; you can redistribute it and/or modify it
|
|
under the terms of the GNU Library General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or (at your
|
|
option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
|
License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to the
|
|
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
02110-1301, USA.
|
|
*/
|
|
|
|
#include "dbbrowser.h"
|
|
#include "dbaccess.h"
|
|
|
|
#include <QSqlTableModel>
|
|
|
|
DbBrowser::DbBrowser(QWidget* parent) :
|
|
QWidget( parent ),
|
|
mTableModel( 0 )
|
|
{
|
|
ui.setupUi( this );
|
|
|
|
if ( DbAccess::database().isOpen() ) {
|
|
QStringList userTables = DbAccess::database().tables(QSql::Tables);
|
|
userTables.sort();
|
|
QStringList systemTables = DbAccess::database().tables(QSql::SystemTables);
|
|
systemTables.sort();
|
|
|
|
ui.tableBox->addItems( QStringList() << userTables << systemTables );
|
|
}
|
|
|
|
ui.refreshButton->setIcon( KIcon( "view-refresh" ) );
|
|
connect( ui.refreshButton, SIGNAL(clicked()), SLOT(refreshClicked()) );
|
|
}
|
|
|
|
void DbBrowser::refreshClicked()
|
|
{
|
|
const QString table = ui.tableBox->currentText();
|
|
if ( table.isEmpty() )
|
|
return;
|
|
delete mTableModel;
|
|
mTableModel = new QSqlTableModel( this, DbAccess::database() );
|
|
mTableModel->setTable( table );
|
|
mTableModel->setEditStrategy( QSqlTableModel::OnRowChange );
|
|
mTableModel->select();
|
|
ui.tableView->setModel( mTableModel );
|
|
connect( ui.tableView->horizontalHeader(), SIGNAL(sortIndicatorChanged(int,Qt::SortOrder)),
|
|
this, SLOT(onSortIndicatorChanged(int,Qt::SortOrder)) );
|
|
}
|
|
|
|
void DbBrowser::onSortIndicatorChanged( int column, Qt::SortOrder order )
|
|
{
|
|
mTableModel->sort( column, order );
|
|
}
|
|
|