summaryrefslogtreecommitdiffstats
path: root/desktop-widgets/simplewidgets.h
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2015-11-02 19:54:34 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-11-02 19:54:34 -0800
commit8ea7f404574c2ee571d2dde6bb6be3791e962150 (patch)
tree6a050178bfc71bf10558968f2a3bc0a12d8c525f /desktop-widgets/simplewidgets.h
parentb273c1b0ca7bfe933e7c83742f1610f6bbe3f4d3 (diff)
parentdf7818a9b8495285b4d9812e5d6d50d6f9c08813 (diff)
downloadsubsurface-8ea7f404574c2ee571d2dde6bb6be3791e962150.tar.gz
Merge branch 'cmakeAndPreferences'
Diffstat (limited to 'desktop-widgets/simplewidgets.h')
-rw-r--r--desktop-widgets/simplewidgets.h237
1 files changed, 237 insertions, 0 deletions
diff --git a/desktop-widgets/simplewidgets.h b/desktop-widgets/simplewidgets.h
new file mode 100644
index 000000000..595c4cd4b
--- /dev/null
+++ b/desktop-widgets/simplewidgets.h
@@ -0,0 +1,237 @@
+#ifndef SIMPLEWIDGETS_H
+#define SIMPLEWIDGETS_H
+
+class MinMaxAvgWidgetPrivate;
+class QAbstractButton;
+class QNetworkReply;
+
+#include <QWidget>
+#include <QGroupBox>
+#include <QDialog>
+#include <stdint.h>
+
+#include "ui_renumber.h"
+#include "ui_setpoint.h"
+#include "ui_shifttimes.h"
+#include "ui_shiftimagetimes.h"
+#include "ui_urldialog.h"
+#include "ui_divecomponentselection.h"
+#include "ui_listfilter.h"
+#include "ui_filterwidget.h"
+#include "exif.h"
+#include <dive.h>
+
+
+class MinMaxAvgWidget : public QWidget {
+ Q_OBJECT
+ Q_PROPERTY(double minimum READ minimum WRITE setMinimum)
+ Q_PROPERTY(double maximum READ maximum WRITE setMaximum)
+ Q_PROPERTY(double average READ average WRITE setAverage)
+public:
+ MinMaxAvgWidget(QWidget *parent);
+ ~MinMaxAvgWidget();
+ double minimum() const;
+ double maximum() const;
+ double average() const;
+ void setMinimum(double minimum);
+ void setMaximum(double maximum);
+ void setAverage(double average);
+ void setMinimum(const QString &minimum);
+ void setMaximum(const QString &maximum);
+ void setAverage(const QString &average);
+ void overrideMinToolTipText(const QString &newTip);
+ void overrideAvgToolTipText(const QString &newTip);
+ void overrideMaxToolTipText(const QString &newTip);
+ void clear();
+
+private:
+ QScopedPointer<MinMaxAvgWidgetPrivate> d;
+};
+
+class RenumberDialog : public QDialog {
+ Q_OBJECT
+public:
+ static RenumberDialog *instance();
+ void renumberOnlySelected(bool selected = true);
+private
+slots:
+ void buttonClicked(QAbstractButton *button);
+
+private:
+ explicit RenumberDialog(QWidget *parent);
+ Ui::RenumberDialog ui;
+ bool selectedOnly;
+};
+
+class SetpointDialog : public QDialog {
+ Q_OBJECT
+public:
+ static SetpointDialog *instance();
+ void setpointData(struct divecomputer *divecomputer, int time);
+private
+slots:
+ void buttonClicked(QAbstractButton *button);
+
+private:
+ explicit SetpointDialog(QWidget *parent);
+ Ui::SetpointDialog ui;
+ struct divecomputer *dc;
+ int time;
+};
+
+class ShiftTimesDialog : public QDialog {
+ Q_OBJECT
+public:
+ static ShiftTimesDialog *instance();
+ void showEvent(QShowEvent *event);
+private
+slots:
+ void buttonClicked(QAbstractButton *button);
+ void changeTime();
+
+private:
+ explicit ShiftTimesDialog(QWidget *parent);
+ int64_t when;
+ Ui::ShiftTimesDialog ui;
+};
+
+class ShiftImageTimesDialog : public QDialog {
+ Q_OBJECT
+public:
+ explicit ShiftImageTimesDialog(QWidget *parent, QStringList fileNames);
+ time_t amount() const;
+ void setOffset(time_t offset);
+ bool matchAll();
+private
+slots:
+ void buttonClicked(QAbstractButton *button);
+ void syncCameraClicked();
+ void dcDateTimeChanged(const QDateTime &);
+ void timeEditChanged(const QTime &time);
+ void updateInvalid();
+ void matchAllImagesToggled(bool);
+
+private:
+ QStringList fileNames;
+ Ui::ShiftImageTimesDialog ui;
+ time_t m_amount;
+ time_t dcImageEpoch;
+ bool matchAllImages;
+};
+
+class URLDialog : public QDialog {
+ Q_OBJECT
+public:
+ explicit URLDialog(QWidget *parent);
+ QString url() const;
+private:
+ Ui::URLDialog ui;
+};
+
+class QCalendarWidget;
+
+class DateWidget : public QWidget {
+ Q_OBJECT
+public:
+ DateWidget(QWidget *parent = 0);
+ QDate date() const;
+public
+slots:
+ void setDate(const QDate &date);
+
+protected:
+ void paintEvent(QPaintEvent *event);
+ void mousePressEvent(QMouseEvent *event);
+ void focusInEvent(QFocusEvent *);
+ void focusOutEvent(QFocusEvent *);
+ void keyPressEvent(QKeyEvent *);
+ void changeEvent(QEvent *);
+ bool eventFilter(QObject *, QEvent *);
+signals:
+ void dateChanged(const QDate &date);
+
+private:
+ QDate mDate;
+ QCalendarWidget *calendarWidget;
+};
+
+class DiveComponentSelection : public QDialog {
+ Q_OBJECT
+public:
+ explicit DiveComponentSelection(QWidget *parent, struct dive *target, struct dive_components *_what);
+private
+slots:
+ void buttonClicked(QAbstractButton *button);
+
+private:
+ Ui::DiveComponentSelectionDialog ui;
+ struct dive *targetDive;
+ struct dive_components *what;
+};
+
+namespace Ui{
+ class FilterWidget2;
+};
+
+class MultiFilter : public QWidget {
+ Q_OBJECT
+public
+slots:
+ void closeFilter();
+ void adjustHeight();
+ void filterFinished();
+
+public:
+ MultiFilter(QWidget *parent);
+ Ui::FilterWidget2 ui;
+};
+
+class TagFilter : public QWidget {
+ Q_OBJECT
+public:
+ TagFilter(QWidget *parent = 0);
+ virtual void showEvent(QShowEvent *);
+ virtual void hideEvent(QHideEvent *);
+
+private:
+ Ui::FilterWidget ui;
+ friend class MultiFilter;
+};
+
+class BuddyFilter : public QWidget {
+ Q_OBJECT
+public:
+ BuddyFilter(QWidget *parent = 0);
+ virtual void showEvent(QShowEvent *);
+ virtual void hideEvent(QHideEvent *);
+
+private:
+ Ui::FilterWidget ui;
+};
+
+class SuitFilter : public QWidget {
+ Q_OBJECT
+public:
+ SuitFilter(QWidget *parent = 0);
+ virtual void showEvent(QShowEvent *);
+ virtual void hideEvent(QHideEvent *);
+
+private:
+ Ui::FilterWidget ui;
+};
+
+class LocationFilter : public QWidget {
+ Q_OBJECT
+public:
+ LocationFilter(QWidget *parent = 0);
+ virtual void showEvent(QShowEvent *);
+ virtual void hideEvent(QHideEvent *);
+
+private:
+ Ui::FilterWidget ui;
+};
+
+bool isGnome3Session();
+QImage grayImage(const QImage &coloredImg);
+
+#endif // SIMPLEWIDGETS_H