mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2025-12-05 21:15:38 -05:00
107 lines
3.9 KiB
QML
107 lines
3.9 KiB
QML
import QtQuick
|
|
import QtQuick.Effects
|
|
import qs.Common
|
|
import qs.Services
|
|
import qs.Widgets
|
|
|
|
Card {
|
|
id: root
|
|
|
|
Row {
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Theme.spacingM
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
spacing: Theme.spacingM
|
|
|
|
DankCircularImage {
|
|
id: avatarContainer
|
|
|
|
width: 77
|
|
height: 77
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
imageSource: {
|
|
if (PortalService.profileImage === "")
|
|
return ""
|
|
|
|
if (PortalService.profileImage.startsWith("/"))
|
|
return "file://" + PortalService.profileImage
|
|
|
|
return PortalService.profileImage
|
|
}
|
|
fallbackIcon: "person"
|
|
}
|
|
|
|
Column {
|
|
spacing: Theme.spacingS
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
StyledText {
|
|
text: UserInfoService.username || "brandon"
|
|
font.pixelSize: Theme.fontSizeLarge
|
|
font.weight: Font.Medium
|
|
color: Theme.surfaceText
|
|
elide: Text.ElideRight
|
|
width: parent.parent.parent.width - avatarContainer.width - Theme.spacingM * 3
|
|
}
|
|
|
|
Row {
|
|
spacing: Theme.spacingS
|
|
|
|
SystemLogo {
|
|
width: 16
|
|
height: 16
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
colorOverride: Theme.primary
|
|
}
|
|
|
|
StyledText {
|
|
text: {
|
|
if (CompositorService.isNiri) return "on niri"
|
|
if (CompositorService.isHyprland) return "on Hyprland"
|
|
return ""
|
|
}
|
|
font.pixelSize: Theme.fontSizeSmall
|
|
color: Qt.rgba(Theme.surfaceText.r, Theme.surfaceText.g, Theme.surfaceText.b, 0.8)
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
elide: Text.ElideRight
|
|
width: parent.parent.parent.parent.width - avatarContainer.width - Theme.spacingM * 3 - 16 - Theme.spacingS
|
|
}
|
|
}
|
|
|
|
Row {
|
|
spacing: Theme.spacingS
|
|
|
|
DankIcon {
|
|
name: "schedule"
|
|
size: 16
|
|
color: Theme.primary
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
|
|
StyledText {
|
|
id: uptimeText
|
|
|
|
property real availableWidth: parent.parent.parent.parent.width - avatarContainer.width - Theme.spacingM * 3 - 16 - Theme.spacingS
|
|
property real longTextWidth: {
|
|
const fontSize = Math.round(Theme.fontSizeSmall || 12)
|
|
const testMetrics = Qt.createQmlObject('import QtQuick; TextMetrics { font.pixelSize: ' + fontSize + ' }', uptimeText)
|
|
testMetrics.text = UserInfoService.uptime || "up 1 hour, 23 minutes"
|
|
const result = testMetrics.width
|
|
testMetrics.destroy()
|
|
return result
|
|
}
|
|
// Just using truncated is always true initially idk
|
|
property bool shouldUseShort: longTextWidth > availableWidth
|
|
|
|
text: shouldUseShort ? UserInfoService.shortUptime : UserInfoService.uptime || "up 1h 23m"
|
|
font.pixelSize: Theme.fontSizeSmall
|
|
color: Qt.rgba(Theme.surfaceText.r, Theme.surfaceText.g, Theme.surfaceText.b, 0.7)
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
elide: Text.ElideRight
|
|
width: availableWidth
|
|
wrapMode: Text.NoWrap
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} |