compactRepresentation property
qml popupapplets that export this property to the root item (a component) will use that instead of an icon
This commit is contained in:
parent
736a56c631
commit
1471d27cfa
@ -129,6 +129,7 @@ set(declarative_appletscript_SRCS
|
||||
common/extension_io.cpp
|
||||
common/javascriptaddonpackagestructure.cpp
|
||||
common/declarativescriptenv.cpp
|
||||
declarative/declarativeitemcontainer.cpp
|
||||
declarative/packageaccessmanager.cpp
|
||||
declarative/packageaccessmanagerfactory.cpp
|
||||
plasmoid/abstractjsappletscript.cpp
|
||||
|
@ -0,0 +1,89 @@
|
||||
/***************************************************************************
|
||||
* Copyright 2011 Marco Martin <mart@kde.org> *
|
||||
* *
|
||||
* This program is free software; you can redistribute it and/or modify *
|
||||
* it under the terms of the GNU General Public License as published by *
|
||||
* the Free Software Foundation; either version 2 of the License, or *
|
||||
* (at your option) any later version. *
|
||||
* *
|
||||
* This program is distributed in the hope that it will be useful, *
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||
* GNU General Public License for more details. *
|
||||
* *
|
||||
* You should have received a copy of the GNU General Public License *
|
||||
* along with this program; if not, write to the *
|
||||
* Free Software Foundation, Inc., *
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA . *
|
||||
***************************************************************************/
|
||||
|
||||
#include "declarativeitemcontainer_p.h"
|
||||
|
||||
#include <KDebug>
|
||||
|
||||
DeclarativeItemContainer::DeclarativeItemContainer(QGraphicsItem *parent)
|
||||
: QGraphicsWidget(parent)
|
||||
{
|
||||
}
|
||||
|
||||
DeclarativeItemContainer::~DeclarativeItemContainer()
|
||||
{
|
||||
}
|
||||
|
||||
void DeclarativeItemContainer::setDeclarativeItem(QDeclarativeItem *item, bool reparent)
|
||||
{
|
||||
if (m_declarativeItem) {
|
||||
disconnect(m_declarativeItem.data(), 0, this, 0);
|
||||
}
|
||||
m_declarativeItem = item;
|
||||
if (reparent) {
|
||||
static_cast<QGraphicsItem *>(item)->setParentItem(this);
|
||||
}
|
||||
setMinimumWidth(item->implicitWidth());
|
||||
setMinimumHeight(item->implicitHeight());
|
||||
resize(item->width(), item->height());
|
||||
connect(m_declarativeItem.data(), SIGNAL(widthChanged()), this, SLOT(widthChanged()));
|
||||
connect(m_declarativeItem.data(), SIGNAL(heightChanged()), this, SLOT(heightChanged()));
|
||||
}
|
||||
|
||||
QDeclarativeItem *DeclarativeItemContainer::declarativeItem() const
|
||||
{
|
||||
return m_declarativeItem.data();
|
||||
}
|
||||
|
||||
void DeclarativeItemContainer::resizeEvent(QGraphicsSceneResizeEvent *event)
|
||||
{
|
||||
if (m_declarativeItem) {
|
||||
m_declarativeItem.data()->setProperty("width", event->newSize().width());
|
||||
m_declarativeItem.data()->setProperty("height", event->newSize().height());
|
||||
}
|
||||
}
|
||||
|
||||
void DeclarativeItemContainer::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
||||
{
|
||||
event->ignore();
|
||||
}
|
||||
|
||||
void DeclarativeItemContainer::widthChanged()
|
||||
{
|
||||
if (!m_declarativeItem) {
|
||||
return;
|
||||
}
|
||||
|
||||
QSizeF newSize(size());
|
||||
newSize.setWidth(m_declarativeItem.data()->width());
|
||||
resize(newSize);
|
||||
}
|
||||
|
||||
void DeclarativeItemContainer::heightChanged()
|
||||
{
|
||||
if (!m_declarativeItem) {
|
||||
return;
|
||||
}
|
||||
|
||||
QSizeF newSize(size());
|
||||
newSize.setHeight(m_declarativeItem.data()->height());
|
||||
resize(newSize);
|
||||
}
|
||||
|
||||
#include "declarativeitemcontainer_p.moc"
|
@ -0,0 +1,52 @@
|
||||
/***************************************************************************
|
||||
* Copyright 2011 Marco Martin <mart@kde.org> *
|
||||
* *
|
||||
* This program is free software; you can redistribute it and/or modify *
|
||||
* it under the terms of the GNU General Public License as published by *
|
||||
* the Free Software Foundation; either version 2 of the License, or *
|
||||
* (at your option) any later version. *
|
||||
* *
|
||||
* This program is distributed in the hope that it will be useful, *
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||
* GNU General Public License for more details. *
|
||||
* *
|
||||
* You should have received a copy of the GNU General Public License *
|
||||
* along with this program; if not, write to the *
|
||||
* Free Software Foundation, Inc., *
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA . *
|
||||
***************************************************************************/
|
||||
|
||||
#ifndef DECLARATIVEITEMCONTAINER_P
|
||||
#define DECLARATIVEITEMCONTAINER_P
|
||||
|
||||
#include <QDeclarativeItem>
|
||||
#include <QGraphicsObject>
|
||||
#include <QGraphicsWidget>
|
||||
#include <QGraphicsSceneResizeEvent>
|
||||
|
||||
|
||||
class DeclarativeItemContainer : public QGraphicsWidget
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
DeclarativeItemContainer(QGraphicsItem *parent = 0);
|
||||
~DeclarativeItemContainer();
|
||||
|
||||
void setDeclarativeItem(QDeclarativeItem *item, bool reparent = true);
|
||||
QDeclarativeItem *declarativeItem() const;
|
||||
|
||||
protected:
|
||||
void resizeEvent(QGraphicsSceneResizeEvent *event);
|
||||
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
||||
|
||||
protected Q_SLOTS:
|
||||
void widthChanged();
|
||||
void heightChanged();
|
||||
|
||||
private:
|
||||
QWeakPointer<QDeclarativeItem> m_declarativeItem;
|
||||
};
|
||||
|
||||
#endif
|
@ -50,6 +50,7 @@
|
||||
#include "plasmoid/themedsvg.h"
|
||||
|
||||
#include "common/scriptenv.h"
|
||||
#include "declarative/declarativeitemcontainer_p.h"
|
||||
#include "declarative/packageaccessmanagerfactory.h"
|
||||
#include "simplebindings/bytearrayclass.h"
|
||||
//not pretty but only way to avoid a double Q_DECLARE_METATYPE(QVariant) in dataengine.h
|
||||
@ -82,6 +83,7 @@ bool DeclarativeAppletScript::init()
|
||||
{
|
||||
m_declarativeWidget = new Plasma::DeclarativeWidget(applet());
|
||||
m_declarativeWidget->setInitializationDelayed(true);
|
||||
connect(m_declarativeWidget, SIGNAL(finished()), this, SLOT(qmlCreationFinished()));
|
||||
KGlobal::locale()->insertCatalog("plasma_applet_" % description().pluginName());
|
||||
|
||||
//make possible to import extensions from the package
|
||||
@ -138,6 +140,31 @@ bool DeclarativeAppletScript::init()
|
||||
return true;
|
||||
}
|
||||
|
||||
void DeclarativeAppletScript::qmlCreationFinished()
|
||||
{
|
||||
//If it's a popupapplet and the root object has a "compactRepresentation" component, use that instead of the icon
|
||||
Plasma::Applet *a = applet();
|
||||
Plasma::PopupApplet *pa = qobject_cast<Plasma::PopupApplet *>(a);
|
||||
if (pa) {
|
||||
QDeclarativeComponent *iconComponent = m_declarativeWidget->rootObject()->property("compactRepresentation").value<QDeclarativeComponent *>();
|
||||
if (iconComponent) {
|
||||
QDeclarativeItem *declarativeIcon = qobject_cast<QDeclarativeItem *>(iconComponent->create(m_declarativeWidget->engine()->rootContext()));
|
||||
if (declarativeIcon) {
|
||||
pa->setPopupIcon(QIcon());
|
||||
QGraphicsLinearLayout *lay = new QGraphicsLinearLayout(a);
|
||||
lay->setContentsMargins(0, 0, 0, 0);
|
||||
DeclarativeItemContainer *declarativeItemContainer = new DeclarativeItemContainer(a);
|
||||
lay->addItem(declarativeItemContainer);
|
||||
declarativeItemContainer->setDeclarativeItem(declarativeIcon);
|
||||
} else {
|
||||
pa->setPopupIcon(a->icon());
|
||||
}
|
||||
} else {
|
||||
pa->setPopupIcon(a->icon());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void DeclarativeAppletScript::collectGarbage()
|
||||
{
|
||||
if (!m_engine) {
|
||||
|
@ -78,6 +78,7 @@ public Q_SLOTS:
|
||||
void extenderItemRestored(Plasma::ExtenderItem* item);
|
||||
void collectGarbage();
|
||||
void configChanged();
|
||||
void qmlCreationFinished();
|
||||
|
||||
protected:
|
||||
bool init();
|
||||
|
Loading…
Reference in New Issue
Block a user