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
|
/*
** Copyright (C) 1999,2000 Toivo Pedaste <toivo@ucs.uwa.edu.au>
**
// This widget is used to display information and the file list of a
// package.
//
// Package information will be displayed using (another) sub-widget
// that is inherited from a QTableView.
//
// The file list will be displayed using a tree list.
//
// The widget is mainly a QTabDialog with two tabs: Info and FileList.
// The Info tab is the default one.
*/
/*
** 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 PACKAGEDISPLAY_H
#define PACKAGEDISPLAY_H
#include "../config.h"
// Qt Headers
#include <qframe.h>
#include <qtabbar.h>
#include <qtabwidget.h>
#include <qvbox.h>
#include <kpopupmenu.h>
#include <klistview.h>
class packagePropertiesWidget;
class packageInfo;
class QListViewItem;
class QTextEdit;
class packageDisplayWidget;
class kpFileList : public KListView
{
Q_OBJECT
public:
kpFileList(QWidget* parent, packageDisplayWidget* parent2);
QString item2Path(QListViewItem *it);
public slots:
void openContext(KListView *, QListViewItem *, const QPoint &);
virtual void clear();
QListViewItem* insert(const QString &cur, const QPixmap &pixmap);
private:
KPopupMenu *FileListMenu;
packageDisplayWidget* pkDisplay;
int openwith;
};
class packageDisplayWidget : public QTabWidget
{
Q_OBJECT
friend class kpFileList;
///////////// METHODS ------------------------------------------------------
public:
packageDisplayWidget(QWidget *parent=0);
// Constructor
~packageDisplayWidget();
// Destructor
void noPackage();
// clear package display in right panel
void changePackage(packageInfo *p);
// Set currently selected package
private:
void setupWidgets();
// This sets up the sub-widgets
void updateFileList();
// This updates the file list to match that found with the currently
// selected package
void updateChangeLog();
// This updates the change log to match that found with the currently
// selected package
void tabSet(QWidget *);
// Set display for corresponding tab
///////////// SLOTS --------------------------------------------------------
public slots:
void tabSelected(QWidget *);
void openBinding(QListViewItem *);
void openBindingWith(QListViewItem *);
void __openBindingWith();
///////////// SIGNALS ------------------------------------------------------
///////////// DATA ---------------------------------------------------------
public:
packageInfo *package;
// the currently selected package
private:
QTabWidget *tabbar;
// The tab bar
QVBox *proptab, *fltab, *cltab;
QWidget *curTab;
// current active tab
kpFileList *fileList;
// This holds the file list (and is used as a page on the tab dialog)
QTextEdit *changeLog;
// Holds changelog
QPixmap tick, cross, question, *blank;
// The pixmaps for the filelist
packagePropertiesWidget *packageProperties;
// This displays the package properties (and is used as a page on the
// tab dialog)
bool initList;
// True is file list has been initialised
};
#endif
|