mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-05 02:30:44 +00:00
clinical Mode: change from Appsetting to p_profile. Implemented default value for New profiles.
This commit is contained in:
parent
61c08e35dc
commit
1cd449cd9e
@ -27,7 +27,6 @@ AppWideSetting::AppWideSetting(Preferences *pref) : PrefSettings(pref)
|
|||||||
// initPref(STR_AS_GraphSnapshots, true);
|
// initPref(STR_AS_GraphSnapshots, true);
|
||||||
initPref(STR_AS_IncludeSerial, false);
|
initPref(STR_AS_IncludeSerial, false);
|
||||||
initPref(STR_AS_MonochromePrinting, false);
|
initPref(STR_AS_MonochromePrinting, false);
|
||||||
initPref(STR_AS_ClinicalMode, true);
|
|
||||||
initPref(STR_AS_ShowPieChart, false);
|
initPref(STR_AS_ShowPieChart, false);
|
||||||
m_animations = initPref(STR_AS_Animations, true).toBool();
|
m_animations = initPref(STR_AS_Animations, true).toBool();
|
||||||
m_squareWavePlots = initPref(STR_AS_SquareWave, false).toBool();
|
m_squareWavePlots = initPref(STR_AS_SquareWave, false).toBool();
|
||||||
|
@ -46,7 +46,6 @@ const QString STR_AS_UsePixmapCaching = "UsePixmapCaching";
|
|||||||
const QString STR_AS_AllowYAxisScaling = "AllowYAxisScaling";
|
const QString STR_AS_AllowYAxisScaling = "AllowYAxisScaling";
|
||||||
const QString STR_AS_IncludeSerial = "IncludeSerial";
|
const QString STR_AS_IncludeSerial = "IncludeSerial";
|
||||||
const QString STR_AS_MonochromePrinting = "PrintBW";
|
const QString STR_AS_MonochromePrinting = "PrintBW";
|
||||||
const QString STR_AS_ClinicalMode = "ClinicalMode";
|
|
||||||
const QString STR_AS_GraphTooltips = "GraphTooltips";
|
const QString STR_AS_GraphTooltips = "GraphTooltips";
|
||||||
const QString STR_AS_LineThickness = "LineThickness";
|
const QString STR_AS_LineThickness = "LineThickness";
|
||||||
const QString STR_AS_LineCursorMode = "LineCursorMode";
|
const QString STR_AS_LineCursorMode = "LineCursorMode";
|
||||||
@ -139,7 +138,6 @@ public:
|
|||||||
//! \brief Whether to print reports in black and white, which can be more legible on non-color printers
|
//! \brief Whether to print reports in black and white, which can be more legible on non-color printers
|
||||||
bool monochromePrinting() const { return getPref(STR_AS_MonochromePrinting).toBool(); }
|
bool monochromePrinting() const { return getPref(STR_AS_MonochromePrinting).toBool(); }
|
||||||
//! \Allow disabling of sessions
|
//! \Allow disabling of sessions
|
||||||
bool clinicalMode() const { return getPref(STR_AS_ClinicalMode).toBool(); }
|
|
||||||
//! \brief Whether to show graph tooltips
|
//! \brief Whether to show graph tooltips
|
||||||
inline bool graphTooltips() const { return m_graphTooltips; }
|
inline bool graphTooltips() const { return m_graphTooltips; }
|
||||||
//! \brief Pen width of line plots
|
//! \brief Pen width of line plots
|
||||||
@ -199,7 +197,6 @@ public:
|
|||||||
void setIncludeSerial(bool b) { setPref(STR_AS_IncludeSerial, b); }
|
void setIncludeSerial(bool b) { setPref(STR_AS_IncludeSerial, b); }
|
||||||
//! \brief Sets whether to print reports in black and white, which can be more legible on non-color printers
|
//! \brief Sets whether to print reports in black and white, which can be more legible on non-color printers
|
||||||
void setMonochromePrinting(bool b) { setPref(STR_AS_MonochromePrinting, b); }
|
void setMonochromePrinting(bool b) { setPref(STR_AS_MonochromePrinting, b); }
|
||||||
void setClinicalMode(bool b) { setPref(STR_AS_ClinicalMode,b); }
|
|
||||||
//! \brief Sets whether to allow double clicking on Y-Axis labels to change vertical scaling mode
|
//! \brief Sets whether to allow double clicking on Y-Axis labels to change vertical scaling mode
|
||||||
void setGraphTooltips(bool b) { setPref(STR_AS_GraphTooltips, m_graphTooltips=b); }
|
void setGraphTooltips(bool b) { setPref(STR_AS_GraphTooltips, m_graphTooltips=b); }
|
||||||
//! \brief Sets the type of overlay flags (which are displayed over the Flow Waveform)
|
//! \brief Sets the type of overlay flags (which are displayed over the Flow Waveform)
|
||||||
|
@ -309,6 +309,7 @@ const QString STR_OS_OxiDiscardThreshold = "OxiDiscardThreshold";
|
|||||||
|
|
||||||
// CPAPSettings Strings
|
// CPAPSettings Strings
|
||||||
const QString STR_CS_ComplianceHours = "ComplianceHours";
|
const QString STR_CS_ComplianceHours = "ComplianceHours";
|
||||||
|
const QString STR_CS_ClinicalMode = "ClinicalMode";
|
||||||
const QString STR_CS_ShowLeaksMode = "ShowLeaksMode";
|
const QString STR_CS_ShowLeaksMode = "ShowLeaksMode";
|
||||||
const QString STR_CS_MaskStartDate = "MaskStartDate";
|
const QString STR_CS_MaskStartDate = "MaskStartDate";
|
||||||
const QString STR_CS_MaskDescription = "MaskDescription";
|
const QString STR_CS_MaskDescription = "MaskDescription";
|
||||||
@ -559,6 +560,7 @@ class CPAPSettings : public PrefSettings
|
|||||||
: PrefSettings(profile)
|
: PrefSettings(profile)
|
||||||
{
|
{
|
||||||
m_complianceHours = initPref(STR_CS_ComplianceHours, 4.0f).toFloat();
|
m_complianceHours = initPref(STR_CS_ComplianceHours, 4.0f).toFloat();
|
||||||
|
m_clinicalMode = initPref(STR_CS_ClinicalMode, false).toBool();
|
||||||
initPref(STR_CS_ShowLeaksMode, 0);
|
initPref(STR_CS_ShowLeaksMode, 0);
|
||||||
// TODO: jedimark: Check if this date is initiliazed yet
|
// TODO: jedimark: Check if this date is initiliazed yet
|
||||||
initPref(STR_CS_MaskStartDate, QDate());
|
initPref(STR_CS_MaskStartDate, QDate());
|
||||||
@ -595,6 +597,7 @@ class CPAPSettings : public PrefSettings
|
|||||||
|
|
||||||
//Getters
|
//Getters
|
||||||
double complianceHours() const { return m_complianceHours; }
|
double complianceHours() const { return m_complianceHours; }
|
||||||
|
bool clinicalMode() const { return m_clinicalMode; }
|
||||||
int leakMode() const { return getPref(STR_CS_ShowLeaksMode).toInt(); }
|
int leakMode() const { return getPref(STR_CS_ShowLeaksMode).toInt(); }
|
||||||
QDate maskStartDate() const { return getPref(STR_CS_MaskStartDate).toDate(); }
|
QDate maskStartDate() const { return getPref(STR_CS_MaskStartDate).toDate(); }
|
||||||
QString maskDescription() const { return getPref(STR_CS_MaskDescription).toString(); }
|
QString maskDescription() const { return getPref(STR_CS_MaskDescription).toString(); }
|
||||||
@ -632,6 +635,7 @@ class CPAPSettings : public PrefSettings
|
|||||||
void setNotes(QString notes) { setPref(STR_CS_Notes, notes); }
|
void setNotes(QString notes) { setPref(STR_CS_Notes, notes); }
|
||||||
void setDateDiagnosed(QDate date) { setPref(STR_CS_DateDiagnosed, date); }
|
void setDateDiagnosed(QDate date) { setPref(STR_CS_DateDiagnosed, date); }
|
||||||
void setComplianceHours(EventDataType hours) { setPref(STR_CS_ComplianceHours, m_complianceHours=hours); }
|
void setComplianceHours(EventDataType hours) { setPref(STR_CS_ComplianceHours, m_complianceHours=hours); }
|
||||||
|
void setClinicalMode(bool mode) { setPref(STR_CS_ClinicalMode, m_clinicalMode=mode); }
|
||||||
void setLeakMode(int leakmode) { setPref(STR_CS_ShowLeaksMode, (int)leakmode); }
|
void setLeakMode(int leakmode) { setPref(STR_CS_ShowLeaksMode, (int)leakmode); }
|
||||||
void setMaskStartDate(QDate date) { setPref(STR_CS_MaskStartDate, date); }
|
void setMaskStartDate(QDate date) { setPref(STR_CS_MaskStartDate, date); }
|
||||||
void setMaskType(MaskType masktype) { setPref(STR_CS_MaskType, (int)masktype); }
|
void setMaskType(MaskType masktype) { setPref(STR_CS_MaskType, (int)masktype); }
|
||||||
@ -659,7 +663,7 @@ class CPAPSettings : public PrefSettings
|
|||||||
int m_clock_drift;
|
int m_clock_drift;
|
||||||
double m_4cmH2OLeaks, m_20cmH2OLeaks;
|
double m_4cmH2OLeaks, m_20cmH2OLeaks;
|
||||||
bool m_userEventFlagging, m_userEventDuplicates, m_calcUnintentionalLeaks, m_resyncFromUserFlagging, m_ahiReset;
|
bool m_userEventFlagging, m_userEventDuplicates, m_calcUnintentionalLeaks, m_resyncFromUserFlagging, m_ahiReset;
|
||||||
bool m_showLeakRedline;
|
bool m_showLeakRedline, m_clinicalMode;
|
||||||
|
|
||||||
EventDataType m_leakRedLine, m_complianceHours, m_ahiWindow;
|
EventDataType m_leakRedLine, m_complianceHours, m_ahiWindow;
|
||||||
|
|
||||||
|
@ -93,7 +93,7 @@ void Session::TrashEvents()
|
|||||||
|
|
||||||
bool Session::enabled(bool realValues) const
|
bool Session::enabled(bool realValues) const
|
||||||
{
|
{
|
||||||
if (AppSetting->clinicalMode() && !realValues) return true;
|
if (p_profile->cpap->clinicalMode() && !realValues) return true;
|
||||||
return s_enabled;
|
return s_enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -578,7 +578,7 @@ void Daily::showEvent(QShowEvent *)
|
|||||||
|
|
||||||
bool Daily::rejectToggleSessionEnable( Session*sess) {
|
bool Daily::rejectToggleSessionEnable( Session*sess) {
|
||||||
if (!sess) return true;
|
if (!sess) return true;
|
||||||
if (AppSetting->clinicalMode()) {
|
if (p_profile->cpap->clinicalMode()) {
|
||||||
QMessageBox mbox(QMessageBox::Warning, tr("Clinical Mode"), tr(" Disabling Sessions requires the Permissive Mode"), QMessageBox::Ok , this);
|
QMessageBox mbox(QMessageBox::Warning, tr("Clinical Mode"), tr(" Disabling Sessions requires the Permissive Mode"), QMessageBox::Ok , this);
|
||||||
mbox.exec();
|
mbox.exec();
|
||||||
return true;
|
return true;
|
||||||
|
@ -307,7 +307,7 @@ void DailySearchTab::populateControl() {
|
|||||||
commandList->addItem(calculateMaxSize(tr("Daily Duration"),ST_DAILY_USAGE));
|
commandList->addItem(calculateMaxSize(tr("Daily Duration"),ST_DAILY_USAGE));
|
||||||
commandList->addItem(calculateMaxSize(tr("Session Duration" ),ST_SESSION_LENGTH));
|
commandList->addItem(calculateMaxSize(tr("Session Duration" ),ST_SESSION_LENGTH));
|
||||||
commandList->addItem(calculateMaxSize(tr("Days Skipped"),ST_DAYS_SKIPPED));
|
commandList->addItem(calculateMaxSize(tr("Days Skipped"),ST_DAYS_SKIPPED));
|
||||||
if ( !AppSetting->clinicalMode() ) {
|
if ( !p_profile->cpap->clinicalMode() ) {
|
||||||
commandList->addItem(calculateMaxSize(tr("Disabled Sessions"),ST_DISABLED_SESSIONS));
|
commandList->addItem(calculateMaxSize(tr("Disabled Sessions"),ST_DISABLED_SESSIONS));
|
||||||
}
|
}
|
||||||
commandList->addItem(calculateMaxSize(tr("Number of Sessions"),ST_SESSIONS_QTY));
|
commandList->addItem(calculateMaxSize(tr("Number of Sessions"),ST_SESSIONS_QTY));
|
||||||
|
@ -292,8 +292,6 @@ void MainWindow::SetupGUI()
|
|||||||
ui->tabWidget->addTab(help, tr("Help Browser"));
|
ui->tabWidget->addTab(help, tr("Help Browser"));
|
||||||
#endif
|
#endif
|
||||||
setupRunning = false;
|
setupRunning = false;
|
||||||
|
|
||||||
m_clinicalMode = AppSetting->clinicalMode();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::logMessage(QString msg)
|
void MainWindow::logMessage(QString msg)
|
||||||
@ -478,6 +476,7 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
prof = profileSelector->SelectProfile(profileName, skippassword); // asks for the password and updates stuff in profileSelector tab
|
prof = profileSelector->SelectProfile(profileName, skippassword); // asks for the password and updates stuff in profileSelector tab
|
||||||
if (!prof) {
|
if (!prof) {
|
||||||
return false;
|
return false;
|
||||||
@ -487,6 +486,7 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
|
|||||||
// Check Lockfile
|
// Check Lockfile
|
||||||
QString lockhost = prof->checkLock();
|
QString lockhost = prof->checkLock();
|
||||||
|
|
||||||
|
|
||||||
if (!lockhost.isEmpty()) {
|
if (!lockhost.isEmpty()) {
|
||||||
if (lockhost.compare(QHostInfo::localHostName()) != 0) {
|
if (lockhost.compare(QHostInfo::localHostName()) != 0) {
|
||||||
if (QMessageBox::warning(nullptr, STR_MessageBox_Warning,
|
if (QMessageBox::warning(nullptr, STR_MessageBox_Warning,
|
||||||
@ -502,7 +502,6 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
|
|||||||
}
|
}
|
||||||
|
|
||||||
p_profile = prof;
|
p_profile = prof;
|
||||||
|
|
||||||
ProgressDialog * progress = new ProgressDialog(this);
|
ProgressDialog * progress = new ProgressDialog(this);
|
||||||
|
|
||||||
progress->setMessage(QObject::tr("Loading profile \"%1\"...").arg(profileName));
|
progress->setMessage(QObject::tr("Loading profile \"%1\"...").arg(profileName));
|
||||||
@ -545,6 +544,15 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
|
|||||||
}
|
}
|
||||||
|
|
||||||
p_profile->LoadMachineData(progress);
|
p_profile->LoadMachineData(progress);
|
||||||
|
|
||||||
|
|
||||||
|
if (!p_profile->LastDay(MT_CPAP).isValid() ) { // quick test if new profile or not.
|
||||||
|
// Override default value of clinicalMode if new profile.
|
||||||
|
// Allows permissiveMode (not clinicalMode) to be the default value for existing profiles.
|
||||||
|
p_profile->cpap->setClinicalMode(true);
|
||||||
|
}
|
||||||
|
m_clinicalMode = p_profile->cpap->clinicalMode();
|
||||||
|
|
||||||
progress->setMessage(tr("Loading profile \"%1\"").arg(profileName));
|
progress->setMessage(tr("Loading profile \"%1\"").arg(profileName));
|
||||||
|
|
||||||
// Show the logo?
|
// Show the logo?
|
||||||
@ -628,6 +636,7 @@ bool MainWindow::OpenProfile(QString profileName, bool skippassword)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
progress->close();
|
progress->close();
|
||||||
delete progress;
|
delete progress;
|
||||||
qDebug() << "Finished opening Profile";
|
qDebug() << "Finished opening Profile";
|
||||||
@ -1401,8 +1410,8 @@ void MainWindow::on_action_Preferences_triggered()
|
|||||||
setApplicationFont();
|
setApplicationFont();
|
||||||
|
|
||||||
|
|
||||||
if (m_clinicalMode != AppSetting->clinicalMode() ) {
|
if (m_clinicalMode != p_profile->cpap->clinicalMode() ) {
|
||||||
m_clinicalMode = AppSetting->clinicalMode();
|
m_clinicalMode = p_profile->cpap->clinicalMode(); ;
|
||||||
reloadProfile();
|
reloadProfile();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -241,11 +241,12 @@ PreferencesDialog::PreferencesDialog(QWidget *parent, Profile *_profile) :
|
|||||||
ui->allowYAxisScaling->setChecked(AppSetting->allowYAxisScaling());
|
ui->allowYAxisScaling->setChecked(AppSetting->allowYAxisScaling());
|
||||||
ui->includeSerial->setChecked(AppSetting->includeSerial());
|
ui->includeSerial->setChecked(AppSetting->includeSerial());
|
||||||
ui->monochromePrinting->setChecked(AppSetting->monochromePrinting());
|
ui->monochromePrinting->setChecked(AppSetting->monochromePrinting());
|
||||||
ui->clinicalMode->setChecked(AppSetting->clinicalMode());
|
ui->complianceHours->setValue(profile->cpap->complianceHours());
|
||||||
|
ui->clinicalMode->setChecked(profile->cpap->clinicalMode());
|
||||||
ui->clinicalTextEdit->setPlainText(clinicalHelp());
|
ui->clinicalTextEdit->setPlainText(clinicalHelp());
|
||||||
// clinicalMode and permissiveMode are radio buttons and must be set to opposite values. Once clinicalMode is used.
|
// clinicalMode and permissiveMode are radio buttons and must be set to opposite values. Once clinicalMode is used.
|
||||||
// Radio Buttons illustrate the operating mode.
|
// Radio Buttons illustrate the operating mode.
|
||||||
ui->permissiveMode->setChecked(!AppSetting->clinicalMode());
|
ui->permissiveMode->setChecked(!profile->cpap->clinicalMode());
|
||||||
|
|
||||||
ui->autoLaunchImporter->setChecked(AppSetting->autoLaunchImport());
|
ui->autoLaunchImporter->setChecked(AppSetting->autoLaunchImport());
|
||||||
#ifndef NO_CHECKUPDATES
|
#ifndef NO_CHECKUPDATES
|
||||||
@ -288,7 +289,6 @@ PreferencesDialog::PreferencesDialog(QWidget *parent, Profile *_profile) :
|
|||||||
ui->cacheSessionData->setChecked(AppSetting->cacheSessions());
|
ui->cacheSessionData->setChecked(AppSetting->cacheSessions());
|
||||||
ui->preloadSummaries->setChecked(profile->session->preloadSummaries());
|
ui->preloadSummaries->setChecked(profile->session->preloadSummaries());
|
||||||
ui->animationsAndTransitionsCheckbox->setChecked(AppSetting->animations());
|
ui->animationsAndTransitionsCheckbox->setChecked(AppSetting->animations());
|
||||||
ui->complianceHours->setValue(profile->cpap->complianceHours());
|
|
||||||
|
|
||||||
ui->prefCalcMiddle->setCurrentIndex(profile->general->prefCalcMiddle());
|
ui->prefCalcMiddle->setCurrentIndex(profile->general->prefCalcMiddle());
|
||||||
ui->prefCalcMax->setCurrentIndex(profile->general->prefCalcMax());
|
ui->prefCalcMax->setCurrentIndex(profile->general->prefCalcMax());
|
||||||
@ -857,7 +857,7 @@ bool PreferencesDialog::Save()
|
|||||||
AppSetting->setAllowYAxisScaling(ui->allowYAxisScaling->isChecked());
|
AppSetting->setAllowYAxisScaling(ui->allowYAxisScaling->isChecked());
|
||||||
AppSetting->setIncludeSerial(ui->includeSerial->isChecked());
|
AppSetting->setIncludeSerial(ui->includeSerial->isChecked());
|
||||||
AppSetting->setMonochromePrinting(ui->monochromePrinting->isChecked());
|
AppSetting->setMonochromePrinting(ui->monochromePrinting->isChecked());
|
||||||
AppSetting->setClinicalMode(ui->clinicalMode->isChecked());
|
p_profile->cpap->setClinicalMode(ui->clinicalMode->isChecked());
|
||||||
AppSetting->setGraphTooltips(ui->graphTooltips->isChecked());
|
AppSetting->setGraphTooltips(ui->graphTooltips->isChecked());
|
||||||
|
|
||||||
AppSetting->setAntiAliasing(ui->useAntiAliasing->isChecked());
|
AppSetting->setAntiAliasing(ui->useAntiAliasing->isChecked());
|
||||||
|
@ -173,7 +173,7 @@ void Statistics::updateDisabledInfo()
|
|||||||
void DisabledInfo::update(QDate latestDate, QDate earliestDate)
|
void DisabledInfo::update(QDate latestDate, QDate earliestDate)
|
||||||
{
|
{
|
||||||
clear();
|
clear();
|
||||||
if ( (!latestDate.isValid()) || (!earliestDate.isValid()) || (AppSetting->clinicalMode()) )return;
|
if ( (!latestDate.isValid()) || (!earliestDate.isValid()) || (p_profile->cpap->clinicalMode()) ) return;
|
||||||
qint64 complianceHours = 3600000.0 * p_profile->cpap->complianceHours(); // conbvert to ms
|
qint64 complianceHours = 3600000.0 * p_profile->cpap->complianceHours(); // conbvert to ms
|
||||||
totalDays = 1+earliestDate.daysTo(latestDate);
|
totalDays = 1+earliestDate.daysTo(latestDate);
|
||||||
for (QDate date = latestDate ; date >= earliestDate ; date=date.addDays(-1) ) {
|
for (QDate date = latestDate ; date >= earliestDate ; date=date.addDays(-1) ) {
|
||||||
@ -632,7 +632,7 @@ Statistics::Statistics(QObject *parent) :
|
|||||||
QObject(parent)
|
QObject(parent)
|
||||||
{
|
{
|
||||||
rows.push_back(StatisticsRow(tr("CPAP Statistics"), SC_HEADING, MT_CPAP));
|
rows.push_back(StatisticsRow(tr("CPAP Statistics"), SC_HEADING, MT_CPAP));
|
||||||
if (!AppSetting->clinicalMode()) {
|
if (!p_profile->cpap->clinicalMode()) {
|
||||||
updateDisabledInfo();
|
updateDisabledInfo();
|
||||||
rows.push_back(StatisticsRow(disabledInfo.display(0),SC_WARNING ,MT_CPAP));
|
rows.push_back(StatisticsRow(disabledInfo.display(0),SC_WARNING ,MT_CPAP));
|
||||||
rows.push_back(StatisticsRow(disabledInfo.display(1),SC_WARNING2,MT_CPAP));
|
rows.push_back(StatisticsRow(disabledInfo.display(1),SC_WARNING2,MT_CPAP));
|
||||||
|
Loading…
Reference in New Issue
Block a user