port UI Logic to QML
This commit is contained in:
parent
8d36c31cb4
commit
d1a3545912
34 changed files with 4386 additions and 12344 deletions
|
@ -1,8 +1,8 @@
|
|||
#include "sites_model.h"
|
||||
|
||||
SitesModel::SitesModel(Settings::RouteMode mode, QObject *parent)
|
||||
: m_mode(mode),
|
||||
QAbstractTableModel(parent)
|
||||
: QAbstractListModel(parent),
|
||||
m_mode(mode)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -14,22 +14,13 @@ void SitesModel::resetCache()
|
|||
endResetModel();
|
||||
}
|
||||
|
||||
QVariant SitesModel::headerData(int section, Qt::Orientation orientation, int role) const
|
||||
{
|
||||
// FIXME: Implement me!
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
int SitesModel::rowCount(const QModelIndex &parent) const
|
||||
{
|
||||
Q_UNUSED(parent)
|
||||
if (!m_cacheReady) genCache();
|
||||
return m_ipsCache.size();
|
||||
}
|
||||
|
||||
int SitesModel::columnCount(const QModelIndex &parent) const
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
|
||||
QVariant SitesModel::data(const QModelIndex &index, int role) const
|
||||
{
|
||||
|
@ -38,24 +29,40 @@ QVariant SitesModel::data(const QModelIndex &index, int role) const
|
|||
|
||||
if (!m_cacheReady) genCache();
|
||||
|
||||
if (role == Qt::DisplayRole){
|
||||
if (role == SitesModel::UrlRole || role == SitesModel::IpRole) {
|
||||
if (m_ipsCache.isEmpty()) return QVariant();
|
||||
|
||||
if (index.column() == 0) {
|
||||
if (role == SitesModel::UrlRole) {
|
||||
return m_ipsCache.at(index.row()).first;
|
||||
}
|
||||
if (index.column() == 1) {
|
||||
if (role == SitesModel::IpRole) {
|
||||
return m_ipsCache.at(index.row()).second;
|
||||
}
|
||||
}
|
||||
|
||||
// if (role == Qt::TextAlignmentRole && index.column() == 1) {
|
||||
// return Qt::AlignRight;
|
||||
// }
|
||||
// if (role == Qt::TextAlignmentRole && index.column() == 1) {
|
||||
// return Qt::AlignRight;
|
||||
// }
|
||||
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
QVariant SitesModel::data(int row, int column)
|
||||
{
|
||||
if (row < 0 || row >= rowCount() || column < 0 || column >= 2) {
|
||||
return QVariant();
|
||||
}
|
||||
if (!m_cacheReady) genCache();
|
||||
|
||||
if (column == 0) {
|
||||
return m_ipsCache.at(row).first;
|
||||
}
|
||||
if (column == 1) {
|
||||
return m_ipsCache.at(row).second;
|
||||
}
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
void SitesModel::genCache() const
|
||||
{
|
||||
qDebug() << "SitesModel::genCache";
|
||||
|
@ -70,3 +77,10 @@ void SitesModel::genCache() const
|
|||
|
||||
m_cacheReady= true;
|
||||
}
|
||||
|
||||
QHash<int, QByteArray> SitesModel::roleNames() const {
|
||||
QHash<int, QByteArray> roles;
|
||||
roles[UrlRole] = "url_path";
|
||||
roles[IpRole] = "ip";
|
||||
return roles;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue