• Skip to content
  • Skip to link menu
KDE 4.2 API Reference
  • KDE API Reference
  • kdepim
  • Sitemap
  • Contact Us
 

kalarm

alarmcalendar.h

Go to the documentation of this file.
00001 /*
00002  *  alarmcalendar.h  -  KAlarm calendar file access
00003  *  Program:  kalarm
00004  *  Copyright © 2001-2008 by David Jarvie <djarvie@kde.org>
00005  *
00006  *  This program is free software; you can redistribute it and/or modify
00007  *  it under the terms of the GNU General Public License as published by
00008  *  the Free Software Foundation; either version 2 of the License, or
00009  *  (at your option) any later version.
00010  *
00011  *  This program is distributed in the hope that it will be useful,
00012  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00013  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
00014  *  GNU General Public License for more details.
00015  *
00016  *  You should have received a copy of the GNU General Public License along
00017  *  with this program; if not, write to the Free Software Foundation, Inc.,
00018  *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
00019  */
00020 
00021 #ifndef ALARMCALENDAR_H
00022 #define ALARMCALENDAR_H
00023 
00024 #include <QObject>
00025 #include <kurl.h>
00026 #include "alarmevent.h"
00027 #include "alarmresources.h"
00028 
00029 namespace KCal {
00030   class Calendar;
00031   class CalendarLocal;
00032 }
00033 class AlarmResource;
00034 class ProgressDialog;
00035 
00036 
00041 class AlarmCalendar : public QObject
00042 {
00043         Q_OBJECT
00044     public:
00045         virtual ~AlarmCalendar();
00046         bool                  valid() const          { return (mCalType == RESOURCES) || mUrl.isValid(); }
00047         KCalEvent::Status     type() const           { return (mCalType == RESOURCES) ? KCalEvent::EMPTY : mEventType; }
00048         bool                  open();
00049         int                   load();
00050         void                  loadResource(AlarmResource*, QWidget* parent);
00051         bool                  reload();
00052         void                  reloadFromCache(const QString& resourceID);
00053         bool                  save();
00054         void                  close();
00055         void                  startUpdate();
00056         bool                  endUpdate();
00057         KAEvent*              earliestAlarm() const;
00058         void                  setAlarmPending(KAEvent*, bool pending = true);
00059         KAEvent::List         atLoginAlarms() const;
00060         KCal::Event*          createKCalEvent(const KAEvent* e, bool original = false, bool cancelCancelledDefer = false) const
00061                                                      { return createKCalEvent(e, QString(), original, cancelCancelledDefer); }
00062         KCal::Event*          createKCalEvent(const KAEvent*, const QString& baseID, bool original = false, bool cancelCancelledDefer = false) const;
00063         KAEvent*              event(const QString& uniqueID);
00064         KCal::Event*          kcalEvent(const QString& uniqueID);
00065         KAEvent*              templateEvent(const QString& templateName);
00066         KAEvent::List         events(KCalEvent::Status s = KCalEvent::EMPTY)   { return events(0, s); }
00067         KAEvent::List         events(AlarmResource*, KCalEvent::Status = KCalEvent::EMPTY);
00068         KAEvent::List         events(const KDateTime& from, const KDateTime& to, KCalEvent::Status);
00069         KCal::Event::List     kcalEvents(KCalEvent::Status s = KCalEvent::EMPTY)   { return kcalEvents(0, s); }
00070         KCal::Event::List     kcalEvents(AlarmResource*, KCalEvent::Status = KCalEvent::EMPTY);
00071         bool                  eventReadOnly(const QString& uniqueID) const;
00072         AlarmResource*        resourceForEvent(const QString& eventID) const;
00073         bool                  addEvent(KAEvent*, QWidget* promptParent = 0, bool useEventID = false, AlarmResource* = 0, bool noPrompt = false, bool* cancelled = 0);
00074         bool                  modifyEvent(const QString& oldEventId, KAEvent* newEvent);
00075         KAEvent*              updateEvent(const KAEvent&);
00076         KAEvent*              updateEvent(const KAEvent*);
00077         bool                  deleteEvent(const QString& eventID, bool save = false);
00078         void                  emitEmptyStatus();
00079         void                  purgeEvents(const KAEvent::List&);
00080         bool                  isOpen() const         { return mOpen; }
00081         bool                  isEmpty() const;
00082         QString               path() const           { return (mCalType == RESOURCES) ? QString() : mUrl.prettyUrl(); }
00083         QString               urlString() const      { return (mCalType == RESOURCES) ? QString() : mUrl.url(); }
00084 
00085         static QString        icalProductId();
00086         static bool           initialiseCalendars();
00087         static void           terminateCalendars();
00088         static AlarmCalendar* resources()            { return mResourcesCalendar; }
00089         static AlarmCalendar* displayCalendar()      { return mDisplayCalendar; }
00090         static AlarmCalendar* displayCalendarOpen();
00091         static bool           importAlarms(QWidget*, AlarmResource* = 0);
00092         static KAEvent*       getEvent(const QString& uniqueID);
00093         static const KCal::Event* getKCalEvent(const QString& uniqueID);
00094 
00095     signals:
00096         void                  earliestAlarmChanged();
00097         void                  calendarSaved(AlarmCalendar*);
00098         void                  emptyStatus(bool empty);
00099 
00100     private slots:
00101         void                  slotCacheDownloaded(AlarmResource*);
00102         void                  slotResourceLoaded(AlarmResource*, bool success);
00103         void                  slotResourceChange(AlarmResource*, AlarmResources::Change);
00104 
00105     private:
00106         enum CalType { RESOURCES, LOCAL_ICAL, LOCAL_VCAL };
00107         typedef QMap<AlarmResource*, KAEvent::List> ResourceMap;  // resource = null for display calendar
00108         typedef QMap<QString, KAEvent*> KAEventMap;  // indexed by event UID
00109         typedef QMap<AlarmResource*, KAEvent*> EarliestMap;
00110 
00111         AlarmCalendar();
00112         AlarmCalendar(const QString& file, KCalEvent::Status);
00113         bool                  saveCal(const QString& newFile = QString());
00114         bool                  addEvent(AlarmResource*, KAEvent*);
00115         KAEvent*              addEvent(AlarmResource*, const KCal::Event*);
00116         void                  addNewEvent(AlarmResource*, KAEvent*);
00117         KCalEvent::Status     deleteEventInternal(const QString& eventID);
00118         void                  updateKAEvents(AlarmResource*, KCal::CalendarLocal*);
00119         static void           updateResourceKAEvents(AlarmResource*, KCal::CalendarLocal*);
00120         void                  removeKAEvents(AlarmResource*, bool closing = false);
00121         void                  findEarliestAlarm(AlarmResource*);
00122 
00123         static AlarmCalendar* mResourcesCalendar;  // the calendar resources
00124         static AlarmCalendar* mDisplayCalendar;    // the display calendar
00125 
00126         KCal::Calendar*       mCalendar;           // AlarmResources or CalendarLocal
00127         ResourceMap           mResourceMap;
00128         KAEventMap            mEventMap;           // lookup of all events by UID
00129         EarliestMap           mEarliestAlarm;      // alarm with earliest trigger time, by resource
00130         QList<QString>        mPendingAlarms;      // IDs of alarms which are currently being processed after triggering
00131         KUrl                  mUrl;                // URL of current calendar file
00132         KUrl                  mICalUrl;            // URL of iCalendar file
00133         typedef QMap<AlarmResource*, ProgressDialog*> ProgressDlgMap;
00134         typedef QMap<AlarmResource*, QWidget*> ResourceWidgetMap;
00135         ProgressDlgMap        mProgressDlgs;       // download progress dialogues
00136         ResourceWidgetMap     mProgressParents;    // parent widgets for download progress dialogues
00137         QString               mLocalFile;          // calendar file, or local copy if it's a remote file
00138         CalType               mCalType;            // what type of calendar mCalendar is (resources/ical/vcal)
00139         KCalEvent::Status     mEventType;          // what type of events the calendar file is for
00140         bool                  mOpen;               // true if the calendar file is open
00141         int                   mUpdateCount;        // nesting level of group of calendar update calls
00142         bool                  mUpdateSave;         // save() was called while mUpdateCount > 0
00143 
00144         using QObject::event;   // prevent "hidden" warning
00145 };
00146 
00147 #endif // ALARMCALENDAR_H

kalarm

Skip menu "kalarm"
  • Main Page
  • Namespace List
  • Class Hierarchy
  • Alphabetical List
  • Class List
  • File List
  • Namespace Members
  • Class Members

kdepim

Skip menu "kdepim"
  • akonadi
  •   clients
  •   kabc
  •   kcal
  •   kcm
  • akregator
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt
  • kdgantt1
  • kjots
  • kleopatra
  • kmail
  • kmobiletools
  • knode
  • knotes
  • kontact
  • kontactinterfaces
  • korganizer
  •   korgac
  • kpilot
  • ktimetracker
  • libkdepim
  • libkholidays
  • libkleo
  • libkpgp
  • maildir
Generated for kdepim by doxygen 1.5.4
This website is maintained by Adriaan de Groot and Allen Winter.
KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal