kaddressbook

cryptowidget.h
1 /*
2  This file is part of KAddressBook.
3  Copyright (c) 2004 Klarälvdalens Datakonsult AB
4 
5  This program is free software; you can redistribute it and/or modify
6  it under the terms of the GNU General Public License as published by
7  the Free Software Foundation; either version 2 of the License, or
8  (at your option) any later version.
9 
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU General Public License for more details.
14 
15  You should have received a copy of the GNU General Public License
16  along with this program; if not, write to the Free Software
17  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 
19  As a special exception, permission is given to link this program
20  with any edition of TQt, and distribute the resulting executable,
21  without including the source code for TQt in the source distribution.
22 */
23 
24 #ifndef CRYPTOWIDGET_H
25 #define CRYPTOWIDGET_H
26 
27 #include "contacteditorwidget.h"
28 
29 class TQComboBox;
30 
31 namespace Kleo {
32  class KeyRequester;
33 }
34 class TQCheckBox;
35 
36 class CryptoWidget : public KAB::ContactEditorWidget
37 {
38  TQ_OBJECT
39 
40 
41  public:
42  CryptoWidget( TDEABC::AddressBook *ab, TQWidget *parent, const char *name = 0 );
43  ~CryptoWidget();
44 
45  void loadContact( TDEABC::Addressee *addr );
46  void storeContact( TDEABC::Addressee *addr );
47  void setReadOnly( bool readOnly );
48 
49  private:
50  enum { NumberOfProtocols = 4 };
51  TQCheckBox* mProtocolCB[NumberOfProtocols];
52  TQComboBox* mSignPref;
53  TQComboBox* mCryptPref;
54  Kleo::KeyRequester* mPgpKey;
55  Kleo::KeyRequester* mSmimeCert;
56  bool mReadOnly;
57 };
58 
59 class CryptoWidgetFactory : public KAB::ContactEditorWidgetFactory
60 {
61  public:
62  CryptoWidgetFactory();
63  KAB::ContactEditorWidget *createWidget( TDEABC::AddressBook *ab, TQWidget *parent, const char *name )
64  {
65  return new CryptoWidget( ab, parent, name );
66  }
67 
68  TQString pageTitle() const;
69  TQString pageIdentifier() const;
70 };
71 
72 #endif