106 lines
2.3 KiB
QML
106 lines
2.3 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts 1.15
|
|
import QtGraphicalEffects 1.15
|
|
|
|
import StatusQ 0.1
|
|
import StatusQ.Components 0.1
|
|
import StatusQ.Controls 0.1
|
|
import StatusQ.Core 0.1
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
Item {
|
|
id: root
|
|
implicitHeight: 50
|
|
|
|
required property string name
|
|
required property string url
|
|
required property string iconUrl
|
|
|
|
signal disconnectDapp()
|
|
|
|
RowLayout {
|
|
anchors.fill: parent
|
|
anchors.margins: 8
|
|
|
|
Item {
|
|
Layout.preferredWidth: 32
|
|
Layout.preferredHeight: 32
|
|
|
|
StatusImage {
|
|
id: iconImage
|
|
|
|
anchors.fill: parent
|
|
|
|
source: iconUrl
|
|
visible: !fallbackImage.visible
|
|
}
|
|
|
|
StatusIcon {
|
|
id: fallbackImage
|
|
|
|
anchors.fill: parent
|
|
|
|
icon: "dapp"
|
|
color: Theme.palette.baseColor1
|
|
|
|
visible: iconImage.isLoading || iconImage.isError || !iconUrl
|
|
}
|
|
|
|
layer.enabled: true
|
|
layer.effect: OpacityMask {
|
|
maskSource: Rectangle {
|
|
width: iconImage.width
|
|
height: iconImage.height
|
|
radius: width / 2
|
|
visible: false
|
|
}
|
|
}
|
|
}
|
|
|
|
ColumnLayout {
|
|
Layout.leftMargin: 12
|
|
Layout.rightMargin: 12
|
|
|
|
StatusBaseText {
|
|
text: name
|
|
|
|
Layout.fillWidth: true
|
|
|
|
font.pixelSize: 13
|
|
font.bold: true
|
|
|
|
elide: Text.ElideRight
|
|
|
|
clip: true
|
|
}
|
|
StatusBaseText {
|
|
text: url
|
|
|
|
Layout.fillWidth: true
|
|
|
|
font.pixelSize: 12
|
|
color: Theme.palette.baseColor1
|
|
|
|
elide: Text.ElideRight
|
|
|
|
clip: true
|
|
}
|
|
}
|
|
|
|
// TODO #14588 - Show tooltip on hover "Disconnect dApp"
|
|
StatusRoundButton {
|
|
implicitWidth: 32
|
|
implicitHeight: 32
|
|
radius: width / 2
|
|
|
|
icon.name: "disconnect"
|
|
|
|
onClicked: {
|
|
console.debug(`TODO #14755 - Disconnect ${name}`)
|
|
//root.disconnectDapp()
|
|
}
|
|
}
|
|
}
|
|
} |