2021-06-14 19:09:53 +02:00
|
|
|
|
// SPDX-License-Identifier: Unlicense
|
|
|
|
|
|
|
|
|
|
import QtQuick 2.12
|
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
|
import QtQuick.Layouts 1.6
|
|
|
|
|
|
|
|
|
|
import 'util.js' as Util
|
|
|
|
|
|
|
|
|
|
// This is the delegate for event list items.
|
2021-09-01 17:13:51 +02:00
|
|
|
|
ItemDelegate {
|
|
|
|
|
required property var model
|
|
|
|
|
required property int index
|
|
|
|
|
required property int time
|
2021-06-14 19:09:53 +02:00
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
property alias fields: inputs.model // field definitions
|
2021-06-14 19:09:53 +02:00
|
|
|
|
property bool editing: false
|
|
|
|
|
|
|
|
|
|
clip: true
|
|
|
|
|
padding: 2
|
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
background: Rectangle {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
color: highlighted ? Util.alphize(border.color, 0.1) :
|
|
|
|
|
(index % 2 === 0 ? palette.base : palette.alternateBase)
|
|
|
|
|
border {
|
|
|
|
|
color: editing ? palette.highlight : palette.dark
|
|
|
|
|
width: highlighted ? 1 : 0
|
|
|
|
|
}
|
|
|
|
|
radius: border.width
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set inputs to current model values.
|
2021-06-14 19:09:53 +02:00
|
|
|
|
function reset() {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
for (var i = 0; i < fields.length; i++) {
|
2021-06-14 19:09:53 +02:00
|
|
|
|
const child = inputs.itemAt(i)
|
|
|
|
|
if (child && child.item)
|
2021-09-01 17:13:51 +02:00
|
|
|
|
child.item.set(model.values[fields[i].name])
|
2021-06-14 19:09:53 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
// Store current inputs in model.
|
2021-06-14 19:09:53 +02:00
|
|
|
|
function store() {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
var values = {}
|
|
|
|
|
for (var i = 0; i < fields.length; i++)
|
|
|
|
|
values[fields[i].name] = inputs.itemAt(i).item.value
|
|
|
|
|
model.values = values
|
2021-06-14 19:09:53 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
Component.onCompleted: reset()
|
|
|
|
|
onEditingChanged: {
|
|
|
|
|
if (editing)
|
|
|
|
|
forceActiveFocus()
|
|
|
|
|
}
|
2021-06-14 19:09:53 +02:00
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
// Try passing key to each field input in order.
|
|
|
|
|
Keys.forwardTo: Array.from({ length: inputs.count }, (_, i) => inputs.itemAt(i).item)
|
2021-06-14 19:09:53 +02:00
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
contentItem: ColumnLayout {
|
2021-06-14 19:09:53 +02:00
|
|
|
|
anchors { left: parent.left; right: parent.right; margins: 5 }
|
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
// Event time, tag and summary.
|
2021-06-14 19:09:53 +02:00
|
|
|
|
RowLayout {
|
|
|
|
|
Label {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
text: new Date(model.time).toISOString().substr(12, 9)
|
2021-06-14 19:09:53 +02:00
|
|
|
|
font.pixelSize: 10
|
|
|
|
|
Layout.alignment: Qt.AlignBaseline
|
|
|
|
|
}
|
|
|
|
|
Label {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
text: model.tag
|
2021-06-14 19:09:53 +02:00
|
|
|
|
font.weight: Font.DemiBold
|
|
|
|
|
Layout.alignment: Qt.AlignBaseline
|
|
|
|
|
}
|
|
|
|
|
Label {
|
|
|
|
|
text: {
|
|
|
|
|
var str = ''
|
2021-09-01 17:13:51 +02:00
|
|
|
|
for (var i = 0; i < inputs.count; i++) {
|
|
|
|
|
const field = inputs.model[i]
|
|
|
|
|
const value = inputs.itemAt(i).item.value
|
|
|
|
|
if (value && field.type !== 'TextArea')
|
|
|
|
|
str += (field.type === 'Bool' ? field.name : value) + ' '
|
2021-06-14 19:09:53 +02:00
|
|
|
|
}
|
|
|
|
|
return str
|
|
|
|
|
}
|
|
|
|
|
elide: Text.ElideRight
|
|
|
|
|
textFormat: Text.PlainText
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.alignment: Qt.AlignBaseline
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-01 17:13:51 +02:00
|
|
|
|
// Event‐specific input fields.
|
2021-06-14 19:09:53 +02:00
|
|
|
|
GridLayout {
|
|
|
|
|
flow: GridLayout.TopToBottom
|
|
|
|
|
rows: inputs.count
|
|
|
|
|
|
|
|
|
|
columnSpacing: 10
|
|
|
|
|
visible: editing
|
|
|
|
|
|
|
|
|
|
// Labels.
|
|
|
|
|
Repeater {
|
|
|
|
|
model: inputs.model
|
|
|
|
|
delegate: Label {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
text: Util.addShortcut(modelData.name, modelData.key)
|
2021-06-14 19:09:53 +02:00
|
|
|
|
Layout.alignment: Qt.AlignRight
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Inputs.
|
|
|
|
|
Repeater {
|
|
|
|
|
id: inputs
|
|
|
|
|
delegate: Loader {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
source: 'qrc:/Fields/' + modelData.type + '.qml'
|
2021-06-14 19:09:53 +02:00
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Binding {
|
2021-09-01 17:13:51 +02:00
|
|
|
|
target: item; property: 'model'
|
|
|
|
|
value: modelData
|
2021-06-14 19:09:53 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|