blob: d1a99b26f5fd4d8abeaa505b20bca26e80fb5431 (
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
|
/*********
*
* This file is part of BibleTime's source code, http://www.bibletime.info/.
*
* Copyright 1999-2006 by the BibleTime developers.
* The BibleTime source code is licensed under the GNU General Public License version 2.0.
*
**********/
#ifndef CMODULECHOOSERBUTTON_H
#define CMODULECHOOSERBUTTON_H
//BibleTime includes
#include "backend/cswordmoduleinfo.h"
#include "util/cpointers.h"
//Qt includes
#include <tqdict.h>
#include <tqtoolbutton.h>
//KDE includes
#include <ktoolbarbutton.h>
#include <kpopupmenu.h>
class KPopupMenu;
class CModuleChooserBar;
/** The CModuleChooserButton displays a list of submenus sorted by language which contain the possible modules
* which can be displayed together with the first one.
* @author The BibleTime team
*/
class CModuleChooserButton : public KToolBarButton, public CPointers {
Q_OBJECT
public:
CModuleChooserButton(CSwordModuleInfo* useModule, CSwordModuleInfo::ModuleType type, const int id, CModuleChooserBar *parent, const char *name = 0 );
~CModuleChooserButton();
CSwordModuleInfo* module();
/**
* Returns the id used for this button.
*/
int getId() const;
void updateMenuItems();
protected: // Protected methods
void populateMenu();
private:
/**
* Returns the icon used for the current status.
*/
const TQString iconName();
bool m_hasModule;
int m_id;
int m_noneId;
int m_titleId;
CSwordModuleInfo::ModuleType m_moduleType;
CSwordModuleInfo* m_module;
KPopupMenu* m_popup;
TQPtrList<KPopupMenu> m_submenus;
CModuleChooserBar* m_moduleChooserBar;
private slots:
void moduleChosen(int ID );
signals:
void sigRemoveButton(const int ID);
void sigAddButton();
void sigChanged();
};
#endif
|