get rid of the ugly async syncgraphicObject()
This commit is contained in:
parent
5562c65127
commit
b5a65921d0
@ -92,6 +92,7 @@ bool DeclarativeAppletScript::init()
|
|||||||
|
|
||||||
m_qmlObject->setQmlPath(mainScript());
|
m_qmlObject->setQmlPath(mainScript());
|
||||||
|
|
||||||
|
|
||||||
if (!m_qmlObject->engine() || !m_qmlObject->engine()->rootContext() || !m_qmlObject->engine()->rootContext()->isValid() || m_qmlObject->mainComponent()->isError()) {
|
if (!m_qmlObject->engine() || !m_qmlObject->engine()->rootContext() || !m_qmlObject->engine()->rootContext()->isValid() || m_qmlObject->mainComponent()->isError()) {
|
||||||
QString reason;
|
QString reason;
|
||||||
foreach (QQmlError error, m_qmlObject->mainComponent()->errors()) {
|
foreach (QQmlError error, m_qmlObject->mainComponent()->errors()) {
|
||||||
@ -102,8 +103,10 @@ bool DeclarativeAppletScript::init()
|
|||||||
}
|
}
|
||||||
|
|
||||||
Plasma::Applet *a = applet();
|
Plasma::Applet *a = applet();
|
||||||
|
|
||||||
Plasma::Containment *cont = qobject_cast<Plasma::Containment *>(a);
|
Plasma::Containment *cont = qobject_cast<Plasma::Containment *>(a);
|
||||||
|
|
||||||
|
|
||||||
if (cont) {
|
if (cont) {
|
||||||
m_interface = new ContainmentInterface(this);
|
m_interface = new ContainmentInterface(this);
|
||||||
//fail? so it's a normal Applet
|
//fail? so it's a normal Applet
|
||||||
@ -115,6 +118,8 @@ bool DeclarativeAppletScript::init()
|
|||||||
this, SLOT(activate()));
|
this, SLOT(activate()));
|
||||||
|
|
||||||
setupObjects();
|
setupObjects();
|
||||||
|
m_qmlObject->completeInitialization();
|
||||||
|
a->setGraphicObject(m_qmlObject->rootObject());
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -123,7 +128,6 @@ void DeclarativeAppletScript::qmlCreationFinished()
|
|||||||
{
|
{
|
||||||
//If it's a popupapplet and the root object has a "compactRepresentation" component, use that instead of the icon
|
//If it's a popupapplet and the root object has a "compactRepresentation" component, use that instead of the icon
|
||||||
Plasma::Applet *a = applet();
|
Plasma::Applet *a = applet();
|
||||||
a->setGraphicObject(m_qmlObject->rootObject());
|
|
||||||
|
|
||||||
//TODO: access rootItem from m_interface
|
//TODO: access rootItem from m_interface
|
||||||
//m_self->setProperty("rootItem", QVariant::fromValue(m_qmlObject->rootObject()));
|
//m_self->setProperty("rootItem", QVariant::fromValue(m_qmlObject->rootObject()));
|
||||||
|
@ -58,20 +58,7 @@ void View::setContainment(Plasma::Containment *cont)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
connect(cont, SIGNAL(graphicObjectChanged()), this, SLOT(syncGraphicObject()));
|
|
||||||
|
|
||||||
if (m_containment.data()->graphicObject()) {
|
if (m_containment.data()->graphicObject()) {
|
||||||
syncGraphicObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Plasma::Containment *View::containment() const
|
|
||||||
{
|
|
||||||
return m_containment.data();
|
|
||||||
}
|
|
||||||
|
|
||||||
void View::syncGraphicObject()
|
|
||||||
{
|
|
||||||
qDebug() << "using as graphic containment" << m_containment.data()->graphicObject()<<m_containment.data();
|
qDebug() << "using as graphic containment" << m_containment.data()->graphicObject()<<m_containment.data();
|
||||||
if (!m_containment || !m_containment.data()->graphicObject()) {
|
if (!m_containment || !m_containment.data()->graphicObject()) {
|
||||||
qWarning() << "Containment not valid (yet?)";
|
qWarning() << "Containment not valid (yet?)";
|
||||||
@ -81,6 +68,12 @@ void View::syncGraphicObject()
|
|||||||
m_containment.data()->graphicObject()->setProperty("visible", false);
|
m_containment.data()->graphicObject()->setProperty("visible", false);
|
||||||
m_containment.data()->graphicObject()->setProperty("parent", QVariant::fromValue(rootObject()));
|
m_containment.data()->graphicObject()->setProperty("parent", QVariant::fromValue(rootObject()));
|
||||||
rootObject()->setProperty("containment", QVariant::fromValue(m_containment.data()->graphicObject()));
|
rootObject()->setProperty("containment", QVariant::fromValue(m_containment.data()->graphicObject()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Plasma::Containment *View::containment() const
|
||||||
|
{
|
||||||
|
return m_containment.data();
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "moc_view.cpp"
|
#include "moc_view.cpp"
|
||||||
|
@ -37,9 +37,6 @@ public:
|
|||||||
void setContainment(Plasma::Containment *cont);
|
void setContainment(Plasma::Containment *cont);
|
||||||
Plasma::Containment *containment() const;
|
Plasma::Containment *containment() const;
|
||||||
|
|
||||||
protected Q_SLOTS:
|
|
||||||
void syncGraphicObject();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Plasma::Package m_package;
|
Plasma::Package m_package;
|
||||||
QWeakPointer<Plasma::Containment> m_containment;
|
QWeakPointer<Plasma::Containment> m_containment;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user