##// END OF EJS Templates
Change the event model to a treeview model + update the last version of CatalogueAPI
Change the event model to a treeview model + update the last version of CatalogueAPI

File last commit:

r1180:938a31670f5f
r1182:c352dc0e2afa
Show More
CatalogueTreeWidgetItem.cpp
103 lines | 3.2 KiB | text/x-c | CppLexer
/ gui / src / Catalogue / CatalogueTreeWidgetItem.cpp
Display catalogues and events with CatalogueAPI
r1162 #include "Catalogue/CatalogueTreeWidgetItem.h"
Display of the save & cancel button next to a catalogue
r1175 #include <memory>
Adaptation to the shared pointers of catalogue controller
r1176 #include <DBCatalogue.h>
Display of the save & cancel button next to a catalogue
r1175 #include <QBoxLayout>
#include <QToolButton>
const auto VALIDATION_BUTTON_ICON_SIZE = 12;
Edition of catalogues from the inspector
r1180 /// Column in the tree widget where the apply and cancel buttons must appear
const auto APPLY_CANCEL_BUTTONS_COLUMN = 1;
Display catalogues and events with CatalogueAPI
r1162 struct CatalogueTreeWidgetItem::CatalogueTreeWidgetItemPrivate {
Adaptation to the shared pointers of catalogue controller
r1176 std::shared_ptr<DBCatalogue> m_Catalogue;
Display catalogues and events with CatalogueAPI
r1162
Adaptation to the shared pointers of catalogue controller
r1176 CatalogueTreeWidgetItemPrivate(std::shared_ptr<DBCatalogue> catalogue) : m_Catalogue(catalogue)
{
}
Display catalogues and events with CatalogueAPI
r1162 };
Adaptation to the shared pointers of catalogue controller
r1176 CatalogueTreeWidgetItem::CatalogueTreeWidgetItem(std::shared_ptr<DBCatalogue> catalogue, int type)
Display catalogues and events with CatalogueAPI
r1162 : QTreeWidgetItem(type),
impl{spimpl::make_unique_impl<CatalogueTreeWidgetItemPrivate>(catalogue)}
{
Rename a catalogue
r1173 setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsEditable);
Display catalogues and events with CatalogueAPI
r1162 }
QVariant CatalogueTreeWidgetItem::data(int column, int role) const
{
Display of the save & cancel button next to a catalogue
r1175 if (column == 0) {
switch (role) {
case Qt::EditRole: // fallthrough
case Qt::DisplayRole:
Adaptation to the shared pointers of catalogue controller
r1176 return impl->m_Catalogue->getName();
Display of the save & cancel button next to a catalogue
r1175 default:
break;
}
Display catalogues and events with CatalogueAPI
r1162 }
return QTreeWidgetItem::data(column, role);
}
Rename a catalogue
r1173 void CatalogueTreeWidgetItem::setData(int column, int role, const QVariant &value)
{
if (role == Qt::EditRole && column == 0) {
auto newName = value.toString();
Adaptation to the shared pointers of catalogue controller
r1176 if (newName != impl->m_Catalogue->getName()) {
Display of the save & cancel button next to a catalogue
r1175 setText(0, newName);
Adaptation to the shared pointers of catalogue controller
r1176 impl->m_Catalogue->setName(newName);
Display of the save & cancel button next to a catalogue
r1175 setHasChanges(true);
}
Rename a catalogue
r1173 }
else {
QTreeWidgetItem::setData(column, role, value);
}
}
Adaptation to the shared pointers of catalogue controller
r1176 std::shared_ptr<DBCatalogue> CatalogueTreeWidgetItem::catalogue() const
Display catalogues and events with CatalogueAPI
r1162 {
return impl->m_Catalogue;
}
Display of the save & cancel button next to a catalogue
r1175
void CatalogueTreeWidgetItem::setHasChanges(bool value)
{
if (value) {
Edition of catalogues from the inspector
r1180 if (treeWidget()->itemWidget(this, APPLY_CANCEL_BUTTONS_COLUMN) == nullptr) {
auto widet = new QWidget{treeWidget()};
auto layout = new QHBoxLayout{widet};
layout->setContentsMargins(0, 0, 0, 0);
layout->setSpacing(0);
auto btnValid = new QToolButton{widet};
btnValid->setIcon(QIcon{":/icones/save"});
btnValid->setIconSize(QSize{VALIDATION_BUTTON_ICON_SIZE, VALIDATION_BUTTON_ICON_SIZE});
btnValid->setAutoRaise(true);
QObject::connect(btnValid, &QToolButton::clicked, [this]() { setHasChanges(false); });
layout->addWidget(btnValid);
auto btnDiscard = new QToolButton{widet};
btnDiscard->setIcon(QIcon{":/icones/discard"});
btnDiscard->setIconSize(
QSize{VALIDATION_BUTTON_ICON_SIZE, VALIDATION_BUTTON_ICON_SIZE});
btnDiscard->setAutoRaise(true);
QObject::connect(btnDiscard, &QToolButton::clicked, [this]() { setHasChanges(false); });
layout->addWidget(btnDiscard);
treeWidget()->setItemWidget(this, APPLY_CANCEL_BUTTONS_COLUMN, {widet});
}
Display of the save & cancel button next to a catalogue
r1175 }
else {
// Note: the widget is destroyed
Edition of catalogues from the inspector
r1180 treeWidget()->setItemWidget(this, APPLY_CANCEL_BUTTONS_COLUMN, nullptr);
Display of the save & cancel button next to a catalogue
r1175 }
}
Edition of catalogues from the inspector
r1180
void CatalogueTreeWidgetItem::refresh()
{
emitDataChanged();
}