Files
htpc-client/layouts/components/Sidebar.qml
T
restitux 7944e4e21b Initial prototype
Basic UI outline with keyboard control. Python database
object is exposed to QML and data can be queried from its methods.
This should provide a generic structure that different UI themes
can be built around.
2022-08-15 17:50:09 +00:00

39 lines
970 B
QML

import QtQuick 2.12
import Ikinuki.Client 1.0
Rectangle {
property var providers
default property int selectedElement: 2
property var max_elements: providers.length
width: parent.width * 0.3
height: parent.height
color: "#22282A"
Column {
anchors.fill: parent
// header
SidebarHeader {}
Repeater {
model: providers
SidebarElement {
name: modelData.Name
selected: (index == selectedElement) ? true : false
}
}
}
function mod(n, m) {
return ((n % m) + m) % m;
}
Keys.onPressed: (event)=> {
if (event.key == Qt.Key_Down) {
selectedElement = mod(selectedElement + 1, max_elements);
}
else if (event.key == Qt.Key_Up) {
selectedElement = mod(selectedElement - 1, max_elements);
}
console.log(selectedElement)
event.accepted = true;
}
}