mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-24 05:21:58 +00:00
feat(MembersTab): Update pending states based on new design
Adding the pending state indicator as a separate item in the members tab listView. Removing the pending indicator from Buttons.
This commit is contained in:
parent
1a781c509f
commit
5fb057f61f
@ -129,8 +129,8 @@ Item {
|
||||
readonly property bool showOnHover: isHovered && ctaAllowed
|
||||
|
||||
/// Button visibility ///
|
||||
readonly property bool acceptButtonVisible: tabIsShowingAcceptButton && (isPending || isRejected || isRejectedPending) && showOnHover
|
||||
readonly property bool rejectButtonVisible: tabIsShowingRejectButton && (isPending || isAcceptedPending) && showOnHover
|
||||
readonly property bool acceptButtonVisible: tabIsShowingAcceptButton && (isPending || isRejected || isRejectedPending || isAcceptedPending) && showOnHover
|
||||
readonly property bool rejectButtonVisible: tabIsShowingRejectButton && (isPending || isRejectedPending || isAcceptedPending) && showOnHover
|
||||
readonly property bool acceptPendingButtonVisible: tabIsShowingAcceptButton && isAcceptedPending
|
||||
readonly property bool rejectPendingButtonVisible: tabIsShowingRejectButton && isRejectedPending
|
||||
readonly property bool kickButtonVisible: tabIsShowingKickBanButtons && isAccepted && showOnHover && canBeBanned
|
||||
@ -139,6 +139,13 @@ Item {
|
||||
readonly property bool banPendingButtonVisible: tabIsShowingKickBanButtons && isBanPending
|
||||
readonly property bool unbanButtonVisible: tabIsShowingUnbanButton && isBanned && showOnHover
|
||||
|
||||
/// Pending states ///
|
||||
readonly property bool isPendingState: isAcceptedPending || isRejectedPending || isBanPending || isKickPending
|
||||
readonly property string pendingStateText: isAcceptedPending ? qsTr("Accept pending...") :
|
||||
isRejectedPending ? qsTr("Reject pending...") :
|
||||
isBanPending ? qsTr("Ban pending...") :
|
||||
isKickPending ? qsTr("Kick pending...") : ""
|
||||
|
||||
statusListItemComponentsSlot.spacing: 16
|
||||
statusListItemTitleArea.anchors.rightMargin: 0
|
||||
statusListItemSubTitle.elide: Text.ElideRight
|
||||
@ -146,38 +153,45 @@ Item {
|
||||
leftPadding: 12
|
||||
|
||||
components: [
|
||||
DisabledTooltipButton {
|
||||
StatusBaseText {
|
||||
id: pendingText
|
||||
width: Math.max(implicitWidth, d.pendingTextMaxWidth)
|
||||
onImplicitWidthChanged: {
|
||||
d.pendingTextMaxWidth = Math.max(implicitWidth, d.pendingTextMaxWidth)
|
||||
}
|
||||
visible: !!text && isPendingState
|
||||
rightPadding: isKickPending || isBanPending ? 0 : Style.current.bigPadding
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: pendingStateText
|
||||
color: Theme.palette.baseColor1
|
||||
StatusToolTip {
|
||||
text: qsTr("Waiting for owner node to come online")
|
||||
visible: hoverHandler.hovered
|
||||
}
|
||||
HoverHandler {
|
||||
id: hoverHandler
|
||||
enabled: pendingText.visible
|
||||
}
|
||||
},
|
||||
StatusButton {
|
||||
id: kickButton
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
visible: kickButtonVisible || kickPendingButtonVisible
|
||||
interactive: kickButtonVisible
|
||||
tooltipText: qsTr("Waiting for owner node to come online")
|
||||
buttonComponent: StatusButton {
|
||||
objectName: "MemberListItem_KickButton"
|
||||
text: kickButtonVisible ? qsTr("Kick") : qsTr("Kick pending")
|
||||
text: qsTr("Kick")
|
||||
visible: kickButtonVisible
|
||||
type: StatusBaseButton.Type.Danger
|
||||
size: StatusBaseButton.Size.Small
|
||||
onClicked: root.kickUserClicked(model.pubKey, memberItem.title)
|
||||
enabled: kickButton.interactive
|
||||
}
|
||||
},
|
||||
|
||||
DisabledTooltipButton {
|
||||
StatusButton {
|
||||
id: banButton
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
//using opacity instead of visible to avoid the acceptButton jumping around
|
||||
opacity: banButtonVisible || banPendingButtonVisible
|
||||
visible: !!banButton.opacity || kickButton.visible
|
||||
enabled: !!opacity
|
||||
interactive: banButtonVisible
|
||||
tooltipText: qsTr("Waiting for owner node to come online")
|
||||
buttonComponent: StatusButton {
|
||||
text: banButtonVisible ? qsTr("Ban") : qsTr("Ban pending")
|
||||
visible: banButtonVisible
|
||||
text: qsTr("Ban")
|
||||
type: StatusBaseButton.Type.Danger
|
||||
size: StatusBaseButton.Size.Small
|
||||
onClicked: root.banUserClicked(model.pubKey, memberItem.title)
|
||||
enabled: banButton.interactive
|
||||
}
|
||||
},
|
||||
|
||||
StatusButton {
|
||||
@ -187,43 +201,31 @@ Item {
|
||||
onClicked: root.unbanUserClicked(model.pubKey)
|
||||
},
|
||||
|
||||
DisabledTooltipButton {
|
||||
StatusButton {
|
||||
id: acceptButton
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
visible: acceptButtonVisible || acceptPendingButtonVisible
|
||||
tooltipText: qsTr("Waiting for owner node to come online")
|
||||
interactive: acceptButtonVisible
|
||||
buttonComponent: StatusButton {
|
||||
text: acceptButtonVisible ? qsTr("Accept") : qsTr("Accept Pending")
|
||||
opacity: acceptButtonVisible
|
||||
text: qsTr("Accept")
|
||||
icon.name: "checkmark-circle"
|
||||
icon.color: enabled ? Theme.palette.successColor1 : disabledTextColor
|
||||
normalColor: Theme.palette.successColor2
|
||||
hoverColor: Theme.palette.successColor3
|
||||
textColor: Theme.palette.successColor1
|
||||
loading: model.requestToJoinLoading
|
||||
enabled: acceptButton.interactive
|
||||
enabled: !acceptPendingButtonVisible
|
||||
onClicked: root.acceptRequestToJoin(model.requestToJoinId)
|
||||
}
|
||||
},
|
||||
|
||||
DisabledTooltipButton {
|
||||
StatusButton {
|
||||
id: rejectButton
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
//using opacity instead of visible to avoid the acceptButton jumping around
|
||||
opacity: rejectButtonVisible || rejectPendingButtonVisible
|
||||
enabled: !!opacity
|
||||
visible: !!rejectButton.opacity || acceptButton.visible
|
||||
tooltipText: qsTr("Waiting for owner node to come online")
|
||||
interactive: rejectButtonVisible
|
||||
buttonComponent: StatusButton {
|
||||
text: rejectPendingButtonVisible ? qsTr("Reject pending") : qsTr("Reject")
|
||||
opacity: rejectButtonVisible
|
||||
text: qsTr("Reject")
|
||||
type: StatusBaseButton.Type.Danger
|
||||
icon.name: "close-circle"
|
||||
icon.color: enabled ? Style.current.danger : disabledTextColor
|
||||
enabled: rejectButton.interactive
|
||||
enabled: !rejectPendingButtonVisible
|
||||
onClicked: root.declineRequestToJoin(model.requestToJoinId)
|
||||
}
|
||||
}
|
||||
]
|
||||
|
||||
width: membersList.width
|
||||
@ -279,4 +281,12 @@ Item {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QtObject {
|
||||
id: d
|
||||
// This is used to calculate the max width of the pending text
|
||||
// so that the text aligned on all rows (the text might be different on each row)
|
||||
property real pendingTextMaxWidth: 0
|
||||
}
|
||||
onPanelTypeChanged: { d.pendingTextMaxWidth = 0 }
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user