/*************************************************************************** * Copyright (C) 2003 by S�bastien Lao�t * * slaout@linux62.org * * * * 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. * * * * 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 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 NEWBASKETDIALOG_H #define NEWBASKETDIALOG_H #include <kdialogbase.h> #include <kiconview.h> #include <tqmap.h> class KIconButton; class TQLineEdit; class TQDragObject; class TQListViewItem; class Basket; class KColorCombo2; /** The class KIconView allow to drag items. We don't want to, so we disable it. * This class also unselect the selected item when the user right click an empty space. We don't want to, so we reselect it if that happens. * @author S�bastien Lao�t */ class SingleSelectionKIconView : public KIconView { Q_OBJECT public: SingleSelectionKIconView(TQWidget *parent = 0, const char *name = 0, WFlags f = 0); TQDragObject* dragObject(); TQIconViewItem* selectedItem() { return m_lastSelected; } private slots: void slotSelectionChanged(TQIconViewItem *item); void slotSelectionChanged(); private: TQIconViewItem *m_lastSelected; }; /** Struct to store default properties of a new basket. * When the dialog shows up, the @p icon is used, as well as the @p backgroundColor. * A template is choosen depending on @p freeLayout and @p columnLayout. * If @p columnLayout is too high, the template with the more columns will be chosen instead. * If the user change the background color in the dialog, then @p backgroundImage and @p textColor will not be used! * @author S�bastien Lao�t */ struct NewBasketDefaultProperties { TQString icon; TQString backgroundImage; TQColor backgroundColor; TQColor textColor; bool freeLayout; int columnCount; NewBasketDefaultProperties(); }; /** The dialog to create a new basket from a template. * @author S�bastien Lao�t */ class NewBasketDialog : public KDialogBase { Q_OBJECT public: NewBasketDialog(Basket *parentBasket, const NewBasketDefaultProperties &defaultProperties, TQWidget *parent = 0); ~NewBasketDialog(); void polish(); protected slots: void slotOk(); void returnPressed(); void manageTemplates(); void nameChanged(const TQString &newName); private: int populateBasketsList(TQListViewItem *item, int indent, int index); NewBasketDefaultProperties m_defaultProperties; KIconButton *m_icon; TQLineEdit *m_name; KColorCombo2 *m_backgroundColor; KIconView *m_templates; TQComboBox *m_createIn; TQMap<int, Basket*> m_basketsMap; }; #endif // NEWBASKETDIALOG_H