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.
114 lines
3.9 KiB
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
|