This repository has been archived on 2026-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
powersync-app/nymea-app/ui/devicepages/InputTriggerDevicePage.qml
2025-12-05 13:40:20 +01:00

126 lines
4.2 KiB
QML

// SPDX-License-Identifier: GPL-3.0-or-later
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright (C) 2013 - 2024, nymea GmbH
* Copyright (C) 2024 - 2025, chargebyte austria GmbH
*
* This file is part of nymea-app.
*
* nymea-app is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* nymea-app is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with nymea-app. If not, see <https://www.gnu.org/licenses/>.
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
import QtQuick
import QtQuick.Controls
import QtQuick.Layouts
import Nymea
import "../components"
import "../customviews"
ThingPageBase {
id: root
property var interfaceEventMap: {
"inputtrigger": "triggered",
"vibrationsensor": "vibrationDetected"
}
readonly property string interfaceName: {
var supportedInterfaces = Object.keys(interfaceEventMap)
for (var i = 0; i < supportedInterfaces.length; i++) {
if (root.thing.thingClass.interfaces.indexOf(supportedInterfaces[i]) >= 0) {
return supportedInterfaces[i]
}
}
return ""
}
readonly property string eventName: interfaceEventMap[interfaceName]
GridLayout {
anchors.fill: parent
columns: app.landscape ? 2 : 1
rowSpacing: 0
columnSpacing: 0
Item {
Layout.fillWidth: true
Layout.preferredHeight: width
Layout.margins: Style.hugeMargins
CircleBackground {
id: iconView
width: Math.min(parent.width, parent.height)
height: width
anchors.centerIn: parent
iconSource: app.interfaceToIcon(root.interfaceName)
onColor: app.interfaceToColor(root.interfaceName)
on: false
Timer {
running: parent.on
repeat: false
interval: 1000
onTriggered: {
parent.on = false
}
}
}
}
GenericTypeLogView {
id: logView
Layout.fillWidth: true
Layout.fillHeight: true
logsModel: logsModel
LogsModel {
id: logsModel
engine: _engine
thingId: root.thing.id
live: true
typeIds: [root.thing.thingClass.eventTypes.findByName(root.eventName).id];
onCountChanged: {
if (!logsModel.busy) {
iconView.on = true
}
}
}
onAddRuleClicked: {
var value = logView.logsModel.get(index).value
var typeId = logView.logsModel.get(index).typeId
var rule = engine.ruleManager.createNewRule();
var eventDescriptor = rule.eventDescriptors.createNewEventDescriptor();
eventDescriptor.thingId = thing.id;
var eventType = root.thing.thingClass.eventTypes.getEventType(typeId);
eventDescriptor.eventTypeId = eventType.id;
rule.name = root.thing.name + " - " + eventType.displayName;
if (eventType.paramTypes.count === 1) {
var paramType = eventType.paramTypes.get(0);
eventDescriptor.paramDescriptors.setParamDescriptor(paramType.id, value, ParamDescriptor.ValueOperatorEquals);
}
rule.eventDescriptors.addEventDescriptor(eventDescriptor);
rule.name = rule.name + " - " + value
var rulePage = pageStack.push(Qt.resolvedUrl("../magic/ThingRulesPage.qml"), {thing: root.thing});
rulePage.addRule(rule);
}
}
}
}