diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | 4aed2c8219774f5d797760606b8489a92ddc5163 (patch) | |
tree | 3f8c130f7d269626bf6a9447407ef6c35954426a /kcontrol/konq/behaviour.cpp | |
download | tdebase-4aed2c8219774f5d797760606b8489a92ddc5163.tar.gz tdebase-4aed2c8219774f5d797760606b8489a92ddc5163.zip |
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/kdebase@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kcontrol/konq/behaviour.cpp')
-rw-r--r-- | kcontrol/konq/behaviour.cpp | 285 |
1 files changed, 285 insertions, 0 deletions
diff --git a/kcontrol/konq/behaviour.cpp b/kcontrol/konq/behaviour.cpp new file mode 100644 index 000000000..4bb782eeb --- /dev/null +++ b/kcontrol/konq/behaviour.cpp @@ -0,0 +1,285 @@ +/** + * Copyright (c) 2001 David Faure <david@mandrakesoft.com> + * + * 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. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ + +// Behaviour options for konqueror + +#include <qcheckbox.h> +#include <qlabel.h> +#include <qlayout.h> +#include <qvbox.h> +#include <qvbuttongroup.h> +#include <qvgroupbox.h> +#include <qwhatsthis.h> + +#include <dcopclient.h> + +#include <kapplication.h> +#include <kconfig.h> +#include <kio/uiserver_stub.h> +#include <klocale.h> +#include <konq_defaults.h> +#include <kstandarddirs.h> +#include <kurlrequester.h> + +#include "behaviour.h" + +KBehaviourOptions::KBehaviourOptions(KConfig *config, QString group, QWidget *parent, const char * ) + : KCModule(parent, "kcmkonq"), g_pConfig(config), groupname(group) +{ + QLabel * label; + + setQuickHelp( i18n("<h1>Konqueror Behavior</h1> You can configure how Konqueror behaves as a file manager here.")); + + QVBoxLayout *lay = new QVBoxLayout( this, 0, KDialog::spacingHint() ); + + QVGroupBox * miscGb = new QVGroupBox(i18n("Misc Options"), this); + lay->addWidget( miscGb ); + QHBox *hbox = new QHBox(miscGb); + QVBox *vbox = new QVBox(hbox); + + // ---- + + winPixmap = new QLabel(hbox); + winPixmap->setFrameStyle( QFrame::StyledPanel | QFrame::Sunken ); + winPixmap->setPixmap(QPixmap(locate("data", + "kcontrol/pics/onlyone.png"))); + winPixmap->setFixedSize( winPixmap->sizeHint() ); + + + // ---- + + cbNewWin = new QCheckBox(i18n("Open folders in separate &windows"), vbox); + QWhatsThis::add( cbNewWin, i18n("If this option is checked, Konqueror will open a new window when " + "you open a folder, rather than showing that folder's contents in the current window.")); + connect(cbNewWin, SIGNAL(clicked()), this, SLOT(changed())); + connect(cbNewWin, SIGNAL(toggled(bool)), SLOT(updateWinPixmap(bool))); + + // ---- + + cbListProgress = new QCheckBox( i18n( "&Show network operations in a single window" ), vbox ); + connect(cbListProgress, SIGNAL(clicked()), this, SLOT(changed())); + + QWhatsThis::add( cbListProgress, i18n("Checking this option will group the" + " progress information for all network file transfers into a single window" + " with a list. When the option is not checked, all transfers appear in a" + " separate window.") ); + + + // -- + + cbShowTips = new QCheckBox( i18n( "Show file &tips" ), vbox ); + connect(cbShowTips, SIGNAL(clicked()), this, SLOT(changed())); + + QWhatsThis::add( cbShowTips, i18n("Here you can control if, when moving the mouse over a file, you want to see a " + "small popup window with additional information about that file")); + + connect(cbShowTips, SIGNAL(toggled(bool)), SLOT(slotShowTips(bool))); +/* + //connect(cbShowTips, SIGNAL(toggled(bool)), sbToolTip, SLOT(setEnabled(bool))); + //connect(cbShowTips, SIGNAL(toggled(bool)), fileTips, SLOT(setEnabled(bool))); + fileTips->setBuddy(sbToolTip); + QString tipstr = i18n("If you move the mouse over a file, you usually see a small popup window that shows some " + "additional information about that file. Here, you can set how many items of information " + "are displayed"); + QWhatsThis::add( fileTips, tipstr ); + QWhatsThis::add( sbToolTip, tipstr ); +*/ + + QHBox *hboxpreview = new QHBox(vbox); + QWidget* spacer = new QWidget( hboxpreview ); + spacer->setMinimumSize( 20, 0 ); + spacer->setSizePolicy( QSizePolicy::Fixed, QSizePolicy::Minimum ); + + cbShowPreviewsInTips = new QCheckBox( i18n( "Show &previews in file tips" ), hboxpreview ); + connect(cbShowPreviewsInTips, SIGNAL(clicked()), this, SLOT(changed())); + + QWhatsThis::add( cbShowPreviewsInTips, i18n("Here you can control if you want the " + "popup window to contain a larger preview for the file, when moving the mouse over it.")); + + cbRenameDirectlyIcon = new QCheckBox(i18n("Rename icons in&line"), vbox); + QWhatsThis::add(cbRenameDirectlyIcon, i18n("Checking this option will allow files to be " + "renamed by clicking directly on the icon name. ")); + connect(cbRenameDirectlyIcon, SIGNAL(clicked()), this, SLOT(changed())); + + QHBoxLayout *hlay = new QHBoxLayout( lay ); + + label = new QLabel(i18n("Home &URL:"), this); + hlay->addWidget( label ); + + homeURL = new KURLRequester(this); + homeURL->setMode(KFile::Directory); + homeURL->setCaption(i18n("Select Home Folder")); + hlay->addWidget( homeURL ); + connect(homeURL, SIGNAL(textChanged(const QString &)), this, SLOT(changed())); + label->setBuddy(homeURL); + + QString homestr = i18n("This is the URL (e.g. a folder or a web page) where " + "Konqueror will jump to when the \"Home\" button is pressed. " + "This is usually your home folder, symbolized by a 'tilde' (~)."); + QWhatsThis::add( label, homestr ); + QWhatsThis::add( homeURL, homestr ); + + lay->addItem(new QSpacerItem(0,20,QSizePolicy::Fixed,QSizePolicy::Fixed)); + + cbShowDeleteCommand = new QCheckBox( i18n( "Show 'Delete' context me&nu entries which bypass the trashcan" ), this ); + lay->addWidget( cbShowDeleteCommand ); + connect(cbShowDeleteCommand, SIGNAL(clicked()), this, SLOT(changed())); + + QWhatsThis::add( cbShowDeleteCommand, i18n("Check this if you want 'Delete' menu commands to be displayed " + "on the desktop and in the file manager's context menus. " + "You can always delete files by holding the Shift key " + "while calling 'Move to Trash'.")); + + QButtonGroup *bg = new QVButtonGroup( i18n("Ask Confirmation For"), this ); + bg->layout()->setSpacing( KDialog::spacingHint() ); + QWhatsThis::add( bg, i18n("This option tells Konqueror whether to ask" + " for a confirmation when you \"delete\" a file." + " <ul><li><em>Move To Trash:</em> moves the file to your trash folder," + " from where it can be recovered very easily.</li>" + " <li><em>Delete:</em> simply deletes the file.</li>" + " </li></ul>") ); + + connect(bg, SIGNAL( clicked( int ) ), SLOT( changed() )); + + cbMoveToTrash = new QCheckBox( i18n("&Move to trash"), bg ); + + cbDelete = new QCheckBox( i18n("D&elete"), bg ); + + lay->addWidget(bg); + + lay->addStretch(); + + load(); +} + +KBehaviourOptions::~KBehaviourOptions() +{ +} + +void KBehaviourOptions::slotShowTips(bool b) +{ +// sbToolTip->setEnabled( b ); + cbShowPreviewsInTips->setEnabled( b ); +// fileTips->setEnabled( b ); + +} + +void KBehaviourOptions::load() +{ + load( false ); +} + +void KBehaviourOptions::load( bool useDefaults ) +{ + g_pConfig->setReadDefaults( useDefaults ); + + g_pConfig->setGroup( groupname ); + cbNewWin->setChecked( g_pConfig->readBoolEntry("AlwaysNewWin", false) ); + updateWinPixmap(cbNewWin->isChecked()); + + homeURL->setURL(g_pConfig->readPathEntry("HomeURL", "~")); + + bool stips = g_pConfig->readBoolEntry( "ShowFileTips", true ); + cbShowTips->setChecked( stips ); + slotShowTips( stips ); + + bool showPreviewsIntips = g_pConfig->readBoolEntry( "ShowPreviewsInFileTips", true ); + cbShowPreviewsInTips->setChecked( showPreviewsIntips ); + + cbRenameDirectlyIcon->setChecked( g_pConfig->readBoolEntry("RenameIconDirectly", DEFAULT_RENAMEICONDIRECTLY ) ); + + KConfig globalconfig("kdeglobals", true, false); + globalconfig.setGroup( "KDE" ); + cbShowDeleteCommand->setChecked( globalconfig.readBoolEntry("ShowDeleteCommand", false) ); + +// if (!stips) sbToolTip->setEnabled( false ); + if (!stips) cbShowPreviewsInTips->setEnabled( false ); + +// sbToolTip->setValue( g_pConfig->readNumEntry( "FileTipItems", 6 ) ); + + KConfig config("uiserverrc"); + config.setGroup( "UIServer" ); + + cbListProgress->setChecked( config.readBoolEntry( "ShowList", false ) ); + + g_pConfig->setGroup( "Trash" ); + cbMoveToTrash->setChecked( g_pConfig->readBoolEntry("ConfirmTrash", DEFAULT_CONFIRMTRASH) ); + cbDelete->setChecked( g_pConfig->readBoolEntry("ConfirmDelete", DEFAULT_CONFIRMDELETE) ); + + emit changed( useDefaults ); +} + +void KBehaviourOptions::defaults() +{ + load( true ); +} + +void KBehaviourOptions::save() +{ + g_pConfig->setGroup( groupname ); + + g_pConfig->writeEntry( "AlwaysNewWin", cbNewWin->isChecked() ); + g_pConfig->writePathEntry( "HomeURL", homeURL->url().isEmpty()? QString("~") : homeURL->url() ); + + g_pConfig->writeEntry( "ShowFileTips", cbShowTips->isChecked() ); + g_pConfig->writeEntry( "ShowPreviewsInFileTips", cbShowPreviewsInTips->isChecked() ); +// g_pConfig->writeEntry( "FileTipsItems", sbToolTip->value() ); + + g_pConfig->writeEntry( "RenameIconDirectly", cbRenameDirectlyIcon->isChecked()); + + KConfig globalconfig("kdeglobals", false, false); + globalconfig.setGroup( "KDE" ); + globalconfig.writeEntry( "ShowDeleteCommand", cbShowDeleteCommand->isChecked()); + globalconfig.sync(); + + g_pConfig->setGroup( "Trash" ); + g_pConfig->writeEntry( "ConfirmTrash", cbMoveToTrash->isChecked()); + g_pConfig->writeEntry( "ConfirmDelete", cbDelete->isChecked()); + g_pConfig->sync(); + + // UIServer setting + KConfig config("uiserverrc"); + config.setGroup( "UIServer" ); + config.writeEntry( "ShowList", cbListProgress->isChecked() ); + config.sync(); + // Tell the running server + if ( kapp->dcopClient()->isApplicationRegistered( "kio_uiserver" ) ) + { + UIServer_stub uiserver( "kio_uiserver", "UIServer" ); + uiserver.setListMode( cbListProgress->isChecked() ); + } + + // Send signal to konqueror + QByteArray data; + if ( !kapp->dcopClient()->isAttached() ) + kapp->dcopClient()->attach(); + kapp->dcopClient()->send( "konqueror*", "KonquerorIface", "reparseConfiguration()", data ); + kapp->dcopClient()->send( "kdesktop", "KDesktopIface", "configure()", data ); +} + +void KBehaviourOptions::updateWinPixmap(bool b) +{ + if (b) + winPixmap->setPixmap(QPixmap(locate("data", + "kcontrol/pics/overlapping.png"))); + else + winPixmap->setPixmap(QPixmap(locate("data", + "kcontrol/pics/onlyone.png"))); +} + +#include "behaviour.moc" |