2018-03-16 21:46:57 +00:00
|
|
|
#ifndef CUTTERWIDGET_H
|
|
|
|
#define CUTTERWIDGET_H
|
|
|
|
|
|
|
|
#include <QDockWidget>
|
|
|
|
|
2019-01-13 11:40:54 +00:00
|
|
|
#include "common/RefreshDeferrer.h"
|
|
|
|
|
2018-03-16 21:46:57 +00:00
|
|
|
class MainWindow;
|
|
|
|
|
|
|
|
class CutterDockWidget : public QDockWidget
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit CutterDockWidget(MainWindow *main, QAction *action = nullptr);
|
2019-01-12 17:02:51 +00:00
|
|
|
~CutterDockWidget() override;
|
|
|
|
bool eventFilter(QObject *object, QEvent *event) override;
|
2019-01-12 19:25:43 +00:00
|
|
|
bool isVisibleToUser() { return isVisibleToUserCurrent; }
|
2019-01-12 17:02:51 +00:00
|
|
|
|
2018-03-16 21:46:57 +00:00
|
|
|
public slots:
|
|
|
|
void toggleDockWidget(bool show);
|
|
|
|
|
2019-01-12 18:01:43 +00:00
|
|
|
signals:
|
|
|
|
void becameVisibleToUser();
|
|
|
|
|
2018-03-16 21:46:57 +00:00
|
|
|
private:
|
|
|
|
QAction *action;
|
|
|
|
|
2019-01-12 18:01:43 +00:00
|
|
|
bool isVisibleToUserCurrent;
|
|
|
|
void updateIsVisibleToUser();
|
2019-01-12 17:02:51 +00:00
|
|
|
|
2018-03-16 21:46:57 +00:00
|
|
|
protected:
|
2018-03-21 20:32:32 +00:00
|
|
|
void closeEvent(QCloseEvent *event) override;
|
2019-01-13 11:40:54 +00:00
|
|
|
|
2019-01-13 14:26:55 +00:00
|
|
|
/*!
|
|
|
|
* \brief Convenience method for creating and registering a RefreshDeferrer without any parameters
|
|
|
|
* \param refreshNowFunc lambda taking no parameters, called when a refresh should occur
|
|
|
|
*/
|
|
|
|
template<typename Func>
|
|
|
|
RefreshDeferrer *createRefreshDeferrer(Func refreshNowFunc)
|
|
|
|
{
|
|
|
|
auto *deferrer = new RefreshDeferrer(nullptr, this);
|
|
|
|
deferrer->registerFor(this);
|
|
|
|
connect(deferrer, &RefreshDeferrer::refreshNow, this, [refreshNowFunc](const RefreshDeferrerParamsResult) {
|
|
|
|
refreshNowFunc();
|
|
|
|
});
|
|
|
|
return deferrer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Convenience method for creating and registering a RefreshDeferrer with a replacing Accumulator
|
|
|
|
* \param replaceIfNull passed to the ReplacingRefreshDeferrerAccumulator
|
|
|
|
* \param refreshNowFunc lambda taking a single parameter of type ParamResult, called when a refresh should occur
|
|
|
|
*/
|
2019-01-13 11:40:54 +00:00
|
|
|
template<class ParamResult, typename Func>
|
2019-01-13 13:59:08 +00:00
|
|
|
RefreshDeferrer *createReplacingRefreshDeferrer(bool replaceIfNull, Func refreshNowFunc)
|
2019-01-13 11:40:54 +00:00
|
|
|
{
|
2019-01-13 13:59:08 +00:00
|
|
|
auto *deferrer = new RefreshDeferrer(new ReplacingRefreshDeferrerAccumulator<ParamResult>(replaceIfNull), this);
|
2019-01-13 11:40:54 +00:00
|
|
|
deferrer->registerFor(this);
|
|
|
|
connect(deferrer, &RefreshDeferrer::refreshNow, this, [refreshNowFunc](const RefreshDeferrerParamsResult paramsResult) {
|
2019-01-13 13:59:08 +00:00
|
|
|
auto *result = static_cast<const ParamResult *>(paramsResult);
|
|
|
|
refreshNowFunc(result);
|
2019-01-13 11:40:54 +00:00
|
|
|
});
|
|
|
|
return deferrer;
|
|
|
|
}
|
2018-03-16 21:46:57 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // CUTTERWIDGET_H
|