mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-24 10:52:52 +00:00
86 lines
2.3 KiB
C++
86 lines
2.3 KiB
C++
/*
|
|
Copyright 2010 Tobias Koenig <tokoe@kde.org>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2 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
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef ADDEMAILADDRESSJOB_H
|
|
#define ADDEMAILADDRESSJOB_H
|
|
|
|
#include "kdepim_export.h"
|
|
|
|
#include <kjob.h>
|
|
|
|
namespace Akonadi {
|
|
class Item;
|
|
}
|
|
|
|
namespace KPIM {
|
|
|
|
/**
|
|
* @short A job to add a new contact with a given email address to Akonadi.
|
|
*
|
|
* The job will check whether a contact with the given email address already
|
|
* exists in Akonadi and inform the user about it, if it does not exist yet,
|
|
* a new contact is added.
|
|
*/
|
|
class KDEPIM_EXPORT AddEmailAddressJob : public KJob
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Creates a new add email address job.
|
|
*
|
|
* @param email The email address.
|
|
* @param parentWidget The widget that will be used as parent for dialog.
|
|
* @param parent The parent object.
|
|
*/
|
|
AddEmailAddressJob( const QString &email, QWidget *parentWidget, QObject *parent = 0 );
|
|
|
|
/**
|
|
* Destroys the add email address job.
|
|
*/
|
|
~AddEmailAddressJob();
|
|
|
|
/**
|
|
* Starts the job.
|
|
*/
|
|
virtual void start();
|
|
|
|
/**
|
|
* Returns the item that represents the new contact.
|
|
*/
|
|
Akonadi::Item contact() const;
|
|
|
|
private:
|
|
//@cond PRIVATE
|
|
class Private;
|
|
Private *const d;
|
|
|
|
Q_PRIVATE_SLOT( d, void slotSearchDone( KJob* ) )
|
|
Q_PRIVATE_SLOT( d, void slotAddContactDone( KJob* ) )
|
|
Q_PRIVATE_SLOT( d, void slotCollectionsFetched( KJob* ) )
|
|
Q_PRIVATE_SLOT( d, void slotResourceCreationDone( KJob* ) )
|
|
Q_PRIVATE_SLOT( d, void slotContactEditorError(const QString &) )
|
|
Q_PRIVATE_SLOT( d, void contactStored( const Akonadi::Item & ) )
|
|
|
|
//@endcond
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|