summaryrefslogtreecommitdiff
path: root/src/libs/utils/detailswidget.cpp
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@nokia.com>2009-10-02 10:12:32 +0200
committerFriedemann Kleint <Friedemann.Kleint@nokia.com>2009-10-02 10:12:32 +0200
commit9dd0a108e30b297ce9b735026304c4dfd5bf21d3 (patch)
tree6c4f1ce72fb0253de4cfc128e01754716b5b2c6d /src/libs/utils/detailswidget.cpp
parent9bef75f8f9cba9903cd180ea837d312985540950 (diff)
downloadqt-creator-9dd0a108e30b297ce9b735026304c4dfd5bf21d3.tar.gz
Fix the Creator widgets Designer plugin, add DetailsWidgets.
Polish the DetailsWidget for that purpose, add properties, make it survive without widgets, add a container extension.
Diffstat (limited to 'src/libs/utils/detailswidget.cpp')
-rw-r--r--src/libs/utils/detailswidget.cpp66
1 files changed, 52 insertions, 14 deletions
diff --git a/src/libs/utils/detailswidget.cpp b/src/libs/utils/detailswidget.cpp
index c69a3bd2f9..1641d09995 100644
--- a/src/libs/utils/detailswidget.cpp
+++ b/src/libs/utils/detailswidget.cpp
@@ -3,21 +3,23 @@
#include <QtGui/QGridLayout>
#include <QtCore/QStack>
+#include <QtGui/QLabel>
+#include <QtGui/QGridLayout>
#include <QtGui/QPainter>
using namespace Utils;
DetailsWidget::DetailsWidget(QWidget *parent)
: QWidget(parent),
+ m_summaryLabel(new QLabel(this)),
+ m_detailsButton(new DetailsButton(this)),
m_widget(0),
- m_toolWidget(0)
+ m_toolWidget(0),
+ m_grid(new QGridLayout(this))
+
{
- m_grid = new QGridLayout(this);
- //m_grid->setMargin(0);
- m_summaryLabel = new QLabel(this);
m_summaryLabel->setTextInteractionFlags(Qt::TextSelectableByMouse);
m_summaryLabel->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
- m_detailsButton = new DetailsButton(this);
m_grid->addWidget(m_summaryLabel, 0, 0, 2, 0);
m_grid->addWidget(m_detailsButton, 1, 2);
@@ -45,8 +47,8 @@ void DetailsWidget::paintEvent(QPaintEvent *paintEvent)
if (!m_detailsButton->isToggled())
return;
- QRect detailsGeometry = m_detailsButton->geometry();
- QRect widgetGeometry = m_widget->geometry();
+ const QRect detailsGeometry = m_detailsButton->geometry();
+ const QRect widgetGeometry = m_widget ? m_widget->geometry() : QRect(x(), y() + height(), width(), 0);
QPoint tl(detailsGeometry.topLeft());
tl += QPoint(-3, -3);
@@ -85,29 +87,65 @@ void DetailsWidget::setSummaryText(const QString &text)
m_summaryLabel->setText(text);
}
+QString DetailsWidget::summaryText() const
+{
+ return m_summaryLabel->text();
+}
+
+bool DetailsWidget::expanded() const
+{
+ return m_detailsButton->isToggled();
+}
+
+void DetailsWidget::setExpanded(bool v)
+{
+ if (expanded() != v)
+ m_detailsButton->animateClick();
+}
+
+QWidget *DetailsWidget::widget() const
+{
+ return m_widget;
+}
+
void DetailsWidget::setWidget(QWidget *widget)
{
if (m_widget == widget)
return;
- if (m_widget)
+ if (m_widget) {
m_grid->removeWidget(m_widget);
- m_grid->addWidget(widget, 2, 0, 1, 3);
- m_widget = widget;
- m_widget->setVisible(m_detailsButton->isToggled());
+ m_widget = 0;
+ }
+ if (widget) {
+ m_grid->addWidget(widget, 2, 0, 1, 3);
+ m_widget = widget;
+ m_widget->setVisible(m_detailsButton->isToggled());
+ }
}
void DetailsWidget::setToolWidget(QWidget *widget)
{
if (m_toolWidget == widget)
return;
- if (m_toolWidget)
+ if (m_toolWidget) {
m_grid->removeWidget(m_toolWidget);
- m_grid->addWidget(widget, 1, 1);
- m_toolWidget = widget;
+ m_toolWidget = 0;
+ }
+ if (widget) {
+ m_grid->addWidget(widget, 1, 1);
+ m_toolWidget = widget;
+ }
+}
+
+QWidget *DetailsWidget::toolWidget() const
+{
+ return m_toolWidget;
}
void DetailsWidget::fixUpLayout()
{
+ if (!m_widget)
+ return;
QWidget *parent = m_widget;
QStack<QWidget *> widgets;
while((parent = parent->parentWidget()) && parent && parent->layout()) {