as Dialog, it searches for a Layout for size hints

This commit is contained in:
Marco Martin 2014-05-29 16:00:10 +02:00
parent 63e78f0901
commit ab1ffcde8b
2 changed files with 116 additions and 6 deletions

View File

@ -38,6 +38,9 @@
#include <Plasma/Corona> #include <Plasma/Corona>
#include <Plasma/PluginLoader> #include <Plasma/PluginLoader>
//Unfortunately QWINDOWSIZE_MAX is not exported
#define DIALOGSIZE_MAX ((1<<24)-1)
namespace PlasmaQuick namespace PlasmaQuick
{ {
@ -50,10 +53,20 @@ public:
~ConfigViewPrivate(); ~ConfigViewPrivate();
void init(); void init();
void updateMinimumWidth();
void updateMinimumHeight();
void updateMaximumWidth();
void updateMaximumHeight();
void mainItemLoaded();
ConfigView *q; ConfigView *q;
QWeakPointer <Plasma::Applet> applet; QWeakPointer <Plasma::Applet> applet;
ConfigModel *configModel; ConfigModel *configModel;
Plasma::Corona *corona; Plasma::Corona *corona;
//Attached Layout property of mainItem, if any
QWeakPointer <QObject> mainItemLayout;
}; };
ConfigViewPrivate::ConfigViewPrivate(Plasma::Applet *appl, ConfigView *view) ConfigViewPrivate::ConfigViewPrivate(Plasma::Applet *appl, ConfigView *view)
@ -107,6 +120,99 @@ void ConfigViewPrivate::init()
delete component; delete component;
} }
void ConfigViewPrivate::updateMinimumWidth()
{
if (mainItemLayout) {
q->setMinimumWidth(mainItemLayout.data()->property("minimumWidth").toInt());
//Sometimes setMinimumWidth doesn't actually resize: Qt bug?
q->setWidth(qMax(q->width(), q->minimumWidth()));
} else {
q->setMinimumWidth(-1);
}
}
void ConfigViewPrivate::updateMinimumHeight()
{
if (mainItemLayout) {
q->setMinimumHeight(mainItemLayout.data()->property("minimumHeight").toInt());
//Sometimes setMinimumHeight doesn't actually resize: Qt bug?
q->setHeight(qMax(q->height(), q->minimumHeight()));
} else {
q->setMinimumHeight(-1);
}
}
void ConfigViewPrivate::updateMaximumWidth()
{
if (mainItemLayout) {
const int hint = mainItemLayout.data()->property("maximumWidth").toInt();
if (hint > 0) {
q->setMaximumWidth(hint);
} else {
q->setMaximumWidth(DIALOGSIZE_MAX);
}
} else {
q->setMaximumWidth(DIALOGSIZE_MAX);
}
}
void ConfigViewPrivate::updateMaximumHeight()
{
if (mainItemLayout) {
const int hint = mainItemLayout.data()->property("maximumHeight").toInt();
if (hint > 0) {
q->setMaximumHeight(hint);
} else {
q->setMaximumHeight(DIALOGSIZE_MAX);
}
} else {
q->setMaximumHeight(DIALOGSIZE_MAX);
}
}
void ConfigViewPrivate::mainItemLoaded()
{
if (applet) {
KConfigGroup cg = applet.data()->config();
cg = KConfigGroup(&cg, "ConfigDialog");
q->resize(cg.readEntry("DialogWidth", q->width()), cg.readEntry("DialogHeight", q->height()));
}
//Extract the representation's Layout, if any
QObject *layout = 0;
//Search a child that has the needed Layout properties
//HACK: here we are not type safe, but is the only way to access to a pointer of Layout
foreach (QObject *child, q->rootObject()->children()) {
//find for the needed property of Layout: minimum/maximum/preferred sizes and fillWidth/fillHeight
if (child->property("minimumWidth").isValid() && child->property("minimumHeight").isValid() &&
child->property("preferredWidth").isValid() && child->property("preferredHeight").isValid() &&
child->property("maximumWidth").isValid() && child->property("maximumHeight").isValid() &&
child->property("fillWidth").isValid() && child->property("fillHeight").isValid()
) {
layout = child;
}
}
mainItemLayout = layout;
if (layout) {
QObject::connect(layout, SIGNAL(minimumWidthChanged()), q, SLOT(updateMinimumWidth()));
QObject::connect(layout, SIGNAL(minimumHeightChanged()), q, SLOT(updateMinimumHeight()));
QObject::connect(layout, SIGNAL(maximumWidthChanged()), q, SLOT(updateMaximumWidth()));
QObject::connect(layout, SIGNAL(maximumHeightChanged()), q, SLOT(updateMaximumHeight()));
updateMinimumWidth();
updateMinimumHeight();
updateMaximumWidth();
updateMaximumHeight();
}
}
ConfigView::ConfigView(Plasma::Applet *applet, QWindow *parent) ConfigView::ConfigView(Plasma::Applet *applet, QWindow *parent)
: QQuickView(parent), : QQuickView(parent),
d(new ConfigViewPrivate(applet, this)) d(new ConfigViewPrivate(applet, this))
@ -115,6 +221,11 @@ ConfigView::ConfigView(Plasma::Applet *applet, QWindow *parent)
qmlRegisterType<ConfigModel>("org.kde.plasma.configuration", 2, 0, "ConfigModel"); qmlRegisterType<ConfigModel>("org.kde.plasma.configuration", 2, 0, "ConfigModel");
qmlRegisterType<ConfigCategory>("org.kde.plasma.configuration", 2, 0, "ConfigCategory"); qmlRegisterType<ConfigCategory>("org.kde.plasma.configuration", 2, 0, "ConfigCategory");
connect(applet, &QObject::destroyed, this, &ConfigView::close); connect(applet, &QObject::destroyed, this, &ConfigView::close);
connect(this, &QQuickView::statusChanged, [=](QQuickView::Status status) {
if (status == QQuickView::Ready) {
d->mainItemLoaded();
}
});
} }
ConfigView::~ConfigView() ConfigView::~ConfigView()
@ -130,12 +241,6 @@ ConfigView::~ConfigView()
void ConfigView::init() void ConfigView::init()
{ {
setSource(QUrl::fromLocalFile(d->corona->package().filePath("appletconfigurationui"))); setSource(QUrl::fromLocalFile(d->corona->package().filePath("appletconfigurationui")));
if (d->applet) {
KConfigGroup cg = d->applet.data()->config();
cg = KConfigGroup(&cg, "ConfigDialog");
resize(cg.readEntry("DialogWidth", width()), cg.readEntry("DialogHeight", height()));
}
} }
ConfigModel *ConfigView::configModel() const ConfigModel *ConfigView::configModel() const

View File

@ -80,6 +80,11 @@ protected:
private: private:
ConfigViewPrivate *const d; ConfigViewPrivate *const d;
Q_PRIVATE_SLOT(d, void updateMinimumWidth())
Q_PRIVATE_SLOT(d, void updateMinimumHeight())
Q_PRIVATE_SLOT(d, void updateMaximumWidth())
Q_PRIVATE_SLOT(d, void updateMaximumHeight())
}; };
} }