diff options
Diffstat (limited to 'src/komposepreferences.cpp')
-rw-r--r-- | src/komposepreferences.cpp | 411 |
1 files changed, 411 insertions, 0 deletions
diff --git a/src/komposepreferences.cpp b/src/komposepreferences.cpp new file mode 100644 index 0000000..45dd7f0 --- /dev/null +++ b/src/komposepreferences.cpp @@ -0,0 +1,411 @@ +// +// C++ Implementation: komposepreferences +// +// Description: +// +// +// Author: Hans Oischinger <hans.oischinger@kde-mail.net>, (C) 2004 +// +// Copyright: See COPYING file that comes with this distribution +// +// +#include "komposepreferences.h" + +#include "komposesettings.h" +#include "komposeglobal.h" + +#include <qlayout.h> +#include <qcheckbox.h> +#include <qlabel.h> +#include <kapplication.h> +#include <qwhatsthis.h> +#include <qtooltip.h> +#include <qspinbox.h> +#include <qgroupbox.h> +#include <qbuttongroup.h> +#include <qhbox.h> +#include <qslider.h> +#include <qpushbutton.h> +#include <qgrid.h> +#include <qvgroupbox.h> +#include <qradiobutton.h> + +#include <kiconloader.h> +#include <kcolorbutton.h> +#include <kfontdialog.h> + +KomposePreferences::KomposePreferences() + : KDialogBase(IconList, i18n("Komposé Preferences"), Ok|Apply|Cancel, Ok) +{ + // FIXME: this is the biggest constructor I've EVER written! + // How about Qt Designer?! + m_hasXinerama = QDesktopWidget().numScreens() > 1; + + QFrame *page1 = addPage( i18n("Behavior"), QString::null, DesktopIcon("winprops", KIcon::SizeMedium) ); + QFrame *page2 = addPage( i18n("Appearance"), QString::null, DesktopIcon("appearance", KIcon::SizeMedium) ); + QFrame *page3 = addPage( i18n("Layouts"), QString::null, DesktopIcon("window_list", KIcon::SizeMedium) ); + + QVBoxLayout *page1Layout = new QVBoxLayout( page1, 0, KDialog::spacingHint() ); + + defaultViewBtnGroup = new QButtonGroup( 2, Horizontal, i18n("Default Layout"), page1 ); + defaultViewBtnGroup->setExclusive( true ); + QString defaultViewBtnGroupHelp = i18n("Determines which view should be started by default (e.g. when you click on the systray icon)."); + QWhatsThis::add( defaultViewBtnGroup, defaultViewBtnGroupHelp ); + QToolTip::add( defaultViewBtnGroup, defaultViewBtnGroupHelp ); + defaultViewWorld = new QRadioButton(i18n("Ungrouped"), defaultViewBtnGroup ); + QString defaultViewWorldHelp = i18n("Fullscreen layout that shows all windows in no specific order"); + QWhatsThis::add( defaultViewWorld, defaultViewWorldHelp ); + QToolTip::add( defaultViewWorld, defaultViewWorldHelp ); + defaultViewVirtualDesks = new QRadioButton(i18n("Grouped by virtual desktops"), defaultViewBtnGroup ); + QString defaultViewVirtualDesksHelp = i18n("Fullscreen layout that shows a representation of your virtual desktops\n and places the windows inside."); + QWhatsThis::add( defaultViewVirtualDesks, defaultViewVirtualDesksHelp ); + QToolTip::add( defaultViewVirtualDesks, defaultViewVirtualDesksHelp ); + defaultViewCurrentDesk = new QRadioButton(i18n("Current virtual desktop"), defaultViewBtnGroup ); + QString defaultViewCurrentDeskHelp = i18n("Fullscreen layout that shows the windows of the desktop you're currently working on."); + QWhatsThis::add( defaultViewCurrentDesk, defaultViewCurrentDeskHelp ); + QToolTip::add( defaultViewCurrentDesk, defaultViewCurrentDeskHelp ); + page1Layout->addWidget(defaultViewBtnGroup); + + if (m_hasXinerama) + { + QGroupBox *xineramaGroupBox = new QGroupBox( 2, Vertical, i18n("Xinerama"), page1 ); + + QDesktopWidget deskwidget; + m_viewScreenAll = new QCheckBox(i18n("Use the whole desktop for Komposé"), xineramaGroupBox); + + QHBox *hLayXineramaGrabDelay = new QHBox(xineramaGroupBox); + QLabel *xineramaLabel = new QLabel(i18n("Use screen:"), hLayXineramaGrabDelay); + m_viewScreen = new QSpinBox(0, deskwidget.numScreens()-1, 1, hLayXineramaGrabDelay); + connect( m_viewScreenAll, SIGNAL(toggled(bool)), m_viewScreen, SLOT(setDisabled(bool)) ); + xineramaLabel->setBuddy(m_viewScreen); + QString xineramaHelp = i18n("Specify the screen where Komposé should appear." ); + QWhatsThis::add( m_viewScreen, xineramaHelp ); + QToolTip::add( m_viewScreen, xineramaHelp ); + QWhatsThis::add( xineramaLabel, xineramaHelp ); + QToolTip::add( xineramaLabel, xineramaHelp ); + + page1Layout->addWidget(xineramaGroupBox); + } + +#ifdef COMPOSITE + QGroupBox *screenshotsGroupBox = new QGroupBox( 4, Vertical, i18n("Screenshots"), page1 ); + + useComposite = new QCheckBox(i18n("Use XComposite if available"), screenshotsGroupBox); + QString useCompositeHelp = i18n("Making use of the Composite extension of newer X Servers makes the grabbing of screenshots obsolete.\nThe contents of all windows are drawn in back buffers that will be accessed by Komposé\nNote that the Composite implementation of even modern graphic card drivers is still very slow and may make your system pretty unusable."); + QWhatsThis::add( useComposite, useCompositeHelp ); + QToolTip::add( useComposite, useCompositeHelp ); + connect( useComposite, SIGNAL(toggled(bool)), SLOT(setUseCompositeToggled(bool)) ); +#else + QGroupBox *screenshotsGroupBox = new QGroupBox( 3, Vertical, i18n("Screenshots"), page1 ); +#endif + + passiveScreenshots = new QCheckBox(i18n("Passive screenshots"), screenshotsGroupBox); + QString passiveScreenshotsHelp = i18n("Create a screenshot whenever you raise or active a window.\nWhen selected the amount the annoying popup-effect before every Komposé activation will be minimized to nearly zero.\nThe drawback is that the screenshots are not so recent and may not display the actual content."); + QWhatsThis::add( passiveScreenshots, passiveScreenshotsHelp ); + QToolTip::add( passiveScreenshots, passiveScreenshotsHelp ); + + QHBox *hLayScreenshotGrabDelay = new QHBox(screenshotsGroupBox); + QLabel *screenshotGrabDelayLabel = new QLabel(i18n("Delay between screenshots (ms):"), hLayScreenshotGrabDelay); + screenshotGrabDelay = new QSpinBox(0, 999, 10, hLayScreenshotGrabDelay); + screenshotGrabDelayLabel->setBuddy(screenshotGrabDelay); + QString screenshotGrabDelayHelp = i18n("Specifies the time to wait between the activation of a window and the screenshot taking.\nIncrease it when your windows need more time to draw themselves after activation.\nValues below 300ms are not recommended, but may work in some cases." ); + QWhatsThis::add( screenshotGrabDelay, screenshotGrabDelayHelp ); + QToolTip::add( screenshotGrabDelay, screenshotGrabDelayHelp ); + QWhatsThis::add( screenshotGrabDelayLabel, screenshotGrabDelayHelp ); + QToolTip::add( screenshotGrabDelayLabel, screenshotGrabDelayHelp ); + + cacheScaledPixmaps = new QCheckBox(i18n("Cache scaled Screenshots"), screenshotsGroupBox); + QString cacheScaledPixmapsHelp = i18n("This may avoid some scaling operations to be called repeatedly when Komposé has been displayed before and the screenshot's size didn't change.\nIt will however increase memory usage quite a bit."); + QWhatsThis::add( cacheScaledPixmaps, cacheScaledPixmapsHelp ); + QToolTip::add( cacheScaledPixmaps, cacheScaledPixmapsHelp ); + + page1Layout->addWidget(screenshotsGroupBox); + + + // Autolock + QGroupBox* autoLockGroup = new QGroupBox( 0, Qt::Horizontal, i18n("Autoactivate when mouse moves into"), page1 ); + QGridLayout* autoLockLayout = new QGridLayout( autoLockGroup->layout(), 5, 2, KDialog::spacingHint() ); + m_topLeftCorner = new QCheckBox( i18n("Top-left corner"), autoLockGroup); + autoLockLayout->addWidget( m_topLeftCorner, 0, 0 ); + m_topRightCorner = new QCheckBox( i18n("Top-right corner"), autoLockGroup ); + autoLockLayout->addWidget( m_topRightCorner, 1, 0 ); + m_bottomLeftCorner = new QCheckBox( i18n("Bottom-left corner"), autoLockGroup ); + autoLockLayout->addWidget( m_bottomLeftCorner, 2, 0 ); + m_bottomRightCorner = new QCheckBox( i18n("Bottom-right corner"), autoLockGroup ); + autoLockLayout->addWidget( m_bottomRightCorner, 3, 0 ); + + m_topEdge = new QCheckBox( i18n("Top edge"), autoLockGroup); + autoLockLayout->addWidget( m_topEdge, 0, 1 ); + m_bottomEdge = new QCheckBox( i18n("Bottom edge"), autoLockGroup ); + autoLockLayout->addWidget( m_bottomEdge, 1, 1 ); + m_leftEdge = new QCheckBox( i18n("Left edge"), autoLockGroup ); + autoLockLayout->addWidget( m_leftEdge, 2, 1 ); + m_rightEdge = new QCheckBox( i18n("Right edge"), autoLockGroup ); + autoLockLayout->addWidget( m_rightEdge, 3, 1 ); + + QHBox *hLayAutoLockDelay = new QHBox(autoLockGroup); + QLabel *autoLockDelayLabel = new QLabel(i18n("Delay until activation (ms):"), hLayAutoLockDelay); + autoLockDelay = new QSpinBox(0, 5000, 10, hLayAutoLockDelay); + autoLockDelayLabel->setBuddy(autoLockDelay); + QString autoLockDelayHelp = i18n("Specifies the time in ms for which the mouse pointer must rest in the corner until auto-activation." ); + QWhatsThis::add( autoLockDelay, autoLockDelayHelp ); + QToolTip::add( autoLockDelay, autoLockDelayHelp ); + QWhatsThis::add( autoLockDelayLabel, autoLockDelayHelp ); + QToolTip::add( autoLockDelayLabel, autoLockDelayHelp ); + autoLockLayout->addMultiCellWidget( hLayAutoLockDelay, 4, 4, 0, 1 ); + + page1Layout->addWidget(autoLockGroup); + + page1Layout->insertStretch(-1); + + + + QVBoxLayout *page2Layout = new QVBoxLayout( page2, 0, KDialog::spacingHint() ); + + imageEffects = new QCheckBox(i18n("Enable image effects"), page2); + QString imageEffectsHelp = i18n("Lighten windows when the mouse moves over it or gray out minimized windows.\nDepending on your system specs this can be a bit slower." ); + QWhatsThis::add( imageEffects, imageEffectsHelp ); + QToolTip::add( imageEffects, imageEffectsHelp ); + page2Layout->addWidget(imageEffects); + + showDesktopNum = new QCheckBox(i18n("Show Desktop number on Systray icon"), page2); + QString showDesktopNumHelp = i18n("Displays the number of the currently active Desktop on the Komposé systray icon." ); + QWhatsThis::add( showDesktopNum, showDesktopNumHelp ); + QToolTip::add( showDesktopNum, showDesktopNumHelp ); + page2Layout->addWidget(showDesktopNum); + + QGroupBox *windowTitleGroupBox = new QGroupBox( 3, Vertical, i18n("Window Titles"), page2 ); + + QHBox *hBoxWindowTitles = new QHBox(windowTitleGroupBox); + showWindowTitles = new QCheckBox(i18n("Show window titles"), hBoxWindowTitles); + windowTitleFontBtn = new QPushButton(i18n("Select Font..."), hBoxWindowTitles); + QString showWindowTitlesHelp = i18n( "Display the name of every window in Komposé" ); + QWhatsThis::add( showWindowTitles, showWindowTitlesHelp ); + QToolTip::add( showWindowTitles, showWindowTitlesHelp ); + connect( showWindowTitles, SIGNAL(toggled(bool)), windowTitleFontBtn, SLOT(setEnabled(bool)) ); + connect( windowTitleFontBtn, SIGNAL(clicked()), this, SLOT(showWindowTitleFontDialog()) ); + + QGrid *gridWindowTitlesColor = new QGrid(2, windowTitleGroupBox); + // windowTitleFontColorLabel = new QLabel(windowTitleFontColor, i18n("Text color: "), gridWindowTitlesColor); // FIXME: How to link to a buddy that doesn't yet exist? + windowTitleFontColorLabel = new QLabel(i18n("Text color:"), gridWindowTitlesColor); + windowTitleFontColor = new KColorButton(Qt::black, gridWindowTitlesColor); + connect( showWindowTitles, SIGNAL(toggled(bool)), windowTitleFontColorLabel, SLOT(setEnabled(bool)) ); + connect( showWindowTitles, SIGNAL(toggled(bool)), windowTitleFontColor, SLOT(setEnabled(bool)) ); + showWindowTitleShadow = new QCheckBox(i18n("Shadow color:"), gridWindowTitlesColor); + windowTitleFontShadowColor = new KColorButton(Qt::lightGray, gridWindowTitlesColor); + connect( showWindowTitles, SIGNAL(toggled(bool)), showWindowTitleShadow, SLOT(setEnabled(bool)) ); + connect( showWindowTitles, SIGNAL(toggled(bool)), windowTitleFontShadowColor, SLOT(setEnabled(bool)) ); + connect( showWindowTitleShadow, SIGNAL(toggled(bool)), windowTitleFontShadowColor, SLOT(setEnabled(bool)) ); + + page2Layout->addWidget(windowTitleGroupBox); + + + + QGroupBox *iconGroupBox = new QGroupBox( 3, Vertical, i18n("Task Icons"), page2 ); + showIcons = new QCheckBox(i18n("Show icons"), iconGroupBox); + iconSize = new QSlider(0, 3, 1, 0, Qt::Horizontal, iconGroupBox); + iconSizeDescription = new QLabel( iconSize, "", iconGroupBox); + connect( iconSize, SIGNAL( sliderMoved(int) ), this, SLOT( updateIconSliderDesc(int) ) ); + connect( iconSize, SIGNAL( valueChanged(int) ), this, SLOT( updateIconSliderDesc(int) ) ); + connect( showIcons, SIGNAL( toggled(bool) ), iconSize, SLOT( setEnabled(bool) ) ); + connect( showIcons, SIGNAL( toggled(bool) ), iconSizeDescription, SLOT( setEnabled(bool) ) ); + page2Layout->addWidget(iconGroupBox); + + page2Layout->insertStretch(-1); + + + + QVBoxLayout *page3Layout = new QVBoxLayout( page3, 0, KDialog::spacingHint() ); + + QVGroupBox *virtDesksLayoutGroupBox = new QVGroupBox( i18n("Grouped by Virtual Desktops"), page3 ); + dynamicVirtDeskLayout = new QCheckBox(i18n("Layout empty virtual desktops minimized"), virtDesksLayoutGroupBox ); + QString dynamicVirtDeskLayoutHelp = i18n("Check this if you want empty virtual desktops to take less space on the screen.\nUncheck it if you want them to be arranged statically, each of the same size."); + QWhatsThis::add( dynamicVirtDeskLayout, dynamicVirtDeskLayoutHelp ); + QToolTip::add( dynamicVirtDeskLayout, dynamicVirtDeskLayoutHelp ); + + QGrid *desktopColorsGroupBox = new QGrid( 2, virtDesksLayoutGroupBox ); + desktopColorsGroupBox->setSpacing( 4 ); + desktopTitleFontColorLabel = new QLabel(i18n("Desktop frame color:"), desktopColorsGroupBox); + desktopTitleFontColor = new KColorButton(Qt::black, desktopColorsGroupBox); + desktopTitleFontHighlightColorLabel = new QLabel(i18n("Desktop frame highlight color:"), desktopColorsGroupBox); + desktopTitleFontHighlightColor = new KColorButton(Qt::black, desktopColorsGroupBox); + + page3Layout->addWidget(virtDesksLayoutGroupBox); + + desktopTitleFontBtn = new QPushButton(i18n("Select Desktop Names Font..."), virtDesksLayoutGroupBox); + connect( desktopTitleFontBtn, SIGNAL(clicked()), this, SLOT(showDesktopTitleFontDialog()) ); + + page3Layout->insertStretch(-1); + + + fillPages(); +} + + +KomposePreferences::~KomposePreferences() +{} + +void KomposePreferences::updateIconSliderDesc( int val ) +{ + switch( val ) + { + case 0: + iconSizeDescription->setText( i18n("16x16") ); + break; + case 1: + iconSizeDescription->setText( i18n("32x32") ); + break; + case 2: + iconSizeDescription->setText( i18n("64x64") ); + break; + case 3: + iconSizeDescription->setText( i18n("Don't scale, show as they are (preferably bigger)") ); + break; + } +} + +void KomposePreferences::showWindowTitleFontDialog() +{ + KFontDialog::getFont( *windowTitleFont ); + // if ( result == KFontDialog::Accepted ) +} + +void KomposePreferences::showDesktopTitleFontDialog() +{ + KFontDialog::getFont( *desktopTitleFont ); +} + +void KomposePreferences::fillPages() +{ + // Sync Settings to Preferences dialog + switch ( KomposeSettings::instance()->getDefaultView() ) + { + case KOMPOSEDISPLAY_VIRTUALDESKS: + defaultViewVirtualDesks->setChecked( true ); + break; + case KOMPOSEDISPLAY_WORLD: + defaultViewWorld->setChecked( true ); + break; + case KOMPOSEDISPLAY_CURRENTDESK: + defaultViewCurrentDesk->setChecked( true ); + break; + } + +#ifdef COMPOSITE + useComposite->setChecked( KomposeSettings::instance()->getUseComposite() ); +#endif + passiveScreenshots->setChecked( KomposeSettings::instance()->getPassiveScreenshots() ); + screenshotGrabDelay->setValue( KomposeSettings::instance()->getScreenshotGrabDelay() / 1000000 ); + cacheScaledPixmaps->setChecked( KomposeSettings::instance()->getCacheScaledPixmaps() ); + dynamicVirtDeskLayout->setChecked( KomposeSettings::instance()->getDynamicVirtDeskLayout() ); + + imageEffects->setChecked( KomposeSettings::instance()->getImageEffects() ); + showDesktopNum->setChecked( KomposeSettings::instance()->getShowDesktopNum() ); + + showWindowTitles->setChecked( KomposeSettings::instance()->getShowWindowTitles() ); + windowTitleFont = new QFont(KomposeSettings::instance()->getWindowTitleFont()); + windowTitleFontColor->setColor( KomposeSettings::instance()->getWindowTitleFontColor() ); + windowTitleFontShadowColor->setColor( KomposeSettings::instance()->getWindowTitleFontShadowColor() ); + showWindowTitleShadow->setChecked( KomposeSettings::instance()->getShowWindowTitleShadow() ); + // Disable dependant widgets + windowTitleFontBtn->setEnabled( KomposeSettings::instance()->getShowWindowTitles() ); + windowTitleFontColorLabel->setEnabled( KomposeSettings::instance()->getShowWindowTitles() ); + windowTitleFontColor->setEnabled( KomposeSettings::instance()->getShowWindowTitles() ); + showWindowTitleShadow->setEnabled( KomposeSettings::instance()->getShowWindowTitles() ); + windowTitleFontShadowColor->setEnabled( KomposeSettings::instance()->getShowWindowTitles() || KomposeSettings::instance()->getShowWindowTitleShadow() ); + + desktopTitleFont = new QFont(KomposeSettings::instance()->getDesktopTitleFont()); + desktopTitleFontColor->setColor( KomposeSettings::instance()->getDesktopTitleFontColor() ); + desktopTitleFontHighlightColor->setColor( KomposeSettings::instance()->getDesktopTitleFontHighlightColor() ); + + showIcons->setChecked( KomposeSettings::instance()->getShowIcons() ); + iconSize->setValue( KomposeSettings::instance()->getIconSize() ); + iconSize->setEnabled( showIcons->isChecked() ); + iconSizeDescription->setEnabled( showIcons->isChecked() ); + updateIconSliderDesc( iconSize->value() ); + + m_topLeftCorner->setChecked( KomposeSettings::instance()->getActivateOnTopLeftCorner() ); + m_bottomLeftCorner->setChecked( KomposeSettings::instance()->getActivateOnBottomLeftCorner() ); + m_topRightCorner->setChecked( KomposeSettings::instance()->getActivateOnTopRightCorner() ); + m_bottomRightCorner->setChecked( KomposeSettings::instance()->getActivateOnBottomRightCorner() ); + + m_topEdge->setChecked( KomposeSettings::instance()->getActivateOnTopEdge() ); + m_bottomEdge->setChecked( KomposeSettings::instance()->getActivateOnBottomEdge() ); + m_rightEdge->setChecked( KomposeSettings::instance()->getActivateOnRightEdge() ); + m_leftEdge->setChecked( KomposeSettings::instance()->getActivateOnLeftEdge() ); + autoLockDelay->setValue( KomposeSettings::instance()->getAutoLockDelay() ); + + if (m_hasXinerama) + { + m_viewScreenAll->setChecked( KomposeSettings::instance()->getViewScreen() == -1 ); + if (KomposeSettings::instance()->getViewScreen() >= 0 ) + m_viewScreen->setValue( KomposeSettings::instance()->getViewScreen() ); + m_viewScreen->setDisabled( m_viewScreenAll->isChecked() ); + } +} + + + + +void KomposePreferences::slotApply() +{ + KomposeSettings::instance()->setDefaultView( defaultViewBtnGroup->selectedId() ); + +#ifdef COMPOSITE + KomposeSettings::instance()->setUseComposite( useComposite->isChecked() ); +#endif + + KomposeSettings::instance()->setPassiveScreenshots( passiveScreenshots->isChecked() ); + KomposeSettings::instance()->setScreenshotGrabDelay( screenshotGrabDelay->value() * 1000000 ); + KomposeSettings::instance()->setCacheScaledPixmaps( cacheScaledPixmaps->isChecked() ); + KomposeSettings::instance()->setDynamicVirtDeskLayout( dynamicVirtDeskLayout->isChecked() ); + KomposeSettings::instance()->setImageEffects( imageEffects->isChecked() ); + KomposeSettings::instance()->setShowDesktopNum( showDesktopNum->isChecked() ); + + KomposeSettings::instance()->setShowWindowTitles( showWindowTitles->isChecked() ); + KomposeSettings::instance()->setWindowTitleFont( *windowTitleFont ); + KomposeSettings::instance()->setWindowTitleFontColor( windowTitleFontColor->color() ); + KomposeSettings::instance()->setWindowTitleFontShadowColor( windowTitleFontShadowColor->color() ); + KomposeSettings::instance()->setShowWindowTitleShadow( showWindowTitleShadow->isChecked() ); + + KomposeSettings::instance()->setDesktopTitleFont( *desktopTitleFont ); + KomposeSettings::instance()->setDesktopTitleFontColor( desktopTitleFontColor->color() ); + KomposeSettings::instance()->setDesktopTitleFontHighlightColor( desktopTitleFontHighlightColor->color() ); + + KomposeSettings::instance()->setShowIcons( showIcons->isChecked() ); + KomposeSettings::instance()->setIconSize( iconSize->value() ); + + KomposeSettings::instance()->setActivateOnTopLeftCorner( m_topLeftCorner->isChecked() ); + KomposeSettings::instance()->setActivateOnTopRighCorner( m_topRightCorner->isChecked() ); + KomposeSettings::instance()->setActivateOnBottomLeftCorner( m_bottomLeftCorner->isChecked() ); + KomposeSettings::instance()->setActivateOnBottomRightCorner( m_bottomRightCorner->isChecked() ); + + KomposeSettings::instance()->setActivateOnTopEdge( m_topEdge->isChecked() ); + KomposeSettings::instance()->setActivateOnRightEdge( m_rightEdge->isChecked() ); + KomposeSettings::instance()->setActivateOnBottomEdge( m_bottomEdge->isChecked() ); + KomposeSettings::instance()->setActivateOnLeftEdge( m_leftEdge->isChecked() ); + KomposeSettings::instance()->setAutoLockDelay( autoLockDelay->value() ); + + if (m_hasXinerama) + { + int viewScreen = m_viewScreen->value(); + if ( m_viewScreenAll->isChecked() ) + viewScreen = -1; + KomposeSettings::instance()->setViewScreen( viewScreen ); + } + + KomposeSettings::instance()->writeConfig(); + + KDialogBase::slotApply(); +} + +void KomposePreferences::slotOk() +{ + slotApply(); + KDialogBase::slotOk(); +} + +void KomposePreferences::setUseCompositeToggled( bool ) +{} + +#include "komposepreferences.moc" |