#ifndef COMBOBUTTON_H #define COMBOBUTTON_H #include class TQString; class TQPixmap; class KPushButton; class KComboBox; /** * @short ComboButton * @author Daniel Faust * @version 0.3 */ class ComboButton : public TQWidget { Q_OBJECT TQ_OBJECT public: enum SizeMode { Min, Max }; /** * Constructor * @param tqparent The tqparent widget * @param name The name of the file list */ ComboButton( TQWidget *tqparent, const char *name = 0 ); /** * Destructor */ virtual ~ComboButton(); /** * Insert a new item with @p text at position @p index */ void insertItem( const TQString &text, int index = -1 ); /** * Insert a new item with an icon @p pixmap and @p text at position @p index */ void insertItem( const TQPixmap &pixmap, const TQString &text, int index = -1 ); /** * Increase the combobutton's height by @p height */ void increaseHeight( int height ); /** * Sets m_sizeMode to @p mode */ void setSizeMode( int mode ); /** * Returns the m_sizeMode */ int sizeMode(); /** * Sets the font of the combobutton */ void setFont( const TQFont& font ); /** * Returns the font of the button */ TQFont font(); private: /** A pointer to the button */ KPushButton *m_button; /** A pointer to the combobox */ KComboBox *m_box; int m_increaseHeight; /** The actual size mode */ int m_sizeMode; /** Recalculate the size of the combobutton */ void balanceSize(); /** The button gets a new label, etc. */ void tqrepaintButton(); //public slots: //void setCurrentItem(const TQString &item, bool insert=false, int index=-1); //void setCurrentItem(int index); private slots: /** * Is called when the user selects an item from the popdown menu of the combobox */ void boxActivated( int index ); /** * Is called when the user clicks the button */ void buttonClicked(); signals: /** * The signal clicked is emitted, when the user selects an item */ void clicked( int index ); }; #endif // COMBOBUTTON_H