1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/*
This file is part of KOrganizer.
Copyright (c) 2000,2001 Cornelius Schumacher <[email protected]>
Copyright (c) 2004 David Faure <[email protected]>
Copyright (C) 2004 Reinhold Kainhofer <[email protected]>
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
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 */
|