blob: 589a6398986ce82e259ec761879676012696e67f (
plain)
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
|
/***************************************************************************
finddialog.h - Trinity Desktop Planetarium
-------------------
begin : Wed Jul 4 2001
copyright : (C) 2001 by Jason Harris
email : jharris@30doradus.org
***************************************************************************/
/***************************************************************************
* *
* 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. *
* *
***************************************************************************/
#ifndef FINDDIALOG_H
#define FINDDIALOG_H
#include <kdialogbase.h>
class TQVBoxLayout;
class TQHBoxLayout;
class TQGridLayout;
class TQLabel;
class TQLineEdit;
class TQComboBox;
class TQListBox;
class TQListBoxItem;
//class TQStringList;
class SkyObjectNameListItem;
/**@class FindDialog
*Dialog window for finding SkyObjects by name. The dialog contains
*a TQListBox showing the list of named objects, a TQLineEdit for filtering
*the list by name, and a TQCombobox for filtering the list by object type.
*
*@short Find Object Dialog
*@author Jason Harris
*@version 1.0
*/
class FindDialog : public KDialogBase {
Q_OBJECT
public:
/**Constructor. Creates all widgets and packs them in TQLayouts. Connects
*Signals and Slots. Runs initObjectList().
*/
FindDialog( TQWidget* parent = 0 );
/**Destructor
*/
~FindDialog();
/**@return the currently-selected item from the listbox of named objects
*/
SkyObjectNameListItem * currentItem() const { return currentitem; }
public slots:
/**When Text is entered in the TQLineEdit, filter the List of objects
*so that only objects which start with the filter text are shown.
*/
void filter();
/**When the selection of the object type TQComboBox is changed, filter
*the List of objects so that only objects of the selected Type are shown.
*/
void filterByType();
/**Overloading the Standard KDialogBase slotOk() to show a "sorry" message
*box if no object is selected when the user presses Ok. The window is
*not closed in this case.
*/
void slotOk();
private slots:
/**Init object list after opening dialog.
*/
void init();
/**Set the selected item in the list to the item specified.
*/
void updateSelection (TQListBoxItem *);
/**Change current filter options.
*/
void setFilter( int f );
protected:
/**Process Keystrokes. The Up and Down arrow keys are used to select the
*Previous/Next item in the listbox of named objects.
*@param e The TQKeyEvent pointer
*/
void keyPressEvent( TQKeyEvent *e );
private:
/**
*Automatically select the first item in the list
*/
void setListItemEnabled();
TQVBoxLayout *vlay;
TQHBoxLayout *hlay;
TQListBox *SearchList;
TQLineEdit *SearchBox;
TQLabel *filterTypeLabel;
TQComboBox *filterType;
SkyObjectNameListItem *currentitem;
int Filter;
};
#endif
|