2024-10-15 21:26:12 +02:00
import QtQuick 2.15
2021-09-28 18:04:06 +03:00
2022-09-08 14:46:28 +02:00
import StatusQ . Core 0.1
2024-10-15 21:26:12 +02:00
import StatusQ . Core . Theme 0.1
2022-03-14 15:32:52 -04:00
import StatusQ . Core . Utils 0.1 as StatusQUtils
2022-04-01 13:46:32 +02:00
import StatusQ . Components 0.1
2021-09-28 18:04:06 +03:00
import utils 1.0
2024-10-15 21:26:12 +02:00
import shared 1.0
import shared . panels 1.0
2020-07-15 17:04:14 -04:00
2021-01-25 15:01:00 -05:00
Column {
2021-10-22 01:39:53 +03:00
id: root
2024-10-15 21:26:12 +02:00
spacing: Theme . padding
2020-07-15 17:04:14 -04:00
anchors.horizontalCenter: parent . horizontalCenter
2024-10-15 21:26:12 +02:00
topPadding: visible ? Theme.bigPadding : 0
2021-08-30 11:50:45 +02:00
bottomPadding: visible ? 50 : 0
2020-07-15 17:04:14 -04:00
2022-01-27 21:10:21 +03:00
property bool amIChatAdmin: false
2021-12-10 17:11:18 +01:00
property string chatName: ""
2022-04-01 13:46:32 +02:00
property string chatId: ""
2021-12-10 17:11:18 +01:00
property int chatType: - 1
property string chatColor: ""
2022-03-14 15:32:52 -04:00
property string chatEmoji: ""
2021-12-10 17:11:18 +01:00
property string chatIcon: ""
2021-10-22 01:39:53 +03:00
2022-04-01 13:46:32 +02:00
StatusSmartIdenticon {
2022-08-15 13:43:38 +02:00
objectName: "channelIdentifierSmartIdenticon"
2020-07-15 17:04:14 -04:00
anchors.horizontalCenter: parent . horizontalCenter
2022-04-01 13:46:32 +02:00
name: root . chatName
2022-08-11 14:55:08 +03:00
asset {
2020-07-15 17:04:14 -04:00
width: 120
height: 120
2022-04-07 21:05:33 +02:00
color: root . chatType === Constants . chatType . oneToOne ? Utils . colorForPubkey ( root . chatId ) : root . chatColor
2022-04-01 13:46:32 +02:00
emoji: root . chatEmoji
2022-08-11 14:55:08 +03:00
name: root . chatIcon
isImage: true
2022-04-01 13:46:32 +02:00
charactersLen: root . chatType === Constants . chatType . oneToOne ? 2 : 1
2020-07-15 17:04:14 -04:00
}
2022-04-01 13:46:32 +02:00
ringSettings.ringSpecModel: root . chatType === Constants . chatType . oneToOne ? Utils . getColorHashAsJson ( root . chatId ) : undefined
2020-07-15 17:04:14 -04:00
}
StyledText {
id: channelName
2022-07-21 12:16:25 -04:00
objectName: "channelIdentifierNameText"
2022-09-21 12:57:08 +03:00
width: parent . width
2020-07-15 17:04:14 -04:00
wrapMode: Text . Wrap
2021-12-10 17:11:18 +01:00
text: root . chatName
2020-07-15 17:04:14 -04:00
font.weight: Font . Bold
font.pixelSize: 22
2024-10-15 21:26:12 +02:00
color: Theme . palette . textColor
2022-09-21 12:57:08 +03:00
horizontalAlignment: Text . AlignHCenter
2020-07-15 17:04:14 -04:00
}
2022-09-08 14:46:28 +02:00
StatusBaseText {
2021-04-28 13:33:10 -04:00
id: descText
2022-09-08 14:46:28 +02:00
width: parent . width
2021-04-28 13:33:10 -04:00
wrapMode: Text . Wrap
text: {
2021-12-10 17:11:18 +01:00
switch ( root . chatType ) {
case Constants.chatType.privateGroupChat:
2024-10-15 21:26:12 +02:00
return qsTr ( "Welcome to the beginning of the <span style='color: %1'>%2</span> group!" ) . arg ( Theme . palette . textColor ) . arg ( root . chatName ) ;
2022-09-08 14:46:28 +02:00
case Constants.chatType.communityChat:
2024-10-15 21:26:12 +02:00
return qsTr ( "Welcome to the beginning of the <span style='color: %1'>#%2</span> channel!" ) . arg ( Theme . palette . textColor ) . arg ( root . chatName ) ;
2021-12-10 17:11:18 +01:00
case Constants.chatType.oneToOne:
2024-10-15 21:26:12 +02:00
return qsTr ( "Any messages you send here are encrypted and can only be read by you and <span style='color: %1'>%2</span>" ) . arg ( Theme . palette . textColor ) . arg ( root . chatName )
2021-04-28 13:33:10 -04:00
default: return "" ;
2020-08-07 17:36:35 -04:00
}
}
2024-10-15 21:26:12 +02:00
font.pixelSize: Theme . primaryTextFontSize
color: Theme . palette . secondaryText
2021-04-28 13:33:10 -04:00
horizontalAlignment: Text . AlignHCenter
textFormat: Text . RichText
2020-08-07 17:36:35 -04:00
}
2020-07-15 17:04:14 -04:00
}