author | sandman <sandman> | 2002-06-09 23:42:42 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-06-09 23:42:42 (UTC) |
commit | 1c56ab829f04ea5b127c1c632cec330e47bca524 (patch) (unidiff) | |
tree | 30f0bd7c2d124cbf2dc41f32234922d2f3be19a7 | |
parent | 25d084dd1a4b69cefcf16a889f22feb39d60f541 (diff) | |
download | opie-1c56ab829f04ea5b127c1c632cec330e47bca524.zip opie-1c56ab829f04ea5b127c1c632cec330e47bca524.tar.gz opie-1c56ab829f04ea5b127c1c632cec330e47bca524.tar.bz2 |
Fixed a counter bug in alarm timer loop.
-rw-r--r-- | core/pim/datebook/datebook.cpp | 14 | ||||
-rw-r--r-- | core/pim/datebook/datebook.h | 2 |
2 files changed, 9 insertions, 7 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp index 8614b3f..2c2965e 100644 --- a/core/pim/datebook/datebook.cpp +++ b/core/pim/datebook/datebook.cpp | |||
@@ -1,989 +1,989 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | ** $Id$ | 19 | ** $Id$ |
20 | ** | 20 | ** |
21 | **********************************************************************/ | 21 | **********************************************************************/ |
22 | 22 | ||
23 | #define QTOPIA_INTERNAL_FD | 23 | #define QTOPIA_INTERNAL_FD |
24 | 24 | ||
25 | #include "datebook.h" | 25 | #include "datebook.h" |
26 | #include "datebookday.h" | 26 | #include "datebookday.h" |
27 | #include "datebooksettings.h" | 27 | #include "datebooksettings.h" |
28 | #include "datebookweek.h" | 28 | #include "datebookweek.h" |
29 | #include "datebookweeklst.h" | 29 | #include "datebookweeklst.h" |
30 | #include "dateentryimpl.h" | 30 | #include "dateentryimpl.h" |
31 | 31 | ||
32 | #include <qpe/datebookmonth.h> | 32 | #include <qpe/datebookmonth.h> |
33 | #include <qpe/qpeapplication.h> | 33 | #include <qpe/qpeapplication.h> |
34 | #include <qpe/config.h> | 34 | #include <qpe/config.h> |
35 | #include <qpe/qpedebug.h> | 35 | #include <qpe/qpedebug.h> |
36 | #include <qpe/event.h> | 36 | #include <qpe/event.h> |
37 | #include <qpe/finddialog.h> | 37 | #include <qpe/finddialog.h> |
38 | #include <qpe/ir.h> | 38 | #include <qpe/ir.h> |
39 | #include <qpe/qpemenubar.h> | 39 | #include <qpe/qpemenubar.h> |
40 | #include <qpe/qpemessagebox.h> | 40 | #include <qpe/qpemessagebox.h> |
41 | #include <qpe/resource.h> | 41 | #include <qpe/resource.h> |
42 | #include <qpe/sound.h> | 42 | #include <qpe/sound.h> |
43 | #include <qpe/timestring.h> | 43 | #include <qpe/timestring.h> |
44 | #include <qpe/qpetoolbar.h> | 44 | #include <qpe/qpetoolbar.h> |
45 | #include <qpe/tzselect.h> | 45 | #include <qpe/tzselect.h> |
46 | #include <qpe/xmlreader.h> | 46 | #include <qpe/xmlreader.h> |
47 | 47 | ||
48 | #include <qaction.h> | 48 | #include <qaction.h> |
49 | #include <qcopchannel_qws.h> | 49 | #include <qcopchannel_qws.h> |
50 | #include <qdatetime.h> | 50 | #include <qdatetime.h> |
51 | #include <qdialog.h> | 51 | #include <qdialog.h> |
52 | #include <qfile.h> | 52 | #include <qfile.h> |
53 | #include <qlabel.h> | 53 | #include <qlabel.h> |
54 | #include <qlayout.h> | 54 | #include <qlayout.h> |
55 | #include <qmessagebox.h> | 55 | #include <qmessagebox.h> |
56 | #include <qpopupmenu.h> | 56 | #include <qpopupmenu.h> |
57 | #include <qpushbutton.h> | 57 | #include <qpushbutton.h> |
58 | #include <qregexp.h> | 58 | #include <qregexp.h> |
59 | #include <qtextcodec.h> | 59 | #include <qtextcodec.h> |
60 | #include <qtextstream.h> | 60 | #include <qtextstream.h> |
61 | #include <qtl.h> | 61 | #include <qtl.h> |
62 | #include <qwidgetstack.h> | 62 | #include <qwidgetstack.h> |
63 | #include <qwindowsystem_qws.h> | 63 | #include <qwindowsystem_qws.h> |
64 | 64 | ||
65 | #include <sys/stat.h> | 65 | #include <sys/stat.h> |
66 | #include <sys/types.h> | 66 | #include <sys/types.h> |
67 | #include <fcntl.h> | 67 | #include <fcntl.h> |
68 | #include <unistd.h> | 68 | #include <unistd.h> |
69 | 69 | ||
70 | #include <stdlib.h> | 70 | #include <stdlib.h> |
71 | 71 | ||
72 | #define DAY 1 | 72 | #define DAY 1 |
73 | #define WEEK 2 | 73 | #define WEEK 2 |
74 | #define WEEKLST 4 | 74 | #define WEEKLST 4 |
75 | #define MONTH 3 | 75 | #define MONTH 3 |
76 | 76 | ||
77 | 77 | ||
78 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | 78 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) |
79 | : QMainWindow( parent, "datebook", f ), | 79 | : QMainWindow( parent, "datebook", f ), |
80 | aPreset( FALSE ), | 80 | aPreset( FALSE ), |
81 | presetTime( -1 ), | 81 | presetTime( -1 ), |
82 | startTime( 8 ), // an acceptable default | 82 | startTime( 8 ), // an acceptable default |
83 | syncing(FALSE), | 83 | syncing(FALSE), |
84 | inSearch(FALSE) | 84 | inSearch(FALSE), |
85 | alarmCounter(0) | ||
85 | { | 86 | { |
86 | QTime t; | 87 | QTime t; |
87 | t.start(); | 88 | t.start(); |
88 | db = new DateBookDBHack; | 89 | db = new DateBookDBHack; |
89 | qDebug("loading db t=%d", t.elapsed() ); | 90 | qDebug("loading db t=%d", t.elapsed() ); |
90 | loadSettings(); | 91 | loadSettings(); |
91 | setCaption( tr("Calendar") ); | 92 | setCaption( tr("Calendar") ); |
92 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); | 93 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); |
93 | 94 | ||
94 | setToolBarsMovable( FALSE ); | 95 | setToolBarsMovable( FALSE ); |
95 | 96 | ||
96 | views = new QWidgetStack( this ); | 97 | views = new QWidgetStack( this ); |
97 | setCentralWidget( views ); | 98 | setCentralWidget( views ); |
98 | 99 | ||
99 | dayView = 0; | 100 | dayView = 0; |
100 | weekView = 0; | 101 | weekView = 0; |
101 | weekLstView = 0; | 102 | weekLstView = 0; |
102 | monthView = 0; | 103 | monthView = 0; |
103 | 104 | ||
104 | QPEToolBar *bar = new QPEToolBar( this ); | 105 | QPEToolBar *bar = new QPEToolBar( this ); |
105 | bar->setHorizontalStretchable( TRUE ); | 106 | bar->setHorizontalStretchable( TRUE ); |
106 | 107 | ||
107 | QPEMenuBar *mb = new QPEMenuBar( bar ); | 108 | QPEMenuBar *mb = new QPEMenuBar( bar ); |
108 | mb->setMargin( 0 ); | 109 | mb->setMargin( 0 ); |
109 | 110 | ||
110 | QPEToolBar *sub_bar = new QPEToolBar(this); | 111 | QPEToolBar *sub_bar = new QPEToolBar(this); |
111 | 112 | ||
112 | QPopupMenu *view = new QPopupMenu( this ); | 113 | QPopupMenu *view = new QPopupMenu( this ); |
113 | QPopupMenu *settings = new QPopupMenu( this ); | 114 | QPopupMenu *settings = new QPopupMenu( this ); |
114 | 115 | ||
115 | mb->insertItem( tr( "View" ), view ); | 116 | mb->insertItem( tr( "View" ), view ); |
116 | mb->insertItem( tr( "Settings" ), settings ); | 117 | mb->insertItem( tr( "Settings" ), settings ); |
117 | 118 | ||
118 | QActionGroup *g = new QActionGroup( this ); | 119 | QActionGroup *g = new QActionGroup( this ); |
119 | g->setExclusive( TRUE ); | 120 | g->setExclusive( TRUE ); |
120 | 121 | ||
121 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), | 122 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), |
122 | QString::null, 0, this, 0 ); | 123 | QString::null, 0, this, 0 ); |
123 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); | 124 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); |
124 | a->addTo( sub_bar ); | 125 | a->addTo( sub_bar ); |
125 | 126 | ||
126 | a = new QAction( tr( "Today" ), Resource::loadPixmap( "to_day" ), QString::null, 0, g, 0 ); | 127 | a = new QAction( tr( "Today" ), Resource::loadPixmap( "to_day" ), QString::null, 0, g, 0 ); |
127 | connect( a, SIGNAL( activated() ), this, SLOT( slotToday() ) ); | 128 | connect( a, SIGNAL( activated() ), this, SLOT( slotToday() ) ); |
128 | a->addTo( sub_bar ); | 129 | a->addTo( sub_bar ); |
129 | a->addTo( view ); | 130 | a->addTo( view ); |
130 | 131 | ||
131 | a = new QAction( tr( "Day" ), Resource::loadPixmap( "day" ), QString::null, 0, g, 0 ); | 132 | a = new QAction( tr( "Day" ), Resource::loadPixmap( "day" ), QString::null, 0, g, 0 ); |
132 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); | 133 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); |
133 | a->addTo( sub_bar ); | 134 | a->addTo( sub_bar ); |
134 | a->addTo( view ); | 135 | a->addTo( view ); |
135 | a->setToggleAction( TRUE ); | 136 | a->setToggleAction( TRUE ); |
136 | a->setOn( TRUE ); | 137 | a->setOn( TRUE ); |
137 | dayAction = a; | 138 | dayAction = a; |
138 | 139 | ||
139 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); | 140 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); |
140 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); | 141 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); |
141 | a->addTo( sub_bar ); | 142 | a->addTo( sub_bar ); |
142 | a->addTo( view ); | 143 | a->addTo( view ); |
143 | a->setToggleAction( TRUE ); | 144 | a->setToggleAction( TRUE ); |
144 | weekAction = a; | 145 | weekAction = a; |
145 | 146 | ||
146 | a = new QAction( tr( "WeekLst" ), Resource::loadPixmap( "weeklst" ), QString::null, 0, g, 0 ); | 147 | a = new QAction( tr( "WeekLst" ), Resource::loadPixmap( "weeklst" ), QString::null, 0, g, 0 ); |
147 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeekLst() ) ); | 148 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeekLst() ) ); |
148 | a->addTo( sub_bar ); | 149 | a->addTo( sub_bar ); |
149 | a->addTo( view ); | 150 | a->addTo( view ); |
150 | a->setToggleAction( TRUE ); | 151 | a->setToggleAction( TRUE ); |
151 | weekLstAction = a; | 152 | weekLstAction = a; |
152 | 153 | ||
153 | a = new QAction( tr( "Month" ), Resource::loadPixmap( "month" ), QString::null, 0, g, 0 ); | 154 | a = new QAction( tr( "Month" ), Resource::loadPixmap( "month" ), QString::null, 0, g, 0 ); |
154 | connect( a, SIGNAL( activated() ), this, SLOT( viewMonth() ) ); | 155 | connect( a, SIGNAL( activated() ), this, SLOT( viewMonth() ) ); |
155 | a->addTo( sub_bar ); | 156 | a->addTo( sub_bar ); |
156 | a->addTo( view ); | 157 | a->addTo( view ); |
157 | a->setToggleAction( TRUE ); | 158 | a->setToggleAction( TRUE ); |
158 | monthAction = a; | 159 | monthAction = a; |
159 | 160 | ||
160 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ), QString::null, 0, g, 0 ); | 161 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ), QString::null, 0, g, 0 ); |
161 | connect( a, SIGNAL(activated()), this, SLOT(slotFind()) ); | 162 | connect( a, SIGNAL(activated()), this, SLOT(slotFind()) ); |
162 | a->addTo( sub_bar ); | 163 | a->addTo( sub_bar ); |
163 | 164 | ||
164 | a = new QAction( tr( "Alarm and Start Time..." ), QString::null, 0, 0 ); | 165 | a = new QAction( tr( "Alarm and Start Time..." ), QString::null, 0, 0 ); |
165 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); | 166 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); |
166 | a->addTo( settings ); | 167 | a->addTo( settings ); |
167 | 168 | ||
168 | QPopupMenu *default_view = new QPopupMenu(this); | 169 | QPopupMenu *default_view = new QPopupMenu(this); |
169 | settings->insertItem( tr( "Default View" ),default_view ); | 170 | settings->insertItem( tr( "Default View" ),default_view ); |
170 | default_view->setCheckable(TRUE); | 171 | default_view->setCheckable(TRUE); |
171 | 172 | ||
172 | Config config("DateBook"); | 173 | Config config("DateBook"); |
173 | config.setGroup("Main"); | 174 | config.setGroup("Main"); |
174 | int current=config.readNumEntry("defaultview", DAY); | 175 | int current=config.readNumEntry("defaultview", DAY); |
175 | 176 | ||
176 | QActionGroup *ag = new QActionGroup(this); | 177 | QActionGroup *ag = new QActionGroup(this); |
177 | a = new QAction( tr( "Day" ), QString::null, 0, 0, 0, true ); | 178 | a = new QAction( tr( "Day" ), QString::null, 0, 0, 0, true ); |
178 | if (current==DAY) a->setOn(true), viewDay(); | 179 | if (current==DAY) a->setOn(true), viewDay(); |
179 | ag->insert(a); | 180 | ag->insert(a); |
180 | a = new QAction( tr( "Week" ), QString::null, 0, 0, 0, true ); | 181 | a = new QAction( tr( "Week" ), QString::null, 0, 0, 0, true ); |
181 | if (current==WEEK) a->setOn(true), viewWeek(); | 182 | if (current==WEEK) a->setOn(true), viewWeek(); |
182 | ag->insert(a); | 183 | ag->insert(a); |
183 | a = new QAction( tr( "WeekLst" ), QString::null, 0, 0, 0, true ); | 184 | a = new QAction( tr( "WeekLst" ), QString::null, 0, 0, 0, true ); |
184 | if (current==WEEKLST) a->setOn(true), viewWeekLst(); | 185 | if (current==WEEKLST) a->setOn(true), viewWeekLst(); |
185 | ag->insert(a); | 186 | ag->insert(a); |
186 | a = new QAction( tr( "Month" ), QString::null, 0, 0, 0, true ); | 187 | a = new QAction( tr( "Month" ), QString::null, 0, 0, 0, true ); |
187 | if (current==MONTH) a->setOn(true), viewMonth(); | 188 | if (current==MONTH) a->setOn(true), viewMonth(); |
188 | ag->insert(a); | 189 | ag->insert(a); |
189 | 190 | ||
190 | ag->addTo(default_view); | 191 | ag->addTo(default_view); |
191 | connect(ag, SIGNAL( selected ( QAction * ) ), | 192 | connect(ag, SIGNAL( selected ( QAction * ) ), |
192 | this, SLOT( newDefaultView(QAction *) ) | 193 | this, SLOT( newDefaultView(QAction *) ) |
193 | ); | 194 | ); |
194 | 195 | ||
195 | connect( qApp, SIGNAL(clockChanged(bool)), | 196 | connect( qApp, SIGNAL(clockChanged(bool)), |
196 | this, SLOT(changeClock(bool)) ); | 197 | this, SLOT(changeClock(bool)) ); |
197 | connect( qApp, SIGNAL(weekChanged(bool)), | 198 | connect( qApp, SIGNAL(weekChanged(bool)), |
198 | this, SLOT(changeWeek(bool)) ); | 199 | this, SLOT(changeWeek(bool)) ); |
199 | 200 | ||
200 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 201 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
201 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), | 202 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), |
202 | this, SLOT(appMessage(const QCString&, const QByteArray&)) ); | 203 | this, SLOT(appMessage(const QCString&, const QByteArray&)) ); |
203 | #endif | 204 | #endif |
204 | 205 | ||
205 | // listen on QPE/System | 206 | // listen on QPE/System |
206 | #if defined(Q_WS_QWS) | 207 | #if defined(Q_WS_QWS) |
207 | #if !defined(QT_NO_COP) | 208 | #if !defined(QT_NO_COP) |
208 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); | 209 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); |
209 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 210 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
210 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | 211 | this, SLOT(receive(const QCString&, const QByteArray&)) ); |
211 | channel = new QCopChannel( "QPE/Datebook", this ); | 212 | channel = new QCopChannel( "QPE/Datebook", this ); |
212 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 213 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
213 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | 214 | this, SLOT(receive(const QCString&, const QByteArray&)) ); |
214 | qDebug("olle\n"); | 215 | qDebug("olle\n"); |
215 | #endif | 216 | #endif |
216 | #endif | 217 | #endif |
217 | 218 | ||
218 | qDebug("done t=%d", t.elapsed() ); | 219 | qDebug("done t=%d", t.elapsed() ); |
219 | 220 | ||
220 | } | 221 | } |
221 | 222 | ||
222 | void DateBook::receive( const QCString &msg, const QByteArray &data ) | 223 | void DateBook::receive( const QCString &msg, const QByteArray &data ) |
223 | { | 224 | { |
224 | QDataStream stream( data, IO_ReadOnly ); | 225 | QDataStream stream( data, IO_ReadOnly ); |
225 | if ( msg == "timeChange(QString)" ) { | 226 | if ( msg == "timeChange(QString)" ) { |
226 | // update active view! | 227 | // update active view! |
227 | if ( dayAction->isOn() ) | 228 | if ( dayAction->isOn() ) |
228 | viewDay(); | 229 | viewDay(); |
229 | else if ( weekAction->isOn() ) | 230 | else if ( weekAction->isOn() ) |
230 | viewWeek(); | 231 | viewWeek(); |
231 | else if ( monthAction->isOn() ) | 232 | else if ( monthAction->isOn() ) |
232 | viewMonth(); | 233 | viewMonth(); |
233 | } | 234 | } |
234 | else if (msg == "editEvent(int)") { | 235 | else if (msg == "editEvent(int)") { |
235 | int uid; | 236 | int uid; |
236 | stream >> uid; | 237 | stream >> uid; |
237 | Event e=db->eventByUID(uid); | 238 | Event e=db->eventByUID(uid); |
238 | editEvent(e); | 239 | editEvent(e); |
239 | } | 240 | } |
240 | } | 241 | } |
241 | 242 | ||
242 | DateBook::~DateBook() | 243 | DateBook::~DateBook() |
243 | { | 244 | { |
244 | } | 245 | } |
245 | 246 | ||
246 | void DateBook::slotSettings() | 247 | void DateBook::slotSettings() |
247 | { | 248 | { |
248 | DateBookSettings frmSettings( ampm, this ); | 249 | DateBookSettings frmSettings( ampm, this ); |
249 | frmSettings.setStartTime( startTime ); | 250 | frmSettings.setStartTime( startTime ); |
250 | frmSettings.setAlarmPreset( aPreset, presetTime ); | 251 | frmSettings.setAlarmPreset( aPreset, presetTime ); |
251 | #if defined (Q_WS_QWS) || defined(_WS_QWS_) | 252 | #if defined (Q_WS_QWS) || defined(_WS_QWS_) |
252 | frmSettings.showMaximized(); | 253 | frmSettings.showMaximized(); |
253 | #endif | 254 | #endif |
254 | 255 | ||
255 | if ( frmSettings.exec() ) { | 256 | if ( frmSettings.exec() ) { |
256 | aPreset = frmSettings.alarmPreset(); | 257 | aPreset = frmSettings.alarmPreset(); |
257 | presetTime = frmSettings.presetTime(); | 258 | presetTime = frmSettings.presetTime(); |
258 | startTime = frmSettings.startTime(); | 259 | startTime = frmSettings.startTime(); |
259 | if ( dayView ) | 260 | if ( dayView ) |
260 | dayView->setStartViewTime( startTime ); | 261 | dayView->setStartViewTime( startTime ); |
261 | if ( weekView ) | 262 | if ( weekView ) |
262 | weekView->setStartViewTime( startTime ); | 263 | weekView->setStartViewTime( startTime ); |
263 | saveSettings(); | 264 | saveSettings(); |
264 | 265 | ||
265 | // make the change obvious | 266 | // make the change obvious |
266 | if ( views->visibleWidget() ) { | 267 | if ( views->visibleWidget() ) { |
267 | if ( views->visibleWidget() == dayView ) | 268 | if ( views->visibleWidget() == dayView ) |
268 | dayView->redraw(); | 269 | dayView->redraw(); |
269 | else if ( views->visibleWidget() == weekView ) | 270 | else if ( views->visibleWidget() == weekView ) |
270 | weekView->redraw(); | 271 | weekView->redraw(); |
271 | } | 272 | } |
272 | } | 273 | } |
273 | } | 274 | } |
274 | 275 | ||
275 | void DateBook::fileNew() | 276 | void DateBook::fileNew() |
276 | { | 277 | { |
277 | slotNewEventFromKey(""); | 278 | slotNewEventFromKey(""); |
278 | } | 279 | } |
279 | 280 | ||
280 | QString DateBook::checkEvent(const Event &e) | 281 | QString DateBook::checkEvent(const Event &e) |
281 | { | 282 | { |
282 | /* check if overlaps with itself */ | 283 | /* check if overlaps with itself */ |
283 | bool checkFailed = FALSE; | 284 | bool checkFailed = FALSE; |
284 | 285 | ||
285 | /* check the next 12 repeats. should catch most problems */ | 286 | /* check the next 12 repeats. should catch most problems */ |
286 | QDate current_date = e.start().date(); | 287 | QDate current_date = e.start().date(); |
287 | Event previous = e; | 288 | Event previous = e; |
288 | for(int i = 0; i < 12; i++) | 289 | for(int i = 0; i < 12; i++) |
289 | { | 290 | { |
290 | QDateTime next; | 291 | QDateTime next; |
291 | if (!nextOccurance(previous, current_date.addDays(1), next)) { | 292 | if (!nextOccurance(previous, current_date.addDays(1), next)) { |
292 | break; // no more repeats | 293 | break; // no more repeats |
293 | } | 294 | } |
294 | if(next < previous.end()) { | 295 | if(next < previous.end()) { |
295 | checkFailed = TRUE; | 296 | checkFailed = TRUE; |
296 | break; | 297 | break; |
297 | } | 298 | } |
298 | current_date = next.date(); | 299 | current_date = next.date(); |
299 | } | 300 | } |
300 | 301 | ||
301 | if(checkFailed) | 302 | if(checkFailed) |
302 | return tr("Event duration is potentially longer\n" | 303 | return tr("Event duration is potentially longer\n" |
303 | "than interval between repeats."); | 304 | "than interval between repeats."); |
304 | 305 | ||
305 | return QString::null; | 306 | return QString::null; |
306 | } | 307 | } |
307 | 308 | ||
308 | QDate DateBook::currentDate() | 309 | QDate DateBook::currentDate() |
309 | { | 310 | { |
310 | QDate d = QDate::currentDate(); | 311 | QDate d = QDate::currentDate(); |
311 | 312 | ||
312 | if ( dayView && views->visibleWidget() == dayView ) { | 313 | if ( dayView && views->visibleWidget() == dayView ) { |
313 | d = dayView->date(); | 314 | d = dayView->date(); |
314 | } else if ( weekView && views->visibleWidget() == weekView ) { | 315 | } else if ( weekView && views->visibleWidget() == weekView ) { |
315 | d = weekView->date(); | 316 | d = weekView->date(); |
316 | } else if ( weekLstView && views->visibleWidget() == weekLstView ) { | 317 | } else if ( weekLstView && views->visibleWidget() == weekLstView ) { |
317 | d = weekLstView->date(); | 318 | d = weekLstView->date(); |
318 | } else if ( monthView && views->visibleWidget() == monthView ) { | 319 | } else if ( monthView && views->visibleWidget() == monthView ) { |
319 | d = monthView->selectedDate(); | 320 | d = monthView->selectedDate(); |
320 | } | 321 | } |
321 | 322 | ||
322 | return d; | 323 | return d; |
323 | } | 324 | } |
324 | 325 | ||
325 | void DateBook::view(int v, const QDate &d) { | 326 | void DateBook::view(int v, const QDate &d) { |
326 | if (v==DAY) { | 327 | if (v==DAY) { |
327 | initDay(); | 328 | initDay(); |
328 | dayAction->setOn( TRUE ); | 329 | dayAction->setOn( TRUE ); |
329 | dayView->setDate( d ); | 330 | dayView->setDate( d ); |
330 | views->raiseWidget( dayView ); | 331 | views->raiseWidget( dayView ); |
331 | dayView->redraw(); | 332 | dayView->redraw(); |
332 | } else if (v==WEEK) { | 333 | } else if (v==WEEK) { |
333 | initWeek(); | 334 | initWeek(); |
334 | weekAction->setOn( TRUE ); | 335 | weekAction->setOn( TRUE ); |
335 | weekView->setDate( d ); | 336 | weekView->setDate( d ); |
336 | views->raiseWidget( weekView ); | 337 | views->raiseWidget( weekView ); |
337 | weekView->redraw(); | 338 | weekView->redraw(); |
338 | } else if (v==WEEKLST) { | 339 | } else if (v==WEEKLST) { |
339 | initWeekLst(); | 340 | initWeekLst(); |
340 | weekLstAction->setOn( TRUE ); | 341 | weekLstAction->setOn( TRUE ); |
341 | weekLstView->setDate(d); | 342 | weekLstView->setDate(d); |
342 | views->raiseWidget( weekLstView ); | 343 | views->raiseWidget( weekLstView ); |
343 | weekLstView->redraw(); | 344 | weekLstView->redraw(); |
344 | } else if (v==MONTH) { | 345 | } else if (v==MONTH) { |
345 | initMonth(); | 346 | initMonth(); |
346 | monthAction->setOn( TRUE ); | 347 | monthAction->setOn( TRUE ); |
347 | monthView->setDate( d.year(), d.month(), d.day() ); | 348 | monthView->setDate( d.year(), d.month(), d.day() ); |
348 | views->raiseWidget( monthView ); | 349 | views->raiseWidget( monthView ); |
349 | monthView->redraw(); | 350 | monthView->redraw(); |
350 | } | 351 | } |
351 | } | 352 | } |
352 | 353 | ||
353 | void DateBook::viewDefault(const QDate &d) { | 354 | void DateBook::viewDefault(const QDate &d) { |
354 | Config config("DateBook"); | 355 | Config config("DateBook"); |
355 | config.setGroup("Main"); | 356 | config.setGroup("Main"); |
356 | int current=config.readNumEntry("defaultview", DAY); | 357 | int current=config.readNumEntry("defaultview", DAY); |
357 | 358 | ||
358 | view(current,d); | 359 | view(current,d); |
359 | } | 360 | } |
360 | 361 | ||
361 | void DateBook::viewDay() { | 362 | void DateBook::viewDay() { |
362 | view(DAY,currentDate()); | 363 | view(DAY,currentDate()); |
363 | } | 364 | } |
364 | 365 | ||
365 | void DateBook::viewWeek() { | 366 | void DateBook::viewWeek() { |
366 | view(WEEK,currentDate()); | 367 | view(WEEK,currentDate()); |
367 | } | 368 | } |
368 | 369 | ||
369 | void DateBook::viewWeekLst() { | 370 | void DateBook::viewWeekLst() { |
370 | view(WEEKLST,currentDate()); | 371 | view(WEEKLST,currentDate()); |
371 | } | 372 | } |
372 | 373 | ||
373 | void DateBook::viewMonth() { | 374 | void DateBook::viewMonth() { |
374 | view(MONTH,currentDate()); | 375 | view(MONTH,currentDate()); |
375 | } | 376 | } |
376 | 377 | ||
377 | void DateBook::editEvent( const Event &e ) | 378 | void DateBook::editEvent( const Event &e ) |
378 | { | 379 | { |
379 | if (syncing) { | 380 | if (syncing) { |
380 | QMessageBox::warning( this, tr("Calendar"), | 381 | QMessageBox::warning( this, tr("Calendar"), |
381 | tr( "Can not edit data, currently syncing") ); | 382 | tr( "Can not edit data, currently syncing") ); |
382 | return; | 383 | return; |
383 | } | 384 | } |
384 | 385 | ||
385 | // workaround added for text input. | 386 | // workaround added for text input. |
386 | QDialog editDlg( this, 0, TRUE ); | 387 | QDialog editDlg( this, 0, TRUE ); |
387 | DateEntry *entry; | 388 | DateEntry *entry; |
388 | editDlg.setCaption( tr("Edit Event") ); | 389 | editDlg.setCaption( tr("Edit Event") ); |
389 | QVBoxLayout *vb = new QVBoxLayout( &editDlg ); | 390 | QVBoxLayout *vb = new QVBoxLayout( &editDlg ); |
390 | QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); | 391 | QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); |
391 | sv->setResizePolicy( QScrollView::AutoOneFit ); | 392 | sv->setResizePolicy( QScrollView::AutoOneFit ); |
392 | // KLUDGE!!! | 393 | // KLUDGE!!! |
393 | sv->setHScrollBarMode( QScrollView::AlwaysOff ); | 394 | sv->setHScrollBarMode( QScrollView::AlwaysOff ); |
394 | vb->addWidget( sv ); | 395 | vb->addWidget( sv ); |
395 | entry = new DateEntry( onMonday, e, ampm, &editDlg, "editor" ); | 396 | entry = new DateEntry( onMonday, e, ampm, &editDlg, "editor" ); |
396 | entry->timezone->setEnabled( FALSE ); | 397 | entry->timezone->setEnabled( FALSE ); |
397 | sv->addChild( entry ); | 398 | sv->addChild( entry ); |
398 | 399 | ||
399 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 400 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
400 | editDlg.showMaximized(); | 401 | editDlg.showMaximized(); |
401 | #endif | 402 | #endif |
402 | while (editDlg.exec() ) { | 403 | while (editDlg.exec() ) { |
403 | Event newEv = entry->event(); | 404 | Event newEv = entry->event(); |
404 | newEv.setUid(e.uid()); // FIXME: Hack not to clear uid | 405 | newEv.setUid(e.uid()); // FIXME: Hack not to clear uid |
405 | QString error = checkEvent(newEv); | 406 | QString error = checkEvent(newEv); |
406 | if (!error.isNull()) { | 407 | if (!error.isNull()) { |
407 | if (QMessageBox::warning(this, "error box", | 408 | if (QMessageBox::warning(this, "error box", |
408 | error, "Fix it", "Continue", | 409 | error, "Fix it", "Continue", |
409 | 0, 0, 1) == 0) | 410 | 0, 0, 1) == 0) |
410 | continue; | 411 | continue; |
411 | } | 412 | } |
412 | db->editEvent(e, newEv); | 413 | db->editEvent(e, newEv); |
413 | emit newEvent(); | 414 | emit newEvent(); |
414 | break; | 415 | break; |
415 | } | 416 | } |
416 | } | 417 | } |
417 | 418 | ||
418 | void DateBook::removeEvent( const Event &e ) | 419 | void DateBook::removeEvent( const Event &e ) |
419 | { | 420 | { |
420 | if (syncing) { | 421 | if (syncing) { |
421 | QMessageBox::warning( this, tr("Calendar"), | 422 | QMessageBox::warning( this, tr("Calendar"), |
422 | tr( "Can not edit data, currently syncing") ); | 423 | tr( "Can not edit data, currently syncing") ); |
423 | return; | 424 | return; |
424 | } | 425 | } |
425 | 426 | ||
426 | QString strName = e.description(); | 427 | QString strName = e.description(); |
427 | 428 | ||
428 | if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) ) | 429 | if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) ) |
429 | return; | 430 | return; |
430 | 431 | ||
431 | db->removeEvent( e ); | 432 | db->removeEvent( e ); |
432 | if ( views->visibleWidget() == dayView && dayView ) | 433 | if ( views->visibleWidget() == dayView && dayView ) |
433 | dayView->redraw(); | 434 | dayView->redraw(); |
434 | } | 435 | } |
435 | 436 | ||
436 | void DateBook::addEvent( const Event &e ) | 437 | void DateBook::addEvent( const Event &e ) |
437 | { | 438 | { |
438 | QDate d = e.start().date(); | 439 | QDate d = e.start().date(); |
439 | initDay(); | 440 | initDay(); |
440 | dayView->setDate( d ); | 441 | dayView->setDate( d ); |
441 | } | 442 | } |
442 | 443 | ||
443 | void DateBook::showDay( int year, int month, int day ) | 444 | void DateBook::showDay( int year, int month, int day ) |
444 | { | 445 | { |
445 | QDate d(year, month, day); | 446 | QDate d(year, month, day); |
446 | view(DAY,d); | 447 | view(DAY,d); |
447 | } | 448 | } |
448 | 449 | ||
449 | void DateBook::initDay() | 450 | void DateBook::initDay() |
450 | { | 451 | { |
451 | if ( !dayView ) { | 452 | if ( !dayView ) { |
452 | dayView = new DateBookDay( ampm, onMonday, db, views, "day view" ); | 453 | dayView = new DateBookDay( ampm, onMonday, db, views, "day view" ); |
453 | views->addWidget( dayView, DAY ); | 454 | views->addWidget( dayView, DAY ); |
454 | dayView->setStartViewTime( startTime ); | 455 | dayView->setStartViewTime( startTime ); |
455 | connect( this, SIGNAL( newEvent() ), | 456 | connect( this, SIGNAL( newEvent() ), |
456 | dayView, SLOT( redraw() ) ); | 457 | dayView, SLOT( redraw() ) ); |
457 | connect( dayView, SIGNAL( newEvent() ), | 458 | connect( dayView, SIGNAL( newEvent() ), |
458 | this, SLOT( fileNew() ) ); | 459 | this, SLOT( fileNew() ) ); |
459 | connect( dayView, SIGNAL( removeEvent( const Event & ) ), | 460 | connect( dayView, SIGNAL( removeEvent( const Event & ) ), |
460 | this, SLOT( removeEvent( const Event & ) ) ); | 461 | this, SLOT( removeEvent( const Event & ) ) ); |
461 | connect( dayView, SIGNAL( editEvent( const Event & ) ), | 462 | connect( dayView, SIGNAL( editEvent( const Event & ) ), |
462 | this, SLOT( editEvent( const Event & ) ) ); | 463 | this, SLOT( editEvent( const Event & ) ) ); |
463 | connect( dayView, SIGNAL( beamEvent( const Event & ) ), | 464 | connect( dayView, SIGNAL( beamEvent( const Event & ) ), |
464 | this, SLOT( beamEvent( const Event & ) ) ); | 465 | this, SLOT( beamEvent( const Event & ) ) ); |
465 | connect( dayView, SIGNAL(sigNewEvent(const QString &)), | 466 | connect( dayView, SIGNAL(sigNewEvent(const QString &)), |
466 | this, SLOT(slotNewEventFromKey(const QString &)) ); | 467 | this, SLOT(slotNewEventFromKey(const QString &)) ); |
467 | } | 468 | } |
468 | } | 469 | } |
469 | 470 | ||
470 | void DateBook::initWeek() | 471 | void DateBook::initWeek() |
471 | { | 472 | { |
472 | if ( !weekView ) { | 473 | if ( !weekView ) { |
473 | weekView = new DateBookWeek( ampm, onMonday, db, views, "week view" ); | 474 | weekView = new DateBookWeek( ampm, onMonday, db, views, "week view" ); |
474 | weekView->setStartViewTime( startTime ); | 475 | weekView->setStartViewTime( startTime ); |
475 | views->addWidget( weekView, WEEK ); | 476 | views->addWidget( weekView, WEEK ); |
476 | connect( weekView, SIGNAL( showDate( int, int, int ) ), | 477 | connect( weekView, SIGNAL( showDate( int, int, int ) ), |
477 | this, SLOT( showDay( int, int, int ) ) ); | 478 | this, SLOT( showDay( int, int, int ) ) ); |
478 | connect( this, SIGNAL( newEvent() ), | 479 | connect( this, SIGNAL( newEvent() ), |
479 | weekView, SLOT( redraw() ) ); | 480 | weekView, SLOT( redraw() ) ); |
480 | } | 481 | } |
481 | //But also get it right: the year that we display can be different | 482 | //But also get it right: the year that we display can be different |
482 | //from the year of the current date. So, first find the year | 483 | //from the year of the current date. So, first find the year |
483 | //number of the current week. | 484 | //number of the current week. |
484 | 485 | ||
485 | int yearNumber, totWeeks; | 486 | int yearNumber, totWeeks; |
486 | calcWeek( currentDate(), totWeeks, yearNumber, onMonday ); | 487 | calcWeek( currentDate(), totWeeks, yearNumber, onMonday ); |
487 | 488 | ||
488 | QDate d = QDate( yearNumber, 12, 31 ); | 489 | QDate d = QDate( yearNumber, 12, 31 ); |
489 | calcWeek( d, totWeeks, yearNumber, onMonday ); | 490 | calcWeek( d, totWeeks, yearNumber, onMonday ); |
490 | 491 | ||
491 | while ( totWeeks == 1 ) { | 492 | while ( totWeeks == 1 ) { |
492 | d = d.addDays( -1 ); | 493 | d = d.addDays( -1 ); |
493 | calcWeek( d, totWeeks, yearNumber, onMonday ); | 494 | calcWeek( d, totWeeks, yearNumber, onMonday ); |
494 | } | 495 | } |
495 | if ( totWeeks != weekView->totalWeeks() ) | 496 | if ( totWeeks != weekView->totalWeeks() ) |
496 | weekView->setTotalWeeks( totWeeks ); | 497 | weekView->setTotalWeeks( totWeeks ); |
497 | } | 498 | } |
498 | void DateBook::initWeekLst() { | 499 | void DateBook::initWeekLst() { |
499 | if ( !weekLstView ) { | 500 | if ( !weekLstView ) { |
500 | weekLstView = new DateBookWeekLst( ampm, onMonday, db, | 501 | weekLstView = new DateBookWeekLst( ampm, onMonday, db, |
501 | views, "weeklst view" ); | 502 | views, "weeklst view" ); |
502 | views->addWidget( weekLstView, WEEKLST ); | 503 | views->addWidget( weekLstView, WEEKLST ); |
503 | 504 | ||
504 | //weekLstView->setStartViewTime( startTime ); | 505 | //weekLstView->setStartViewTime( startTime ); |
505 | connect( weekLstView, SIGNAL( showDate( int, int, int ) ), | 506 | connect( weekLstView, SIGNAL( showDate( int, int, int ) ), |
506 | this, SLOT( showDay( int, int, int ) ) ); | 507 | this, SLOT( showDay( int, int, int ) ) ); |
507 | connect( weekLstView, SIGNAL( addEvent( const QDateTime &, | 508 | connect( weekLstView, SIGNAL( addEvent( const QDateTime &, |
508 | const QDateTime &, | 509 | const QDateTime &, |
509 | const QString & ) ), | 510 | const QString & ) ), |
510 | this, SLOT( slotNewEntry( const QDateTime &, | 511 | this, SLOT( slotNewEntry( const QDateTime &, |
511 | const QDateTime &, | 512 | const QDateTime &, |
512 | const QString & ) ) ); | 513 | const QString & ) ) ); |
513 | connect( this, SIGNAL( newEvent() ), | 514 | connect( this, SIGNAL( newEvent() ), |
514 | weekLstView, SLOT( redraw() ) ); | 515 | weekLstView, SLOT( redraw() ) ); |
515 | connect( weekLstView, SIGNAL( editEvent( const Event & ) ), | 516 | connect( weekLstView, SIGNAL( editEvent( const Event & ) ), |
516 | this, SLOT( editEvent( const Event & ) ) ); | 517 | this, SLOT( editEvent( const Event & ) ) ); |
517 | } | 518 | } |
518 | } | 519 | } |
519 | 520 | ||
520 | 521 | ||
521 | void DateBook::initMonth() | 522 | void DateBook::initMonth() |
522 | { | 523 | { |
523 | if ( !monthView ) { | 524 | if ( !monthView ) { |
524 | monthView = new DateBookMonth( views, "month view", FALSE, db ); | 525 | monthView = new DateBookMonth( views, "month view", FALSE, db ); |
525 | views->addWidget( monthView, MONTH ); | 526 | views->addWidget( monthView, MONTH ); |
526 | connect( monthView, SIGNAL( dateClicked( int, int, int ) ), | 527 | connect( monthView, SIGNAL( dateClicked( int, int, int ) ), |
527 | this, SLOT( showDay( int, int, int ) ) ); | 528 | this, SLOT( showDay( int, int, int ) ) ); |
528 | connect( this, SIGNAL( newEvent() ), | 529 | connect( this, SIGNAL( newEvent() ), |
529 | monthView, SLOT( redraw() ) ); | 530 | monthView, SLOT( redraw() ) ); |
530 | qApp->processEvents(); | 531 | qApp->processEvents(); |
531 | } | 532 | } |
532 | } | 533 | } |
533 | 534 | ||
534 | void DateBook::loadSettings() | 535 | void DateBook::loadSettings() |
535 | { | 536 | { |
536 | { | 537 | { |
537 | Config config( "qpe" ); | 538 | Config config( "qpe" ); |
538 | config.setGroup("Time"); | 539 | config.setGroup("Time"); |
539 | ampm = config.readBoolEntry( "AMPM", TRUE ); | 540 | ampm = config.readBoolEntry( "AMPM", TRUE ); |
540 | onMonday = config.readBoolEntry( "MONDAY" ); | 541 | onMonday = config.readBoolEntry( "MONDAY" ); |
541 | } | 542 | } |
542 | 543 | ||
543 | { | 544 | { |
544 | Config config("DateBook"); | 545 | Config config("DateBook"); |
545 | config.setGroup("Main"); | 546 | config.setGroup("Main"); |
546 | startTime = config.readNumEntry("startviewtime", 8); | 547 | startTime = config.readNumEntry("startviewtime", 8); |
547 | aPreset = config.readBoolEntry("alarmpreset"); | 548 | aPreset = config.readBoolEntry("alarmpreset"); |
548 | presetTime = config.readNumEntry("presettime"); | 549 | presetTime = config.readNumEntry("presettime"); |
549 | } | 550 | } |
550 | } | 551 | } |
551 | 552 | ||
552 | void DateBook::saveSettings() | 553 | void DateBook::saveSettings() |
553 | { | 554 | { |
554 | Config config( "qpe" ); | 555 | Config config( "qpe" ); |
555 | Config configDB( "DateBook" ); | 556 | Config configDB( "DateBook" ); |
556 | configDB.setGroup( "Main" ); | 557 | configDB.setGroup( "Main" ); |
557 | configDB.writeEntry("startviewtime",startTime); | 558 | configDB.writeEntry("startviewtime",startTime); |
558 | configDB.writeEntry("alarmpreset",aPreset); | 559 | configDB.writeEntry("alarmpreset",aPreset); |
559 | configDB.writeEntry("presettime",presetTime); | 560 | configDB.writeEntry("presettime",presetTime); |
560 | } | 561 | } |
561 | 562 | ||
562 | void DateBook::newDefaultView(QAction *a) { | 563 | void DateBook::newDefaultView(QAction *a) { |
563 | int val=DAY; | 564 | int val=DAY; |
564 | if (a->text() == "Day") val=DAY; | 565 | if (a->text() == "Day") val=DAY; |
565 | if (a->text() == "Week") val=WEEK; | 566 | if (a->text() == "Week") val=WEEK; |
566 | if (a->text() == "WeekLst") val=WEEKLST; | 567 | if (a->text() == "WeekLst") val=WEEKLST; |
567 | if (a->text() == "Month") val=MONTH; | 568 | if (a->text() == "Month") val=MONTH; |
568 | 569 | ||
569 | Config configDB( "DateBook" ); | 570 | Config configDB( "DateBook" ); |
570 | configDB.setGroup( "Main" ); | 571 | configDB.setGroup( "Main" ); |
571 | configDB.writeEntry("defaultview",val); | 572 | configDB.writeEntry("defaultview",val); |
572 | } | 573 | } |
573 | 574 | ||
574 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) | 575 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) |
575 | { | 576 | { |
576 | bool needShow = FALSE; | 577 | bool needShow = FALSE; |
577 | if ( msg == "alarm(QDateTime,int)" ) { | 578 | if ( msg == "alarm(QDateTime,int)" ) { |
578 | QDataStream ds(data,IO_ReadOnly); | 579 | QDataStream ds(data,IO_ReadOnly); |
579 | QDateTime when; int warn; | 580 | QDateTime when; int warn; |
580 | ds >> when >> warn; | 581 | ds >> when >> warn; |
581 | 582 | ||
582 | // check to make it's okay to continue, | 583 | // check to make it's okay to continue, |
583 | // this is the case that the time was set ahead, and | 584 | // this is the case that the time was set ahead, and |
584 | // we are forced given a stale alarm... | 585 | // we are forced given a stale alarm... |
585 | QDateTime current = QDateTime::currentDateTime(); | 586 | QDateTime current = QDateTime::currentDateTime(); |
586 | if ( current.time().hour() != when.time().hour() | 587 | if ( current.time().hour() != when.time().hour() |
587 | && current.time().minute() != when.time().minute() ) | 588 | && current.time().minute() != when.time().minute() ) |
588 | return; | 589 | return; |
589 | 590 | ||
590 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); | 591 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); |
591 | if ( list.count() > 0 ) { | 592 | if ( list.count() > 0 ) { |
592 | QString msg; | 593 | QString msg; |
593 | bool bSound = FALSE; | 594 | bool bSound = FALSE; |
594 | int stopTimer = 0; | 595 | int stopTimer = 0; |
595 | bool found = FALSE; | 596 | bool found = FALSE; |
596 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); | 597 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); |
597 | it!=list.end(); ++it ) { | 598 | it!=list.end(); ++it ) { |
598 | if ( (*it).event().hasAlarm() ) { | 599 | if ( (*it).event().hasAlarm() ) { |
599 | found = TRUE; | 600 | found = TRUE; |
600 | msg += "<CENTER><B>" + (*it).description() + "</B>" | 601 | msg += "<CENTER><B>" + (*it).description() + "</B>" |
601 | + "<BR>" + (*it).location() + "<BR>" | 602 | + "<BR>" + (*it).location() + "<BR>" |
602 | + TimeString::dateString((*it).event().start(),ampm) | 603 | + TimeString::dateString((*it).event().start(),ampm) |
603 | + (warn | 604 | + (warn |
604 | ? tr(" (in " + QString::number(warn) | 605 | ? tr(" (in " + QString::number(warn) |
605 | + tr(" minutes)")) | 606 | + tr(" minutes)")) |
606 | : QString("")) | 607 | : QString("")) |
607 | + "<BR>" | 608 | + "<BR>" |
608 | + (*it).notes() + "</CENTER>"; | 609 | + (*it).notes() + "</CENTER>"; |
609 | if ( (*it).event().alarmSound() != Event::Silent ) { | 610 | if ( (*it).event().alarmSound() != Event::Silent ) { |
610 | bSound = TRUE; | 611 | bSound = TRUE; |
611 | } | 612 | } |
612 | } | 613 | } |
613 | } | 614 | } |
614 | if ( found ) { | 615 | if ( found ) { |
615 | if ( bSound ) { | 616 | if ( bSound ) { |
616 | Sound::soundAlarm(); | 617 | Sound::soundAlarm(); |
618 | alarmCounter = 0; | ||
617 | stopTimer = startTimer( 5000 ); | 619 | stopTimer = startTimer( 5000 ); |
618 | } | 620 | } |
619 | 621 | ||
620 | QDialog dlg( this, 0, TRUE ); | 622 | QDialog dlg( this, 0, TRUE ); |
621 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); | 623 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); |
622 | QScrollView *view = new QScrollView( &dlg, "scrollView"); | 624 | QScrollView *view = new QScrollView( &dlg, "scrollView"); |
623 | view->setResizePolicy( QScrollView::AutoOneFit ); | 625 | view->setResizePolicy( QScrollView::AutoOneFit ); |
624 | vb->addWidget( view ); | 626 | vb->addWidget( view ); |
625 | QLabel *lblMsg = new QLabel( msg, &dlg ); | 627 | QLabel *lblMsg = new QLabel( msg, &dlg ); |
626 | view->addChild( lblMsg ); | 628 | view->addChild( lblMsg ); |
627 | QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg ); | 629 | QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg ); |
628 | connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) ); | 630 | connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) ); |
629 | vb->addWidget( cmdOk ); | 631 | vb->addWidget( cmdOk ); |
630 | 632 | ||
631 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 633 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
632 | dlg.showMaximized(); | 634 | dlg.showMaximized(); |
633 | #endif | 635 | #endif |
634 | needShow = dlg.exec(); | 636 | needShow = dlg.exec(); |
635 | 637 | ||
636 | if ( bSound ) | 638 | if ( bSound ) |
637 | killTimer( stopTimer ); | 639 | killTimer( stopTimer ); |
638 | } | 640 | } |
639 | } | 641 | } |
640 | } else if ( msg == "nextView()" ) { | 642 | } else if ( msg == "nextView()" ) { |
641 | QWidget* cur = views->visibleWidget(); | 643 | QWidget* cur = views->visibleWidget(); |
642 | if ( cur ) { | 644 | if ( cur ) { |
643 | if ( cur == dayView ) | 645 | if ( cur == dayView ) |
644 | viewWeek(); | 646 | viewWeek(); |
645 | else if ( cur == weekView ) | 647 | else if ( cur == weekView ) |
646 | viewWeekLst(); | 648 | viewWeekLst(); |
647 | else if ( cur == weekLstView ) | 649 | else if ( cur == weekLstView ) |
648 | viewMonth(); | 650 | viewMonth(); |
649 | else if ( cur == monthView ) | 651 | else if ( cur == monthView ) |
650 | viewDay(); | 652 | viewDay(); |
651 | needShow = TRUE; | 653 | needShow = TRUE; |
652 | } | 654 | } |
653 | } | 655 | } |
654 | if ( needShow ) { | 656 | if ( needShow ) { |
655 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 657 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
656 | showMaximized(); | 658 | showMaximized(); |
657 | #else | 659 | #else |
658 | show(); | 660 | show(); |
659 | #endif | 661 | #endif |
660 | raise(); | 662 | raise(); |
661 | QPEApplication::setKeepRunning(); | 663 | QPEApplication::setKeepRunning(); |
662 | setActiveWindow(); | 664 | setActiveWindow(); |
663 | } | 665 | } |
664 | } | 666 | } |
665 | 667 | ||
666 | void DateBook::reload() | 668 | void DateBook::reload() |
667 | { | 669 | { |
668 | db->reload(); | 670 | db->reload(); |
669 | if ( dayAction->isOn() ) | 671 | if ( dayAction->isOn() ) |
670 | viewDay(); | 672 | viewDay(); |
671 | else if ( weekAction->isOn() ) | 673 | else if ( weekAction->isOn() ) |
672 | viewWeek(); | 674 | viewWeek(); |
673 | else if ( monthAction->isOn() ) | 675 | else if ( monthAction->isOn() ) |
674 | viewMonth(); | 676 | viewMonth(); |
675 | syncing = FALSE; | 677 | syncing = FALSE; |
676 | } | 678 | } |
677 | 679 | ||
678 | void DateBook::flush() | 680 | void DateBook::flush() |
679 | { | 681 | { |
680 | syncing = TRUE; | 682 | syncing = TRUE; |
681 | db->save(); | 683 | db->save(); |
682 | } | 684 | } |
683 | 685 | ||
684 | void DateBook::timerEvent( QTimerEvent *e ) | 686 | void DateBook::timerEvent( QTimerEvent *e ) |
685 | { | 687 | { |
686 | static int stop = 0; | 688 | if ( alarmCounter < 10 ) { |
687 | if ( stop < 10 ) { | 689 | alarmCounter++; |
688 | Sound::soundAlarm(); | 690 | Sound::soundAlarm(); |
689 | stop++; | 691 | } |
690 | } else { | 692 | else |
691 | stop = 0; | ||
692 | killTimer( e->timerId() ); | 693 | killTimer( e->timerId() ); |
693 | } | ||
694 | } | 694 | } |
695 | 695 | ||
696 | void DateBook::changeClock( bool newClock ) | 696 | void DateBook::changeClock( bool newClock ) |
697 | { | 697 | { |
698 | ampm = newClock; | 698 | ampm = newClock; |
699 | // repaint the affected objects... | 699 | // repaint the affected objects... |
700 | if (dayView) dayView->redraw(); | 700 | if (dayView) dayView->redraw(); |
701 | if (weekView) weekView->redraw(); | 701 | if (weekView) weekView->redraw(); |
702 | if (weekLstView) weekLstView->redraw(); | 702 | if (weekLstView) weekLstView->redraw(); |
703 | } | 703 | } |
704 | 704 | ||
705 | void DateBook::changeWeek( bool m ) | 705 | void DateBook::changeWeek( bool m ) |
706 | { | 706 | { |
707 | /* no need to redraw, each widget catches. Do need to | 707 | /* no need to redraw, each widget catches. Do need to |
708 | store though for widgets we haven't made yet */ | 708 | store though for widgets we haven't made yet */ |
709 | onMonday = m; | 709 | onMonday = m; |
710 | } | 710 | } |
711 | 711 | ||
712 | void DateBook::slotToday() | 712 | void DateBook::slotToday() |
713 | { | 713 | { |
714 | // we need to view today using default view | 714 | // we need to view today using default view |
715 | viewDefault(QDate::currentDate()); | 715 | viewDefault(QDate::currentDate()); |
716 | } | 716 | } |
717 | 717 | ||
718 | void DateBook::closeEvent( QCloseEvent *e ) | 718 | void DateBook::closeEvent( QCloseEvent *e ) |
719 | { | 719 | { |
720 | if(syncing) { | 720 | if(syncing) { |
721 | /* no need to save, did that at flush */ | 721 | /* no need to save, did that at flush */ |
722 | e->accept(); | 722 | e->accept(); |
723 | return; | 723 | return; |
724 | } | 724 | } |
725 | 725 | ||
726 | // save settings will generate it's own error messages, no | 726 | // save settings will generate it's own error messages, no |
727 | // need to do checking ourselves. | 727 | // need to do checking ourselves. |
728 | saveSettings(); | 728 | saveSettings(); |
729 | if ( db->save() ) | 729 | if ( db->save() ) |
730 | e->accept(); | 730 | e->accept(); |
731 | else { | 731 | else { |
732 | if ( QMessageBox::critical( this, tr( "Out of space" ), | 732 | if ( QMessageBox::critical( this, tr( "Out of space" ), |
733 | tr("Calendar was unable to save\n" | 733 | tr("Calendar was unable to save\n" |
734 | "your changes.\n" | 734 | "your changes.\n" |
735 | "Free up some space and try again.\n" | 735 | "Free up some space and try again.\n" |
736 | "\nQuit anyway?"), | 736 | "\nQuit anyway?"), |
737 | QMessageBox::Yes|QMessageBox::Escape, | 737 | QMessageBox::Yes|QMessageBox::Escape, |
738 | QMessageBox::No|QMessageBox::Default ) | 738 | QMessageBox::No|QMessageBox::Default ) |
739 | != QMessageBox::No ) | 739 | != QMessageBox::No ) |
740 | e->accept(); | 740 | e->accept(); |
741 | else | 741 | else |
742 | e->ignore(); | 742 | e->ignore(); |
743 | } | 743 | } |
744 | } | 744 | } |
745 | 745 | ||
746 | // Entering directly from the "keyboard" | 746 | // Entering directly from the "keyboard" |
747 | void DateBook::slotNewEventFromKey( const QString &str ) | 747 | void DateBook::slotNewEventFromKey( const QString &str ) |
748 | { | 748 | { |
749 | if (syncing) { | 749 | if (syncing) { |
750 | QMessageBox::warning( this, tr("Calendar"), | 750 | QMessageBox::warning( this, tr("Calendar"), |
751 | tr( "Can not edit data, currently syncing") ); | 751 | tr( "Can not edit data, currently syncing") ); |
752 | return; | 752 | return; |
753 | } | 753 | } |
754 | 754 | ||
755 | // We get to here from a key pressed in the Day View | 755 | // We get to here from a key pressed in the Day View |
756 | // So we can assume some things. We want the string | 756 | // So we can assume some things. We want the string |
757 | // passed in to be part of the description. | 757 | // passed in to be part of the description. |
758 | QDateTime start, end; | 758 | QDateTime start, end; |
759 | if ( views->visibleWidget() == dayView ) { | 759 | if ( views->visibleWidget() == dayView ) { |
760 | dayView->selectedDates( start, end ); | 760 | dayView->selectedDates( start, end ); |
761 | } else if ( views->visibleWidget() == monthView ) { | 761 | } else if ( views->visibleWidget() == monthView ) { |
762 | QDate d = monthView->selectedDate(); | 762 | QDate d = monthView->selectedDate(); |
763 | start = end = d; | 763 | start = end = d; |
764 | start.setTime( QTime( 10, 0 ) ); | 764 | start.setTime( QTime( 10, 0 ) ); |
765 | end.setTime( QTime( 12, 0 ) ); | 765 | end.setTime( QTime( 12, 0 ) ); |
766 | } else if ( views->visibleWidget() == weekView ) { | 766 | } else if ( views->visibleWidget() == weekView ) { |
767 | QDate d = weekView->date(); | 767 | QDate d = weekView->date(); |
768 | start = end = d; | 768 | start = end = d; |
769 | start.setTime( QTime( 10, 0 ) ); | 769 | start.setTime( QTime( 10, 0 ) ); |
770 | end.setTime( QTime( 12, 0 ) ); | 770 | end.setTime( QTime( 12, 0 ) ); |
771 | } | 771 | } |
772 | slotNewEntry(start, end, str); | 772 | slotNewEntry(start, end, str); |
773 | } | 773 | } |
774 | void DateBook::slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str) { | 774 | void DateBook::slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str) { |
775 | // argh! This really needs to be encapsulated in a class | 775 | // argh! This really needs to be encapsulated in a class |
776 | // or function. | 776 | // or function. |
777 | QDialog newDlg( this, 0, TRUE ); | 777 | QDialog newDlg( this, 0, TRUE ); |
778 | newDlg.setCaption( DateEntryBase::tr("New Event") ); | 778 | newDlg.setCaption( DateEntryBase::tr("New Event") ); |
779 | DateEntry *e; | 779 | DateEntry *e; |
780 | QVBoxLayout *vb = new QVBoxLayout( &newDlg ); | 780 | QVBoxLayout *vb = new QVBoxLayout( &newDlg ); |
781 | QScrollView *sv = new QScrollView( &newDlg ); | 781 | QScrollView *sv = new QScrollView( &newDlg ); |
782 | sv->setResizePolicy( QScrollView::AutoOneFit ); | 782 | sv->setResizePolicy( QScrollView::AutoOneFit ); |
783 | sv->setFrameStyle( QFrame::NoFrame ); | 783 | sv->setFrameStyle( QFrame::NoFrame ); |
784 | sv->setHScrollBarMode( QScrollView::AlwaysOff ); | 784 | sv->setHScrollBarMode( QScrollView::AlwaysOff ); |
785 | vb->addWidget( sv ); | 785 | vb->addWidget( sv ); |
786 | 786 | ||
787 | Event ev; | 787 | Event ev; |
788 | ev.setDescription( str ); | 788 | ev.setDescription( str ); |
789 | // When the new gui comes in, change this... | 789 | // When the new gui comes in, change this... |
790 | ev.setLocation( tr("(Unknown)") ); | 790 | ev.setLocation( tr("(Unknown)") ); |
791 | ev.setStart( start ); | 791 | ev.setStart( start ); |
792 | ev.setEnd( end ); | 792 | ev.setEnd( end ); |
793 | 793 | ||
794 | e = new DateEntry( onMonday, ev, ampm, &newDlg ); | 794 | e = new DateEntry( onMonday, ev, ampm, &newDlg ); |
795 | e->setAlarmEnabled( aPreset, presetTime, Event::Loud ); | 795 | e->setAlarmEnabled( aPreset, presetTime, Event::Loud ); |
796 | sv->addChild( e ); | 796 | sv->addChild( e ); |
797 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 797 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
798 | newDlg.showMaximized(); | 798 | newDlg.showMaximized(); |
799 | #endif | 799 | #endif |
800 | while (newDlg.exec()) { | 800 | while (newDlg.exec()) { |
801 | ev = e->event(); | 801 | ev = e->event(); |
802 | ev.assignUid(); | 802 | ev.assignUid(); |
803 | QString error = checkEvent( ev ); | 803 | QString error = checkEvent( ev ); |
804 | if ( !error.isNull() ) { | 804 | if ( !error.isNull() ) { |
805 | if ( QMessageBox::warning( this, tr("Error!"), | 805 | if ( QMessageBox::warning( this, tr("Error!"), |
806 | error, tr("Fix it"), tr("Continue"), 0, 0, 1 ) == 0 ) | 806 | error, tr("Fix it"), tr("Continue"), 0, 0, 1 ) == 0 ) |
807 | continue; | 807 | continue; |
808 | } | 808 | } |
809 | db->addEvent( ev ); | 809 | db->addEvent( ev ); |
810 | emit newEvent(); | 810 | emit newEvent(); |
811 | break; | 811 | break; |
812 | } | 812 | } |
813 | } | 813 | } |
814 | 814 | ||
815 | void DateBook::setDocument( const QString &filename ) | 815 | void DateBook::setDocument( const QString &filename ) |
816 | { | 816 | { |
817 | if ( filename.find(".vcs") != int(filename.length()) - 4 ) return; | 817 | if ( filename.find(".vcs") != int(filename.length()) - 4 ) return; |
818 | 818 | ||
819 | QValueList<Event> tl = Event::readVCalendar( filename ); | 819 | QValueList<Event> tl = Event::readVCalendar( filename ); |
820 | for( QValueList<Event>::Iterator it = tl.begin(); it != tl.end(); ++it ) { | 820 | for( QValueList<Event>::Iterator it = tl.begin(); it != tl.end(); ++it ) { |
821 | db->addEvent( *it ); | 821 | db->addEvent( *it ); |
822 | } | 822 | } |
823 | } | 823 | } |
824 | 824 | ||
825 | static const char * beamfile = "/tmp/obex/event.vcs"; | 825 | static const char * beamfile = "/tmp/obex/event.vcs"; |
826 | 826 | ||
827 | void DateBook::beamEvent( const Event &e ) | 827 | void DateBook::beamEvent( const Event &e ) |
828 | { | 828 | { |
829 | qDebug("trying to beamn"); | 829 | qDebug("trying to beamn"); |
830 | unlink( beamfile ); // delete if exists | 830 | unlink( beamfile ); // delete if exists |
831 | mkdir("/tmp/obex/", 0755); | 831 | mkdir("/tmp/obex/", 0755); |
832 | Event::writeVCalendar( beamfile, e ); | 832 | Event::writeVCalendar( beamfile, e ); |
833 | Ir *ir = new Ir( this ); | 833 | Ir *ir = new Ir( this ); |
834 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); | 834 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); |
835 | QString description = e.description(); | 835 | QString description = e.description(); |
836 | ir->send( beamfile, description, "text/x-vCalendar" ); | 836 | ir->send( beamfile, description, "text/x-vCalendar" ); |
837 | } | 837 | } |
838 | 838 | ||
839 | void DateBook::beamDone( Ir *ir ) | 839 | void DateBook::beamDone( Ir *ir ) |
840 | { | 840 | { |
841 | delete ir; | 841 | delete ir; |
842 | unlink( beamfile ); | 842 | unlink( beamfile ); |
843 | } | 843 | } |
844 | 844 | ||
845 | void DateBook::slotFind() | 845 | void DateBook::slotFind() |
846 | { | 846 | { |
847 | // move it to the day view... | 847 | // move it to the day view... |
848 | viewDay(); | 848 | viewDay(); |
849 | FindDialog frmFind( "Calendar", this ); | 849 | FindDialog frmFind( "Calendar", this ); |
850 | frmFind.setUseDate( true ); | 850 | frmFind.setUseDate( true ); |
851 | frmFind.setDate( currentDate() ); | 851 | frmFind.setDate( currentDate() ); |
852 | QObject::connect( &frmFind, | 852 | QObject::connect( &frmFind, |
853 | SIGNAL(signalFindClicked(const QString&, const QDate&, | 853 | SIGNAL(signalFindClicked(const QString&, const QDate&, |
854 | bool, bool, int)), | 854 | bool, bool, int)), |
855 | this, | 855 | this, |
856 | SLOT(slotDoFind(const QString&, const QDate&, | 856 | SLOT(slotDoFind(const QString&, const QDate&, |
857 | bool, bool, int)) ); | 857 | bool, bool, int)) ); |
858 | QObject::connect( this, | 858 | QObject::connect( this, |
859 | SIGNAL(signalNotFound()), | 859 | SIGNAL(signalNotFound()), |
860 | &frmFind, | 860 | &frmFind, |
861 | SLOT(slotNotFound()) ); | 861 | SLOT(slotNotFound()) ); |
862 | QObject::connect( this, | 862 | QObject::connect( this, |
863 | SIGNAL(signalWrapAround()), | 863 | SIGNAL(signalWrapAround()), |
864 | &frmFind, | 864 | &frmFind, |
865 | SLOT(slotWrapAround()) ); | 865 | SLOT(slotWrapAround()) ); |
866 | frmFind.exec(); | 866 | frmFind.exec(); |
867 | inSearch = false; | 867 | inSearch = false; |
868 | } | 868 | } |
869 | 869 | ||
870 | bool catComp( QArray<int> cats, int category ) | 870 | bool catComp( QArray<int> cats, int category ) |
871 | { | 871 | { |
872 | bool returnMe; | 872 | bool returnMe; |
873 | int i, | 873 | int i, |
874 | count; | 874 | count; |
875 | 875 | ||
876 | count = int(cats.count()); | 876 | count = int(cats.count()); |
877 | returnMe = false; | 877 | returnMe = false; |
878 | if ( (category == -1 && count == 0) || category == -2 ) | 878 | if ( (category == -1 && count == 0) || category == -2 ) |
879 | returnMe = true; | 879 | returnMe = true; |
880 | else { | 880 | else { |
881 | for ( i = 0; i < count; i++ ) { | 881 | for ( i = 0; i < count; i++ ) { |
882 | if ( category == cats[i] ) { | 882 | if ( category == cats[i] ) { |
883 | returnMe = true; | 883 | returnMe = true; |
884 | break; | 884 | break; |
885 | } | 885 | } |
886 | } | 886 | } |
887 | } | 887 | } |
888 | return returnMe; | 888 | return returnMe; |
889 | } | 889 | } |
890 | 890 | ||
891 | 891 | ||
892 | void DateBook::slotDoFind( const QString& txt, const QDate &dt, | 892 | void DateBook::slotDoFind( const QString& txt, const QDate &dt, |
893 | bool caseSensitive, bool /*backwards*/, | 893 | bool caseSensitive, bool /*backwards*/, |
894 | int category ) | 894 | int category ) |
895 | { | 895 | { |
896 | QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ), | 896 | QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ), |
897 | next; | 897 | next; |
898 | 898 | ||
899 | QRegExp r( txt ); | 899 | QRegExp r( txt ); |
900 | r.setCaseSensitive( caseSensitive ); | 900 | r.setCaseSensitive( caseSensitive ); |
901 | 901 | ||
902 | 902 | ||
903 | static Event rev, | 903 | static Event rev, |
904 | nonrev; | 904 | nonrev; |
905 | if ( !inSearch ) { | 905 | if ( !inSearch ) { |
906 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); | 906 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); |
907 | nonrev.setStart( rev.start() ); | 907 | nonrev.setStart( rev.start() ); |
908 | inSearch = true; | 908 | inSearch = true; |
909 | } | 909 | } |
910 | static QDate searchDate = dt; | 910 | static QDate searchDate = dt; |
911 | static bool wrapAround = true; | 911 | static bool wrapAround = true; |
912 | bool candidtate; | 912 | bool candidtate; |
913 | candidtate = false; | 913 | candidtate = false; |
914 | 914 | ||
915 | QValueList<Event> repeats = db->getRawRepeats(); | 915 | QValueList<Event> repeats = db->getRawRepeats(); |
916 | 916 | ||
917 | // find the candidate for the first repeat that matches... | 917 | // find the candidate for the first repeat that matches... |
918 | QValueListConstIterator<Event> it; | 918 | QValueListConstIterator<Event> it; |
919 | QDate start = dt; | 919 | QDate start = dt; |
920 | for ( it = repeats.begin(); it != repeats.end(); ++it ) { | 920 | for ( it = repeats.begin(); it != repeats.end(); ++it ) { |
921 | if ( catComp( (*it).categories(), category ) ) { | 921 | if ( catComp( (*it).categories(), category ) ) { |
922 | while ( nextOccurance( *it, start, next ) ) { | 922 | while ( nextOccurance( *it, start, next ) ) { |
923 | if ( next < dtEnd ) { | 923 | if ( next < dtEnd ) { |
924 | if ( (*it).match( r ) && !(next <= rev.start()) ) { | 924 | if ( (*it).match( r ) && !(next <= rev.start()) ) { |
925 | rev = *it; | 925 | rev = *it; |
926 | dtEnd = next; | 926 | dtEnd = next; |
927 | rev.setStart( next ); | 927 | rev.setStart( next ); |
928 | candidtate = true; | 928 | candidtate = true; |
929 | wrapAround = true; | 929 | wrapAround = true; |
930 | start = dt; | 930 | start = dt; |
931 | break; | 931 | break; |
932 | } else | 932 | } else |
933 | start = next.date().addDays( 1 ); | 933 | start = next.date().addDays( 1 ); |
934 | } | 934 | } |
935 | } | 935 | } |
936 | } | 936 | } |
937 | } | 937 | } |
938 | 938 | ||
939 | // now the for first non repeat... | 939 | // now the for first non repeat... |
940 | QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() ); | 940 | QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() ); |
941 | qHeapSort( nonRepeats.begin(), nonRepeats.end() ); | 941 | qHeapSort( nonRepeats.begin(), nonRepeats.end() ); |
942 | for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) { | 942 | for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) { |
943 | if ( catComp( (*it).categories(), category ) ) { | 943 | if ( catComp( (*it).categories(), category ) ) { |
944 | if ( (*it).start() < dtEnd ) { | 944 | if ( (*it).start() < dtEnd ) { |
945 | if ( (*it).match( r ) && !(*it <= nonrev) ) { | 945 | if ( (*it).match( r ) && !(*it <= nonrev) ) { |
946 | nonrev = *it; | 946 | nonrev = *it; |
947 | dtEnd = nonrev.start(); | 947 | dtEnd = nonrev.start(); |
948 | candidtate = true; | 948 | candidtate = true; |
949 | wrapAround = true; | 949 | wrapAround = true; |
950 | break; | 950 | break; |
951 | } | 951 | } |
952 | } | 952 | } |
953 | } | 953 | } |
954 | } | 954 | } |
955 | if ( candidtate ) { | 955 | if ( candidtate ) { |
956 | dayView->setStartViewTime( dtEnd.time().hour() ); | 956 | dayView->setStartViewTime( dtEnd.time().hour() ); |
957 | dayView->setDate( dtEnd.date().year(), dtEnd.date().month(), | 957 | dayView->setDate( dtEnd.date().year(), dtEnd.date().month(), |
958 | dtEnd.date().day() ); | 958 | dtEnd.date().day() ); |
959 | } else { | 959 | } else { |
960 | if ( wrapAround ) { | 960 | if ( wrapAround ) { |
961 | emit signalWrapAround(); | 961 | emit signalWrapAround(); |
962 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); | 962 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); |
963 | nonrev.setStart( rev.start() ); | 963 | nonrev.setStart( rev.start() ); |
964 | } else | 964 | } else |
965 | emit signalNotFound(); | 965 | emit signalNotFound(); |
966 | wrapAround = !wrapAround; | 966 | wrapAround = !wrapAround; |
967 | } | 967 | } |
968 | } | 968 | } |
969 | 969 | ||
970 | Event DateBookDBHack::eventByUID(int uid) { | 970 | Event DateBookDBHack::eventByUID(int uid) { |
971 | 971 | ||
972 | // FIXME: Dirty Hacks to get hold of the private event lists | 972 | // FIXME: Dirty Hacks to get hold of the private event lists |
973 | QDate start; | 973 | QDate start; |
974 | QDate end=start.addDays(-1); | 974 | QDate end=start.addDays(-1); |
975 | QValueList<Event> myEventList=getNonRepeatingEvents(start,end); | 975 | QValueList<Event> myEventList=getNonRepeatingEvents(start,end); |
976 | QValueList<Event> myRepeatEvents=getRawRepeats(); | 976 | QValueList<Event> myRepeatEvents=getRawRepeats(); |
977 | 977 | ||
978 | QValueList<Event>::ConstIterator it; | 978 | QValueList<Event>::ConstIterator it; |
979 | 979 | ||
980 | for (it = myEventList.begin(); it != myEventList.end(); it++) { | 980 | for (it = myEventList.begin(); it != myEventList.end(); it++) { |
981 | if ((*it).uid() == uid) return *it; | 981 | if ((*it).uid() == uid) return *it; |
982 | } | 982 | } |
983 | for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) { | 983 | for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) { |
984 | if ((*it).uid() == uid) return *it; | 984 | if ((*it).uid() == uid) return *it; |
985 | } | 985 | } |
986 | 986 | ||
987 | qDebug("Event not found: uid=%d\n", uid); | 987 | qDebug("Event not found: uid=%d\n", uid); |
988 | } | 988 | } |
989 | 989 | ||
diff --git a/core/pim/datebook/datebook.h b/core/pim/datebook/datebook.h index d1fe90d..e7be0dd 100644 --- a/core/pim/datebook/datebook.h +++ b/core/pim/datebook/datebook.h | |||
@@ -1,126 +1,128 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #ifndef DATEBOOK_H | 20 | #ifndef DATEBOOK_H |
21 | #define DATEBOOK_H | 21 | #define DATEBOOK_H |
22 | 22 | ||
23 | #include <qpe/datebookdb.h> | 23 | #include <qpe/datebookdb.h> |
24 | 24 | ||
25 | #include <qmainwindow.h> | 25 | #include <qmainwindow.h> |
26 | 26 | ||
27 | class QAction; | 27 | class QAction; |
28 | class QWidgetStack; | 28 | class QWidgetStack; |
29 | class DateBookDay; | 29 | class DateBookDay; |
30 | class DateBookWeek; | 30 | class DateBookWeek; |
31 | class DateBookWeekLst; | 31 | class DateBookWeekLst; |
32 | class DateBookMonth; | 32 | class DateBookMonth; |
33 | class Event; | 33 | class Event; |
34 | class QDate; | 34 | class QDate; |
35 | class Ir; | 35 | class Ir; |
36 | 36 | ||
37 | class DateBookDBHack : public DateBookDB { | 37 | class DateBookDBHack : public DateBookDB { |
38 | public: | 38 | public: |
39 | Event eventByUID(int id); | 39 | Event eventByUID(int id); |
40 | }; | 40 | }; |
41 | 41 | ||
42 | class DateBook : public QMainWindow | 42 | class DateBook : public QMainWindow |
43 | { | 43 | { |
44 | Q_OBJECT | 44 | Q_OBJECT |
45 | 45 | ||
46 | public: | 46 | public: |
47 | DateBook( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); | 47 | DateBook( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); |
48 | ~DateBook(); | 48 | ~DateBook(); |
49 | 49 | ||
50 | signals: | 50 | signals: |
51 | void newEvent(); | 51 | void newEvent(); |
52 | void signalNotFound(); | 52 | void signalNotFound(); |
53 | void signalWrapAround(); | 53 | void signalWrapAround(); |
54 | 54 | ||
55 | protected: | 55 | protected: |
56 | QDate currentDate(); | 56 | QDate currentDate(); |
57 | void timerEvent( QTimerEvent *e ); | 57 | void timerEvent( QTimerEvent *e ); |
58 | void closeEvent( QCloseEvent *e ); | 58 | void closeEvent( QCloseEvent *e ); |
59 | 59 | ||
60 | void view(int v, const QDate &d); | 60 | void view(int v, const QDate &d); |
61 | 61 | ||
62 | public slots: | 62 | public slots: |
63 | void flush(); | 63 | void flush(); |
64 | void reload(); | 64 | void reload(); |
65 | 65 | ||
66 | private slots: | 66 | private slots: |
67 | void fileNew(); | 67 | void fileNew(); |
68 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str); | 68 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str); |
69 | void slotSettings(); | 69 | void slotSettings(); |
70 | void newDefaultView(QAction *a); | 70 | void newDefaultView(QAction *a); |
71 | void slotToday();// view today | 71 | void slotToday();// view today |
72 | void changeClock( bool newClock ); | 72 | void changeClock( bool newClock ); |
73 | void changeWeek( bool newDay ); | 73 | void changeWeek( bool newDay ); |
74 | void appMessage(const QCString& msg, const QByteArray& data); | 74 | void appMessage(const QCString& msg, const QByteArray& data); |
75 | // handle key events in the day view... | 75 | // handle key events in the day view... |
76 | void slotNewEventFromKey( const QString &str ); | 76 | void slotNewEventFromKey( const QString &str ); |
77 | void slotFind(); | 77 | void slotFind(); |
78 | void slotDoFind( const QString &, const QDate &, bool, bool, int ); | 78 | void slotDoFind( const QString &, const QDate &, bool, bool, int ); |
79 | 79 | ||
80 | void viewDefault(const QDate &d); | 80 | void viewDefault(const QDate &d); |
81 | 81 | ||
82 | void viewDay(); | 82 | void viewDay(); |
83 | void viewWeek(); | 83 | void viewWeek(); |
84 | void viewWeekLst(); | 84 | void viewWeekLst(); |
85 | void viewMonth(); | 85 | void viewMonth(); |
86 | 86 | ||
87 | void showDay( int y, int m, int d ); | 87 | void showDay( int y, int m, int d ); |
88 | 88 | ||
89 | void editEvent( const Event &e ); | 89 | void editEvent( const Event &e ); |
90 | void removeEvent( const Event &e ); | 90 | void removeEvent( const Event &e ); |
91 | 91 | ||
92 | void receive( const QCString &msg, const QByteArray &data ); | 92 | void receive( const QCString &msg, const QByteArray &data ); |
93 | void setDocument( const QString & ); | 93 | void setDocument( const QString & ); |
94 | void beamEvent( const Event &e ); | 94 | void beamEvent( const Event &e ); |
95 | void beamDone( Ir *ir ); | 95 | void beamDone( Ir *ir ); |
96 | 96 | ||
97 | private: | 97 | private: |
98 | void addEvent( const Event &e ); | 98 | void addEvent( const Event &e ); |
99 | void initDay(); | 99 | void initDay(); |
100 | void initWeek(); | 100 | void initWeek(); |
101 | void initWeekLst(); | 101 | void initWeekLst(); |
102 | void initMonth(); | 102 | void initMonth(); |
103 | void loadSettings(); | 103 | void loadSettings(); |
104 | void saveSettings(); | 104 | void saveSettings(); |
105 | 105 | ||
106 | private: | 106 | private: |
107 | DateBookDBHack *db; | 107 | DateBookDBHack *db; |
108 | QWidgetStack *views; | 108 | QWidgetStack *views; |
109 | DateBookDay *dayView; | 109 | DateBookDay *dayView; |
110 | DateBookWeek *weekView; | 110 | DateBookWeek *weekView; |
111 | DateBookMonth *monthView; | 111 | DateBookMonth *monthView; |
112 | DateBookWeekLst *weekLstView; | 112 | DateBookWeekLst *weekLstView; |
113 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; | 113 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; |
114 | bool aPreset; // have everything set to alarm? | 114 | bool aPreset; // have everything set to alarm? |
115 | int presetTime; // the standard time for the alarm | 115 | int presetTime; // the standard time for the alarm |
116 | int startTime; | 116 | int startTime; |
117 | bool ampm; | 117 | bool ampm; |
118 | bool onMonday; | 118 | bool onMonday; |
119 | 119 | ||
120 | bool syncing; | 120 | bool syncing; |
121 | bool inSearch; | 121 | bool inSearch; |
122 | 122 | ||
123 | int alarmCounter; | ||
124 | |||
123 | QString checkEvent(const Event &); | 125 | QString checkEvent(const Event &); |
124 | }; | 126 | }; |
125 | 127 | ||
126 | #endif | 128 | #endif |