Files
metabuilder/fakemui/qml-components/data-display/CStatusBadge.qml
JohnDoe6345789 58a94d0489 feat(styles): add component-specific styles for TaskDetail, SearchDialog, and Documentation
feat(styles): create global styles entry point and organize global styles

feat(styles): implement base HTML element styles and utility classes for flexbox

feat(styles): establish layout, position, spacing, and text utility classes

feat(styles): introduce mixins for animations, cards, dialogs, flexbox, grid, and responsive design

test(quick_guide): add component and metadata validation tests for quick_guide package

test(ui_level6): implement metadata validation tests for ui_level6 package
2025-12-30 02:29:58 +00:00

65 lines
1.8 KiB
QML

import QtQuick
Rectangle {
id: badge
property string status: "unknown" // completed, running, queued, failed, unknown
property string text: status
property bool showDot: true
property var themeColors: ({})
// Internal colors with fallbacks
readonly property var colors: ({
success: themeColors.success || "#22c55e",
info: themeColors.info || "#3b82f6",
warning: themeColors.warning || "#f59e0b",
error: themeColors.error || "#ef4444",
neutral: themeColors.mid || "#333333"
})
implicitHeight: 22
implicitWidth: badgeRow.implicitWidth + 12
radius: 4
color: {
switch(status) {
case "completed": return colors.success
case "running": return colors.info
case "queued": return colors.warning
case "failed": return colors.error
default: return colors.neutral
}
}
Row {
id: badgeRow
anchors.centerIn: parent
spacing: 6
// Animated dot for running status
Rectangle {
anchors.verticalCenter: parent.verticalCenter
width: 6
height: 6
radius: 3
color: "#ffffff"
visible: badge.showDot && badge.status === "running"
SequentialAnimation on opacity {
running: badge.status === "running"
loops: Animation.Infinite
NumberAnimation { to: 0.3; duration: 500 }
NumberAnimation { to: 1.0; duration: 500 }
}
}
Text {
text: badge.text
font.pixelSize: 11
font.weight: Font.Medium
color: "#ffffff"
textFormat: Text.PlainText
}
}
}