summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/today/changelog4
-rw-r--r--core/pim/today/opie-today.control2
-rw-r--r--core/pim/today/today.cpp17
-rw-r--r--core/pim/today/today.h4
-rw-r--r--core/pim/today/todayconfig.cpp14
-rw-r--r--core/pim/today/todayconfig.h1
6 files changed, 39 insertions, 3 deletions
diff --git a/core/pim/today/changelog b/core/pim/today/changelog
index 25d63ef..eb2496a 100644
--- a/core/pim/today/changelog
+++ b/core/pim/today/changelog
@@ -1,48 +1,52 @@
10.5.2
2
3* refresh settings
4
10.5.1 50.5.1
2 6
3* icons scalable and clickable again 7* icons scalable and clickable again
4 8
50.5 90.5
6 10
7* now fully plugin based 11* now fully plugin based
8 12
90.3.4 130.3.4
10 14
11* "fill our business card now a clickable label" 15* "fill our business card now a clickable label"
12* Several bugfixes regarding todo section. 16* Several bugfixes regarding todo section.
13 17
140.3.3 180.3.3
15 19
16* Changed the logo so it better scales to bigger display and also 20* Changed the logo so it better scales to bigger display and also
17 made the "Today" string translatable. 21 made the "Today" string translatable.
18* some am/pm fixes 22* some am/pm fixes
19* clickable labels now in libopie 23* clickable labels now in libopie
20 24
210.3.2 250.3.2
22 26
23* Autostart is now more configurable. You can decide how long 27* Autostart is now more configurable. You can decide how long
24 the ipaq has to has been suspended, before autostart is triggered.(Opie 28 the ipaq has to has been suspended, before autostart is triggered.(Opie
25 only) 29 only)
26* am/pm time optinal (autodetect) 30* am/pm time optinal (autodetect)
27 31
280.3.1 320.3.1
29 33
30* fixed the wrong color of the buttons 34* fixed the wrong color of the buttons
31* better translation (thanks carsten and others) 35* better translation (thanks carsten and others)
32* fixes memory leaks 36* fixes memory leaks
33* bugfixes in calendar part, now location and note are working again. 37* bugfixes in calendar part, now location and note are working again.
34 38
350.3.0 390.3.0
36 40
37* today uses now tododb from libopie. So major changes in the todo part: 41* today uses now tododb from libopie. So major changes in the todo part:
38 - overdue items on top 42 - overdue items on top
39 - then sorted by date, then by priority 43 - then sorted by date, then by priority
40* some cleanups 44* some cleanups
41* speed optimisations 45* speed optimisations
42 46
430.2.9 470.2.9
44 48
45* Many bugfixes. 49* Many bugfixes.
46* Today now apparently sorts the dates _allways_ right, i would assume it 50* Today now apparently sorts the dates _allways_ right, i would assume it
47to be a qt bug 51to be a qt bug
48 52
diff --git a/core/pim/today/opie-today.control b/core/pim/today/opie-today.control
index 28087f9..267a195 100644
--- a/core/pim/today/opie-today.control
+++ b/core/pim/today/opie-today.control
@@ -1,16 +1,16 @@
1Files: bin/today apps/1Pim/today.desktop pics/today/* 1Files: bin/today apps/1Pim/today.desktop pics/today/*
2Priority: optional 2Priority: optional
3Section: opie/applications 3Section: opie/applications
4Maintainer: Maximilian Reiß <harlekin@handhelds.org> 4Maintainer: Maximilian Reiß <harlekin@handhelds.org>
5Architecture: arm 5Architecture: arm
6Version: 0.5.1-$SUB_VERSION 6Version: 0.5.2-$SUB_VERSION
7Depends: opie-base ($QPE_VERSION), libopie ($QPE_VERSION) 7Depends: opie-base ($QPE_VERSION), libopie ($QPE_VERSION)
8License: GPL 8License: GPL
9Description: today screen 9Description: today screen
10 This today screen app gives an overview of appointments 10 This today screen app gives an overview of appointments
11 and todos. 11 and todos.
12 It also shows incoming and outgoing mails from opiemail. 12 It also shows incoming and outgoing mails from opiemail.
13 When using Opie (opie.handhelds.org) today can be autostarted 13 When using Opie (opie.handhelds.org) today can be autostarted
14 on resume. 14 on resume.
15 It is highly configurable. 15 It is highly configurable.
16 16
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index dd98824..8184730 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -20,148 +20,162 @@
20 20
21#include <qpe/config.h> 21#include <qpe/config.h>
22#include <qpe/qcopenvelope_qws.h> 22#include <qpe/qcopenvelope_qws.h>
23#include <qpe/resource.h> 23#include <qpe/resource.h>
24#include <qpe/global.h> 24#include <qpe/global.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26#include <qpe/contact.h> 26#include <qpe/contact.h>
27 27
28#include <qdir.h> 28#include <qdir.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qpushbutton.h> 30#include <qpushbutton.h>
31#include <qlabel.h> 31#include <qlabel.h>
32#include <qtimer.h> 32#include <qtimer.h>
33#include <qpixmap.h> 33#include <qpixmap.h>
34#include <qlayout.h> 34#include <qlayout.h>
35#include <qhbox.h> 35#include <qhbox.h>
36#include <opie/otabwidget.h> 36#include <opie/otabwidget.h>
37#include <qdialog.h> 37#include <qdialog.h>
38#include <qwhatsthis.h> 38#include <qwhatsthis.h>
39 39
40 40
41struct TodayPlugin { 41struct TodayPlugin {
42 QLibrary *library; 42 QLibrary *library;
43 TodayPluginInterface *iface; 43 TodayPluginInterface *iface;
44 TodayPluginObject *guiPart; 44 TodayPluginObject *guiPart;
45 QWidget *guiBox; 45 QWidget *guiBox;
46 QString name; 46 QString name;
47 bool active; 47 bool active;
48 int pos; 48 int pos;
49}; 49};
50 50
51static QValueList<TodayPlugin> pluginList; 51static QValueList<TodayPlugin> pluginList;
52 52
53Today::Today( QWidget* parent, const char* name, WFlags fl ) 53Today::Today( QWidget* parent, const char* name, WFlags fl )
54 : TodayBase( parent, name, fl ) { 54 : TodayBase( parent, name, fl ) {
55 55
56 QObject::connect( (QObject*)ConfigButton, SIGNAL( clicked() ), this, SLOT( startConfig() ) ); 56 QObject::connect( (QObject*)ConfigButton, SIGNAL( clicked() ), this, SLOT( startConfig() ) );
57 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) ); 57 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) );
58 58
59#if defined(Q_WS_QWS) 59#if defined(Q_WS_QWS)
60#if !defined(QT_NO_COP) 60#if !defined(QT_NO_COP)
61 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this ); 61 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this );
62 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ), 62 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ),
63 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) ); 63 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) );
64#endif 64#endif
65#endif 65#endif
66 66
67 setOwnerField(); 67 setOwnerField();
68 m_refreshTimer = new QTimer( this );
69 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
70 m_refreshTimer->start( 15000 );
68 refresh(); 71 refresh();
69 showMaximized(); 72 showMaximized();
70} 73}
71 74
72/** 75/**
73 * Qcop receive method. 76 * Qcop receive method.
74 */ 77 */
75void Today::channelReceived( const QCString &msg, const QByteArray & data ) { 78void Today::channelReceived( const QCString &msg, const QByteArray & data ) {
76 QDataStream stream( data, IO_ReadOnly ); 79 QDataStream stream( data, IO_ReadOnly );
77 if ( msg == "message(QString)" ) { 80 if ( msg == "message(QString)" ) {
78 QString message; 81 QString message;
79 stream >> message; 82 stream >> message;
80 setOwnerField( message ); 83 setOwnerField( message );
81 } 84 }
82} 85}
83 86
87void Today::setRefreshTimer( int interval ) {
88
89 if ( m_refreshTimerEnabled ) {
90 m_refreshTimer->changeInterval( interval );
91 }
92}
93
94
84/** 95/**
85 * Initialises the owner field with the default value, the username 96 * Initialises the owner field with the default value, the username
86 */ 97 */
87void Today::setOwnerField() { 98void Today::setOwnerField() {
88 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" ); 99 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" );
89 if ( QFile::exists( file ) ) { 100 if ( QFile::exists( file ) ) {
90 Contact cont = Contact::readVCard( file )[0]; 101 Contact cont = Contact::readVCard( file )[0];
91 QString returnString = cont.fullName(); 102 QString returnString = cont.fullName();
92 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" ); 103 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" );
93 } else { 104 } else {
94 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" ); 105 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" );
95 } 106 }
96} 107}
97 108
98/** 109/**
99 * Set the owner field with a given QString, for example per qcop. 110 * Set the owner field with a given QString, for example per qcop.
100 */ 111 */
101void Today::setOwnerField( QString &message ) { 112void Today::setOwnerField( QString &message ) {
102 if ( !message.isEmpty() ) { 113 if ( !message.isEmpty() ) {
103 OwnerField->setText( "<b>" + message + "</b>" ); 114 OwnerField->setText( "<b>" + message + "</b>" );
104 } 115 }
105} 116}
106 117
107 118
108/** 119/**
109 * Init stuff needed for today. Reads the config file. 120 * Init stuff needed for today. Reads the config file.
110 */ 121 */
111void Today::init() { 122void Today::init() {
112 // read config 123 // read config
113 Config cfg( "today" ); 124 Config cfg( "today" );
114 cfg.setGroup( "Plugins" );
115 125
126 cfg.setGroup( "Plugins" );
116 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); 127 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' );
117 m_allApplets = cfg.readListEntry( "AllApplets", ',' ); 128 m_allApplets = cfg.readListEntry( "AllApplets", ',' );
129
118 cfg.setGroup( "General" ); 130 cfg.setGroup( "General" );
119 m_iconSize = cfg.readNumEntry( "IconSize", 18 ); 131 m_iconSize = cfg.readNumEntry( "IconSize", 18 );
132 m_refreshTimer->changeInterval( cfg.readNumEntry( "checkinterval", 15000 ) );
133
120} 134}
121 135
122 136
123/** 137/**
124 * Load the plugins 138 * Load the plugins
125 */ 139 */
126void Today::loadPlugins() { 140void Today::loadPlugins() {
127 141
128 QValueList<TodayPlugin>::Iterator tit; 142 QValueList<TodayPlugin>::Iterator tit;
129 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) { 143 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) {
130 (*tit).library->unload(); 144 (*tit).library->unload();
131 delete (*tit).library; 145 delete (*tit).library;
132 } 146 }
133 pluginList.clear(); 147 pluginList.clear();
134 148
135 QString path = QPEApplication::qpeDir() + "/plugins/today"; 149 QString path = QPEApplication::qpeDir() + "/plugins/today";
136 QDir dir( path, "lib*.so" ); 150 QDir dir( path, "lib*.so" );
137 151
138 QStringList list = dir.entryList(); 152 QStringList list = dir.entryList();
139 QStringList::Iterator it; 153 QStringList::Iterator it;
140 154
141 QMap<QString, TodayPlugin> tempList; 155 QMap<QString, TodayPlugin> tempList;
142 156
143 for ( it = list.begin(); it != list.end(); ++it ) { 157 for ( it = list.begin(); it != list.end(); ++it ) {
144 TodayPluginInterface *iface = 0; 158 TodayPluginInterface *iface = 0;
145 QLibrary *lib = new QLibrary( path + "/" + *it ); 159 QLibrary *lib = new QLibrary( path + "/" + *it );
146 160
147 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() ); 161 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() );
148 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) { 162 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) {
149 qDebug( "loading: %s", QString( path + "/" + *it ).latin1() ); 163 qDebug( "loading: %s", QString( path + "/" + *it ).latin1() );
150 qDebug( QString(*it) ); 164 qDebug( QString(*it) );
151 TodayPlugin plugin; 165 TodayPlugin plugin;
152 plugin.library = lib; 166 plugin.library = lib;
153 plugin.iface = iface; 167 plugin.iface = iface;
154 plugin.name = QString(*it); 168 plugin.name = QString(*it);
155 169
156 // find out if plugins should be shown 170 // find out if plugins should be shown
157 if ( m_excludeApplets.grep( *it ).isEmpty() ) { 171 if ( m_excludeApplets.grep( *it ).isEmpty() ) {
158 plugin.active = true; 172 plugin.active = true;
159 } else { 173 } else {
160 plugin.active = false; 174 plugin.active = false;
161 } 175 }
162 plugin.guiPart = plugin.iface->guiPart(); 176 plugin.guiPart = plugin.iface->guiPart();
163 177
164 // package the whole thing into a qwidget so it can be shown and hidden 178 // package the whole thing into a qwidget so it can be shown and hidden
165 plugin.guiBox = new QWidget( this ); 179 plugin.guiBox = new QWidget( this );
166 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox ); 180 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox );
167 QPixmap plugPix; 181 QPixmap plugPix;
@@ -248,90 +262,91 @@ void Today::draw() {
248 layout->addStretch(0); 262 layout->addStretch(0);
249} 263}
250 264
251 265
252/** 266/**
253 * The method for the configuration dialog. 267 * The method for the configuration dialog.
254 */ 268 */
255void Today::startConfig() { 269void Today::startConfig() {
256 270
257 TodayConfig conf( this, "dialog", true ); 271 TodayConfig conf( this, "dialog", true );
258 272
259 TodayPlugin plugin; 273 TodayPlugin plugin;
260 QList<TodayConfigWidget> configWidgetList; 274 QList<TodayConfigWidget> configWidgetList;
261 275
262 for ( int i = pluginList.count() - 1 ; i >= 0; i-- ) { 276 for ( int i = pluginList.count() - 1 ; i >= 0; i-- ) {
263 plugin = pluginList[i]; 277 plugin = pluginList[i];
264 278
265 // load the config widgets in the tabs 279 // load the config widgets in the tabs
266 if ( plugin.guiPart->configWidget( this ) != 0l ) { 280 if ( plugin.guiPart->configWidget( this ) != 0l ) {
267 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 ); 281 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 );
268 configWidgetList.append( widget ); 282 configWidgetList.append( widget );
269 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig() 283 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig()
270 , plugin.guiPart->appName() ); 284 , plugin.guiPart->appName() );
271 } 285 }
272 // set the order/activate tab 286 // set the order/activate tab
273 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(), 287 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(),
274 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) ); 288 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) );
275 } 289 }
276 290
277 if ( conf.exec() == QDialog::Accepted ) { 291 if ( conf.exec() == QDialog::Accepted ) {
278 conf.writeConfig(); 292 conf.writeConfig();
279 TodayConfigWidget *confWidget; 293 TodayConfigWidget *confWidget;
280 for ( confWidget = configWidgetList.first(); confWidget != 0; 294 for ( confWidget = configWidgetList.first(); confWidget != 0;
281 confWidget = configWidgetList.next() ) { 295 confWidget = configWidgetList.next() ) {
282 confWidget->writeConfig(); 296 confWidget->writeConfig();
283 } 297 }
284 refresh(); 298 refresh();
285 } 299 }
286} 300}
287 301
288 302
289/** 303/**
290 * Refresh for the view. Reload all applets 304 * Refresh for the view. Reload all applets
291 * 305 *
292 */ 306 */
293void Today::refresh() { 307void Today::refresh() {
294 init(); 308 init();
295 309
310 qDebug(" refresh ");
296 // set the date in top label 311 // set the date in top label
297 QDate date = QDate::currentDate(); 312 QDate date = QDate::currentDate();
298 QString time = ( tr( date.toString() ) ); 313 QString time = ( tr( date.toString() ) );
299 314
300 DateLabel->setText( QString( "<font color=#FFFFFF>" + time + "</font>" ) ); 315 DateLabel->setText( QString( "<font color=#FFFFFF>" + time + "</font>" ) );
301 316
302 if ( layout ) { 317 if ( layout ) {
303 delete layout; 318 delete layout;
304 } 319 }
305 layout = new QVBoxLayout( this ); 320 layout = new QVBoxLayout( this );
306 layout->addWidget( Frame ); 321 layout->addWidget( Frame );
307 layout->addWidget( OwnerField ); 322 layout->addWidget( OwnerField );
308 323
309 loadPlugins(); 324 loadPlugins();
310 draw(); 325 draw();
311} 326}
312 327
313void Today::startAddressbook() { 328void Today::startAddressbook() {
314 QCopEnvelope e( "QPE/System", "execute(QString)" ); 329 QCopEnvelope e( "QPE/System", "execute(QString)" );
315 e << QString( "addressbook" ); 330 e << QString( "addressbook" );
316} 331}
317 332
318 333
319void Today::startApplication() { 334void Today::startApplication() {
320 QCopEnvelope e( "QPE/System", "execute(QString)" ); 335 QCopEnvelope e( "QPE/System", "execute(QString)" );
321 e << QString( sender()->name() ); 336 e << QString( sender()->name() );
322} 337}
323 338
324/** 339/**
325 * launch addressbook (personal card) 340 * launch addressbook (personal card)
326 */ 341 */
327void Today::editCard() { 342void Today::editCard() {
328 startAddressbook(); 343 startAddressbook();
329 while( !QCopChannel::isRegistered( "QPE/Addressbook" ) ) { 344 while( !QCopChannel::isRegistered( "QPE/Addressbook" ) ) {
330 qApp->processEvents(); 345 qApp->processEvents();
331 } 346 }
332 QCopEnvelope v( "QPE/Addressbook", "editPersonalAndClose()" ); 347 QCopEnvelope v( "QPE/Addressbook", "editPersonalAndClose()" );
333} 348}
334 349
335Today::~Today() { 350Today::~Today() {
336} 351}
337 352
diff --git a/core/pim/today/today.h b/core/pim/today/today.h
index 6f13df6..4485a0b 100644
--- a/core/pim/today/today.h
+++ b/core/pim/today/today.h
@@ -11,63 +11,67 @@
11 * it under the terms of the GNU General Public License as published by * 11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or * 12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. * 13 * (at your option) any later version. *
14 * * 14 * *
15 ***************************************************************************/ 15 ***************************************************************************/
16 16
17 17
18#ifndef TODAY_H 18#ifndef TODAY_H
19#define TODAY_H 19#define TODAY_H
20 20
21#include <opie/tododb.h> 21#include <opie/tododb.h>
22 22
23#include <qdatetime.h> 23#include <qdatetime.h>
24#include <qlist.h> 24#include <qlist.h>
25#include <qhbox.h> 25#include <qhbox.h>
26 26
27#include <qpe/qlibrary.h> 27#include <qpe/qlibrary.h>
28#include <qpe/event.h> 28#include <qpe/event.h>
29 29
30#include "todayconfig.h" 30#include "todayconfig.h"
31#include "todaybase.h" 31#include "todaybase.h"
32#include <opie/todayplugininterface.h> 32#include <opie/todayplugininterface.h>
33 33
34class QVBoxLayout; 34class QVBoxLayout;
35class OClickableLabel; 35class OClickableLabel;
36 36
37 37
38class Today : public TodayBase { 38class Today : public TodayBase {
39 39
40 Q_OBJECT 40 Q_OBJECT
41 41
42 public: 42 public:
43 Today( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 43 Today( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
44 ~Today(); 44 ~Today();
45 45
46private slots: 46private slots:
47 void startConfig(); 47 void startConfig();
48 void startAddressbook(); 48 void startAddressbook();
49 void startApplication(); 49 void startApplication();
50 void editCard(); 50 void editCard();
51 void refresh(); 51 void refresh();
52 52
53private: 53private:
54 void init(); 54 void init();
55 void setOwnerField(); 55 void setOwnerField();
56 void setOwnerField(QString &string); 56 void setOwnerField(QString &string);
57 void loadPlugins(); 57 void loadPlugins();
58 void draw(); 58 void draw();
59 void setRefreshTimer( int );
59 60
60private slots: 61private slots:
61 void channelReceived(const QCString &msg, const QByteArray & data); 62 void channelReceived(const QCString &msg, const QByteArray & data);
62 63
63 private: 64 private:
64 TodayConfig *conf; 65 TodayConfig *conf;
65 QStringList m_excludeApplets; 66 QStringList m_excludeApplets;
66 QStringList m_allApplets; 67 QStringList m_allApplets;
67 68
69 QTimer *m_refreshTimer;
70
71 bool m_refreshTimerEnabled;
68 int m_newStart; 72 int m_newStart;
69 int m_iconSize; 73 int m_iconSize;
70 int m_maxCharClip; 74 int m_maxCharClip;
71}; 75};
72 76
73#endif 77#endif
diff --git a/core/pim/today/todayconfig.cpp b/core/pim/today/todayconfig.cpp
index f9dd8f7..db1141a 100644
--- a/core/pim/today/todayconfig.cpp
+++ b/core/pim/today/todayconfig.cpp
@@ -54,190 +54,202 @@ public:
54TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal ) 54TodayConfig::TodayConfig( QWidget* parent, const char* name, bool modal )
55 : QDialog( parent, name, modal, WStyle_ContextHelp ) { 55 : QDialog( parent, name, modal, WStyle_ContextHelp ) {
56 56
57 setCaption( tr( "Today config" ) ); 57 setCaption( tr( "Today config" ) );
58 58
59 QVBoxLayout *layout = new QVBoxLayout( this ); 59 QVBoxLayout *layout = new QVBoxLayout( this );
60 TabWidget3 = new OTabWidget ( this, "tabwidget", OTabWidget::Global, OTabWidget::Bottom ); 60 TabWidget3 = new OTabWidget ( this, "tabwidget", OTabWidget::Global, OTabWidget::Bottom );
61 layout->addWidget( TabWidget3 ); 61 layout->addWidget( TabWidget3 );
62 62
63 tab_2 = new QWidget( TabWidget3, "tab_2" ); 63 tab_2 = new QWidget( TabWidget3, "tab_2" );
64 QVBoxLayout *tab2Layout = new QVBoxLayout( tab_2, 4 ,4 ); 64 QVBoxLayout *tab2Layout = new QVBoxLayout( tab_2, 4 ,4 );
65 QLabel *l = new QLabel( tr( "Load which plugins in what order:" ), tab_2 ); 65 QLabel *l = new QLabel( tr( "Load which plugins in what order:" ), tab_2 );
66 tab2Layout->addWidget( l ); 66 tab2Layout->addWidget( l );
67 QHBox *hbox1 = new QHBox( tab_2 ); 67 QHBox *hbox1 = new QHBox( tab_2 );
68 m_appletListView = new QListView( hbox1 ); 68 m_appletListView = new QListView( hbox1 );
69 m_appletListView->addColumn( "PluginList" ); 69 m_appletListView->addColumn( "PluginList" );
70 m_appletListView->header()->hide(); 70 m_appletListView->header()->hide();
71 m_appletListView->setSorting( -1 ); 71 m_appletListView->setSorting( -1 );
72 QWhatsThis::add( m_appletListView, tr( "Check a checkbox to activate/deactivate a plugin ore use the arrow buttons on the right to change the appearance order" ) ); 72 QWhatsThis::add( m_appletListView, tr( "Check a checkbox to activate/deactivate a plugin ore use the arrow buttons on the right to change the appearance order" ) );
73 QVBox *vbox1 = new QVBox( hbox1 ); 73 QVBox *vbox1 = new QVBox( hbox1 );
74 new ToolButton( vbox1, tr( "Move Up" ), "up", this , SLOT( moveSelectedUp() ) ); 74 new ToolButton( vbox1, tr( "Move Up" ), "up", this , SLOT( moveSelectedUp() ) );
75 new ToolButton( vbox1, tr( "Move Down" ), "down", this , SLOT( moveSelectedDown() ) ); 75 new ToolButton( vbox1, tr( "Move Down" ), "down", this , SLOT( moveSelectedDown() ) );
76 tab2Layout->addWidget( hbox1 ); 76 tab2Layout->addWidget( hbox1 );
77 TabWidget3->addTab( tab_2, "pass", tr( "active/order" ) ); 77 TabWidget3->addTab( tab_2, "pass", tr( "active/order" ) );
78 78
79 tab_3 = new QWidget( TabWidget3, "tab_3" ); 79 tab_3 = new QWidget( TabWidget3, "tab_3" );
80 QVBoxLayout *tab3Layout = new QVBoxLayout( tab_3 ); 80 QVBoxLayout *tab3Layout = new QVBoxLayout( tab_3 );
81 tab3Layout->setMargin( 20 ); 81 tab3Layout->setMargin( 20 );
82 QHBox *hbox_auto = new QHBox( tab_3 ); 82 QHBox *hbox_auto = new QHBox( tab_3 );
83 TextLabel2 = new QLabel( hbox_auto, "AutoStart" ); 83 TextLabel2 = new QLabel( hbox_auto, "AutoStart" );
84 TextLabel2->setText( tr( "autostart on \nresume?\n (Opie only)" ) ); 84 TextLabel2->setText( tr( "autostart on \nresume?\n (Opie only)" ) );
85 QWhatsThis::add( TextLabel2 , tr( "Check this if today should be autostarted on resume." ) ); 85 QWhatsThis::add( TextLabel2 , tr( "Check this if today should be autostarted on resume." ) );
86 CheckBoxAuto = new QCheckBox( hbox_auto, "CheckBoxAuto" ); 86 CheckBoxAuto = new QCheckBox( hbox_auto, "CheckBoxAuto" );
87 QWhatsThis::add( CheckBoxAuto, tr( "Check this if today should be autostarted on resume." ) ); 87 QWhatsThis::add( CheckBoxAuto, tr( "Check this if today should be autostarted on resume." ) );
88 QHBox *hbox_inactive = new QHBox( tab_3 ); 88 QHBox *hbox_inactive = new QHBox( tab_3 );
89 TimeLabel = new QLabel( hbox_inactive, "TimeLabel" ); 89 TimeLabel = new QLabel( hbox_inactive, "TimeLabel" );
90 TimeLabel->setText( tr( "minutes inactive" ) ); 90 TimeLabel->setText( tr( "minutes inactive" ) );
91 QWhatsThis::add( TimeLabel , tr( "How many minutes has the PDA been suspended before the autostart feature kicks in on resume" ) ); 91 QWhatsThis::add( TimeLabel , tr( "How many minutes has the PDA been suspended before the autostart feature kicks in on resume" ) );
92 SpinBoxTime = new QSpinBox( hbox_inactive, "TimeSpinner" ); 92 SpinBoxTime = new QSpinBox( hbox_inactive, "TimeSpinner" );
93 QWhatsThis::add( SpinBoxTime , tr( "How many minutes has the PDA been suspended before the autostart feature kicks in on resume" ) ); 93 QWhatsThis::add( SpinBoxTime , tr( "How many minutes has the PDA been suspended before the autostart feature kicks in on resume" ) );
94 QHBox *hbox_iconSize = new QHBox( tab_3 ); 94 QHBox *hbox_iconSize = new QHBox( tab_3 );
95 QLabel *iconSizeLabel = new QLabel( hbox_iconSize, "iconSizeLabel" ); 95 QLabel *iconSizeLabel = new QLabel( hbox_iconSize, "iconSizeLabel" );
96 iconSizeLabel->setText( tr( "Icon size" ) ); 96 iconSizeLabel->setText( tr( "Icon size" ) );
97 QWhatsThis::add( iconSizeLabel, tr( "Set the icon size in pixel" ) ); 97 QWhatsThis::add( iconSizeLabel, tr( "Set the icon size in pixel" ) );
98 SpinBoxIconSize = new QSpinBox( hbox_iconSize, "TimeSpinner" ); 98 SpinBoxIconSize = new QSpinBox( hbox_iconSize, "TimeSpinner" );
99 SpinBoxIconSize->setMaxValue( 32 ); 99 SpinBoxIconSize->setMaxValue( 32 );
100 QWhatsThis::add( SpinBoxIconSize, tr( "Set the icon size in pixel" ) ); 100 QWhatsThis::add( SpinBoxIconSize, tr( "Set the icon size in pixel" ) );
101 101
102 QHBox *hbox_refresh = new QHBox( tab_3 );
103 QLabel *refreshLabel = new QLabel( hbox_refresh );
104 refreshLabel->setText( tr( "Refresh" ) );
105 QWhatsThis::add( refreshLabel, tr( "How often should Today refresh itself" ) );
106 SpinRefresh = new QSpinBox( hbox_refresh );
107 SpinRefresh->setMinValue( 2 );
108 SpinRefresh->setSuffix( tr( " seconds" ) );
109 QWhatsThis::add( SpinRefresh, tr( "How often should Today refresh itself" ) );
110
102 tab3Layout->addWidget( hbox_auto ); 111 tab3Layout->addWidget( hbox_auto );
103 tab3Layout->addWidget( hbox_inactive ); 112 tab3Layout->addWidget( hbox_inactive );
104 tab3Layout->addWidget( hbox_iconSize ); 113 tab3Layout->addWidget( hbox_iconSize );
114 tab3Layout->addWidget( hbox_refresh );
105 TabWidget3->addTab( tab_3, "SettingsIcon", tr( "Misc" ) ); 115 TabWidget3->addTab( tab_3, "SettingsIcon", tr( "Misc" ) );
106 116
107 m_applets_changed = false; 117 m_applets_changed = false;
108 118
109 connect ( m_appletListView , SIGNAL( clicked ( QListViewItem * ) ), this, SLOT( appletChanged ( ) ) ); 119 connect ( m_appletListView , SIGNAL( clicked ( QListViewItem * ) ), this, SLOT( appletChanged ( ) ) );
110 120
111 readConfig(); 121 readConfig();
112 showMaximized(); 122 showMaximized();
113} 123}
114 124
115 125
116/** 126/**
117 * Autostart, uses the new (opie only) autostart method in the launcher code. 127 * Autostart, uses the new (opie only) autostart method in the launcher code.
118 * If registered against that today ist started on each resume. 128 * If registered against that today ist started on each resume.
119 */ 129 */
120void TodayConfig::setAutoStart() { 130void TodayConfig::setAutoStart() {
121 Config cfg( "today" ); 131 Config cfg( "today" );
122 cfg.setGroup( "Autostart" ); 132 cfg.setGroup( "Autostart" );
123 if ( m_autoStart ) { 133 if ( m_autoStart ) {
124 QCopEnvelope e( "QPE/System", "autoStart(QString,QString,QString)" ); 134 QCopEnvelope e( "QPE/System", "autoStart(QString,QString,QString)" );
125 e << QString( "add" ); 135 e << QString( "add" );
126 e << QString( "today" ); 136 e << QString( "today" );
127 e << QString( "%1" ).arg( m_autoStartTimer ); 137 e << QString( "%1" ).arg( m_autoStartTimer );
128 } else { 138 } else {
129 QCopEnvelope e( "QPE/System", "autoStart(QString,QString)" ); 139 QCopEnvelope e( "QPE/System", "autoStart(QString,QString)" );
130 e << QString( "remove" ); 140 e << QString( "remove" );
131 e << QString( "today" ); 141 e << QString( "today" );
132 } 142 }
133} 143}
134 144
135/** 145/**
136 * Read the config part 146 * Read the config part
137 */ 147 */
138void TodayConfig::readConfig() { 148void TodayConfig::readConfig() {
139 Config cfg( "today" ); 149 Config cfg( "today" );
140 cfg.setGroup( "Autostart" ); 150 cfg.setGroup( "Autostart" );
141 m_autoStart = cfg.readNumEntry( "autostart", 1 ); 151 m_autoStart = cfg.readNumEntry( "autostart", 1 );
142 CheckBoxAuto->setChecked( m_autoStart ); 152 CheckBoxAuto->setChecked( m_autoStart );
143 m_autoStartTimer = cfg.readNumEntry( "autostartdelay", 0 ); 153 m_autoStartTimer = cfg.readNumEntry( "autostartdelay", 0 );
144 SpinBoxTime->setValue( m_autoStartTimer ); 154 SpinBoxTime->setValue( m_autoStartTimer );
145 155
146 cfg.setGroup( "General" ); 156 cfg.setGroup( "General" );
147 m_iconSize = cfg.readNumEntry( "IconSize", 18 ); 157 m_iconSize = cfg.readNumEntry( "IconSize", 18 );
148 SpinBoxIconSize->setValue( m_iconSize ); 158 SpinBoxIconSize->setValue( m_iconSize );
159 SpinRefresh->setValue( cfg.readNumEntry( "checkinterval", 15000 ) / 1000 );
160
149 161
150 cfg.setGroup( "Plugins" ); 162 cfg.setGroup( "Plugins" );
151 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); 163 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' );
152} 164}
153 165
154/** 166/**
155 * Write the config part 167 * Write the config part
156 */ 168 */
157void TodayConfig::writeConfig() { 169void TodayConfig::writeConfig() {
158 Config cfg( "today" ); 170 Config cfg( "today" );
159 cfg.setGroup( "Plugins" ); 171 cfg.setGroup( "Plugins" );
160 if ( m_applets_changed ) { 172 if ( m_applets_changed ) {
161 QStringList exclude; 173 QStringList exclude;
162 QStringList include; 174 QStringList include;
163 QStringList all_applets; 175 QStringList all_applets;
164 176
165 QListViewItemIterator list_it( m_appletListView ); 177 QListViewItemIterator list_it( m_appletListView );
166 178
167 // this makes sure the names get saved in the order selected 179 // this makes sure the names get saved in the order selected
168 for ( ; list_it.current(); ++list_it ) { 180 for ( ; list_it.current(); ++list_it ) {
169 QMap <QString, QCheckListItem *>::Iterator it; 181 QMap <QString, QCheckListItem *>::Iterator it;
170 for ( it = m_applets.begin(); it != m_applets. end (); ++it ) { 182 for ( it = m_applets.begin(); it != m_applets. end (); ++it ) {
171 if ( list_it.current() == (*it) && !(*it)-> isOn () ) { 183 if ( list_it.current() == (*it) && !(*it)-> isOn () ) {
172 exclude << it.key(); 184 exclude << it.key();
173 } else if ( list_it.current() == (*it) && (*it)-> isOn () ){ 185 } else if ( list_it.current() == (*it) && (*it)-> isOn () ){
174 include << it.key(); 186 include << it.key();
175 } 187 }
176 if ( list_it.current() == (*it) ) { 188 if ( list_it.current() == (*it) ) {
177 all_applets << it.key(); 189 all_applets << it.key();
178 } 190 }
179 } 191 }
180 } 192 }
181 cfg.writeEntry( "ExcludeApplets", exclude, ',' ); 193 cfg.writeEntry( "ExcludeApplets", exclude, ',' );
182 cfg.writeEntry( "IncludeApplets", include, ',' ); 194 cfg.writeEntry( "IncludeApplets", include, ',' );
183 cfg.writeEntry( "AllApplets", all_applets, ',' ); 195 cfg.writeEntry( "AllApplets", all_applets, ',' );
184 } 196 }
185 197
186 cfg.setGroup( "Autostart" ); 198 cfg.setGroup( "Autostart" );
187 m_autoStart = CheckBoxAuto->isChecked(); 199 m_autoStart = CheckBoxAuto->isChecked();
188 cfg.writeEntry( "autostart", m_autoStart ); 200 cfg.writeEntry( "autostart", m_autoStart );
189 m_autoStartTimer = SpinBoxTime->value(); 201 m_autoStartTimer = SpinBoxTime->value();
190 cfg.writeEntry( "autostartdelay", m_autoStartTimer ); 202 cfg.writeEntry( "autostartdelay", m_autoStartTimer );
191 m_iconSize = SpinBoxIconSize->value(); 203 m_iconSize = SpinBoxIconSize->value();
192 204
193 cfg.setGroup( "General" ); 205 cfg.setGroup( "General" );
194 cfg.writeEntry( "IconSize", m_iconSize ); 206 cfg.writeEntry( "IconSize", m_iconSize );
195 207 cfg.writeEntry( "checkinterval", SpinRefresh->value()*1000 );
196 208
197 // set autostart settings 209 // set autostart settings
198 setAutoStart(); 210 setAutoStart();
199} 211}
200 212
201 213
202void TodayConfig::moveSelectedUp() { 214void TodayConfig::moveSelectedUp() {
203 QListViewItem *item = m_appletListView->selectedItem(); 215 QListViewItem *item = m_appletListView->selectedItem();
204 if ( item && item->itemAbove() ) { 216 if ( item && item->itemAbove() ) {
205 item->itemAbove()->moveItem( item ); 217 item->itemAbove()->moveItem( item );
206 } 218 }
207} 219}
208 220
209 221
210void TodayConfig::moveSelectedDown() { 222void TodayConfig::moveSelectedDown() {
211 QListViewItem *item = m_appletListView->selectedItem(); 223 QListViewItem *item = m_appletListView->selectedItem();
212 if ( item && item->itemBelow() ) { 224 if ( item && item->itemBelow() ) {
213 item->moveItem( item->itemBelow() ); 225 item->moveItem( item->itemBelow() );
214 } 226 }
215} 227}
216 228
217 229
218/** 230/**
219 * Set up the icons in the order/active tab 231 * Set up the icons in the order/active tab
220 */ 232 */
221void TodayConfig::pluginManagement( QString libName, QString name, QPixmap icon ) { 233void TodayConfig::pluginManagement( QString libName, QString name, QPixmap icon ) {
222 234
223 QCheckListItem *item; 235 QCheckListItem *item;
224 item = new QCheckListItem( m_appletListView, name, QCheckListItem::CheckBox ); 236 item = new QCheckListItem( m_appletListView, name, QCheckListItem::CheckBox );
225 237
226 if ( !icon.isNull() ) { 238 if ( !icon.isNull() ) {
227 item->setPixmap( 0, icon ); 239 item->setPixmap( 0, icon );
228 } 240 }
229 241
230 if ( m_excludeApplets.find( libName ) == m_excludeApplets.end() ) { 242 if ( m_excludeApplets.find( libName ) == m_excludeApplets.end() ) {
231 item->setOn( TRUE ); 243 item->setOn( TRUE );
232 } 244 }
233 245
234 m_applets[libName] = item; 246 m_applets[libName] = item;
235 247
236 // kind of hack to get the first tab as default. 248 // kind of hack to get the first tab as default.
237 TabWidget3->setCurrentTab( tab_2 ); 249 TabWidget3->setCurrentTab( tab_2 );
238} 250}
239 251
240void TodayConfig::appletChanged() { 252void TodayConfig::appletChanged() {
241 m_applets_changed = true; 253 m_applets_changed = true;
242} 254}
243 255
diff --git a/core/pim/today/todayconfig.h b/core/pim/today/todayconfig.h
index 827e106..68483c2 100644
--- a/core/pim/today/todayconfig.h
+++ b/core/pim/today/todayconfig.h
@@ -22,52 +22,53 @@
22#include <qlistview.h> 22#include <qlistview.h>
23#include <opie/otabwidget.h> 23#include <opie/otabwidget.h>
24 24
25class QCheckBox; 25class QCheckBox;
26class QLabel; 26class QLabel;
27class QSpinBox; 27class QSpinBox;
28class QTabWidget; 28class QTabWidget;
29 29
30class TodayConfig : public QDialog { 30class TodayConfig : public QDialog {
31 31
32 Q_OBJECT 32 Q_OBJECT
33 33
34public: 34public:
35 TodayConfig( QWidget* parent = 0, const char* name = 0, bool modal = FALSE ); 35 TodayConfig( QWidget* parent = 0, const char* name = 0, bool modal = FALSE );
36 ~TodayConfig(); 36 ~TodayConfig();
37 37
38 OTabWidget* TabWidget3; 38 OTabWidget* TabWidget3;
39 39
40 void writeConfig(); 40 void writeConfig();
41 void pluginManagement( QString libName, QString name, QPixmap icon ); 41 void pluginManagement( QString libName, QString name, QPixmap icon );
42 42
43 43
44protected slots: 44protected slots:
45 void appletChanged(); 45 void appletChanged();
46 void moveSelectedUp(); 46 void moveSelectedUp();
47 void moveSelectedDown(); 47 void moveSelectedDown();
48 48
49private: 49private:
50 void setAutoStart(); 50 void setAutoStart();
51 void readConfig(); 51 void readConfig();
52 52
53 QListView* m_appletListView; 53 QListView* m_appletListView;
54 QMap<QString,QCheckListItem*> m_applets; 54 QMap<QString,QCheckListItem*> m_applets;
55 55
56 int m_autoStart; 56 int m_autoStart;
57 int m_autoStartTimer; 57 int m_autoStartTimer;
58 int m_iconSize; 58 int m_iconSize;
59 QStringList m_excludeApplets; 59 QStringList m_excludeApplets;
60 bool m_applets_changed; 60 bool m_applets_changed;
61 61
62 QLabel* TextLabel2; 62 QLabel* TextLabel2;
63 QCheckBox* CheckBoxAuto; 63 QCheckBox* CheckBoxAuto;
64 QWidget* tab_2; 64 QWidget* tab_2;
65 QWidget* tab_3; 65 QWidget* tab_3;
66 QLabel* TextLabel1; 66 QLabel* TextLabel1;
67 QSpinBox* SpinBox7; 67 QSpinBox* SpinBox7;
68 QLabel* TimeLabel; 68 QLabel* TimeLabel;
69 QSpinBox* SpinBoxTime; 69 QSpinBox* SpinBoxTime;
70 QSpinBox* SpinRefresh;
70 QSpinBox* SpinBoxIconSize; 71 QSpinBox* SpinBoxIconSize;
71}; 72};
72 73
73#endif 74#endif