Resolve "reload catalog" #84

Merged
eelke merged 7 commits from 64-reload-catalog into master 2019-10-09 17:48:53 +00:00
3 changed files with 22 additions and 9 deletions
Showing only changes of commit 5c586ea807 - Show all commits

View file

@ -1,4 +1,5 @@
#include "TablesTableModel.h" #include "TablesTableModel.h"
#include "ScopeGuard.h"
#include "catalog/PgDatabaseCatalog.h" #include "catalog/PgDatabaseCatalog.h"
#include "catalog/PgClass.h" #include "catalog/PgClass.h"
#include "catalog/PgClassContainer.h" #include "catalog/PgClassContainer.h"
@ -15,23 +16,27 @@ TablesTableModel::TablesTableModel(QObject *parent)
void TablesTableModel::setNamespaceFilter(NamespaceFilter nsf) void TablesTableModel::setNamespaceFilter(NamespaceFilter nsf)
{ {
m_namespaceFilter = nsf; m_namespaceFilter = nsf;
reloadData(); refresh();
} }
void TablesTableModel::setCatalog(std::shared_ptr<const PgDatabaseCatalog> cat) void TablesTableModel::setCatalog(std::shared_ptr<const PgDatabaseCatalog> cat)
{ {
if (cat != m_catalog) {
m_catalog = cat; m_catalog = cat;
reloadData(); refreshConnection = connect(m_catalog.get(), &PgDatabaseCatalog::refreshed,
this, &TablesTableModel::refresh);
}
refresh();
} }
void TablesTableModel::reloadData() void TablesTableModel::refresh()
{ {
beginResetModel();
SCOPE_EXIT { endResetModel(); };
if (!m_catalog) if (!m_catalog)
return; return;
beginResetModel();
// Later afscheiden naar filter functie // Later afscheiden naar filter functie
auto classes = m_catalog->classes(); auto classes = m_catalog->classes();
@ -59,7 +64,6 @@ void TablesTableModel::reloadData()
} }
doSort(1); doSort(1);
endResetModel();
} }
void TablesTableModel::setSortOrder(int so) void TablesTableModel::setSortOrder(int so)

View file

@ -49,13 +49,16 @@ private:
std::shared_ptr<const PgDatabaseCatalog> m_catalog; std::shared_ptr<const PgDatabaseCatalog> m_catalog;
NamespaceFilter m_namespaceFilter = NamespaceFilter::User; NamespaceFilter m_namespaceFilter = NamespaceFilter::User;
t_Tables m_tables; t_Tables m_tables;
QMetaObject::Connection refreshConnection;
void reloadData();
Oid getType(int column) const; Oid getType(int column) const;
QVariant getData(const QModelIndex &index) const; QVariant getData(const QModelIndex &index) const;
// QString formatTableName(const PgClass &cls) const; // QString formatTableName(const PgClass &cls) const;
void doSort(int so); void doSort(int so);
private slots:
void refresh();
}; };
#endif // TABLESTABLEMODEL_H #endif // TABLESTABLEMODEL_H

View file

@ -72,6 +72,12 @@ CatalogTablesPage::CatalogTablesPage(QWidget *parent)
// Signals // Signals
connect(m_tableView->selectionModel(), &QItemSelectionModel::currentRowChanged, this, connect(m_tableView->selectionModel(), &QItemSelectionModel::currentRowChanged, this,
&CatalogTablesPage::tableListTable_currentRowChanged); &CatalogTablesPage::tableListTable_currentRowChanged);
connect(m_tablesModel, &TablesTableModel::modelReset,
[this] ()
{
selectedTableChanged({});
m_propertiesPage->setActiveRow({});
});
connect(m_tablesModel, &QAbstractItemModel::layoutChanged, connect(m_tablesModel, &QAbstractItemModel::layoutChanged,
this, &CatalogTablesPage::tableListTable_layoutChanged); this, &CatalogTablesPage::tableListTable_layoutChanged);