summaryrefslogtreecommitdiff
authorharlekin <harlekin>2003-03-30 22:44:10 (UTC)
committer harlekin <harlekin>2003-03-30 22:44:10 (UTC)
commita014a9f0d0fe82dc5daf2b37ad4458cc5722db0d (patch) (unidiff)
treeb3826416037c7650c3cc0fd9f0038ed705f3cc1c
parent0b6d158a2a2b52d83ad4b1046ce9dbffff2190e6 (diff)
downloadopie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.zip
opie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.tar.gz
opie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.tar.bz2
layout fix, closes bug #761
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/today/today.cpp10
-rw-r--r--core/pim/today/todaybase.cpp1
2 files changed, 6 insertions, 5 deletions
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index 4ec690c..83d8601 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -1,394 +1,396 @@
1/* 1/*
2 * today.cpp 2 * today.cpp
3 * 3 *
4 * copyright : (c) 2002,2003 by Maximilian Reiß 4 * copyright : (c) 2002,2003 by Maximilian Reiß
5 * email : harlekin@handhelds.org 5 * email : harlekin@handhelds.org
6 * 6 *
7 */ 7 */
8/*************************************************************************** 8/***************************************************************************
9 * * 9 * *
10 * This program is free software; you can redistribute it and/or modify * 10 * This program is free software; you can redistribute it and/or modify *
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 18
19#define QTOPIA_INTERNAL_LANGLIST 19#define QTOPIA_INTERNAL_LANGLIST
20 20
21#include "today.h" 21#include "today.h"
22 22
23#include <qpe/config.h> 23#include <qpe/config.h>
24#include <qpe/qcopenvelope_qws.h> 24#include <qpe/qcopenvelope_qws.h>
25#include <qpe/resource.h> 25#include <qpe/resource.h>
26#include <qpe/global.h> 26#include <qpe/global.h>
27#include <qpe/qpeapplication.h> 27#include <qpe/qpeapplication.h>
28#include <qpe/contact.h> 28#include <qpe/contact.h>
29#include <qpe/timestring.h> 29#include <qpe/timestring.h>
30 30
31#include <qdir.h> 31#include <qdir.h>
32#include <qfile.h> 32#include <qfile.h>
33#include <qtimer.h> 33#include <qtimer.h>
34#include <qwhatsthis.h> 34#include <qwhatsthis.h>
35#include <qtranslator.h> 35#include <qtranslator.h>
36 36
37struct TodayPlugin { 37struct TodayPlugin {
38 TodayPlugin() : library( 0 ), iface( 0 ), guiPart( 0 ), guiBox( 0 ) {} 38 TodayPlugin() : library( 0 ), iface( 0 ), guiPart( 0 ), guiBox( 0 ) {}
39 QLibrary *library; 39 QLibrary *library;
40 QInterfacePtr<TodayPluginInterface> iface; 40 QInterfacePtr<TodayPluginInterface> iface;
41 TodayPluginObject *guiPart; 41 TodayPluginObject *guiPart;
42 QWidget *guiBox; 42 QWidget *guiBox;
43 QString name; 43 QString name;
44 bool active; 44 bool active;
45 bool excludeRefresh; 45 bool excludeRefresh;
46 int pos; 46 int pos;
47}; 47};
48 48
49static QValueList<TodayPlugin> pluginList; 49static QValueList<TodayPlugin> pluginList;
50 50
51Today::Today( QWidget* parent, const char* name, WFlags fl ) 51Today::Today( QWidget* parent, const char* name, WFlags fl )
52 : TodayBase( parent, name, fl ) { 52 : TodayBase( parent, name, fl ) {
53 53
54 QObject::connect( (QObject*)ConfigButton, SIGNAL( clicked() ), this, SLOT( startConfig() ) ); 54 QObject::connect( (QObject*)ConfigButton, SIGNAL( clicked() ), this, SLOT( startConfig() ) );
55 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) ); 55 QObject::connect( (QObject*)OwnerField, SIGNAL( clicked() ), this, SLOT( editCard() ) );
56 56
57#if defined(Q_WS_QWS) 57#if defined(Q_WS_QWS)
58#if !defined(QT_NO_COP) 58#if !defined(QT_NO_COP)
59 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this ); 59 QCopChannel *todayChannel = new QCopChannel( "QPE/Today" , this );
60 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ), 60 connect ( todayChannel, SIGNAL( received( const QCString &, const QByteArray &) ),
61 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) ); 61 this, SLOT ( channelReceived( const QCString &, const QByteArray &) ) );
62#endif 62#endif
63#endif 63#endif
64 64
65 setOwnerField(); 65 setOwnerField();
66 m_refreshTimer = new QTimer( this ); 66 m_refreshTimer = new QTimer( this );
67 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 67 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
68 m_refreshTimer->start( 15000 ); 68 m_refreshTimer->start( 15000 );
69 //init(); 69 //init();
70 loadPlugins(); 70 loadPlugins();
71 showMaximized(); 71 showMaximized();
72} 72}
73 73
74/** 74/**
75 * Qcop receive method. 75 * Qcop receive method.
76 */ 76 */
77void Today::channelReceived( const QCString &msg, const QByteArray & data ) { 77void Today::channelReceived( const QCString &msg, const QByteArray & data ) {
78 QDataStream stream( data, IO_ReadOnly ); 78 QDataStream stream( data, IO_ReadOnly );
79 if ( msg == "message(QString)" ) { 79 if ( msg == "message(QString)" ) {
80 QString message; 80 QString message;
81 stream >> message; 81 stream >> message;
82 setOwnerField( message ); 82 setOwnerField( message );
83 } 83 }
84} 84}
85 85
86void Today::setRefreshTimer( int interval ) { 86void Today::setRefreshTimer( int interval ) {
87 87
88 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 88 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
89 89
90 // 0 is "never" case 90 // 0 is "never" case
91 if ( !interval == 0 ) { 91 if ( !interval == 0 ) {
92 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 92 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
93 m_refreshTimer->changeInterval( interval ); 93 m_refreshTimer->changeInterval( interval );
94 } 94 }
95} 95}
96 96
97 97
98/** 98/**
99 * Initialises the owner field with the default value, the username 99 * Initialises the owner field with the default value, the username
100 */ 100 */
101void Today::setOwnerField() { 101void Today::setOwnerField() {
102 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" ); 102 QString file = Global::applicationFileName( "addressbook", "businesscard.vcf" );
103 if ( QFile::exists( file ) ) { 103 if ( QFile::exists( file ) ) {
104 Contact cont = Contact::readVCard( file )[0]; 104 Contact cont = Contact::readVCard( file )[0];
105 QString returnString = cont.fullName(); 105 QString returnString = cont.fullName();
106 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" ); 106 OwnerField->setText( "<b>" + tr ( "Owned by " ) + returnString + "</b>" );
107 } else { 107 } else {
108 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" ); 108 OwnerField->setText( "<b>" + tr ( "Please fill out the business card" ) + " </b>" );
109 } 109 }
110} 110}
111 111
112/** 112/**
113 * Set the owner field with a given QString, for example per qcop. 113 * Set the owner field with a given QString, for example per qcop.
114 */ 114 */
115void Today::setOwnerField( QString &message ) { 115void Today::setOwnerField( QString &message ) {
116 if ( !message.isEmpty() ) { 116 if ( !message.isEmpty() ) {
117 OwnerField->setText( "<b>" + message + "</b>" ); 117 OwnerField->setText( "<b>" + message + "</b>" );
118 } 118 }
119} 119}
120 120
121/** 121/**
122 * Init stuff needed for today. Reads the config file. 122 * Init stuff needed for today. Reads the config file.
123 */ 123 */
124void Today::init() { 124void Today::init() {
125 // read config 125 // read config
126 Config cfg( "today" ); 126 Config cfg( "today" );
127 127
128 cfg.setGroup( "Plugins" ); 128 cfg.setGroup( "Plugins" );
129 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); 129 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' );
130 m_allApplets = cfg.readListEntry( "AllApplets", ',' ); 130 m_allApplets = cfg.readListEntry( "AllApplets", ',' );
131 131
132 cfg.setGroup( "General" ); 132 cfg.setGroup( "General" );
133 m_iconSize = cfg.readNumEntry( "IconSize", 18 ); 133 m_iconSize = cfg.readNumEntry( "IconSize", 18 );
134 m_hideBanner = cfg.readNumEntry( "HideBanner", 0 ); 134 m_hideBanner = cfg.readNumEntry( "HideBanner", 0 );
135 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) ); 135 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) );
136 136
137 // set the date in top label 137 // set the date in top label
138 QDate date = QDate::currentDate(); 138 QDate date = QDate::currentDate();
139 DateLabel->setText( QString( "<font color=#FFFFFF>" + TimeString::longDateString( date ) + "</font>" ) ); 139 DateLabel->setText( QString( "<font color=#FFFFFF>" + TimeString::longDateString( date ) + "</font>" ) );
140 140
141 if ( layout ) { 141 if ( layout ) {
142 delete layout; 142 delete layout;
143 } 143 }
144 144
145 if ( m_hideBanner ) { 145 if ( m_hideBanner ) {
146 Opiezilla->hide(); 146 Opiezilla->hide();
147 TodayLabel->hide(); 147 TodayLabel->hide();
148 } else { 148 } else {
149 Opiezilla->show(); 149 Opiezilla->show();
150 TodayLabel->show(); 150 TodayLabel->show();
151 } 151 }
152 152
153 layout = new QVBoxLayout( this ); 153 layout = new QVBoxLayout( this );
154 layout->addWidget( Frame ); 154 layout->addWidget( Frame );
155 layout->addWidget( OwnerField ); 155 layout->addWidget( OwnerField );
156} 156}
157 157
158/** 158/**
159 * Load the plugins 159 * Load the plugins
160 */ 160 */
161void Today::loadPlugins() { 161void Today::loadPlugins() {
162 162
163 init(); 163 init();
164 QValueList<TodayPlugin>::Iterator tit; 164 QValueList<TodayPlugin>::Iterator tit;
165 if ( !pluginList.isEmpty() ) { 165 if ( !pluginList.isEmpty() ) {
166 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) { 166 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) {
167 (*tit).guiBox->hide(); 167 (*tit).guiBox->hide();
168 (*tit).guiBox->reparent( 0, QPoint( 0, 0 ) ); 168 (*tit).guiBox->reparent( 0, QPoint( 0, 0 ) );
169 delete (*tit).guiBox; 169 delete (*tit).guiBox;
170 (*tit).library->unload(); 170 (*tit).library->unload();
171 delete (*tit).library; 171 delete (*tit).library;
172 } 172 }
173 pluginList.clear(); 173 pluginList.clear();
174 } 174 }
175 175
176 QString path = QPEApplication::qpeDir() + "/plugins/today"; 176 QString path = QPEApplication::qpeDir() + "/plugins/today";
177 QDir dir( path, "lib*.so" ); 177 QDir dir( path, "lib*.so" );
178 178
179 QStringList list = dir.entryList(); 179 QStringList list = dir.entryList();
180 QStringList::Iterator it; 180 QStringList::Iterator it;
181 181
182 QMap<QString, TodayPlugin> tempList; 182 QMap<QString, TodayPlugin> tempList;
183 183
184 for ( it = list.begin(); it != list.end(); ++it ) { 184 for ( it = list.begin(); it != list.end(); ++it ) {
185 QInterfacePtr<TodayPluginInterface> iface; 185 QInterfacePtr<TodayPluginInterface> iface;
186 QLibrary *lib = new QLibrary( path + "/" + *it ); 186 QLibrary *lib = new QLibrary( path + "/" + *it );
187 187
188 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() ); 188 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() );
189 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) { 189 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) {
190 qDebug( "accepted: %s", QString( path + "/" + *it ).latin1() ); 190 qDebug( "accepted: %s", QString( path + "/" + *it ).latin1() );
191 qDebug( QString(*it) ); 191 qDebug( QString(*it) );
192 192
193 TodayPlugin plugin; 193 TodayPlugin plugin;
194 plugin.library = lib; 194 plugin.library = lib;
195 plugin.iface = iface; 195 plugin.iface = iface;
196 plugin.name = QString(*it); 196 plugin.name = QString(*it);
197 197
198 QString type = (*it).left( (*it).find(".") ); 198 QString type = (*it).left( (*it).find(".") );
199 QStringList langs = Global::languageList(); 199 QStringList langs = Global::languageList();
200 for (QStringList::ConstIterator lit = langs.begin(); lit!=langs.end(); ++lit) { 200 for (QStringList::ConstIterator lit = langs.begin(); lit!=langs.end(); ++lit) {
201 QString lang = *lit; 201 QString lang = *lit;
202 qDebug( "Languages: " + lang ); 202 qDebug( "Languages: " + lang );
203 QTranslator * trans = new QTranslator( qApp ); 203 QTranslator * trans = new QTranslator( qApp );
204 QString tfn = QPEApplication::qpeDir()+"/i18n/" + lang + "/" + type + ".qm"; 204 QString tfn = QPEApplication::qpeDir()+"/i18n/" + lang + "/" + type + ".qm";
205 if ( trans->load( tfn ) ) { 205 if ( trans->load( tfn ) ) {
206 qApp->installTranslator( trans ); 206 qApp->installTranslator( trans );
207 } else { 207 } else {
208 delete trans; 208 delete trans;
209 } 209 }
210 } 210 }
211 211
212 // find out if plugins should be shown 212 // find out if plugins should be shown
213 if ( m_excludeApplets.grep( *it ).isEmpty() ) { 213 if ( m_excludeApplets.grep( *it ).isEmpty() ) {
214 plugin.active = true; 214 plugin.active = true;
215 } else { 215 } else {
216 plugin.active = false; 216 plugin.active = false;
217 } 217 }
218 218
219 plugin.guiPart = plugin.iface->guiPart(); 219 plugin.guiPart = plugin.iface->guiPart();
220 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh(); 220 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh();
221 221
222 // package the whole thing into a qwidget so it can be shown and hidden 222 // package the whole thing into a qwidget so it can be shown and hidden
223 plugin.guiBox = new QWidget( this ); 223 plugin.guiBox = new QWidget( this );
224 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox ); 224 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox );
225 QPixmap plugPix; 225 QPixmap plugPix;
226 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 ); 226 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 );
227 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox ); 227 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox );
228 plugIcon->setPixmap( plugPix ); 228 plugIcon->setPixmap( plugPix );
229 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") ); 229 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") );
230 plugIcon->setName( plugin.guiPart->appName() ); 230 plugIcon->setName( plugin.guiPart->appName() );
231 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) ); 231 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) );
232 // a scrollview for each plugin 232 // a scrollview for each plugin
233 QScrollView* sv = new QScrollView( plugin.guiBox ); 233 QScrollView* sv = new QScrollView( plugin.guiBox );
234 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() ); 234 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() );
235 // not sure if that is good .-) 235 // not sure if that is good .-)
236 sv->setMinimumHeight( 12 ); 236 sv->setMinimumHeight( 12 );
237 sv->setResizePolicy( QScrollView::AutoOneFit ); 237 sv->setResizePolicy( QScrollView::AutoOneFit );
238 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 238 sv->setHScrollBarMode( QScrollView::AlwaysOff );
239 sv->setFrameShape( QFrame::NoFrame ); 239 sv->setFrameShape( QFrame::NoFrame );
240 sv->addChild( plugWidget ); 240 sv->addChild( plugWidget );
241 // make sure the icon is on the top alligned 241 // make sure the icon is on the top alligned
242 boxLayout->addWidget( plugIcon, 0, AlignTop ); 242 boxLayout->addWidget( plugIcon, 0, AlignTop );
243 boxLayout->addWidget( sv, 0, AlignTop ); 243 boxLayout->addWidget( sv, 0, AlignTop );
244 boxLayout->setStretchFactor( plugIcon, 1 ); 244 boxLayout->setStretchFactor( plugIcon, 1 );
245 boxLayout->setStretchFactor( sv, 9 ); 245 boxLayout->setStretchFactor( sv, 9 );
246 // "prebuffer" it in one more list, to get the sorting done 246 // "prebuffer" it in one more list, to get the sorting done
247 tempList.insert( plugin.name, plugin ); 247 tempList.insert( plugin.name, plugin );
248 248
249 // on first start the list is off course empty 249 // on first start the list is off course empty
250 if ( m_allApplets.isEmpty() ) { 250 if ( m_allApplets.isEmpty() ) {
251 layout->addWidget( plugin.guiBox ); 251 layout->addWidget( plugin.guiBox );
252 pluginList.append( plugin ); 252 pluginList.append( plugin );
253 } 253 }
254 254
255 // if plugin is not yet in the list, add it to the layout too 255 // if plugin is not yet in the list, add it to the layout too
256 else if ( !m_allApplets.contains( plugin.name ) ) { 256 else if ( !m_allApplets.contains( plugin.name ) ) {
257 layout->addWidget( plugin.guiBox ); 257 layout->addWidget( plugin.guiBox );
258 pluginList.append( plugin ); 258 pluginList.append( plugin );
259 } 259 }
260 } else { 260 } else {
261 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() ); 261 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() );
262 delete lib; 262 delete lib;
263 } 263 }
264 } 264 }
265 265
266 if ( !m_allApplets.isEmpty() ) { 266 if ( !m_allApplets.isEmpty() ) {
267 TodayPlugin tempPlugin; 267 TodayPlugin tempPlugin;
268 QStringList::Iterator stringit; 268 QStringList::Iterator stringit;
269 269
270 for( stringit = m_allApplets.begin(); stringit != m_allApplets.end(); ++stringit ) { 270 for( stringit = m_allApplets.begin(); stringit != m_allApplets.end(); ++stringit ) {
271 tempPlugin = ( tempList.find( *stringit ) ).data(); 271 tempPlugin = ( tempList.find( *stringit ) ).data();
272 if ( !( (tempPlugin.name).isEmpty() ) ) { 272 if ( !( (tempPlugin.name).isEmpty() ) ) {
273 layout->addWidget( tempPlugin.guiBox ); 273 layout->addWidget( tempPlugin.guiBox );
274 pluginList.append( tempPlugin ); 274 pluginList.append( tempPlugin );
275 } 275 }
276 } 276 }
277 } 277 }
278 draw(); 278 draw();
279} 279}
280 280
281 281
282/** 282/**
283 * Repaint method. Reread all fields. 283 * Repaint method. Reread all fields.
284 */ 284 */
285void Today::draw() { 285void Today::draw() {
286 286
287 if ( pluginList.count() == 0 ) { 287 if ( pluginList.count() == 0 ) {
288 QLabel *noPlugins = new QLabel( this ); 288 QLabel *noPlugins = new QLabel( this );
289 noPlugins->setText( tr( "No plugins found" ) ); 289 noPlugins->setText( tr( "No plugins found" ) );
290 layout->addWidget( noPlugins ); 290 layout->addWidget( noPlugins );
291 return; 291 return;
292 } 292 }
293 293
294 uint count = 0; 294 uint count = 0;
295 TodayPlugin plugin; 295 TodayPlugin plugin;
296 for ( uint i = 0; i < pluginList.count(); i++ ) { 296 for ( uint i = 0; i < pluginList.count(); i++ ) {
297 plugin = pluginList[i]; 297 plugin = pluginList[i];
298 298
299 if ( plugin.active ) { 299 if ( plugin.active ) {
300 // qDebug( plugin.name + " is ACTIVE " ); 300 // qDebug( plugin.name + " is ACTIVE " );
301 plugin.guiBox->show(); 301 plugin.guiBox->show();
302 } else { 302 } else {
303 // qDebug( plugin.name + " is INACTIVE" ); 303 // qDebug( plugin.name + " is INACTIVE" );
304 plugin.guiBox->hide(); 304 plugin.guiBox->hide();
305 } 305 }
306 count++; 306 count++;
307 } 307 }
308 308
309 if ( count == 0 ) { 309 if ( count == 0 ) {
310 QLabel *noPluginsActive = new QLabel( this ); 310 QLabel *noPluginsActive = new QLabel( this );
311 noPluginsActive->setText( tr( "No plugins activated" ) ); 311 noPluginsActive->setText( tr( "No plugins activated" ) );
312 layout->addWidget( noPluginsActive ); 312 layout->addWidget( noPluginsActive );
313 } 313 }
314 layout->addStretch(0); 314 layout->addStretch(0);
315} 315}
316 316
317 317
318/** 318/**
319 * The method for the configuration dialog. 319 * The method for the configuration dialog.
320 */ 320 */
321void Today::startConfig() { 321void Today::startConfig() {
322 322
323 // disconnect timer to prevent problems while being on config dialog 323 // disconnect timer to prevent problems while being on config dialog
324 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 324 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
325 m_refreshTimer->stop( ); 325 m_refreshTimer->stop( );
326 326
327 TodayConfig conf( this, "dialog", true ); 327 TodayConfig conf( this, "dialog", true );
328 328
329 TodayPlugin plugin; 329 TodayPlugin plugin;
330 QList<TodayConfigWidget> configWidgetList; 330 QList<TodayConfigWidget> configWidgetList;
331 331
332 for ( int i = pluginList.count() - 1; i >= 0; i-- ) { 332 for ( int i = pluginList.count() - 1; i >= 0; i-- ) {
333 plugin = pluginList[i]; 333 plugin = pluginList[i];
334 334
335 // load the config widgets in the tabs 335 // load the config widgets in the tabs
336 if ( plugin.guiPart->configWidget( this ) != 0l ) { 336 if ( plugin.guiPart->configWidget( this ) != 0l ) {
337 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 ); 337 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 );
338 configWidgetList.append( widget ); 338 configWidgetList.append( widget );
339 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig() 339 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig()
340 , plugin.guiPart->appName() ); 340 , plugin.guiPart->appName() );
341 } 341 }
342 // set the order/activate tab 342 // set the order/activate tab
343 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(), 343 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(),
344 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) ); 344 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) );
345 } 345 }
346 346
347 if ( conf.exec() == QDialog::Accepted ) { 347 if ( conf.exec() == QDialog::Accepted ) {
348 conf.writeConfig(); 348 conf.writeConfig();
349 TodayConfigWidget *confWidget; 349 TodayConfigWidget *confWidget;
350 for ( confWidget = configWidgetList.first(); confWidget != 0; 350 for ( confWidget = configWidgetList.first(); confWidget != 0;
351 confWidget = configWidgetList.next() ) { 351 confWidget = configWidgetList.next() ) {
352 confWidget->writeConfig(); 352 confWidget->writeConfig();
353 } 353 }
354 loadPlugins(); 354 loadPlugins();
355 } else { 355 } else {
356 // since refresh is not called in that case , reconnect the signal 356 // since refresh is not called in that case , reconnect the signal
357 m_refreshTimer->start( 15000 ); // get the config value in here later 357 m_refreshTimer->start( 15000 ); // get the config value in here later
358 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 358 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
359 } 359 }
360} 360}
361 361
362 362
363/** 363/**
364 * Refresh for the view. Reload all applets 364 * Refresh for the view. Reload all applets
365 * 365 *
366 */ 366 */
367void Today::refresh() { 367void Today::refresh() {
368 368
369 init(); 369 init();
370 370
371 QValueList<TodayPlugin>::Iterator it; 371 QValueList<TodayPlugin>::Iterator it;
372 for ( it = pluginList.begin(); it != pluginList.end(); ++it ) { 372 for ( it = pluginList.begin(); it != pluginList.end(); ++it ) {
373 if ( !(*it).excludeRefresh ) { 373 if ( !(*it).excludeRefresh ) {
374 (*it).guiPart->refresh(); 374 (*it).guiPart->refresh();
375 qDebug( "refresh" ); 375 layout->addWidget( (*it).guiBox );
376 } 376 qDebug( "refresh" );
377 }
377 } 378 }
379 layout->addStretch(0);
378} 380}
379 381
380void Today::startApplication() { 382void Today::startApplication() {
381 QCopEnvelope e( "QPE/System", "execute(QString)" ); 383 QCopEnvelope e( "QPE/System", "execute(QString)" );
382 e << QString( sender()->name() ); 384 e << QString( sender()->name() );
383} 385}
384 386
385/** 387/**
386 * launch addressbook (personal card) 388 * launch addressbook (personal card)
387 */ 389 */
388void Today::editCard() { 390void Today::editCard() {
389 QCopEnvelope env( "QPE/Application/addressbook", "editPersonalAndClose()" ); 391 QCopEnvelope env( "QPE/Application/addressbook", "editPersonalAndClose()" );
390} 392}
391 393
392Today::~Today() { 394Today::~Today() {
393} 395}
394 396
diff --git a/core/pim/today/todaybase.cpp b/core/pim/today/todaybase.cpp
index 7beed34..41daa7d 100644
--- a/core/pim/today/todaybase.cpp
+++ b/core/pim/today/todaybase.cpp
@@ -1,109 +1,108 @@
1/* 1/*
2 * todaybase.cpp 2 * todaybase.cpp
3 * 3 *
4 * copyright : (c) 2002, 2003 by Maximilian Reiß 4 * copyright : (c) 2002, 2003 by Maximilian Reiß
5 * email : harlekin@handhelds.org 5 * email : harlekin@handhelds.org
6 * 6 *
7 */ 7 */
8/*************************************************************************** 8/***************************************************************************
9 * * 9 * *
10 * This program is free software; you can redistribute it and/or modify * 10 * This program is free software; you can redistribute it and/or modify *
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#include "todaybase.h" 17#include "todaybase.h"
18 18
19#include <qvbox.h> 19#include <qvbox.h>
20#include <qlabel.h> 20#include <qlabel.h>
21#include <qwhatsthis.h> 21#include <qwhatsthis.h>
22 22
23#include <qpe/resource.h> 23#include <qpe/resource.h>
24 24
25 25
26TodayBase::TodayBase( QWidget* parent, const char* name, WFlags ) 26TodayBase::TodayBase( QWidget* parent, const char* name, WFlags )
27 : QWidget( parent, name, WStyle_ContextHelp ) { 27 : QWidget( parent, name, WStyle_ContextHelp ) {
28 28
29 QPixmap logo = Resource::loadPixmap( "today/today_logo"); // logo 29 QPixmap logo = Resource::loadPixmap( "today/today_logo"); // logo
30 QPixmap opiezilla = Resource::loadPixmap("today/opiezilla" ); //the opiezilla 30 QPixmap opiezilla = Resource::loadPixmap("today/opiezilla" ); //the opiezilla
31 QPixmap config = Resource::loadPixmap( "SettingsIcon" ); // config icon 31 QPixmap config = Resource::loadPixmap( "SettingsIcon" ); // config icon
32 32
33 layout = 0L; 33 layout = 0L;
34 34
35 QPalette pal = this->palette(); 35 QPalette pal = this->palette();
36 QColor col = pal.color( QPalette::Active, QColorGroup::Background ); 36 QColor col = pal.color( QPalette::Active, QColorGroup::Background );
37 pal.setColor( QPalette::Active, QColorGroup::Button, col ); 37 pal.setColor( QPalette::Active, QColorGroup::Button, col );
38 pal.setColor( QPalette::Inactive, QColorGroup::Button, col ); 38 pal.setColor( QPalette::Inactive, QColorGroup::Button, col );
39 pal.setColor( QPalette::Normal, QColorGroup::Button, col ); 39 pal.setColor( QPalette::Normal, QColorGroup::Button, col );
40 pal.setColor( QPalette::Disabled, QColorGroup::Button, col ); 40 pal.setColor( QPalette::Disabled, QColorGroup::Button, col );
41 this->setPalette( pal ); 41 this->setPalette( pal );
42 42
43 // --- logo Section --- 43 // --- logo Section ---
44 QPalette pal2; 44 QPalette pal2;
45 QColorGroup cg; 45 QColorGroup cg;
46 cg.setColor( QColorGroup::Text, white ); 46 cg.setColor( QColorGroup::Text, white );
47 cg.setBrush( QColorGroup::Background, QBrush( QColor( 238, 238, 230 ), logo ) ); 47 cg.setBrush( QColorGroup::Background, QBrush( QColor( 238, 238, 230 ), logo ) );
48 pal2.setActive( cg ); 48 pal2.setActive( cg );
49 49
50// today logo 50// today logo
51 Frame = new QLabel( this, "Frame" ); 51 Frame = new QLabel( this, "Frame" );
52 Frame->setPalette( pal2 ); 52 Frame->setPalette( pal2 );
53 Frame->setFrameShape( QFrame::StyledPanel ); 53 Frame->setFrameShape( QFrame::StyledPanel );
54 Frame->setFrameShadow( QFrame::Raised ); 54 Frame->setFrameShadow( QFrame::Raised );
55 Frame->setLineWidth( 0 ); 55 Frame->setLineWidth( 0 );
56 Frame->setMaximumHeight( 50 );
57 56
58 QHBoxLayout *frameLayout = new QHBoxLayout( Frame ); 57 QHBoxLayout *frameLayout = new QHBoxLayout( Frame );
59 QVBox *box1 = new QVBox( Frame ); 58 QVBox *box1 = new QVBox( Frame );
60 box1->setMinimumWidth( 100 ); 59 box1->setMinimumWidth( 100 );
61 // Today text 60 // Today text
62 TodayLabel = new QLabel( box1, "TodayText" ); 61 TodayLabel = new QLabel( box1, "TodayText" );
63 QFont TodayLabel_font( TodayLabel->font() ); 62 QFont TodayLabel_font( TodayLabel->font() );
64 TodayLabel_font.setBold( TRUE ); 63 TodayLabel_font.setBold( TRUE );
65 TodayLabel_font.setPointSize( 40 ); 64 TodayLabel_font.setPointSize( 40 );
66 TodayLabel->setFont( TodayLabel_font ); 65 TodayLabel->setFont( TodayLabel_font );
67 TodayLabel->setBackgroundOrigin( QLabel::ParentOrigin ); 66 TodayLabel->setBackgroundOrigin( QLabel::ParentOrigin );
68 TodayLabel->setText( "<font color=#FFFFFF>" + tr("Today") +"</font>" ); 67 TodayLabel->setText( "<font color=#FFFFFF>" + tr("Today") +"</font>" );
69 68
70 // date 69 // date
71 DateLabel = new QLabel( box1, "TextLabel1" ); 70 DateLabel = new QLabel( box1, "TextLabel1" );
72 QFont DateLabel_font( DateLabel->font() ); 71 QFont DateLabel_font( DateLabel->font() );
73 DateLabel_font.setBold( TRUE ); 72 DateLabel_font.setBold( TRUE );
74 DateLabel->setFont( DateLabel_font ); 73 DateLabel->setFont( DateLabel_font );
75 DateLabel->setBackgroundOrigin( QLabel::ParentOrigin ); 74 DateLabel->setBackgroundOrigin( QLabel::ParentOrigin );
76 DateLabel->setTextFormat( RichText ); 75 DateLabel->setTextFormat( RichText );
77 76
78 // Opiezilla 77 // Opiezilla
79 Opiezilla = new QLabel( Frame, "OpieZilla" ); 78 Opiezilla = new QLabel( Frame, "OpieZilla" );
80 Opiezilla->setPixmap( opiezilla ); 79 Opiezilla->setPixmap( opiezilla );
81 QWhatsThis::add( Opiezilla , tr( "Today by Maximilian Reiß" ) ); 80 QWhatsThis::add( Opiezilla , tr( "Today by Maximilian Reiß" ) );
82 Opiezilla->setBackgroundOrigin( QLabel::ParentOrigin ); 81 Opiezilla->setBackgroundOrigin( QLabel::ParentOrigin );
83 82
84 83
85 // Ownerfield 84 // Ownerfield
86 OwnerField = new OClickableLabel( this , "Owner" ); 85 OwnerField = new OClickableLabel( this , "Owner" );
87 OwnerField->setGeometry( QRect( 0, 0, this->width(), 12 ) ); 86 OwnerField->setGeometry( QRect( 0, 0, this->width(), 12 ) );
88 OwnerField->setAlignment( int (QLabel::AlignTop | QLabel::AlignLeft ) ); 87 OwnerField->setAlignment( int (QLabel::AlignTop | QLabel::AlignLeft ) );
89 OwnerField->setMaximumHeight(12); 88 OwnerField->setMaximumHeight(12);
90 89
91 // config 90 // config
92 ConfigButton = new OClickableLabel ( Frame, "PushButton1" ); 91 ConfigButton = new OClickableLabel ( Frame, "PushButton1" );
93 ConfigButton->setPixmap( config ); 92 ConfigButton->setPixmap( config );
94 QWhatsThis::add( ConfigButton, tr( "Click here to get to the config dialog" ) ); 93 QWhatsThis::add( ConfigButton, tr( "Click here to get to the config dialog" ) );
95 ConfigButton->setBackgroundOrigin( QLabel::ParentOrigin ); 94 ConfigButton->setBackgroundOrigin( QLabel::ParentOrigin );
96 95
97 frameLayout->addWidget( box1 ); 96 frameLayout->addWidget( box1 );
98 frameLayout->addStretch( 2 ); 97 frameLayout->addStretch( 2 );
99 frameLayout->addWidget( ConfigButton, 0, AlignBottom ); 98 frameLayout->addWidget( ConfigButton, 0, AlignBottom );
100 frameLayout->addWidget( Opiezilla ); 99 frameLayout->addWidget( Opiezilla );
101} 100}
102 101
103 102
104/** 103/**
105 * D' tor 104 * D' tor
106 */ 105 */
107TodayBase::~TodayBase() { 106TodayBase::~TodayBase() {
108} 107}
109 108