2022-07-15 09:30:16 +02:00
|
|
|
import QtQml
|
2022-05-31 23:26:41 +02:00
|
|
|
import QtQuick
|
|
|
|
import QtQuick.Layouts
|
|
|
|
|
2022-07-15 09:30:16 +02:00
|
|
|
import Status.Controls.Navigation
|
2022-05-31 23:26:41 +02:00
|
|
|
|
2022-07-15 09:30:16 +02:00
|
|
|
|
|
|
|
/// Template for side NavigationBar
|
|
|
|
///
|
|
|
|
/// The width is given, the rest of the controls have to adapt to the width
|
|
|
|
/// Contains a list of
|
2022-05-31 23:26:41 +02:00
|
|
|
Item {
|
2022-07-15 09:30:16 +02:00
|
|
|
id: root
|
|
|
|
|
2022-05-31 23:26:41 +02:00
|
|
|
implicitWidth: 78
|
2022-07-15 09:30:16 +02:00
|
|
|
implicitHeight: mainLayout.implicitHeight
|
|
|
|
|
2022-08-03 14:43:33 +02:00
|
|
|
property alias currentIndex: listView.currentIndex
|
2022-07-15 09:30:16 +02:00
|
|
|
|
|
|
|
required property var sections
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
id: mainLayout
|
|
|
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
MacTrafficLights {
|
|
|
|
Layout.margins: 13
|
|
|
|
}
|
|
|
|
|
|
|
|
ListView {
|
|
|
|
id: listView
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
model: root.sections
|
|
|
|
|
|
|
|
// TODO: sync with user settings
|
|
|
|
currentIndex: 0
|
|
|
|
|
|
|
|
onCurrentItemChanged: currentItem.item.selected = true
|
|
|
|
|
|
|
|
// Each delegate is a section
|
|
|
|
delegate: Loader {
|
|
|
|
property var content: modelData.content
|
|
|
|
sourceComponent: modelData.navigationSection
|
|
|
|
Connections {
|
|
|
|
target: item
|
|
|
|
function onSelectedChanged() {
|
|
|
|
listView.currentIndex = index
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-05-31 23:26:41 +02:00
|
|
|
}
|