summaryrefslogtreecommitdiffstats
path: root/kcontrol/konq/behaviour.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit4aed2c8219774f5d797760606b8489a92ddc5163 (patch)
tree3f8c130f7d269626bf6a9447407ef6c35954426a /kcontrol/konq/behaviour.cpp
downloadtdebase-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.cpp285
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"