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:
Alex Jbanca 2023-08-21 13:57:24 +03:00 committed by Alex Jbanca
parent 1a781c509f
commit 5fb057f61f

View File

@ -129,8 +129,8 @@ Item {
readonly property bool showOnHover: isHovered && ctaAllowed readonly property bool showOnHover: isHovered && ctaAllowed
/// Button visibility /// /// Button visibility ///
readonly property bool acceptButtonVisible: tabIsShowingAcceptButton && (isPending || isRejected || isRejectedPending) && showOnHover readonly property bool acceptButtonVisible: tabIsShowingAcceptButton && (isPending || isRejected || isRejectedPending || isAcceptedPending) && showOnHover
readonly property bool rejectButtonVisible: tabIsShowingRejectButton && (isPending || isAcceptedPending) && showOnHover readonly property bool rejectButtonVisible: tabIsShowingRejectButton && (isPending || isRejectedPending || isAcceptedPending) && showOnHover
readonly property bool acceptPendingButtonVisible: tabIsShowingAcceptButton && isAcceptedPending readonly property bool acceptPendingButtonVisible: tabIsShowingAcceptButton && isAcceptedPending
readonly property bool rejectPendingButtonVisible: tabIsShowingRejectButton && isRejectedPending readonly property bool rejectPendingButtonVisible: tabIsShowingRejectButton && isRejectedPending
readonly property bool kickButtonVisible: tabIsShowingKickBanButtons && isAccepted && showOnHover && canBeBanned readonly property bool kickButtonVisible: tabIsShowingKickBanButtons && isAccepted && showOnHover && canBeBanned
@ -139,6 +139,13 @@ Item {
readonly property bool banPendingButtonVisible: tabIsShowingKickBanButtons && isBanPending readonly property bool banPendingButtonVisible: tabIsShowingKickBanButtons && isBanPending
readonly property bool unbanButtonVisible: tabIsShowingUnbanButton && isBanned && showOnHover 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 statusListItemComponentsSlot.spacing: 16
statusListItemTitleArea.anchors.rightMargin: 0 statusListItemTitleArea.anchors.rightMargin: 0
statusListItemSubTitle.elide: Text.ElideRight statusListItemSubTitle.elide: Text.ElideRight
@ -146,38 +153,45 @@ Item {
leftPadding: 12 leftPadding: 12
components: [ 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 id: kickButton
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
visible: kickButtonVisible || kickPendingButtonVisible
interactive: kickButtonVisible
tooltipText: qsTr("Waiting for owner node to come online")
buttonComponent: StatusButton {
objectName: "MemberListItem_KickButton" objectName: "MemberListItem_KickButton"
text: kickButtonVisible ? qsTr("Kick") : qsTr("Kick pending") text: qsTr("Kick")
visible: kickButtonVisible
type: StatusBaseButton.Type.Danger type: StatusBaseButton.Type.Danger
size: StatusBaseButton.Size.Small size: StatusBaseButton.Size.Small
onClicked: root.kickUserClicked(model.pubKey, memberItem.title) onClicked: root.kickUserClicked(model.pubKey, memberItem.title)
enabled: kickButton.interactive
}
}, },
DisabledTooltipButton { StatusButton {
id: banButton id: banButton
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
//using opacity instead of visible to avoid the acceptButton jumping around visible: banButtonVisible
opacity: banButtonVisible || banPendingButtonVisible text: qsTr("Ban")
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")
type: StatusBaseButton.Type.Danger type: StatusBaseButton.Type.Danger
size: StatusBaseButton.Size.Small size: StatusBaseButton.Size.Small
onClicked: root.banUserClicked(model.pubKey, memberItem.title) onClicked: root.banUserClicked(model.pubKey, memberItem.title)
enabled: banButton.interactive
}
}, },
StatusButton { StatusButton {
@ -187,43 +201,31 @@ Item {
onClicked: root.unbanUserClicked(model.pubKey) onClicked: root.unbanUserClicked(model.pubKey)
}, },
DisabledTooltipButton { StatusButton {
id: acceptButton id: acceptButton
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
visible: acceptButtonVisible || acceptPendingButtonVisible opacity: acceptButtonVisible
tooltipText: qsTr("Waiting for owner node to come online") text: qsTr("Accept")
interactive: acceptButtonVisible
buttonComponent: StatusButton {
text: acceptButtonVisible ? qsTr("Accept") : qsTr("Accept Pending")
icon.name: "checkmark-circle" icon.name: "checkmark-circle"
icon.color: enabled ? Theme.palette.successColor1 : disabledTextColor icon.color: enabled ? Theme.palette.successColor1 : disabledTextColor
normalColor: Theme.palette.successColor2 normalColor: Theme.palette.successColor2
hoverColor: Theme.palette.successColor3 hoverColor: Theme.palette.successColor3
textColor: Theme.palette.successColor1 textColor: Theme.palette.successColor1
loading: model.requestToJoinLoading loading: model.requestToJoinLoading
enabled: acceptButton.interactive enabled: !acceptPendingButtonVisible
onClicked: root.acceptRequestToJoin(model.requestToJoinId) onClicked: root.acceptRequestToJoin(model.requestToJoinId)
}
}, },
DisabledTooltipButton { StatusButton {
id: rejectButton id: rejectButton
anchors.verticalCenter: parent.verticalCenter opacity: rejectButtonVisible
//using opacity instead of visible to avoid the acceptButton jumping around text: qsTr("Reject")
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")
type: StatusBaseButton.Type.Danger type: StatusBaseButton.Type.Danger
icon.name: "close-circle" icon.name: "close-circle"
icon.color: enabled ? Style.current.danger : disabledTextColor icon.color: enabled ? Style.current.danger : disabledTextColor
enabled: rejectButton.interactive enabled: !rejectPendingButtonVisible
onClicked: root.declineRequestToJoin(model.requestToJoinId) onClicked: root.declineRequestToJoin(model.requestToJoinId)
} }
}
] ]
width: membersList.width 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 }
} }