summaryrefslogtreecommitdiffstats
path: root/kdecore/kconfigdialogmanager.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdecore/kconfigdialogmanager.h')
-rw-r--r--kdecore/kconfigdialogmanager.h236
1 files changed, 0 insertions, 236 deletions
diff --git a/kdecore/kconfigdialogmanager.h b/kdecore/kconfigdialogmanager.h
deleted file mode 100644
index d0b385b60..000000000
--- a/kdecore/kconfigdialogmanager.h
+++ /dev/null
@@ -1,236 +0,0 @@
-/*
- * This file is part of the KDE libraries
- * Copyright (C) 2003 Benjamin C Meyer (ben+kdelibs at meyerhome dot net)
- * Copyright (C) 2003 Waldo Bastian <bastian@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 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 KCONFIGDIALOGMANAGER_H
-#define KCONFIGDIALOGMANAGER_H
-
-#include <tqobject.h>
-#include <tqptrlist.h>
-#include "kdelibs_export.h"
-
-class KConfigSkeleton;
-class KConfigSkeletonItem;
-class TQWidget;
-class TQSqlPropertyMap;
-
-/**
- * @short Provides a means of automatically retrieving,
- * saving and resetting KConfigSkeleton based settings in a dialog.
- *
- * The KConfigDialogManager class provides a means of automatically
- * retrieving, saving and resetting basic settings.
- * It also can emit signals when settings have been changed
- * (settings were saved) or modified (the user changes a checkbox
- * from on to off).
- *
- * The names of the widgets to be managed have to correspond to the names of the
- * configuration entries in the KConfigSkeleton object plus an additional
- * "kcfg_" prefix. For example a widget named "kcfg_MyOption" would be
- * associated to the configuration entry "MyOption".
- *
- * KConfigDialogManager uses the TQSqlPropertyMap class to determine if it can do
- * anything to a widget. Note that KConfigDialogManager doesn't require a
- * database, it simply uses the functionality that is built into the
- * TQSqlPropertyMap class. New widgets can be added to the map using
- * TQSqlPropertyMap::installDefaultMap(). Note that you can't just add any
- * class. The class must have a matching Q_PROPERTY(...) macro defined.
- *
- * For example (note that KColorButton is already added and it doesn't need to
- * manually added):
- *
- * kcolorbutton.h defines the following property:
- * \code
- * Q_PROPERTY( TQColor color READ color WRITE setColor )
- * \endcode
- *
- * To add KColorButton the following code would be inserted in the main.
- *
- * \code
- * kapp->installKDEPropertyMap();
- * TQSqlPropertyMap *map = TQSqlPropertyMap::defaultMap();
- * map->insert("KColorButton", "color");
- * \endcode
- *
- * If you add a new widget to the TQSqlPropertyMap and wish to be notified when
- * it is modified you should add its signal using addWidgetChangedSignal().
-
- * @since 3.2
- * @author Benjamin C Meyer <ben+kdelibs at meyerhome dot net>
- * @author Waldo Bastian <bastian@kde.org>
- */
-class KDECORE_EXPORT KConfigDialogManager : public TQObject {
-
-Q_OBJECT
-
-signals:
- /**
- * One or more of the settings have been saved (such as when the user
- * clicks on the Apply button). This is only emitted by updateSettings()
- * whenever one or more setting were changed and consequently saved.
- */
- void settingsChanged();
-
- /**
- * TODO: Verify
- * One or more of the settings have been changed.
- * @param widget - The widget group (pass in via addWidget()) that
- * contains the one or more modified setting.
- * @see settingsChanged()
- */
- void settingsChanged( TQWidget *widget );
-
- /**
- * If retrieveSettings() was told to track changes then if
- * any known setting was changed this signal will be emitted. Note
- * that a settings can be modified several times and might go back to the
- * original saved state. hasChanged() will tell you if anything has
- * actually changed from the saved values.
- */
- void widgetModified();
-
-
-public:
-
- /**
- * Constructor.
- * @param parent Dialog widget to manage
- * @param conf Object that contains settings
- * @param name - Object name.
- */
- KConfigDialogManager(TQWidget *parent, KConfigSkeleton *conf, const char *name=0);
-
- /**
- * Destructor.
- */
- ~KConfigDialogManager();
-
- /**
- * Add additional widgets to manage
- * @param widget Additional widget to manage, inlcuding all its children
- */
- void addWidget(TQWidget *widget);
-
- /**
- * Returns whether the current state of the known widgets are
- * different from the state in the config object.
- */
- bool hasChanged();
-
- /**
- * Returns whether the current state of the known widgets are
- * the same as the default state in the config object.
- */
- bool isDefault();
-
-public slots:
- /**
- * Traverse the specified widgets, saving the settings of all known
- * widgets in the settings object.
- *
- * Example use: User clicks Ok or Apply button in a configure dialog.
- */
- void updateSettings();
-
- /**
- * Traverse the specified widgets, sets the state of all known
- * widgets according to the state in the settings object.
- *
- * Example use: Initialisation of dialog.
- * Example use: User clicks Reset button in a configure dialog.
- */
- void updateWidgets();
-
- /**
- * Traverse the specified widgets, sets the state of all known
- * widgets according to the default state in the settings object.
- *
- * Example use: User clicks Defaults button in a configure dialog.
- */
- void updateWidgetsDefault();
-
-protected:
-
- /**
- * @param trackChanges - If any changes by the widgets should be tracked
- * set true. This causes the emitting the modified() signal when
- * something changes.
- * TODO: @return bool - True if any setting was changed from the default.
- */
- void init(bool trackChanges);
-
- /**
- * Recursive function that finds all known children.
- * Goes through the children of widget and if any are known and not being
- * ignored, stores them in currentGroup. Also checks if the widget
- * should be disabled because it is set immutable.
- * @param widget - Parent of the children to look at.
- * @param trackChanges - If true then tracks any changes to the children of
- * widget that are known.
- * @return bool - If a widget was set to something other then its default.
- */
- bool parseChildren(const TQWidget *widget, bool trackChanges);
-
- /**
- * Set a property
- */
- void setProperty(TQWidget *w, const TQVariant &v);
-
- /**
- * Retrieve a property
- */
- TQVariant property(TQWidget *w);
-
- /**
- * Setup secondary widget properties
- */
- void setupWidget(TQWidget *widget, KConfigSkeletonItem *item);
-
-protected:
- /**
- * KConfigSkeleton object used to store settings
- */
- KConfigSkeleton *m_conf;
-
- /**
- * Dialog being managed
- */
- TQWidget *m_dialog;
-
- /**
- * Pointer to the property map for easy access.
- */
- TQSqlPropertyMap *propertyMap;
-
- /**
- * Map of the classes and the signals that they emit when changed.
- */
- TQMap<TQString, TQCString> changedMap;
-
-private:
- class Private;
- /**
- * KConfigDialogManager Private class.
- */
- Private *d;
-
-};
-
-#endif // KCONFIGDIALOGMANAGER_H
-