2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2020-06-30 16:01:37 -04:00
|
|
|
import QtMultimedia 5.13
|
2020-07-20 13:04:33 -04:00
|
|
|
import QtQuick.Dialogs 1.0
|
2020-06-24 13:23:49 +10:00
|
|
|
import "../components"
|
2020-05-27 19:06:41 -04:00
|
|
|
import "../../../../shared"
|
|
|
|
import "../../../../imports"
|
|
|
|
|
|
|
|
Rectangle {
|
2020-07-09 15:10:28 -04:00
|
|
|
id: rectangle
|
2020-07-14 13:40:58 +02:00
|
|
|
property alias textInput: txtData
|
2020-05-27 19:06:41 -04:00
|
|
|
border.width: 0
|
2020-07-09 15:10:28 -04:00
|
|
|
height: 52
|
2020-07-13 14:45:54 -04:00
|
|
|
color: Style.current.transparent
|
2020-05-27 19:06:41 -04:00
|
|
|
|
2020-07-02 14:49:02 -04:00
|
|
|
visible: chatsModel.activeChannel.chatType !== Constants.chatTypePrivateGroupChat || chatsModel.activeChannel.isMember(profileModel.profile.pubKey)
|
2020-06-15 13:41:19 -04:00
|
|
|
|
2020-07-10 15:02:57 -04:00
|
|
|
Audio {
|
|
|
|
id: sendMessageSound
|
|
|
|
source: "../../../../sounds/send_message.wav"
|
|
|
|
}
|
|
|
|
|
|
|
|
function interpretMessage(msg) {
|
|
|
|
if (msg === "/shrug") {
|
|
|
|
return "¯\\\\\\_(ツ)\\_/¯"
|
|
|
|
}
|
|
|
|
if (msg === "/tableflip") {
|
|
|
|
return "(╯°□°)╯︵ ┻━┻"
|
|
|
|
}
|
|
|
|
|
|
|
|
return msg
|
|
|
|
}
|
|
|
|
|
2020-08-03 10:01:47 -04:00
|
|
|
function sendMsg(event){
|
|
|
|
if(chatColumn.isImage){
|
|
|
|
chatsModel.sendImage(sendImageArea.image);
|
|
|
|
}
|
|
|
|
var msg = chatsModel.plainText(Emoji.deparse(txtData.text).trim()).trim()
|
|
|
|
if(msg.length > 0){
|
|
|
|
msg = interpretMessage(msg)
|
|
|
|
chatsModel.sendMessage(msg, chatColumn.isReply ? SelectedMessage.messageId : "", Utils.isOnlyEmoji(msg) ? Constants.emojiType : Constants.messageType);
|
|
|
|
txtData.text = "";
|
|
|
|
if(event) event.accepted = true
|
|
|
|
sendMessageSound.stop()
|
|
|
|
Qt.callLater(sendMessageSound.play);
|
|
|
|
}
|
|
|
|
chatColumn.hideExtendedArea();
|
|
|
|
}
|
2020-07-14 13:40:58 +02:00
|
|
|
|
2020-08-03 10:01:47 -04:00
|
|
|
function onEnter(event){
|
2020-07-02 14:49:02 -04:00
|
|
|
if (event.modifiers === Qt.NoModifier && (event.key === Qt.Key_Enter || event.key === Qt.Key_Return)) {
|
2020-08-03 10:01:47 -04:00
|
|
|
sendMsg(event);
|
2020-06-24 22:01:13 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-20 13:04:33 -04:00
|
|
|
FileDialog {
|
|
|
|
id: imageDialog
|
|
|
|
title: qsTr("Please choose an image")
|
|
|
|
folder: shortcuts.pictures
|
|
|
|
nameFilters: [
|
|
|
|
qsTr("Image files (*.jpg *.jpeg *.png)")
|
|
|
|
]
|
|
|
|
onAccepted: {
|
|
|
|
chatColumn.showImageArea(imageDialog.fileUrls);
|
|
|
|
txtData.forceActiveFocus();
|
|
|
|
}
|
|
|
|
onRejected: {
|
|
|
|
chatColumn.hideExtendedArea();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-09 15:10:28 -04:00
|
|
|
ScrollView {
|
|
|
|
id: scrollView
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.right: sendBtns.left
|
|
|
|
anchors.rightMargin: 0
|
2020-07-31 11:25:45 -04:00
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
topPadding: Style.current.padding
|
|
|
|
|
2020-07-09 15:10:28 -04:00
|
|
|
StyledTArea {
|
2020-07-31 17:30:55 -04:00
|
|
|
textFormat: Text.RichText
|
2020-07-09 15:10:28 -04:00
|
|
|
id: txtData
|
|
|
|
text: ""
|
|
|
|
selectByMouse: true
|
2020-07-31 11:25:45 -04:00
|
|
|
wrapMode: TextArea.Wrap
|
2020-07-09 15:10:28 -04:00
|
|
|
font.pixelSize: 15
|
|
|
|
//% "Type a message..."
|
|
|
|
placeholderText: qsTrId("type-a-message")
|
|
|
|
Keys.onPressed: onEnter(event)
|
|
|
|
background: Rectangle {
|
2020-07-22 16:16:06 -04:00
|
|
|
color: Style.current.transparent
|
2020-07-02 14:49:02 -04:00
|
|
|
}
|
2020-06-24 13:23:49 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-09 15:10:28 -04:00
|
|
|
ChatButtons {
|
|
|
|
id: sendBtns
|
2020-07-16 16:23:00 +10:00
|
|
|
height: parent.height
|
2020-07-09 15:10:28 -04:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: parent.right
|
|
|
|
addToChat: function (text) {
|
|
|
|
txtData.insert(txtData.length, text)
|
|
|
|
}
|
2020-08-03 10:01:47 -04:00
|
|
|
onSend: function(){
|
|
|
|
sendMsg(false)
|
|
|
|
}
|
2020-07-09 15:10:28 -04:00
|
|
|
}
|
2020-05-28 15:41:31 -04:00
|
|
|
}
|
|
|
|
/*##^##
|
|
|
|
Designer {
|
2020-07-10 17:47:31 -04:00
|
|
|
D{i:0;formeditorColor:"#ffffff"}
|
2020-05-28 15:41:31 -04:00
|
|
|
}
|
|
|
|
##^##*/
|