/* Copyright (c) 2008 Volker Krause This library 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 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 AKONADI_COLLECTIONPROPERTIESDIALOG_H #define AKONADI_COLLECTIONPROPERTIESDIALOG_H #include "akonadi_export.h" #include #include namespace Akonadi { class Collection; /** * @short A generic and extensible dialog for collection properties. * * This dialog allows you to show or modify the properties of a collection. * * @code * * Akonadi::Collection collection = ... * * CollectionPropertiesDialog dlg( collection, this ); * dlg.exec(); * * @endcode * * It can be extended by custom pages, which contains gui elements for custom * properties. * * @see Akonadi::CollectionPropertiesPage * * @author Volker Krause */ class AKONADI_EXPORT CollectionPropertiesDialog : public KDialog { Q_OBJECT public: /** * Enumerates the registered default pages which can be displayed. * * @since 4.7 */ enum DefaultPage { GeneralPage, //!< General properties page CachePage //!< Cache properties page }; /** * Creates a new collection properties dialog. * * @param collection The collection which properties should be shown. * @param parent The parent widget. */ explicit CollectionPropertiesDialog(const Collection &collection, QWidget *parent = 0); /** * Creates a new collection properties dialog. * * This constructor allows to specify the subset of registered pages that will * be shown as well as their order. The pages have to set an objectName in their * constructor to make it work. If an empty list is passed, all registered pages * will be loaded. Use defaultPageObjectName() to fetch the object name for a * registered default page. * * @param collection The collection which properties should be shown. * @param pages The object names of the pages that shall be loaded. * @param parent The parent widget. * * @since 4.6 */ CollectionPropertiesDialog(const Collection &collection, const QStringList &pages, QWidget *parent = 0); /** * Destroys the collection properties dialog. * * @note Never call manually, the dialog is deleted automatically once all changes * are written back to the Akonadi storage. */ ~CollectionPropertiesDialog(); /** * Register custom pages for the collection properties dialog. * * @param factory The properties page factory that provides the custom page. * * @see Akonadi::CollectionPropertiesPageFactory */ static void registerPage(CollectionPropertiesPageFactory *factory); /** * Sets whether to @p use default page or not. * * @since 4.4 * @param use mode of default page's usage */ static void useDefaultPage(bool use); /** * Returns the object name of one of the dialog's registered default pages. * The object name may be used in the QStringList constructor parameter to * specify which default pages should be shown. * * @param page the desired page * @return the page's object name * * @since 4.7 */ static QString defaultPageObjectName(DefaultPage page); /** * Sets the page to be shown in the tab widget. * * @param name The object name of the page that is to be shown. * * @since 4.10 */ void setCurrentPage(const QString &name); private: //@cond PRIVATE class Private; Private *const d; Q_PRIVATE_SLOT(d, void save()) Q_PRIVATE_SLOT(d, void saveResult(KJob *)) //@endcond }; } #endif