2021-08-05 14:06:19 -04:00
|
|
|
import QtQuick 2.12
|
2022-07-04 12:47:29 +02:00
|
|
|
import QtQuick.Controls 2.14
|
2021-08-05 14:06:19 -04:00
|
|
|
import QtQuick.Layouts 1.3
|
|
|
|
import QtQml.Models 2.3
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2022-03-09 11:27:32 +01:00
|
|
|
import shared.controls.chat 1.0
|
|
|
|
import shared.panels 1.0
|
2021-08-05 14:06:19 -04:00
|
|
|
|
2021-10-21 00:47:23 +02:00
|
|
|
import StatusQ.Components 0.1
|
2022-07-04 12:47:29 +02:00
|
|
|
import StatusQ.Popups 0.1
|
2021-10-21 00:47:23 +02:00
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusPopupMenu {
|
2021-08-05 14:06:19 -04:00
|
|
|
id: root
|
2022-03-09 11:27:32 +01:00
|
|
|
|
2021-11-05 01:38:57 +02:00
|
|
|
property var store
|
2022-03-09 11:27:32 +01:00
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
width: 210
|
2022-03-09 11:27:32 +01:00
|
|
|
|
|
|
|
ProfileHeader {
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
displayName: root.store.userProfileInst.name
|
|
|
|
pubkey: root.store.userProfileInst.pubKey
|
|
|
|
icon: root.store.userProfileInst.icon
|
|
|
|
}
|
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuSeparator {
|
2022-03-09 11:27:32 +01:00
|
|
|
}
|
2021-08-05 14:06:19 -04:00
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuItem {
|
2022-08-18 09:38:47 +02:00
|
|
|
objectName: "userStatusViewMyProfileAction"
|
2022-03-09 11:27:32 +01:00
|
|
|
text: qsTr("View My Profile")
|
2022-07-04 12:47:29 +02:00
|
|
|
icon.name: "profile"
|
2022-03-09 11:27:32 +01:00
|
|
|
onTriggered: {
|
|
|
|
Global.openProfilePopup(root.store.userProfileInst.pubKey)
|
|
|
|
root.close()
|
2021-08-05 14:06:19 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuSeparator {
|
2021-08-05 14:06:19 -04:00
|
|
|
}
|
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: alwaysOnlineAction
|
2022-08-12 18:31:39 +02:00
|
|
|
objectName: "userStatusMenuAlwaysOnlineAction"
|
2022-06-10 11:01:31 +02:00
|
|
|
text: qsTr("Always online")
|
2022-08-11 14:55:08 +03:00
|
|
|
icon.name: Style.svg("statuses/online")
|
|
|
|
assetSettings.isImage: true
|
|
|
|
icon.width: 12
|
|
|
|
icon.height: 12
|
2022-07-04 12:47:29 +02:00
|
|
|
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.alwaysOnline
|
2021-08-05 14:06:19 -04:00
|
|
|
onTriggered: {
|
2022-07-04 12:47:29 +02:00
|
|
|
store.setCurrentUserStatus(Constants.currentUserStatus.alwaysOnline)
|
2021-11-22 12:08:09 +01:00
|
|
|
root.close();
|
2021-08-05 14:06:19 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: inactiveAction
|
2022-08-12 18:31:39 +02:00
|
|
|
objectName: "userStatusMenuInactiveAction"
|
2022-06-10 11:01:31 +02:00
|
|
|
text: qsTr("Inactive")
|
2022-08-11 14:55:08 +03:00
|
|
|
icon.name: Style.svg("statuses/inactive")
|
|
|
|
assetSettings.isImage: true
|
|
|
|
icon.width: 12
|
|
|
|
icon.height: 12
|
2022-07-04 12:47:29 +02:00
|
|
|
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.inactive
|
2021-08-05 14:06:19 -04:00
|
|
|
onTriggered: {
|
2022-07-04 12:47:29 +02:00
|
|
|
store.setCurrentUserStatus(Constants.currentUserStatus.inactive)
|
2021-11-22 12:08:09 +01:00
|
|
|
root.close();
|
2021-08-05 14:06:19 -04:00
|
|
|
}
|
|
|
|
}
|
2022-06-10 11:01:31 +02:00
|
|
|
|
2022-07-04 12:47:29 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: automaticAction
|
2022-08-12 18:31:39 +02:00
|
|
|
objectName: "userStatusMenuAutomaticAction"
|
2022-06-10 11:01:31 +02:00
|
|
|
text: qsTr("Set status automatically")
|
2022-08-11 14:55:08 +03:00
|
|
|
icon.name: Style.svg("statuses/automatic")
|
|
|
|
assetSettings.isImage: true
|
2022-07-04 12:47:29 +02:00
|
|
|
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.automatic
|
2022-06-10 11:01:31 +02:00
|
|
|
onTriggered: {
|
2022-07-04 12:47:29 +02:00
|
|
|
store.setCurrentUserStatus(Constants.currentUserStatus.automatic)
|
2022-06-10 11:01:31 +02:00
|
|
|
root.close();
|
|
|
|
}
|
|
|
|
}
|
2021-08-05 14:06:19 -04:00
|
|
|
}
|