-rw-r--r-- | bin/kdepim/WhatsNew.txt | 1 | ||||
-rw-r--r-- | kaddressbook/viewmanager.cpp | 7 | ||||
-rw-r--r-- | kaddressbook/views/configuretableviewdialog.cpp | 2 |
3 files changed, 9 insertions, 1 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index 2e5cf50..18e94a7 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,27 +1,28 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 2.2.1 ************ | 3 | ********** VERSION 2.2.1 ************ |
4 | 4 | ||
5 | KO/Pi: | 5 | KO/Pi: |
6 | Fixed a problem displaying very long allday events in agenda view in single day mode. | 6 | Fixed a problem displaying very long allday events in agenda view in single day mode. |
7 | 7 | ||
8 | KA/Pi: | 8 | KA/Pi: |
9 | Added a config option to turn on asking before a contact is deleted. | 9 | Added a config option to turn on asking before a contact is deleted. |
10 | Fixed a problem with the default view and view selection at startup. | ||
10 | 11 | ||
11 | ********** VERSION 2.2.0 ************ | 12 | ********** VERSION 2.2.0 ************ |
12 | 13 | ||
13 | New stable release! | 14 | New stable release! |
14 | Fixed some minor usability problems. | 15 | Fixed some minor usability problems. |
15 | Added writing of next alarm to a file for usage on pdaXrom. | 16 | Added writing of next alarm to a file for usage on pdaXrom. |
16 | 17 | ||
17 | 18 | ||
18 | ************************************* | 19 | ************************************* |
19 | 20 | ||
20 | You can find the complete changelog | 21 | You can find the complete changelog |
21 | from version 1.7.7 to 2.2.0 | 22 | from version 1.7.7 to 2.2.0 |
22 | in the source package or on | 23 | in the source package or on |
23 | 24 | ||
24 | http://www.pi-sync.net/html/changelog.html | 25 | http://www.pi-sync.net/html/changelog.html |
25 | 26 | ||
26 | 27 | ||
27 | 28 | ||
diff --git a/kaddressbook/viewmanager.cpp b/kaddressbook/viewmanager.cpp index c738ad8..b5d9419 100644 --- a/kaddressbook/viewmanager.cpp +++ b/kaddressbook/viewmanager.cpp | |||
@@ -196,145 +196,152 @@ void ViewManager::setSelected( const QString &uid, bool selected ) | |||
196 | void ViewManager::setListSelected(QStringList list) | 196 | void ViewManager::setListSelected(QStringList list) |
197 | { | 197 | { |
198 | int i, count = list.count(); | 198 | int i, count = list.count(); |
199 | for ( i = 0; i < count;++i ) | 199 | for ( i = 0; i < count;++i ) |
200 | setSelected( list[i], true ); | 200 | setSelected( list[i], true ); |
201 | 201 | ||
202 | } | 202 | } |
203 | void ViewManager::unloadViews() | 203 | void ViewManager::unloadViews() |
204 | { | 204 | { |
205 | mViewDict.clear(); | 205 | mViewDict.clear(); |
206 | mActiveView = 0; | 206 | mActiveView = 0; |
207 | } | 207 | } |
208 | 208 | ||
209 | void ViewManager::selectView( const QString &name ) | 209 | void ViewManager::selectView( const QString &name ) |
210 | { | 210 | { |
211 | setActiveView( name ); | 211 | setActiveView( name ); |
212 | mCore->saveSettings(); | 212 | mCore->saveSettings(); |
213 | } | 213 | } |
214 | void ViewManager::setActiveView( const QString &name ) | 214 | void ViewManager::setActiveView( const QString &name ) |
215 | { | 215 | { |
216 | KAddressBookView *view = 0; | 216 | KAddressBookView *view = 0; |
217 | 217 | ||
218 | // Check that this isn't the same as the current active view | 218 | // Check that this isn't the same as the current active view |
219 | if ( mActiveView && ( mActiveView->caption() == name ) ) | 219 | if ( mActiveView && ( mActiveView->caption() == name ) ) |
220 | return; | 220 | return; |
221 | 221 | ||
222 | // At this point we know the view that should be active is not | 222 | // At this point we know the view that should be active is not |
223 | // currently active. We will try to find the new on in the list. If | 223 | // currently active. We will try to find the new on in the list. If |
224 | // we can't find it, it means it hasn't been instantiated, so we will | 224 | // we can't find it, it means it hasn't been instantiated, so we will |
225 | // create it on demand. | 225 | // create it on demand. |
226 | 226 | ||
227 | view = mViewDict.find( name ); | 227 | view = mViewDict.find( name ); |
228 | 228 | ||
229 | // Check if we found the view. If we didn't, then we need to create it | 229 | // Check if we found the view. If we didn't, then we need to create it |
230 | if ( view == 0 ) { | 230 | if ( view == 0 ) { |
231 | KConfig *config = mCore->config(); | 231 | KConfig *config = mCore->config(); |
232 | 232 | ||
233 | KConfigGroupSaver saver( config, name ); | 233 | KConfigGroupSaver saver( config, name ); |
234 | 234 | ||
235 | QString type = config->readEntry( "Type", "Table" ); | 235 | QString type = config->readEntry( "Type", "Table" ); |
236 | 236 | ||
237 | kdDebug(5720) << "ViewManager::setActiveView: creating view - " << name << endl; | 237 | kdDebug(5720) << "ViewManager::setActiveView: creating view - " << name << endl; |
238 | 238 | ||
239 | ViewFactory *factory = mViewFactoryDict.find( type ); | 239 | ViewFactory *factory = mViewFactoryDict.find( type ); |
240 | if ( factory ) | 240 | if ( factory ) |
241 | view = factory->view( mCore->addressBook(), mViewWidgetStack ); | 241 | view = factory->view( mCore->addressBook(), mViewWidgetStack ); |
242 | 242 | ||
243 | if ( view ) { | 243 | if ( view ) { |
244 | if ( !mViewNameList.contains( name ) ) { | ||
245 | mViewNameList.append( name ); | ||
246 | } | ||
244 | view->setCaption( name ); | 247 | view->setCaption( name ); |
245 | mViewDict.insert( name, view ); | 248 | mViewDict.insert( name, view ); |
246 | //US my version needs an int as second parameter to addWidget | 249 | //US my version needs an int as second parameter to addWidget |
247 | mViewWidgetStack->addWidget( view, -1 ); | 250 | mViewWidgetStack->addWidget( view, -1 ); |
248 | view->readConfig( config ); | 251 | view->readConfig( config ); |
249 | 252 | ||
250 | // The manager just relays the signals | 253 | // The manager just relays the signals |
251 | connect( view, SIGNAL( selected( const QString& ) ), | 254 | connect( view, SIGNAL( selected( const QString& ) ), |
252 | SIGNAL( selected( const QString & ) ) ); | 255 | SIGNAL( selected( const QString & ) ) ); |
253 | connect( view, SIGNAL( executed( const QString& ) ), | 256 | connect( view, SIGNAL( executed( const QString& ) ), |
254 | SIGNAL( executed( const QString& ) ) ); | 257 | SIGNAL( executed( const QString& ) ) ); |
255 | 258 | ||
256 | connect( view, SIGNAL( deleteRequest( ) ), | 259 | connect( view, SIGNAL( deleteRequest( ) ), |
257 | SIGNAL( deleteRequest( ) ) ); | 260 | SIGNAL( deleteRequest( ) ) ); |
258 | 261 | ||
259 | connect( view, SIGNAL( modified() ), SIGNAL( modified() ) ); | 262 | connect( view, SIGNAL( modified() ), SIGNAL( modified() ) ); |
260 | connect( view, SIGNAL( dropped( QDropEvent* ) ), | 263 | connect( view, SIGNAL( dropped( QDropEvent* ) ), |
261 | SLOT( dropped( QDropEvent* ) ) ); | 264 | SLOT( dropped( QDropEvent* ) ) ); |
262 | connect( view, SIGNAL( startDrag() ), SLOT( startDrag() ) ); | 265 | connect( view, SIGNAL( startDrag() ), SLOT( startDrag() ) ); |
263 | } | 266 | } |
264 | } | 267 | } |
265 | 268 | ||
266 | // If we found or created the view, raise it and refresh it | 269 | // If we found or created the view, raise it and refresh it |
267 | if ( view ) { | 270 | if ( view ) { |
268 | mActiveView = view; | 271 | mActiveView = view; |
269 | mViewWidgetStack->raiseWidget( view ); | 272 | mViewWidgetStack->raiseWidget( view ); |
270 | // Set the proper filter in the view. By setting the combo | 273 | // Set the proper filter in the view. By setting the combo |
271 | // box, the activated slot will be called, which will push | 274 | // box, the activated slot will be called, which will push |
272 | // the filter to the view and refresh it. | 275 | // the filter to the view and refresh it. |
273 | 276 | ||
274 | if ( view->defaultFilterType() == KAddressBookView::None ) { | 277 | if ( view->defaultFilterType() == KAddressBookView::None ) { |
275 | 278 | ||
276 | mActionSelectFilter->setCurrentItem( 0 ); | 279 | mActionSelectFilter->setCurrentItem( 0 ); |
277 | setActiveFilter( 0 ); | 280 | setActiveFilter( 0 ); |
278 | } else if ( view->defaultFilterType() == KAddressBookView::Active ) { | 281 | } else if ( view->defaultFilterType() == KAddressBookView::Active ) { |
279 | setActiveFilter( mActionSelectFilter->currentItem() ); | 282 | setActiveFilter( mActionSelectFilter->currentItem() ); |
280 | } else { | 283 | } else { |
281 | uint pos = filterPosition( view->defaultFilterName() ); | 284 | uint pos = filterPosition( view->defaultFilterName() ); |
282 | mActionSelectFilter->setCurrentItem( pos ); | 285 | mActionSelectFilter->setCurrentItem( pos ); |
283 | setActiveFilter( pos ); | 286 | setActiveFilter( pos ); |
284 | } | 287 | } |
285 | //US qDebug("ViewManager::setActiveView 6" ); | 288 | //US qDebug("ViewManager::setActiveView 6" ); |
286 | 289 | ||
287 | // Update the inc search widget to show the fields in the new active | 290 | // Update the inc search widget to show the fields in the new active |
288 | // view. | 291 | // view. |
289 | mCore->setSearchFields( mActiveView->fields() ); | 292 | mCore->setSearchFields( mActiveView->fields() ); |
290 | 293 | ||
291 | //US performance optimization. setActiveFilter calls also mActiveView->refresh() | 294 | //US performance optimization. setActiveFilter calls also mActiveView->refresh() |
292 | //US mActiveView->refresh(); | 295 | //US mActiveView->refresh(); |
296 | |||
297 | mActionSelectView->setItems( mViewNameList ); | ||
298 | mActionSelectView->setCurrentItem( mViewNameList.findIndex( mActiveView->caption() ) ); | ||
299 | |||
293 | } | 300 | } |
294 | else | 301 | else |
295 | { | 302 | { |
296 | qDebug("ViewManager::setActiveView: unable to find view" ); | 303 | qDebug("ViewManager::setActiveView: unable to find view" ); |
297 | } | 304 | } |
298 | } | 305 | } |
299 | 306 | ||
300 | //US added another method with no parameter, since my moc compiler does not support default parameters. | 307 | //US added another method with no parameter, since my moc compiler does not support default parameters. |
301 | void ViewManager::refreshView() | 308 | void ViewManager::refreshView() |
302 | { | 309 | { |
303 | refreshView( QString::null ); | 310 | refreshView( QString::null ); |
304 | } | 311 | } |
305 | 312 | ||
306 | void ViewManager::refreshView( const QString &uid ) | 313 | void ViewManager::refreshView( const QString &uid ) |
307 | { | 314 | { |
308 | if ( mActiveView ) | 315 | if ( mActiveView ) |
309 | mActiveView->refresh( uid ); | 316 | mActiveView->refresh( uid ); |
310 | } | 317 | } |
311 | 318 | ||
312 | void ViewManager::setFocusAV() | 319 | void ViewManager::setFocusAV() |
313 | { | 320 | { |
314 | if ( mActiveView ) | 321 | if ( mActiveView ) |
315 | mActiveView->setFocusAV(); | 322 | mActiveView->setFocusAV(); |
316 | } | 323 | } |
317 | void ViewManager::editView() | 324 | void ViewManager::editView() |
318 | { | 325 | { |
319 | if ( !mActiveView ) | 326 | if ( !mActiveView ) |
320 | return; | 327 | return; |
321 | 328 | ||
322 | ViewFactory *factory = mViewFactoryDict.find( mActiveView->type() ); | 329 | ViewFactory *factory = mViewFactoryDict.find( mActiveView->type() ); |
323 | ViewConfigureWidget *wdg = 0; | 330 | ViewConfigureWidget *wdg = 0; |
324 | ViewConfigureDialog* dlg = 0; | 331 | ViewConfigureDialog* dlg = 0; |
325 | if ( factory ) { | 332 | if ( factory ) { |
326 | // Save the filters so the dialog has the latest set | 333 | // Save the filters so the dialog has the latest set |
327 | Filter::save( mCore->config(), "Filter", mFilterList ); | 334 | Filter::save( mCore->config(), "Filter", mFilterList ); |
328 | dlg = new ViewConfigureDialog( 0, mActiveView->caption(), this, "conf_dlg" ); | 335 | dlg = new ViewConfigureDialog( 0, mActiveView->caption(), this, "conf_dlg" ); |
329 | wdg = factory->configureWidget( mCore->addressBook(), dlg,"conf_wid" ); | 336 | wdg = factory->configureWidget( mCore->addressBook(), dlg,"conf_wid" ); |
330 | } else { | 337 | } else { |
331 | qDebug("ViewManager::editView()::cannot find viewfactory "); | 338 | qDebug("ViewManager::editView()::cannot find viewfactory "); |
332 | return; | 339 | return; |
333 | } | 340 | } |
334 | if ( wdg ) { | 341 | if ( wdg ) { |
335 | dlg->setWidget( wdg ); | 342 | dlg->setWidget( wdg ); |
336 | 343 | ||
337 | #ifndef DESKTOP_VERSION | 344 | #ifndef DESKTOP_VERSION |
338 | //dlg.setMaximumSize( 640, 480 ); | 345 | //dlg.setMaximumSize( 640, 480 ); |
339 | //dlg->setGeometry( 40,40, 400, 300); | 346 | //dlg->setGeometry( 40,40, 400, 300); |
340 | dlg->showMaximized(); | 347 | dlg->showMaximized(); |
diff --git a/kaddressbook/views/configuretableviewdialog.cpp b/kaddressbook/views/configuretableviewdialog.cpp index 0e36abd..c329cd9 100644 --- a/kaddressbook/views/configuretableviewdialog.cpp +++ b/kaddressbook/views/configuretableviewdialog.cpp | |||
@@ -62,97 +62,97 @@ ConfigureTableViewWidget::ConfigureTableViewWidget( KABC::AddressBook *ab, | |||
62 | 62 | ||
63 | mPage = new LookAndFeelPage( page ); | 63 | mPage = new LookAndFeelPage( page ); |
64 | } | 64 | } |
65 | 65 | ||
66 | ConfigureTableViewWidget::~ConfigureTableViewWidget() | 66 | ConfigureTableViewWidget::~ConfigureTableViewWidget() |
67 | { | 67 | { |
68 | } | 68 | } |
69 | 69 | ||
70 | void ConfigureTableViewWidget::restoreSettings( KConfig *config ) | 70 | void ConfigureTableViewWidget::restoreSettings( KConfig *config ) |
71 | { | 71 | { |
72 | ViewConfigureWidget::restoreSettings( config ); | 72 | ViewConfigureWidget::restoreSettings( config ); |
73 | 73 | ||
74 | mPage->restoreSettings( config ); | 74 | mPage->restoreSettings( config ); |
75 | } | 75 | } |
76 | 76 | ||
77 | void ConfigureTableViewWidget::saveSettings( KConfig *config ) | 77 | void ConfigureTableViewWidget::saveSettings( KConfig *config ) |
78 | { | 78 | { |
79 | ViewConfigureWidget::saveSettings( config ); | 79 | ViewConfigureWidget::saveSettings( config ); |
80 | 80 | ||
81 | mPage->saveSettings( config ); | 81 | mPage->saveSettings( config ); |
82 | } | 82 | } |
83 | 83 | ||
84 | 84 | ||
85 | 85 | ||
86 | LookAndFeelPage::LookAndFeelPage(QWidget *parent, const char *name) | 86 | LookAndFeelPage::LookAndFeelPage(QWidget *parent, const char *name) |
87 | : QVBox(parent, name) | 87 | : QVBox(parent, name) |
88 | { | 88 | { |
89 | initGUI(); | 89 | initGUI(); |
90 | 90 | ||
91 | // Set initial state | 91 | // Set initial state |
92 | enableBackgroundToggled(mBackgroundBox->isChecked()); | 92 | enableBackgroundToggled(mBackgroundBox->isChecked()); |
93 | } | 93 | } |
94 | 94 | ||
95 | void LookAndFeelPage::restoreSettings( KConfig *config ) | 95 | void LookAndFeelPage::restoreSettings( KConfig *config ) |
96 | { | 96 | { |
97 | mAlternateButton->setChecked(config->readBoolEntry("ABackground", true)); | 97 | mAlternateButton->setChecked(config->readBoolEntry("ABackground", true)); |
98 | mLineButton->setChecked(config->readBoolEntry("SingleLine", false)); | 98 | mLineButton->setChecked(config->readBoolEntry("SingleLine", false)); |
99 | mToolTipBox->setChecked(config->readBoolEntry("ToolTips", true)); | 99 | mToolTipBox->setChecked(config->readBoolEntry("ToolTips", true)); |
100 | 100 | ||
101 | if (!mAlternateButton->isChecked() & !mLineButton->isChecked()) | 101 | if (!mAlternateButton->isChecked() & !mLineButton->isChecked()) |
102 | mNoneButton->setChecked(true); | 102 | mNoneButton->setChecked(true); |
103 | 103 | ||
104 | mBackgroundBox->setChecked(config->readBoolEntry("Background", false)); | 104 | mBackgroundBox->setChecked(config->readBoolEntry("Background", false)); |
105 | mBackgroundName->lineEdit()->setText(config->readEntry("BackgroundName")); | 105 | mBackgroundName->lineEdit()->setText(config->readEntry("BackgroundName")); |
106 | 106 | ||
107 | // colors | 107 | // colors |
108 | cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) ); | 108 | cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) ); |
109 | QColor c; | 109 | QColor c; |
110 | qDebug("LookAndFeelPage::restoreSettings make base color configurable"); | 110 | //qDebug("LookAndFeelPage::restoreSettings make base color configurable"); |
111 | 111 | ||
112 | #ifndef KAB_EMBEDDED | 112 | #ifndef KAB_EMBEDDED |
113 | c = KGlobalSettings::baseColor(); | 113 | c = KGlobalSettings::baseColor(); |
114 | #else //KAB_EMBEDDED | 114 | #else //KAB_EMBEDDED |
115 | c = QColor(0,0,0); | 115 | c = QColor(0,0,0); |
116 | #endif //KAB_EMBEDDED | 116 | #endif //KAB_EMBEDDED |
117 | 117 | ||
118 | c = colorGroup().background(); | 118 | c = colorGroup().background(); |
119 | lbColors->insertItem( new ColorListItem( i18n("Background Color"), | 119 | lbColors->insertItem( new ColorListItem( i18n("Background Color"), |
120 | config->readColorEntry( "BackgroundColor", &c ) ) ); | 120 | config->readColorEntry( "BackgroundColor", &c ) ) ); |
121 | c = colorGroup().foreground(); | 121 | c = colorGroup().foreground(); |
122 | lbColors->insertItem( new ColorListItem( i18n("Text Color"), | 122 | lbColors->insertItem( new ColorListItem( i18n("Text Color"), |
123 | config->readColorEntry( "TextColor", &c ) ) ); | 123 | config->readColorEntry( "TextColor", &c ) ) ); |
124 | c = colorGroup().button(); | 124 | c = colorGroup().button(); |
125 | lbColors->insertItem( new ColorListItem( i18n("Header Background Color"), | 125 | lbColors->insertItem( new ColorListItem( i18n("Header Background Color"), |
126 | config->readColorEntry( "HeaderBackgroundColor", &c ) ) ); | 126 | config->readColorEntry( "HeaderBackgroundColor", &c ) ) ); |
127 | c = colorGroup().buttonText(); | 127 | c = colorGroup().buttonText(); |
128 | lbColors->insertItem( new ColorListItem( i18n("Header Text Color"), | 128 | lbColors->insertItem( new ColorListItem( i18n("Header Text Color"), |
129 | config->readColorEntry( "HeaderTextColor", &c ) ) ); | 129 | config->readColorEntry( "HeaderTextColor", &c ) ) ); |
130 | c = colorGroup().highlight(); | 130 | c = colorGroup().highlight(); |
131 | lbColors->insertItem( new ColorListItem( i18n("Highlight Color"), | 131 | lbColors->insertItem( new ColorListItem( i18n("Highlight Color"), |
132 | config->readColorEntry( "HighlightColor", &c ) ) ); | 132 | config->readColorEntry( "HighlightColor", &c ) ) ); |
133 | c = colorGroup().highlightedText(); | 133 | c = colorGroup().highlightedText(); |
134 | lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"), | 134 | lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"), |
135 | config->readColorEntry( "HighlightedTextColor", &c ) ) ); | 135 | config->readColorEntry( "HighlightedTextColor", &c ) ) ); |
136 | c = colorGroup().background(); | 136 | c = colorGroup().background(); |
137 | lbColors->insertItem( new ColorListItem( i18n("Alternating Background Color"), | 137 | lbColors->insertItem( new ColorListItem( i18n("Alternating Background Color"), |
138 | config->readColorEntry( "AlternatingBackgroundColor", &c ) ) ); | 138 | config->readColorEntry( "AlternatingBackgroundColor", &c ) ) ); |
139 | 139 | ||
140 | enableColors(); | 140 | enableColors(); |
141 | 141 | ||
142 | // fonts | 142 | // fonts |
143 | QFont fnt = font(); | 143 | QFont fnt = font(); |
144 | updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont ); | 144 | updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont ); |
145 | fnt.setBold( true ); | 145 | fnt.setBold( true ); |
146 | updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont ); | 146 | updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont ); |
147 | cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) ); | 147 | cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) ); |
148 | enableFonts(); | 148 | enableFonts(); |
149 | 149 | ||
150 | } | 150 | } |
151 | 151 | ||
152 | void LookAndFeelPage::saveSettings( KConfig *config ) | 152 | void LookAndFeelPage::saveSettings( KConfig *config ) |
153 | { | 153 | { |
154 | config->writeEntry("ABackground", mAlternateButton->isChecked()); | 154 | config->writeEntry("ABackground", mAlternateButton->isChecked()); |
155 | config->writeEntry("SingleLine", mLineButton->isChecked()); | 155 | config->writeEntry("SingleLine", mLineButton->isChecked()); |
156 | config->writeEntry("ToolTips", mToolTipBox->isChecked()); | 156 | config->writeEntry("ToolTips", mToolTipBox->isChecked()); |
157 | config->writeEntry("Background", mBackgroundBox->isChecked()); | 157 | config->writeEntry("Background", mBackgroundBox->isChecked()); |
158 | config->writeEntry("BackgroundName", mBackgroundName->lineEdit()->text()); | 158 | config->writeEntry("BackgroundName", mBackgroundName->lineEdit()->text()); |