checkability for AppletsTable in ExportTemplateDlg

work/spdx
Michail Vourlakos
parent f63622db0f
commit 156b2190a8

@ -39,9 +39,6 @@ ExportTemplateDialog::ExportTemplateDialog(SettingsDialog *parent, Controller::L
m_ui->setupUi(this);
//! we must create handlers after creating/adjusting the ui
m_handler = new Handler::ExportTemplateHandler(this);
m_ui->appletsTable->horizontalHeader()->setStretchLastSection(true);
m_ui->appletsTable->verticalHeader()->setVisible(false);
}
ExportTemplateDialog::~ExportTemplateDialog()

@ -50,6 +50,9 @@ ExportTemplateHandler::~ExportTemplateHandler()
void ExportTemplateHandler::init()
{
m_ui->appletsTable->horizontalHeader()->setStretchLastSection(true);
m_ui->appletsTable->verticalHeader()->setVisible(false);
//! Layouts
m_appletsProxyModel = new QSortFilterProxyModel(this);
m_appletsProxyModel->setSourceModel(m_appletsModel);

@ -90,6 +90,18 @@ void Applets::setData(const Latte::Data::AppletsTable &applets)
}
}
Qt::ItemFlags Applets::flags(const QModelIndex &index) const
{
const int column = index.column();
const int row = index.row();
auto flags = QAbstractTableModel::flags(index);
flags |= Qt::ItemIsUserCheckable;
return flags;
}
QVariant Applets::headerData(int section, Qt::Orientation orientation, int role) const
{
if (orientation != Qt::Horizontal) {
@ -115,6 +127,28 @@ QVariant Applets::headerData(int section, Qt::Orientation orientation, int role)
return QAbstractTableModel::headerData(section, orientation, role);
}
bool Applets::setData(const QModelIndex &index, const QVariant &value, int role)
{
const int row = index.row();
const int column = index.column();
if (!m_appletsTable.rowExists(row) || column<0 || column > NAMECOLUMN) {
return false;
}
//! specific roles to each independent cell
switch (column) {
case NAMECOLUMN:
if (role == Qt::CheckStateRole) {
m_appletsTable[row].isSelected = (value.toInt() > 0 ? true : false);
return true;
}
break;
};
return false;
}
QVariant Applets::data(const QModelIndex &index, int role) const
{
const int row = index.row();
@ -126,6 +160,10 @@ QVariant Applets::data(const QModelIndex &index, int role) const
if (role == NAMEROLE || role == Qt::DisplayRole) {
return m_appletsTable[row].name;
} else if (role == Qt::CheckStateRole) {
return (m_appletsTable[row].isSelected ? Qt::Checked : Qt::Unchecked);
} else if (role== Qt::DecorationRole) {
return QIcon::fromTheme(m_appletsTable[row].icon);
} else if (role == IDROLE) {
return m_appletsTable[row].id;
} else if (role == SELECTEDROLE) {
@ -135,7 +173,7 @@ QVariant Applets::data(const QModelIndex &index, int role) const
} else if (role == DESCRIPTIONROLE) {
return m_appletsTable[row].description;
} else if (role == SORTINGROLE) {
return m_appletsTable[row].isInstalled() ? QString(1000 + m_appletsTable[row].name) : m_appletsTable[row].name;
return m_appletsTable[row].isInstalled() ? QString::number(1000) + m_appletsTable[row].name : QString::number(0000) + m_appletsTable[row].name;
}
return QVariant{};

@ -63,7 +63,9 @@ public:
int row(const QString &id);
QVariant data(const QModelIndex &index, int role) const override;
bool setData(const QModelIndex &index, const QVariant &value, int role) override;
QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const override;
Qt::ItemFlags flags(const QModelIndex &index) const override;
void setData(const Latte::Data::AppletsTable &applets);

Loading…
Cancel
Save