/** * kmcomposereditor.cpp * * Copyright (C) 2007, 2008 Laurent Montel * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA */ #include "kmcomposereditor.h" #include "kmcomposewin.h" #include "kmcommands.h" #include #include #include #include #include #include #include #include #include #include #include #include #include "kmkernel.h" #include "foldercollection.h" #include #include #include #include #include KMComposerEditor::KMComposerEditor( KMComposeWin *win,QWidget *parent) :KMeditor(parent),m_composerWin(win) { } KMComposerEditor::~KMComposerEditor() { } void KMComposerEditor::createActions( KActionCollection *actionCollection ) { KMeditor::createActions( actionCollection ); mPasteQuotation = new KAction( i18n("Pa&ste as Quotation"), this ); actionCollection->addAction("paste_quoted", mPasteQuotation ); connect( mPasteQuotation, SIGNAL(triggered(bool) ), this, SLOT( slotPasteAsQuotation()) ); mAddQuoteChars = new KAction( i18n("Add &Quote Characters"), this ); actionCollection->addAction( "tools_quote", mAddQuoteChars ); connect( mAddQuoteChars, SIGNAL(triggered(bool) ), this, SLOT(slotAddQuotes()) ); mRemQuoteChars = new KAction( i18n("Re&move Quote Characters"), this ); actionCollection->addAction( "tools_unquote", mRemQuoteChars ); connect (mRemQuoteChars, SIGNAL(triggered(bool) ), this, SLOT(slotRemoveQuotes()) ); } void KMComposerEditor::setHighlighterColors(KPIMTextEdit::EMailQuoteHighlighter * highlighter) { // defaults from kmreaderwin.cpp. FIXME: centralize somewhere. QColor color1( 0x00, 0x80, 0x00 ); QColor color2( 0x00, 0x70, 0x00 ); QColor color3( 0x00, 0x60, 0x00 ); QColor misspelled = Qt::red; if ( !GlobalSettings::self()->useDefaultColors() ) { KConfigGroup readerConfig( KMKernel::config(), "Reader" ); color3 = readerConfig.readEntry( "QuotedText3", color3 ); color2 = readerConfig.readEntry( "QuotedText2", color2 ); color1 = readerConfig.readEntry( "QuotedText1", color1 ); misspelled = readerConfig.readEntry( "MisspelledColor", misspelled ); } highlighter->setQuoteColor( Qt::black /* ignored anyway */, color3, color2, color1, misspelled ); } QString KMComposerEditor::smartQuote( const QString & msg ) { return m_composerWin->smartQuote( msg ); } const QString KMComposerEditor::defaultQuoteSign() const { if ( !m_quotePrefix.simplified().isEmpty() ) return m_quotePrefix; else return KPIMTextEdit::TextEdit::defaultQuoteSign(); } int KMComposerEditor::quoteLength( const QString& line ) const { if ( !m_quotePrefix.simplified().isEmpty() ) { if ( line.startsWith( m_quotePrefix ) ) return m_quotePrefix.length(); else return 0; } else return KPIMTextEdit::TextEdit::quoteLength( line ); } void KMComposerEditor::setQuotePrefixName( const QString "ePrefix ) { m_quotePrefix = quotePrefix; } QString KMComposerEditor::quotePrefixName() const { if ( !m_quotePrefix.simplified().isEmpty() ) return m_quotePrefix; else return ">"; } void KMComposerEditor::replaceUnknownChars( const QTextCodec *codec ) { QTextCursor cursor( document() ); cursor.beginEditBlock(); while ( !cursor.atEnd() ) { cursor.movePosition( QTextCursor::NextCharacter, QTextCursor::KeepAnchor ); QChar cur = cursor.selectedText().at( 0 ); if ( !codec->canEncode( cur ) ) { cursor.insertText( "?" ); } else { cursor.clearSelection(); } } cursor.endEditBlock(); } bool KMComposerEditor::canInsertFromMimeData( const QMimeData *source ) const { if ( source->hasImage() && source->hasFormat( "image/png" ) ) return true; if ( source->hasFormat( "text/x-kmail-textsnippet" ) ) return true; if ( source->hasUrls() ) return true; return KPIMTextEdit::TextEdit::canInsertFromMimeData( source ); } void KMComposerEditor::insertFromMimeData( const QMimeData *source ) { // If this is a PNG image, either add it as an attachment or as an inline image if ( source->hasImage() && source->hasFormat( "image/png" ) ) { if ( textMode() == KRichTextEdit::Rich ) { KMenu menu; const QAction *addAsInlineImageAction = menu.addAction( i18n("Add as &Inline Image") ); /*const QAction *addAsAttachmentAction = */menu.addAction( i18n("Add as &Attachment") ); const QAction *selectedAction = menu.exec( QCursor::pos() ); if ( selectedAction == addAsInlineImageAction ) { // Let the textedit from kdepimlibs handle inline images KPIMTextEdit::TextEdit::insertFromMimeData( source ); return; } // else fall through } // Get the image data before showing the dialog, since that processes events which can delete // the QMimeData object behind our back const QByteArray imageData = source->data( "image/png" ); // Ok, when we reached this point, the user wants to add the image as an attachment. // Ask for the filename first. bool ok; const QString attName = KInputDialog::getText( "KMail", i18n( "Name of the attachment:" ), QString(), &ok, this ); if ( !ok ) { return; } m_composerWin->addAttachment( attName, "base64", imageData, "image", "png", QByteArray(), QString(), QByteArray() ); return; } if ( source->hasFormat( "text/x-kmail-textsnippet" ) ) { emit insertSnippet(); return; } // If this is a URL list, add those files as attachments or text const KUrl::List urlList = KUrl::List::fromMimeData( source ); if ( !urlList.isEmpty() ) { //Search if it's message items. Akonadi::Item::List items; foreach ( const KUrl &url, urlList ) { Akonadi::Item item = Akonadi::Item::fromUrl( url ); if ( item.isValid() ) { items << item; } } if ( items.isEmpty() ) { KMenu p; const QAction *addAsTextAction = p.addAction( i18n("Add as &Text") ); const QAction *addAsAttachmentAction = p.addAction( i18n("Add as &Attachment") ); const QAction *selectedAction = p.exec( QCursor::pos() ); if ( selectedAction == addAsTextAction ) { foreach( const KUrl &url, urlList ) { textCursor().insertText(url.url()); } } else if ( selectedAction == addAsAttachmentAction ) { foreach( const KUrl &url, urlList ) { m_composerWin->addAttachment( url,"" ); } } return; } else { Akonadi::ItemFetchJob *itemFetchJob = new Akonadi::ItemFetchJob( items, this ); itemFetchJob->fetchScope().fetchFullPayload( true ); itemFetchJob->fetchScope().setAncestorRetrieval( Akonadi::ItemFetchScope::Parent ); connect( itemFetchJob, SIGNAL( result( KJob* ) ), this, SLOT( slotFetchJob( KJob* ) ) ); return; } } KPIMTextEdit::TextEdit::insertFromMimeData( source ); } void KMComposerEditor::slotFetchJob( KJob * job ) { if ( job->error() ) { static_cast(job)->ui()->showErrorMessage(); return; } Akonadi::ItemFetchJob *fjob = dynamic_cast( job ); if ( !fjob ) return; Akonadi::Item::List items = fjob->items(); uint identity = 0; if ( items.at( 0 ).isValid() && items.at( 0 ).parentCollection().isValid() ) { QSharedPointer fd( FolderCollection::forCollection( items.at( 0 ).parentCollection() ) ); identity = fd->identity(); } KMCommand *command = new KMForwardAttachedCommand( m_composerWin, items,identity, m_composerWin ); command->start(); } #include "kmcomposereditor.moc"