-rw-r--r-- | examples/simple-pim/simple.cpp | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/examples/simple-pim/simple.cpp b/examples/simple-pim/simple.cpp index 3e9fcd3..029e71b 100644 --- a/examples/simple-pim/simple.cpp +++ b/examples/simple-pim/simple.cpp | |||
@@ -1,445 +1,445 @@ | |||
1 | #include <qaction.h> // action | 1 | #include <qaction.h> // action |
2 | #include <qmenubar.h> // menubar | 2 | #include <qmenubar.h> // menubar |
3 | #include <qtoolbar.h> // toolbar | 3 | #include <qtoolbar.h> // toolbar |
4 | #include <qlabel.h> // a label | 4 | #include <qlabel.h> // a label |
5 | #include <qpushbutton.h> // the header file for the QPushButton | 5 | #include <qpushbutton.h> // the header file for the QPushButton |
6 | #include <qlayout.h> | 6 | #include <qlayout.h> |
7 | #include <qtimer.h> // we use it for the singleShot | 7 | #include <qtimer.h> // we use it for the singleShot |
8 | #include <qdatetime.h> // for QDate | 8 | #include <qdatetime.h> // for QDate |
9 | #include <qtextview.h> // a rich text widget | 9 | #include <qtextview.h> // a rich text widget |
10 | #include <qdialog.h> | 10 | #include <qdialog.h> |
11 | #include <qwhatsthis.h> // for whats this | 11 | #include <qwhatsthis.h> // for whats this |
12 | 12 | ||
13 | #include <qpe/qpeapplication.h> // the QPEApplication | 13 | #include <qpe/qpeapplication.h> // the QPEApplication |
14 | #include <qpe/resource.h> | 14 | #include <qpe/resource.h> |
15 | #include <qpe/sound.h> | 15 | #include <qpe/sound.h> |
16 | #include <qpe/qcopenvelope_qws.h> | 16 | #include <qpe/qcopenvelope_qws.h> |
17 | #include <qpe/datebookmonth.h> | 17 | #include <qpe/datebookmonth.h> |
18 | #include <qpe/timestring.h> | 18 | #include <qpe/timestring.h> |
19 | 19 | ||
20 | #include <opie/oapplicationfactory.h> // a template + macro to save the main method and allow quick launching | 20 | #include <opie/oapplicationfactory.h> // a template + macro to save the main method and allow quick launching |
21 | #include <opie/otabwidget.h> | 21 | #include <opie/otabwidget.h> |
22 | #include <opie/owait.h> | 22 | #include <opie/owait.h> |
23 | 23 | ||
24 | #include "simple.h" | 24 | #include "simple.h" |
25 | 25 | ||
26 | /* | 26 | /* |
27 | * implementation of simple | 27 | * implementation of simple |
28 | */ | 28 | */ |
29 | 29 | ||
30 | /* | 30 | /* |
31 | * The factory is used for quicklaunching | 31 | * The factory is used for quicklaunching |
32 | * It needs a constructor ( c'tor ) with at least QWidget, const char* and WFlags as parameter and a static QString appName() matching the TARGET of the .pro | 32 | * It needs a constructor ( c'tor ) with at least QWidget, const char* and WFlags as parameter and a static QString appName() matching the TARGET of the .pro |
33 | * | 33 | * |
34 | * Depending on the global quick launch setting this will create | 34 | * Depending on the global quick launch setting this will create |
35 | * either a main method or one for our component plugin system | 35 | * either a main method or one for our component plugin system |
36 | */ | 36 | */ |
37 | 37 | ||
38 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) | 38 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) |
39 | 39 | ||
40 | MainWindow::MainWindow(QWidget *parent, const char* name, WFlags fl ) | 40 | MainWindow::MainWindow(QWidget *parent, const char* name, WFlags fl ) |
41 | : QMainWindow( parent, name, fl ) { | 41 | : QMainWindow( parent, name, fl ) { |
42 | setCaption(tr("My MainWindow") ); | 42 | setCaption(tr("My MainWindow") ); |
43 | 43 | ||
44 | m_desktopChannel = 0; | 44 | m_desktopChannel = 0; |
45 | m_loading = 0; | 45 | m_loading = 0; |
46 | 46 | ||
47 | initUI(); | 47 | initUI(); |
48 | 48 | ||
49 | 49 | ||
50 | /* | 50 | /* |
51 | * Tab widget as central | 51 | * Tab widget as central |
52 | */ | 52 | */ |
53 | m_tab = new OTabWidget(this); | 53 | m_tab = new OTabWidget(this); |
54 | 54 | ||
55 | setCentralWidget( m_tab ); | 55 | setCentralWidget( m_tab ); |
56 | 56 | ||
57 | m_todoView = new PIMListView(m_tab, "Todo view" ); | 57 | m_todoView = new PIMListView(m_tab, "Todo view" ); |
58 | m_tab->addTab( m_todoView,"todo/TodoList", tr("Todos") ); | 58 | m_tab->addTab( m_todoView,"todo/TodoList", tr("Todos") ); |
59 | 59 | ||
60 | m_dateView = new PIMListView(m_tab, "Datebook view" ); | 60 | m_dateView = new PIMListView(m_tab, "Datebook view" ); |
61 | m_tab->addTab( m_dateView, "datebook/DateBook", tr("Events") ); | 61 | m_tab->addTab( m_dateView, "datebook/DateBook", tr("Events") ); |
62 | 62 | ||
63 | /* now connect the actions */ | 63 | /* now connect the actions */ |
64 | /* | 64 | /* |
65 | * we connect the activated to our show | 65 | * we connect the activated to our show |
66 | * and on activation we will show a detailed | 66 | * and on activation we will show a detailed |
67 | * summary of the record | 67 | * summary of the record |
68 | */ | 68 | */ |
69 | connect(m_fire, SIGNAL(activated() ), | 69 | connect(m_fire, SIGNAL(activated() ), |
70 | this, SLOT(slotShow() ) ); | 70 | this, SLOT(slotShow() ) ); |
71 | 71 | ||
72 | /* | 72 | /* |
73 | * We will change the date | 73 | * We will change the date |
74 | */ | 74 | */ |
75 | connect(m_dateAction, SIGNAL(activated() ), | 75 | connect(m_dateAction, SIGNAL(activated() ), |
76 | this, SLOT(slotDate() ) ); | 76 | this, SLOT(slotDate() ) ); |
77 | 77 | ||
78 | /* | 78 | /* |
79 | * connect the show signal of the PIMListView | 79 | * connect the show signal of the PIMListView |
80 | * to a slot to show a dialog | 80 | * to a slot to show a dialog |
81 | */ | 81 | */ |
82 | connect(m_todoView, SIGNAL(showRecord(const OPimRecord& ) ), | 82 | connect(m_todoView, SIGNAL(showRecord(const OPimRecord&) ), |
83 | this, SLOT(slotShowRecord(const OPimRecord& ) ) ); | 83 | this, SLOT(slotShowRecord(const OPimRecord&) ) ); |
84 | connect(m_dateView, SIGNAL(showRecord(const OPimRecord& ) ), | 84 | connect(m_dateView, SIGNAL(showRecord(const OPimRecord&) ), |
85 | this, SLOT(slotShowRecord(const OPimRecord& ) ) ); | 85 | this, SLOT(slotShowRecord(const OPimRecord&) ) ); |
86 | 86 | ||
87 | /* | 87 | /* |
88 | * Now comes the important lines of code for this example | 88 | * Now comes the important lines of code for this example |
89 | * We do not directly call load but delay loading until | 89 | * We do not directly call load but delay loading until |
90 | * all Events are dispatches and handled. | 90 | * all Events are dispatches and handled. |
91 | * SO we will load once our window is mapped to screen | 91 | * SO we will load once our window is mapped to screen |
92 | * to achieve that we use a QTimer::singleShot | 92 | * to achieve that we use a QTimer::singleShot |
93 | * After 10 milli seconds the timer fires and on TimerEvent | 93 | * After 10 milli seconds the timer fires and on TimerEvent |
94 | * out slot slotLoad will be called | 94 | * out slot slotLoad will be called |
95 | * Remember this a Constructor to construct your object and not | 95 | * Remember this a Constructor to construct your object and not |
96 | * to load | 96 | * to load |
97 | */ | 97 | */ |
98 | QTimer::singleShot( 10, this, SLOT(slotLoad() ) ); | 98 | QTimer::singleShot( 10, this, SLOT(slotLoad() ) ); |
99 | } | 99 | } |
100 | 100 | ||
101 | MainWindow::~MainWindow() { | 101 | MainWindow::~MainWindow() { |
102 | // again nothing to delete because Qt takes care | 102 | // again nothing to delete because Qt takes care |
103 | } | 103 | } |
104 | 104 | ||
105 | 105 | ||
106 | void MainWindow::setDocument( const QString& /*str*/ ) { | 106 | void MainWindow::setDocument( const QString& /*str*/ ) { |
107 | } | 107 | } |
108 | 108 | ||
109 | 109 | ||
110 | void MainWindow::initUI() { | 110 | void MainWindow::initUI() { |
111 | 111 | ||
112 | setToolBarsMovable( false ); | 112 | setToolBarsMovable( false ); |
113 | 113 | ||
114 | QToolBar *menuBarHolder = new QToolBar( this ); | 114 | QToolBar *menuBarHolder = new QToolBar( this ); |
115 | 115 | ||
116 | menuBarHolder->setHorizontalStretchable( true ); | 116 | menuBarHolder->setHorizontalStretchable( true ); |
117 | QMenuBar *mb = new QMenuBar( menuBarHolder ); | 117 | QMenuBar *mb = new QMenuBar( menuBarHolder ); |
118 | QToolBar *tb = new QToolBar( this ); | 118 | QToolBar *tb = new QToolBar( this ); |
119 | 119 | ||
120 | QPopupMenu *fileMenu = new QPopupMenu( this ); | 120 | QPopupMenu *fileMenu = new QPopupMenu( this ); |
121 | 121 | ||
122 | 122 | ||
123 | QAction *a = new QAction( tr("Quit"), Resource::loadIconSet("quit_icon"), | 123 | QAction *a = new QAction( tr("Quit"), Resource::loadIconSet("quit_icon"), |
124 | QString::null, 0, this, "quit_action" ); | 124 | QString::null, 0, this, "quit_action" ); |
125 | /* | 125 | /* |
126 | * Connect quit to the QApplication quit slot | 126 | * Connect quit to the QApplication quit slot |
127 | */ | 127 | */ |
128 | connect(a, SIGNAL(activated() ), | 128 | connect(a, SIGNAL(activated() ), |
129 | qApp, SLOT(quit() ) ); | 129 | qApp, SLOT(quit() ) ); |
130 | a->addTo( fileMenu ); | 130 | a->addTo( fileMenu ); |
131 | 131 | ||
132 | a = new QAction(tr("View Current"), | 132 | a = new QAction(tr("View Current"), |
133 | Resource::loadIconSet("zoom"), | 133 | Resource::loadIconSet("zoom"), |
134 | QString::null, 0, this, "view current"); | 134 | QString::null, 0, this, "view current"); |
135 | /* a simple whats this online explanation of out button */ | 135 | /* a simple whats this online explanation of out button */ |
136 | a->setWhatsThis(tr("Views the current record") ); | 136 | a->setWhatsThis(tr("Views the current record") ); |
137 | /* or QWhatsThis::add(widget, "description" ); */ | 137 | /* or QWhatsThis::add(widget, "description" ); */ |
138 | 138 | ||
139 | /* see the power? */ | 139 | /* see the power? */ |
140 | a->addTo( fileMenu ); | 140 | a->addTo( fileMenu ); |
141 | a->addTo( tb ); | 141 | a->addTo( tb ); |
142 | m_fire = a; | 142 | m_fire = a; |
143 | 143 | ||
144 | a = new QAction(tr("Choose Date"), | 144 | a = new QAction(tr("Choose Date"), |
145 | Resource::loadIconSet("day"), | 145 | Resource::loadIconSet("day"), |
146 | QString::null, 0, this, "choose date" ); | 146 | QString::null, 0, this, "choose date" ); |
147 | a->addTo( fileMenu ); | 147 | a->addTo( fileMenu ); |
148 | a->addTo( tb ); | 148 | a->addTo( tb ); |
149 | m_dateAction = a; | 149 | m_dateAction = a; |
150 | 150 | ||
151 | mb->insertItem(tr("File"), fileMenu ); | 151 | mb->insertItem(tr("File"), fileMenu ); |
152 | 152 | ||
153 | } | 153 | } |
154 | 154 | ||
155 | void MainWindow::slotLoad() { | 155 | void MainWindow::slotLoad() { |
156 | /* | 156 | /* |
157 | * There is no real shared access in the PIM API | 157 | * There is no real shared access in the PIM API |
158 | * It wasn't finish cause of health problems of one | 158 | * It wasn't finish cause of health problems of one |
159 | * of the authors so we do something fancy and use QCOP | 159 | * of the authors so we do something fancy and use QCOP |
160 | * the IPC system to get a current copy | 160 | * the IPC system to get a current copy |
161 | */ | 161 | */ |
162 | /* NOTES to QCOP: QCOP operates over channels and use QDataStream | 162 | /* NOTES to QCOP: QCOP operates over channels and use QDataStream |
163 | * to send data. You can check if a channel isRegistered or hook | 163 | * to send data. You can check if a channel isRegistered or hook |
164 | * yourself to that channel. A Channel is QCString and normally | 164 | * yourself to that channel. A Channel is QCString and normally |
165 | * prefix with QPE/ and then the system in example QPE/System, | 165 | * prefix with QPE/ and then the system in example QPE/System, |
166 | * QPE/Desktop a special channel is the application channel | 166 | * QPE/Desktop a special channel is the application channel |
167 | * it QPE/Application/appname this channel gets created on app | 167 | * it QPE/Application/appname this channel gets created on app |
168 | * startup by QPEApplication. QCOP is asynchronous | 168 | * startup by QPEApplication. QCOP is asynchronous |
169 | * | 169 | * |
170 | * To send you'll use QCopEnevelope | 170 | * To send you'll use QCopEnevelope |
171 | * | 171 | * |
172 | */ | 172 | */ |
173 | /* | 173 | /* |
174 | * What we will do is first is get to know if either | 174 | * What we will do is first is get to know if either |
175 | * datebook or todolist are running if so we will kindly | 175 | * datebook or todolist are running if so we will kindly |
176 | * asked to save the data for us. | 176 | * asked to save the data for us. |
177 | * If neither are running we can load directly | 177 | * If neither are running we can load directly |
178 | */ | 178 | */ |
179 | if (!QCopChannel::isRegistered("QPE/Application/todolist") && | 179 | if (!QCopChannel::isRegistered("QPE/Application/todolist") && |
180 | !QCopChannel::isRegistered("QPE/Application/datebook") ) { | 180 | !QCopChannel::isRegistered("QPE/Application/datebook") ) { |
181 | m_db.load(); | 181 | m_db.load(); |
182 | m_tb.load(); | 182 | m_tb.load(); |
183 | return slotLoadForDay( QDate::currentDate() ); | 183 | return slotLoadForDay( QDate::currentDate() ); |
184 | } | 184 | } |
185 | 185 | ||
186 | /* | 186 | /* |
187 | * prepare our answer machine the QCopChannel | 187 | * prepare our answer machine the QCopChannel |
188 | * QPE/Desktop will send "flushDone(QString)" when | 188 | * QPE/Desktop will send "flushDone(QString)" when |
189 | * the flush is done it emits a signal on receive | 189 | * the flush is done it emits a signal on receive |
190 | */ | 190 | */ |
191 | m_desktopChannel = new QCopChannel("QPE/Desktop"); | 191 | m_desktopChannel = new QCopChannel("QPE/Desktop"); |
192 | connect(m_desktopChannel, SIGNAL(received(const QCString&, const QByteArray& ) ), | 192 | connect(m_desktopChannel, SIGNAL(received(const QCString&,const QByteArray&) ), |
193 | this, SLOT(slotDesktopReceive(const QCString&, const QByteArray& ) ) ); | 193 | this, SLOT(slotDesktopReceive(const QCString&,const QByteArray&) ) ); |
194 | /* the numberof synced channels will be set to zero */ | 194 | /* the numberof synced channels will be set to zero */ |
195 | m_synced = 0; | 195 | m_synced = 0; |
196 | 196 | ||
197 | /* | 197 | /* |
198 | * We use {} around the QCopEnvelope because it sends its | 198 | * We use {} around the QCopEnvelope because it sends its |
199 | * data on destruction of QCopEnvelope with | 199 | * data on destruction of QCopEnvelope with |
200 | */ | 200 | */ |
201 | /* check again if not present increment synced*/ | 201 | /* check again if not present increment synced*/ |
202 | if ( QCopChannel::isRegistered("QPE/Application/todolist") ) { | 202 | if ( QCopChannel::isRegistered("QPE/Application/todolist") ) { |
203 | QCopEnvelope env("QPE/Application/todolist", "flush()" ); | 203 | QCopEnvelope env("QPE/Application/todolist", "flush()" ); |
204 | // env << data; but we do not have any parameters here | 204 | // env << data; but we do not have any parameters here |
205 | }else | 205 | }else |
206 | m_synced++; | 206 | m_synced++; |
207 | 207 | ||
208 | if ( QCopChannel::isRegistered("QPE/Application/datebook") ) { | 208 | if ( QCopChannel::isRegistered("QPE/Application/datebook") ) { |
209 | QCopEnvelope env("QPE/Application/datebook", "flush()" ); | 209 | QCopEnvelope env("QPE/Application/datebook", "flush()" ); |
210 | }else | 210 | }else |
211 | m_synced++; | 211 | m_synced++; |
212 | 212 | ||
213 | /* we will provide a wait scrren */ | 213 | /* we will provide a wait scrren */ |
214 | m_loading = new OWait(this, "wait screen" ); | 214 | m_loading = new OWait(this, "wait screen" ); |
215 | } | 215 | } |
216 | 216 | ||
217 | void MainWindow::slotDesktopReceive(const QCString& cmd, const QByteArray& data ) { | 217 | void MainWindow::slotDesktopReceive(const QCString& cmd, const QByteArray& data ) { |
218 | /* the bytearray was filled with the QDataStream now | 218 | /* the bytearray was filled with the QDataStream now |
219 | * we open it read only to get the value(s) | 219 | * we open it read only to get the value(s) |
220 | */ | 220 | */ |
221 | QDataStream stream(data, IO_ReadOnly ); | 221 | QDataStream stream(data, IO_ReadOnly ); |
222 | /* | 222 | /* |
223 | * we're only interested in the flushDone | 223 | * we're only interested in the flushDone |
224 | */ | 224 | */ |
225 | if ( cmd == "flushDone(QString)" ) { | 225 | if ( cmd == "flushDone(QString)" ) { |
226 | QString appname; | 226 | QString appname; |
227 | stream >> appname; // get the first argument out of stream | 227 | stream >> appname; // get the first argument out of stream |
228 | if (appname == QString::fromLatin1("datebook") || | 228 | if (appname == QString::fromLatin1("datebook") || |
229 | appname == QString::fromLatin1("todolist") ) | 229 | appname == QString::fromLatin1("todolist") ) |
230 | m_synced++; | 230 | m_synced++; |
231 | } | 231 | } |
232 | 232 | ||
233 | /* | 233 | /* |
234 | * If we synced both we can go ahead | 234 | * If we synced both we can go ahead |
235 | * In future this is not needed anymore when we finally | 235 | * In future this is not needed anymore when we finally |
236 | * implemented X-Ref and other PIM features | 236 | * implemented X-Ref and other PIM features |
237 | */ | 237 | */ |
238 | if (m_synced >= 2 ) { | 238 | if (m_synced >= 2 ) { |
239 | delete m_loading; | 239 | delete m_loading; |
240 | delete m_desktopChannel; | 240 | delete m_desktopChannel; |
241 | /* now we finally can start doing the actual loading */ | 241 | /* now we finally can start doing the actual loading */ |
242 | m_tb.load(); | 242 | m_tb.load(); |
243 | m_db.load(); | 243 | m_db.load(); |
244 | { | 244 | { |
245 | /* tell the applications to reload */ | 245 | /* tell the applications to reload */ |
246 | QCopEnvelope("QPE/Application/todolist", "reload()"); | 246 | QCopEnvelope("QPE/Application/todolist", "reload()"); |
247 | QCopEnvelope("QPE/Application/datebook", "reload()"); | 247 | QCopEnvelope("QPE/Application/datebook", "reload()"); |
248 | } | 248 | } |
249 | slotLoadForDay( QDate::currentDate() ); | 249 | slotLoadForDay( QDate::currentDate() ); |
250 | } | 250 | } |
251 | 251 | ||
252 | } | 252 | } |
253 | 253 | ||
254 | /* overloaded member for shortcoming of libqpe */ | 254 | /* overloaded member for shortcoming of libqpe */ |
255 | void MainWindow::slotLoadForDay(int y, int m, int d) { | 255 | void MainWindow::slotLoadForDay(int y, int m, int d) { |
256 | /* year,month, day */ | 256 | /* year,month, day */ |
257 | slotLoadForDay( QDate(y, m, d ) ); | 257 | slotLoadForDay( QDate(y, m, d ) ); |
258 | } | 258 | } |
259 | 259 | ||
260 | void MainWindow::slotLoadForDay(const QDate& date) { | 260 | void MainWindow::slotLoadForDay(const QDate& date) { |
261 | 261 | ||
262 | 262 | ||
263 | /* all todos for today including the ones without dueDate */ | 263 | /* all todos for today including the ones without dueDate */ |
264 | m_todoView->set( m_tb.effectiveToDos(date, date ) ); | 264 | m_todoView->set( m_tb.effectiveToDos(date, date ) ); |
265 | m_dateView->set( m_db.effectiveEvents( date, date ) ); | 265 | m_dateView->set( m_db.effectiveEvents( date, date ) ); |
266 | } | 266 | } |
267 | 267 | ||
268 | /* we want to show the current record */ | 268 | /* we want to show the current record */ |
269 | void MainWindow::slotShow() { | 269 | void MainWindow::slotShow() { |
270 | /* we only added PIMListViews so we can safely cast */ | 270 | /* we only added PIMListViews so we can safely cast */ |
271 | PIMListView *view = static_cast<PIMListView*>(m_tab->currentWidget() ); | 271 | PIMListView *view = static_cast<PIMListView*>(m_tab->currentWidget() ); |
272 | 272 | ||
273 | /* ask the view to send a signal */ | 273 | /* ask the view to send a signal */ |
274 | view->showCurrentRecord(); | 274 | view->showCurrentRecord(); |
275 | 275 | ||
276 | } | 276 | } |
277 | 277 | ||
278 | /* as answer this slot will be called */ | 278 | /* as answer this slot will be called */ |
279 | void MainWindow::slotShowRecord( const OPimRecord& rec) { | 279 | void MainWindow::slotShowRecord( const OPimRecord& rec) { |
280 | /* got a parent but still is a toplevel MODAL dialog */ | 280 | /* got a parent but still is a toplevel MODAL dialog */ |
281 | QDialog* dia = new QDialog(this,"dialog",TRUE ); | 281 | QDialog* dia = new QDialog(this,"dialog",TRUE ); |
282 | QVBoxLayout *box = new QVBoxLayout( dia ); | 282 | QVBoxLayout *box = new QVBoxLayout( dia ); |
283 | dia->setCaption( tr("View Record") ); | 283 | dia->setCaption( tr("View Record") ); |
284 | 284 | ||
285 | 285 | ||
286 | QTextView *view = new QTextView(dia ); | 286 | QTextView *view = new QTextView(dia ); |
287 | view->setText( rec.toRichText() ); | 287 | view->setText( rec.toRichText() ); |
288 | box->addWidget( view ); | 288 | box->addWidget( view ); |
289 | /* | 289 | /* |
290 | * execute via QPEApplication | 290 | * execute via QPEApplication |
291 | * this allows QPEApplication to make a sane decision | 291 | * this allows QPEApplication to make a sane decision |
292 | * on the size | 292 | * on the size |
293 | */ | 293 | */ |
294 | dia->showMaximized(); | 294 | dia->showMaximized(); |
295 | QPEApplication::execDialog( dia ); | 295 | QPEApplication::execDialog( dia ); |
296 | delete dia; | 296 | delete dia; |
297 | } | 297 | } |
298 | 298 | ||
299 | 299 | ||
300 | void MainWindow::slotDate() { | 300 | void MainWindow::slotDate() { |
301 | /* | 301 | /* |
302 | * called by the action we will show a Popup | 302 | * called by the action we will show a Popup |
303 | * at the current mouse position with a DateChooser | 303 | * at the current mouse position with a DateChooser |
304 | * to select the day | 304 | * to select the day |
305 | */ | 305 | */ |
306 | qWarning("slot Date"); | 306 | qWarning("slot Date"); |
307 | QPopupMenu *menu = new QPopupMenu(); | 307 | QPopupMenu *menu = new QPopupMenu(); |
308 | /* A Month to select a date from TRUE for auto close */ | 308 | /* A Month to select a date from TRUE for auto close */ |
309 | DateBookMonth *month = new DateBookMonth(menu, 0, true ); | 309 | DateBookMonth *month = new DateBookMonth(menu, 0, true ); |
310 | connect(month, SIGNAL(dateClicked(int, int, int) ), | 310 | connect(month, SIGNAL(dateClicked(int,int,int) ), |
311 | this, SLOT(slotLoadForDay(int, int, int) ) ); | 311 | this, SLOT(slotLoadForDay(int,int,int) ) ); |
312 | 312 | ||
313 | menu->insertItem( month ); | 313 | menu->insertItem( month ); |
314 | 314 | ||
315 | menu->exec( QCursor::pos() ); | 315 | menu->exec( QCursor::pos() ); |
316 | 316 | ||
317 | /* | 317 | /* |
318 | * we do not need to delete month because | 318 | * we do not need to delete month because |
319 | * we delete its parent menu | 319 | * we delete its parent menu |
320 | */ | 320 | */ |
321 | 321 | ||
322 | delete menu; | 322 | delete menu; |
323 | } | 323 | } |
324 | 324 | ||
325 | /* | 325 | /* |
326 | * An anonymous namespace this symbol is only available here | 326 | * An anonymous namespace this symbol is only available here |
327 | * so truely private | 327 | * so truely private |
328 | */ | 328 | */ |
329 | namespace { | 329 | namespace { |
330 | /* not static cause namespace does that what static would do */ | 330 | /* not static cause namespace does that what static would do */ |
331 | const int RTTI = 5050; | 331 | const int RTTI = 5050; |
332 | /* | 332 | /* |
333 | * every ListView got Items. we've special pim items | 333 | * every ListView got Items. we've special pim items |
334 | * holding ownership and the pointer to a pim record | 334 | * holding ownership and the pointer to a pim record |
335 | * it can't hold a pimrecord directly because this | 335 | * it can't hold a pimrecord directly because this |
336 | * would introduce slicing... any break | 336 | * would introduce slicing... any break |
337 | */ | 337 | */ |
338 | /* | 338 | /* |
339 | * A struct is a special class. Everything is public by | 339 | * A struct is a special class. Everything is public by |
340 | * default. | 340 | * default. |
341 | */ | 341 | */ |
342 | struct PIMListViewItem : public QListViewItem { | 342 | struct PIMListViewItem : public QListViewItem { |
343 | /* | 343 | /* |
344 | *currently no hierachies are planed for the example | 344 | *currently no hierachies are planed for the example |
345 | * so only one constructor with a QListView as parent | 345 | * so only one constructor with a QListView as parent |
346 | */ | 346 | */ |
347 | PIMListViewItem( QListView*, OPimRecord* record ); | 347 | PIMListViewItem( QListView*, OPimRecord* record ); |
348 | ~PIMListViewItem(); | 348 | ~PIMListViewItem(); |
349 | 349 | ||
350 | /* used by the QListViewItem to easily allow identifiying of different | 350 | /* used by the QListViewItem to easily allow identifiying of different |
351 | * items. Values greater than 1000 should be used */ | 351 | * items. Values greater than 1000 should be used */ |
352 | int rtti()const; | 352 | int rtti()const; |
353 | OPimRecord* record()const; | 353 | OPimRecord* record()const; |
354 | 354 | ||
355 | private: | 355 | private: |
356 | OPimRecord* m_record; | 356 | OPimRecord* m_record; |
357 | }; | 357 | }; |
358 | 358 | ||
359 | PIMListViewItem::PIMListViewItem( QListView *p, OPimRecord* rec ) | 359 | PIMListViewItem::PIMListViewItem( QListView *p, OPimRecord* rec ) |
360 | : QListViewItem(p), m_record( rec ) { | 360 | : QListViewItem(p), m_record( rec ) { |
361 | } | 361 | } |
362 | 362 | ||
363 | PIMListViewItem::~PIMListViewItem() { | 363 | PIMListViewItem::~PIMListViewItem() { |
364 | /* we've the onwership so we need to delete it */ | 364 | /* we've the onwership so we need to delete it */ |
365 | delete m_record; | 365 | delete m_record; |
366 | } | 366 | } |
367 | 367 | ||
368 | OPimRecord* PIMListViewItem::record()const { | 368 | OPimRecord* PIMListViewItem::record()const { |
369 | return m_record; | 369 | return m_record; |
370 | } | 370 | } |
371 | 371 | ||
372 | } | 372 | } |
373 | 373 | ||
374 | 374 | ||
375 | PIMListView::PIMListView( QWidget* widget, const char* name, WFlags fl ) | 375 | PIMListView::PIMListView( QWidget* widget, const char* name, WFlags fl ) |
376 | : QListView(widget, name, fl ) | 376 | : QListView(widget, name, fl ) |
377 | { | 377 | { |
378 | addColumn("Summary"); | 378 | addColumn("Summary"); |
379 | } | 379 | } |
380 | 380 | ||
381 | PIMListView::~PIMListView() { | 381 | PIMListView::~PIMListView() { |
382 | 382 | ||
383 | } | 383 | } |
384 | 384 | ||
385 | void PIMListView::set( OTodoAccess::List list ) { | 385 | void PIMListView::set( OTodoAccess::List list ) { |
386 | /* clear first and then add new items */ | 386 | /* clear first and then add new items */ |
387 | clear(); | 387 | clear(); |
388 | 388 | ||
389 | OTodoAccess::List::Iterator it; | 389 | OTodoAccess::List::Iterator it; |
390 | for (it = list.begin(); it != list.end(); ++it ) { | 390 | for (it = list.begin(); it != list.end(); ++it ) { |
391 | /* | 391 | /* |
392 | * make a new item which automatically gets added to the listview | 392 | * make a new item which automatically gets added to the listview |
393 | * and call the copy c'tor to create a new OTodo | 393 | * and call the copy c'tor to create a new OTodo |
394 | */ | 394 | */ |
395 | PIMListViewItem *i = new PIMListViewItem(this, new OTodo( *it ) ); | 395 | PIMListViewItem *i = new PIMListViewItem(this, new OTodo( *it ) ); |
396 | i->setText(0, (*it).summary() ); | 396 | i->setText(0, (*it).summary() ); |
397 | } | 397 | } |
398 | } | 398 | } |
399 | 399 | ||
400 | void PIMListView::set( const OEffectiveEvent::ValueList& lst ) { | 400 | void PIMListView::set( const OEffectiveEvent::ValueList& lst ) { |
401 | /* clear first and then add items */ | 401 | /* clear first and then add items */ |
402 | clear(); | 402 | clear(); |
403 | 403 | ||
404 | OEffectiveEvent::ValueList::ConstIterator it; | 404 | OEffectiveEvent::ValueList::ConstIterator it; |
405 | for ( it = lst.begin(); it != lst.end(); ++it ) { | 405 | for ( it = lst.begin(); it != lst.end(); ++it ) { |
406 | PIMListViewItem *i = new PIMListViewItem(this, new OEvent( (*it).event() ) ); | 406 | PIMListViewItem *i = new PIMListViewItem(this, new OEvent( (*it).event() ) ); |
407 | i->setText( 0, PIMListView::makeString( (*it) ) ); | 407 | i->setText( 0, PIMListView::makeString( (*it) ) ); |
408 | } | 408 | } |
409 | 409 | ||
410 | } | 410 | } |
411 | 411 | ||
412 | void PIMListView::showCurrentRecord() { | 412 | void PIMListView::showCurrentRecord() { |
413 | /* it could be possible that their is no currentItem */ | 413 | /* it could be possible that their is no currentItem */ |
414 | if (!currentItem() ) | 414 | if (!currentItem() ) |
415 | return; | 415 | return; |
416 | 416 | ||
417 | /* | 417 | /* |
418 | * we only add PIMListViewItems so it is save | 418 | * we only add PIMListViewItems so it is save |
419 | * to do this case. If this would not be the case | 419 | * to do this case. If this would not be the case |
420 | * use rtti() to check in a switch() case | 420 | * use rtti() to check in a switch() case |
421 | */ | 421 | */ |
422 | PIMListViewItem *item = static_cast<PIMListViewItem*>( currentItem() ); | 422 | PIMListViewItem *item = static_cast<PIMListViewItem*>( currentItem() ); |
423 | 423 | ||
424 | /* finally you see how to emit a signal */ | 424 | /* finally you see how to emit a signal */ |
425 | emit showRecord( (*item->record() ) ); | 425 | emit showRecord( (*item->record() ) ); |
426 | } | 426 | } |
427 | 427 | ||
428 | QString PIMListView::makeString( const OEffectiveEvent& ev ) { | 428 | QString PIMListView::makeString( const OEffectiveEvent& ev ) { |
429 | QString str; | 429 | QString str; |
430 | str += ev.description(); | 430 | str += ev.description(); |
431 | if ( !ev.event().isAllDay() ) { | 431 | if ( !ev.event().isAllDay() ) { |
432 | if ( ev.startDate() != ev.endDate() ) { | 432 | if ( ev.startDate() != ev.endDate() ) { |
433 | str += tr("Start ") + TimeString::timeString( ev.event().startDateTime().time() ); | 433 | str += tr("Start ") + TimeString::timeString( ev.event().startDateTime().time() ); |
434 | str += " - " + TimeString::longDateString( ev.startDate() ); | 434 | str += " - " + TimeString::longDateString( ev.startDate() ); |
435 | str += tr("End ") + TimeString::timeString( ev.event().endDateTime().time() ); | 435 | str += tr("End ") + TimeString::timeString( ev.event().endDateTime().time() ); |
436 | str += " - " + TimeString::longDateString( ev.endDate() ); | 436 | str += " - " + TimeString::longDateString( ev.endDate() ); |
437 | }else{ | 437 | }else{ |
438 | str += tr("Time ") + TimeString::timeString( ev.startTime() ); | 438 | str += tr("Time ") + TimeString::timeString( ev.startTime() ); |
439 | str += " - " + TimeString::timeString( ev.endTime() ); | 439 | str += " - " + TimeString::timeString( ev.endTime() ); |
440 | } | 440 | } |
441 | }else | 441 | }else |
442 | str += tr(" This is an All-Day Event"); | 442 | str += tr(" This is an All-Day Event"); |
443 | 443 | ||
444 | return str; | 444 | return str; |
445 | } | 445 | } |