blob: 3fecf2e8baf5c06a1f7c073cf8938a48f9abd0f9 (
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
|
/***************************************************************************
kmymoneyaccountbutton - description
-------------------
begin : Mon May 31 2004
copyright : (C) 2000-2004 by Michael Edwardes
email : mte@users.sourceforge.net
Javier Campos Morales <javi_c@users.sourceforge.net>
Felix Rodriguez <frodriguez@users.sourceforge.net>
John C <thetacoturtle@users.sourceforge.net>
Thomas Baumgart <ipwizard@users.sourceforge.net>
Kevin Tambascio <ktambascio@users.sourceforge.net>
***************************************************************************/
/***************************************************************************
* *
* 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 KMYMONEYACCOUNTBUTTON_H
#define KMYMONEYACCOUNTBUTTON_H
// ----------------------------------------------------------------------------
// QT Includes
// ----------------------------------------------------------------------------
// KDE Includes
#include <kpushbutton.h>
#include <kcombobox.h>
// ----------------------------------------------------------------------------
// Project Includes
#include <kmymoney/kmymoneyutils.h>
class kMyMoneyAccountCompletion;
/**
* @author Thomas Baumgart
*/
class KMyMoneyAccountCombo : public KComboBox
{
TQ_OBJECT
public:
KMyMoneyAccountCombo( TQWidget* parent = 0, const char* name = 0 );
~KMyMoneyAccountCombo();
/**
* Method returns how many items are in the account selector list.
*/
int count(void) const;
/**
* This method loads the set of accounts into the widget
* as defined by the parameter @p accountIdList. @p accountIdList is
* a TQValueList of account ids.
*
* @param baseName TQString which should be used as group text
* @param accountIdList TQValueList of TQString account ids
* which should be loaded into the widget
* @param clear if true (default) clears the widget before populating
* @return This method returns the number of accounts loaded into the list
*/
int loadList(const TQString& baseName, const TQValueList<TQString>& accountIdList, const bool clear = true);
TQStringList accountList(const TQValueList<MyMoneyAccount::accountTypeE>& list = TQValueList<MyMoneyAccount::accountTypeE>()) const;
int loadList(KMyMoneyUtils::categoryTypeE typeMask);
int loadList(const TQValueList<int>& list);
int loadList(MyMoneyAccount::accountTypeE type);
void setSelected(const TQString& id);
void setSelected(const MyMoneyAccount& acc);
/**
* This method returns the list of selected account id's. If
* no account is selected, the list is empty.
*
* @return list of selected accounts
*/
TQStringList selectedAccounts(void) const;
virtual void keyPressEvent(TQKeyEvent* e);
public slots:
void slotButtonPressed(void);
void slotSelected(const TQString&);
protected slots:
signals:
void accountSelected(const TQString&);
void pressed();
void released();
void clicked();
protected:
void mousePressEvent(TQMouseEvent *e);
void mouseReleaseEvent(TQMouseEvent *e);
void setText(const TQString& txt);
private:
kMyMoneyAccountCompletion* m_completion;
bool m_mlbDown;
};
#endif
|