From 114a878c64ce6f8223cfd22d76a20eb16d177e5e Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdevelop@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- parts/uimode/uichooser_widget.cpp | 153 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 153 insertions(+) create mode 100644 parts/uimode/uichooser_widget.cpp (limited to 'parts/uimode/uichooser_widget.cpp') diff --git a/parts/uimode/uichooser_widget.cpp b/parts/uimode/uichooser_widget.cpp new file mode 100644 index 00000000..5e6ffbf7 --- /dev/null +++ b/parts/uimode/uichooser_widget.cpp @@ -0,0 +1,153 @@ +/*************************************************************************** + uichooser_widget.cpp - ? + ------------------- + begin : ? + copyright : (C) 2003 by the KDevelop team + email : team@kdevelop.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include +#include +#include +#include +#include +#include +#include + +#include "uichooser_part.h" +#include "kdevmainwindow.h" +#include "uichooser_widget.h" + +UIChooserWidget::UIChooserWidget( UIChooserPart * part, QWidget *parent, const char *name) + : UIChooser(parent, name) + ,m_part(part), _lastMode(0L) +{ + load(); +} + +void UIChooserWidget::load() +{ + KConfig *config = kapp->config(); + config->setGroup("UI"); + + int mdistyle = config->readNumEntry( "MDIStyle", 1 ); + switch( mdistyle ) + { + case 0: + IconsOnly->setChecked( true ); + break; + case 1: + TextOnly->setChecked( true ); + break; + case 3: + TextAndIcons->setChecked( true ); + break; + default: + TextOnly->setChecked( true ); + } + + int tabVisibility = config->readNumEntry( "TabWidgetVisibility", _AlwaysShowTabs ); + switch( tabVisibility ) + { + case _AlwaysShowTabs: + AlwaysShowTabs->setChecked( true ); + break; + case _NeverShowTabs: + NeverShowTabs->setChecked( true ); + break; + } + + bool CloseOnHover = config->readBoolEntry( "CloseOnHover", false ); + + if ( CloseOnHover ) + { + DoCloseOnHover->setChecked( true ); + } + else + { + DoNotCloseOnHover->setChecked( true ); + } + OpenNewTabAfterCurrent->setChecked(config->readBoolEntry( "OpenNewTabAfterCurrent", false )); + ShowTabIcons->setChecked(config->readBoolEntry( "ShowTabIcons", true )); + ShowCloseTabsButton->setChecked(config->readBoolEntry( "ShowCloseTabsButton", true )); + + maybeEnableCloseOnHover(false); +} + + +void UIChooserWidget::save() +{ + KConfig *config = kapp->config(); + config->setGroup("UI"); + + if ( AlwaysShowTabs->isChecked() ) + { + config->writeEntry( "TabWidgetVisibility", _AlwaysShowTabs ); + } + else if ( NeverShowTabs->isChecked() ) + { + config->writeEntry( "TabWidgetVisibility", _NeverShowTabs ); + } + + if ( DoNotCloseOnHover->isChecked() ) + { + config->writeEntry( "CloseOnHover", false ); + } + else if ( DoCloseOnHover->isChecked() ) + { + config->writeEntry( "CloseOnHover", true ); + } + + // using magic numbers for now.. where are these values defined?? + if ( IconsOnly->isChecked() ) + { + config->writeEntry( "MDIStyle", 0 ); + } + else if ( TextAndIcons->isChecked() ) + { + config->writeEntry( "MDIStyle", 3 ); + } + else // TextOnly + { + config->writeEntry( "MDIStyle", 1 ); + } + config->writeEntry("OpenNewTabAfterCurrent", OpenNewTabAfterCurrent->isChecked()); + config->writeEntry("ShowTabIcons", ShowTabIcons->isChecked()); + config->writeEntry("ShowCloseTabsButton", ShowCloseTabsButton->isChecked()); + + config->sync(); +} + + +void UIChooserWidget::accept() +{ + save(); +} + +void UIChooserWidget::maybeEnableCloseOnHover( bool ) +{ + if ( !NeverShowTabs->isChecked() && !ShowTabIcons->isChecked()) + { + HoverCloseGroup->setEnabled(false); + } else if ( NeverShowTabs->isChecked() ) + { + HoverCloseGroup->setEnabled( false ); + TabbedBrowsingGroup->setEnabled( false ); + } else + { + HoverCloseGroup->setEnabled( true ); + TabbedBrowsingGroup->setEnabled( true ); + } +} + + +#include "uichooser_widget.moc" -- cgit v1.2.1