2011-11-24 22:59:48 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2011 by Sebastian Kügler <sebas@kde.org>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library 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 1.1
|
|
|
|
import org.kde.plasma.core 0.1 as PlasmaCore
|
|
|
|
import org.kde.qtextracomponents 0.1
|
|
|
|
|
|
|
|
PlasmaCore.FrameSvgItem {
|
|
|
|
id: editBubble
|
|
|
|
objectName: "editBubble"
|
|
|
|
property int iconSize: 32;
|
2011-12-01 03:49:28 +01:00
|
|
|
|
2011-11-24 22:59:48 +01:00
|
|
|
imagePath: "dialogs/background"
|
2012-03-30 20:08:42 -03:00
|
|
|
width: 4*iconSize
|
|
|
|
height: 2*iconSize
|
2011-12-01 02:27:18 +01:00
|
|
|
z: 100000
|
2011-11-25 05:07:13 +01:00
|
|
|
//anchors { top: parent.bottom; right: parent.right; topMargin: -(iconSize/4); }
|
2011-11-24 22:59:48 +01:00
|
|
|
|
2011-11-25 05:07:13 +01:00
|
|
|
// fully dynamic show / hide
|
|
|
|
//state: (textInput.activeFocus && (textInput.selectedText != "" || textInput.canPaste)) ? "expanded" : "collapsed";
|
|
|
|
// state controlled externally
|
|
|
|
state: "collapsed"
|
2011-11-24 22:59:48 +01:00
|
|
|
|
|
|
|
Row {
|
|
|
|
id: buttonRow
|
2012-03-30 20:08:42 -03:00
|
|
|
spacing: iconSize
|
2011-11-24 22:59:48 +01:00
|
|
|
anchors { horizontalCenter: parent.horizontalCenter; verticalCenter: parent.verticalCenter; margins: 8; }
|
|
|
|
height: editBubble.iconSize
|
|
|
|
QIconItem {
|
2012-03-30 20:08:42 -03:00
|
|
|
id: copyIcon
|
|
|
|
icon: QIcon("edit-copy")
|
2011-11-24 22:59:48 +01:00
|
|
|
width: editBubble.iconSize
|
|
|
|
height: editBubble.iconSize
|
2012-03-30 20:08:42 -03:00
|
|
|
enabled: textInput.selectedText != ""
|
2011-11-24 22:59:48 +01:00
|
|
|
MouseArea {
|
2012-03-30 20:08:42 -03:00
|
|
|
anchors.centerIn: parent
|
|
|
|
width: 2*parent.width
|
|
|
|
height: 2*parent.height
|
|
|
|
onClicked: { textField.copy(); editBubble.state = "collapsed"; }
|
|
|
|
onPressed: PropertyAnimation { target: copyIcon; properties: "scale";
|
2011-11-24 22:59:48 +01:00
|
|
|
from: 1.0; to: 0.9;
|
|
|
|
duration: 175; easing.type: Easing.OutExpo; }
|
2012-03-30 20:08:42 -03:00
|
|
|
onReleased: PropertyAnimation { target: copyIcon; properties: "scale";
|
2011-11-24 22:59:48 +01:00
|
|
|
from: 0.9; to: 1.0;
|
|
|
|
duration: 175; easing.type: Easing.OutExpo; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
QIconItem {
|
2012-03-30 20:08:42 -03:00
|
|
|
id: pasteIcon
|
|
|
|
icon: QIcon("edit-paste")
|
2011-11-24 22:59:48 +01:00
|
|
|
width: editBubble.iconSize
|
|
|
|
height: editBubble.iconSize
|
2012-03-30 20:08:42 -03:00
|
|
|
enabled: textInput.canPaste
|
2011-11-24 22:59:48 +01:00
|
|
|
MouseArea {
|
2012-03-30 20:08:42 -03:00
|
|
|
anchors.centerIn: parent;
|
|
|
|
width: 2*parent.width
|
|
|
|
height: 2*parent.height
|
|
|
|
onClicked: { textField.paste(); editBubble.state = "collapsed"; }
|
|
|
|
onPressed: PropertyAnimation { target: pasteIcon; properties: "scale";
|
2011-11-24 22:59:48 +01:00
|
|
|
from: 1.0; to: 0.9;
|
|
|
|
duration: 175; easing.type: Easing.OutExpo; }
|
2012-03-30 20:08:42 -03:00
|
|
|
onReleased: PropertyAnimation { target: pasteIcon; properties: "scale";
|
2011-11-24 22:59:48 +01:00
|
|
|
from: 0.9; to: 1.0;
|
|
|
|
duration: 175; easing.type: Easing.OutExpo; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
states: [
|
|
|
|
State {
|
|
|
|
id: expanded
|
|
|
|
name: "expanded";
|
|
|
|
PropertyChanges { target: editBubble; opacity: 1.0; scale: 1.0 }
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
id: collapsed
|
|
|
|
name: "collapsed";
|
|
|
|
PropertyChanges { target: editBubble; opacity: 0; scale: 0.9 }
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
transitions: [
|
|
|
|
Transition {
|
|
|
|
from: "collapsed"; to: "expanded"
|
|
|
|
ParallelAnimation {
|
|
|
|
PropertyAnimation { properties: "opacity"; duration: 175; easing.type: Easing.InExpo; }
|
|
|
|
PropertyAnimation { properties: "scale"; duration: 175; easing.type: Easing.InExpo; }
|
|
|
|
}
|
|
|
|
},
|
|
|
|
Transition {
|
|
|
|
from: "expanded"; to: "collapsed"
|
|
|
|
ParallelAnimation {
|
|
|
|
PropertyAnimation { properties: "opacity"; duration: 175; easing.type: Easing.OutExpo; }
|
|
|
|
PropertyAnimation { properties: "scale"; duration: 100; easing.type: Easing.OutExpo; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|