/* * Copyright 2013 Sebastian Kügler * * 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 2.010-1301, USA. */ import QtQuick 2.0 import org.kde.plasma.core 2.0 as PlasmaCore import org.kde.plasma.components 2.0 as PlasmaComponents import org.kde.plasma.extras 2.0 as PlasmaExtras import org.kde.qtextracomponents 2.0 as QtExtras import org.kde.draganddrop 2.0 as DragAndDrop // MousePage PlasmaComponents.Page { id: dragPage property int _h: 48 property bool isDragging: false anchors { fill: parent margins: _s } PlasmaExtras.Title { id: dlabel anchors { left: parent.left; right: parent.right; top: parent.top; } text: "Drag & Drop" } Column { id: dragCol width: (parent.width-_h)/2 height: parent.height anchors { left: parent.left; top: parent.top; topMargin: itemHeight/2 } spacing: _h/4 property int itemHeight: _h*1.5 DragItem { text: "Image and URL" icon: "image-png" height: parent.itemHeight DragAndDrop.DragArea { objectName: "imageandurl" anchors { fill: parent; } //delegateImage: "akonadi" mimeData.url: "http://plasma.kde.org" onDragStarted: { isDragging = true; print(" drag started for " + objectName); ooo.text = objectName } onDrop: { isDragging = false; print(" item dropped " + objectName); ooo.text = objectName } //Rectangle { anchors.fill: parent; color: "blue"; opacity: 0.4; } } } DragItem { text: "Delegate Image" icon: "image-png" height: parent.itemHeight DragAndDrop.DragArea { objectName: "image" anchors { fill: parent; } //delegateImage: "akonadi" //mimeData.url: "http://plasma.kde.org" onDragStarted: { isDragging = true; print(" drag started for " + objectName); ooo.text = objectName } onDrop: { isDragging = false; print(" item dropped " + objectName); ooo.text = objectName } //Rectangle { anchors.fill: parent; color: "green"; opacity: 0.4; } } } DragItem { text: "HTML" icon: "text-html" height: parent.itemHeight DragAndDrop.DragArea { objectName: "html" anchors { fill: parent; } mimeData.html: "One Two Three Four Five " onDragStarted: { isDragging = true; print(" drag started for " + objectName); ooo.text = objectName } onDrop: { isDragging = false; print(" item dropped " + objectName); ooo.text = objectName } } } DragItem { text: "Color" icon: "preferences-color" height: parent.itemHeight DragAndDrop.DragArea { objectName: "color" anchors { fill: parent; } mimeData.color: "orange" onDragStarted: { isDragging = true; print(" drag started for " + objectName); ooo.text = objectName } onDrop: { isDragging = false; print(" item dropped " + objectName); ooo.text = objectName //mimeData. } } } DragItem { text: "Lots of Stuff" icon: "ksplash" height: parent.itemHeight DragAndDrop.DragArea { id: dragArea2 objectName: "stuff" // width: parent.width / 2 // height: dropArea.height / 2 anchors.fill: parent mimeData.text: "Clownfish" mimeData.html: "

Swimming in a Sea of Cheese

Primus->perform();

" mimeData.color: "darkred" mimeData.url: "http://plasma.kde.org" mimeData.urls: ["http://planetkde.org", "http://fsfe.org", "http://techbase.kde.org", "http://qt-project.org"] //Rectangle { anchors.fill: parent; color: "yellow"; opacity: 0.6; } onDragStarted: { isDragging = true; print(" drag started for " + objectName); ooo.text = objectName } onDrop: { isDragging = false; print(" item dropped " + objectName); ooo.text = objectName } } } PlasmaComponents.Label { id: ooo } } DragAndDrop.DropArea { id: dropArea //width: parent.width- / 2 //visible: false anchors { right: parent.right; left: dragCol.right; bottom: parent.bottom; top: parent.top; margins: _h/2 } PlasmaComponents.ListItem { id: dropHightlight anchors.fill: parent opacity: 0 PropertyAnimation { properties: "opacity"; easing.type: Easing.Linear; duration: 2000; } } Rectangle { id: clr; anchors.fill: parent; color: "transparent"; opacity: color != "transparent" ? 1 : 0; } PlasmaComponents.Label { id: ilabel font.pointSize: _h / 2 text: "Drop here." opacity: isDragging ? 0.7 : 0 anchors.centerIn: parent horizontalAlignment: Text.AlignCenter PropertyAnimation { properties: "opacity"; easing.type: Easing.Linear; duration: 2000; } } PlasmaComponents.Label { id: slabel font.pointSize: _h / 4 //text: "Drop here." //opacity: isDragging ? 1 : 0 //onTextChanged: print("droparea changed to " + text) anchors.top: parent.top anchors.right: parent.right anchors.left: parent.left //horizontalAlignment: Text.AlignCenter } onDragEnter: { // slabel.text = "drop item here"; dropHightlight.opacity = 1; } onDragLeave: { // slabel.text = "drop left"; dropHightlight.opacity = 0; } onDrop: { var txt = event.mimeData.html; txt += event.mimeData.text; if (event.mimeData.url != "") { txt += "
Url: " + event.mimeData.url; } var i = 0; var u; for (u in event.mimeData.urls) { txt += "
Url " + i + " : " + event.mimeData.urls[i]; i++; } // print("COLOR: " + event.mimeData.color); if (event.mimeData.hasColor()) { clr.color = event.mimeData.color; } else { clr.color = "transparent"; } slabel.text = txt dropHightlight.opacity = 0.5; } } }