|
|
|
/***************************************************************************
|
|
|
|
* Copyright (C) 2002-2004 by Alexander Dymo *
|
|
|
|
* cloudtemple@mskat.net *
|
|
|
|
* *
|
|
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU Library General Public License as *
|
|
|
|
* published by the Free Software Foundation; either version 2 of the *
|
|
|
|
* License, or (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
* This program is distributed in the hope that it will be useful, *
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
|
|
* GNU General Public License for more details. *
|
|
|
|
* *
|
|
|
|
* You should have received a copy of the GNU Library General Public *
|
|
|
|
* License along with this program; if not, write to the *
|
|
|
|
* Free Software Foundation, Inc., *
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
|
|
|
|
***************************************************************************/
|
|
|
|
#ifndef PCOMBOBOX_H
|
|
|
|
#define PCOMBOBOX_H
|
|
|
|
|
|
|
|
#include <tqmap.h>
|
|
|
|
|
|
|
|
#include <tqcombobox.h>
|
|
|
|
|
|
|
|
#include "propertywidget.h"
|
|
|
|
|
|
|
|
class TQComboBox;
|
|
|
|
|
|
|
|
namespace PropertyLib{
|
|
|
|
|
|
|
|
/**
|
|
|
|
@short %Property editor with combobox.
|
|
|
|
*/
|
|
|
|
class PComboBox: public PropertyWidget{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**This constructor is used for read-only selection combo. It provides a value from valueList*/
|
|
|
|
PComboBox(MultiProperty *property, const TQMap<TQString, TQVariant> &list, TQWidget *parent = 0, const char *name = 0);
|
|
|
|
/**This constructor is used for read-write selection combo. It provides a value from valueList*/
|
|
|
|
PComboBox(MultiProperty *property, const TQMap<TQString, TQVariant> &list, bool rw, TQWidget *parent = 0, const char *name = 0);
|
|
|
|
|
|
|
|
/**@return the value currently entered in the editor widget.*/
|
|
|
|
virtual TQVariant value() const;
|
|
|
|
/**Sets the value shown in the editor widget. Set emitChange to false
|
|
|
|
if you don't want to emit propertyChanged signal.*/
|
|
|
|
virtual void setValue(const TQVariant &value, bool emitChange=true);
|
|
|
|
/**Sets the list of possible values shown in the editor widget. This method
|
|
|
|
does not emit propertyChanged signal. Reimplemented because combobox is used
|
|
|
|
to display possible values from valueList.*/
|
|
|
|
virtual void setValueList(const TQMap<TQString, TQVariant> &valueList);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
TQString findDescription(const TQVariant &value);
|
|
|
|
|
|
|
|
protected slots:
|
|
|
|
void updateProperty(int val);
|
|
|
|
|
|
|
|
private:
|
|
|
|
virtual void fillBox();
|
|
|
|
void init(bool rw = false);
|
|
|
|
|
|
|
|
/** map<description, value>*/
|
|
|
|
TQMap<TQString, TQVariant> m_valueList;
|
|
|
|
|
|
|
|
TQComboBox *m_edit;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|