diff --git a/Htmldocs/release_notes.html b/Htmldocs/release_notes.html
index 1e25023c..e590c7f6 100644
--- a/Htmldocs/release_notes.html
+++ b/Htmldocs/release_notes.html
@@ -23,6 +23,7 @@
[new] Add support for new settings codes in recently manufactured 700X110 DreamStations.
[new] Add 95% flow limitation to Therapy Efficacy section on Statistics page.
+ [new] Add date range option to Statistics page.
[new] Improve appearance and operation of event types and graphs comboboxes on Daily and Overview pages.
[fix] Correct SleepStyle machines sometimes identified as Icon machines.
[fix] Improve event flag position in flow graph for DV6 machines.
diff --git a/oscar/SleepLib/profiles.h b/oscar/SleepLib/profiles.h
index 5c5e3068..fd0fd0de 100644
--- a/oscar/SleepLib/profiles.h
+++ b/oscar/SleepLib/profiles.h
@@ -363,6 +363,8 @@ const QString STR_US_PrefCalcPercentile = "PrefCalcPercentile";
const QString STR_US_PrefCalcMax = "PrefCalcMax";
const QString STR_US_ShowUnknownFlags = "ShowUnknownFlags";
const QString STR_US_StatReportMode = "StatReportMode";
+const QString STR_US_StatReportRangeStart = "StatReportRangeStart";
+const QString STR_US_StatReportRangeEnd = "StatReportRangeEnd";
const QString STR_US_LastOverviewRange = "LastOverviewRange";
const QString STR_US_CustomOverviewRangeStart = "CustomOverviewRangeStart";
const QString STR_US_CustomOverviewRangeEnd = "CustomOverviewRangeEnd";
@@ -727,6 +729,8 @@ class UserSettings : public PrefSettings
m_prefCalcPercentile = initPref(STR_US_PrefCalcPercentile, (double)95.0).toDouble();
m_prefCalcMax = initPref(STR_US_PrefCalcMax, (int)0).toInt();
initPref(STR_US_StatReportMode, 0);
+ initPref(STR_US_StatReportRangeStart, QDate(1,1,2000));
+ initPref(STR_US_StatReportRangeEnd, QDate(1,1,2000));
m_showUnownFlags = initPref(STR_US_ShowUnknownFlags, false).toBool();
initPref(STR_US_LastOverviewRange, 4);
}
@@ -740,6 +744,8 @@ class UserSettings : public PrefSettings
inline double prefCalcPercentile() const { return m_prefCalcPercentile; }
inline int prefCalcMax() const { return m_prefCalcMax; }
int statReportMode() const { return getPref(STR_US_StatReportMode).toInt(); }
+ QDate statReportRangeStart() const { return getPref(STR_US_StatReportRangeStart).toDate(); }
+ QDate statReportRangeEnd() const { return getPref(STR_US_StatReportRangeEnd).toDate(); }
inline bool showUnknownFlags() const { return m_showUnownFlags; }
int lastOverviewRange() const { return getPref(STR_US_LastOverviewRange).toInt(); }
QDate customOverviewRangeStart () const { return getPref(STR_US_CustomOverviewRangeStart).toDate(); }
@@ -754,6 +760,8 @@ class UserSettings : public PrefSettings
void setPrefCalcPercentile(double p) { setPref(STR_US_PrefCalcPercentile, m_prefCalcPercentile=p); }
void setPrefCalcMax(int i) { setPref(STR_US_PrefCalcMax, m_prefCalcMax=i); }
void setStatReportMode(int i) { setPref(STR_US_StatReportMode, i); }
+ void setStatReportRangeStart(QDate i) { setPref (STR_US_StatReportRangeStart, i); }
+ void setStatReportRangeEnd(QDate i) { setPref (STR_US_StatReportRangeEnd, i); }
void setShowUnknownFlags(bool b) { setPref(STR_US_ShowUnknownFlags, m_showUnownFlags=b); }
void setLastOverviewRange(int i) { setPref(STR_US_LastOverviewRange, i); }
void setCustomOverviewRangeStart(QDate i) { setPref(STR_US_CustomOverviewRangeStart, i); }
diff --git a/oscar/mainwindow.cpp b/oscar/mainwindow.cpp
index 7367683f..bec8259a 100644
--- a/oscar/mainwindow.cpp
+++ b/oscar/mainwindow.cpp
@@ -183,7 +183,7 @@ void MainWindow::SetupGUI()
ui->statEndDate->setVisible(false);
ui->statStartDate->setVisible(false);
- ui->reportModeRange->setVisible(false);
+// ui->reportModeRange->setVisible(false);
int srm = 0;
if (p_profile) {
srm = p_profile->general->statReportMode();
@@ -582,9 +582,13 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
switch (srm) {
case 0:
ui->reportModeStandard->setChecked(true);
+ ui->statEndDate->setVisible(false);
+ ui->statStartDate->setVisible(false);
break;
case 1:
ui->reportModeMonthly->setChecked(true);
+ ui->statEndDate->setVisible(false);
+ ui->statStartDate->setVisible(false);
break;
case 2:
ui->reportModeRange->setChecked(true);
@@ -2382,6 +2386,10 @@ void MainWindow::GenerateStatistics()
QString htmlStats = stats.GenerateHTML();
QString htmlRecords = stats.UpdateRecordsBox();
+ bool brange = (p_profile->general->statReportMode() == 2);
+ ui->statEndDate->setVisible(brange);
+ ui->statStartDate->setVisible(brange);
+
updateFavourites();
setStatsHTML(htmlStats);
@@ -2452,6 +2460,18 @@ void MainWindow::on_reportModeRange_clicked()
}
}
+void MainWindow::on_statEndDate_dateChanged(const QDate &date)
+{
+ p_profile->general->setStatReportRangeEnd(date);
+ GenerateStatistics();
+}
+
+void MainWindow::on_statStartDate_dateChanged(const QDate &date)
+{
+ p_profile->general->setStatReportRangeStart(date);
+ GenerateStatistics();
+}
+
void MainWindow::on_actionPurgeCurrentDaysOximetry_triggered()
{
if (!daily)
diff --git a/oscar/mainwindow.h b/oscar/mainwindow.h
index fa0cbf01..14702fac 100644
--- a/oscar/mainwindow.h
+++ b/oscar/mainwindow.h
@@ -324,6 +324,10 @@ class MainWindow : public QMainWindow
void on_reportModeRange_clicked();
+ void on_statEndDate_dateChanged(const QDate &date);
+
+ void on_statStartDate_dateChanged(const QDate &date);
+
void on_actionPurgeCurrentDaysOximetry_triggered();
void logMessage(QString msg);
diff --git a/oscar/statistics.cpp b/oscar/statistics.cpp
index 9effb1df..0b904e6b 100644
--- a/oscar/statistics.cpp
+++ b/oscar/statistics.cpp
@@ -28,7 +28,7 @@ extern MainWindow *mainwin;
// HTML components that make up Statistics page and printed report
QString htmlReportHeader = ""; // Page header
-QString htmlReportHeaderPrint = ""; // Page header
+QString htmlReportHeaderPrint = ""; // Page header
QString htmlUsage = ""; // CPAP and Oximetry
QString htmlMachineSettings = ""; // Machine (formerly Rx) changes
QString htmlMachines = ""; // Machines used in this profile
@@ -1141,6 +1141,7 @@ QString Statistics::GenerateCPAPUsage()
if (number_periods > 12) {
number_periods = 12;
}
+// } else if (p_profile->general->statReportMode() == STAT_MODE_RANGE) {
}
QDate last = lastcpap, first = lastcpap;
@@ -1165,7 +1166,7 @@ QString Statistics::GenerateCPAPUsage()
periods.push_back(Period(qMax(last.addDays(-29),first), last, tr("Last 30 Days")));
periods.push_back(Period(qMax(last.addMonths(-6), first), last, tr("Last 6 Months")));
periods.push_back(Period(qMax(last.addMonths(-12), first), last, tr("Last Year")));
- } else { // STAT_MODE_MONTHLY or STAT_MODE_RANGE
+ } else if (p_profile->general->statReportMode() == STAT_MODE_MONTHLY) {
QDate l=last,s=last;
periods.push_back(Period(last,last,tr("Last Session")));
@@ -1188,6 +1189,10 @@ QString Statistics::GenerateCPAPUsage()
for (; j < number_periods; ++j) {
periods.push_back(Period(last,last, ""));
}
+ } else { // STAT_MODE_RANGE
+ first = p_profile->general->statReportRangeStart();
+ last = p_profile->general->statReportRangeEnd();
+ periods.push_back(Period(first,last,first.toString(MedDateFormat)+" -
"+last.toString(MedDateFormat)));
}
int days = p_profile->countDays(row.type, first, last);