mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-24 13:32:22 +00:00
aa8d9a7f48
A `StatusIcon` that rotates infinitely and can be used for indicating pending states. Usage: ``` StatusLoadingIndicator { width: 24 // default: 17 height: 24 // default: 17 color: "red" // default: loading asset color } ``` This also removes `LoadingImage` component from `ui/shared`. Closes #2360
117 lines
3.4 KiB
QML
117 lines
3.4 KiB
QML
import QtQuick 2.13
|
|
import QtGraphicalEffects 1.13
|
|
import "../../../../../imports"
|
|
import "../../../../../shared"
|
|
import "../../../../../shared/status/core"
|
|
import "../../../../../shared/status"
|
|
|
|
Rectangle {
|
|
property url collectibleIconSource: "../../../../img/collectibles/CryptoKitties.png"
|
|
property string collectibleName: "CryptoKitties"
|
|
property bool isLoading: true
|
|
property bool hovered: false
|
|
property var toggleCollectible: function () {}
|
|
property int collectiblesQty: 6
|
|
|
|
id: collectibleHeader
|
|
height: 64
|
|
width: parent.width
|
|
color: hovered ? Style.current.backgroundHover : Style.current.transparent
|
|
border.width: 0
|
|
radius: Style.current.radius
|
|
|
|
Image {
|
|
id: collectibleIconImage
|
|
source: collectibleHeader.collectibleIconSource
|
|
width: 40
|
|
height: 40
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.padding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
|
|
StyledText {
|
|
id: collectibleName
|
|
text: collectibleHeader.collectibleName
|
|
anchors.left: collectibleIconImage.right
|
|
anchors.leftMargin: Style.current.padding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
font.pixelSize: 17
|
|
}
|
|
|
|
StyledText {
|
|
visible: collectiblesQty >= Constants.maxTokens
|
|
//% "Maximum number of collectibles to display reached"
|
|
text: qsTrId("maximum-number-of-collectibles-to-display-reached")
|
|
font.pixelSize: 17
|
|
color: Style.current.secondaryText
|
|
anchors.left: collectibleName.right
|
|
anchors.leftMargin: Style.current.padding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
Loader {
|
|
active: true
|
|
sourceComponent: collectibleHeader.isLoading ? loadingComponent : handleComponent
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: Style.current.padding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
|
|
Component {
|
|
id: loadingComponent
|
|
|
|
StatusLoadingIndicator {}
|
|
}
|
|
|
|
Component {
|
|
id: handleComponent
|
|
|
|
Item {
|
|
id: element1
|
|
width: childrenRect.width
|
|
height: numberCollectibleText.height
|
|
|
|
StyledText {
|
|
id: numberCollectibleText
|
|
color: Style.current.secondaryText
|
|
text: !!error ? "-" : collectibleHeader.collectiblesQty
|
|
font.pixelSize: 15
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
|
|
SVGImage {
|
|
id: caretImg
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
source: "../../../../img/caret.svg"
|
|
width: 11
|
|
anchors.left: numberCollectibleText.right
|
|
anchors.leftMargin: Style.current.padding
|
|
fillMode: Image.PreserveAspectFit
|
|
}
|
|
ColorOverlay {
|
|
anchors.fill: caretImg
|
|
source: caretImg
|
|
color: Style.current.black
|
|
}
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
enabled: !collectibleHeader.isLoading
|
|
anchors.fill: parent
|
|
cursorShape: Qt.PointingHandCursor
|
|
hoverEnabled: true
|
|
onEntered: {
|
|
collectibleHeader.hovered = true
|
|
}
|
|
onExited: {
|
|
collectibleHeader.hovered = false
|
|
}
|
|
onClicked: {
|
|
collectibleHeader.toggleCollectible()
|
|
}
|
|
}
|
|
}
|