Library migration #36
6 changed files with 55 additions and 310 deletions
|
@ -1,30 +0,0 @@
|
||||||
import QtQuick 2.9
|
|
||||||
import QtMultimedia 5.8
|
|
||||||
import QtQuick.Window 2.2
|
|
||||||
import QtQuick.Controls 2.2
|
|
||||||
import QtQuick.Layouts 1.3
|
|
||||||
import QtGraphicalEffects 1.0
|
|
||||||
import QtQuick.Controls.Styles 1.4
|
|
||||||
import "../components"
|
|
||||||
|
|
||||||
ListView {
|
|
||||||
id: control
|
|
||||||
|
|
||||||
property string title: qsTr("connections")
|
|
||||||
property var parentObj
|
|
||||||
|
|
||||||
spacing: parentObj.rowSpacing
|
|
||||||
boundsBehavior: Flickable.StopAtBounds
|
|
||||||
|
|
||||||
model: speedBackend.scStwClient.extensions.length
|
|
||||||
delegate: ConnectionDelegate {
|
|
||||||
|
|
||||||
opacity: 1
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: parentObj.delegateHeight
|
|
||||||
|
|
||||||
text: speedBackend.scStwClient.extensions[index]["name"]
|
|
||||||
status: {'status': speedBackend.scStwClient.extensions[index]["state"], 'progress': speedBackend.scStwClient.extensions[index]["progress"]}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -21,24 +21,6 @@ Column {
|
||||||
|
|
||||||
opacity: 0
|
opacity: 0
|
||||||
|
|
||||||
function doFirmwareUpdate() {
|
|
||||||
doFirmwareUpdateTimer.start()
|
|
||||||
}
|
|
||||||
|
|
||||||
Timer {
|
|
||||||
id: doFirmwareUpdateTimer
|
|
||||||
|
|
||||||
interval: 10
|
|
||||||
repeat: false
|
|
||||||
running: false
|
|
||||||
|
|
||||||
onTriggered: {
|
|
||||||
busyDl.open()
|
|
||||||
var ret = speedBackend.scStwClient.updateFirmware()
|
|
||||||
busyDl.displayMessageAndClose(ret ? "OK":"error", ret ? "#6bd43b":"#e03b2f" )
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ConnectionDelegate {
|
ConnectionDelegate {
|
||||||
id: connectToBaseDel
|
id: connectToBaseDel
|
||||||
|
|
||||||
|
@ -188,258 +170,69 @@ Column {
|
||||||
Component {
|
Component {
|
||||||
id: baseStationConnectedOptionsComp
|
id: baseStationConnectedOptionsComp
|
||||||
|
|
||||||
ScrollView{
|
Column {
|
||||||
id: flickable
|
id: baseStationConnectedOptions
|
||||||
contentHeight: baseStationConnectedOptions.childrenRect.height
|
|
||||||
contentWidth: -1
|
|
||||||
width: parentComp.width
|
width: parentComp.width
|
||||||
height: control.height - baseStationOptionsLd.y
|
|
||||||
|
|
||||||
clip: true
|
|
||||||
|
|
||||||
opacity: 0 // opacity and scale are adjusted by baseStationOptionsLd
|
|
||||||
scale: 0.95
|
|
||||||
|
|
||||||
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
||||||
ScrollBar.vertical: ScrollBar {
|
|
||||||
parent: flickable.parent
|
|
||||||
anchors.top: flickable.top
|
|
||||||
anchors.left: flickable.right
|
|
||||||
anchors.bottom: flickable.bottom
|
|
||||||
policy: ScrollBar.AlwaysOn
|
|
||||||
interactive: false
|
|
||||||
}
|
|
||||||
|
|
||||||
Column {
|
|
||||||
id: baseStationConnectedOptions
|
|
||||||
|
|
||||||
width: parentComp.width
|
|
||||||
|
|
||||||
SmoothSliderDelegate {
|
|
||||||
id: baseStationVolumeDel
|
|
||||||
text: qsTr("volume")
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: parentObj.delegateHeight
|
|
||||||
|
|
||||||
sliderValue: 0
|
|
||||||
|
|
||||||
onSliderFinished: {
|
|
||||||
enabled = false
|
|
||||||
speedBackend.writeSetting("SoundVolume", sliderValue)
|
|
||||||
enabled = true
|
|
||||||
}
|
|
||||||
|
|
||||||
Component.onCompleted: {
|
|
||||||
var val = speedBackend.readSetting("SoundVolume")
|
|
||||||
if(val !== "false"){
|
|
||||||
sliderValue = parseFloat(val)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
NextPageDelegate {
|
|
||||||
id: baseStationConnectionsDel
|
|
||||||
text: qsTr("connected extensions")
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: parentObj.delegateHeight
|
|
||||||
|
|
||||||
visible: height > 5
|
|
||||||
|
|
||||||
onClicked: {
|
|
||||||
parentObj.push(baseStationConnections)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
SmoothItemDelegate {
|
|
||||||
id: connectUsbExtensionsDel
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: parentObj.delegateHeight
|
|
||||||
|
|
||||||
text: "pair extensions"
|
|
||||||
|
|
||||||
onClicked: {
|
|
||||||
busyDl.open()
|
|
||||||
var ret = speedBackend.scStwClient.pairConnectedUsbExtensions()
|
|
||||||
busyDl.displayMessageAndClose(ret === 200 ? "OK":"error", ret === 200 ? "#6bd43b":"#e03b2f" )
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
SmoothItemDelegate {
|
|
||||||
id: baseStationUpdateDel
|
|
||||||
|
|
||||||
// 0: hidden 1: update firmware 2: sync time
|
|
||||||
property int mode: speedBackend.scStwClient.isFirmwareUpToDate() ?
|
|
||||||
(Math.abs(parseInt(speedBackend.scStwClient.getTimeOffset())) > 10000 ? 2:0)
|
|
||||||
:1
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: mode > 0 ? parentObj.delegateHeight:0
|
|
||||||
|
|
||||||
visible: height > 5
|
|
||||||
|
|
||||||
text: mode === 2 ? qsTr("sync time"):qsTr("update firmware")
|
|
||||||
|
|
||||||
onClicked: {
|
|
||||||
if(mode === 1) {
|
|
||||||
control.doFirmwareUpdate()
|
|
||||||
}
|
|
||||||
else if(mode === 2){
|
|
||||||
busyDl.open()
|
|
||||||
var ret = speedBackend.scStwClient.updateTime()
|
|
||||||
busyDl.displayMessageAndClose(ret ? "OK":"error", ret ? "#6bd43b":"#e03b2f" )
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Rectangle {
|
|
||||||
anchors.left: parent.left
|
|
||||||
width: parent.width
|
|
||||||
height: 1
|
|
||||||
color: appTheme.style.lineColor
|
|
||||||
}
|
|
||||||
|
|
||||||
Item {
|
|
||||||
anchors.left: parent.left
|
|
||||||
width: parent.width
|
|
||||||
height: parentObj.delegateHeight * 0.5
|
|
||||||
|
|
||||||
|
|
||||||
Label {
|
|
||||||
|
|
||||||
anchors {
|
|
||||||
top: parent.top
|
|
||||||
left: parent.left
|
|
||||||
}
|
|
||||||
|
|
||||||
width: parent.width * 0.5
|
|
||||||
height: parent.height * 0.5
|
|
||||||
|
|
||||||
|
|
||||||
verticalAlignment: Text.AlignTop
|
|
||||||
horizontalAlignment: Text.AlignLeft
|
|
||||||
|
|
||||||
fontSizeMode: Text.Fit
|
|
||||||
font.pixelSize: height
|
|
||||||
|
|
||||||
minimumPixelSize: 1
|
|
||||||
|
|
||||||
color: appTheme.style.lineColor
|
|
||||||
text: "version: " + speedBackend.scStwClient.getFirmwareVersion()
|
|
||||||
}
|
|
||||||
|
|
||||||
Label {
|
|
||||||
|
|
||||||
property var date: new Date(new Date().getTime() + parseInt(speedBackend.scStwClient.getTimeOffset()))
|
|
||||||
|
|
||||||
anchors {
|
|
||||||
top: parent.top
|
|
||||||
right: parent.right
|
|
||||||
}
|
|
||||||
|
|
||||||
width: parent.width * 0.5
|
|
||||||
height: parent.height
|
|
||||||
|
|
||||||
verticalAlignment: Text.AlignTop
|
|
||||||
horizontalAlignment: Text.AlignRight
|
|
||||||
|
|
||||||
fontSizeMode: Text.Fit
|
|
||||||
|
|
||||||
minimumPixelSize: 1
|
|
||||||
font.pixelSize: height
|
|
||||||
|
|
||||||
color: appTheme.style.lineColor
|
|
||||||
text: date.toLocaleDateString() + "\n" + date.toLocaleTimeString()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
Popup {
|
|
||||||
id: busyDl
|
|
||||||
|
|
||||||
property string message: ""
|
|
||||||
property color messageColor: "transparent"
|
|
||||||
|
|
||||||
x: Math.round((parent.width - width) / 2)
|
|
||||||
y: Math.round((parent.height - height) / 2)
|
|
||||||
|
|
||||||
width: app.width
|
|
||||||
height: app.height
|
|
||||||
|
|
||||||
modal: true
|
|
||||||
dim: true
|
|
||||||
|
|
||||||
closePolicy: Dialog.NoAutoClose
|
|
||||||
|
|
||||||
function displayMessageAndClose(message, messageColor) {
|
|
||||||
busyDl.message = message
|
|
||||||
busyDl.messageColor = messageColor
|
|
||||||
|
|
||||||
closeDelayTimer.start()
|
|
||||||
}
|
|
||||||
|
|
||||||
Timer {
|
|
||||||
id: closeDelayTimer
|
|
||||||
|
|
||||||
interval: 1000
|
|
||||||
repeat: false
|
|
||||||
running: false
|
|
||||||
|
|
||||||
onTriggered: {
|
|
||||||
busyDl.close()
|
|
||||||
busyDl.message = ""
|
|
||||||
busyDl.messageColor = "transparent"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
background: Item {
|
|
||||||
FancyBusyIndicator {
|
|
||||||
anchors.centerIn: parent
|
|
||||||
opacity: busyDl.message === "" ? 1:0
|
|
||||||
|
|
||||||
lineColor: "white"
|
|
||||||
|
|
||||||
Behavior on opacity { NumberAnimation { duration: 150 } }
|
|
||||||
}
|
|
||||||
|
|
||||||
Label {
|
Label {
|
||||||
anchors.centerIn: parent
|
id: headerLabel
|
||||||
|
|
||||||
width: parent.width * 0.5
|
width: parent.width
|
||||||
height: parent.height * 0.5
|
height: parentObj.delegateHeight
|
||||||
|
|
||||||
opacity: busyDl.message === "" ? 0:1
|
|
||||||
|
|
||||||
color: busyDl.messageColor
|
|
||||||
text: busyDl.message
|
|
||||||
|
|
||||||
fontSizeMode: Text.Fit
|
|
||||||
font.pixelSize: height
|
|
||||||
minimumPixelSize: 1
|
|
||||||
|
|
||||||
font.bold: true
|
|
||||||
|
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
|
||||||
Behavior on opacity { NumberAnimation { duration: 150 } }
|
fontSizeMode: Text.Fit
|
||||||
}
|
font.pixelSize: height
|
||||||
}
|
|
||||||
|
|
||||||
T.Overlay.modal: Rectangle {
|
minimumPixelSize: 1
|
||||||
id: modalRect
|
|
||||||
color: "#80404040"
|
text: "ScStwBaseStation"
|
||||||
Behavior on opacity { NumberAnimation { duration: 150 } }
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
id: firmwareVersionLabel
|
||||||
|
|
||||||
|
width: parent.width
|
||||||
|
height: parentObj.delegateHeight * 0.3
|
||||||
|
|
||||||
|
|
||||||
|
verticalAlignment: Text.AlignTop
|
||||||
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
|
||||||
|
fontSizeMode: Text.Fit
|
||||||
|
font.pixelSize: height
|
||||||
|
|
||||||
|
minimumPixelSize: 1
|
||||||
|
|
||||||
|
color: appTheme.style.lineColor
|
||||||
|
text: "Firmware: " + speedBackend.scStwClient.getFirmwareVersion() + " API: " + speedBackend.scStwClient.getApiVersion()
|
||||||
|
}
|
||||||
|
|
||||||
|
SmoothSliderDelegate {
|
||||||
|
id: baseStationVolumeDel
|
||||||
|
text: qsTr("volume")
|
||||||
|
|
||||||
|
width: parent.width
|
||||||
|
height: parentObj.delegateHeight
|
||||||
|
|
||||||
|
sliderValue: 0
|
||||||
|
|
||||||
|
onSliderFinished: {
|
||||||
|
enabled = false
|
||||||
|
speedBackend.writeSetting("SoundVolume", sliderValue)
|
||||||
|
enabled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
Component.onCompleted: {
|
||||||
|
var val = speedBackend.readSetting("SoundVolume")
|
||||||
|
if(val !== "false"){
|
||||||
|
sliderValue = parseFloat(val)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -47,16 +47,6 @@ StackView {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*-----Page to view devices that core connected to the pase startion-----*/
|
|
||||||
Component{
|
|
||||||
id: baseStationConnections
|
|
||||||
|
|
||||||
SettingsBaseStationConnectionsPage {
|
|
||||||
parentObj: control
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*-----Custom animations-----*/
|
/*-----Custom animations-----*/
|
||||||
pushEnter: Transition {
|
pushEnter: Transition {
|
||||||
NumberAnimation {
|
NumberAnimation {
|
||||||
|
|
|
@ -23,6 +23,5 @@
|
||||||
<file>SettingsDialog/StartPage.qml</file>
|
<file>SettingsDialog/StartPage.qml</file>
|
||||||
<file>SettingsDialog/SettingsStartSequencePage.qml</file>
|
<file>SettingsDialog/SettingsStartSequencePage.qml</file>
|
||||||
<file>SettingsDialog/SettingsBaseStationPage.qml</file>
|
<file>SettingsDialog/SettingsBaseStationPage.qml</file>
|
||||||
<file>SettingsDialog/SettingsBaseStationConnectionsPage.qml</file>
|
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|
|
@ -223,13 +223,6 @@ void ScStwAppBackend::reloadRaceSettings() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: move to client
|
|
||||||
/*
|
|
||||||
QVariantMap ScStwAppBackend::getBaseStationProperties() {
|
|
||||||
QVariantMap firmware = {{"version", this->scStwClient->getFirmwareVersion()}, {"upToDate", this->scStwClient->isFirmwareUpToDate()}};
|
|
||||||
return {{"firmware", firmware}, {"timeOffset", this->scStwClient->getTimeOffset()}};
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
void ScStwAppBackend::reloadBaseStationIpAdress() {
|
void ScStwAppBackend::reloadBaseStationIpAdress() {
|
||||||
this->scStwClient->setIP(pGlobalAppSettings->loadSetting("baseStationIpAdress"));
|
this->scStwClient->setIP(pGlobalAppSettings->loadSetting("baseStationIpAdress"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 2893d341c2542ffae2c88cb976763fa599ff6622
|
Subproject commit 3f199b151131775e572c964bd3bb64120940c153
|
Reference in a new issue