Add HScrollableTextArea and make SendBox use it

This commit is contained in:
miruka 2019-04-28 11:50:46 -04:00
parent 25badb693d
commit 80067b5060
2 changed files with 53 additions and 40 deletions

View File

@ -0,0 +1,24 @@
import QtQuick 2.7
import QtQuick.Controls 2.2
ScrollView {
property alias placeholderText: textArea.placeholderText
property alias text: textArea.text
property alias area: textArea
default property alias textAreaData: textArea.data
clip: true
TextArea {
id: textArea
readOnly: ! visible
selectByMouse: true
wrapMode: TextEdit.Wrap
font.family: HStyle.fontFamily.sans
font.pixelSize: HStyle.fontSize.normal
color: HStyle.colors.foreground
}
}

View File

@ -14,7 +14,7 @@ Base.HGlassRectangle {
Layout.maximumHeight: pageStack.height / 2 Layout.maximumHeight: pageStack.height / 2
color: Base.HStyle.chat.sendBox.background color: Base.HStyle.chat.sendBox.background
RowLayout { Base.HRowLayout {
anchors.fill: parent anchors.fill: parent
spacing: 0 spacing: 0
@ -24,50 +24,39 @@ Base.HGlassRectangle {
dimension: root.Layout.minimumHeight dimension: root.Layout.minimumHeight
} }
ScrollView { Base.HScrollableTextArea {
Layout.fillHeight: true Layout.fillHeight: true
Layout.fillWidth: true Layout.fillWidth: true
id: sendBoxScrollView
clip: true
TextArea { id: textArea
property string typedText: text placeholderText: qsTr("Type a message...")
area.focus: true
id: textArea function setTyping(typing) {
placeholderText: qsTr("Type a message...") Backend.clientManager.clients[chatPage.userId]
wrapMode: TextEdit.Wrap .setTypingState(chatPage.roomId, typing)
selectByMouse: true
readOnly: ! visible
font.family: "Roboto"
font.pixelSize: 16
focus: true
function setTyping(typing) {
Backend.clientManager.clients[chatPage.userId]
.setTypingState(chatPage.roomId, typing)
}
onTypedTextChanged: setTyping(Boolean(text))
onEditingFinished: setTyping(false) // when lost focus
Keys.onReturnPressed: {
event.accepted = true
if (event.modifiers & Qt.ShiftModifier ||
event.modifiers & Qt.ControlModifier ||
event.modifiers & Qt.AltModifier) {
textArea.insert(textArea.cursorPosition, "\n")
return
}
if (textArea.text === "") { return }
Backend.clientManager.clients[chatPage.userId]
.sendMarkdown(chatPage.roomId, textArea.text)
textArea.clear()
}
Keys.onEnterPressed: Keys.onReturnPressed(event) // numpad enter
} }
onTextChanged: setTyping(Boolean(text))
area.onEditingFinished: setTyping(false) // when lost focus
Keys.onReturnPressed: {
event.accepted = true
if (event.modifiers & Qt.ShiftModifier ||
event.modifiers & Qt.ControlModifier ||
event.modifiers & Qt.AltModifier) {
textArea.insert(textArea.cursorPosition, "\n")
return
}
if (textArea.text === "") { return }
Backend.clientManager.clients[chatPage.userId]
.sendMarkdown(chatPage.roomId, textArea.text)
textArea.clear()
}
Keys.onEnterPressed: Keys.onReturnPressed(event) // numpad enter
} }
} }
} }