mirror of
https://github.com/GoldenCheetah/GoldenCheetah.git
synced 2026-02-13 16:18:42 +00:00
Refactor of the date settings into its own widget so we can re-use it across any chart that supports date ranges.
195 lines
5.4 KiB
C++
195 lines
5.4 KiB
C++
/*
|
|
* Copyright (c) 2010 Mark Liversedge (liversedge@gmail.com)
|
|
*
|
|
* This program 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 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program 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 this program; if not, write to the Free Software Foundation, Inc., 51
|
|
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef _GC_LTMTool_h
|
|
#define _GC_LTMTool_h 1
|
|
#include "GoldenCheetah.h"
|
|
|
|
#include "MainWindow.h"
|
|
#include "Season.h"
|
|
#include "RideMetric.h"
|
|
#include "LTMSettings.h"
|
|
|
|
#ifdef GC_HAVE_LUCENE
|
|
#include "SearchFilterBox.h"
|
|
#endif
|
|
|
|
#include <QDir>
|
|
#include <QtGui>
|
|
|
|
// tree widget types
|
|
#define ROOT_TYPE 1
|
|
#define DATE_TYPE 2
|
|
#define METRIC_TYPE 3
|
|
|
|
#define SYS_DATE 1
|
|
#define USER_DATE 2
|
|
|
|
|
|
class LTMTool : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
G_OBJECT
|
|
|
|
|
|
public:
|
|
|
|
LTMTool(MainWindow *parent, const QDir &home, bool Multi = true);
|
|
|
|
//const Season *currentDateRange() { return dateRange; }
|
|
//void selectDateRange(int);
|
|
QList<QTreeWidgetItem *> selectedMetrics() { return metricTree->selectedItems(); }
|
|
|
|
QString metricName(QTreeWidgetItem *);
|
|
QString metricSymbol(QTreeWidgetItem *);
|
|
MetricDetail metricDetails(QTreeWidgetItem *);
|
|
MetricDetail* metricDetails(QString symbol);
|
|
void selectMetric(QString symbol);
|
|
static void translateMetrics(MainWindow *main, const QDir &home, LTMSettings *settings);
|
|
|
|
// allow others to create and update season structures
|
|
//int newSeason(QString, QDate, QDate, int);
|
|
//void updateSeason(int, QString, QDate, QDate, int);
|
|
|
|
// apply settings to the metric selector
|
|
void applySettings(LTMSettings *);
|
|
|
|
// get/set the date range
|
|
//void setDateRange(QString);
|
|
//QString _dateRange() const;
|
|
|
|
void setUseSelected(int);;
|
|
int useSelected();
|
|
|
|
bool isFiltered() { return _amFiltered; }
|
|
QStringList &filters() { return filenames; }
|
|
|
|
#ifdef GC_HAVE_LUCENE
|
|
SearchFilterBox *searchBox;
|
|
#endif
|
|
|
|
// preset charts
|
|
QList<LTMSettings> presets;
|
|
|
|
// accessed by LTMWindow hence public
|
|
QComboBox *presetPicker;
|
|
QComboBox *groupBy;
|
|
QCheckBox *shadeZones;
|
|
QCheckBox *showLegend;
|
|
QPushButton *saveButton;
|
|
QPushButton *manageButton;
|
|
|
|
DateSettingsEdit *dateSetting;
|
|
|
|
signals:
|
|
|
|
//void dateRangeSelected(const Season *);
|
|
void filterChanged();
|
|
void metricSelected();
|
|
void useCustomRange(DateRange); // use the range passed...
|
|
void useStandardRange(); // fall back to standard date range...
|
|
void useThruToday(); // fall back to standard date range thru today
|
|
|
|
private slots:
|
|
//void dateRangeTreeWidgetSelectionChanged();
|
|
//void dateRangePopup(QPoint);
|
|
//void dateRangeChanged(QTreeWidgetItem *, int);
|
|
//void renameRange();
|
|
//void editRange();
|
|
//void deleteRange();
|
|
void metricTreeWidgetSelectionChanged();
|
|
void metricTreePopup(QPoint);
|
|
void colorPicker();
|
|
void editMetric();
|
|
void configChanged();
|
|
//void resetSeasons(); // rebuild the seasons list if it changes
|
|
|
|
void clearFilter();
|
|
void setFilter(QStringList);
|
|
|
|
private:
|
|
|
|
QwtPlotCurve::CurveStyle curveStyle(RideMetric::MetricType);
|
|
QwtSymbol::Style symbolStyle(RideMetric::MetricType);
|
|
// Helper function for default charts translation
|
|
void translateDefaultCharts(QList<LTMSettings>&charts);
|
|
|
|
const QDir home;
|
|
MainWindow *main;
|
|
bool useMetricUnits;
|
|
bool active; // ignore season changed signals since we triggered them
|
|
|
|
//Seasons *seasons;
|
|
//QTreeWidget *dateRangeTree;
|
|
//QTreeWidgetItem *allDateRanges;
|
|
//const Season *dateRange;
|
|
|
|
bool _amFiltered; // is a filter appling?
|
|
QStringList filenames; // filters
|
|
|
|
QList<MetricDetail> metrics;
|
|
QTreeWidget *metricTree;
|
|
QTreeWidgetItem *allMetrics;
|
|
|
|
//QTreeWidgetItem *activeDateRange; // when using context menus
|
|
QTreeWidgetItem *activeMetric; // when using context menus
|
|
|
|
QTabWidget *tabs;
|
|
|
|
};
|
|
|
|
class EditMetricDetailDialog : public QDialog
|
|
{
|
|
Q_OBJECT
|
|
G_OBJECT
|
|
|
|
|
|
public:
|
|
EditMetricDetailDialog(MainWindow *, MetricDetail *);
|
|
|
|
public slots:
|
|
void colorClicked();
|
|
void applyClicked();
|
|
void cancelClicked();
|
|
|
|
private:
|
|
MainWindow *mainWindow;
|
|
MetricDetail *metricDetail;
|
|
|
|
QLineEdit *userName,
|
|
*userUnits;
|
|
|
|
QComboBox *curveStyle,
|
|
*curveSymbol;
|
|
QCheckBox *stack;
|
|
QPushButton *curveColor;
|
|
QDoubleSpinBox *showBest,
|
|
*showOut,
|
|
*baseLine;
|
|
QCheckBox *curveSmooth,
|
|
*curveTrend;
|
|
|
|
QPushButton *applyButton, *cancelButton;
|
|
|
|
QColor penColor; // chosen from color Picker
|
|
void setButtonIcon(QColor);
|
|
};
|
|
|
|
#endif // _GC_LTMTool_h
|
|
|