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
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
|
/*
** Copyright (C) 1999,2000 Toivo Pedaste <toivo@ucs.uwa.edu.au>
**
// Author: Damyan Pepper
//
// This widget is used to provide the management mode of ksetup.
// There are two subwidgets; firstly a tree list showing all the
// currently installed packages and secondly a display of the currently
// selected package's properties.
//
// There are also some control buttons which allow the currently
// selected package to be uninstalled or verified.
*/
/*
** 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 in a file called COPYING; if not, write to
** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
** MA 02110-1301, USA.
*/
/*
** Bug reports and questions can be sent to kde-devel@kde.org
*/
#ifndef MANAGEMENTWIDGET_H
#define MANAGEMENTWIDGET_H
#include "../config.h"
// Standard Headers
// Qt Headers
#include <tqframe.h>
#include <tqpushbutton.h>
#include <tqptrlist.h>
#include <tqstring.h>
#include <tqlayout.h>
#include <tqtabwidget.h>
#include <tqlabel.h>
#include <tqhbox.h>
// KDE headers
#include <kaction.h>
#include <klistview.h>
#include <klistviewsearchline.h>
// ksetup headers
#include "packageInfo.h"
#include "kplview.h"
class packageDisplayWidget;
class packageInfo;
class QSplitter;
class KActionCollection;
class KToolBar;
class managementWidget;
class KpListViewSearchLine : public KListViewSearchLine
{
Q_OBJECT
public:
KpListViewSearchLine(TQWidget *parent, KpTreeList *listView);
~KpListViewSearchLine();
void updateSearch(const TQString &s = TQString::null);
private:
KpTreeList *list;
};
class managementWidget : public QFrame
{
Q_OBJECT
///////////// METHODS ------------------------------------------------------
public:
managementWidget(TQWidget *parent);
// Constructor
~managementWidget();
// Destructor
KpTreeListItem *updatePackage(packageInfo *pki, bool install);
// update package in treelist
void readPSeparator();
void writePSeparator();
// config: position of panel seperator
void doChangePackage(packageInfo *p);
// emit change package
KpTreeListItem *search(TQString str, bool subStr, bool wrap,
bool start=FALSE);
protected:
void resizeEvent(TQResizeEvent *re);
// This is called when the widget is resized
private:
void setupWidgets();
// This sets up the sub-widgets
void setupInstButton();
// Set button for inst or uninst
void arrangeWidgets();
// This arranges the widgets in the window (should be called after a
// resize event)
void setupMultButton(int &cntInstall, int &cntUnInstall);
// Setup mult install/uninstall button appropriately
///////////// SLOTS ------------------------------------------------------
public slots:
void collectData(bool refresh);
// This collects data about all the packages installed.
// The list tree is filled with this data. Whenever something happens
// that requires data to be (re)collected a signal connected to this slot
// should be emitted. This function can also be called directly.
void rebuildListTree();
// This rebuilds the list tree. This would normally be called if the
// data contained about the packages has been changed (e.g. a verification
// failed / succeeded).
void uninstallMultClicked();
// This is called when uninstalling multiple packages
void uninstallSingleClicked();
// This is called when uninstalling a single package
void installSingleClicked();
// This is called when the install button has been clicked with single package
void installMultClicked();
// This is called when the install button has been clicked with multiple packages
void setInstallAction(KAction *a) { install_action = a; }
void setUninstallAction(KAction *a) { uninstall_action = a; }
void packageHighlighted(TQListViewItem *);
// This is called when a package has been highlighted in the list tree
void tabChanged(int);
// treelist display tab changed
void checkMarked();
// Count marked packages that can be installed/uninstalled
///////////// SIGNALS ------------------------------------------------------
///////////// DATA ---------------------------------------------------------
private:
TQPushButton *linstButton,*luinstButton,*instButton,*uinstButton;
// This button is used to (un)install the selected package
packageDisplayWidget *packageDisplay;
// This widget displays the package info / file-list
TQBoxLayout *top, *leftbox, *rightbox, *lbuttons, *rbuttons;
// These are the geometry managers
TQFrame *leftpanel, *rightpanel;
// frame to put QBox in
TQTabWidget *ltab;
// tab between various treelist displays
TQSplitter *vPan;
// veritcal panner between panels
KToolBar *searchToolBar;
TQPtrList<KpTreeListItem> selList;
// list for selected packages
TQString tType[4];
// identifiers for tree display
public:
TQPtrList<packageInfo> *allPackages;
// The list of packages
TQDict<packageInfo> *dirInstPackages;
// maps installed package name to package
TQDict<packageInfo> *dirUninstPackages;
// maps uninstalled package name to package
TQDict<packageInfo> *dirInfoPackages;
// maps Info package name to package
KpTreeList *treeList;
// This is the tree list where all the packages / groups are displayed
KpListViewSearchLine *searchLine;
// Widget for search treeList
KAction *install_action;
KAction *uninstall_action;
};
#endif
|