libkcal

calhelper.cpp
Go to the documentation of this file.
1/*
2 This file is part of the kcal library.
3
4 Copyright (c) 2009-2010 Klarälvdalens Datakonsult AB, a KDAB Group company <info@kdab.net>
5
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Library General Public
8 License as published by the Free Software Foundation; either
9 version 2 of the License, or (at your option) any later version.
10
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Library General Public 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
18 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 Boston, MA 02110-1301, USA.
20*/
32#include "calhelper.h"
33#include "calendarresources.h"
34
35using namespace KCal;
36
38{
39 CalendarResources *cal = dynamic_cast<CalendarResources*>( calendar );
40 if ( !cal || !incidence ) {
41 return true;
42 }
43
44 CalendarResourceManager *manager = cal->resourceManager();
45 CalendarResourceManager::Iterator it;
46 for ( it = manager->begin(); it != manager->end(); ++it ) {
47 TQString subRes = (*it)->subresourceIdentifier( incidence );
48 if ( !subRes.isEmpty() && !subRes.contains( "/.INBOX.directory/" ) ) {
49 return false;
50 }
51 }
52 return true;
53}
54
56{
57 return isMyKolabIncidence( calendar, incidence );
58}
59
61{
62 // Determine if this incidence is in my calendar (and owned by me)
63 Incidence *existingIncidence = 0;
64 if ( calendar ) {
65 existingIncidence = calendar->incidence( uid );
66 if ( !isMyCalendarIncidence( calendar, existingIncidence ) ) {
67 existingIncidence = 0;
68 }
69 if ( !existingIncidence ) {
70 const Incidence::List list = calendar->incidences();
71 for ( Incidence::List::ConstIterator it = list.begin(), end = list.end(); it != end; ++it ) {
72 if ( (*it)->schedulingID() == uid && isMyCalendarIncidence( calendar, *it ) ) {
73 existingIncidence = *it;
74 break;
75 }
76 }
77 }
78 }
79 return existingIncidence;
80}
81
83{
84 CalendarResources *cal = dynamic_cast<CalendarResources*>( calendar );
85 if ( !cal ) {
86 return true;
87 }
88
89 CalendarResourceManager *manager = cal->resourceManager();
90 CalendarResourceManager::Iterator it;
91 for ( it = manager->begin(); it != manager->end(); ++it ) {
92 TQString res = (*it)->type();
93 if ( res == "imap" ) {
94 return true;
95 }
96 }
97 return false;
98}
99
100bool CalHelper::hasMyWritableEventsFolders( const TQString &family )
101{
102 TQString myfamily = family;
103 if ( family.isEmpty() ) {
104 myfamily = "calendar";
105 }
106
107 CalendarResourceManager manager( myfamily );
108 manager.readConfig();
109
110 CalendarResourceManager::ActiveIterator it;
111 for ( it=manager.activeBegin(); it != manager.activeEnd(); ++it ) {
112 if ( (*it)->readOnly() ) {
113 continue;
114 }
115
116 const TQStringList subResources = (*it)->subresources();
117 if ( subResources.isEmpty() ) {
118 return true;
119 }
120
121 TQStringList::ConstIterator subIt;
122 for ( subIt=subResources.begin(); subIt != subResources.end(); ++subIt ) {
123 if ( !(*it)->subresourceActive( (*subIt) ) ) {
124 continue;
125 }
126 if ( (*it)->type() == "imap" || (*it)->type() == "kolab" ) {
127 if ( (*it)->subresourceType( ( *subIt ) ) == "todo" ||
128 (*it)->subresourceType( ( *subIt ) ) == "journal" ||
129 !(*subIt).contains( "/.INBOX.directory/" ) ) {
130 continue;
131 }
132 }
133 return true;
134 }
135 }
136 return false;
137}
138
140{
141 CalendarResources *cal = dynamic_cast<CalendarResources*>( calendar );
142 if ( !cal || !incidence ) {
143 return 0;
144 }
145
146 return cal->resource( incidence );
147}
148
149TQPair<ResourceCalendar *, TQString> CalHelper::incSubResourceCalendar( Calendar *calendar,
150 Incidence *incidence )
151{
152 TQPair<ResourceCalendar *, TQString> p( 0, TQString() );
153
154 CalendarResources *cal = dynamic_cast<CalendarResources*>( calendar );
155 if ( !cal || !incidence ) {
156 return p;
157 }
158
159 ResourceCalendar *res = cal->resource( incidence );
160
161 TQString subRes;
162 if ( res && res->canHaveSubresources() ) {
163 subRes = res->subresourceIdentifier( incidence );
164 }
165 p = qMakePair( res, subRes );
166 return p;
167}
Provides a Calendar composed of several Calendar Resources.
This file is part of the API for handling calendar data and provides static convenience functions for...
This class provides a Calendar which is composed of other Calendars known as "Resources".
ResourceCalendar * resource(Incidence *incidence)
Get the Resource associated with a specified Incidence.
CalendarResourceManager * resourceManager() const
Get the CalendarResourceManager used by this calendar.
This is the main "calendar" object class.
Definition: calendar.h:171
virtual Incidence::List incidences()
Return a filtered list of all Incidences for this Calendar.
Definition: calendar.cpp:178
Incidence * incidence(const TQString &uid)
Returns the Incidence associated with the given unique identifier.
Definition: calendar.cpp:576
This class provides the base class common to all calendar components.
Definition: incidence.h:48
This class provides the interfaces for a calendar resource.
virtual TQString subresourceIdentifier(Incidence *incidence)
Get the identifier of the subresource associated with a specified incidence.
virtual bool canHaveSubresources() const
Is this subresource capable of having subresources or not?
ResourceCalendar * incResourceCalendar(Calendar *calendar, Incidence *incidence)
Returns the ResourceCalendar where the Incidence is stored, if any.
Definition: calhelper.cpp:139
bool isMyKolabIncidence(Calendar *calendar, Incidence *incidence)
Determine if the specified incidence is likely a Kolab incidence owned by the the user.
Definition: calhelper.cpp:37
bool usingGroupware(Calendar *calendar)
Determines if the Calendar is using a Groupware resource type.
Definition: calhelper.cpp:82
TQPair< ResourceCalendar *, TQString > incSubResourceCalendar(Calendar *calendar, Incidence *incidence)
Returns the (ResourceCalendar, SubResourceCalendar) pair where the Incidence is stored,...
Definition: calhelper.cpp:149
bool isMyCalendarIncidence(Calendar *calendar, Incidence *incidence)
Determine if the specified incidence is likely owned by the the user, independent of the Resource typ...
Definition: calhelper.cpp:55
Incidence * findMyCalendarIncidenceByUid(Calendar *calendar, const TQString &uid)
Searches for the specified Incidence by UID, returning an Incidence pointer if and only if the found ...
Definition: calhelper.cpp:60
bool hasMyWritableEventsFolders(const TQString &family)
Determines if the Calendar has any writable folders with Events content that are owned by me.
Definition: calhelper.cpp:100
Namespace KCal is for global classes, objects and/or functions in libkcal.
Definition: alarm.h:38