Files
metabuilder/fakemui/qml-components/lab/CDateTimePicker.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

67 lines
2.0 KiB
QML

import QtQuick
import QtQuick.Controls
import QtQuick.Layouts
Item {
id: dateTimePicker
property date value: new Date()
property string label: ""
property bool disabled: false
signal dateTimeChanged(date newDateTime)
implicitWidth: datePickerItem.implicitWidth + timePickerItem.implicitWidth + 16
implicitHeight: contentColumn.implicitHeight
ColumnLayout {
id: contentColumn
anchors.fill: parent
spacing: 4
// Label
Text {
visible: dateTimePicker.label
text: dateTimePicker.label
font.pixelSize: 12
color: "#666666"
}
RowLayout {
Layout.fillWidth: true
spacing: 8
CDatePicker {
id: datePickerItem
value: dateTimePicker.value
disabled: dateTimePicker.disabled
onDateChanged: function(newDate) {
if (newDate && !isNaN(newDate.getTime())) {
var current = dateTimePicker.value
newDate.setHours(current.getHours(), current.getMinutes())
dateTimePicker.value = newDate
dateTimeChanged(newDate)
}
}
}
CTimePicker {
id: timePickerItem
value: dateTimePicker.value
disabled: dateTimePicker.disabled
onTimeChanged: function(newTime) {
if (newTime && !isNaN(newTime.getTime())) {
var current = dateTimePicker.value
var newDate = new Date(current)
newDate.setHours(newTime.getHours(), newTime.getMinutes())
dateTimePicker.value = newDate
dateTimeChanged(newDate)
}
}
}
}
}
}