Browse Source

thermostat: add holiday mode

master
Richard Genoud 5 years ago
parent
commit
bc650bd3e3
4 changed files with 62 additions and 11 deletions
  1. +12
    -1
      soft/thermostat/inc/holiday_dlg.h
  2. +6
    -1
      soft/thermostat/inc/mainwindow.h
  3. +16
    -7
      soft/thermostat/src/holiday_dlg.cpp
  4. +28
    -2
      soft/thermostat/src/mainwindow.cpp

+ 12
- 1
soft/thermostat/inc/holiday_dlg.h View File

@ -11,7 +11,8 @@
#include <QWidget> #include <QWidget>
#include <QObject> #include <QObject>
#include <QPushButton>
#include <QDate>
#include <QCalendarWidget>
class HolidayDlg : public QWidget class HolidayDlg : public QWidget
{ {
@ -22,6 +23,16 @@ public:
Qt::WindowFlags f = Qt::WindowFlags()); Qt::WindowFlags f = Qt::WindowFlags());
~HolidayDlg(); ~HolidayDlg();
private:
QCalendarWidget m_cal;
signals:
void close_holiday_dlg(void);
void holiday_mode(QDate end_date);
private slots:
void validate_holiday_mode(void);
}; };
#endif // HOLIDAYDLG_H #endif // HOLIDAYDLG_H


+ 6
- 1
soft/thermostat/inc/mainwindow.h View File

@ -14,6 +14,8 @@
#include <QPushButton> #include <QPushButton>
#include <QtWidgets> #include <QtWidgets>
#include <QVector> #include <QVector>
#include <QTimer>
#include <QDate>
#include "mqttclient.h" #include "mqttclient.h"
#include "zoneitem.h" #include "zoneitem.h"
@ -36,6 +38,7 @@ private:
QTimer *m_timer; QTimer *m_timer;
BoostDlg *m_boost; BoostDlg *m_boost;
MenuDlg *m_menu; MenuDlg *m_menu;
QDate m_end_holiday;
QStackedWidget m_central_widget; QStackedWidget m_central_widget;
void update_state_btn(enum power_states st); void update_state_btn(enum power_states st);
double get_target_temperature(int room_idx); double get_target_temperature(int room_idx);
@ -52,7 +55,9 @@ private slots:
void show_main(void); void show_main(void);
void show_menu(void); void show_menu(void);
void boost_slot(int idx, struct boost_data &data); void boost_slot(int idx, struct boost_data &data);
void show_holiday_dlg(void);
void do_show_holiday_dlg(void);
void do_close_holiday_dlg(void);
void set_holiday_mode(QDate end_date);
signals: signals:
void setAllHeatersOn(bool on); void setAllHeatersOn(bool on);


+ 16
- 7
soft/thermostat/src/holiday_dlg.cpp View File

