|
|
|
/**
|
|
|
|
* kmfolderdia.cpp
|
|
|
|
*
|
|
|
|
* Copyright (c) 1997-2004 KMail Developers
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* 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; version 2 of the License
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* In addition, as a special exception, the copyright holders give
|
|
|
|
* permission to link the code of this program with any edition of
|
|
|
|
* the TQt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
* of TQt that use the same license as TQt), and distribute linked
|
|
|
|
* combinations including the two. You must obey the GNU General
|
|
|
|
* Public License in all respects for all of the code used other than
|
|
|
|
* TQt. If you modify this file, you may extend this exception to
|
|
|
|
* your version of the file, but you are not obligated to do so. If
|
|
|
|
* you do not wish to do so, delete this exception statement from
|
|
|
|
* your version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include "acljobs.h"
|
|
|
|
#include "kmfolderdia.h"
|
|
|
|
#include "kmacctfolder.h"
|
|
|
|
#include "kmfoldermgr.h"
|
|
|
|
#include <libkpimidentities/identitycombo.h>
|
|
|
|
#include "kmfolderimap.h"
|
|
|
|
#include "kmfoldercachedimap.h"
|
|
|
|
#include "kmfolder.h"
|
|
|
|
#include "kmheaders.h"
|
|
|
|
#include "kmcommands.h"
|
|
|
|
#include "kmfoldertree.h"
|
|
|
|
#include "folderdiaacltab.h"
|
|
|
|
#include "folderdiaquotatab.h"
|
|
|
|
#include "kmailicalifaceimpl.h"
|
|
|
|
#include "globalsettings.h"
|
|
|
|
#include "folderrequester.h"
|
|
|
|
|
|
|
|
#include <keditlistbox.h>
|
|
|
|
#include <klineedit.h>
|
|
|
|
#include <tdelocale.h>
|
|
|
|
#include <knuminput.h>
|
|
|
|
#include <tdemessagebox.h>
|
|
|
|
#include <kicondialog.h>
|
|
|
|
#include <tdeconfig.h>
|
|
|
|
#include <kdebug.h>
|
|
|
|
#include <tdelistview.h>
|
|
|
|
#include <kpushbutton.h>
|
|
|
|
|
|
|
|
#include <tqcheckbox.h>
|
|
|
|
#include <tqlayout.h>
|
|
|
|
#include <tqgroupbox.h>
|
|
|
|
#include <tqregexp.h>
|
|
|
|
#include <tqlabel.h>
|
|
|
|
#include <tqvbox.h>
|
|
|
|
#include <tqtooltip.h>
|
|
|
|
#include <tqwhatsthis.h>
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <tqhbuttongroup.h>
|
|
|
|
#include <tqradiobutton.h>
|
|
|
|
#include <tqtextedit.h>
|
|
|
|
|
|
|
|
#include "templatesconfiguration.h"
|
|
|
|
#include "templatesconfiguration_kfg.h"
|
|
|
|
|
|
|
|
#include "kmfolderdia.moc"
|
|
|
|
|
|
|
|
using namespace KMail;
|
|
|
|
|
|
|
|
static TQString inCaseWeDecideToRenameTheTab( I18N_NOOP( "Permissions (ACL)" ) );
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
KMFolderDialog::KMFolderDialog(KMFolder *aFolder, KMFolderDir *aFolderDir,
|
|
|
|
KMFolderTree* aParent, const TQString& aCap,
|
|
|
|
const TQString& aName):
|
|
|
|
KDialogBase( KDialogBase::Tabbed,
|
|
|
|
aCap, KDialogBase::Ok|KDialogBase::Cancel,
|
|
|
|
KDialogBase::Ok, aParent, "KMFolderDialog", TRUE ),
|
|
|
|
mFolder( aFolder ),
|
|
|
|
mFolderDir( aFolderDir ),
|
|
|
|
mParentFolder( 0 ),
|
|
|
|
mIsNewFolder( aFolder == 0 ),
|
|
|
|
mFolderTree( aParent )
|
|
|
|
{
|
|
|
|
kdDebug(5006)<<"KMFolderDialog::KMFolderDialog()" << endl;
|
|
|
|
|
|
|
|
TQStringList folderNames;
|
|
|
|
TQValueList<TQGuardedPtr<KMFolder> > folders;
|
|
|
|
// get all folders but search and folders that can not have children
|
|
|
|
aParent->createFolderList(&folderNames, &folders, true, true,
|
|
|
|
true, false, true, false);
|
|
|
|
|
|
|
|
if( mFolderDir ) {
|
|
|
|
// search the parent folder of the folder
|
|
|
|
FolderList::ConstIterator it;
|
|
|
|
int i = 1;
|
|
|
|
for( it = folders.begin(); it != folders.end(); ++it, ++i ) {
|
|
|
|
if( (*it)->child() == mFolderDir ) {
|
|
|
|
mParentFolder = *it;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
FolderDiaTab* tab;
|
|
|
|
TQVBox* box;
|
|
|
|
|
|
|
|
box = addVBoxPage( i18n("General") );
|
|
|
|
tab = new FolderDiaGeneralTab( this, aName, box );
|
|
|
|
addTab( tab );
|
|
|
|
box = addVBoxPage( i18n("Templates") );
|
|
|
|
tab = new FolderDiaTemplatesTab( this, box );
|
|
|
|
addTab( tab );
|
|
|
|
|
|
|
|
KMFolder* refFolder = mFolder ? mFolder : mParentFolder;
|
|
|
|
KMFolderType folderType = refFolder ? refFolder->folderType() : KMFolderTypeUnknown;
|
|
|
|
bool noContent = mFolder ? mFolder->storage()->noContent() : false;
|
|
|
|
if ( !noContent && refFolder && ( folderType == KMFolderTypeImap || folderType == KMFolderTypeCachedImap ) ) {
|
|
|
|
if ( FolderDiaACLTab::supports( refFolder ) ) {
|
|
|
|
box = addVBoxPage( i18n("Access Control") );
|
|
|
|
tab = new FolderDiaACLTab( this, box );
|
|
|
|
addTab( tab );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( !noContent && refFolder && ( folderType == KMFolderTypeImap || folderType == KMFolderTypeCachedImap ) ) {
|
|
|
|
if ( FolderDiaQuotaTab::supports( refFolder ) ) {
|
|
|
|
box = addVBoxPage( i18n("Quota") );
|
|
|
|
tab = new FolderDiaQuotaTab( this, box );
|
|
|
|
addTab( tab );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for ( unsigned int i = 0 ; i < mTabs.count() ; ++i )
|
|
|
|
mTabs[i]->load();
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMFolderDialog::addTab( FolderDiaTab* tab )
|
|
|
|
{
|
|
|
|
connect( tab, TQT_SIGNAL( readyForAccept() ),
|
|
|
|
this, TQT_SLOT( slotReadyForAccept() ) );
|
|
|
|
connect( tab, TQT_SIGNAL( cancelAccept() ),
|
|
|
|
this, TQT_SLOT( slotCancelAccept() ) );
|
|
|
|
//connect( tab, TQT_SIGNAL(changed( bool )),
|
|
|
|
// this, TQT_SLOT(slotChanged( bool )) );
|
|
|
|
mTabs.append( tab );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Not used yet (no button), but ready to be used :)
|
|
|
|
void KMFolderDialog::slotApply()
|
|
|
|
{
|
|
|
|
if ( mFolder.isNull() && !mIsNewFolder ) { // deleted meanwhile?
|
|
|
|
KDialogBase::slotApply();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
for ( unsigned int i = 0 ; i < mTabs.count() ; ++i )
|
|
|
|
mTabs[i]->save();
|
|
|
|
if ( !mFolder.isNull() && mIsNewFolder ) // we just created it
|
|
|
|
mIsNewFolder = false; // so it's not new anymore :)
|
|
|
|
KDialogBase::slotApply();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Called when pressing Ok
|
|
|
|
// We want to apply the changes first (which is async), before closing the dialog,
|
|
|
|
// in case of errors during the upload.
|
|
|
|
void KMFolderDialog::slotOk()
|
|
|
|
{
|
|
|
|
if ( mFolder.isNull() && !mIsNewFolder ) { // deleted meanwhile?
|
|
|
|
KDialogBase::slotOk();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
mDelayedSavingTabs = 0; // number of tabs which need delayed saving
|
|
|
|
for ( unsigned int i = 0 ; i < mTabs.count() ; ++i ) {
|
|
|
|
FolderDiaTab::AccepStatus s = mTabs[i]->accept();
|
|
|
|
if ( s == FolderDiaTab::Canceled ) {
|
|
|
|
slotCancelAccept();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else if ( s == FolderDiaTab::Delayed )
|
|
|
|
++mDelayedSavingTabs;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mDelayedSavingTabs )
|
|
|
|
enableButtonOK( false );
|
|
|
|
else
|
|
|
|
KDialogBase::slotOk();
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMFolderDialog::slotReadyForAccept()
|
|
|
|
{
|
|
|
|
--mDelayedSavingTabs;
|
|
|
|
if ( mDelayedSavingTabs == 0 )
|
|
|
|
KDialogBase::slotOk();
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMFolderDialog::slotCancelAccept()
|
|
|
|
{
|
|
|
|
mDelayedSavingTabs = -1;
|
|
|
|
enableButtonOK( true );
|
|
|
|
// Don't try to create it twice
|
|
|
|
if ( !mFolder.isNull() )
|
|
|
|
mIsNewFolder = false;
|
|
|
|
|
|
|
|
// Other tabs might call slotReadyForAccept. -1 ensures that it won't close the dialog,
|
|
|
|
// but the OK button being enabled means that people might succeed in running
|
|
|
|
// the same job from save more than once.
|
|
|
|
// Solution: mAcceptCanceled = true instead of -1.
|
|
|
|
// Bah for now we only have one tab which can delay saving -> later.
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMFolderDialog::slotChanged( bool )
|
|
|
|
{
|
|
|
|
// TODO, support for 'changed', and Apply button.
|
|
|
|
// sample code for here: KCMultiDialog calls bool changed() on every TDECModuleProxy...
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMFolderDialog::setFolder( KMFolder* folder )
|
|
|
|
{
|
|
|
|
Q_ASSERT( mFolder.isNull() );
|
|
|
|
mFolder = folder;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void addLine( TQWidget *parent, TQVBoxLayout* layout )
|
|
|
|
{
|
|
|
|
TQFrame *line = new TQFrame( parent, "line" );
|
|
|
|
line->setGeometry( TQRect( 80, 150, 250, 20 ) );
|
|
|
|
line->setFrameShape( TQFrame::HLine );
|
|
|
|
line->setFrameShadow( TQFrame::Sunken );
|
|
|
|
line->setFrameShape( TQFrame::HLine );
|
|
|
|
layout->addWidget( line );
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
KMail::FolderDiaGeneralTab::FolderDiaGeneralTab( KMFolderDialog* dlg,
|
|
|
|
const TQString& aName,
|
|
|
|
TQWidget* parent, const char* name )
|
|
|
|
: FolderDiaTab( parent, name ),
|
|
|
|
mSharedSeenFlagsCheckBox( 0 ),
|
|
|
|
mDlg( dlg )
|
|
|
|
{
|
|
|
|
|
|
|
|
mIsLocalSystemFolder = mDlg->folder()->isSystemFolder();
|
|
|
|
mIsResourceFolder = kmkernel->iCalIface().isStandardResourceFolder( mDlg->folder() );
|
|
|
|
|
|
|
|
TQLabel *label;
|
|
|
|
|
|
|
|
TQVBoxLayout *topLayout = new TQVBoxLayout( this, 0, KDialog::spacingHint() );
|
|
|
|
|
|
|
|
// Musn't be able to edit details for a non-resource, system folder.
|
|
|
|
if ( !mIsLocalSystemFolder || mIsResourceFolder ) {
|
|
|
|
|
|
|
|
TQHBoxLayout *hl = new TQHBoxLayout( topLayout );
|
|
|
|
hl->setSpacing( KDialog::spacingHint() );
|
|
|
|
|
|
|
|
label = new TQLabel( i18n("&Name:"), this );
|
|
|
|
hl->addWidget( label );
|
|
|
|
|
|
|
|
// Determine if we are allowed to rename this folder. Only possible if the folder supports
|
|
|
|
// ACLs.
|
|
|
|
bool nameChangeAllowed = true;
|
|
|
|
if ( mDlg->folder() && mDlg->parentFolder() &&
|
|
|
|
mDlg->folder()->storage() && mDlg->parentFolder()->storage() &&
|
|
|
|
( mDlg->folder()->folderType() == KMFolderTypeCachedImap ||
|
|
|
|
mDlg->folder()->folderType() == KMFolderTypeImap ) ) {
|
|
|
|
ImapAccountBase *account = 0;
|
|
|
|
KMFolderCachedImap *dimap = 0;
|
|
|
|
KMFolderImap *imap = 0;
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeCachedImap ) {
|
|
|
|
dimap = static_cast<KMFolderCachedImap*>( mDlg->folder()->storage() );
|
|
|
|
account = dynamic_cast<ImapAccountBase*>( dimap->account() );
|
|
|
|
}
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeImap ) {
|
|
|
|
imap = static_cast<KMFolderImap*>( mDlg->folder()->storage() );
|
|
|
|
account = dynamic_cast<ImapAccountBase*>( imap->account() );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( account && account->hasACLSupport() ) {
|
|
|
|
int parentRights = -1;
|
|
|
|
int folderRights = -1;
|
|
|
|
bool parentRightsOk = false;
|
|
|
|
bool folderRightsOk = false;
|
|
|
|
if ( imap ) {
|
|
|
|
KMFolderImap * const parent = dynamic_cast<KMFolderImap*>( mDlg->parentFolder()->storage() );
|
|
|
|
folderRights = imap->userRights();
|
|
|
|
folderRightsOk = imap->userRightsState() == KMail::ACLJobs::Ok;
|
|
|
|
if ( parent ) {
|
|
|
|
parentRights = parent->userRights();
|
|
|
|
parentRightsOk = parent->userRightsState() == KMail::ACLJobs::Ok;
|
|
|
|
}
|
|
|
|
} else if ( dimap ) {
|
|
|
|
KMFolderCachedImap * const parent = dynamic_cast<KMFolderCachedImap*>( mDlg->parentFolder()->storage() );
|
|
|
|
folderRights = dimap->userRights();
|
|
|
|
folderRightsOk = dimap->userRightsState() == KMail::ACLJobs::Ok;
|
|
|
|
if ( parent ) {
|
|
|
|
parentRights = parent->userRights();
|
|
|
|
parentRightsOk = parent->userRightsState() == KMail::ACLJobs::Ok;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// For renaming, we need support for deleting the mailbox and then re-creating it.
|
|
|
|
if ( parentRightsOk && folderRightsOk &&
|
|
|
|
( !( parentRights & KMail::ACLJobs::Create ) || !( folderRights & KMail::ACLJobs::Delete ) ) ) {
|
|
|
|
nameChangeAllowed = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mNameEdit = new KLineEdit( this );
|
|
|
|
if( !mDlg->folder() && nameChangeAllowed )
|
|
|
|
mNameEdit->setFocus();
|
|
|
|
mNameEdit->setEnabled( nameChangeAllowed );
|
|
|
|
if ( !nameChangeAllowed ) {
|
|
|
|
TQToolTip::add( mNameEdit, i18n( "Not enough permissions to rename this folder.\n"
|
|
|
|
"The parent folder doesn't have write support.\n"
|
|
|
|
"A sync is needed after changing the permissions." ) );
|
|
|
|
}
|
|
|
|
mNameEdit->setText( mDlg->folder() ? mDlg->folder()->label() : i18n("unnamed") );
|
|
|
|
if (!aName.isEmpty())
|
|
|
|
mNameEdit->setText(aName);
|
|
|
|
mNameEdit->setMinimumSize(mNameEdit->sizeHint());
|
|
|
|
// prevent renaming of IMAP inbox
|
|
|
|
if ( mDlg->folder() && mDlg->folder()->isSystemFolder() ) {
|
|
|
|
TQString imapPath;
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeImap )
|
|
|
|
imapPath = static_cast<KMFolderImap*>( mDlg->folder()->storage() )->imapPath();
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeCachedImap )
|
|
|
|
imapPath = static_cast<KMFolderCachedImap*>( mDlg->folder()->storage() )->imapPath();
|
|
|
|
if ( imapPath == "/INBOX/" )
|
|
|
|
mNameEdit->setEnabled( false );
|
|
|
|
}
|
|
|
|
label->setBuddy( mNameEdit );
|
|
|
|
hl->addWidget( mNameEdit );
|
|
|
|
connect( mNameEdit, TQT_SIGNAL( textChanged( const TQString & ) ),
|
|
|
|
this, TQT_SLOT( slotFolderNameChanged( const TQString & ) ) );
|
|
|
|
|
|
|
|
|
|
|
|
//start icons group
|
|
|
|
TQVBoxLayout *ivl = new TQVBoxLayout( topLayout );
|
|
|
|
ivl->setSpacing( KDialog::spacingHint() );
|
|
|
|
|
|
|
|
TQHBoxLayout *ihl = new TQHBoxLayout( ivl );
|
|
|
|
mIconsCheckBox = new TQCheckBox( i18n("Use custom &icons"), this );
|
|
|
|
mIconsCheckBox->setChecked( false );
|
|
|
|
ihl->addWidget( mIconsCheckBox );
|
|
|
|
ihl->addStretch( 2 );
|
|
|
|
|
|
|
|
mNormalIconLabel = new TQLabel( i18n("&Normal:"), this );
|
|
|
|
mNormalIconLabel->setEnabled( false );
|
|
|
|
ihl->addWidget( mNormalIconLabel );
|
|
|
|
|
|
|
|
mNormalIconButton = new TDEIconButton( this );
|
|
|
|
mNormalIconLabel->setBuddy( mNormalIconButton );
|
|
|
|
mNormalIconButton->setIconType( TDEIcon::NoGroup , TDEIcon::Any, true );
|
|
|
|
mNormalIconButton->setIconSize( 16 );
|
|
|
|
mNormalIconButton->setStrictIconSize( true );
|
|
|
|
mNormalIconButton->setFixedSize( 28, 28 );
|
|
|
|
// Can't use iconset here
|
|
|
|
mNormalIconButton->setIcon( "folder" );
|
|
|
|
mNormalIconButton->setEnabled( false );
|
|
|
|
ihl->addWidget( mNormalIconButton );
|
|
|
|
|
|
|
|
mUnreadIconLabel = new TQLabel( i18n("&Unread:"), this );
|
|
|
|
mUnreadIconLabel->setEnabled( false );
|
|
|
|
ihl->addWidget( mUnreadIconLabel );
|
|
|
|
|
|
|
|
mUnreadIconButton = new TDEIconButton( this );
|
|
|
|
mUnreadIconLabel->setBuddy( mUnreadIconButton );
|
|
|
|
mUnreadIconButton->setIconType( TDEIcon::NoGroup, TDEIcon::Any, true );
|
|
|
|
mUnreadIconButton->setIconSize( 16 );
|
|
|
|
mUnreadIconButton->setStrictIconSize( true );
|
|
|
|
mUnreadIconButton->setFixedSize( 28, 28 );
|
|
|
|
// Can't use iconset here
|
|
|
|
mUnreadIconButton->setIcon( "folder_open" );
|
|
|
|
mUnreadIconButton->setEnabled( false );
|
|
|
|
ihl->addWidget( mUnreadIconButton );
|
|
|
|
ihl->addStretch( 1 );
|
|
|
|
|
|
|
|
connect( mIconsCheckBox, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mNormalIconButton, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
connect( mIconsCheckBox, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mUnreadIconButton, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
connect( mIconsCheckBox, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mNormalIconLabel, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
connect( mIconsCheckBox, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mUnreadIconLabel, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
|
|
|
|
connect( mNormalIconButton, TQT_SIGNAL(iconChanged(TQString)),
|
|
|
|
this, TQT_SLOT(slotChangeIcon(TQString)) );
|
|
|
|
|
|
|
|
//end icons group
|
|
|
|
addLine( this, topLayout);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// should new mail in this folder be ignored?
|
|
|
|
TQHBoxLayout *hbl = new TQHBoxLayout( topLayout );
|
|
|
|
hbl->setSpacing( KDialog::spacingHint() );
|
|
|
|
mNotifyOnNewMailCheckBox =
|
|
|
|
new TQCheckBox( i18n("Act on new/unread mail in this folder" ), this );
|
|
|
|
TQWhatsThis::add( mNotifyOnNewMailCheckBox,
|
|
|
|
i18n( "<qt><p>If this option is enabled then you will be notified about "
|
|
|
|
"new/unread mail in this folder. Moreover, going to the "
|
|
|
|
"next/previous folder with unread messages will stop at this "
|
|
|
|
"folder.</p>"
|
|
|
|
"<p>Uncheck this option if you do not want to be notified about "
|
|
|
|
"new/unread mail in this folder and if you want this folder to "
|
|
|
|
"be skipped when going to the next/previous folder with unread "
|
|
|
|
"messages. This is useful for ignoring any new/unread mail in "
|
|
|
|
"your trash and spam folder.</p></qt>" ) );
|
|
|
|
hbl->addWidget( mNotifyOnNewMailCheckBox );
|
|
|
|
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeImap ) {
|
|
|
|
// should this folder be included in new-mail-checks?
|
|
|
|
|
|
|
|
TQHBoxLayout *nml = new TQHBoxLayout( topLayout );
|
|
|
|
nml->setSpacing( KDialog::spacingHint() );
|
|
|
|
mNewMailCheckBox = new TQCheckBox( i18n("Include this folder in mail checks"), this );
|
|
|
|
// default is on
|
|
|
|
mNewMailCheckBox->setChecked(true);
|
|
|
|
nml->addWidget( mNewMailCheckBox );
|
|
|
|
nml->addStretch( 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
// should replies to mails in this folder be kept in this same folder?
|
|
|
|
hbl = new TQHBoxLayout( topLayout );
|
|
|
|
hbl->setSpacing( KDialog::spacingHint() );
|
|
|
|
mKeepRepliesInSameFolderCheckBox =
|
|
|
|
new TQCheckBox( i18n("Keep replies in this folder" ), this );
|
|
|
|
TQWhatsThis::add( mKeepRepliesInSameFolderCheckBox,
|
|
|
|
i18n( "Check this option if you want replies you write "
|
|
|
|
"to mails in this folder to be put in this same folder "
|
|
|
|
"after sending, instead of in the configured sent-mail folder." ) );
|
|
|
|
hbl->addWidget( mKeepRepliesInSameFolderCheckBox );
|
|
|
|
hbl->addStretch( 1 );
|
|
|
|
|
|
|
|
addLine( this, topLayout );
|
|
|
|
|
|
|
|
// use grid layout for the following combobox settings
|
|
|
|
TQGridLayout *gl = new TQGridLayout( topLayout, 3, 2, KDialog::spacingHint() );
|
|
|
|
gl->setColStretch( 1, 100 ); // make the second column use all available space
|
|
|
|
int row = -1;
|
|
|
|
|
|
|
|
// sender or receiver column?
|
|
|
|
++row;
|
|
|
|
TQString tip = i18n("Show Sender/Receiver Column in List of Messages");
|
|
|
|
|
|
|
|
TQLabel *sender_label = new TQLabel( i18n("Sho&w column:" ), this );
|
|
|
|
gl->addWidget( sender_label, row, 0 );
|
|
|
|
mShowSenderReceiverComboBox = new TQComboBox( this );
|
|
|
|
TQToolTip::add( mShowSenderReceiverComboBox, tip );
|
|
|
|
sender_label->setBuddy(mShowSenderReceiverComboBox);
|
|
|
|
gl->addWidget( mShowSenderReceiverComboBox, row, 1 );
|
|
|
|
mShowSenderReceiverComboBox->insertItem(i18n("Default"), 0);
|
|
|
|
mShowSenderReceiverComboBox->insertItem(i18n("Sender"), 1);
|
|
|
|
mShowSenderReceiverComboBox->insertItem(i18n("Receiver"), 2);
|
|
|
|
|
|
|
|
TQString whoField;
|
|
|
|
if (mDlg->folder()) whoField = mDlg->folder()->userWhoField();
|
|
|
|
if (whoField.isEmpty()) mShowSenderReceiverComboBox->setCurrentItem(0);
|
|
|
|
else if (whoField == "From") mShowSenderReceiverComboBox->setCurrentItem(1);
|
|
|
|
else if (whoField == "To") mShowSenderReceiverComboBox->setCurrentItem(2);
|
|
|
|
|
|
|
|
|
|
|
|
// sender identity
|
|
|
|
++row;
|
|
|
|
label = new TQLabel( i18n("&Sender identity:"), this );
|
|
|
|
gl->addWidget( label, row, 0 );
|
|
|
|
mIdentityComboBox = new KPIM::IdentityCombo( kmkernel->identityManager(), this );
|
|
|
|
label->setBuddy( mIdentityComboBox );
|
|
|
|
gl->addWidget( mIdentityComboBox, row, 1 );
|
|
|
|
TQWhatsThis::add( mIdentityComboBox,
|
|
|
|
i18n( "Select the sender identity to be used when writing new mail "
|
|
|
|
"or replying to mail in this folder. This means that if you are in "
|
|
|
|
"one of your work folders, you can make KMail use the corresponding "
|
|
|
|
"sender email address, signature and signing or encryption keys "
|
|
|
|
"automatically. Identities can be set up in the main configuration "
|
|
|
|
"dialog. (Settings -> Configure KMail)") );
|
|
|
|
|
|
|
|
// folder contents
|
|
|
|
if ( ( !mIsLocalSystemFolder || mIsResourceFolder ) &&
|
|
|
|
kmkernel->iCalIface().isEnabled() &&
|
|
|
|
mDlg->folder() && mDlg->folder()->folderType() != KMFolderTypeImap ) {
|
|
|
|
// Only do make this settable, if the IMAP resource is enabled
|
|
|
|
// and it's not the personal folders (those must not be changed)
|
|
|
|
++row;
|
|
|
|
label = new TQLabel( i18n("&Folder contents:"), this );
|
|
|
|
gl->addWidget( label, row, 0 );
|
|
|
|
mContentsComboBox = new TQComboBox( this );
|
|
|
|
label->setBuddy( mContentsComboBox );
|
|
|
|
gl->addWidget( mContentsComboBox, row, 1 );
|
|
|
|
|
|
|
|
mContentsComboBox->insertItem( i18n( "Mail" ) );
|
|
|
|
mContentsComboBox->insertItem( i18n( "Calendar" ) );
|
|
|
|
mContentsComboBox->insertItem( i18n( "Contacts" ) );
|
|
|
|
mContentsComboBox->insertItem( i18n( "Notes" ) );
|
|
|
|
mContentsComboBox->insertItem( i18n( "Tasks" ) );
|
|
|
|
mContentsComboBox->insertItem( i18n( "Journal" ) );
|
|
|
|
if ( mDlg->folder() )
|
|
|
|
mContentsComboBox->setCurrentItem( mDlg->folder()->storage()->contentsType() );
|
|
|
|
connect ( mContentsComboBox, TQT_SIGNAL ( activated( int ) ),
|
|
|
|
this, TQT_SLOT( slotFolderContentsSelectionChanged( int ) ) );
|
|
|
|
if ( mDlg->folder()->isReadOnly() || mIsResourceFolder )
|
|
|
|
mContentsComboBox->setEnabled( false );
|
|
|
|
} else {
|
|
|
|
mContentsComboBox = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
mIncidencesForComboBox = 0;
|
|
|
|
mAlarmsBlockedCheckBox = 0;
|
|
|
|
|
|
|
|
// Kolab incidences-for annotation.
|
|
|
|
// Show incidences-for combobox if the contents type can be changed (new folder),
|
|
|
|
// or if it's set to calendar or task (existing folder)
|
|
|
|
if ( ( GlobalSettings::self()->theIMAPResourceStorageFormat() ==
|
|
|
|
GlobalSettings::EnumTheIMAPResourceStorageFormat::XML ) &&
|
|
|
|
mContentsComboBox ) {
|
|
|
|
++row;
|
|
|
|
|
|
|
|
TQLabel* label = new TQLabel( i18n( "Generate free/&busy and activate alarms for:" ), this );
|
|
|
|
gl->addWidget( label, row, 0 );
|
|
|
|
mIncidencesForComboBox = new TQComboBox( this );
|
|
|
|
label->setBuddy( mIncidencesForComboBox );
|
|
|
|
gl->addWidget( mIncidencesForComboBox, row, 1 );
|
|
|
|
|
|
|
|
const TQString whatsThisForMyOwnFolders =
|
|
|
|
i18n( "This setting defines which users sharing "
|
|
|
|
"this folder should get \"busy\" periods in their freebusy lists "
|
|
|
|
"and should see the alarms for the events or tasks in this folder. "
|
|
|
|
"The setting applies to Calendar and Task folders only "
|
|
|
|
"(for tasks, this setting is only used for alarms).\n\n"
|
|
|
|
"Example use cases: if the boss shares a folder with his secretary, "
|
|
|
|
"only the boss should be marked as busy for his meetings, so he should "
|
|
|
|
"select \"Admins\", since the secretary has no admin rights on the folder.\n"
|
|
|
|
"On the other hand if a working group shares a Calendar for "
|
|
|
|
"group meetings, all readers of the folders should be marked "
|
|
|
|
"as busy for meetings.\n"
|
|
|
|
"A company-wide folder with optional events in it would use \"Nobody\" "
|
|
|
|
"since it is not known who will go to those events." );
|
|
|
|
|
|
|
|
TQWhatsThis::add( mIncidencesForComboBox, whatsThisForMyOwnFolders );
|
|
|
|
mIncidencesForComboBox->insertItem( i18n( "Nobody" ) );
|
|
|
|
mIncidencesForComboBox->insertItem( i18n( "Admins of This Folder" ) );
|
|
|
|
mIncidencesForComboBox->insertItem( i18n( "All Readers of This Folder" ) );
|
|
|
|
++row;
|
|
|
|
const TQString whatsThisForReadOnlyFolders =
|
|
|
|
i18n( "This setting allows you to disable alarms for folders shared by others. ");
|
|
|
|
mAlarmsBlockedCheckBox = new TQCheckBox( this );
|
|
|
|
mAlarmsBlockedCheckBox->setText( i18n( "Block alarms locally" ) );
|
|
|
|
gl->addMultiCellWidget( mAlarmsBlockedCheckBox, row, row, 0, 1);
|
|
|
|
TQWhatsThis::add( mAlarmsBlockedCheckBox, whatsThisForReadOnlyFolders );
|
|
|
|
|
|
|
|
if ( mDlg->folder()->storage()->contentsType() != KMail::ContentsTypeCalendar
|
|
|
|
&& mDlg->folder()->storage()->contentsType() != KMail::ContentsTypeTask ) {
|
|
|
|
mIncidencesForComboBox->setEnabled( false );
|
|
|
|
mAlarmsBlockedCheckBox->setEnabled( false );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mDlg->folder()->folderType() == KMFolderTypeCachedImap ) {
|
|
|
|
kdDebug() << k_funcinfo << mDlg->folder()->folderType() << endl;
|
|
|
|
mSharedSeenFlagsCheckBox = new TQCheckBox( this );
|
|
|
|
mSharedSeenFlagsCheckBox->setText( i18n( "Share unread state with all users" ) );
|
|
|
|
++row;
|
|
|
|
gl->addMultiCellWidget( mSharedSeenFlagsCheckBox, row, row, 0, 1 );
|
|
|
|
TQWhatsThis::add( mSharedSeenFlagsCheckBox, i18n( "If enabled, the unread state of messages in this folder will be the same "
|
|
|
|
"for all users having access to this folders. If disabled (the default), every user with access to this folder has her "
|
|
|
|
"own unread state." ) );
|
|
|
|
}
|
|
|
|
topLayout->addStretch( 100 ); // eat all superfluous space
|
|
|
|
|
|
|
|
initializeWithValuesFromFolder( mDlg->folder() );
|
|
|
|
}
|
|
|
|
|
|
|
|
void FolderDiaGeneralTab::load()
|
|
|
|
{
|
|
|
|
// Nothing here, all is done in the ctor
|
|
|
|
}
|
|
|
|
|
|
|
|
void FolderDiaGeneralTab::initializeWithValuesFromFolder( KMFolder* folder ) {
|
|
|
|
if ( !folder )
|
|
|
|
return;
|
|
|
|
|
|
|
|
if ( !mIsLocalSystemFolder ) {
|
|
|
|
// folder icons
|
|
|
|
mIconsCheckBox->setChecked( folder->useCustomIcons() );
|
|
|
|
mNormalIconLabel->setEnabled( folder->useCustomIcons() );
|
|
|
|
mNormalIconButton->setEnabled( folder->useCustomIcons() );
|
|
|
|
mUnreadIconLabel->setEnabled( folder->useCustomIcons() );
|
|
|
|
mUnreadIconButton->setEnabled( folder->useCustomIcons() );
|
|
|
|
TQString iconPath = folder->normalIconPath();
|
|
|
|
if ( !iconPath.isEmpty() )
|
|
|
|
mNormalIconButton->setIcon( iconPath );
|
|
|
|
iconPath = folder->unreadIconPath();
|
|
|
|
if ( !iconPath.isEmpty() )
|
|
|
|
mUnreadIconButton->setIcon( iconPath );
|
|
|
|
}
|
|
|
|
|
|
|
|
// folder identity
|
|
|
|
mIdentityComboBox->setCurrentIdentity( folder->identity() );
|
|
|
|
// ignore new mail
|
|
|
|
mNotifyOnNewMailCheckBox->setChecked( !folder->ignoreNewMail() );
|
|
|
|
|
|
|
|
const bool keepInFolder = !folder->isReadOnly() && folder->putRepliesInSameFolder();
|
|
|
|
mKeepRepliesInSameFolderCheckBox->setChecked( keepInFolder );
|
|
|
|
mKeepRepliesInSameFolderCheckBox->setDisabled( folder->isReadOnly() );
|
|
|
|
|
|
|
|
if (folder->folderType() == KMFolderTypeImap)
|
|
|
|
{
|
|
|
|
KMFolderImap* imapFolder = static_cast<KMFolderImap*>(folder->storage());
|
|
|
|
bool checked = imapFolder->includeInMailCheck();
|
|
|
|
mNewMailCheckBox->setChecked(checked);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mIncidencesForComboBox ) {
|
|
|
|
KMFolderCachedImap* dimap = static_cast<KMFolderCachedImap *>( folder->storage() );
|
|
|
|
mIncidencesForComboBox->setCurrentItem( dimap->incidencesFor() );
|
|
|
|
mIncidencesForComboBox->setDisabled( mDlg->folder()->isReadOnly() );
|
|
|
|
}
|
|
|
|
if ( mAlarmsBlockedCheckBox ) {
|
|
|
|
KMFolderCachedImap* dimap = static_cast<KMFolderCachedImap *>( folder->storage() );
|
|
|
|
mAlarmsBlockedCheckBox->setChecked( dimap->alarmsBlocked() );
|
|
|
|
}
|
|
|
|
if ( mSharedSeenFlagsCheckBox ) {
|
|
|
|
KMFolderCachedImap *dimap = static_cast<KMFolderCachedImap*>( folder->storage() );
|
|
|
|
ImapAccountBase *account = dynamic_cast<ImapAccountBase*>( dimap->account() );
|
|
|
|
mSharedSeenFlagsCheckBox->setChecked( dimap->sharedSeenFlags() );
|
|
|
|
mSharedSeenFlagsCheckBox->setDisabled( folder->isReadOnly() );
|
|
|
|
if ( account && account->hasCapability( "x-kmail-sharedseen" ) )
|
|
|
|
mSharedSeenFlagsCheckBox->show();
|
|
|
|
else
|
|
|
|
mSharedSeenFlagsCheckBox->hide();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
void FolderDiaGeneralTab::slotFolderNameChanged( const TQString& str )
|
|
|
|
{
|
|
|
|
mDlg->enableButtonOK( !str.isEmpty() );
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
void FolderDiaGeneralTab::slotFolderContentsSelectionChanged( int )
|
|
|
|
{
|
|
|
|
KMail::FolderContentsType type =
|
|
|
|
static_cast<KMail::FolderContentsType>( mContentsComboBox->currentItem() );
|
|
|
|
if( type != KMail::ContentsTypeMail && GlobalSettings::self()->hideGroupwareFolders() ) {
|
|
|
|
TQString message = i18n("You have configured this folder to contain groupware information "
|
|
|
|
"and the general configuration option to hide groupware folders is "
|
|
|
|
"set. That means that this folder will disappear once the configuration "
|
|
|
|
"dialog is closed. If you want to remove the folder again, you will need "
|
|
|
|
"to temporarily disable hiding of groupware folders to be able to see it.");
|
|
|
|
KMessageBox::information( this, message );
|
|
|
|
}
|
|
|
|
const bool enable = type == KMail::ContentsTypeCalendar ||
|
|
|
|
type == KMail::ContentsTypeTask;
|
|
|
|
if ( mIncidencesForComboBox )
|
|
|
|
mIncidencesForComboBox->setEnabled( enable );
|
|
|
|
if ( mAlarmsBlockedCheckBox )
|
|
|
|
mAlarmsBlockedCheckBox->setEnabled( enable );
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
bool FolderDiaGeneralTab::save()
|
|
|
|
{
|
|
|
|
KMFolder* folder = mDlg->folder();
|
|
|
|
folder->setIdentity( mIdentityComboBox->currentIdentity() );
|
|
|
|
// set whoField
|
|
|
|
if (mShowSenderReceiverComboBox->currentItem() == 1)
|
|
|
|
folder->setUserWhoField("From");
|
|
|
|
else if (mShowSenderReceiverComboBox->currentItem() == 2)
|
|
|
|
folder->setUserWhoField("To");
|
|
|
|
else
|
|
|
|
folder->setUserWhoField("");
|
|
|
|
|
|
|
|
folder->setIgnoreNewMail( !mNotifyOnNewMailCheckBox->isChecked() );
|
|
|
|
folder->setPutRepliesInSameFolder( mKeepRepliesInSameFolderCheckBox->isChecked() );
|
|
|
|
|
|
|
|
TQString fldName, oldFldName;
|
|
|
|
KMFolderCachedImap* dimap = 0;
|
|
|
|
if ( folder->folderType() == KMFolderTypeCachedImap )
|
|
|
|
dimap = static_cast<KMFolderCachedImap *>( mDlg->folder()->storage() );
|
|
|
|
|
|
|
|
if ( !mIsLocalSystemFolder || mIsResourceFolder )
|
|
|
|
{
|
|
|
|
oldFldName = mDlg->folder()->name();
|
|
|
|
if (!mNameEdit->text().isEmpty())
|
|
|
|
fldName = mNameEdit->text();
|
|
|
|
else
|
|
|
|
fldName = oldFldName;
|
|
|
|
|
|
|
|
if ( mDlg->parentFolder() &&
|
|
|
|
mDlg->parentFolder()->folderType() != KMFolderTypeImap &&
|
|
|
|
mDlg->parentFolder()->folderType() != KMFolderTypeCachedImap )
|
|
|
|
fldName.remove('/');
|
|
|
|
fldName.remove(TQRegExp("^\\.*"));
|
|
|
|
if (fldName.isEmpty()) fldName = i18n("unnamed");
|
|
|
|
|
|
|
|
|
|
|
|
// Update the tree iff new icon paths are different and not empty or if
|
|
|
|
// useCustomIcons changed.
|
|
|
|
if ( folder->useCustomIcons() != mIconsCheckBox->isChecked() ) {
|
|
|
|
folder->setUseCustomIcons( mIconsCheckBox->isChecked() );
|
|
|
|
// Reset icons, useCustomIcons was turned off.
|
|
|
|
if ( !folder->useCustomIcons() ) {
|
|
|
|
folder->setIconPaths( "", "" );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( folder->useCustomIcons() && (
|
|
|
|
(( mNormalIconButton->icon() != folder->normalIconPath() ) &&
|
|
|
|
( !mNormalIconButton->icon().isEmpty())) ||
|
|
|
|
(( mUnreadIconButton->icon() != folder->unreadIconPath() ) &&
|
|
|
|
( !mUnreadIconButton->icon().isEmpty())) ) ) {
|
|
|
|
folder->setIconPaths( mNormalIconButton->icon(), mUnreadIconButton->icon() );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set type field
|
|
|
|
if ( mContentsComboBox ) {
|
|
|
|
KMail::FolderContentsType type =
|
|
|
|
static_cast<KMail::FolderContentsType>( mContentsComboBox->currentItem() );
|
|
|
|
folder->storage()->setContentsType( type );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( dimap ) {
|
|
|
|
if ( mIncidencesForComboBox ) {
|
|
|
|
KMFolderCachedImap::IncidencesFor incfor = KMFolderCachedImap::IncForAdmins;
|
|
|
|
incfor = static_cast<KMFolderCachedImap::IncidencesFor>( mIncidencesForComboBox->currentItem() );
|
|
|
|
if ( dimap->incidencesFor() != incfor ) {
|
|
|
|
dimap->setIncidencesFor( incfor );
|
|
|
|
dimap->writeConfig();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( mAlarmsBlockedCheckBox && mAlarmsBlockedCheckBox->isChecked() != dimap->alarmsBlocked() ) {
|
|
|
|
dimap->setAlarmsBlocked( mAlarmsBlockedCheckBox->isChecked() );
|
|
|
|
dimap->writeConfig();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( folder->folderType() == KMFolderTypeImap )
|
|
|
|
{
|
|
|
|
KMFolderImap* imapFolder = static_cast<KMFolderImap*>( folder->storage() );
|
|
|
|
imapFolder->setIncludeInMailCheck(
|
|
|
|
mNewMailCheckBox->isChecked() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( dimap && mSharedSeenFlagsCheckBox &&
|
|
|
|
mSharedSeenFlagsCheckBox->isChecked() != dimap->sharedSeenFlags() ) {
|
|
|
|
dimap->setSharedSeenFlags( mSharedSeenFlagsCheckBox->isChecked() );
|
|
|
|
dimap->writeConfig();
|
|
|
|
}
|
|
|
|
|
|
|
|
// make sure everything is on disk, connected slots will call readConfig()
|
|
|
|
// when creating a new folder.
|
|
|
|
folder->storage()->writeConfig();
|
|
|
|
|
|
|
|
TQString msg;
|
|
|
|
if ( !folder->isValidName( fldName, msg ) ) {
|
|
|
|
KMessageBox::sorry( this, msg );
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
// Renamed an existing folder? We don't check for oldName == newName on
|
|
|
|
// purpose here. The folder might be pending renaming on the next dimap
|
|
|
|
// sync already, in which case the old name would still be around and
|
|
|
|
// something like Calendar -> CalendarFoo -> Calendar inbetween syncs would
|
|
|
|
// fail. Therefor let the folder sort it out itself, whether the rename is
|
|
|
|
// a noop or not.
|
|
|
|
if ( !oldFldName.isEmpty() )
|
|
|
|
{
|
|
|
|
kmkernel->folderMgr()->renameFolder( folder, fldName );
|
|
|
|
} else {
|
|
|
|
kmkernel->folderMgr()->contentsChanged();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void FolderDiaGeneralTab::slotChangeIcon( TQString icon ) // can't use a const-ref here, due to TDEIconButton's signal
|
|
|
|
{
|
|
|
|
mUnreadIconButton->setIcon( icon );
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
KMail::FolderDiaTemplatesTab::FolderDiaTemplatesTab( KMFolderDialog* dlg,
|
|
|
|
TQWidget* parent )
|
|
|
|
: FolderDiaTab( parent, 0 ), mDlg( dlg )
|
|
|
|
{
|
|
|
|
|
|
|
|
mIsLocalSystemFolder = mDlg->folder()->isSystemFolder();
|
|
|
|
|
|
|
|
|
|
|
|
TQVBoxLayout *topLayout = new TQVBoxLayout( this, 0, KDialog::spacingHint() );
|
|
|
|
|
|
|
|
mCustom = new TQCheckBox( i18n("&Use custom message templates"), this );
|
|
|
|
topLayout->addWidget( mCustom );
|
|
|
|
|
|
|
|
mWidget = new TemplatesConfiguration( this , "folder-templates" );
|
|
|
|
mWidget->setEnabled( false );
|
|
|
|
topLayout->addWidget( mWidget );
|
|
|
|
|
|
|
|
TQHBoxLayout *btns = new TQHBoxLayout( topLayout, KDialog::spacingHint() );
|
|
|
|
mCopyGlobal = new KPushButton( i18n("&Copy global templates"), this );
|
|
|
|
mCopyGlobal->setEnabled( false );
|
|
|
|
btns->addWidget( mCopyGlobal );
|
|
|
|
|
|
|
|
connect( mCustom, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mWidget, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
connect( mCustom, TQT_SIGNAL(toggled(bool)),
|
|
|
|
mCopyGlobal, TQT_SLOT(setEnabled(bool)) );
|
|
|
|
|
|
|
|
connect( mCopyGlobal, TQT_SIGNAL(clicked()),
|
|
|
|
this, TQT_SLOT(slotCopyGlobal()) );
|
|
|
|
|
|
|
|
initializeWithValuesFromFolder( mDlg->folder() );
|
|
|
|
|
|
|
|
connect( mWidget, TQT_SIGNAL( changed() ),
|
|
|
|
this, TQT_SLOT( slotEmitChanged( void ) ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
void FolderDiaTemplatesTab::load()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void FolderDiaTemplatesTab::initializeWithValuesFromFolder( KMFolder* folder ) {
|
|
|
|
if ( !folder )
|
|
|
|
return;
|
|
|
|
|
|
|
|
mFolder = folder;
|
|
|
|
|
|
|
|
TQString fid = folder->idString();
|
|
|
|
|
|
|
|
Templates t( fid );
|
|
|
|
|
|
|
|
mCustom->setChecked(t.useCustomTemplates());
|
|
|
|
|
|
|
|
mIdentity = folder->identity();
|
|
|
|
|
|
|
|
mWidget->loadFromFolder( fid, mIdentity );
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
bool FolderDiaTemplatesTab::save()
|
|
|
|
{
|
|
|
|
KMFolder* folder = mDlg->folder();
|
|
|
|
|
|
|
|
TQString fid = folder->idString();
|
|
|
|
Templates t(fid);
|
|
|
|
|
|
|
|
kdDebug() << "use custom templates for folder " << fid << ": " << mCustom->isChecked() << endl;
|
|
|
|
t.setUseCustomTemplates(mCustom->isChecked());
|
|
|
|
t.writeConfig();
|
|
|
|
|
|
|
|
mWidget->saveToFolder(fid);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FolderDiaTemplatesTab::slotEmitChanged() {}
|
|
|
|
|
|
|
|
void FolderDiaTemplatesTab::slotCopyGlobal() {
|
|
|
|
if ( mIdentity ) {
|
|
|
|
mWidget->loadFromIdentity( mIdentity );
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
mWidget->loadFromGlobal();
|
|
|
|
}
|
|
|
|
}
|