mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-24 10:52:52 +00:00
176 lines
4.8 KiB
C++
176 lines
4.8 KiB
C++
/*
|
|
This file is part of Akonadi Contact.
|
|
|
|
Copyright (c) 2007-2009 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 AKONADI_CONTACTEDITORDIALOG_H
|
|
#define AKONADI_CONTACTEDITORDIALOG_H
|
|
|
|
#include "akonadi-contact_export.h"
|
|
|
|
#include <kdialog.h>
|
|
|
|
class QAbstractItemModel;
|
|
|
|
namespace Akonadi {
|
|
|
|
class AbstractContactEditorWidget;
|
|
class ContactEditor;
|
|
class Collection;
|
|
class Item;
|
|
|
|
/**
|
|
* @short A dialog for creating or editing a contact in Akonadi.
|
|
*
|
|
* This dialog provides a way to create a new contact or edit
|
|
* an existing contact in Akonadi.
|
|
*
|
|
* Example for creating a new contact:
|
|
*
|
|
* @code
|
|
*
|
|
* using namespace Akonadi;
|
|
*
|
|
* ContactEditorDialog *dlg = new ContactEditorDialog( ContactEditorDialog::CreateMode, this );
|
|
* connect( dlg, SIGNAL( contactStored( const Akonadi::Item& ) ),
|
|
* this, SLOT( contactStored( const Akonadi::Item& ) ) );
|
|
* dlg->show();
|
|
*
|
|
*
|
|
* @endcode
|
|
*
|
|
* Example for editing an existing contact:
|
|
*
|
|
* @code
|
|
*
|
|
* using namespace Akonadi;
|
|
*
|
|
* const Item contact = ...;
|
|
*
|
|
* ContactEditorDialog *dlg = new ContactEditorDialog( ContactEditorDialog::EditMode, this );
|
|
* connect( dlg, SIGNAL( contactStored( const Akonadi::Item& ) ),
|
|
* this, SLOT( contactStored( const Akonadi::Item& ) ) );
|
|
* dlg->setContact( contact );
|
|
* dlg->show();
|
|
*
|
|
* @endcode
|
|
*
|
|
* @author Tobias Koenig <tokoe@kde.org>
|
|
* @since 4.4
|
|
*/
|
|
class AKONADI_CONTACT_EXPORT ContactEditorDialog : public KDialog
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Describes the mode of the editor dialog.
|
|
*/
|
|
enum Mode {
|
|
CreateMode, ///< Creates a new contact
|
|
EditMode ///< Edits an existing contact
|
|
};
|
|
|
|
enum DisplayMode {
|
|
FullMode, //Show all pages
|
|
VCardMode //Show just pages with elements stored in vcard.
|
|
};
|
|
|
|
/**
|
|
* Creates a new contact editor dialog with the standard editor widget.
|
|
*
|
|
* @param mode The mode of the dialog.
|
|
* @param parent The parent widget of the dialog.
|
|
*/
|
|
explicit ContactEditorDialog( Mode mode, QWidget *parent = 0 );
|
|
|
|
/**
|
|
* Creates a new contact editor dialog with a custom editor widget.
|
|
*
|
|
* @param mode The mode of the dialog.
|
|
* @param editorWidget The contact editor widget that shall be used for editing.
|
|
* @param parent The parent widget of the dialog.
|
|
*/
|
|
ContactEditorDialog( Mode mode, AbstractContactEditorWidget *editorWidget, QWidget *parent = 0 );
|
|
|
|
/**
|
|
* Creates a new contact editor dialog with a custom editor widget.
|
|
*
|
|
* @param mode The mode of the dialog.
|
|
* @param displayMode The mode of displaying: full or vcard
|
|
* @param parent The parent widget of the dialog.
|
|
* @since 4.10
|
|
*/
|
|
ContactEditorDialog( Mode mode, DisplayMode displayMode, QWidget *parent = 0 );
|
|
|
|
/**
|
|
* Destroys the contact editor dialog.
|
|
*/
|
|
~ContactEditorDialog();
|
|
|
|
/**
|
|
* Sets the @p contact to edit when in EditMode.
|
|
* @param contact the contact to edit
|
|
* @note The contact item just must have a uid set, all
|
|
* other data are fetched by the dialog automatically.
|
|
*/
|
|
void setContact( const Akonadi::Item &contact );
|
|
|
|
/**
|
|
* Sets the @p addressbook that shall be selected as default in create mode.
|
|
*/
|
|
void setDefaultAddressBook( const Akonadi::Collection &addressbook );
|
|
|
|
/**
|
|
* Returns the ContactEditor that is used by this dialog.
|
|
*/
|
|
ContactEditor* editor() const;
|
|
|
|
Q_SIGNALS:
|
|
/**
|
|
* This signal is emitted whenever a contact was updated or stored.
|
|
*
|
|
* @param contact The data reference of the contact.
|
|
*/
|
|
void contactStored( const Akonadi::Item &contact );
|
|
|
|
/**
|
|
* This signal is emitted whenever a contact is not updated or stored.
|
|
*
|
|
* @param errMsg The error during updating or storing contact.
|
|
*/
|
|
void error(const QString& errMsg);
|
|
|
|
public Q_SLOTS:
|
|
void accept();
|
|
|
|
private:
|
|
//@cond PRIVATE
|
|
class Private;
|
|
Private* const d;
|
|
|
|
Q_PRIVATE_SLOT( d, void slotOkClicked() )
|
|
Q_PRIVATE_SLOT( d, void slotCancelClicked() )
|
|
Q_PRIVATE_SLOT( d, void slotFinish() )
|
|
//@endcond
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|