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.
98 lines
3.8 KiB
98 lines
3.8 KiB
/*
|
|
This file is part of KOrganizer.
|
|
Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
|
|
Copyright (c) 2004 David Faure <faure@kde.org>
|
|
Copyright (C) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
|
|
|
|
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.
|
|
|
|
As a special exception, permission is given to link this program
|
|
with any edition of TQt, and distribute the resulting executable,
|
|
without including the source code for TQt in the source distribution.
|
|
*/
|
|
#ifndef EVENTARCHIVER_H
|
|
#define EVENTARCHIVER_H
|
|
|
|
#include <tqobject.h>
|
|
#include <tqdatetime.h>
|
|
#include <libkcal/event.h>
|
|
|
|
namespace KCal {
|
|
class Calendar;
|
|
class Event;
|
|
}
|
|
using namespace KCal;
|
|
|
|
/**
|
|
* This class handles expiring and archiving of events.
|
|
* It is used directly by the archivedialog, and it is also
|
|
* triggered by actionmanager's timer for auto-archiving.
|
|
*
|
|
* The settings are not held in this class, but directly in KOPrefs (from korganizer.kcfg)
|
|
* Be sure to set mArchiveAction and mArchiveFile before a manual archiving
|
|
* mAutoArchive is used for auto archiving.
|
|
*/
|
|
class EventArchiver : public TQObject
|
|
{
|
|
Q_OBJECT
|
|
TQ_OBJECT
|
|
|
|
public:
|
|
EventArchiver( TQObject* parent = 0, const char* name = 0 );
|
|
virtual ~EventArchiver();
|
|
|
|
/**
|
|
* Delete or archive events once
|
|
* @param calendar the calendar to archive
|
|
* @param limitDate all events *before* the limitDate (not included) will be deleted/archived.
|
|
* @param widget parent widget for message boxes
|
|
* Confirmation and "no events to process" dialogs will be shown
|
|
*/
|
|
void runOnce( Calendar* calendar, const TQDate& limitDate, TQWidget* widget );
|
|
|
|
/**
|
|
* Delete or archive events. This is called regularly, when auto-archiving is enabled
|
|
* @param calendar the calendar to archive
|
|
* @param widget parent widget for message boxes
|
|
* @param withGUI whether this is called from the dialog, so message boxes should be shown.
|
|
* Note that error dialogs like "cannot save" are shown even if from this method, so widget
|
|
* should be set in all cases.
|
|
*/
|
|
void runAuto( Calendar* calendar, TQWidget* widget, bool withGUI );
|
|
|
|
signals:
|
|
void eventsDeleted();
|
|
|
|
private:
|
|
void run( Calendar* calendar, const TQDate& limitDate, TQWidget* widget, bool withGUI, bool errorIfNone );
|
|
|
|
void deleteIncidences( Calendar* calendar, const TQDate& limitDate, TQWidget* widget,
|
|
const Incidence::List& incidences, bool withGUI );
|
|
void archiveIncidences( Calendar* calendar, const TQDate& limitDate, TQWidget* widget,
|
|
const Incidence::List& incidences, bool withGUI );
|
|
|
|
/**
|
|
* Checks if all to-dos under @p todo and including @p todo were completed before @p limitDate.
|
|
* If not, we can't archive this to-do.
|
|
* @param todo root of the sub-tree we are checking
|
|
* @param limitDate
|
|
* @param checkedUids used internaly to prevent infinit recursion due to invalid calendar files
|
|
*/
|
|
bool isSubTreeComplete( const Todo *todo, const TQDate &limitDate,
|
|
TQStringList checkedUids = TQStringList() ) const;
|
|
};
|
|
|
|
#endif /* EVENTARCHIVER_H */
|