Mercurial > minori
view include/gui/widgets/sidebar.h @ 150:ffa535b6d630
*: avoid usage of std::[pair,tuple]
https://arne-mertz.de/2017/03/smelly-pair-tuple/
it's better to use real structures and such where variables are easily known...
also apparently using [] on structs is actually valid? I had no idea.
author | Paper <mrpapersonic@gmail.com> |
---|---|
date | Tue, 14 Nov 2023 16:27:33 -0500 |
parents | 80f49f623d30 |
children | 862d0d8619f6 |
line wrap: on
line source
#ifndef __gui__sidebar_h #define __gui__sidebar_h #include <QItemSelectionModel> #include <QListWidget> class QListWidgetItem; class SideBar final : public QListWidget { Q_OBJECT public: SideBar(QWidget* parent = nullptr); QListWidgetItem* AddItem(QString name, QIcon icon = QIcon()); QListWidgetItem* AddSeparator(); int GetCurrentItem(); bool IndexIsSeparator(QModelIndex index) const; static QIcon CreateIcon(const char* file); void SetBackgroundColor(QColor color); signals: void CurrentItemChanged(int index); public slots: void SetCurrentItem(int index); protected: virtual void mouseMoveEvent(QMouseEvent* event) override; QItemSelectionModel::SelectionFlags selectionCommand(const QModelIndex& index, const QEvent* event) const override; int RemoveSeparatorsFromIndex(int index); int AddSeparatorsToIndex(int index); }; #endif // __gui__sidebar_h