You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kmymoney/kmymoney2/widgets/kmymoneyaccountcombo.h

114 lines
3.9 KiB

/***************************************************************************
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
{
Q_OBJECT
TQ_OBJECT
public:
KMyMoneyAccountCombo( TQWidget* tqparent = 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