// This file is part of RSS Guard. // // Copyright (C) 2011-2016 by Martin Rotter // // RSS Guard is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // RSS Guard is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with RSS Guard. If not, see . #ifndef SETTINGSPANEL_H #define SETTINGSPANEL_H #include class Settings; class SettingsPanel : public QWidget { Q_OBJECT public: explicit SettingsPanel(Settings *settings, QWidget *parent = 0); virtual QString title() const = 0; virtual void loadSettings() = 0; virtual void saveSettings() = 0; bool requiresRestart() const; bool isDirty() const; protected: void onBeginLoadSettings(); void onEndLoadSettings(); void onBeginSaveSettings(); void onEndSaveSettings(); // Settings to use to save/load. Settings *settings() const; protected slots: // Sets this settings panel as dirty (some settings are changed) and emits the signal. // NOTE: This will be probably called by subclasses when user changes some stuff. void dirtifySettings(); // These methods should not be probably called by subclasses. void setIsDirty(bool is_dirty); void setRequiresRestart(bool requiresRestart); void requireRestart(); signals: void settingsChanged(); private: bool m_requiresRestart; bool m_isDirty; bool m_isLoading; Settings *m_settings; }; #endif // SETTINGSPANEL_H