moment/src/qml/SidePane/AccountDelegate.qml

123 lines
3.5 KiB
QML
Raw Normal View History

import QtQuick 2.12
import QtQuick.Layouts 1.12
import "../Base"
import "../utils.js" as Utils
HTileDelegate {
id: accountDelegate
spacing: 0
topPadding: model.index > 0 ? sidePane.currentSpacing / 2 : 0
bottomPadding: topPadding
backgroundColor: theme.sidePane.account.background
opacity: collapsed && ! forceExpand ?
theme.sidePane.account.collapsedOpacity : 1
shouldBeCurrent:
window.uiState.page == "Pages/EditAccount/EditAccount.qml" &&
window.uiState.pageProperties.userId == model.data.user_id
setCurrentTimer.running:
2019-08-31 01:05:11 +10:00
! sidePaneList.activateLimiter.running && ! sidePane.hasFocus
Behavior on opacity { HNumberAnimation {} }
property bool disconnecting: false
2019-08-31 01:05:11 +10:00
readonly property bool forceExpand: Boolean(sidePaneList.filter)
// Hide harmless error when a filter matches nothing
readonly property bool collapsed: try {
2019-08-31 01:05:11 +10:00
return sidePaneList.collapseAccounts[model.data.user_id] || false
} catch (err) {}
onActivated: if (! disconnecting) {
pageLoader.showPage(
"EditAccount/EditAccount", { "userId": model.data.user_id }
)
}
function toggleCollapse() {
window.uiState.collapseAccounts[model.data.user_id] = ! collapsed
window.uiStateChanged()
}
image: HUserAvatar {
clientUserId: model.data.user_id
userId: model.data.user_id
displayName: model.data.display_name
mxc: model.data.avatar_url
}
title.color: theme.sidePane.account.name
title.text: model.data.display_name || model.data.user_id
title.font.pixelSize: theme.fontSize.big
title.leftPadding: sidePane.currentSpacing
2019-11-07 21:44:53 +11:00
HButton {
id: addChat
iconItem.dimension: 16
icon.name: "add-account" // TODO
backgroundColor: "transparent"
toolTip.text: qsTr("Add new chat")
onClicked: pageLoader.showPage(
"AddChat/AddChat", {userId: model.data.user_id},
)
2019-11-07 21:44:53 +11:00
leftPadding: theme.spacing / 2
rightPadding: leftPadding
visible: opacity > 0
opacity: expand.loading ? 0 : 1
Layout.fillHeight: true
Behavior on opacity { HNumberAnimation {} }
}
HButton {
id: expand
2019-08-28 05:00:50 +10:00
loading: ! model.data.first_sync_done || ! model.data.profile_updated
2019-11-07 21:44:53 +11:00
iconItem.dimension: 16
icon.name: "expand"
backgroundColor: "transparent"
toolTip.text: collapsed ? qsTr("Expand") : qsTr("Collapse")
onClicked: accountDelegate.toggleCollapse()
2019-11-07 21:44:53 +11:00
leftPadding: theme.spacing / 2
rightPadding: leftPadding
visible: opacity > 0
2019-08-28 05:00:50 +10:00
opacity: ! loading && accountDelegate.forceExpand ? 0 : 1
2019-11-07 21:44:53 +11:00
Layout.fillHeight: true
iconItem.transform: Rotation {
2019-11-07 21:44:53 +11:00
origin.x: expand.iconItem.width / 2
origin.y: expand.iconItem.height / 2
2019-08-28 05:00:50 +10:00
angle: expand.loading ? 0 : collapsed ? 180 : 90
Behavior on angle { HNumberAnimation {} }
}
Behavior on opacity { HNumberAnimation {} }
}
contextMenu: HMenu {
HMenuItem {
icon.name: "logout"
2019-08-29 08:21:13 +10:00
icon.color: theme.colors.negativeBackground
text: qsTr("Logout")
onTriggered: Utils.makePopup(
"Popups/LogoutPopup.qml",
mainUI,
{ "userId": model.data.user_id },
popup => { popup.ok.connect(() => { disconnecting = true }) },
)
}
}
}