1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
|
#ifndef KCHART_DATA_EDITOR_H
#define KCHART_DATA_EDITOR_H
#include <qstrlist.h>
#include <qspinbox.h>
#include <kdialogbase.h>
#include "kchart_part.h"
class QLabel;
class QSpinBox;
class QCheckBox;
namespace KChart
{
class KChartParams;
// This class inherits QSpinBox, but fixes a problem with it.
// Consider the following case:
//
// 1. The SpinBox for rows has the value 4.
// 2. The user enters the number 2 into it.
// 3. The user presses the little up arrow in the spinbox.
// 4. valueChanged(2) is emitted and 2 rows are removed.
// 5. valueChanged(3) is emitted and 1 row is added.
//
// Now (at least) one row is removed that was never meant to be
// removed and data is lost. This class fixes that by changing the
// semantics. So instead of the behaviour of above, the
// valueChanged(2) is never emitted and instead of valueChanged(3),
// valueChanged(5) is emitted.
//
class kchartDataSpinBox : public QSpinBox
{
Q_OBJECT
public:
kchartDataSpinBox(QWidget *);
~kchartDataSpinBox();
public slots:
// The user pressed the Up-button
void stepUp();
// The user pressed the Down-button
void stepDown();
protected:
void interpretText(){;};
bool eventFilter( QObject *obj, QEvent *ev );
signals:
// the value is changed (stepUp/stepDown was called or the focus is lost)
void valueChangedSpecial(int);
private:
// True if we should ignore the next value change (see above).
bool m_ignore;
};
// ----------------------------------------------------------------
// The reason for having a special Table class is to implement
// keyboard navigation in editing mode.
//
class kchartDataTable : public QTable
{
Q_OBJECT
public:
kchartDataTable(QWidget *);
~kchartDataTable();
protected:
// handles keyboard navigation
bool eventFilter( QObject *obj, QEvent *ev );
};
// ----------------------------------------------------------------
class kchartDataEditor : public KDialogBase
{
Q_OBJECT
public:
kchartDataEditor(QWidget* parent = 0);
void setData(KChartParams *params, KDChartTableData *dat);
void getData(KChartParams *params, KDChartTableData *dat);
void setRowLabels(const QStringList &rowLabels);
void getRowLabels(QStringList &rowLabels);
void setColLabels(const QStringList &colLabels);
void getColLabels(QStringList &colLabels);
bool modified() const { return m_modified; }
protected:
/**
* Returns the number of rows used as headers (ie. containing labels for the X axis or a series name,
* depending on the orientation of the data)
*/
int headerRows();
/**
* Returns the number of columns used as headers (ie. containing labels for the X axis or a series name,
* depending on the orientation of the data)
*/
int headerCols();
/**
* Updates the table widget's vertical header to match the row labels specified in the leftmost column of
* each row
*/
void updateRowHeaders();
/**
* Updates the table widget's horizontal header to match the column labels specified in the top row of each
* column
*/
void updateColHeaders();
private:
void addDocs();
signals:
void applyClicked(kchartDataEditor *ed);
private slots:
void slotApply();
/** Removes the row which the current cell belongs to */
void removeCurrentRow();
/** Removes the column which the current cell belongs to */
void removeCurrentColumn();
/** Inserts a new row below the current cell */
void insertRow();
/** Inserts a new column to the right of the current cell */
void insertColumn();
void setRows(int rows);
void setCols(int cols);
// Called when something changes in the table.
void tableChanged(int row, int col);
// Called when the current cell is changed
void currentChanged(int row, int col);
private:
// Widgets in the editor
kchartDataTable *m_table;
QPushButton *m_insertRowButton;
QPushButton *m_insertColButton;
QPushButton *m_removeRowButton;
QPushButton *m_removeColButton;
QLabel *m_rowsLA;
kchartDataSpinBox *m_rowsSB;
QLabel *m_colsLA;
kchartDataSpinBox *m_colsSB;
QCheckBox *m_firstRowAsLabel;
QCheckBox *m_firstColAsLabel;
// This member is set to true if the user shrinks the data table,
// and confirms this by clicking OK in a warning dialog.
bool m_userWantsToShrink;
bool m_modified;
};
} //KChart namespace
#endif
|