You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/libkcal/attendee.h

163 lines
3.9 KiB

/*
This file is part of libkcal.
Copyright (c) 2001-2003 Cornelius Schumacher <schumacher@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 KCAL_ATTENDEE_H
#define KCAL_ATTENDEE_H
#include <tqstring.h>
#include <tqstringlist.h>
#include "listbase.h"
#include "person.h"
namespace KCal {
/**
This class represents information related to an attendee of an event.
*/
class LIBKCAL_EXPORT Attendee : public Person
{
public:
enum PartStat { NeedsAction, Accepted, Declined, Tentative,
Delegated, Completed, InProcess, None };
enum Role { ReqParticipant, OptParticipant, NonParticipant, Chair };
typedef ListBase<Attendee> List;
/**
Create Attendee.
@param name Name
@param email Email address
@param rsvp Request for reply
@param status Status (see enum for list)
@param role Role
@param u the uid for the attendee
*/
Attendee( const TQString &name, const TQString &email,
bool rsvp = false, PartStat status = None,
Role role = ReqParticipant, const TQString &u = TQString::null );
/**
Destruct Attendee.
*/
virtual ~Attendee();
/**
Set role of Attendee.
*/
// FIXME: List of roles still has to be documented.
void setRole( Role );
/**
Return role of Attendee.
*/
Role role() const;
/**
Return role as clear text string.
*/
TQString roleStr() const;
/**
Return string represenation of role.
*/
static TQString roleName( Role );
/**
Return string representations of all available roles.
*/
static TQStringList roleList();
/**
Return unique id of the attendee.
*/
TQString uid() const;
/**
Set unique id of attendee.
*/
void setUid ( const TQString & );
/**
Set status. See enum for definitions of possible values.
*/
void seStatus( PartStat s );
/**
Return status.
*/
PartStat status() const;
/**
Return status as human-readable string.
*/
TQString statusStr() const;
/**
Return string representation of attendee status.
*/
static TQString statusName( PartStat );
/**
Return string representations of all available attendee status values.
*/
static TQStringList statusList();
/**
Set if Attendee is asked to reply.
*/
void setRSVP( bool r ) { mRSVP = r; }
/**
Return, if Attendee is asked to reply.
*/
bool RSVP() const { return mRSVP; }
/**
Sets the delegate.
*/
void setDelegate( const TQString &delegate ) { mDelegate = delegate; }
/**
Returns the delegate.
*/
TQString delegate() const { return mDelegate; }
/**
Sets the delegator.
*/
void setDelegator( const TQString &delegator ) { mDelegator = delegator; }
/**
Returns the delegator.
*/
TQString delegator() const { return mDelegator; }
private:
bool mRSVP;
Role mRole;
PartStat mStatus;
TQString mUid;
TQString mDelegate;
TQString mDelegator;
class Private;
Private *d;
};
bool operator==( const Attendee& a1, const Attendee& a2 );
}
#endif