• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepimlibs API Reference
  • KDE Home
  • Contact Us
 

akonadi

  • sources
  • kde-4.12
  • kdepimlibs
  • akonadi
  • contact
contactgroupeditor.h
1 /*
2  This file is part of Akonadi Contact.
3 
4  Copyright (c) 2009 Tobias Koenig <tokoe@kde.org>
5 
6  This library is free software; you can redistribute it and/or modify it
7  under the terms of the GNU Library General Public License as published by
8  the Free Software Foundation; either version 2 of the License, or (at your
9  option) any later version.
10 
11  This library is distributed in the hope that it will be useful, but WITHOUT
12  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
14  License for more details.
15 
16  You should have received a copy of the GNU Library General Public License
17  along with this library; see the file COPYING.LIB. If not, write to the
18  Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19  02110-1301, USA.
20 */
21 
22 #ifndef AKONADI_CONTACTGROUPEDITOR_H
23 #define AKONADI_CONTACTGROUPEDITOR_H
24 
25 #include "akonadi-contact_export.h"
26 
27 #include <QWidget>
28 
29 namespace KABC {
30 class ContactGroup;
31 }
32 
33 namespace Akonadi {
34 
35 class Collection;
36 class Item;
37 
82 class AKONADI_CONTACT_EXPORT ContactGroupEditor : public QWidget
83 {
84  Q_OBJECT
85 
86  public:
90  enum Mode {
91  CreateMode,
92  EditMode
93  };
94 
101  explicit ContactGroupEditor( Mode mode, QWidget *parent = 0 );
102 
106  virtual ~ContactGroupEditor();
107 
113  void setContactGroupTemplate( const KABC::ContactGroup &group );
114 
119  void setDefaultAddressBook( const Akonadi::Collection &addressbook );
120 
121  void groupNameIsValid(bool isValid);
122 
123  public Q_SLOTS:
127  void loadContactGroup( const Akonadi::Item &group );
128 
134  bool saveContactGroup();
135 
136  Q_SIGNALS:
141  void contactGroupStored( const Akonadi::Item &group );
142 
147  void error( const QString &errorMsg );
148 
149  private:
150  //@cond PRIVATE
151  friend class ContactGroupEditorDialog;
152 
153  class Private;
154  Private* const d;
155 
156  Q_DISABLE_COPY( ContactGroupEditor )
157 
158  Q_PRIVATE_SLOT( d, void itemFetchDone( KJob* ) )
159  Q_PRIVATE_SLOT( d, void parentCollectionFetchDone( KJob* ) )
160  Q_PRIVATE_SLOT( d, void storeDone( KJob* ) )
161  Q_PRIVATE_SLOT( d, void itemChanged( const Akonadi::Item&, const QSet<QByteArray>& ) )
162  Q_PRIVATE_SLOT( d, void adaptHeaderSizes() )
163  //@endcond
164 };
165 
166 }
167 
168 #endif
Akonadi::Collection
Represents a collection of PIM items.
Definition: collection.h:75
Akonadi::ContactGroupEditor::CreateMode
Creates a new contact group.
Definition: contactgroupeditor.h:91
Akonadi::ContactGroupEditor::Mode
Mode
Describes the mode of the contact group editor.
Definition: contactgroupeditor.h:90
Akonadi::ContactGroupEditorDialog
A dialog for creating or editing a contact group in Akonadi.
Definition: contactgroupeditordialog.h:75
Akonadi::ContactGroupEditor
An widget to edit contact groups in Akonadi.
Definition: contactgroupeditor.h:82
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:00:27 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

akonadi

Skip menu "akonadi"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • Modules
  • Related Pages

kdepimlibs API Reference

Skip menu "kdepimlibs API Reference"
  • akonadi
  •   contact
  •   kmime
  •   socialutils
  • kabc
  • kalarmcal
  • kblog
  • kcal
  • kcalcore
  • kcalutils
  • kholidays
  • kimap
  • kldap
  • kmbox
  • kmime
  • kpimidentities
  • kpimtextedit
  • kresources
  • ktnef
  • kxmlrpcclient
  • microblog

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal