diff options
-rw-r--r-- | mobile-widgets/qml/StatisticsPage.qml | 18 | ||||
-rw-r--r-- | mobile-widgets/statsmanager.cpp | 12 | ||||
-rw-r--r-- | mobile-widgets/statsmanager.h | 7 |
3 files changed, 37 insertions, 0 deletions
diff --git a/mobile-widgets/qml/StatisticsPage.qml b/mobile-widgets/qml/StatisticsPage.qml index 7c5b498ca..3fcfdfcc2 100644 --- a/mobile-widgets/qml/StatisticsPage.qml +++ b/mobile-widgets/qml/StatisticsPage.qml @@ -98,6 +98,24 @@ Kirigami.Page { } } } + ColumnLayout { + id: i5 + Layout.column: wide ? 0 : 2 + Layout.row: wide ? 4 : 1 + Layout.margins: Kirigami.Units.smallSpacing + TemplateLabelSmall { + text: qsTr("Operation") + } + TemplateComboBox { + id: var2Operation + model: statsManager.operation2List + currentIndex: statsManager.operation2Index; + Layout.fillWidth: false + onCurrentIndexChanged: { + statsManager.var2OperationChanged(currentIndex) + } + } + } Item { Layout.column: wide ? 0 : 4 Layout.row: wide ? 4 : 0 diff --git a/mobile-widgets/statsmanager.cpp b/mobile-widgets/statsmanager.cpp index 8a192fe36..639b9294a 100644 --- a/mobile-widgets/statsmanager.cpp +++ b/mobile-widgets/statsmanager.cpp @@ -51,14 +51,17 @@ void StatsManager::updateUi() setBinnerList(uiState.binners1, binner1List, binner1Index); setVariableList(uiState.var2, var2List, var2Index); setBinnerList(uiState.binners2, binner2List, binner2Index); + setVariableList(uiState.operations2, operation2List, operation2Index); var1ListChanged(); binner1ListChanged(); var2ListChanged(); binner2ListChanged(); + operation2ListChanged(); var1IndexChanged(); binner1IndexChanged(); var2IndexChanged(); binner2IndexChanged(); + operation2IndexChanged(); if (view) view->plot(state); @@ -93,3 +96,12 @@ void StatsManager::var2BinnerChanged(int idx) state.binner2Changed(idx); updateUi(); } + +void StatsManager::var2OperationChanged(int idx) +{ + if (uiState.var2.variables.empty()) + return; + idx = std::clamp(idx, 0, (int)uiState.operations2.variables.size()); + state.var2OperationChanged(uiState.operations2.variables[idx].id); + updateUi(); +} diff --git a/mobile-widgets/statsmanager.h b/mobile-widgets/statsmanager.h index c4afa6881..82c7a6b89 100644 --- a/mobile-widgets/statsmanager.h +++ b/mobile-widgets/statsmanager.h @@ -14,10 +14,12 @@ public: Q_PROPERTY(QStringList binner1List MEMBER binner1List NOTIFY binner1ListChanged) Q_PROPERTY(QStringList var2List MEMBER var2List NOTIFY var2ListChanged) Q_PROPERTY(QStringList binner2List MEMBER binner2List NOTIFY binner2ListChanged) + Q_PROPERTY(QStringList operation2List MEMBER operation2List NOTIFY operation2ListChanged) Q_PROPERTY(int var1Index MEMBER var1Index NOTIFY var1IndexChanged) Q_PROPERTY(int binner1Index MEMBER binner1Index NOTIFY binner1IndexChanged) Q_PROPERTY(int var2Index MEMBER var2Index NOTIFY var2IndexChanged) Q_PROPERTY(int binner2Index MEMBER binner2Index NOTIFY binner2IndexChanged) + Q_PROPERTY(int operation2Index MEMBER operation2Index NOTIFY operation2IndexChanged) StatsManager(); ~StatsManager(); @@ -27,15 +29,18 @@ public: Q_INVOKABLE void var1BinnerChanged(int idx); Q_INVOKABLE void var2Changed(int idx); Q_INVOKABLE void var2BinnerChanged(int idx); + Q_INVOKABLE void var2OperationChanged(int idx); signals: void var1ListChanged(); void binner1ListChanged(); void var2ListChanged(); void binner2ListChanged(); + void operation2ListChanged(); void var1IndexChanged(); void binner1IndexChanged(); void var2IndexChanged(); void binner2IndexChanged(); + void operation2IndexChanged(); private: StatsView *view; StatsState state; @@ -43,10 +48,12 @@ private: QStringList binner1List; QStringList var2List; QStringList binner2List; + QStringList operation2List; int var1Index; int binner1Index; int var2Index; int binner2Index; + int operation2Index; StatsState::UIState uiState; // Remember UI state so that we can interpret indexes void updateUi(); |