summaryrefslogtreecommitdiff
path: root/libopie2
authordrw <drw>2005-02-02 18:37:25 (UTC)
committer drw <drw>2005-02-02 18:37:25 (UTC)
commit5b2a4d83b6b60cc9ca634aeb481cf15d70fc9b2f (patch) (unidiff)
treed25b57c129781d58800fd708a207cb128737c8fb /libopie2
parent130d8dbc763e51cf072c39c21f5fa7ae15f56ba3 (diff)
downloadopie-5b2a4d83b6b60cc9ca634aeb481cf15d70fc9b2f.zip
opie-5b2a4d83b6b60cc9ca634aeb481cf15d70fc9b2f.tar.gz
opie-5b2a4d83b6b60cc9ca634aeb481cf15d70fc9b2f.tar.bz2
Some minor updates/simplification
Diffstat (limited to 'libopie2') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiepim/ui/opimmainwindow.cpp24
-rw-r--r--libopie2/opiepim/ui/opimmainwindow.h5
2 files changed, 6 insertions, 23 deletions
diff --git a/libopie2/opiepim/ui/opimmainwindow.cpp b/libopie2/opiepim/ui/opimmainwindow.cpp
index a72d174..053b250 100644
--- a/libopie2/opiepim/ui/opimmainwindow.cpp
+++ b/libopie2/opiepim/ui/opimmainwindow.cpp
@@ -1,384 +1,372 @@
1/* 1/*
2 This file is part of the Opie Project 2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de) 3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org> 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l. 5 .=l.
6 .>+-= 6 .>+-=
7 _;:, .> :=|. This program is free software; you can 7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under 8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software 10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License, 11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version. 12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_. 13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that 14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY; 15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of 16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A 17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU 18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more 19..}^=.= = ; Library General Public License for more
20++= -. .` .: details. 20++= -. .` .: details.
21 : = ...= . :.=- 21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU 22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with 23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB. 24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28*/ 28*/
29 29
30#include "opimmainwindow.h" 30#include "opimmainwindow.h"
31 31
32/* OPIE */ 32/* OPIE */
33#include <opie2/opimresolver.h> 33#include <opie2/opimresolver.h>
34#include <opie2/odebug.h> 34#include <opie2/odebug.h>
35 35
36#include <qpe/categoryselect.h> 36#include <qpe/categoryselect.h>
37#include <qpe/ir.h> 37#include <qpe/ir.h>
38#include <qpe/qcopenvelope_qws.h> 38#include <qpe/qcopenvelope_qws.h>
39#include <qpe/qpeapplication.h> 39#include <qpe/qpeapplication.h>
40#include <qpe/resource.h> 40#include <qpe/resource.h>
41#include <qpe/sound.h> 41#include <qpe/sound.h>
42 42
43/* QT */ 43/* QT */
44#include <qaction.h> 44#include <qaction.h>
45#include <qapplication.h> 45#include <qapplication.h>
46#include <qcombobox.h> 46#include <qcombobox.h>
47#include <qcopchannel_qws.h> 47#include <qcopchannel_qws.h>
48#include <qdatetime.h> 48#include <qdatetime.h>
49#include <qmenubar.h> 49#include <qmenubar.h>
50#include <qobjectlist.h> 50#include <qobjectlist.h>
51#include <qpopupmenu.h> 51#include <qpopupmenu.h>
52#include <qtoolbar.h> 52#include <qtoolbar.h>
53#include <qwhatsthis.h>
53 54
54namespace Opie { 55namespace Opie {
55OPimMainWindow::OPimMainWindow( const QString &serviceName, 56OPimMainWindow::OPimMainWindow( const QString &serviceName, const QString &catName,
56 const QString &appName, const QString &catName,
57 const QString &itemName, const QString &configName, 57 const QString &itemName, const QString &configName,
58 QWidget *parent, const char* name, WFlags f ) 58 QWidget *parent, const char* name, WFlags f )
59 : QMainWindow( parent, name, f ), m_rtti(-1), m_service( serviceName ), m_fallBack( 0l ), 59 : QMainWindow( parent, name, f ), m_rtti(-1), m_service( serviceName ), m_fallBack( 0l ),
60 m_appName( appName ), m_catGroupName( catName ), m_config( configName ), m_itemContextMenu( 0l ) 60 m_catGroupName( catName ), m_config( configName ), m_itemContextMenu( 0l )
61{ 61{
62 62
63 /* 63 /*
64 * let's generate our QCopChannel 64 * let's generate our QCopChannel
65 */ 65 */
66 m_str = QString("QPE/"+m_service).local8Bit(); 66 m_str = QString("QPE/"+m_service).local8Bit();
67 m_channel= new QCopChannel(m_str, this ); 67 m_channel= new QCopChannel(m_str, this );
68 connect(m_channel, SIGNAL(received(const QCString&,const QByteArray&)), 68 connect(m_channel, SIGNAL(received(const QCString&,const QByteArray&)),
69 this, SLOT(appMessage(const QCString&,const QByteArray&)) ); 69 this, SLOT(appMessage(const QCString&,const QByteArray&)) );
70 connect(qApp, SIGNAL(appMessage(const QCString&,const QByteArray&)), 70 connect(qApp, SIGNAL(appMessage(const QCString&,const QByteArray&)),
71 this, SLOT(appMessage(const QCString&,const QByteArray&)) ); 71 this, SLOT(appMessage(const QCString&,const QByteArray&)) );
72 72
73 /* connect flush and reload */ 73 /* connect flush and reload */
74 connect(qApp, SIGNAL(flush() ), 74 connect(qApp, SIGNAL(flush() ),
75 this, SLOT(flush() ) ); 75 this, SLOT(flush() ) );
76 connect(qApp, SIGNAL(reload() ), 76 connect(qApp, SIGNAL(reload() ),
77 this, SLOT(reload() ) ); 77 this, SLOT(reload() ) );
78 78
79 // Initialize user interface items
80 setCaption( m_appName );
81 initBars( itemName ); 79 initBars( itemName );
82} 80}
83 81
84OPimMainWindow::~OPimMainWindow() { 82OPimMainWindow::~OPimMainWindow() {
85 delete m_channel; 83 delete m_channel;
86} 84}
87 85
88QCopChannel* OPimMainWindow::channel() { 86QCopChannel* OPimMainWindow::channel() {
89 return m_channel; 87 return m_channel;
90} 88}
91 89
92void OPimMainWindow::doSetDocument( const QString& ) { 90void OPimMainWindow::doSetDocument( const QString& ) {
93 91
94} 92}
95 93
96void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) { 94void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) {
97 bool needShow = false; 95 bool needShow = false;
98 /* 96 /*
99 * create demands to create 97 * create demands to create
100 * a new record... 98 * a new record...
101 */ 99 */
102 QDataStream stream(array, IO_ReadOnly); 100 QDataStream stream(array, IO_ReadOnly);
103 if ( cmd == "create()" ) { 101 if ( cmd == "create()" ) {
104 raise(); 102 raise();
105 int uid = create(); 103 int uid = create();
106 QCopEnvelope e(m_str, "created(int)" ); 104 QCopEnvelope e(m_str, "created(int)" );
107 e << uid; 105 e << uid;
108 needShow = true; 106 needShow = true;
109 }else if ( cmd == "remove(int)" ) { 107 }else if ( cmd == "remove(int)" ) {
110 int uid; 108 int uid;
111 stream >> uid; 109 stream >> uid;
112 bool rem = remove( uid ); 110 bool rem = remove( uid );
113 QCopEnvelope e(m_str, "removed(bool)" ); 111 QCopEnvelope e(m_str, "removed(bool)" );
114 e << rem; 112 e << rem;
115 needShow = true; 113 needShow = true;
116 }else if ( cmd == "beam(int)" ) { 114 }else if ( cmd == "beam(int)" ) {
117 int uid; 115 int uid;
118 stream >> uid; 116 stream >> uid;
119 beam( uid); 117 beam( uid);
120 }else if ( cmd == "show(int)" ) { 118 }else if ( cmd == "show(int)" ) {
121 raise(); 119 raise();
122 int uid; 120 int uid;
123 stream >> uid; 121 stream >> uid;
124 show( uid ); 122 show( uid );
125 needShow = true; 123 needShow = true;
126 }else if ( cmd == "edit(int)" ) { 124 }else if ( cmd == "edit(int)" ) {
127 raise(); 125 raise();
128 int uid; 126 int uid;
129 stream >> uid; 127 stream >> uid;
130 edit( uid ); 128 edit( uid );
131 }else if ( cmd == "add(int,QByteArray)" ) { 129 }else if ( cmd == "add(int,QByteArray)" ) {
132 int rtti; 130 int rtti;
133 QByteArray array; 131 QByteArray array;
134 stream >> rtti; 132 stream >> rtti;
135 stream >> array; 133 stream >> array;
136 m_fallBack = record(rtti, array ); 134 m_fallBack = record(rtti, array );
137 if (!m_fallBack) return; 135 if (!m_fallBack) return;
138 add( *m_fallBack ); 136 add( *m_fallBack );
139 delete m_fallBack; 137 delete m_fallBack;
140 }else if ( cmd == "alarm(QDateTime,int)" ) { 138 }else if ( cmd == "alarm(QDateTime,int)" ) {
141 raise(); 139 raise();
142 QDateTime dt; int uid; 140 QDateTime dt; int uid;
143 stream >> dt; 141 stream >> dt;
144 stream >> uid; 142 stream >> uid;
145 QDateTime current = QDateTime::currentDateTime(); 143 QDateTime current = QDateTime::currentDateTime();
146 if ( current.time().hour() != dt.time().hour() && current.time().minute() != dt.time().minute() ) 144 if ( current.time().hour() != dt.time().hour() && current.time().minute() != dt.time().minute() )
147 return; 145 return;
148 doAlarm( dt, uid ); 146 doAlarm( dt, uid );
149 needShow = true; 147 needShow = true;
150 } 148 }
151 149
152 if (needShow ) 150 if (needShow )
153 QPEApplication::setKeepRunning(); 151 QPEApplication::setKeepRunning();
154} 152}
155 153
156/* implement the url scripting here */ 154/* implement the url scripting here */
157void OPimMainWindow::setDocument( const QString& str) { 155void OPimMainWindow::setDocument( const QString& str) {
158 doSetDocument( str ); 156 doSetDocument( str );
159} 157}
160 158
161/* 159/*
162 * we now try to get the array demarshalled 160 * we now try to get the array demarshalled
163 * check if the rtti matches this one 161 * check if the rtti matches this one
164 */ 162 */
165OPimRecord* OPimMainWindow::record( int rtti, const QByteArray& array ) { 163OPimRecord* OPimMainWindow::record( int rtti, const QByteArray& array ) {
166 if ( service() != rtti ) 164 if ( service() != rtti )
167 return 0l; 165 return 0l;
168 166
169 OPimRecord* record = OPimResolver::self()->record( rtti ); 167 OPimRecord* record = OPimResolver::self()->record( rtti );
170 QDataStream str(array, IO_ReadOnly ); 168 QDataStream str(array, IO_ReadOnly );
171 if ( !record || !record->loadFromStream(str) ) { 169 if ( !record || !record->loadFromStream(str) ) {
172 delete record; 170 delete record;
173 record = 0l; 171 record = 0l;
174 } 172 }
175 173
176 return record; 174 return record;
177} 175}
178 176
179/* 177/*
180 * get the rtti for the service 178 * get the rtti for the service
181 */ 179 */
182int OPimMainWindow::service() { 180int OPimMainWindow::service() {
183 if ( m_rtti == -1 ) 181 if ( m_rtti == -1 )
184 m_rtti = OPimResolver::self()->serviceId( m_service ); 182 m_rtti = OPimResolver::self()->serviceId( m_service );
185 183
186 return m_rtti; 184 return m_rtti;
187} 185}
188 186
189void OPimMainWindow::doAlarm( const QDateTime&, int ) { 187void OPimMainWindow::doAlarm( const QDateTime&, int ) {
190 188
191} 189}
192 190
193void OPimMainWindow::startAlarm(int count ) { 191void OPimMainWindow::startAlarm(int count ) {
194 m_alarmCount = count; 192 m_alarmCount = count;
195 m_playedCount = 0; 193 m_playedCount = 0;
196 Sound::soundAlarm(); 194 Sound::soundAlarm();
197 m_timerId = startTimer( 5000 ); 195 m_timerId = startTimer( 5000 );
198} 196}
199 197
200void OPimMainWindow::killAlarm() { 198void OPimMainWindow::killAlarm() {
201 killTimer( m_timerId ); 199 killTimer( m_timerId );
202} 200}
203 201
204void OPimMainWindow::timerEvent( QTimerEvent* e) { 202void OPimMainWindow::timerEvent( QTimerEvent* e) {
205 if ( m_playedCount <m_alarmCount ) { 203 if ( m_playedCount <m_alarmCount ) {
206 m_playedCount++; 204 m_playedCount++;
207 Sound::soundAlarm(); 205 Sound::soundAlarm();
208 }else { 206 }else {
209 killTimer( e->timerId() ); 207 killTimer( e->timerId() );
210 } 208 }
211} 209}
212 210
213QPopupMenu *OPimMainWindow::itemContextMenu() { 211QPopupMenu *OPimMainWindow::itemContextMenu() {
214 if ( !m_itemContextMenu ) { 212 if ( !m_itemContextMenu ) {
215 // Create context menu if hasn't been done before 213 // Create context menu if hasn't been done before
216 m_itemContextMenu = new QPopupMenu( this ); 214 m_itemContextMenu = new QPopupMenu( this );
217 m_itemEditAction->addTo( m_itemContextMenu ); 215 m_itemEditAction->addTo( m_itemContextMenu );
218 m_itemDuplicateAction->addTo( m_itemContextMenu ); 216 m_itemDuplicateAction->addTo( m_itemContextMenu );
219 m_itemDeleteAction->addTo( m_itemContextMenu ); 217 m_itemDeleteAction->addTo( m_itemContextMenu );
220 } 218 }
221 219
222 return m_itemContextMenu; 220 return m_itemContextMenu;
223} 221}
224 222
225void OPimMainWindow::insertItemMenuItems( QActionGroup *items ) { 223void OPimMainWindow::insertItemMenuItems( QActionGroup *items ) {
226 // Insert menu items into Item menu 224 // Insert menu items into Item menu
227 if ( items ) { 225 if ( items ) {
228 // Rebuild Item menu 226 // Rebuild Item menu
229 m_itemMenu->clear(); 227 m_itemMenu->clear();
230 m_itemMenuGroup1->addTo( m_itemMenu ); 228 m_itemMenuGroup1->addTo( m_itemMenu );
231 m_itemMenu->insertSeparator(); 229 m_itemMenu->insertSeparator();
232 items->addTo( m_itemMenu ); 230 items->addTo( m_itemMenu );
233 m_itemMenu->insertSeparator(); 231 m_itemMenu->insertSeparator();
234 m_itemMenuGroup2->addTo( m_itemMenu ); 232 m_itemMenuGroup2->addTo( m_itemMenu );
235 } 233 }
236} 234}
237 235
238void OPimMainWindow::insertViewMenuItems( QActionGroup *items ) { 236void OPimMainWindow::insertViewMenuItems( QActionGroup *items ) {
239 // Insert menu items into View menu 237 // Insert menu items into View menu
240 if ( items ) { 238 if ( items ) {
241 // Rebuild Item menu 239 // Rebuild Item menu
242 m_viewMenu->clear(); 240 m_viewMenu->clear();
243 m_viewMenuGroup->addTo( m_viewMenu ); 241 m_viewMenuGroup->addTo( m_viewMenu );
244 m_viewMenu->insertSeparator(); 242 m_viewMenu->insertSeparator();
245 m_viewMenuAppGroup = items; 243 m_viewMenuAppGroup = items;
246 m_viewMenuAppGroup->addTo( m_viewMenu ); 244 m_viewMenuAppGroup->addTo( m_viewMenu );
247 } 245 }
248} 246}
249 247
250void OPimMainWindow::slotViewCategory( const QString &category ) {
251 // Set application caption
252 QString caption = m_appName;
253 if ( category != tr( "All" ) )
254 caption.append( QString( " - %1" ).arg( category ) );
255 setCaption( caption );
256
257 // Notify application
258 emit categorySelected( category );
259}
260
261void OPimMainWindow::setViewCategory( const QString &category ) { 248void OPimMainWindow::setViewCategory( const QString &category ) {
262 // Find category in list 249 // Find category in list
263 for ( int i = 0; i < m_catSelect->count(); i++ ) { 250 for ( int i = 0; i < m_catSelect->count(); i++ ) {
264 if ( m_catSelect->text( i ) == category ) { 251 if ( m_catSelect->text( i ) == category ) {
265 m_catSelect->setCurrentItem( i ); 252 m_catSelect->setCurrentItem( i );
266 slotViewCategory( category ); 253 emit categorySelected( category );
267 return; 254 return;
268 } 255 }
269 } 256 }
270} 257}
271 258
272void OPimMainWindow::reloadCategories() { 259void OPimMainWindow::reloadCategories() {
273 QString selected = m_catSelect->currentText(); 260 QString selected = m_catSelect->currentText();
274 261
275 // Remove old categories from list 262 // Remove old categories from list
276 m_catSelect->clear(); 263 m_catSelect->clear();
277 264
278 // Add categories to list 265 // Add categories to list
279 Categories cats; 266 Categories cats;
280 cats.load( categoryFileName() ); 267 cats.load( categoryFileName() );
281 m_catSelect->insertItem( tr( "All" ) ); 268 m_catSelect->insertItem( tr( "All" ) );
282 m_catSelect->insertStringList( cats.labels( m_catGroupName ) ); 269 m_catSelect->insertStringList( cats.labels( m_catGroupName ) );
283 m_catSelect->insertItem( tr( "Unfiled" ) ); 270 m_catSelect->insertItem( tr( "Unfiled" ) );
284} 271}
285 272
286void OPimMainWindow::initBars( const QString &itemName ) { 273void OPimMainWindow::initBars( const QString &itemName ) {
287 QString itemStr = itemName.lower(); 274 QString itemStr = itemName.lower();
288 275
289 setToolBarsMovable( false ); 276 setToolBarsMovable( false );
290 277
291 // Create application menu bar 278 // Create application menu bar
292 QToolBar *mbHold = new QToolBar( this ); 279 QToolBar *mbHold = new QToolBar( this );
293 mbHold->setHorizontalStretchable( true ); 280 mbHold->setHorizontalStretchable( true );
294 QMenuBar *menubar = new QMenuBar( mbHold ); 281 QMenuBar *menubar = new QMenuBar( mbHold );
295 menubar->setMargin( 0 ); 282 menubar->setMargin( 0 );
296 283
297 // Create application menu bar 284 // Create application menu bar
298 QToolBar *toolbar = new QToolBar( this ); 285 QToolBar *toolbar = new QToolBar( this );
299 286
300 // Create sub-menus 287 // Create sub-menus
301 m_itemMenu = new QPopupMenu( this ); 288 m_itemMenu = new QPopupMenu( this );
302 m_itemMenu->setCheckable( true ); 289 m_itemMenu->setCheckable( true );
303 menubar->insertItem( itemName, m_itemMenu ); 290 menubar->insertItem( itemName, m_itemMenu );
304 m_viewMenu = new QPopupMenu( this ); 291 m_viewMenu = new QPopupMenu( this );
305 m_viewMenu->setCheckable( true ); 292 m_viewMenu->setCheckable( true );
306 menubar->insertItem( tr( "View" ), m_viewMenu ); 293 menubar->insertItem( tr( "View" ), m_viewMenu );
307 294
308 m_viewMenuAppGroup = 0l; 295 m_viewMenuAppGroup = 0l;
309 296
310 // Item menu 297 // Item menu
311 m_itemMenuGroup1 = new QActionGroup( this, QString::null, false ); 298 m_itemMenuGroup1 = new QActionGroup( this, QString::null, false );
312 299
313 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), 300 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ),
314 QString::null, 0, m_itemMenuGroup1, 0 ); 301 QString::null, 0, m_itemMenuGroup1, 0 );
315 connect( a, SIGNAL(activated()), this, SLOT(slotItemNew()) ); 302 connect( a, SIGNAL(activated()), this, SLOT(slotItemNew()) );
316 a->setWhatsThis( tr( "Click here to create a new item." ) ); 303 a->setWhatsThis( tr( "Click here to create a new item." ) );
317 a->addTo( toolbar ); 304 a->addTo( toolbar );
318 305
319 m_itemEditAction = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ), 306 m_itemEditAction = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ),
320 QString::null, 0, m_itemMenuGroup1, 0 ); 307 QString::null, 0, m_itemMenuGroup1, 0 );
321 connect( m_itemEditAction, SIGNAL(activated()), this, SLOT(slotItemEdit()) ); 308 connect( m_itemEditAction, SIGNAL(activated()), this, SLOT(slotItemEdit()) );
322 m_itemEditAction->setWhatsThis( tr( "Click here to edit the selected item." ) ); 309 m_itemEditAction->setWhatsThis( tr( "Click here to edit the selected item." ) );
323 m_itemEditAction->addTo( toolbar ); 310 m_itemEditAction->addTo( toolbar );
324 311
325 m_itemDuplicateAction = new QAction( tr( "Duplicate" ), Resource::loadPixmap( "copy" ), 312 m_itemDuplicateAction = new QAction( tr( "Duplicate" ), Resource::loadPixmap( "copy" ),
326 QString::null, 0, m_itemMenuGroup1, 0 ); 313 QString::null, 0, m_itemMenuGroup1, 0 );
327 connect( m_itemDuplicateAction, SIGNAL(activated()), this, SLOT(slotItemDuplicate()) ); 314 connect( m_itemDuplicateAction, SIGNAL(activated()), this, SLOT(slotItemDuplicate()) );
328 m_itemDuplicateAction->setWhatsThis( tr( "Click here to duplicate the selected item." ) ); 315 m_itemDuplicateAction->setWhatsThis( tr( "Click here to duplicate the selected item." ) );
329 316
330 m_itemDeleteAction = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ), 317 m_itemDeleteAction = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ),
331 QString::null, 0, m_itemMenuGroup1, 0 ); 318 QString::null, 0, m_itemMenuGroup1, 0 );
332 connect( m_itemDeleteAction, SIGNAL(activated()), this, SLOT(slotItemDelete()) ); 319 connect( m_itemDeleteAction, SIGNAL(activated()), this, SLOT(slotItemDelete()) );
333 m_itemDeleteAction->setWhatsThis( tr( "Click here to delete the selected item." ) ); 320 m_itemDeleteAction->setWhatsThis( tr( "Click here to delete the selected item." ) );
334 m_itemDeleteAction->addTo( toolbar ); 321 m_itemDeleteAction->addTo( toolbar );
335 322
336 if ( Ir::supported() ) { 323 if ( Ir::supported() ) {
337 a = new QAction( tr( "Beam" ), Resource::loadPixmap( "beam" ), 324 a = new QAction( tr( "Beam" ), Resource::loadPixmap( "beam" ),
338 QString::null, 0, m_itemMenuGroup1, 0 ); 325 QString::null, 0, m_itemMenuGroup1, 0 );
339 connect( a, SIGNAL(activated()), this, SLOT(slotItemBeam()) ); 326 connect( a, SIGNAL(activated()), this, SLOT(slotItemBeam()) );
340 a->setWhatsThis( tr( "Click here to transmit the selected item." ) ); 327 a->setWhatsThis( tr( "Click here to transmit the selected item." ) );
341 //a->addTo( m_itemMenu ); 328 //a->addTo( m_itemMenu );
342 a->addTo( toolbar ); 329 a->addTo( toolbar );
343 } 330 }
344 331
345 m_itemMenuGroup1->addTo( m_itemMenu ); 332 m_itemMenuGroup1->addTo( m_itemMenu );
346 333
347 m_itemMenu->insertSeparator(); 334 m_itemMenu->insertSeparator();
348 335
349 m_itemMenuGroup2 = new QActionGroup( this, QString::null, false ); 336 m_itemMenuGroup2 = new QActionGroup( this, QString::null, false );
350 337
351// a = new QAction( tr( "Find" ), Resource::loadPixmap( "find" ), 338// a = new QAction( tr( "Find" ), Resource::loadPixmap( "find" ),
352// QString::null, 0, m_itemMenuGroup2, 0 ); 339// QString::null, 0, m_itemMenuGroup2, 0 );
353// connect( a, SIGNAL(activated()), this, SLOT(slotItemFind()) ); 340// connect( a, SIGNAL(activated()), this, SLOT(slotItemFind()) );
354// a->setWhatsThis( tr( "Click here to search for an item." ) ); 341// a->setWhatsThis( tr( "Click here to search for an item." ) );
355// a->addTo( toolbar ); 342// a->addTo( toolbar );
356 343
357 a = new QAction( tr( "Configure" ), Resource::loadPixmap( "SettingsIcon" ), 344 a = new QAction( tr( "Configure" ), Resource::loadPixmap( "SettingsIcon" ),
358 QString::null, 0, m_itemMenuGroup2, 0 ); 345 QString::null, 0, m_itemMenuGroup2, 0 );
359 connect( a, SIGNAL(activated()), this, SLOT(slotConfigure()) ); 346 connect( a, SIGNAL(activated()), this, SLOT(slotConfigure()) );
360 a->setWhatsThis( tr( "Click here to set your preferences for this application." ) ); 347 a->setWhatsThis( tr( "Click here to set your preferences for this application." ) );
361 348
362 m_itemMenuGroup2->addTo( m_itemMenu ); 349 m_itemMenuGroup2->addTo( m_itemMenu );
363 350
364 // View menu 351 // View menu
365 m_viewMenuGroup = new QActionGroup( this, QString::null, false ); 352 m_viewMenuGroup = new QActionGroup( this, QString::null, false );
366 353
367 a = new QAction( tr( "Filter" ), QString::null, 0, m_viewMenuGroup, 0 ); 354 a = new QAction( tr( "Filter" ), QString::null, 0, m_viewMenuGroup, 0 );
368 connect( a, SIGNAL(activated()), this, SLOT(slotViewFilter()) ); 355 connect( a, SIGNAL(activated()), this, SLOT(slotViewFilter()) );
369 a->setWhatsThis( tr( "Click here to filter the items displayed." ) ); 356 a->setWhatsThis( tr( "Click here to filter the items displayed." ) );
370 357
371 a = new QAction( tr( "Filter Settings" ), QString::null, 0, m_viewMenuGroup, 0 ); 358 a = new QAction( tr( "Filter Settings" ), QString::null, 0, m_viewMenuGroup, 0 );
372 connect( a, SIGNAL(activated()), this, SLOT(slotViewFilterSettings()) ); 359 connect( a, SIGNAL(activated()), this, SLOT(slotViewFilterSettings()) );
373 a->setWhatsThis( tr( "Click here to modify the current filter settings." ) ); 360 a->setWhatsThis( tr( "Click here to modify the current filter settings." ) );
374 361
375 // Create view toolbar 362 // Create view toolbar
376 toolbar = new QToolBar( this ); 363 toolbar = new QToolBar( this );
377 m_catSelect = new QComboBox( toolbar ); 364 m_catSelect = new QComboBox( toolbar );
378 connect( m_catSelect, SIGNAL(activated(const QString&)), this, SLOT(slotViewCategory(const QString&)) ); 365 connect( m_catSelect, SIGNAL(activated(const QString&)), this, SIGNAL(categorySelected(const QString&)) );
366 QWhatsThis::add( m_catSelect, tr( "Click here to filter items by category." ) );
379 367
380 // Do initial load of categories 368 // Do initial load of categories
381 reloadCategories(); 369 reloadCategories();
382} 370}
383 371
384} // namespace Opie 372} // namespace Opie
diff --git a/libopie2/opiepim/ui/opimmainwindow.h b/libopie2/opiepim/ui/opimmainwindow.h
index ffc7feb..b446583 100644
--- a/libopie2/opiepim/ui/opimmainwindow.h
+++ b/libopie2/opiepim/ui/opimmainwindow.h
@@ -1,186 +1,181 @@
1/* 1/*
2 This file is part of the Opie Project 2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de) 3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org> 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l. 5 .=l.
6 .>+-= 6 .>+-=
7 _;:, .> :=|. This program is free software; you can 7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under 8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software 10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License, 11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version. 12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_. 13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that 14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY; 15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of 16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A 17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU 18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more 19..}^=.= = ; Library General Public License for more
20++= -. .` .: details. 20++= -. .` .: details.
21 : = ...= . :.=- 21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU 22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with 23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB. 24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28*/ 28*/
29#ifndef OPIE_PIM_MAINWINDOW_H 29#ifndef OPIE_PIM_MAINWINDOW_H
30#define OPIE_PIM_MAINWINDOW_H 30#define OPIE_PIM_MAINWINDOW_H
31 31
32#include <opie2/opimrecord.h> 32#include <opie2/opimrecord.h>
33 33
34#include <qpe/categories.h> 34#include <qpe/categories.h>
35#include <qpe/config.h> 35#include <qpe/config.h>
36 36
37#include <qmainwindow.h> 37#include <qmainwindow.h>
38 38
39class QAction; 39class QAction;
40class QActionGroup; 40class QActionGroup;
41class QComboBox; 41class QComboBox;
42class QCopChannel; 42class QCopChannel;
43class QDateTime; 43class QDateTime;
44class QPopupMenu; 44class QPopupMenu;
45 45
46namespace Opie { 46namespace Opie {
47/** 47/**
48 * This is a common Opie PIM MainWindow 48 * This is a common Opie PIM MainWindow
49 * it takes care of the QCOP internals 49 * it takes care of the QCOP internals
50 * and implements some functions 50 * and implements some functions
51 * for the URL scripting schema 51 * for the URL scripting schema
52 */ 52 */
53/* 53/*
54 * due Qt and Templates with signal and slots 54 * due Qt and Templates with signal and slots
55 * do not work that good :( 55 * do not work that good :(
56 * (Ok how to moc a template ;) ) 56 * (Ok how to moc a template ;) )
57 * We will have the mainwindow which calls a struct which 57 * We will have the mainwindow which calls a struct which
58 * is normally reimplemented as a template ;) 58 * is normally reimplemented as a template ;)
59 */ 59 */
60 60
61class OPimMainWindow : public QMainWindow { 61class OPimMainWindow : public QMainWindow {
62 Q_OBJECT 62 Q_OBJECT
63public: 63public:
64 enum TransPort { BlueTooth=0, 64 enum TransPort { BlueTooth=0,
65 IrDa }; 65 IrDa };
66 66
67 OPimMainWindow( const QString &serviceName, 67 OPimMainWindow( const QString &serviceName,
68 const QString &appName = QString::null,
69 const QString &catName = QString::null, 68 const QString &catName = QString::null,
70 const QString &itemName = QString::null, 69 const QString &itemName = QString::null,
71 const QString &configName = QString::null, 70 const QString &configName = QString::null,
72 QWidget *parent = 0l, const char* name = 0l, WFlags f = WType_TopLevel ); 71 QWidget *parent = 0l, const char* name = 0l, WFlags f = WType_TopLevel );
73 virtual ~OPimMainWindow(); 72 virtual ~OPimMainWindow();
74 73
75 74
76protected slots: 75protected slots:
77 /* 76 /*
78 * called when a setDocument 77 * called when a setDocument
79 * couldn't be handled by this window 78 * couldn't be handled by this window
80 */ 79 */
81 virtual void doSetDocument( const QString& ); 80 virtual void doSetDocument( const QString& );
82 /* for syncing */ 81 /* for syncing */
83 virtual void flush() = 0; 82 virtual void flush() = 0;
84 virtual void reload() = 0; 83 virtual void reload() = 0;
85 84
86 /** create a new Records and return the uid */ 85 /** create a new Records and return the uid */
87 virtual int create() = 0; 86 virtual int create() = 0;
88 /** remove a record with UID == uid */ 87 /** remove a record with UID == uid */
89 virtual bool remove( int uid ) = 0; 88 virtual bool remove( int uid ) = 0;
90 /** beam the record with UID = uid */ 89 /** beam the record with UID = uid */
91 virtual void beam( int uid ) = 0; 90 virtual void beam( int uid ) = 0;
92 91
93 /** show the record with UID == uid */ 92 /** show the record with UID == uid */
94 virtual void show( int uid ) = 0; 93 virtual void show( int uid ) = 0;
95 /** edit the record */ 94 /** edit the record */
96 virtual void edit( int uid ) = 0; 95 virtual void edit( int uid ) = 0;
97 96
98 /** make a copy of it! */ 97 /** make a copy of it! */
99 virtual void add( const OPimRecord& ) = 0; 98 virtual void add( const OPimRecord& ) = 0;
100 99
101 virtual void doAlarm( const QDateTime&, int uid ); 100 virtual void doAlarm( const QDateTime&, int uid );
102 101
103 QCopChannel* channel(); 102 QCopChannel* channel();
104 103
105 /** UI-related slots */ 104 /** UI-related slots */
106 virtual void slotItemNew() = 0; 105 virtual void slotItemNew() = 0;
107 virtual void slotItemEdit() = 0; 106 virtual void slotItemEdit() = 0;
108 virtual void slotItemDuplicate() = 0; 107 virtual void slotItemDuplicate() = 0;
109 virtual void slotItemDelete() = 0; 108 virtual void slotItemDelete() = 0;
110 virtual void slotItemBeam() = 0; 109 virtual void slotItemBeam() = 0;
111 //virtual void slotItemFind() = 0; 110 //virtual void slotItemFind() = 0;
112 virtual void slotConfigure() = 0; 111 virtual void slotConfigure() = 0;
113 112
114protected: 113protected:
115 /** 114 /**
116 * start to play soundAlarm() 115 * start to play soundAlarm()
117 * @param count How many times the alarm is played 116 * @param count How many times the alarm is played
118 */ 117 */
119 void startAlarm( int count = 10 ); 118 void startAlarm( int count = 10 );
120 void killAlarm(); 119 void killAlarm();
121 void timerEvent( QTimerEvent* ); 120 void timerEvent( QTimerEvent* );
122 121
123 /** UI-related functions */ 122 /** UI-related functions */
124 QPopupMenu *itemContextMenu(); 123 QPopupMenu *itemContextMenu();
125 124
126 void insertItemMenuItems( QActionGroup *items ); 125 void insertItemMenuItems( QActionGroup *items );
127 void insertViewMenuItems( QActionGroup *items ); 126 void insertViewMenuItems( QActionGroup *items );
128 127
129 void setViewCategory( const QString &category ); 128 void setViewCategory( const QString &category );
130 void reloadCategories(); 129 void reloadCategories();
131 130
132private slots: 131private slots:
133 void appMessage( const QCString&, const QByteArray& ); 132 void appMessage( const QCString&, const QByteArray& );
134 void setDocument( const QString& ); 133 void setDocument( const QString& );
135 134
136 /** UI-related slots */
137 void slotViewCategory( const QString &category );
138
139private: 135private:
140 class Private; 136 class Private;
141 Private* d; 137 Private* d;
142 138
143 int m_rtti; 139 int m_rtti;
144 QCopChannel* m_channel; 140 QCopChannel* m_channel;
145 QString m_service; 141 QString m_service;
146 QCString m_str; 142 QCString m_str;
147 OPimRecord* m_fallBack; 143 OPimRecord* m_fallBack;
148 int m_alarmCount; 144 int m_alarmCount;
149 int m_playedCount; 145 int m_playedCount;
150 int m_timerId; 146 int m_timerId;
151 147
152 QString m_appName; // Name of application for title bar
153 QString m_catGroupName; // Name of category group 148 QString m_catGroupName; // Name of category group
154 Config m_config; // Configuration settings file 149 Config m_config; // Configuration settings file
155 150
156 // Menu bar data 151 // Menu bar data
157 QPopupMenu *m_itemContextMenu; // Pointer to context-sensitive menu 152 QPopupMenu *m_itemContextMenu; // Pointer to context-sensitive menu
158 QPopupMenu *m_itemMenu; // Pointer to item menu 153 QPopupMenu *m_itemMenu; // Pointer to item menu
159 QPopupMenu *m_viewMenu; // Pointer to view menu 154 QPopupMenu *m_viewMenu; // Pointer to view menu
160 QActionGroup *m_itemMenuGroup1; // Action group containing default items in Item menu 155 QActionGroup *m_itemMenuGroup1; // Action group containing default items in Item menu
161 QActionGroup *m_itemMenuGroup2; // Action group containing default items in Item menu 156 QActionGroup *m_itemMenuGroup2; // Action group containing default items in Item menu
162 QActionGroup *m_viewMenuAppGroup; // Action group containing application items in View menu 157 QActionGroup *m_viewMenuAppGroup; // Action group containing application items in View menu
163 QActionGroup *m_viewMenuGroup; // Action group containing default items in View menu 158 QActionGroup *m_viewMenuGroup; // Action group containing default items in View menu
164 QAction *m_itemEditAction; // Edit current item action 159 QAction *m_itemEditAction; // Edit current item action
165 QAction *m_itemDuplicateAction; // Duplicate current item action 160 QAction *m_itemDuplicateAction; // Duplicate current item action
166 QAction *m_itemDeleteAction; // Delete current item action 161 QAction *m_itemDeleteAction; // Delete current item action
167 162
168 QComboBox *m_catSelect; // Category selection combo box 163 QComboBox *m_catSelect; // Category selection combo box
169 164
170 /* I would love to do this as a template 165 /* I would love to do this as a template
171 * but can't think of a right way 166 * but can't think of a right way
172 * because I need signal and slots -zecke 167 * because I need signal and slots -zecke
173 */ 168 */
174 virtual OPimRecord* record( int rtti, const QByteArray& ) ; 169 virtual OPimRecord* record( int rtti, const QByteArray& ) ;
175 int service(); 170 int service();
176 171
177 /** UI-related functions */ 172 /** UI-related functions */
178 void initBars( const QString &itemName = tr( "Item" ) ); 173 void initBars( const QString &itemName = tr( "Item" ) );
179 174
180signals: 175signals:
181 void categorySelected( const QString &cat ); 176 void categorySelected( const QString &cat );
182}; 177};
183 178
184} 179}
185 180
186#endif 181#endif