/* * 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. */ /**Documented API Inherits: Item Imports: QtQuick 1.1 org.kde.plasma.core 0.1 Description: Creates a simple plasma theme based text area. Like kates.. Properties: alias font: Sets the font for the text area. int inputMethodHints: bool errorHighlight: If it is true then the problematic lines will be highlighted. alias cursorPosition: Returns the cursor's position. alias horizontalAlignment: TODO alias verticalAlignment:TODO alias readOnly: If this property is set to true the text cannot be edited by user interaction. alias selectedText: This read-only property provides the text currently selected in the text edit. alias selectionEnd: The cursor position after the last character in the current selection. This property is read-only. property alias selectionStart: The cursor position before the first character in the current selection. This property is read-only. property alias text: The text to display property alias textFormat: The way the text property should be displayed. TextEdit.AutoText TextEdit.PlainText TextEdit.RichText TextEdit.StyledText alias wrapMode: Set this property to wrap the text to the TextEdit item's width. TextEdit.NoWrap - no wrapping will be performed. If the text contains insufficient newlines, then implicitWidth will exceed a set width. TextEdit.WordWrap - wrapping is done on word boundaries only. If a word is too long, implicitWidth will exceed a set width. TextEdit.WrapAnywhere - wrapping is done at any point on a line, even if it occurs in the middle of a word. TextEdit.Wrap - if possible, wrapping occurs at a word boundary; otherwise it will occur at the appropriate point on the line, even in the middle of a word. string placeholderText:TODO alias interactive: This property describes whether the user can interact with the Flickable. A user cannot drag or flick a Flickable that is not interactive. This property is useful for temporarily disabling flicking. This allows special interaction with Flickable's children; for example, you might want to freeze a flickable map while scrolling through a pop-up dialog that is a child of the Flickable. alias contentMaxWidth: Sets the maximum width that the contents can have. alias contentMaxHeight: Sets the maximum height that the contents can have. property real scrollWidth: Sets the step that the scrollwidth will move. alias activeFocus: This property indicates whether the item has active focus. An item with active focus will receive keyboard input. **/ import QtQuick 1.1 import org.kde.plasma.core 0.1 as PlasmaCore import "private" as Private Item { id: textArea // Common API property alias font: textEdit.font // alias to textEdit.font property int inputMethodHints property bool errorHighlight property alias cursorPosition: textEdit.cursorPosition property alias horizontalAlignment: textEdit.cursorPosition property alias verticalAlignment: textEdit.cursorPosition property alias readOnly: textEdit.readOnly property alias selectedText: textEdit.selectedText // read-only property alias selectionEnd: textEdit.selectionEnd // read-only property alias selectionStart: textEdit.selectionStart // read-only property alias text: textEdit.text property alias textFormat: textEdit.textFormat // enumeration property alias wrapMode: textEdit.wrapMode // enumeration property string placeholderText // functions function copy() { textEdit.copy(); } function paste() { textEdit.paste(); } function cut() { textEdit.cut(); } function select(start, end) { textEdit.select(start, end); } function selectAll() { textEdit.selectAll(); } function selectWord() { textEdit.selectWord(); } function positionAt(pos) { textEdit.positionAt(pos); } function positionToRectangle(pos) { textEdit.positionToRectangle(pos); } // Plasma API property alias interactive: flickArea.interactive property alias contentMaxWidth: textEdit.width property alias contentMaxHeight: textEdit.height // Set active focus to it's internal textInput. // Overriding QtQuick.Item forceActiveFocus function. function forceActiveFocus() { textEdit.forceActiveFocus(); } // Overriding QtQuick.Item activeFocus property. property alias activeFocus: textEdit.activeFocus opacity: enabled ? 1.0 : 0.5 Private.TextFieldFocus { id: hover state: textArea.activeFocus ? "focus" : (mouseWatcher.containsMouse ? "hover" : "hidden") anchors.fill: base } MouseArea { id: mouseWatcher anchors.fill: hover hoverEnabled: true } PlasmaCore.FrameSvgItem { id: base // TODO: see what is the best policy for margins anchors { fill: parent } imagePath: "widgets/lineedit" prefix: "base" } Flickable { id: flickArea anchors { fill: parent leftMargin: 2 * base.margins.left rightMargin: 2 * base.margins.right + (verticalScroll.visible ? verticalScroll.width : 0) topMargin: 2 * base.margins.top bottomMargin: 2 * base.margins.bottom + (horizontalScroll.visible ? verticalScroll.width : 0) } interactive: !verticalScroll.interactive //textArea.activeFocus contentWidth: { if (textEdit.wrapMode == TextEdit.NoWrap) return textEdit.paintedWidth; return Math.min(textEdit.paintedWidth, textEdit.width); } contentHeight: Math.min(textEdit.paintedHeight, textEdit.height) clip: true TextEdit { id: textEdit width: flickArea.width height: flickArea.height clip: true wrapMode: TextEdit.Wrap enabled: textArea.enabled 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 color: theme.viewTextColor selectByMouse: verticalScroll.interactive onCursorPositionChanged: { if (cursorRectangle.x < flickArea.contentX) { flickArea.contentX = cursorRectangle.x; return; } if (cursorRectangle.x > flickArea.contentX + flickArea.width - cursorRectangle.width) { flickArea.contentX = cursorRectangle.x - cursorRectangle.width; return; } if (cursorRectangle.y < flickArea.contentY) { flickArea.contentY = cursorRectangle.y; return; } if (cursorRectangle.y > flickArea.contentY + flickArea.height - cursorRectangle.height) { flickArea.contentY = cursorRectangle.y - cursorRectangle.height; return; } } // Proxying keys events is not required by the // common API but is desired in the plasma API. Keys.onPressed: textArea.Keys.pressed(event); Keys.onReleased: textArea.Keys.released(event); Text { anchors.fill: parent text: textArea.placeholderText visible: textEdit.text == "" && !textArea.activeFocus opacity: 0.5 } onActiveFocusChanged: { if (!textField.activeFocus) { textInput.closeSoftwareInputPanel() } } } } ScrollBar { id: horizontalScroll anchors { bottom: parent.bottom left: parent.left right: flickArea.right } enabled: parent.enabled flickableItem: flickArea orientation: Qt.Horizontal stepSize: textEdit.font.pixelSize } ScrollBar { id: verticalScroll anchors { right: parent.right top: parent.top bottom: flickArea.bottom } enabled: parent.enabled flickableItem: flickArea orientation: Qt.Vertical stepSize: textEdit.font.pixelSize } }