author | ulf69 <ulf69> | 2004-08-06 20:29:00 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-08-06 20:29:00 (UTC) |
commit | 38d84409bcca83516eb816461c8b79b4cf6cbf57 (patch) (unidiff) | |
tree | f7cc928c007ed6f4bca43d7474343d78bd0f4eab /microkde/kdeui | |
parent | 40ac88770c32ae78e194096e758ef3818d2fb434 (diff) | |
download | kdepimpi-38d84409bcca83516eb816461c8b79b4cf6cbf57.zip kdepimpi-38d84409bcca83516eb816461c8b79b4cf6cbf57.tar.gz kdepimpi-38d84409bcca83516eb816461c8b79b4cf6cbf57.tar.bz2 |
expanded functionality of kcmultidialog to support other applications
-rw-r--r-- | microkde/kdeui/kcmodule.h | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/microkde/kdeui/kcmodule.h b/microkde/kdeui/kcmodule.h index 90a87c9..bc020bc 100644 --- a/microkde/kdeui/kcmodule.h +++ b/microkde/kdeui/kcmodule.h | |||
@@ -1,266 +1,267 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the KDE libraries | 2 | This file is part of the KDE libraries |
3 | 3 | ||
4 | Copyright (c) 1999 Matthias Hoelzer-Kluepfel <hoelzer@kde.org> | 4 | Copyright (c) 1999 Matthias Hoelzer-Kluepfel <hoelzer@kde.org> |
5 | 5 | ||
6 | This library is free software; you can redistribute it and/or | 6 | This library is free software; you can redistribute it and/or |
7 | modify it under the terms of the GNU Library General Public | 7 | modify it under the terms of the GNU Library General Public |
8 | License as published by the Free Software Foundation; either | 8 | License as published by the Free Software Foundation; either |
9 | version 2 of the License, or (at your option) any later version. | 9 | version 2 of the License, or (at your option) any later version. |
10 | 10 | ||
11 | This library is distributed in the hope that it will be useful, | 11 | This library is distributed in the hope that it will be useful, |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 | Library General Public License for more details. | 14 | Library General Public License for more details. |
15 | 15 | ||
16 | You should have received a copy of the GNU Library General Public License | 16 | You should have received a copy of the GNU Library General Public License |
17 | along with this library; see the file COPYING.LIB. If not, write to | 17 | along with this library; see the file COPYING.LIB. If not, write to |
18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
19 | Boston, MA 02111-1307, USA. | 19 | Boston, MA 02111-1307, USA. |
20 | 20 | ||
21 | */ | 21 | */ |
22 | #ifndef __KCMODULE_H__ | 22 | #ifndef __KCMODULE_H__ |
23 | #define __KCMODULE_H__ | 23 | #define __KCMODULE_H__ |
24 | 24 | ||
25 | #include <qwidget.h> | 25 | #include <qwidget.h> |
26 | #include <qstringlist.h> | 26 | #include <qstringlist.h> |
27 | //USclass KAboutData; | 27 | //USclass KAboutData; |
28 | class KCModulePrivate; | 28 | class KCModulePrivate; |
29 | class KPrefs; | ||
29 | //US class KInstance; | 30 | //US class KInstance; |
30 | 31 | ||
31 | /** | 32 | /** |
32 | * The base class for control center modules. | 33 | * The base class for control center modules. |
33 | * | 34 | * |
34 | * Starting from KDE 2.0, control center modules are realized as shared | 35 | * Starting from KDE 2.0, control center modules are realized as shared |
35 | * libraries that are loaded into the control center at runtime. | 36 | * libraries that are loaded into the control center at runtime. |
36 | * | 37 | * |
37 | * The module in principle is a simple widget displaying the | 38 | * The module in principle is a simple widget displaying the |
38 | * item to be changed. The module has a very small interface. | 39 | * item to be changed. The module has a very small interface. |
39 | * | 40 | * |
40 | * All the necessary glue logic and the GUI bells and whistles | 41 | * All the necessary glue logic and the GUI bells and whistles |
41 | * are provided by the control center and must not concern | 42 | * are provided by the control center and must not concern |
42 | * the module author. | 43 | * the module author. |
43 | * | 44 | * |
44 | * To write a config module, you have to create a library | 45 | * To write a config module, you have to create a library |
45 | * that contains at one factory function like this: | 46 | * that contains at one factory function like this: |
46 | * | 47 | * |
47 | * <pre> | 48 | * <pre> |
48 | * #include <kgenericfactory.h> | 49 | * #include <kgenericfactory.h> |
49 | * | 50 | * |
50 | * typedef KGenericFactory<YourKCModule, QWidget> YourKCModuleFactory; | 51 | * typedef KGenericFactory<YourKCModule, QWidget> YourKCModuleFactory; |
51 | * K_EXPORT_COMPONENT_FACTORY( yourLibName, YourKCModuleFactory("name_of_the_po_file") ); | 52 | * K_EXPORT_COMPONENT_FACTORY( yourLibName, YourKCModuleFactory("name_of_the_po_file") ); |
52 | * </pre> | 53 | * </pre> |
53 | * | 54 | * |
54 | * The parameter "name_of_the_po_file" has to correspond with the messages target | 55 | * The parameter "name_of_the_po_file" has to correspond with the messages target |
55 | * that you created in your Makefile.am. | 56 | * that you created in your Makefile.am. |
56 | * | 57 | * |
57 | * See kdebase/kcontrol/HOWTO for more detailed documentation. | 58 | * See kdebase/kcontrol/HOWTO for more detailed documentation. |
58 | * | 59 | * |
59 | * @author Matthias Hoelzer-Kluepfel <hoelzer@kde.org> | 60 | * @author Matthias Hoelzer-Kluepfel <hoelzer@kde.org> |
60 | */ | 61 | */ |
61 | 62 | ||
62 | class KCModule : public QWidget | 63 | class KCModule : public QWidget |
63 | { | 64 | { |
64 | Q_OBJECT | 65 | Q_OBJECT |
65 | 66 | ||
66 | public: | 67 | public: |
67 | 68 | ||
68 | /** | 69 | /** |
69 | * An enumeration type for the buttons used by this module. | 70 | * An enumeration type for the buttons used by this module. |
70 | * You should only use Help, Default and Apply. The rest is obsolete. | 71 | * You should only use Help, Default and Apply. The rest is obsolete. |
71 | * | 72 | * |
72 | * @see KCModule::buttons @see KCModule::setButtons | 73 | * @see KCModule::buttons @see KCModule::setButtons |
73 | */ | 74 | */ |
74 | enum Button {Help=1, Default=2, Apply=16, | 75 | enum Button {Help=1, Default=2, Apply=16, |
75 | Reset=4, /* obsolete, do not use! */ | 76 | Reset=4, /* obsolete, do not use! */ |
76 | Cancel=8, /* obsolete, do not use! */ | 77 | Cancel=8, /* obsolete, do not use! */ |
77 | Ok=32, /* obsolete, do not use! */ | 78 | Ok=32, /* obsolete, do not use! */ |
78 | SysDefault=64 /* obsolete, do not use! */ }; | 79 | SysDefault=64 /* obsolete, do not use! */ }; |
79 | 80 | ||
80 | /* | 81 | /* |
81 | * Base class for all KControlModules. | 82 | * Base class for all KControlModules. |
82 | * Make sure you have a QStringList argument in your | 83 | * Make sure you have a QStringList argument in your |
83 | * implementation. | 84 | * implementation. |
84 | */ | 85 | */ |
85 | KCModule(QWidget *parent=0, const char *name=0, const QStringList &args=QStringList() ); | 86 | KCModule(QWidget *parent=0, const char *name=0, const QStringList &args=QStringList() ); |
86 | 87 | ||
87 | //US KCModule(KInstance *instance, QWidget *parent=0, const QStringList &args=QStringList() ); | 88 | //US KCModule(KInstance *instance, QWidget *parent=0, const QStringList &args=QStringList() ); |
88 | 89 | ||
89 | /* | 90 | /* |
90 | * Destroys the module. | 91 | * Destroys the module. |
91 | */ | 92 | */ |
92 | ~KCModule(); | 93 | ~KCModule(); |
93 | 94 | ||
94 | /** | 95 | /** |
95 | * Load the configuration data into the module. | 96 | * Load the configuration data into the module. |
96 | * | 97 | * |
97 | * The load method sets the user interface elements of the | 98 | * The load method sets the user interface elements of the |
98 | * module to reflect the current settings stored in the | 99 | * module to reflect the current settings stored in the |
99 | * configuration files. | 100 | * configuration files. |
100 | * | 101 | * |
101 | * This method is invoked whenever the module should read its configuration | 102 | * This method is invoked whenever the module should read its configuration |
102 | * (most of the times from a config file) and update the user interface. | 103 | * (most of the times from a config file) and update the user interface. |
103 | * This happens when the user clicks the "Reset" button in the control | 104 | * This happens when the user clicks the "Reset" button in the control |
104 | * center, to undo all of his changes and restore the currently valid | 105 | * center, to undo all of his changes and restore the currently valid |
105 | * settings. NOTE that this is not called after the modules is loaded, | 106 | * settings. NOTE that this is not called after the modules is loaded, |
106 | * so you probably want to call this method in the constructor. | 107 | * so you probably want to call this method in the constructor. |
107 | */ | 108 | */ |
108 | virtual void load() {}; | 109 | virtual void load(KPrefs* prefs) {}; |
109 | 110 | ||
110 | /** | 111 | /** |
111 | * Save the configuration data. | 112 | * Save the configuration data. |
112 | * | 113 | * |
113 | * The save method stores the config information as shown | 114 | * The save method stores the config information as shown |
114 | * in the user interface in the config files. | 115 | * in the user interface in the config files. |
115 | * | 116 | * |
116 | * If necessary, this method also updates the running system, | 117 | * If necessary, this method also updates the running system, |
117 | * e.g. by restarting applications. | 118 | * e.g. by restarting applications. |
118 | * | 119 | * |
119 | * save is called when the user clicks "Apply" or "Ok". | 120 | * save is called when the user clicks "Apply" or "Ok". |
120 | */ | 121 | */ |
121 | virtual void save() {}; | 122 | virtual void save(KPrefs* prefs) {}; |
122 | 123 | ||
123 | /** | 124 | /** |
124 | * Sets the configuration to sensible default values. | 125 | * Sets the configuration to sensible default values. |
125 | * | 126 | * |
126 | * This method is called when the user clicks the "Default" | 127 | * This method is called when the user clicks the "Default" |
127 | * button. It should set the display to useful values. | 128 | * button. It should set the display to useful values. |
128 | */ | 129 | */ |
129 | virtual void defaults() {}; | 130 | virtual void defaults(KPrefs* prefs) {}; |
130 | 131 | ||
131 | /** | 132 | /** |
132 | * Set the configuration to system default values. | 133 | * Set the configuration to system default values. |
133 | * | 134 | * |
134 | * This method is called when the user clicks the "System-Default" | 135 | * This method is called when the user clicks the "System-Default" |
135 | * button. It should set the display to the system default values. | 136 | * button. It should set the display to the system default values. |
136 | * | 137 | * |
137 | * NOTE: The default behaviour is to call defaults(). | 138 | * NOTE: The default behaviour is to call defaults(). |
138 | */ | 139 | */ |
139 | virtual void sysdefaults() { defaults(); }; | 140 | virtual void sysdefaults(KPrefs* prefs) { defaults(prefs); }; |
140 | 141 | ||
141 | /** | 142 | /** |
142 | * Return a quick-help text. | 143 | * Return a quick-help text. |
143 | * | 144 | * |
144 | * This method is called when the module is docked. | 145 | * This method is called when the module is docked. |
145 | * The quick-help text should contain a short description of the module and | 146 | * The quick-help text should contain a short description of the module and |
146 | * links to the module's help files. You can use QML formating tags in the text. | 147 | * links to the module's help files. You can use QML formating tags in the text. |
147 | * | 148 | * |
148 | * NOTE: Please make sure the quick help text gets translated (use i18n()). | 149 | * NOTE: Please make sure the quick help text gets translated (use i18n()). |
149 | */ | 150 | */ |
150 | virtual QString quickHelp() const { return QString::null; }; | 151 | virtual QString quickHelp() const { return QString::null; }; |
151 | 152 | ||
152 | /** | 153 | /** |
153 | * Returns a the KAboutData for this module | 154 | * Returns a the KAboutData for this module |
154 | * This is generally only called for the KBugReport. | 155 | * This is generally only called for the KBugReport. |
155 | * Override and have it return a pointer to a constant | 156 | * Override and have it return a pointer to a constant |
156 | */ | 157 | */ |
157 | //US virtual const KAboutData *aboutData() const { return 0; } | 158 | //US virtual const KAboutData *aboutData() const { return 0; } |
158 | 159 | ||
159 | /** | 160 | /** |
160 | * Indicate which buttons will be used. | 161 | * Indicate which buttons will be used. |
161 | * | 162 | * |
162 | * The return value is a value or'ed together from | 163 | * The return value is a value or'ed together from |
163 | * the Button enumeration type. | 164 | * the Button enumeration type. |
164 | * | 165 | * |
165 | * @see KCModule::setButtons | 166 | * @see KCModule::setButtons |
166 | */ | 167 | */ |
167 | int buttons() const { return _btn; }; | 168 | int buttons() const { return _btn; }; |
168 | 169 | ||
169 | /** | 170 | /** |
170 | * Get the RootOnly message for this module. | 171 | * Get the RootOnly message for this module. |
171 | * | 172 | * |
172 | * When the module must be run as root, or acts differently | 173 | * When the module must be run as root, or acts differently |
173 | * for root and a normal user, it is sometimes useful to | 174 | * for root and a normal user, it is sometimes useful to |
174 | * customize the message that appears at the top of the module | 175 | * customize the message that appears at the top of the module |
175 | * when used as a normal user. This function returns this | 176 | * when used as a normal user. This function returns this |
176 | * customized message. If none has been set, a default message | 177 | * customized message. If none has been set, a default message |
177 | * will be used. | 178 | * will be used. |
178 | * | 179 | * |
179 | * @see KCModule::setRootOnlyMsg | 180 | * @see KCModule::setRootOnlyMsg |
180 | */ | 181 | */ |
181 | QString rootOnlyMsg() const; | 182 | QString rootOnlyMsg() const; |
182 | 183 | ||
183 | /** | 184 | /** |
184 | * Tell if KControl should show a RootOnly message when run as | 185 | * Tell if KControl should show a RootOnly message when run as |
185 | * a normal user. | 186 | * a normal user. |
186 | * | 187 | * |
187 | * In some cases, the module don't want a RootOnly message to | 188 | * In some cases, the module don't want a RootOnly message to |
188 | * appear (for example if it has already one). This function | 189 | * appear (for example if it has already one). This function |
189 | * tells KControl if a RootOnly message should be shown | 190 | * tells KControl if a RootOnly message should be shown |
190 | * | 191 | * |
191 | * @see KCModule::setUseRootOnlyMsg | 192 | * @see KCModule::setUseRootOnlyMsg |
192 | */ | 193 | */ |
193 | bool useRootOnlyMsg() const; | 194 | bool useRootOnlyMsg() const; |
194 | 195 | ||
195 | 196 | ||
196 | //US KInstance *instance() const; | 197 | //US KInstance *instance() const; |
197 | 198 | ||
198 | signals: | 199 | signals: |
199 | 200 | ||
200 | /** | 201 | /** |
201 | * Indicate that the state of the modules contents has changed. | 202 | * Indicate that the state of the modules contents has changed. |
202 | * | 203 | * |
203 | * This signal is emitted whenever the state of the configuration | 204 | * This signal is emitted whenever the state of the configuration |
204 | * shown in the module changes. It allows the control center to | 205 | * shown in the module changes. It allows the control center to |
205 | * keep track of unsaved changes. | 206 | * keep track of unsaved changes. |
206 | * | 207 | * |
207 | */ | 208 | */ |
208 | void changed(bool state); | 209 | void changed(bool state); |
209 | 210 | ||
210 | /** | 211 | /** |
211 | * Indicate that the module's quickhelp has changed. | 212 | * Indicate that the module's quickhelp has changed. |
212 | * | 213 | * |
213 | * Emit this signal whenever the module's quickhelp changes. | 214 | * Emit this signal whenever the module's quickhelp changes. |
214 | * Modules implemented as tabbed dialogs might want to implement | 215 | * Modules implemented as tabbed dialogs might want to implement |
215 | * per-tab quickhelp for example. | 216 | * per-tab quickhelp for example. |
216 | * | 217 | * |
217 | */ | 218 | */ |
218 | void quickHelpChanged(); | 219 | void quickHelpChanged(); |
219 | 220 | ||
220 | protected: | 221 | protected: |
221 | 222 | ||
222 | /** | 223 | /** |
223 | * Sets the buttons to display. | 224 | * Sets the buttons to display. |
224 | * | 225 | * |
225 | * Help: shows a "Help" button. | 226 | * Help: shows a "Help" button. |
226 | * Default: shows a "Use Defaults" button | 227 | * Default: shows a "Use Defaults" button |
227 | * Apply: in kcontrol this will show an "Apply" and "Reset" button | 228 | * Apply: in kcontrol this will show an "Apply" and "Reset" button |
228 | * in kcmshell this will show an "Ok", "Apply" and "Cancel" button | 229 | * in kcmshell this will show an "Ok", "Apply" and "Cancel" button |
229 | * | 230 | * |
230 | * If Apply is not specified, kcmshell will show a "Close" button. | 231 | * If Apply is not specified, kcmshell will show a "Close" button. |
231 | * | 232 | * |
232 | * @see KCModule::buttons | 233 | * @see KCModule::buttons |
233 | */ | 234 | */ |
234 | void setButtons(int btn) { _btn = btn; }; | 235 | void setButtons(int btn) { _btn = btn; }; |
235 | 236 | ||
236 | /** | 237 | /** |
237 | * Sets the RootOnly message. | 238 | * Sets the RootOnly message. |
238 | * | 239 | * |
239 | * This message will be shown at the top of the module of the | 240 | * This message will be shown at the top of the module of the |
240 | * corresponding desktop file contains the line X-KDE-RootOnly=true. | 241 | * corresponding desktop file contains the line X-KDE-RootOnly=true. |
241 | * If no message is set, a default one will be used. | 242 | * If no message is set, a default one will be used. |
242 | * | 243 | * |
243 | * @see KCModule::rootOnlyMessage | 244 | * @see KCModule::rootOnlyMessage |
244 | */ | 245 | */ |
245 | void setRootOnlyMsg(const QString& msg); | 246 | void setRootOnlyMsg(const QString& msg); |
246 | 247 | ||
247 | /** | 248 | /** |
248 | * Change wether or not the RootOnly message should be shown. | 249 | * Change wether or not the RootOnly message should be shown. |
249 | * | 250 | * |
250 | * Following the value of @p on, the RootOnly message will be | 251 | * Following the value of @p on, the RootOnly message will be |
251 | * shown or not. | 252 | * shown or not. |
252 | * | 253 | * |
253 | * @see KCModule::useRootOnlyMsg | 254 | * @see KCModule::useRootOnlyMsg |
254 | */ | 255 | */ |
255 | void setUseRootOnlyMsg(bool on); | 256 | void setUseRootOnlyMsg(bool on); |
256 | 257 | ||
257 | private: | 258 | private: |
258 | 259 | ||
259 | int _btn; | 260 | int _btn; |
260 | protected: | 261 | protected: |
261 | virtual void virtual_hook( int id, void* data ); | 262 | virtual void virtual_hook( int id, void* data ); |
262 | private: | 263 | private: |
263 | KCModulePrivate *d; | 264 | KCModulePrivate *d; |
264 | }; | 265 | }; |
265 | 266 | ||
266 | #endif | 267 | #endif |