2022-05-13 13:12:05 +00:00
|
|
|
// Copyright (C) 2021 The Qt Company Ltd.
|
|
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
|
2021-02-10 11:52:50 +00:00
|
|
|
import QtQuick
|
|
|
|
import QtQuick.Controls
|
|
|
|
import QtQuick.Layouts
|
|
|
|
import QtQuick.LocalStorage
|
2016-10-27 14:11:01 +00:00
|
|
|
import "Database.js" as JS
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: root
|
2019-09-17 16:10:59 +00:00
|
|
|
required property ListView listView
|
2021-02-10 13:51:42 +00:00
|
|
|
signal statusMessage(string msg)
|
2023-02-20 18:36:40 +00:00
|
|
|
|
|
|
|
width: Screen.width / 2
|
|
|
|
height: Screen.height / 7
|
2021-02-10 13:51:42 +00:00
|
|
|
enabled: false
|
2019-09-17 16:10:59 +00:00
|
|
|
|
2016-10-27 14:11:01 +00:00
|
|
|
function insertrec() {
|
2023-02-20 18:36:40 +00:00
|
|
|
const rowid = parseInt(JS.dbInsert(dateInput.text, descInput.text, distInput.text), 10)
|
2016-10-27 14:11:01 +00:00
|
|
|
if (rowid) {
|
|
|
|
listView.model.setProperty(listView.currentIndex, "id", rowid)
|
|
|
|
listView.forceLayout()
|
|
|
|
}
|
|
|
|
return rowid;
|
|
|
|
}
|
|
|
|
|
|
|
|
function editrec(Pdate, Pdesc, Pdistance, Prowid) {
|
|
|
|
dateInput.text = Pdate
|
|
|
|
descInput.text = Pdesc
|
|
|
|
distInput.text = Pdistance
|
|
|
|
}
|
|
|
|
|
|
|
|
function initrec_new() {
|
2016-12-13 11:55:40 +00:00
|
|
|
dateInput.clear()
|
|
|
|
descInput.clear()
|
|
|
|
distInput.clear()
|
2016-10-27 14:11:01 +00:00
|
|
|
listView.model.insert(0, {
|
|
|
|
date: "",
|
|
|
|
trip_desc: "",
|
2016-12-13 11:55:40 +00:00
|
|
|
distance: 0
|
2016-10-27 14:11:01 +00:00
|
|
|
})
|
|
|
|
listView.currentIndex = 0
|
|
|
|
dateInput.forceActiveFocus()
|
|
|
|
}
|
|
|
|
|
|
|
|
function initrec() {
|
2016-12-13 11:55:40 +00:00
|
|
|
dateInput.clear()
|
|
|
|
descInput.clear()
|
|
|
|
distInput.clear()
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function setlistview() {
|
|
|
|
listView.model.setProperty(listView.currentIndex, "date",
|
|
|
|
dateInput.text)
|
|
|
|
listView.model.setProperty(listView.currentIndex, "trip_desc",
|
|
|
|
descInput.text)
|
|
|
|
listView.model.setProperty(listView.currentIndex, "distance",
|
2016-12-13 11:55:40 +00:00
|
|
|
parseInt(distInput.text,10))
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: rootrect
|
|
|
|
border.width: 10
|
|
|
|
color: "#161616"
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
id: mainLayout
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: gridBox
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
|
|
|
GridLayout {
|
|
|
|
id: gridLayout
|
|
|
|
rows: 3
|
|
|
|
flow: GridLayout.TopToBottom
|
|
|
|
anchors.fill: parent
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
Label {
|
2021-02-10 13:51:42 +00:00
|
|
|
text: qsTr("Date")
|
2016-10-27 14:11:01 +00:00
|
|
|
font.pixelSize: 22
|
|
|
|
rightPadding: 10
|
|
|
|
}
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
Label {
|
2021-02-10 13:51:42 +00:00
|
|
|
text: qsTr("Description")
|
2016-10-27 14:11:01 +00:00
|
|
|
font.pixelSize: 22
|
|
|
|
rightPadding: 10
|
|
|
|
}
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
Label {
|
2021-02-10 13:51:42 +00:00
|
|
|
text: qsTr("Distance")
|
2016-10-27 14:11:01 +00:00
|
|
|
font.pixelSize: 22
|
|
|
|
}
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
TextField {
|
2016-10-27 14:11:01 +00:00
|
|
|
id: dateInput
|
|
|
|
font.pixelSize: 22
|
|
|
|
activeFocusOnPress: true
|
|
|
|
activeFocusOnTab: true
|
2024-01-19 17:06:58 +00:00
|
|
|
Layout.fillWidth: false
|
2021-02-10 13:51:42 +00:00
|
|
|
|
|
|
|
ToolTip {
|
|
|
|
x: parent.width + 3
|
|
|
|
y: (parent.height - height) / 2
|
|
|
|
text: qsTr("Date format = 'YYYY-MM-DD'")
|
2023-02-20 18:36:40 +00:00
|
|
|
visible: dateInput.enabled && dateInput.hovered
|
2021-02-10 13:51:42 +00:00
|
|
|
delay: 1000
|
|
|
|
}
|
|
|
|
|
2019-05-22 16:18:05 +00:00
|
|
|
validator: RegularExpressionValidator {
|
2021-02-10 13:51:42 +00:00
|
|
|
regularExpression: /\d{4}[,.:/-]\d\d?[,.:/-]\d\d?/
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
2021-02-10 13:51:42 +00:00
|
|
|
|
2023-02-20 18:36:40 +00:00
|
|
|
onFocusChanged: function() {
|
2021-02-10 13:51:42 +00:00
|
|
|
if (!dateInput.focus && !acceptableInput && root.enabled)
|
|
|
|
root.statusMessage(qsTr("Please fill in the date"));
|
|
|
|
}
|
|
|
|
|
2023-02-20 18:36:40 +00:00
|
|
|
onEditingFinished: function() {
|
|
|
|
const regex = /(\d+)[,.:/-](\d+)[,.:/-](\d+)/
|
2021-02-10 13:51:42 +00:00
|
|
|
if (dateInput.text.match(regex))
|
|
|
|
dateInput.text = dateInput.text.replace(regex, '$1-$2-$3')
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
TextField {
|
2016-10-27 14:11:01 +00:00
|
|
|
id: descInput
|
2023-02-20 18:36:40 +00:00
|
|
|
property string oldString
|
2016-10-27 14:11:01 +00:00
|
|
|
font.pixelSize: 22
|
|
|
|
activeFocusOnPress: true
|
|
|
|
activeFocusOnTab: true
|
2024-01-19 17:06:58 +00:00
|
|
|
Layout.fillWidth: false
|
2023-02-20 18:36:40 +00:00
|
|
|
onFocusChanged: if (focus) oldString = descInput.text
|
|
|
|
onEditingFinished: function() {
|
|
|
|
if (descInput.text.length < 8 && descInput.text !== descInput.oldString && root.enabled)
|
2021-02-10 13:51:42 +00:00
|
|
|
root.statusMessage(qsTr("Enter a description of minimum 8 characters"))
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-10 11:52:50 +00:00
|
|
|
TextField {
|
2016-10-27 14:11:01 +00:00
|
|
|
id: distInput
|
2023-02-20 18:36:40 +00:00
|
|
|
property string oldString
|
2016-10-27 14:11:01 +00:00
|
|
|
font.pixelSize: 22
|
|
|
|
activeFocusOnPress: true
|
|
|
|
activeFocusOnTab: true
|
2024-01-19 17:06:58 +00:00
|
|
|
Layout.fillWidth: false
|
2019-05-22 16:18:05 +00:00
|
|
|
validator: RegularExpressionValidator {
|
|
|
|
regularExpression: /\d{1,3}/
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
2023-02-20 18:36:40 +00:00
|
|
|
onFocusChanged: if (focus) oldString = distInput.text
|
|
|
|
onEditingFinished: function() {
|
|
|
|
if (distInput.text === "" && distInput.text !== distInput.oldString && root.enabled)
|
2021-02-10 13:51:42 +00:00
|
|
|
root.statusMessage(qsTr("Please fill in the distance"))
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-11-28 11:01:56 +00:00
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: dateInput.forceActiveFocus()
|
|
|
|
}
|
2016-10-27 14:11:01 +00:00
|
|
|
}
|