diff options
author | Treeki <treeki@gmail.com> | 2012-09-06 00:31:19 +0200 |
---|---|---|
committer | Treeki <treeki@gmail.com> | 2012-09-06 00:31:19 +0200 |
commit | 2e52bea24a65cf70380c4e13c2f9f1238f023e91 (patch) | |
tree | 771d4c0b74db52ebecde1af722714905a072b149 /lsseteditor.cpp | |
parent | f928869357765e3a73501064408bb7bc0ee363ef (diff) | |
download | LayoutStudio-2e52bea24a65cf70380c4e13c2f9f1238f023e91.tar.gz LayoutStudio-2e52bea24a65cf70380c4e13c2f9f1238f023e91.zip |
some black magic involving templates which doesn't even work, pushing so I can work on it at home
Diffstat (limited to '')
-rw-r--r-- | lsseteditor.cpp | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/lsseteditor.cpp b/lsseteditor.cpp new file mode 100644 index 0000000..bc63476 --- /dev/null +++ b/lsseteditor.cpp @@ -0,0 +1,60 @@ +#include "lsseteditor.h" +#include <QGridLayout> +#include <QLabel> + +_LSSetEditorBase::_LSSetEditorBase(int maxEntries, QWidget *parent) : + QWidget(parent) { + + m_maxEntries = maxEntries; + m_loadingThings = 0; +} + + +void _LSSetEditorBase::handleEntrySelected(int index) { + if (!m_loadingThings) + showEntry(index); +} + + +void _LSSetEditorBase::handleEntryCountChanged(int count) { + if (!m_loadingThings) { + int oldCount = m_chooser->count(); + if (oldCount == count) + return; + + changeEntryCountTo(count); + resizeDataListTo(count); + + // moving from 0 to something...? + if (oldCount == 0) { + m_chooser->setCurrentIndex(0); + showEntry(0); + } + + emit dataEdited(); + } +} + + +void _LSSetEditorBase::setup(QWidget *eWidget) { + m_loadingThings++; + + m_entryCount = new QSpinBox(this); + m_entryCount->setRange(0, m_maxEntries); + connect(m_entryCount, SIGNAL(valueChanged(int)), SLOT(handleEntryCountChanged(int))); + + m_chooser = new QComboBox(this); + connect(m_chooser, SIGNAL(currentIndexChanged(int)), SLOT(handleEntrySelected(int))); + + QGridLayout *layout = new QGridLayout(this); + + layout->addWidget(new QLabel("Count:", this), 0, 0, 1, 1); + layout->addWidget(m_entryCount, 0, 1, 1, 1); + layout->setColumnMinimumWidth(2, 10); + layout->addWidget(m_chooser, 0, 3, 1, 1); + layout->setColumnStretch(3, 1); + + layout->addWidget(eWidget, 1, 0, 1, 4); + + m_loadingThings--; +} |