/* * Copyright (c) 2002-2003 Jesper K. Pedersen <blackie@kde.org> * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License version 2 as published by the Free Software Foundation. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. **/ #ifndef __tdemultiformlistbox #define __tdemultiformlistbox #include "tdemultiformlistboxfactory.h" #include "tdemultiformlistbox-shower.h" #include "tdemultiformlistboxentry.h" #include <tqptrlist.h> #include <tqlayout.h> #include <tqscrollview.h> #ifdef TQT_ONLY #include "compat.h" #else #include <tdelocale.h> #endif class TQDataStream; typedef TQPtrList<KMultiFormListBoxEntry> KMultiFormListBoxEntryList ; typedef TQPtrList<TQWidget> WidgetList; class KMultiFormListBoxMultiVisible; /** The main class used to get an KMultiFormListBox widget. The KMultiFormListBox widget consist of a sub-widget which is repeated a number of times, it is up to the end user to determine the number of times the sub widget is repeated, and he may require an additional copy simply by pressing a ``Add'' or ``More Entries'' button. The KMultiFormListBox widget has two different faces (i.e. two different end user interfaces). One (Windowed) will show a listbox from which the end user can access each subwidget containing data by pressing the LMB on a name for the element. The other face (MultiVisible) shows all the subwidgets in one huge ``Listbox''. To use the KMultiFormListBox widget you must create a class which is inherited from the @ref KMultiFormListBoxFactory class. This new class must override the function `create'. This function must return a freshly made instance of the class @ref KMultiFormListBoxEntry (or a subclass of this). The KMultiFormListBoxEntry instance is the one inserted into the KMultiFormListBox widget (one instance for each sub widget in the KMultiFormListBox widget). @author Jesper Kj�r Pedersen <blackie@kde.org> **/ class KMultiFormListBox : public TQWidget { TQ_OBJECT public: enum KMultiFormListBoxType {MultiVisible, Windowed}; /** @param factory A factory used to generate the instances of KMultiFormListBoxEntry class which is repeated in the KMultiFormListBox @param parent A pointer to the parent widget **/ KMultiFormListBox(KMultiFormListBoxFactory *factory, KMultiFormListBoxType tp=Windowed, TQWidget *parent = 0, bool showUpDownButtons = true, bool showHelpButton = true, TQString addButtonText = i18n("Add"), const char *name = 0); /** @return The elements in the KMultiFormListBox. **/ KMultiFormListBoxEntryList elements(); const KMultiFormListBoxEntryList elements() const; /** TODO. **/ void append(KMultiFormListBoxEntry *); /** write data out to stream */ void toStream( TQDataStream& stream ) const; /** reads data in from stream */ void fromStream( TQDataStream& stream ); public slots: /** Adds an empty element to the KMultiFormListBox. This slot is only required for the @ref MultiVisible face. It should be connected to a button which lets the user know that he may get more elements in this KMultiFormListBox by pressing it. The button should be labeled ``More Entries'' or something similar. **/ void addElement(); // Adds an empty element to the KMultiFormListBox /** Changes the face of the KMultiFormListBox. @param face The new face of the KMultiFormListBox **/ void slotChangeFace(KMultiFormListBoxType newFace); private: KMultiFormListBoxShower *theWidget; KMultiFormListBoxFactory *_factory; }; #endif /* tdemultiformlistbox */