mirror of
https://gitlab.linphone.org/BC/public/linphone-desktop.git
synced 2026-04-19 07:48:30 +00:00
Display presence text with time of last seen. Regroup text format into PresenceLevel.qml Set publish expires to 2minutes in order to be more correct. Update SDK for the last seen callback of presence model. # Conflicts: # linphone-app/assets/languages/ja.ts
145 lines
4.5 KiB
QML
145 lines
4.5 KiB
QML
import QtQuick 2.7
|
|
import QtQuick.Layouts 1.3
|
|
import QtGraphicalEffects 1.12
|
|
|
|
import Linphone 1.0
|
|
import Linphone.Styles 1.0
|
|
import Common 1.0
|
|
|
|
import UtilsCpp 1.0
|
|
|
|
// =============================================================================
|
|
|
|
Rectangle {
|
|
id: item
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// An entry from `SipAddressesModel`, an `SipAddressObserver` or a ChatRoomModel
|
|
property var entry
|
|
// entry should have these functions : presenceStatus, sipAddress, username, avatar (image)
|
|
|
|
property alias subtitleColor: description.subtitleColor
|
|
property alias titleColor: description.titleColor
|
|
property alias statusText : description.statusText
|
|
property alias isDarkMode: avatar.isDarkMode
|
|
|
|
property bool displayUnreadMessageCount: false
|
|
property bool showSubtitle : true
|
|
property bool showBusyIndicator: false
|
|
property string subtitle: ''
|
|
|
|
property string subject: (entry && entry.conferenceInfoModel && entry.conferenceInfoModel.subject
|
|
? entry.conferenceInfoModel.subject
|
|
: '')
|
|
property string username: entry
|
|
? entry.username
|
|
? entry.username
|
|
: entry.contactModel
|
|
? entry.contactModel.vcard.username
|
|
: UtilsCpp.getDisplayName(entry.sipAddress || entry.fullPeerAddress || entry.peerAddress || '')
|
|
: ''
|
|
property string organizer: entry && entry.conferenceInfoModel ? UtilsCpp.getDisplayName(entry.conferenceInfoModel.organizer) : ''
|
|
|
|
signal avatarClicked(var mouse)
|
|
// ---------------------------------------------------------------------------
|
|
|
|
color: 'transparent' // No color by default.
|
|
height: ContactStyle.height
|
|
|
|
RowLayout {
|
|
anchors {
|
|
fill: parent
|
|
leftMargin: ContactStyle.leftMargin
|
|
}
|
|
spacing: 0
|
|
|
|
Avatar {
|
|
id: avatar
|
|
|
|
Layout.preferredHeight: ContactStyle.contentHeight
|
|
Layout.preferredWidth: ContactStyle.contentHeight
|
|
|
|
//image: _contact && _contact.vcard.avatar
|
|
image: entry?(entry.avatar ? entry.avatar
|
|
: entry.contactModel ? entry.contactModel.vcard.avatar
|
|
: '')
|
|
:''
|
|
presenceLevel: entry?(entry.contactModel ? (entry.contactModel.presenceStatus >= 0 ? Presence.getPresenceLevel(entry.contactModel.presenceStatus) : -1)
|
|
: (entry.presenceStatus >= 0 ? Presence.getPresenceLevel(entry.presenceStatus) : -1)
|
|
)
|
|
:-1
|
|
presenceTimestamp: entry && entry.contactModel && entry.contactModel.presenceTimestamp
|
|
username: entry!=undefined
|
|
? entry.conferenceInfoModel
|
|
? item.organizer
|
|
: entry.isOneToOne!=undefined && !entry.isOneToOne
|
|
? ''
|
|
: item.username
|
|
: item.username
|
|
isOneToOne: entry==undefined || entry.isOneToOne==undefined || entry.isOneToOne
|
|
|
|
Icon{
|
|
anchors.top:parent.top
|
|
anchors.horizontalCenter: parent.right
|
|
visible: entry!=undefined && entry.haveEncryption != undefined && entry.haveEncryption
|
|
icon: entry?(entry.securityLevel === 2?'secure_level_1': entry.securityLevel===3? 'secure_level_2' : 'secure_level_unsafe'):'secure_level_unsafe'
|
|
iconSize: parent.height/2
|
|
}
|
|
MouseArea{
|
|
anchors.fill: parent
|
|
onClicked: item.avatarClicked(mouse)
|
|
}
|
|
|
|
Loader{
|
|
id: busyLoader
|
|
|
|
anchors.fill: parent
|
|
anchors.margins: 5
|
|
|
|
active: item.showBusyIndicator
|
|
sourceComponent: Component{
|
|
BusyIndicator{// Joining spinner
|
|
id: joiningSpinner
|
|
running: false
|
|
Timer{// Delay starting spinner (Qt bug)
|
|
id: indicatorDelay
|
|
interval: 100
|
|
onTriggered: joiningSpinner.running = true
|
|
}
|
|
Component.onCompleted: indicatorDelay.start()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
ContactDescription {
|
|
id: description
|
|
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
Layout.leftMargin: ContactStyle.spacing
|
|
|
|
titleText: item.subject
|
|
? item.subject
|
|
: item.username
|
|
subtitleText: entry && item.showSubtitle
|
|
? item.subtitle
|
|
? item.subtitle
|
|
: (entry.isOneToOne == undefined || entry.isOneToOne) && (entry.haveEncryption == undefined || !entry.haveEncryption)
|
|
? item.organizer
|
|
? item.organizer
|
|
: entry.sipAddress || entry.fullPeerAddress || entry.peerAddress || ''
|
|
: entry.participants
|
|
? entry.participants.addressesToString
|
|
: ''
|
|
: ''
|
|
}
|
|
|
|
ContactMessageCounter {
|
|
Layout.alignment: Qt.AlignTop
|
|
Layout.preferredWidth: count > 0 && visible ? implicitWidth : 0
|
|
entry: item.entry
|
|
displayCounter: item.displayUnreadMessageCount
|
|
}
|
|
}
|
|
}
|