From d68b24188fd453bd8ca09e3035edc4faee74c6af Mon Sep 17 00:00:00 2001 From: Nicolas Werner Date: Thu, 9 Apr 2020 00:07:04 +0200 Subject: Size reply background by contents --- src/timeline/DelegateChooser.cpp | 21 +++++++++++---------- src/timeline/DelegateChooser.h | 6 +++++- 2 files changed, 16 insertions(+), 11 deletions(-) (limited to 'src/timeline') diff --git a/src/timeline/DelegateChooser.cpp b/src/timeline/DelegateChooser.cpp index 46ab6c0e..1f5fae7e 100644 --- a/src/timeline/DelegateChooser.cpp +++ b/src/timeline/DelegateChooser.cpp @@ -94,9 +94,9 @@ DelegateChooser::recalcChild() for (const auto choice : qAsConst(choices_)) { auto choiceValue = choice->roleValue(); if (!roleValue_.isValid() || !choiceValue.isValid() || choiceValue == roleValue_) { - if (child) { - child->setParentItem(nullptr); - child = nullptr; + if (child_) { + child_->setParentItem(nullptr); + child_ = nullptr; } choice->delegate()->create(incubator, QQmlEngine::contextForObject(this)); @@ -116,19 +116,20 @@ void DelegateChooser::DelegateIncubator::statusChanged(QQmlIncubator::Status status) { if (status == QQmlIncubator::Ready) { - chooser.child = dynamic_cast(object()); - if (chooser.child == nullptr) { + chooser.child_ = dynamic_cast(object()); + if (chooser.child_ == nullptr) { nhlog::ui()->error("Delegate has to be derived of Item!"); return; } - chooser.child->setParentItem(&chooser); - connect(chooser.child, &QQuickItem::heightChanged, &chooser, [this]() { - chooser.setHeight(chooser.child->height()); + chooser.child_->setParentItem(&chooser); + connect(chooser.child_, &QQuickItem::heightChanged, &chooser, [this]() { + chooser.setHeight(chooser.child_->height()); }); - chooser.setHeight(chooser.child->height()); - QQmlEngine::setObjectOwnership(chooser.child, + chooser.setHeight(chooser.child_->height()); + QQmlEngine::setObjectOwnership(chooser.child_, QQmlEngine::ObjectOwnership::JavaScriptOwnership); + emit chooser.childChanged(); } else if (status == QQmlIncubator::Error) { for (const auto &e : errors()) diff --git a/src/timeline/DelegateChooser.h b/src/timeline/DelegateChooser.h index 68ebeb04..2524b068 100644 --- a/src/timeline/DelegateChooser.h +++ b/src/timeline/DelegateChooser.h @@ -45,18 +45,22 @@ class DelegateChooser : public QQuickItem public: Q_PROPERTY(QQmlListProperty choices READ choices CONSTANT) Q_PROPERTY(QVariant roleValue READ roleValue WRITE setRoleValue NOTIFY roleValueChanged) + Q_PROPERTY(QQuickItem *child READ child NOTIFY childChanged) QQmlListProperty choices(); QVariant roleValue() const; void setRoleValue(const QVariant &value); + QQuickItem *child() const { return child_; } + void recalcChild(); void componentComplete() override; signals: void roleChanged(); void roleValueChanged(); + void childChanged(); private: struct DelegateIncubator : public QQmlIncubator @@ -72,7 +76,7 @@ private: QVariant roleValue_; QList choices_; - QQuickItem *child = nullptr; + QQuickItem *child_ = nullptr; DelegateIncubator incubator{*this}; static void appendChoice(QQmlListProperty *, DelegateChoice *); -- cgit 1.5.1