summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/today/today.cpp16
-rw-r--r--core/pim/today/today.h1
2 files changed, 2 insertions, 15 deletions
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index 1b31cfd..e6f8c93 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -124,134 +124,132 @@ void Today::setOwnerField( QString &message ) {
124 124
125 125
126/** 126/**
127 * Init stuff needed for today. Reads the config file. 127 * Init stuff needed for today. Reads the config file.
128 */ 128 */
129void Today::init() { 129void Today::init() {
130 // read config 130 // read config
131 Config cfg( "today" ); 131 Config cfg( "today" );
132 132
133 cfg.setGroup( "Plugins" ); 133 cfg.setGroup( "Plugins" );
134 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' ); 134 m_excludeApplets = cfg.readListEntry( "ExcludeApplets", ',' );
135 m_allApplets = cfg.readListEntry( "AllApplets", ',' ); 135 m_allApplets = cfg.readListEntry( "AllApplets", ',' );
136 136
137 cfg.setGroup( "General" ); 137 cfg.setGroup( "General" );
138 m_iconSize = cfg.readNumEntry( "IconSize", 18 ); 138 m_iconSize = cfg.readNumEntry( "IconSize", 18 );
139 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) ); 139 setRefreshTimer( cfg.readNumEntry( "checkinterval", 15000 ) );
140} 140}
141 141
142 142
143/** 143/**
144 * Load the plugins 144 * Load the plugins
145 */ 145 */
146void Today::loadPlugins() { 146void Today::loadPlugins() {
147 147
148 // extra list for plugins that exclude themself from periodic refresh 148 // extra list for plugins that exclude themself from periodic refresh
149 QMap<QString, TodayPlugin> pluginListRefreshExclude; 149 QMap<QString, TodayPlugin> pluginListRefreshExclude;
150 150
151 QValueList<TodayPlugin>::Iterator tit; 151 QValueList<TodayPlugin>::Iterator tit;
152 if ( !pluginList.isEmpty() ) { 152 if ( !pluginList.isEmpty() ) {
153 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) { 153 for ( tit = pluginList.begin(); tit != pluginList.end(); ++tit ) {
154 if ( (*tit).excludeRefresh ) { 154 if ( (*tit).excludeRefresh ) {
155 pluginListRefreshExclude.insert( (*tit).name , (*tit) ); 155 pluginListRefreshExclude.insert( (*tit).name , (*tit) );
156 qDebug( "Found an plugin that does not want refresh feature" ); 156 qDebug( "Found an plugin that does not want refresh feature" );
157 } else { 157 } else {
158 (*tit).library->unload(); 158 (*tit).library->unload();
159 delete (*tit).library; 159 delete (*tit).library;
160 } 160 }
161 } 161 }
162 pluginList.clear(); 162 pluginList.clear();
163 } 163 }
164 164
165 QString path = QPEApplication::qpeDir() + "/plugins/today"; 165 QString path = QPEApplication::qpeDir() + "/plugins/today";
166 QDir dir( path, "lib*.so" ); 166 QDir dir( path, "lib*.so" );
167 167
168 QStringList list = dir.entryList(); 168 QStringList list = dir.entryList();
169 QStringList::Iterator it; 169 QStringList::Iterator it;
170 170
171 QMap<QString, TodayPlugin> tempList; 171 QMap<QString, TodayPlugin> tempList;
172 172
173 for ( it = list.begin(); it != list.end(); ++it ) { 173 for ( it = list.begin(); it != list.end(); ++it ) {
174 //TodayPluginInterface *iface = 0; 174 //TodayPluginInterface *iface = 0;
175 QInterfacePtr<TodayPluginInterface> iface; 175 QInterfacePtr<TodayPluginInterface> iface;
176 QLibrary *lib = new QLibrary( path + "/" + *it ); 176 QLibrary *lib = new QLibrary( path + "/" + *it );
177 177
178 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() ); 178 qDebug( "querying: %s", QString( path + "/" + *it ).latin1() );
179 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) { 179 if ( lib->queryInterface( IID_TodayPluginInterface, (QUnknownInterface**)&iface ) == QS_OK ) {
180 qDebug( "loading: %s", QString( path + "/" + *it ).latin1() ); 180 qDebug( "loading: %s", QString( path + "/" + *it ).latin1() );
181 qDebug( QString(*it) ); 181 qDebug( QString(*it) );
182 182
183 // If plugin is exludes from refresh, get it in the list again here. 183 // If plugin is exludes from refresh, get it in the list again here.
184 184
185 if ( pluginListRefreshExclude.contains( (*it) ) ) { 185 if ( pluginListRefreshExclude.contains( (*it) ) ) {
186 // if its not in allApplets list, add it to a layout 186 // if its not in allApplets list, add it to a layout
187 if ( !m_allApplets.contains( pluginListRefreshExclude[(*it)].name ) ) { 187 if ( !m_allApplets.contains( pluginListRefreshExclude[(*it)].name ) ) {
188 qDebug( "NUGASDA" );
189 layout->addWidget( pluginListRefreshExclude[(*it)].guiBox ); 188 layout->addWidget( pluginListRefreshExclude[(*it)].guiBox );
190 pluginList.append( pluginListRefreshExclude[(*it)] ); 189 pluginList.append( pluginListRefreshExclude[(*it)] );
191 } else { 190 } else {
192 tempList.insert( pluginListRefreshExclude[(*it)].name, pluginListRefreshExclude[(*it)] ); 191 tempList.insert( pluginListRefreshExclude[(*it)].name, pluginListRefreshExclude[(*it)] );
193 qDebug( "TEST2 " + pluginListRefreshExclude[(*it)].name );
194 } 192 }
195 } else { 193 } else {
196 194
197 TodayPlugin plugin; 195 TodayPlugin plugin;
198 plugin.library = lib; 196 plugin.library = lib;
199 plugin.iface = iface; 197 plugin.iface = iface;
200 plugin.name = QString(*it); 198 plugin.name = QString(*it);
201 199
202 // find out if plugins should be shown 200 // find out if plugins should be shown
203 if ( m_excludeApplets.grep( *it ).isEmpty() ) { 201 if ( m_excludeApplets.grep( *it ).isEmpty() ) {
204 plugin.active = true; 202 plugin.active = true;
205 } else { 203 } else {
206 plugin.active = false; 204 plugin.active = false;
207 } 205 }
208 206
209 plugin.guiPart = plugin.iface->guiPart(); 207 plugin.guiPart = plugin.iface->guiPart();
210 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh(); 208 plugin.excludeRefresh = plugin.guiPart->excludeFromRefresh();
211 209
212 // package the whole thing into a qwidget so it can be shown and hidden 210 // package the whole thing into a qwidget so it can be shown and hidden
213 plugin.guiBox = new QWidget( this ); 211 plugin.guiBox = new QWidget( this );
214 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox ); 212 QHBoxLayout *boxLayout = new QHBoxLayout( plugin.guiBox );
215 QPixmap plugPix; 213 QPixmap plugPix;
216 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 ); 214 plugPix.convertFromImage( Resource::loadImage( plugin.guiPart->pixmapNameWidget() ).smoothScale( m_iconSize, m_iconSize ), 0 );
217 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox ); 215 OClickableLabel* plugIcon = new OClickableLabel( plugin.guiBox );
218 plugIcon->setPixmap( plugPix ); 216 plugIcon->setPixmap( plugPix );
219 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") ); 217 QWhatsThis::add( plugIcon, tr("Click here to launch the associated app") );
220 plugIcon->setName( plugin.guiPart->appName() ); 218 plugIcon->setName( plugin.guiPart->appName() );
221 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) ); 219 connect( plugIcon, SIGNAL( clicked() ), this, SLOT( startApplication() ) );
222 // a scrollview for each plugin 220 // a scrollview for each plugin
223 QScrollView* sv = new QScrollView( plugin.guiBox ); 221 QScrollView* sv = new QScrollView( plugin.guiBox );
224 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() ); 222 QWidget *plugWidget = plugin.guiPart->widget( sv->viewport() );
225 // not sure if that is good .-) 223 // not sure if that is good .-)
226 sv->setMinimumHeight( 10 ); 224 sv->setMinimumHeight( 10 );
227 sv->setResizePolicy( QScrollView::AutoOneFit ); 225 sv->setResizePolicy( QScrollView::AutoOneFit );
228 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 226 sv->setHScrollBarMode( QScrollView::AlwaysOff );
229 sv->setFrameShape( QFrame::NoFrame ); 227 sv->setFrameShape( QFrame::NoFrame );
230 sv->addChild( plugWidget ); 228 sv->addChild( plugWidget );
231 // make sure the icon is on the top alligned 229 // make sure the icon is on the top alligned
232 boxLayout->addWidget( plugIcon, 0, AlignTop ); 230 boxLayout->addWidget( plugIcon, 0, AlignTop );
233 boxLayout->addWidget( sv, 0, AlignTop ); 231 boxLayout->addWidget( sv, 0, AlignTop );
234 boxLayout->setStretchFactor( plugIcon, 1 ); 232 boxLayout->setStretchFactor( plugIcon, 1 );
235 boxLayout->setStretchFactor( sv, 9 ); 233 boxLayout->setStretchFactor( sv, 9 );
236 // "prebuffer" it in one more list, to get the sorting done 234 // "prebuffer" it in one more list, to get the sorting done
237 tempList.insert( plugin.name, plugin ); 235 tempList.insert( plugin.name, plugin );
238 236
239 // on first start the list is off course empty 237 // on first start the list is off course empty
240 if ( m_allApplets.isEmpty() ) { 238 if ( m_allApplets.isEmpty() ) {
241 layout->addWidget( plugin.guiBox ); 239 layout->addWidget( plugin.guiBox );
242 pluginList.append( plugin ); 240 pluginList.append( plugin );
243 } 241 }
244 242
245 // if plugin is not yet in the list, add it to the layout too 243 // if plugin is not yet in the list, add it to the layout too
246 else if ( !m_allApplets.contains( plugin.name ) ) { 244 else if ( !m_allApplets.contains( plugin.name ) ) {
247 layout->addWidget( plugin.guiBox ); 245 layout->addWidget( plugin.guiBox );
248 pluginList.append( plugin ); 246 pluginList.append( plugin );
249 } 247 }
250 } 248 }
251 } else { 249 } else {
252 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() ); 250 qDebug( "could not recognize %s", QString( path + "/" + *it ).latin1() );
253 delete lib; 251 delete lib;
254 } 252 }
255 } 253 }
256 254
257 if ( !m_allApplets.isEmpty() ) { 255 if ( !m_allApplets.isEmpty() ) {
@@ -294,107 +292,97 @@ void Today::draw() {
294 plugin.guiBox->hide(); 292 plugin.guiBox->hide();
295 } 293 }
296 count++; 294 count++;
297 } 295 }
298 296
299 if ( count == 0 ) { 297 if ( count == 0 ) {
300 QLabel *noPluginsActive = new QLabel( this ); 298 QLabel *noPluginsActive = new QLabel( this );
301 noPluginsActive->setText( tr( "No plugins activated" ) ); 299 noPluginsActive->setText( tr( "No plugins activated" ) );
302 layout->addWidget( noPluginsActive ); 300 layout->addWidget( noPluginsActive );
303 } 301 }
304 layout->addStretch(0); 302 layout->addStretch(0);
305} 303}
306 304
307 305
308/** 306/**
309 * The method for the configuration dialog. 307 * The method for the configuration dialog.
310 */ 308 */
311void Today::startConfig() { 309void Today::startConfig() {
312 310
313 // disconnect timer to prevent problems while being on config dialog 311 // disconnect timer to prevent problems while being on config dialog
314 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 312 disconnect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
315 313
316 TodayConfig conf( this, "dialog", true ); 314 TodayConfig conf( this, "dialog", true );
317 315
318 TodayPlugin plugin; 316 TodayPlugin plugin;
319 QList<TodayConfigWidget> configWidgetList; 317 QList<TodayConfigWidget> configWidgetList;
320 318
321 for ( int i = pluginList.count() - 1 ; i >= 0; i-- ) { 319 for ( int i = pluginList.count() - 1 ; i >= 0; i-- ) {
322 plugin = pluginList[i]; 320 plugin = pluginList[i];
323 321
324 // load the config widgets in the tabs 322 // load the config widgets in the tabs
325 if ( plugin.guiPart->configWidget( this ) != 0l ) { 323 if ( plugin.guiPart->configWidget( this ) != 0l ) {
326 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 ); 324 TodayConfigWidget* widget = plugin.guiPart->configWidget( conf.TabWidget3 );
327 configWidgetList.append( widget ); 325 configWidgetList.append( widget );
328 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig() 326 conf.TabWidget3->addTab( widget, plugin.guiPart->pixmapNameConfig()
329 , plugin.guiPart->appName() ); 327 , plugin.guiPart->appName() );
330 } 328 }
331 // set the order/activate tab 329 // set the order/activate tab
332 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(), 330 conf.pluginManagement( plugin.name, plugin.guiPart->pluginName(),
333 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) ); 331 Resource::loadPixmap( plugin.guiPart->pixmapNameWidget() ) );
334 } 332 }
335 333
336 if ( conf.exec() == QDialog::Accepted ) { 334 if ( conf.exec() == QDialog::Accepted ) {
337 conf.writeConfig(); 335 conf.writeConfig();
338 TodayConfigWidget *confWidget; 336 TodayConfigWidget *confWidget;
339 for ( confWidget = configWidgetList.first(); confWidget != 0; 337 for ( confWidget = configWidgetList.first(); confWidget != 0;
340 confWidget = configWidgetList.next() ) { 338 confWidget = configWidgetList.next() ) {
341 confWidget->writeConfig(); 339 confWidget->writeConfig();
342 } 340 }
343 refresh(); 341 refresh();
344 } else { 342 } else {
345 // since refresh is not called in that case , reconnect the signal 343 // since refresh is not called in that case , reconnect the signal
346 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 344 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
347 } 345 }
348} 346}
349 347
350 348
351/** 349/**
352 * Refresh for the view. Reload all applets 350 * Refresh for the view. Reload all applets
353 * 351 *
354 */ 352 */
355void Today::refresh() { 353void Today::refresh() {
356 init(); 354 init();
357 355
358 qDebug(" refresh "); 356 // qDebug(" refresh ");
359 // set the date in top label 357 // set the date in top label
360 QDate date = QDate::currentDate(); 358 QDate date = QDate::currentDate();
361 QString time = ( tr( date.toString() ) ); 359 QString time = ( tr( date.toString() ) );
362 360
363 DateLabel->setText( QString( "<font color=#FFFFFF>" + time + "</font>" ) ); 361 DateLabel->setText( QString( "<font color=#FFFFFF>" + time + "</font>" ) );
364 362
365 if ( layout ) { 363 if ( layout ) {
366 delete layout; 364 delete layout;
367 } 365 }
368 layout = new QVBoxLayout( this ); 366 layout = new QVBoxLayout( this );
369 layout->addWidget( Frame ); 367 layout->addWidget( Frame );
370 layout->addWidget( OwnerField ); 368 layout->addWidget( OwnerField );
371 369
372 loadPlugins(); 370 loadPlugins();
373 draw(); 371 draw();
374} 372}
375 373
376void Today::startAddressbook() {
377 QCopEnvelope e( "QPE/System", "execute(QString)" );
378 e << QString( "addressbook" );
379}
380
381
382void Today::startApplication() { 374void Today::startApplication() {
383 QCopEnvelope e( "QPE/System", "execute(QString)" ); 375 QCopEnvelope e( "QPE/System", "execute(QString)" );
384 e << QString( sender()->name() ); 376 e << QString( sender()->name() );
385} 377}
386 378
387/** 379/**
388 * launch addressbook (personal card) 380 * launch addressbook (personal card)
389 */ 381 */
390void Today::editCard() { 382void Today::editCard() {
391 startAddressbook(); 383 QCopEnvelope env( "QPE/Application/addressbook", "editPersonalAndClose()" );
392 while( !QCopChannel::isRegistered( "QPE/Addressbook" ) ) {
393 qApp->processEvents();
394 }
395 QCopEnvelope v( "QPE/Addressbook", "editPersonalAndClose()" );
396} 384}
397 385
398Today::~Today() { 386Today::~Today() {
399} 387}
400 388
diff --git a/core/pim/today/today.h b/core/pim/today/today.h
index 4485a0b..35b7ee3 100644
--- a/core/pim/today/today.h
+++ b/core/pim/today/today.h
@@ -1,77 +1,76 @@
1/* 1/*
2 * today.h 2 * today.h
3 * 3 *
4 * copyright : (c) 2002 by Maximilian Reiß 4 * copyright : (c) 2002 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#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();
49 void startApplication(); 48 void startApplication();
50 void editCard(); 49 void editCard();
51 void refresh(); 50 void refresh();
52 51
53private: 52private:
54 void init(); 53 void init();
55 void setOwnerField(); 54 void setOwnerField();
56 void setOwnerField(QString &string); 55 void setOwnerField(QString &string);
57 void loadPlugins(); 56 void loadPlugins();
58 void draw(); 57 void draw();
59 void setRefreshTimer( int ); 58 void setRefreshTimer( int );
60 59
61private slots: 60private slots:
62 void channelReceived(const QCString &msg, const QByteArray & data); 61 void channelReceived(const QCString &msg, const QByteArray & data);
63 62
64 private: 63 private:
65 TodayConfig *conf; 64 TodayConfig *conf;
66 QStringList m_excludeApplets; 65 QStringList m_excludeApplets;
67 QStringList m_allApplets; 66 QStringList m_allApplets;
68 67
69 QTimer *m_refreshTimer; 68 QTimer *m_refreshTimer;
70 69
71 bool m_refreshTimerEnabled; 70 bool m_refreshTimerEnabled;
72 int m_newStart; 71 int m_newStart;
73 int m_iconSize; 72 int m_iconSize;
74 int m_maxCharClip; 73 int m_maxCharClip;
75}; 74};
76 75
77#endif 76#endif