2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2021-04-28 11:30:41 -04:00
|
|
|
import QtGraphicalEffects 1.0
|
2020-05-27 17:09:12 -04:00
|
|
|
import "../../../shared"
|
2020-09-29 11:06:57 +02:00
|
|
|
import "../../../shared/status"
|
2020-05-25 16:34:26 -04:00
|
|
|
import "../../../imports"
|
2020-06-25 12:27:46 -04:00
|
|
|
import "./components"
|
2020-05-27 17:59:34 -04:00
|
|
|
import "./ChatColumn"
|
2020-09-29 11:06:57 +02:00
|
|
|
import "./ChatColumn/ChatComponents"
|
2020-07-20 15:29:57 -04:00
|
|
|
import "./data"
|
2020-10-28 18:44:09 +11:00
|
|
|
import "../Wallet"
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2020-05-26 14:16:07 -04:00
|
|
|
StackLayout {
|
2020-07-10 11:37:23 -04:00
|
|
|
id: chatColumnLayout
|
2020-11-19 14:30:09 -04:00
|
|
|
|
2020-05-26 14:16:07 -04:00
|
|
|
property int chatGroupsListViewCount: 0
|
2020-07-20 13:04:33 -04:00
|
|
|
|
2020-07-09 13:47:36 -04:00
|
|
|
property bool isReply: false
|
2020-07-20 13:04:33 -04:00
|
|
|
property bool isImage: false
|
|
|
|
|
|
|
|
property bool isExtendedInput: isReply || isImage
|
|
|
|
|
2020-07-15 12:19:25 -04:00
|
|
|
property bool isConnected: false
|
2020-08-10 15:06:46 +02:00
|
|
|
property string contactToRemove: ""
|
|
|
|
|
2021-04-28 11:30:41 -04:00
|
|
|
property var doNotShowAddToContactBannerToThose: ([])
|
|
|
|
|
2020-09-23 09:28:20 +02:00
|
|
|
property var onActivated: function () {
|
|
|
|
chatInput.textInput.forceActiveFocus(Qt.MouseFocusReason)
|
|
|
|
}
|
|
|
|
|
2021-04-28 11:30:41 -04:00
|
|
|
property string activeChatId: chatsModel.activeChannel.id
|
|
|
|
property bool isBlocked: profileModel.contacts.isContactBlocked(activeChatId)
|
2021-05-05 14:19:55 -04:00
|
|
|
|
2021-05-05 16:14:45 -04:00
|
|
|
property alias input: chatInput
|
2020-12-02 11:10:22 +02:00
|
|
|
|
2020-09-23 09:28:20 +02:00
|
|
|
Component.onCompleted: {
|
|
|
|
chatInput.textInput.forceActiveFocus(Qt.MouseFocusReason)
|
|
|
|
}
|
|
|
|
|
2020-05-26 14:16:07 -04:00
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
2020-05-28 08:56:43 -04:00
|
|
|
Layout.minimumWidth: 300
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2020-06-05 10:50:39 -04:00
|
|
|
currentIndex: chatsModel.activeChannelIndex > -1 && chatGroupsListViewCount > 0 ? 0 : 1
|
2020-05-26 11:55:32 -04:00
|
|
|
|
2021-02-03 17:38:05 -04:00
|
|
|
|
2021-02-15 11:29:16 -05:00
|
|
|
property var idMap: ({})
|
2021-03-23 11:57:19 -04:00
|
|
|
property var suggestionsObj: ([])
|
2021-02-03 17:38:05 -04:00
|
|
|
|
|
|
|
function addSuggestionFromMessageList(i){
|
|
|
|
const contactAddr = chatsModel.messageList.getMessageData(i, "publicKey");
|
|
|
|
if(idMap[contactAddr]) return;
|
2021-03-23 11:57:19 -04:00
|
|
|
suggestionsObj.push({
|
|
|
|
alias: chatsModel.messageList.getMessageData(i, "alias"),
|
|
|
|
ensName: chatsModel.messageList.getMessageData(i, "ensName"),
|
|
|
|
address: contactAddr,
|
|
|
|
identicon: chatsModel.messageList.getMessageData(i, "identicon"),
|
|
|
|
localNickname: chatsModel.messageList.getMessageData(i, "localName")
|
|
|
|
})
|
|
|
|
chatInput.suggestionsList.append(suggestionsObj[suggestionsObj.length - 1]);
|
2021-02-03 17:38:05 -04:00
|
|
|
idMap[contactAddr] = true;
|
|
|
|
}
|
|
|
|
|
2021-03-23 11:57:19 -04:00
|
|
|
function populateSuggestions() {
|
2021-02-03 16:13:05 -04:00
|
|
|
chatInput.suggestionsList.clear()
|
|
|
|
const len = chatsModel.suggestionList.rowCount()
|
|
|
|
|
2021-02-03 17:38:05 -04:00
|
|
|
idMap = {}
|
2021-02-03 16:13:05 -04:00
|
|
|
|
|
|
|
for (let i = 0; i < len; i++) {
|
|
|
|
const contactAddr = chatsModel.suggestionList.rowData(i, "address");
|
|
|
|
if(idMap[contactAddr]) continue;
|
2021-03-23 11:57:19 -04:00
|
|
|
suggestionsObj.push({
|
|
|
|
alias: chatsModel.suggestionList.rowData(i, "alias"),
|
|
|
|
ensName: chatsModel.suggestionList.rowData(i, "ensName"),
|
|
|
|
address: contactAddr,
|
2021-05-07 16:26:58 +10:00
|
|
|
identicon: getProfileImage(contactAddr, false, false) || chatsModel.suggestionList.rowData(i, "identicon"),
|
2021-03-23 11:57:19 -04:00
|
|
|
localNickname: chatsModel.suggestionList.rowData(i, "localNickname")
|
|
|
|
})
|
|
|
|
|
|
|
|
chatInput.suggestionsList.append(suggestionsObj[suggestionsObj.length - 1]);
|
2021-02-03 16:13:05 -04:00
|
|
|
idMap[contactAddr] = true;
|
|
|
|
}
|
|
|
|
const len2 = chatsModel.messageList.rowCount();
|
2021-02-15 11:29:16 -05:00
|
|
|
for (let f = 0; f < len2; f++) {
|
|
|
|
addSuggestionFromMessageList(f);
|
2021-02-03 16:13:05 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-23 12:13:39 -04:00
|
|
|
function showReplyArea() {
|
2020-07-20 13:04:33 -04:00
|
|
|
isReply = true;
|
|
|
|
isImage = false;
|
2020-09-29 11:06:57 +02:00
|
|
|
let replyMessageIndex = chatsModel.messageList.getMessageIndex(SelectedMessage.messageId);
|
|
|
|
if (replyMessageIndex === -1) return;
|
|
|
|
|
|
|
|
let userName = chatsModel.messageList.getMessageData(replyMessageIndex, "userName")
|
|
|
|
let message = chatsModel.messageList.getMessageData(replyMessageIndex, "message")
|
|
|
|
let identicon = chatsModel.messageList.getMessageData(replyMessageIndex, "identicon")
|
|
|
|
|
|
|
|
chatInput.showReplyArea(userName, message, identicon)
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
|
|
|
|
2020-09-29 11:06:57 +02:00
|
|
|
function requestAddressForTransaction(address, amount, tokenAddress, tokenDecimals = 18) {
|
2020-10-12 22:44:04 +11:00
|
|
|
amount = utilsModel.eth2Wei(amount.toString(), tokenDecimals)
|
2021-04-28 11:30:41 -04:00
|
|
|
chatsModel.transactions.requestAddress(activeChatId,
|
2020-12-06 11:24:28 -04:00
|
|
|
address,
|
|
|
|
amount,
|
|
|
|
tokenAddress)
|
2020-11-03 21:29:56 +11:00
|
|
|
txModalLoader.close()
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
2020-09-29 11:06:57 +02:00
|
|
|
function requestTransaction(address, amount, tokenAddress, tokenDecimals = 18) {
|
2020-10-12 22:44:04 +11:00
|
|
|
amount = utilsModel.eth2Wei(amount.toString(), tokenDecimals)
|
2021-04-28 11:30:41 -04:00
|
|
|
chatsModel.transactions.request(activeChatId,
|
2020-09-29 11:06:57 +02:00
|
|
|
address,
|
|
|
|
amount,
|
|
|
|
tokenAddress)
|
2020-11-03 21:29:56 +11:00
|
|
|
txModalLoader.close()
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
2020-09-29 11:06:57 +02:00
|
|
|
|
2020-12-03 23:58:36 +02:00
|
|
|
Connections {
|
2020-12-06 18:15:51 -04:00
|
|
|
target: profileModel.contacts
|
2020-12-03 23:58:36 +02:00
|
|
|
onContactListChanged: {
|
2021-04-28 11:30:41 -04:00
|
|
|
isBlocked = profileModel.contacts.isContactBlocked(activeChatId);
|
2020-12-03 23:58:36 +02:00
|
|
|
}
|
|
|
|
}
|
2021-04-07 14:26:03 -04:00
|
|
|
|
|
|
|
Timer {
|
|
|
|
id: timer
|
|
|
|
}
|
2020-07-20 13:04:33 -04:00
|
|
|
|
2020-05-26 14:16:07 -04:00
|
|
|
ColumnLayout {
|
2020-07-09 13:47:36 -04:00
|
|
|
spacing: 0
|
2020-05-26 11:55:32 -04:00
|
|
|
|
2021-04-07 14:26:03 -04:00
|
|
|
TopBar {
|
|
|
|
id: topBar
|
|
|
|
z: 60
|
2020-05-26 14:16:07 -04:00
|
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignTop
|
2020-05-26 11:55:32 -04:00
|
|
|
Layout.fillWidth: true
|
2020-07-15 12:19:25 -04:00
|
|
|
}
|
|
|
|
|
2021-04-07 14:26:03 -04:00
|
|
|
Rectangle {
|
|
|
|
Component.onCompleted: {
|
|
|
|
isConnected = chatsModel.isOnline
|
|
|
|
if(!isConnected){
|
|
|
|
connectedStatusRect.visible = true
|
2020-07-15 12:19:25 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-07 14:26:03 -04:00
|
|
|
id: connectedStatusRect
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
|
|
Layout.fillWidth: true
|
|
|
|
z: 60
|
|
|
|
height: 40
|
|
|
|
color: isConnected ? Style.current.green : Style.current.darkGrey
|
|
|
|
visible: false
|
|
|
|
Text {
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
color: Style.current.white
|
|
|
|
id: connectedStatusLbl
|
|
|
|
text: isConnected ?
|
|
|
|
//% "Connected"
|
|
|
|
qsTrId("connected") :
|
|
|
|
//% "Disconnected"
|
|
|
|
qsTrId("disconnected")
|
2020-07-15 12:19:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: chatsModel
|
|
|
|
onOnlineStatusChanged: {
|
2020-07-24 10:33:17 -04:00
|
|
|
if (connected == isConnected) return;
|
|
|
|
isConnected = connected;
|
|
|
|
if(isConnected){
|
2021-04-07 14:26:03 -04:00
|
|
|
timer.setTimeout(function(){
|
2020-07-15 12:19:25 -04:00
|
|
|
connectedStatusRect.visible = false;
|
|
|
|
}, 5000);
|
|
|
|
} else {
|
|
|
|
connectedStatusRect.visible = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-05-25 16:34:26 -04:00
|
|
|
}
|
|
|
|
|
2021-04-28 11:30:41 -04:00
|
|
|
Item {
|
|
|
|
visible: chatsModel.activeChannel.chatType === Constants.chatTypeOneToOne &&
|
|
|
|
!profileModel.contacts.isAdded(activeChatId) &&
|
|
|
|
!doNotShowAddToContactBannerToThose.includes(activeChatId)
|
|
|
|
Layout.alignment: Qt.AlignTop
|
|
|
|
Layout.fillWidth: true
|
|
|
|
height: 36
|
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
source: "../../img/plusSign.svg"
|
|
|
|
anchors.right: addToContactsTxt.left
|
|
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
layer.enabled: true
|
|
|
|
layer.effect: ColorOverlay { color: addToContactsTxt.color }
|
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: addToContactsTxt
|
|
|
|
text: qsTr("Add to contacts")
|
|
|
|
color: Style.current.primary
|
|
|
|
anchors.centerIn: parent
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
onClicked: profileModel.contacts.addContact(activeChatId)
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusIconButton {
|
|
|
|
id: closeBtn
|
|
|
|
icon.name: "close"
|
|
|
|
onClicked: {
|
|
|
|
const newArray = Object.assign([], doNotShowAddToContactBannerToThose)
|
|
|
|
newArray.push(activeChatId)
|
|
|
|
doNotShowAddToContactBannerToThose = newArray
|
|
|
|
}
|
|
|
|
width: 20
|
|
|
|
height: 20
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.halfPadding
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-07 14:26:03 -04:00
|
|
|
StackLayout {
|
|
|
|
id: stackLayoutChatMessages
|
2020-05-25 16:34:26 -04:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
2021-04-07 14:26:03 -04:00
|
|
|
clip: true
|
|
|
|
Repeater {
|
|
|
|
model: chatsModel
|
|
|
|
Loader {
|
|
|
|
active: false
|
|
|
|
sourceComponent: ChatMessages {
|
|
|
|
id: chatMessages
|
|
|
|
messageList: model.messages
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-02-22 14:09:26 -04:00
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: chatsModel
|
|
|
|
onActiveChannelChanged: {
|
|
|
|
stackLayoutChatMessages.currentIndex = chatsModel.getMessageListIndex(chatsModel.activeChannelIndex)
|
2021-02-28 11:33:25 -04:00
|
|
|
if(stackLayoutChatMessages.currentIndex > -1 && !stackLayoutChatMessages.children[stackLayoutChatMessages.currentIndex].active){
|
|
|
|
stackLayoutChatMessages.children[stackLayoutChatMessages.currentIndex].active = true;
|
|
|
|
}
|
2021-02-22 14:09:26 -04:00
|
|
|
}
|
|
|
|
}
|
2021-04-07 14:26:03 -04:00
|
|
|
}
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2020-11-16 13:32:56 +01:00
|
|
|
StatusImageModal {
|
2020-09-12 20:22:07 +02:00
|
|
|
id: imagePopup
|
|
|
|
}
|
|
|
|
|
2020-07-20 15:29:57 -04:00
|
|
|
EmojiReactions {
|
|
|
|
id: reactionModel
|
|
|
|
}
|
|
|
|
|
2020-08-03 13:17:03 -04:00
|
|
|
MessageContextMenu {
|
2020-07-09 13:47:36 -04:00
|
|
|
id: messageContextMenu
|
|
|
|
}
|
2021-02-03 16:13:05 -04:00
|
|
|
|
2020-07-14 13:40:58 +02:00
|
|
|
Connections {
|
|
|
|
target: chatsModel
|
|
|
|
onActiveChannelChanged: {
|
2021-02-03 16:13:05 -04:00
|
|
|
chatInput.suggestions.hide();
|
2021-02-03 17:38:05 -04:00
|
|
|
chatInput.textInput.forceActiveFocus(Qt.MouseFocusReason)
|
2021-02-03 16:13:05 -04:00
|
|
|
populateSuggestions();
|
|
|
|
}
|
|
|
|
onMessagePushed: {
|
2021-02-03 17:38:05 -04:00
|
|
|
addSuggestionFromMessageList(messageIndex);
|
2020-07-14 13:40:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-07 16:26:58 +10:00
|
|
|
Connections {
|
|
|
|
target: profileModel
|
|
|
|
onContactsChanged: {
|
|
|
|
populateSuggestions();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-24 13:23:49 +10:00
|
|
|
Rectangle {
|
2020-07-09 13:47:36 -04:00
|
|
|
id: inputArea
|
2020-06-24 13:23:49 +10:00
|
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignBottom
|
2020-05-25 16:34:26 -04:00
|
|
|
Layout.fillWidth: true
|
2020-06-24 13:23:49 +10:00
|
|
|
Layout.preferredWidth: parent.width
|
2020-09-29 11:06:57 +02:00
|
|
|
height: chatInput.height
|
2020-06-24 13:23:49 +10:00
|
|
|
Layout.preferredHeight: height
|
2020-09-29 11:06:57 +02:00
|
|
|
color: "transparent"
|
2020-07-09 13:47:36 -04:00
|
|
|
|
2020-12-01 13:18:49 -04:00
|
|
|
Connections {
|
|
|
|
target: chatsModel
|
|
|
|
onLoadingMessagesChanged:
|
|
|
|
if(value){
|
|
|
|
loadingMessagesIndicator.active = true
|
|
|
|
} else {
|
|
|
|
timer.setTimeout(function(){
|
|
|
|
loadingMessagesIndicator.active = false;
|
|
|
|
}, 5000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-07 13:47:00 +02:00
|
|
|
Loader {
|
2020-12-01 13:18:49 -04:00
|
|
|
id: loadingMessagesIndicator
|
2020-09-07 13:47:00 +02:00
|
|
|
active: chatsModel.loadingMessages
|
|
|
|
sourceComponent: loadingIndicator
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.bottom: chatInput.top
|
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
anchors.bottomMargin: Style.current.padding
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: loadingIndicator
|
2021-02-08 13:16:28 +01:00
|
|
|
LoadingAnimation {}
|
2020-09-07 13:47:00 +02:00
|
|
|
}
|
|
|
|
|
2020-09-29 11:06:57 +02:00
|
|
|
StatusChatInput {
|
2020-07-14 13:40:58 +02:00
|
|
|
id: chatInput
|
2020-11-16 15:42:53 -04:00
|
|
|
visible: {
|
2021-02-11 15:37:31 -05:00
|
|
|
const community = chatsModel.communities.activeCommunity
|
2021-03-31 11:39:42 -04:00
|
|
|
if (chatsModel.activeChannel.chatType === Constants.chatTypePrivateGroupChat) {
|
|
|
|
return chatsModel.activeChannel.isMember
|
2020-12-11 15:38:10 -05:00
|
|
|
}
|
2021-03-31 11:39:42 -04:00
|
|
|
return !community.active ||
|
|
|
|
community.access === Constants.communityChatPublicAccess ||
|
|
|
|
community.admin ||
|
|
|
|
chatsModel.activeChannel.canPost
|
2020-11-16 15:42:53 -04:00
|
|
|
}
|
2020-12-02 11:10:22 +02:00
|
|
|
enabled: !isBlocked
|
2020-12-03 23:58:36 +02:00
|
|
|
chatInputPlaceholder: isBlocked ?
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "This user has been blocked."
|
|
|
|
qsTrId("this-user-has-been-blocked-") :
|
|
|
|
//% "Type a message."
|
|
|
|
qsTrId("type-a-message-")
|
2020-09-29 11:06:57 +02:00
|
|
|
anchors.bottom: parent.bottom
|
2020-12-06 11:24:28 -04:00
|
|
|
recentStickers: chatsModel.stickers.recent
|
|
|
|
stickerPackList: chatsModel.stickers.stickerPacks
|
2020-09-29 11:06:57 +02:00
|
|
|
chatType: chatsModel.activeChannel.chatType
|
|
|
|
onSendTransactionCommandButtonClicked: {
|
2020-10-28 18:44:09 +11:00
|
|
|
if (chatsModel.activeChannel.ensVerified) {
|
|
|
|
txModalLoader.sourceComponent = cmpSendTransactionWithEns
|
|
|
|
} else {
|
|
|
|
txModalLoader.sourceComponent = cmpSendTransactionNoEns
|
|
|
|
}
|
|
|
|
txModalLoader.item.open()
|
|
|
|
}
|
|
|
|
onReceiveTransactionCommandButtonClicked: {
|
|
|
|
txModalLoader.sourceComponent = cmpReceiveTransaction
|
|
|
|
txModalLoader.item.open()
|
|
|
|
}
|
|
|
|
onStickerSelected: {
|
2020-12-06 11:24:28 -04:00
|
|
|
chatsModel.stickers.send(hashId, packId)
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
2020-12-07 15:59:24 +01:00
|
|
|
onSendMessage: {
|
|
|
|
if (chatInput.fileUrls.length > 0){
|
2021-03-10 15:59:01 +11:00
|
|
|
chatsModel.sendImages(JSON.stringify(fileUrls));
|
2020-12-07 15:59:24 +01:00
|
|
|
}
|
2021-02-24 13:37:46 -04:00
|
|
|
let msg = chatsModel.plainText(Emoji.deparse(chatInput.textInput.text))
|
2020-12-07 15:59:24 +01:00
|
|
|
if (msg.length > 0){
|
|
|
|
msg = chatInput.interpretMessage(msg)
|
2021-03-23 11:57:19 -04:00
|
|
|
chatsModel.sendMessage(msg, chatInput.isReply ? SelectedMessage.messageId : "", Utils.isOnlyEmoji(msg) ? Constants.emojiType : Constants.messageType, false, JSON.stringify(suggestionsObj));
|
2021-02-28 11:33:25 -04:00
|
|
|
if(event) event.accepted = true
|
|
|
|
sendMessageSound.stop();
|
|
|
|
Qt.callLater(sendMessageSound.play);
|
2021-02-08 08:38:55 -04:00
|
|
|
|
2021-02-24 13:37:46 -04:00
|
|
|
chatInput.textInput.clear();
|
|
|
|
chatInput.textInput.textFormat = TextEdit.PlainText;
|
|
|
|
chatInput.textInput.textFormat = TextEdit.RichText;
|
2020-12-07 15:59:24 +01:00
|
|
|
}
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
EmptyChat {}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: txModalLoader
|
2020-11-03 21:29:56 +11:00
|
|
|
function close() {
|
|
|
|
if (!this.item) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
this.item.close()
|
|
|
|
this.closed()
|
|
|
|
}
|
|
|
|
function closed() {
|
|
|
|
this.sourceComponent = undefined
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
|
|
|
Component {
|
|
|
|
id: cmpSendTransactionNoEns
|
|
|
|
ChatCommandModal {
|
|
|
|
id: sendTransactionNoEns
|
2020-11-03 21:29:56 +11:00
|
|
|
onClosed: {
|
|
|
|
txModalLoader.closed()
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
sendChatCommand: chatColumnLayout.requestAddressForTransaction
|
|
|
|
isRequested: false
|
|
|
|
//% "Send"
|
|
|
|
commandTitle: qsTrId("command-button-send")
|
|
|
|
title: commandTitle
|
|
|
|
//% "Request Address"
|
|
|
|
finalButtonLabel: qsTrId("request-address")
|
|
|
|
selectRecipient.selectedRecipient: {
|
|
|
|
return {
|
|
|
|
address: Constants.zeroAddress, // Setting as zero address since we don't have the address yet
|
2020-10-30 10:08:07 +11:00
|
|
|
alias: chatsModel.activeChannel.alias,
|
2021-04-28 11:30:41 -04:00
|
|
|
identicon: activeChatIdenticon,
|
2020-10-28 18:44:09 +11:00
|
|
|
name: chatsModel.activeChannel.name,
|
|
|
|
type: RecipientSelector.Type.Contact
|
|
|
|
}
|
|
|
|
}
|
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
|
|
|
selectRecipient.readOnly: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Component {
|
|
|
|
id: cmpReceiveTransaction
|
|
|
|
ChatCommandModal {
|
|
|
|
id: receiveTransaction
|
2020-11-03 21:29:56 +11:00
|
|
|
onClosed: {
|
|
|
|
txModalLoader.closed()
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
sendChatCommand: chatColumnLayout.requestTransaction
|
|
|
|
isRequested: true
|
|
|
|
//% "Request"
|
|
|
|
commandTitle: qsTrId("wallet-request")
|
|
|
|
title: commandTitle
|
|
|
|
//% "Request"
|
|
|
|
finalButtonLabel: qsTrId("wallet-request")
|
|
|
|
selectRecipient.selectedRecipient: {
|
|
|
|
return {
|
|
|
|
address: Constants.zeroAddress, // Setting as zero address since we don't have the address yet
|
2020-10-30 10:08:07 +11:00
|
|
|
alias: chatsModel.activeChannel.alias,
|
2021-04-28 11:30:41 -04:00
|
|
|
identicon: activeChatIdenticon,
|
2020-10-28 18:44:09 +11:00
|
|
|
name: chatsModel.activeChannel.name,
|
|
|
|
type: RecipientSelector.Type.Contact
|
2020-09-29 11:06:57 +02:00
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
|
|
|
selectRecipient.readOnly: true
|
2020-05-25 16:34:26 -04:00
|
|
|
}
|
2020-05-26 14:16:07 -04:00
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
Component {
|
|
|
|
id: cmpSendTransactionWithEns
|
|
|
|
SendModal {
|
|
|
|
id: sendTransactionWithEns
|
|
|
|
onOpened: {
|
|
|
|
walletModel.getGasPricePredictions()
|
|
|
|
}
|
2020-11-03 21:29:56 +11:00
|
|
|
onClosed: {
|
|
|
|
txModalLoader.closed()
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
selectRecipient.readOnly: true
|
|
|
|
selectRecipient.selectedRecipient: {
|
|
|
|
return {
|
|
|
|
address: "",
|
2020-10-30 10:08:07 +11:00
|
|
|
alias: chatsModel.activeChannel.alias,
|
2021-04-28 11:30:41 -04:00
|
|
|
identicon: activeChatIdenticon,
|
2020-10-28 18:44:09 +11:00
|
|
|
name: chatsModel.activeChannel.name,
|
2020-10-30 10:08:07 +11:00
|
|
|
type: RecipientSelector.Type.Contact,
|
2020-10-28 18:44:09 +11:00
|
|
|
ensVerified: true
|
|
|
|
}
|
|
|
|
}
|
2020-10-30 10:08:07 +11:00
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
2020-09-29 11:06:57 +02:00
|
|
|
}
|
2020-05-25 16:34:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/*##^##
|
|
|
|
Designer {
|
2020-05-27 13:26:21 -04:00
|
|
|
D{i:0;formeditorColor:"#ffffff";height:770;width:800}
|
2020-05-25 16:34:26 -04:00
|
|
|
}
|
|
|
|
##^##*/
|