KUtils
KSettings Namespace Reference
A collection of classes to create configuration dialogs that work over component boundaries. More...
Classes | |
class | ComponentsDialog |
Dialog for selecting which plugins should be active for an application. More... | |
class | Dialog |
Generic configuration dialog that even works over component boundaries. More... | |
class | Dispatcher |
Dispatch change notifications from the KCMs to the program. More... | |
class | PluginPage |
Convenience KCModule for creating a plugins config page. More... | |
Variables | |
static KStaticDeleter< Dispatcher > | ksd_kpd |
Detailed Description
A collection of classes to create configuration dialogs that work over component boundaries.
How to use KSettings::Dialog in your application.
1. Open the dialog from your app
All you need to do is instanciate KSettings::Dialog and show() it. I recommend the following:
create the 'Configure MyApp' StdAction like this:
KStdAction::preferences( this, SLOT( showConfigDialog() ), actionCollection );
and the slot looks like this:
if( m_dlg == 0 ) m_dlg = new KSettings::Dialog( this ); m_dlg->show();
Of course you need to have the 'KSettingsDialog * m_dlg' member var and initialize it to 0 in the ctor.
If your application uses KParts that don't set 'X-KDE-ParentApp=<the instance name of your application>' then you need to use the second ctor of KSettings::Dialog:
m_dlg = new KSettings::Dialog( QStringList::split( ';', "component1;component2" ) );
The KSettings::Dialog object will be destructed automatically by the QObject mechanisms.
2. Create pages for your dialog
Every page is a KCM. This is what you need for creating a page:
class MyAppConfig : public KCModule { Q_OBJECT public: MyAppConfig( QWidget *parent, const char *name = 0, const QStringList &args = QStringList() ); ~MyAppConfig(); void load(); void save(); void defaults(); }
and in the cpp file:
typedef KGenericFactory<MyAppConfig, QWidget> MyAppConfigFactory; K_EXPORT_COMPONENT_FACTORY( kcm_myappconfig, MyAppConfigFactory( "kcm_myappconfig" ) ); MyAppConfig::MyAppConfig( QWidget *parent, const char *, const QStringList &args ) : KCModule( MyAppConfigFactory::instance(), parent, args ) { // create the pages GUI load(); } // implementations for the other methods
For the KConfig object you can either use KGlobal::config() (I don't recommend it) or KSimpleConfig( "myapprc" ). I added a method to KSettings::Dispatcher that gives you the KConfig object for every registered instance name: KSettings::Dispatcher::configForInstanceName
3. The .desktop file for the page
The .desktop file holds all the information for the dialog to find the page and insert it at the right place (with the right icon, name and comment).
An example file:
[Desktop Entry] Encoding=UTF-8 Icon=myapp Type=Service ServiceTypes=KCModule X-KDE-ModuleType=Library X-KDE-Library=myappconfig X-KDE-FactoryName=MyAppConfigFactory X-KDE-ParentApp=myapp X-KDE-ParentComponents=myapp X-KDE-Weight=10 Name=General Comment=General configuration of my app
Some explanation for those keys:
- You just keep 'Encoding', 'Type', 'ServiceTypes' and 'X-KDE-ModuleType' like in the example. For very special needs you might add another ServiceType to the list...
- Icon is the icon that will be used in the listview/iconview for your page.
- X-KDE-Library is the name of the library where the page is in. The library always needs to be prefixed with kcm_ but you don't write the prefix in the desktop file. For more docu on this look for the KCModule docu.
- X-KDE-FactoryName is either the name of the Factory you used in the KGenericFactory call or the suffix of the create_ function that you created. Again for more info look for the KCModule docu.
- X-KDE-ParentApp is the name of the application this config page belongs to. It is used by the first two KSettings::Dialog constructors. The Dialog will use all modules that set X-KDE-ParentApp to KGlobal::instance()->instanceName(). It should be pretty easy to find out what name that is: look at the first argument to the KAboutData ctor.
- X-KDE-ParentComponents is a list of the components (plugin/KPart/whatever) this config page belongs to. Normally there is only one component. It is used for two things:
- If you use KSettings::Dispatcher the dispatcher will notify all components in this list after the save() method of your KCM has been called. The components then can reload the configuration and apply the changes the user did to the config.
- If your component is used by another application (that is not = X-KDE-ParentApp) then it may add the name of the component to the ctor of KSettings::Dialog and the dialog will automatically include all config pages that have the components name in their ParentComponents list.
- X-KDE-Weight sets the order for the modules to be inserted into the dialog. The higher the number (heavier) the lower the module will appear in the list. (the default value is 100)
- Name is the string that is shown in the listview/iconview right below the icon.
- Comment is the string that is shown on top of the config page for a short description what you can do on this page.
4. The .setdlg file for hierarchical (TreeList) page layouts
If your config dialog should show a tree of pages in the config dialog you need to define that hierarchy with a .setdlg file.
The file should be installed in apps/<appname>/<appname>.setdlg. If third party plugins need to merge in they will install their file to apps/<appname>/ksettingsdialog/<pluginname>.setdlg.
A .setdlg file contains one or more blocks like the following:
[id] Name= Comment= Icon= Weight= Parent=
- The group name (id) is the name you use in the .desktop file of the page: If your page's .desktop file says "X-KDE-CfgDlgHierarchy=id" then it will be inserted as a child of this entry.
Name:
The name of the section. It will appear in the listview.Comment:
A description of what the modules in this section are. It will appear in the place where the KCMs are placed when the user clicks on the item in the listview.Icon:
An icon for the item.Weight:
Defines the position in the listview. See X-KDE-Weight above.Parent:
If this group should be a child of another group write the parent's group id here.
5. The Pluginselector
There are two ways to use the KPluginSelector widget. One is to use the class directly and the second to use KSettings::PluginPage as baseclass for a config page that shows the KPluginSelector widget.
I'll cover the second usage here and the calls to addPlugins are just the same for the first.
To create a plugin page you need the following code:
typedef KGenericFactory<MyAppPluginConfig, QWidget> MyAppPluginConfigFactory; K_EXPORT_COMPONENT_FACTORY( kcm_myapppluginconfig, MyAppPluginConfigFactory( "kcm_myapppluginconfig" ) ); MyAppPluginConfig( QWidget * parent, const char *, const QStringList & args ) : PluginPage( MyAppPluginConfigFactory::instance(), parent, args ) { pluginSelector()->addPlugins( ... ); pluginSelector()->addPlugins( ... ); . . . }
pluginSelector() returns a pointer to the KPluginSelector widget of the page. There are three addPlugins methods available, two for adding KParts plugins and one for the rest.
6. The .desktop files of plugin config pages
this is the entry for the Makefile.am:
myappconfigpagedir = $(kde_servicesdir)/<appname> myappconfigpage_DATA = myappconfigpage.desktop
And this is what the .desktop file looks like:
[Desktop Entry] Encoding=UTF-8 Type=Service Icon=<iconname> ServiceTypes=KPluginInfo Name=MyPlugin Comment=My plugin is cool and does foo and bar. X-KDE-PluginInfo-Name=myplugin X-KDE-PluginInfo-Author=<your name> X-KDE-PluginInfo-Email=<your email> X-KDE-PluginInfo-Website=http://www.myplugin.org/ X-KDE-PluginInfo-Category=CoolPlugins X-KDE-PluginInfo-Version=0.1 X-KDE-PluginInfo-License=GPL X-KDE-PluginInfo-EnabledByDefault=true X-KDE-PluginInfo-Depends=myotherplugin X-KDE-CfgDlgHierarchy=GroupID
Explanation: mandatory entries:
- leave
Type
andEncoding
like in the example Name
Comment
X-KDE-PluginInfo-Name
is the "internal name" of the plugin.- You need to have
KPluginInfo
inServiceTypes
but of course you may have more entries in there.
optional entries:
Icon
is the icon used for your plugin (it's shown in the pluginselector if you set one).X-KDE-PluginInfo-Author
andX-KDE-PluginInfo-Email
is some information about the author of the plugin.X-KDE-PluginInfo-Website
is the address for a webpage for this plugin.X-KDE-PluginInfo-Category
is used if your application has different categories of plugins.X-KDE-PluginInfo-Version
is the version of this plugin.X-KDE-PluginInfo-License
is the license of this plugin.X-KDE-PluginInfo-EnabledByDefault
tells the program whether the plugin should be enabled on first startup or not.X-KDE-PluginInfo-Depends
can be used to tell the application that you need to have myotherplugin enabled for your plugin to work.X-KDE-CfgDlgHierarchy
is used if you use aKSettings::Dialog::ConfigurableInline
KSettings::Dialog to put the plugin checkbox into the group with the GroupID you set here.
If you have questions contact Matthias Kretz <kretz@kde.org>.
Variable Documentation
KStaticDeleter<Dispatcher> KSettings::ksd_kpd [static] |
Definition at line 36 of file dispatcher.cpp.