mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-23 18:32:51 +00:00
64 lines
2.1 KiB
C++
64 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 );
|
||
|
}
|
||
|
|