support for containment type in the desktop file

add a test panel containment
This commit is contained in:
Marco Martin 2013-02-14 19:11:17 +01:00
parent 14e3446a10
commit 4e44bc4c31
17 changed files with 162 additions and 10 deletions

View File

@ -210,6 +210,7 @@ QList<Plasma::Containment *> Corona::importLayout(const KConfigGroup &conf)
Containment *Corona::containmentForScreen(int screen, int desktop) const
{
foreach (Containment *containment, d->containments) {
kWarning() << "AAAAA"<<containment<<containment->screen()<<containment->location();
if (containment->screen() == screen &&
(desktop < 0 || containment->desktop() == desktop) &&
(containment->containmentType() == Containment::DesktopContainment ||

View File

@ -15,4 +15,5 @@ Comment[x-test]=xxPlasma applet container and background painterxx
[PropertyDef::X-Plasma-ContainmentCategories]
Type=QStringList
[PropertyDef::X-Plasma-ContainmentType]
Type=QString

View File

@ -68,6 +68,22 @@ DeclarativeAppletScript::~DeclarativeAppletScript()
bool DeclarativeAppletScript::init()
{
Plasma::Containment *pc = qobject_cast<Plasma::Containment *>(applet());
if (pc) {
QString type = pc->pluginInfo().property("X-Plasma-ContainmentType").toString();
if (type == "DesktopContainment") {
pc->setContainmentType(Plasma::Containment::DesktopContainment);
} else if (type == "PanelContainment") {
pc->setContainmentType(Plasma::Containment::PanelContainment);
} if (type == "CustomContainment") {
pc->setContainmentType(Plasma::Containment::CustomContainment);
} else if (type == "CustomPanelContainment") {
pc->setContainmentType(Plasma::Containment::CustomPanelContainment);
}
}
m_qmlObject = new QmlObject(applet());
m_qmlObject->setInitializationDelayed(true);
//FIXME: what replaced this?
@ -134,9 +150,7 @@ bool DeclarativeAppletScript::init()
a->setProperty("graphicObject", QVariant::fromValue(m_interface));
qDebug() << "Graphic object created:" << a << a->property("graphicObject");
//Is this a containment?
Plasma::Containment *pc = qobject_cast<Plasma::Containment *>(a);
//Create the ToolBox
if (pc) {
Plasma::Package pkg = Plasma::PluginLoader::self()->loadPackage("Plasma/Generic");
pkg.setPath("org.kde.toolbox");

View File

@ -50,7 +50,6 @@ target_link_libraries(testplasma2
install(TARGETS testplasma2 ${INSTALL_TARGETS_DEFAULT_ARGS})
add_subdirectory(applets)
add_subdirectory(containments)
add_subdirectory(qmlpackages)
installPackage(testcontainment org.kde.testcontainment)
installPackage(testapplet org.kde.testapplet)
installPackage(testcomponentsapplet org.kde.testcomponentsapplet)

View File

@ -0,0 +1,3 @@
installPackage(testapplet org.kde.testapplet)
installPackage(testcomponentsapplet org.kde.testcomponentsapplet)

View File

@ -0,0 +1,3 @@
installPackage(testcontainment org.kde.testcontainment)
installPackage(testpanel org.kde.testpanel)

View File

@ -0,0 +1,113 @@
/*
* Copyright 2013 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.
*/
import QtQuick 2.0
import org.kde.plasma.core 0.1 as PlasmaCore
import org.kde.plasma.components 0.1 as PlasmaComponents
Item {
id: root
width: 640
height: 480
property Item toolBox
Connections {
target: plasmoid
onAppletAdded: {
var container = appletContainerComponent.createObject(root)
container.visible = true
print("Applet added: " + applet)
applet.parent = container
container.applet = applet
applet.anchors.fill= applet.parent
applet.visible = true
}
}
Component {
id: appletContainerComponent
PlasmaCore.FrameSvgItem {
id: frame
x: 50
y: 50
width: large + frame.margins.left + frame.margins.right
height: large + frame.margins.top + frame.margins.bottom
property alias applet: appletContainer.children
property int small: 90
property int large: 400
property int tm: 0
property int lm: 0
imagePath: applet.length > 0 && applet[0].backgroundHints == 0 ? "" : "widgets/background"
onImagePathChanged: {
// Reposition applet so it fits into the frame
if (imagePath == "") {
frame.x = frame.x + lm;
frame.y = frame.y + tm;
} else {
// Cache values, so we can subtract them when the background is removed
frame.lm = frame.margins.left;
frame.tm = frame.margins.top;
frame.x = frame.x - frame.margins.left;
frame.y = frame.y - frame.margins.top;
}
}
MouseArea {
anchors.fill: parent
drag.target: parent
onClicked: {
var s = (frame.width == frame.large) ? frame.small : frame.large;
frame.x = s
frame.height = s
frame.width = s
}
}
Item {
id: appletContainer
anchors {
fill: parent
leftMargin: frame.margins.left
rightMargin: parent.margins.right
topMargin: parent.margins.top
bottomMargin: parent.margins.bottom
}
}
PlasmaComponents.BusyIndicator {
z: 1000
visible: applet.length > 0 && applet[0].busy
running: visible
anchors.centerIn: parent
}
}
}
Component.onCompleted: {
print("Test Containment loaded")
print(plasmoid)
}
}

View File

@ -0,0 +1,18 @@
[Desktop Entry]
Encoding=UTF-8
Keywords=
Name=Panel Test
Type=Service
X-KDE-ServiceTypes=Plasma/Applet,Plasma/Containment
X-Plasma-API=declarativeappletscript
X-KDE-ParentApp=
X-KDE-PluginInfo-Author=Marco Martin
X-KDE-PluginInfo-Category=
X-KDE-PluginInfo-Email=mart@kde.org
X-KDE-PluginInfo-License=GPLv2+
X-KDE-PluginInfo-Name=org.kde.testpanel
X-KDE-PluginInfo-Version=
X-KDE-PluginInfo-Website=
X-Plasma-MainScript=ui/main.qml
X-Plasma-ContainmentType=PanelContainment

View File

@ -115,7 +115,7 @@ void DesktopCorona::checkScreen(int screen, bool signalWhenExists)
void DesktopCorona::checkDesktop(/*Activity *activity,*/ bool signalWhenExists, int screen, int desktop)
{
Plasma::Containment *c = /*activity->*/containmentForScreen(screen, desktop);
qWarning()<<"AAAAA"<<c<<c->formFactor();
//TODO: remove following when activities are restored
if (!c) {
c = addContainment("desktop");

View File

@ -28,7 +28,7 @@ class PanelView : public View
Q_OBJECT
public:
PanelView(Plasma::Corona *corona, QWindow *parent = 0);
explicit PanelView(Plasma::Corona *corona, QWindow *parent = 0);
virtual ~PanelView();
private:

View File

@ -31,7 +31,7 @@ class View : public QQuickView
Q_OBJECT
public:
View(Plasma::Corona *corona, QWindow *parent = 0);
explicit View(Plasma::Corona *corona, QWindow *parent = 0);
virtual ~View();
//FIXME: not super nice, but we have to be sure qml assignment is done after window flags