RetroShare/retroshare-qml-app/src/GxsIdentityDelegate.qml

293 lines
6.3 KiB
QML
Raw Normal View History

/*
* RetroShare Android QML App
* Copyright (C) 2017 Gioacchino Mazzurco <gio@eigenlab.org>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.7
import QtQuick.Controls 2.0
import "." //Needed for ChatCache singleton
2017-06-12 08:26:55 -04:00
import "./components"
Item
{
id: delegateRoot
2017-07-08 13:28:54 -04:00
height: 57
width: parent.width
property var chatId: undefined
property var lastMessageData: ({})
2017-06-06 10:06:41 -04:00
property var locale: Qt.locale()
2017-06-13 08:51:53 -04:00
Rectangle
{
id: contactItem
anchors.fill: parent
color: contactItemArea.containsPress ? "lightgrey" : "transparent"
width: parent.width
height: parent.height
MouseArea
{
id: contactItemArea
anchors.fill: parent
onClicked:
{
console.log("GxsIntentityDelegate onclicked:", model.name,
model.gxs_id)
contactsView.searching = false
if(model.own) contactsView.own_gxs_id = model.gxs_id
else
{
var jsonData = { "own_gxs_hex": contactsView.own_gxs_id,
"remote_gxs_hex": model.gxs_id }
rsApi.request("/chat/initiate_distant_chat",
JSON.stringify(jsonData),
startDistantChatCB)
}
}
onPressAndHold: showDetails()
hoverEnabled: true
}
Rectangle
{
id: backgroundRectangle
anchors.fill: parent.fill
anchors.right: parent.right
width: parent.width - colorHash.width - 15
height: parent.height
color:"transparent"
Rectangle
{
id: borderBottom
width: parent.width
height: 1
anchors.bottom: parent.bottom
anchors.right: parent.right
color: "lightgrey"
}
}
Rectangle
{
anchors.fill: parent
color: "transparent"
anchors.margins: 5
ColorHash
{
id: colorHash
hash: model.gxs_id
height: parent.height - 4
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
anchors.leftMargin: 2
MouseArea
{
anchors.fill: parent
onClicked: delegateRoot.showDetails()
}
}
Column
{
2017-06-06 10:26:57 -04:00
id: chatInfoRow
height: parent.height
2017-07-08 13:28:54 -04:00
width: parent.width - isContactRow.width - colorHash.width
anchors.left: colorHash.right
2017-07-08 13:28:54 -04:00
anchors.leftMargin: 10
anchors.right: isContactRow.left
anchors.rightMargin: 5
Item
{
width: parent.width
height: parent.height /2
Text
{
id: nickText
color: model.own ? "blue" : "black"
text: model.name
font.bold: true
2017-07-08 13:28:54 -04:00
anchors.bottom: parent.bottom
}
Text
{
text: setTime()
anchors.right: parent.right
2017-06-06 10:37:10 -04:00
color: "darkslategrey"
2017-07-08 13:28:54 -04:00
anchors.bottom: parent.bottom
}
}
Item
{
id: lastMessageText
width: parent.width
2017-07-08 13:28:54 -04:00
height: (lastMessageData && lastMessageData.msg !== undefined)? parent.height /2 : 0
Text
{
id: lastMessageSender
font.italic: true
2017-06-06 10:37:10 -04:00
color: "royalblue"
text: ((lastMessageData && lastMessageData.incoming !== undefined) && !lastMessageData.incoming)? "You: " : ""
2017-06-12 10:23:41 -04:00
height: parent.height
}
2017-06-06 10:37:10 -04:00
Text
{
id: lastMessageMsg
2017-06-06 10:26:57 -04:00
anchors.left: lastMessageSender.right
text: (lastMessageData && lastMessageData.msg !== undefined)? lastMessageData.msg : ""
rightPadding: 5
2017-06-06 10:26:57 -04:00
elide: Text.ElideRight
2017-06-06 10:37:10 -04:00
color: "darkslategrey"
2017-06-06 10:26:57 -04:00
width: chatInfoRow.width - 30
2017-06-12 10:23:41 -04:00
height: parent.height
}
Rectangle
{
visible: model.unread_count > 0
color: "cornflowerblue"
antialiasing: true
2017-07-08 13:28:54 -04:00
height: parent.height - 6
radius: height/2
width: height
2017-07-08 13:28:54 -04:00
// anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
Text
{
color: "white"
font.bold: true
text: model.unread_count
anchors.centerIn: parent
}
}
}
}
Row
{
2017-07-08 13:28:54 -04:00
id: isContactRow
anchors.right: parent.right
anchors.rightMargin: 10
anchors.verticalCenter: parent.verticalCenter
height: parent.height - 10
spacing: 4
Image
{
source: model.is_contact ?
"qrc:/icons/rating.svg" :
"qrc:/icons/rating-unrated.svg"
height: parent.height - 4
sourceSize.height: height
fillMode: Image.PreserveAspectFit
anchors.verticalCenter: parent.verticalCenter
id: isContactIcon
}
}
}
}
2017-06-13 08:51:53 -04:00
Component.onCompleted:
{
if (!chatId){
chatId = getChatIdFromGXS()
}
if (chatId) {
var last = getChatLastMessage(chatId)
if (last) lastMessageData = last
}
}
2017-06-13 08:51:53 -04:00
Connections
{
target: ChatCache.lastMessageCache
onLastMessageChanged: {
if (!chatId) {
chatId = getChatIdFromGXS()
}
if (chatId && chatId === chatI){
console.log("New last message received!")
lastMessageData = newLastMessage
}
}
}
2017-06-13 08:51:53 -04:00
function getChatLastMessage (chatId)
{
return ChatCache.lastMessageCache.getChatLastMessage(chatId)
}
2017-06-13 08:51:53 -04:00
function getChatIdFromGXS ()
{
var id= ChatCache.lastMessageCache.getChatIdFromGxs(model.gxs_id)
return ChatCache.lastMessageCache.getChatIdFromGxs(model.gxs_id)
}
2017-06-13 08:51:53 -04:00
function setTime()
{
if (!lastMessageData || lastMessageData.recv_time === undefined) return ""
var timeFormat = "dd.MM.yyyy";
var recvDate = new Date(lastMessageData.recv_time*1000)
// Check if is today
2017-06-13 08:51:53 -04:00
if ( new Date (lastMessageData.recv_time*1000).setHours(0,0,0,0) == new Date ().setHours(0,0,0,0))
{
timeFormat = "hh:mm"
}
var timeString = Qt.formatDateTime(recvDate, timeFormat)
return timeString
}
function showDetails()
{
console.log("showDetails()", index)
contactsView.searching = false
stackView.push(
"qrc:/ContactDetails.qml",
{md: contactsListView.model.get(index)})
}
2017-06-13 08:51:53 -04:00
function startDistantChatCB (par)
{
var chId = JSON.parse(par.response).data.chat_id
ChatCache.lastMessageCache.setRemoteGXS(chId, { gxs: model.gxs_id, name: model.name})
contactsView.startChatCallback (par)
}
}