/* * Copyright (C) 2011 by Daker Fernandes Pinheiro * * 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 2.0 import org.kde.plasma.core 0.1 as PlasmaCore import org.kde.qtextracomponents 0.1 import "EditBubble.js" as EditBubbleHelper Item { id: textField // Common API property bool errorHighlight: false // TODO property string placeholderText property alias inputMethodHints: textInput.inputMethodHints property alias font: textInput.font property alias cursorPosition: textInput.cursorPosition property alias readOnly: textInput.readOnly property alias echoMode: textInput.echoMode // Supports TextInput.Normal,TextInput.Password, TextInput.NoEcho, TextInput.PasswordEchoOnEdit property alias passwordCharacter: textInput.passwordCharacter property alias acceptableInput: textInput.acceptableInput // read-only property alias inputMask: textInput.inputMask property alias validator: textInput.validator property alias selectedText: textInput.selectedText // read-only property alias selectionEnd: textInput.selectionEnd // read-only property alias selectionStart: textInput.selectionStart // read-only property alias text: textInput.text property alias maximumLength: textInput.maximumLength //Plasma api property bool clearButtonShown: false function copy() { textInput.copy(); } function paste() { textInput.paste(); } function cut() { textInput.cut(); } function select(start, end) { textInput.select(start, end); } function selectAll() { textInput.selectAll(); } function selectWord() { textInput.selectWord(); } function positionAt(pos) { textInput.positionAt(pos); } function positionToRectangle(pos) { textInput.positionToRectangle(pos); } // Set active focus to it's internal textInput. // Overriding QtQuick.Item forceActiveFocus function. function forceActiveFocus() { textInput.forceActiveFocus(); } // Overriding QtQuick.Item activeFocus property. property alias activeFocus: textInput.activeFocus // TODO: fix default size implicitWidth: theme.defaultFont.mSize.width*12 implicitHeight: theme.defaultFont.mSize.height*1.6 // TODO: needs to define if there will be specific graphics for // disabled text fields opacity: enabled ? 1.0 : 0.5 TextFieldFocus { id: hover state: textInput.activeFocus ? "focus" : (mouseWatcher.containsMouse ? "hover" : "hidden") anchors.fill: base } PlasmaCore.FrameSvgItem { id: base // TODO: see what is the correct policy for margins anchors.fill: parent imagePath: "widgets/lineedit" prefix: "base" } MouseArea { id: mouseWatcher anchors.fill: hover hoverEnabled: false } Text { anchors { left: parent.left right: parent.right verticalCenter: parent.verticalCenter leftMargin: 2 * base.margins.left rightMargin: 2 * base.margins.right } text: placeholderText visible: textInput.text == "" && !textField.activeFocus // XXX: using textColor and low opacity for theming placeholderText color: theme.buttonTextColor opacity: 0.5 elide: Text.ElideRight clip: true font.capitalization: theme.defaultFont.capitalization font.family: theme.defaultFont.family font.italic: theme.defaultFont.italic font.letterSpacing: theme.defaultFont.letterSpacing font.pointSize: theme.defaultFont.pointSize font.strikeout: theme.defaultFont.strikeout font.underline: theme.defaultFont.underline font.weight: theme.defaultFont.weight font.wordSpacing: theme.defaultFont.wordSpacing } EditBubble { id: editBubble; iconSize: 32 } TextInput { id: textInput parent: mouseEventListener anchors { left: parent.left right: parent.right verticalCenter: parent.verticalCenter // TODO: see what is the correct policy for margins leftMargin: 2 * base.margins.left rightMargin: 2 * base.margins.right } selectByMouse: true passwordCharacter: "•" color: theme.buttonTextColor enabled: textField.enabled clip: true // Proxying keys events is not required by the // common API but is desired in the plasma API. Keys.forwardTo: textField } PlasmaCore.IconItem { parent: mouseEventListener // reparent to the MouseFilter for MouseArea to work id: clearButton source: "edit-clear-locationbar-rtl" height: Math.max(textInput.height, theme.smallIconSize) width: height opacity: (textInput.text != "" && clearButtonShown) ? 1 : 0 Behavior on opacity { NumberAnimation { duration: 250 easing.type: Easing.InOutQuad } } anchors { right: parent.right rightMargin: y verticalCenter: textInput.verticalCenter } MouseArea { anchors.fill: parent onClicked: { textInput.text = "" textInput.forceActiveFocus() } } } MouseEventListener { id: mouseEventListener anchors.fill: parent onPressAndHold: { EditBubbleHelper.placeEditBubble(mouse); editBubble.state = (textInput.activeFocus && (textInput.selectedText != "" || textInput.canPaste)) ? "expanded" : "collapsed"; } onPositionChanged: { EditBubbleHelper.placeEditBubble(mouse); } } onActiveFocusChanged: { if (!activeFocus) { editBubble.state = "collapsed"; } } }