1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/*
Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
Copyright (C) 2003-2004 Reinhold Kainhofer <reinhold@kainhofer.com>
Copyright (c) 2007 Volker Krause <vkrause@kde.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef KOATTENDEEEDITOR_H
#define KOATTENDEEEDITOR_H
#include <qwidget.h>
#include <libkcal/attendee.h>
class QBoxLayout;
class QComboBox;
class QCheckBox;
class QLabel;
class QPushButton;
class QHBox;
namespace KPIM {
class AddresseeLineEdit;
}
namespace KABC {
class Addressee;
}
namespace KCal {
class Incidence;
}
/**
Common base class for attendee editor and free busy view.
*/
class KOAttendeeEditor : public QWidget
{
Q_OBJECT
public:
KOAttendeeEditor( QWidget *parent, const char *name = 0 );
virtual void insertAttendee( KCal::Attendee* attendee, bool fetchFB = true ) = 0;
virtual void readEvent( KCal::Incidence *incidence );
virtual void writeEvent( KCal::Incidence *incidence );
/** return a clone of the event with attendees to be canceld*/
void cancelAttendeeEvent( KCal::Incidence *incidence );
public slots:
void acceptForMe();
void declineForMe();
signals:
void updateAttendeeSummary( int count );
protected:
void initOrganizerWidgets( QWidget *parent, QBoxLayout *layout );
void initEditWidgets( QWidget *parent, QBoxLayout *layout );
/** Reads values from a KABC::Addressee and inserts a new Attendee
* item into the listview with those items. Used when adding attendees
* from the addressbook and expanding distribution lists.
* The optional Attendee parameter can be used to pass in default values
* to be used by the new Attendee. */
void insertAttendeeFromAddressee( const KABC::Addressee &a, const KCal::Attendee* at=0 );
void fillOrganizerCombo();
virtual KCal::Attendee* currentAttendee() const = 0;
virtual void updateCurrentItem() = 0;
virtual void changeStatusForMe( KCal::Attendee::PartStat status ) = 0;
virtual bool eventFilter( QObject *, QEvent *);
protected slots:
void addNewAttendee();
void openAddressBook();
void setEnableAttendeeInput( bool enabled );
void updateAttendeeInput();
void clearAttendeeInput();
void fillAttendeeInput( KCal::Attendee *a );
void updateAttendee();
protected:
KPIM::AddresseeLineEdit *mNameEdit;
QString mUid;
QComboBox* mRoleCombo;
QCheckBox* mRsvpButton;
QComboBox* mStatusCombo;
QHBox* mOrganizerHBox;
QComboBox *mOrganizerCombo; // either we organize it (combo shown)
QLabel *mOrganizerLabel; // or someone else does (just a label is shown)
QLabel* mDelegateLabel;
QPushButton* mAddButton;
QPushButton* mRemoveButton;
QPushButton* mAddressBookButton;
QPtrList<KCal::Attendee> mdelAttendees;
QPtrList<KCal::Attendee> mnewAttendees;
private:
bool mDisableItemUpdate;
};
#endif
|