@ -22,7 +22,11 @@ HolidayDlg::HolidayDlg(QWidget *parent, Qt::WindowFlags f) :
{ {
QVBoxLayout *middleLayout = new QVBoxLayout; QVBoxLayout *middleLayout = new QVBoxLayout;
QHBoxLayout *mainLayout = new QHBoxLayout; QHBoxLayout *mainLayout = new QHBoxLayout;
QCalendarWidget *cal = new QCalendarWidget(this);
m_cal.setGridVisible(true);
m_cal.setMinimumDate(QDate::currentDate());
m_cal.setDateEditEnabled(false);
QSizePolicy *szPolicy = new QSizePolicy(QSizePolicy::Minimum, QSizePolicy *szPolicy = new QSizePolicy(QSizePolicy::Minimum,
QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding,
QSizePolicy::PushButton); QSizePolicy::PushButton);
@ -42,14 +46,13 @@ HolidayDlg::HolidayDlg(QWidget *parent, Qt::WindowFlags f) :
middleLayout->addWidget(ok_btn); middleLayout->addWidget(ok_btn);
middleLayout->addWidget(cancel_btn); middleLayout->addWidget(cancel_btn);
mainLayout->addWidget(cal);
mainLayout->addWidget(&m_cal);
mainLayout->addLayout(middleLayout); mainLayout->addLayout(middleLayout);
connect(cal, SIGNAL(clicked(void)), this, SIGNAL(show_holiday_dlg(void)));
connect(next_btn, SIGNAL(clicked(void)), cal, SLOT(showNextMonth(void)));
connect(prev_btn, SIGNAL(clicked(void)), cal, SLOT(showPreviousMonth(void)));
// connect(ok_btn, SIGNAL(clicked(void)), this, SIGNAL(closed(void)));
// connect(cancel_btn, SIGNAL(clicked(void)), this, SLOT(show_confirm_exit_dlg(void)));
connect(next_btn, SIGNAL(clicked(void)), &m_cal, SLOT(showNextMonth(void)));
connect(prev_btn, SIGNAL(clicked(void)), &m_cal, SLOT(showPreviousMonth(void)));
connect(ok_btn, SIGNAL(clicked(void)), this, SLOT(validate_holiday_mode(void)));
connect(cancel_btn, SIGNAL(clicked(void)), this, SIGNAL(close_holiday_dlg(void)));
this->setLayout(mainLayout); this->setLayout(mainLayout);
@ -59,5 +62,11 @@ HolidayDlg::~HolidayDlg()
{ {
} }
void HolidayDlg::validate_holiday_mode(void)
{
emit holiday_mode(m_cal.selectedDate());
emit close_holiday_dlg();
}
/* vim: set tabstop=8 shiftwidth=8 softtabstop=0 noexpandtab: */ /* vim: set tabstop=8 shiftwidth=8 softtabstop=0 noexpandtab: */

+ 28
- 2
soft/thermostat/src/mainwindow.cpp View File

@ -31,6 +31,8 @@ MainWindow::MainWindow(QWidget *parent) :
m_boost = NULL; m_boost = NULL;
m_menu = NULL; m_menu = NULL;
m_end_holiday = QDate::currentDate();;
Settings *s = Settings::getInstance(); Settings *s = Settings::getInstance();
for (int i = 0; i < s->nbZones(); i++) { for (int i = 0; i < s->nbZones(); i++) {
@ -150,12 +152,31 @@ void MainWindow::show_boost(void)
m_central_widget.setCurrentWidget(m_boost); m_central_widget.setCurrentWidget(m_boost);
} }
void MainWindow::show_holiday_dlg(void)
void MainWindow::do_show_holiday_dlg(void)
{ {
HolidayDlg *holiday_dlg = new HolidayDlg(this); HolidayDlg *holiday_dlg = new HolidayDlg(this);
m_central_widget.addWidget(holiday_dlg); m_central_widget.addWidget(holiday_dlg);
m_central_widget.setCurrentWidget(holiday_dlg); m_central_widget.setCurrentWidget(holiday_dlg);
connect(holiday_dlg, SIGNAL(close_holiday_dlg(void)), this, SLOT(do_close_holiday_dlg(void)));
connect(holiday_dlg, SIGNAL(holiday_mode(QDate)), this, SLOT(set_holiday_mode(QDate)));
}
void MainWindow::do_close_holiday_dlg(void)
{
QWidget *current = m_central_widget.currentWidget();
if (current == NULL)
return;
m_central_widget.removeWidget(current);
delete current;
}
void MainWindow::set_holiday_mode(QDate end_date)
{
m_end_holiday = end_date;
apply_order_to_heaters();
} }
void MainWindow::show_menu(void) void MainWindow::show_menu(void)
@ -163,7 +184,7 @@ void MainWindow::show_menu(void)
m_menu = new MenuDlg(NULL); m_menu = new MenuDlg(NULL);
connect(m_menu, SIGNAL(closed(void)), this, SLOT(show_main(void))); connect(m_menu, SIGNAL(closed(void)), this, SLOT(show_main(void)));
connect(m_menu, SIGNAL(show_holiday_dlg(void)), this, SLOT(show_holiday_dlg(void)));
connect(m_menu, SIGNAL(show_holiday_dlg(void)), this, SLOT(do_show_holiday_dlg(void)));
m_central_widget.addWidget(m_menu); m_central_widget.addWidget(m_menu);
m_central_widget.setCurrentWidget(m_menu); m_central_widget.setCurrentWidget(m_menu);
@ -373,6 +394,11 @@ void MainWindow::apply_order_to_heaters(void)
{ {
Settings *s = Settings::getInstance(); Settings *s = Settings::getInstance();
if (m_end_holiday > QDate::currentDate()) {
qDebug() << "Holiday mode => emit ALL_OFF order";
emit setAllHeatersOn(false);
}
switch (s->m_state) { switch (s->m_state) {
case ON: case ON:
qDebug() << "emit ALL_ON order"; qDebug() << "emit ALL_ON order";


Loading…
Cancel
Save