121 lines
3.3 KiB
QML
121 lines
3.3 KiB
QML
|
/*
|
||
|
* Copyright 2014 Vishesh Handa <vhanda@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,
|
||
|
* 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 Library 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 QtQuick.Controls 1.1 as Controls
|
||
|
import QtQuick.Layouts 1.1
|
||
|
|
||
|
import org.kde.plasma.core 2.0 as PlasmaCore
|
||
|
|
||
|
ColumnLayout {
|
||
|
Controls.Label {
|
||
|
Layout.maximumWidth: mainLayout.width
|
||
|
wrapMode: Text.WordWrap
|
||
|
text: "Click on each coloured box to make a dialog popup. It should popup in the correct position. The popup should also move from one rectanlge to the other on hovering"
|
||
|
}
|
||
|
|
||
|
RowLayout {
|
||
|
id: mainLayout
|
||
|
Rectangle {
|
||
|
width: 300
|
||
|
height: 100
|
||
|
color: "red"
|
||
|
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onClicked: {
|
||
|
dialog.visualParent = parent;
|
||
|
dialog.visible = !dialog.visible;
|
||
|
}
|
||
|
onEntered: {
|
||
|
dialog.visualParent = parent;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Rectangle {
|
||
|
width: 300
|
||
|
height: 100
|
||
|
color: "blue"
|
||
|
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onClicked: {
|
||
|
dialog.visualParent = parent;
|
||
|
dialog.visible = !dialog.visible;
|
||
|
}
|
||
|
onEntered: {
|
||
|
dialog.visualParent = parent;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Rectangle {
|
||
|
width: 300
|
||
|
height: 100
|
||
|
color: "green"
|
||
|
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onClicked: {
|
||
|
dialog.visualParent = parent;
|
||
|
dialog.visible = !dialog.visible;
|
||
|
}
|
||
|
onEntered: {
|
||
|
dialog.visualParent = parent;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Rectangle {
|
||
|
width: 300
|
||
|
height: 100
|
||
|
color: "yellow"
|
||
|
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onClicked: {
|
||
|
dialog.visualParent = parent;
|
||
|
dialog.visible = !dialog.visible;
|
||
|
}
|
||
|
onEntered: {
|
||
|
dialog.visualParent = parent;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
PlasmaCore.Dialog {
|
||
|
id: dialog
|
||
|
location: PlasmaCore.Types.BottomEdge
|
||
|
visible: false
|
||
|
|
||
|
Rectangle {
|
||
|
color: "black"
|
||
|
width: 150
|
||
|
height: 150
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|