|
|
|
/*
|
|
|
|
This file is part of libkcal.
|
|
|
|
|
|
|
|
Copyright (c) 2009-2010 Klarälvdalens Datakonsult AB, a KDAB Group company <info@kdab.net>
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
@file
|
|
|
|
This file is part of the API for handling calendar data and provides
|
|
|
|
static convenience functions for making decisions about calendar data.
|
|
|
|
|
|
|
|
@author Allen Winter \<allen@kdab.net\>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef KCAL_CALHELPER_H
|
|
|
|
#define KCAL_CALHELPER_H
|
|
|
|
|
|
|
|
class TQString;
|
|
|
|
#include <tqpair.h>
|
|
|
|
|
|
|
|
namespace KCal {
|
|
|
|
class Calendar;
|
|
|
|
class Incidence;
|
|
|
|
class ResourceCalendar;
|
|
|
|
|
|
|
|
/**
|
|
|
|
@brief
|
|
|
|
Provides methods for making decisions about calendar data.
|
|
|
|
*/
|
|
|
|
namespace CalHelper {
|
|
|
|
|
|
|
|
/**
|
|
|
|
Determine if the specified incidence is likely a Kolab incidence
|
|
|
|
owned by the the user.
|
|
|
|
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
@param incidence is a pointer to an Incidence object.
|
|
|
|
|
|
|
|
@return true if it is likely that the specified incidence belongs
|
|
|
|
to the user in their Kolab resource; false otherwise.
|
|
|
|
*/
|
|
|
|
bool isMyKolabIncidence( Calendar *calendar, Incidence *incidence );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Determine if the specified incidence is likely owned by the the user,
|
|
|
|
independent of the Resource type.
|
|
|
|
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
@param incidence is a pointer to an Incidence object.
|
|
|
|
|
|
|
|
@return true if it is likely that the specified incidence belongs
|
|
|
|
to the user; false otherwise.
|
|
|
|
*/
|
|
|
|
bool isMyCalendarIncidence( Calendar *calendar, Incidence *incidence );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Searches for the specified Incidence by UID, returning an Incidence pointer
|
|
|
|
if and only if the found Incidence is owned by the user.
|
|
|
|
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
@param Uid is a TQString containing an Incidence UID.
|
|
|
|
|
|
|
|
@return a pointer to the Incidence found; 0 if the Incidence is not found
|
|
|
|
or the Incidence is found but is not owned by the user.
|
|
|
|
*/
|
|
|
|
Incidence *findMyCalendarIncidenceByUid( Calendar *calendar, const TQString &uid );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Determines if the Calendar is using a Groupware resource type.
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
|
|
|
|
@return true if the Calendar is using a known Groupware resource type;
|
|
|
|
false otherwise.
|
|
|
|
@since 4.4
|
|
|
|
*/
|
|
|
|
bool usingGroupware( Calendar *calendar );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Determines if the Calendar has any writable folders with Events content
|
|
|
|
that are owned by me.
|
|
|
|
@param family is the resource family name or "calendar" if empty.
|
|
|
|
|
|
|
|
@return true if the any such writable folders are found; false otherwise.
|
|
|
|
@since 4.5
|
|
|
|
*/
|
|
|
|
bool hasMyWritableEventsFolders( const TQString &family );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the ResourceCalendar where the Incidence is stored, if any.
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
@param incidence is a pointer to an Incidence object.
|
|
|
|
|
|
|
|
@return a pointer to the ResourceCalendar where the Incidence is stored;
|
|
|
|
else 0 if none can be found.
|
|
|
|
@since 4.5
|
|
|
|
*/
|
|
|
|
ResourceCalendar *incResourceCalendar( Calendar *calendar, Incidence *incidence );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the (ResourceCalendar, SubResourceCalendar) pair where the
|
|
|
|
Incidence is stored, if any.
|
|
|
|
@param calendar is a pointer to a valid Calendar object.
|
|
|
|
@param incidence is a pointer to an Incidence object.
|
|
|
|
|
|
|
|
@return a TQPair containing a pointer to the Incidence's ResourceCalendar
|
|
|
|
in the 'first' element of the TQPair and the SubResourceCalendar in the
|
|
|
|
'second' element.
|
|
|
|
|
|
|
|
@note many resource types do not support subresources, so the 'second'
|
|
|
|
element will be an empty TQString in those situations.
|
|
|
|
@since 4.5
|
|
|
|
*/
|
|
|
|
TQPair<ResourceCalendar *, TQString> incSubResourceCalendar( Calendar *calendar,
|
|
|
|
Incidence *incidence );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|