author | harlekin <harlekin> | 2003-03-30 22:44:10 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2003-03-30 22:44:10 (UTC) |
commit | a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d (patch) (unidiff) | |
tree | b3826416037c7650c3cc0fd9f0038ed705f3cc1c | |
parent | 0b6d158a2a2b52d83ad4b1046ce9dbffff2190e6 (diff) | |
download | opie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.zip opie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.tar.gz opie-a014a9f0d0fe82dc5daf2b37ad4458cc5722db0d.tar.bz2 |
layout fix, closes bug #761
-rw-r--r-- | core/pim/today/today.cpp | 10 | ||||
-rw-r--r-- | core/pim/today/todaybase.cpp | 1 |
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 | ||
37 | struct TodayPlugin { | 37 | struct 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 | ||
49 | static QValueList<TodayPlugin> pluginList; | 49 | static QValueList<TodayPlugin> pluginList; |
50 | 50 | ||
51 | Today::Today( QWidget* parent, const char* name, WFlags fl ) | 51 | Today::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 | */ |
77 | void Today::channelReceived( const QCString &msg, const QByteArray & data ) { | 77 | void 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 | ||
86 | void Today::setRefreshTimer( int interval ) { | 86 | void 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 | */ |
101 | void Today::setOwnerField() { | 101 | void 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 | */ |
115 | void Today::setOwnerField( QString &message ) { | 115 | void 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 | */ |
124 | void Today::init() { | 124 | void 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 | */ |
161 | void Today::loadPlugins() { | 161 | void 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 | */ |
285 | void Today::draw() { | 285 | void 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 | */ |
321 | void Today::startConfig() { | 321 | void 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 | */ |
367 | void Today::refresh() { | 367 | void 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 | ||
380 | void Today::startApplication() { | 382 | void 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 | */ |
388 | void Today::editCard() { | 390 | void Today::editCard() { |
389 | QCopEnvelope env( "QPE/Application/addressbook", "editPersonalAndClose()" ); | 391 | QCopEnvelope env( "QPE/Application/addressbook", "editPersonalAndClose()" ); |
390 | } | 392 | } |
391 | 393 | ||
392 | Today::~Today() { | 394 | Today::~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 | ||
26 | TodayBase::TodayBase( QWidget* parent, const char* name, WFlags ) | 26 | TodayBase::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 | */ |
107 | TodayBase::~TodayBase() { | 106 | TodayBase::~TodayBase() { |
108 | } | 107 | } |
109 | 108 | ||