summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2005-04-02 12:16:34 (UTC)
committer zautrix <zautrix>2005-04-02 12:16:34 (UTC)
commit997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe (patch) (unidiff)
treef788b37459574b5cea0d2ab874882c6a396c240d
parente0d51120d2f0c178115746e0c1357af40f95bc77 (diff)
downloadkdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.zip
kdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.tar.gz
kdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.tar.bz2
more fixes
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--kaddressbook/kabcore.cpp5
-rw-r--r--kaddressbook/viewmanager.cpp2
-rw-r--r--kaddressbook/views/colorlistbox.cpp7
-rw-r--r--kaddressbook/views/colorlistbox.h1
-rw-r--r--kaddressbook/views/configurecardviewdialog.cpp4
-rw-r--r--kaddressbook/views/configuretableviewdialog.cpp6
-rw-r--r--korganizer/koagenda.cpp57
-rw-r--r--korganizer/koagenda.h4
-rw-r--r--korganizer/koagendaview.cpp18
-rw-r--r--korganizer/koagendaview.h4
-rw-r--r--korganizer/kotodoview.cpp49
-rw-r--r--microkde/kcolordialog.cpp1
-rw-r--r--microkde/kdeui/ktoolbar.cpp2
13 files changed, 120 insertions, 40 deletions
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp
index 5ef61b1..e34951a 100644
--- a/kaddressbook/kabcore.cpp
+++ b/kaddressbook/kabcore.cpp
@@ -1,3395 +1,3396 @@
1/* 1/*
2 This file is part of KAddressbook. 2 This file is part of KAddressbook.
3 Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> 3 Copyright (c) 2003 Tobias Koenig <tokoe@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 Async a special exception, permission is given to link this program 19 Async a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24/*s 24/*s
25Enhanced Version of the file for platform independent KDE tools. 25Enhanced Version of the file for platform independent KDE tools.
26Copyright (c) 2004 Ulf Schenk 26Copyright (c) 2004 Ulf Schenk
27 27
28$Id$ 28$Id$
29*/ 29*/
30 30
31#include "kabcore.h" 31#include "kabcore.h"
32 32
33#include <stdaddressbook.h> 33#include <stdaddressbook.h>
34#include <klocale.h> 34#include <klocale.h>
35#include <kfiledialog.h> 35#include <kfiledialog.h>
36#include <qtimer.h> 36#include <qtimer.h>
37#include <qlabel.h> 37#include <qlabel.h>
38#include <qregexp.h> 38#include <qregexp.h>
39#include <qlineedit.h> 39#include <qlineedit.h>
40#include <qcheckbox.h> 40#include <qcheckbox.h>
41#include <qpushbutton.h> 41#include <qpushbutton.h>
42#include <qprogressbar.h> 42#include <qprogressbar.h>
43#include <libkdepim/phoneaccess.h> 43#include <libkdepim/phoneaccess.h>
44 44
45#ifndef KAB_EMBEDDED 45#ifndef KAB_EMBEDDED
46#include <qclipboard.h> 46#include <qclipboard.h>
47#include <qdir.h> 47#include <qdir.h>
48#include <qfile.h> 48#include <qfile.h>
49#include <qapplicaton.h> 49#include <qapplicaton.h>
50#include <qprogressbar.h> 50#include <qprogressbar.h>
51#include <qlayout.h> 51#include <qlayout.h>
52#include <qregexp.h> 52#include <qregexp.h>
53#include <qvbox.h> 53#include <qvbox.h>
54#include <kabc/addresseelist.h> 54#include <kabc/addresseelist.h>
55#include <kabc/errorhandler.h> 55#include <kabc/errorhandler.h>
56#include <kabc/resource.h> 56#include <kabc/resource.h>
57#include <kabc/vcardconverter.h> 57#include <kabc/vcardconverter.h>
58#include <kapplication.h> 58#include <kapplication.h>
59#include <kactionclasses.h> 59#include <kactionclasses.h>
60#include <kcmultidialog.h> 60#include <kcmultidialog.h>
61#include <kdebug.h> 61#include <kdebug.h>
62#include <kdeversion.h> 62#include <kdeversion.h>
63#include <kkeydialog.h> 63#include <kkeydialog.h>
64#include <kmessagebox.h> 64#include <kmessagebox.h>
65#include <kprinter.h> 65#include <kprinter.h>
66#include <kprotocolinfo.h> 66#include <kprotocolinfo.h>
67#include <kresources/selectdialog.h> 67#include <kresources/selectdialog.h>
68#include <kstandarddirs.h> 68#include <kstandarddirs.h>
69#include <ktempfile.h> 69#include <ktempfile.h>
70#include <kxmlguiclient.h> 70#include <kxmlguiclient.h>
71#include <kaboutdata.h> 71#include <kaboutdata.h>
72#include <libkdepim/categoryselectdialog.h> 72#include <libkdepim/categoryselectdialog.h>
73 73
74#include "addresseeutil.h" 74#include "addresseeutil.h"
75#include "addresseeeditordialog.h" 75#include "addresseeeditordialog.h"
76#include "extensionmanager.h" 76#include "extensionmanager.h"
77#include "kstdaction.h" 77#include "kstdaction.h"
78#include "kaddressbookservice.h" 78#include "kaddressbookservice.h"
79#include "ldapsearchdialog.h" 79#include "ldapsearchdialog.h"
80#include "printing/printingwizard.h" 80#include "printing/printingwizard.h"
81#else // KAB_EMBEDDED 81#else // KAB_EMBEDDED
82 82
83#include <kapplication.h> 83#include <kapplication.h>
84#include "KDGanttMinimizeSplitter.h" 84#include "KDGanttMinimizeSplitter.h"
85#include "kaddressbookmain.h" 85#include "kaddressbookmain.h"
86#include "kactioncollection.h" 86#include "kactioncollection.h"
87#include "addresseedialog.h" 87#include "addresseedialog.h"
88//US 88//US
89#include <addresseeview.h> 89#include <addresseeview.h>
90 90
91#include <qapp.h> 91#include <qapp.h>
92#include <qmenubar.h> 92#include <qmenubar.h>
93//#include <qtoolbar.h> 93//#include <qtoolbar.h>
94#include <qmessagebox.h> 94#include <qmessagebox.h>
95#include <kdebug.h> 95#include <kdebug.h>
96#include <kiconloader.h> // needed for SmallIcon 96#include <kiconloader.h> // needed for SmallIcon
97#include <kresources/kcmkresources.h> 97#include <kresources/kcmkresources.h>
98#include <ktoolbar.h> 98#include <ktoolbar.h>
99 99
100 100
101//#include <qlabel.h> 101//#include <qlabel.h>
102 102
103 103
104#ifndef DESKTOP_VERSION 104#ifndef DESKTOP_VERSION
105#include <qpe/ir.h> 105#include <qpe/ir.h>
106#include <qpe/qpemenubar.h> 106#include <qpe/qpemenubar.h>
107#include <qtopia/qcopenvelope_qws.h> 107#include <qtopia/qcopenvelope_qws.h>
108#else 108#else
109 109
110#include <qmenubar.h> 110#include <qmenubar.h>
111#endif 111#endif
112 112
113#endif // KAB_EMBEDDED 113#endif // KAB_EMBEDDED
114#include "kcmconfigs/kcmkabconfig.h" 114#include "kcmconfigs/kcmkabconfig.h"
115#include "kcmconfigs/kcmkdepimconfig.h" 115#include "kcmconfigs/kcmkdepimconfig.h"
116#include "kpimglobalprefs.h" 116#include "kpimglobalprefs.h"
117#include "externalapphandler.h" 117#include "externalapphandler.h"
118#include "xxportselectdialog.h" 118#include "xxportselectdialog.h"
119 119
120 120
121#include <kresources/selectdialog.h> 121#include <kresources/selectdialog.h>
122#include <kmessagebox.h> 122#include <kmessagebox.h>
123 123
124#include <picture.h> 124#include <picture.h>
125#include <resource.h> 125#include <resource.h>
126 126
127//US#include <qsplitter.h> 127//US#include <qsplitter.h>
128#include <qmap.h> 128#include <qmap.h>
129#include <qdir.h> 129#include <qdir.h>
130#include <qfile.h> 130#include <qfile.h>
131#include <qvbox.h> 131#include <qvbox.h>
132#include <qlayout.h> 132#include <qlayout.h>
133#include <qclipboard.h> 133#include <qclipboard.h>
134#include <qtextstream.h> 134#include <qtextstream.h>
135#include <qradiobutton.h> 135#include <qradiobutton.h>
136#include <qbuttongroup.h> 136#include <qbuttongroup.h>
137 137
138#include <libkdepim/categoryselectdialog.h> 138#include <libkdepim/categoryselectdialog.h>
139#include <libkdepim/categoryeditdialog.h> 139#include <libkdepim/categoryeditdialog.h>
140#include <kabc/vcardconverter.h> 140#include <kabc/vcardconverter.h>
141 141
142 142
143#include "addresseeutil.h" 143#include "addresseeutil.h"
144#include "undocmds.h" 144#include "undocmds.h"
145#include "addresseeeditordialog.h" 145#include "addresseeeditordialog.h"
146#include "viewmanager.h" 146#include "viewmanager.h"
147#include "details/detailsviewcontainer.h" 147#include "details/detailsviewcontainer.h"
148#include "kabprefs.h" 148#include "kabprefs.h"
149#include "xxportmanager.h" 149#include "xxportmanager.h"
150#include "incsearchwidget.h" 150#include "incsearchwidget.h"
151#include "jumpbuttonbar.h" 151#include "jumpbuttonbar.h"
152#include "extensionmanager.h" 152#include "extensionmanager.h"
153#include "addresseeconfig.h" 153#include "addresseeconfig.h"
154#include "nameeditdialog.h" 154#include "nameeditdialog.h"
155#include <kcmultidialog.h> 155#include <kcmultidialog.h>
156 156
157#ifdef _WIN32_ 157#ifdef _WIN32_
158#ifdef _OL_IMPORT_ 158#ifdef _OL_IMPORT_
159#include "kaimportoldialog.h" 159#include "kaimportoldialog.h"
160#endif 160#endif
161#else 161#else
162#include <unistd.h> 162#include <unistd.h>
163#endif 163#endif
164// sync includes 164// sync includes
165#include <libkdepim/ksyncprofile.h> 165#include <libkdepim/ksyncprofile.h>
166#include <libkdepim/ksyncprefsdialog.h> 166#include <libkdepim/ksyncprefsdialog.h>
167 167
168 168
169class KABCatPrefs : public QDialog 169class KABCatPrefs : public QDialog
170{ 170{
171 public: 171 public:
172 KABCatPrefs( QWidget *parent=0, const char *name=0 ) : 172 KABCatPrefs( QWidget *parent=0, const char *name=0 ) :
173 QDialog( parent, name, true ) 173 QDialog( parent, name, true )
174 { 174 {
175 setCaption( i18n("Manage new Categories") ); 175 setCaption( i18n("Manage new Categories") );
176 QVBoxLayout* lay = new QVBoxLayout( this ); 176 QVBoxLayout* lay = new QVBoxLayout( this );
177 lay->setSpacing( 3 ); 177 lay->setSpacing( 3 );
178 lay->setMargin( 3 ); 178 lay->setMargin( 3 );
179 QLabel * lab = new QLabel( i18n("After importing/loading/syncing\nthere may be new categories in\naddressees\nwhich are not in the category list.\nPlease choose what to do:\n "), this ); 179 QLabel * lab = new QLabel( i18n("After importing/loading/syncing\nthere may be new categories in\naddressees\nwhich are not in the category list.\nPlease choose what to do:\n "), this );
180 lay->addWidget( lab ); 180 lay->addWidget( lab );
181 QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("New categories not in list:"), this ); 181 QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("New categories not in list:"), this );
182 lay->addWidget( format ); 182 lay->addWidget( format );
183 format->setExclusive ( true ) ; 183 format->setExclusive ( true ) ;
184 addCatBut = new QRadioButton(i18n("Add to category list"), format ); 184 addCatBut = new QRadioButton(i18n("Add to category list"), format );
185 new QRadioButton(i18n("Remove from addressees"), format ); 185 new QRadioButton(i18n("Remove from addressees"), format );
186 addCatBut->setChecked( true ); 186 addCatBut->setChecked( true );
187 QPushButton * ok = new QPushButton( i18n("OK"), this ); 187 QPushButton * ok = new QPushButton( i18n("OK"), this );
188 lay->addWidget( ok ); 188 lay->addWidget( ok );
189 QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); 189 QPushButton * cancel = new QPushButton( i18n("Cancel"), this );
190 lay->addWidget( cancel ); 190 lay->addWidget( cancel );
191 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); 191 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) );
192 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); 192 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) );
193 resize( 200, 200 ); 193 resize( 200, 200 );
194 } 194 }
195 195
196 bool addCat() { return addCatBut->isChecked(); } 196 bool addCat() { return addCatBut->isChecked(); }
197private: 197private:
198 QRadioButton* addCatBut; 198 QRadioButton* addCatBut;
199}; 199};
200 200
201class KABFormatPrefs : public QDialog 201class KABFormatPrefs : public QDialog
202{ 202{
203 public: 203 public:
204 KABFormatPrefs( QWidget *parent=0, const char *name=0 ) : 204 KABFormatPrefs( QWidget *parent=0, const char *name=0 ) :
205 QDialog( parent, name, true ) 205 QDialog( parent, name, true )
206 { 206 {
207 setCaption( i18n("Set formatted name") ); 207 setCaption( i18n("Set formatted name") );
208 QVBoxLayout* lay = new QVBoxLayout( this ); 208 QVBoxLayout* lay = new QVBoxLayout( this );
209 lay->setSpacing( 3 ); 209 lay->setSpacing( 3 );
210 lay->setMargin( 3 ); 210 lay->setMargin( 3 );
211 QLabel * lab = new QLabel( i18n("You can set the formatted name\nfor a list of contacts in one go."), this ); 211 QLabel * lab = new QLabel( i18n("You can set the formatted name\nfor a list of contacts in one go."), this );
212 lay->addWidget( lab ); 212 lay->addWidget( lab );
213 QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("Set formatted name to:"), this ); 213 QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("Set formatted name to:"), this );
214 lay->addWidget( format ); 214 lay->addWidget( format );
215 format->setExclusive ( true ) ; 215 format->setExclusive ( true ) ;
216 simple = new QRadioButton(i18n("Simple: James Bond"), format ); 216 simple = new QRadioButton(i18n("Simple: James Bond"), format );
217 full = new QRadioButton(i18n("Full: Mr. James 007 Bond I"), format ); 217 full = new QRadioButton(i18n("Full: Mr. James 007 Bond I"), format );
218 reverse = new QRadioButton(i18n("Reverse: Bond, James"), format ); 218 reverse = new QRadioButton(i18n("Reverse: Bond, James"), format );
219 company = new QRadioButton(i18n("Organization: MI6"), format ); 219 company = new QRadioButton(i18n("Organization: MI6"), format );
220 simple->setChecked( true ); 220 simple->setChecked( true );
221 setCompany = new QCheckBox(i18n("Set formatted name to\norganization, if name empty"), this); 221 setCompany = new QCheckBox(i18n("Set formatted name to\norganization, if name empty"), this);
222 lay->addWidget( setCompany ); 222 lay->addWidget( setCompany );
223 QPushButton * ok = new QPushButton( i18n("Select contact list"), this ); 223 QPushButton * ok = new QPushButton( i18n("Select contact list"), this );
224 lay->addWidget( ok ); 224 lay->addWidget( ok );
225 QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); 225 QPushButton * cancel = new QPushButton( i18n("Cancel"), this );
226 lay->addWidget( cancel ); 226 lay->addWidget( cancel );
227 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); 227 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) );
228 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); 228 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) );
229 //resize( 200, 200 ); 229 //resize( 200, 200 );
230 230
231 } 231 }
232public: 232public:
233 QRadioButton* simple, *full, *reverse, *company; 233 QRadioButton* simple, *full, *reverse, *company;
234 QCheckBox* setCompany; 234 QCheckBox* setCompany;
235}; 235};
236 236
237 237
238 238
239class KAex2phonePrefs : public QDialog 239class KAex2phonePrefs : public QDialog
240{ 240{
241 public: 241 public:
242 KAex2phonePrefs( QWidget *parent=0, const char *name=0 ) : 242 KAex2phonePrefs( QWidget *parent=0, const char *name=0 ) :
243 QDialog( parent, name, true ) 243 QDialog( parent, name, true )
244 { 244 {
245 setCaption( i18n("Export to phone options") ); 245 setCaption( i18n("Export to phone options") );
246 QVBoxLayout* lay = new QVBoxLayout( this ); 246 QVBoxLayout* lay = new QVBoxLayout( this );
247 lay->setSpacing( 3 ); 247 lay->setSpacing( 3 );
248 lay->setMargin( 3 ); 248 lay->setMargin( 3 );
249 QLabel *lab; 249 QLabel *lab;
250 lay->addWidget(lab = new QLabel( i18n("Please read Help-Sync Howto\nto know what settings to use."), this ) ); 250 lay->addWidget(lab = new QLabel( i18n("Please read Help-Sync Howto\nto know what settings to use."), this ) );
251 lab->setAlignment (AlignHCenter ); 251 lab->setAlignment (AlignHCenter );
252 QHBox* temphb; 252 QHBox* temphb;
253 temphb = new QHBox( this ); 253 temphb = new QHBox( this );
254 new QLabel( i18n("I/O device: "), temphb ); 254 new QLabel( i18n("I/O device: "), temphb );
255 mPhoneDevice = new QLineEdit( temphb); 255 mPhoneDevice = new QLineEdit( temphb);
256 lay->addWidget( temphb ); 256 lay->addWidget( temphb );
257 temphb = new QHBox( this ); 257 temphb = new QHBox( this );
258 new QLabel( i18n("Connection: "), temphb ); 258 new QLabel( i18n("Connection: "), temphb );
259 mPhoneConnection = new QLineEdit( temphb); 259 mPhoneConnection = new QLineEdit( temphb);
260 lay->addWidget( temphb ); 260 lay->addWidget( temphb );
261 temphb = new QHBox( this ); 261 temphb = new QHBox( this );
262 new QLabel( i18n("Model(opt.): "), temphb ); 262 new QLabel( i18n("Model(opt.): "), temphb );
263 mPhoneModel = new QLineEdit( temphb); 263 mPhoneModel = new QLineEdit( temphb);
264 lay->addWidget( temphb ); 264 lay->addWidget( temphb );
265 // mWriteToSim = new QCheckBox( i18n("Write Contacts to SIM card\n(if not, write to phone memory)"), this ); 265 // mWriteToSim = new QCheckBox( i18n("Write Contacts to SIM card\n(if not, write to phone memory)"), this );
266 // lay->addWidget( mWriteToSim ); 266 // lay->addWidget( mWriteToSim );
267 lay->addWidget(lab = new QLabel( i18n("NOTE: This will remove all old\ncontact data on phone!"), this ) ); 267 lay->addWidget(lab = new QLabel( i18n("NOTE: This will remove all old\ncontact data on phone!"), this ) );
268 lab->setAlignment (AlignHCenter); 268 lab->setAlignment (AlignHCenter);
269 QPushButton * ok = new QPushButton( i18n("Export to mobile phone!"), this ); 269 QPushButton * ok = new QPushButton( i18n("Export to mobile phone!"), this );
270 lay->addWidget( ok ); 270 lay->addWidget( ok );
271 QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); 271 QPushButton * cancel = new QPushButton( i18n("Cancel"), this );
272 lay->addWidget( cancel ); 272 lay->addWidget( cancel );
273 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); 273 connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) );
274 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); 274 connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) );
275 resize( 220, 240 ); 275 resize( 220, 240 );
276 276
277 } 277 }
278 278
279public: 279public:
280 QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel; 280 QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel;
281 QCheckBox* mWriteToSim; 281 QCheckBox* mWriteToSim;
282}; 282};
283 283
284 284
285bool pasteWithNewUid = true; 285bool pasteWithNewUid = true;
286 286
287#ifdef KAB_EMBEDDED 287#ifdef KAB_EMBEDDED
288KABCore::KABCore( KAddressBookMain *client, bool readWrite, QWidget *parent, const char *name ) 288KABCore::KABCore( KAddressBookMain *client, bool readWrite, QWidget *parent, const char *name )
289 : QWidget( parent, name ), KSyncInterface(), mGUIClient( client ), mViewManager( 0 ), 289 : QWidget( parent, name ), KSyncInterface(), mGUIClient( client ), mViewManager( 0 ),
290 mExtensionManager( 0 ),mConfigureDialog( 0 ),/*US mLdapSearchDialog( 0 ),*/ 290 mExtensionManager( 0 ),mConfigureDialog( 0 ),/*US mLdapSearchDialog( 0 ),*/
291 mReadWrite( readWrite ), mModified( false ), mMainWindow(client) 291 mReadWrite( readWrite ), mModified( false ), mMainWindow(client)
292#else //KAB_EMBEDDED 292#else //KAB_EMBEDDED
293KABCore::KABCore( KXMLGUIClient *client, bool readWrite, QWidget *parent, const char *name ) 293KABCore::KABCore( KXMLGUIClient *client, bool readWrite, QWidget *parent, const char *name )
294 : QWidget( parent, name ), KSyncInterface(), mGUIClient( client ), mViewManager( 0 ), 294 : QWidget( parent, name ), KSyncInterface(), mGUIClient( client ), mViewManager( 0 ),
295 mExtensionManager( 0 ), mConfigureDialog( 0 ), mLdapSearchDialog( 0 ), 295 mExtensionManager( 0 ), mConfigureDialog( 0 ), mLdapSearchDialog( 0 ),
296 mReadWrite( readWrite ), mModified( false ) 296 mReadWrite( readWrite ), mModified( false )
297#endif //KAB_EMBEDDED 297#endif //KAB_EMBEDDED
298{ 298{
299 // syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu); 299 // syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu);
300 // syncManager->setBlockSave(false); 300 // syncManager->setBlockSave(false);
301 mIncSearchWidget = 0; 301 mIncSearchWidget = 0;
302 mMiniSplitter = 0; 302 mMiniSplitter = 0;
303 mExtensionBarSplitter = 0; 303 mExtensionBarSplitter = 0;
304 mIsPart = !parent->inherits( "KAddressBookMain" ); 304 mIsPart = !parent->inherits( "KAddressBookMain" );
305 mAddressBook = KABC::StdAddressBook::self(); 305 mAddressBook = KABC::StdAddressBook::self();
306 KABC::StdAddressBook::setAutomaticSave( false ); 306 KABC::StdAddressBook::setAutomaticSave( false );
307 307
308#ifndef KAB_EMBEDDED 308#ifndef KAB_EMBEDDED
309 mAddressBook->setErrorHandler( new KABC::GUIErrorHandler ); 309 mAddressBook->setErrorHandler( new KABC::GUIErrorHandler );
310#endif //KAB_EMBEDDED 310#endif //KAB_EMBEDDED
311 311
312 connect( mAddressBook, SIGNAL( addressBookChanged( AddressBook * ) ), 312 connect( mAddressBook, SIGNAL( addressBookChanged( AddressBook * ) ),
313 SLOT( addressBookChanged() ) ); 313 SLOT( addressBookChanged() ) );
314 314
315#if 0 315#if 0
316 // LR moved to addressbook init method 316 // LR moved to addressbook init method
317 mAddressBook->addCustomField( i18n( "Department" ), KABC::Field::Organization, 317 mAddressBook->addCustomField( i18n( "Department" ), KABC::Field::Organization,
318 "X-Department", "KADDRESSBOOK" ); 318 "X-Department", "KADDRESSBOOK" );
319 mAddressBook->addCustomField( i18n( "Profession" ), KABC::Field::Organization, 319 mAddressBook->addCustomField( i18n( "Profession" ), KABC::Field::Organization,
320 "X-Profession", "KADDRESSBOOK" ); 320 "X-Profession", "KADDRESSBOOK" );
321 mAddressBook->addCustomField( i18n( "Assistant's Name" ), KABC::Field::Organization, 321 mAddressBook->addCustomField( i18n( "Assistant's Name" ), KABC::Field::Organization,
322 "X-AssistantsName", "KADDRESSBOOK" ); 322 "X-AssistantsName", "KADDRESSBOOK" );
323 mAddressBook->addCustomField( i18n( "Manager's Name" ), KABC::Field::Organization, 323 mAddressBook->addCustomField( i18n( "Manager's Name" ), KABC::Field::Organization,
324 "X-ManagersName", "KADDRESSBOOK" ); 324 "X-ManagersName", "KADDRESSBOOK" );
325 mAddressBook->addCustomField( i18n( "Spouse's Name" ), KABC::Field::Personal, 325 mAddressBook->addCustomField( i18n( "Spouse's Name" ), KABC::Field::Personal,
326 "X-SpousesName", "KADDRESSBOOK" ); 326 "X-SpousesName", "KADDRESSBOOK" );
327 mAddressBook->addCustomField( i18n( "Office" ), KABC::Field::Personal, 327 mAddressBook->addCustomField( i18n( "Office" ), KABC::Field::Personal,
328 "X-Office", "KADDRESSBOOK" ); 328 "X-Office", "KADDRESSBOOK" );
329 mAddressBook->addCustomField( i18n( "IM Address" ), KABC::Field::Personal, 329 mAddressBook->addCustomField( i18n( "IM Address" ), KABC::Field::Personal,
330 "X-IMAddress", "KADDRESSBOOK" ); 330 "X-IMAddress", "KADDRESSBOOK" );
331 mAddressBook->addCustomField( i18n( "Anniversary" ), KABC::Field::Personal, 331 mAddressBook->addCustomField( i18n( "Anniversary" ), KABC::Field::Personal,
332 "X-Anniversary", "KADDRESSBOOK" ); 332 "X-Anniversary", "KADDRESSBOOK" );
333 333
334 //US added this field to become compatible with Opie/qtopia addressbook 334 //US added this field to become compatible with Opie/qtopia addressbook
335 // values can be "female" or "male" or "". An empty field represents undefined. 335 // values can be "female" or "male" or "". An empty field represents undefined.
336 mAddressBook->addCustomField( i18n( "Gender" ), KABC::Field::Personal, 336 mAddressBook->addCustomField( i18n( "Gender" ), KABC::Field::Personal,
337 "X-Gender", "KADDRESSBOOK" ); 337 "X-Gender", "KADDRESSBOOK" );
338 mAddressBook->addCustomField( i18n( "Children" ), KABC::Field::Personal, 338 mAddressBook->addCustomField( i18n( "Children" ), KABC::Field::Personal,
339 "X-Children", "KADDRESSBOOK" ); 339 "X-Children", "KADDRESSBOOK" );
340 mAddressBook->addCustomField( i18n( "FreeBusyUrl" ), KABC::Field::Personal, 340 mAddressBook->addCustomField( i18n( "FreeBusyUrl" ), KABC::Field::Personal,
341 "X-FreeBusyUrl", "KADDRESSBOOK" ); 341 "X-FreeBusyUrl", "KADDRESSBOOK" );
342#endif 342#endif
343 initGUI(); 343 initGUI();
344 344
345 mIncSearchWidget->setFocus(); 345 mIncSearchWidget->setFocus();
346 346
347 347
348 connect( mViewManager, SIGNAL( selected( const QString& ) ), 348 connect( mViewManager, SIGNAL( selected( const QString& ) ),
349 SLOT( setContactSelected( const QString& ) ) ); 349 SLOT( setContactSelected( const QString& ) ) );
350 connect( mViewManager, SIGNAL( executed( const QString& ) ), 350 connect( mViewManager, SIGNAL( executed( const QString& ) ),
351 SLOT( executeContact( const QString& ) ) ); 351 SLOT( executeContact( const QString& ) ) );
352 352
353 connect( mViewManager, SIGNAL( deleteRequest( ) ), 353 connect( mViewManager, SIGNAL( deleteRequest( ) ),
354 SLOT( deleteContacts( ) ) ); 354 SLOT( deleteContacts( ) ) );
355 connect( mViewManager, SIGNAL( modified() ), 355 connect( mViewManager, SIGNAL( modified() ),
356 SLOT( setModified() ) ); 356 SLOT( setModified() ) );
357 357
358 connect( mExtensionManager, SIGNAL( modified( const KABC::Addressee::List& ) ), this, SLOT( extensionModified( const KABC::Addressee::List& ) ) ); 358 connect( mExtensionManager, SIGNAL( modified( const KABC::Addressee::List& ) ), this, SLOT( extensionModified( const KABC::Addressee::List& ) ) );
359 connect( mExtensionManager, SIGNAL( changedActiveExtension( int ) ), this, SLOT( extensionChanged( int ) ) ); 359 connect( mExtensionManager, SIGNAL( changedActiveExtension( int ) ), this, SLOT( extensionChanged( int ) ) );
360 360
361 connect( mXXPortManager, SIGNAL( modified() ), 361 connect( mXXPortManager, SIGNAL( modified() ),
362 SLOT( setModified() ) ); 362 SLOT( setModified() ) );
363 363
364 connect( mJumpButtonBar, SIGNAL( jumpToLetter( const QString& ) ), 364 connect( mJumpButtonBar, SIGNAL( jumpToLetter( const QString& ) ),
365 SLOT( incrementalSearchJump( const QString& ) ) ); 365 SLOT( incrementalSearchJump( const QString& ) ) );
366 connect( mIncSearchWidget, SIGNAL( fieldChanged() ), 366 connect( mIncSearchWidget, SIGNAL( fieldChanged() ),
367 mJumpButtonBar, SLOT( recreateButtons() ) ); 367 mJumpButtonBar, SLOT( recreateButtons() ) );
368 368
369 connect( mDetails, SIGNAL( sendEmail( const QString& ) ), 369 connect( mDetails, SIGNAL( sendEmail( const QString& ) ),
370 SLOT( sendMail( const QString& ) ) ); 370 SLOT( sendMail( const QString& ) ) );
371 371
372 372
373 connect( ExternalAppHandler::instance(), SIGNAL (requestForNameEmailUidList(const QString&, const QString&)),this, SLOT(requestForNameEmailUidList(const QString&, const QString&))); 373 connect( ExternalAppHandler::instance(), SIGNAL (requestForNameEmailUidList(const QString&, const QString&)),this, SLOT(requestForNameEmailUidList(const QString&, const QString&)));
374 connect( ExternalAppHandler::instance(), SIGNAL (requestForDetails(const QString&, const QString&, const QString&, const QString&, const QString&)),this, SLOT(requestForDetails(const QString&, const QString&, const QString&, const QString&, const QString&))); 374 connect( ExternalAppHandler::instance(), SIGNAL (requestForDetails(const QString&, const QString&, const QString&, const QString&, const QString&)),this, SLOT(requestForDetails(const QString&, const QString&, const QString&, const QString&, const QString&)));
375 connect( ExternalAppHandler::instance(), SIGNAL (requestForBirthdayList(const QString&, const QString&)),this, SLOT(requestForBirthdayList(const QString&, const QString&))); 375 connect( ExternalAppHandler::instance(), SIGNAL (requestForBirthdayList(const QString&, const QString&)),this, SLOT(requestForBirthdayList(const QString&, const QString&)));
376 connect( ExternalAppHandler::instance(), SIGNAL (nextView()),this, SLOT(setDetailsToggle())); 376 connect( ExternalAppHandler::instance(), SIGNAL (nextView()),this, SLOT(setDetailsToggle()));
377 connect( ExternalAppHandler::instance(), SIGNAL (callContactdialog()),this, SLOT(callContactdialog())); 377 connect( ExternalAppHandler::instance(), SIGNAL (callContactdialog()),this, SLOT(callContactdialog()));
378 378
379 379
380#ifndef KAB_EMBEDDED 380#ifndef KAB_EMBEDDED
381 connect( mViewManager, SIGNAL( urlDropped( const KURL& ) ), 381 connect( mViewManager, SIGNAL( urlDropped( const KURL& ) ),
382 mXXPortManager, SLOT( importVCard( const KURL& ) ) ); 382 mXXPortManager, SLOT( importVCard( const KURL& ) ) );
383 383
384 connect( mDetails, SIGNAL( browse( const QString& ) ), 384 connect( mDetails, SIGNAL( browse( const QString& ) ),
385 SLOT( browse( const QString& ) ) ); 385 SLOT( browse( const QString& ) ) );
386 386
387 387
388 mAddressBookService = new KAddressBookService( this ); 388 mAddressBookService = new KAddressBookService( this );
389 389
390#endif //KAB_EMBEDDED 390#endif //KAB_EMBEDDED
391 391
392 mMessageTimer = new QTimer( this ); 392 mMessageTimer = new QTimer( this );
393 connect( mMessageTimer, SIGNAL( timeout() ), this, SLOT( setCaptionBack() ) ); 393 connect( mMessageTimer, SIGNAL( timeout() ), this, SLOT( setCaptionBack() ) );
394 mEditorDialog = 0; 394 mEditorDialog = 0;
395 createAddresseeEditorDialog( this ); 395 createAddresseeEditorDialog( this );
396 setModified( false ); 396 setModified( false );
397 mBRdisabled = false; 397 mBRdisabled = false;
398#ifndef DESKTOP_VERSION 398#ifndef DESKTOP_VERSION
399 infrared = 0; 399 infrared = 0;
400#endif 400#endif
401 //toggleBeamReceive( ); 401 //toggleBeamReceive( );
402 //mMainWindow->toolBar()->show(); 402 mMainWindow->toolBar()->show();
403 // we have a toolbar repainting error on the Zaurus when starting KA/Pi 403 // we have a toolbar repainting error on the Zaurus when starting KA/Pi
404 QTimer::singleShot( 10, this , SLOT ( updateToolBar())); 404 QTimer::singleShot( 10, this , SLOT ( updateToolBar()));
405} 405}
406 406
407void KABCore::updateToolBar() 407void KABCore::updateToolBar()
408{ 408{
409 static int iii = 0; 409 static int iii = 0;
410 ++iii; 410 ++iii;
411 mMainWindow->toolBar()->repaintMe(); 411 mMainWindow->toolBar()->repaintMe();
412 if ( iii < 4 ) 412 if ( iii < 4 )
413 QTimer::singleShot( 100*iii, this , SLOT ( updateToolBar())); 413 QTimer::singleShot( 100*iii, this , SLOT ( updateToolBar()));
414} 414}
415KABCore::~KABCore() 415KABCore::~KABCore()
416{ 416{
417 // save(); 417 // save();
418 //saveSettings(); 418 //saveSettings();
419 //KABPrefs::instance()->writeConfig(); 419 //KABPrefs::instance()->writeConfig();
420 delete AddresseeConfig::instance(); 420 delete AddresseeConfig::instance();
421 mAddressBook = 0; 421 mAddressBook = 0;
422 KABC::StdAddressBook::close(); 422 KABC::StdAddressBook::close();
423 423
424 delete syncManager; 424 delete syncManager;
425#ifndef DESKTOP_VERSION 425#ifndef DESKTOP_VERSION
426 if ( infrared ) 426 if ( infrared )
427 delete infrared; 427 delete infrared;
428#endif 428#endif
429} 429}
430void KABCore::receive( const QCString& cmsg, const QByteArray& data ) 430void KABCore::receive( const QCString& cmsg, const QByteArray& data )
431{ 431{
432 //qDebug("KA: QCOP message received: %s ", cmsg.data() ); 432 //qDebug("KA: QCOP message received: %s ", cmsg.data() );
433 if ( cmsg == "setDocument(QString)" ) { 433 if ( cmsg == "setDocument(QString)" ) {
434 QDataStream stream( data, IO_ReadOnly ); 434 QDataStream stream( data, IO_ReadOnly );
435 QString fileName; 435 QString fileName;
436 stream >> fileName; 436 stream >> fileName;
437 recieve( fileName ); 437 recieve( fileName );
438 return; 438 return;
439 } 439 }
440} 440}
441void KABCore::toggleBeamReceive( ) 441void KABCore::toggleBeamReceive( )
442{ 442{
443 if ( mBRdisabled ) 443 if ( mBRdisabled )
444 return; 444 return;
445#ifndef DESKTOP_VERSION 445#ifndef DESKTOP_VERSION
446 if ( infrared ) { 446 if ( infrared ) {
447 qDebug("KA: AB disable BeamReceive "); 447 qDebug("KA: AB disable BeamReceive ");
448 delete infrared; 448 delete infrared;
449 infrared = 0; 449 infrared = 0;
450 mActionBR->setChecked(false); 450 mActionBR->setChecked(false);
451 return; 451 return;
452 } 452 }
453 qDebug("KA: AB enable BeamReceive "); 453 qDebug("KA: AB enable BeamReceive ");
454 mActionBR->setChecked(true); 454 mActionBR->setChecked(true);
455 455
456 infrared = new QCopChannel("QPE/Application/addressbook",this, "channelAB" ) ; 456 infrared = new QCopChannel("QPE/Application/addressbook",this, "channelAB" ) ;
457 QObject::connect( infrared, SIGNAL (received ( const QCString &, const QByteArray & )),this, SLOT(receive( const QCString&, const QByteArray& ))); 457 QObject::connect( infrared, SIGNAL (received ( const QCString &, const QByteArray & )),this, SLOT(receive( const QCString&, const QByteArray& )));
458#endif 458#endif
459} 459}
460 460
461 461
462void KABCore::disableBR(bool b) 462void KABCore::disableBR(bool b)
463{ 463{
464#ifndef DESKTOP_VERSION 464#ifndef DESKTOP_VERSION
465 if ( b ) { 465 if ( b ) {
466 if ( infrared ) { 466 if ( infrared ) {
467 toggleBeamReceive( ); 467 toggleBeamReceive( );
468 } 468 }
469 mBRdisabled = true; 469 mBRdisabled = true;
470 } else { 470 } else {
471 if ( mBRdisabled ) { 471 if ( mBRdisabled ) {
472 mBRdisabled = false; 472 mBRdisabled = false;
473 //toggleBeamReceive( ); 473 //toggleBeamReceive( );
474 } 474 }
475 } 475 }
476#endif 476#endif
477 477
478} 478}
479void KABCore::recieve( QString fn ) 479void KABCore::recieve( QString fn )
480{ 480{
481 //qDebug("KABCore::recieve "); 481 //qDebug("KABCore::recieve ");
482 int count = mAddressBook->importFromFile( fn, true ); 482 int count = mAddressBook->importFromFile( fn, true );
483 if ( count ) 483 if ( count )
484 setModified( true ); 484 setModified( true );
485 mViewManager->refreshView(); 485 mViewManager->refreshView();
486 message(i18n("%1 contact(s) received!").arg( count )); 486 message(i18n("%1 contact(s) received!").arg( count ));
487 topLevelWidget()->showMaximized(); 487 topLevelWidget()->showMaximized();
488 topLevelWidget()->raise(); 488 topLevelWidget()->raise();
489} 489}
490void KABCore::restoreSettings() 490void KABCore::restoreSettings()
491{ 491{
492 mMultipleViewsAtOnce = KABPrefs::instance()->mMultipleViewsAtOnce; 492 mMultipleViewsAtOnce = KABPrefs::instance()->mMultipleViewsAtOnce;
493 493
494 bool state; 494 bool state;
495 495
496 if (mMultipleViewsAtOnce) 496 if (mMultipleViewsAtOnce)
497 state = KABPrefs::instance()->mDetailsPageVisible; 497 state = KABPrefs::instance()->mDetailsPageVisible;
498 else 498 else
499 state = false; 499 state = false;
500 500
501 mActionDetails->setChecked( state ); 501 mActionDetails->setChecked( state );
502 setDetailsVisible( state ); 502 setDetailsVisible( state );
503 503
504 state = KABPrefs::instance()->mJumpButtonBarVisible; 504 state = KABPrefs::instance()->mJumpButtonBarVisible;
505 505
506 mActionJumpBar->setChecked( state ); 506 mActionJumpBar->setChecked( state );
507 setJumpButtonBarVisible( state ); 507 setJumpButtonBarVisible( state );
508/*US 508/*US
509 QValueList<int> splitterSize = KABPrefs::instance()->mDetailsSplitter; 509 QValueList<int> splitterSize = KABPrefs::instance()->mDetailsSplitter;
510 if ( splitterSize.count() == 0 ) { 510 if ( splitterSize.count() == 0 ) {
511 splitterSize.append( width() / 2 ); 511 splitterSize.append( width() / 2 );
512 splitterSize.append( width() / 2 ); 512 splitterSize.append( width() / 2 );
513 } 513 }
514 mMiniSplitter->setSizes( splitterSize ); 514 mMiniSplitter->setSizes( splitterSize );
515 if ( mExtensionBarSplitter ) { 515 if ( mExtensionBarSplitter ) {
516 splitterSize = KABPrefs::instance()->mExtensionsSplitter; 516 splitterSize = KABPrefs::instance()->mExtensionsSplitter;
517 if ( splitterSize.count() == 0 ) { 517 if ( splitterSize.count() == 0 ) {
518 splitterSize.append( width() / 2 ); 518 splitterSize.append( width() / 2 );
519 splitterSize.append( width() / 2 ); 519 splitterSize.append( width() / 2 );
520 } 520 }
521 mExtensionBarSplitter->setSizes( splitterSize ); 521 mExtensionBarSplitter->setSizes( splitterSize );
522 522
523 } 523 }
524*/ 524*/
525 mViewManager->restoreSettings(); 525 mViewManager->restoreSettings();
526 mIncSearchWidget->setCurrentItem( KABPrefs::instance()->mCurrentIncSearchField ); 526 mIncSearchWidget->setCurrentItem( KABPrefs::instance()->mCurrentIncSearchField );
527 mExtensionManager->restoreSettings(); 527 mExtensionManager->restoreSettings();
528#ifdef DESKTOP_VERSION 528#ifdef DESKTOP_VERSION
529 int wid = width(); 529 int wid = width();
530 if ( wid < 10 ) 530 if ( wid < 10 )
531 wid = 400; 531 wid = 400;
532#else 532#else
533 int wid = QApplication::desktop()->width(); 533 int wid = QApplication::desktop()->width();
534 if ( wid < 640 ) 534 if ( wid < 640 )
535 wid = QApplication::desktop()->height(); 535 wid = QApplication::desktop()->height();
536#endif 536#endif
537 QValueList<int> splitterSize;// = KABPrefs::instance()->mDetailsSplitter; 537 QValueList<int> splitterSize;// = KABPrefs::instance()->mDetailsSplitter;
538 if ( true /*splitterSize.count() == 0*/ ) { 538 if ( true /*splitterSize.count() == 0*/ ) {
539 splitterSize.append( wid / 2 ); 539 splitterSize.append( wid / 2 );
540 splitterSize.append( wid / 2 ); 540 splitterSize.append( wid / 2 );
541 } 541 }
542 mMiniSplitter->setSizes( splitterSize ); 542 mMiniSplitter->setSizes( splitterSize );
543 if ( mExtensionBarSplitter ) { 543 if ( mExtensionBarSplitter ) {
544 //splitterSize = KABPrefs::instance()->mExtensionsSplitter; 544 //splitterSize = KABPrefs::instance()->mExtensionsSplitter;
545 if ( true /*splitterSize.count() == 0*/ ) { 545 if ( true /*splitterSize.count() == 0*/ ) {
546 splitterSize.append( wid / 2 ); 546 splitterSize.append( wid / 2 );
547 splitterSize.append( wid / 2 ); 547 splitterSize.append( wid / 2 );
548 } 548 }
549 mExtensionBarSplitter->setSizes( splitterSize ); 549 mExtensionBarSplitter->setSizes( splitterSize );
550 550
551 } 551 }
552 552
553 553
554} 554}
555 555
556void KABCore::saveSettings() 556void KABCore::saveSettings()
557{ 557{
558 KABPrefs::instance()->mJumpButtonBarVisible = mActionJumpBar->isChecked(); 558 KABPrefs::instance()->mJumpButtonBarVisible = mActionJumpBar->isChecked();
559 if ( mExtensionBarSplitter ) 559 if ( mExtensionBarSplitter )
560 KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); 560 KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes();
561 KABPrefs::instance()->mDetailsPageVisible = mActionDetails->isChecked(); 561 KABPrefs::instance()->mDetailsPageVisible = mActionDetails->isChecked();
562 KABPrefs::instance()->mDetailsSplitter = mMiniSplitter->sizes(); 562 KABPrefs::instance()->mDetailsSplitter = mMiniSplitter->sizes();
563#ifndef KAB_EMBEDDED 563#ifndef KAB_EMBEDDED
564 564
565 KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); 565 KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes();
566 KABPrefs::instance()->mDetailsSplitter = mDetailsSplitter->sizes(); 566 KABPrefs::instance()->mDetailsSplitter = mDetailsSplitter->sizes();
567#endif //KAB_EMBEDDED 567#endif //KAB_EMBEDDED
568 mExtensionManager->saveSettings(); 568 mExtensionManager->saveSettings();
569 mViewManager->saveSettings(); 569 mViewManager->saveSettings();
570 570
571 KABPrefs::instance()->mCurrentIncSearchField = mIncSearchWidget->currentItem(); 571 KABPrefs::instance()->mCurrentIncSearchField = mIncSearchWidget->currentItem();
572 KABPrefs::instance()->writeConfig(); 572 KABPrefs::instance()->writeConfig();
573 qDebug("KA: KABCore::saveSettings() "); 573 qDebug("KA: KABCore::saveSettings() ");
574} 574}
575 575
576KABC::AddressBook *KABCore::addressBook() const 576KABC::AddressBook *KABCore::addressBook() const
577{ 577{
578 return mAddressBook; 578 return mAddressBook;
579} 579}
580 580
581KConfig *KABCore::config() 581KConfig *KABCore::config()
582{ 582{
583#ifndef KAB_EMBEDDED 583#ifndef KAB_EMBEDDED
584 return KABPrefs::instance()->config(); 584 return KABPrefs::instance()->config();
585#else //KAB_EMBEDDED 585#else //KAB_EMBEDDED
586 return KABPrefs::instance()->getConfig(); 586 return KABPrefs::instance()->getConfig();
587#endif //KAB_EMBEDDED 587#endif //KAB_EMBEDDED
588} 588}
589 589
590KActionCollection *KABCore::actionCollection() const 590KActionCollection *KABCore::actionCollection() const
591{ 591{
592 return mGUIClient->actionCollection(); 592 return mGUIClient->actionCollection();
593} 593}
594 594
595KABC::Field *KABCore::currentSearchField() const 595KABC::Field *KABCore::currentSearchField() const
596{ 596{
597 if (mIncSearchWidget) 597 if (mIncSearchWidget)
598 return mIncSearchWidget->currentField(); 598 return mIncSearchWidget->currentField();
599 else 599 else
600 return 0; 600 return 0;
601} 601}
602 602
603QStringList KABCore::selectedUIDs() const 603QStringList KABCore::selectedUIDs() const
604{ 604{
605 return mViewManager->selectedUids(); 605 return mViewManager->selectedUids();
606} 606}
607 607
608KABC::Resource *KABCore::requestResource( QWidget *parent ) 608KABC::Resource *KABCore::requestResource( QWidget *parent )
609{ 609{
610 QPtrList<KABC::Resource> kabcResources = addressBook()->resources(); 610 QPtrList<KABC::Resource> kabcResources = addressBook()->resources();
611 611
612 QPtrList<KRES::Resource> kresResources; 612 QPtrList<KRES::Resource> kresResources;
613 QPtrListIterator<KABC::Resource> resIt( kabcResources ); 613 QPtrListIterator<KABC::Resource> resIt( kabcResources );
614 KABC::Resource *resource; 614 KABC::Resource *resource;
615 while ( ( resource = resIt.current() ) != 0 ) { 615 while ( ( resource = resIt.current() ) != 0 ) {
616 ++resIt; 616 ++resIt;
617 if ( !resource->readOnly() ) { 617 if ( !resource->readOnly() ) {
618 KRES::Resource *res = static_cast<KRES::Resource*>( resource ); 618 KRES::Resource *res = static_cast<KRES::Resource*>( resource );
619 if ( res ) 619 if ( res )
620 kresResources.append( res ); 620 kresResources.append( res );
621 } 621 }
622 } 622 }
623 623
624 KRES::Resource *res = KRES::SelectDialog::getResource( kresResources, parent ); 624 KRES::Resource *res = KRES::SelectDialog::getResource( kresResources, parent );
625 return static_cast<KABC::Resource*>( res ); 625 return static_cast<KABC::Resource*>( res );
626} 626}
627 627
628#ifndef KAB_EMBEDDED 628#ifndef KAB_EMBEDDED
629KAboutData *KABCore::createAboutData() 629KAboutData *KABCore::createAboutData()
630#else //KAB_EMBEDDED 630#else //KAB_EMBEDDED
631void KABCore::createAboutData() 631void KABCore::createAboutData()
632#endif //KAB_EMBEDDED 632#endif //KAB_EMBEDDED
633{ 633{
634#ifndef KAB_EMBEDDED 634#ifndef KAB_EMBEDDED
635 KAboutData *about = new KAboutData( "kaddressbook", I18N_NOOP( "KAddressBook" ), 635 KAboutData *about = new KAboutData( "kaddressbook", I18N_NOOP( "KAddressBook" ),
636 "3.1", I18N_NOOP( "The KDE Address Book" ), 636 "3.1", I18N_NOOP( "The KDE Address Book" ),
637 KAboutData::License_GPL_V2, 637 KAboutData::License_GPL_V2,
638 I18N_NOOP( "(c) 1997-2003, The KDE PIM Team" ) ); 638 I18N_NOOP( "(c) 1997-2003, The KDE PIM Team" ) );
639 about->addAuthor( "Tobias Koenig", I18N_NOOP( "Current maintainer " ), "tokoe@kde.org" ); 639 about->addAuthor( "Tobias Koenig", I18N_NOOP( "Current maintainer " ), "tokoe@kde.org" );
640 about->addAuthor( "Don Sanders", I18N_NOOP( "Original author " ) ); 640 about->addAuthor( "Don Sanders", I18N_NOOP( "Original author " ) );
641 about->addAuthor( "Cornelius Schumacher", 641 about->addAuthor( "Cornelius Schumacher",
642 I18N_NOOP( "Co-maintainer, libkabc port, CSV import/export " ), 642 I18N_NOOP( "Co-maintainer, libkabc port, CSV import/export " ),
643 "schumacher@kde.org" ); 643 "schumacher@kde.org" );
644 about->addAuthor( "Mike Pilone", I18N_NOOP( "GUI and framework redesign " ), 644 about->addAuthor( "Mike Pilone", I18N_NOOP( "GUI and framework redesign " ),
645 "mpilone@slac.com" ); 645 "mpilone@slac.com" );
646 about->addAuthor( "Greg Stern", I18N_NOOP( "DCOP interface" ) ); 646 about->addAuthor( "Greg Stern", I18N_NOOP( "DCOP interface" ) );
647 about->addAuthor( "Mark Westcott", I18N_NOOP( "Contact pinning" ) ); 647 about->addAuthor( "Mark Westcott", I18N_NOOP( "Contact pinning" ) );
648 about->addAuthor( "Michel Boyer de la Giroday", I18N_NOOP( "LDAP Lookup\n" ), 648 about->addAuthor( "Michel Boyer de la Giroday", I18N_NOOP( "LDAP Lookup\n" ),
649 "michel@klaralvdalens-datakonsult.se" ); 649 "michel@klaralvdalens-datakonsult.se" );
650 about->addAuthor( "Steffen Hansen", I18N_NOOP( "LDAP Lookup " ), 650 about->addAuthor( "Steffen Hansen", I18N_NOOP( "LDAP Lookup " ),
651 "hansen@kde.org" ); 651 "hansen@kde.org" );
652 652
653 return about; 653 return about;
654#endif //KAB_EMBEDDED 654#endif //KAB_EMBEDDED
655 655
656 QString version; 656 QString version;
657#include <../version> 657#include <../version>
658 QMessageBox::about( this, "About KAddressbook/Pi", 658 QMessageBox::about( this, "About KAddressbook/Pi",
659 "KAddressbook/Platform-independent\n" 659 "KAddressbook/Platform-independent\n"
660 "(KA/Pi) " +version + " - " + 660 "(KA/Pi) " +version + " - " +
661#ifdef DESKTOP_VERSION 661#ifdef DESKTOP_VERSION
662 "Desktop Edition\n" 662 "Desktop Edition\n"
663#else 663#else
664 "PDA-Edition\n" 664 "PDA-Edition\n"
665 "for: Zaurus 5500 / 7x0 / 8x0\n" 665 "for: Zaurus 5500 / 7x0 / 8x0\n"
666#endif 666#endif
667 667
668 "(c) 2004 Ulf Schenk\n" 668 "(c) 2004 Ulf Schenk\n"
669 "(c) 2004 Lutz Rogowski\n" 669 "(c) 2004 Lutz Rogowski\n"
670 "(c) 1997-2003, The KDE PIM Team\n" 670 "(c) 1997-2003, The KDE PIM Team\n"
671 "Tobias Koenig Current maintainer\ntokoe@kde.org\n" 671 "Tobias Koenig Current maintainer\ntokoe@kde.org\n"
672 "Don Sanders Original author\n" 672 "Don Sanders Original author\n"
673 "Cornelius Schumacher Co-maintainer\nschumacher@kde.org\n" 673 "Cornelius Schumacher Co-maintainer\nschumacher@kde.org\n"
674 "Mike Pilone GUI and framework redesign\nmpilone@slac.com\n" 674 "Mike Pilone GUI and framework redesign\nmpilone@slac.com\n"
675 "Greg Stern DCOP interface\n" 675 "Greg Stern DCOP interface\n"
676 "Mark Westcot Contact pinning\n" 676 "Mark Westcot Contact pinning\n"
677 "Michel Boyer de la Giroday LDAP Lookup\n" "michel@klaralvdalens-datakonsult.se\n" 677 "Michel Boyer de la Giroday LDAP Lookup\n" "michel@klaralvdalens-datakonsult.se\n"
678 "Steffen Hansen LDAP Lookup\nhansen@kde.org\n" 678 "Steffen Hansen LDAP Lookup\nhansen@kde.org\n"
679#ifdef _WIN32_ 679#ifdef _WIN32_
680 "(c) 2004 Lutz Rogowski Import from OL\nrogowski@kde.org\n" 680 "(c) 2004 Lutz Rogowski Import from OL\nrogowski@kde.org\n"
681#endif 681#endif
682 ); 682 );
683} 683}
684 684
685void KABCore::setContactSelected( const QString &uid ) 685void KABCore::setContactSelected( const QString &uid )
686{ 686{
687 KABC::Addressee addr = mAddressBook->findByUid( uid ); 687 KABC::Addressee addr = mAddressBook->findByUid( uid );
688 if ( !mDetails->isHidden() ) 688 if ( !mDetails->isHidden() )
689 mDetails->setAddressee( addr ); 689 mDetails->setAddressee( addr );
690 690
691 if ( !addr.isEmpty() ) { 691 if ( !addr.isEmpty() ) {
692 emit contactSelected( addr.formattedName() ); 692 emit contactSelected( addr.formattedName() );
693 KABC::Picture pic = addr.photo(); 693 KABC::Picture pic = addr.photo();
694 if ( pic.isIntern() ) { 694 if ( pic.isIntern() ) {
695//US emit contactSelected( pic.data() ); 695//US emit contactSelected( pic.data() );
696//US instead use: 696//US instead use:
697 QPixmap px; 697 QPixmap px;
698 if (pic.data().isNull() != true) 698 if (pic.data().isNull() != true)
699 { 699 {
700 px.convertFromImage(pic.data()); 700 px.convertFromImage(pic.data());
701 } 701 }
702 702
703 emit contactSelected( px ); 703 emit contactSelected( px );
704 } 704 }
705 } 705 }
706 706
707 707
708 mExtensionManager->setSelectionChanged(); 708 mExtensionManager->setSelectionChanged();
709 709
710 // update the actions 710 // update the actions
711 bool selected = !uid.isEmpty(); 711 bool selected = !uid.isEmpty();
712 712
713 if ( mReadWrite ) { 713 if ( mReadWrite ) {
714 mActionCut->setEnabled( selected ); 714 mActionCut->setEnabled( selected );
715 mActionPaste->setEnabled( selected ); 715 mActionPaste->setEnabled( selected );
716 } 716 }
717 717
718 mActionCopy->setEnabled( selected ); 718 mActionCopy->setEnabled( selected );
719 mActionDelete->setEnabled( selected ); 719 mActionDelete->setEnabled( selected );
720 mActionEditAddressee->setEnabled( selected ); 720 mActionEditAddressee->setEnabled( selected );
721 mActionMail->setEnabled( selected ); 721 mActionMail->setEnabled( selected );
722 mActionMailVCard->setEnabled( selected ); 722 mActionMailVCard->setEnabled( selected );
723 //if (mActionBeam) 723 //if (mActionBeam)
724 //mActionBeam->setEnabled( selected ); 724 //mActionBeam->setEnabled( selected );
725 mActionWhoAmI->setEnabled( selected ); 725 mActionWhoAmI->setEnabled( selected );
726} 726}
727 727
728void KABCore::sendMail() 728void KABCore::sendMail()
729{ 729{
730 sendMail( mViewManager->selectedEmails().join( ", " ) ); 730 sendMail( mViewManager->selectedEmails().join( ", " ) );
731} 731}
732 732
733void KABCore::sendMail( const QString& emaillist ) 733void KABCore::sendMail( const QString& emaillist )
734{ 734{
735 // the parameter has the form "name1 <abc@aol.com>,name2 <abc@aol.com>;... " 735 // the parameter has the form "name1 <abc@aol.com>,name2 <abc@aol.com>;... "
736 if (emaillist.contains(",") > 0) 736 if (emaillist.contains(",") > 0)
737 ExternalAppHandler::instance()->mailToMultipleContacts( emaillist, QString::null ); 737 ExternalAppHandler::instance()->mailToMultipleContacts( emaillist, QString::null );
738 else 738 else
739 ExternalAppHandler::instance()->mailToOneContact( emaillist ); 739 ExternalAppHandler::instance()->mailToOneContact( emaillist );
740} 740}
741 741
742 742
743 743
744void KABCore::mailVCard() 744void KABCore::mailVCard()
745{ 745{
746 QStringList uids = mViewManager->selectedUids(); 746 QStringList uids = mViewManager->selectedUids();
747 if ( !uids.isEmpty() ) 747 if ( !uids.isEmpty() )
748 mailVCard( uids ); 748 mailVCard( uids );
749} 749}
750 750
751void KABCore::mailVCard( const QStringList& uids ) 751void KABCore::mailVCard( const QStringList& uids )
752{ 752{
753 QStringList urls; 753 QStringList urls;
754 754
755// QString tmpdir = locateLocal("tmp", KGlobal::getAppName()); 755// QString tmpdir = locateLocal("tmp", KGlobal::getAppName());
756 756
757 QString dirName = "/tmp/" + KApplication::randomString( 8 ); 757 QString dirName = "/tmp/" + KApplication::randomString( 8 );
758 758
759 759
760 760
761 QDir().mkdir( dirName, true ); 761 QDir().mkdir( dirName, true );
762 762
763 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) { 763 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) {
764 KABC::Addressee a = mAddressBook->findByUid( *it ); 764 KABC::Addressee a = mAddressBook->findByUid( *it );
765 765
766 if ( a.isEmpty() ) 766 if ( a.isEmpty() )
767 continue; 767 continue;
768 768
769 QString name = a.givenName() + "_" + a.familyName() + ".vcf"; 769 QString name = a.givenName() + "_" + a.familyName() + ".vcf";
770 770
771 QString fileName = dirName + "/" + name; 771 QString fileName = dirName + "/" + name;
772 772
773 QFile outFile(fileName); 773 QFile outFile(fileName);
774 774
775 if ( outFile.open(IO_WriteOnly) ) { // file opened successfully 775 if ( outFile.open(IO_WriteOnly) ) { // file opened successfully
776 KABC::VCardConverter converter; 776 KABC::VCardConverter converter;
777 QString vcard; 777 QString vcard;
778 778
779 converter.addresseeToVCard( a, vcard ); 779 converter.addresseeToVCard( a, vcard );
780 780
781 QTextStream t( &outFile ); // use a text stream 781 QTextStream t( &outFile ); // use a text stream
782 t.setEncoding( QTextStream::UnicodeUTF8 ); 782 t.setEncoding( QTextStream::UnicodeUTF8 );
783 t << vcard; 783 t << vcard;
784 784
785 outFile.close(); 785 outFile.close();
786 786
787 urls.append( fileName ); 787 urls.append( fileName );
788 } 788 }
789 } 789 }
790 790
791 bool result = ExternalAppHandler::instance()->mailToMultipleContacts( QString::null, urls.join(", ") ); 791 bool result = ExternalAppHandler::instance()->mailToMultipleContacts( QString::null, urls.join(", ") );
792 792
793 793
794/*US 794/*US
795 kapp->invokeMailer( QString::null, QString::null, QString::null, 795 kapp->invokeMailer( QString::null, QString::null, QString::null,
796 QString::null, // subject 796 QString::null, // subject
797 QString::null, // body 797 QString::null, // body
798 QString::null, 798 QString::null,
799 urls ); // attachments 799 urls ); // attachments
800*/ 800*/
801 801
802} 802}
803 803
804/** 804/**
805 Beams the "WhoAmI contact. 805 Beams the "WhoAmI contact.
806*/ 806*/
807void KABCore::beamMySelf() 807void KABCore::beamMySelf()
808{ 808{
809 KABC::Addressee a = KABC::StdAddressBook::self()->whoAmI(); 809 KABC::Addressee a = KABC::StdAddressBook::self()->whoAmI();
810 if (!a.isEmpty()) 810 if (!a.isEmpty())
811 { 811 {
812 QStringList uids; 812 QStringList uids;
813 uids << a.uid(); 813 uids << a.uid();
814 814
815 beamVCard(uids); 815 beamVCard(uids);
816 } else { 816 } else {
817 KMessageBox::information( this, i18n( "Your personal contact is\nnot set! Please select it\nand set it with menu:\nSettings - Set Who Am I\n" ) ); 817 KMessageBox::information( this, i18n( "Your personal contact is\nnot set! Please select it\nand set it with menu:\nSettings - Set Who Am I\n" ) );
818 818
819 819
820 } 820 }
821} 821}
822void KABCore::updateMainWindow() 822void KABCore::updateMainWindow()
823{ 823{
824 mMainWindow->showMaximized(); 824 mMainWindow->showMaximized();
825 mMainWindow->update(); 825 mMainWindow->update();
826} 826}
827void KABCore::resizeEvent(QResizeEvent* e ) 827void KABCore::resizeEvent(QResizeEvent* e )
828{ 828{
829 if ( !mMiniSplitter ) 829 if ( !mMiniSplitter )
830 return; 830 return;
831 //qDebug("KABCore::resizeEvent(QResizeEvent* e ) "); 831 //qDebug("KABCore::resizeEvent(QResizeEvent* e ) ");
832 if ( QApplication::desktop()->width() >= 480 ) { 832 if ( QApplication::desktop()->width() >= 480 ) {
833 if (QApplication::desktop()->width() == 640 ) { // e.g. 640x480 833 if (QApplication::desktop()->width() == 640 ) { // e.g. 640x480
834 if ( mMiniSplitter->orientation() == Qt::Vertical ) { 834 if ( mMiniSplitter->orientation() == Qt::Vertical ) {
835 mMiniSplitter->setOrientation( Qt::Horizontal); 835 mMiniSplitter->setOrientation( Qt::Horizontal);
836 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); 836 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right );
837 } 837 }
838 if ( QApplication::desktop()->width() <= 640 ) { 838 if ( QApplication::desktop()->width() <= 640 ) {
839 mMainWindow->showMinimized(); 839 mMainWindow->showMinimized();
840 //mMainWindow->setMaximumSize( QApplication::desktop()->size() ); 840 //mMainWindow->setMaximumSize( QApplication::desktop()->size() );
841 mViewManager->getFilterAction()->setComboWidth( 150 ); 841 mViewManager->getFilterAction()->setComboWidth( 150 );
842 if ( mIncSearchWidget ) 842 if ( mIncSearchWidget )
843 mIncSearchWidget->setSize(); 843 mIncSearchWidget->setSize();
844 QTimer::singleShot( 1, this , SLOT ( updateMainWindow())); 844 QTimer::singleShot( 1, this , SLOT ( updateMainWindow()));
845 } 845 }
846 846
847 } else if (QApplication::desktop()->width() == 480 ){// e.g. 480x640 847 } else if (QApplication::desktop()->width() == 480 ){// e.g. 480x640
848 if ( mMiniSplitter->orientation() == Qt::Horizontal ) { 848 if ( mMiniSplitter->orientation() == Qt::Horizontal ) {
849 mMiniSplitter->setOrientation( Qt::Vertical ); 849 mMiniSplitter->setOrientation( Qt::Vertical );
850 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); 850 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down );
851 } 851 }
852 if ( QApplication::desktop()->width() <= 640 ) { 852 if ( QApplication::desktop()->width() <= 640 ) {
853 //mMainWindow->setMaximumSize( QApplication::desktop()->size() ); 853 //mMainWindow->setMaximumSize( QApplication::desktop()->size() );
854 mMainWindow->showMinimized(); 854 mMainWindow->showMinimized();
855 if ( KABPrefs::instance()->mHideSearchOnSwitch ) { 855 if ( KABPrefs::instance()->mHideSearchOnSwitch ) {
856 if ( mIncSearchWidget ) { 856 if ( mIncSearchWidget ) {
857 mIncSearchWidget->setSize(); 857 mIncSearchWidget->setSize();
858 } 858 }
859 } else { 859 } else {
860 mViewManager->getFilterAction()->setComboWidth( 0 ); 860 mViewManager->getFilterAction()->setComboWidth( 0 );
861 } 861 }
862 QTimer::singleShot( 1, this , SLOT ( updateMainWindow())); 862 QTimer::singleShot( 1, this , SLOT ( updateMainWindow()));
863 } 863 }
864 } 864 }
865 } 865 }
866 QWidget::resizeEvent( e ); 866 QWidget::resizeEvent( e );
867 867
868} 868}
869void KABCore::export2phone() 869void KABCore::export2phone()
870{ 870{
871 871
872 QStringList uids; 872 QStringList uids;
873 XXPortSelectDialog dlg( this, false, this ); 873 XXPortSelectDialog dlg( this, false, this );
874 if ( dlg.exec() ) 874 if ( dlg.exec() )
875 uids = dlg.uids(); 875 uids = dlg.uids();
876 else 876 else
877 return; 877 return;
878 if ( uids.isEmpty() ) 878 if ( uids.isEmpty() )
879 return; 879 return;
880 // qDebug("count %d ", uids.count()); 880 // qDebug("count %d ", uids.count());
881 881
882 KAex2phonePrefs ex2phone; 882 KAex2phonePrefs ex2phone;
883 ex2phone.mPhoneConnection->setText( KPimGlobalPrefs::instance()->mEx2PhoneConnection ); 883 ex2phone.mPhoneConnection->setText( KPimGlobalPrefs::instance()->mEx2PhoneConnection );
884 ex2phone.mPhoneDevice->setText( KPimGlobalPrefs::instance()->mEx2PhoneDevice ); 884 ex2phone.mPhoneDevice->setText( KPimGlobalPrefs::instance()->mEx2PhoneDevice );
885 ex2phone.mPhoneModel->setText( KPimGlobalPrefs::instance()->mEx2PhoneModel ); 885 ex2phone.mPhoneModel->setText( KPimGlobalPrefs::instance()->mEx2PhoneModel );
886 886
887 if ( !ex2phone.exec() ) { 887 if ( !ex2phone.exec() ) {
888 return; 888 return;
889 } 889 }
890 KPimGlobalPrefs::instance()->mEx2PhoneConnection = ex2phone.mPhoneConnection->text(); 890 KPimGlobalPrefs::instance()->mEx2PhoneConnection = ex2phone.mPhoneConnection->text();
891 KPimGlobalPrefs::instance()->mEx2PhoneDevice = ex2phone.mPhoneDevice->text(); 891 KPimGlobalPrefs::instance()->mEx2PhoneDevice = ex2phone.mPhoneDevice->text();
892 KPimGlobalPrefs::instance()->mEx2PhoneModel = ex2phone.mPhoneModel->text(); 892 KPimGlobalPrefs::instance()->mEx2PhoneModel = ex2phone.mPhoneModel->text();
893 893
894 894
895 PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice, 895 PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice,
896 KPimGlobalPrefs::instance()->mEx2PhoneConnection, 896 KPimGlobalPrefs::instance()->mEx2PhoneConnection,
897 KPimGlobalPrefs::instance()->mEx2PhoneModel ); 897 KPimGlobalPrefs::instance()->mEx2PhoneModel );
898 898
899 QString fileName = getPhoneFile(); 899 QString fileName = getPhoneFile();
900 if ( ! mAddressBook->export2PhoneFormat( uids ,fileName ) ) 900 if ( ! mAddressBook->export2PhoneFormat( uids ,fileName ) )
901 return; 901 return;
902 902
903 message(i18n("Exporting to phone...")); 903 message(i18n("Exporting to phone..."));
904 QTimer::singleShot( 1, this , SLOT ( writeToPhone())); 904 QTimer::singleShot( 1, this , SLOT ( writeToPhone()));
905 905
906} 906}
907QString KABCore::getPhoneFile() 907QString KABCore::getPhoneFile()
908{ 908{
909#ifdef DESKTOP_VERSION 909#ifdef DESKTOP_VERSION
910 return locateLocal("tmp", "phonefile.vcf"); 910 return locateLocal("tmp", "phonefile.vcf");
911#else 911#else
912 return "/tmp/phonefile.vcf"; 912 return "/tmp/phonefile.vcf";
913#endif 913#endif
914 914
915} 915}
916void KABCore::writeToPhone( ) 916void KABCore::writeToPhone( )
917{ 917{
918 if ( PhoneAccess::writeToPhone( getPhoneFile() ) ) 918 if ( PhoneAccess::writeToPhone( getPhoneFile() ) )
919 message(i18n("Export to phone finished!")); 919 message(i18n("Export to phone finished!"));
920 else 920 else
921 qDebug(i18n("KA: Error exporting to phone")); 921 qDebug(i18n("KA: Error exporting to phone"));
922} 922}
923void KABCore::beamVCard() 923void KABCore::beamVCard()
924{ 924{
925 QStringList uids; 925 QStringList uids;
926 XXPortSelectDialog dlg( this, false, this ); 926 XXPortSelectDialog dlg( this, false, this );
927 if ( dlg.exec() ) 927 if ( dlg.exec() )
928 uids = dlg.uids(); 928 uids = dlg.uids();
929 else 929 else
930 return; 930 return;
931 if ( uids.isEmpty() ) 931 if ( uids.isEmpty() )
932 return; 932 return;
933 beamVCard( uids ); 933 beamVCard( uids );
934} 934}
935 935
936 936
937void KABCore::beamVCard(const QStringList& uids) 937void KABCore::beamVCard(const QStringList& uids)
938{ 938{
939 939
940 // LR: we should use the /tmp dir on the Zaurus, 940 // LR: we should use the /tmp dir on the Zaurus,
941 // because: /tmp = RAM, (HOME)/kdepim = flash memory 941 // because: /tmp = RAM, (HOME)/kdepim = flash memory
942 942
943#ifdef DESKTOP_VERSION 943#ifdef DESKTOP_VERSION
944 QString fileName = locateLocal("tmp", "kapibeamfile.vcf"); 944 QString fileName = locateLocal("tmp", "kapibeamfile.vcf");
945#else 945#else
946 QString fileName = "/tmp/kapibeamfile.vcf"; 946 QString fileName = "/tmp/kapibeamfile.vcf";
947#endif 947#endif
948 948
949 KABC::VCardConverter converter; 949 KABC::VCardConverter converter;
950 QString description; 950 QString description;
951 QString datastream; 951 QString datastream;
952 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) { 952 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) {
953 KABC::Addressee a = mAddressBook->findByUid( *it ); 953 KABC::Addressee a = mAddressBook->findByUid( *it );
954 954
955 if ( a.isEmpty() ) 955 if ( a.isEmpty() )
956 continue; 956 continue;
957 957
958 if (description.isEmpty()) 958 if (description.isEmpty())
959 description = a.formattedName(); 959 description = a.formattedName();
960 960
961 QString vcard; 961 QString vcard;
962 converter.addresseeToVCard( a, vcard ); 962 converter.addresseeToVCard( a, vcard );
963 int start = 0; 963 int start = 0;
964 int next; 964 int next;
965 while ( (next = vcard.find("TYPE=", start) )>= 0 ) { 965 while ( (next = vcard.find("TYPE=", start) )>= 0 ) {
966 int semi = vcard.find(";", next); 966 int semi = vcard.find(";", next);
967 int dopp = vcard.find(":", next); 967 int dopp = vcard.find(":", next);
968 int sep; 968 int sep;
969 if ( semi < dopp && semi >= 0 ) 969 if ( semi < dopp && semi >= 0 )
970 sep = semi ; 970 sep = semi ;
971 else 971 else
972 sep = dopp; 972 sep = dopp;
973 datastream +=vcard.mid( start, next - start); 973 datastream +=vcard.mid( start, next - start);
974 datastream +=vcard.mid( next+5,sep -next -5 ).upper(); 974 datastream +=vcard.mid( next+5,sep -next -5 ).upper();
975 start = sep; 975 start = sep;
976 } 976 }
977 datastream += vcard.mid( start,vcard.length() ); 977 datastream += vcard.mid( start,vcard.length() );
978 } 978 }
979#ifndef DESKTOP_VERSION 979#ifndef DESKTOP_VERSION
980 QFile outFile(fileName); 980 QFile outFile(fileName);
981 if ( outFile.open(IO_WriteOnly) ) { 981 if ( outFile.open(IO_WriteOnly) ) {
982 datastream.replace ( QRegExp("VERSION:3.0") , "VERSION:2.1" ); 982 datastream.replace ( QRegExp("VERSION:3.0") , "VERSION:2.1" );
983 QTextStream t( &outFile ); // use a text stream 983 QTextStream t( &outFile ); // use a text stream
984 //t.setEncoding( QTextStream::UnicodeUTF8 ); 984 //t.setEncoding( QTextStream::UnicodeUTF8 );
985 t.setEncoding( QTextStream::Latin1 ); 985 t.setEncoding( QTextStream::Latin1 );
986 t <<datastream.latin1(); 986 t <<datastream.latin1();
987 outFile.close(); 987 outFile.close();
988 Ir *ir = new Ir( this ); 988 Ir *ir = new Ir( this );
989 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) ); 989 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) );
990 ir->send( fileName, description, "text/x-vCard" ); 990 ir->send( fileName, description, "text/x-vCard" );
991 } else { 991 } else {
992 qDebug("KA: Error open temp beam file "); 992 qDebug("KA: Error open temp beam file ");
993 return; 993 return;
994 } 994 }
995#endif 995#endif
996 996
997} 997}
998 998
999void KABCore::beamDone( Ir *ir ) 999void KABCore::beamDone( Ir *ir )
1000{ 1000{
1001#ifndef DESKTOP_VERSION 1001#ifndef DESKTOP_VERSION
1002 delete ir; 1002 delete ir;
1003#endif 1003#endif
1004 topLevelWidget()->raise(); 1004 topLevelWidget()->raise();
1005 message( i18n("Beaming finished!") ); 1005 message( i18n("Beaming finished!") );
1006} 1006}
1007 1007
1008 1008
1009void KABCore::browse( const QString& url ) 1009void KABCore::browse( const QString& url )
1010{ 1010{
1011#ifndef KAB_EMBEDDED 1011#ifndef KAB_EMBEDDED
1012 kapp->invokeBrowser( url ); 1012 kapp->invokeBrowser( url );
1013#else //KAB_EMBEDDED 1013#else //KAB_EMBEDDED
1014 qDebug("KABCore::browse must be fixed"); 1014 qDebug("KABCore::browse must be fixed");
1015#endif //KAB_EMBEDDED 1015#endif //KAB_EMBEDDED
1016} 1016}
1017 1017
1018void KABCore::selectAllContacts() 1018void KABCore::selectAllContacts()
1019{ 1019{
1020 mViewManager->setSelected( QString::null, true ); 1020 mViewManager->setSelected( QString::null, true );
1021} 1021}
1022 1022
1023void KABCore::deleteContacts() 1023void KABCore::deleteContacts()
1024{ 1024{
1025 QStringList uidList = mViewManager->selectedUids(); 1025 QStringList uidList = mViewManager->selectedUids();
1026 deleteContacts( uidList ); 1026 deleteContacts( uidList );
1027} 1027}
1028 1028
1029void KABCore::deleteContacts( const QStringList &uids ) 1029void KABCore::deleteContacts( const QStringList &uids )
1030{ 1030{
1031 if ( uids.count() > 0 ) { 1031 if ( uids.count() > 0 ) {
1032 PwDeleteCommand *command = new PwDeleteCommand( mAddressBook, uids ); 1032 PwDeleteCommand *command = new PwDeleteCommand( mAddressBook, uids );
1033 UndoStack::instance()->push( command ); 1033 UndoStack::instance()->push( command );
1034 RedoStack::instance()->clear(); 1034 RedoStack::instance()->clear();
1035 1035
1036 // now if we deleted anything, refresh 1036 // now if we deleted anything, refresh
1037 setContactSelected( QString::null ); 1037 setContactSelected( QString::null );
1038 setModified( true ); 1038 setModified( true );
1039 } 1039 }
1040} 1040}
1041 1041
1042void KABCore::copyContacts() 1042void KABCore::copyContacts()
1043{ 1043{
1044 KABC::Addressee::List addrList = mViewManager->selectedAddressees(); 1044 KABC::Addressee::List addrList = mViewManager->selectedAddressees();
1045 1045
1046 QString clipText = AddresseeUtil::addresseesToClipboard( addrList ); 1046 QString clipText = AddresseeUtil::addresseesToClipboard( addrList );
1047 1047
1048 kdDebug(5720) << "KABCore::copyContacts: " << clipText << endl; 1048 kdDebug(5720) << "KABCore::copyContacts: " << clipText << endl;
1049 1049
1050 QClipboard *cb = QApplication::clipboard(); 1050 QClipboard *cb = QApplication::clipboard();
1051 cb->setText( clipText ); 1051 cb->setText( clipText );
1052} 1052}
1053 1053
1054void KABCore::cutContacts() 1054void KABCore::cutContacts()
1055{ 1055{
1056 QStringList uidList = mViewManager->selectedUids(); 1056 QStringList uidList = mViewManager->selectedUids();
1057 1057
1058//US if ( uidList.size() > 0 ) { 1058//US if ( uidList.size() > 0 ) {
1059 if ( uidList.count() > 0 ) { 1059 if ( uidList.count() > 0 ) {
1060 PwCutCommand *command = new PwCutCommand( mAddressBook, uidList ); 1060 PwCutCommand *command = new PwCutCommand( mAddressBook, uidList );
1061 UndoStack::instance()->push( command ); 1061 UndoStack::instance()->push( command );
1062 RedoStack::instance()->clear(); 1062 RedoStack::instance()->clear();
1063 1063
1064 setModified( true ); 1064 setModified( true );
1065 } 1065 }
1066} 1066}
1067 1067
1068void KABCore::pasteContacts() 1068void KABCore::pasteContacts()
1069{ 1069{
1070 QClipboard *cb = QApplication::clipboard(); 1070 QClipboard *cb = QApplication::clipboard();
1071 1071
1072 KABC::Addressee::List list = AddresseeUtil::clipboardToAddressees( cb->text() ); 1072 KABC::Addressee::List list = AddresseeUtil::clipboardToAddressees( cb->text() );
1073 1073
1074 pasteContacts( list ); 1074 pasteContacts( list );
1075} 1075}
1076 1076
1077void KABCore::pasteContacts( KABC::Addressee::List &list ) 1077void KABCore::pasteContacts( KABC::Addressee::List &list )
1078{ 1078{
1079 KABC::Resource *resource = requestResource( this ); 1079 KABC::Resource *resource = requestResource( this );
1080 KABC::Addressee::List::Iterator it; 1080 KABC::Addressee::List::Iterator it;
1081 for ( it = list.begin(); it != list.end(); ++it ) 1081 for ( it = list.begin(); it != list.end(); ++it )
1082 (*it).setResource( resource ); 1082 (*it).setResource( resource );
1083 1083
1084 PwPasteCommand *command = new PwPasteCommand( this, list ); 1084 PwPasteCommand *command = new PwPasteCommand( this, list );
1085 UndoStack::instance()->push( command ); 1085 UndoStack::instance()->push( command );
1086 RedoStack::instance()->clear(); 1086 RedoStack::instance()->clear();
1087 1087
1088 setModified( true ); 1088 setModified( true );
1089} 1089}
1090 1090
1091void KABCore::setWhoAmI() 1091void KABCore::setWhoAmI()
1092{ 1092{
1093 KABC::Addressee::List addrList = mViewManager->selectedAddressees(); 1093 KABC::Addressee::List addrList = mViewManager->selectedAddressees();
1094 1094
1095 if ( addrList.count() > 1 ) { 1095 if ( addrList.count() > 1 ) {
1096 KMessageBox::sorry( this, i18n( "Please select only one contact." ) ); 1096 KMessageBox::sorry( this, i18n( "Please select only one contact." ) );
1097 return; 1097 return;
1098 } 1098 }
1099 1099
1100 QString text( i18n( "<qt>Do you really want to use <b>%1</b> as your new personal contact?</qt>" ) ); 1100 QString text( i18n( "<qt>Do you really want to use <b>%1</b> as your new personal contact?</qt>" ) );
1101 if ( KMessageBox::questionYesNo( this, text.arg( addrList[ 0 ].assembledName() ) ) == KMessageBox::Yes ) 1101 if ( KMessageBox::questionYesNo( this, text.arg( addrList[ 0 ].assembledName() ) ) == KMessageBox::Yes )
1102 static_cast<KABC::StdAddressBook*>( KABC::StdAddressBook::self() )->setWhoAmI( addrList[ 0 ] ); 1102 static_cast<KABC::StdAddressBook*>( KABC::StdAddressBook::self() )->setWhoAmI( addrList[ 0 ] );
1103} 1103}
1104void KABCore::editCategories() 1104void KABCore::editCategories()
1105{ 1105{
1106 KPIM::CategoryEditDialog dlg ( KABPrefs::instance(), this, "", true ); 1106 KPIM::CategoryEditDialog dlg ( KABPrefs::instance(), this, "", true );
1107 dlg.exec(); 1107 dlg.exec();
1108} 1108}
1109void KABCore::setCategories() 1109void KABCore::setCategories()
1110{ 1110{
1111 1111
1112 QStringList uids; 1112 QStringList uids;
1113 XXPortSelectDialog dlgx( this, false, this ); 1113 XXPortSelectDialog dlgx( this, false, this );
1114 if ( dlgx.exec() ) 1114 if ( dlgx.exec() )
1115 uids = dlgx.uids(); 1115 uids = dlgx.uids();
1116 else 1116 else
1117 return; 1117 return;
1118 if ( uids.isEmpty() ) 1118 if ( uids.isEmpty() )
1119 return; 1119 return;
1120 // qDebug("count %d ", uids.count()); 1120 // qDebug("count %d ", uids.count());
1121 1121
1122 1122
1123 KPIM::CategorySelectDialog dlg( KABPrefs::instance(), this, "", true ); 1123 KPIM::CategorySelectDialog dlg( KABPrefs::instance(), this, "", true );
1124 if ( !dlg.exec() ) { 1124 if ( !dlg.exec() ) {
1125 message( i18n("Setting categories cancelled") ); 1125 message( i18n("Setting categories cancelled") );
1126 return; 1126 return;
1127 } 1127 }
1128 bool merge = false; 1128 bool merge = false;
1129 QString msg = i18n( "Merge with existing categories?" ); 1129 QString msg = i18n( "Merge with existing categories?" );
1130 if ( KMessageBox::questionYesNo( this, msg ) == KMessageBox::Yes ) 1130 if ( KMessageBox::questionYesNo( this, msg ) == KMessageBox::Yes )
1131 merge = true; 1131 merge = true;
1132 1132
1133 message( i18n("Setting categories ... please wait!") ); 1133 message( i18n("Setting categories ... please wait!") );
1134 QStringList categories = dlg.selectedCategories(); 1134 QStringList categories = dlg.selectedCategories();
1135 1135
1136 //QStringList uids = mViewManager->selectedUids(); 1136 //QStringList uids = mViewManager->selectedUids();
1137 QStringList::Iterator it; 1137 QStringList::Iterator it;
1138 for ( it = uids.begin(); it != uids.end(); ++it ) { 1138 for ( it = uids.begin(); it != uids.end(); ++it ) {
1139 KABC::Addressee addr = mAddressBook->findByUid( *it ); 1139 KABC::Addressee addr = mAddressBook->findByUid( *it );
1140 if ( !addr.isEmpty() ) { 1140 if ( !addr.isEmpty() ) {
1141 if ( !merge ) 1141 if ( !merge )
1142 addr.setCategories( categories ); 1142 addr.setCategories( categories );
1143 else { 1143 else {
1144 QStringList addrCategories = addr.categories(); 1144 QStringList addrCategories = addr.categories();
1145 QStringList::Iterator catIt; 1145 QStringList::Iterator catIt;
1146 for ( catIt = categories.begin(); catIt != categories.end(); ++catIt ) { 1146 for ( catIt = categories.begin(); catIt != categories.end(); ++catIt ) {
1147 if ( !addrCategories.contains( *catIt ) ) 1147 if ( !addrCategories.contains( *catIt ) )
1148 addrCategories.append( *catIt ); 1148 addrCategories.append( *catIt );
1149 } 1149 }
1150 addr.setCategories( addrCategories ); 1150 addr.setCategories( addrCategories );
1151 } 1151 }
1152 mAddressBook->insertAddressee( addr ); 1152 mAddressBook->insertAddressee( addr );
1153 } 1153 }
1154 } 1154 }
1155 1155
1156 if ( uids.count() > 0 ) 1156 if ( uids.count() > 0 )
1157 setModified( true ); 1157 setModified( true );
1158 message( i18n("Setting categories completed!") ); 1158 message( i18n("Setting categories completed!") );
1159} 1159}
1160 1160
1161void KABCore::setSearchFields( const KABC::Field::List &fields ) 1161void KABCore::setSearchFields( const KABC::Field::List &fields )
1162{ 1162{
1163 mIncSearchWidget->setFields( fields ); 1163 mIncSearchWidget->setFields( fields );
1164} 1164}
1165 1165
1166void KABCore::incrementalSearch( const QString& text ) 1166void KABCore::incrementalSearch( const QString& text )
1167{ 1167{
1168 QString stext; 1168 QString stext;
1169 if ( KABPrefs::instance()->mAutoSearchWithWildcard ) { 1169 if ( KABPrefs::instance()->mAutoSearchWithWildcard ) {
1170 stext = "*" + text; 1170 stext = "*" + text;
1171 } else { 1171 } else {
1172 stext = text; 1172 stext = text;
1173 } 1173 }
1174 mViewManager->doSearch( stext, mIncSearchWidget->currentField() ); 1174 mViewManager->doSearch( stext, mIncSearchWidget->currentField() );
1175} 1175}
1176void KABCore::incrementalSearchJump( const QString& text ) 1176void KABCore::incrementalSearchJump( const QString& text )
1177{ 1177{
1178 mViewManager->doSearch( text, mIncSearchWidget->currentField() ); 1178 mViewManager->doSearch( text, mIncSearchWidget->currentField() );
1179} 1179}
1180 1180
1181void KABCore::setModified() 1181void KABCore::setModified()
1182{ 1182{
1183 setModified( true ); 1183 setModified( true );
1184} 1184}
1185 1185
1186void KABCore::setModifiedWOrefresh() 1186void KABCore::setModifiedWOrefresh()
1187{ 1187{
1188 // qDebug("KABCore::setModifiedWOrefresh() "); 1188 // qDebug("KABCore::setModifiedWOrefresh() ");
1189 mModified = true; 1189 mModified = true;
1190 mActionSave->setEnabled( mModified ); 1190 mActionSave->setEnabled( mModified );
1191 1191
1192 1192
1193} 1193}
1194void KABCore::setModified( bool modified ) 1194void KABCore::setModified( bool modified )
1195{ 1195{
1196 mModified = modified; 1196 mModified = modified;
1197 mActionSave->setEnabled( mModified ); 1197 mActionSave->setEnabled( mModified );
1198 1198
1199 if ( modified ) 1199 if ( modified )
1200 mJumpButtonBar->recreateButtons(); 1200 mJumpButtonBar->recreateButtons();
1201 1201
1202 mViewManager->refreshView(); 1202 mViewManager->refreshView();
1203 1203
1204} 1204}
1205 1205
1206bool KABCore::modified() const 1206bool KABCore::modified() const
1207{ 1207{
1208 return mModified; 1208 return mModified;
1209} 1209}
1210 1210
1211void KABCore::contactModified( const KABC::Addressee &addr ) 1211void KABCore::contactModified( const KABC::Addressee &addr )
1212{ 1212{
1213 addrModified( addr ); 1213 addrModified( addr );
1214#if 0 // debug only 1214#if 0 // debug only
1215 KABC::Addressee ad = addr; 1215 KABC::Addressee ad = addr;
1216 ad.computeCsum( "123"); 1216 ad.computeCsum( "123");
1217#endif 1217#endif
1218} 1218}
1219 1219
1220void KABCore::addrModified( const KABC::Addressee &addr ,bool updateDetails ) 1220void KABCore::addrModified( const KABC::Addressee &addr ,bool updateDetails )
1221{ 1221{
1222 1222
1223 Command *command = 0; 1223 Command *command = 0;
1224 QString uid; 1224 QString uid;
1225 1225
1226 // check if it exists already 1226 // check if it exists already
1227 KABC::Addressee origAddr = mAddressBook->findByUid( addr.uid() ); 1227 KABC::Addressee origAddr = mAddressBook->findByUid( addr.uid() );
1228 if ( origAddr.isEmpty() ) 1228 if ( origAddr.isEmpty() )
1229 command = new PwNewCommand( mAddressBook, addr ); 1229 command = new PwNewCommand( mAddressBook, addr );
1230 else { 1230 else {
1231 command = new PwEditCommand( mAddressBook, origAddr, addr ); 1231 command = new PwEditCommand( mAddressBook, origAddr, addr );
1232 uid = addr.uid(); 1232 uid = addr.uid();
1233 } 1233 }
1234 1234
1235 UndoStack::instance()->push( command ); 1235 UndoStack::instance()->push( command );
1236 RedoStack::instance()->clear(); 1236 RedoStack::instance()->clear();
1237 if ( updateDetails ) 1237 if ( updateDetails )
1238 mDetails->setAddressee( addr ); 1238 mDetails->setAddressee( addr );
1239 setModified( true ); 1239 setModified( true );
1240} 1240}
1241 1241
1242void KABCore::newContact() 1242void KABCore::newContact()
1243{ 1243{
1244 1244
1245 1245
1246 QPtrList<KABC::Resource> kabcResources = mAddressBook->resources(); 1246 QPtrList<KABC::Resource> kabcResources = mAddressBook->resources();
1247 1247
1248 QPtrList<KRES::Resource> kresResources; 1248 QPtrList<KRES::Resource> kresResources;
1249 QPtrListIterator<KABC::Resource> it( kabcResources ); 1249 QPtrListIterator<KABC::Resource> it( kabcResources );
1250 KABC::Resource *resource; 1250 KABC::Resource *resource;
1251 while ( ( resource = it.current() ) != 0 ) { 1251 while ( ( resource = it.current() ) != 0 ) {
1252 ++it; 1252 ++it;
1253 if ( !resource->readOnly() ) { 1253 if ( !resource->readOnly() ) {
1254 KRES::Resource *res = static_cast<KRES::Resource*>( resource ); 1254 KRES::Resource *res = static_cast<KRES::Resource*>( resource );
1255 if ( res ) 1255 if ( res )
1256 kresResources.append( res ); 1256 kresResources.append( res );
1257 } 1257 }
1258 } 1258 }
1259 1259
1260 KRES::Resource *res = KRES::SelectDialog::getResource( kresResources, this ); 1260 KRES::Resource *res = KRES::SelectDialog::getResource( kresResources, this );
1261 resource = static_cast<KABC::Resource*>( res ); 1261 resource = static_cast<KABC::Resource*>( res );
1262 1262
1263 if ( resource ) { 1263 if ( resource ) {
1264 KABC::Addressee addr; 1264 KABC::Addressee addr;
1265 addr.setResource( resource ); 1265 addr.setResource( resource );
1266 mEditorDialog->setAddressee( addr ); 1266 mEditorDialog->setAddressee( addr );
1267 mEditorDialog->setCaption( i18n("Edit new contact")); 1267 mEditorDialog->setCaption( i18n("Edit new contact"));
1268 KApplication::execDialog ( mEditorDialog ); 1268 KApplication::execDialog ( mEditorDialog );
1269 1269
1270 } else 1270 } else
1271 return; 1271 return;
1272 1272
1273 // mEditorDict.insert( dialog->addressee().uid(), dialog ); 1273 // mEditorDict.insert( dialog->addressee().uid(), dialog );
1274 1274
1275 1275
1276} 1276}
1277 1277
1278void KABCore::addEmail( QString aStr ) 1278void KABCore::addEmail( QString aStr )
1279{ 1279{
1280#ifndef KAB_EMBEDDED 1280#ifndef KAB_EMBEDDED
1281 QString fullName, email; 1281 QString fullName, email;
1282 1282
1283 KABC::Addressee::parseEmailAddress( aStr, fullName, email ); 1283 KABC::Addressee::parseEmailAddress( aStr, fullName, email );
1284 1284
1285 // Try to lookup the addressee matching the email address 1285 // Try to lookup the addressee matching the email address
1286 bool found = false; 1286 bool found = false;
1287 QStringList emailList; 1287 QStringList emailList;
1288 KABC::AddressBook::Iterator it; 1288 KABC::AddressBook::Iterator it;
1289 for ( it = mAddressBook->begin(); !found && (it != mAddressBook->end()); ++it ) { 1289 for ( it = mAddressBook->begin(); !found && (it != mAddressBook->end()); ++it ) {
1290 emailList = (*it).emails(); 1290 emailList = (*it).emails();
1291 if ( emailList.contains( email ) > 0 ) { 1291 if ( emailList.contains( email ) > 0 ) {
1292 found = true; 1292 found = true;
1293 (*it).setNameFromString( fullName ); 1293 (*it).setNameFromString( fullName );
1294 editContact( (*it).uid() ); 1294 editContact( (*it).uid() );
1295 } 1295 }
1296 } 1296 }
1297 1297
1298 if ( !found ) { 1298 if ( !found ) {
1299 KABC::Addressee addr; 1299 KABC::Addressee addr;
1300 addr.setNameFromString( fullName ); 1300 addr.setNameFromString( fullName );
1301 addr.insertEmail( email, true ); 1301 addr.insertEmail( email, true );
1302 1302
1303 mAddressBook->insertAddressee( addr ); 1303 mAddressBook->insertAddressee( addr );
1304 mViewManager->refreshView( addr.uid() ); 1304 mViewManager->refreshView( addr.uid() );
1305 editContact( addr.uid() ); 1305 editContact( addr.uid() );
1306 } 1306 }
1307#else //KAB_EMBEDDED 1307#else //KAB_EMBEDDED
1308 qDebug("KABCore::addEmail finsih method"); 1308 qDebug("KABCore::addEmail finsih method");
1309#endif //KAB_EMBEDDED 1309#endif //KAB_EMBEDDED
1310} 1310}
1311 1311
1312void KABCore::importVCard( const KURL &url, bool showPreview ) 1312void KABCore::importVCard( const KURL &url, bool showPreview )
1313{ 1313{
1314 mXXPortManager->importVCard( url, showPreview ); 1314 mXXPortManager->importVCard( url, showPreview );
1315} 1315}
1316void KABCore::importFromOL() 1316void KABCore::importFromOL()
1317{ 1317{
1318#ifdef _OL_IMPORT_ 1318#ifdef _OL_IMPORT_
1319 KAImportOLdialog* idgl = new KAImportOLdialog( i18n("Import Contacts from OL"), mAddressBook, this ); 1319 KAImportOLdialog* idgl = new KAImportOLdialog( i18n("Import Contacts from OL"), mAddressBook, this );
1320 idgl->exec(); 1320 idgl->exec();
1321 KABC::Addressee::List list = idgl->getAddressList(); 1321 KABC::Addressee::List list = idgl->getAddressList();
1322 if ( list.count() > 0 ) { 1322 if ( list.count() > 0 ) {
1323 KABC::Addressee::List listNew; 1323 KABC::Addressee::List listNew;
1324 KABC::Addressee::List listExisting; 1324 KABC::Addressee::List listExisting;
1325 KABC::Addressee::List::Iterator it; 1325 KABC::Addressee::List::Iterator it;
1326 KABC::AddressBook::Iterator iter; 1326 KABC::AddressBook::Iterator iter;
1327 for ( it = list.begin(); it != list.end(); ++it ) { 1327 for ( it = list.begin(); it != list.end(); ++it ) {
1328 if ( mAddressBook->findByUid((*it).uid() ).isEmpty()) 1328 if ( mAddressBook->findByUid((*it).uid() ).isEmpty())
1329 listNew.append( (*it) ); 1329 listNew.append( (*it) );
1330 else 1330 else
1331 listExisting.append( (*it) ); 1331 listExisting.append( (*it) );
1332 } 1332 }
1333 if ( listExisting.count() > 0 ) 1333 if ( listExisting.count() > 0 )
1334 KMessageBox::information( this, i18n("%1 contacts not added to addressbook\nbecause they were already in the addressbook!").arg( listExisting.count() )); 1334 KMessageBox::information( this, i18n("%1 contacts not added to addressbook\nbecause they were already in the addressbook!").arg( listExisting.count() ));
1335 if ( listNew.count() > 0 ) { 1335 if ( listNew.count() > 0 ) {
1336 pasteWithNewUid = false; 1336 pasteWithNewUid = false;
1337 pasteContacts( listNew ); 1337 pasteContacts( listNew );
1338 pasteWithNewUid = true; 1338 pasteWithNewUid = true;
1339 } 1339 }
1340 } 1340 }
1341 delete idgl; 1341 delete idgl;
1342#endif 1342#endif
1343} 1343}
1344 1344
1345void KABCore::importVCard( const QString &vCard, bool showPreview ) 1345void KABCore::importVCard( const QString &vCard, bool showPreview )
1346{ 1346{
1347 mXXPortManager->importVCard( vCard, showPreview ); 1347 mXXPortManager->importVCard( vCard, showPreview );
1348} 1348}
1349 1349
1350//US added a second method without defaultparameter 1350//US added a second method without defaultparameter
1351void KABCore::editContact2() { 1351void KABCore::editContact2() {
1352 editContact( QString::null ); 1352 editContact( QString::null );
1353} 1353}
1354 1354
1355void KABCore::editContact( const QString &uid ) 1355void KABCore::editContact( const QString &uid )
1356{ 1356{
1357 1357
1358 if ( mExtensionManager->isQuickEditVisible() ) 1358 if ( mExtensionManager->isQuickEditVisible() )
1359 return; 1359 return;
1360 1360
1361 // First, locate the contact entry 1361 // First, locate the contact entry
1362 QString localUID = uid; 1362 QString localUID = uid;
1363 if ( localUID.isNull() ) { 1363 if ( localUID.isNull() ) {
1364 QStringList uidList = mViewManager->selectedUids(); 1364 QStringList uidList = mViewManager->selectedUids();
1365 if ( uidList.count() > 0 ) 1365 if ( uidList.count() > 0 )
1366 localUID = *( uidList.at( 0 ) ); 1366 localUID = *( uidList.at( 0 ) );
1367 } 1367 }
1368 1368
1369 KABC::Addressee addr = mAddressBook->findByUid( localUID ); 1369 KABC::Addressee addr = mAddressBook->findByUid( localUID );
1370 if ( !addr.isEmpty() ) { 1370 if ( !addr.isEmpty() ) {
1371 mEditorDialog->setAddressee( addr ); 1371 mEditorDialog->setAddressee( addr );
1372 KApplication::execDialog ( mEditorDialog ); 1372 KApplication::execDialog ( mEditorDialog );
1373 } 1373 }
1374} 1374}
1375 1375
1376/** 1376/**
1377 Shows or edits the detail view for the given uid. If the uid is QString::null, 1377 Shows or edits the detail view for the given uid. If the uid is QString::null,
1378 the method will try to find a selected addressee in the view. 1378 the method will try to find a selected addressee in the view.
1379 */ 1379 */
1380void KABCore::executeContact( const QString &uid /*US = QString::null*/ ) 1380void KABCore::executeContact( const QString &uid /*US = QString::null*/ )
1381{ 1381{
1382 if ( mMultipleViewsAtOnce ) 1382 if ( mMultipleViewsAtOnce )
1383 { 1383 {
1384 editContact( uid ); 1384 editContact( uid );
1385 } 1385 }
1386 else 1386 else
1387 { 1387 {
1388 setDetailsVisible( true ); 1388 setDetailsVisible( true );
1389 mActionDetails->setChecked(true); 1389 mActionDetails->setChecked(true);
1390 } 1390 }
1391 1391
1392} 1392}
1393 1393
1394void KABCore::save() 1394void KABCore::save()
1395{ 1395{
1396 if (syncManager->blockSave()) 1396 if (syncManager->blockSave())
1397 return; 1397 return;
1398 if ( !mModified ) 1398 if ( !mModified )
1399 return; 1399 return;
1400 1400
1401 syncManager->setBlockSave(true); 1401 syncManager->setBlockSave(true);
1402 QString text = i18n( "There was an error while attempting to save\n the " 1402 QString text = i18n( "There was an error while attempting to save\n the "
1403 "address book. Please check that some \nother application is " 1403 "address book. Please check that some \nother application is "
1404 "not using it. " ); 1404 "not using it. " );
1405 message(i18n("Saving ... please wait! "), false); 1405 message(i18n("Saving ... please wait! "), false);
1406 //qApp->processEvents(); 1406 //qApp->processEvents();
1407#ifndef KAB_EMBEDDED 1407#ifndef KAB_EMBEDDED
1408 KABC::StdAddressBook *b = dynamic_cast<KABC::StdAddressBook*>( mAddressBook ); 1408 KABC::StdAddressBook *b = dynamic_cast<KABC::StdAddressBook*>( mAddressBook );
1409 if ( !b || !b->save() ) { 1409 if ( !b || !b->save() ) {
1410 KMessageBox::error( this, text, i18n( "Unable to Save" ) ); 1410 KMessageBox::error( this, text, i18n( "Unable to Save" ) );
1411 } 1411 }
1412#else //KAB_EMBEDDED 1412#else //KAB_EMBEDDED
1413 KABC::StdAddressBook *b = (KABC::StdAddressBook*)( mAddressBook ); 1413 KABC::StdAddressBook *b = (KABC::StdAddressBook*)( mAddressBook );
1414 if ( !b || !b->save() ) { 1414 if ( !b || !b->save() ) {
1415 QMessageBox::critical( this, i18n( "Unable to Save" ), text, i18n("Ok")); 1415 QMessageBox::critical( this, i18n( "Unable to Save" ), text, i18n("Ok"));
1416 } 1416 }
1417#endif //KAB_EMBEDDED 1417#endif //KAB_EMBEDDED
1418 1418
1419 message(i18n("Addressbook saved!")); 1419 message(i18n("Addressbook saved!"));
1420 setModified( false ); 1420 setModified( false );
1421 syncManager->setBlockSave(false); 1421 syncManager->setBlockSave(false);
1422} 1422}
1423 1423
1424 1424
1425void KABCore::undo() 1425void KABCore::undo()
1426{ 1426{
1427 UndoStack::instance()->undo(); 1427 UndoStack::instance()->undo();
1428 1428
1429 // Refresh the view 1429 // Refresh the view
1430 mViewManager->refreshView(); 1430 mViewManager->refreshView();
1431} 1431}
1432 1432
1433void KABCore::redo() 1433void KABCore::redo()
1434{ 1434{
1435 RedoStack::instance()->redo(); 1435 RedoStack::instance()->redo();
1436 1436
1437 // Refresh the view 1437 // Refresh the view
1438 mViewManager->refreshView(); 1438 mViewManager->refreshView();
1439} 1439}
1440void KABCore::setJumpButtonBar( bool visible ) 1440void KABCore::setJumpButtonBar( bool visible )
1441{ 1441{
1442 setJumpButtonBarVisible(visible ); 1442 setJumpButtonBarVisible(visible );
1443 saveSettings(); 1443 saveSettings();
1444} 1444}
1445void KABCore::setJumpButtonBarVisible( bool visible ) 1445void KABCore::setJumpButtonBarVisible( bool visible )
1446{ 1446{
1447 if (mMultipleViewsAtOnce) 1447 if (mMultipleViewsAtOnce)
1448 { 1448 {
1449 if ( visible ) 1449 if ( visible )
1450 mJumpButtonBar->show(); 1450 mJumpButtonBar->show();
1451 else 1451 else
1452 mJumpButtonBar->hide(); 1452 mJumpButtonBar->hide();
1453 } 1453 }
1454 else 1454 else
1455 { 1455 {
1456 // show the jumpbar only if "the details are hidden" == "viewmanager are shown" 1456 // show the jumpbar only if "the details are hidden" == "viewmanager are shown"
1457 if (mViewManager->isVisible()) 1457 if (mViewManager->isVisible())
1458 { 1458 {
1459 if ( visible ) 1459 if ( visible )
1460 mJumpButtonBar->show(); 1460 mJumpButtonBar->show();
1461 else 1461 else
1462 mJumpButtonBar->hide(); 1462 mJumpButtonBar->hide();
1463 } 1463 }
1464 else 1464 else
1465 { 1465 {
1466 mJumpButtonBar->hide(); 1466 mJumpButtonBar->hide();
1467 } 1467 }
1468 } 1468 }
1469 if ( visible ) { 1469 if ( visible ) {
1470 if ( mIncSearchWidget->currentItem() == 0 ) { 1470 if ( mIncSearchWidget->currentItem() == 0 ) {
1471 message( i18n("Change search field enable jump bar") ); 1471 message( i18n("Change search field enable jump bar") );
1472 } 1472 }
1473 } 1473 }
1474} 1474}
1475 1475
1476 1476
1477void KABCore::setDetailsToState() 1477void KABCore::setDetailsToState()
1478{ 1478{
1479 setDetailsVisible( mActionDetails->isChecked() ); 1479 setDetailsVisible( mActionDetails->isChecked() );
1480} 1480}
1481void KABCore::setDetailsToggle() 1481void KABCore::setDetailsToggle()
1482{ 1482{
1483 mActionDetails->setChecked( !mActionDetails->isChecked() ); 1483 mActionDetails->setChecked( !mActionDetails->isChecked() );
1484 setDetailsToState(); 1484 setDetailsToState();
1485} 1485}
1486 1486
1487 1487
1488 1488
1489void KABCore::setDetailsVisible( bool visible ) 1489void KABCore::setDetailsVisible( bool visible )
1490{ 1490{
1491 if (visible && mDetails->isHidden()) 1491 if (visible && mDetails->isHidden())
1492 { 1492 {
1493 KABC::Addressee::List addrList = mViewManager->selectedAddressees(); 1493 KABC::Addressee::List addrList = mViewManager->selectedAddressees();
1494 if ( addrList.count() > 0 ) 1494 if ( addrList.count() > 0 )
1495 mDetails->setAddressee( addrList[ 0 ] ); 1495 mDetails->setAddressee( addrList[ 0 ] );
1496 } 1496 }
1497 1497
1498 // mMultipleViewsAtOnce=false: mDetails is always visible. But we switch between 1498 // mMultipleViewsAtOnce=false: mDetails is always visible. But we switch between
1499 // the listview and the detailview. We do that by changing the splitbar size. 1499 // the listview and the detailview. We do that by changing the splitbar size.
1500 if (mMultipleViewsAtOnce) 1500 if (mMultipleViewsAtOnce)
1501 { 1501 {
1502 if ( visible ) 1502 if ( visible )
1503 mDetails->show(); 1503 mDetails->show();
1504 else 1504 else
1505 mDetails->hide(); 1505 mDetails->hide();
1506 } 1506 }
1507 else 1507 else
1508 { 1508 {
1509 if ( visible ) { 1509 if ( visible ) {
1510 mViewManager->hide(); 1510 mViewManager->hide();
1511 mDetails->show(); 1511 mDetails->show();
1512 mIncSearchWidget->setFocus(); 1512 mIncSearchWidget->setFocus();
1513 } 1513 }
1514 else { 1514 else {
1515 mViewManager->show(); 1515 mViewManager->show();
1516 mDetails->hide(); 1516 mDetails->hide();
1517 mViewManager->setFocusAV(); 1517 mViewManager->setFocusAV();
1518 } 1518 }
1519 setJumpButtonBarVisible( !visible ); 1519 setJumpButtonBarVisible( !visible );
1520 } 1520 }
1521 1521
1522} 1522}
1523 1523
1524void KABCore::extensionChanged( int id ) 1524void KABCore::extensionChanged( int id )
1525{ 1525{
1526 //change the details view only for non desktop systems 1526 //change the details view only for non desktop systems
1527#ifndef DESKTOP_VERSION 1527#ifndef DESKTOP_VERSION
1528 1528
1529 if (id == 0) 1529 if (id == 0)
1530 { 1530 {
1531 //the user disabled the extension. 1531 //the user disabled the extension.
1532 1532
1533 if (mMultipleViewsAtOnce) 1533 if (mMultipleViewsAtOnce)
1534 { // enable detailsview again 1534 { // enable detailsview again
1535 setDetailsVisible( true ); 1535 setDetailsVisible( true );
1536 mActionDetails->setChecked( true ); 1536 mActionDetails->setChecked( true );
1537 } 1537 }
1538 else 1538 else
1539 { //go back to the listview 1539 { //go back to the listview
1540 setDetailsVisible( false ); 1540 setDetailsVisible( false );
1541 mActionDetails->setChecked( false ); 1541 mActionDetails->setChecked( false );
1542 mActionDetails->setEnabled(true); 1542 mActionDetails->setEnabled(true);
1543 } 1543 }
1544 1544
1545 } 1545 }
1546 else 1546 else
1547 { 1547 {
1548 //the user enabled the extension. 1548 //the user enabled the extension.
1549 setDetailsVisible( false ); 1549 setDetailsVisible( false );
1550 mActionDetails->setChecked( false ); 1550 mActionDetails->setChecked( false );
1551 1551
1552 if (!mMultipleViewsAtOnce) 1552 if (!mMultipleViewsAtOnce)
1553 { 1553 {
1554 mActionDetails->setEnabled(false); 1554 mActionDetails->setEnabled(false);
1555 } 1555 }
1556 1556
1557 mExtensionManager->setSelectionChanged(); 1557 mExtensionManager->setSelectionChanged();
1558 1558
1559 } 1559 }
1560 1560
1561#endif// DESKTOP_VERSION 1561#endif// DESKTOP_VERSION
1562 1562
1563} 1563}
1564 1564
1565 1565
1566void KABCore::extensionModified( const KABC::Addressee::List &list ) 1566void KABCore::extensionModified( const KABC::Addressee::List &list )
1567{ 1567{
1568 1568
1569 if ( list.count() != 0 ) { 1569 if ( list.count() != 0 ) {
1570 KABC::Addressee::List::ConstIterator it; 1570 KABC::Addressee::List::ConstIterator it;
1571 for ( it = list.begin(); it != list.end(); ++it ) 1571 for ( it = list.begin(); it != list.end(); ++it )
1572 mAddressBook->insertAddressee( *it ); 1572 mAddressBook->insertAddressee( *it );
1573 if ( list.count() > 1 ) 1573 if ( list.count() > 1 )
1574 setModified(); 1574 setModified();
1575 else 1575 else
1576 setModifiedWOrefresh(); 1576 setModifiedWOrefresh();
1577 } 1577 }
1578 if ( list.count() == 0 ) 1578 if ( list.count() == 0 )
1579 mViewManager->refreshView(); 1579 mViewManager->refreshView();
1580 else 1580 else
1581 mViewManager->refreshView( list[ 0 ].uid() ); 1581 mViewManager->refreshView( list[ 0 ].uid() );
1582 1582
1583 1583
1584 1584
1585} 1585}
1586 1586
1587QString KABCore::getNameByPhone( const QString &phone ) 1587QString KABCore::getNameByPhone( const QString &phone )
1588{ 1588{
1589#ifndef KAB_EMBEDDED 1589#ifndef KAB_EMBEDDED
1590 QRegExp r( "[/*/-/ ]" ); 1590 QRegExp r( "[/*/-/ ]" );
1591 QString localPhone( phone ); 1591 QString localPhone( phone );
1592 1592
1593 bool found = false; 1593 bool found = false;
1594 QString ownerName = ""; 1594 QString ownerName = "";
1595 KABC::AddressBook::Iterator iter; 1595 KABC::AddressBook::Iterator iter;
1596 KABC::PhoneNumber::List::Iterator phoneIter; 1596 KABC::PhoneNumber::List::Iterator phoneIter;
1597 KABC::PhoneNumber::List phoneList; 1597 KABC::PhoneNumber::List phoneList;
1598 for ( iter = mAddressBook->begin(); !found && ( iter != mAddressBook->end() ); ++iter ) { 1598 for ( iter = mAddressBook->begin(); !found && ( iter != mAddressBook->end() ); ++iter ) {
1599 phoneList = (*iter).phoneNumbers(); 1599 phoneList = (*iter).phoneNumbers();
1600 for ( phoneIter = phoneList.begin(); !found && ( phoneIter != phoneList.end() ); 1600 for ( phoneIter = phoneList.begin(); !found && ( phoneIter != phoneList.end() );
1601 ++phoneIter) { 1601 ++phoneIter) {
1602 // Get rid of separator chars so just the numbers are compared. 1602 // Get rid of separator chars so just the numbers are compared.
1603 if ( (*phoneIter).number().replace( r, "" ) == localPhone.replace( r, "" ) ) { 1603 if ( (*phoneIter).number().replace( r, "" ) == localPhone.replace( r, "" ) ) {
1604 ownerName = (*iter).formattedName(); 1604 ownerName = (*iter).formattedName();
1605 found = true; 1605 found = true;
1606 } 1606 }
1607 } 1607 }
1608 } 1608 }
1609 1609
1610 return ownerName; 1610 return ownerName;
1611#else //KAB_EMBEDDED 1611#else //KAB_EMBEDDED
1612 qDebug("KABCore::getNameByPhone finsih method"); 1612 qDebug("KABCore::getNameByPhone finsih method");
1613 return ""; 1613 return "";
1614#endif //KAB_EMBEDDED 1614#endif //KAB_EMBEDDED
1615 1615
1616} 1616}
1617 1617
1618void KABCore::openConfigDialog() 1618void KABCore::openConfigDialog()
1619{ 1619{
1620 KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true ); 1620 KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true );
1621 KCMKabConfig* kabcfg = new KCMKabConfig( ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" ); 1621 KCMKabConfig* kabcfg = new KCMKabConfig( ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" );
1622 ConfigureDialog->addModule(kabcfg ); 1622 ConfigureDialog->addModule(kabcfg );
1623 KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); 1623 KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" );
1624 ConfigureDialog->addModule(kdelibcfg ); 1624 ConfigureDialog->addModule(kdelibcfg );
1625 1625
1626 connect( ConfigureDialog, SIGNAL( applyClicked() ), 1626 connect( ConfigureDialog, SIGNAL( applyClicked() ),
1627 this, SLOT( configurationChanged() ) ); 1627 this, SLOT( configurationChanged() ) );
1628 connect( ConfigureDialog, SIGNAL( okClicked() ), 1628 connect( ConfigureDialog, SIGNAL( okClicked() ),
1629 this, SLOT( configurationChanged() ) ); 1629 this, SLOT( configurationChanged() ) );
1630 saveSettings(); 1630 saveSettings();
1631#ifndef DESKTOP_VERSION 1631#ifndef DESKTOP_VERSION
1632 ConfigureDialog->showMaximized(); 1632 ConfigureDialog->showMaximized();
1633#endif 1633#endif
1634 if ( ConfigureDialog->exec() ) 1634 if ( ConfigureDialog->exec() )
1635 KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") ); 1635 KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") );
1636 delete ConfigureDialog; 1636 delete ConfigureDialog;
1637} 1637}
1638 1638
1639void KABCore::openLDAPDialog() 1639void KABCore::openLDAPDialog()
1640{ 1640{
1641#ifndef KAB_EMBEDDED 1641#ifndef KAB_EMBEDDED
1642 if ( !mLdapSearchDialog ) { 1642 if ( !mLdapSearchDialog ) {
1643 mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this ); 1643 mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this );
1644 connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager, 1644 connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager,
1645 SLOT( refreshView() ) ); 1645 SLOT( refreshView() ) );
1646 connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this, 1646 connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this,
1647 SLOT( setModified() ) ); 1647 SLOT( setModified() ) );
1648 } else 1648 } else
1649 mLdapSearchDialog->restoreSettings(); 1649 mLdapSearchDialog->restoreSettings();
1650 1650
1651 if ( mLdapSearchDialog->isOK() ) 1651 if ( mLdapSearchDialog->isOK() )
1652 mLdapSearchDialog->exec(); 1652 mLdapSearchDialog->exec();
1653#else //KAB_EMBEDDED 1653#else //KAB_EMBEDDED
1654 qDebug("KABCore::openLDAPDialog() finsih method"); 1654 qDebug("KABCore::openLDAPDialog() finsih method");
1655#endif //KAB_EMBEDDED 1655#endif //KAB_EMBEDDED
1656} 1656}
1657 1657
1658void KABCore::print() 1658void KABCore::print()
1659{ 1659{
1660#ifndef KAB_EMBEDDED 1660#ifndef KAB_EMBEDDED
1661 KPrinter printer; 1661 KPrinter printer;
1662 if ( !printer.setup( this ) ) 1662 if ( !printer.setup( this ) )
1663 return; 1663 return;
1664 1664
1665 KABPrinting::PrintingWizard wizard( &printer, mAddressBook, 1665 KABPrinting::PrintingWizard wizard( &printer, mAddressBook,
1666 mViewManager->selectedUids(), this ); 1666 mViewManager->selectedUids(), this );
1667 1667
1668 wizard.exec(); 1668 wizard.exec();
1669#else //KAB_EMBEDDED 1669#else //KAB_EMBEDDED
1670 qDebug("KABCore::print() finsih method"); 1670 qDebug("KABCore::print() finsih method");
1671#endif //KAB_EMBEDDED 1671#endif //KAB_EMBEDDED
1672 1672
1673} 1673}
1674 1674
1675 1675
1676void KABCore::addGUIClient( KXMLGUIClient *client ) 1676void KABCore::addGUIClient( KXMLGUIClient *client )
1677{ 1677{
1678 if ( mGUIClient ) 1678 if ( mGUIClient )
1679 mGUIClient->insertChildClient( client ); 1679 mGUIClient->insertChildClient( client );
1680 else 1680 else
1681 KMessageBox::error( this, "no KXMLGUICLient"); 1681 KMessageBox::error( this, "no KXMLGUICLient");
1682} 1682}
1683 1683
1684 1684
1685void KABCore::configurationChanged() 1685void KABCore::configurationChanged()
1686{ 1686{
1687 mExtensionManager->reconfigure(); 1687 mExtensionManager->reconfigure();
1688} 1688}
1689 1689
1690void KABCore::addressBookChanged() 1690void KABCore::addressBookChanged()
1691{ 1691{
1692/*US 1692/*US
1693 QDictIterator<AddresseeEditorDialog> it( mEditorDict ); 1693 QDictIterator<AddresseeEditorDialog> it( mEditorDict );
1694 while ( it.current() ) { 1694 while ( it.current() ) {
1695 if ( it.current()->dirty() ) { 1695 if ( it.current()->dirty() ) {
1696 QString text = i18n( "Data has been changed externally. Unsaved " 1696 QString text = i18n( "Data has been changed externally. Unsaved "
1697 "changes will be lost." ); 1697 "changes will be lost." );
1698 KMessageBox::information( this, text ); 1698 KMessageBox::information( this, text );
1699 } 1699 }
1700 it.current()->setAddressee( mAddressBook->findByUid( it.currentKey() ) ); 1700 it.current()->setAddressee( mAddressBook->findByUid( it.currentKey() ) );
1701 ++it; 1701 ++it;
1702 } 1702 }
1703*/ 1703*/
1704 if (mEditorDialog) 1704 if (mEditorDialog)
1705 { 1705 {
1706 if (mEditorDialog->dirty()) 1706 if (mEditorDialog->dirty())
1707 { 1707 {
1708 QString text = i18n( "Data has been changed externally. Unsaved " 1708 QString text = i18n( "Data has been changed externally. Unsaved "
1709 "changes will be lost." ); 1709 "changes will be lost." );
1710 KMessageBox::information( this, text ); 1710 KMessageBox::information( this, text );
1711 } 1711 }
1712 QString currentuid = mEditorDialog->addressee().uid(); 1712 QString currentuid = mEditorDialog->addressee().uid();
1713 mEditorDialog->setAddressee( mAddressBook->findByUid( currentuid ) ); 1713 mEditorDialog->setAddressee( mAddressBook->findByUid( currentuid ) );
1714 } 1714 }
1715 mViewManager->refreshView(); 1715 mViewManager->refreshView();
1716 1716
1717 1717
1718} 1718}
1719 1719
1720AddresseeEditorDialog *KABCore::createAddresseeEditorDialog( QWidget *parent, 1720AddresseeEditorDialog *KABCore::createAddresseeEditorDialog( QWidget *parent,
1721 const char *name ) 1721 const char *name )
1722{ 1722{
1723 1723
1724 if ( mEditorDialog == 0 ) { 1724 if ( mEditorDialog == 0 ) {
1725 mEditorDialog = new AddresseeEditorDialog( this, parent, 1725 mEditorDialog = new AddresseeEditorDialog( this, parent,
1726 name ? name : "editorDialog" ); 1726 name ? name : "editorDialog" );
1727 1727
1728 1728
1729 connect( mEditorDialog, SIGNAL( contactModified( const KABC::Addressee& ) ), 1729 connect( mEditorDialog, SIGNAL( contactModified( const KABC::Addressee& ) ),
1730 SLOT( contactModified( const KABC::Addressee& ) ) ); 1730 SLOT( contactModified( const KABC::Addressee& ) ) );
1731 //connect( mEditorDialog, SIGNAL( editorDestroyed( const QString& ) ), 1731 //connect( mEditorDialog, SIGNAL( editorDestroyed( const QString& ) ),
1732 // SLOT( slotEditorDestroyed( const QString& ) ) ; 1732 // SLOT( slotEditorDestroyed( const QString& ) ) ;
1733 } 1733 }
1734 1734
1735 return mEditorDialog; 1735 return mEditorDialog;
1736} 1736}
1737 1737
1738void KABCore::slotEditorDestroyed( const QString &uid ) 1738void KABCore::slotEditorDestroyed( const QString &uid )
1739{ 1739{
1740 //mEditorDict.remove( uid ); 1740 //mEditorDict.remove( uid );
1741} 1741}
1742 1742
1743void KABCore::initGUI() 1743void KABCore::initGUI()
1744{ 1744{
1745#ifndef KAB_EMBEDDED 1745#ifndef KAB_EMBEDDED
1746 QHBoxLayout *topLayout = new QHBoxLayout( this ); 1746 QHBoxLayout *topLayout = new QHBoxLayout( this );
1747 topLayout->setSpacing( KDialogBase::spacingHint() ); 1747 topLayout->setSpacing( KDialogBase::spacingHint() );
1748 1748
1749 mExtensionBarSplitter = new QSplitter( this ); 1749 mExtensionBarSplitter = new QSplitter( this );
1750 mExtensionBarSplitter->setOrientation( Qt::Vertical ); 1750 mExtensionBarSplitter->setOrientation( Qt::Vertical );
1751 1751
1752 mDetailsSplitter = new QSplitter( mExtensionBarSplitter ); 1752 mDetailsSplitter = new QSplitter( mExtensionBarSplitter );
1753 1753
1754 QVBox *viewSpace = new QVBox( mDetailsSplitter ); 1754 QVBox *viewSpace = new QVBox( mDetailsSplitter );
1755 mIncSearchWidget = new IncSearchWidget( viewSpace ); 1755 mIncSearchWidget = new IncSearchWidget( viewSpace );
1756 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 1756 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
1757 SLOT( incrementalSearch( const QString& ) ) ); 1757 SLOT( incrementalSearch( const QString& ) ) );
1758 1758
1759 mViewManager = new ViewManager( this, viewSpace ); 1759 mViewManager = new ViewManager( this, viewSpace );
1760 viewSpace->setStretchFactor( mViewManager, 1 ); 1760 viewSpace->setStretchFactor( mViewManager, 1 );
1761 1761
1762 mDetails = new ViewContainer( mDetailsSplitter ); 1762 mDetails = new ViewContainer( mDetailsSplitter );
1763 1763
1764 mJumpButtonBar = new JumpButtonBar( this, this ); 1764 mJumpButtonBar = new JumpButtonBar( this, this );
1765 1765
1766 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); 1766 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter );
1767 1767
1768 topLayout->addWidget( mExtensionBarSplitter ); 1768 topLayout->addWidget( mExtensionBarSplitter );
1769 topLayout->setStretchFactor( mExtensionBarSplitter, 100 ); 1769 topLayout->setStretchFactor( mExtensionBarSplitter, 100 );
1770 topLayout->addWidget( mJumpButtonBar ); 1770 topLayout->addWidget( mJumpButtonBar );
1771 //topLayout->setStretchFactor( mJumpButtonBar, 1 ); 1771 //topLayout->setStretchFactor( mJumpButtonBar, 1 );
1772 1772
1773 mXXPortManager = new XXPortManager( this, this ); 1773 mXXPortManager = new XXPortManager( this, this );
1774 1774
1775#else //KAB_EMBEDDED 1775#else //KAB_EMBEDDED
1776 //US initialize viewMenu before settingup viewmanager. 1776 //US initialize viewMenu before settingup viewmanager.
1777 // Viewmanager needs this menu to plugin submenues. 1777 // Viewmanager needs this menu to plugin submenues.
1778 viewMenu = new QPopupMenu( this ); 1778 viewMenu = new QPopupMenu( this );
1779 settingsMenu = new QPopupMenu( this ); 1779 settingsMenu = new QPopupMenu( this );
1780 //filterMenu = new QPopupMenu( this ); 1780 //filterMenu = new QPopupMenu( this );
1781 ImportMenu = new QPopupMenu( this ); 1781 ImportMenu = new QPopupMenu( this );
1782 ExportMenu = new QPopupMenu( this ); 1782 ExportMenu = new QPopupMenu( this );
1783 syncMenu = new QPopupMenu( this ); 1783 syncMenu = new QPopupMenu( this );
1784 changeMenu= new QPopupMenu( this ); 1784 changeMenu= new QPopupMenu( this );
1785 beamMenu= new QPopupMenu( this ); 1785 beamMenu= new QPopupMenu( this );
1786 1786
1787//US since we have no splitter for the embedded system, setup 1787//US since we have no splitter for the embedded system, setup
1788// a layout with two frames. One left and one right. 1788// a layout with two frames. One left and one right.
1789 1789
1790 QBoxLayout *topLayout; 1790 QBoxLayout *topLayout;
1791 1791
1792 // = new QHBoxLayout( this ); 1792 // = new QHBoxLayout( this );
1793// QBoxLayout *topLayout = (QBoxLayout*)layout(); 1793// QBoxLayout *topLayout = (QBoxLayout*)layout();
1794 1794
1795// QWidget *mainBox = new QWidget( this ); 1795// QWidget *mainBox = new QWidget( this );
1796// QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox); 1796// QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox);
1797 1797
1798#ifdef DESKTOP_VERSION 1798#ifdef DESKTOP_VERSION
1799 topLayout = new QHBoxLayout( this ); 1799 topLayout = new QHBoxLayout( this );
1800 1800
1801 1801
1802 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); 1802 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this);
1803 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); 1803 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right );
1804 1804
1805 topLayout->addWidget(mMiniSplitter ); 1805 topLayout->addWidget(mMiniSplitter );
1806 1806
1807 mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter ); 1807 mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter );
1808 mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); 1808 mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down );
1809 mViewManager = new ViewManager( this, mExtensionBarSplitter ); 1809 mViewManager = new ViewManager( this, mExtensionBarSplitter );
1810 mDetails = new ViewContainer( mMiniSplitter ); 1810 mDetails = new ViewContainer( mMiniSplitter );
1811 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); 1811 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter );
1812#else 1812#else
1813 if ( QApplication::desktop()->width() > 480 ) { 1813 if ( QApplication::desktop()->width() > 480 ) {
1814 topLayout = new QHBoxLayout( this ); 1814 topLayout = new QHBoxLayout( this );
1815 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); 1815 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this);
1816 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); 1816 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right );
1817 } else { 1817 } else {
1818 1818
1819 topLayout = new QHBoxLayout( this ); 1819 topLayout = new QHBoxLayout( this );
1820 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this); 1820 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this);
1821 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); 1821 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down );
1822 } 1822 }
1823 1823
1824 topLayout->addWidget(mMiniSplitter ); 1824 topLayout->addWidget(mMiniSplitter );
1825 mViewManager = new ViewManager( this, mMiniSplitter ); 1825 mViewManager = new ViewManager( this, mMiniSplitter );
1826 mDetails = new ViewContainer( mMiniSplitter ); 1826 mDetails = new ViewContainer( mMiniSplitter );
1827 1827
1828 1828
1829 mExtensionManager = new ExtensionManager( this, mMiniSplitter ); 1829 mExtensionManager = new ExtensionManager( this, mMiniSplitter );
1830#endif 1830#endif
1831 //eh->hide(); 1831 //eh->hide();
1832 // topLayout->addWidget(mExtensionManager ); 1832 // topLayout->addWidget(mExtensionManager );
1833 1833
1834 1834
1835/*US 1835/*US
1836#ifndef KAB_NOSPLITTER 1836#ifndef KAB_NOSPLITTER
1837 QHBoxLayout *topLayout = new QHBoxLayout( this ); 1837 QHBoxLayout *topLayout = new QHBoxLayout( this );
1838//US topLayout->setSpacing( KDialogBase::spacingHint() ); 1838//US topLayout->setSpacing( KDialogBase::spacingHint() );
1839 topLayout->setSpacing( 10 ); 1839 topLayout->setSpacing( 10 );
1840 1840
1841 mDetailsSplitter = new QSplitter( this ); 1841 mDetailsSplitter = new QSplitter( this );
1842 1842
1843 QVBox *viewSpace = new QVBox( mDetailsSplitter ); 1843 QVBox *viewSpace = new QVBox( mDetailsSplitter );
1844 1844
1845 mViewManager = new ViewManager( this, viewSpace ); 1845 mViewManager = new ViewManager( this, viewSpace );
1846 viewSpace->setStretchFactor( mViewManager, 1 ); 1846 viewSpace->setStretchFactor( mViewManager, 1 );
1847 1847
1848 mDetails = new ViewContainer( mDetailsSplitter ); 1848 mDetails = new ViewContainer( mDetailsSplitter );
1849 1849
1850 topLayout->addWidget( mDetailsSplitter ); 1850 topLayout->addWidget( mDetailsSplitter );
1851 topLayout->setStretchFactor( mDetailsSplitter, 100 ); 1851 topLayout->setStretchFactor( mDetailsSplitter, 100 );
1852#else //KAB_NOSPLITTER 1852#else //KAB_NOSPLITTER
1853 QHBoxLayout *topLayout = new QHBoxLayout( this ); 1853 QHBoxLayout *topLayout = new QHBoxLayout( this );
1854//US topLayout->setSpacing( KDialogBase::spacingHint() ); 1854//US topLayout->setSpacing( KDialogBase::spacingHint() );
1855 topLayout->setSpacing( 10 ); 1855 topLayout->setSpacing( 10 );
1856 1856
1857// mDetailsSplitter = new QSplitter( this ); 1857// mDetailsSplitter = new QSplitter( this );
1858 1858
1859 QVBox *viewSpace = new QVBox( this ); 1859 QVBox *viewSpace = new QVBox( this );
1860 1860
1861 mViewManager = new ViewManager( this, viewSpace ); 1861 mViewManager = new ViewManager( this, viewSpace );
1862 viewSpace->setStretchFactor( mViewManager, 1 ); 1862 viewSpace->setStretchFactor( mViewManager, 1 );
1863 1863
1864 mDetails = new ViewContainer( this ); 1864 mDetails = new ViewContainer( this );
1865 1865
1866 topLayout->addWidget( viewSpace ); 1866 topLayout->addWidget( viewSpace );
1867// topLayout->setStretchFactor( mDetailsSplitter, 100 ); 1867// topLayout->setStretchFactor( mDetailsSplitter, 100 );
1868 topLayout->addWidget( mDetails ); 1868 topLayout->addWidget( mDetails );
1869#endif //KAB_NOSPLITTER 1869#endif //KAB_NOSPLITTER
1870*/ 1870*/
1871 1871
1872 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu); 1872 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu);
1873 syncManager->setBlockSave(false); 1873 syncManager->setBlockSave(false);
1874 1874
1875 connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); 1875 connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) );
1876 connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); 1876 connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) );
1877 QString sync_file = sentSyncFile(); 1877 QString sync_file = sentSyncFile();
1878 //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1()); 1878 //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1());
1879 syncManager->setDefaultFileName( sync_file ); 1879 syncManager->setDefaultFileName( sync_file );
1880 //connect(syncManager , SIGNAL( ), this, SLOT( ) ); 1880 //connect(syncManager , SIGNAL( ), this, SLOT( ) );
1881 1881
1882#endif //KAB_EMBEDDED 1882#endif //KAB_EMBEDDED
1883 initActions(); 1883 initActions();
1884 1884
1885#ifdef KAB_EMBEDDED 1885#ifdef KAB_EMBEDDED
1886 addActionsManually(); 1886 addActionsManually();
1887 //US make sure the export and import menues are initialized before creating the xxPortManager. 1887 //US make sure the export and import menues are initialized before creating the xxPortManager.
1888 mXXPortManager = new XXPortManager( this, this ); 1888 mXXPortManager = new XXPortManager( this, this );
1889 1889
1890 // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() ); 1890 // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() );
1891 //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget); 1891 //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget);
1892 // mActionQuit->plug ( mMainWindow->toolBar()); 1892 // mActionQuit->plug ( mMainWindow->toolBar());
1893 //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() ); 1893 //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() );
1894 //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget); 1894 //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget);
1895 // mIncSearchWidget->hide(); 1895 // mIncSearchWidget->hide();
1896 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 1896 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
1897 SLOT( incrementalSearch( const QString& ) ) ); 1897 SLOT( incrementalSearch( const QString& ) ) );
1898 connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) ); 1898 connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) );
1899 connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) ); 1899 connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) );
1900 1900
1901 mJumpButtonBar = new JumpButtonBar( this, this ); 1901 mJumpButtonBar = new JumpButtonBar( this, this );
1902 1902
1903 topLayout->addWidget( mJumpButtonBar ); 1903 topLayout->addWidget( mJumpButtonBar );
1904//US topLayout->setStretchFactor( mJumpButtonBar, 10 ); 1904//US topLayout->setStretchFactor( mJumpButtonBar, 10 );
1905 1905
1906// mMainWindow->getIconToolBar()->raise(); 1906// mMainWindow->getIconToolBar()->raise();
1907 1907
1908#endif //KAB_EMBEDDED 1908#endif //KAB_EMBEDDED
1909 1909
1910} 1910}
1911void KABCore::initActions() 1911void KABCore::initActions()
1912{ 1912{
1913//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 1913//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
1914 1914
1915#ifndef KAB_EMBEDDED 1915#ifndef KAB_EMBEDDED
1916 connect( QApplication::clipboard(), SIGNAL( dataChanged() ), 1916 connect( QApplication::clipboard(), SIGNAL( dataChanged() ),
1917 SLOT( clipboardDataChanged() ) ); 1917 SLOT( clipboardDataChanged() ) );
1918#endif //KAB_EMBEDDED 1918#endif //KAB_EMBEDDED
1919 1919
1920 // file menu 1920 // file menu
1921 1921
1922 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() ); 1922 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() );
1923 //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() ); 1923 //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() );
1924 mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager, 1924 mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager,
1925 SLOT( printView() ), actionCollection(), "kaddressbook_print" ); 1925 SLOT( printView() ), actionCollection(), "kaddressbook_print" );
1926 1926
1927 1927
1928 mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails, 1928 mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails,
1929 SLOT( printView() ), actionCollection(), "kaddressbook_print2" ); 1929 SLOT( printView() ), actionCollection(), "kaddressbook_print2" );
1930 1930
1931 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this, 1931 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this,
1932 SLOT( save() ), actionCollection(), "file_sync" ); 1932 SLOT( save() ), actionCollection(), "file_sync" );
1933 1933
1934 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this, 1934 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this,
1935 SLOT( newContact() ), actionCollection(), "file_new_contact" ); 1935 SLOT( newContact() ), actionCollection(), "file_new_contact" );
1936 1936
1937 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0, 1937 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0,
1938 this, SLOT( mailVCard() ), 1938 this, SLOT( mailVCard() ),
1939 actionCollection(), "file_mail_vcard"); 1939 actionCollection(), "file_mail_vcard");
1940 1940
1941 mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this, 1941 mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this,
1942 SLOT( export2phone() ), actionCollection(), 1942 SLOT( export2phone() ), actionCollection(),
1943 "kaddressbook_ex2phone" ); 1943 "kaddressbook_ex2phone" );
1944 1944
1945 mActionBeamVCard = 0; 1945 mActionBeamVCard = 0;
1946 mActionBeam = 0; 1946 mActionBeam = 0;
1947 1947
1948#ifndef DESKTOP_VERSION 1948#ifndef DESKTOP_VERSION
1949 if ( Ir::supported() ) { 1949 if ( Ir::supported() ) {
1950 mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this, 1950 mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this,
1951 SLOT( beamVCard() ), actionCollection(), 1951 SLOT( beamVCard() ), actionCollection(),
1952 "kaddressbook_beam_vcard" ); 1952 "kaddressbook_beam_vcard" );
1953 1953
1954 mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this, 1954 mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this,
1955 SLOT( beamMySelf() ), actionCollection(), 1955 SLOT( beamMySelf() ), actionCollection(),
1956 "kaddressbook_beam_myself" ); 1956 "kaddressbook_beam_myself" );
1957 } 1957 }
1958#endif 1958#endif
1959 1959
1960 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0, 1960 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0,
1961 this, SLOT( editContact2() ), 1961 this, SLOT( editContact2() ),
1962 actionCollection(), "file_properties" ); 1962 actionCollection(), "file_properties" );
1963 1963
1964#ifdef KAB_EMBEDDED 1964#ifdef KAB_EMBEDDED
1965 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() ); 1965 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() );
1966 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0, 1966 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0,
1967 mMainWindow, SLOT( exit() ), 1967 mMainWindow, SLOT( exit() ),
1968 actionCollection(), "quit" ); 1968 actionCollection(), "quit" );
1969#endif //KAB_EMBEDDED 1969#endif //KAB_EMBEDDED
1970 1970
1971 // edit menu 1971 // edit menu
1972 if ( mIsPart ) { 1972 if ( mIsPart ) {
1973 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this, 1973 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this,
1974 SLOT( copyContacts() ), actionCollection(), 1974 SLOT( copyContacts() ), actionCollection(),
1975 "kaddressbook_copy" ); 1975 "kaddressbook_copy" );
1976 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this, 1976 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this,
1977 SLOT( cutContacts() ), actionCollection(), 1977 SLOT( cutContacts() ), actionCollection(),
1978 "kaddressbook_cut" ); 1978 "kaddressbook_cut" );
1979 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this, 1979 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this,
1980 SLOT( pasteContacts() ), actionCollection(), 1980 SLOT( pasteContacts() ), actionCollection(),
1981 "kaddressbook_paste" ); 1981 "kaddressbook_paste" );
1982 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this, 1982 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this,
1983 SLOT( selectAllContacts() ), actionCollection(), 1983 SLOT( selectAllContacts() ), actionCollection(),
1984 "kaddressbook_select_all" ); 1984 "kaddressbook_select_all" );
1985 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this, 1985 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this,
1986 SLOT( undo() ), actionCollection(), 1986 SLOT( undo() ), actionCollection(),
1987 "kaddressbook_undo" ); 1987 "kaddressbook_undo" );
1988 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z, 1988 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z,
1989 this, SLOT( redo() ), actionCollection(), 1989 this, SLOT( redo() ), actionCollection(),
1990 "kaddressbook_redo" ); 1990 "kaddressbook_redo" );
1991 } else { 1991 } else {
1992 mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() ); 1992 mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() );
1993 mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() ); 1993 mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() );
1994 mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() ); 1994 mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() );
1995 mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() ); 1995 mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() );
1996 mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() ); 1996 mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() );
1997 mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() ); 1997 mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() );
1998 } 1998 }
1999 1999
2000 mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", 2000 mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete",
2001 Key_Delete, this, SLOT( deleteContacts() ), 2001 Key_Delete, this, SLOT( deleteContacts() ),
2002 actionCollection(), "edit_delete" ); 2002 actionCollection(), "edit_delete" );
2003 2003
2004 mActionUndo->setEnabled( false ); 2004 mActionUndo->setEnabled( false );
2005 mActionRedo->setEnabled( false ); 2005 mActionRedo->setEnabled( false );
2006 2006
2007 // settings menu 2007 // settings menu
2008#ifdef KAB_EMBEDDED 2008#ifdef KAB_EMBEDDED
2009//US special menuentry to configure the addressbook resources. On KDE 2009//US special menuentry to configure the addressbook resources. On KDE
2010// you do that through the control center !!! 2010// you do that through the control center !!!
2011 mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, 2011 mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this,
2012 SLOT( configureResources() ), actionCollection(), 2012 SLOT( configureResources() ), actionCollection(),
2013 "kaddressbook_configure_resources" ); 2013 "kaddressbook_configure_resources" );
2014#endif //KAB_EMBEDDED 2014#endif //KAB_EMBEDDED
2015 2015
2016 if ( mIsPart ) { 2016 if ( mIsPart ) {
2017 mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, 2017 mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this,
2018 SLOT( openConfigDialog() ), actionCollection(), 2018 SLOT( openConfigDialog() ), actionCollection(),
2019 "kaddressbook_configure" ); 2019 "kaddressbook_configure" );
2020 2020
2021 //US not implemented yet 2021 //US not implemented yet
2022 //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, 2022 //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0,
2023 // this, SLOT( configureKeyBindings() ), actionCollection(), 2023 // this, SLOT( configureKeyBindings() ), actionCollection(),
2024 // "kaddressbook_configure_shortcuts" ); 2024 // "kaddressbook_configure_shortcuts" );
2025#ifdef KAB_EMBEDDED 2025#ifdef KAB_EMBEDDED
2026 mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); 2026 mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() );
2027 mActionConfigureToolbars->setEnabled( false ); 2027 mActionConfigureToolbars->setEnabled( false );
2028#endif //KAB_EMBEDDED 2028#endif //KAB_EMBEDDED
2029 2029
2030 } else { 2030 } else {
2031 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() ); 2031 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() );
2032 2032
2033 //US not implemented yet 2033 //US not implemented yet
2034 //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() ); 2034 //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() );
2035 } 2035 }
2036 2036
2037 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, 2037 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0,
2038 actionCollection(), "options_show_jump_bar" ); 2038 actionCollection(), "options_show_jump_bar" );
2039 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) ); 2039 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) );
2040 2040
2041 mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, 2041 mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0,
2042 actionCollection(), "options_show_details" ); 2042 actionCollection(), "options_show_details" );
2043 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); 2043 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) );
2044 2044
2045 2045
2046 mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, 2046 mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this,
2047 SLOT( toggleBeamReceive() ), actionCollection(), 2047 SLOT( toggleBeamReceive() ), actionCollection(),
2048 "kaddressbook_beam_rec" ); 2048 "kaddressbook_beam_rec" );
2049 2049
2050 2050
2051 // misc 2051 // misc
2052 // only enable LDAP lookup if we can handle the protocol 2052 // only enable LDAP lookup if we can handle the protocol
2053#ifndef KAB_EMBEDDED 2053#ifndef KAB_EMBEDDED
2054 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { 2054 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) {
2055 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, 2055 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0,
2056 this, SLOT( openLDAPDialog() ), actionCollection(), 2056 this, SLOT( openLDAPDialog() ), actionCollection(),
2057 "ldap_lookup" ); 2057 "ldap_lookup" );
2058 } 2058 }
2059#else //KAB_EMBEDDED 2059#else //KAB_EMBEDDED
2060 //qDebug("KABCore::initActions() LDAP has to be implemented"); 2060 //qDebug("KABCore::initActions() LDAP has to be implemented");
2061#endif //KAB_EMBEDDED 2061#endif //KAB_EMBEDDED
2062 2062
2063 2063
2064 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, 2064 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this,
2065 SLOT( setWhoAmI() ), actionCollection(), 2065 SLOT( setWhoAmI() ), actionCollection(),
2066 "set_personal" ); 2066 "set_personal" );
2067 2067
2068 2068
2069 mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this, 2069 mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this,
2070 SLOT( setCategories() ), actionCollection(), 2070 SLOT( setCategories() ), actionCollection(),
2071 "edit_set_categories" ); 2071 "edit_set_categories" );
2072 mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this, 2072 mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this,
2073 SLOT( editCategories() ), actionCollection(), 2073 SLOT( editCategories() ), actionCollection(),
2074 "edit__categories" ); 2074 "edit__categories" );
2075 2075
2076 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, 2076 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this,
2077 SLOT( removeVoice() ), actionCollection(), 2077 SLOT( removeVoice() ), actionCollection(),
2078 "remove_voice" ); 2078 "remove_voice" );
2079 mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this, 2079 mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this,
2080 SLOT( setFormattedName() ), actionCollection(), 2080 SLOT( setFormattedName() ), actionCollection(),
2081 "set_formatted" ); 2081 "set_formatted" );
2082 2082
2083 mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this, 2083 mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this,
2084 SLOT( manageCategories() ), actionCollection(), 2084 SLOT( manageCategories() ), actionCollection(),
2085 "remove_voice" ); 2085 "remove_voice" );
2086 2086
2087 2087
2088 mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, 2088 mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this,
2089 SLOT( importFromOL() ), actionCollection(), 2089 SLOT( importFromOL() ), actionCollection(),
2090 "import_OL" ); 2090 "import_OL" );
2091#ifdef KAB_EMBEDDED 2091#ifdef KAB_EMBEDDED
2092 mActionLicence = new KAction( i18n( "Licence" ), 0, 2092 mActionLicence = new KAction( i18n( "Licence" ), 0,
2093 this, SLOT( showLicence() ), actionCollection(), 2093 this, SLOT( showLicence() ), actionCollection(),
2094 "licence_about_data" ); 2094 "licence_about_data" );
2095 mActionFaq = new KAction( i18n( "Faq" ), 0, 2095 mActionFaq = new KAction( i18n( "Faq" ), 0,
2096 this, SLOT( faq() ), actionCollection(), 2096 this, SLOT( faq() ), actionCollection(),
2097 "faq_about_data" ); 2097 "faq_about_data" );
2098 mActionWN = new KAction( i18n( "What's New?" ), 0, 2098 mActionWN = new KAction( i18n( "What's New?" ), 0,
2099 this, SLOT( whatsnew() ), actionCollection(), 2099 this, SLOT( whatsnew() ), actionCollection(),
2100 "wn" ); 2100 "wn" );
2101 mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, 2101 mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0,
2102 this, SLOT( synchowto() ), actionCollection(), 2102 this, SLOT( synchowto() ), actionCollection(),
2103 "sync" ); 2103 "sync" );
2104 mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0, 2104 mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0,
2105 this, SLOT( kdesynchowto() ), actionCollection(), 2105 this, SLOT( kdesynchowto() ), actionCollection(),
2106 "kdesync" ); 2106 "kdesync" );
2107 mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0, 2107 mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0,
2108 this, SLOT( multisynchowto() ), actionCollection(), 2108 this, SLOT( multisynchowto() ), actionCollection(),
2109 "multisync" ); 2109 "multisync" );
2110 2110
2111 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, 2111 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0,
2112 this, SLOT( createAboutData() ), actionCollection(), 2112 this, SLOT( createAboutData() ), actionCollection(),
2113 "kaddressbook_about_data" ); 2113 "kaddressbook_about_data" );
2114#endif //KAB_EMBEDDED 2114#endif //KAB_EMBEDDED
2115 2115
2116 clipboardDataChanged(); 2116 clipboardDataChanged();
2117 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 2117 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
2118 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 2118 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
2119} 2119}
2120 2120
2121//US we need this function, to plug all actions into the correct menues. 2121//US we need this function, to plug all actions into the correct menues.
2122// KDE uses a XML format to plug the actions, but we work her without this overhead. 2122// KDE uses a XML format to plug the actions, but we work her without this overhead.
2123void KABCore::addActionsManually() 2123void KABCore::addActionsManually()
2124{ 2124{
2125//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 2125//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
2126 2126
2127#ifdef KAB_EMBEDDED 2127#ifdef KAB_EMBEDDED
2128 QPopupMenu *fileMenu = new QPopupMenu( this ); 2128 QPopupMenu *fileMenu = new QPopupMenu( this );
2129 QPopupMenu *editMenu = new QPopupMenu( this ); 2129 QPopupMenu *editMenu = new QPopupMenu( this );
2130 QPopupMenu *helpMenu = new QPopupMenu( this ); 2130 QPopupMenu *helpMenu = new QPopupMenu( this );
2131 2131
2132 KToolBar* tb = mMainWindow->toolBar(); 2132 KToolBar* tb = mMainWindow->toolBar();
2133 mMainWindow->setToolBarsMovable (false ); 2133 mMainWindow->setToolBarsMovable (false );
2134#ifndef DESKTOP_VERSION 2134#ifndef DESKTOP_VERSION
2135 if ( KABPrefs::instance()->mFullMenuBarVisible ) { 2135 if ( KABPrefs::instance()->mFullMenuBarVisible ) {
2136#endif 2136#endif
2137 QMenuBar* mb = mMainWindow->menuBar(); 2137 QMenuBar* mb = mMainWindow->menuBar();
2138 2138
2139 //US setup menubar. 2139 //US setup menubar.
2140 //Disable the following block if you do not want to have a menubar. 2140 //Disable the following block if you do not want to have a menubar.
2141 mb->insertItem( i18n("&File"), fileMenu ); 2141 mb->insertItem( i18n("&File"), fileMenu );
2142 mb->insertItem( i18n("&Edit"), editMenu ); 2142 mb->insertItem( i18n("&Edit"), editMenu );
2143 mb->insertItem( i18n("&View"), viewMenu ); 2143 mb->insertItem( i18n("&View"), viewMenu );
2144 mb->insertItem( i18n("&Settings"), settingsMenu ); 2144 mb->insertItem( i18n("&Settings"), settingsMenu );
2145#ifdef DESKTOP_VERSION 2145#ifdef DESKTOP_VERSION
2146 mb->insertItem( i18n("Synchronize"), syncMenu ); 2146 mb->insertItem( i18n("Synchronize"), syncMenu );
2147#else 2147#else
2148 mb->insertItem( i18n("Sync"), syncMenu ); 2148 mb->insertItem( i18n("Sync"), syncMenu );
2149#endif 2149#endif
2150 //mb->insertItem( i18n("&Change"), changeMenu ); 2150 //mb->insertItem( i18n("&Change"), changeMenu );
2151 mb->insertItem( i18n("&Help"), helpMenu ); 2151 mb->insertItem( i18n("&Help"), helpMenu );
2152 mIncSearchWidget = new IncSearchWidget( tb ); 2152 mIncSearchWidget = new IncSearchWidget( tb );
2153 // tb->insertWidget(-1, 0, mIncSearchWidget); 2153 // tb->insertWidget(-1, 0, mIncSearchWidget);
2154#ifndef DESKTOP_VERSION 2154#ifndef DESKTOP_VERSION
2155 } else { 2155 } else {
2156 //US setup toolbar 2156 //US setup toolbar
2157 QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); 2157 QPEMenuBar *menuBarTB = new QPEMenuBar( tb );
2158 QPopupMenu *popupBarTB = new QPopupMenu( this ); 2158 QPopupMenu *popupBarTB = new QPopupMenu( this );
2159 menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB); 2159 menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB);
2160 tb->insertWidget(-1, 0, menuBarTB); 2160 tb->insertWidget(-1, 0, menuBarTB);
2161 mIncSearchWidget = new IncSearchWidget( tb ); 2161 mIncSearchWidget = new IncSearchWidget( tb );
2162 tb->enableMoving(false); 2162 tb->enableMoving(false);
2163 popupBarTB->insertItem( i18n("&File"), fileMenu ); 2163 popupBarTB->insertItem( i18n("&File"), fileMenu );
2164 popupBarTB->insertItem( i18n("&Edit"), editMenu ); 2164 popupBarTB->insertItem( i18n("&Edit"), editMenu );
2165 popupBarTB->insertItem( i18n("&View"), viewMenu ); 2165 popupBarTB->insertItem( i18n("&View"), viewMenu );
2166 popupBarTB->insertItem( i18n("&Settings"), settingsMenu ); 2166 popupBarTB->insertItem( i18n("&Settings"), settingsMenu );
2167 popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); 2167 popupBarTB->insertItem( i18n("Synchronize"), syncMenu );
2168 mViewManager->getFilterAction()->plug ( popupBarTB); 2168 mViewManager->getFilterAction()->plug ( popupBarTB);
2169 //popupBarTB->insertItem( i18n("&Change selected"), changeMenu ); 2169 //popupBarTB->insertItem( i18n("&Change selected"), changeMenu );
2170 popupBarTB->insertItem( i18n("&Help"), helpMenu ); 2170 popupBarTB->insertItem( i18n("&Help"), helpMenu );
2171 if (QApplication::desktop()->width() > 320 ) { 2171 if (QApplication::desktop()->width() > 320 ) {
2172 // mViewManager->getFilterAction()->plug ( tb); 2172 // mViewManager->getFilterAction()->plug ( tb);
2173 } 2173 }
2174 } 2174 }
2175#endif 2175#endif
2176 mIncSearchWidget->setSize();
2176 // mActionQuit->plug ( mMainWindow->toolBar()); 2177 // mActionQuit->plug ( mMainWindow->toolBar());
2177 2178
2178 2179
2179 2180
2180 //US Now connect the actions with the menue entries. 2181 //US Now connect the actions with the menue entries.
2181#ifdef DESKTOP_VERSION 2182#ifdef DESKTOP_VERSION
2182 mActionPrint->plug( fileMenu ); 2183 mActionPrint->plug( fileMenu );
2183 mActionPrintDetails->plug( fileMenu ); 2184 mActionPrintDetails->plug( fileMenu );
2184 fileMenu->insertSeparator(); 2185 fileMenu->insertSeparator();
2185#endif 2186#endif
2186 mActionMail->plug( fileMenu ); 2187 mActionMail->plug( fileMenu );
2187 fileMenu->insertSeparator(); 2188 fileMenu->insertSeparator();
2188 2189
2189 mActionNewContact->plug( editMenu ); 2190 mActionNewContact->plug( editMenu );
2190 mActionNewContact->plug( tb ); 2191 mActionNewContact->plug( tb );
2191 2192
2192 mActionEditAddressee->plug( editMenu ); 2193 mActionEditAddressee->plug( editMenu );
2193 editMenu->insertSeparator(); 2194 editMenu->insertSeparator();
2194 // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || 2195 // if ((KGlobal::getDesktopSize() > KGlobal::Small ) ||
2195 // (!KABPrefs::instance()->mMultipleViewsAtOnce )) 2196 // (!KABPrefs::instance()->mMultipleViewsAtOnce ))
2196 mActionEditAddressee->plug( tb ); 2197 mActionEditAddressee->plug( tb );
2197 2198
2198 // fileMenu->insertSeparator(); 2199 // fileMenu->insertSeparator();
2199 mActionSave->plug( fileMenu ); 2200 mActionSave->plug( fileMenu );
2200 fileMenu->insertItem( "&Import", ImportMenu ); 2201 fileMenu->insertItem( "&Import", ImportMenu );
2201 fileMenu->insertItem( "&Export", ExportMenu ); 2202 fileMenu->insertItem( "&Export", ExportMenu );
2202 editMenu->insertItem( i18n("&Change"), changeMenu ); 2203 editMenu->insertItem( i18n("&Change"), changeMenu );
2203 editMenu->insertSeparator(); 2204 editMenu->insertSeparator();
2204#ifndef DESKTOP_VERSION 2205#ifndef DESKTOP_VERSION
2205 if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu ); 2206 if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu );
2206#endif 2207#endif
2207#if 0 2208#if 0
2208 // PENDING fix MailVCard 2209 // PENDING fix MailVCard
2209 fileMenu->insertSeparator(); 2210 fileMenu->insertSeparator();
2210 mActionMailVCard->plug( fileMenu ); 2211 mActionMailVCard->plug( fileMenu );
2211#endif 2212#endif
2212#ifndef DESKTOP_VERSION 2213#ifndef DESKTOP_VERSION
2213 if ( Ir::supported() ) mActionBR->plug( beamMenu ); 2214 if ( Ir::supported() ) mActionBR->plug( beamMenu );
2214 if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu ); 2215 if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu );
2215 if ( Ir::supported() ) mActionBeam->plug( beamMenu ); 2216 if ( Ir::supported() ) mActionBeam->plug( beamMenu );
2216#endif 2217#endif
2217 fileMenu->insertSeparator(); 2218 fileMenu->insertSeparator();
2218 mActionQuit->plug( fileMenu ); 2219 mActionQuit->plug( fileMenu );
2219#ifdef _OL_IMPORT_ 2220#ifdef _OL_IMPORT_
2220 mActionImportOL->plug( ImportMenu ); 2221 mActionImportOL->plug( ImportMenu );
2221#endif 2222#endif
2222 // edit menu 2223 // edit menu
2223 mActionUndo->plug( editMenu ); 2224 mActionUndo->plug( editMenu );
2224 mActionRedo->plug( editMenu ); 2225 mActionRedo->plug( editMenu );
2225 editMenu->insertSeparator(); 2226 editMenu->insertSeparator();
2226 mActionCut->plug( editMenu ); 2227 mActionCut->plug( editMenu );
2227 mActionCopy->plug( editMenu ); 2228 mActionCopy->plug( editMenu );
2228 mActionPaste->plug( editMenu ); 2229 mActionPaste->plug( editMenu );
2229 mActionDelete->plug( editMenu ); 2230 mActionDelete->plug( editMenu );
2230 editMenu->insertSeparator(); 2231 editMenu->insertSeparator();
2231 mActionSelectAll->plug( editMenu ); 2232 mActionSelectAll->plug( editMenu );
2232 2233
2233 mActionSetFormattedName->plug( changeMenu ); 2234 mActionSetFormattedName->plug( changeMenu );
2234 mActionRemoveVoice->plug( changeMenu ); 2235 mActionRemoveVoice->plug( changeMenu );
2235 // settingsmings menu 2236 // settingsmings menu
2236//US special menuentry to configure the addressbook resources. On KDE 2237//US special menuentry to configure the addressbook resources. On KDE
2237// you do that through the control center !!! 2238// you do that through the control center !!!
2238 // settingsMenu->insertSeparator(); 2239 // settingsMenu->insertSeparator();
2239 2240
2240 mActionConfigKAddressbook->plug( settingsMenu, 0 ); 2241 mActionConfigKAddressbook->plug( settingsMenu, 0 );
2241 mActionConfigResources->plug( settingsMenu,1 ); 2242 mActionConfigResources->plug( settingsMenu,1 );
2242 settingsMenu->insertSeparator(2); 2243 settingsMenu->insertSeparator(2);
2243 2244
2244 if ( mIsPart ) { 2245 if ( mIsPart ) {
2245 //US not implemented yet 2246 //US not implemented yet
2246 //mActionConfigShortcuts->plug( settingsMenu ); 2247 //mActionConfigShortcuts->plug( settingsMenu );
2247 //mActionConfigureToolbars->plug( settingsMenu ); 2248 //mActionConfigureToolbars->plug( settingsMenu );
2248 2249
2249 } else { 2250 } else {
2250 //US not implemented yet 2251 //US not implemented yet
2251 //mActionKeyBindings->plug( settingsMenu ); 2252 //mActionKeyBindings->plug( settingsMenu );
2252 } 2253 }
2253 2254
2254 mActionEditCategories->plug( settingsMenu ); 2255 mActionEditCategories->plug( settingsMenu );
2255 mActionManageCategories->plug( settingsMenu ); 2256 mActionManageCategories->plug( settingsMenu );
2256 mActionJumpBar->plug( viewMenu,0 ); 2257 mActionJumpBar->plug( viewMenu,0 );
2257 mActionDetails->plug( viewMenu,0 ); 2258 mActionDetails->plug( viewMenu,0 );
2258 //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) 2259 //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop )
2259 mActionDetails->plug( tb ); 2260 mActionDetails->plug( tb );
2260 settingsMenu->insertSeparator(); 2261 settingsMenu->insertSeparator();
2261#ifndef DESKTOP_VERSION 2262#ifndef DESKTOP_VERSION
2262 if ( Ir::supported() ) mActionBR->plug(settingsMenu ); 2263 if ( Ir::supported() ) mActionBR->plug(settingsMenu );
2263 settingsMenu->insertSeparator(); 2264 settingsMenu->insertSeparator();
2264#endif 2265#endif
2265 2266
2266 mActionWhoAmI->plug( settingsMenu ); 2267 mActionWhoAmI->plug( settingsMenu );
2267 //mActionEditCategories->plug( changeMenu ); 2268 //mActionEditCategories->plug( changeMenu );
2268 mActionCategories->plug( changeMenu ); 2269 mActionCategories->plug( changeMenu );
2269 //mActionManageCategories->plug( changeMenu ); 2270 //mActionManageCategories->plug( changeMenu );
2270 2271
2271 //mActionCategories->plug( settingsMenu ); 2272 //mActionCategories->plug( settingsMenu );
2272 2273
2273 2274
2274 mActionWN->plug( helpMenu ); 2275 mActionWN->plug( helpMenu );
2275 mActionSyncHowto->plug( helpMenu ); 2276 mActionSyncHowto->plug( helpMenu );
2276 mActionKdeSyncHowto->plug( helpMenu ); 2277 mActionKdeSyncHowto->plug( helpMenu );
2277 mActionMultiSyncHowto->plug( helpMenu ); 2278 mActionMultiSyncHowto->plug( helpMenu );
2278 mActionFaq->plug( helpMenu ); 2279 mActionFaq->plug( helpMenu );
2279 mActionLicence->plug( helpMenu ); 2280 mActionLicence->plug( helpMenu );
2280 mActionAboutKAddressbook->plug( helpMenu ); 2281 mActionAboutKAddressbook->plug( helpMenu );
2281 2282
2282 if (KGlobal::getDesktopSize() > KGlobal::Small ) { 2283 if (KGlobal::getDesktopSize() > KGlobal::Small ) {
2283 2284
2284 mActionSave->plug( tb ); 2285 mActionSave->plug( tb );
2285 mViewManager->getFilterAction()->plug ( tb); 2286 mViewManager->getFilterAction()->plug ( tb);
2286 //LR hide filteraction on started in 480x640 2287 //LR hide filteraction on started in 480x640
2287 if (QApplication::desktop()->width() == 480 ) { 2288 if (QApplication::desktop()->width() == 480 ) {
2288 mViewManager->getFilterAction()->setComboWidth( 0 ); 2289 mViewManager->getFilterAction()->setComboWidth( 0 );
2289 } 2290 }
2290 mActionUndo->plug( tb ); 2291 mActionUndo->plug( tb );
2291 mActionDelete->plug( tb ); 2292 mActionDelete->plug( tb );
2292 mActionRedo->plug( tb ); 2293 mActionRedo->plug( tb );
2293 } else { 2294 } else {
2294 mActionSave->plug( tb ); 2295 mActionSave->plug( tb );
2295 tb->enableMoving(false); 2296 tb->enableMoving(false);
2296 } 2297 }
2297 //mActionQuit->plug ( tb ); 2298 //mActionQuit->plug ( tb );
2298 // tb->insertWidget(-1, 0, mIncSearchWidget, 6); 2299 //tb->insertWidget(-1, 0, mIncSearchWidget, 6);
2299 2300
2300 //US link the searchwidget first to this. 2301 //US link the searchwidget first to this.
2301 // The real linkage to the toolbar happens later. 2302 // The real linkage to the toolbar happens later.
2302//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); 2303//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE);
2303//US tb->insertItem( mIncSearchWidget ); 2304//US tb->insertItem( mIncSearchWidget );
2304/*US 2305/*US
2305 mIncSearchWidget = new IncSearchWidget( tb ); 2306 mIncSearchWidget = new IncSearchWidget( tb );
2306 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 2307 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
2307 SLOT( incrementalSearch( const QString& ) ) ); 2308 SLOT( incrementalSearch( const QString& ) ) );
2308 2309
2309 mJumpButtonBar = new JumpButtonBar( this, this ); 2310 mJumpButtonBar = new JumpButtonBar( this, this );
2310 2311
2311//US topLayout->addWidget( mJumpButtonBar ); 2312//US topLayout->addWidget( mJumpButtonBar );
2312 this->layout()->add( mJumpButtonBar ); 2313 this->layout()->add( mJumpButtonBar );
2313*/ 2314*/
2314 2315
2315#endif //KAB_EMBEDDED 2316#endif //KAB_EMBEDDED
2316 2317
2317 mActionExport2phone->plug( ExportMenu ); 2318 mActionExport2phone->plug( ExportMenu );
2318 connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); 2319 connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) );
2319 syncManager->fillSyncMenu(); 2320 syncManager->fillSyncMenu();
2320 2321
2321} 2322}
2322void KABCore::showLicence() 2323void KABCore::showLicence()
2323{ 2324{
2324 KApplication::showLicence(); 2325 KApplication::showLicence();
2325} 2326}
2326 2327
2327void KABCore::manageCategories( ) 2328void KABCore::manageCategories( )
2328{ 2329{
2329 KABCatPrefs* cp = new KABCatPrefs(); 2330 KABCatPrefs* cp = new KABCatPrefs();
2330 cp->show(); 2331 cp->show();
2331 int w =cp->sizeHint().width() ; 2332 int w =cp->sizeHint().width() ;
2332 int h = cp->sizeHint().height() ; 2333 int h = cp->sizeHint().height() ;
2333 int dw = QApplication::desktop()->width(); 2334 int dw = QApplication::desktop()->width();
2334 int dh = QApplication::desktop()->height(); 2335 int dh = QApplication::desktop()->height();
2335 cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); 2336 cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h );
2336 if ( !cp->exec() ) { 2337 if ( !cp->exec() ) {
2337 delete cp; 2338 delete cp;
2338 return; 2339 return;
2339 } 2340 }
2340 int count = 0; 2341 int count = 0;
2341 int cc = 0; 2342 int cc = 0;
2342 message( i18n("Please wait, processing categories...")); 2343 message( i18n("Please wait, processing categories..."));
2343 if ( cp->addCat() ) { 2344 if ( cp->addCat() ) {
2344 KABC::AddressBook::Iterator it; 2345 KABC::AddressBook::Iterator it;
2345 QStringList catList = KABPrefs::instance()->mCustomCategories; 2346 QStringList catList = KABPrefs::instance()->mCustomCategories;
2346 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2347 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2347 ++cc; 2348 ++cc;
2348 if ( cc %10 == 0) 2349 if ( cc %10 == 0)
2349 message(i18n("Processing contact #%1").arg(cc)); 2350 message(i18n("Processing contact #%1").arg(cc));
2350 QStringList catIncList = (*it).categories(); 2351 QStringList catIncList = (*it).categories();
2351 int i; 2352 int i;
2352 for( i = 0; i< catIncList.count(); ++i ) { 2353 for( i = 0; i< catIncList.count(); ++i ) {
2353 if ( !catList.contains (catIncList[i])) { 2354 if ( !catList.contains (catIncList[i])) {
2354 catList.append( catIncList[i] ); 2355 catList.append( catIncList[i] );
2355 //qDebug("add cat %s ", catIncList[i].latin1()); 2356 //qDebug("add cat %s ", catIncList[i].latin1());
2356 ++count; 2357 ++count;
2357 } 2358 }
2358 } 2359 }
2359 } 2360 }
2360 catList.sort(); 2361 catList.sort();
2361 KABPrefs::instance()->mCustomCategories = catList; 2362 KABPrefs::instance()->mCustomCategories = catList;
2362 KABPrefs::instance()->writeConfig(); 2363 KABPrefs::instance()->writeConfig();
2363 message(QString::number( count )+ i18n(" categories added to list! ")); 2364 message(QString::number( count )+ i18n(" categories added to list! "));
2364 } else { 2365 } else {
2365 QStringList catList = KABPrefs::instance()->mCustomCategories; 2366 QStringList catList = KABPrefs::instance()->mCustomCategories;
2366 QStringList catIncList; 2367 QStringList catIncList;
2367 QStringList newCatList; 2368 QStringList newCatList;
2368 KABC::AddressBook::Iterator it; 2369 KABC::AddressBook::Iterator it;
2369 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2370 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2370 ++cc; 2371 ++cc;
2371 if ( cc %10 == 0) 2372 if ( cc %10 == 0)
2372 message(i18n("Processing contact #%1").arg(cc)); 2373 message(i18n("Processing contact #%1").arg(cc));
2373 QStringList catIncList = (*it).categories(); 2374 QStringList catIncList = (*it).categories();
2374 int i; 2375 int i;
2375 if ( catIncList.count() ) { 2376 if ( catIncList.count() ) {
2376 newCatList.clear(); 2377 newCatList.clear();
2377 for( i = 0; i< catIncList.count(); ++i ) { 2378 for( i = 0; i< catIncList.count(); ++i ) {
2378 if ( catList.contains (catIncList[i])) { 2379 if ( catList.contains (catIncList[i])) {
2379 newCatList.append( catIncList[i] ); 2380 newCatList.append( catIncList[i] );
2380 } 2381 }
2381 } 2382 }
2382 newCatList.sort(); 2383 newCatList.sort();
2383 (*it).setCategories( newCatList ); 2384 (*it).setCategories( newCatList );
2384 mAddressBook->insertAddressee( (*it) ); 2385 mAddressBook->insertAddressee( (*it) );
2385 } 2386 }
2386 } 2387 }
2387 setModified( true ); 2388 setModified( true );
2388 mViewManager->refreshView(); 2389 mViewManager->refreshView();
2389 message( i18n("Removing categories done!")); 2390 message( i18n("Removing categories done!"));
2390 } 2391 }
2391 delete cp; 2392 delete cp;
2392} 2393}
2393void KABCore::removeVoice() 2394void KABCore::removeVoice()
2394{ 2395{
2395 if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No ) 2396 if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No )
2396 return; 2397 return;
2397 XXPortSelectDialog dlg( this, false, this ); 2398 XXPortSelectDialog dlg( this, false, this );
2398 if ( !dlg.exec() ) 2399 if ( !dlg.exec() )
2399 return; 2400 return;
2400 mAddressBook->setUntagged(); 2401 mAddressBook->setUntagged();
2401 dlg.tagSelected(); 2402 dlg.tagSelected();
2402 message(i18n("Removing voice..."), false ); 2403 message(i18n("Removing voice..."), false );
2403 KABC::AddressBook::Iterator it; 2404 KABC::AddressBook::Iterator it;
2404 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2405 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2405 if ( (*it).tagged() ) { 2406 if ( (*it).tagged() ) {
2406 (*it).removeVoice(); 2407 (*it).removeVoice();
2407 } 2408 }
2408 } 2409 }
2409 message(i18n("Refreshing view...") ); 2410 message(i18n("Refreshing view...") );
2410 qApp->processEvents(); 2411 qApp->processEvents();
2411 mViewManager->refreshView( "" ); 2412 mViewManager->refreshView( "" );
2412 Addressee add; 2413 Addressee add;
2413 mDetails->setAddressee( add ); 2414 mDetails->setAddressee( add );
2414 message(i18n("Remove voice completed!") ); 2415 message(i18n("Remove voice completed!") );
2415 2416
2416 2417
2417 2418
2418} 2419}
2419 2420
2420void KABCore::setFormattedName() 2421void KABCore::setFormattedName()
2421{ 2422{
2422 KABFormatPrefs setpref; 2423 KABFormatPrefs setpref;
2423 if ( !setpref.exec() ) { 2424 if ( !setpref.exec() ) {
2424 return; 2425 return;
2425 } 2426 }
2426 XXPortSelectDialog dlg( this, false, this ); 2427 XXPortSelectDialog dlg( this, false, this );
2427 if ( !dlg.exec() ) 2428 if ( !dlg.exec() )
2428 return; 2429 return;
2429 mAddressBook->setUntagged(); 2430 mAddressBook->setUntagged();
2430 dlg.tagSelected(); 2431 dlg.tagSelected();
2431 int count = 0; 2432 int count = 0;
2432 KABC::AddressBook::Iterator it; 2433 KABC::AddressBook::Iterator it;
2433 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2434 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2434 if ( (*it).tagged() ) { 2435 if ( (*it).tagged() ) {
2435 ++count; 2436 ++count;
2436 if ( count %10 == 0 ) 2437 if ( count %10 == 0 )
2437 message(i18n("Changing contact #%1").arg( count ) ); 2438 message(i18n("Changing contact #%1").arg( count ) );
2438 qApp->processEvents(); 2439 qApp->processEvents();
2439 QString fName; 2440 QString fName;
2440 if ( setpref.simple->isChecked() ) 2441 if ( setpref.simple->isChecked() )
2441 fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName ); 2442 fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName );
2442 else if ( setpref.full->isChecked() ) 2443 else if ( setpref.full->isChecked() )
2443 fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName ); 2444 fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName );
2444 else if ( setpref.reverse->isChecked() ) 2445 else if ( setpref.reverse->isChecked() )
2445 fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName ); 2446 fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName );
2446 else 2447 else
2447 fName = (*it).organization(); 2448 fName = (*it).organization();
2448 if ( setpref.setCompany->isChecked() ) 2449 if ( setpref.setCompany->isChecked() )
2449 if ( fName.isEmpty() || fName =="," ) 2450 if ( fName.isEmpty() || fName =="," )
2450 fName = (*it).organization(); 2451 fName = (*it).organization();
2451 (*it).setFormattedName( fName ); 2452 (*it).setFormattedName( fName );
2452 } 2453 }
2453 } 2454 }
2454 message(i18n("Refreshing view...") ); 2455 message(i18n("Refreshing view...") );
2455 qApp->processEvents(); 2456 qApp->processEvents();
2456 mViewManager->refreshView( "" ); 2457 mViewManager->refreshView( "" );
2457 Addressee add; 2458 Addressee add;
2458 mDetails->setAddressee( add ); 2459 mDetails->setAddressee( add );
2459 message(i18n("Setting formatted name completed!") ); 2460 message(i18n("Setting formatted name completed!") );
2460} 2461}
2461 2462
2462void KABCore::clipboardDataChanged() 2463void KABCore::clipboardDataChanged()
2463{ 2464{
2464 2465
2465 if ( mReadWrite ) 2466 if ( mReadWrite )
2466 mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); 2467 mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() );
2467 2468
2468} 2469}
2469 2470
2470void KABCore::updateActionMenu() 2471void KABCore::updateActionMenu()
2471{ 2472{
2472 UndoStack *undo = UndoStack::instance(); 2473 UndoStack *undo = UndoStack::instance();
2473 RedoStack *redo = RedoStack::instance(); 2474 RedoStack *redo = RedoStack::instance();
2474 2475
2475 if ( undo->isEmpty() ) 2476 if ( undo->isEmpty() )
2476 mActionUndo->setText( i18n( "Undo" ) ); 2477 mActionUndo->setText( i18n( "Undo" ) );
2477 else 2478 else
2478 mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); 2479 mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) );
2479 2480
2480 mActionUndo->setEnabled( !undo->isEmpty() ); 2481 mActionUndo->setEnabled( !undo->isEmpty() );
2481 2482
2482 if ( !redo->top() ) 2483 if ( !redo->top() )
2483 mActionRedo->setText( i18n( "Redo" ) ); 2484 mActionRedo->setText( i18n( "Redo" ) );
2484 else 2485 else
2485 mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); 2486 mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) );
2486 2487
2487 mActionRedo->setEnabled( !redo->isEmpty() ); 2488 mActionRedo->setEnabled( !redo->isEmpty() );
2488} 2489}
2489 2490
2490void KABCore::configureKeyBindings() 2491void KABCore::configureKeyBindings()
2491{ 2492{
2492#ifndef KAB_EMBEDDED 2493#ifndef KAB_EMBEDDED
2493 KKeyDialog::configure( actionCollection(), true ); 2494 KKeyDialog::configure( actionCollection(), true );
2494#else //KAB_EMBEDDED 2495#else //KAB_EMBEDDED
2495 qDebug("KABCore::configureKeyBindings() not implemented"); 2496 qDebug("KABCore::configureKeyBindings() not implemented");
2496#endif //KAB_EMBEDDED 2497#endif //KAB_EMBEDDED
2497} 2498}
2498 2499
2499#ifdef KAB_EMBEDDED 2500#ifdef KAB_EMBEDDED
2500void KABCore::configureResources() 2501void KABCore::configureResources()
2501{ 2502{
2502 KRES::KCMKResources dlg( this, "" , 0 ); 2503 KRES::KCMKResources dlg( this, "" , 0 );
2503 2504
2504 if ( !dlg.exec() ) 2505 if ( !dlg.exec() )
2505 return; 2506 return;
2506 KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") ); 2507 KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") );
2507} 2508}
2508#endif //KAB_EMBEDDED 2509#endif //KAB_EMBEDDED
2509 2510
2510 2511
2511/* this method will be called through the QCop interface from Ko/Pi to select addresses 2512/* this method will be called through the QCop interface from Ko/Pi to select addresses
2512 * for the attendees list of an event. 2513 * for the attendees list of an event.
2513 */ 2514 */
2514void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid) 2515void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid)
2515{ 2516{
2516 2517
2517 bool ok = false; 2518 bool ok = false;
2518 mEmailSourceChannel = sourceChannel; 2519 mEmailSourceChannel = sourceChannel;
2519 int wid = uid.toInt( &ok ); 2520 int wid = uid.toInt( &ok );
2520 qDebug("UID %s ", uid.latin1()); 2521 qDebug("UID %s ", uid.latin1());
2521 if ( ok ) { 2522 if ( ok ) {
2522 if ( wid != QApplication::desktop()->width() ) { 2523 if ( wid != QApplication::desktop()->width() ) {
2523 qDebug("KA/Pi: Request from different desktop geometry. Resizing ..."); 2524 qDebug("KA/Pi: Request from different desktop geometry. Resizing ...");
2524 message( i18n("Resizing, please wait...") ); 2525 message( i18n("Resizing, please wait...") );
2525 mMainWindow->showMinimized(); 2526 mMainWindow->showMinimized();
2526 /* 2527 /*
2527 { 2528 {
2528 QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); 2529 QCopEnvelope e("QPE/Application/kapi", "callContactdialog()");
2529 } 2530 }
2530 */ 2531 */
2531 QTimer::singleShot( 1,this, SLOT ( resizeAndCallContactdialog() ) ); 2532 QTimer::singleShot( 1,this, SLOT ( resizeAndCallContactdialog() ) );
2532 return; 2533 return;
2533 } 2534 }
2534 2535
2535 } else { 2536 } else {
2536 qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid "); 2537 qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid ");
2537 } 2538 }
2538 callContactdialog(); 2539 callContactdialog();
2539 //QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); 2540 //QCopEnvelope e("QPE/Application/kapi", "callContactdialog()");
2540 2541
2541} 2542}
2542void KABCore::resizeAndCallContactdialog() 2543void KABCore::resizeAndCallContactdialog()
2543{ 2544{
2544 updateMainWindow(); 2545 updateMainWindow();
2545 QTimer::singleShot( 100,this, SLOT ( callContactdialog() ) ); 2546 QTimer::singleShot( 100,this, SLOT ( callContactdialog() ) );
2546} 2547}
2547 2548
2548void KABCore::callContactdialog() 2549void KABCore::callContactdialog()
2549{ 2550{
2550 QStringList nameList; 2551 QStringList nameList;
2551 QStringList emailList; 2552 QStringList emailList;
2552 QStringList uidList; 2553 QStringList uidList;
2553 qDebug("WIDTH %d ", QApplication::desktop()->width() ); 2554 qDebug("WIDTH %d ", QApplication::desktop()->width() );
2554 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); 2555 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this);
2555 uint i=0; 2556 uint i=0;
2556 for (i=0; i < list.count(); i++) 2557 for (i=0; i < list.count(); i++)
2557 { 2558 {
2558 nameList.append(list[i].realName()); 2559 nameList.append(list[i].realName());
2559 emailList.append(list[i].preferredEmail()); 2560 emailList.append(list[i].preferredEmail());
2560 uidList.append(list[i].uid()); 2561 uidList.append(list[i].uid());
2561 } 2562 }
2562 QString uid = "unnamed"; 2563 QString uid = "unnamed";
2563 //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1()); 2564 //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1());
2564 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(mEmailSourceChannel, uid, nameList, emailList, uidList); 2565 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(mEmailSourceChannel, uid, nameList, emailList, uidList);
2565 2566
2566} 2567}
2567/* this method will be called through the QCop interface from Ko/Pi to select birthdays 2568/* this method will be called through the QCop interface from Ko/Pi to select birthdays
2568 * to put them into the calendar. 2569 * to put them into the calendar.
2569 */ 2570 */
2570void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid) 2571void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid)
2571{ 2572{
2572 // qDebug("KABCore::requestForBirthdayList"); 2573 // qDebug("KABCore::requestForBirthdayList");
2573 QStringList birthdayList; 2574 QStringList birthdayList;
2574 QStringList anniversaryList; 2575 QStringList anniversaryList;
2575 QStringList realNameList; 2576 QStringList realNameList;
2576 QStringList preferredEmailList; 2577 QStringList preferredEmailList;
2577 QStringList assembledNameList; 2578 QStringList assembledNameList;
2578 QStringList uidList; 2579 QStringList uidList;
2579 2580
2580 KABC::AddressBook::Iterator it; 2581 KABC::AddressBook::Iterator it;
2581 2582
2582 int count = 0; 2583 int count = 0;
2583 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2584 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2584 ++count; 2585 ++count;
2585 } 2586 }
2586 QProgressBar bar(count,0 ); 2587 QProgressBar bar(count,0 );
2587 int w = 300; 2588 int w = 300;
2588 if ( QApplication::desktop()->width() < 320 ) 2589 if ( QApplication::desktop()->width() < 320 )
2589 w = 220; 2590 w = 220;
2590 int h = bar.sizeHint().height() ; 2591 int h = bar.sizeHint().height() ;
2591 int dw = QApplication::desktop()->width(); 2592 int dw = QApplication::desktop()->width();
2592 int dh = QApplication::desktop()->height(); 2593 int dh = QApplication::desktop()->height();
2593 bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); 2594 bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h );
2594 bar.show(); 2595 bar.show();
2595 bar.setCaption (i18n("Collecting birthdays - close to abort!") ); 2596 bar.setCaption (i18n("Collecting birthdays - close to abort!") );
2596 qApp->processEvents(); 2597 qApp->processEvents();
2597 2598
2598 QDate bday; 2599 QDate bday;
2599 QString anni; 2600 QString anni;
2600 QString formattedbday; 2601 QString formattedbday;
2601 2602
2602 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) 2603 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it )
2603 { 2604 {
2604 if ( ! bar.isVisible() ) 2605 if ( ! bar.isVisible() )
2605 return; 2606 return;
2606 bar.setProgress( count++ ); 2607 bar.setProgress( count++ );
2607 qApp->processEvents(); 2608 qApp->processEvents();
2608 bday = (*it).birthday().date(); 2609 bday = (*it).birthday().date();
2609 anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" ); 2610 anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" );
2610 2611
2611 if ( bday.isValid() || !anni.isEmpty()) 2612 if ( bday.isValid() || !anni.isEmpty())
2612 { 2613 {
2613 if (bday.isValid()) 2614 if (bday.isValid())
2614 formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate); 2615 formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate);
2615 else 2616 else
2616 formattedbday = "NOTVALID"; 2617 formattedbday = "NOTVALID";
2617 if (anni.isEmpty()) 2618 if (anni.isEmpty())
2618 anni = "INVALID"; 2619 anni = "INVALID";
2619 2620
2620 birthdayList.append(formattedbday); 2621 birthdayList.append(formattedbday);
2621 anniversaryList.append(anni); //should be ISODate 2622 anniversaryList.append(anni); //should be ISODate
2622 realNameList.append((*it).realName()); 2623 realNameList.append((*it).realName());
2623 preferredEmailList.append((*it).preferredEmail()); 2624 preferredEmailList.append((*it).preferredEmail());
2624 assembledNameList.append((*it).assembledName()); 2625 assembledNameList.append((*it).assembledName());
2625 uidList.append((*it).uid()); 2626 uidList.append((*it).uid());
2626 2627
2627 //qDebug("found birthday in KA/Pi: %s,%s,%s,%s: %s, %s", (*it).realName().latin1(), (*it).preferredEmail().latin1(), (*it).assembledName().latin1(), (*it).uid().latin1(), formattedbday.latin1(), anni.latin1() ); 2628 //qDebug("found birthday in KA/Pi: %s,%s,%s,%s: %s, %s", (*it).realName().latin1(), (*it).preferredEmail().latin1(), (*it).assembledName().latin1(), (*it).uid().latin1(), formattedbday.latin1(), anni.latin1() );
2628 } 2629 }
2629 } 2630 }
2630 2631
2631 bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList); 2632 bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList);
2632 2633
2633} 2634}
2634 2635
2635/* this method will be called through the QCop interface from other apps to show details of a contact. 2636/* this method will be called through the QCop interface from other apps to show details of a contact.
2636 */ 2637 */
2637void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid) 2638void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid)
2638{ 2639{
2639 //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); 2640 //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1());
2640 2641
2641 QString foundUid = QString::null; 2642 QString foundUid = QString::null;
2642 if ( ! uid.isEmpty() ) { 2643 if ( ! uid.isEmpty() ) {
2643 Addressee adrr = mAddressBook->findByUid( uid ); 2644 Addressee adrr = mAddressBook->findByUid( uid );
2644 if ( !adrr.isEmpty() ) { 2645 if ( !adrr.isEmpty() ) {
2645 foundUid = uid; 2646 foundUid = uid;
2646 } 2647 }
2647 if ( email == "sendbacklist" ) { 2648 if ( email == "sendbacklist" ) {
2648 //qDebug("ssssssssssssssssssssssend "); 2649 //qDebug("ssssssssssssssssssssssend ");
2649 QStringList nameList; 2650 QStringList nameList;
2650 QStringList emailList; 2651 QStringList emailList;
2651 QStringList uidList; 2652 QStringList uidList;
2652 nameList.append(adrr.realName()); 2653 nameList.append(adrr.realName());
2653 emailList = adrr.emails(); 2654 emailList = adrr.emails();
2654 uidList.append( adrr.preferredEmail()); 2655 uidList.append( adrr.preferredEmail());
2655 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); 2656 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList);
2656 return; 2657 return;
2657 } 2658 }
2658 2659
2659 } 2660 }
2660 2661
2661 if ( email == "sendbacklist" ) 2662 if ( email == "sendbacklist" )
2662 return; 2663 return;
2663 if (foundUid.isEmpty()) 2664 if (foundUid.isEmpty())
2664 { 2665 {
2665 //find the uid of the person first 2666 //find the uid of the person first
2666 Addressee::List namelist; 2667 Addressee::List namelist;
2667 Addressee::List emaillist; 2668 Addressee::List emaillist;
2668 2669
2669 if (!name.isEmpty()) 2670 if (!name.isEmpty())
2670 namelist = mAddressBook->findByName( name ); 2671 namelist = mAddressBook->findByName( name );
2671 2672
2672 if (!email.isEmpty()) 2673 if (!email.isEmpty())
2673 emaillist = mAddressBook->findByEmail( email ); 2674 emaillist = mAddressBook->findByEmail( email );
2674 //qDebug("count %d %d ", namelist.count(),emaillist.count() ); 2675 //qDebug("count %d %d ", namelist.count(),emaillist.count() );
2675 //check if we have a match in Namelist and Emaillist 2676 //check if we have a match in Namelist and Emaillist
2676 if ((namelist.count() == 0) && (emaillist.count() > 0)) { 2677 if ((namelist.count() == 0) && (emaillist.count() > 0)) {
2677 foundUid = emaillist[0].uid(); 2678 foundUid = emaillist[0].uid();
2678 } 2679 }
2679 else if ((namelist.count() > 0) && (emaillist.count() == 0)) 2680 else if ((namelist.count() > 0) && (emaillist.count() == 0))
2680 foundUid = namelist[0].uid(); 2681 foundUid = namelist[0].uid();
2681 else 2682 else
2682 { 2683 {
2683 for (int i = 0; i < namelist.count(); i++) 2684 for (int i = 0; i < namelist.count(); i++)
2684 { 2685 {
2685 for (int j = 0; j < emaillist.count(); j++) 2686 for (int j = 0; j < emaillist.count(); j++)
2686 { 2687 {
2687 if (namelist[i] == emaillist[j]) 2688 if (namelist[i] == emaillist[j])
2688 { 2689 {
2689 foundUid = namelist[i].uid(); 2690 foundUid = namelist[i].uid();
2690 } 2691 }
2691 } 2692 }
2692 } 2693 }
2693 } 2694 }
2694 } 2695 }
2695 else 2696 else
2696 { 2697 {
2697 foundUid = uid; 2698 foundUid = uid;
2698 } 2699 }
2699 2700
2700 if (!foundUid.isEmpty()) 2701 if (!foundUid.isEmpty())
2701 { 2702 {
2702 2703
2703 // raise Ka/Pi if it is in the background 2704 // raise Ka/Pi if it is in the background
2704#ifndef DESKTOP_VERSION 2705#ifndef DESKTOP_VERSION
2705#ifndef KORG_NODCOP 2706#ifndef KORG_NODCOP
2706 //QCopEnvelope e("QPE/Application/kapi", "raise()"); 2707 //QCopEnvelope e("QPE/Application/kapi", "raise()");
2707#endif 2708#endif
2708#endif 2709#endif
2709 2710
2710 mMainWindow->showMaximized(); 2711 mMainWindow->showMaximized();
2711 mMainWindow-> raise(); 2712 mMainWindow-> raise();
2712 2713
2713 mViewManager->setSelected( "", false); 2714 mViewManager->setSelected( "", false);
2714 mViewManager->refreshView( "" ); 2715 mViewManager->refreshView( "" );
2715 mViewManager->setSelected( foundUid, true ); 2716 mViewManager->setSelected( foundUid, true );
2716 mViewManager->refreshView( foundUid ); 2717 mViewManager->refreshView( foundUid );
2717 2718
2718 if ( !mMultipleViewsAtOnce ) 2719 if ( !mMultipleViewsAtOnce )
2719 { 2720 {
2720 setDetailsVisible( true ); 2721 setDetailsVisible( true );
2721 mActionDetails->setChecked(true); 2722 mActionDetails->setChecked(true);
2722 } 2723 }
2723 } 2724 }
2724} 2725}
2725 2726
2726void KABCore::whatsnew() 2727void KABCore::whatsnew()
2727{ 2728{
2728 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); 2729 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" );
2729} 2730}
2730void KABCore::synchowto() 2731void KABCore::synchowto()
2731{ 2732{
2732 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); 2733 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" );
2733} 2734}
2734void KABCore::kdesynchowto() 2735void KABCore::kdesynchowto()
2735{ 2736{
2736 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); 2737 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" );
2737} 2738}
2738void KABCore::multisynchowto() 2739void KABCore::multisynchowto()
2739{ 2740{
2740 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); 2741 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" );
2741} 2742}
2742void KABCore::faq() 2743void KABCore::faq()
2743{ 2744{
2744 KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); 2745 KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" );
2745} 2746}
2746 2747
2747#include <libkcal/syncdefines.h> 2748#include <libkcal/syncdefines.h>
2748 2749
2749KABC::Addressee KABCore::getLastSyncAddressee() 2750KABC::Addressee KABCore::getLastSyncAddressee()
2750{ 2751{
2751 Addressee lse; 2752 Addressee lse;
2752 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2753 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2753 2754
2754 //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); 2755 //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() );
2755 lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); 2756 lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice );
2756 if (lse.isEmpty()) { 2757 if (lse.isEmpty()) {
2757 qDebug("KA: Creating new last-syncAddressee "); 2758 qDebug("KA: Creating new last-syncAddressee ");
2758 lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); 2759 lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice );
2759 QString sum = ""; 2760 QString sum = "";
2760 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) 2761 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL )
2761 sum = "E: "; 2762 sum = "E: ";
2762 lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); 2763 lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event"));
2763 lse.setRevision( mLastAddressbookSync ); 2764 lse.setRevision( mLastAddressbookSync );
2764 lse.setCategories( i18n("SyncEvent") ); 2765 lse.setCategories( i18n("SyncEvent") );
2765 mAddressBook->insertAddressee( lse ); 2766 mAddressBook->insertAddressee( lse );
2766 } 2767 }
2767 return lse; 2768 return lse;
2768} 2769}
2769int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) 2770int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full )
2770{ 2771{
2771 2772
2772 //void setZaurusId(int id); 2773 //void setZaurusId(int id);
2773 // int zaurusId() const; 2774 // int zaurusId() const;
2774 // void setZaurusUid(int id); 2775 // void setZaurusUid(int id);
2775 // int zaurusUid() const; 2776 // int zaurusUid() const;
2776 // void setZaurusStat(int id); 2777 // void setZaurusStat(int id);
2777 // int zaurusStat() const; 2778 // int zaurusStat() const;
2778 // 0 equal 2779 // 0 equal
2779 // 1 take local 2780 // 1 take local
2780 // 2 take remote 2781 // 2 take remote
2781 // 3 cancel 2782 // 3 cancel
2782 QDateTime lastSync = mLastAddressbookSync; 2783 QDateTime lastSync = mLastAddressbookSync;
2783 QDateTime localMod = local->revision(); 2784 QDateTime localMod = local->revision();
2784 QDateTime remoteMod = remote->revision(); 2785 QDateTime remoteMod = remote->revision();
2785 2786
2786 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2787 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2787 2788
2788 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2789 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2789 bool remCh, locCh; 2790 bool remCh, locCh;
2790 remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); 2791 remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) );
2791 //if ( remCh ) 2792 //if ( remCh )
2792 // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); 2793 // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() );
2793 locCh = ( localMod > mLastAddressbookSync ); 2794 locCh = ( localMod > mLastAddressbookSync );
2794 //qDebug("cahnged rem %d loc %d",remCh, locCh ); 2795 //qDebug("cahnged rem %d loc %d",remCh, locCh );
2795 if ( !remCh && ! locCh ) { 2796 if ( !remCh && ! locCh ) {
2796 //qDebug("both not changed "); 2797 //qDebug("both not changed ");
2797 lastSync = localMod.addDays(1); 2798 lastSync = localMod.addDays(1);
2798 if ( mode <= SYNC_PREF_ASK ) 2799 if ( mode <= SYNC_PREF_ASK )
2799 return 0; 2800 return 0;
2800 } else { 2801 } else {
2801 if ( locCh ) { 2802 if ( locCh ) {
2802 //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); 2803 //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1());
2803 lastSync = localMod.addDays( -1 ); 2804 lastSync = localMod.addDays( -1 );
2804 if ( !remCh ) 2805 if ( !remCh )
2805 remoteMod =( lastSync.addDays( -1 ) ); 2806 remoteMod =( lastSync.addDays( -1 ) );
2806 } else { 2807 } else {
2807 //qDebug(" not loc changed "); 2808 //qDebug(" not loc changed ");
2808 lastSync = localMod.addDays( 1 ); 2809 lastSync = localMod.addDays( 1 );
2809 if ( remCh ) { 2810 if ( remCh ) {
2810 //qDebug("rem changed "); 2811 //qDebug("rem changed ");
2811 remoteMod =( lastSync.addDays( 1 ) ); 2812 remoteMod =( lastSync.addDays( 1 ) );
2812 } 2813 }
2813 2814
2814 } 2815 }
2815 } 2816 }
2816 full = true; 2817 full = true;
2817 if ( mode < SYNC_PREF_ASK ) 2818 if ( mode < SYNC_PREF_ASK )
2818 mode = SYNC_PREF_ASK; 2819 mode = SYNC_PREF_ASK;
2819 } else { 2820 } else {
2820 if ( localMod == remoteMod ) 2821 if ( localMod == remoteMod )
2821 return 0; 2822 return 0;
2822 2823
2823 } 2824 }
2824 //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec()); 2825 //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec());
2825 //qDebug("lastsync %s ", lastSync.toString().latin1() ); 2826 //qDebug("lastsync %s ", lastSync.toString().latin1() );
2826 //full = true; //debug only 2827 //full = true; //debug only
2827 if ( full ) { 2828 if ( full ) {
2828 bool equ = ( (*local) == (*remote) ); 2829 bool equ = ( (*local) == (*remote) );
2829 if ( equ ) { 2830 if ( equ ) {
2830 //qDebug("equal "); 2831 //qDebug("equal ");
2831 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2832 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2832 local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); 2833 local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) );
2833 } 2834 }
2834 if ( mode < SYNC_PREF_FORCE_LOCAL ) 2835 if ( mode < SYNC_PREF_FORCE_LOCAL )
2835 return 0; 2836 return 0;
2836 2837
2837 }//else //debug only 2838 }//else //debug only
2838 //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); 2839 //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1());
2839 } 2840 }
2840 int result; 2841 int result;
2841 bool localIsNew; 2842 bool localIsNew;
2842 //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , local->lastModified().toString().latin1() , remote->lastModified().toString().latin1() ); 2843 //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , local->lastModified().toString().latin1() , remote->lastModified().toString().latin1() );
2843 2844
2844 if ( full && mode < SYNC_PREF_NEWEST ) 2845 if ( full && mode < SYNC_PREF_NEWEST )
2845 mode = SYNC_PREF_ASK; 2846 mode = SYNC_PREF_ASK;
2846 2847
2847 switch( mode ) { 2848 switch( mode ) {
2848 case SYNC_PREF_LOCAL: 2849 case SYNC_PREF_LOCAL:
2849 if ( lastSync > remoteMod ) 2850 if ( lastSync > remoteMod )
2850 return 1; 2851 return 1;
2851 if ( lastSync > localMod ) 2852 if ( lastSync > localMod )
2852 return 2; 2853 return 2;
2853 return 1; 2854 return 1;
2854 break; 2855 break;
2855 case SYNC_PREF_REMOTE: 2856 case SYNC_PREF_REMOTE:
2856 if ( lastSync > remoteMod ) 2857 if ( lastSync > remoteMod )
2857 return 1; 2858 return 1;
2858 if ( lastSync > localMod ) 2859 if ( lastSync > localMod )
2859 return 2; 2860 return 2;
2860 return 2; 2861 return 2;
2861 break; 2862 break;
2862 case SYNC_PREF_NEWEST: 2863 case SYNC_PREF_NEWEST:
2863 if ( localMod > remoteMod ) 2864 if ( localMod > remoteMod )
2864 return 1; 2865 return 1;
2865 else 2866 else
2866 return 2; 2867 return 2;
2867 break; 2868 break;
2868 case SYNC_PREF_ASK: 2869 case SYNC_PREF_ASK:
2869 //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); 2870 //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() );
2870 if ( lastSync > remoteMod ) 2871 if ( lastSync > remoteMod )
2871 return 1; 2872 return 1;
2872 if ( lastSync > localMod ) { 2873 if ( lastSync > localMod ) {
2873 return 2; 2874 return 2;
2874 } 2875 }
2875 localIsNew = localMod >= remoteMod; 2876 localIsNew = localMod >= remoteMod;
2876 //qDebug("conflict! ************************************** "); 2877 //qDebug("conflict! ************************************** ");
2877 { 2878 {
2878 KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this ); 2879 KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this );
2879 result = acd.executeD(localIsNew); 2880 result = acd.executeD(localIsNew);
2880 return result; 2881 return result;
2881 } 2882 }
2882 break; 2883 break;
2883 case SYNC_PREF_FORCE_LOCAL: 2884 case SYNC_PREF_FORCE_LOCAL:
2884 return 1; 2885 return 1;
2885 break; 2886 break;
2886 case SYNC_PREF_FORCE_REMOTE: 2887 case SYNC_PREF_FORCE_REMOTE:
2887 return 2; 2888 return 2;
2888 break; 2889 break;
2889 2890
2890 default: 2891 default:
2891 // SYNC_PREF_TAKE_BOTH not implemented 2892 // SYNC_PREF_TAKE_BOTH not implemented
2892 break; 2893 break;
2893 } 2894 }
2894 return 0; 2895 return 0;
2895} 2896}
2896 2897
2897 2898
2898bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode) 2899bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode)
2899{ 2900{
2900 bool syncOK = true; 2901 bool syncOK = true;
2901 int addedAddressee = 0; 2902 int addedAddressee = 0;
2902 int addedAddresseeR = 0; 2903 int addedAddresseeR = 0;
2903 int deletedAddresseeR = 0; 2904 int deletedAddresseeR = 0;
2904 int deletedAddresseeL = 0; 2905 int deletedAddresseeL = 0;
2905 int changedLocal = 0; 2906 int changedLocal = 0;
2906 int changedRemote = 0; 2907 int changedRemote = 0;
2907 int filteredIN = 0; 2908 int filteredIN = 0;
2908 int filteredOUT = 0; 2909 int filteredOUT = 0;
2909 2910
2910 QString mCurrentSyncName = syncManager->getCurrentSyncName(); 2911 QString mCurrentSyncName = syncManager->getCurrentSyncName();
2911 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2912 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2912 2913
2913 //QPtrList<Addressee> el = local->rawAddressees(); 2914 //QPtrList<Addressee> el = local->rawAddressees();
2914 Addressee addresseeR; 2915 Addressee addresseeR;
2915 QString uid; 2916 QString uid;
2916 int take; 2917 int take;
2917 Addressee addresseeL; 2918 Addressee addresseeL;
2918 Addressee addresseeRSync; 2919 Addressee addresseeRSync;
2919 Addressee addresseeLSync; 2920 Addressee addresseeLSync;
2920 // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees(); 2921 // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees();
2921 //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees(); 2922 //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees();
2922 bool fullDateRange = false; 2923 bool fullDateRange = false;
2923 local->resetTempSyncStat(); 2924 local->resetTempSyncStat();
2924 mLastAddressbookSync = QDateTime::currentDateTime(); 2925 mLastAddressbookSync = QDateTime::currentDateTime();
2925 if ( syncManager->syncWithDesktop() ) { 2926 if ( syncManager->syncWithDesktop() ) {
2926 // remote->removeSyncInfo( QString());//remove all info 2927 // remote->removeSyncInfo( QString());//remove all info
2927 if ( KSyncManager::mRequestedSyncEvent.isValid() ) { 2928 if ( KSyncManager::mRequestedSyncEvent.isValid() ) {
2928 mLastAddressbookSync = KSyncManager::mRequestedSyncEvent; 2929 mLastAddressbookSync = KSyncManager::mRequestedSyncEvent;
2929 qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() ); 2930 qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() );
2930 } else { 2931 } else {
2931 qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime "); 2932 qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime ");
2932 } 2933 }
2933 } 2934 }
2934 QDateTime modifiedCalendar = mLastAddressbookSync; 2935 QDateTime modifiedCalendar = mLastAddressbookSync;
2935 addresseeLSync = getLastSyncAddressee(); 2936 addresseeLSync = getLastSyncAddressee();
2936 qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1()); 2937 qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1());
2937 addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName ); 2938 addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName );
2938 if ( !addresseeR.isEmpty() ) { 2939 if ( !addresseeR.isEmpty() ) {
2939 addresseeRSync = addresseeR; 2940 addresseeRSync = addresseeR;
2940 remote->removeAddressee(addresseeR ); 2941 remote->removeAddressee(addresseeR );
2941 2942
2942 } else { 2943 } else {
2943 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2944 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2944 addresseeRSync = addresseeLSync ; 2945 addresseeRSync = addresseeLSync ;
2945 } else { 2946 } else {
2946 //qDebug("FULLDATE 1"); 2947 //qDebug("FULLDATE 1");
2947 fullDateRange = true; 2948 fullDateRange = true;
2948 Addressee newAdd; 2949 Addressee newAdd;
2949 addresseeRSync = newAdd; 2950 addresseeRSync = newAdd;
2950 addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee")); 2951 addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee"));
2951 addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName ); 2952 addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName );
2952 addresseeRSync.setRevision( mLastAddressbookSync ); 2953 addresseeRSync.setRevision( mLastAddressbookSync );
2953 addresseeRSync.setCategories( i18n("SyncAddressee") ); 2954 addresseeRSync.setCategories( i18n("SyncAddressee") );
2954 } 2955 }
2955 } 2956 }
2956 if ( addresseeLSync.revision() == mLastAddressbookSync ) { 2957 if ( addresseeLSync.revision() == mLastAddressbookSync ) {
2957 // qDebug("FULLDATE 2"); 2958 // qDebug("FULLDATE 2");
2958 fullDateRange = true; 2959 fullDateRange = true;
2959 } 2960 }
2960 if ( ! fullDateRange ) { 2961 if ( ! fullDateRange ) {
2961 if ( addresseeLSync.revision() != addresseeRSync.revision() ) { 2962 if ( addresseeLSync.revision() != addresseeRSync.revision() ) {
2962 2963
2963 // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() ); 2964 // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() );
2964 //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec()); 2965 //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec());
2965 fullDateRange = true; 2966 fullDateRange = true;
2966 //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() ); 2967 //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() );
2967 } 2968 }
2968 } 2969 }
2969 // fullDateRange = true; // debug only! 2970 // fullDateRange = true; // debug only!
2970 if ( fullDateRange ) 2971 if ( fullDateRange )
2971 mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365); 2972 mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365);
2972 else 2973 else
2973 mLastAddressbookSync = addresseeLSync.revision(); 2974 mLastAddressbookSync = addresseeLSync.revision();
2974 // for resyncing if own file has changed 2975 // for resyncing if own file has changed
2975 // PENDING fixme later when implemented 2976 // PENDING fixme later when implemented
2976#if 0 2977#if 0
2977 if ( mCurrentSyncDevice == "deleteaftersync" ) { 2978 if ( mCurrentSyncDevice == "deleteaftersync" ) {
2978 mLastAddressbookSync = loadedFileVersion; 2979 mLastAddressbookSync = loadedFileVersion;
2979 qDebug("setting mLastAddressbookSync "); 2980 qDebug("setting mLastAddressbookSync ");
2980 } 2981 }
2981#endif 2982#endif
2982 2983
2983 2984
2984 // ********** setting filters **************** 2985 // ********** setting filters ****************
2985 Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB ); 2986 Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB );
2986 Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB ); 2987 Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB );
2987 2988
2988 //qDebug("*************************** "); 2989 //qDebug("*************************** ");
2989 // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() ); 2990 // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() );
2990 QStringList er = remote->uidList(); 2991 QStringList er = remote->uidList();
2991 Addressee inR ;//= er.first(); 2992 Addressee inR ;//= er.first();
2992 Addressee inL; 2993 Addressee inL;
2993 2994
2994 syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count()); 2995 syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count());
2995 2996
2996 int modulo = (er.count()/10)+1; 2997 int modulo = (er.count()/10)+1;
2997 int incCounter = 0; 2998 int incCounter = 0;
2998 while ( incCounter < er.count()) { 2999 while ( incCounter < er.count()) {
2999 if (syncManager->isProgressBarCanceled()) 3000 if (syncManager->isProgressBarCanceled())
3000 return false; 3001 return false;
3001 if ( incCounter % modulo == 0 ) 3002 if ( incCounter % modulo == 0 )
3002 syncManager->showProgressBar(incCounter); 3003 syncManager->showProgressBar(incCounter);
3003 3004
3004 uid = er[ incCounter ]; 3005 uid = er[ incCounter ];
3005 bool skipIncidence = false; 3006 bool skipIncidence = false;
3006 if ( uid.left(19) == QString("last-syncAddressee-") ) 3007 if ( uid.left(19) == QString("last-syncAddressee-") )
3007 skipIncidence = true; 3008 skipIncidence = true;
3008 QString idS,OidS; 3009 QString idS,OidS;
3009 qApp->processEvents(); 3010 qApp->processEvents();
3010 if ( !skipIncidence ) { 3011 if ( !skipIncidence ) {
3011 inL = local->findByUid( uid ); 3012 inL = local->findByUid( uid );
3012 inR = remote->findByUid( uid ); 3013 inR = remote->findByUid( uid );
3013 //inL.setResource( 0 ); 3014 //inL.setResource( 0 );
3014 //inR.setResource( 0 ); 3015 //inR.setResource( 0 );
3015 if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars 3016 if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars
3016 if ( !inL.resource() || inL.resource()->includeInSync() ) { 3017 if ( !inL.resource() || inL.resource()->includeInSync() ) {
3017 if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) { 3018 if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) {
3018 //qDebug("take %d %s ", take, inL.summary().latin1()); 3019 //qDebug("take %d %s ", take, inL.summary().latin1());
3019 if ( take == 3 ) 3020 if ( take == 3 )
3020 return false; 3021 return false;
3021 if ( take == 1 ) {// take local ********************** 3022 if ( take == 1 ) {// take local **********************
3022 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3023 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3023 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 3024 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
3024 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 3025 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
3025 local->insertAddressee( inL, false ); 3026 local->insertAddressee( inL, false );
3026 idS = inR.externalUID(); 3027 idS = inR.externalUID();
3027 OidS = inR.originalExternalUID(); 3028 OidS = inR.originalExternalUID();
3028 } 3029 }
3029 else 3030 else
3030 idS = inR.IDStr(); 3031 idS = inR.IDStr();
3031 remote->removeAddressee( inR ); 3032 remote->removeAddressee( inR );
3032 inR = inL; 3033 inR = inL;
3033 inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); 3034 inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL );
3034 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3035 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3035 inR.setOriginalExternalUID( OidS ); 3036 inR.setOriginalExternalUID( OidS );
3036 inR.setExternalUID( idS ); 3037 inR.setExternalUID( idS );
3037 if ( syncManager->syncWithDesktop() ) { 3038 if ( syncManager->syncWithDesktop() ) {
3038 inR.setIDStr("changed" ); 3039 inR.setIDStr("changed" );
3039 } 3040 }
3040 //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" ); 3041 //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" );
3041 } else { 3042 } else {
3042 inR.setIDStr( idS ); 3043 inR.setIDStr( idS );
3043 } 3044 }
3044 inR.setResource( 0 ); 3045 inR.setResource( 0 );
3045 remote->insertAddressee( inR , false); 3046 remote->insertAddressee( inR , false);
3046 ++changedRemote; 3047 ++changedRemote;
3047 } else { // take == 2 take remote ********************** 3048 } else { // take == 2 take remote **********************
3048 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3049 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3049 if ( inR.revision().date().year() < 2004 ) 3050 if ( inR.revision().date().year() < 2004 )
3050 inR.setRevision( modifiedCalendar ); 3051 inR.setRevision( modifiedCalendar );
3051 } 3052 }
3052 idS = inL.IDStr(); 3053 idS = inL.IDStr();
3053 local->removeAddressee( inL ); 3054 local->removeAddressee( inL );
3054 inL = inR; 3055 inL = inR;
3055 inL.setIDStr( idS ); 3056 inL.setIDStr( idS );
3056 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3057 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3057 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 3058 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
3058 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 3059 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
3059 } 3060 }
3060 inL.setResource( 0 ); 3061 inL.setResource( 0 );
3061 local->insertAddressee( inL , false ); 3062 local->insertAddressee( inL , false );
3062 ++changedLocal; 3063 ++changedLocal;
3063 } 3064 }
3064 } 3065 }
3065 } 3066 }
3066 } else { // no conflict ********** add or delete remote 3067 } else { // no conflict ********** add or delete remote
3067 if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) { 3068 if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) {
3068 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3069 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3069 QString des = addresseeLSync.note(); 3070 QString des = addresseeLSync.note();
3070 if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it 3071 if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it
3071 inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE ); 3072 inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE );
3072 remote->insertAddressee( inR, false ); 3073 remote->insertAddressee( inR, false );
3073 ++deletedAddresseeR; 3074 ++deletedAddresseeR;
3074 } else { 3075 } else {
3075 inR.setRevision( modifiedCalendar ); 3076 inR.setRevision( modifiedCalendar );
3076 remote->insertAddressee( inR, false ); 3077 remote->insertAddressee( inR, false );
3077 inL = inR; 3078 inL = inR;
3078 inL.setIDStr( ":" ); 3079 inL.setIDStr( ":" );
3079 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 3080 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
3080 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 3081 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
3081 inL.setResource( 0 ); 3082 inL.setResource( 0 );
3082 local->insertAddressee( inL , false); 3083 local->insertAddressee( inL , false);
3083 ++addedAddressee; 3084 ++addedAddressee;
3084 } 3085 }
3085 } else { 3086 } else {
3086 if ( inR.revision() > mLastAddressbookSync || mode == 5 ) { 3087 if ( inR.revision() > mLastAddressbookSync || mode == 5 ) {
3087 inR.setRevision( modifiedCalendar ); 3088 inR.setRevision( modifiedCalendar );
3088 remote->insertAddressee( inR, false ); 3089 remote->insertAddressee( inR, false );
3089 inR.setResource( 0 ); 3090 inR.setResource( 0 );
3090 local->insertAddressee( inR, false ); 3091 local->insertAddressee( inR, false );
3091 ++addedAddressee; 3092 ++addedAddressee;
3092 } else { 3093 } else {
3093 // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); 3094 // pending checkExternSyncAddressee(addresseeRSyncSharp, inR);
3094 remote->removeAddressee( inR ); 3095 remote->removeAddressee( inR );
3095 ++deletedAddresseeR; 3096 ++deletedAddresseeR;
3096 } 3097 }
3097 } 3098 }
3098 } else { 3099 } else {
3099 ++filteredIN; 3100 ++filteredIN;
3100 } 3101 }
3101 } 3102 }
3102 } 3103 }
3103 ++incCounter; 3104 ++incCounter;
3104 } 3105 }
3105 er.clear(); 3106 er.clear();
3106 QStringList el = local->uidList(); 3107 QStringList el = local->uidList();
3107 modulo = (el.count()/10)+1; 3108 modulo = (el.count()/10)+1;
3108 3109
3109 syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); 3110 syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count());
3110 incCounter = 0; 3111 incCounter = 0;
3111 while ( incCounter < el.count()) { 3112 while ( incCounter < el.count()) {
3112 qApp->processEvents(); 3113 qApp->processEvents();
3113 if (syncManager->isProgressBarCanceled()) 3114 if (syncManager->isProgressBarCanceled())
3114 return false; 3115 return false;
3115 if ( incCounter % modulo == 0 ) 3116 if ( incCounter % modulo == 0 )
3116 syncManager->showProgressBar(incCounter); 3117 syncManager->showProgressBar(incCounter);
3117 uid = el[ incCounter ]; 3118 uid = el[ incCounter ];
3118 bool skipIncidence = false; 3119 bool skipIncidence = false;
3119 if ( uid.left(19) == QString("last-syncAddressee-") ) 3120 if ( uid.left(19) == QString("last-syncAddressee-") )
3120 skipIncidence = true; 3121 skipIncidence = true;
3121 if ( !skipIncidence ) { 3122 if ( !skipIncidence ) {
3122 inL = local->findByUid( uid ); 3123 inL = local->findByUid( uid );
3123 if ( !inL.resource() || inL.resource()->includeInSync() ) { 3124 if ( !inL.resource() || inL.resource()->includeInSync() ) {
3124 inR = remote->findByUid( uid ); 3125 inR = remote->findByUid( uid );
3125 if ( inR.isEmpty() ){ 3126 if ( inR.isEmpty() ){
3126 if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) { 3127 if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) {
3127 // no conflict ********** add or delete local 3128 // no conflict ********** add or delete local
3128 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3129 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3129 if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { 3130 if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) {
3130 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); 3131 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL);
3131 local->removeAddressee( inL ); 3132 local->removeAddressee( inL );
3132 ++deletedAddresseeL; 3133 ++deletedAddresseeL;
3133 } else { 3134 } else {
3134 if ( ! syncManager->mWriteBackExistingOnly ) { 3135 if ( ! syncManager->mWriteBackExistingOnly ) {
3135 inL.removeID(mCurrentSyncDevice ); 3136 inL.removeID(mCurrentSyncDevice );
3136 ++addedAddresseeR; 3137 ++addedAddresseeR;
3137 inL.setRevision( modifiedCalendar ); 3138 inL.setRevision( modifiedCalendar );
3138 local->insertAddressee( inL, false ); 3139 local->insertAddressee( inL, false );
3139 inR = inL; 3140 inR = inL;
3140 inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); 3141 inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL );
3141 inR.setResource( 0 ); 3142 inR.setResource( 0 );
3142 remote->insertAddressee( inR, false ); 3143 remote->insertAddressee( inR, false );
3143 } 3144 }
3144 } 3145 }
3145 } else { 3146 } else {
3146 if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { 3147 if ( inL.revision() < mLastAddressbookSync && mode != 4 ) {
3147 //qDebug("data %s ", inL.revision().toString().latin1()); 3148 //qDebug("data %s ", inL.revision().toString().latin1());
3148 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); 3149 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL);
3149 local->removeAddressee( inL ); 3150 local->removeAddressee( inL );
3150 ++deletedAddresseeL; 3151 ++deletedAddresseeL;
3151 } else { 3152 } else {
3152 if ( ! syncManager->mWriteBackExistingOnly ) { 3153 if ( ! syncManager->mWriteBackExistingOnly ) {
3153 ++addedAddresseeR; 3154 ++addedAddresseeR;
3154 inL.setRevision( modifiedCalendar ); 3155 inL.setRevision( modifiedCalendar );
3155 local->insertAddressee( inL, false ); 3156 local->insertAddressee( inL, false );
3156 inR = inL; 3157 inR = inL;
3157 inR.setIDStr( ":" ); 3158 inR.setIDStr( ":" );
3158 inR.setResource( 0 ); 3159 inR.setResource( 0 );
3159 remote->insertAddressee( inR, false ); 3160 remote->insertAddressee( inR, false );
3160 } 3161 }
3161 } 3162 }
3162 } 3163 }
3163 } else { 3164 } else {
3164 ++filteredOUT; 3165 ++filteredOUT;
3165 } 3166 }
3166 } 3167 }
3167 } 3168 }
3168 } 3169 }
3169 ++incCounter; 3170 ++incCounter;
3170 } 3171 }
3171 el.clear(); 3172 el.clear();
3172 syncManager->hideProgressBar(); 3173 syncManager->hideProgressBar();
3173 mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); 3174 mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 );
3174 // get rid of micro seconds 3175 // get rid of micro seconds
3175 QTime t = mLastAddressbookSync.time(); 3176 QTime t = mLastAddressbookSync.time();
3176 mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); 3177 mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) );
3177 addresseeLSync.setRevision( mLastAddressbookSync ); 3178 addresseeLSync.setRevision( mLastAddressbookSync );
3178 addresseeRSync.setRevision( mLastAddressbookSync ); 3179 addresseeRSync.setRevision( mLastAddressbookSync );
3179 addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; 3180 addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ;
3180 addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); 3181 addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName );
3181 addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; 3182 addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ;
3182 addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); 3183 addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") );
3183 addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; 3184 addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ;
3184 addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); 3185 addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() );
3185 addresseeRSync.setNote( "" ) ; 3186 addresseeRSync.setNote( "" ) ;
3186 addresseeLSync.setNote( "" ); 3187 addresseeLSync.setNote( "" );
3187 3188
3188 if ( mGlobalSyncMode == SYNC_MODE_NORMAL) 3189 if ( mGlobalSyncMode == SYNC_MODE_NORMAL)
3189 remote->insertAddressee( addresseeRSync, false ); 3190 remote->insertAddressee( addresseeRSync, false );
3190 local->insertAddressee( addresseeLSync, false ); 3191 local->insertAddressee( addresseeLSync, false );
3191 QString mes; 3192 QString mes;
3192 mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR, filteredIN, filteredOUT ); 3193 mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR, filteredIN, filteredOUT );
3193 qDebug( mes ); 3194 qDebug( mes );
3194 mes = i18n("Local addressbook changed!\n") +mes; 3195 mes = i18n("Local addressbook changed!\n") +mes;
3195 if ( syncManager->mShowSyncSummary ) { 3196 if ( syncManager->mShowSyncSummary ) {
3196 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, 3197 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes,
3197 i18n("KA/Pi Synchronization"),i18n("Write back"))) { 3198 i18n("KA/Pi Synchronization"),i18n("Write back"))) {
3198 qDebug("KA: WB cancelled "); 3199 qDebug("KA: WB cancelled ");
3199 syncManager->mWriteBackFile = false; 3200 syncManager->mWriteBackFile = false;
3200 return syncOK; 3201 return syncOK;
3201 } 3202 }
3202 } 3203 }
3203 return syncOK; 3204 return syncOK;
3204} 3205}
3205 3206
3206 3207
3207//this is a overwritten callbackmethods from the syncinterface 3208//this is a overwritten callbackmethods from the syncinterface
3208bool KABCore::sync(KSyncManager* manager, QString filename, int mode) 3209bool KABCore::sync(KSyncManager* manager, QString filename, int mode)
3209{ 3210{
3210 3211
3211 //pending prepare addresseeview for output 3212 //pending prepare addresseeview for output
3212 //pending detect, if remote file has REV field. if not switch to external sync 3213 //pending detect, if remote file has REV field. if not switch to external sync
3213 mGlobalSyncMode = SYNC_MODE_NORMAL; 3214 mGlobalSyncMode = SYNC_MODE_NORMAL;
3214 if ( manager != syncManager ) 3215 if ( manager != syncManager )
3215 qDebug("KABCore::sync:: ERROR! :: manager != syncManager "); 3216 qDebug("KABCore::sync:: ERROR! :: manager != syncManager ");
3216 QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); 3217 QString mCurrentSyncDevice = manager->getCurrentSyncDevice();
3217 3218
3218 AddressBook abLocal(filename,"syncContact"); 3219 AddressBook abLocal(filename,"syncContact");
3219 bool syncOK = false; 3220 bool syncOK = false;
3220 if ( abLocal.load() ) { 3221 if ( abLocal.load() ) {
3221 qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode ); 3222 qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode );
3222 bool external = false; 3223 bool external = false;
3223 bool isXML = false; 3224 bool isXML = false;
3224 if ( filename.right(4) == ".xml") { 3225 if ( filename.right(4) == ".xml") {
3225 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3226 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3226 isXML = true; 3227 isXML = true;
3227 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); 3228 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true );
3228 } else { 3229 } else {
3229 external = !manager->mIsKapiFile; 3230 external = !manager->mIsKapiFile;
3230 if ( external ) { 3231 if ( external ) {
3231 qDebug("KA: Sync::Setting vcf mode to external "); 3232 qDebug("KA: Sync::Setting vcf mode to external ");
3232 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3233 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3233 AddressBook::Iterator it; 3234 AddressBook::Iterator it;
3234 for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { 3235 for ( it = abLocal.begin(); it != abLocal.end(); ++it ) {
3235 (*it).setID( mCurrentSyncDevice, (*it).uid() ); 3236 (*it).setID( mCurrentSyncDevice, (*it).uid() );
3236 (*it).computeCsum( mCurrentSyncDevice ); 3237 (*it).computeCsum( mCurrentSyncDevice );
3237 } 3238 }
3238 } 3239 }
3239 } 3240 }
3240 //AddressBook::Iterator it; 3241 //AddressBook::Iterator it;
3241 //QStringList vcards; 3242 //QStringList vcards;
3242 //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { 3243 //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) {
3243 // qDebug("Name %s ", (*it).familyName().latin1()); 3244 // qDebug("Name %s ", (*it).familyName().latin1());
3244 //} 3245 //}
3245 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); 3246 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode );
3246 syncManager->hideProgressBar(); 3247 syncManager->hideProgressBar();
3247 if ( syncOK ) { 3248 if ( syncOK ) {
3248 if ( syncManager->mWriteBackFile ) 3249 if ( syncManager->mWriteBackFile )
3249 { 3250 {
3250 if ( external ) 3251 if ( external )
3251 abLocal.removeSyncAddressees( !isXML); 3252 abLocal.removeSyncAddressees( !isXML);
3252 qDebug("KA: Sync::Saving remote AB "); 3253 qDebug("KA: Sync::Saving remote AB ");
3253 if ( ! abLocal.saveAB()) 3254 if ( ! abLocal.saveAB())
3254 qDebug("KA: sync::Error writing back AB to file "); 3255 qDebug("KA: sync::Error writing back AB to file ");
3255 if ( external ) { 3256 if ( external ) {
3256 // afterwrite processing 3257 // afterwrite processing
3257 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); 3258 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML);
3258 } 3259 }
3259 } 3260 }
3260 } 3261 }
3261 setModified(); 3262 setModified();
3262 3263
3263 } 3264 }
3264 abLocal.removeResources(); 3265 abLocal.removeResources();
3265 if ( syncOK ) 3266 if ( syncOK )
3266 mViewManager->refreshView(); 3267 mViewManager->refreshView();
3267 return syncOK; 3268 return syncOK;
3268 3269
3269} 3270}
3270void KABCore::removeSyncInfo( QString syncProfile) 3271void KABCore::removeSyncInfo( QString syncProfile)
3271{ 3272{
3272 qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1()); 3273 qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1());
3273 mAddressBook->removeSyncInfo( syncProfile ); 3274 mAddressBook->removeSyncInfo( syncProfile );
3274 setModified(); 3275 setModified();
3275} 3276}
3276 3277
3277 3278
3278//this is a overwritten callbackmethods from the syncinterface 3279//this is a overwritten callbackmethods from the syncinterface
3279bool KABCore::syncExternal(KSyncManager* manager, QString resource) 3280bool KABCore::syncExternal(KSyncManager* manager, QString resource)
3280{ 3281{
3281 if ( resource == "phone" ) 3282 if ( resource == "phone" )
3282 return syncPhone(); 3283 return syncPhone();
3283 disableBR( true ); 3284 disableBR( true );
3284 if ( manager != syncManager ) 3285 if ( manager != syncManager )
3285 qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager "); 3286 qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager ");
3286 QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); 3287 QString mCurrentSyncDevice = manager->getCurrentSyncDevice();
3287 3288
3288 AddressBook abLocal( resource,"syncContact"); 3289 AddressBook abLocal( resource,"syncContact");
3289 bool syncOK = false; 3290 bool syncOK = false;
3290 message(i18n("Loading DTM address data..."), false); 3291 message(i18n("Loading DTM address data..."), false);
3291 if ( abLocal.load() ) { 3292 if ( abLocal.load() ) {
3292 qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); 3293 qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1());
3293 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3294 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3294 message(i18n("Sync preprocessing..."),false); 3295 message(i18n("Sync preprocessing..."),false);
3295 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); 3296 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false );
3296 message(i18n("Synchronizing..."),false); 3297 message(i18n("Synchronizing..."),false);
3297 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); 3298 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs );
3298 syncManager->hideProgressBar(); 3299 syncManager->hideProgressBar();
3299 if ( syncOK ) { 3300 if ( syncOK ) {
3300 if ( syncManager->mWriteBackFile ) { 3301 if ( syncManager->mWriteBackFile ) {
3301 abLocal.removeSyncAddressees( false ); 3302 abLocal.removeSyncAddressees( false );
3302 message(i18n("Saving DTM address data..."),false); 3303 message(i18n("Saving DTM address data..."),false);
3303 abLocal.saveAB(); 3304 abLocal.saveAB();
3304 message(i18n("Sync postprocessing..."),false); 3305 message(i18n("Sync postprocessing..."),false);
3305 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); 3306 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true );
3306 } 3307 }
3307 } else 3308 } else
3308 message( i18n("Sync cancelled or failed.") ); 3309 message( i18n("Sync cancelled or failed.") );
3309 setModified(); 3310 setModified();
3310 } 3311 }
3311 abLocal.removeResources(); 3312 abLocal.removeResources();
3312 if ( syncOK ) { 3313 if ( syncOK ) {
3313 mViewManager->refreshView(); 3314 mViewManager->refreshView();
3314 message(i18n("DTM syncing finished.")); 3315 message(i18n("DTM syncing finished."));
3315 } 3316 }
3316 disableBR( false ); 3317 disableBR( false );
3317 return syncOK; 3318 return syncOK;
3318 3319
3319} 3320}
3320void KABCore::message( QString m, bool startTimer) 3321void KABCore::message( QString m, bool startTimer)
3321{ 3322{
3322 topLevelWidget()->setCaption( m ); 3323 topLevelWidget()->setCaption( m );
3323 qApp->processEvents(); 3324 qApp->processEvents();
3324 if ( startTimer ) 3325 if ( startTimer )
3325 mMessageTimer->start( 15000, true ); 3326 mMessageTimer->start( 15000, true );
3326 else 3327 else
3327 mMessageTimer->stop(); 3328 mMessageTimer->stop();
3328} 3329}
3329bool KABCore::syncPhone() 3330bool KABCore::syncPhone()
3330{ 3331{
3331 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 3332 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
3332 QString fileName = getPhoneFile(); 3333 QString fileName = getPhoneFile();
3333 if ( !PhoneAccess::readFromPhone( fileName) ) { 3334 if ( !PhoneAccess::readFromPhone( fileName) ) {
3334 message(i18n("Phone access failed!")); 3335 message(i18n("Phone access failed!"));
3335 return false; 3336 return false;
3336 } 3337 }
3337 AddressBook abLocal( fileName,"syncContact"); 3338 AddressBook abLocal( fileName,"syncContact");
3338 bool syncOK = false; 3339 bool syncOK = false;
3339 { 3340 {
3340 abLocal.importFromFile( fileName ); 3341 abLocal.importFromFile( fileName );
3341 qDebug("KA: AB phone loaded ,sync device %s",mCurrentSyncDevice.latin1()); 3342 qDebug("KA: AB phone loaded ,sync device %s",mCurrentSyncDevice.latin1());
3342 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3343 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3343 abLocal.preparePhoneSync( mCurrentSyncDevice, true ); 3344 abLocal.preparePhoneSync( mCurrentSyncDevice, true );
3344 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); 3345 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true );
3345 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); 3346 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs );
3346 syncManager->hideProgressBar(); 3347 syncManager->hideProgressBar();
3347 if ( syncOK ) { 3348 if ( syncOK ) {
3348 if ( syncManager->mWriteBackFile ) { 3349 if ( syncManager->mWriteBackFile ) {
3349 abLocal.removeSyncAddressees( true ); 3350 abLocal.removeSyncAddressees( true );
3350 abLocal.saveABphone( fileName ); 3351 abLocal.saveABphone( fileName );
3351 abLocal.findNewExtIds( fileName, mCurrentSyncDevice ); 3352 abLocal.findNewExtIds( fileName, mCurrentSyncDevice );
3352 //abLocal.preparePhoneSync( mCurrentSyncDevice, false ); 3353 //abLocal.preparePhoneSync( mCurrentSyncDevice, false );
3353 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); 3354 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true );
3354 } 3355 }
3355 } 3356 }
3356 setModified(); 3357 setModified();
3357 } 3358 }
3358 abLocal.removeResources(); 3359 abLocal.removeResources();
3359 if ( syncOK ) 3360 if ( syncOK )
3360 mViewManager->refreshView(); 3361 mViewManager->refreshView();
3361 return syncOK; 3362 return syncOK;
3362} 3363}
3363void KABCore::getFile( bool success ) 3364void KABCore::getFile( bool success )
3364{ 3365{
3365 if ( ! success ) { 3366 if ( ! success ) {
3366 message( i18n("Error receiving file. Nothing changed!") ); 3367 message( i18n("Error receiving file. Nothing changed!") );
3367 return; 3368 return;
3368 } 3369 }
3369 int count = mAddressBook->importFromFile( sentSyncFile() , false, true ); 3370 int count = mAddressBook->importFromFile( sentSyncFile() , false, true );
3370 if ( count ) 3371 if ( count )
3371 setModified( true ); 3372 setModified( true );
3372 message( i18n("Pi-Sync successful!") ); 3373 message( i18n("Pi-Sync successful!") );
3373 mViewManager->refreshView(); 3374 mViewManager->refreshView();
3374} 3375}
3375void KABCore::syncFileRequest() 3376void KABCore::syncFileRequest()
3376{ 3377{
3377 if ( KABPrefs::instance()->mPassiveSyncWithDesktop ) { 3378 if ( KABPrefs::instance()->mPassiveSyncWithDesktop ) {
3378 syncManager->slotSyncMenu( 999 ); 3379 syncManager->slotSyncMenu( 999 );
3379 } 3380 }
3380 mAddressBook->export2File( sentSyncFile() ); 3381 mAddressBook->export2File( sentSyncFile() );
3381} 3382}
3382QString KABCore::sentSyncFile() 3383QString KABCore::sentSyncFile()
3383{ 3384{
3384#ifdef DESKTOP_VERSION 3385#ifdef DESKTOP_VERSION
3385 return locateLocal( "tmp", "copysyncab.vcf" ); 3386 return locateLocal( "tmp", "copysyncab.vcf" );
3386#else 3387#else
3387 return QString( "/tmp/copysyncab.vcf" ); 3388 return QString( "/tmp/copysyncab.vcf" );
3388#endif 3389#endif
3389} 3390}
3390 3391
3391void KABCore::setCaptionBack() 3392void KABCore::setCaptionBack()
3392{ 3393{
3393 mMessageTimer->stop(); 3394 mMessageTimer->stop();
3394 topLevelWidget()->setCaption( i18n("KAddressbook/Pi") ); 3395 topLevelWidget()->setCaption( i18n("KAddressbook/Pi") );
3395} 3396}
diff --git a/kaddressbook/viewmanager.cpp b/kaddressbook/viewmanager.cpp
index 86f0f3d..0614d06 100644
--- a/kaddressbook/viewmanager.cpp
+++ b/kaddressbook/viewmanager.cpp
@@ -1,737 +1,737 @@
1/* 1/*
2 This file is part of KAddressBook. 2 This file is part of KAddressBook.
3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com> 3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24/* 24/*
25Enhanced Version of the file for platform independent KDE tools. 25Enhanced Version of the file for platform independent KDE tools.
26Copyright (c) 2004 Ulf Schenk 26Copyright (c) 2004 Ulf Schenk
27 27
28$Id$ 28$Id$
29*/ 29*/
30 30
31 31
32#ifndef KAB_EMBEDDED 32#ifndef KAB_EMBEDDED
33#include <libkdepim/kvcarddrag.h> 33#include <libkdepim/kvcarddrag.h>
34#include <kabc/vcardconverter.h> 34#include <kabc/vcardconverter.h>
35#include <kconfig.h> 35#include <kconfig.h>
36#include <kdeversion.h> 36#include <kdeversion.h>
37#include <kiconloader.h> 37#include <kiconloader.h>
38#include <klocale.h> 38#include <klocale.h>
39#include <kmessagebox.h> 39#include <kmessagebox.h>
40#include <kmultipledrag.h> 40#include <kmultipledrag.h>
41#include <ktrader.h> 41#include <ktrader.h>
42#include <kurldrag.h> 42#include <kurldrag.h>
43 43
44#include "addresseeutil.h" 44#include "addresseeutil.h"
45#else //KAB_EMBEDDED 45#else //KAB_EMBEDDED
46#include "views/kaddressbookiconview.h" 46#include "views/kaddressbookiconview.h"
47#include "views/kaddressbooktableview.h" 47#include "views/kaddressbooktableview.h"
48#include "views/kaddressbookcardview.h" 48#include "views/kaddressbookcardview.h"
49#include "kaddressbookview.h" 49#include "kaddressbookview.h"
50 50
51#include <qaction.h> 51#include <qaction.h>
52#include <qmessagebox.h> 52#include <qmessagebox.h>
53#include <qpopupmenu.h> 53#include <qpopupmenu.h>
54#include <kconfigbase.h> 54#include <kconfigbase.h>
55 55
56#endif //KAB_EMBEDDED 56#endif //KAB_EMBEDDED
57 57
58 58
59#include <kdebug.h> 59#include <kdebug.h>
60#include <kactionclasses.h> 60#include <kactionclasses.h>
61 61
62#include <qlayout.h> 62#include <qlayout.h>
63#include <qapplication.h> 63#include <qapplication.h>
64#include <qwidgetstack.h> 64#include <qwidgetstack.h>
65 65
66#include <kabc/addressbook.h> 66#include <kabc/addressbook.h>
67#include "filtereditdialog.h" 67#include "filtereditdialog.h"
68#include "addviewdialog.h" 68#include "addviewdialog.h"
69#include "kabcore.h" 69#include "kabcore.h"
70#include "kabprefs.h" 70#include "kabprefs.h"
71#include "viewmanager.h" 71#include "viewmanager.h"
72 72
73ViewManager::ViewManager( KABCore *core, QWidget *parent, const char *name ) 73ViewManager::ViewManager( KABCore *core, QWidget *parent, const char *name )
74 : QWidget( parent, name ), mCore( core ), mActiveView( 0 ) 74 : QWidget( parent, name ), mCore( core ), mActiveView( 0 )
75{ 75{
76 initGUI(); 76 initGUI();
77 initActions(); 77 initActions();
78 78
79 mViewDict.setAutoDelete( true ); 79 mViewDict.setAutoDelete( true );
80 80
81 createViewFactories(); 81 createViewFactories();
82} 82}
83 83
84ViewManager::~ViewManager() 84ViewManager::~ViewManager()
85{ 85{
86 unloadViews(); 86 unloadViews();
87 mViewFactoryDict.clear(); 87 mViewFactoryDict.clear();
88} 88}
89void ViewManager::scrollUP() 89void ViewManager::scrollUP()
90{ 90{
91 if ( mActiveView ) 91 if ( mActiveView )
92 mActiveView->scrollUP(); 92 mActiveView->scrollUP();
93} 93}
94void ViewManager::scrollDOWN() 94void ViewManager::scrollDOWN()
95{ 95{
96 if ( mActiveView ) 96 if ( mActiveView )
97 mActiveView->scrollDOWN(); 97 mActiveView->scrollDOWN();
98} 98}
99void ViewManager::restoreSettings() 99void ViewManager::restoreSettings()
100{ 100{
101 mViewNameList = KABPrefs::instance()->mViewNames; 101 mViewNameList = KABPrefs::instance()->mViewNames;
102 QString activeViewName = KABPrefs::instance()->mCurrentView; 102 QString activeViewName = KABPrefs::instance()->mCurrentView;
103 103
104 mActionSelectView->setItems( mViewNameList ); 104 mActionSelectView->setItems( mViewNameList );
105 105
106 // Filter 106 // Filter
107 mFilterList = Filter::restore( mCore->config(), "Filter" ); 107 mFilterList = Filter::restore( mCore->config(), "Filter" );
108 mActionSelectFilter->setItems( filterNames() ); 108 mActionSelectFilter->setItems( filterNames() );
109 mActionSelectFilter->setCurrentItem( KABPrefs::instance()->mCurrentFilter ); 109 mActionSelectFilter->setCurrentItem( KABPrefs::instance()->mCurrentFilter );
110 int cw = 150; 110 int cw = 150;
111 if (QApplication::desktop()->width() == 480 && !KABPrefs::instance()->mHideSearchOnSwitch) 111 if (QApplication::desktop()->width() == 480 && !KABPrefs::instance()->mHideSearchOnSwitch)
112 cw = 0; 112 cw = 0;
113 mActionSelectFilter->setComboWidth( cw ); 113 mActionSelectFilter->setComboWidth( cw );
114 // Tell the views to reread their config, since they may have 114 // Tell the views to reread their config, since they may have
115 // been modified by global settings 115 // been modified by global settings
116 QString _oldgroup = mCore->config()->group(); 116 QString _oldgroup = mCore->config()->group();
117 117
118 QDictIterator<KAddressBookView> it( mViewDict ); 118 QDictIterator<KAddressBookView> it( mViewDict );
119 for ( it.toFirst(); it.current(); ++it ) { 119 for ( it.toFirst(); it.current(); ++it ) {
120 KConfigGroupSaver saver( mCore->config(), it.currentKey() ); 120 KConfigGroupSaver saver( mCore->config(), it.currentKey() );
121 it.current()->readConfig( mCore->config() ); 121 it.current()->readConfig( mCore->config() );
122 } 122 }
123 setActiveView( activeViewName ); 123 setActiveView( activeViewName );
124 124
125 mActionDeleteView->setEnabled( mViewNameList.count() > 1 ); 125 mActionDeleteView->setEnabled( mViewNameList.count() > 1 );
126} 126}
127 127
128void ViewManager::saveSettings() 128void ViewManager::saveSettings()
129{ 129{
130 QString _oldgroup = mCore->config()->group(); 130 QString _oldgroup = mCore->config()->group();
131 131
132 QDictIterator<KAddressBookView> it( mViewDict ); 132 QDictIterator<KAddressBookView> it( mViewDict );
133 for ( it.toFirst(); it.current(); ++it ) { 133 for ( it.toFirst(); it.current(); ++it ) {
134 KConfigGroupSaver saver( mCore->config(), it.currentKey() ); 134 KConfigGroupSaver saver( mCore->config(), it.currentKey() );
135#ifdef DESKTOP_VERSION 135#ifdef DESKTOP_VERSION
136 (*it)->writeConfig( mCore->config() ); 136 (*it)->writeConfig( mCore->config() );
137#else 137#else
138 (*it).writeConfig( mCore->config() ); 138 (*it).writeConfig( mCore->config() );
139#endif 139#endif
140 } 140 }
141 141
142 Filter::save( mCore->config(), "Filter", mFilterList ); 142 Filter::save( mCore->config(), "Filter", mFilterList );
143 KABPrefs::instance()->mCurrentFilter = mActionSelectFilter->currentItem(); 143 KABPrefs::instance()->mCurrentFilter = mActionSelectFilter->currentItem();
144 144
145 // write the view name list 145 // write the view name list
146 KABPrefs::instance()->mViewNames = mViewNameList; 146 KABPrefs::instance()->mViewNames = mViewNameList;
147 KABPrefs::instance()->mCurrentView = mActiveView->caption(); 147 KABPrefs::instance()->mCurrentView = mActiveView->caption();
148 148
149} 149}
150 150
151QStringList ViewManager::selectedUids() const 151QStringList ViewManager::selectedUids() const
152{ 152{
153 if ( mActiveView ) 153 if ( mActiveView )
154 return mActiveView->selectedUids(); 154 return mActiveView->selectedUids();
155 else 155 else
156 return QStringList(); 156 return QStringList();
157} 157}
158 158
159QStringList ViewManager::selectedEmails() const 159QStringList ViewManager::selectedEmails() const
160{ 160{
161 if ( mActiveView ) 161 if ( mActiveView )
162 return mActiveView->selectedEmails(); 162 return mActiveView->selectedEmails();
163 else 163 else
164 return QStringList(); 164 return QStringList();
165} 165}
166 166
167KABC::Addressee::List ViewManager::selectedAddressees() const 167KABC::Addressee::List ViewManager::selectedAddressees() const
168{ 168{
169 KABC::Addressee::List list; 169 KABC::Addressee::List list;
170 if ( mActiveView ) { 170 if ( mActiveView ) {
171 QStringList uids = mActiveView->selectedUids(); 171 QStringList uids = mActiveView->selectedUids();
172 QStringList::Iterator it; 172 QStringList::Iterator it;
173 for ( it = uids.begin(); it != uids.end(); ++it ) { 173 for ( it = uids.begin(); it != uids.end(); ++it ) {
174 KABC::Addressee addr = mCore->addressBook()->findByUid( *it ); 174 KABC::Addressee addr = mCore->addressBook()->findByUid( *it );
175 if ( !addr.isEmpty() ) 175 if ( !addr.isEmpty() )
176 list.append( addr ); 176 list.append( addr );
177 } 177 }
178 } 178 }
179 179
180 return list; 180 return list;
181} 181}
182//US added another method with no parameter, since my moc compiler does not support default parameters. 182//US added another method with no parameter, since my moc compiler does not support default parameters.
183void ViewManager::setSelected() 183void ViewManager::setSelected()
184{ 184{
185 setSelected( QString::null, true ); 185 setSelected( QString::null, true );
186} 186}
187 187
188void ViewManager::setSelected( const QString &uid, bool selected ) 188void ViewManager::setSelected( const QString &uid, bool selected )
189{ 189{
190 if ( mActiveView ) 190 if ( mActiveView )
191 mActiveView->setSelected( uid, selected ); 191 mActiveView->setSelected( uid, selected );
192} 192}
193 193
194void ViewManager::setListSelected(QStringList list) 194void ViewManager::setListSelected(QStringList list)
195{ 195{
196 int i, count = list.count(); 196 int i, count = list.count();
197 for ( i = 0; i < count;++i ) 197 for ( i = 0; i < count;++i )
198 setSelected( list[i], true ); 198 setSelected( list[i], true );
199 199
200} 200}
201void ViewManager::unloadViews() 201void ViewManager::unloadViews()
202{ 202{
203 mViewDict.clear(); 203 mViewDict.clear();
204 mActiveView = 0; 204 mActiveView = 0;
205} 205}
206 206
207void ViewManager::selectView( const QString &name ) 207void ViewManager::selectView( const QString &name )
208{ 208{
209 setActiveView( name ); 209 setActiveView( name );
210 mCore->saveSettings(); 210 mCore->saveSettings();
211} 211}
212void ViewManager::setActiveView( const QString &name ) 212void ViewManager::setActiveView( const QString &name )
213{ 213{
214 KAddressBookView *view = 0; 214 KAddressBookView *view = 0;
215 215
216 // Check that this isn't the same as the current active view 216 // Check that this isn't the same as the current active view
217 if ( mActiveView && ( mActiveView->caption() == name ) ) 217 if ( mActiveView && ( mActiveView->caption() == name ) )
218 return; 218 return;
219 219
220 // At this point we know the view that should be active is not 220 // At this point we know the view that should be active is not
221 // currently active. We will try to find the new on in the list. If 221 // currently active. We will try to find the new on in the list. If
222 // we can't find it, it means it hasn't been instantiated, so we will 222 // we can't find it, it means it hasn't been instantiated, so we will
223 // create it on demand. 223 // create it on demand.
224 224
225 view = mViewDict.find( name ); 225 view = mViewDict.find( name );
226 226
227 // Check if we found the view. If we didn't, then we need to create it 227 // Check if we found the view. If we didn't, then we need to create it
228 if ( view == 0 ) { 228 if ( view == 0 ) {
229 KConfig *config = mCore->config(); 229 KConfig *config = mCore->config();
230 230
231 KConfigGroupSaver saver( config, name ); 231 KConfigGroupSaver saver( config, name );
232 232
233 QString type = config->readEntry( "Type", "Table" ); 233 QString type = config->readEntry( "Type", "Table" );
234 234
235 kdDebug(5720) << "ViewManager::setActiveView: creating view - " << name << endl; 235 kdDebug(5720) << "ViewManager::setActiveView: creating view - " << name << endl;
236 236
237 ViewFactory *factory = mViewFactoryDict.find( type ); 237 ViewFactory *factory = mViewFactoryDict.find( type );
238 if ( factory ) 238 if ( factory )
239 view = factory->view( mCore->addressBook(), mViewWidgetStack ); 239 view = factory->view( mCore->addressBook(), mViewWidgetStack );
240 240
241 if ( view ) { 241 if ( view ) {
242 view->setCaption( name ); 242 view->setCaption( name );
243 mViewDict.insert( name, view ); 243 mViewDict.insert( name, view );
244//US my version needs an int as second parameter to addWidget 244//US my version needs an int as second parameter to addWidget
245 mViewWidgetStack->addWidget( view, -1 ); 245 mViewWidgetStack->addWidget( view, -1 );
246 view->readConfig( config ); 246 view->readConfig( config );
247 247
248 // The manager just relays the signals 248 // The manager just relays the signals
249 connect( view, SIGNAL( selected( const QString& ) ), 249 connect( view, SIGNAL( selected( const QString& ) ),
250 SIGNAL( selected( const QString & ) ) ); 250 SIGNAL( selected( const QString & ) ) );
251 connect( view, SIGNAL( executed( const QString& ) ), 251 connect( view, SIGNAL( executed( const QString& ) ),
252 SIGNAL( executed( const QString& ) ) ); 252 SIGNAL( executed( const QString& ) ) );
253 253
254 connect( view, SIGNAL( deleteRequest( ) ), 254 connect( view, SIGNAL( deleteRequest( ) ),
255 SIGNAL( deleteRequest( ) ) ); 255 SIGNAL( deleteRequest( ) ) );
256 256
257 connect( view, SIGNAL( modified() ), SIGNAL( modified() ) ); 257 connect( view, SIGNAL( modified() ), SIGNAL( modified() ) );
258 connect( view, SIGNAL( dropped( QDropEvent* ) ), 258 connect( view, SIGNAL( dropped( QDropEvent* ) ),
259 SLOT( dropped( QDropEvent* ) ) ); 259 SLOT( dropped( QDropEvent* ) ) );
260 connect( view, SIGNAL( startDrag() ), SLOT( startDrag() ) ); 260 connect( view, SIGNAL( startDrag() ), SLOT( startDrag() ) );
261 } 261 }
262 } 262 }
263 263
264 // If we found or created the view, raise it and refresh it 264 // If we found or created the view, raise it and refresh it
265 if ( view ) { 265 if ( view ) {
266 mActiveView = view; 266 mActiveView = view;
267 mViewWidgetStack->raiseWidget( view ); 267 mViewWidgetStack->raiseWidget( view );
268 // Set the proper filter in the view. By setting the combo 268 // Set the proper filter in the view. By setting the combo
269 // box, the activated slot will be called, which will push 269 // box, the activated slot will be called, which will push
270 // the filter to the view and refresh it. 270 // the filter to the view and refresh it.
271 271
272 if ( view->defaultFilterType() == KAddressBookView::None ) { 272 if ( view->defaultFilterType() == KAddressBookView::None ) {
273 273
274 mActionSelectFilter->setCurrentItem( 0 ); 274 mActionSelectFilter->setCurrentItem( 0 );
275 setActiveFilter( 0 ); 275 setActiveFilter( 0 );
276 } else if ( view->defaultFilterType() == KAddressBookView::Active ) { 276 } else if ( view->defaultFilterType() == KAddressBookView::Active ) {
277 setActiveFilter( mActionSelectFilter->currentItem() ); 277 setActiveFilter( mActionSelectFilter->currentItem() );
278 } else { 278 } else {
279 uint pos = filterPosition( view->defaultFilterName() ); 279 uint pos = filterPosition( view->defaultFilterName() );
280 mActionSelectFilter->setCurrentItem( pos ); 280 mActionSelectFilter->setCurrentItem( pos );
281 setActiveFilter( pos ); 281 setActiveFilter( pos );
282 } 282 }
283//US qDebug("ViewManager::setActiveView 6" ); 283//US qDebug("ViewManager::setActiveView 6" );
284 284
285 // Update the inc search widget to show the fields in the new active 285 // Update the inc search widget to show the fields in the new active
286 // view. 286 // view.
287 mCore->setSearchFields( mActiveView->fields() ); 287 mCore->setSearchFields( mActiveView->fields() );
288 288
289//US performance optimization. setActiveFilter calls also mActiveView->refresh() 289//US performance optimization. setActiveFilter calls also mActiveView->refresh()
290//US mActiveView->refresh(); 290//US mActiveView->refresh();
291 } 291 }
292 else 292 else
293 { 293 {
294 qDebug("ViewManager::setActiveView: unable to find view" ); 294 qDebug("ViewManager::setActiveView: unable to find view" );
295 } 295 }
296} 296}
297 297
298//US added another method with no parameter, since my moc compiler does not support default parameters. 298//US added another method with no parameter, since my moc compiler does not support default parameters.
299void ViewManager::refreshView() 299void ViewManager::refreshView()
300{ 300{
301 refreshView( QString::null ); 301 refreshView( QString::null );
302} 302}
303 303
304void ViewManager::refreshView( const QString &uid ) 304void ViewManager::refreshView( const QString &uid )
305{ 305{
306 if ( mActiveView ) 306 if ( mActiveView )
307 mActiveView->refresh( uid ); 307 mActiveView->refresh( uid );
308} 308}
309 309
310void ViewManager::setFocusAV() 310void ViewManager::setFocusAV()
311{ 311{
312 if ( mActiveView ) 312 if ( mActiveView )
313 mActiveView->setFocusAV(); 313 mActiveView->setFocusAV();
314} 314}
315void ViewManager::editView() 315void ViewManager::editView()
316{ 316{
317 if ( !mActiveView ) 317 if ( !mActiveView )
318 return; 318 return;
319 319
320 ViewFactory *factory = mViewFactoryDict.find( mActiveView->type() ); 320 ViewFactory *factory = mViewFactoryDict.find( mActiveView->type() );
321 ViewConfigureWidget *wdg = 0; 321 ViewConfigureWidget *wdg = 0;
322 ViewConfigureDialog* dlg = 0; 322 ViewConfigureDialog* dlg = 0;
323 if ( factory ) { 323 if ( factory ) {
324 // Save the filters so the dialog has the latest set 324 // Save the filters so the dialog has the latest set
325 Filter::save( mCore->config(), "Filter", mFilterList ); 325 Filter::save( mCore->config(), "Filter", mFilterList );
326 dlg = new ViewConfigureDialog( 0, mActiveView->caption(), this, "conf_dlg" ); 326 dlg = new ViewConfigureDialog( 0, mActiveView->caption(), this, "conf_dlg" );
327 wdg = factory->configureWidget( mCore->addressBook(), dlg,"conf_wid" ); 327 wdg = factory->configureWidget( mCore->addressBook(), dlg,"conf_wid" );
328 } else { 328 } else {
329 qDebug("ViewManager::editView()::cannot find viewfactory "); 329 qDebug("ViewManager::editView()::cannot find viewfactory ");
330 return; 330 return;
331 } 331 }
332 if ( wdg ) { 332 if ( wdg ) {
333 dlg->setWidget( wdg ); 333 dlg->setWidget( wdg );
334 334
335#ifndef DESKTOP_VERSION 335#ifndef DESKTOP_VERSION
336 //dlg.setMaximumSize( 640, 480 ); 336 //dlg.setMaximumSize( 640, 480 );
337 //dlg->setGeometry( 40,40, 400, 300); 337 //dlg->setGeometry( 40,40, 400, 300);
338 dlg->showMaximized(); 338 dlg->showMaximized();
339#endif 339#endif
340 340
341 KConfigGroupSaver saver( mCore->config(), mActiveView->caption() ); 341 KConfigGroupSaver saver( mCore->config(), mActiveView->caption() );
342 342
343 dlg->restoreSettings( mCore->config() ); 343 dlg->restoreSettings( mCore->config() );
344 344
345 if ( dlg->exec() ) { 345 if ( dlg->exec() ) {
346 dlg->saveSettings( mCore->config() ); 346 dlg->saveSettings( mCore->config() );
347 mActiveView->readConfig( mCore->config() ); 347 mActiveView->readConfig( mCore->config() );
348 348
349 // Set the proper filter in the view. By setting the combo 349 // Set the proper filter in the view. By setting the combo
350 // box, the activated slot will be called, which will push 350 // box, the activated slot will be called, which will push
351 // the filter to the view and refresh it. 351 // the filter to the view and refresh it.
352 if ( mActiveView->defaultFilterType() == KAddressBookView::None ) { 352 if ( mActiveView->defaultFilterType() == KAddressBookView::None ) {
353 mActionSelectFilter->setCurrentItem( 0 ); 353 mActionSelectFilter->setCurrentItem( 0 );
354 setActiveFilter( 0 ); 354 setActiveFilter( 0 );
355 } else if ( mActiveView->defaultFilterType() == KAddressBookView::Active ) { 355 } else if ( mActiveView->defaultFilterType() == KAddressBookView::Active ) {
356 setActiveFilter( mActionSelectFilter->currentItem() ); 356 setActiveFilter( mActionSelectFilter->currentItem() );
357 } else { 357 } else {
358 uint pos = filterPosition( mActiveView->defaultFilterName() ); 358 uint pos = filterPosition( mActiveView->defaultFilterName() );
359 mActionSelectFilter->setCurrentItem( pos ); 359 mActionSelectFilter->setCurrentItem( pos );
360 setActiveFilter( pos ); 360 setActiveFilter( pos );
361 } 361 }
362 mCore->setSearchFields( mActiveView->fields() ); 362 mCore->setSearchFields( mActiveView->fields() );
363//US performance optimization. setActiveFilter calls also mActiveView->refresh() 363//US performance optimization. setActiveFilter calls also mActiveView->refresh()
364//US mActiveView->refresh(); 364//US mActiveView->refresh();
365 365
366 366
367 //US this is a bugfix, that we get notified if we change a views configuration 367 //US this is a bugfix, that we get notified if we change a views configuration
368 emit modified(); 368 emit modified();
369 369
370 } 370 }
371 371
372 } 372 }
373 delete dlg; 373 delete dlg;
374} 374}
375 375
376void ViewManager::deleteView() 376void ViewManager::deleteView()
377{ 377{
378 QString text = i18n( "<qt>Are you sure that you want to delete the view <b>%1</b>?</qt>" ) 378 QString text = i18n( "<qt>Are you sure that you want to delete the view <b>%1</b>?</qt>" )
379 .arg( mActiveView->caption() ); 379 .arg( mActiveView->caption() );
380 QString caption = i18n( "Confirm Delete" ); 380 QString caption = i18n( "Confirm Delete" );
381 381
382 382
383 if (QMessageBox::information( this, caption, 383 if (QMessageBox::information( this, caption,
384 text, 384 text,
385 i18n("Yes!"), i18n("No"), 0, 0 ) == 0) 385 i18n("Yes!"), i18n("No"), 0, 0 ) == 0)
386 { 386 {
387 mViewNameList.remove( mActiveView->caption() ); 387 mViewNameList.remove( mActiveView->caption() );
388 388
389 // remove the view from the config file 389 // remove the view from the config file
390 KConfig *config = mCore->config(); 390 KConfig *config = mCore->config();
391 config->deleteGroup( mActiveView->caption() ); 391 config->deleteGroup( mActiveView->caption() );
392 392
393 mViewDict.remove( mActiveView->caption() ); 393 mViewDict.remove( mActiveView->caption() );
394 mActiveView = 0; 394 mActiveView = 0;
395 395
396 // we are in an invalid state now, but that should be fixed after 396 // we are in an invalid state now, but that should be fixed after
397 // we emit the signal 397 // we emit the signal
398 mActionSelectView->setItems( mViewNameList ); 398 mActionSelectView->setItems( mViewNameList );
399 if ( mViewNameList.count() > 0 ) { 399 if ( mViewNameList.count() > 0 ) {
400 mActionSelectView->setCurrentItem( 0 ); 400 mActionSelectView->setCurrentItem( 0 );
401 setActiveView( mViewNameList[ 0 ] ); 401 setActiveView( mViewNameList[ 0 ] );
402 } 402 }
403 mActionDeleteView->setEnabled( mViewNameList.count() > 1 ); 403 mActionDeleteView->setEnabled( mViewNameList.count() > 1 );
404 } 404 }
405} 405}
406 406
407void ViewManager::addView() 407void ViewManager::addView()
408{ 408{
409 AddViewDialog dialog( &mViewFactoryDict, this ); 409 AddViewDialog dialog( &mViewFactoryDict, this );
410 410
411 if ( dialog.exec() ) { 411 if ( dialog.exec() ) {
412 QString newName = dialog.viewName(); 412 QString newName = dialog.viewName();
413 QString type = dialog.viewType(); 413 QString type = dialog.viewType();
414 414
415 // Check for name conflicts 415 // Check for name conflicts
416 bool firstConflict = true; 416 bool firstConflict = true;
417 int numTries = 1; 417 int numTries = 1;
418 while ( mViewNameList.contains( newName ) > 0 ) { 418 while ( mViewNameList.contains( newName ) > 0 ) {
419 if ( !firstConflict ) { 419 if ( !firstConflict ) {
420 newName = newName.left( newName.length() - 4 ); 420 newName = newName.left( newName.length() - 4 );
421 firstConflict = false; 421 firstConflict = false;
422 } 422 }
423 423
424 newName = QString( "%1 <%2>" ).arg( newName ).arg( numTries ); 424 newName = QString( "%1 <%2>" ).arg( newName ).arg( numTries );
425 numTries++; 425 numTries++;
426 } 426 }
427 427
428 // Add the new one to the list 428 // Add the new one to the list
429 mViewNameList.append( newName ); 429 mViewNameList.append( newName );
430 430
431 // write the view to the config file, 431 // write the view to the config file,
432 KConfig *config = mCore->config(); 432 KConfig *config = mCore->config();
433 433
434 config->deleteGroup( newName ); 434 config->deleteGroup( newName );
435 435
436 KConfigGroupSaver saver( config, newName ); 436 KConfigGroupSaver saver( config, newName );
437 437
438 config->writeEntry( "Type", type ); 438 config->writeEntry( "Type", type );
439 439
440 // try to set the active view 440 // try to set the active view
441 mActionSelectView->setItems( mViewNameList ); 441 mActionSelectView->setItems( mViewNameList );
442 mActionSelectView->setCurrentItem( mViewNameList.findIndex( newName ) ); 442 mActionSelectView->setCurrentItem( mViewNameList.findIndex( newName ) );
443 setActiveView( newName ); 443 setActiveView( newName );
444 444
445 editView(); 445 editView();
446 446
447 mActionDeleteView->setEnabled( mViewNameList.count() > 1 ); 447 mActionDeleteView->setEnabled( mViewNameList.count() > 1 );
448 } 448 }
449} 449}
450 450
451void ViewManager::createViewFactories() 451void ViewManager::createViewFactories()
452{ 452{
453#ifndef KAB_EMBEDDED 453#ifndef KAB_EMBEDDED
454 KTrader::OfferList plugins = KTrader::self()->query( "KAddressBook/View" ); 454 KTrader::OfferList plugins = KTrader::self()->query( "KAddressBook/View" );
455 KTrader::OfferList::ConstIterator it; 455 KTrader::OfferList::ConstIterator it;
456 for ( it = plugins.begin(); it != plugins.end(); ++it ) { 456 for ( it = plugins.begin(); it != plugins.end(); ++it ) {
457 if ( !(*it)->hasServiceType( "KAddressBook/View" ) ) 457 if ( !(*it)->hasServiceType( "KAddressBook/View" ) )
458 continue; 458 continue;
459 459
460 KLibFactory *factory = KLibLoader::self()->factory( (*it)->library().latin1() ); 460 KLibFactory *factory = KLibLoader::self()->factory( (*it)->library().latin1() );
461 461
462 if ( !factory ) { 462 if ( !factory ) {
463 kdDebug(5720) << "ViewManager::createViewFactories(): Factory creation failed" << endl; 463 kdDebug(5720) << "ViewManager::createViewFactories(): Factory creation failed" << endl;
464 continue; 464 continue;
465 } 465 }
466 466
467 ViewFactory *viewFactory = static_cast<ViewFactory*>( factory ); 467 ViewFactory *viewFactory = static_cast<ViewFactory*>( factory );
468 468
469 if ( !viewFactory ) { 469 if ( !viewFactory ) {
470 kdDebug(5720) << "ViewManager::createViewFactories(): Cast failed" << endl; 470 kdDebug(5720) << "ViewManager::createViewFactories(): Cast failed" << endl;
471 continue; 471 continue;
472 } 472 }
473 473
474 mViewFactoryDict.insert( viewFactory->type(), viewFactory ); 474 mViewFactoryDict.insert( viewFactory->type(), viewFactory );
475 } 475 }
476 476
477#else //KAB_EMBEDDED 477#else //KAB_EMBEDDED
478 ViewFactory* viewFactory = new IconViewFactory(); 478 ViewFactory* viewFactory = new IconViewFactory();
479 mViewFactoryDict.insert( viewFactory->type(), viewFactory ); 479 mViewFactoryDict.insert( viewFactory->type(), viewFactory );
480// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1()); 480// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1());
481 481
482 viewFactory = new TableViewFactory(); 482 viewFactory = new TableViewFactory();
483 mViewFactoryDict.insert( viewFactory->type(), viewFactory ); 483 mViewFactoryDict.insert( viewFactory->type(), viewFactory );
484// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1()); 484// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1());
485 485
486 viewFactory = new CardViewFactory(); 486 viewFactory = new CardViewFactory();
487 mViewFactoryDict.insert( viewFactory->type(), viewFactory ); 487 mViewFactoryDict.insert( viewFactory->type(), viewFactory );
488// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1()); 488// qDebug("ViewManager::createViewFactories() Loading factory: %s", viewFactory->type().latin1());
489 489
490#endif //KAB_EMBEDDED 490#endif //KAB_EMBEDDED
491 491
492} 492}
493 493
494void ViewManager::dropped( QDropEvent *e ) 494void ViewManager::dropped( QDropEvent *e )
495{ 495{
496 496
497#ifndef KAB_EMBEDDED 497#ifndef KAB_EMBEDDED
498 498
499 QString clipText, vcards; 499 QString clipText, vcards;
500 KURL::List urls; 500 KURL::List urls;
501 501
502 if ( KURLDrag::decode( e, urls) ) { 502 if ( KURLDrag::decode( e, urls) ) {
503 KURL::List::Iterator it = urls.begin(); 503 KURL::List::Iterator it = urls.begin();
504 int c = urls.count(); 504 int c = urls.count();
505 if ( c > 1 ) { 505 if ( c > 1 ) {
506 QString questionString = i18n( "Import one contact into your addressbook?", "Import %n contacts into your addressbook?", c ); 506 QString questionString = i18n( "Import one contact into your addressbook?", "Import %n contacts into your addressbook?", c );
507 if ( KMessageBox::questionYesNo( this, questionString, i18n( "Import Contacts?" ) ) == KMessageBox::Yes ) { 507 if ( KMessageBox::questionYesNo( this, questionString, i18n( "Import Contacts?" ) ) == KMessageBox::Yes ) {
508 for ( ; it != urls.end(); ++it ) 508 for ( ; it != urls.end(); ++it )
509 emit urlDropped( *it ); 509 emit urlDropped( *it );
510 } 510 }
511 } else if ( c == 1 ) 511 } else if ( c == 1 )
512 emit urlDropped( *it ); 512 emit urlDropped( *it );
513 } else if ( KVCardDrag::decode( e, vcards ) ) { 513 } else if ( KVCardDrag::decode( e, vcards ) ) {
514 KABC::Addressee addr; 514 KABC::Addressee addr;
515 KABC::VCardConverter converter; 515 KABC::VCardConverter converter;
516 QStringList list = QStringList::split( "\r\n\r\n", vcards ); 516 QStringList list = QStringList::split( "\r\n\r\n", vcards );
517 QStringList::Iterator it; 517 QStringList::Iterator it;
518 for ( it = list.begin(); it != list.end(); ++it ) { 518 for ( it = list.begin(); it != list.end(); ++it ) {
519 if ( converter.vCardToAddressee( (*it).stripWhiteSpace(), addr ) ) { 519 if ( converter.vCardToAddressee( (*it).stripWhiteSpace(), addr ) ) {
520 KABC::Addressee a = mCore->addressBook()->findByUid( addr.uid() ); 520 KABC::Addressee a = mCore->addressBook()->findByUid( addr.uid() );
521 if ( a.isEmpty() ) { 521 if ( a.isEmpty() ) {
522 mCore->addressBook()->insertAddressee( addr ); 522 mCore->addressBook()->insertAddressee( addr );
523 emit modified(); 523 emit modified();
524 } 524 }
525 } 525 }
526 } 526 }
527 527
528 mActiveView->refresh(); 528 mActiveView->refresh();
529 } 529 }
530#else //KAB_EMBEDDED 530#else //KAB_EMBEDDED
531qDebug("ViewManager::dropped() has to be changed!!" ); 531qDebug("ViewManager::dropped() has to be changed!!" );
532#endif //KAB_EMBEDDED 532#endif //KAB_EMBEDDED
533 533
534} 534}
535 535
536void ViewManager::startDrag() 536void ViewManager::startDrag()
537{ 537{
538 kdDebug(5720) << "ViewManager::startDrag: starting to drag" << endl; 538 kdDebug(5720) << "ViewManager::startDrag: starting to drag" << endl;
539 539
540#ifndef KAB_EMBEDDED 540#ifndef KAB_EMBEDDED
541 541
542 // Get the list of all the selected addressees 542 // Get the list of all the selected addressees
543 KABC::Addressee::List addrList; 543 KABC::Addressee::List addrList;
544 QStringList uidList = selectedUids(); 544 QStringList uidList = selectedUids();
545 QStringList::Iterator iter; 545 QStringList::Iterator iter;
546 for ( iter = uidList.begin(); iter != uidList.end(); ++iter ) 546 for ( iter = uidList.begin(); iter != uidList.end(); ++iter )
547 addrList.append( mCore->addressBook()->findByUid( *iter ) ); 547 addrList.append( mCore->addressBook()->findByUid( *iter ) );
548 548
549 KMultipleDrag *drag = new KMultipleDrag( this ); 549 KMultipleDrag *drag = new KMultipleDrag( this );
550 drag->addDragObject( new QTextDrag( AddresseeUtil::addresseesToClipboard(addrList), this ) ); 550 drag->addDragObject( new QTextDrag( AddresseeUtil::addresseesToClipboard(addrList), this ) );
551 KABC::Addressee::List::Iterator it; 551 KABC::Addressee::List::Iterator it;
552 QStringList vcards; 552 QStringList vcards;
553 for ( it = addrList.begin(); it != addrList.end(); ++it ) { 553 for ( it = addrList.begin(); it != addrList.end(); ++it ) {
554 QString vcard = QString::null; 554 QString vcard = QString::null;
555 KABC::VCardConverter converter; 555 KABC::VCardConverter converter;
556 if ( converter.addresseeToVCard( *it, vcard ) ) 556 if ( converter.addresseeToVCard( *it, vcard ) )
557 vcards.append( vcard ); 557 vcards.append( vcard );
558 } 558 }
559 drag->addDragObject( new KVCardDrag( vcards.join( "\r\n" ), this ) ); 559 drag->addDragObject( new KVCardDrag( vcards.join( "\r\n" ), this ) );
560 560
561 drag->setPixmap( KGlobal::iconLoader()->loadIcon( "vcard", KIcon::Desktop ) ); 561 drag->setPixmap( KGlobal::iconLoader()->loadIcon( "vcard", KIcon::Desktop ) );
562 drag->dragCopy(); 562 drag->dragCopy();
563 563
564#else //KAB_EMBEDDED 564#else //KAB_EMBEDDED
565qDebug("ViewManager::startDrag() has to be changed!!" ); 565qDebug("ViewManager::startDrag() has to be changed!!" );
566#endif //KAB_EMBEDDED 566#endif //KAB_EMBEDDED
567 567
568} 568}
569void ViewManager::doSearch( const QString& s,KABC::Field *field ) 569void ViewManager::doSearch( const QString& s,KABC::Field *field )
570{ 570{
571 if ( mActiveView ) 571 if ( mActiveView )
572 mActiveView->doSearch( s, field ); 572 mActiveView->doSearch( s, field );
573 573
574} 574}
575void ViewManager::setActiveFilter( int index ) 575void ViewManager::setActiveFilter( int index )
576{ 576{
577 Filter currentFilter; 577 Filter currentFilter;
578 578
579 if ( ( index - 1 ) < 0 ) 579 if ( ( index - 1 ) < 0 )
580 currentFilter = Filter(); 580 currentFilter = Filter();
581 else 581 else
582 currentFilter = mFilterList[ index - 1 ]; 582 currentFilter = mFilterList[ index - 1 ];
583 583
584 // Check if we have a view. Since the filter combo is created before 584 // Check if we have a view. Since the filter combo is created before
585 // the view, this slot could be called before there is a valid view. 585 // the view, this slot could be called before there is a valid view.
586 if ( mActiveView ) { 586 if ( mActiveView ) {
587 mActiveView->setFilter( currentFilter ); 587 mActiveView->setFilter( currentFilter );
588 mActiveView->refresh(); 588 mActiveView->refresh();
589 emit selected( QString::null ); 589 emit selected( QString::null );
590 } 590 }
591} 591}
592 592
593void ViewManager::configureFilters() 593void ViewManager::configureFilters()
594{ 594{
595 FilterDialog dlg( this ); 595 FilterDialog dlg( this );
596 596
597 dlg.setFilters( mFilterList ); 597 dlg.setFilters( mFilterList );
598 598
599 if ( dlg.exec() ) 599 if ( dlg.exec() )
600 mFilterList = dlg.filters(); 600 mFilterList = dlg.filters();
601 601
602 uint pos = mActionSelectFilter->currentItem(); 602 uint pos = mActionSelectFilter->currentItem();
603 mActionSelectFilter->setItems( filterNames() ); 603 mActionSelectFilter->setItems( filterNames() );
604 mActionSelectFilter->setCurrentItem( pos ); 604 mActionSelectFilter->setCurrentItem( pos );
605 setActiveFilter( pos ); 605 setActiveFilter( pos );
606 int cw = 150; 606 int cw = 150;
607 if (QApplication::desktop()->width() == 480 && !KABPrefs::instance()->mHideSearchOnSwitch) 607 if (QApplication::desktop()->width() == 480 && !KABPrefs::instance()->mHideSearchOnSwitch)
608 cw = 0; 608 cw = 0;
609 mActionSelectFilter->setComboWidth( cw ); 609 mActionSelectFilter->setComboWidth( cw );
610 saveSettings(); 610 saveSettings();
611} 611}
612 612
613QStringList ViewManager::filterNames() const 613QStringList ViewManager::filterNames() const
614{ 614{
615 QStringList names( i18n( "No Filter" ) ); 615 QStringList names( i18n( "No Filter" ) );
616 616
617 Filter::List::ConstIterator it; 617 Filter::List::ConstIterator it;
618 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it ) 618 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it )
619 names.append( (*it).name() ); 619 names.append( (*it).name() );
620 620
621 return names; 621 return names;
622} 622}
623Filter ViewManager::getFilterByName( const QString &name ) const 623Filter ViewManager::getFilterByName( const QString &name ) const
624{ 624{
625 Filter::List::ConstIterator it; 625 Filter::List::ConstIterator it;
626 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it ) 626 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it )
627 if ( name == (*it).name() ) 627 if ( name == (*it).name() )
628 return (*it); 628 return (*it);
629 629
630 return Filter(); 630 return Filter();
631} 631}
632 632
633int ViewManager::filterPosition( const QString &name ) const 633int ViewManager::filterPosition( const QString &name ) const
634{ 634{
635 int pos = 0; 635 int pos = 0;
636 636
637 Filter::List::ConstIterator it; 637 Filter::List::ConstIterator it;
638 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it, ++pos ) 638 for ( it = mFilterList.begin(); it != mFilterList.end(); ++it, ++pos )
639 if ( name == (*it).name() ) 639 if ( name == (*it).name() )
640 return pos + 1; 640 return pos + 1;
641 641
642 return 0; 642 return 0;
643} 643}
644 644
645void ViewManager::initActions() 645void ViewManager::initActions()
646{ 646{
647//US <ActionList name="view_loadedviews"/> 647//US <ActionList name="view_loadedviews"/>
648//US <Separator/> 648//US <Separator/>
649 649
650#ifdef KAB_EMBEDDED 650#ifdef KAB_EMBEDDED
651 QPopupMenu *viewmenu = (QPopupMenu*)mCore->getViewMenu(); 651 QPopupMenu *viewmenu = (QPopupMenu*)mCore->getViewMenu();
652 QPopupMenu *settingsmenu = (QPopupMenu*)mCore->getSettingsMenu(); 652 QPopupMenu *settingsmenu = (QPopupMenu*)mCore->getSettingsMenu();
653 QPopupMenu *filtermenu = (QPopupMenu*)mCore->getFilterMenu(); 653 QPopupMenu *filtermenu = (QPopupMenu*)mCore->getFilterMenu();
654#endif //KAB_EMBEDDED 654#endif //KAB_EMBEDDED
655 655
656 mActionSelectView = new KSelectAction( i18n( "Select View" ), 0, mCore->actionCollection(), "select_view" ); 656 mActionSelectView = new KSelectAction( i18n( "Select View" ), 0, mCore->actionCollection(), "select_view" );
657#if KDE_VERSION >= 309 657#if KDE_VERSION >= 309
658 mActionSelectView->setMenuAccelsEnabled( false ); 658 mActionSelectView->setMenuAccelsEnabled( false );
659#endif 659#endif
660 connect( mActionSelectView, SIGNAL( activated( const QString& ) ), 660 connect( mActionSelectView, SIGNAL( activated( const QString& ) ),
661 SLOT( selectView( const QString& ) ) ); 661 SLOT( selectView( const QString& ) ) );
662 662
663 663
664#ifdef KAB_EMBEDDED 664#ifdef KAB_EMBEDDED
665 mActionSelectView->plug(viewmenu); 665 mActionSelectView->plug(viewmenu);
666 viewmenu->insertSeparator(); 666 viewmenu->insertSeparator();
667#endif //KAB_EMBEDDED 667#endif //KAB_EMBEDDED
668 668
669 KAction *action; 669 KAction *action;
670 670
671 action = new KAction( i18n( "Modify View..." ), "configure", 0, this, 671 action = new KAction( i18n( "Modify View..." ), "configure", 0, this,
672 SLOT( editView() ), mCore->actionCollection(), "view_modify" ); 672 SLOT( editView() ), mCore->actionCollection(), "view_modify" );
673#ifndef KAB_EMBEDDED 673#ifndef KAB_EMBEDDED
674 action->setWhatsThis( i18n( "By pressing this button a dialog opens that allows you to modify the view of the addressbook. There you can add or remove fields that you want to be shown or hidden in the addressbook like the name for example." ) ); 674 action->setWhatsThis( i18n( "By pressing this button a dialog opens that allows you to modify the view of the addressbook. There you can add or remove fields that you want to be shown or hidden in the addressbook like the name for example." ) );
675#else //KAB_EMBEDDED 675#else //KAB_EMBEDDED
676 action->plug(viewmenu); 676 action->plug(viewmenu);
677#endif //KAB_EMBEDDED 677#endif //KAB_EMBEDDED
678 678
679 action = new KAction( i18n( "Add View..." ), "window_new", 0, this, 679 action = new KAction( i18n( "Add View..." ), "window_new", 0, this,
680 SLOT( addView() ), mCore->actionCollection(), "view_add" ); 680 SLOT( addView() ), mCore->actionCollection(), "view_add" );
681#ifndef KAB_EMBEDDED 681#ifndef KAB_EMBEDDED
682 action->setWhatsThis( i18n( "You can add a new view by choosing one of the dialog that appears after pressing the button. You have to give the view a name, so that you can distinguish between the different views." ) ); 682 action->setWhatsThis( i18n( "You can add a new view by choosing one of the dialog that appears after pressing the button. You have to give the view a name, so that you can distinguish between the different views." ) );
683#else //KAB_EMBEDDED 683#else //KAB_EMBEDDED
684 action->plug(viewmenu); 684 action->plug(viewmenu);
685#endif //KAB_EMBEDDED 685#endif //KAB_EMBEDDED
686 686
687 mActionDeleteView = new KAction( i18n( "Delete View" ), "view_remove", 0, 687 mActionDeleteView = new KAction( i18n( "Delete View" ), "view_remove", 0,
688 this, SLOT( deleteView() ), 688 this, SLOT( deleteView() ),
689 mCore->actionCollection(), "view_delete" ); 689 mCore->actionCollection(), "view_delete" );
690#ifndef KAB_EMBEDDED 690#ifndef KAB_EMBEDDED
691 mActionDeleteView->setWhatsThis( i18n( "By pressing this button you can delete the actual view, which you have added before." ) ); 691 mActionDeleteView->setWhatsThis( i18n( "By pressing this button you can delete the actual view, which you have added before." ) );
692#else //KAB_EMBEDDED 692#else //KAB_EMBEDDED
693 mActionDeleteView->plug(viewmenu); 693 mActionDeleteView->plug(viewmenu);
694 viewmenu->insertSeparator(); 694 viewmenu->insertSeparator();
695#endif //KAB_EMBEDDED 695#endif //KAB_EMBEDDED
696 696
697#ifndef KAB_EMBEDDED 697#ifndef KAB_EMBEDDED
698 action = new KAction( i18n( "Refresh View" ), "reload", 0, this, 698 action = new KAction( i18n( "Refresh View" ), "reload", 0, this,
699 SLOT( refreshView(const QString &) ), mCore->actionCollection(), 699 SLOT( refreshView(const QString &) ), mCore->actionCollection(),
700 "view_refresh" ); 700 "view_refresh" );
701 action->setWhatsThis( i18n( "The view will be refreshed by pressing this button." ) ); 701 action->setWhatsThis( i18n( "The view will be refreshed by pressing this button." ) );
702#else //KAB_EMBEDDED 702#else //KAB_EMBEDDED
703 action = new KAction( i18n( "Refresh View" ), "reload", 0, this, 703 action = new KAction( i18n( "Refresh View" ), "reload", 0, this,
704 SLOT( refreshView()), mCore->actionCollection(), 704 SLOT( refreshView()), mCore->actionCollection(),
705 "view_refresh" ); 705 "view_refresh" );
706 action->plug(viewmenu); 706 action->plug(viewmenu);
707 viewmenu->insertSeparator(); 707 //viewmenu->insertSeparator();
708#endif //KAB_EMBEDDED 708#endif //KAB_EMBEDDED
709 709
710 action = new KAction( i18n( "Edit &Filters..." ), "filter", 0, this, 710 action = new KAction( i18n( "Edit &Filters..." ), "filter", 0, this,
711 SLOT( configureFilters() ), mCore->actionCollection(), 711 SLOT( configureFilters() ), mCore->actionCollection(),
712 "options_edit_filters" ); 712 "options_edit_filters" );
713 713
714 mActionSelectFilter = new KSelectAction( i18n( "Select Filter" ), "filter", mCore->actionCollection(), "select_filter" ); 714 mActionSelectFilter = new KSelectAction( i18n( "Select Filter" ), "filter", mCore->actionCollection(), "select_filter" );
715#if KDE_VERSION >= 309 715#if KDE_VERSION >= 309
716 mActionSelectFilter->setMenuAccelsEnabled( false ); 716 mActionSelectFilter->setMenuAccelsEnabled( false );
717#endif 717#endif
718 connect( mActionSelectFilter, SIGNAL( activated( int ) ), 718 connect( mActionSelectFilter, SIGNAL( activated( int ) ),
719 SLOT( setActiveFilter( int ) ) ); 719 SLOT( setActiveFilter( int ) ) );
720 720
721#ifdef KAB_EMBEDDED 721#ifdef KAB_EMBEDDED
722 action->plug(settingsmenu); 722 action->plug(settingsmenu);
723 mActionSelectFilter->plug(viewmenu,0); 723 mActionSelectFilter->plug(viewmenu,0);
724#endif //KAB_EMBEDDED 724#endif //KAB_EMBEDDED
725 725
726} 726}
727 727
728void ViewManager::initGUI() 728void ViewManager::initGUI()
729{ 729{
730 QHBoxLayout *layout = new QHBoxLayout( this, 0, 0 ); 730 QHBoxLayout *layout = new QHBoxLayout( this, 0, 0 );
731 mViewWidgetStack = new QWidgetStack( this ); 731 mViewWidgetStack = new QWidgetStack( this );
732 layout->addWidget( mViewWidgetStack ); 732 layout->addWidget( mViewWidgetStack );
733} 733}
734 734
735#ifndef KAB_EMBEDDED 735#ifndef KAB_EMBEDDED
736#include "viewmanager.moc" 736#include "viewmanager.moc"
737#endif //KAB_EMBEDDED 737#endif //KAB_EMBEDDED
diff --git a/kaddressbook/views/colorlistbox.cpp b/kaddressbook/views/colorlistbox.cpp
index c243fa0..7386207 100644
--- a/kaddressbook/views/colorlistbox.cpp
+++ b/kaddressbook/views/colorlistbox.cpp
@@ -1,230 +1,235 @@
1/* 1/*
2 * kmail: KDE mail client 2 * kmail: KDE mail client
3 * This file: Copyright (C) 2000 Espen Sand, espen@kde.org 3 * This file: Copyright (C) 2000 Espen Sand, espen@kde.org
4 * 4 *
5 * This program is free software; you can redistribute it and/or modify 5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by 6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or 7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version. 8 * (at your option) any later version.
9 * 9 *
10 * This program is distributed in the hope that it will be useful, 10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details. 13 * GNU General Public License for more details.
14 * 14 *
15 * You should have received a copy of the GNU General Public License 15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software 16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 * 18 *
19 */ 19 */
20 20
21#include <qpainter.h> 21#include <qpainter.h>
22 22
23#include <kcolordialog.h> 23#include <kcolordialog.h>
24 24
25#ifndef KAB_EMBEDDED 25#ifndef KAB_EMBEDDED
26#include <kcolordrag.h> 26#include <kcolordrag.h>
27#endif //KAB_EMBEDDED 27#endif //KAB_EMBEDDED
28 28
29#include "colorlistbox.h" 29#include "colorlistbox.h"
30 30
31ColorListBox::ColorListBox( QWidget *parent, const char *name, WFlags f ) 31ColorListBox::ColorListBox( QWidget *parent, const char *name, WFlags f )
32 :KListBox( parent, name, f ), mCurrentOnDragEnter(-1) 32 :KListBox( parent, name, f ), mCurrentOnDragEnter(-1)
33{ 33{
34 connect( this, SIGNAL(selected(int)), this, SLOT(newColor(int)) ); 34 connect( this, SIGNAL(selected(int)), this, SLOT(newColor(int)) );
35 connect( this, SIGNAL(clicked(QListBoxItem *)), this, SLOT(slotNewColor(QListBoxItem *)) );
35 setAcceptDrops( true); 36 setAcceptDrops( true);
36} 37}
37 38
38 39
39void ColorListBox::setEnabled( bool state ) 40void ColorListBox::setEnabled( bool state )
40{ 41{
41 if( state == isEnabled() ) 42 if( state == isEnabled() )
42 { 43 {
43 return; 44 return;
44 } 45 }
45 46
46 QListBox::setEnabled( state ); 47 QListBox::setEnabled( state );
47 for( uint i=0; i<count(); i++ ) 48 for( uint i=0; i<count(); i++ )
48 { 49 {
49 updateItem( i ); 50 updateItem( i );
50 } 51 }
51} 52}
52 53
53 54
54void ColorListBox::setColor( uint index, const QColor &color ) 55void ColorListBox::setColor( uint index, const QColor &color )
55{ 56{
56 if( index < count() ) 57 if( index < count() )
57 { 58 {
58 ColorListItem *colorItem = (ColorListItem*)item(index); 59 ColorListItem *colorItem = (ColorListItem*)item(index);
59 colorItem->setColor(color); 60 colorItem->setColor(color);
60 updateItem( colorItem ); 61 updateItem( colorItem );
61 } 62 }
62} 63}
63 64
64 65
65QColor ColorListBox::color( uint index ) const 66QColor ColorListBox::color( uint index ) const
66{ 67{
67 if( index < count() ) 68 if( index < count() )
68 { 69 {
69 ColorListItem *colorItem = (ColorListItem*)item(index); 70 ColorListItem *colorItem = (ColorListItem*)item(index);
70 return( colorItem->color() ); 71 return( colorItem->color() );
71 } 72 }
72 else 73 else
73 { 74 {
74 return( black ); 75 return( black );
75 } 76 }
76} 77}
77 78void ColorListBox::slotNewColor(QListBoxItem * i)
79{
80 if ( i )
81 newColor( index( i ) );
82}
78 83
79void ColorListBox::newColor( int index ) 84void ColorListBox::newColor( int index )
80{ 85{
81 if( isEnabled() == false ) 86 if( isEnabled() == false )
82 { 87 {
83 return; 88 return;
84 } 89 }
85 90
86 if( (uint)index < count() ) 91 if( (uint)index < count() )
87 { 92 {
88 QColor c = color( index ); 93 QColor c = color( index );
89#ifndef KAB_EMBEDDED 94#ifndef KAB_EMBEDDED
90 if( KColorDialog::getColor( c, this ) != QDialog::Rejected ) 95 if( KColorDialog::getColor( c, this ) != QDialog::Rejected )
91 { 96 {
92 setColor( index, c ); 97 setColor( index, c );
93 } 98 }
94#else //KAB_EMBEDDED 99#else //KAB_EMBEDDED
95 KColorDialog* k = new KColorDialog( this ); 100 KColorDialog* k = new KColorDialog( this );
96 k->setColor( c ); 101 k->setColor( c );
97 int res = k->exec(); 102 int res = k->exec();
98 if ( res ) { 103 if ( res ) {
99 setColor( index, k->getColor() ); 104 setColor( index, k->getColor() );
100 } 105 }
101 delete k; 106 delete k;
102#endif //KAB_EMBEDDED 107#endif //KAB_EMBEDDED
103 108
104 } 109 }
105} 110}
106 111
107 112
108void ColorListBox::dragEnterEvent( QDragEnterEvent *e ) 113void ColorListBox::dragEnterEvent( QDragEnterEvent *e )
109{ 114{
110#ifndef KAB_EMBEDDED 115#ifndef KAB_EMBEDDED
111 if( KColorDrag::canDecode(e) && isEnabled() ) 116 if( KColorDrag::canDecode(e) && isEnabled() )
112 { 117 {
113 mCurrentOnDragEnter = currentItem(); 118 mCurrentOnDragEnter = currentItem();
114 e->accept( true ); 119 e->accept( true );
115 } 120 }
116 else 121 else
117 { 122 {
118 mCurrentOnDragEnter = -1; 123 mCurrentOnDragEnter = -1;
119 e->accept( false ); 124 e->accept( false );
120 } 125 }
121#else //KAB_EMBEDDED 126#else //KAB_EMBEDDED
122qDebug("ColorListBox::dragEnterEvent drag&drop currently not supported"); 127qDebug("ColorListBox::dragEnterEvent drag&drop currently not supported");
123#endif //KAB_EMBEDDED 128#endif //KAB_EMBEDDED
124 129
125} 130}
126 131
127 132
128void ColorListBox::dragLeaveEvent( QDragLeaveEvent * ) 133void ColorListBox::dragLeaveEvent( QDragLeaveEvent * )
129{ 134{
130#ifndef KAB_EMBEDDED 135#ifndef KAB_EMBEDDED
131 136
132 if( mCurrentOnDragEnter != -1 ) 137 if( mCurrentOnDragEnter != -1 )
133 { 138 {
134 setCurrentItem( mCurrentOnDragEnter ); 139 setCurrentItem( mCurrentOnDragEnter );
135 mCurrentOnDragEnter = -1; 140 mCurrentOnDragEnter = -1;
136 } 141 }
137#else //KAB_EMBEDDED 142#else //KAB_EMBEDDED
138qDebug("ColorListBox::dragLeaveEvent drag&drop currently not supported"); 143qDebug("ColorListBox::dragLeaveEvent drag&drop currently not supported");
139#endif //KAB_EMBEDDED 144#endif //KAB_EMBEDDED
140} 145}
141 146
142 147
143void ColorListBox::dragMoveEvent( QDragMoveEvent *e ) 148void ColorListBox::dragMoveEvent( QDragMoveEvent *e )
144{ 149{
145#ifndef KAB_EMBEDDED 150#ifndef KAB_EMBEDDED
146 if( KColorDrag::canDecode(e) && isEnabled() ) 151 if( KColorDrag::canDecode(e) && isEnabled() )
147 { 152 {
148 ColorListItem *item = (ColorListItem*)itemAt( e->pos() ); 153 ColorListItem *item = (ColorListItem*)itemAt( e->pos() );
149 if( item != 0 ) 154 if( item != 0 )
150 { 155 {
151 setCurrentItem ( item ); 156 setCurrentItem ( item );
152 } 157 }
153 } 158 }
154#else //KAB_EMBEDDED 159#else //KAB_EMBEDDED
155qDebug("ColorListBox::dragMoveEvent drag&drop currently not supported"); 160qDebug("ColorListBox::dragMoveEvent drag&drop currently not supported");
156#endif //KAB_EMBEDDED 161#endif //KAB_EMBEDDED
157 162
158} 163}
159 164
160 165
161void ColorListBox::dropEvent( QDropEvent *e ) 166void ColorListBox::dropEvent( QDropEvent *e )
162{ 167{
163#ifndef KAB_EMBEDDED 168#ifndef KAB_EMBEDDED
164 QColor color; 169 QColor color;
165 if( KColorDrag::decode( e, color ) ) 170 if( KColorDrag::decode( e, color ) )
166 { 171 {
167 int index = currentItem(); 172 int index = currentItem();
168 if( index != -1 ) 173 if( index != -1 )
169 { 174 {
170 ColorListItem *colorItem = (ColorListItem*)item(index); 175 ColorListItem *colorItem = (ColorListItem*)item(index);
171 colorItem->setColor(color); 176 colorItem->setColor(color);
172 triggerUpdate( false ); // Redraw item 177 triggerUpdate( false ); // Redraw item
173 } 178 }
174 mCurrentOnDragEnter = -1; 179 mCurrentOnDragEnter = -1;
175 } 180 }
176 181
177#else //KAB_EMBEDDED 182#else //KAB_EMBEDDED
178qDebug("ColorListBox::dropEvent drag&drop currently not supported"); 183qDebug("ColorListBox::dropEvent drag&drop currently not supported");
179#endif //KAB_EMBEDDED 184#endif //KAB_EMBEDDED
180 185
181} 186}
182 187
183 188
184 189
185ColorListItem::ColorListItem( const QString &text, const QColor &color ) 190ColorListItem::ColorListItem( const QString &text, const QColor &color )
186 : QListBoxItem(), mColor( color ), mBoxWidth( 30 ) 191 : QListBoxItem(), mColor( color ), mBoxWidth( 30 )
187{ 192{
188 setText( text ); 193 setText( text );
189} 194}
190 195
191 196
192const QColor &ColorListItem::color( void ) 197const QColor &ColorListItem::color( void )
193{ 198{
194 return( mColor ); 199 return( mColor );
195} 200}
196 201
197 202
198void ColorListItem::setColor( const QColor &color ) 203void ColorListItem::setColor( const QColor &color )
199{ 204{
200 mColor = color; 205 mColor = color;
201} 206}
202 207
203 208
204void ColorListItem::paint( QPainter *p ) 209void ColorListItem::paint( QPainter *p )
205{ 210{
206 QFontMetrics fm = p->fontMetrics(); 211 QFontMetrics fm = p->fontMetrics();
207 int h = fm.height(); 212 int h = fm.height();
208 213
209 p->drawText( mBoxWidth+3*2, fm.ascent() + fm.leading()/2, text() ); 214 p->drawText( mBoxWidth+3*2, fm.ascent() + fm.leading()/2, text() );
210 215
211 p->setPen( Qt::black ); 216 p->setPen( Qt::black );
212 p->drawRect( 3, 1, mBoxWidth, h-1 ); 217 p->drawRect( 3, 1, mBoxWidth, h-1 );
213 p->fillRect( 4, 2, mBoxWidth-2, h-3, mColor ); 218 p->fillRect( 4, 2, mBoxWidth-2, h-3, mColor );
214} 219}
215 220
216 221
217int ColorListItem::height(const QListBox *lb ) const 222int ColorListItem::height(const QListBox *lb ) const
218{ 223{
219 return( lb->fontMetrics().lineSpacing()+1 ); 224 return( lb->fontMetrics().lineSpacing()+1 );
220} 225}
221 226
222 227
223int ColorListItem::width(const QListBox *lb ) const 228int ColorListItem::width(const QListBox *lb ) const
224{ 229{
225 return( mBoxWidth + lb->fontMetrics().width( text() ) + 6 ); 230 return( mBoxWidth + lb->fontMetrics().width( text() ) + 6 );
226} 231}
227 232
228#ifndef KAB_EMBEDDED 233#ifndef KAB_EMBEDDED
229#include "colorlistbox.moc" 234#include "colorlistbox.moc"
230#endif //KAB_EMBEDDED 235#endif //KAB_EMBEDDED
diff --git a/kaddressbook/views/colorlistbox.h b/kaddressbook/views/colorlistbox.h
index 4a0e705..bb91484 100644
--- a/kaddressbook/views/colorlistbox.h
+++ b/kaddressbook/views/colorlistbox.h
@@ -1,76 +1,77 @@
1/* 1/*
2 * kmail: KDE mail client 2 * kmail: KDE mail client
3 * This file: Copyright (C) 2000 Espen Sand, espen@kde.org 3 * This file: Copyright (C) 2000 Espen Sand, espen@kde.org
4 * 4 *
5 * This program is free software; you can redistribute it and/or modify 5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by 6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or 7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version. 8 * (at your option) any later version.
9 * 9 *
10 * This program is distributed in the hope that it will be useful, 10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details. 13 * GNU General Public License for more details.
14 * 14 *
15 * You should have received a copy of the GNU General Public License 15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software 16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 * 18 *
19 */ 19 */
20 20
21#ifndef _COLOR_LISTBOX_H_ 21#ifndef _COLOR_LISTBOX_H_
22#define _COLOR_LISTBOX_H_ 22#define _COLOR_LISTBOX_H_
23 23
24#include <klistbox.h> 24#include <klistbox.h>
25 25
26class QDragEnterEvent; 26class QDragEnterEvent;
27class QDragLeaveEvent; 27class QDragLeaveEvent;
28class QDragMoveEvent; 28class QDragMoveEvent;
29class QDropEvent; 29class QDropEvent;
30 30
31class ColorListBox : public KListBox 31class ColorListBox : public KListBox
32{ 32{
33 Q_OBJECT 33 Q_OBJECT
34 34
35 public: 35 public:
36 ColorListBox( QWidget *parent=0, const char * name=0, WFlags f=0 ); 36 ColorListBox( QWidget *parent=0, const char * name=0, WFlags f=0 );
37 void setColor( uint index, const QColor &color ); 37 void setColor( uint index, const QColor &color );
38 QColor color( uint index ) const; 38 QColor color( uint index ) const;
39 39
40 public slots: 40 public slots:
41 virtual void setEnabled( bool state ); 41 virtual void setEnabled( bool state );
42 42
43 protected: 43 protected:
44 void dragEnterEvent( QDragEnterEvent *e ); 44 void dragEnterEvent( QDragEnterEvent *e );
45 void dragLeaveEvent( QDragLeaveEvent *e ); 45 void dragLeaveEvent( QDragLeaveEvent *e );
46 void dragMoveEvent( QDragMoveEvent *e ); 46 void dragMoveEvent( QDragMoveEvent *e );
47 void dropEvent( QDropEvent *e ); 47 void dropEvent( QDropEvent *e );
48 48
49 private slots: 49 private slots:
50 void newColor( int index ); 50 void newColor( int index );
51 void slotNewColor(QListBoxItem * i);
51 52
52 private: 53 private:
53 int mCurrentOnDragEnter; 54 int mCurrentOnDragEnter;
54 55
55}; 56};
56 57
57 58
58class ColorListItem : public QListBoxItem 59class ColorListItem : public QListBoxItem
59{ 60{
60 public: 61 public:
61 ColorListItem( const QString &text, const QColor &color=Qt::black ); 62 ColorListItem( const QString &text, const QColor &color=Qt::black );
62 const QColor &color( void ); 63 const QColor &color( void );
63 void setColor( const QColor &color ); 64 void setColor( const QColor &color );
64 65
65 protected: 66 protected:
66 virtual void paint( QPainter * ); 67 virtual void paint( QPainter * );
67 virtual int height( const QListBox * ) const; 68 virtual int height( const QListBox * ) const;
68 virtual int width( const QListBox * ) const; 69 virtual int width( const QListBox * ) const;
69 70
70 private: 71 private:
71 QColor mColor; 72 QColor mColor;
72 int mBoxWidth; 73 int mBoxWidth;
73}; 74};
74 75
75#endif 76#endif
76 77
diff --git a/kaddressbook/views/configurecardviewdialog.cpp b/kaddressbook/views/configurecardviewdialog.cpp
index 366e54c..e0fbd21 100644
--- a/kaddressbook/views/configurecardviewdialog.cpp
+++ b/kaddressbook/views/configurecardviewdialog.cpp
@@ -1,365 +1,369 @@
1/* 1/*
2 This file is part of KAddressBook. 2 This file is part of KAddressBook.
3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com> 3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24#include <qstring.h> 24#include <qstring.h>
25#include <qlayout.h> 25#include <qlayout.h>
26#include <qlabel.h> 26#include <qlabel.h>
27#include <qcheckbox.h> 27#include <qcheckbox.h>
28#include <qvbox.h> 28#include <qvbox.h>
29#include <qgroupbox.h> 29#include <qgroupbox.h>
30#include <qspinbox.h> 30#include <qspinbox.h>
31#include <qtabwidget.h> 31#include <qtabwidget.h>
32#include <qwhatsthis.h> 32#include <qwhatsthis.h>
33 33
34#include <kdebug.h> 34#include <kdebug.h>
35#include <kglobal.h> 35#include <kglobal.h>
36#include <kglobalsettings.h> 36#include <kglobalsettings.h>
37#include <klocale.h> 37#include <klocale.h>
38#include <kiconloader.h> 38#include <kiconloader.h>
39#include <kconfig.h> 39#include <kconfig.h>
40#include <kfontdialog.h> 40#include <kfontdialog.h>
41 41
42#ifndef KAB_EMBEDDED 42#ifndef KAB_EMBEDDED
43#include <kpushbutton.h> 43#include <kpushbutton.h>
44#else //KAB_EMBEDDED 44#else //KAB_EMBEDDED
45#include <qpushbutton.h> 45#include <qpushbutton.h>
46#endif //KAB_EMBEDDED 46#endif //KAB_EMBEDDED
47 47
48#include "colorlistbox.h" 48#include "colorlistbox.h"
49 49
50#include "configurecardviewdialog.h" 50#include "configurecardviewdialog.h"
51 51
52///////////////////////////////// 52/////////////////////////////////
53// ConfigureCardViewDialog 53// ConfigureCardViewDialog
54 54
55ConfigureCardViewWidget::ConfigureCardViewWidget( KABC::AddressBook *ab, QWidget *parent, 55ConfigureCardViewWidget::ConfigureCardViewWidget( KABC::AddressBook *ab, QWidget *parent,
56 const char *name ) 56 const char *name )
57 : ViewConfigureWidget( ab, parent, name ) 57 : ViewConfigureWidget( ab, parent, name )
58{ 58{
59#ifndef KAB_EMBEDDED 59#ifndef KAB_EMBEDDED
60 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null, 60 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null,
61 DesktopIcon( "looknfeel" ) ); 61 DesktopIcon( "looknfeel" ) );
62#else //KAB_EMBEDDED 62#else //KAB_EMBEDDED
63 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null, 63 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null,
64 KGlobal::iconLoader()->loadIcon( "looknfeel", 64 KGlobal::iconLoader()->loadIcon( "looknfeel",
65 KIcon::Panel ) ); 65 KIcon::Panel ) );
66#endif //KAB_EMBEDDED 66#endif //KAB_EMBEDDED
67 67
68 mAdvancedPage = new CardViewLookNFeelPage( page ); 68 mAdvancedPage = new CardViewLookNFeelPage( page );
69} 69}
70 70
71ConfigureCardViewWidget::~ConfigureCardViewWidget() 71ConfigureCardViewWidget::~ConfigureCardViewWidget()
72{ 72{
73} 73}
74 74
75void ConfigureCardViewWidget::restoreSettings( KConfig *config ) 75void ConfigureCardViewWidget::restoreSettings( KConfig *config )
76{ 76{
77 ViewConfigureWidget::restoreSettings( config ); 77 ViewConfigureWidget::restoreSettings( config );
78 78
79 mAdvancedPage->restoreSettings( config ); 79 mAdvancedPage->restoreSettings( config );
80} 80}
81 81
82void ConfigureCardViewWidget::saveSettings( KConfig *config ) 82void ConfigureCardViewWidget::saveSettings( KConfig *config )
83{ 83{
84 ViewConfigureWidget::saveSettings( config ); 84 ViewConfigureWidget::saveSettings( config );
85 85
86 mAdvancedPage->saveSettings( config ); 86 mAdvancedPage->saveSettings( config );
87} 87}
88 88
89//////////////////////// 89////////////////////////
90// CardViewLookNFeelPage 90// CardViewLookNFeelPage
91CardViewLookNFeelPage::CardViewLookNFeelPage( QWidget *parent, const char *name ) 91CardViewLookNFeelPage::CardViewLookNFeelPage( QWidget *parent, const char *name )
92 : QVBox( parent, name ) 92 : QVBox( parent, name )
93{ 93{
94 initGUI(); 94 initGUI();
95} 95}
96 96
97CardViewLookNFeelPage::~CardViewLookNFeelPage() 97CardViewLookNFeelPage::~CardViewLookNFeelPage()
98{ 98{
99} 99}
100 100
101void CardViewLookNFeelPage::restoreSettings( KConfig *config ) 101void CardViewLookNFeelPage::restoreSettings( KConfig *config )
102{ 102{
103 // colors 103 // colors
104 cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) ); 104 cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) );
105 QColor c; 105 QColor c;
106qDebug("CardViewLookNFeelPage::restoreSettings make base color configurable"); 106qDebug("CardViewLookNFeelPage::restoreSettings make base color configurable");
107 107
108#ifndef KAB_EMBEDDED 108#ifndef KAB_EMBEDDED
109 c = KGlobalSettings::baseColor(); 109 c = KGlobalSettings::baseColor();
110#else //KAB_EMBEDDED 110#else //KAB_EMBEDDED
111 c = QColor(0,0,0); 111 c = QColor(0,0,0);
112#endif //KAB_EMBEDDED 112#endif //KAB_EMBEDDED
113 113
114 c = colorGroup().background(); 114 c = colorGroup().background();
115 lbColors->insertItem( new ColorListItem( i18n("Background Color"), 115 lbColors->insertItem( new ColorListItem( i18n("Background Color"),
116 config->readColorEntry( "BackgroundColor", &c ) ) ); 116 config->readColorEntry( "BackgroundColor", &c ) ) );
117 c = colorGroup().foreground(); 117 c = colorGroup().foreground();
118 lbColors->insertItem( new ColorListItem( i18n("Text Color"), 118 lbColors->insertItem( new ColorListItem( i18n("Text Color"),
119 config->readColorEntry( "TextColor", &c ) ) ); 119 config->readColorEntry( "TextColor", &c ) ) );
120 c = colorGroup().button(); 120 c = colorGroup().button();
121 lbColors->insertItem( new ColorListItem( i18n("Header, Border and Separator Color"), 121 lbColors->insertItem( new ColorListItem( i18n("Header, Border and Separator Color"),
122 config->readColorEntry( "HeaderColor", &c ) ) ); 122 config->readColorEntry( "HeaderColor", &c ) ) );
123 c = colorGroup().buttonText(); 123 c = colorGroup().buttonText();
124 lbColors->insertItem( new ColorListItem( i18n("Header Text Color"), 124 lbColors->insertItem( new ColorListItem( i18n("Header Text Color"),
125 config->readColorEntry( "HeaderTextColor", &c ) ) ); 125 config->readColorEntry( "HeaderTextColor", &c ) ) );
126 c = colorGroup().highlight(); 126 c = colorGroup().highlight();
127 lbColors->insertItem( new ColorListItem( i18n("Highlight Color"), 127 lbColors->insertItem( new ColorListItem( i18n("Highlight Color"),
128 config->readColorEntry( "HighlightColor", &c ) ) ); 128 config->readColorEntry( "HighlightColor", &c ) ) );
129 c = colorGroup().highlightedText(); 129 c = colorGroup().highlightedText();
130 lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"), 130 lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"),
131 config->readColorEntry( "HighlightedTextColor", &c ) ) ); 131 config->readColorEntry( "HighlightedTextColor", &c ) ) );
132 132
133 enableColors(); 133 enableColors();
134 134
135 // fonts 135 // fonts
136 QFont fnt = font(); 136 QFont fnt = font();
137 updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont ); 137 updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont );
138 fnt.setBold( true ); 138 fnt.setBold( true );
139 updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont ); 139 updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont );
140 cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) ); 140 cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) );
141 enableFonts(); 141 enableFonts();
142 142
143 // layout 143 // layout
144 sbMargin->setValue( config->readNumEntry( "ItemMargin", 0 ) ); 144 sbMargin->setValue( config->readNumEntry( "ItemMargin", 0 ) );
145 sbSpacing->setValue( config->readNumEntry( "ItemSpacing", 10 ) ); 145 sbSpacing->setValue( config->readNumEntry( "ItemSpacing", 10 ) );
146 sbSepWidth->setValue( config->readNumEntry( "SeparatorWidth", 2 ) ); 146 sbSepWidth->setValue( config->readNumEntry( "SeparatorWidth", 2 ) );
147 cbDrawSeps->setChecked( config->readBoolEntry( "DrawSeparators", true ) ); 147 cbDrawSeps->setChecked( config->readBoolEntry( "DrawSeparators", true ) );
148 cbDrawBorders->setChecked( config->readBoolEntry( "DrawBorder", true ) ); 148 cbDrawBorders->setChecked( config->readBoolEntry( "DrawBorder", true ) );
149 149
150 // behaviour 150 // behaviour
151 cbShowFieldLabels->setChecked( config->readBoolEntry( "DrawFieldLabels", false ) ); 151 cbShowFieldLabels->setChecked( config->readBoolEntry( "DrawFieldLabels", false ) );
152 cbShowEmptyFields->setChecked( config->readBoolEntry( "ShowEmptyFields", false ) ); 152 cbShowEmptyFields->setChecked( config->readBoolEntry( "ShowEmptyFields", false ) );
153} 153}
154 154
155void CardViewLookNFeelPage::saveSettings( KConfig *config ) 155void CardViewLookNFeelPage::saveSettings( KConfig *config )
156{ 156{
157 // colors 157 // colors
158 config->writeEntry( "EnableCustomColors", cbEnableCustomColors->isChecked() ); 158 config->writeEntry( "EnableCustomColors", cbEnableCustomColors->isChecked() );
159 if ( cbEnableCustomColors->isChecked() ) // ?? - Hmmm. 159 if ( cbEnableCustomColors->isChecked() ) // ?? - Hmmm.
160 { 160 {
161 config->writeEntry( "BackgroundColor", lbColors->color( 0 ) ); 161 config->writeEntry( "BackgroundColor", lbColors->color( 0 ) );
162 config->writeEntry( "TextColor", lbColors->color( 1 ) ); 162 config->writeEntry( "TextColor", lbColors->color( 1 ) );
163 config->writeEntry( "HeaderColor", lbColors->color( 2 ) ); 163 config->writeEntry( "HeaderColor", lbColors->color( 2 ) );
164 config->writeEntry( "HeaderTextColor", lbColors->color( 3 ) ); 164 config->writeEntry( "HeaderTextColor", lbColors->color( 3 ) );
165 config->writeEntry( "HighlightColor", lbColors->color( 4 ) ); 165 config->writeEntry( "HighlightColor", lbColors->color( 4 ) );
166 config->writeEntry( "HighlightedTextColor", lbColors->color( 5 ) ); 166 config->writeEntry( "HighlightedTextColor", lbColors->color( 5 ) );
167 } 167 }
168 // fonts 168 // fonts
169 config->writeEntry( "EnableCustomFonts", cbEnableCustomFonts->isChecked() ); 169 config->writeEntry( "EnableCustomFonts", cbEnableCustomFonts->isChecked() );
170 if ( cbEnableCustomFonts->isChecked() ) 170 if ( cbEnableCustomFonts->isChecked() )
171 { 171 {
172 config->writeEntry( "TextFont", lTextFont->font() ); 172 config->writeEntry( "TextFont", lTextFont->font() );
173 config->writeEntry( "HeaderFont", lHeaderFont->font() ); 173 config->writeEntry( "HeaderFont", lHeaderFont->font() );
174 } 174 }
175 // layout 175 // layout
176 config->writeEntry( "ItemMargin", sbMargin->value() ); 176 config->writeEntry( "ItemMargin", sbMargin->value() );
177 config->writeEntry( "ItemSpacing", sbSpacing->value() ); 177 config->writeEntry( "ItemSpacing", sbSpacing->value() );
178 config->writeEntry( "SeparatorWidth", sbSepWidth->value() ); 178 config->writeEntry( "SeparatorWidth", sbSepWidth->value() );
179 config->writeEntry("DrawBorder", cbDrawBorders->isChecked()); 179 config->writeEntry("DrawBorder", cbDrawBorders->isChecked());
180 config->writeEntry("DrawSeparators", cbDrawSeps->isChecked()); 180 config->writeEntry("DrawSeparators", cbDrawSeps->isChecked());
181 181
182 // behaviour 182 // behaviour
183 config->writeEntry("DrawFieldLabels", cbShowFieldLabels->isChecked()); 183 config->writeEntry("DrawFieldLabels", cbShowFieldLabels->isChecked());
184 config->writeEntry("ShowEmptyFields", cbShowEmptyFields->isChecked()); 184 config->writeEntry("ShowEmptyFields", cbShowEmptyFields->isChecked());
185} 185}
186 186
187void CardViewLookNFeelPage::setTextFont() 187void CardViewLookNFeelPage::setTextFont()
188{ 188{
189 QFont f( lTextFont->font() ); 189 QFont f( lTextFont->font() );
190#ifndef KAB_EMBEDDED 190#ifndef KAB_EMBEDDED
191 if ( KFontDialog::getFont( f, false, this ) == QDialog::Accepted ) 191 if ( KFontDialog::getFont( f, false, this ) == QDialog::Accepted )
192 updateFontLabel( f, lTextFont ); 192 updateFontLabel( f, lTextFont );
193#else //KAB_EMBEDDED 193#else //KAB_EMBEDDED
194 bool ok; 194 bool ok;
195 QFont fout = KFontDialog::getFont( f, ok); 195 QFont fout = KFontDialog::getFont( f, ok);
196 if ( ok ) 196 if ( ok )
197 updateFontLabel( fout, lTextFont ); 197 updateFontLabel( fout, lTextFont );
198#endif //KAB_EMBEDDED 198#endif //KAB_EMBEDDED
199} 199}
200 200
201void CardViewLookNFeelPage::setHeaderFont() 201void CardViewLookNFeelPage::setHeaderFont()
202{ 202{
203 QFont f( lHeaderFont->font() ); 203 QFont f( lHeaderFont->font() );
204#ifndef KAB_EMBEDDED 204#ifndef KAB_EMBEDDED
205 if ( KFontDialog::getFont( f,false, this ) == QDialog::Accepted ) 205 if ( KFontDialog::getFont( f,false, this ) == QDialog::Accepted )
206 updateFontLabel( f, lHeaderFont ); 206 updateFontLabel( f, lHeaderFont );
207#else //KAB_EMBEDDED 207#else //KAB_EMBEDDED
208 bool ok; 208 bool ok;
209 QFont fout = KFontDialog::getFont( f, ok); 209 QFont fout = KFontDialog::getFont( f, ok);
210 if ( ok ) 210 if ( ok )
211 updateFontLabel( fout, lHeaderFont ); 211 updateFontLabel( fout, lHeaderFont );
212#endif //KAB_EMBEDDED 212#endif //KAB_EMBEDDED
213} 213}
214 214
215void CardViewLookNFeelPage::enableFonts() 215void CardViewLookNFeelPage::enableFonts()
216{ 216{
217 vbFonts->setEnabled( cbEnableCustomFonts->isChecked() ); 217 vbFonts->setEnabled( cbEnableCustomFonts->isChecked() );
218 if ( cbEnableCustomFonts->isChecked() )
219 vbFonts->setFocus();
218} 220}
219 221
220void CardViewLookNFeelPage::enableColors() 222void CardViewLookNFeelPage::enableColors()
221{ 223{
222 lbColors->setEnabled( cbEnableCustomColors->isChecked() ); 224 lbColors->setEnabled( cbEnableCustomColors->isChecked() );
225 if ( cbEnableCustomColors->isChecked() )
226 lbColors->setFocus();
223} 227}
224 228
225void CardViewLookNFeelPage::initGUI() 229void CardViewLookNFeelPage::initGUI()
226{ 230{
227 int spacing = KDialog::spacingHint(); 231 int spacing = KDialog::spacingHint();
228 int margin = KDialog::marginHint(); 232 int margin = KDialog::marginHint();
229 233
230 QTabWidget *tabs = new QTabWidget( this ); 234 QTabWidget *tabs = new QTabWidget( this );
231 235
232 // Layout 236 // Layout
233 QVBox *loTab = new QVBox( this, "layouttab" ); 237 QVBox *loTab = new QVBox( this, "layouttab" );
234 238
235 loTab->setSpacing( spacing ); 239 loTab->setSpacing( spacing );
236 loTab->setMargin( margin ); 240 loTab->setMargin( margin );
237 241
238 QGroupBox *gbGeneral = new QGroupBox( 1, Qt::Horizontal, i18n("General"), loTab ); 242 QGroupBox *gbGeneral = new QGroupBox( 1, Qt::Horizontal, i18n("General"), loTab );
239 243
240 cbDrawSeps = new QCheckBox( i18n("Draw &separators"), gbGeneral ); 244 cbDrawSeps = new QCheckBox( i18n("Draw &separators"), gbGeneral );
241 245
242 QHBox *hbSW = new QHBox( gbGeneral ); 246 QHBox *hbSW = new QHBox( gbGeneral );
243 QLabel *lSW = new QLabel( i18n("Separator &width:"), hbSW ); 247 QLabel *lSW = new QLabel( i18n("Separator &width:"), hbSW );
244 sbSepWidth = new QSpinBox( 1, 50, 1, hbSW ); 248 sbSepWidth = new QSpinBox( 1, 50, 1, hbSW );
245 lSW->setBuddy( sbSepWidth); 249 lSW->setBuddy( sbSepWidth);
246 250
247 QHBox *hbPadding = new QHBox( gbGeneral ); 251 QHBox *hbPadding = new QHBox( gbGeneral );
248 QLabel *lSpacing = new QLabel( i18n("&Padding:"), hbPadding ); 252 QLabel *lSpacing = new QLabel( i18n("&Padding:"), hbPadding );
249 sbSpacing = new QSpinBox( 0, 100, 1, hbPadding ); 253 sbSpacing = new QSpinBox( 0, 100, 1, hbPadding );
250 lSpacing->setBuddy( sbSpacing ); 254 lSpacing->setBuddy( sbSpacing );
251 255
252 QGroupBox *gbCards = new QGroupBox( 1, Qt::Horizontal, i18n("Cards"), loTab ); 256 QGroupBox *gbCards = new QGroupBox( 1, Qt::Horizontal, i18n("Cards"), loTab );
253 257
254 QHBox *hbMargin = new QHBox( gbCards ); 258 QHBox *hbMargin = new QHBox( gbCards );
255 QLabel *lMargin = new QLabel( i18n("&Margin:"), hbMargin ); 259 QLabel *lMargin = new QLabel( i18n("&Margin:"), hbMargin );
256 sbMargin = new QSpinBox( 0, 100, 1, hbMargin ); 260 sbMargin = new QSpinBox( 0, 100, 1, hbMargin );
257 lMargin->setBuddy( sbMargin ); 261 lMargin->setBuddy( sbMargin );
258 262
259 cbDrawBorders = new QCheckBox( i18n("Draw &borders"), gbCards ); 263 cbDrawBorders = new QCheckBox( i18n("Draw &borders"), gbCards );
260 264
261 loTab->setStretchFactor( new QWidget( loTab ), 1 ); 265 loTab->setStretchFactor( new QWidget( loTab ), 1 );
262 266
263 QWhatsThis::add( sbMargin, i18n( 267 QWhatsThis::add( sbMargin, i18n(
264 "The item margin is the distance (in pixels) between the item edge and the item data. Most noticeably, " 268 "The item margin is the distance (in pixels) between the item edge and the item data. Most noticeably, "
265 "incrementing the item margin will add space between the focus rectangle and the item data." 269 "incrementing the item margin will add space between the focus rectangle and the item data."
266 ) ); 270 ) );
267 QWhatsThis::add( lMargin, QWhatsThis::textFor( sbMargin ) ); 271 QWhatsThis::add( lMargin, QWhatsThis::textFor( sbMargin ) );
268 QWhatsThis::add( sbSpacing, i18n( 272 QWhatsThis::add( sbSpacing, i18n(
269 "The Item Spacing decides the distance (in pixels) between the items and anything else: the view " 273 "The Item Spacing decides the distance (in pixels) between the items and anything else: the view "
270 "borders, other items or column separators." 274 "borders, other items or column separators."
271 ) ); 275 ) );
272 QWhatsThis::add( lSpacing, QWhatsThis::textFor( sbSpacing ) ); 276 QWhatsThis::add( lSpacing, QWhatsThis::textFor( sbSpacing ) );
273 QWhatsThis::add( sbSepWidth, i18n("Sets the width of column separators") ); 277 QWhatsThis::add( sbSepWidth, i18n("Sets the width of column separators") );
274 QWhatsThis::add( lSW, QWhatsThis::textFor( sbSepWidth ) ); 278 QWhatsThis::add( lSW, QWhatsThis::textFor( sbSepWidth ) );
275 279
276 tabs->addTab( loTab, i18n("&Layout") ); 280 tabs->addTab( loTab, i18n("&Layout") );
277 281
278 // Colors 282 // Colors
279 QVBox *colorTab = new QVBox( this, "colortab" ); 283 QVBox *colorTab = new QVBox( this, "colortab" );
280 colorTab->setSpacing( spacing ); 284 colorTab->setSpacing( spacing );
281 colorTab->setMargin( spacing ); 285 colorTab->setMargin( spacing );
282 cbEnableCustomColors = new QCheckBox( i18n("&Enable custom Colors"), colorTab ); 286 cbEnableCustomColors = new QCheckBox( i18n("&Enable custom Colors"), colorTab );
283 connect( cbEnableCustomColors, SIGNAL(clicked()), this, SLOT(enableColors()) ); 287 connect( cbEnableCustomColors, SIGNAL(clicked()), this, SLOT(enableColors()) );
284 lbColors = new ColorListBox( colorTab ); 288 lbColors = new ColorListBox( colorTab );
285 tabs->addTab( colorTab, i18n("&Colors") ); 289 tabs->addTab( colorTab, i18n("&Colors") );
286 290
287 QWhatsThis::add( cbEnableCustomColors, i18n( 291 QWhatsThis::add( cbEnableCustomColors, i18n(
288 "If custom colors are enabled, you may choose the colors for the view below. " 292 "If custom colors are enabled, you may choose the colors for the view below. "
289 "Otherwise colors from your current KDE color scheme are used." 293 "Otherwise colors from your current KDE color scheme are used."
290 ) ); 294 ) );
291 QWhatsThis::add( lbColors, i18n( 295 QWhatsThis::add( lbColors, i18n(
292 "Double click or press RETURN on a item to select a color for the related strings in the view." 296 "Double click or press RETURN on a item to select a color for the related strings in the view."
293 ) ); 297 ) );
294 298
295 // Fonts 299 // Fonts
296 QVBox *fntTab = new QVBox( this, "fonttab" ); 300 QVBox *fntTab = new QVBox( this, "fonttab" );
297 301
298 fntTab->setSpacing( spacing ); 302 fntTab->setSpacing( spacing );
299 fntTab->setMargin( spacing ); 303 fntTab->setMargin( spacing );
300 304
301 cbEnableCustomFonts = new QCheckBox( i18n("&Enable custom fonts"), fntTab ); 305 cbEnableCustomFonts = new QCheckBox( i18n("&Enable custom fonts"), fntTab );
302 connect( cbEnableCustomFonts, SIGNAL(clicked()), this, SLOT(enableFonts()) ); 306 connect( cbEnableCustomFonts, SIGNAL(clicked()), this, SLOT(enableFonts()) );
303 307
304 vbFonts = new QWidget( fntTab ); 308 vbFonts = new QWidget( fntTab );
305 QGridLayout *gFnts = new QGridLayout( vbFonts, 2, 3 ); 309 QGridLayout *gFnts = new QGridLayout( vbFonts, 2, 3 );
306 gFnts->setSpacing( spacing ); 310 gFnts->setSpacing( spacing );
307 gFnts->setAutoAdd( true ); 311 gFnts->setAutoAdd( true );
308 gFnts->setColStretch( 1, 1 ); 312 gFnts->setColStretch( 1, 1 );
309 QLabel *lTFnt = new QLabel( i18n("&Text font:"), vbFonts ); 313 QLabel *lTFnt = new QLabel( i18n("&Text font:"), vbFonts );
310 lTextFont = new QLabel( vbFonts ); 314 lTextFont = new QLabel( vbFonts );
311 lTextFont->setFrameStyle( QFrame::Panel|QFrame::Sunken ); 315 lTextFont->setFrameStyle( QFrame::Panel|QFrame::Sunken );
312#ifndef KAB_EMBEDDED 316#ifndef KAB_EMBEDDED
313 btnFont = new KPushButton( i18n("Choose..."), vbFonts ); 317 btnFont = new KPushButton( i18n("Choose..."), vbFonts );
314#else //KAB_EMBEDDED 318#else //KAB_EMBEDDED
315 btnFont = new QPushButton( i18n("Choose..."), vbFonts ); 319 btnFont = new QPushButton( i18n("Choose..."), vbFonts );
316#endif //KAB_EMBEDDED 320#endif //KAB_EMBEDDED
317 321
318 lTFnt->setBuddy( btnFont ); 322 lTFnt->setBuddy( btnFont );
319 323
320 connect( btnFont, SIGNAL(clicked()), this, SLOT(setTextFont()) ); 324 connect( btnFont, SIGNAL(clicked()), this, SLOT(setTextFont()) );
321 325
322 QLabel *lHFnt = new QLabel( i18n("&Header font:"), vbFonts ); 326 QLabel *lHFnt = new QLabel( i18n("&Header font:"), vbFonts );
323 lHeaderFont = new QLabel( vbFonts ); 327 lHeaderFont = new QLabel( vbFonts );
324 lHeaderFont->setFrameStyle( QFrame::Panel|QFrame::Sunken ); 328 lHeaderFont->setFrameStyle( QFrame::Panel|QFrame::Sunken );
325#ifndef KAB_EMBEDDED 329#ifndef KAB_EMBEDDED
326 btnHeaderFont = new KPushButton( i18n("Choose..."), vbFonts ); 330 btnHeaderFont = new KPushButton( i18n("Choose..."), vbFonts );
327#else //KAB_EMBEDDED 331#else //KAB_EMBEDDED
328 btnHeaderFont = new QPushButton( i18n("Choose..."), vbFonts ); 332 btnHeaderFont = new QPushButton( i18n("Choose..."), vbFonts );
329#endif //KAB_EMBEDDED 333#endif //KAB_EMBEDDED
330 lHFnt->setBuddy( btnHeaderFont ); 334 lHFnt->setBuddy( btnHeaderFont );
331 connect( btnHeaderFont, SIGNAL(clicked()), this, SLOT(setHeaderFont()) ); 335 connect( btnHeaderFont, SIGNAL(clicked()), this, SLOT(setHeaderFont()) );
332 336
333 fntTab->setStretchFactor( new QWidget( fntTab ), 1 ); 337 fntTab->setStretchFactor( new QWidget( fntTab ), 1 );
334 338
335 QWhatsThis::add( cbEnableCustomFonts, i18n( 339 QWhatsThis::add( cbEnableCustomFonts, i18n(
336 "If custom fonts are enabled, you may choose which fonts to use for this view below. " 340 "If custom fonts are enabled, you may choose which fonts to use for this view below. "
337 "Otherwise the default KDE font will be used, in bold style for the header and " 341 "Otherwise the default KDE font will be used, in bold style for the header and "
338 "normal style for the data." 342 "normal style for the data."
339 ) ); 343 ) );
340 344
341 tabs->addTab( fntTab, i18n("&Fonts") ); 345 tabs->addTab( fntTab, i18n("&Fonts") );
342 346
343 // Behaviour 347 // Behaviour
344 QVBox *behaviourTab = new QVBox( this ); 348 QVBox *behaviourTab = new QVBox( this );
345 behaviourTab->setMargin( margin ); 349 behaviourTab->setMargin( margin );
346 behaviourTab->setSpacing( spacing ); 350 behaviourTab->setSpacing( spacing );
347 351
348 cbShowEmptyFields = new QCheckBox( i18n("Show &empty fields"), behaviourTab ); 352 cbShowEmptyFields = new QCheckBox( i18n("Show &empty fields"), behaviourTab );
349 cbShowFieldLabels = new QCheckBox( i18n("Show field &labels"), behaviourTab ); 353 cbShowFieldLabels = new QCheckBox( i18n("Show field &labels"), behaviourTab );
350 354
351 behaviourTab->setStretchFactor( new QWidget( behaviourTab ), 1 ); 355 behaviourTab->setStretchFactor( new QWidget( behaviourTab ), 1 );
352 356
353 tabs->addTab( behaviourTab, i18n("Be&havior") ); 357 tabs->addTab( behaviourTab, i18n("Be&havior") );
354 358
355} 359}
356 360
357void CardViewLookNFeelPage::updateFontLabel( QFont fnt, QLabel *l ) 361void CardViewLookNFeelPage::updateFontLabel( QFont fnt, QLabel *l )
358{ 362{
359 l->setFont( fnt ); 363 l->setFont( fnt );
360 l->setText( QString( fnt.family() + " %1" ).arg( fnt.pointSize() ) ); 364 l->setText( QString( fnt.family() + " %1" ).arg( fnt.pointSize() ) );
361} 365}
362 366
363#ifndef KAB_EMBEDDED 367#ifndef KAB_EMBEDDED
364#include "configurecardviewdialog.moc" 368#include "configurecardviewdialog.moc"
365#endif //KAB_EMBEDDED 369#endif //KAB_EMBEDDED
diff --git a/kaddressbook/views/configuretableviewdialog.cpp b/kaddressbook/views/configuretableviewdialog.cpp
index 8bcceb2..0e36abd 100644
--- a/kaddressbook/views/configuretableviewdialog.cpp
+++ b/kaddressbook/views/configuretableviewdialog.cpp
@@ -1,341 +1,345 @@
1/* 1/*
2 This file is part of KAddressBook. 2 This file is part of KAddressBook.
3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com> 3 Copyright (c) 2002 Mike Pilone <mpilone@slac.com>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24#include <qstring.h> 24#include <qstring.h>
25#include <qwidget.h> 25#include <qwidget.h>
26#include <qlayout.h> 26#include <qlayout.h>
27#include <qlabel.h> 27#include <qlabel.h>
28#include <qradiobutton.h> 28#include <qradiobutton.h>
29#include <qcheckbox.h> 29#include <qcheckbox.h>
30#include <qvbox.h> 30#include <qvbox.h>
31#include <qbuttongroup.h> 31#include <qbuttongroup.h>
32#include <qtabwidget.h> 32#include <qtabwidget.h>
33#include <qwhatsthis.h> 33#include <qwhatsthis.h>
34#include <qpushbutton.h> 34#include <qpushbutton.h>
35 35
36#include <kglobal.h> 36#include <kglobal.h>
37#include <klocale.h> 37#include <klocale.h>
38#include <klineedit.h> 38#include <klineedit.h>
39#include <kurlrequester.h> 39#include <kurlrequester.h>
40#include <kiconloader.h> 40#include <kiconloader.h>
41#include <kfontdialog.h> 41#include <kfontdialog.h>
42 42
43#ifndef KAB_EMBEDDED 43#ifndef KAB_EMBEDDED
44#include <kimageio.h> 44#include <kimageio.h>
45#else //KAB_EMBEDDED 45#else //KAB_EMBEDDED
46#endif //KAB_EMBEDDED 46#endif //KAB_EMBEDDED
47 47
48#include <kconfig.h> 48#include <kconfig.h>
49 49
50#include "colorlistbox.h" 50#include "colorlistbox.h"
51 51
52#include "configuretableviewdialog.h" 52#include "configuretableviewdialog.h"
53 53
54ConfigureTableViewWidget::ConfigureTableViewWidget( KABC::AddressBook *ab, 54ConfigureTableViewWidget::ConfigureTableViewWidget( KABC::AddressBook *ab,
55 QWidget *parent, 55 QWidget *parent,
56 const char *name ) 56 const char *name )
57 : ViewConfigureWidget( ab, parent, name ) 57 : ViewConfigureWidget( ab, parent, name )
58{ 58{
59 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null, 59 QWidget *page = addPage( i18n( "Look & Feel" ), QString::null,
60 KGlobal::iconLoader()->loadIcon( "looknfeel", 60 KGlobal::iconLoader()->loadIcon( "looknfeel",
61 KIcon::Panel ) ); 61 KIcon::Panel ) );
62 62
63 mPage = new LookAndFeelPage( page ); 63 mPage = new LookAndFeelPage( page );
64} 64}
65 65
66ConfigureTableViewWidget::~ConfigureTableViewWidget() 66ConfigureTableViewWidget::~ConfigureTableViewWidget()
67{ 67{
68} 68}
69 69
70void ConfigureTableViewWidget::restoreSettings( KConfig *config ) 70void 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
77void ConfigureTableViewWidget::saveSettings( KConfig *config ) 77void 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
86LookAndFeelPage::LookAndFeelPage(QWidget *parent, const char *name) 86LookAndFeelPage::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
95void LookAndFeelPage::restoreSettings( KConfig *config ) 95void 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;
110qDebug("LookAndFeelPage::restoreSettings make base color configurable"); 110qDebug("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
152void LookAndFeelPage::saveSettings( KConfig *config ) 152void 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());
159 159
160 // colors 160 // colors
161 config->writeEntry( "EnableCustomColors", cbEnableCustomColors->isChecked() ); 161 config->writeEntry( "EnableCustomColors", cbEnableCustomColors->isChecked() );
162 if ( cbEnableCustomColors->isChecked() ) // ?? - Hmmm. 162 if ( cbEnableCustomColors->isChecked() ) // ?? - Hmmm.
163 { 163 {
164 config->writeEntry( "BackgroundColor", lbColors->color( 0 ) ); 164 config->writeEntry( "BackgroundColor", lbColors->color( 0 ) );
165 config->writeEntry( "TextColor", lbColors->color( 1 ) ); 165 config->writeEntry( "TextColor", lbColors->color( 1 ) );
166 config->writeEntry( "HeaderBackgroundColor", lbColors->color( 2 ) ); 166 config->writeEntry( "HeaderBackgroundColor", lbColors->color( 2 ) );
167 config->writeEntry( "HeaderTextColor", lbColors->color( 3 ) ); 167 config->writeEntry( "HeaderTextColor", lbColors->color( 3 ) );
168 config->writeEntry( "HighlightColor", lbColors->color( 4 ) ); 168 config->writeEntry( "HighlightColor", lbColors->color( 4 ) );
169 config->writeEntry( "HighlightedTextColor", lbColors->color( 5 ) ); 169 config->writeEntry( "HighlightedTextColor", lbColors->color( 5 ) );
170 config->writeEntry( "AlternatingBackgroundColor", lbColors->color( 6 ) ); 170 config->writeEntry( "AlternatingBackgroundColor", lbColors->color( 6 ) );
171 } 171 }
172 // fonts 172 // fonts
173 config->writeEntry( "EnableCustomFonts", cbEnableCustomFonts->isChecked() ); 173 config->writeEntry( "EnableCustomFonts", cbEnableCustomFonts->isChecked() );
174 if ( cbEnableCustomFonts->isChecked() ) 174 if ( cbEnableCustomFonts->isChecked() )
175 { 175 {
176 config->writeEntry( "TextFont", lTextFont->font() ); 176 config->writeEntry( "TextFont", lTextFont->font() );
177 config->writeEntry( "HeaderFont", lHeaderFont->font() ); 177 config->writeEntry( "HeaderFont", lHeaderFont->font() );
178 } 178 }
179 179
180} 180}
181 181
182void LookAndFeelPage::setTextFont() 182void LookAndFeelPage::setTextFont()
183{ 183{
184 QFont f( lTextFont->font() ); 184 QFont f( lTextFont->font() );
185#ifndef KAB_EMBEDDED 185#ifndef KAB_EMBEDDED
186 if ( KFontDialog::getFont( f, false, this ) == QDialog::Accepted ) 186 if ( KFontDialog::getFont( f, false, this ) == QDialog::Accepted )
187 updateFontLabel( f, lTextFont ); 187 updateFontLabel( f, lTextFont );
188#else //KAB_EMBEDDED 188#else //KAB_EMBEDDED
189 bool ok; 189 bool ok;
190 QFont fout = KFontDialog::getFont( f, ok); 190 QFont fout = KFontDialog::getFont( f, ok);
191 if ( ok ) 191 if ( ok )
192 updateFontLabel( fout, lTextFont ); 192 updateFontLabel( fout, lTextFont );
193#endif //KAB_EMBEDDED 193#endif //KAB_EMBEDDED
194} 194}
195 195
196void LookAndFeelPage::setHeaderFont() 196void LookAndFeelPage::setHeaderFont()
197{ 197{
198 QFont f( lHeaderFont->font() ); 198 QFont f( lHeaderFont->font() );
199#ifndef KAB_EMBEDDED 199#ifndef KAB_EMBEDDED
200 if ( KFontDialog::getFont( f,false, this ) == QDialog::Accepted ) 200 if ( KFontDialog::getFont( f,false, this ) == QDialog::Accepted )
201 updateFontLabel( f, lHeaderFont ); 201 updateFontLabel( f, lHeaderFont );
202#else //KAB_EMBEDDED 202#else //KAB_EMBEDDED
203 bool ok; 203 bool ok;
204 QFont fout = KFontDialog::getFont( f, ok); 204 QFont fout = KFontDialog::getFont( f, ok);
205 if ( ok ) 205 if ( ok )
206 updateFontLabel( fout, lHeaderFont ); 206 updateFontLabel( fout, lHeaderFont );
207#endif //KAB_EMBEDDED 207#endif //KAB_EMBEDDED
208} 208}
209 209
210void LookAndFeelPage::enableFonts() 210void LookAndFeelPage::enableFonts()
211{ 211{
212 vbFonts->setEnabled( cbEnableCustomFonts->isChecked() ); 212 vbFonts->setEnabled( cbEnableCustomFonts->isChecked() );
213 if ( cbEnableCustomFonts->isChecked() )
214 vbFonts->setFocus();
213} 215}
214 216
215void LookAndFeelPage::enableColors() 217void LookAndFeelPage::enableColors()
216{ 218{
217 lbColors->setEnabled( cbEnableCustomColors->isChecked() ); 219 lbColors->setEnabled( cbEnableCustomColors->isChecked() );
220 if ( cbEnableCustomColors->isChecked() )
221 lbColors->setFocus();
218} 222}
219 223
220void LookAndFeelPage::initGUI() 224void LookAndFeelPage::initGUI()
221{ 225{
222 int spacing = KDialog::spacingHint(); 226 int spacing = KDialog::spacingHint();
223 int margin = KDialog::marginHint(); 227 int margin = KDialog::marginHint();
224 228
225 QTabWidget *tabs = new QTabWidget( this ); 229 QTabWidget *tabs = new QTabWidget( this );
226 230
227 // General 231 // General
228 QVBox *generalTab = new QVBox( this, "generaltab" ); 232 QVBox *generalTab = new QVBox( this, "generaltab" );
229 233
230 generalTab->setSpacing( spacing ); 234 generalTab->setSpacing( spacing );
231 generalTab->setMargin( margin ); 235 generalTab->setMargin( margin );
232 236
233 QButtonGroup *group = new QButtonGroup(1, Qt::Horizontal, 237 QButtonGroup *group = new QButtonGroup(1, Qt::Horizontal,
234 i18n("Row Separator"), generalTab); 238 i18n("Row Separator"), generalTab);
235 239
236 mAlternateButton = new QRadioButton(i18n("Alternating backgrounds"), 240 mAlternateButton = new QRadioButton(i18n("Alternating backgrounds"),
237 group, "mAlternateButton"); 241 group, "mAlternateButton");
238 mLineButton = new QRadioButton(i18n("Single line"), group, "mLineButton"); 242 mLineButton = new QRadioButton(i18n("Single line"), group, "mLineButton");
239 mNoneButton = new QRadioButton(i18n("None"), group, "mNoneButton"); 243 mNoneButton = new QRadioButton(i18n("None"), group, "mNoneButton");
240 244
241 mBackgroundBox = new QCheckBox(i18n("Enable background image:"), generalTab, 245 mBackgroundBox = new QCheckBox(i18n("Enable background image:"), generalTab,
242 "mBackgroundBox"); 246 "mBackgroundBox");
243 connect(mBackgroundBox, SIGNAL(toggled(bool)), 247 connect(mBackgroundBox, SIGNAL(toggled(bool)),
244 SLOT(enableBackgroundToggled(bool))); 248 SLOT(enableBackgroundToggled(bool)));
245 // LR image not implemented 249 // LR image not implemented
246 mBackgroundBox->setEnabled( false ); 250 mBackgroundBox->setEnabled( false );
247 mBackgroundName = new KURLRequester(generalTab, "mBackgroundName"); 251 mBackgroundName = new KURLRequester(generalTab, "mBackgroundName");
248#ifndef KAB_EMBEDDED 252#ifndef KAB_EMBEDDED
249 mBackgroundName->setMode(KFile::File | KFile::ExistingOnly | 253 mBackgroundName->setMode(KFile::File | KFile::ExistingOnly |
250 KFile::LocalOnly); 254 KFile::LocalOnly);
251 mBackgroundName->setFilter(KImageIO::pattern(KImageIO::Reading)); 255 mBackgroundName->setFilter(KImageIO::pattern(KImageIO::Reading));
252#endif //KAB_EMBEDDED 256#endif //KAB_EMBEDDED
253 257
254 // ToolTip Checkbox 258 // ToolTip Checkbox
255 mToolTipBox = new QCheckBox(i18n("Enable contact tooltips"), generalTab, 259 mToolTipBox = new QCheckBox(i18n("Enable contact tooltips"), generalTab,
256 "mToolTipBox"); 260 "mToolTipBox");
257 261
258 tabs->addTab( generalTab, i18n("&General") ); 262 tabs->addTab( generalTab, i18n("&General") );
259 263
260 // Colors 264 // Colors
261 QVBox *colorTab = new QVBox( this, "colortab" ); 265 QVBox *colorTab = new QVBox( this, "colortab" );
262 colorTab->setSpacing( spacing ); 266 colorTab->setSpacing( spacing );
263 colorTab->setMargin( spacing ); 267 colorTab->setMargin( spacing );
264 cbEnableCustomColors = new QCheckBox( i18n("&Enable custom Colors"), colorTab ); 268 cbEnableCustomColors = new QCheckBox( i18n("&Enable custom Colors"), colorTab );
265 connect( cbEnableCustomColors, SIGNAL(clicked()), this, SLOT(enableColors()) ); 269 connect( cbEnableCustomColors, SIGNAL(clicked()), this, SLOT(enableColors()) );
266 lbColors = new ColorListBox( colorTab ); 270 lbColors = new ColorListBox( colorTab );
267 tabs->addTab( colorTab, i18n("&Colors") ); 271 tabs->addTab( colorTab, i18n("&Colors") );
268 272
269 QWhatsThis::add( cbEnableCustomColors, i18n( 273 QWhatsThis::add( cbEnableCustomColors, i18n(
270 "If custom colors are enabled, you may choose the colors for the view below. " 274 "If custom colors are enabled, you may choose the colors for the view below. "
271 "Otherwise colors from your current KDE color scheme are used." 275 "Otherwise colors from your current KDE color scheme are used."
272 ) ); 276 ) );
273 QWhatsThis::add( lbColors, i18n( 277 QWhatsThis::add( lbColors, i18n(
274 "Double click or press RETURN on a item to select a color for the related strings in the view." 278 "Double click or press RETURN on a item to select a color for the related strings in the view."
275 ) ); 279 ) );
276 280
277 // Fonts 281 // Fonts
278 QVBox *fntTab = new QVBox( this, "fonttab" ); 282 QVBox *fntTab = new QVBox( this, "fonttab" );
279 283
280 fntTab->setSpacing( spacing ); 284 fntTab->setSpacing( spacing );
281 fntTab->setMargin( spacing ); 285 fntTab->setMargin( spacing );
282 286
283 cbEnableCustomFonts = new QCheckBox( i18n("&Enable custom fonts"), fntTab ); 287 cbEnableCustomFonts = new QCheckBox( i18n("&Enable custom fonts"), fntTab );
284 connect( cbEnableCustomFonts, SIGNAL(clicked()), this, SLOT(enableFonts()) ); 288 connect( cbEnableCustomFonts, SIGNAL(clicked()), this, SLOT(enableFonts()) );
285 289
286 vbFonts = new QWidget( fntTab ); 290 vbFonts = new QWidget( fntTab );
287 QGridLayout *gFnts = new QGridLayout( vbFonts, 2, 3 ); 291 QGridLayout *gFnts = new QGridLayout( vbFonts, 2, 3 );
288 gFnts->setSpacing( spacing ); 292 gFnts->setSpacing( spacing );
289 gFnts->setAutoAdd( true ); 293 gFnts->setAutoAdd( true );
290 gFnts->setColStretch( 1, 1 ); 294 gFnts->setColStretch( 1, 1 );
291 QLabel *lTFnt = new QLabel( i18n("&Text font:"), vbFonts ); 295 QLabel *lTFnt = new QLabel( i18n("&Text font:"), vbFonts );
292 lTextFont = new QLabel( vbFonts ); 296 lTextFont = new QLabel( vbFonts );
293 lTextFont->setFrameStyle( QFrame::Panel|QFrame::Sunken ); 297 lTextFont->setFrameStyle( QFrame::Panel|QFrame::Sunken );
294#ifndef KAB_EMBEDDED 298#ifndef KAB_EMBEDDED
295 btnFont = new KPushButton( i18n("Choose..."), vbFonts ); 299 btnFont = new KPushButton( i18n("Choose..."), vbFonts );
296#else //KAB_EMBEDDED 300#else //KAB_EMBEDDED
297 btnFont = new QPushButton( i18n("Choose..."), vbFonts ); 301 btnFont = new QPushButton( i18n("Choose..."), vbFonts );
298#endif //KAB_EMBEDDED 302#endif //KAB_EMBEDDED
299 303
300 lTFnt->setBuddy( btnFont ); 304 lTFnt->setBuddy( btnFont );
301 305
302 connect( btnFont, SIGNAL(clicked()), this, SLOT(setTextFont()) ); 306 connect( btnFont, SIGNAL(clicked()), this, SLOT(setTextFont()) );
303 307
304 QLabel *lHFnt = new QLabel( i18n("&Header font:"), vbFonts ); 308 QLabel *lHFnt = new QLabel( i18n("&Header font:"), vbFonts );
305 lHeaderFont = new QLabel( vbFonts ); 309 lHeaderFont = new QLabel( vbFonts );
306 lHeaderFont->setFrameStyle( QFrame::Panel|QFrame::Sunken ); 310 lHeaderFont->setFrameStyle( QFrame::Panel|QFrame::Sunken );
307#ifndef KAB_EMBEDDED 311#ifndef KAB_EMBEDDED
308 btnHeaderFont = new KPushButton( i18n("Choose..."), vbFonts ); 312 btnHeaderFont = new KPushButton( i18n("Choose..."), vbFonts );
309#else //KAB_EMBEDDED 313#else //KAB_EMBEDDED
310 btnHeaderFont = new QPushButton( i18n("Choose..."), vbFonts ); 314 btnHeaderFont = new QPushButton( i18n("Choose..."), vbFonts );
311#endif //KAB_EMBEDDED 315#endif //KAB_EMBEDDED
312 lHFnt->setBuddy( btnHeaderFont ); 316 lHFnt->setBuddy( btnHeaderFont );
313 connect( btnHeaderFont, SIGNAL(clicked()), this, SLOT(setHeaderFont()) ); 317 connect( btnHeaderFont, SIGNAL(clicked()), this, SLOT(setHeaderFont()) );
314 318
315 fntTab->setStretchFactor( new QWidget( fntTab ), 1 ); 319 fntTab->setStretchFactor( new QWidget( fntTab ), 1 );
316 320
317 QWhatsThis::add( cbEnableCustomFonts, i18n( 321 QWhatsThis::add( cbEnableCustomFonts, i18n(
318 "If custom fonts are enabled, you may choose which fonts to use for this view below. " 322 "If custom fonts are enabled, you may choose which fonts to use for this view below. "
319 "Otherwise the default KDE font will be used, in bold style for the header and " 323 "Otherwise the default KDE font will be used, in bold style for the header and "
320 "normal style for the data." 324 "normal style for the data."
321 ) ); 325 ) );
322 326
323 tabs->addTab( fntTab, i18n("&Fonts") ); 327 tabs->addTab( fntTab, i18n("&Fonts") );
324 328
325} 329}
326 330
327void LookAndFeelPage::enableBackgroundToggled(bool enabled) 331void LookAndFeelPage::enableBackgroundToggled(bool enabled)
328{ 332{
329 mBackgroundName->setEnabled(enabled); 333 mBackgroundName->setEnabled(enabled);
330} 334}
331 335
332 336
333void LookAndFeelPage::updateFontLabel( QFont fnt, QLabel *l ) 337void LookAndFeelPage::updateFontLabel( QFont fnt, QLabel *l )
334{ 338{
335 l->setFont( fnt ); 339 l->setFont( fnt );
336 l->setText( QString( fnt.family() + " %1" ).arg( fnt.pointSize() ) ); 340 l->setText( QString( fnt.family() + " %1" ).arg( fnt.pointSize() ) );
337} 341}
338 342
339#ifndef KAB_EMBEDDED 343#ifndef KAB_EMBEDDED
340#include "configuretableviewdialog.moc" 344#include "configuretableviewdialog.moc"
341#endif //KAB_EMBEDDED 345#endif //KAB_EMBEDDED
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp
index deadfc9..de964da 100644
--- a/korganizer/koagenda.cpp
+++ b/korganizer/koagenda.cpp
@@ -1,2234 +1,2273 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 Marcus Bains line. 5 Marcus Bains line.
6 Copyright (c) 2001 Ali Rahimi 6 Copyright (c) 2001 Ali Rahimi
7 7
8 This program is free software; you can redistribute it and/or modify 8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by 9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or 10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version. 11 (at your option) any later version.
12 12
13 This program is distributed in the hope that it will be useful, 13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of 14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details. 16 GNU General Public License for more details.
17 17
18 You should have received a copy of the GNU General Public License 18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software 19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
21 21
22 As a special exception, permission is given to link this program 22 As a special exception, permission is given to link this program
23 with any edition of Qt, and distribute the resulting executable, 23 with any edition of Qt, and distribute the resulting executable,
24 without including the source code for Qt in the source distribution. 24 without including the source code for Qt in the source distribution.
25*/ 25*/
26 26
27#ifndef _WIN32_ 27#ifndef _WIN32_
28#define protected public 28#define protected public
29#include <qwidget.h> 29#include <qwidget.h>
30#undef protected 30#undef protected
31#endif 31#endif
32#include <qintdict.h> 32#include <qintdict.h>
33#include <qdatetime.h> 33#include <qdatetime.h>
34#include <qapplication.h> 34#include <qapplication.h>
35#include <qpopupmenu.h> 35#include <qpopupmenu.h>
36#include <qcursor.h> 36#include <qcursor.h>
37#include <qpainter.h> 37#include <qpainter.h>
38 38
39#include <kdebug.h> 39#include <kdebug.h>
40#include <klocale.h> 40#include <klocale.h>
41#include <kiconloader.h> 41#include <kiconloader.h>
42#include <kglobal.h> 42#include <kglobal.h>
43 43
44#include "koagendaitem.h" 44#include "koagendaitem.h"
45#include "koprefs.h" 45#include "koprefs.h"
46#include "koglobals.h" 46#include "koglobals.h"
47 47
48#include "koagenda.h" 48#include "koagenda.h"
49 49
50#include <libkcal/event.h> 50#include <libkcal/event.h>
51#include <libkcal/todo.h> 51#include <libkcal/todo.h>
52 52
53#ifndef DESKTOP_VERSION 53#ifndef DESKTOP_VERSION
54#include <qpe/qpeapplication.h> 54#include <qpe/qpeapplication.h>
55#endif 55#endif
56 56
57//extern bool globalFlagBlockPainting; 57//extern bool globalFlagBlockPainting;
58extern int globalFlagBlockAgenda; 58extern int globalFlagBlockAgenda;
59extern int globalFlagBlockAgendaItemPaint; 59extern int globalFlagBlockAgendaItemPaint;
60extern int globalFlagBlockAgendaItemUpdate; 60extern int globalFlagBlockAgendaItemUpdate;
61extern int globalFlagBlockStartup; 61extern int globalFlagBlockStartup;
62 62
63//////////////////////////////////////////////////////////////////////////// 63////////////////////////////////////////////////////////////////////////////
64MarcusBains::MarcusBains(KOAgenda *_agenda,const char *name) 64MarcusBains::MarcusBains(KOAgenda *_agenda,const char *name)
65 : QFrame(_agenda->viewport(),name), agenda(_agenda) 65 : QFrame(_agenda->viewport(),name), agenda(_agenda)
66{ 66{
67 setLineWidth(0); 67 setLineWidth(0);
68 setMargin(0); 68 setMargin(0);
69 setBackgroundColor(Qt::red); 69 setBackgroundColor(Qt::red);
70 minutes = new QTimer(this); 70 minutes = new QTimer(this);
71 connect(minutes, SIGNAL(timeout()), this, SLOT(updateLoc())); 71 connect(minutes, SIGNAL(timeout()), this, SLOT(updateLoc()));
72 minutes->start(0, true); 72 minutes->start(0, true);
73 mTimeBox = new QLabel(this); 73 mTimeBox = new QLabel(this);
74 mTimeBox->setAlignment(Qt::AlignRight | Qt::AlignBottom); 74 mTimeBox->setAlignment(Qt::AlignRight | Qt::AlignBottom);
75 QPalette pal = mTimeBox->palette(); 75 QPalette pal = mTimeBox->palette();
76 pal.setColor(QColorGroup::Foreground, Qt::red); 76 pal.setColor(QColorGroup::Foreground, Qt::red);
77 mTimeBox->setPalette(pal); 77 mTimeBox->setPalette(pal);
78 //mTimeBox->setAutoMask(true); 78 //mTimeBox->setAutoMask(true);
79 79
80 agenda->addChild(mTimeBox); 80 agenda->addChild(mTimeBox);
81 81
82 oldToday = -1; 82 oldToday = -1;
83} 83}
84 84
85MarcusBains::~MarcusBains() 85MarcusBains::~MarcusBains()
86{ 86{
87 delete minutes; 87 delete minutes;
88} 88}
89 89
90int MarcusBains::todayColumn() 90int MarcusBains::todayColumn()
91{ 91{
92 QDate currentDate = QDate::currentDate(); 92 QDate currentDate = QDate::currentDate();
93 93
94 DateList dateList = agenda->dateList(); 94 DateList dateList = agenda->dateList();
95 DateList::ConstIterator it; 95 DateList::ConstIterator it;
96 int col = 0; 96 int col = 0;
97 for(it = dateList.begin(); it != dateList.end(); ++it) { 97 for(it = dateList.begin(); it != dateList.end(); ++it) {
98 if((*it) == currentDate) 98 if((*it) == currentDate)
99 return KOGlobals::self()->reverseLayout() ? 99 return KOGlobals::self()->reverseLayout() ?
100 agenda->columns() - 1 - col : col; 100 agenda->columns() - 1 - col : col;
101 ++col; 101 ++col;
102 } 102 }
103 103
104 return -1; 104 return -1;
105} 105}
106void MarcusBains::updateLoc() 106void MarcusBains::updateLoc()
107{ 107{
108 updateLocation(); 108 updateLocation();
109} 109}
110void MarcusBains::updateLocation(bool recalculate) 110void MarcusBains::updateLocation(bool recalculate)
111{ 111{
112 112
113 QTime tim = QTime::currentTime(); 113 QTime tim = QTime::currentTime();
114 //qDebug(" MarcusBains::updateLocation %s ", tim.toString().latin1()); 114 //qDebug(" MarcusBains::updateLocation %s ", tim.toString().latin1());
115 if((tim.hour() == 0) && (oldTime.hour()==23)) 115 if((tim.hour() == 0) && (oldTime.hour()==23))
116 recalculate = true; 116 recalculate = true;
117 117
118 int mins = tim.hour()*60 + tim.minute(); 118 int mins = tim.hour()*60 + tim.minute();
119 int minutesPerCell = 24 * 60 / agenda->rows(); 119 int minutesPerCell = 24 * 60 / agenda->rows();
120 int y = mins*agenda->gridSpacingY()/minutesPerCell; 120 int y = mins*agenda->gridSpacingY()/minutesPerCell;
121 int today = recalculate ? todayColumn() : oldToday; 121 int today = recalculate ? todayColumn() : oldToday;
122 int x = agenda->gridSpacingX()*today; 122 int x = agenda->gridSpacingX()*today;
123 bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled); 123 bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled);
124 124
125 oldTime = tim; 125 oldTime = tim;
126 oldToday = today; 126 oldToday = today;
127 127
128 if(disabled || (today<0)) { 128 if(disabled || (today<0)) {
129 hide(); mTimeBox->hide(); 129 hide(); mTimeBox->hide();
130 return; 130 return;
131 } else { 131 } else {
132 show(); mTimeBox->show(); 132 show(); mTimeBox->show();
133 } 133 }
134 134
135 if(recalculate) 135 if(recalculate)
136 setFixedSize(agenda->gridSpacingX(),1); 136 setFixedSize(agenda->gridSpacingX(),1);
137 agenda->moveChild(this, x, y); 137 agenda->moveChild(this, x, y);
138 raise(); 138 raise();
139 139
140 if(recalculate) 140 if(recalculate)
141 //mTimeBox->setFont(QFont("helvetica",10)); 141 //mTimeBox->setFont(QFont("helvetica",10));
142 mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont); 142 mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont);
143 143
144 mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds)); 144 mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds));
145 mTimeBox->adjustSize(); 145 mTimeBox->adjustSize();
146 // the -2 below is there because there is a bug in this program 146 // the -2 below is there because there is a bug in this program
147 // somewhere, where the last column of this widget is a few pixels 147 // somewhere, where the last column of this widget is a few pixels
148 // narrower than the other columns. 148 // narrower than the other columns.
149 int offs = (today==agenda->columns()-1) ? -4 : 0; 149 int offs = (today==agenda->columns()-1) ? -4 : 0;
150 agenda->moveChild(mTimeBox, 150 agenda->moveChild(mTimeBox,
151 x+agenda->gridSpacingX()-mTimeBox->width()+offs-1, 151 x+agenda->gridSpacingX()-mTimeBox->width()+offs-1,
152 y-mTimeBox->height()); 152 y-mTimeBox->height());
153 153
154 mTimeBox->raise(); 154 mTimeBox->raise();
155 //mTimeBox->setAutoMask(true); 155 //mTimeBox->setAutoMask(true);
156 minutes->start(5000,true); 156 minutes->start(5000,true);
157} 157}
158 158
159 159
160//////////////////////////////////////////////////////////////////////////// 160////////////////////////////////////////////////////////////////////////////
161 161
162 162
163/* 163/*
164 Create an agenda widget with rows rows and columns columns. 164 Create an agenda widget with rows rows and columns columns.
165*/ 165*/
166KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, 166KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent,
167 const char *name,WFlags f) : 167 const char *name,WFlags f) :
168 QScrollView(parent,name,f) 168 QScrollView(parent,name,f)
169{ 169{
170 170
171 171 mAllAgendaPopup = 0;
172 mColumns = columns; 172 mColumns = columns;
173 mRows = rows; 173 mRows = rows;
174 mGridSpacingY = rowSize; 174 mGridSpacingY = rowSize;
175 mAllDayMode = false; 175 mAllDayMode = false;
176#ifndef DESKTOP_VERSION 176#ifndef DESKTOP_VERSION
177 //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); 177 //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold );
178#endif 178#endif
179 mHolidayMask = 0; 179 mHolidayMask = 0;
180 init(); 180 init();
181} 181}
182 182
183/* 183/*
184 Create an agenda widget with columns columns and one row. This is used for 184 Create an agenda widget with columns columns and one row. This is used for
185 all-day events. 185 all-day events.
186*/ 186*/
187KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : 187KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) :
188 QScrollView(parent,name,f) 188 QScrollView(parent,name,f)
189{ 189{
190 mAllAgendaPopup = 0;
190 blockResize = false; 191 blockResize = false;
191 mColumns = columns; 192 mColumns = columns;
192 mRows = 1; 193 mRows = 1;
193 //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize); 194 //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize);
194 mGridSpacingY = KOPrefs::instance()->mAllDaySize; 195 mGridSpacingY = KOPrefs::instance()->mAllDaySize;
195 mAllDayMode = true; 196 mAllDayMode = true;
196#ifndef DESKTOP_VERSION 197#ifndef DESKTOP_VERSION
197 //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); 198 //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold );
198#endif 199#endif
199 mHolidayMask = 0; 200 mHolidayMask = 0;
200 init(); 201 init();
201} 202}
202 203
203 204
204KOAgenda::~KOAgenda() 205KOAgenda::~KOAgenda()
205{ 206{
206 if(mMarcusBains) delete mMarcusBains; 207 if(mMarcusBains) delete mMarcusBains;
207 208
208} 209}
209 210
210Incidence *KOAgenda::selectedIncidence() const 211Incidence *KOAgenda::selectedIncidence() const
211{ 212{
212 return (mSelectedItem ? mSelectedItem->incidence() : 0); 213 return (mSelectedItem ? mSelectedItem->incidence() : 0);
213} 214}
214 215
215 216
216QDate KOAgenda::selectedIncidenceDate() const 217QDate KOAgenda::selectedIncidenceDate() const
217{ 218{
218 return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); 219 return (mSelectedItem ? mSelectedItem->itemDate() : QDate());
219} 220}
220 221
221 222
222void KOAgenda::init() 223void KOAgenda::init()
223{ 224{
224 mPopupTimer = new QTimer(this); 225 mPopupTimer = new QTimer(this);
225 connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); 226 connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu()));
226 227
227 mNewItemPopup = new QPopupMenu( this ); 228 mNewItemPopup = new QPopupMenu( this );
228 connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); 229 connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) );
229 QString pathString = ""; 230 QString pathString = "";
230 if ( !KOPrefs::instance()->mToolBarMiniIcons ) { 231 if ( !KOPrefs::instance()->mToolBarMiniIcons ) {
231 if ( QApplication::desktop()->width() < 480 ) 232 if ( QApplication::desktop()->width() < 480 )
232 pathString += "icons16/"; 233 pathString += "icons16/";
233 } else 234 } else
234 pathString += "iconsmini/"; 235 pathString += "iconsmini/";
235 236
236 mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); 237 mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 );
237 mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); 238 mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 );
238 mNewItemPopup->insertSeparator ( ); 239 mNewItemPopup->insertSeparator ( );
239 mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); 240 mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 );
240 mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); 241 mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 );
241 mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); 242 mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 );
242 mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); 243 mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 );
243 mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("This month"),6 ); 244 mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("This month"),6 );
244 mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); 245 mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 );
245#ifndef _WIN32_ 246#ifndef _WIN32_
246 int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase 247 int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase
247 viewport()->setWFlags ( wflags); 248 viewport()->setWFlags ( wflags);
248#endif 249#endif
249 mGridSpacingX = 80; 250 mGridSpacingX = 80;
250 mResizeBorderWidth = 8; 251 mResizeBorderWidth = 8;
251 mScrollBorderWidth = 8; 252 mScrollBorderWidth = 8;
252 mScrollDelay = 30; 253 mScrollDelay = 30;
253 mScrollOffset = 10; 254 mScrollOffset = 10;
254 mPaintPixmap.resize( 20,20); 255 mPaintPixmap.resize( 20,20);
255 //enableClipper(true); 256 //enableClipper(true);
256 257
257 // Grab key strokes for keyboard navigation of agenda. Seems to have no 258 // Grab key strokes for keyboard navigation of agenda. Seems to have no
258 // effect. Has to be fixed. 259 // effect. Has to be fixed.
259 setFocusPolicy(WheelFocus); 260 setFocusPolicy(WheelFocus);
260 261
261 connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); 262 connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp()));
262 connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); 263 connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown()));
263 connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); 264 connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize()));
264 265
265 mStartCellX = 0; 266 mStartCellX = 0;
266 mStartCellY = 0; 267 mStartCellY = 0;
267 mCurrentCellX = 0; 268 mCurrentCellX = 0;
268 mCurrentCellY = 0; 269 mCurrentCellY = 0;
269 270
270 mSelectionCellX = 0; 271 mSelectionCellX = 0;
271 mSelectionYTop = 0; 272 mSelectionYTop = 0;
272 mSelectionHeight = 0; 273 mSelectionHeight = 0;
273 274
274 mOldLowerScrollValue = -1; 275 mOldLowerScrollValue = -1;
275 mOldUpperScrollValue = -1; 276 mOldUpperScrollValue = -1;
276 277
277 mClickedItem = 0; 278 mClickedItem = 0;
278 279
279 mActionItem = 0; 280 mActionItem = 0;
280 mActionType = NOP; 281 mActionType = NOP;
281 mItemMoved = false; 282 mItemMoved = false;
282 283
283 mSelectedItem = 0; 284 mSelectedItem = 0;
284 285
285 // mItems.setAutoDelete(true); 286 // mItems.setAutoDelete(true);
286 287
287 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); 288 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 );
288 289
289 viewport()->update(); 290 viewport()->update();
290 291
291 setMinimumSize(30, 1); 292 setMinimumSize(30, 1);
292// setMaximumHeight(mGridSpacingY * mRows + 5); 293// setMaximumHeight(mGridSpacingY * mRows + 5);
293 294
294 // Disable horizontal scrollbar. This is a hack. The geometry should be 295 // Disable horizontal scrollbar. This is a hack. The geometry should be
295 // controlled in a way that the contents horizontally always fits. Then it is 296 // controlled in a way that the contents horizontally always fits. Then it is
296 // not necessary to turn off the scrollbar. 297 // not necessary to turn off the scrollbar.
297 setHScrollBarMode(AlwaysOff); 298 setHScrollBarMode(AlwaysOff);
298 if ( ! mAllDayMode ) 299 if ( ! mAllDayMode )
299 setVScrollBarMode(AlwaysOn); 300 setVScrollBarMode(AlwaysOn);
300 else 301 else
301 setVScrollBarMode(AlwaysOff); 302 setVScrollBarMode(AlwaysOff);
302 303
303 setStartHour(KOPrefs::instance()->mDayBegins); 304 setStartHour(KOPrefs::instance()->mDayBegins);
304 305
305 calculateWorkingHours(); 306 calculateWorkingHours();
306 307
307 connect(verticalScrollBar(),SIGNAL(valueChanged(int)), 308 connect(verticalScrollBar(),SIGNAL(valueChanged(int)),
308 SLOT(checkScrollBoundaries(int))); 309 SLOT(checkScrollBoundaries(int)));
309 310
310 // Create the Marcus Bains line. 311 // Create the Marcus Bains line.
311 if(mAllDayMode) 312 if(mAllDayMode)
312 mMarcusBains = 0; 313 mMarcusBains = 0;
313 else { 314 else {
314 mMarcusBains = new MarcusBains(this); 315 mMarcusBains = new MarcusBains(this);
315 addChild(mMarcusBains); 316 addChild(mMarcusBains);
316 } 317 }
317 mPopupKind = 0; 318 mPopupKind = 0;
318 mPopupItem = 0; 319 mPopupItem = 0;
319} 320}
320 321
321void KOAgenda::clear() 322void KOAgenda::clear()
322{ 323{
323 KOAgendaItem *item; 324 KOAgendaItem *item;
324 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 325 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
325 mUnusedItems.append( item ); 326 mUnusedItems.append( item );
326 //item->hide(); 327 //item->hide();
327 } 328 }
328 mItems.clear(); 329 mItems.clear();
329 mSelectedItem = 0; 330 mSelectedItem = 0;
330 clearSelection(); 331 clearSelection();
331} 332}
332 333
333void KOAgenda::clearSelection() 334void KOAgenda::clearSelection()
334{ 335{
335 mSelectionCellX = 0; 336 mSelectionCellX = 0;
336 mSelectionYTop = 0; 337 mSelectionYTop = 0;
337 mSelectionHeight = 0; 338 mSelectionHeight = 0;
338} 339}
339 340
340void KOAgenda::marcus_bains() 341void KOAgenda::marcus_bains()
341{ 342{
342 if(mMarcusBains) mMarcusBains->updateLocation(true); 343 if(mMarcusBains) mMarcusBains->updateLocation(true);
343} 344}
344 345
345 346
346void KOAgenda::changeColumns(int columns) 347void KOAgenda::changeColumns(int columns)
347{ 348{
348 if (columns == 0) { 349 if (columns == 0) {
349 qDebug("KOAgenda::changeColumns() called with argument 0 "); 350 qDebug("KOAgenda::changeColumns() called with argument 0 ");
350 return; 351 return;
351 } 352 }
352 clear(); 353 clear();
353 mColumns = columns; 354 mColumns = columns;
354 computeSizes(); 355 computeSizes();
355} 356}
356 357
357/* 358/*
358 This is the eventFilter function, which gets all events from the KOAgendaItems 359 This is the eventFilter function, which gets all events from the KOAgendaItems
359 contained in the agenda. It has to handle moving and resizing for all items. 360 contained in the agenda. It has to handle moving and resizing for all items.
360*/ 361*/
361bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) 362bool KOAgenda::eventFilter ( QObject *object, QEvent *event )
362{ 363{
363 // kdDebug() << "KOAgenda::eventFilter" << endl; 364 // kdDebug() << "KOAgenda::eventFilter" << endl;
364 switch(event->type()) { 365 switch(event->type()) {
365 case QEvent::MouseButtonPress: 366 case QEvent::MouseButtonPress:
366 case QEvent::MouseButtonDblClick: 367 case QEvent::MouseButtonDblClick:
367 case QEvent::MouseButtonRelease: 368 case QEvent::MouseButtonRelease:
368 case QEvent::MouseMove: 369 case QEvent::MouseMove:
369 return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); 370 return eventFilter_mouse(object, static_cast<QMouseEvent *>(event));
370 371
371 case (QEvent::Leave): 372 case (QEvent::Leave):
372 if (!mActionItem) 373 if (!mActionItem)
373 setCursor(arrowCursor); 374 setCursor(arrowCursor);
374 return true; 375 return true;
375 376
376 default: 377 default:
377 return QScrollView::eventFilter(object,event); 378 return QScrollView::eventFilter(object,event);
378 } 379 }
379} 380}
380void KOAgenda::popupMenu() 381void KOAgenda::popupMenu()
381{ 382{
382 mPopupTimer->stop(); 383 mPopupTimer->stop();
383 if ( mPopupKind == 1 ) { 384 if ( mPopupKind == 1 ) {
384 if (mActionItem ) { 385 if (mActionItem ) {
385 endItemAction(); 386 endItemAction();
386 } 387 }
387 mLeftMouseDown = false; // no more leftMouse computation 388 mLeftMouseDown = false; // no more leftMouse computation
388 if (mPopupItem) { 389 if (mPopupItem) {
389 selectItem(mPopupItem); 390 selectItem(mPopupItem);
391 if ( mAllAgendaPopup )
392 mAllAgendaPopup->installEventFilter( this );
390 emit showIncidencePopupSignal(mPopupItem->incidence()); 393 emit showIncidencePopupSignal(mPopupItem->incidence());
391 394
392 } 395 }
393 } else if ( mPopupKind == 2 ) { 396 } else if ( mPopupKind == 2 ) {
394 if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action 397 if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action
395 endSelectAction( false ); // do not emit new event signal 398 endSelectAction( false ); // do not emit new event signal
396 mLeftMouseDown = false; // no more leftMouse computation 399 mLeftMouseDown = false; // no more leftMouse computation
397 } 400 }
401 mNewItemPopup->installEventFilter( this );
398 mNewItemPopup->popup( mPopupPos); 402 mNewItemPopup->popup( mPopupPos);
403
399 } 404 }
400 mLeftMouseDown = false; 405 mLeftMouseDown = false;
401 mPopupItem = 0; 406 mPopupItem = 0;
402 mPopupKind = 0; 407 mPopupKind = 0;
403} 408}
404 409
405bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) 410bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
406{ 411{
407 //qDebug("KOAgenda::eventFilter_mous "); 412 static int startX = 0;
413 static int startY = 0;
414 static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 );
415 static bool blockMoving = true;
416
417 //qDebug("KOAgenda::eventFilter_mous ");
418 if ( object == mNewItemPopup ) {
419 //qDebug("mNewItemPopup ");
420 if ( me->type() == QEvent::MouseButtonRelease ) {
421 mNewItemPopup->removeEventFilter( this );
422 int dX = me->globalPos().x() - mPopupPos.x();;
423 if ( dX < 0 )
424 dX = -dX;
425 int dY = me->globalPos().y() - mPopupPos.y();
426 if ( dY < 0 )
427 dY = -dY;
428 if ( dX > blockmoveDist || dY > blockmoveDist ) {
429 mNewItemPopup->hide();
430 }
431 }
432 return true;
433 }
434 if ( object == mAllAgendaPopup ) {
435 //qDebug(" mAllAgendaPopup ");
436 if ( me->type() == QEvent::MouseButtonRelease ) {
437 mAllAgendaPopup->removeEventFilter( this );
438 int dX = me->globalPos().x() - mPopupPos.x();;
439 if ( dX < 0 )
440 dX = -dX;
441 int dY = me->globalPos().y() - mPopupPos.y();
442 if ( dY < 0 )
443 dY = -dY;
444 if ( dX > blockmoveDist || dY > blockmoveDist ) {
445 mAllAgendaPopup->hide();
446 }
447 }
448 return true;
449 }
408 QPoint viewportPos; 450 QPoint viewportPos;
409 if (object != viewport()) { 451 if (object != viewport()) {
410 viewportPos = ((QWidget *)object)->mapToParent(me->pos()); 452 viewportPos = ((QWidget *)object)->mapToParent(me->pos());
411 } else { 453 } else {
412 viewportPos = me->pos(); 454 viewportPos = me->pos();
413 } 455 }
414 static int startX = 0; 456
415 static int startY = 0;
416 static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 );
417 static bool blockMoving = true;
418 switch (me->type()) { 457 switch (me->type()) {
419 case QEvent::MouseButtonPress: 458 case QEvent::MouseButtonPress:
420 if (me->button() == LeftButton) { 459 if (me->button() == LeftButton) {
421 mPopupTimer->start( 600 ); 460 mPopupTimer->start( 600 );
422 mLeftMouseDown = true; 461 mLeftMouseDown = true;
423 } 462 }
424 blockMoving = true; 463 blockMoving = true;
425 startX = viewportPos.x(); 464 startX = viewportPos.x();
426 startY = viewportPos.y(); 465 startY = viewportPos.y();
466 mPopupPos = me->globalPos();
427 if (object != viewport()) { 467 if (object != viewport()) {
428 mPopupItem = (KOAgendaItem *)object; 468 mPopupItem = (KOAgendaItem *)object;
429 mPopupKind = 1; 469 mPopupKind = 1;
430 if (me->button() == RightButton) { 470 if (me->button() == RightButton) {
431 popupMenu(); 471 popupMenu();
432 } else if (me->button() == LeftButton) { 472 } else if (me->button() == LeftButton) {
433 mActionItem = (KOAgendaItem *)object; 473 mActionItem = (KOAgendaItem *)object;
434 if (mActionItem) { 474 if (mActionItem) {
435 if ( mSelectionHeight > 0 ) { 475 if ( mSelectionHeight > 0 ) {
436 int selectionCellX = mSelectionCellX * mGridSpacingX; 476 int selectionCellX = mSelectionCellX * mGridSpacingX;
437 int selectionYTop = mSelectionYTop; 477 int selectionYTop = mSelectionYTop;
438 int gridSpacingX = mGridSpacingX; 478 int gridSpacingX = mGridSpacingX;
439 int selectionHeight = mSelectionHeight; 479 int selectionHeight = mSelectionHeight;
440 clearSelection(); 480 clearSelection();
441 repaintContents( selectionCellX, selectionYTop, 481 repaintContents( selectionCellX, selectionYTop,
442 gridSpacingX, selectionHeight,false ); 482 gridSpacingX, selectionHeight,false );
443 } 483 }
444 selectItem(mActionItem); 484 selectItem(mActionItem);
445 Incidence *incidence = mActionItem->incidence(); 485 Incidence *incidence = mActionItem->incidence();
446 if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { 486 if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) {
447 mActionItem = 0; 487 mActionItem = 0;
448 } else { 488 } else {
449 startItemAction(viewportPos); 489 startItemAction(viewportPos);
450 } 490 }
451 } 491 }
452 } 492 }
453 } else { // ---------- viewport() 493 } else { // ---------- viewport()
454 mPopupItem = 0; 494 mPopupItem = 0;
455 mPopupKind = 2; 495 mPopupKind = 2;
456 selectItem(0); 496 selectItem(0);
457 mActionItem = 0; 497 mActionItem = 0;
458 mPopupPos = viewport()->mapToGlobal( me->pos() );
459 if (me->button() == RightButton) { 498 if (me->button() == RightButton) {
460 int x,y; 499 int x,y;
461 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 500 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
462 int gx,gy; 501 int gx,gy;
463 contentsToGrid(x,y,gx,gy); 502 contentsToGrid(x,y,gx,gy);
464 mCurrentCellX = gx; 503 mCurrentCellX = gx;
465 mCurrentCellY = gy; 504 mCurrentCellY = gy;
466 mStartCellX = gx; 505 mStartCellX = gx;
467 mStartCellY = gy; 506 mStartCellY = gy;
468 popupMenu(); 507 popupMenu();
469 } else if (me->button() == LeftButton) { 508 } else if (me->button() == LeftButton) {
470 setCursor(arrowCursor); 509 setCursor(arrowCursor);
471 startSelectAction(viewportPos); 510 startSelectAction(viewportPos);
472 } 511 }
473 } 512 }
474 break; 513 break;
475 514
476 case QEvent::MouseButtonRelease: 515 case QEvent::MouseButtonRelease:
477 if (me->button() == LeftButton ) { 516 if (me->button() == LeftButton ) {
478 mPopupTimer->stop(); 517 mPopupTimer->stop();
479 } 518 }
480 if (object != viewport()) { 519 if (object != viewport()) {
481 if (me->button() == LeftButton && mLeftMouseDown) { 520 if (me->button() == LeftButton && mLeftMouseDown) {
482 if (mActionItem) { 521 if (mActionItem) {
483 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); 522 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos));
484 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); 523 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 );
485 if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { 524 if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) {
486 mScrollUpTimer.stop(); 525 mScrollUpTimer.stop();
487 mScrollDownTimer.stop(); 526 mScrollDownTimer.stop();
488 mActionItem->resetMove(); 527 mActionItem->resetMove();
489 placeSubCells( mActionItem ); 528 placeSubCells( mActionItem );
490 // emit startDragSignal( mActionItem->incidence() ); 529 // emit startDragSignal( mActionItem->incidence() );
491 setCursor( arrowCursor ); 530 setCursor( arrowCursor );
492 mActionItem = 0; 531 mActionItem = 0;
493 mActionType = NOP; 532 mActionType = NOP;
494 mItemMoved = 0; 533 mItemMoved = 0;
495 mLeftMouseDown = false; 534 mLeftMouseDown = false;
496 return true; 535 return true;
497 } 536 }
498 endItemAction(); 537 endItemAction();
499 } 538 }
500 } 539 }
501 540
502 } else { // ---------- viewport() 541 } else { // ---------- viewport()
503 if (me->button() == LeftButton && mLeftMouseDown ) { //left click 542 if (me->button() == LeftButton && mLeftMouseDown ) { //left click
504 endSelectAction( true ); // emit new event signal 543 endSelectAction( true ); // emit new event signal
505 } 544 }
506 } 545 }
507 if (me->button() == LeftButton) 546 if (me->button() == LeftButton)
508 mLeftMouseDown = false; 547 mLeftMouseDown = false;
509 548
510 break; 549 break;
511 550
512 case QEvent::MouseMove: 551 case QEvent::MouseMove:
513 //qDebug("mm "); 552 //qDebug("mm ");
514 if ( !mLeftMouseDown ) 553 if ( !mLeftMouseDown )
515 return false; 554 return false;
516 if ( blockMoving ) { 555 if ( blockMoving ) {
517 int dX, dY; 556 int dX, dY;
518 dX = startX - viewportPos.x(); 557 dX = startX - viewportPos.x();
519 if ( dX < 0 ) 558 if ( dX < 0 )
520 dX = -dX; 559 dX = -dX;
521 dY = viewportPos.y() - startY; 560 dY = viewportPos.y() - startY;
522 if ( dY < 0 ) 561 if ( dY < 0 )
523 dY = -dY; 562 dY = -dY;
524 //qDebug("%d %d %d ", dX, dY , blockmoveDist ); 563 //qDebug("%d %d %d ", dX, dY , blockmoveDist );
525 if ( dX > blockmoveDist || dY > blockmoveDist ) { 564 if ( dX > blockmoveDist || dY > blockmoveDist ) {
526 blockMoving = false; 565 blockMoving = false;
527 } 566 }
528 } 567 }
529 if ( ! blockMoving ) 568 if ( ! blockMoving )
530 mPopupTimer->stop(); 569 mPopupTimer->stop();
531 if (object != viewport()) { 570 if (object != viewport()) {
532 KOAgendaItem *moveItem = (KOAgendaItem *)object; 571 KOAgendaItem *moveItem = (KOAgendaItem *)object;
533 if (!moveItem->incidence()->isReadOnly() ) { 572 if (!moveItem->incidence()->isReadOnly() ) {
534 if (!mActionItem) 573 if (!mActionItem)
535 setNoActionCursor(moveItem,viewportPos); 574 setNoActionCursor(moveItem,viewportPos);
536 else { 575 else {
537 if ( !blockMoving ) 576 if ( !blockMoving )
538 performItemAction(viewportPos); 577 performItemAction(viewportPos);
539 } 578 }
540 } 579 }
541 } else { // ---------- viewport() 580 } else { // ---------- viewport()
542 mPopupPos = viewport()->mapToGlobal( me->pos() ); 581 mPopupPos = viewport()->mapToGlobal( me->pos() );
543 if ( mActionType == SELECT ) { 582 if ( mActionType == SELECT ) {
544 performSelectAction( viewportPos ); 583 performSelectAction( viewportPos );
545 } 584 }
546 } 585 }
547 break; 586 break;
548 587
549 case QEvent::MouseButtonDblClick: 588 case QEvent::MouseButtonDblClick:
550 mPopupTimer->stop(); 589 mPopupTimer->stop();
551 if (object == viewport()) { 590 if (object == viewport()) {
552 selectItem(0); 591 selectItem(0);
553 int x,y; 592 int x,y;
554 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 593 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
555 int gx,gy; 594 int gx,gy;
556 contentsToGrid(x,y,gx,gy); 595 contentsToGrid(x,y,gx,gy);
557 emit newEventSignal(gx,gy); 596 emit newEventSignal(gx,gy);
558 } else { 597 } else {
559 KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; 598 KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object;
560 selectItem(doubleClickedItem); 599 selectItem(doubleClickedItem);
561 if ( KOPrefs::instance()->mEditOnDoubleClick ) 600 if ( KOPrefs::instance()->mEditOnDoubleClick )
562 emit editIncidenceSignal(doubleClickedItem->incidence()); 601 emit editIncidenceSignal(doubleClickedItem->incidence());
563 else 602 else
564 emit showIncidenceSignal(doubleClickedItem->incidence()); 603 emit showIncidenceSignal(doubleClickedItem->incidence());
565 } 604 }
566 break; 605 break;
567 606
568 default: 607 default:
569 break; 608 break;
570 } 609 }
571 return true; 610 return true;
572#if 0 611#if 0
573 //qDebug("KOAgenda::eventFilter_mous "); 612 //qDebug("KOAgenda::eventFilter_mous ");
574 QPoint viewportPos; 613 QPoint viewportPos;
575 if (object != viewport()) { 614 if (object != viewport()) {
576 viewportPos = ((QWidget *)object)->mapToParent(me->pos()); 615 viewportPos = ((QWidget *)object)->mapToParent(me->pos());
577 } else { 616 } else {
578 viewportPos = me->pos(); 617 viewportPos = me->pos();
579 } 618 }
580 static int startX = 0; 619 static int startX = 0;
581 static int startY = 0; 620 static int startY = 0;
582 static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); 621 static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 );
583 static bool blockMoving = true; 622 static bool blockMoving = true;
584 static bool leftMouseDown = false; 623 static bool leftMouseDown = false;
585 bool rightButtonPressed = false; 624 bool rightButtonPressed = false;
586 switch (me->type()) { 625 switch (me->type()) {
587 case QEvent::MouseButtonPress: 626 case QEvent::MouseButtonPress:
588 if (me->button() == LeftButton) { 627 if (me->button() == LeftButton) {
589 leftMouseDown = true; 628 leftMouseDown = true;
590 } 629 }
591 else if (me->button() == RightButton) { 630 else if (me->button() == RightButton) {
592 leftMouseDown = false; 631 leftMouseDown = false;
593 } 632 }
594 blockMoving = true; 633 blockMoving = true;
595 startX = viewportPos.x(); 634 startX = viewportPos.x();
596 startY = viewportPos.y(); 635 startY = viewportPos.y();
597 if (object != viewport()) { // item clicked ************** 636 if (object != viewport()) { // item clicked **************
598 if (me->button() == RightButton) { 637 if (me->button() == RightButton) {
599 leftMouseDown = false; 638 leftMouseDown = false;
600 mClickedItem = (KOAgendaItem *)object; 639 mClickedItem = (KOAgendaItem *)object;
601 if (mActionItem ) { 640 if (mActionItem ) {
602 endItemAction(); 641 endItemAction();
603 } 642 }
604 if (mClickedItem) { 643 if (mClickedItem) {
605 selectItem(mClickedItem); 644 selectItem(mClickedItem);
606 emit showIncidencePopupSignal(mClickedItem->incidence()); 645 emit showIncidencePopupSignal(mClickedItem->incidence());
607 } 646 }
608 return true; 647 return true;
609 } else if (me->button() == LeftButton) { 648 } else if (me->button() == LeftButton) {
610 mActionItem = (KOAgendaItem *)object; 649 mActionItem = (KOAgendaItem *)object;
611 if (mActionItem) { 650 if (mActionItem) {
612 if ( mSelectionHeight > 0 ) { 651 if ( mSelectionHeight > 0 ) {
613 int selectionCellX = mSelectionCellX * mGridSpacingX; 652 int selectionCellX = mSelectionCellX * mGridSpacingX;
614 int selectionYTop = mSelectionYTop; 653 int selectionYTop = mSelectionYTop;
615 int gridSpacingX = mGridSpacingX; 654 int gridSpacingX = mGridSpacingX;
616 int selectionHeight = mSelectionHeight; 655 int selectionHeight = mSelectionHeight;
617 clearSelection(); 656 clearSelection();
618 repaintContents( selectionCellX, selectionYTop, 657 repaintContents( selectionCellX, selectionYTop,
619 gridSpacingX, selectionHeight,false ); 658 gridSpacingX, selectionHeight,false );
620 } 659 }
621 selectItem(mActionItem); 660 selectItem(mActionItem);
622 Incidence *incidence = mActionItem->incidence(); 661 Incidence *incidence = mActionItem->incidence();
623 if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { 662 if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) {
624 mActionItem = 0; 663 mActionItem = 0;
625 } else { 664 } else {
626 startItemAction(viewportPos); 665 startItemAction(viewportPos);
627 } 666 }
628 } 667 }
629 } 668 }
630 } else { // ---------- viewport() 669 } else { // ---------- viewport()
631 selectItem(0); 670 selectItem(0);
632 mActionItem = 0; 671 mActionItem = 0;
633 if (me->button() == LeftButton ) { 672 if (me->button() == LeftButton ) {
634 setCursor(arrowCursor); 673 setCursor(arrowCursor);
635 startSelectAction(viewportPos); 674 startSelectAction(viewportPos);
636 } else if (me->button() == RightButton ) { 675 } else if (me->button() == RightButton ) {
637 setCursor(arrowCursor); 676 setCursor(arrowCursor);
638 if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action 677 if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action
639 endSelectAction( false ); // do not emit new event signal 678 endSelectAction( false ); // do not emit new event signal
640 leftMouseDown = false; // no more leftMouse computation 679 leftMouseDown = false; // no more leftMouse computation
641 } 680 }
642 int x,y; 681 int x,y;
643 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 682 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
644 int gx,gy; 683 int gx,gy;
645 contentsToGrid(x,y,gx,gy); 684 contentsToGrid(x,y,gx,gy);
646 mCurrentCellX = gx; 685 mCurrentCellX = gx;
647 mCurrentCellY = gy; 686 mCurrentCellY = gy;
648 mStartCellX = gx; 687 mStartCellX = gx;
649 mStartCellY = gy; 688 mStartCellY = gy;
650 mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) ); 689 mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) );
651 } 690 }
652 } 691 }
653 break; 692 break;
654 693
655 case QEvent::MouseButtonRelease: 694 case QEvent::MouseButtonRelease:
656 695
657 if (object != viewport()) { 696 if (object != viewport()) {
658 if (me->button() == LeftButton && leftMouseDown) { 697 if (me->button() == LeftButton && leftMouseDown) {
659 if (mActionItem) { 698 if (mActionItem) {
660 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); 699 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos));
661 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); 700 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 );
662 if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { 701 if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) {
663 mScrollUpTimer.stop(); 702 mScrollUpTimer.stop();
664 mScrollDownTimer.stop(); 703 mScrollDownTimer.stop();
665 mActionItem->resetMove(); 704 mActionItem->resetMove();
666 placeSubCells( mActionItem ); 705 placeSubCells( mActionItem );
667 // emit startDragSignal( mActionItem->incidence() ); 706 // emit startDragSignal( mActionItem->incidence() );
668 setCursor( arrowCursor ); 707 setCursor( arrowCursor );
669 mActionItem = 0; 708 mActionItem = 0;
670 mActionType = NOP; 709 mActionType = NOP;
671 mItemMoved = 0; 710 mItemMoved = 0;
672 leftMouseDown = false; 711 leftMouseDown = false;
673 return true; 712 return true;
674 } 713 }
675 endItemAction(); 714 endItemAction();
676 } 715 }
677 } 716 }
678 717
679 } else { // ---------- viewport() 718 } else { // ---------- viewport()
680 if (me->button() == LeftButton && leftMouseDown ) { //left click 719 if (me->button() == LeftButton && leftMouseDown ) { //left click
681 endSelectAction( true ); // emit new event signal 720 endSelectAction( true ); // emit new event signal
682 } 721 }
683 } 722 }
684 if (me->button() == LeftButton) 723 if (me->button() == LeftButton)
685 leftMouseDown = false; 724 leftMouseDown = false;
686 725
687 break; 726 break;
688 727
689 case QEvent::MouseMove: 728 case QEvent::MouseMove:
690 if ( !leftMouseDown ) 729 if ( !leftMouseDown )
691 return true; 730 return true;
692 if ( blockMoving ) { 731 if ( blockMoving ) {
693 int dX, dY; 732 int dX, dY;
694 dX = startX - viewportPos.x(); 733 dX = startX - viewportPos.x();
695 if ( dX < 0 ) 734 if ( dX < 0 )
696 dX = -dX; 735 dX = -dX;
697 dY = viewportPos.y() - startY; 736 dY = viewportPos.y() - startY;
698 if ( dY < 0 ) 737 if ( dY < 0 )
699 dY = -dY; 738 dY = -dY;
700 //qDebug("%d %d %d ", dX, dY , blockmoveDist ); 739 //qDebug("%d %d %d ", dX, dY , blockmoveDist );
701 if ( dX > blockmoveDist || dY > blockmoveDist ) { 740 if ( dX > blockmoveDist || dY > blockmoveDist ) {
702 blockMoving = false; 741 blockMoving = false;
703 } 742 }
704 } 743 }
705 if (object != viewport()) { 744 if (object != viewport()) {
706 KOAgendaItem *moveItem = (KOAgendaItem *)object; 745 KOAgendaItem *moveItem = (KOAgendaItem *)object;
707 if (!moveItem->incidence()->isReadOnly() ) { 746 if (!moveItem->incidence()->isReadOnly() ) {
708 if (!mActionItem) 747 if (!mActionItem)
709 setNoActionCursor(moveItem,viewportPos); 748 setNoActionCursor(moveItem,viewportPos);
710 else { 749 else {
711 if ( !blockMoving ) 750 if ( !blockMoving )
712 performItemAction(viewportPos); 751 performItemAction(viewportPos);
713 } 752 }
714 } 753 }
715 } else { // ---------- viewport() 754 } else { // ---------- viewport()
716 if ( mActionType == SELECT ) { 755 if ( mActionType == SELECT ) {
717 performSelectAction( viewportPos ); 756 performSelectAction( viewportPos );
718 } 757 }
719 } 758 }
720 break; 759 break;
721 760
722 case QEvent::MouseButtonDblClick: 761 case QEvent::MouseButtonDblClick:
723 blockMoving = false; 762 blockMoving = false;
724 leftMouseDown = false; 763 leftMouseDown = false;
725 if (object == viewport()) { 764 if (object == viewport()) {
726 selectItem(0); 765 selectItem(0);
727 int x,y; 766 int x,y;
728 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 767 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
729 int gx,gy; 768 int gx,gy;
730 contentsToGrid(x,y,gx,gy); 769 contentsToGrid(x,y,gx,gy);
731 emit newEventSignal(gx,gy); 770 emit newEventSignal(gx,gy);
732 } else { 771 } else {
733 KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; 772 KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object;
734 selectItem(doubleClickedItem); 773 selectItem(doubleClickedItem);
735 if ( KOPrefs::instance()->mEditOnDoubleClick ) 774 if ( KOPrefs::instance()->mEditOnDoubleClick )
736 emit editIncidenceSignal(doubleClickedItem->incidence()); 775 emit editIncidenceSignal(doubleClickedItem->incidence());
737 else 776 else
738 emit showIncidenceSignal(doubleClickedItem->incidence()); 777 emit showIncidenceSignal(doubleClickedItem->incidence());
739 } 778 }
740 break; 779 break;
741 780
742 default: 781 default:
743 break; 782 break;
744 } 783 }
745 return true; 784 return true;
746#endif 785#endif
747} 786}
748 787
749void KOAgenda::newItem( int item ) 788void KOAgenda::newItem( int item )
750{ 789{
751 if ( item == 1 ) { //new event 790 if ( item == 1 ) { //new event
752 newEventSignal(mStartCellX ,mStartCellY ); 791 newEventSignal(mStartCellX ,mStartCellY );
753 } else 792 } else
754 if ( item == 2 ) { //new event 793 if ( item == 2 ) { //new event
755 newTodoSignal(mStartCellX ,mStartCellY ); 794 newTodoSignal(mStartCellX ,mStartCellY );
756 } else 795 } else
757 { 796 {
758 emit showDateView( item, mStartCellX ); 797 emit showDateView( item, mStartCellX );
759 // 3Day view 798 // 3Day view
760 // 4Week view 799 // 4Week view
761 // 5Month view 800 // 5Month view
762 // 6Journal view 801 // 6Journal view
763 } 802 }
764} 803}
765void KOAgenda::startSelectAction(QPoint viewportPos) 804void KOAgenda::startSelectAction(QPoint viewportPos)
766{ 805{
767 //emit newStartSelectSignal(); 806 //emit newStartSelectSignal();
768 807
769 mActionType = SELECT; 808 mActionType = SELECT;
770 809
771 int x,y; 810 int x,y;
772 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 811 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
773 int gx,gy; 812 int gx,gy;
774 contentsToGrid(x,y,gx,gy); 813 contentsToGrid(x,y,gx,gy);
775 814
776 mStartCellX = gx; 815 mStartCellX = gx;
777 mStartCellY = gy; 816 mStartCellY = gy;
778 mCurrentCellX = gx; 817 mCurrentCellX = gx;
779 mCurrentCellY = gy; 818 mCurrentCellY = gy;
780 819
781 // Store coordinates of old selection 820 // Store coordinates of old selection
782 int selectionX = mSelectionCellX * mGridSpacingX; 821 int selectionX = mSelectionCellX * mGridSpacingX;
783 int selectionYTop = mSelectionYTop; 822 int selectionYTop = mSelectionYTop;
784 int selectionHeight = mSelectionHeight; 823 int selectionHeight = mSelectionHeight;
785 824
786 // Store new selection 825 // Store new selection
787 mSelectionCellX = gx; 826 mSelectionCellX = gx;
788 mSelectionYTop = gy * mGridSpacingY; 827 mSelectionYTop = gy * mGridSpacingY;
789 mSelectionHeight = mGridSpacingY; 828 mSelectionHeight = mGridSpacingY;
790 829
791 // Clear old selection 830 // Clear old selection
792 repaintContents( selectionX, selectionYTop, 831 repaintContents( selectionX, selectionYTop,
793 mGridSpacingX, selectionHeight,false ); 832 mGridSpacingX, selectionHeight,false );
794 833
795 // Paint new selection 834 // Paint new selection
796 // repaintContents( mSelectionCellX * mGridSpacingX, mSelectionYTop, 835 // repaintContents( mSelectionCellX * mGridSpacingX, mSelectionYTop,
797 // mGridSpacingX, mSelectionHeight ); 836 // mGridSpacingX, mSelectionHeight );
798} 837}
799 838
800void KOAgenda::performSelectAction(QPoint viewportPos) 839void KOAgenda::performSelectAction(QPoint viewportPos)
801{ 840{
802 int x,y; 841 int x,y;
803 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 842 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
804 int gx,gy; 843 int gx,gy;
805 contentsToGrid(x,y,gx,gy); 844 contentsToGrid(x,y,gx,gy);
806 845
807 QPoint clipperPos = clipper()-> 846 QPoint clipperPos = clipper()->
808 mapFromGlobal(viewport()->mapToGlobal(viewportPos)); 847 mapFromGlobal(viewport()->mapToGlobal(viewportPos));
809 848
810 // Scroll if cursor was moved to upper or lower end of agenda. 849 // Scroll if cursor was moved to upper or lower end of agenda.
811 if (clipperPos.y() < mScrollBorderWidth) { 850 if (clipperPos.y() < mScrollBorderWidth) {
812 mScrollUpTimer.start(mScrollDelay); 851 mScrollUpTimer.start(mScrollDelay);
813 } else if (visibleHeight() - clipperPos.y() < 852 } else if (visibleHeight() - clipperPos.y() <
814 mScrollBorderWidth) { 853 mScrollBorderWidth) {
815 mScrollDownTimer.start(mScrollDelay); 854 mScrollDownTimer.start(mScrollDelay);
816 } else { 855 } else {
817 mScrollUpTimer.stop(); 856 mScrollUpTimer.stop();
818 mScrollDownTimer.stop(); 857 mScrollDownTimer.stop();
819 } 858 }
820 859
821 if ( gy > mCurrentCellY ) { 860 if ( gy > mCurrentCellY ) {
822 mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; 861 mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop;
823 862
824#if 0 863#if 0
825 // FIXME: Repaint only the newly selected region 864 // FIXME: Repaint only the newly selected region
826 repaintContents( mSelectionCellX * mGridSpacingX, 865 repaintContents( mSelectionCellX * mGridSpacingX,
827 mCurrentCellY + mGridSpacingY, 866 mCurrentCellY + mGridSpacingY,
828 mGridSpacingX, 867 mGridSpacingX,
829 mSelectionHeight - ( gy - mCurrentCellY - 1 ) * mGridSpacingY ); 868 mSelectionHeight - ( gy - mCurrentCellY - 1 ) * mGridSpacingY );
830#else 869#else
831 repaintContents( (KOGlobals::self()->reverseLayout() ? 870 repaintContents( (KOGlobals::self()->reverseLayout() ?
832 mColumns - 1 - mSelectionCellX : mSelectionCellX) * 871 mColumns - 1 - mSelectionCellX : mSelectionCellX) *
833 mGridSpacingX, mSelectionYTop, 872 mGridSpacingX, mSelectionYTop,
834 mGridSpacingX, mSelectionHeight , false); 873 mGridSpacingX, mSelectionHeight , false);
835#endif 874#endif
836 875
837 mCurrentCellY = gy; 876 mCurrentCellY = gy;
838 } else if ( gy < mCurrentCellY ) { 877 } else if ( gy < mCurrentCellY ) {
839 if ( gy >= mStartCellY ) { 878 if ( gy >= mStartCellY ) {
840 int selectionHeight = mSelectionHeight; 879 int selectionHeight = mSelectionHeight;
841 mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; 880 mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop;
842 881
843 repaintContents( (KOGlobals::self()->reverseLayout() ? 882 repaintContents( (KOGlobals::self()->reverseLayout() ?
844 mColumns - 1 - mSelectionCellX : mSelectionCellX) * 883 mColumns - 1 - mSelectionCellX : mSelectionCellX) *
845 mGridSpacingX, mSelectionYTop, 884 mGridSpacingX, mSelectionYTop,
846 mGridSpacingX, selectionHeight,false ); 885 mGridSpacingX, selectionHeight,false );
847 886
848 mCurrentCellY = gy; 887 mCurrentCellY = gy;
849 } else { 888 } else {
850 } 889 }
851 } 890 }
852} 891}
853 892
854void KOAgenda::endSelectAction( bool emitNewEvent ) 893void KOAgenda::endSelectAction( bool emitNewEvent )
855{ 894{
856 mActionType = NOP; 895 mActionType = NOP;
857 mScrollUpTimer.stop(); 896 mScrollUpTimer.stop();
858 mScrollDownTimer.stop(); 897 mScrollDownTimer.stop();
859 898
860 emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); 899 emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY);
861 if ( emitNewEvent && mStartCellY < mCurrentCellY ) { 900 if ( emitNewEvent && mStartCellY < mCurrentCellY ) {
862 qDebug("ew event signal "); 901 qDebug("ew event signal ");
863 emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); 902 emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY);
864 } 903 }
865} 904}
866 905
867void KOAgenda::startItemAction(QPoint viewportPos) 906void KOAgenda::startItemAction(QPoint viewportPos)
868{ 907{
869 int x,y; 908 int x,y;
870 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 909 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
871 int gx,gy; 910 int gx,gy;
872 contentsToGrid(x,y,gx,gy); 911 contentsToGrid(x,y,gx,gy);
873 912
874 mStartCellX = gx; 913 mStartCellX = gx;
875 mStartCellY = gy; 914 mStartCellY = gy;
876 mCurrentCellX = gx; 915 mCurrentCellX = gx;
877 mCurrentCellY = gy; 916 mCurrentCellY = gy;
878 917
879 if (mAllDayMode) { 918 if (mAllDayMode) {
880 int gridDistanceX = (x - gx * mGridSpacingX); 919 int gridDistanceX = (x - gx * mGridSpacingX);
881 if (gridDistanceX < mResizeBorderWidth && 920 if (gridDistanceX < mResizeBorderWidth &&
882 mActionItem->cellX() == mCurrentCellX) { 921 mActionItem->cellX() == mCurrentCellX) {
883 mActionType = RESIZELEFT; 922 mActionType = RESIZELEFT;
884 setCursor(sizeHorCursor); 923 setCursor(sizeHorCursor);
885 } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && 924 } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth &&
886 mActionItem->cellXWidth() == mCurrentCellX) { 925 mActionItem->cellXWidth() == mCurrentCellX) {
887 mActionType = RESIZERIGHT; 926 mActionType = RESIZERIGHT;
888 setCursor(sizeHorCursor); 927 setCursor(sizeHorCursor);
889 } else { 928 } else {
890 mActionType = MOVE; 929 mActionType = MOVE;
891 mActionItem->startMove(); 930 mActionItem->startMove();
892 setCursor(sizeAllCursor); 931 setCursor(sizeAllCursor);
893 } 932 }
894 } else { 933 } else {
895 int gridDistanceY = (y - gy * mGridSpacingY); 934 int gridDistanceY = (y - gy * mGridSpacingY);
896 bool allowResize = ( mActionItem->incidence()->type() != "Todo" ); 935 bool allowResize = ( mActionItem->incidence()->type() != "Todo" );
897 if (allowResize && gridDistanceY < mResizeBorderWidth && 936 if (allowResize && gridDistanceY < mResizeBorderWidth &&
898 mActionItem->cellYTop() == mCurrentCellY && 937 mActionItem->cellYTop() == mCurrentCellY &&
899 !mActionItem->firstMultiItem()) { 938 !mActionItem->firstMultiItem()) {
900 mActionType = RESIZETOP; 939 mActionType = RESIZETOP;
901 setCursor(sizeVerCursor); 940 setCursor(sizeVerCursor);
902 } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth && 941 } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth &&
903 mActionItem->cellYBottom() == mCurrentCellY && 942 mActionItem->cellYBottom() == mCurrentCellY &&
904 !mActionItem->lastMultiItem()) { 943 !mActionItem->lastMultiItem()) {
905 mActionType = RESIZEBOTTOM; 944 mActionType = RESIZEBOTTOM;
906 setCursor(sizeVerCursor); 945 setCursor(sizeVerCursor);
907 } else { 946 } else {
908 mActionType = MOVE; 947 mActionType = MOVE;
909 mActionItem->startMove(); 948 mActionItem->startMove();
910 setCursor(sizeAllCursor); 949 setCursor(sizeAllCursor);
911 } 950 }
912 } 951 }
913} 952}
914 953
915void KOAgenda::performItemAction(QPoint viewportPos) 954void KOAgenda::performItemAction(QPoint viewportPos)
916{ 955{
917// kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; 956// kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl;
918// QPoint point = viewport()->mapToGlobal(viewportPos); 957// QPoint point = viewport()->mapToGlobal(viewportPos);
919// kdDebug() << "Global: " << point.x() << "," << point.y() << endl; 958// kdDebug() << "Global: " << point.x() << "," << point.y() << endl;
920// point = clipper()->mapFromGlobal(point); 959// point = clipper()->mapFromGlobal(point);
921// kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; 960// kdDebug() << "clipper: " << point.x() << "," << point.y() << endl;
922// kdDebug() << "visible height: " << visibleHeight() << endl; 961// kdDebug() << "visible height: " << visibleHeight() << endl;
923 int x,y; 962 int x,y;
924 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 963 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
925// kdDebug() << "contents: " << x << "," << y << "\n" << endl; 964// kdDebug() << "contents: " << x << "," << y << "\n" << endl;
926 int gx,gy; 965 int gx,gy;
927 contentsToGrid(x,y,gx,gy); 966 contentsToGrid(x,y,gx,gy);
928 QPoint clipperPos = clipper()-> 967 QPoint clipperPos = clipper()->
929 mapFromGlobal(viewport()->mapToGlobal(viewportPos)); 968 mapFromGlobal(viewport()->mapToGlobal(viewportPos));
930 969
931 // Cursor left active agenda area. 970 // Cursor left active agenda area.
932 // This starts a drag. 971 // This starts a drag.
933 if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/ 972 if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/
934 clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) { 973 clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) {
935 if ( mActionType == MOVE ) { 974 if ( mActionType == MOVE ) {
936 mScrollUpTimer.stop(); 975 mScrollUpTimer.stop();
937 mScrollDownTimer.stop(); 976 mScrollDownTimer.stop();
938 mActionItem->resetMove(); 977 mActionItem->resetMove();
939 placeSubCells( mActionItem ); 978 placeSubCells( mActionItem );
940 // emit startDragSignal( mActionItem->incidence() ); 979 // emit startDragSignal( mActionItem->incidence() );
941 setCursor( arrowCursor ); 980 setCursor( arrowCursor );
942 mActionItem = 0; 981 mActionItem = 0;
943 mActionType = NOP; 982 mActionType = NOP;
944 mItemMoved = 0; 983 mItemMoved = 0;
945 return; 984 return;
946 } 985 }
947 } else { 986 } else {
948 switch ( mActionType ) { 987 switch ( mActionType ) {
949 case MOVE: 988 case MOVE:
950 setCursor( sizeAllCursor ); 989 setCursor( sizeAllCursor );
951 break; 990 break;
952 case RESIZETOP: 991 case RESIZETOP:
953 case RESIZEBOTTOM: 992 case RESIZEBOTTOM:
954 setCursor( sizeVerCursor ); 993 setCursor( sizeVerCursor );
955 break; 994 break;
956 case RESIZELEFT: 995 case RESIZELEFT:
957 case RESIZERIGHT: 996 case RESIZERIGHT:
958 setCursor( sizeHorCursor ); 997 setCursor( sizeHorCursor );
959 break; 998 break;
960 default: 999 default:
961 setCursor( arrowCursor ); 1000 setCursor( arrowCursor );
962 } 1001 }
963 } 1002 }
964 1003
965 // Scroll if item was moved to upper or lower end of agenda. 1004 // Scroll if item was moved to upper or lower end of agenda.
966 if (clipperPos.y() < mScrollBorderWidth) { 1005 if (clipperPos.y() < mScrollBorderWidth) {
967 mScrollUpTimer.start(mScrollDelay); 1006 mScrollUpTimer.start(mScrollDelay);
968 } else if (visibleHeight() - clipperPos.y() < 1007 } else if (visibleHeight() - clipperPos.y() <
969 mScrollBorderWidth) { 1008 mScrollBorderWidth) {
970 mScrollDownTimer.start(mScrollDelay); 1009 mScrollDownTimer.start(mScrollDelay);
971 } else { 1010 } else {
972 mScrollUpTimer.stop(); 1011 mScrollUpTimer.stop();
973 mScrollDownTimer.stop(); 1012 mScrollDownTimer.stop();
974 } 1013 }
975 1014
976 // Move or resize item if necessary 1015 // Move or resize item if necessary
977 if (mCurrentCellX != gx || mCurrentCellY != gy) { 1016 if (mCurrentCellX != gx || mCurrentCellY != gy) {
978 mItemMoved = true; 1017 mItemMoved = true;
979 mActionItem->raise(); 1018 mActionItem->raise();
980 if (mActionType == MOVE) { 1019 if (mActionType == MOVE) {
981 // Move all items belonging to a multi item 1020 // Move all items belonging to a multi item
982 KOAgendaItem *moveItem = mActionItem->firstMultiItem(); 1021 KOAgendaItem *moveItem = mActionItem->firstMultiItem();
983 bool isMultiItem = (moveItem || mActionItem->lastMultiItem()); 1022 bool isMultiItem = (moveItem || mActionItem->lastMultiItem());
984 if (!moveItem) moveItem = mActionItem; 1023 if (!moveItem) moveItem = mActionItem;
985 while (moveItem) { 1024 while (moveItem) {
986 int dy; 1025 int dy;
987 if (isMultiItem) dy = 0; 1026 if (isMultiItem) dy = 0;
988 else dy = gy - mCurrentCellY; 1027 else dy = gy - mCurrentCellY;
989 moveItem->moveRelative(gx - mCurrentCellX,dy); 1028 moveItem->moveRelative(gx - mCurrentCellX,dy);
990 int x,y; 1029 int x,y;
991 gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y); 1030 gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y);
992 moveItem->resize(mGridSpacingX * moveItem->cellWidth(), 1031 moveItem->resize(mGridSpacingX * moveItem->cellWidth(),
993 mGridSpacingY * moveItem->cellHeight()); 1032 mGridSpacingY * moveItem->cellHeight());
994 moveChild(moveItem,x,y); 1033 moveChild(moveItem,x,y);
995 moveItem = moveItem->nextMultiItem(); 1034 moveItem = moveItem->nextMultiItem();
996 } 1035 }
997 } else if (mActionType == RESIZETOP) { 1036 } else if (mActionType == RESIZETOP) {
998 if (mCurrentCellY <= mActionItem->cellYBottom()) { 1037 if (mCurrentCellY <= mActionItem->cellYBottom()) {
999 mActionItem->expandTop(gy - mCurrentCellY); 1038 mActionItem->expandTop(gy - mCurrentCellY);
1000 mActionItem->resize(mActionItem->width(), 1039 mActionItem->resize(mActionItem->width(),
1001 mGridSpacingY * mActionItem->cellHeight()); 1040 mGridSpacingY * mActionItem->cellHeight());
1002 int x,y; 1041 int x,y;
1003 gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y); 1042 gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y);
1004 //moveChild(mActionItem,childX(mActionItem),y); 1043 //moveChild(mActionItem,childX(mActionItem),y);
1005 QScrollView::moveChild( mActionItem,childX(mActionItem),y ); 1044 QScrollView::moveChild( mActionItem,childX(mActionItem),y );
1006 } 1045 }
1007 } else if (mActionType == RESIZEBOTTOM) { 1046 } else if (mActionType == RESIZEBOTTOM) {
1008 if (mCurrentCellY >= mActionItem->cellYTop()) { 1047 if (mCurrentCellY >= mActionItem->cellYTop()) {
1009 mActionItem->expandBottom(gy - mCurrentCellY); 1048 mActionItem->expandBottom(gy - mCurrentCellY);
1010 mActionItem->resize(mActionItem->width(), 1049 mActionItem->resize(mActionItem->width(),
1011 mGridSpacingY * mActionItem->cellHeight()); 1050 mGridSpacingY * mActionItem->cellHeight());
1012 } 1051 }
1013 } else if (mActionType == RESIZELEFT) { 1052 } else if (mActionType == RESIZELEFT) {
1014 if (mCurrentCellX <= mActionItem->cellXWidth()) { 1053 if (mCurrentCellX <= mActionItem->cellXWidth()) {
1015 mActionItem->expandLeft(gx - mCurrentCellX); 1054 mActionItem->expandLeft(gx - mCurrentCellX);
1016 mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), 1055 mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(),
1017 mActionItem->height()); 1056 mActionItem->height());
1018 int x,y; 1057 int x,y;
1019 gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y); 1058 gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y);
1020 moveChild(mActionItem,x,childY(mActionItem)); 1059 moveChild(mActionItem,x,childY(mActionItem));
1021 } 1060 }
1022 } else if (mActionType == RESIZERIGHT) { 1061 } else if (mActionType == RESIZERIGHT) {
1023 if (mCurrentCellX >= mActionItem->cellX()) { 1062 if (mCurrentCellX >= mActionItem->cellX()) {
1024 mActionItem->expandRight(gx - mCurrentCellX); 1063 mActionItem->expandRight(gx - mCurrentCellX);
1025 mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), 1064 mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(),
1026 mActionItem->height()); 1065 mActionItem->height());
1027 } 1066 }
1028 } 1067 }
1029 mCurrentCellX = gx; 1068 mCurrentCellX = gx;
1030 mCurrentCellY = gy; 1069 mCurrentCellY = gy;
1031 } 1070 }
1032} 1071}
1033 1072
1034void KOAgenda::endItemAction() 1073void KOAgenda::endItemAction()
1035{ 1074{
1036 1075
1037 if ( mItemMoved ) { 1076 if ( mItemMoved ) {
1038 KOAgendaItem *placeItem = mActionItem->firstMultiItem(); 1077 KOAgendaItem *placeItem = mActionItem->firstMultiItem();
1039 if ( !placeItem ) { 1078 if ( !placeItem ) {
1040 placeItem = mActionItem; 1079 placeItem = mActionItem;
1041 } 1080 }
1042 if ( placeItem->incidence()->recurrence()->doesRecur() ) { 1081 if ( placeItem->incidence()->recurrence()->doesRecur() ) {
1043 Incidence* oldInc = placeItem->incidence(); 1082 Incidence* oldInc = placeItem->incidence();
1044 placeItem->recreateIncidence(); 1083 placeItem->recreateIncidence();
1045 emit addToCalSignal(placeItem->incidence(), oldInc ); 1084 emit addToCalSignal(placeItem->incidence(), oldInc );
1046 } 1085 }
1047 int type = mActionType; 1086 int type = mActionType;
1048 if ( mAllDayMode ) 1087 if ( mAllDayMode )
1049 type = -1; 1088 type = -1;
1050 KOAgendaItem *modifiedItem = placeItem; 1089 KOAgendaItem *modifiedItem = placeItem;
1051 //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */); 1090 //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */);
1052 QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems(); 1091 QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems();
1053 KOAgendaItem *item; 1092 KOAgendaItem *item;
1054 1093
1055 if ( placeItem->incidence()->type() == "Todo" ) { 1094 if ( placeItem->incidence()->type() == "Todo" ) {
1056 mSelectedItem = 0; 1095 mSelectedItem = 0;
1057 //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth()); 1096 //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth());
1058 modifiedItem->mLastMoveXPos = mCurrentCellX; 1097 modifiedItem->mLastMoveXPos = mCurrentCellX;
1059 emit itemModified( modifiedItem, mActionType ); 1098 emit itemModified( modifiedItem, mActionType );
1060 } 1099 }
1061 else { 1100 else {
1062#if 0 1101#if 0
1063 for ( item=oldconflictItems.first(); item != 0; 1102 for ( item=oldconflictItems.first(); item != 0;
1064 item=oldconflictItems.next() ) { 1103 item=oldconflictItems.next() ) {
1065 placeSubCells(item); 1104 placeSubCells(item);
1066 } 1105 }
1067 while ( placeItem ) { 1106 while ( placeItem ) {
1068 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); 1107 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1());
1069 placeSubCells( placeItem ); 1108 placeSubCells( placeItem );
1070 placeItem = placeItem->nextMultiItem(); 1109 placeItem = placeItem->nextMultiItem();
1071 } 1110 }
1072#endif 1111#endif
1073 1112
1074 globalFlagBlockAgendaItemPaint = 1; 1113 globalFlagBlockAgendaItemPaint = 1;
1075 for ( item=oldconflictItems.first(); item != 0; 1114 for ( item=oldconflictItems.first(); item != 0;
1076 item=oldconflictItems.next() ) { 1115 item=oldconflictItems.next() ) {
1077 placeSubCells(item); 1116 placeSubCells(item);
1078 } 1117 }
1079 while ( placeItem ) { 1118 while ( placeItem ) {
1080 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); 1119 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1());
1081 oldconflictItems = placeItem->conflictItems(); 1120 oldconflictItems = placeItem->conflictItems();
1082 for ( item=oldconflictItems.first(); item != 0; 1121 for ( item=oldconflictItems.first(); item != 0;
1083 item=oldconflictItems.next() ) { 1122 item=oldconflictItems.next() ) {
1084 placeSubCells(item); 1123 placeSubCells(item);
1085 } 1124 }
1086 placeSubCells( placeItem ); 1125 placeSubCells( placeItem );
1087 placeItem = placeItem->nextMultiItem(); 1126 placeItem = placeItem->nextMultiItem();
1088 } 1127 }
1089 globalFlagBlockAgendaItemPaint = 0; 1128 globalFlagBlockAgendaItemPaint = 0;
1090 for ( item=oldconflictItems.first(); item != 0; 1129 for ( item=oldconflictItems.first(); item != 0;
1091 item=oldconflictItems.next() ) { 1130 item=oldconflictItems.next() ) {
1092 globalFlagBlockAgendaItemUpdate = 0; 1131 globalFlagBlockAgendaItemUpdate = 0;
1093 item->repaintMe(); 1132 item->repaintMe();
1094 globalFlagBlockAgendaItemUpdate = 1; 1133 globalFlagBlockAgendaItemUpdate = 1;
1095 item->repaint( false ); 1134 item->repaint( false );
1096 } 1135 }
1097 placeItem = modifiedItem; 1136 placeItem = modifiedItem;
1098 1137
1099 while ( placeItem ) { 1138 while ( placeItem ) {
1100 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); 1139 //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1());
1101 globalFlagBlockAgendaItemUpdate = 0; 1140 globalFlagBlockAgendaItemUpdate = 0;
1102 placeItem->repaintMe(); 1141 placeItem->repaintMe();
1103 globalFlagBlockAgendaItemUpdate = 1; 1142 globalFlagBlockAgendaItemUpdate = 1;
1104 placeItem->repaint(false); 1143 placeItem->repaint(false);
1105 placeItem = placeItem->nextMultiItem(); 1144 placeItem = placeItem->nextMultiItem();
1106 } 1145 }
1107 emit itemModified( modifiedItem, mActionType ); 1146 emit itemModified( modifiedItem, mActionType );
1108 1147
1109 1148
1110 placeItem = modifiedItem; 1149 placeItem = modifiedItem;
1111 while ( placeItem ) { 1150 while ( placeItem ) {
1112 oldconflictItems = placeItem->conflictItems(); 1151 oldconflictItems = placeItem->conflictItems();
1113 for ( item=oldconflictItems.first(); item != 0; 1152 for ( item=oldconflictItems.first(); item != 0;
1114 item=oldconflictItems.next() ) { 1153 item=oldconflictItems.next() ) {
1115 placeSubCells(item); 1154 placeSubCells(item);
1116 } 1155 }
1117 placeSubCells( placeItem ); 1156 placeSubCells( placeItem );
1118 placeItem = placeItem->nextMultiItem(); 1157 placeItem = placeItem->nextMultiItem();
1119 1158
1120 } 1159 }
1121 placeItem = modifiedItem; 1160 placeItem = modifiedItem;
1122 while ( placeItem ) { 1161 while ( placeItem ) {
1123 oldconflictItems = placeItem->conflictItems(); 1162 oldconflictItems = placeItem->conflictItems();
1124 for ( item=oldconflictItems.first(); item != 0; 1163 for ( item=oldconflictItems.first(); item != 0;
1125 item=oldconflictItems.next() ) { 1164 item=oldconflictItems.next() ) {
1126 globalFlagBlockAgendaItemUpdate = 0; 1165 globalFlagBlockAgendaItemUpdate = 0;
1127 item->repaintMe(); 1166 item->repaintMe();
1128 globalFlagBlockAgendaItemUpdate = 1; 1167 globalFlagBlockAgendaItemUpdate = 1;
1129 item->repaint(false); 1168 item->repaint(false);
1130 } 1169 }
1131 placeItem = placeItem->nextMultiItem(); 1170 placeItem = placeItem->nextMultiItem();
1132 } 1171 }
1133 /* 1172 /*
1134 1173
1135 oldconflictItems = modifiedItem->conflictItems(); 1174 oldconflictItems = modifiedItem->conflictItems();
1136 for ( item=oldconflictItems.first(); item != 0; 1175 for ( item=oldconflictItems.first(); item != 0;
1137 item=oldconflictItems.next() ) { 1176 item=oldconflictItems.next() ) {
1138 globalFlagBlockAgendaItemUpdate = 0; 1177 globalFlagBlockAgendaItemUpdate = 0;
1139 item->paintMe(false); 1178 item->paintMe(false);
1140 globalFlagBlockAgendaItemUpdate = 1; 1179 globalFlagBlockAgendaItemUpdate = 1;
1141 item->repaint(false); 1180 item->repaint(false);
1142 } 1181 }
1143 */ 1182 */
1144 1183
1145 1184
1146 } 1185 }
1147 1186
1148 } 1187 }
1149 1188
1150 mScrollUpTimer.stop(); 1189 mScrollUpTimer.stop();
1151 mScrollDownTimer.stop(); 1190 mScrollDownTimer.stop();
1152 setCursor( arrowCursor ); 1191 setCursor( arrowCursor );
1153 mActionItem = 0; 1192 mActionItem = 0;
1154 mActionType = NOP; 1193 mActionType = NOP;
1155 mItemMoved = 0; 1194 mItemMoved = 0;
1156 1195
1157} 1196}
1158 1197
1159void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) 1198void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos)
1160{ 1199{
1161// kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; 1200// kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl;
1162// QPoint point = viewport()->mapToGlobal(viewportPos); 1201// QPoint point = viewport()->mapToGlobal(viewportPos);
1163// kdDebug() << "Global: " << point.x() << "," << point.y() << endl; 1202// kdDebug() << "Global: " << point.x() << "," << point.y() << endl;
1164// point = clipper()->mapFromGlobal(point); 1203// point = clipper()->mapFromGlobal(point);
1165// kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; 1204// kdDebug() << "clipper: " << point.x() << "," << point.y() << endl;
1166 1205
1167 int x,y; 1206 int x,y;
1168 viewportToContents(viewportPos.x(),viewportPos.y(),x,y); 1207 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
1169// kdDebug() << "contents: " << x << "," << y << "\n" << endl; 1208// kdDebug() << "contents: " << x << "," << y << "\n" << endl;
1170 int gx,gy; 1209 int gx,gy;
1171 contentsToGrid(x,y,gx,gy); 1210 contentsToGrid(x,y,gx,gy);
1172 1211
1173 // Change cursor to resize cursor if appropriate 1212 // Change cursor to resize cursor if appropriate
1174 if (mAllDayMode) { 1213 if (mAllDayMode) {
1175 int gridDistanceX = (x - gx * mGridSpacingX); 1214 int gridDistanceX = (x - gx * mGridSpacingX);
1176 if (gridDistanceX < mResizeBorderWidth && 1215 if (gridDistanceX < mResizeBorderWidth &&
1177 moveItem->cellX() == gx) { 1216 moveItem->cellX() == gx) {
1178 setCursor(sizeHorCursor); 1217 setCursor(sizeHorCursor);
1179 } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && 1218 } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth &&
1180 moveItem->cellXWidth() == gx) { 1219 moveItem->cellXWidth() == gx) {
1181 setCursor(sizeHorCursor); 1220 setCursor(sizeHorCursor);
1182 } else { 1221 } else {
1183 setCursor(arrowCursor); 1222 setCursor(arrowCursor);
1184 } 1223 }
1185 } else { 1224 } else {
1186 int gridDistanceY = (y - gy * mGridSpacingY); 1225 int gridDistanceY = (y - gy * mGridSpacingY);
1187 if (gridDistanceY < mResizeBorderWidth && 1226 if (gridDistanceY < mResizeBorderWidth &&
1188 moveItem->cellYTop() == gy && 1227 moveItem->cellYTop() == gy &&
1189 !moveItem->firstMultiItem()) { 1228 !moveItem->firstMultiItem()) {
1190 setCursor(sizeVerCursor); 1229 setCursor(sizeVerCursor);
1191 } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth && 1230 } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth &&
1192 moveItem->cellYBottom() == gy && 1231 moveItem->cellYBottom() == gy &&
1193 !moveItem->lastMultiItem()) { 1232 !moveItem->lastMultiItem()) {
1194 setCursor(sizeVerCursor); 1233 setCursor(sizeVerCursor);
1195 } else { 1234 } else {
1196 setCursor(arrowCursor); 1235 setCursor(arrowCursor);
1197 } 1236 }
1198 } 1237 }
1199} 1238}
1200 1239
1201 1240
1202/* 1241/*
1203 Place item in cell and take care that multiple items using the same cell do 1242 Place item in cell and take care that multiple items using the same cell do
1204 not overlap. This method is not yet optimal. It doesn´t use the maximum space 1243 not overlap. This method is not yet optimal. It doesn´t use the maximum space
1205 it can get in all cases. 1244 it can get in all cases.
1206 At the moment the method has a bug: When an item is placed only the sub cell 1245 At the moment the method has a bug: When an item is placed only the sub cell
1207 widths of the items are changed, which are within the Y region the item to 1246 widths of the items are changed, which are within the Y region the item to
1208 place spans. When the sub cell width change of one of this items affects a 1247 place spans. When the sub cell width change of one of this items affects a
1209 cell, where other items are, which do not overlap in Y with the item to place, 1248 cell, where other items are, which do not overlap in Y with the item to place,
1210 the display gets corrupted, although the corruption looks quite nice. 1249 the display gets corrupted, although the corruption looks quite nice.
1211*/ 1250*/
1212void KOAgenda::placeSubCells(KOAgendaItem *placeItem) 1251void KOAgenda::placeSubCells(KOAgendaItem *placeItem)
1213{ 1252{
1214 1253
1215 QPtrList<KOAgendaItem> conflictItems; 1254 QPtrList<KOAgendaItem> conflictItems;
1216 int maxSubCells = 0; 1255 int maxSubCells = 0;
1217 QIntDict<KOAgendaItem> subCellDict(5); 1256 QIntDict<KOAgendaItem> subCellDict(5);
1218 1257
1219 KOAgendaItem *item; 1258 KOAgendaItem *item;
1220 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1259 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1221 if (item != placeItem) { 1260 if (item != placeItem) {
1222 if (placeItem->cellX() <= item->cellXWidth() && 1261 if (placeItem->cellX() <= item->cellXWidth() &&
1223 placeItem->cellXWidth() >= item->cellX()) { 1262 placeItem->cellXWidth() >= item->cellX()) {
1224 if ((placeItem->cellYTop() <= item->cellYBottom()) && 1263 if ((placeItem->cellYTop() <= item->cellYBottom()) &&
1225 (placeItem->cellYBottom() >= item->cellYTop())) { 1264 (placeItem->cellYBottom() >= item->cellYTop())) {
1226 conflictItems.append(item); 1265 conflictItems.append(item);
1227 if (item->subCells() > maxSubCells) 1266 if (item->subCells() > maxSubCells)
1228 maxSubCells = item->subCells(); 1267 maxSubCells = item->subCells();
1229 subCellDict.insert(item->subCell(),item); 1268 subCellDict.insert(item->subCell(),item);
1230 } 1269 }
1231 } 1270 }
1232 } 1271 }
1233 } 1272 }
1234 1273
1235 if (conflictItems.count() > 0) { 1274 if (conflictItems.count() > 0) {
1236 // Look for unused sub cell and insert item 1275 // Look for unused sub cell and insert item
1237 int i; 1276 int i;
1238 for(i=0;i<maxSubCells;++i) { 1277 for(i=0;i<maxSubCells;++i) {
1239 if (!subCellDict.find(i)) { 1278 if (!subCellDict.find(i)) {
1240 placeItem->setSubCell(i); 1279 placeItem->setSubCell(i);
1241 break; 1280 break;
1242 } 1281 }
1243 } 1282 }
1244 if (i == maxSubCells) { 1283 if (i == maxSubCells) {
1245 placeItem->setSubCell(maxSubCells); 1284 placeItem->setSubCell(maxSubCells);
1246 maxSubCells++; // add new item to number of sub cells 1285 maxSubCells++; // add new item to number of sub cells
1247 } 1286 }
1248 1287
1249 // Prepare for sub cell geometry adjustment 1288 // Prepare for sub cell geometry adjustment
1250 int newSubCellWidth; 1289 int newSubCellWidth;
1251 if (mAllDayMode) newSubCellWidth = mGridSpacingY / maxSubCells; 1290 if (mAllDayMode) newSubCellWidth = mGridSpacingY / maxSubCells;
1252 else newSubCellWidth = mGridSpacingX / maxSubCells; 1291 else newSubCellWidth = mGridSpacingX / maxSubCells;
1253 conflictItems.append(placeItem); 1292 conflictItems.append(placeItem);
1254 1293
1255 1294
1256 // Adjust sub cell geometry of all direct conflict items 1295 // Adjust sub cell geometry of all direct conflict items
1257 for ( item=conflictItems.first(); item != 0; 1296 for ( item=conflictItems.first(); item != 0;
1258 item=conflictItems.next() ) { 1297 item=conflictItems.next() ) {
1259 item->setSubCells(maxSubCells); 1298 item->setSubCells(maxSubCells);
1260 if (mAllDayMode) { 1299 if (mAllDayMode) {
1261 item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth); 1300 item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth);
1262 } else { 1301 } else {
1263 item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY); 1302 item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY);
1264 } 1303 }
1265 int x,y; 1304 int x,y;
1266 gridToContents(item->cellX(),item->cellYTop(),x,y); 1305 gridToContents(item->cellX(),item->cellYTop(),x,y);
1267 if (mAllDayMode) { 1306 if (mAllDayMode) {
1268 y += item->subCell() * newSubCellWidth; 1307 y += item->subCell() * newSubCellWidth;
1269 } else { 1308 } else {
1270 x += item->subCell() * newSubCellWidth; 1309 x += item->subCell() * newSubCellWidth;
1271 } 1310 }
1272 moveChild(item,x,y); 1311 moveChild(item,x,y);
1273 // qDebug("moveChild %s %d %d ", item->incidence()->summary().latin1() ,x,y); 1312 // qDebug("moveChild %s %d %d ", item->incidence()->summary().latin1() ,x,y);
1274 //item->updateItem(); 1313 //item->updateItem();
1275 } 1314 }
1276 // Adjust sub cell geometry of all conflict items of all conflict items 1315 // Adjust sub cell geometry of all conflict items of all conflict items
1277 for ( item=conflictItems.first(); item != 0; 1316 for ( item=conflictItems.first(); item != 0;
1278 item=conflictItems.next() ) { 1317 item=conflictItems.next() ) {
1279 if ( placeItem != item ) { 1318 if ( placeItem != item ) {
1280 KOAgendaItem *item2; 1319 KOAgendaItem *item2;
1281 QPtrList<KOAgendaItem> conflictItems2 = item->conflictItems(); 1320 QPtrList<KOAgendaItem> conflictItems2 = item->conflictItems();
1282 for ( item2=conflictItems2.first(); item2 != 0; 1321 for ( item2=conflictItems2.first(); item2 != 0;
1283 item2=conflictItems2.next() ) { 1322 item2=conflictItems2.next() ) {
1284 if ( item2->subCells() != maxSubCells) { 1323 if ( item2->subCells() != maxSubCells) {
1285 item2->setSubCells(maxSubCells); 1324 item2->setSubCells(maxSubCells);
1286 if (mAllDayMode) { 1325 if (mAllDayMode) {
1287 item2->resize(item2->cellWidth() * mGridSpacingX, newSubCellWidth); 1326 item2->resize(item2->cellWidth() * mGridSpacingX, newSubCellWidth);
1288 } else { 1327 } else {
1289 item2->resize(newSubCellWidth, item2->cellHeight() * mGridSpacingY); 1328 item2->resize(newSubCellWidth, item2->cellHeight() * mGridSpacingY);
1290 } 1329 }
1291 int x,y; 1330 int x,y;
1292 gridToContents(item2->cellX(),item2->cellYTop(),x,y); 1331 gridToContents(item2->cellX(),item2->cellYTop(),x,y);
1293 if (mAllDayMode) { 1332 if (mAllDayMode) {
1294 y += item2->subCell() * newSubCellWidth; 1333 y += item2->subCell() * newSubCellWidth;
1295 } else { 1334 } else {
1296 x += item2->subCell() * newSubCellWidth; 1335 x += item2->subCell() * newSubCellWidth;
1297 } 1336 }
1298 moveChild(item2,x,y); 1337 moveChild(item2,x,y);
1299 //qDebug("setttttt %d %s",maxSubCells, item2->text().latin1() ); 1338 //qDebug("setttttt %d %s",maxSubCells, item2->text().latin1() );
1300 } 1339 }
1301 } 1340 }
1302 } 1341 }
1303 } 1342 }
1304 } else { 1343 } else {
1305 placeItem->setSubCell(0); 1344 placeItem->setSubCell(0);
1306 placeItem->setSubCells(1); 1345 placeItem->setSubCells(1);
1307 if (mAllDayMode) placeItem->resize(placeItem->width(),mGridSpacingY); 1346 if (mAllDayMode) placeItem->resize(placeItem->width(),mGridSpacingY);
1308 else placeItem->resize(mGridSpacingX,placeItem->height()); 1347 else placeItem->resize(mGridSpacingX,placeItem->height());
1309 int x,y; 1348 int x,y;
1310 gridToContents(placeItem->cellX(),placeItem->cellYTop(),x,y); 1349 gridToContents(placeItem->cellX(),placeItem->cellYTop(),x,y);
1311 moveChild(placeItem,x,y); 1350 moveChild(placeItem,x,y);
1312 } 1351 }
1313 placeItem->setConflictItems(conflictItems); 1352 placeItem->setConflictItems(conflictItems);
1314 // for ( item=conflictItems.first(); item != 0; 1353 // for ( item=conflictItems.first(); item != 0;
1315// item=conflictItems.next() ) { 1354// item=conflictItems.next() ) {
1316// //item->updateItem(); 1355// //item->updateItem();
1317// //qDebug("xxx item->updateItem() %s %d %d", item->incidence()->summary().latin1(),item->x(), item->y() ); 1356// //qDebug("xxx item->updateItem() %s %d %d", item->incidence()->summary().latin1(),item->x(), item->y() );
1318// } 1357// }
1319// placeItem->updateItem(); 1358// placeItem->updateItem();
1320} 1359}
1321 1360
1322void KOAgenda::drawContents(QPainter* p, int cx, int cy, int cw, int ch) 1361void KOAgenda::drawContents(QPainter* p, int cx, int cy, int cw, int ch)
1323{ 1362{
1324 if ( globalFlagBlockAgenda ) 1363 if ( globalFlagBlockAgenda )
1325 return; 1364 return;
1326 //qDebug("KOAgenda::drawContents "); 1365 //qDebug("KOAgenda::drawContents ");
1327 if ( mCurPixWid != contentsWidth() || mCurPixHei != contentsHeight() ) 1366 if ( mCurPixWid != contentsWidth() || mCurPixHei != contentsHeight() )
1328 ;//drawContentsToPainter(); 1367 ;//drawContentsToPainter();
1329 1368
1330 QPaintDevice* pd = p->device(); 1369 QPaintDevice* pd = p->device();
1331 p->end(); 1370 p->end();
1332 int vx, vy; 1371 int vx, vy;
1333 int selectionX = KOGlobals::self()->reverseLayout() ? 1372 int selectionX = KOGlobals::self()->reverseLayout() ?
1334 (mColumns - 1 - mSelectionCellX) * mGridSpacingX : 1373 (mColumns - 1 - mSelectionCellX) * mGridSpacingX :
1335 mSelectionCellX * mGridSpacingX; 1374 mSelectionCellX * mGridSpacingX;
1336 contentsToViewport ( cx, cy, vx,vy); 1375 contentsToViewport ( cx, cy, vx,vy);
1337 // qDebug(" %d %d %d %d ", cx, cy, cw,ch) ; 1376 // qDebug(" %d %d %d %d ", cx, cy, cw,ch) ;
1338 if ( !(selectionX == cx && cy == mSelectionYTop && cw ==mGridSpacingX && ch == mSelectionHeight ) ) 1377 if ( !(selectionX == cx && cy == mSelectionYTop && cw ==mGridSpacingX && ch == mSelectionHeight ) )
1339 bitBlt ( pd, vx, vy, &mPaintPixmap, cx, cy, cw, ch ,CopyROP); 1378 bitBlt ( pd, vx, vy, &mPaintPixmap, cx, cy, cw, ch ,CopyROP);
1340 1379
1341 if ( mSelectionHeight > 0 ) { 1380 if ( mSelectionHeight > 0 ) {
1342 //qDebug("---- %d %d %d %d ", selectionX, mSelectionYTop, mGridSpacingX, mSelectionHeight ); 1381 //qDebug("---- %d %d %d %d ", selectionX, mSelectionYTop, mGridSpacingX, mSelectionHeight );
1343 if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) && 1382 if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) &&
1344 ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) { 1383 ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) {
1345 contentsToViewport ( selectionX, mSelectionYTop, vx,vy); 1384 contentsToViewport ( selectionX, mSelectionYTop, vx,vy);
1346 bitBlt ( pd, vx+1, vy, &mHighlightPixmap, 0, mSelectionYTop, mGridSpacingX-1, mSelectionHeight ,CopyROP); 1385 bitBlt ( pd, vx+1, vy, &mHighlightPixmap, 0, mSelectionYTop, mGridSpacingX-1, mSelectionHeight ,CopyROP);
1347 } 1386 }
1348 } 1387 }
1349 //qDebug("btbl "); 1388 //qDebug("btbl ");
1350 p->begin( pd ); 1389 p->begin( pd );
1351 //qDebug("end "); 1390 //qDebug("end ");
1352} 1391}
1353 1392
1354void KOAgenda::finishUpdate() 1393void KOAgenda::finishUpdate()
1355{ 1394{
1356 1395
1357 KOAgendaItem *item; 1396 KOAgendaItem *item;
1358 globalFlagBlockAgendaItemPaint = 1; 1397 globalFlagBlockAgendaItemPaint = 1;
1359 // Adjust sub cell geometry of all conflict items of all conflict items of all conflict items ... of the conflict item with the max number of conflictitems 1398 // Adjust sub cell geometry of all conflict items of all conflict items of all conflict items ... of the conflict item with the max number of conflictitems
1360 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1399 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1361 if ( !item->checkLayout() ) { 1400 if ( !item->checkLayout() ) {
1362 //qDebug(" conflictitem found "); 1401 //qDebug(" conflictitem found ");
1363 int newSubCellWidth; 1402 int newSubCellWidth;
1364 if (mAllDayMode) newSubCellWidth = mGridSpacingY / item->subCells(); 1403 if (mAllDayMode) newSubCellWidth = mGridSpacingY / item->subCells();
1365 else newSubCellWidth = mGridSpacingX / item->subCells(); 1404 else newSubCellWidth = mGridSpacingX / item->subCells();
1366 1405
1367 if (mAllDayMode) { 1406 if (mAllDayMode) {
1368 item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth); 1407 item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth);
1369 } else { 1408 } else {
1370 item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY); 1409 item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY);
1371 } 1410 }
1372 int x,y; 1411 int x,y;
1373 gridToContents(item->cellX(),item->cellYTop(),x,y); 1412 gridToContents(item->cellX(),item->cellYTop(),x,y);
1374 if (mAllDayMode) { 1413 if (mAllDayMode) {
1375 y += item->subCell() * newSubCellWidth; 1414 y += item->subCell() * newSubCellWidth;
1376 } else { 1415 } else {
1377 x += item->subCell() * newSubCellWidth; 1416 x += item->subCell() * newSubCellWidth;
1378 } 1417 }
1379 moveChild(item,x,y); 1418 moveChild(item,x,y);
1380 } 1419 }
1381 } 1420 }
1382 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1421 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1383 if ( !item->isVisible() ) 1422 if ( !item->isVisible() )
1384 item->show(); 1423 item->show();
1385 1424
1386 } 1425 }
1387 globalFlagBlockAgendaItemUpdate = 0; 1426 globalFlagBlockAgendaItemUpdate = 0;
1388 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1427 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1389 item->repaintMe( ); 1428 item->repaintMe( );
1390 } 1429 }
1391 globalFlagBlockAgendaItemUpdate = 1; 1430 globalFlagBlockAgendaItemUpdate = 1;
1392 qApp->processEvents(); 1431 qApp->processEvents();
1393 globalFlagBlockAgendaItemPaint = 0; 1432 globalFlagBlockAgendaItemPaint = 0;
1394 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1433 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1395 item->repaint( false ); 1434 item->repaint( false );
1396 } 1435 }
1397 1436
1398} 1437}
1399 1438
1400/* 1439/*
1401 Draw grid in the background of the agenda. 1440 Draw grid in the background of the agenda.
1402*/ 1441*/
1403void KOAgenda::drawContentsToPainter( QPainter* paint, bool backgroundOnly )// int cx, int cy, int cw, int ch) 1442void KOAgenda::drawContentsToPainter( QPainter* paint, bool backgroundOnly )// int cx, int cy, int cw, int ch)
1404{ 1443{
1405 1444
1406 1445
1407 if ( ! mGridSpacingX || ! mGridSpacingY ||! mHolidayMask ) 1446 if ( ! mGridSpacingX || ! mGridSpacingY ||! mHolidayMask )
1408 return; 1447 return;
1409 if ( globalFlagBlockAgenda > 1 && globalFlagBlockAgenda < 4 ) 1448 if ( globalFlagBlockAgenda > 1 && globalFlagBlockAgenda < 4 )
1410 return; 1449 return;
1411 int cx = 0, cy = 0, cw = contentsWidth(), ch = contentsHeight(); 1450 int cx = 0, cy = 0, cw = contentsWidth(), ch = contentsHeight();
1412 if ( ch < 1 ) 1451 if ( ch < 1 )
1413 ch = 1; 1452 ch = 1;
1414 if ( mPaintPixmap.width() < contentsWidth()+42 || mPaintPixmap.height() < ch ) { 1453 if ( mPaintPixmap.width() < contentsWidth()+42 || mPaintPixmap.height() < ch ) {
1415 mPaintPixmap.resize( contentsWidth()+42, ch ); 1454 mPaintPixmap.resize( contentsWidth()+42, ch );
1416 } 1455 }
1417 mCurPixWid = contentsWidth(); 1456 mCurPixWid = contentsWidth();
1418 mCurPixHei = ch; 1457 mCurPixHei = ch;
1419 if ( mHighlightPixmap.width() < mGridSpacingX-1 || mHighlightPixmap.height() < ch ) { 1458 if ( mHighlightPixmap.width() < mGridSpacingX-1 || mHighlightPixmap.height() < ch ) {
1420 mHighlightPixmap.resize( mGridSpacingX-1, ch ); 1459 mHighlightPixmap.resize( mGridSpacingX-1, ch );
1421 mHighlightPixmap.fill ( KOPrefs::instance()->mHighlightColor ); 1460 mHighlightPixmap.fill ( KOPrefs::instance()->mHighlightColor );
1422 } 1461 }
1423 mPixPainter.begin( &mPaintPixmap) ; 1462 mPixPainter.begin( &mPaintPixmap) ;
1424 //qDebug("wid %d hei %d ",mPaintPixmap.width(),mPaintPixmap.height() ); 1463 //qDebug("wid %d hei %d ",mPaintPixmap.width(),mPaintPixmap.height() );
1425 QPainter * p ; 1464 QPainter * p ;
1426 if (paint == 0) { 1465 if (paint == 0) {
1427 mPaintPixmap.fill(KOPrefs::instance()->mAgendaBgColor); 1466 mPaintPixmap.fill(KOPrefs::instance()->mAgendaBgColor);
1428 p = &mPixPainter; 1467 p = &mPixPainter;
1429 } 1468 }
1430 else 1469 else
1431 p = paint ; 1470 p = paint ;
1432 // qDebug("++++++KOAgenda::drawContentsTo Painter %d %d %d %d ", cx, cy, cw, ch); 1471 // qDebug("++++++KOAgenda::drawContentsTo Painter %d %d %d %d ", cx, cy, cw, ch);
1433 1472
1434 //--cx;++cw; 1473 //--cx;++cw;
1435 int lGridSpacingY = mGridSpacingY*2; 1474 int lGridSpacingY = mGridSpacingY*2;
1436 int selDay; 1475 int selDay;
1437 if ( !backgroundOnly ) 1476 if ( !backgroundOnly )
1438 for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay) 1477 for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay)
1439 { 1478 {
1440 if ( mSelectedDates[selDay] == QDateTime::currentDateTime ().date() && KOPrefs::instance()->mHighlightCurrentDay) { 1479 if ( mSelectedDates[selDay] == QDateTime::currentDateTime ().date() && KOPrefs::instance()->mHighlightCurrentDay) {
1441 int x1 = cx; 1480 int x1 = cx;
1442 int y1 = 0; 1481 int y1 = 0;
1443 if (y1 < cy) y1 = cy; 1482 if (y1 < cy) y1 = cy;
1444 int x2 = cx+cw-1; 1483 int x2 = cx+cw-1;
1445 int y2 = contentsHeight(); 1484 int y2 = contentsHeight();
1446 if (y2 > cy+ch-1) y2=cy+ch-1; 1485 if (y2 > cy+ch-1) y2=cy+ch-1;
1447 if (x2 >= x1 && y2 >= y1) { 1486 if (x2 >= x1 && y2 >= y1) {
1448 int gxStart = selDay; 1487 int gxStart = selDay;
1449 int gxEnd = gxStart ; 1488 int gxEnd = gxStart ;
1450 int xStart = KOGlobals::self()->reverseLayout() ? 1489 int xStart = KOGlobals::self()->reverseLayout() ?
1451 (mColumns - 1 - gxStart)*mGridSpacingX : 1490 (mColumns - 1 - gxStart)*mGridSpacingX :
1452 gxStart*mGridSpacingX; 1491 gxStart*mGridSpacingX;
1453 if (xStart < x1) xStart = x1; 1492 if (xStart < x1) xStart = x1;
1454 int xEnd = KOGlobals::self()->reverseLayout() ? 1493 int xEnd = KOGlobals::self()->reverseLayout() ?
1455 (mColumns - gxStart)*mGridSpacingX-1 : 1494 (mColumns - gxStart)*mGridSpacingX-1 :
1456 (gxStart+1)*mGridSpacingX-1; 1495 (gxStart+1)*mGridSpacingX-1;
1457 if (xEnd > x2) xEnd = x2; 1496 if (xEnd > x2) xEnd = x2;
1458 if ( KOPrefs::instance()->mUseHighlightLightColor ) 1497 if ( KOPrefs::instance()->mUseHighlightLightColor )
1459 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, 1498 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1,
1460 KOPrefs::instance()->mAgendaBgColor.light()); 1499 KOPrefs::instance()->mAgendaBgColor.light());
1461 else 1500 else
1462 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, 1501 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1,
1463 KOPrefs::instance()->mAgendaBgColor.dark()); 1502 KOPrefs::instance()->mAgendaBgColor.dark());
1464 1503
1465 } 1504 }
1466 } 1505 }
1467 } 1506 }
1468 // Highlight working hours 1507 // Highlight working hours
1469 1508
1470 if ( !backgroundOnly ) 1509 if ( !backgroundOnly )
1471 if (mWorkingHoursEnable) { 1510 if (mWorkingHoursEnable) {
1472 int x1 = cx; 1511 int x1 = cx;
1473 int y1 = mWorkingHoursYTop; 1512 int y1 = mWorkingHoursYTop;
1474 if (y1 < cy) y1 = cy; 1513 if (y1 < cy) y1 = cy;
1475 int x2 = cx+cw-1; 1514 int x2 = cx+cw-1;
1476 // int x2 = mGridSpacingX * 5 - 1; 1515 // int x2 = mGridSpacingX * 5 - 1;
1477 // if (x2 > cx+cw-1) x2 = cx + cw - 1; 1516 // if (x2 > cx+cw-1) x2 = cx + cw - 1;
1478 int y2 = mWorkingHoursYBottom; 1517 int y2 = mWorkingHoursYBottom;
1479 if (y2 > cy+ch-1) y2=cy+ch-1; 1518 if (y2 > cy+ch-1) y2=cy+ch-1;
1480 1519
1481 if (x2 >= x1 && y2 >= y1) { 1520 if (x2 >= x1 && y2 >= y1) {
1482 // qDebug("x1 %d mGridSpacingX %d ", x1, mGridSpacingX ); 1521 // qDebug("x1 %d mGridSpacingX %d ", x1, mGridSpacingX );
1483 int gxStart = x1/mGridSpacingX; 1522 int gxStart = x1/mGridSpacingX;
1484 int gxEnd = x2/mGridSpacingX; 1523 int gxEnd = x2/mGridSpacingX;
1485 while(gxStart <= gxEnd) { 1524 while(gxStart <= gxEnd) {
1486 if (gxStart < int(mHolidayMask->count()) && 1525 if (gxStart < int(mHolidayMask->count()) &&
1487 !mHolidayMask->at(gxStart)) { 1526 !mHolidayMask->at(gxStart)) {
1488 int xStart = KOGlobals::self()->reverseLayout() ? 1527 int xStart = KOGlobals::self()->reverseLayout() ?
1489 (mColumns - 1 - gxStart)*mGridSpacingX : 1528 (mColumns - 1 - gxStart)*mGridSpacingX :
1490 gxStart*mGridSpacingX; 1529 gxStart*mGridSpacingX;
1491 if (xStart < x1) xStart = x1; 1530 if (xStart < x1) xStart = x1;
1492 int xEnd = KOGlobals::self()->reverseLayout() ? 1531 int xEnd = KOGlobals::self()->reverseLayout() ?
1493 (mColumns - gxStart)*mGridSpacingX-1 : 1532 (mColumns - gxStart)*mGridSpacingX-1 :
1494 (gxStart+1)*mGridSpacingX-1; 1533 (gxStart+1)*mGridSpacingX-1;
1495 if (xEnd > x2) xEnd = x2; 1534 if (xEnd > x2) xEnd = x2;
1496 if ( mSelectedDates[gxStart] == QDateTime::currentDateTime ().date()&& KOPrefs::instance()->mHighlightCurrentDay ) { 1535 if ( mSelectedDates[gxStart] == QDateTime::currentDateTime ().date()&& KOPrefs::instance()->mHighlightCurrentDay ) {
1497 if ( KOPrefs::instance()->mUseHighlightLightColor ) 1536 if ( KOPrefs::instance()->mUseHighlightLightColor )
1498 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, 1537 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1,
1499 KOPrefs::instance()->mWorkingHoursColor.light()); 1538 KOPrefs::instance()->mWorkingHoursColor.light());
1500 else 1539 else
1501 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, 1540 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1,
1502 KOPrefs::instance()->mWorkingHoursColor.dark()); 1541 KOPrefs::instance()->mWorkingHoursColor.dark());
1503 } else { 1542 } else {
1504 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, 1543 p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1,
1505 KOPrefs::instance()->mWorkingHoursColor); 1544 KOPrefs::instance()->mWorkingHoursColor);
1506 } 1545 }
1507 } 1546 }
1508 ++gxStart; 1547 ++gxStart;
1509 } 1548 }
1510 } 1549 }
1511 } 1550 }
1512 /* 1551 /*
1513 int selectionX = KOGlobals::self()->reverseLayout() ? 1552 int selectionX = KOGlobals::self()->reverseLayout() ?
1514 (mColumns - 1 - mSelectionCellX) * mGridSpacingX : 1553 (mColumns - 1 - mSelectionCellX) * mGridSpacingX :
1515 mSelectionCellX * mGridSpacingX; 1554 mSelectionCellX * mGridSpacingX;
1516 1555
1517 // Draw selection 1556 // Draw selection
1518 if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) && 1557 if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) &&
1519 ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) { 1558 ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) {
1520 // TODO: paint only part within cx,cy,cw,ch 1559 // TODO: paint only part within cx,cy,cw,ch
1521 p->fillRect( selectionX, mSelectionYTop, mGridSpacingX, 1560 p->fillRect( selectionX, mSelectionYTop, mGridSpacingX,
1522 mSelectionHeight, KOPrefs::instance()->mHighlightColor ); 1561 mSelectionHeight, KOPrefs::instance()->mHighlightColor );
1523 } 1562 }
1524 */ 1563 */
1525 // Draw vertical lines of grid 1564 // Draw vertical lines of grid
1526 1565
1527 int x = ((int)(cx/mGridSpacingX))*mGridSpacingX; 1566 int x = ((int)(cx/mGridSpacingX))*mGridSpacingX;
1528 if ( mGridSpacingX > 0 ) { 1567 if ( mGridSpacingX > 0 ) {
1529 while (x < cx + cw) { 1568 while (x < cx + cw) {
1530 p->drawLine(x,cy,x,cy+ch); 1569 p->drawLine(x,cy,x,cy+ch);
1531 x+=mGridSpacingX; 1570 x+=mGridSpacingX;
1532 } 1571 }
1533 } 1572 }
1534 // Draw horizontal lines of grid 1573 // Draw horizontal lines of grid
1535 int y = ((int)(cy/lGridSpacingY))*lGridSpacingY; 1574 int y = ((int)(cy/lGridSpacingY))*lGridSpacingY;
1536 if ( lGridSpacingY > 0 ) { 1575 if ( lGridSpacingY > 0 ) {
1537 while (y < cy + ch) { 1576 while (y < cy + ch) {
1538 p->setPen( SolidLine ); 1577 p->setPen( SolidLine );
1539 p->drawLine(cx,y,cx+cw,y); 1578 p->drawLine(cx,y,cx+cw,y);
1540 y+=lGridSpacingY; 1579 y+=lGridSpacingY;
1541 p->setPen( DotLine ); 1580 p->setPen( DotLine );
1542 p->drawLine(cx,y,cx+cw,y); 1581 p->drawLine(cx,y,cx+cw,y);
1543 y+=lGridSpacingY; 1582 y+=lGridSpacingY;
1544 } 1583 }
1545 p->setPen( SolidLine ); 1584 p->setPen( SolidLine );
1546 } 1585 }
1547 mPixPainter.end() ; 1586 mPixPainter.end() ;
1548} 1587}
1549 1588
1550/* 1589/*
1551 Convert srcollview contents coordinates to agenda grid coordinates. 1590 Convert srcollview contents coordinates to agenda grid coordinates.
1552*/ 1591*/
1553void KOAgenda::contentsToGrid (int x, int y, int& gx, int& gy) 1592void KOAgenda::contentsToGrid (int x, int y, int& gx, int& gy)
1554{ 1593{
1555 gx = KOGlobals::self()->reverseLayout() ? mColumns - 1 - x/mGridSpacingX : 1594 gx = KOGlobals::self()->reverseLayout() ? mColumns - 1 - x/mGridSpacingX :
1556 x/mGridSpacingX; 1595 x/mGridSpacingX;
1557 gy = y/mGridSpacingY; 1596 gy = y/mGridSpacingY;
1558} 1597}
1559 1598
1560/* 1599/*
1561 Convert agenda grid coordinates to scrollview contents coordinates. 1600 Convert agenda grid coordinates to scrollview contents coordinates.
1562*/ 1601*/
1563void KOAgenda::gridToContents (int gx, int gy, int& x, int& y) 1602void KOAgenda::gridToContents (int gx, int gy, int& x, int& y)
1564{ 1603{
1565 x = KOGlobals::self()->reverseLayout() ? (mColumns - 1 - gx)*mGridSpacingX: 1604 x = KOGlobals::self()->reverseLayout() ? (mColumns - 1 - gx)*mGridSpacingX:
1566 gx*mGridSpacingX; 1605 gx*mGridSpacingX;
1567 y = gy*mGridSpacingY; 1606 y = gy*mGridSpacingY;
1568} 1607}
1569 1608
1570 1609
1571/* 1610/*
1572 Return Y coordinate corresponding to time. Coordinates are rounded to fit into 1611 Return Y coordinate corresponding to time. Coordinates are rounded to fit into
1573 the grid. 1612 the grid.
1574*/ 1613*/
1575int KOAgenda::timeToY(const QTime &time) 1614int KOAgenda::timeToY(const QTime &time)
1576{ 1615{
1577 int minutesPerCell = 24 * 60 / mRows; 1616 int minutesPerCell = 24 * 60 / mRows;
1578 int timeMinutes = time.hour() * 60 + time.minute(); 1617 int timeMinutes = time.hour() * 60 + time.minute();
1579 int Y = (timeMinutes + (minutesPerCell / 2)) / minutesPerCell; 1618 int Y = (timeMinutes + (minutesPerCell / 2)) / minutesPerCell;
1580 return Y; 1619 return Y;
1581} 1620}
1582 1621
1583 1622
1584/* 1623/*
1585 Return time corresponding to cell y coordinate. Coordinates are rounded to 1624 Return time corresponding to cell y coordinate. Coordinates are rounded to
1586 fit into the grid. 1625 fit into the grid.
1587*/ 1626*/
1588QTime KOAgenda::gyToTime(int gy) 1627QTime KOAgenda::gyToTime(int gy)
1589{ 1628{
1590 1629
1591 int secondsPerCell = 24 * 60 * 60/ mRows; 1630 int secondsPerCell = 24 * 60 * 60/ mRows;
1592 1631
1593 int timeSeconds = secondsPerCell * gy; 1632 int timeSeconds = secondsPerCell * gy;
1594 1633
1595 QTime time( 0, 0, 0 ); 1634 QTime time( 0, 0, 0 );
1596 if ( timeSeconds < 24 * 60 * 60 ) { 1635 if ( timeSeconds < 24 * 60 * 60 ) {
1597 time = time.addSecs(timeSeconds); 1636 time = time.addSecs(timeSeconds);
1598 } else { 1637 } else {
1599 time.setHMS( 23, 59, 59 ); 1638 time.setHMS( 23, 59, 59 );
1600 } 1639 }
1601 1640
1602 return time; 1641 return time;
1603} 1642}
1604 1643
1605void KOAgenda::setStartHour(int startHour) 1644void KOAgenda::setStartHour(int startHour)
1606{ 1645{
1607 int startCell = startHour * mRows / 24; 1646 int startCell = startHour * mRows / 24;
1608 setContentsPos(0,startCell * gridSpacingY()); 1647 setContentsPos(0,startCell * gridSpacingY());
1609} 1648}
1610void KOAgenda::hideUnused() 1649void KOAgenda::hideUnused()
1611{ 1650{
1612 // experimental only 1651 // experimental only
1613 // return; 1652 // return;
1614 KOAgendaItem *item; 1653 KOAgendaItem *item;
1615 for ( item=mUnusedItems.first(); item != 0; item=mUnusedItems.next() ) { 1654 for ( item=mUnusedItems.first(); item != 0; item=mUnusedItems.next() ) {
1616 item->hide(); 1655 item->hide();
1617 } 1656 }
1618} 1657}
1619 1658
1620 1659
1621KOAgendaItem *KOAgenda::getNewItem(Incidence * event,QDate qd, QWidget* view) 1660KOAgendaItem *KOAgenda::getNewItem(Incidence * event,QDate qd, QWidget* view)
1622{ 1661{
1623 1662
1624 KOAgendaItem *fi; 1663 KOAgendaItem *fi;
1625 for ( fi=mUnusedItems.first(); fi != 0; fi=mUnusedItems.next() ) { 1664 for ( fi=mUnusedItems.first(); fi != 0; fi=mUnusedItems.next() ) {
1626 if ( fi->incidence() == event ) { 1665 if ( fi->incidence() == event ) {
1627 mUnusedItems.remove(); 1666 mUnusedItems.remove();
1628 fi->init( event, qd ); 1667 fi->init( event, qd );
1629 return fi; 1668 return fi;
1630 } 1669 }
1631 } 1670 }
1632 fi=mUnusedItems.first(); 1671 fi=mUnusedItems.first();
1633 if ( fi ) { 1672 if ( fi ) {
1634 mUnusedItems.remove(); 1673 mUnusedItems.remove();
1635 fi->init( event, qd ); 1674 fi->init( event, qd );
1636 return fi; 1675 return fi;
1637 } 1676 }
1638 // qDebug("new KOAgendaItem "); 1677 // qDebug("new KOAgendaItem ");
1639 1678
1640 KOAgendaItem* agendaItem = new KOAgendaItem( event, qd, view, mAllDayMode ); 1679 KOAgendaItem* agendaItem = new KOAgendaItem( event, qd, view, mAllDayMode );
1641 agendaItem->installEventFilter(this); 1680 agendaItem->installEventFilter(this);
1642 addChild(agendaItem,0,0); 1681 addChild(agendaItem,0,0);
1643 return agendaItem; 1682 return agendaItem;
1644} 1683}
1645KOAgendaItem * KOAgenda::getItemForTodo ( Todo * todo ) 1684KOAgendaItem * KOAgenda::getItemForTodo ( Todo * todo )
1646{ 1685{
1647 KOAgendaItem *item; 1686 KOAgendaItem *item;
1648 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1687 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1649 if ( item->incidence() == todo ) { 1688 if ( item->incidence() == todo ) {
1650 mItems.remove(); 1689 mItems.remove();
1651 return item; 1690 return item;
1652 } 1691 }
1653 } 1692 }
1654 return 0; 1693 return 0;
1655} 1694}
1656 1695
1657 1696
1658void KOAgenda::updateTodo( Todo * todo, int days, bool remove) 1697void KOAgenda::updateTodo( Todo * todo, int days, bool remove)
1659{ 1698{
1660 // ( todo->hasCompletedDate() && todo->completed().date() == currentDate )|| 1699 // ( todo->hasCompletedDate() && todo->completed().date() == currentDate )||
1661 KOAgendaItem *item; 1700 KOAgendaItem *item;
1662 item = getItemForTodo ( todo ); 1701 item = getItemForTodo ( todo );
1663 //qDebug("KOAgenda::updateTodo %d %d %d %d", this, todo, days, remove); 1702 //qDebug("KOAgenda::updateTodo %d %d %d %d", this, todo, days, remove);
1664 if ( item ) { 1703 if ( item ) {
1665 blockSignals( true ); 1704 blockSignals( true );
1666 //qDebug("item found "); 1705 //qDebug("item found ");
1667 item->hide(); 1706 item->hide();
1668 item->setCellX(-2, -1 ); 1707 item->setCellX(-2, -1 );
1669 item->select(false); 1708 item->select(false);
1670 mUnusedItems.append( item ); 1709 mUnusedItems.append( item );
1671 mItems.remove( item ); 1710 mItems.remove( item );
1672 QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); 1711 QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems();
1673 KOAgendaItem *itemit; 1712 KOAgendaItem *itemit;
1674 //globalFlagBlockAgendaItemPaint = 1; 1713 //globalFlagBlockAgendaItemPaint = 1;
1675 for ( itemit=oldconflictItems.first(); itemit != 0; 1714 for ( itemit=oldconflictItems.first(); itemit != 0;
1676 itemit=oldconflictItems.next() ) { 1715 itemit=oldconflictItems.next() ) {
1677 if ( itemit != item ) 1716 if ( itemit != item )
1678 placeSubCells(itemit); 1717 placeSubCells(itemit);
1679 } 1718 }
1680 qApp->processEvents(); 1719 qApp->processEvents();
1681 //globalFlagBlockAgendaItemPaint = 0; 1720 //globalFlagBlockAgendaItemPaint = 0;
1682 for ( itemit=oldconflictItems.first(); itemit != 0; 1721 for ( itemit=oldconflictItems.first(); itemit != 0;
1683 itemit=oldconflictItems.next() ) { 1722 itemit=oldconflictItems.next() ) {
1684 globalFlagBlockAgendaItemUpdate = 0; 1723 globalFlagBlockAgendaItemUpdate = 0;
1685 if ( itemit != item ) 1724 if ( itemit != item )
1686 itemit->repaintMe(); 1725 itemit->repaintMe();
1687 globalFlagBlockAgendaItemUpdate = 1; 1726 globalFlagBlockAgendaItemUpdate = 1;
1688 itemit->repaint(); 1727 itemit->repaint();
1689 } 1728 }
1690 blockSignals( false ); 1729 blockSignals( false );
1691 } 1730 }
1692 if ( remove ) { 1731 if ( remove ) {
1693 //qDebug("remove****************************************** "); 1732 //qDebug("remove****************************************** ");
1694 return; 1733 return;
1695 } 1734 }
1696 //qDebug("updateTodo+++++++++++++++++++++++++++++++++++++ "); 1735 //qDebug("updateTodo+++++++++++++++++++++++++++++++++++++ ");
1697 bool overdue = (!todo->isCompleted()) && (todo->dtDue() < QDate::currentDate())&& ( KOPrefs::instance()->mShowTodoInAgenda ); 1736 bool overdue = (!todo->isCompleted()) && (todo->dtDue() < QDate::currentDate())&& ( KOPrefs::instance()->mShowTodoInAgenda );
1698 QDate currentDate; 1737 QDate currentDate;
1699 QDateTime dt; 1738 QDateTime dt;
1700 if ( todo->hasCompletedDate() ) 1739 if ( todo->hasCompletedDate() )
1701 dt = todo->completed(); 1740 dt = todo->completed();
1702 else 1741 else
1703 dt = todo->dtDue(); 1742 dt = todo->dtDue();
1704 if ( overdue ) { 1743 if ( overdue ) {
1705 currentDate = QDate::currentDate(); 1744 currentDate = QDate::currentDate();
1706 days += todo->dtDue().date().daysTo( currentDate ); 1745 days += todo->dtDue().date().daysTo( currentDate );
1707 } 1746 }
1708 else 1747 else
1709 currentDate = dt.date(); 1748 currentDate = dt.date();
1710 1749
1711 if (( todo->doesFloat() || overdue) && !todo->hasCompletedDate() ) { 1750 if (( todo->doesFloat() || overdue) && !todo->hasCompletedDate() ) {
1712 if ( ! mAllDayMode ) return; 1751 if ( ! mAllDayMode ) return;
1713 // aldayagenda 1752 // aldayagenda
1714 globalFlagBlockAgendaItemPaint = 1; 1753 globalFlagBlockAgendaItemPaint = 1;
1715 item = insertAllDayItem(todo, currentDate,days, days); 1754 item = insertAllDayItem(todo, currentDate,days, days);
1716 item->show(); 1755 item->show();
1717 1756
1718 } 1757 }
1719 else { 1758 else {
1720 if ( mAllDayMode ) return; 1759 if ( mAllDayMode ) return;
1721 // mAgenda 1760 // mAgenda
1722 globalFlagBlockAgendaItemPaint = 1; 1761 globalFlagBlockAgendaItemPaint = 1;
1723 int endY = timeToY(dt.time()) - 1; 1762 int endY = timeToY(dt.time()) - 1;
1724 int hi = 12/KOPrefs::instance()->mHourSize; 1763 int hi = 12/KOPrefs::instance()->mHourSize;
1725 int startY = endY - 1-hi; 1764 int startY = endY - 1-hi;
1726 item = insertItem(todo,currentDate,days,startY,endY); 1765 item = insertItem(todo,currentDate,days,startY,endY);
1727 item->show(); 1766 item->show();
1728 } 1767 }
1729 qApp->processEvents(); 1768 qApp->processEvents();
1730 globalFlagBlockAgendaItemPaint = 0; 1769 globalFlagBlockAgendaItemPaint = 0;
1731 QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); 1770 QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems();
1732 KOAgendaItem *itemit; 1771 KOAgendaItem *itemit;
1733 for ( itemit=oldconflictItems.first(); itemit != 0; 1772 for ( itemit=oldconflictItems.first(); itemit != 0;
1734 itemit=oldconflictItems.next() ) { 1773 itemit=oldconflictItems.next() ) {
1735 globalFlagBlockAgendaItemUpdate = 0; 1774 globalFlagBlockAgendaItemUpdate = 0;
1736 itemit->repaintMe(); 1775 itemit->repaintMe();
1737 globalFlagBlockAgendaItemUpdate = 1; 1776 globalFlagBlockAgendaItemUpdate = 1;
1738 itemit->repaint(); 1777 itemit->repaint();
1739 } 1778 }
1740 globalFlagBlockAgendaItemUpdate = 0; 1779 globalFlagBlockAgendaItemUpdate = 0;
1741 item->repaintMe(); 1780 item->repaintMe();
1742 globalFlagBlockAgendaItemUpdate = 1; 1781 globalFlagBlockAgendaItemUpdate = 1;
1743 item->repaint(); 1782 item->repaint();
1744} 1783}
1745/* 1784/*
1746 Insert KOAgendaItem into agenda. 1785 Insert KOAgendaItem into agenda.
1747*/ 1786*/
1748KOAgendaItem *KOAgenda::insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom) 1787KOAgendaItem *KOAgenda::insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom)
1749{ 1788{
1750 if (mAllDayMode) { 1789 if (mAllDayMode) {
1751 qDebug("KOAgenda: calling insertItem in all-day mode is illegal. "); 1790 qDebug("KOAgenda: calling insertItem in all-day mode is illegal. ");
1752 return 0; 1791 return 0;
1753 } 1792 }
1754 1793
1755 KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); 1794 KOAgendaItem *agendaItem = getNewItem(event,qd,viewport());
1756 //agendaItem->setFrameStyle(WinPanel|Raised); 1795 //agendaItem->setFrameStyle(WinPanel|Raised);
1757 1796
1758 int YSize = YBottom - YTop + 1; 1797 int YSize = YBottom - YTop + 1;
1759 if (YSize < 0) { 1798 if (YSize < 0) {
1760 YSize = 1; 1799 YSize = 1;
1761 } 1800 }
1762 int iheight = mGridSpacingY * YSize; 1801 int iheight = mGridSpacingY * YSize;
1763 1802
1764 agendaItem->resize(mGridSpacingX,iheight ); 1803 agendaItem->resize(mGridSpacingX,iheight );
1765 agendaItem->setCellXY(X,YTop,YBottom); 1804 agendaItem->setCellXY(X,YTop,YBottom);
1766 agendaItem->setCellXWidth(X); 1805 agendaItem->setCellXWidth(X);
1767 1806
1768 //addChild(agendaItem,X*mGridSpacingX,YTop*mGridSpacingY); 1807 //addChild(agendaItem,X*mGridSpacingX,YTop*mGridSpacingY);
1769 mItems.append(agendaItem); 1808 mItems.append(agendaItem);
1770 1809
1771 placeSubCells(agendaItem); 1810 placeSubCells(agendaItem);
1772 1811
1773 //agendaItem->show(); 1812 //agendaItem->show();
1774 1813
1775 marcus_bains(); 1814 marcus_bains();
1776 1815
1777 return agendaItem; 1816 return agendaItem;
1778} 1817}
1779 1818
1780 1819
1781/* 1820/*
1782 Insert all-day KOAgendaItem into agenda. 1821 Insert all-day KOAgendaItem into agenda.
1783*/ 1822*/
1784KOAgendaItem *KOAgenda::insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd) 1823KOAgendaItem *KOAgenda::insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd)
1785{ 1824{
1786 if (!mAllDayMode) { 1825 if (!mAllDayMode) {
1787 return 0; 1826 return 0;
1788 } 1827 }
1789 1828
1790 KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); 1829 KOAgendaItem *agendaItem = getNewItem(event,qd,viewport());
1791 1830
1792 agendaItem->setCellXY(XBegin,0,0); 1831 agendaItem->setCellXY(XBegin,0,0);
1793 agendaItem->setCellXWidth(XEnd); 1832 agendaItem->setCellXWidth(XEnd);
1794 agendaItem->resize(mGridSpacingX * agendaItem->cellWidth(),mGridSpacingY); 1833 agendaItem->resize(mGridSpacingX * agendaItem->cellWidth(),mGridSpacingY);
1795 1834
1796 //addChild(agendaItem,XBegin*mGridSpacingX,0); 1835 //addChild(agendaItem,XBegin*mGridSpacingX,0);
1797 mItems.append(agendaItem); 1836 mItems.append(agendaItem);
1798 1837
1799 placeSubCells(agendaItem); 1838 placeSubCells(agendaItem);
1800 1839
1801 //agendaItem->show(); 1840 //agendaItem->show();
1802 1841
1803 return agendaItem; 1842 return agendaItem;
1804} 1843}
1805 1844
1806 1845
1807void KOAgenda::insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, 1846void KOAgenda::insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd,
1808 int YTop,int YBottom) 1847 int YTop,int YBottom)
1809{ 1848{
1810 if (mAllDayMode) { 1849 if (mAllDayMode) {
1811 ; 1850 ;
1812 return; 1851 return;
1813 } 1852 }
1814 1853
1815 int cellX,cellYTop,cellYBottom; 1854 int cellX,cellYTop,cellYBottom;
1816 QString newtext; 1855 QString newtext;
1817 int width = XEnd - XBegin + 1; 1856 int width = XEnd - XBegin + 1;
1818 int count = 0; 1857 int count = 0;
1819 KOAgendaItem *current = 0; 1858 KOAgendaItem *current = 0;
1820 QPtrList<KOAgendaItem> multiItems; 1859 QPtrList<KOAgendaItem> multiItems;
1821 for (cellX = XBegin;cellX <= XEnd;++cellX) { 1860 for (cellX = XBegin;cellX <= XEnd;++cellX) {
1822 if (cellX == XBegin) cellYTop = YTop; 1861 if (cellX == XBegin) cellYTop = YTop;
1823 else cellYTop = 0; 1862 else cellYTop = 0;
1824 if (cellX == XEnd) cellYBottom = YBottom; 1863 if (cellX == XEnd) cellYBottom = YBottom;
1825 else cellYBottom = rows() - 1; 1864 else cellYBottom = rows() - 1;
1826 newtext = QString("(%1/%2): ").arg(++count).arg(width); 1865 newtext = QString("(%1/%2): ").arg(++count).arg(width);
1827 newtext.append(event->summary()); 1866 newtext.append(event->summary());
1828 current = insertItem(event,qd,cellX,cellYTop,cellYBottom); 1867 current = insertItem(event,qd,cellX,cellYTop,cellYBottom);
1829 current->setText(newtext); 1868 current->setText(newtext);
1830 multiItems.append(current); 1869 multiItems.append(current);
1831 } 1870 }
1832 1871
1833 KOAgendaItem *next = 0; 1872 KOAgendaItem *next = 0;
1834 KOAgendaItem *last = multiItems.last(); 1873 KOAgendaItem *last = multiItems.last();
1835 KOAgendaItem *first = multiItems.first(); 1874 KOAgendaItem *first = multiItems.first();
1836 KOAgendaItem *setFirst,*setLast; 1875 KOAgendaItem *setFirst,*setLast;
1837 current = first; 1876 current = first;
1838 while (current) { 1877 while (current) {
1839 next = multiItems.next(); 1878 next = multiItems.next();
1840 if (current == first) setFirst = 0; 1879 if (current == first) setFirst = 0;
1841 else setFirst = first; 1880 else setFirst = first;
1842 if (current == last) setLast = 0; 1881 if (current == last) setLast = 0;
1843 else setLast = last; 1882 else setLast = last;
1844 1883
1845 current->setMultiItem(setFirst,next,setLast); 1884 current->setMultiItem(setFirst,next,setLast);
1846 current = next; 1885 current = next;
1847 } 1886 }
1848 1887
1849 marcus_bains(); 1888 marcus_bains();
1850} 1889}
1851 1890
1852 1891
1853//QSizePolicy KOAgenda::sizePolicy() const 1892//QSizePolicy KOAgenda::sizePolicy() const
1854//{ 1893//{
1855 // Thought this would make the all-day event agenda minimum size and the 1894 // Thought this would make the all-day event agenda minimum size and the
1856 // normal agenda take the remaining space. But it doesn´t work. The QSplitter 1895 // normal agenda take the remaining space. But it doesn´t work. The QSplitter
1857 // don´t seem to think that an Expanding widget needs more space than a 1896 // don´t seem to think that an Expanding widget needs more space than a
1858 // Preferred one. 1897 // Preferred one.
1859 // But it doesn´t hurt, so it stays. 1898 // But it doesn´t hurt, so it stays.
1860// if (mAllDayMode) { 1899// if (mAllDayMode) {
1861// return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Preferred); 1900// return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Preferred);
1862// } else { 1901// } else {
1863// return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding); 1902// return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
1864// } 1903// }
1865//} 1904//}
1866void KOAgenda::finishResize ( ) 1905void KOAgenda::finishResize ( )
1867{ 1906{
1868 //qDebug("finishResize+++++++++++++++++++++++++++++++ ( ) "); 1907 //qDebug("finishResize+++++++++++++++++++++++++++++++ ( ) ");
1869 if ( globalFlagBlockAgenda == 0 ) { 1908 if ( globalFlagBlockAgenda == 0 ) {
1870 finishUpdate(); 1909 finishUpdate();
1871 //qDebug("finishUpdate() called "); 1910 //qDebug("finishUpdate() called ");
1872 } 1911 }
1873} 1912}
1874/* 1913/*
1875 Overridden from QScrollView to provide proper resizing of KOAgendaItems. 1914 Overridden from QScrollView to provide proper resizing of KOAgendaItems.
1876*/ 1915*/
1877void KOAgenda::resizeEvent ( QResizeEvent *ev ) 1916void KOAgenda::resizeEvent ( QResizeEvent *ev )
1878{ 1917{
1879 1918
1880 mResizeTimer.start( 150 , true ); 1919 mResizeTimer.start( 150 , true );
1881 computeSizes(); 1920 computeSizes();
1882 return; 1921 return;
1883 1922
1884} 1923}
1885void KOAgenda::computeSizes() 1924void KOAgenda::computeSizes()
1886{ 1925{
1887 if ( globalFlagBlockStartup ) 1926 if ( globalFlagBlockStartup )
1888 return; 1927 return;
1889 int frameOffset = frameWidth() * 2 +1; 1928 int frameOffset = frameWidth() * 2 +1;
1890 if (mAllDayMode) { 1929 if (mAllDayMode) {
1891 mGridSpacingX = (width()-frameOffset) / mColumns; 1930 mGridSpacingX = (width()-frameOffset) / mColumns;
1892 mGridSpacingY = height() - 2 * frameWidth() - 1; 1931 mGridSpacingY = height() - 2 * frameWidth() - 1;
1893 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY + 1); 1932 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY + 1);
1894 // mGridSpacingY = height(); 1933 // mGridSpacingY = height();
1895 // resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); 1934 // resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 );
1896 1935
1897 KOAgendaItem *item; 1936 KOAgendaItem *item;
1898 int subCellWidth; 1937 int subCellWidth;
1899 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1938 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1900 subCellWidth = mGridSpacingY / item->subCells(); 1939 subCellWidth = mGridSpacingY / item->subCells();
1901 item->resize(mGridSpacingX * item->cellWidth(),subCellWidth); 1940 item->resize(mGridSpacingX * item->cellWidth(),subCellWidth);
1902 moveChild(item,KOGlobals::self()->reverseLayout() ? 1941 moveChild(item,KOGlobals::self()->reverseLayout() ?
1903 (mColumns - 1 - item->cellX()) * mGridSpacingX : 1942 (mColumns - 1 - item->cellX()) * mGridSpacingX :
1904 item->cellX() * mGridSpacingX, 1943 item->cellX() * mGridSpacingX,
1905 item->subCell() * subCellWidth); 1944 item->subCell() * subCellWidth);
1906 } 1945 }
1907 KOPrefs::instance()->mAllDaySize = mGridSpacingY; 1946 KOPrefs::instance()->mAllDaySize = mGridSpacingY;
1908 } else { 1947 } else {
1909 mGridSpacingX = (width() - verticalScrollBar()->width()-frameOffset)/mColumns; 1948 mGridSpacingX = (width() - verticalScrollBar()->width()-frameOffset)/mColumns;
1910 if (height() > mGridSpacingY * mRows + 1 ) { 1949 if (height() > mGridSpacingY * mRows + 1 ) {
1911 KOPrefs::instance()->mHourSize = ((height())/mRows)+1; 1950 KOPrefs::instance()->mHourSize = ((height())/mRows)+1;
1912 mGridSpacingY = KOPrefs::instance()->mHourSize ; 1951 mGridSpacingY = KOPrefs::instance()->mHourSize ;
1913 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); 1952 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 );
1914 emit resizedSignal(); 1953 emit resizedSignal();
1915 } else 1954 } else
1916 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); 1955 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 );
1917 KOAgendaItem *item; 1956 KOAgendaItem *item;
1918 int subCellWidth; 1957 int subCellWidth;
1919 1958
1920 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 1959 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
1921 subCellWidth = mGridSpacingX / item->subCells(); 1960 subCellWidth = mGridSpacingX / item->subCells();
1922 item->resize(subCellWidth,item->height()); 1961 item->resize(subCellWidth,item->height());
1923 moveChild(item,(KOGlobals::self()->reverseLayout() ? 1962 moveChild(item,(KOGlobals::self()->reverseLayout() ?
1924 (mColumns - 1 - item->cellX()) * mGridSpacingX : 1963 (mColumns - 1 - item->cellX()) * mGridSpacingX :
1925 item->cellX() * mGridSpacingX) + 1964 item->cellX() * mGridSpacingX) +
1926 item->subCell() * subCellWidth,childY(item)); 1965 item->subCell() * subCellWidth,childY(item));
1927 } 1966 }
1928 } 1967 }
1929 int cw = contentsWidth(); 1968 int cw = contentsWidth();
1930 int ch = contentsHeight(); 1969 int ch = contentsHeight();
1931 if ( mAllDayMode ) { 1970 if ( mAllDayMode ) {
1932 QPixmap* paintPixAll = KOAgendaItem::paintPixAllday(); 1971 QPixmap* paintPixAll = KOAgendaItem::paintPixAllday();
1933 if ( (paintPixAll->width() < cw || paintPixAll->height() < ch) && cw > 0 && ch > 0 ) 1972 if ( (paintPixAll->width() < cw || paintPixAll->height() < ch) && cw > 0 && ch > 0 )
1934 paintPixAll->resize( cw, ch ); 1973 paintPixAll->resize( cw, ch );
1935 } else { 1974 } else {
1936 QPixmap* paintPix = KOAgendaItem::paintPix(); 1975 QPixmap* paintPix = KOAgendaItem::paintPix();
1937 if ( paintPix->width() < cw || paintPix->height() < ch ) 1976 if ( paintPix->width() < cw || paintPix->height() < ch )
1938 KOAgendaItem::resizePixmap( cw , ch ); 1977 KOAgendaItem::resizePixmap( cw , ch );
1939 } 1978 }
1940 1979
1941 checkScrollBoundaries(); 1980 checkScrollBoundaries();
1942 marcus_bains(); 1981 marcus_bains();
1943 drawContentsToPainter(); 1982 drawContentsToPainter();
1944 viewport()->repaint(false); 1983 viewport()->repaint(false);
1945} 1984}
1946 1985
1947void KOAgenda::scrollUp() 1986void KOAgenda::scrollUp()
1948{ 1987{
1949 scrollBy(0,-mScrollOffset); 1988 scrollBy(0,-mScrollOffset);
1950} 1989}
1951 1990
1952 1991
1953void KOAgenda::scrollDown() 1992void KOAgenda::scrollDown()
1954{ 1993{
1955 scrollBy(0,mScrollOffset); 1994 scrollBy(0,mScrollOffset);
1956} 1995}
1957 1996
1958void KOAgenda::popupAlarm() 1997void KOAgenda::popupAlarm()
1959{ 1998{
1960 if (!mClickedItem) { 1999 if (!mClickedItem) {
1961 qDebug("KOAgenda::popupAlarm() called without having a clicked item "); 2000 qDebug("KOAgenda::popupAlarm() called without having a clicked item ");
1962 return; 2001 return;
1963 } 2002 }
1964 // TODO: deal correctly with multiple alarms 2003 // TODO: deal correctly with multiple alarms
1965 Alarm* alarm; 2004 Alarm* alarm;
1966 QPtrList<Alarm> list(mClickedItem->incidence()->alarms()); 2005 QPtrList<Alarm> list(mClickedItem->incidence()->alarms());
1967 for(alarm=list.first();alarm;alarm=list.next()) { 2006 for(alarm=list.first();alarm;alarm=list.next()) {
1968 alarm->toggleAlarm(); 2007 alarm->toggleAlarm();
1969 } 2008 }
1970 emit itemModified( mClickedItem , KOGlobals::EVENTEDITED ); 2009 emit itemModified( mClickedItem , KOGlobals::EVENTEDITED );
1971 mClickedItem->paintMe( true ); 2010 mClickedItem->paintMe( true );
1972 mClickedItem->repaint( false ); 2011 mClickedItem->repaint( false );
1973} 2012}
1974 2013
1975/* 2014/*
1976 Calculates the minimum width 2015 Calculates the minimum width
1977*/ 2016*/
1978int KOAgenda::minimumWidth() const 2017int KOAgenda::minimumWidth() const
1979{ 2018{
1980 // TODO:: develop a way to dynamically determine the minimum width 2019 // TODO:: develop a way to dynamically determine the minimum width
1981 int min = 100; 2020 int min = 100;
1982 2021
1983 return min; 2022 return min;
1984} 2023}
1985 2024
1986void KOAgenda::updateConfig() 2025void KOAgenda::updateConfig()
1987{ 2026{
1988 if ( viewport()->backgroundColor() != KOPrefs::instance()->mAgendaBgColor) 2027 if ( viewport()->backgroundColor() != KOPrefs::instance()->mAgendaBgColor)
1989 viewport()->setBackgroundColor(KOPrefs::instance()->mAgendaBgColor); 2028 viewport()->setBackgroundColor(KOPrefs::instance()->mAgendaBgColor);
1990 if ( mAllDayMode ) { 2029 if ( mAllDayMode ) {
1991 mGridSpacingY = height() - 1 ;// KOPrefs::instance()->mAllDaySize; 2030 mGridSpacingY = height() - 1 ;// KOPrefs::instance()->mAllDaySize;
1992 //mGridSpacingY = KOPrefs::instance()->mAllDaySize; 2031 //mGridSpacingY = KOPrefs::instance()->mAllDaySize;
1993 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY+1 ); 2032 resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY+1 );
1994 // setMaximumHeight( mGridSpacingY+1 ); 2033 // setMaximumHeight( mGridSpacingY+1 );
1995 viewport()->repaint( false ); 2034 viewport()->repaint( false );
1996 //setFixedHeight( mGridSpacingY+1 ); 2035 //setFixedHeight( mGridSpacingY+1 );
1997 //qDebug("KOPrefs:aaaaa:instance()->mAllDaySize %d ", KOPrefs::instance()->mAllDaySize); 2036 //qDebug("KOPrefs:aaaaa:instance()->mAllDaySize %d ", KOPrefs::instance()->mAllDaySize);
1998 } 2037 }
1999 else { 2038 else {
2000 mGridSpacingY = KOPrefs::instance()->mHourSize; 2039 mGridSpacingY = KOPrefs::instance()->mHourSize;
2001 calculateWorkingHours(); 2040 calculateWorkingHours();
2002 marcus_bains(); 2041 marcus_bains();
2003 } 2042 }
2004} 2043}
2005 2044
2006void KOAgenda::checkScrollBoundaries() 2045void KOAgenda::checkScrollBoundaries()
2007{ 2046{
2008 // Invalidate old values to force update 2047 // Invalidate old values to force update
2009 mOldLowerScrollValue = -1; 2048 mOldLowerScrollValue = -1;
2010 mOldUpperScrollValue = -1; 2049 mOldUpperScrollValue = -1;
2011 2050
2012 checkScrollBoundaries(verticalScrollBar()->value()); 2051 checkScrollBoundaries(verticalScrollBar()->value());
2013} 2052}
2014 2053
2015void KOAgenda::checkScrollBoundaries(int v) 2054void KOAgenda::checkScrollBoundaries(int v)
2016{ 2055{
2017 if ( mGridSpacingY == 0 ) 2056 if ( mGridSpacingY == 0 )
2018 return; 2057 return;
2019 int yMin = v/mGridSpacingY; 2058 int yMin = v/mGridSpacingY;
2020 int yMax = (v+visibleHeight())/mGridSpacingY; 2059 int yMax = (v+visibleHeight())/mGridSpacingY;
2021 2060
2022// kdDebug() << "--- yMin: " << yMin << " yMax: " << yMax << endl; 2061// kdDebug() << "--- yMin: " << yMin << " yMax: " << yMax << endl;
2023 2062
2024 if (yMin != mOldLowerScrollValue) { 2063 if (yMin != mOldLowerScrollValue) {
2025 mOldLowerScrollValue = yMin; 2064 mOldLowerScrollValue = yMin;
2026 emit lowerYChanged(yMin); 2065 emit lowerYChanged(yMin);
2027 } 2066 }
2028 if (yMax != mOldUpperScrollValue) { 2067 if (yMax != mOldUpperScrollValue) {
2029 mOldUpperScrollValue = yMax; 2068 mOldUpperScrollValue = yMax;
2030 emit upperYChanged(yMax); 2069 emit upperYChanged(yMax);
2031 } 2070 }
2032} 2071}
2033 2072
2034void KOAgenda::deselectItem() 2073void KOAgenda::deselectItem()
2035{ 2074{
2036 if (mSelectedItem.isNull()) return; 2075 if (mSelectedItem.isNull()) return;
2037 mSelectedItem->select(false); 2076 mSelectedItem->select(false);
2038 mSelectedItem = 0; 2077 mSelectedItem = 0;
2039} 2078}
2040 2079
2041void KOAgenda::selectItem(KOAgendaItem *item) 2080void KOAgenda::selectItem(KOAgendaItem *item)
2042{ 2081{
2043 if ((KOAgendaItem *)mSelectedItem == item) return; 2082 if ((KOAgendaItem *)mSelectedItem == item) return;
2044 deselectItem(); 2083 deselectItem();
2045 if (item == 0) { 2084 if (item == 0) {
2046 emit incidenceSelected( 0 ); 2085 emit incidenceSelected( 0 );
2047 return; 2086 return;
2048 } 2087 }
2049 mSelectedItem = item; 2088 mSelectedItem = item;
2050 mSelectedItem->select(); 2089 mSelectedItem->select();
2051 emit incidenceSelected( mSelectedItem->incidence() ); 2090 emit incidenceSelected( mSelectedItem->incidence() );
2052} 2091}
2053 2092
2054// This function seems never be called. 2093// This function seems never be called.
2055void KOAgenda::keyPressEvent( QKeyEvent *kev ) 2094void KOAgenda::keyPressEvent( QKeyEvent *kev )
2056{ 2095{
2057 switch(kev->key()) { 2096 switch(kev->key()) {
2058 case Key_PageDown: 2097 case Key_PageDown:
2059 verticalScrollBar()->addPage(); 2098 verticalScrollBar()->addPage();
2060 break; 2099 break;
2061 case Key_PageUp: 2100 case Key_PageUp:
2062 verticalScrollBar()->subtractPage(); 2101 verticalScrollBar()->subtractPage();
2063 break; 2102 break;
2064 case Key_Down: 2103 case Key_Down:
2065 verticalScrollBar()->addLine(); 2104 verticalScrollBar()->addLine();
2066 break; 2105 break;
2067 case Key_Up: 2106 case Key_Up:
2068 verticalScrollBar()->subtractLine(); 2107 verticalScrollBar()->subtractLine();
2069 break; 2108 break;
2070 default: 2109 default:
2071 ; 2110 ;
2072 } 2111 }
2073} 2112}
2074 2113
2075void KOAgenda::calculateWorkingHours() 2114void KOAgenda::calculateWorkingHours()
2076{ 2115{
2077// mWorkingHoursEnable = KOPrefs::instance()->mEnableWorkingHours; 2116// mWorkingHoursEnable = KOPrefs::instance()->mEnableWorkingHours;
2078 mWorkingHoursEnable = !mAllDayMode; 2117 mWorkingHoursEnable = !mAllDayMode;
2079 2118
2080 mWorkingHoursYTop = mGridSpacingY * 2119 mWorkingHoursYTop = mGridSpacingY *
2081 KOPrefs::instance()->mWorkingHoursStart * 4; 2120 KOPrefs::instance()->mWorkingHoursStart * 4;
2082 mWorkingHoursYBottom = mGridSpacingY * 2121 mWorkingHoursYBottom = mGridSpacingY *
2083 KOPrefs::instance()->mWorkingHoursEnd * 4 - 1; 2122 KOPrefs::instance()->mWorkingHoursEnd * 4 - 1;
2084} 2123}
2085 2124
2086 2125
2087DateList KOAgenda::dateList() const 2126DateList KOAgenda::dateList() const
2088{ 2127{
2089 return mSelectedDates; 2128 return mSelectedDates;
2090} 2129}
2091 2130
2092void KOAgenda::setDateList(const DateList &selectedDates) 2131void KOAgenda::setDateList(const DateList &selectedDates)
2093{ 2132{
2094 mSelectedDates = selectedDates; 2133 mSelectedDates = selectedDates;
2095 marcus_bains(); 2134 marcus_bains();
2096} 2135}
2097 2136
2098void KOAgenda::setHolidayMask(QMemArray<bool> *mask) 2137void KOAgenda::setHolidayMask(QMemArray<bool> *mask)
2099{ 2138{
2100 mHolidayMask = mask; 2139 mHolidayMask = mask;
2101 2140
2102/* 2141/*
2103 kdDebug() << "HolidayMask: "; 2142 kdDebug() << "HolidayMask: ";
2104 for(uint i=0;i<mask->count();++i) { 2143 for(uint i=0;i<mask->count();++i) {
2105 kdDebug() << (mask->at(i) ? "*" : "o"); 2144 kdDebug() << (mask->at(i) ? "*" : "o");
2106 } 2145 }
2107 kdDebug() << endl; 2146 kdDebug() << endl;
2108*/ 2147*/
2109} 2148}
2110 2149
2111void KOAgenda::contentsMousePressEvent ( QMouseEvent *event ) 2150void KOAgenda::contentsMousePressEvent ( QMouseEvent *event )
2112{ 2151{
2113 2152
2114 QScrollView::contentsMousePressEvent(event); 2153 QScrollView::contentsMousePressEvent(event);
2115} 2154}
2116 2155
2117void KOAgenda::storePosition() 2156void KOAgenda::storePosition()
2118{ 2157{
2119 //mContentPosition 2158 //mContentPosition
2120 int max = mGridSpacingY*4*24; 2159 int max = mGridSpacingY*4*24;
2121 if ( contentsY() < 5 && max > viewport()->height()*3/2 ) 2160 if ( contentsY() < 5 && max > viewport()->height()*3/2 )
2122 mContentPosition = 0; 2161 mContentPosition = 0;
2123 else if ( contentsY() + viewport()->height() > max - 5 && max > viewport()->height()*3/2) 2162 else if ( contentsY() + viewport()->height() > max - 5 && max > viewport()->height()*3/2)
2124 mContentPosition = -1.0; 2163 mContentPosition = -1.0;
2125 else 2164 else
2126 mContentPosition = ((float) max)/ ((float)(contentsY()+ ( viewport()->height()/2))); 2165 mContentPosition = ((float) max)/ ((float)(contentsY()+ ( viewport()->height()/2)));
2127 //qDebug("mContentPosition %f %d %d %d",mContentPosition , max, contentsY() ,viewport()->height()); 2166 //qDebug("mContentPosition %f %d %d %d",mContentPosition , max, contentsY() ,viewport()->height());
2128 2167
2129} 2168}
2130void KOAgenda::restorePosition() 2169void KOAgenda::restorePosition()
2131{ 2170{
2132 int posY; 2171 int posY;
2133 int max = mGridSpacingY*4*24; 2172 int max = mGridSpacingY*4*24;
2134 if ( mContentPosition < 0 ) 2173 if ( mContentPosition < 0 )
2135 posY = max-viewport()->height(); 2174 posY = max-viewport()->height();
2136 else 2175 else
2137 if ( mContentPosition == 0 ) 2176 if ( mContentPosition == 0 )
2138 posY = 0; 2177 posY = 0;
2139 else 2178 else
2140 posY = (max/mContentPosition)-(viewport()->height()/2); 2179 posY = (max/mContentPosition)-(viewport()->height()/2);
2141 setContentsPos (0, posY ); 2180 setContentsPos (0, posY );
2142 //qDebug("posY %d hei %d", posY, max); 2181 //qDebug("posY %d hei %d", posY, max);
2143 2182
2144} 2183}
2145void KOAgenda::moveChild( QWidget *w, int x , int y ) 2184void KOAgenda::moveChild( QWidget *w, int x , int y )
2146{ 2185{
2147 ++x; 2186 ++x;
2148 QScrollView::moveChild( w, x , y ); 2187 QScrollView::moveChild( w, x , y );
2149} 2188}
2150#include <qmessagebox.h> 2189#include <qmessagebox.h>
2151#ifdef DESKTOP_VERSION 2190#ifdef DESKTOP_VERSION
2152#include <qprinter.h> 2191#include <qprinter.h>
2153#include <qpainter.h> 2192#include <qpainter.h>
2154#include <qpaintdevicemetrics.h> 2193#include <qpaintdevicemetrics.h>
2155 2194
2156#endif 2195#endif
2157void KOAgenda::printSelection() 2196void KOAgenda::printSelection()
2158{ 2197{
2159#ifdef DESKTOP_VERSION 2198#ifdef DESKTOP_VERSION
2160 if ( mStartCellY == mCurrentCellY ) { 2199 if ( mStartCellY == mCurrentCellY ) {
2161 int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), 2200 int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),
2162 i18n("Nothing selected!\n\nThis prints the full width of the Agenda view as you see it!\n\nTo determine the vertical range of the printing, please select\na vertical range (with the left mouse button down) in one column. "), 2201 i18n("Nothing selected!\n\nThis prints the full width of the Agenda view as you see it!\n\nTo determine the vertical range of the printing, please select\na vertical range (with the left mouse button down) in one column. "),
2163 i18n("OK"), 0, 0, 2202 i18n("OK"), 0, 0,
2164 0, 1 ); 2203 0, 1 );
2165 return; 2204 return;
2166 } 2205 }
2167 2206
2168 float dx, dy; 2207 float dx, dy;
2169 int x,y,w,h; 2208 int x,y,w,h;
2170 x= 0; 2209 x= 0;
2171 w= contentsWidth()+2; 2210 w= contentsWidth()+2;
2172 // h= contentsHeight(); 2211 // h= contentsHeight();
2173 y = mGridSpacingY*mStartCellY; 2212 y = mGridSpacingY*mStartCellY;
2174 h = mGridSpacingY*(mCurrentCellY+1)-y+2; 2213 h = mGridSpacingY*(mCurrentCellY+1)-y+2;
2175 2214
2176 //return; 2215 //return;
2177 QPrinter* printer = new QPrinter(); 2216 QPrinter* printer = new QPrinter();
2178 if ( !printer->setup()) { 2217 if ( !printer->setup()) {
2179 delete printer; 2218 delete printer;
2180 return; 2219 return;
2181 } 2220 }
2182 QPainter p( printer ); 2221 QPainter p( printer );
2183 QPaintDeviceMetrics m = QPaintDeviceMetrics ( printer ); 2222 QPaintDeviceMetrics m = QPaintDeviceMetrics ( printer );
2184 QString date = i18n("Date range: ")+KGlobal::locale()->formatDate( mSelectedDates.first() )+" - "+KGlobal::locale()->formatDate( mSelectedDates.last() ); 2223 QString date = i18n("Date range: ")+KGlobal::locale()->formatDate( mSelectedDates.first() )+" - "+KGlobal::locale()->formatDate( mSelectedDates.last() );
2185 //date += " --- printing time: " + KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), true ); 2224 //date += " --- printing time: " + KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), true );
2186 int hei = p.boundingRect(0,0, 5, 5, Qt::AlignLeft, date ).height(); 2225 int hei = p.boundingRect(0,0, 5, 5, Qt::AlignLeft, date ).height();
2187 // p.drawText( 0, 0, date ); 2226 // p.drawText( 0, 0, date );
2188 int offset = m.width()/8; 2227 int offset = m.width()/8;
2189 // compute the scale 2228 // compute the scale
2190 dx = ((float) m.width()-offset) / (float)w; 2229 dx = ((float) m.width()-offset) / (float)w;
2191 dy = (float)(m.height() - ( 2 * hei )-offset ) / (float)h; 2230 dy = (float)(m.height() - ( 2 * hei )-offset ) / (float)h;
2192 float scale; 2231 float scale;
2193 // scale to fit the width or height of the paper 2232 // scale to fit the width or height of the paper
2194 if ( dx < dy ) 2233 if ( dx < dy )
2195 scale = dx; 2234 scale = dx;
2196 else 2235 else
2197 scale = dy; 2236 scale = dy;
2198 // set the scale 2237 // set the scale
2199 p.drawText( offset* scale, offset* scale*3/4, date ); 2238 p.drawText( offset* scale, offset* scale*3/4, date );
2200 2239
2201 int selDay; 2240 int selDay;
2202 float widOffset = ((float) m.width()-offset) / ((float)(mSelectedDates.count())); 2241 float widOffset = ((float) m.width()-offset) / ((float)(mSelectedDates.count()));
2203 float startX = 1; 2242 float startX = 1;
2204 for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay) 2243 for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay)
2205 { 2244 {
2206 QString text = KGlobal::locale()->formatDate( mSelectedDates[selDay],true ); 2245 QString text = KGlobal::locale()->formatDate( mSelectedDates[selDay],true );
2207 p.setClipRect(offset* scale+startX , 0, widOffset-4, offset* scale+(2*hei* scale) ); 2246 p.setClipRect(offset* scale+startX , 0, widOffset-4, offset* scale+(2*hei* scale) );
2208 p.drawText( offset* scale+startX, (offset+hei)* scale, text ); 2247 p.drawText( offset* scale+startX, (offset+hei)* scale, text );
2209 startX += widOffset; 2248 startX += widOffset;
2210 2249
2211 } 2250 }
2212 p.translate( offset* scale,offset* scale+ (-y * scale)+(2*hei* scale)); 2251 p.translate( offset* scale,offset* scale+ (-y * scale)+(2*hei* scale));
2213 p.scale( scale, scale ); 2252 p.scale( scale, scale );
2214 p.setClipRect( offset* scale, offset* scale+(2*hei* scale), w*scale, h*scale ); 2253 p.setClipRect( offset* scale, offset* scale+(2*hei* scale), w*scale, h*scale );
2215 // now printing with y offset: 2 hei 2254 // now printing with y offset: 2 hei
2216 // p.translate( 0, -y*scale); 2255 // p.translate( 0, -y*scale);
2217 2256
2218 drawContentsToPainter(&p, true ); 2257 drawContentsToPainter(&p, true );
2219 globalFlagBlockAgendaItemUpdate = false; 2258 globalFlagBlockAgendaItemUpdate = false;
2220 KOAgendaItem *item; 2259 KOAgendaItem *item;
2221 for ( item=mItems.first(); item != 0; item=mItems.next() ) { 2260 for ( item=mItems.first(); item != 0; item=mItems.next() ) {
2222 item->select(false); 2261 item->select(false);
2223 item->paintMe( false, &p ); 2262 item->paintMe( false, &p );
2224 } 2263 }
2225 globalFlagBlockAgendaItemUpdate = true; 2264 globalFlagBlockAgendaItemUpdate = true;
2226 p.end(); 2265 p.end();
2227 delete printer; 2266 delete printer;
2228#else 2267#else
2229 int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), 2268 int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),
2230 i18n("Not supported \non PDA!\n"), 2269 i18n("Not supported \non PDA!\n"),
2231 i18n("OK"), 0, 0, 2270 i18n("OK"), 0, 0,
2232 0, 1 ); 2271 0, 1 );
2233#endif 2272#endif
2234} 2273}
diff --git a/korganizer/koagenda.h b/korganizer/koagenda.h
index 35c08b6..4f1fdb9 100644
--- a/korganizer/koagenda.h
+++ b/korganizer/koagenda.h
@@ -1,296 +1,298 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23#ifndef KOAGENDA_H 23#ifndef KOAGENDA_H
24#define KOAGENDA_H 24#define KOAGENDA_H
25 25
26#include <qscrollview.h> 26#include <qscrollview.h>
27#include <qtimer.h> 27#include <qtimer.h>
28#include <qmemarray.h> 28#include <qmemarray.h>
29#include <qpainter.h> 29#include <qpainter.h>
30#include <qpixmap.h> 30#include <qpixmap.h>
31#include <qguardedptr.h> 31#include <qguardedptr.h>
32 32
33#include "koagendaitem.h" 33#include "koagendaitem.h"
34#include "koeventview.h"
34 35
35class QPopupMenu; 36class QPopupMenu;
36class QTime; 37class QTime;
37class KConfig; 38class KConfig;
38class QFrame; 39class QFrame;
39class KOAgenda; 40class KOAgenda;
40class KCal::Event; 41class KCal::Event;
41class KCal::Todo; 42class KCal::Todo;
42 43
43using namespace KCal; 44using namespace KCal;
44 45
45class MarcusBains : public QFrame { 46class MarcusBains : public QFrame {
46 Q_OBJECT 47 Q_OBJECT
47 public: 48 public:
48 MarcusBains(KOAgenda *agenda=0,const char *name=0); 49 MarcusBains(KOAgenda *agenda=0,const char *name=0);
49 virtual ~MarcusBains(); 50 virtual ~MarcusBains();
50 51
51 public slots: 52 public slots:
52 void updateLocation(bool recalculate=false); 53 void updateLocation(bool recalculate=false);
53 void updateLoc(); 54 void updateLoc();
54 55
55 private: 56 private:
56 int todayColumn(); 57 int todayColumn();
57 QTimer *minutes; 58 QTimer *minutes;
58 QLabel *mTimeBox; 59 QLabel *mTimeBox;
59 KOAgenda *agenda; 60 KOAgenda *agenda;
60 QTime oldTime; 61 QTime oldTime;
61 int oldToday; 62 int oldToday;
62}; 63};
63 64
64 65
65class KOAgenda : public QScrollView 66class KOAgenda : public QScrollView
66{ 67{
67 Q_OBJECT 68 Q_OBJECT
68 public: 69 public:
69 enum MouseActionType { NOP, MOVE, SELECT, 70 enum MouseActionType { NOP, MOVE, SELECT,
70 RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT }; 71 RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT };
71 72
72 KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0, 73 KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0,
73 const char * name=0, WFlags f=0 ); 74 const char * name=0, WFlags f=0 );
74 KOAgenda ( int columns, QWidget * parent=0, 75 KOAgenda ( int columns, QWidget * parent=0,
75 const char * name=0, WFlags f=0 ); 76 const char * name=0, WFlags f=0 );
76 virtual ~KOAgenda(); 77 virtual ~KOAgenda();
77 78
78 Incidence *selectedIncidence() const; 79 Incidence *selectedIncidence() const;
79 QDate selectedIncidenceDate() const; 80 QDate selectedIncidenceDate() const;
80 81
81 virtual bool eventFilter ( QObject *, QEvent * ); 82 virtual bool eventFilter ( QObject *, QEvent * );
82 83
83 void contentsToGrid (int x, int y, int& gx, int& gy); 84 void contentsToGrid (int x, int y, int& gx, int& gy);
84 void gridToContents (int gx, int gy, int& x, int& y); 85 void gridToContents (int gx, int gy, int& x, int& y);
85 86
86 int timeToY (const QTime &time); 87 int timeToY (const QTime &time);
87 QTime gyToTime (int y); 88 QTime gyToTime (int y);
88 89
89 void setStartHour(int startHour); 90 void setStartHour(int startHour);
90 91
91 KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom); 92 KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom);
92 KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd); 93 KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd);
93 void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, 94 void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd,
94 int YTop,int YBottom); 95 int YTop,int YBottom);
95 96
96 void changeColumns(int columns); 97 void changeColumns(int columns);
97 98
98 int columns() { return mColumns; } 99 int columns() { return mColumns; }
99 int rows() { return mRows; } 100 int rows() { return mRows; }
100 101
101 int gridSpacingX() const { return mGridSpacingX; } 102 int gridSpacingX() const { return mGridSpacingX; }
102 int gridSpacingY() const { return mGridSpacingY; } 103 int gridSpacingY() const { return mGridSpacingY; }
103 104
104// virtual QSizePolicy sizePolicy() const; 105// virtual QSizePolicy sizePolicy() const;
105 106
106 void clear(); 107 void clear();
107 108
108 void clearSelection(); 109 void clearSelection();
109 void hideUnused(); 110 void hideUnused();
110 111
111 /** Calculates the minimum width */ 112 /** Calculates the minimum width */
112 virtual int minimumWidth() const; 113 virtual int minimumWidth() const;
113 /** Update configuration from preference settings */ 114 /** Update configuration from preference settings */
114 void updateConfig(); 115 void updateConfig();
115 116
116 void checkScrollBoundaries(); 117 void checkScrollBoundaries();
117 118
118 void setHolidayMask(QMemArray<bool> *); 119 void setHolidayMask(QMemArray<bool> *);
119 void setDateList(const DateList &selectedDates); 120 void setDateList(const DateList &selectedDates);
120 DateList dateList() const; 121 DateList dateList() const;
121 void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false); 122 void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false);
122 void finishUpdate(); 123 void finishUpdate();
123 void printSelection(); 124 void printSelection();
124 void storePosition(); 125 void storePosition();
125 void restorePosition(); 126 void restorePosition();
126 127 void setPopup( KOEventPopupMenu * p ) { mAllAgendaPopup = p; }
127 128
128 public slots: 129 public slots:
129 void popupMenu(); 130 void popupMenu();
130 void newItem( int ); 131 void newItem( int );
131 void moveChild( QWidget *, int, int ); 132 void moveChild( QWidget *, int, int );
132 void scrollUp(); 133 void scrollUp();
133 void scrollDown(); 134 void scrollDown();
134 void updateTodo( Todo * t, int , bool ); 135 void updateTodo( Todo * t, int , bool );
135 void popupAlarm(); 136 void popupAlarm();
136 137
137 void checkScrollBoundaries(int); 138 void checkScrollBoundaries(int);
138 139
139 /** Deselect selected items. This function does not emit any signals. */ 140 /** Deselect selected items. This function does not emit any signals. */
140 void deselectItem(); 141 void deselectItem();
141 /** Select item. If the argument is 0, the currently selected item gets 142 /** Select item. If the argument is 0, the currently selected item gets
142 deselected. This function emits the itemSelected(bool) signal to inform 143 deselected. This function emits the itemSelected(bool) signal to inform
143 about selection/deseelction of events. */ 144 about selection/deseelction of events. */
144 void selectItem(KOAgendaItem *); 145 void selectItem(KOAgendaItem *);
145 void finishResize(); 146 void finishResize();
146 147
147 signals: 148 signals:
148 void showDateView( int, int); 149 void showDateView( int, int);
149 void newEventSignal(); 150 void newEventSignal();
150 void newEventSignal(int gx,int gy); 151 void newEventSignal(int gx,int gy);
151 void newTodoSignal(int gx,int gy); 152 void newTodoSignal(int gx,int gy);
152 void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); 153 void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd);
153 void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); 154 void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd);
154 void newStartSelectSignal(); 155 void newStartSelectSignal();
155 void showIncidenceSignal(Incidence *); 156 void showIncidenceSignal(Incidence *);
156 void editIncidenceSignal(Incidence *); 157 void editIncidenceSignal(Incidence *);
157 void deleteIncidenceSignal(Incidence *); 158 void deleteIncidenceSignal(Incidence *);
158 void showIncidencePopupSignal(Incidence *); 159 void showIncidencePopupSignal(Incidence *);
159 160
160 void itemModified(KOAgendaItem *item, int ); 161 void itemModified(KOAgendaItem *item, int );
161 void incidenceSelected(Incidence *); 162 void incidenceSelected(Incidence *);
162 163
163 void lowerYChanged(int); 164 void lowerYChanged(int);
164 void upperYChanged(int); 165 void upperYChanged(int);
165 166
166 void startDragSignal(Incidence *); 167 void startDragSignal(Incidence *);
167 void addToCalSignal(Incidence *, Incidence *); 168 void addToCalSignal(Incidence *, Incidence *);
168 void resizedSignal(); 169 void resizedSignal();
169 170
170 protected: 171 protected:
172 KOEventPopupMenu * mAllAgendaPopup;
171 QPainter mPixPainter; 173 QPainter mPixPainter;
172 QPixmap mPaintPixmap; 174 QPixmap mPaintPixmap;
173 QPixmap mHighlightPixmap; 175 QPixmap mHighlightPixmap;
174 void drawContents(QPainter *p,int cx, int cy, int cw, int ch); 176 void drawContents(QPainter *p,int cx, int cy, int cw, int ch);
175 virtual void resizeEvent ( QResizeEvent * ); 177 virtual void resizeEvent ( QResizeEvent * );
176 178
177 /** Handles mouse events. Called from eventFilter */ 179 /** Handles mouse events. Called from eventFilter */
178 virtual bool eventFilter_mouse ( QObject *, QMouseEvent * ); 180 virtual bool eventFilter_mouse ( QObject *, QMouseEvent * );
179 181
180 /** Start selecting time span. */ 182 /** Start selecting time span. */
181 void startSelectAction(QPoint viewportPos); 183 void startSelectAction(QPoint viewportPos);
182 184
183 /** Select time span. */ 185 /** Select time span. */
184 void performSelectAction(QPoint viewportPos); 186 void performSelectAction(QPoint viewportPos);
185 187
186 /** Emd selecting time span. */ 188 /** Emd selecting time span. */
187 void endSelectAction( bool emitNewEvent = false ); 189 void endSelectAction( bool emitNewEvent = false );
188 190
189 /** Start moving/resizing agenda item */ 191 /** Start moving/resizing agenda item */
190 void startItemAction(QPoint viewportPos); 192 void startItemAction(QPoint viewportPos);
191 193
192 /** Move/resize agenda item */ 194 /** Move/resize agenda item */
193 void performItemAction(QPoint viewportPos); 195 void performItemAction(QPoint viewportPos);
194 196
195 /** End moving/resizing agenda item */ 197 /** End moving/resizing agenda item */
196 void endItemAction(); 198 void endItemAction();
197 199
198 /** Set cursor, when no item action is in progress */ 200 /** Set cursor, when no item action is in progress */
199 void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos); 201 void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos);
200 202
201 /** Place agenda item in agenda and adjust other cells if necessary */ 203 /** Place agenda item in agenda and adjust other cells if necessary */
202 void placeSubCells(KOAgendaItem *placeItem); 204 void placeSubCells(KOAgendaItem *placeItem);
203 205
204 /** Process the keyevent, including the ignored keyevents of eventwidgets. 206 /** Process the keyevent, including the ignored keyevents of eventwidgets.
205 * Implements pgup/pgdn and cursor key navigation in the view. 207 * Implements pgup/pgdn and cursor key navigation in the view.
206 */ 208 */
207 void keyPressEvent( QKeyEvent * ); 209 void keyPressEvent( QKeyEvent * );
208 210
209 void calculateWorkingHours(); 211 void calculateWorkingHours();
210 212
211 virtual void contentsMousePressEvent ( QMouseEvent * ); 213 virtual void contentsMousePressEvent ( QMouseEvent * );
212 214
213 private: 215 private:
214 void init(); 216 void init();
215 void marcus_bains(); 217 void marcus_bains();
216 bool mAllDayMode; 218 bool mAllDayMode;
217 bool blockResize; 219 bool blockResize;
218 bool mLeftMouseDown; 220 bool mLeftMouseDown;
219 KOAgendaItem *mPopupItem; 221 KOAgendaItem *mPopupItem;
220 QTimer* mPopupTimer; 222 QTimer* mPopupTimer;
221 int mPopupKind; 223 int mPopupKind;
222 QPoint mPopupPos; 224 QPoint mPopupPos;
223 QTimer mResizeTimer; 225 QTimer mResizeTimer;
224 double mContentPosition; 226 double mContentPosition;
225 227
226 // Width and height of agenda cells 228 // Width and height of agenda cells
227 int mGridSpacingX; 229 int mGridSpacingX;
228 int mGridSpacingY; 230 int mGridSpacingY;
229 231
230 // size of border, where mouse action will resize the KOAgendaItem 232 // size of border, where mouse action will resize the KOAgendaItem
231 int mResizeBorderWidth; 233 int mResizeBorderWidth;
232 234
233 // size of border, where mouse mve will cause a scroll of the agenda 235 // size of border, where mouse mve will cause a scroll of the agenda
234 int mScrollBorderWidth; 236 int mScrollBorderWidth;
235 int mScrollDelay; 237 int mScrollDelay;
236 int mScrollOffset; 238 int mScrollOffset;
237 239
238 QTimer mScrollUpTimer; 240 QTimer mScrollUpTimer;
239 QTimer mScrollDownTimer; 241 QTimer mScrollDownTimer;
240 242
241 // Number of Columns/Rows of agenda grid 243 // Number of Columns/Rows of agenda grid
242 int mColumns; 244 int mColumns;
243 int mRows; 245 int mRows;
244 246
245 // Cells to store Move and Resize coordiantes 247 // Cells to store Move and Resize coordiantes
246 int mStartCellX; 248 int mStartCellX;
247 int mStartCellY; 249 int mStartCellY;
248 int mCurrentCellX; 250 int mCurrentCellX;
249 int mCurrentCellY; 251 int mCurrentCellY;
250 252
251 // Working Hour coordiantes 253 // Working Hour coordiantes
252 bool mWorkingHoursEnable; 254 bool mWorkingHoursEnable;
253 int mWorkingHoursYTop; 255 int mWorkingHoursYTop;
254 int mWorkingHoursYBottom; 256 int mWorkingHoursYBottom;
255 257
256 // Selection 258 // Selection
257 int mSelectionCellX; 259 int mSelectionCellX;
258 int mSelectionYTop; 260 int mSelectionYTop;
259 int mSelectionHeight; 261 int mSelectionHeight;
260 262
261 // List of dates to be displayed 263 // List of dates to be displayed
262 DateList mSelectedDates; 264 DateList mSelectedDates;
263 265
264 // The KOAgendaItem, which has been right-clicked last 266 // The KOAgendaItem, which has been right-clicked last
265 KOAgendaItem *mClickedItem; 267 KOAgendaItem *mClickedItem;
266 268
267 // The KOAgendaItem, which is being moved/resized 269 // The KOAgendaItem, which is being moved/resized
268 QGuardedPtr<KOAgendaItem> mActionItem; 270 QGuardedPtr<KOAgendaItem> mActionItem;
269 271
270 // Currently selected item 272 // Currently selected item
271 QGuardedPtr<KOAgendaItem> mSelectedItem; 273 QGuardedPtr<KOAgendaItem> mSelectedItem;
272 274
273 // The Marcus Bains Line widget. 275 // The Marcus Bains Line widget.
274 MarcusBains *mMarcusBains; 276 MarcusBains *mMarcusBains;
275 void computeSizes(); 277 void computeSizes();
276 278
277 MouseActionType mActionType; 279 MouseActionType mActionType;
278 280
279 bool mItemMoved; 281 bool mItemMoved;
280 282
281 // List of all Items contained in agenda 283 // List of all Items contained in agenda
282 QPtrList<KOAgendaItem> mItems; 284 QPtrList<KOAgendaItem> mItems;
283 QPtrList<KOAgendaItem> mUnusedItems; 285 QPtrList<KOAgendaItem> mUnusedItems;
284 KOAgendaItem* getNewItem(Incidence * event,QDate qd, QWidget* viewport); 286 KOAgendaItem* getNewItem(Incidence * event,QDate qd, QWidget* viewport);
285 QPopupMenu *mItemPopup; // Right mouse button popup menu for KOAgendaItems 287 QPopupMenu *mItemPopup; // Right mouse button popup menu for KOAgendaItems
286 QPopupMenu *mNewItemPopup; 288 QPopupMenu *mNewItemPopup;
287 289
288 int mOldLowerScrollValue; 290 int mOldLowerScrollValue;
289 int mOldUpperScrollValue; 291 int mOldUpperScrollValue;
290 KOAgendaItem * getItemForTodo ( Todo * todo ); 292 KOAgendaItem * getItemForTodo ( Todo * todo );
291 QMemArray<bool> *mHolidayMask; 293 QMemArray<bool> *mHolidayMask;
292 int mCurPixWid; 294 int mCurPixWid;
293 int mCurPixHei; 295 int mCurPixHei;
294}; 296};
295 297
296#endif // KOAGENDA_H 298#endif // KOAGENDA_H
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp
index 8d32152..95388ef 100644
--- a/korganizer/koagendaview.cpp
+++ b/korganizer/koagendaview.cpp
@@ -1,1700 +1,1702 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24#include <qhbox.h> 24#include <qhbox.h>
25#include <qvbox.h> 25#include <qvbox.h>
26#include <qlabel.h> 26#include <qlabel.h>
27#include <qframe.h> 27#include <qframe.h>
28#include <qlayout.h> 28#include <qlayout.h>
29#ifndef KORG_NOSPLITTER 29#ifndef KORG_NOSPLITTER
30#include <qsplitter.h> 30#include <qsplitter.h>
31#endif 31#endif
32#include <qfont.h> 32#include <qfont.h>
33#include <qfontmetrics.h> 33#include <qfontmetrics.h>
34#include <qpopupmenu.h> 34#include <qpopupmenu.h>
35#include <qtooltip.h> 35#include <qtooltip.h>
36#include <qpainter.h> 36#include <qpainter.h>
37#include <qpushbutton.h> 37#include <qpushbutton.h>
38#include <qapplication.h> 38#include <qapplication.h>
39 39
40#include <kapplication.h> 40#include <kapplication.h>
41#include <KDGanttMinimizeSplitter.h> 41#include <KDGanttMinimizeSplitter.h>
42#include <kdebug.h> 42#include <kdebug.h>
43#include <kstandarddirs.h> 43#include <kstandarddirs.h>
44#include <kiconloader.h> 44#include <kiconloader.h>
45#include <klocale.h> 45#include <klocale.h>
46#include <kconfig.h> 46#include <kconfig.h>
47#include <kglobal.h> 47#include <kglobal.h>
48#include "calendarview.h" 48#include "calendarview.h"
49#include "koviewmanager.h" 49#include "koviewmanager.h"
50 50
51#include <libkcal/calendar.h> 51#include <libkcal/calendar.h>
52#include <libkcal/icaldrag.h> 52#include <libkcal/icaldrag.h>
53#include <libkcal/dndfactory.h> 53#include <libkcal/dndfactory.h>
54 54
55#include <kcalendarsystem.h> 55#include <kcalendarsystem.h>
56 56
57#include "koglobals.h" 57#include "koglobals.h"
58#ifndef KORG_NOPLUGINS 58#ifndef KORG_NOPLUGINS
59#include "kocore.h" 59#include "kocore.h"
60#endif 60#endif
61#include "koprefs.h" 61#include "koprefs.h"
62#include "koagenda.h" 62#include "koagenda.h"
63#include "koagendaitem.h" 63#include "koagendaitem.h"
64#ifndef KORG_NOPRINTER 64#ifndef KORG_NOPRINTER
65#include "calprinter.h" 65#include "calprinter.h"
66#endif 66#endif
67 67
68#include "koagendaview.h" 68#include "koagendaview.h"
69//#include "koagendaview.moc" 69//#include "koagendaview.moc"
70 70
71//extern bool globalFlagBlockPainting; 71//extern bool globalFlagBlockPainting;
72extern int globalFlagBlockAgenda; 72extern int globalFlagBlockAgenda;
73extern int globalFlagBlockStartup; 73extern int globalFlagBlockStartup;
74extern int globalFlagBlockAgendaItemPaint; 74extern int globalFlagBlockAgendaItemPaint;
75extern int globalFlagBlockAgendaItemUpdate; 75extern int globalFlagBlockAgendaItemUpdate;
76extern int globalFlagBlockLabel; 76extern int globalFlagBlockLabel;
77using namespace KOrg; 77using namespace KOrg;
78 78
79 79
80 80
81TimeLabels::TimeLabels(int rows,QWidget *parent,const char *name,WFlags f) : 81TimeLabels::TimeLabels(int rows,QWidget *parent,const char *name,WFlags f) :
82 QScrollView(parent,name,f) 82 QScrollView(parent,name,f)
83{ 83{
84 myPix.resize( 1, 1 ); 84 myPix.resize( 1, 1 );
85 mRows = rows; 85 mRows = rows;
86 86
87 mRedrawNeeded = true; 87 mRedrawNeeded = true;
88 setMinimumHeight( 20 ); 88 setMinimumHeight( 20 );
89 mCellHeight = KOPrefs::instance()->mHourSize*4; 89 mCellHeight = KOPrefs::instance()->mHourSize*4;
90 90
91 enableClipper(true); 91 enableClipper(true);
92 92
93 setHScrollBarMode(AlwaysOff); 93 setHScrollBarMode(AlwaysOff);
94 setVScrollBarMode(AlwaysOff); 94 setVScrollBarMode(AlwaysOff);
95 95
96 resizeContents(50,mRows * mCellHeight); 96 resizeContents(50,mRows * mCellHeight);
97 97
98 viewport()->setBackgroundMode( PaletteBackground ); 98 viewport()->setBackgroundMode( PaletteBackground );
99} 99}
100 100
101void TimeLabels::setCellHeight(int height) 101void TimeLabels::setCellHeight(int height)
102{ 102{
103 mCellHeight = height; 103 mCellHeight = height;
104} 104}
105 105
106/* 106/*
107 Optimization so that only the "dirty" portion of the scroll view 107 Optimization so that only the "dirty" portion of the scroll view
108 is redrawn. Unfortunately, this is not called by default paintEvent() method. 108 is redrawn. Unfortunately, this is not called by default paintEvent() method.
109*/ 109*/
110void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) 110void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch)
111{ 111{
112 112
113 cx = contentsX() + frameWidth()*2; 113 cx = contentsX() + frameWidth()*2;
114 cw = contentsWidth() ; 114 cw = contentsWidth() ;
115 // end of workaround 115 // end of workaround
116 116
117 int cell = ((int)(cy/mCellHeight)); 117 int cell = ((int)(cy/mCellHeight));
118 int y = cell * mCellHeight; 118 int y = cell * mCellHeight;
119 QFontMetrics fm = fontMetrics(); 119 QFontMetrics fm = fontMetrics();
120 QString hour; 120 QString hour;
121 QString suffix = "am"; 121 QString suffix = "am";
122 int timeHeight = fm.ascent(); 122 int timeHeight = fm.ascent();
123 QFont nFont = p->font(); 123 QFont nFont = p->font();
124 124
125 if (!KGlobal::locale()->use12Clock()) { 125 if (!KGlobal::locale()->use12Clock()) {
126 if ( QApplication::desktop()->width() <= 320 ) 126 if ( QApplication::desktop()->width() <= 320 )
127 suffix = "00"; 127 suffix = "00";
128 else 128 else
129 suffix = "00"; 129 suffix = "00";
130 } 130 }
131 131
132 if ( timeHeight > mCellHeight ) { 132 if ( timeHeight > mCellHeight ) {
133 timeHeight = mCellHeight-1; 133 timeHeight = mCellHeight-1;
134 int pointS = nFont.pointSize(); 134 int pointS = nFont.pointSize();
135 while ( pointS > 4 ) { 135 while ( pointS > 4 ) {
136 nFont.setPointSize( pointS ); 136 nFont.setPointSize( pointS );
137 fm = QFontMetrics( nFont ); 137 fm = QFontMetrics( nFont );
138 if ( fm.ascent() < mCellHeight ) 138 if ( fm.ascent() < mCellHeight )
139 break; 139 break;
140 -- pointS; 140 -- pointS;
141 } 141 }
142 fm = QFontMetrics( nFont ); 142 fm = QFontMetrics( nFont );
143 timeHeight = fm.ascent(); 143 timeHeight = fm.ascent();
144 } 144 }
145 //timeHeight -= (timeHeight/4-2); 145 //timeHeight -= (timeHeight/4-2);
146 QFont sFont = nFont; 146 QFont sFont = nFont;
147 sFont.setPointSize( sFont.pointSize()/2 ); 147 sFont.setPointSize( sFont.pointSize()/2 );
148 QFontMetrics fmS( sFont ); 148 QFontMetrics fmS( sFont );
149 int sHei = fmS.ascent() ; 149 int sHei = fmS.ascent() ;
150 //sHei -= (sHei/4-2); 150 //sHei -= (sHei/4-2);
151 int startW = this->width() - frameWidth()-2; 151 int startW = this->width() - frameWidth()-2;
152 int tw2 = fmS.width(suffix); 152 int tw2 = fmS.width(suffix);
153 timeHeight = (timeHeight-1) /2 -1; 153 timeHeight = (timeHeight-1) /2 -1;
154 while (y < cy + ch+mCellHeight) { 154 while (y < cy + ch+mCellHeight) {
155 p->drawLine(startW-tw2+1 ,y,cw,y); 155 p->drawLine(startW-tw2+1 ,y,cw,y);
156 hour.setNum(cell); 156 hour.setNum(cell);
157 // handle 24h and am/pm time formats 157 // handle 24h and am/pm time formats
158 if (KGlobal::locale()->use12Clock()) { 158 if (KGlobal::locale()->use12Clock()) {
159 if (cell > 11) suffix = "pm"; 159 if (cell > 11) suffix = "pm";
160 else 160 else
161 suffix = "am"; 161 suffix = "am";
162 if (cell == 0) hour.setNum(12); 162 if (cell == 0) hour.setNum(12);
163 if (cell > 12) hour.setNum(cell - 12); 163 if (cell > 12) hour.setNum(cell - 12);
164 } 164 }
165 165
166 // center and draw the time label 166 // center and draw the time label
167 int timeWidth = fm.width(hour); 167 int timeWidth = fm.width(hour);
168 int offset = startW - timeWidth - tw2 ; 168 int offset = startW - timeWidth - tw2 ;
169 p->setFont( nFont ); 169 p->setFont( nFont );
170 p->drawText( offset, y+ timeHeight, hour); 170 p->drawText( offset, y+ timeHeight, hour);
171 p->setFont( sFont ); 171 p->setFont( sFont );
172 offset = startW - tw2+1; 172 offset = startW - tw2+1;
173 p->drawText( offset, y -1, suffix); 173 p->drawText( offset, y -1, suffix);
174 174
175 // increment indices 175 // increment indices
176 y += mCellHeight; 176 y += mCellHeight;
177 cell++; 177 cell++;
178 } 178 }
179 179
180 180
181 181
182 182
183#if 0 183#if 0
184 mRedrawNeeded = true; 184 mRedrawNeeded = true;
185 if ( mRedrawNeeded ) { 185 if ( mRedrawNeeded ) {
186 cx = contentsX() + frameWidth()*2; 186 cx = contentsX() + frameWidth()*2;
187 cw = contentsWidth() ; 187 cw = contentsWidth() ;
188 // end of workaround 188 // end of workaround
189 189
190 int cell = ((int)(cy/mCellHeight)); 190 int cell = ((int)(cy/mCellHeight));
191 int y = cell * mCellHeight; 191 int y = cell * mCellHeight;
192 QFontMetrics fm = fontMetrics(); 192 QFontMetrics fm = fontMetrics();
193 QString hour; 193 QString hour;
194 QString suffix; 194 QString suffix;
195 int timeHeight = fm.ascent(); 195 int timeHeight = fm.ascent();
196 QFont nFont = p->font(); 196 QFont nFont = p->font();
197 197
198 if (!KGlobal::locale()->use12Clock()) { 198 if (!KGlobal::locale()->use12Clock()) {
199 if ( QApplication::desktop()->width() <= 320 ) 199 if ( QApplication::desktop()->width() <= 320 )
200 suffix = ""; 200 suffix = "";
201 else 201 else
202 suffix = "00"; 202 suffix = "00";
203 } 203 }
204 204
205 if ( timeHeight > mCellHeight ) { 205 if ( timeHeight > mCellHeight ) {
206 timeHeight = mCellHeight-1; 206 timeHeight = mCellHeight-1;
207 int pointS = nFont.pointSize(); 207 int pointS = nFont.pointSize();
208 while ( pointS > 4 ) { 208 while ( pointS > 4 ) {
209 nFont.setPointSize( pointS ); 209 nFont.setPointSize( pointS );
210 fm = QFontMetrics( nFont ); 210 fm = QFontMetrics( nFont );
211 if ( fm.ascent() < mCellHeight ) 211 if ( fm.ascent() < mCellHeight )
212 break; 212 break;
213 -- pointS; 213 -- pointS;
214 } 214 }
215 fm = QFontMetrics( nFont ); 215 fm = QFontMetrics( nFont );
216 timeHeight = fm.ascent(); 216 timeHeight = fm.ascent();
217 } 217 }
218 //timeHeight -= (timeHeight/4-2); 218 //timeHeight -= (timeHeight/4-2);
219 QFont sFont = nFont; 219 QFont sFont = nFont;
220 sFont.setPointSize( sFont.pointSize()/2 ); 220 sFont.setPointSize( sFont.pointSize()/2 );
221 QFontMetrics fmS( sFont ); 221 QFontMetrics fmS( sFont );
222 int sHei = fmS.ascent() ; 222 int sHei = fmS.ascent() ;
223 //sHei -= (sHei/4-2); 223 //sHei -= (sHei/4-2);
224 int startW = this->width() - frameWidth()-2; 224 int startW = this->width() - frameWidth()-2;
225 int tw2 = fmS.width(suffix); 225 int tw2 = fmS.width(suffix);
226 while (y < cy + ch) { 226 while (y < cy + ch) {
227 p->drawLine(cx,y,cw,y); 227 p->drawLine(cx,y,cw,y);
228 hour.setNum(cell); 228 hour.setNum(cell);
229 // handle 24h and am/pm time formats 229 // handle 24h and am/pm time formats
230 if (KGlobal::locale()->use12Clock()) { 230 if (KGlobal::locale()->use12Clock()) {
231 if (cell > 11) suffix = "pm"; 231 if (cell > 11) suffix = "pm";
232 else 232 else
233 suffix = "am"; 233 suffix = "am";
234 if (cell == 0) hour.setNum(12); 234 if (cell == 0) hour.setNum(12);
235 if (cell > 12) hour.setNum(cell - 12); 235 if (cell > 12) hour.setNum(cell - 12);
236 tw2 = fmS.width(suffix); 236 tw2 = fmS.width(suffix);
237 } 237 }
238 238
239 // center and draw the time label 239 // center and draw the time label
240 int timeWidth = fm.width(hour); 240 int timeWidth = fm.width(hour);
241 int offset = startW - timeWidth - tw2 ; 241 int offset = startW - timeWidth - tw2 ;
242 p->setFont( nFont ); 242 p->setFont( nFont );
243 p->drawText( offset, y+ timeHeight, hour); 243 p->drawText( offset, y+ timeHeight, hour);
244 p->setFont( sFont ); 244 p->setFont( sFont );
245 offset = startW - tw2+1; 245 offset = startW - tw2+1;
246 p->drawText( offset, y+ sHei, suffix); 246 p->drawText( offset, y+ sHei, suffix);
247 247
248 // increment indices 248 // increment indices
249 y += mCellHeight; 249 y += mCellHeight;
250 cell++; 250 cell++;
251 } 251 }
252 } else { 252 } else {
253 //qDebug("NO redraw "); 253 //qDebug("NO redraw ");
254 } 254 }
255 // double buffer not yet implemented 255 // double buffer not yet implemented
256 //bitBlt (this, 0, 0, &myPix, 0 ,0,width(), height() ,CopyROP); 256 //bitBlt (this, 0, 0, &myPix, 0 ,0,width(), height() ,CopyROP);
257 //mRedrawNeeded = false; 257 //mRedrawNeeded = false;
258#endif 258#endif
259} 259}
260 260
261/** 261/**
262 Calculates the minimum width. 262 Calculates the minimum width.
263*/ 263*/
264int TimeLabels::minimumWidth() const 264int TimeLabels::minimumWidth() const
265{ 265{
266 return mMiniWidth; 266 return mMiniWidth;
267} 267}
268 268
269/** updates widget's internal state */ 269/** updates widget's internal state */
270void TimeLabels::updateConfig() 270void TimeLabels::updateConfig()
271{ 271{
272 mRedrawNeeded = true; 272 mRedrawNeeded = true;
273 // set the font 273 // set the font
274 // config->setGroup("Fonts"); 274 // config->setGroup("Fonts");
275 // QFont font = config->readFontEntry("TimeBar Font"); 275 // QFont font = config->readFontEntry("TimeBar Font");
276 setFont(KOPrefs::instance()->mTimeBarFont); 276 setFont(KOPrefs::instance()->mTimeBarFont);
277 QString test = "20"; 277 QString test = "20";
278 if (KGlobal::locale()->use12Clock()) 278 if (KGlobal::locale()->use12Clock())
279 test = "12"; 279 test = "12";
280 mMiniWidth = fontMetrics().width(test); 280 mMiniWidth = fontMetrics().width(test);
281 if (KGlobal::locale()->use12Clock()) 281 if (KGlobal::locale()->use12Clock())
282 test = "pm"; 282 test = "pm";
283 else { 283 else {
284 if ( QApplication::desktop()->width() <= 320 ) 284 if ( QApplication::desktop()->width() <= 320 )
285 test = "00"; 285 test = "00";
286 else 286 else
287 test = "00"; 287 test = "00";
288 } 288 }
289 QFont sFont = font(); 289 QFont sFont = font();
290 sFont.setPointSize( sFont.pointSize()/2 ); 290 sFont.setPointSize( sFont.pointSize()/2 );
291 QFontMetrics fmS( sFont ); 291 QFontMetrics fmS( sFont );
292 mMiniWidth += fmS.width( test ) + frameWidth()*2 +4 ; 292 mMiniWidth += fmS.width( test ) + frameWidth()*2 +4 ;
293 // update geometry restrictions based on new settings 293 // update geometry restrictions based on new settings
294 setFixedWidth( mMiniWidth ); 294 setFixedWidth( mMiniWidth );
295 295
296 // update HourSize 296 // update HourSize
297 mCellHeight = KOPrefs::instance()->mHourSize*4; 297 mCellHeight = KOPrefs::instance()->mHourSize*4;
298 resizeContents(50,mRows * mCellHeight); 298 resizeContents(50,mRows * mCellHeight);
299} 299}
300 300
301/** update time label positions */ 301/** update time label positions */
302void TimeLabels::positionChanged() 302void TimeLabels::positionChanged()
303{ 303{
304 int adjustment = mAgenda->contentsY(); 304 int adjustment = mAgenda->contentsY();
305 setContentsPos(0, adjustment); 305 setContentsPos(0, adjustment);
306} 306}
307 307
308/** */ 308/** */
309void TimeLabels::setAgenda(KOAgenda* agenda) 309void TimeLabels::setAgenda(KOAgenda* agenda)
310{ 310{
311 mAgenda = agenda; 311 mAgenda = agenda;
312} 312}
313 313
314void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) 314void TimeLabels::contentsMousePressEvent ( QMouseEvent * e)
315{ 315{
316 mMouseDownY = e->pos().y(); 316 mMouseDownY = e->pos().y();
317 mOrgCap = topLevelWidget()->caption(); 317 mOrgCap = topLevelWidget()->caption();
318} 318}
319 319
320void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) 320void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e )
321{ 321{
322 int diff = mMouseDownY - e->pos().y(); 322 int diff = mMouseDownY - e->pos().y();
323 if ( diff < 10 && diff > -10 ) 323 if ( diff < 10 && diff > -10 )
324 return; 324 return;
325 int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; 325 int tSize = KOPrefs::instance()->mHourSize + (diff/10) ;
326 if ( tSize < 4 ) 326 if ( tSize < 4 )
327 tSize = 4; 327 tSize = 4;
328 if ( tSize > 22 ) 328 if ( tSize > 22 )
329 tSize = 22; 329 tSize = 22;
330 tSize = (tSize-2)/2; 330 tSize = (tSize-2)/2;
331 topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); 331 topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize));
332 332
333} 333}
334void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) 334void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e )
335{ 335{
336 topLevelWidget()->setCaption( mOrgCap ); 336 topLevelWidget()->setCaption( mOrgCap );
337 int diff = mMouseDownY - e->pos().y(); 337 int diff = mMouseDownY - e->pos().y();
338 if ( diff < 10 && diff > -10 ) 338 if ( diff < 10 && diff > -10 )
339 return; 339 return;
340 int tSize = KOPrefs::instance()->mHourSize + (diff/10); 340 int tSize = KOPrefs::instance()->mHourSize + (diff/10);
341 if ( tSize < 4 ) 341 if ( tSize < 4 )
342 tSize = 4; 342 tSize = 4;
343 if ( tSize > 22 ) 343 if ( tSize > 22 )
344 tSize = 22; 344 tSize = 22;
345 tSize = (tSize/2)*2; 345 tSize = (tSize/2)*2;
346 if ( tSize == KOPrefs::instance()->mHourSize ) 346 if ( tSize == KOPrefs::instance()->mHourSize )
347 return; 347 return;
348 KOPrefs::instance()->mHourSize = tSize; 348 KOPrefs::instance()->mHourSize = tSize;
349 emit scaleChanged(); 349 emit scaleChanged();
350} 350}
351 351
352/** This is called in response to repaint() */ 352/** This is called in response to repaint() */
353void TimeLabels::paintEvent(QPaintEvent*) 353void TimeLabels::paintEvent(QPaintEvent*)
354{ 354{
355 355
356 // kdDebug() << "paintevent..." << endl; 356 // kdDebug() << "paintevent..." << endl;
357 // this is another hack! 357 // this is another hack!
358 // QPainter painter(this); 358 // QPainter painter(this);
359 //QString c 359 //QString c
360 repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); 360 repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight());
361} 361}
362 362
363//////////////////////////////////////////////////////////////////////////// 363////////////////////////////////////////////////////////////////////////////
364 364
365EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) 365EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name)
366 : QFrame(parent,name) 366 : QFrame(parent,name)
367{ 367{
368 mColumns = 1; 368 mColumns = 1;
369 mTopBox = 0; 369 mTopBox = 0;
370 mLocation = loc; 370 mLocation = loc;
371 mTopLayout = 0; 371 mTopLayout = 0;
372 mPaintWidget = 0; 372 mPaintWidget = 0;
373 mXOffset = 0; 373 mXOffset = 0;
374 if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); 374 if (mLocation == Top) mPixmap = SmallIcon("1uparrow");
375 else mPixmap = SmallIcon("1downarrow"); 375 else mPixmap = SmallIcon("1downarrow");
376 mEnabled.resize(mColumns); 376 mEnabled.resize(mColumns);
377 mEnabled.fill( false ); 377 mEnabled.fill( false );
378 setMinimumHeight(mPixmap.height()); 378 setMinimumHeight(mPixmap.height());
379} 379}
380 380
381EventIndicator::~EventIndicator() 381EventIndicator::~EventIndicator()
382{ 382{
383} 383}
384 384
385void EventIndicator::drawContents(QPainter *p) 385void EventIndicator::drawContents(QPainter *p)
386{ 386{
387 387
388 // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; 388 // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl;
389 KDGanttSplitterHandle* han = 0; 389 KDGanttSplitterHandle* han = 0;
390 if ( mPaintWidget ) 390 if ( mPaintWidget )
391 han = mPaintWidget->firstHandle(); 391 han = mPaintWidget->firstHandle();
392 if ( ! han ) { 392 if ( ! han ) {
393 int i; 393 int i;
394 for(i=0;i<mColumns;++i) { 394 for(i=0;i<mColumns;++i) {
395 if (mEnabled[i]) { 395 if (mEnabled[i]) {
396 int cellWidth = contentsRect().right()/mColumns; 396 int cellWidth = contentsRect().right()/mColumns;
397 int xOffset = KOGlobals::self()->reverseLayout() ? 397 int xOffset = KOGlobals::self()->reverseLayout() ?
398 (mColumns - 1 - i)*cellWidth + (cellWidth -mPixmap.width())/2 : 398 (mColumns - 1 - i)*cellWidth + (cellWidth -mPixmap.width())/2 :
399 i*cellWidth + (cellWidth -mPixmap.width()) /2; 399 i*cellWidth + (cellWidth -mPixmap.width()) /2;
400 p->drawPixmap(QPoint(1+xOffset,0),mPixmap); 400 p->drawPixmap(QPoint(1+xOffset,0),mPixmap);
401 } 401 }
402 } 402 }
403 } else { 403 } else {
404 han->repaint(); 404 han->repaint();
405 //mPaintWidget->setBackgroundColor( red ); 405 //mPaintWidget->setBackgroundColor( red );
406 406
407 QPainter pa( han ); 407 QPainter pa( han );
408 int i; 408 int i;
409 bool setColor = false; 409 bool setColor = false;
410 for(i=0;i<mColumns;++i) { 410 for(i=0;i<mColumns;++i) {
411 if (mEnabled[i]) { 411 if (mEnabled[i]) {
412 setColor = true; 412 setColor = true;
413 413
414 int cellWidth = contentsRect().right()/mColumns; 414 int cellWidth = contentsRect().right()/mColumns;
415 int xOffset = KOGlobals::self()->reverseLayout() ? 415 int xOffset = KOGlobals::self()->reverseLayout() ?
416 (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : 416 (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 :
417 i*cellWidth + cellWidth/2 -mPixmap.width()/2; 417 i*cellWidth + cellWidth/2 -mPixmap.width()/2;
418 pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); 418 pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap);
419 //qDebug("222draw pix %d ",xOffset ); 419 //qDebug("222draw pix %d ",xOffset );
420 420
421 } 421 }
422 422
423 } 423 }
424 pa.end(); 424 pa.end();
425 425
426 } 426 }
427} 427}
428 428
429void EventIndicator::setXOffset( int x ) 429void EventIndicator::setXOffset( int x )
430{ 430{
431 mXOffset = x; 431 mXOffset = x;
432} 432}
433void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) 433void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w )
434{ 434{
435 mPaintWidget = w; 435 mPaintWidget = w;
436 setMaximumHeight(0); 436 setMaximumHeight(0);
437 setMinimumHeight(0); 437 setMinimumHeight(0);
438} 438}
439void EventIndicator::changeColumns(int columns) 439void EventIndicator::changeColumns(int columns)
440{ 440{
441 mColumns = columns; 441 mColumns = columns;
442 mEnabled.resize(mColumns); 442 mEnabled.resize(mColumns);
443 443
444 update(); 444 update();
445} 445}
446 446
447void EventIndicator::enableColumn(int column, bool enable) 447void EventIndicator::enableColumn(int column, bool enable)
448{ 448{
449 mEnabled[column] = enable; 449 mEnabled[column] = enable;
450} 450}
451 451
452 452
453//////////////////////////////////////////////////////////////////////////// 453////////////////////////////////////////////////////////////////////////////
454//////////////////////////////////////////////////////////////////////////// 454////////////////////////////////////////////////////////////////////////////
455//////////////////////////////////////////////////////////////////////////// 455////////////////////////////////////////////////////////////////////////////
456 456
457KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : 457KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) :
458 KOEventView (cal,parent,name) 458 KOEventView (cal,parent,name)
459{ 459{
460 mBlockUpdating = true; 460 mBlockUpdating = true;
461 mStartHour = 8; 461 mStartHour = 8;
462 mSelectedDates.append(QDate::currentDate()); 462 mSelectedDates.append(QDate::currentDate());
463 463
464 mLayoutDayLabels = 0; 464 mLayoutDayLabels = 0;
465 mDayLabelsFrame = 0; 465 mDayLabelsFrame = 0;
466 mDayLabels = 0; 466 mDayLabels = 0;
467 bool isRTL = KOGlobals::self()->reverseLayout(); 467 bool isRTL = KOGlobals::self()->reverseLayout();
468 QPixmap expandPix; 468 QPixmap expandPix;
469 if ( KOPrefs::instance()->mVerticalScreen ) { 469 if ( KOPrefs::instance()->mVerticalScreen ) {
470 expandPix = SmallIcon( "1updownarrow" ); 470 expandPix = SmallIcon( "1updownarrow" );
471 } else { 471 } else {
472 expandPix = SmallIcon("1leftrightarrow" ); 472 expandPix = SmallIcon("1leftrightarrow" );
473 } 473 }
474 474
475 QBoxLayout *topLayout = new QVBoxLayout(this); 475 QBoxLayout *topLayout = new QVBoxLayout(this);
476 476
477 // Create day name labels for agenda columns 477 // Create day name labels for agenda columns
478 // Create agenda splitter 478 // Create agenda splitter
479 479
480 mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); 480 mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this);
481 mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); 481 mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up );
482 topLayout->addWidget( mSplitterAgenda ); 482 topLayout->addWidget( mSplitterAgenda );
483 mAllDayFrame = new QHBox(mSplitterAgenda); 483 mAllDayFrame = new QHBox(mSplitterAgenda);
484 mAllDayFrame->setFocusPolicy(NoFocus); 484 mAllDayFrame->setFocusPolicy(NoFocus);
485 QWidget *agendaFrame = new QWidget(mSplitterAgenda); 485 QWidget *agendaFrame = new QWidget(mSplitterAgenda);
486 agendaFrame->setFocusPolicy(NoFocus); 486 agendaFrame->setFocusPolicy(NoFocus);
487 487
488 // Create all-day agenda widget 488 // Create all-day agenda widget
489 mDummyAllDayLeft = new QVBox( mAllDayFrame ); 489 mDummyAllDayLeft = new QVBox( mAllDayFrame );
490 490
491 mExpandButton = new QPushButton(mDummyAllDayLeft); 491 mExpandButton = new QPushButton(mDummyAllDayLeft);
492 mExpandButton->setPixmap( expandPix ); 492 mExpandButton->setPixmap( expandPix );
493 int widebut = mExpandButton->sizeHint().width()+4; 493 int widebut = mExpandButton->sizeHint().width()+4;
494 int heibut = mExpandButton->sizeHint().height()+4; 494 int heibut = mExpandButton->sizeHint().height()+4;
495 if ( heibut > widebut ) 495 if ( heibut > widebut )
496 widebut = heibut ; 496 widebut = heibut ;
497 497
498 //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, 498 //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed,
499 // QSizePolicy::Fixed ) ); 499 // QSizePolicy::Fixed ) );
500 mExpandButton->setFixedSize( widebut, widebut); 500 mExpandButton->setFixedSize( widebut, widebut);
501 connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); 501 connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) );
502 mExpandButton->setFocusPolicy(NoFocus); 502 mExpandButton->setFocusPolicy(NoFocus);
503 mAllDayAgenda = new KOAgenda(1,mAllDayFrame); 503 mAllDayAgenda = new KOAgenda(1,mAllDayFrame);
504 mAllDayAgenda->setFocusPolicy(NoFocus); 504 mAllDayAgenda->setFocusPolicy(NoFocus);
505 QLabel *dummyAllDayRight = new QLabel (mAllDayFrame); 505 QLabel *dummyAllDayRight = new QLabel (mAllDayFrame);
506 506
507 // Create event context menu for all day agenda 507 // Create event context menu for all day agenda
508 mAllDayAgendaPopup = eventPopup(); 508 //mAllDayAgendaPopup = eventPopup();
509 connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)),
510 mAllDayAgendaPopup,SLOT(showIncidencePopup(Incidence *)));
511 509
512 // Create agenda frame 510 // Create agenda frame
513 QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3); 511 QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3);
514 // QHBox *agendaFrame = new QHBox(splitterAgenda); 512 // QHBox *agendaFrame = new QHBox(splitterAgenda);
515 513
516 // create event indicator bars 514 // create event indicator bars
517 mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); 515 mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame);
518#ifndef DESKTOP_VERSION 516#ifndef DESKTOP_VERSION
519 // FIX 517 // FIX
520 mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); 518 mEventIndicatorTop->setPaintWidget( mSplitterAgenda );
521#endif 519#endif
522 mDayLabelsFrame = new QHBox(agendaFrame); 520 mDayLabelsFrame = new QHBox(agendaFrame);
523 //topLayout->addWidget(mDayLabelsFrame); 521 //topLayout->addWidget(mDayLabelsFrame);
524 mDayLabels = new QFrame (mDayLabelsFrame); 522 mDayLabels = new QFrame (mDayLabelsFrame);
525 mLayoutDayLabels = new QHBoxLayout(mDayLabels); 523 mLayoutDayLabels = new QHBoxLayout(mDayLabels);
526 agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2); 524 agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2);
527 agendaLayout->addWidget(mEventIndicatorTop,1,1); 525 agendaLayout->addWidget(mEventIndicatorTop,1,1);
528 526
529 mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, 527 mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom,
530 agendaFrame); 528 agendaFrame);
531 agendaLayout->addWidget(mEventIndicatorBottom,3,1); 529 agendaLayout->addWidget(mEventIndicatorBottom,3,1);
532 QWidget *dummyAgendaRight = new QWidget(agendaFrame); 530 QWidget *dummyAgendaRight = new QWidget(agendaFrame);
533 agendaLayout->addWidget(dummyAgendaRight,1,2); 531 agendaLayout->addWidget(dummyAgendaRight,1,2);
534 532
535 // Create time labels 533 // Create time labels
536 mTimeLabels = new TimeLabels(24,agendaFrame); 534 mTimeLabels = new TimeLabels(24,agendaFrame);
537 agendaLayout->addWidget(mTimeLabels,2,0); 535 agendaLayout->addWidget(mTimeLabels,2,0);
538 connect(mTimeLabels,SIGNAL( scaleChanged()), 536 connect(mTimeLabels,SIGNAL( scaleChanged()),
539 this,SLOT(updateConfig())); 537 this,SLOT(updateConfig()));
540 538
541 // Create agenda 539 // Create agenda
542 mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); 540 mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame);
543 agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2); 541 agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2);
544 agendaLayout->setColStretch(1,1); 542 agendaLayout->setColStretch(1,1);
545 mAgenda->setFocusPolicy(NoFocus); 543 mAgenda->setFocusPolicy(NoFocus);
546 // Create event context menu for agenda 544 // Create event context menu for agenda
547 mAgendaPopup = eventPopup(); 545 mAllAgendaPopup = eventPopup();
548 546
549 mAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), 547 mAllAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")),
550 i18n("Toggle Alarm"),mAgenda, 548 i18n("Toggle Alarm"),mAgenda,
551 SLOT(popupAlarm()),true); 549 SLOT(popupAlarm()),true);
552 550
553 551
554 connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), 552 connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)),
555 mAgendaPopup,SLOT(showIncidencePopup(Incidence *))); 553 mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *)));
556 554
555 connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)),
556 mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *)));
557 mAgenda->setPopup( mAllAgendaPopup );
558 mAllDayAgenda->setPopup( mAllAgendaPopup );
557 // make connections between dependent widgets 559 // make connections between dependent widgets
558 mTimeLabels->setAgenda(mAgenda); 560 mTimeLabels->setAgenda(mAgenda);
559 561
560 // Update widgets to reflect user preferences 562 // Update widgets to reflect user preferences
561 // updateConfig(); 563 // updateConfig();
562 564
563 // createDayLabels(); 565 // createDayLabels();
564 566
565 // these blank widgets make the All Day Event box line up with the agenda 567 // these blank widgets make the All Day Event box line up with the agenda
566 dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); 568 dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width());
567 dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); 569 dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width());
568 mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); 570 mDummyAllDayLeft->setFixedWidth(mTimeLabels->width());
569 571
570 // Scrolling 572 // Scrolling
571 connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), 573 connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)),
572 mTimeLabels, SLOT(positionChanged())); 574 mTimeLabels, SLOT(positionChanged()));
573 connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), 575 connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)),
574 SLOT(setContentsPos(int))); 576 SLOT(setContentsPos(int)));
575 577
576 connect(mAgenda,SIGNAL(showDateView( int, int)),SLOT(slotShowDateView( int, int ))); 578 connect(mAgenda,SIGNAL(showDateView( int, int)),SLOT(slotShowDateView( int, int )));
577 connect(mAllDayAgenda,SIGNAL(showDateView( int, int )), SLOT(slotShowDateView( int, int ) )); 579 connect(mAllDayAgenda,SIGNAL(showDateView( int, int )), SLOT(slotShowDateView( int, int ) ));
578 580
579 // Create/Show/Edit/Delete Event 581 // Create/Show/Edit/Delete Event
580 connect(mAgenda,SIGNAL(newEventSignal(int,int)), 582 connect(mAgenda,SIGNAL(newEventSignal(int,int)),
581 SLOT(newEvent(int,int))); 583 SLOT(newEvent(int,int)));
582 connect(mAgenda,SIGNAL(newTodoSignal(int,int)), 584 connect(mAgenda,SIGNAL(newTodoSignal(int,int)),
583 SLOT(newTodo(int,int))); 585 SLOT(newTodo(int,int)));
584 connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), 586 connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)),
585 SLOT(newEvent(int,int,int,int))); 587 SLOT(newEvent(int,int,int,int)));
586 connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), 588 connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)),
587 SLOT(newEventAllDay(int,int))); 589 SLOT(newEventAllDay(int,int)));
588 connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)), 590 connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)),
589 SLOT(newTodoAllDay(int,int))); 591 SLOT(newTodoAllDay(int,int)));
590 connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), 592 connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)),
591 SLOT(newEventAllDay(int,int))); 593 SLOT(newEventAllDay(int,int)));
592 connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), 594 connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)),
593 SLOT(newTimeSpanSelected(int,int,int,int))); 595 SLOT(newTimeSpanSelected(int,int,int,int)));
594 connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), 596 connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)),
595 SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); 597 SLOT(newTimeSpanSelectedAllDay(int,int,int,int)));
596 connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); 598 connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView()));
597 connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); 599 connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView()));
598 600
599 connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), 601 connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)),
600 SIGNAL(editIncidenceSignal(Incidence *))); 602 SIGNAL(editIncidenceSignal(Incidence *)));
601 connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), 603 connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)),
602 SIGNAL(editIncidenceSignal(Incidence *))); 604 SIGNAL(editIncidenceSignal(Incidence *)));
603 connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), 605 connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)),
604 SIGNAL(showIncidenceSignal(Incidence *))); 606 SIGNAL(showIncidenceSignal(Incidence *)));
605 connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), 607 connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)),
606 SIGNAL(showIncidenceSignal(Incidence *))); 608 SIGNAL(showIncidenceSignal(Incidence *)));
607 connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), 609 connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)),
608 SIGNAL(deleteIncidenceSignal(Incidence *))); 610 SIGNAL(deleteIncidenceSignal(Incidence *)));
609 connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), 611 connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)),
610 SIGNAL(deleteIncidenceSignal(Incidence *))); 612 SIGNAL(deleteIncidenceSignal(Incidence *)));
611 613
612 connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), 614 connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )),
613 SLOT(updateEventDates(KOAgendaItem *, int ))); 615 SLOT(updateEventDates(KOAgendaItem *, int )));
614 connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), 616 connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )),
615 SLOT(updateEventDates(KOAgendaItem *, int))); 617 SLOT(updateEventDates(KOAgendaItem *, int)));
616 618
617 // event indicator update 619 // event indicator update
618 connect(mAgenda,SIGNAL(lowerYChanged(int)), 620 connect(mAgenda,SIGNAL(lowerYChanged(int)),
619 SLOT(updateEventIndicatorTop(int))); 621 SLOT(updateEventIndicatorTop(int)));
620 connect(mAgenda,SIGNAL(upperYChanged(int)), 622 connect(mAgenda,SIGNAL(upperYChanged(int)),
621 SLOT(updateEventIndicatorBottom(int))); 623 SLOT(updateEventIndicatorBottom(int)));
622 // drag signals 624 // drag signals
623 /* 625 /*
624 connect(mAgenda,SIGNAL(startDragSignal(Event *)), 626 connect(mAgenda,SIGNAL(startDragSignal(Event *)),
625 SLOT(startDrag(Event *))); 627 SLOT(startDrag(Event *)));
626 connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), 628 connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)),
627 SLOT(startDrag(Event *))); 629 SLOT(startDrag(Event *)));
628 */ 630 */
629 // synchronize selections 631 // synchronize selections
630 connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), 632 connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ),
631 mAllDayAgenda, SLOT( deselectItem() ) ); 633 mAllDayAgenda, SLOT( deselectItem() ) );
632 connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), 634 connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ),
633 mAgenda, SLOT( deselectItem() ) ); 635 mAgenda, SLOT( deselectItem() ) );
634 connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), 636 connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ),
635 SIGNAL( incidenceSelected( Incidence * ) ) ); 637 SIGNAL( incidenceSelected( Incidence * ) ) );
636 connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), 638 connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ),
637 SIGNAL( incidenceSelected( Incidence * ) ) ); 639 SIGNAL( incidenceSelected( Incidence * ) ) );
638 connect( mAgenda, SIGNAL( resizedSignal() ), 640 connect( mAgenda, SIGNAL( resizedSignal() ),
639 SLOT( updateConfig( ) ) ); 641 SLOT( updateConfig( ) ) );
640 connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), 642 connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ),
641 SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); 643 SLOT( addToCalSlot(Incidence *, Incidence * ) ) );
642 connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), 644 connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ),
643 SLOT( addToCalSlot(Incidence * , Incidence *) ) ); 645 SLOT( addToCalSlot(Incidence * , Incidence *) ) );
644 // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); 646 // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) );
645 //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); 647 //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) );
646 648
647 649
648} 650}
649 651
650void KOAgendaView::toggleAllDay() 652void KOAgendaView::toggleAllDay()
651{ 653{
652 if ( mSplitterAgenda->firstHandle() ) 654 if ( mSplitterAgenda->firstHandle() )
653 mSplitterAgenda->firstHandle()->toggle(); 655 mSplitterAgenda->firstHandle()->toggle();
654} 656}
655void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) 657void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld )
656{ 658{
657 calendar()->addIncidence( inc ); 659 calendar()->addIncidence( inc );
658 660
659 if ( incOld ) { 661 if ( incOld ) {
660 if ( incOld->type() == "Todo" ) 662 if ( incOld->type() == "Todo" )
661 emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED ); 663 emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED );
662 else 664 else
663 emit incidenceChanged(incOld, KOGlobals::EVENTEDITED); 665 emit incidenceChanged(incOld, KOGlobals::EVENTEDITED);
664 } 666 }
665 667
666} 668}
667 669
668KOAgendaView::~KOAgendaView() 670KOAgendaView::~KOAgendaView()
669{ 671{
670 delete mAgendaPopup; 672 delete mAllAgendaPopup;
671 delete mAllDayAgendaPopup; 673 //delete mAllDayAgendaPopup;
672 delete KOAgendaItem::paintPix(); 674 delete KOAgendaItem::paintPix();
673 delete KOAgendaItem::paintPixSel(); 675 delete KOAgendaItem::paintPixSel();
674} 676}
675void KOAgendaView::resizeEvent( QResizeEvent* e ) 677void KOAgendaView::resizeEvent( QResizeEvent* e )
676{ 678{
677 //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width()); 679 //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width());
678 bool uc = false; 680 bool uc = false;
679 int ow = e->oldSize().width(); 681 int ow = e->oldSize().width();
680 int oh = e->oldSize().height(); 682 int oh = e->oldSize().height();
681 int w = e->size().width(); 683 int w = e->size().width();
682 int h = e->size().height(); 684 int h = e->size().height();
683 if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) { 685 if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) {
684 if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda ) 686 if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda )
685 uc = true; 687 uc = true;
686 //qDebug("view changed %d %d %d %d ", ow, oh , w , h); 688 //qDebug("view changed %d %d %d %d ", ow, oh , w , h);
687 } 689 }
688 mUpcomingWidth = e->size().width() ; 690 mUpcomingWidth = e->size().width() ;
689 if ( mBlockUpdating || uc ) { 691 if ( mBlockUpdating || uc ) {
690 mBlockUpdating = false; 692 mBlockUpdating = false;
691 //mAgenda->setMinimumSize(800 , 600 ); 693 //mAgenda->setMinimumSize(800 , 600 );
692 //qDebug("mAgenda->resize+++++++++++++++ "); 694 //qDebug("mAgenda->resize+++++++++++++++ ");
693 updateConfig(); 695 updateConfig();
694 //qDebug("KOAgendaView::Updating now possible "); 696 //qDebug("KOAgendaView::Updating now possible ");
695 } else 697 } else
696 createDayLabels(); 698 createDayLabels();
697 //qDebug("resizeEvent end "); 699 //qDebug("resizeEvent end ");
698 700
699} 701}
700void KOAgendaView::slotDaylabelClicked( int num ) 702void KOAgendaView::slotDaylabelClicked( int num )
701{ 703{
702 704
703 QDate firstDate = mSelectedDates.first(); 705 QDate firstDate = mSelectedDates.first();
704 if ( num == -1 ) 706 if ( num == -1 )
705 emit showDateView( 6, firstDate ); 707 emit showDateView( 6, firstDate );
706 else if (num >= 0 ) { 708 else if (num >= 0 ) {
707 if ( mSelectedDates.count() == 1) 709 if ( mSelectedDates.count() == 1)
708 emit showDateView( 9, firstDate.addDays( num ) ); 710 emit showDateView( 9, firstDate.addDays( num ) );
709 else 711 else
710 emit showDateView( 3, firstDate.addDays( num ) ); 712 emit showDateView( 3, firstDate.addDays( num ) );
711 } 713 }
712 else 714 else
713 showDateView( 10, firstDate.addDays(1) ); 715 showDateView( 10, firstDate.addDays(1) );
714} 716}
715 717
716KOAgendaButton* KOAgendaView::getNewDaylabel() 718KOAgendaButton* KOAgendaView::getNewDaylabel()
717{ 719{
718 720
719 KOAgendaButton * dayLabel = new KOAgendaButton(mDayLabels); 721 KOAgendaButton * dayLabel = new KOAgendaButton(mDayLabels);
720 connect( dayLabel, SIGNAL( numClicked(int) ), this, SLOT ( slotDaylabelClicked(int) ) ); 722 connect( dayLabel, SIGNAL( numClicked(int) ), this, SLOT ( slotDaylabelClicked(int) ) );
721 mDayLabelsList.append( dayLabel ); 723 mDayLabelsList.append( dayLabel );
722 mLayoutDayLabels->addWidget(dayLabel); 724 mLayoutDayLabels->addWidget(dayLabel);
723 return dayLabel ; 725 return dayLabel ;
724} 726}
725 727
726void KOAgendaView::createDayLabels() 728void KOAgendaView::createDayLabels()
727{ 729{
728 730
729 if ( mBlockUpdating || globalFlagBlockLabel == 1) { 731 if ( mBlockUpdating || globalFlagBlockLabel == 1) {
730 // qDebug(" KOAgendaView::createDayLabels() blocked "); 732 // qDebug(" KOAgendaView::createDayLabels() blocked ");
731 return; 733 return;
732 734
733 } 735 }
734 int newHight; 736 int newHight;
735 737
736 // ### Before deleting and recreating we could check if mSelectedDates changed... 738 // ### Before deleting and recreating we could check if mSelectedDates changed...
737 // It would remove some flickering and gain speed (since this is called by 739 // It would remove some flickering and gain speed (since this is called by
738 // each updateView() call) 740 // each updateView() call)
739 741
740 int maxWid = mUpcomingWidth - mTimeLabels->width()- mAgenda->verticalScrollBar()->width() - mAgenda->frameWidth()*2; 742 int maxWid = mUpcomingWidth - mTimeLabels->width()- mAgenda->verticalScrollBar()->width() - mAgenda->frameWidth()*2;
741 if ( QApplication::desktop()->width() <= 320 ) 743 if ( QApplication::desktop()->width() <= 320 )
742 maxWid -= 10; 744 maxWid -= 10;
743 mDayLabelsFrame->setMaximumWidth( mUpcomingWidth ); 745 mDayLabelsFrame->setMaximumWidth( mUpcomingWidth );
744 if ( maxWid < 0 ) 746 if ( maxWid < 0 )
745 maxWid = 20; 747 maxWid = 20;
746 748
747 QFont dlf = KOPrefs::instance()->mTimeLabelsFont; 749 QFont dlf = KOPrefs::instance()->mTimeLabelsFont;
748 QFontMetrics fm ( dlf ); 750 QFontMetrics fm ( dlf );
749 int selCount = mSelectedDates.count(); 751 int selCount = mSelectedDates.count();
750 QString dayTest = "Mon 20"; 752 QString dayTest = "Mon 20";
751 //QString dayTest = "Mon 20"; 753 //QString dayTest = "Mon 20";
752 int wid = fm.width( dayTest ); 754 int wid = fm.width( dayTest );
753 //maxWid -= ( selCount * 3 ); //working for QLabels 755 //maxWid -= ( selCount * 3 ); //working for QLabels
754 maxWid -= ( selCount * 3 ); //working for QPushButton 756 maxWid -= ( selCount * 3 ); //working for QPushButton
755 if ( maxWid < 0 ) 757 if ( maxWid < 0 )
756 maxWid = 20; 758 maxWid = 20;
757 int needWid = wid * selCount; 759 int needWid = wid * selCount;
758 //qDebug("++++++++Needed : %d MaxWidth: %d", needWid, maxWid ); 760 //qDebug("++++++++Needed : %d MaxWidth: %d", needWid, maxWid );
759 //if ( needWid > maxWid ) 761 //if ( needWid > maxWid )
760 // qDebug("DAYLABELS TOOOOOOO BIG "); 762 // qDebug("DAYLABELS TOOOOOOO BIG ");
761 while ( needWid > maxWid ) { 763 while ( needWid > maxWid ) {
762 dayTest = dayTest.left( dayTest.length() - 1 ); 764 dayTest = dayTest.left( dayTest.length() - 1 );
763 wid = fm.width( dayTest ); 765 wid = fm.width( dayTest );
764 needWid = wid * selCount; 766 needWid = wid * selCount;
765 } 767 }
766 int maxLen = dayTest.length(); 768 int maxLen = dayTest.length();
767 int fontPoint = dlf.pointSize(); 769 int fontPoint = dlf.pointSize();
768 if ( maxLen < 2 ) { 770 if ( maxLen < 2 ) {
769 int fontPoint = dlf.pointSize(); 771 int fontPoint = dlf.pointSize();
770 while ( fontPoint > 4 ) { 772 while ( fontPoint > 4 ) {
771 --fontPoint; 773 --fontPoint;
772 dlf.setPointSize( fontPoint ); 774 dlf.setPointSize( fontPoint );
773 QFontMetrics f( dlf ); 775 QFontMetrics f( dlf );
774 wid = f.width( "30" ); 776 wid = f.width( "30" );
775 needWid = wid * selCount; 777 needWid = wid * selCount;
776 if ( needWid < maxWid ) 778 if ( needWid < maxWid )
777 break; 779 break;
778 } 780 }
779 maxLen = 2; 781 maxLen = 2;
780 } 782 }
781 //qDebug("Max len %d ", dayTest.length() ); 783 //qDebug("Max len %d ", dayTest.length() );
782 784
783 QFontMetrics tempF( dlf ); 785 QFontMetrics tempF( dlf );
784 newHight = tempF.height(); 786 newHight = tempF.height();
785 mDayLabels->setFont( dlf ); 787 mDayLabels->setFont( dlf );
786 // mLayoutDayLabels = new QHBoxLayout(mDayLabels);; 788 // mLayoutDayLabels = new QHBoxLayout(mDayLabels);;
787 // mLayoutDayLabels->addSpacing(mTimeLabels->width()); 789 // mLayoutDayLabels->addSpacing(mTimeLabels->width());
788 //mLayoutDayLabels->addSpacing( 2 ); 790 //mLayoutDayLabels->addSpacing( 2 );
789 // QFont lFont = dlf; 791 // QFont lFont = dlf;
790 bool appendLabels = false; 792 bool appendLabels = false;
791 KOAgendaButton *dayLabel; 793 KOAgendaButton *dayLabel;
792 dayLabel = mDayLabelsList.first(); 794 dayLabel = mDayLabelsList.first();
793 if ( !dayLabel ) { 795 if ( !dayLabel ) {
794 appendLabels = true; 796 appendLabels = true;
795 dayLabel = getNewDaylabel(); 797 dayLabel = getNewDaylabel();
796 } 798 }
797 dayLabel->setFixedWidth( mTimeLabels->width()+mAgenda->frameWidth() ); 799 dayLabel->setFixedWidth( mTimeLabels->width()+mAgenda->frameWidth() );
798 dayLabel->setFont( dlf ); 800 dayLabel->setFont( dlf );
799 dayLabel->setNum( -1 ); 801 dayLabel->setNum( -1 );
800 //dayLabel->setAlignment(QLabel::AlignHCenter); 802 //dayLabel->setAlignment(QLabel::AlignHCenter);
801#if 0 803#if 0
802 if ( QApplication::desktop()->width() <= 320 ) 804 if ( QApplication::desktop()->width() <= 320 )
803 dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ).left(2) ); 805 dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ).left(2) );
804 else 806 else
805#endif 807#endif
806 dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ) ); 808 dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ) );
807 dayLabel->show(); 809 dayLabel->show();
808 DateList::ConstIterator dit; 810 DateList::ConstIterator dit;
809 bool oneday = (mSelectedDates.first() == mSelectedDates.last() ); 811 bool oneday = (mSelectedDates.first() == mSelectedDates.last() );
810 int counter = -1; 812 int counter = -1;
811 for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { 813 for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) {
812 ++counter; 814 ++counter;
813 QDate date = *dit; 815 QDate date = *dit;
814 // QBoxLayout *dayLayout = new QVBoxLayout(mLayoutDayLabels); 816 // QBoxLayout *dayLayout = new QVBoxLayout(mLayoutDayLabels);
815 if ( ! appendLabels ) { 817 if ( ! appendLabels ) {
816 dayLabel = mDayLabelsList.next(); 818 dayLabel = mDayLabelsList.next();
817 if ( !dayLabel ) 819 if ( !dayLabel )
818 appendLabels = true; 820 appendLabels = true;
819 } 821 }
820 if ( appendLabels ) { 822 if ( appendLabels ) {
821 dayLabel = getNewDaylabel(); 823 dayLabel = getNewDaylabel();
822 } 824 }
823 dayLabel->setMinimumWidth( 1 ); 825 dayLabel->setMinimumWidth( 1 );
824 dayLabel->setMaximumWidth( 10240 ); 826 dayLabel->setMaximumWidth( 10240 );
825 dayLabel->setFont( dlf ); 827 dayLabel->setFont( dlf );
826 dayLabel->show(); 828 dayLabel->show();
827 dayLabel->setAutoRepeat( false ); 829 dayLabel->setAutoRepeat( false );
828 dayLabel->setNum( counter ); 830 dayLabel->setNum( counter );
829 QString str; 831 QString str;
830 int dW = KOGlobals::self()->calendarSystem()->dayOfWeek(date); 832 int dW = KOGlobals::self()->calendarSystem()->dayOfWeek(date);
831 QString dayName = KOGlobals::self()->calendarSystem()->weekDayName( dW, true ); 833 QString dayName = KOGlobals::self()->calendarSystem()->weekDayName( dW, true );
832 switch ( maxLen ) { 834 switch ( maxLen ) {
833 case 2: 835 case 2:
834 str = QString::number( date.day() ); 836 str = QString::number( date.day() );
835 break; 837 break;
836 838
837 case 3: 839 case 3:
838 str = dayName.left( 1 ) +QString::number( date.day()); 840 str = dayName.left( 1 ) +QString::number( date.day());
839 841
840 break; 842 break;
841 case 4: 843 case 4:
842 str = dayName.left( 1 ) + " " +QString::number( date.day()); 844 str = dayName.left( 1 ) + " " +QString::number( date.day());
843 845
844 break; 846 break;
845 case 5: 847 case 5:
846 str = dayName.left( 2 ) + " " +QString::number( date.day()); 848 str = dayName.left( 2 ) + " " +QString::number( date.day());
847 849
848 break; 850 break;
849 case 6: 851 case 6:
850 str = dayName.left( 3 ) + " " +QString::number( date.day()); 852 str = dayName.left( 3 ) + " " +QString::number( date.day());
851 break; 853 break;
852 854
853 default: 855 default:
854 break; 856 break;
855 } 857 }
856 if ( oneday ) { 858 if ( oneday ) {
857 QString addString; 859 QString addString;
858 if ( mSelectedDates.first() == QDateTime::currentDateTime().date() ) 860 if ( mSelectedDates.first() == QDateTime::currentDateTime().date() )
859 addString = i18n("Today"); 861 addString = i18n("Today");
860 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(1) ) 862 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(1) )
861 addString = i18n("Tomorrow"); 863 addString = i18n("Tomorrow");
862 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-1) ) 864 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-1) )
863 addString = i18n("Yesterday"); 865 addString = i18n("Yesterday");
864 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-2) ) 866 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-2) )
865 addString = i18n("Day before yesterday"); 867 addString = i18n("Day before yesterday");
866 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(2) ) 868 else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(2) )
867 addString = i18n("Day after tomorrow"); 869 addString = i18n("Day after tomorrow");
868 if ( !addString.isEmpty() ) { 870 if ( !addString.isEmpty() ) {
869 str = addString+", " + str; 871 str = addString+", " + str;
870 } else { 872 } else {
871 str = KGlobal::locale()->formatDate( date, KOPrefs::instance()->mShortDateInViewer); 873 str = KGlobal::locale()->formatDate( date, KOPrefs::instance()->mShortDateInViewer);
872 } 874 }
873 } 875 }
874 dayLabel->setText(str); 876 dayLabel->setText(str);
875 //dayLabel->setAlignment(QLabel::AlignHCenter); 877 //dayLabel->setAlignment(QLabel::AlignHCenter);
876 if (date == QDate::currentDate()) { 878 if (date == QDate::currentDate()) {
877 QFont bFont = dlf; 879 QFont bFont = dlf;
878 bFont.setBold( true ); 880 bFont.setBold( true );
879 dayLabel->setFont(bFont); 881 dayLabel->setFont(bFont);
880 } 882 }
881 //dayLayout->addWidget(dayLabel); 883 //dayLayout->addWidget(dayLabel);
882 884
883#ifndef KORG_NOPLUGINS 885#ifndef KORG_NOPLUGINS
884 CalendarDecoration::List cds = KOCore::self()->calendarDecorations(); 886 CalendarDecoration::List cds = KOCore::self()->calendarDecorations();
885 CalendarDecoration *it; 887 CalendarDecoration *it;
886 for(it = cds.first(); it; it = cds.next()) { 888 for(it = cds.first(); it; it = cds.next()) {
887 QString text = it->shortText( date ); 889 QString text = it->shortText( date );
888 if ( !text.isEmpty() ) { 890 if ( !text.isEmpty() ) {
889 QLabel *label = new QLabel(text,mDayLabels); 891 QLabel *label = new QLabel(text,mDayLabels);
890 label->setAlignment(AlignCenter); 892 label->setAlignment(AlignCenter);
891 dayLayout->addWidget(label); 893 dayLayout->addWidget(label);
892 } 894 }
893 } 895 }
894 896
895 for(it = cds.first(); it; it = cds.next()) { 897 for(it = cds.first(); it; it = cds.next()) {
896 QWidget *wid = it->smallWidget(mDayLabels,date); 898 QWidget *wid = it->smallWidget(mDayLabels,date);
897 if ( wid ) { 899 if ( wid ) {
898 // wid->setHeight(20); 900 // wid->setHeight(20);
899 dayLayout->addWidget(wid); 901 dayLayout->addWidget(wid);
900 } 902 }
901 } 903 }
902#endif 904#endif
903 } 905 }
904 if ( ! appendLabels ) { 906 if ( ! appendLabels ) {
905 dayLabel = mDayLabelsList.next(); 907 dayLabel = mDayLabelsList.next();
906 if ( !dayLabel ) 908 if ( !dayLabel )
907 appendLabels = true; 909 appendLabels = true;
908 } 910 }
909 if ( appendLabels ) { 911 if ( appendLabels ) {
910 dayLabel = getNewDaylabel(); 912 dayLabel = getNewDaylabel();
911 } 913 }
912 //dayLabel->hide();//test only 914 //dayLabel->hide();//test only
913 int offset = (mAgenda->width() - mAgenda->verticalScrollBar()->width()- (mAgenda->frameWidth()*2) ) % mSelectedDates.count() ; 915 int offset = (mAgenda->width() - mAgenda->verticalScrollBar()->width()- (mAgenda->frameWidth()*2) ) % mSelectedDates.count() ;
914 if ( offset < 0 ) offset = 0; 916 if ( offset < 0 ) offset = 0;
915 //qDebug("mLayoutDayLabels->addSpacing %d ", mAgenda->verticalScrollBar()->width()+offset+2 ); 917 //qDebug("mLayoutDayLabels->addSpacing %d ", mAgenda->verticalScrollBar()->width()+offset+2 );
916 dayLabel->setText(">");//QString::number ( mSelectedDates.first().month() ) ); 918 dayLabel->setText(">");//QString::number ( mSelectedDates.first().month() ) );
917 dayLabel->setFont( dlf ); 919 dayLabel->setFont( dlf );
918 dayLabel->setAutoRepeat( true ); 920 dayLabel->setAutoRepeat( true );
919 dayLabel->show(); 921 dayLabel->show();
920 dayLabel->setNum( -2 ); 922 dayLabel->setNum( -2 );
921 dayLabel->setFixedWidth( mAgenda->verticalScrollBar()->width()+ offset ); 923 dayLabel->setFixedWidth( mAgenda->verticalScrollBar()->width()+ offset );
922 924
923 //qDebug("setToFixed %d ", mAgenda->verticalScrollBar()->width()+ offset+2); 925 //qDebug("setToFixed %d ", mAgenda->verticalScrollBar()->width()+ offset+2);
924 //mLayoutDayLabels->addSpacing(mAgenda->verticalScrollBar()->width()+ offset+2); 926 //mLayoutDayLabels->addSpacing(mAgenda->verticalScrollBar()->width()+ offset+2);
925 if ( !appendLabels ) { 927 if ( !appendLabels ) {
926 dayLabel = mDayLabelsList.next(); 928 dayLabel = mDayLabelsList.next();
927 while ( dayLabel ) { 929 while ( dayLabel ) {
928 //qDebug("!dayLabel %d",dayLabel ); 930 //qDebug("!dayLabel %d",dayLabel );
929 dayLabel->hide(); 931 dayLabel->hide();
930 dayLabel = mDayLabelsList.next(); 932 dayLabel = mDayLabelsList.next();
931 } 933 }
932 } 934 }
933 935
934 mDayLabelsFrame->setFixedHeight( newHight + 4 ); 936 mDayLabelsFrame->setFixedHeight( newHight + 4 );
935} 937}
936 938
937int KOAgendaView::maxDatesHint() 939int KOAgendaView::maxDatesHint()
938{ 940{
939 // Not sure about the max number of events, so return 0 for now. 941 // Not sure about the max number of events, so return 0 for now.
940 return 0; 942 return 0;
941} 943}
942 944
943int KOAgendaView::currentDateCount() 945int KOAgendaView::currentDateCount()
944{ 946{
945 return mSelectedDates.count(); 947 return mSelectedDates.count();
946} 948}
947 949
948QPtrList<Incidence> KOAgendaView::selectedIncidences() 950QPtrList<Incidence> KOAgendaView::selectedIncidences()
949{ 951{
950 QPtrList<Incidence> selected; 952 QPtrList<Incidence> selected;
951 Incidence *incidence; 953 Incidence *incidence;
952 954
953 incidence = mAgenda->selectedIncidence(); 955 incidence = mAgenda->selectedIncidence();
954 if (incidence) selected.append(incidence); 956 if (incidence) selected.append(incidence);
955 957
956 incidence = mAllDayAgenda->selectedIncidence(); 958 incidence = mAllDayAgenda->selectedIncidence();
957 if (incidence) selected.append(incidence); 959 if (incidence) selected.append(incidence);
958 960
959 return selected; 961 return selected;
960} 962}
961 963
962DateList KOAgendaView::selectedDates() 964DateList KOAgendaView::selectedDates()
963{ 965{
964 DateList selected; 966 DateList selected;
965 QDate qd; 967 QDate qd;
966 968
967 qd = mAgenda->selectedIncidenceDate(); 969 qd = mAgenda->selectedIncidenceDate();
968 if (qd.isValid()) selected.append(qd); 970 if (qd.isValid()) selected.append(qd);
969 971
970 qd = mAllDayAgenda->selectedIncidenceDate(); 972 qd = mAllDayAgenda->selectedIncidenceDate();
971 if (qd.isValid()) selected.append(qd); 973 if (qd.isValid()) selected.append(qd);
972 974
973 return selected; 975 return selected;
974} 976}
975 977
976 978
977void KOAgendaView::updateView() 979void KOAgendaView::updateView()
978{ 980{
979 if ( mBlockUpdating ) 981 if ( mBlockUpdating )
980 return; 982 return;
981 // kdDebug() << "KOAgendaView::updateView()" << endl; 983 // kdDebug() << "KOAgendaView::updateView()" << endl;
982 fillAgenda(); 984 fillAgenda();
983 985
984} 986}
985 987
986 988
987/* 989/*
988 Update configuration settings for the agenda view. This method is not 990 Update configuration settings for the agenda view. This method is not
989 complete. 991 complete.
990*/ 992*/
991void KOAgendaView::updateConfig() 993void KOAgendaView::updateConfig()
992{ 994{
993 if ( mBlockUpdating ) 995 if ( mBlockUpdating )
994 return; 996 return;
995 if ( mAgenda->height() > 96 * KOPrefs::instance()->mHourSize ) { 997 if ( mAgenda->height() > 96 * KOPrefs::instance()->mHourSize ) {
996 int old = KOPrefs::instance()->mHourSize; 998 int old = KOPrefs::instance()->mHourSize;
997 KOPrefs::instance()->mHourSize = mAgenda->height()/96 +1; 999 KOPrefs::instance()->mHourSize = mAgenda->height()/96 +1;
998 qDebug("KOPrefs::instance()->mHourSize adjusted %d to %d ", old,KOPrefs::instance()->mHourSize ); 1000 qDebug("KOPrefs::instance()->mHourSize adjusted %d to %d ", old,KOPrefs::instance()->mHourSize );
999 } 1001 }
1000 1002
1001 1003
1002 // update config for children 1004 // update config for children
1003 mTimeLabels->updateConfig(); 1005 mTimeLabels->updateConfig();
1004 mAgenda->storePosition(); 1006 mAgenda->storePosition();
1005 mAgenda->updateConfig(); 1007 mAgenda->updateConfig();
1006 mAllDayAgenda->updateConfig(); 1008 mAllDayAgenda->updateConfig();
1007 // widget synchronization 1009 // widget synchronization
1008 //TODO: find a better way, maybe signal/slot 1010 //TODO: find a better way, maybe signal/slot
1009 mTimeLabels->positionChanged(); 1011 mTimeLabels->positionChanged();
1010 1012
1011 // for some reason, this needs to be called explicitly 1013 // for some reason, this needs to be called explicitly
1012 mTimeLabels->repaint(); 1014 mTimeLabels->repaint();
1013 1015
1014 mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); 1016 mDummyAllDayLeft->setFixedWidth(mTimeLabels->width());
1015 1017
1016 // ToolTips displaying summary of events 1018 // ToolTips displaying summary of events
1017 KOAgendaItem::toolTipGroup()->setEnabled(KOPrefs::instance() 1019 KOAgendaItem::toolTipGroup()->setEnabled(KOPrefs::instance()
1018 ->mEnableToolTips); 1020 ->mEnableToolTips);
1019 1021
1020 //setHolidayMasks(); 1022 //setHolidayMasks();
1021 1023
1022 //createDayLabels(); called by via updateView(); 1024 //createDayLabels(); called by via updateView();
1023 mEventIndicatorTop->setXOffset(mTimeLabels->width() + mAgenda->frameWidth()); 1025 mEventIndicatorTop->setXOffset(mTimeLabels->width() + mAgenda->frameWidth());
1024 updateView(); 1026 updateView();
1025 mAgenda->restorePosition(); 1027 mAgenda->restorePosition();
1026} 1028}
1027 1029
1028 1030
1029void KOAgendaView::updateEventDates(KOAgendaItem *item, int type) 1031void KOAgendaView::updateEventDates(KOAgendaItem *item, int type)
1030{ 1032{
1031 // kdDebug() << "KOAgendaView::updateEventDates(): " << item->text() << endl; 1033 // kdDebug() << "KOAgendaView::updateEventDates(): " << item->text() << endl;
1032 //qDebug("KOAgendaView::updateEventDates "); 1034 //qDebug("KOAgendaView::updateEventDates ");
1033 QDateTime startDt,endDt; 1035 QDateTime startDt,endDt;
1034 QDate startDate; 1036 QDate startDate;
1035 int lenInSecs; 1037 int lenInSecs;
1036 // if ( type == KOAgenda::RESIZETOP ) 1038 // if ( type == KOAgenda::RESIZETOP )
1037 // qDebug("RESIZETOP "); 1039 // qDebug("RESIZETOP ");
1038 // if ( type == KOAgenda::RESIZEBOTTOM ) 1040 // if ( type == KOAgenda::RESIZEBOTTOM )
1039 // qDebug("RESIZEBOTTOM "); 1041 // qDebug("RESIZEBOTTOM ");
1040 // if ( type == KOAgenda::MOVE ) 1042 // if ( type == KOAgenda::MOVE )
1041 // qDebug("MOVE "); 1043 // qDebug("MOVE ");
1042 if ( item->incidence()->type() == "Event" ) { 1044 if ( item->incidence()->type() == "Event" ) {
1043 startDt =item->incidence()->dtStart(); 1045 startDt =item->incidence()->dtStart();
1044 endDt = item->incidence()->dtEnd(); 1046 endDt = item->incidence()->dtEnd();
1045 lenInSecs = startDt.secsTo( endDt ); 1047 lenInSecs = startDt.secsTo( endDt );
1046 } 1048 }
1047 1049
1048 // emit incidenceItemChanged( item->incidence(), KOGlobals::EVENTEDITED ); 1050 // emit incidenceItemChanged( item->incidence(), KOGlobals::EVENTEDITED );
1049 1051
1050 if ( item->incidence()->type()=="Todo" && item->mLastMoveXPos > 0 ) { 1052 if ( item->incidence()->type()=="Todo" && item->mLastMoveXPos > 0 ) {
1051 startDate = mSelectedDates[item->mLastMoveXPos]; 1053 startDate = mSelectedDates[item->mLastMoveXPos];
1052 } else { 1054 } else {
1053 if (item->cellX() < 0) { 1055 if (item->cellX() < 0) {
1054 startDate = (mSelectedDates.first()).addDays(item->cellX()); 1056 startDate = (mSelectedDates.first()).addDays(item->cellX());
1055 } else { 1057 } else {
1056 startDate = mSelectedDates[item->cellX()]; 1058 startDate = mSelectedDates[item->cellX()];
1057 } 1059 }
1058 } 1060 }
1059 startDt.setDate(startDate); 1061 startDt.setDate(startDate);
1060 1062
1061 if (item->incidence()->doesFloat()) { 1063 if (item->incidence()->doesFloat()) {
1062 endDt.setDate(startDate.addDays(item->cellWidth() - 1)); 1064 endDt.setDate(startDate.addDays(item->cellWidth() - 1));
1063 } else { 1065 } else {
1064 if ( type == KOAgenda::RESIZETOP || type == KOAgenda::MOVE ) 1066 if ( type == KOAgenda::RESIZETOP || type == KOAgenda::MOVE )
1065 startDt.setTime(mAgenda->gyToTime(item->cellYTop())); 1067 startDt.setTime(mAgenda->gyToTime(item->cellYTop()));
1066 if ( item->incidence()->type() == "Event" ) { 1068 if ( item->incidence()->type() == "Event" ) {
1067 if ( type == KOAgenda::MOVE ) { 1069 if ( type == KOAgenda::MOVE ) {
1068 endDt = startDt.addSecs(lenInSecs); 1070 endDt = startDt.addSecs(lenInSecs);
1069 1071
1070 } else if ( type == KOAgenda::RESIZEBOTTOM ) { 1072 } else if ( type == KOAgenda::RESIZEBOTTOM ) {
1071 if (item->lastMultiItem()) { 1073 if (item->lastMultiItem()) {
1072 endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); 1074 endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1));
1073 endDt.setDate(startDate. 1075 endDt.setDate(startDate.
1074 addDays(item->lastMultiItem()->cellX() - item->cellX())); 1076 addDays(item->lastMultiItem()->cellX() - item->cellX()));
1075 } else { 1077 } else {
1076 endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); 1078 endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1));
1077 endDt.setDate(startDate); 1079 endDt.setDate(startDate);
1078 } 1080 }
1079 } 1081 }
1080 } else { 1082 } else {
1081 // todo 1083 // todo
1082 if (item->lastMultiItem()) { 1084 if (item->lastMultiItem()) {
1083 endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); 1085 endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1));
1084 endDt.setDate(startDate. 1086 endDt.setDate(startDate.
1085 addDays(item->lastMultiItem()->cellX() - item->cellX())); 1087 addDays(item->lastMultiItem()->cellX() - item->cellX()));
1086 } else { 1088 } else {
1087 //qDebug("tem->cellYBottom() %d",item->cellYBottom() ); 1089 //qDebug("tem->cellYBottom() %d",item->cellYBottom() );
1088 if ( item->cellYBottom() > 0 ) 1090 if ( item->cellYBottom() > 0 )
1089 endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); 1091 endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1));
1090 else 1092 else
1091 endDt.setTime((static_cast<Todo*>(item->incidence()))->dtDue().time()); 1093 endDt.setTime((static_cast<Todo*>(item->incidence()))->dtDue().time());
1092 endDt.setDate(startDate); 1094 endDt.setDate(startDate);
1093 } 1095 }
1094 } 1096 }
1095 } 1097 }
1096 if ( item->incidence()->type() == "Event" ) { 1098 if ( item->incidence()->type() == "Event" ) {
1097 item->incidence()->setDtStart(startDt); 1099 item->incidence()->setDtStart(startDt);
1098 (static_cast<Event*>(item->incidence()))->setDtEnd(endDt); 1100 (static_cast<Event*>(item->incidence()))->setDtEnd(endDt);
1099 } else if ( item->incidence()->type() == "Todo" ) { 1101 } else if ( item->incidence()->type() == "Todo" ) {
1100 Todo* to = static_cast<Todo*>(item->incidence()); 1102 Todo* to = static_cast<Todo*>(item->incidence());
1101 1103
1102 to->setDtDue(endDt); 1104 to->setDtDue(endDt);
1103 if ( to->hasStartDate() ) { 1105 if ( to->hasStartDate() ) {
1104 if (to->dtStart() >= to->dtDue() ) 1106 if (to->dtStart() >= to->dtDue() )
1105 to->setDtStart(to->dtDue().addDays( -2 )); 1107 to->setDtStart(to->dtDue().addDays( -2 ));
1106 } 1108 }
1107 1109
1108 } 1110 }
1109 //qDebug("KOAgendaView::updateEventDates stsart %s end %s ", startDt.toString().latin1(), endDt.toString().latin1() ); 1111 //qDebug("KOAgendaView::updateEventDates stsart %s end %s ", startDt.toString().latin1(), endDt.toString().latin1() );
1110 item->incidence()->setRevision(item->incidence()->revision()+1); 1112 item->incidence()->setRevision(item->incidence()->revision()+1);
1111 item->setItemDate(startDt.date()); 1113 item->setItemDate(startDt.date());
1112 //item->updateItem(); 1114 //item->updateItem();
1113 if ( item->incidence()->type() == "Todo" ) { 1115 if ( item->incidence()->type() == "Todo" ) {
1114 emit todoMoved((Todo*)item->incidence(), KOGlobals::EVENTEDITED ); 1116 emit todoMoved((Todo*)item->incidence(), KOGlobals::EVENTEDITED );
1115 1117
1116 } 1118 }
1117 else 1119 else
1118 emit incidenceChanged(item->incidence(), KOGlobals::EVENTEDITED); 1120 emit incidenceChanged(item->incidence(), KOGlobals::EVENTEDITED);
1119 item->updateItem(); 1121 item->updateItem();
1120} 1122}
1121 1123
1122void KOAgendaView::showDates( const QDate &start, const QDate &end ) 1124void KOAgendaView::showDates( const QDate &start, const QDate &end )
1123{ 1125{
1124 // kdDebug() << "KOAgendaView::selectDates" << endl; 1126 // kdDebug() << "KOAgendaView::selectDates" << endl;
1125 1127
1126 mSelectedDates.clear(); 1128 mSelectedDates.clear();
1127 // qDebug("KOAgendaView::showDates "); 1129 // qDebug("KOAgendaView::showDates ");
1128 QDate d = start; 1130 QDate d = start;
1129 while (d <= end) { 1131 while (d <= end) {
1130 mSelectedDates.append(d); 1132 mSelectedDates.append(d);
1131 d = d.addDays( 1 ); 1133 d = d.addDays( 1 );
1132 } 1134 }
1133 1135
1134 // and update the view 1136 // and update the view
1135 fillAgenda(); 1137 fillAgenda();
1136} 1138}
1137 1139
1138 1140
1139void KOAgendaView::showEvents(QPtrList<Event>) 1141void KOAgendaView::showEvents(QPtrList<Event>)
1140{ 1142{
1141 kdDebug() << "KOAgendaView::showEvents() is not yet implemented" << endl; 1143 kdDebug() << "KOAgendaView::showEvents() is not yet implemented" << endl;
1142} 1144}
1143 1145
1144void KOAgendaView::changeEventDisplay(Event *, int) 1146void KOAgendaView::changeEventDisplay(Event *, int)
1145{ 1147{
1146 // qDebug("KOAgendaView::changeEventDisplay "); 1148 // qDebug("KOAgendaView::changeEventDisplay ");
1147 // kdDebug() << "KOAgendaView::changeEventDisplay" << endl; 1149 // kdDebug() << "KOAgendaView::changeEventDisplay" << endl;
1148 // this should be re-written to be MUCH smarter. Right now we 1150 // this should be re-written to be MUCH smarter. Right now we
1149 // are just playing dumb. 1151 // are just playing dumb.
1150 fillAgenda(); 1152 fillAgenda();
1151} 1153}
1152 1154
1153void KOAgendaView::fillAgenda(const QDate &) 1155void KOAgendaView::fillAgenda(const QDate &)
1154{ 1156{
1155 // qDebug("KOAgendaView::fillAgenda "); 1157 // qDebug("KOAgendaView::fillAgenda ");
1156 fillAgenda(); 1158 fillAgenda();
1157} 1159}
1158 1160
1159void KOAgendaView::fillAgenda() 1161void KOAgendaView::fillAgenda()
1160{ 1162{
1161 if ( globalFlagBlockStartup ) 1163 if ( globalFlagBlockStartup )
1162 return; 1164 return;
1163 if ( globalFlagBlockAgenda == 1 ) 1165 if ( globalFlagBlockAgenda == 1 )
1164 return; 1166 return;
1165 static bool onlyOne = false; 1167 static bool onlyOne = false;
1166 if ( onlyOne ) 1168 if ( onlyOne )
1167 return; 1169 return;
1168 onlyOne = true; 1170 onlyOne = true;
1169 //if ( globalFlagBlockAgenda == 2 ) 1171 //if ( globalFlagBlockAgenda == 2 )
1170 //globalFlagBlockAgenda = 0; 1172 //globalFlagBlockAgenda = 0;
1171 // globalFlagBlockPainting = false; 1173 // globalFlagBlockPainting = false;
1172 if ( globalFlagBlockAgenda == 0 ) 1174 if ( globalFlagBlockAgenda == 0 )
1173 globalFlagBlockAgenda = 1; 1175 globalFlagBlockAgenda = 1;
1174 // clearView(); 1176 // clearView();
1175 //qDebug("fillAgenda()++++ "); 1177 //qDebug("fillAgenda()++++ ");
1176 globalFlagBlockAgendaItemPaint = 1; 1178 globalFlagBlockAgendaItemPaint = 1;
1177 1179
1178 mAllDayAgenda->changeColumns(mSelectedDates.count()); 1180 mAllDayAgenda->changeColumns(mSelectedDates.count());
1179 mAgenda->changeColumns(mSelectedDates.count()); 1181 mAgenda->changeColumns(mSelectedDates.count());
1180 qApp->processEvents(); 1182 qApp->processEvents();
1181 mEventIndicatorTop->changeColumns(mSelectedDates.count()); 1183 mEventIndicatorTop->changeColumns(mSelectedDates.count());
1182 mEventIndicatorBottom->changeColumns(mSelectedDates.count()); 1184 mEventIndicatorBottom->changeColumns(mSelectedDates.count());
1183 setHolidayMasks(); 1185 setHolidayMasks();
1184 1186
1185 //mAgenda->hideUnused(); 1187 //mAgenda->hideUnused();
1186 //mAllDayAgenda->hideUnused(); 1188 //mAllDayAgenda->hideUnused();
1187 1189
1188 // mAgenda->blockNextRepaint( false ); 1190 // mAgenda->blockNextRepaint( false );
1189 // mAgenda->viewport()->repaint(); 1191 // mAgenda->viewport()->repaint();
1190 // mAgenda->blockNextRepaint( true ); 1192 // mAgenda->blockNextRepaint( true );
1191 mMinY.resize(mSelectedDates.count()); 1193 mMinY.resize(mSelectedDates.count());
1192 mMaxY.resize(mSelectedDates.count()); 1194 mMaxY.resize(mSelectedDates.count());
1193 1195
1194 QPtrList<Event> dayEvents; 1196 QPtrList<Event> dayEvents;
1195 1197
1196 // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. 1198 // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue.
1197 // Therefore, gtodoset all of them. 1199 // Therefore, gtodoset all of them.
1198 QPtrList<Todo> todos = calendar()->todos(); 1200 QPtrList<Todo> todos = calendar()->todos();
1199 1201
1200 mAgenda->setDateList(mSelectedDates); 1202 mAgenda->setDateList(mSelectedDates);
1201 1203
1202 QDate today = QDate::currentDate(); 1204 QDate today = QDate::currentDate();
1203 1205
1204 DateList::ConstIterator dit; 1206 DateList::ConstIterator dit;
1205 int curCol = 0; 1207 int curCol = 0;
1206 for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { 1208 for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) {
1207 QDate currentDate = *dit; 1209 QDate currentDate = *dit;
1208 // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString() 1210 // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString()
1209 // << endl; 1211 // << endl;
1210 1212
1211 dayEvents = calendar()->events(currentDate,true); 1213 dayEvents = calendar()->events(currentDate,true);
1212 1214
1213 // Default values, which can never be reached 1215 // Default values, which can never be reached
1214 mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1; 1216 mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1;
1215 mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1; 1217 mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1;
1216 1218
1217 unsigned int numEvent; 1219 unsigned int numEvent;
1218 for(numEvent=0;numEvent<dayEvents.count();++numEvent) { 1220 for(numEvent=0;numEvent<dayEvents.count();++numEvent) {
1219 Event *event = dayEvents.at(numEvent); 1221 Event *event = dayEvents.at(numEvent);
1220 if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) 1222 if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") )
1221 if ( event->uid().left(15) == QString("last-syncEvent-") ) 1223 if ( event->uid().left(15) == QString("last-syncEvent-") )
1222 continue; 1224 continue;
1223 // kdDebug() << " Event: " << event->summary() << endl; 1225 // kdDebug() << " Event: " << event->summary() << endl;
1224 1226
1225 int beginX = currentDate.daysTo(event->dtStart().date()) + curCol; 1227 int beginX = currentDate.daysTo(event->dtStart().date()) + curCol;
1226 int endX = currentDate.daysTo(event->dtEnd().date()) + curCol; 1228 int endX = currentDate.daysTo(event->dtEnd().date()) + curCol;
1227 1229
1228 // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl; 1230 // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl;
1229 1231
1230 if (event->doesFloat()) { 1232 if (event->doesFloat()) {
1231 if (event->recurrence()->doesRecur()) { 1233 if (event->recurrence()->doesRecur()) {
1232 mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); 1234 mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol);
1233 } else { 1235 } else {
1234 if (beginX <= 0 && curCol == 0) { 1236 if (beginX <= 0 && curCol == 0) {
1235 mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); 1237 mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX);
1236 } else if (beginX == curCol) { 1238 } else if (beginX == curCol) {
1237 mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); 1239 mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX);
1238 } 1240 }
1239 } 1241 }
1240 } else if (event->isMultiDay()) { 1242 } else if (event->isMultiDay()) {
1241 if ( event->doesRecur () ) { 1243 if ( event->doesRecur () ) {
1242 QDate dateit = currentDate; 1244 QDate dateit = currentDate;
1243 int count = 0; 1245 int count = 0;
1244 int max = event->dtStart().daysTo( event->dtEnd() ) +2; 1246 int max = event->dtStart().daysTo( event->dtEnd() ) +2;
1245 while (! event->recursOn( dateit ) && count <= max ) { 1247 while (! event->recursOn( dateit ) && count <= max ) {
1246 ++count; 1248 ++count;
1247 dateit = dateit.addDays( -1 ); 1249 dateit = dateit.addDays( -1 );
1248 } 1250 }
1249 bool ok; 1251 bool ok;
1250 QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok ); 1252 QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok );
1251 if ( ok ) 1253 if ( ok )
1252 { 1254 {
1253 int secs = event->dtStart().secsTo( event->dtEnd() ); 1255 int secs = event->dtStart().secsTo( event->dtEnd() );
1254 QDateTime nextOcend =nextOcstart.addSecs( secs ); ; 1256 QDateTime nextOcend =nextOcstart.addSecs( secs ); ;
1255 beginX = currentDate.daysTo(nextOcstart.date()) + curCol; 1257 beginX = currentDate.daysTo(nextOcstart.date()) + curCol;
1256 endX = currentDate.daysTo(nextOcend.date()) + curCol; 1258 endX = currentDate.daysTo(nextOcend.date()) + curCol;
1257 1259
1258 } 1260 }
1259 } 1261 }
1260 int startY = mAgenda->timeToY(event->dtStart().time()); 1262 int startY = mAgenda->timeToY(event->dtStart().time());
1261 int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; 1263 int endY = mAgenda->timeToY(event->dtEnd().time()) - 1;
1262 //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol ); 1264 //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol );
1263 if ((beginX <= 0 && curCol == 0) || beginX == curCol) { 1265 if ((beginX <= 0 && curCol == 0) || beginX == curCol) {
1264 //qDebug("insert!!! "); 1266 //qDebug("insert!!! ");
1265 mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY); 1267 mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY);
1266 } 1268 }
1267 if (beginX == curCol) { 1269 if (beginX == curCol) {
1268 mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); 1270 mMaxY[curCol] = mAgenda->timeToY(QTime(23,59));
1269 if (startY < mMinY[curCol]) mMinY[curCol] = startY; 1271 if (startY < mMinY[curCol]) mMinY[curCol] = startY;
1270 } else if (endX == curCol) { 1272 } else if (endX == curCol) {
1271 mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); 1273 mMinY[curCol] = mAgenda->timeToY(QTime(0,0));
1272 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; 1274 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY;
1273 } else { 1275 } else {
1274 mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); 1276 mMinY[curCol] = mAgenda->timeToY(QTime(0,0));
1275 mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); 1277 mMaxY[curCol] = mAgenda->timeToY(QTime(23,59));
1276 } 1278 }
1277 } else { 1279 } else {
1278 int startY = mAgenda->timeToY(event->dtStart().time()); 1280 int startY = mAgenda->timeToY(event->dtStart().time());
1279 int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; 1281 int endY = mAgenda->timeToY(event->dtEnd().time()) - 1;
1280 if (endY < startY) endY = startY; 1282 if (endY < startY) endY = startY;
1281 mAgenda->insertItem(event,currentDate,curCol,startY,endY); 1283 mAgenda->insertItem(event,currentDate,curCol,startY,endY);
1282 if (startY < mMinY[curCol]) mMinY[curCol] = startY; 1284 if (startY < mMinY[curCol]) mMinY[curCol] = startY;
1283 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; 1285 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY;
1284 } 1286 }
1285 } 1287 }
1286 // ---------- [display Todos -------------- 1288 // ---------- [display Todos --------------
1287 unsigned int numTodo; 1289 unsigned int numTodo;
1288 for (numTodo = 0; numTodo < todos.count(); ++numTodo) { 1290 for (numTodo = 0; numTodo < todos.count(); ++numTodo) {
1289 Todo *todo = todos.at(numTodo); 1291 Todo *todo = todos.at(numTodo);
1290 1292
1291 if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date 1293 if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date
1292 1294
1293 // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. 1295 // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue.
1294 // Already completed items can be displayed on their original due date 1296 // Already completed items can be displayed on their original due date
1295 //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda 1297 //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda
1296 bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; 1298 bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda;
1297 bool fillIn = false; 1299 bool fillIn = false;
1298 if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) 1300 if ( todo->hasCompletedDate() && todo->completed().date() == currentDate )
1299 fillIn = true; 1301 fillIn = true;
1300 if ( ! fillIn && !todo->hasCompletedDate() ) 1302 if ( ! fillIn && !todo->hasCompletedDate() )
1301 fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); 1303 fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue);
1302 if ( fillIn ) { 1304 if ( fillIn ) {
1303 if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue 1305 if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue
1304 if ( KOPrefs::instance()->mShowTodoInAgenda ) 1306 if ( KOPrefs::instance()->mShowTodoInAgenda )
1305 mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); 1307 mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol);
1306 } 1308 }
1307 else { 1309 else {
1308 QDateTime dt; 1310 QDateTime dt;
1309 if ( todo->hasCompletedDate() ) 1311 if ( todo->hasCompletedDate() )
1310 dt = todo->completed(); 1312 dt = todo->completed();
1311 else 1313 else
1312 dt = todo->dtDue();; 1314 dt = todo->dtDue();;
1313 1315
1314 1316
1315 int endY = mAgenda->timeToY(dt.time()) - 1; 1317 int endY = mAgenda->timeToY(dt.time()) - 1;
1316 int hi = (18/KOPrefs::instance()->mHourSize); 1318 int hi = (18/KOPrefs::instance()->mHourSize);
1317 //qDebug("hei %d ",KOPrefs::instance()->mHourSize); 1319 //qDebug("hei %d ",KOPrefs::instance()->mHourSize);
1318 int startY = endY -hi; 1320 int startY = endY -hi;
1319 1321
1320 mAgenda->insertItem(todo,currentDate,curCol,startY,endY); 1322 mAgenda->insertItem(todo,currentDate,curCol,startY,endY);
1321 1323
1322 if (startY < mMinY[curCol]) mMinY[curCol] = startY; 1324 if (startY < mMinY[curCol]) mMinY[curCol] = startY;
1323 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; 1325 if (endY > mMaxY[curCol]) mMaxY[curCol] = endY;
1324 } 1326 }
1325 } 1327 }
1326 } 1328 }
1327 // ---------- display Todos] -------------- 1329 // ---------- display Todos] --------------
1328 1330
1329 ++curCol; 1331 ++curCol;
1330 } 1332 }
1331 mAgenda->hideUnused(); 1333 mAgenda->hideUnused();
1332 mAllDayAgenda->hideUnused(); 1334 mAllDayAgenda->hideUnused();
1333 mAgenda->checkScrollBoundaries(); 1335 mAgenda->checkScrollBoundaries();
1334 1336
1335 deleteSelectedDateTime(); 1337 deleteSelectedDateTime();
1336 1338
1337 createDayLabels(); 1339 createDayLabels();
1338 emit incidenceSelected( 0 ); 1340 emit incidenceSelected( 0 );
1339 1341
1340 if ( globalFlagBlockAgenda == 2 ) { 1342 if ( globalFlagBlockAgenda == 2 ) {
1341 if ( KOPrefs::instance()->mSetTimeToDayStartAt ) 1343 if ( KOPrefs::instance()->mSetTimeToDayStartAt )
1342 setStartHour( KOPrefs::instance()->mDayBegins ); 1344 setStartHour( KOPrefs::instance()->mDayBegins );
1343 else if ( KOPrefs::instance()->mCenterOnCurrentTime ) 1345 else if ( KOPrefs::instance()->mCenterOnCurrentTime )
1344 setStartHour( QTime::currentTime ().hour() ); 1346 setStartHour( QTime::currentTime ().hour() );
1345 // qApp->processEvents(); 1347 // qApp->processEvents();
1346 } 1348 }
1347 qApp->processEvents(); 1349 qApp->processEvents();
1348 //qDebug("qApp->processEvents(); END "); 1350 //qDebug("qApp->processEvents(); END ");
1349 globalFlagBlockAgenda = 0; 1351 globalFlagBlockAgenda = 0;
1350 1352
1351 // mAgenda->hideUnused(); 1353 // mAgenda->hideUnused();
1352 //mAllDayAgenda->hideUnused(); 1354 //mAllDayAgenda->hideUnused();
1353 mAllDayAgenda->drawContentsToPainter(); 1355 mAllDayAgenda->drawContentsToPainter();
1354 mAgenda->drawContentsToPainter(); 1356 mAgenda->drawContentsToPainter();
1355 repaintAgenda(); 1357 repaintAgenda();
1356 onlyOne = false; 1358 onlyOne = false;
1357 // mAgenda->finishUpdate(); 1359 // mAgenda->finishUpdate();
1358 //mAllDayAgenda->finishUpdate(); 1360 //mAllDayAgenda->finishUpdate();
1359 1361
1360 // repaintAgenda(); 1362 // repaintAgenda();
1361 //qApp->processEvents(); 1363 //qApp->processEvents();
1362 // globalFlagBlockAgenda = 0; 1364 // globalFlagBlockAgenda = 0;
1363} 1365}
1364void KOAgendaView::repaintAgenda() 1366void KOAgendaView::repaintAgenda()
1365{ 1367{
1366 // mAllDayAgenda->drawContentsToPainter(); 1368 // mAllDayAgenda->drawContentsToPainter();
1367// mAllDayAgenda->viewport()->repaint( false ); 1369// mAllDayAgenda->viewport()->repaint( false );
1368// mAgenda->drawContentsToPainter(); 1370// mAgenda->drawContentsToPainter();
1369// mAgenda->viewport()->repaint( false ); 1371// mAgenda->viewport()->repaint( false );
1370// qApp->processEvents(); 1372// qApp->processEvents();
1371 1373
1372 //qDebug("KOAgendaView::repaintAgenda() "); 1374 //qDebug("KOAgendaView::repaintAgenda() ");
1373 //qApp->processEvents(); 1375 //qApp->processEvents();
1374 mAgenda->viewport()->repaint( false ); 1376 mAgenda->viewport()->repaint( false );
1375 mAllDayAgenda->viewport()->repaint( false ); 1377 mAllDayAgenda->viewport()->repaint( false );
1376 mAgenda->finishUpdate(); 1378 mAgenda->finishUpdate();
1377 mAllDayAgenda->finishUpdate(); 1379 mAllDayAgenda->finishUpdate();
1378} 1380}
1379 1381
1380 1382
1381void KOAgendaView::clearView() 1383void KOAgendaView::clearView()
1382{ 1384{
1383 // kdDebug() << "ClearView" << endl; 1385 // kdDebug() << "ClearView" << endl;
1384 mAllDayAgenda->clear(); 1386 mAllDayAgenda->clear();
1385 mAgenda->clear(); 1387 mAgenda->clear();
1386} 1388}
1387 1389
1388void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, 1390void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd,
1389 const QDate &td) 1391 const QDate &td)
1390{ 1392{
1391#ifndef KORG_NOPRINTER 1393#ifndef KORG_NOPRINTER
1392 if (fd == td) 1394 if (fd == td)
1393 calPrinter->preview(CalPrinter::Day, fd, td); 1395 calPrinter->preview(CalPrinter::Day, fd, td);
1394 else 1396 else
1395 calPrinter->preview(CalPrinter::Week, fd, td); 1397 calPrinter->preview(CalPrinter::Week, fd, td);
1396#endif 1398#endif
1397} 1399}
1398 1400
1399// void KOAgendaView::updateMovedTodo() 1401// void KOAgendaView::updateMovedTodo()
1400// { 1402// {
1401// // updateConfig(); 1403// // updateConfig();
1402// // emit updateTodoViews(); 1404// // emit updateTodoViews();
1403// } 1405// }
1404 1406
1405void KOAgendaView::slotShowDateView( int mode , int d ) 1407void KOAgendaView::slotShowDateView( int mode , int d )
1406{ 1408{
1407 if ( d >= mSelectedDates.count() ) { 1409 if ( d >= mSelectedDates.count() ) {
1408 qDebug("KOAgendaView::slotShowDateView datecounterror %d d ", d, mSelectedDates.count() ); 1410 qDebug("KOAgendaView::slotShowDateView datecounterror %d d ", d, mSelectedDates.count() );
1409 1411
1410 } else { 1412 } else {
1411 QDate day = mSelectedDates[d]; 1413 QDate day = mSelectedDates[d];
1412 emit showDateView(mode , day ); 1414 emit showDateView(mode , day );
1413 } 1415 }
1414 1416
1415} 1417}
1416void KOAgendaView::newEvent(int gx, int gy) 1418void KOAgendaView::newEvent(int gx, int gy)
1417{ 1419{
1418 if (!mSelectedDates.count()) return; 1420 if (!mSelectedDates.count()) return;
1419 1421
1420 QDate day = mSelectedDates[gx]; 1422 QDate day = mSelectedDates[gx];
1421 1423
1422 QTime time = mAgenda->gyToTime(gy); 1424 QTime time = mAgenda->gyToTime(gy);
1423 QDateTime dt(day,time); 1425 QDateTime dt(day,time);
1424 // if ( dt < QDateTime::currentDateTime () ) 1426 // if ( dt < QDateTime::currentDateTime () )
1425 // dt = QDateTime::currentDateTime ().addSecs( 3600 ); 1427 // dt = QDateTime::currentDateTime ().addSecs( 3600 );
1426 emit newEventSignal(dt); 1428 emit newEventSignal(dt);
1427} 1429}
1428 1430
1429void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) 1431void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd)
1430{ 1432{
1431 if (!mSelectedDates.count()) return; 1433 if (!mSelectedDates.count()) return;
1432 1434
1433 QDate dayStart = mSelectedDates[gxStart]; 1435 QDate dayStart = mSelectedDates[gxStart];
1434 QDate dayEnd = mSelectedDates[gxEnd]; 1436 QDate dayEnd = mSelectedDates[gxEnd];
1435 1437
1436 QTime timeStart = mAgenda->gyToTime(gyStart); 1438 QTime timeStart = mAgenda->gyToTime(gyStart);
1437 QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); 1439 QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 );
1438 1440
1439 QDateTime dtStart(dayStart,timeStart); 1441 QDateTime dtStart(dayStart,timeStart);
1440 QDateTime dtEnd(dayEnd,timeEnd); 1442 QDateTime dtEnd(dayEnd,timeEnd);
1441 1443
1442 emit newEventSignal(dtStart,dtEnd); 1444 emit newEventSignal(dtStart,dtEnd);
1443} 1445}
1444 1446
1445void KOAgendaView::newEventAllDay(int gx, int ) 1447void KOAgendaView::newEventAllDay(int gx, int )
1446{ 1448{
1447 if (!mSelectedDates.count()) return; 1449 if (!mSelectedDates.count()) return;
1448 1450
1449 QDate day = mSelectedDates[gx]; 1451 QDate day = mSelectedDates[gx];
1450 1452
1451 emit newEventSignal(day); 1453 emit newEventSignal(day);
1452} 1454}
1453void KOAgendaView::newTodoAllDay(int gx, int ) 1455void KOAgendaView::newTodoAllDay(int gx, int )
1454{ 1456{
1455 if (!mSelectedDates.count()) return; 1457 if (!mSelectedDates.count()) return;
1456 1458
1457 QDateTime day (mSelectedDates[gx] ); 1459 QDateTime day (mSelectedDates[gx] );
1458 emit newTodoSignal(day, true); 1460 emit newTodoSignal(day, true);
1459} 1461}
1460void KOAgendaView::newTodo(int gx, int gy ) 1462void KOAgendaView::newTodo(int gx, int gy )
1461{ 1463{
1462 if (!mSelectedDates.count()) return; 1464 if (!mSelectedDates.count()) return;
1463 QDate dayStart = mSelectedDates[gx]; 1465 QDate dayStart = mSelectedDates[gx];
1464 QTime timeStart = mAgenda->gyToTime(gy); 1466 QTime timeStart = mAgenda->gyToTime(gy);
1465 QDateTime dt (dayStart,timeStart); 1467 QDateTime dt (dayStart,timeStart);
1466 emit newTodoSignal( dt, false ); 1468 emit newTodoSignal( dt, false );
1467} 1469}
1468 1470
1469void KOAgendaView::updateEventIndicatorTop(int newY) 1471void KOAgendaView::updateEventIndicatorTop(int newY)
1470{ 1472{
1471 uint i; 1473 uint i;
1472 for(i=0;i<mMinY.size();++i) { 1474 for(i=0;i<mMinY.size();++i) {
1473 if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true); 1475 if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true);
1474 else mEventIndicatorTop->enableColumn(i,false); 1476 else mEventIndicatorTop->enableColumn(i,false);
1475 } 1477 }
1476 1478
1477 mEventIndicatorTop->update(); 1479 mEventIndicatorTop->update();
1478} 1480}
1479 1481
1480void KOAgendaView::updateEventIndicatorBottom(int newY) 1482void KOAgendaView::updateEventIndicatorBottom(int newY)
1481{ 1483{
1482 uint i; 1484 uint i;
1483 for(i=0;i<mMaxY.size();++i) { 1485 for(i=0;i<mMaxY.size();++i) {
1484 if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true); 1486 if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true);
1485 else mEventIndicatorBottom->enableColumn(i,false); 1487 else mEventIndicatorBottom->enableColumn(i,false);
1486 } 1488 }
1487 1489
1488 mEventIndicatorBottom->update(); 1490 mEventIndicatorBottom->update();
1489} 1491}
1490 1492
1491void KOAgendaView::startDrag(Event *event) 1493void KOAgendaView::startDrag(Event *event)
1492{ 1494{
1493#ifndef KORG_NODND 1495#ifndef KORG_NODND
1494 DndFactory factory( calendar() ); 1496 DndFactory factory( calendar() );
1495 ICalDrag *vd = factory.createDrag(event,this); 1497 ICalDrag *vd = factory.createDrag(event,this);
1496 if (vd->drag()) { 1498 if (vd->drag()) {
1497 kdDebug() << "KOAgendaView::startDrag(): Delete drag source" << endl; 1499 kdDebug() << "KOAgendaView::startDrag(): Delete drag source" << endl;
1498 } 1500 }
1499#endif 1501#endif
1500} 1502}
1501 1503
1502void KOAgendaView::readSettings() 1504void KOAgendaView::readSettings()
1503{ 1505{
1504 readSettings(KOGlobals::config()); 1506 readSettings(KOGlobals::config());
1505} 1507}
1506 1508
1507void KOAgendaView::readSettings(KConfig *config) 1509void KOAgendaView::readSettings(KConfig *config)
1508{ 1510{
1509 // kdDebug() << "KOAgendaView::readSettings()" << endl; 1511 // kdDebug() << "KOAgendaView::readSettings()" << endl;
1510 1512
1511 config->setGroup("Views"); 1513 config->setGroup("Views");
1512 1514
1513 //#ifndef KORG_NOSPLITTER 1515 //#ifndef KORG_NOSPLITTER
1514 QValueList<int> sizes = config->readIntListEntry("Separator AgendaView"); 1516 QValueList<int> sizes = config->readIntListEntry("Separator AgendaView");
1515 if (sizes.count() == 2) { 1517 if (sizes.count() == 2) {
1516 if ( sizes[0] < 20 ) { 1518 if ( sizes[0] < 20 ) {
1517 sizes[1] = sizes[1] +20 - sizes[0]; 1519 sizes[1] = sizes[1] +20 - sizes[0];
1518 sizes[0] = 20; 1520 sizes[0] = 20;
1519 } 1521 }
1520 mSplitterAgenda->setSizes(sizes); 1522 mSplitterAgenda->setSizes(sizes);
1521 // qDebug("read %d %d ",sizes[0],sizes[1] ); 1523 // qDebug("read %d %d ",sizes[0],sizes[1] );
1522 } 1524 }
1523 //#endif 1525 //#endif
1524 1526
1525 // updateConfig(); 1527 // updateConfig();
1526} 1528}
1527 1529
1528void KOAgendaView::writeSettings(KConfig *config) 1530void KOAgendaView::writeSettings(KConfig *config)
1529{ 1531{
1530 // kdDebug() << "KOAgendaView::writeSettings()" << endl; 1532 // kdDebug() << "KOAgendaView::writeSettings()" << endl;
1531 1533
1532 config->setGroup("Views"); 1534 config->setGroup("Views");
1533 1535
1534 //#ifndef KORG_NOSPLITTER 1536 //#ifndef KORG_NOSPLITTER
1535 QValueList<int> list = mSplitterAgenda->sizes(); 1537 QValueList<int> list = mSplitterAgenda->sizes();
1536 config->writeEntry("Separator AgendaView",list); 1538 config->writeEntry("Separator AgendaView",list);
1537 //qDebug("write %d %d ", list[0],list[1] ); 1539 //qDebug("write %d %d ", list[0],list[1] );
1538 //#endif 1540 //#endif
1539} 1541}
1540 1542
1541void KOAgendaView::setHolidayMasks() 1543void KOAgendaView::setHolidayMasks()
1542{ 1544{
1543 mHolidayMask.resize(mSelectedDates.count()); 1545 mHolidayMask.resize(mSelectedDates.count());
1544 1546
1545 uint i; 1547 uint i;
1546 for(i=0;i<mSelectedDates.count();++i) { 1548 for(i=0;i<mSelectedDates.count();++i) {
1547 QDate date = mSelectedDates[i]; 1549 QDate date = mSelectedDates[i];
1548 bool showSaturday = KOPrefs::instance()->mExcludeSaturdays && (date.dayOfWeek() == 6); 1550 bool showSaturday = KOPrefs::instance()->mExcludeSaturdays && (date.dayOfWeek() == 6);
1549 bool showSunday = KOPrefs::instance()->mExcludeHolidays && (date.dayOfWeek() == 7); 1551 bool showSunday = KOPrefs::instance()->mExcludeHolidays && (date.dayOfWeek() == 7);
1550 bool showHoliday = false; 1552 bool showHoliday = false;
1551 if ( KOPrefs::instance()->mExcludeHolidays ) { 1553 if ( KOPrefs::instance()->mExcludeHolidays ) {
1552 QPtrList<Event> events = calendar()->events( date, true ); 1554 QPtrList<Event> events = calendar()->events( date, true );
1553 Event *event; 1555 Event *event;
1554 for( event = events.first(); event; event = events.next() ) { 1556 for( event = events.first(); event; event = events.next() ) {
1555 if ( event->isHoliday()) { 1557 if ( event->isHoliday()) {
1556 showHoliday = true; 1558 showHoliday = true;
1557 break; 1559 break;
1558 } 1560 }
1559 } 1561 }
1560 1562
1561 } 1563 }
1562 1564
1563#ifndef KORG_NOPLUGINS 1565#ifndef KORG_NOPLUGINS
1564 bool showHoliday = KOPrefs::instance()->mExcludeHolidays && 1566 bool showHoliday = KOPrefs::instance()->mExcludeHolidays &&
1565 !KOCore::self()->holiday(date).isEmpty(); 1567 !KOCore::self()->holiday(date).isEmpty();
1566#endif 1568#endif
1567 bool showDay = showSaturday || showSunday || showHoliday; 1569 bool showDay = showSaturday || showSunday || showHoliday;
1568 1570
1569 if (showDay) { 1571 if (showDay) {
1570 mHolidayMask.at(i) = true; 1572 mHolidayMask.at(i) = true;
1571 } else { 1573 } else {
1572 mHolidayMask.at(i) = false; 1574 mHolidayMask.at(i) = false;
1573 } 1575 }
1574 } 1576 }
1575 1577
1576 mAgenda->setHolidayMask(&mHolidayMask); 1578 mAgenda->setHolidayMask(&mHolidayMask);
1577 mAllDayAgenda->setHolidayMask(&mHolidayMask); 1579 mAllDayAgenda->setHolidayMask(&mHolidayMask);
1578} 1580}
1579 1581
1580void KOAgendaView::setContentsPos(int y) 1582void KOAgendaView::setContentsPos(int y)
1581{ 1583{
1582 mAgenda->setContentsPos(0,y); 1584 mAgenda->setContentsPos(0,y);
1583} 1585}
1584 1586
1585void KOAgendaView::clearSelection() 1587void KOAgendaView::clearSelection()
1586{ 1588{
1587 mAgenda->deselectItem(); 1589 mAgenda->deselectItem();
1588 mAllDayAgenda->deselectItem(); 1590 mAllDayAgenda->deselectItem();
1589} 1591}
1590 1592
1591void KOAgendaView::newTimeSpanSelectedAllDay(int gxStart, int gyStart, 1593void KOAgendaView::newTimeSpanSelectedAllDay(int gxStart, int gyStart,
1592 int gxEnd, int gyEnd) 1594 int gxEnd, int gyEnd)
1593{ 1595{
1594 mTimeSpanInAllDay = true; 1596 mTimeSpanInAllDay = true;
1595 newTimeSpanSelected(gxStart,gyStart,gxEnd,gyEnd); 1597 newTimeSpanSelected(gxStart,gyStart,gxEnd,gyEnd);
1596} 1598}
1597 1599
1598 1600
1599 1601
1600 1602
1601void KOAgendaView::newTimeSpanSelected(int gxStart, int gyStart, 1603void KOAgendaView::newTimeSpanSelected(int gxStart, int gyStart,
1602 int gxEnd, int gyEnd) 1604 int gxEnd, int gyEnd)
1603{ 1605{
1604 if (!mSelectedDates.count()) return; 1606 if (!mSelectedDates.count()) return;
1605 1607
1606 QDate dayStart = mSelectedDates[gxStart]; 1608 QDate dayStart = mSelectedDates[gxStart];
1607 QDate dayEnd = mSelectedDates[gxEnd]; 1609 QDate dayEnd = mSelectedDates[gxEnd];
1608 1610
1609 QTime timeStart = mAgenda->gyToTime(gyStart); 1611 QTime timeStart = mAgenda->gyToTime(gyStart);
1610 QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); 1612 QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 );
1611 1613
1612 QDateTime dtStart(dayStart,timeStart); 1614 QDateTime dtStart(dayStart,timeStart);
1613 QDateTime dtEnd(dayEnd,timeEnd); 1615 QDateTime dtEnd(dayEnd,timeEnd);
1614 1616
1615 mTimeSpanBegin = dtStart; 1617 mTimeSpanBegin = dtStart;
1616 mTimeSpanEnd = dtEnd; 1618 mTimeSpanEnd = dtEnd;
1617 1619
1618} 1620}
1619 1621
1620void KOAgendaView::deleteSelectedDateTime() 1622void KOAgendaView::deleteSelectedDateTime()
1621{ 1623{
1622 mTimeSpanBegin.setDate(QDate()); 1624 mTimeSpanBegin.setDate(QDate());
1623 mTimeSpanEnd.setDate(QDate()); 1625 mTimeSpanEnd.setDate(QDate());
1624 mTimeSpanInAllDay = false; 1626 mTimeSpanInAllDay = false;
1625} 1627}
1626 1628
1627void KOAgendaView::keyPressEvent ( QKeyEvent * e ) 1629void KOAgendaView::keyPressEvent ( QKeyEvent * e )
1628{ 1630{
1629 e->ignore(); 1631 e->ignore();
1630} 1632}
1631 1633
1632void KOAgendaView::scrollOneHourUp() 1634void KOAgendaView::scrollOneHourUp()
1633{ 1635{
1634 1636
1635 mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 ); 1637 mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 );
1636} 1638}
1637void KOAgendaView::scrollOneHourDown() 1639void KOAgendaView::scrollOneHourDown()
1638{ 1640{
1639 mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 ); 1641 mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 );
1640} 1642}
1641 1643
1642void KOAgendaView::setStartHour( int h ) 1644void KOAgendaView::setStartHour( int h )
1643{ 1645{
1644 mAgenda->setStartHour( h ); 1646 mAgenda->setStartHour( h );
1645 1647
1646} 1648}
1647void KOAgendaView::setInitStartHour() 1649void KOAgendaView::setInitStartHour()
1648{ 1650{
1649 1651
1650 if ( KOPrefs::instance()->mCenterOnCurrentTime ) 1652 if ( KOPrefs::instance()->mCenterOnCurrentTime )
1651 setStartHour( QTime::currentTime ().hour() ); 1653 setStartHour( QTime::currentTime ().hour() );
1652 else 1654 else
1653 setStartHour( KOPrefs::instance()->mDayBegins ); 1655 setStartHour( KOPrefs::instance()->mDayBegins );
1654 1656
1655} 1657}
1656 1658
1657 1659
1658void KOAgendaView::updateTodo( Todo * t, int ) 1660void KOAgendaView::updateTodo( Todo * t, int )
1659{ 1661{
1660 if ( !isVisible() ) 1662 if ( !isVisible() )
1661 return; 1663 return;
1662 bool remove = false; 1664 bool remove = false;
1663 bool removeAD = false; 1665 bool removeAD = false;
1664 QDate da; 1666 QDate da;
1665 if ( t->hasCompletedDate() ) 1667 if ( t->hasCompletedDate() )
1666 da = t->completed().date(); 1668 da = t->completed().date();
1667 else 1669 else
1668 da = t->dtDue().date(); 1670 da = t->dtDue().date();
1669 if ( ! t->hasDueDate() && !t->hasCompletedDate() ) { 1671 if ( ! t->hasDueDate() && !t->hasCompletedDate() ) {
1670 remove = true; 1672 remove = true;
1671 removeAD = true; 1673 removeAD = true;
1672 } 1674 }
1673 else { 1675 else {
1674 bool overdue = (!t->isCompleted()) && (t->dtDue() < QDate::currentDate()) && KOPrefs::instance()->mShowTodoInAgenda ; 1676 bool overdue = (!t->isCompleted()) && (t->dtDue() < QDate::currentDate()) && KOPrefs::instance()->mShowTodoInAgenda ;
1675 if ( overdue && 1677 if ( overdue &&
1676 QDate::currentDate() >= mSelectedDates.first() && 1678 QDate::currentDate() >= mSelectedDates.first() &&
1677 QDate::currentDate() <= mSelectedDates.last()) { 1679 QDate::currentDate() <= mSelectedDates.last()) {
1678 removeAD = false; 1680 removeAD = false;
1679 remove = true; 1681 remove = true;
1680 } 1682 }
1681 else { 1683 else {
1682 1684
1683 if ( da < mSelectedDates.first() || 1685 if ( da < mSelectedDates.first() ||
1684 da > mSelectedDates.last() ) { 1686 da > mSelectedDates.last() ) {
1685 remove = true; 1687 remove = true;
1686 removeAD = true; 1688 removeAD = true;
1687 } else { 1689 } else {
1688 remove = t->doesFloat() && !t->hasCompletedDate(); 1690 remove = t->doesFloat() && !t->hasCompletedDate();
1689 removeAD = !remove; 1691 removeAD = !remove;
1690 } 1692 }
1691 } 1693 }
1692 } 1694 }
1693 int days = mSelectedDates.first().daysTo( da ); 1695 int days = mSelectedDates.first().daysTo( da );
1694 //qDebug("daysto %d %d %d", days, remove,removeAD ); 1696 //qDebug("daysto %d %d %d", days, remove,removeAD );
1695 mAgenda->updateTodo( t , days, remove); 1697 mAgenda->updateTodo( t , days, remove);
1696 if ( KOPrefs::instance()->mShowTodoInAgenda ) 1698 if ( KOPrefs::instance()->mShowTodoInAgenda )
1697 mAllDayAgenda->updateTodo( t , days, removeAD); 1699 mAllDayAgenda->updateTodo( t , days, removeAD);
1698 //qDebug("KOAgendaView::updateTodo( Todo *, int ) "); 1700 //qDebug("KOAgendaView::updateTodo( Todo *, int ) ");
1699 1701
1700} 1702}
diff --git a/korganizer/koagendaview.h b/korganizer/koagendaview.h
index 30c9b05..c6e6602 100644
--- a/korganizer/koagendaview.h
+++ b/korganizer/koagendaview.h
@@ -1,292 +1,292 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23#ifndef KOAGENDAVIEW_H 23#ifndef KOAGENDAVIEW_H
24#define KOAGENDAVIEW_H 24#define KOAGENDAVIEW_H
25 25
26#include <qscrollview.h> 26#include <qscrollview.h>
27#include <qdatetime.h> 27#include <qdatetime.h>
28#include <qpushbutton.h> 28#include <qpushbutton.h>
29#include <qlayout.h> 29#include <qlayout.h>
30#ifndef DESKTOP_VERSION 30#ifndef DESKTOP_VERSION
31#include <qksplitter.h> 31#include <qksplitter.h>
32#else 32#else
33#include <qsplitter.h> 33#include <qsplitter.h>
34#endif 34#endif
35#include <qmemarray.h> 35#include <qmemarray.h>
36 36
37#include "koeventview.h" 37#include "koeventview.h"
38 38
39class QHBox; 39class QHBox;
40class QFrame; 40class QFrame;
41class QLabel; 41class QLabel;
42class QPushButton; 42class QPushButton;
43class CalendarView; 43class CalendarView;
44class KOAgenda; 44class KOAgenda;
45class KOAgendaItem; 45class KOAgendaItem;
46class KConfig; 46class KConfig;
47class KDGanttMinimizeSplitter; 47class KDGanttMinimizeSplitter;
48 48
49class KOAgendaButton : public QPushButton 49class KOAgendaButton : public QPushButton
50{ 50{
51 Q_OBJECT 51 Q_OBJECT
52 public: 52 public:
53 KOAgendaButton( QWidget *parent=0, const char *name=0 ) : 53 KOAgendaButton( QWidget *parent=0, const char *name=0 ) :
54 QPushButton( parent, name ) 54 QPushButton( parent, name )
55 { 55 {
56 mNum = -3; 56 mNum = -3;
57 setFlat( true ); 57 setFlat( true );
58 setFocusPolicy(NoFocus); 58 setFocusPolicy(NoFocus);
59 setSizePolicy(QSizePolicy( QSizePolicy::Expanding ,QSizePolicy::Expanding )); 59 setSizePolicy(QSizePolicy( QSizePolicy::Expanding ,QSizePolicy::Expanding ));
60 connect( this, SIGNAL( clicked() ), this, SLOT ( bClicked() ) ); 60 connect( this, SIGNAL( clicked() ), this, SLOT ( bClicked() ) );
61 }; 61 };
62 62
63 QSize sizeHint () const { return QSize( 5,5) ;} 63 QSize sizeHint () const { return QSize( 5,5) ;}
64 void setNum( int n) { mNum = n; } 64 void setNum( int n) { mNum = n; }
65private slots: 65private slots:
66 void bClicked() {emit numClicked( mNum);} 66 void bClicked() {emit numClicked( mNum);}
67signals: 67signals:
68 void numClicked( int ); 68 void numClicked( int );
69private: 69private:
70 int mNum; 70 int mNum;
71}; 71};
72 72
73class TimeLabels : public QScrollView { 73class TimeLabels : public QScrollView {
74 Q_OBJECT 74 Q_OBJECT
75 public: 75 public:
76 TimeLabels(int rows,QWidget *parent=0,const char *name=0,WFlags f=0); 76 TimeLabels(int rows,QWidget *parent=0,const char *name=0,WFlags f=0);
77 77
78 void setCellHeight(int height); 78 void setCellHeight(int height);
79 79
80 /** Calculates the minimum width */ 80 /** Calculates the minimum width */
81 virtual int minimumWidth() const; 81 virtual int minimumWidth() const;
82 82
83 /** updates widget's internal state */ 83 /** updates widget's internal state */
84 void updateConfig(); 84 void updateConfig();
85 85
86 /** */ 86 /** */
87 void setAgenda(KOAgenda* agenda); 87 void setAgenda(KOAgenda* agenda);
88 88
89 /** */ 89 /** */
90 virtual void paintEvent(QPaintEvent* e); 90 virtual void paintEvent(QPaintEvent* e);
91 void contentsMousePressEvent ( QMouseEvent * ) ; 91 void contentsMousePressEvent ( QMouseEvent * ) ;
92 void contentsMouseReleaseEvent ( QMouseEvent * ); 92 void contentsMouseReleaseEvent ( QMouseEvent * );
93 void contentsMouseMoveEvent ( QMouseEvent * ); 93 void contentsMouseMoveEvent ( QMouseEvent * );
94 94
95 public slots: 95 public slots:
96 /** update time label positions */ 96 /** update time label positions */
97 void positionChanged(); 97 void positionChanged();
98 signals: 98 signals:
99 void scaleChanged(); 99 void scaleChanged();
100 protected: 100 protected:
101 void drawContents(QPainter *p,int cx, int cy, int cw, int ch); 101 void drawContents(QPainter *p,int cx, int cy, int cw, int ch);
102 102
103 private: 103 private:
104 QPixmap myPix; 104 QPixmap myPix;
105 bool mRedrawNeeded; 105 bool mRedrawNeeded;
106 int mMiniWidth; 106 int mMiniWidth;
107 int mMouseDownY; 107 int mMouseDownY;
108 QString mOrgCap; 108 QString mOrgCap;
109 int mRows; 109 int mRows;
110 int mCellHeight; 110 int mCellHeight;
111 111
112 /** */ 112 /** */
113 KOAgenda* mAgenda; 113 KOAgenda* mAgenda;
114}; 114};
115 115
116class EventIndicator : public QFrame { 116class EventIndicator : public QFrame {
117 Q_OBJECT 117 Q_OBJECT
118 public: 118 public:
119 enum Location { Top, Bottom }; 119 enum Location { Top, Bottom };
120 EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0); 120 EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0);
121 virtual ~EventIndicator(); 121 virtual ~EventIndicator();
122 122
123 void changeColumns(int columns); 123 void changeColumns(int columns);
124 void setPaintWidget( KDGanttMinimizeSplitter* ); 124 void setPaintWidget( KDGanttMinimizeSplitter* );
125 void setXOffset( int ); 125 void setXOffset( int );
126 void enableColumn(int column, bool enable); 126 void enableColumn(int column, bool enable);
127 127
128 protected: 128 protected:
129 void drawContents(QPainter *); 129 void drawContents(QPainter *);
130 130
131 private: 131 private:
132 int mXOffset; 132 int mXOffset;
133 KDGanttMinimizeSplitter* mPaintWidget; 133 KDGanttMinimizeSplitter* mPaintWidget;
134 int mColumns; 134 int mColumns;
135 QHBox *mTopBox; 135 QHBox *mTopBox;
136 QBoxLayout *mTopLayout; 136 QBoxLayout *mTopLayout;
137 Location mLocation; 137 Location mLocation;
138 QPixmap mPixmap; 138 QPixmap mPixmap;
139 QMemArray<bool> mEnabled; 139 QMemArray<bool> mEnabled;
140}; 140};
141 141
142/** 142/**
143 KOAgendaView is the agenda-like view used to display events in an one or 143 KOAgendaView is the agenda-like view used to display events in an one or
144 multi-day view. 144 multi-day view.
145*/ 145*/
146class KOAgendaView : public KOEventView { 146class KOAgendaView : public KOEventView {
147 Q_OBJECT 147 Q_OBJECT
148 public: 148 public:
149 KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 ); 149 KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 );
150 virtual ~KOAgendaView(); 150 virtual ~KOAgendaView();
151 void setStartHour( int ); 151 void setStartHour( int );
152 void toggleAllDay(); 152 void toggleAllDay();
153 153
154 154
155 /** Returns maximum number of days supported by the koagendaview */ 155 /** Returns maximum number of days supported by the koagendaview */
156 virtual int maxDatesHint(); 156 virtual int maxDatesHint();
157 157
158 /** Returns number of currently shown dates. */ 158 /** Returns number of currently shown dates. */
159 virtual int currentDateCount(); 159 virtual int currentDateCount();
160 160
161 /** returns the currently selected events */ 161 /** returns the currently selected events */
162 virtual QPtrList<Incidence> selectedIncidences(); 162 virtual QPtrList<Incidence> selectedIncidences();
163 163
164 /** returns the currently selected events */ 164 /** returns the currently selected events */
165 virtual DateList selectedDates(); 165 virtual DateList selectedDates();
166 166
167 /** Remove all events from view */ 167 /** Remove all events from view */
168 void clearView(); 168 void clearView();
169 KOAgenda *agenda() { return mAgenda;} 169 KOAgenda *agenda() { return mAgenda;}
170 virtual void printPreview(CalPrinter *calPrinter, 170 virtual void printPreview(CalPrinter *calPrinter,
171 const QDate &, const QDate &); 171 const QDate &, const QDate &);
172 172
173 /** start-datetime of selection */ 173 /** start-datetime of selection */
174 QDateTime selectionStart() {return mTimeSpanBegin;} 174 QDateTime selectionStart() {return mTimeSpanBegin;}
175 /** end-datetime of selection */ 175 /** end-datetime of selection */
176 QDateTime selectionEnd() {return mTimeSpanEnd;} 176 QDateTime selectionEnd() {return mTimeSpanEnd;}
177 /** returns true if selection is for whole day */ 177 /** returns true if selection is for whole day */
178 bool selectedIsAllDay() {return mTimeSpanInAllDay;} 178 bool selectedIsAllDay() {return mTimeSpanInAllDay;}
179 /** make selected start/end invalid */ 179 /** make selected start/end invalid */
180 void deleteSelectedDateTime(); 180 void deleteSelectedDateTime();
181 void repaintAgenda(); 181 void repaintAgenda();
182 public slots: 182 public slots:
183 void setInitStartHour(); 183 void setInitStartHour();
184 virtual void updateView(); 184 virtual void updateView();
185 virtual void updateConfig(); 185 virtual void updateConfig();
186 virtual void showDates(const QDate &start, const QDate &end); 186 virtual void showDates(const QDate &start, const QDate &end);
187 virtual void showEvents(QPtrList<Event> eventList); 187 virtual void showEvents(QPtrList<Event> eventList);
188 188
189 void updateTodo( Todo *, int ); 189 void updateTodo( Todo *, int );
190 void changeEventDisplay(Event *, int); 190 void changeEventDisplay(Event *, int);
191 191
192 void clearSelection(); 192 void clearSelection();
193 193
194 void newTodo(int gx,int gy); 194 void newTodo(int gx,int gy);
195 void newEvent(int gx,int gy); 195 void newEvent(int gx,int gy);
196 void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd); 196 void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd);
197 void newEventAllDay(int gx, int gy); 197 void newEventAllDay(int gx, int gy);
198 void newTodoAllDay(int gx, int gy); 198 void newTodoAllDay(int gx, int gy);
199 199
200 void startDrag(Event *); 200 void startDrag(Event *);
201 201
202 void readSettings(); 202 void readSettings();
203 void readSettings(KConfig *); 203 void readSettings(KConfig *);
204 void writeSettings(KConfig *); 204 void writeSettings(KConfig *);
205 205
206 void setContentsPos(int y); 206 void setContentsPos(int y);
207 207
208 void scrollOneHourUp(); 208 void scrollOneHourUp();
209 void scrollOneHourDown(); 209 void scrollOneHourDown();
210 void addToCalSlot(Incidence *, Incidence *); 210 void addToCalSlot(Incidence *, Incidence *);
211 void slotShowDateView( int, int ); 211 void slotShowDateView( int, int );
212 212
213 signals: 213 signals:
214 void showDateView( int, QDate ); 214 void showDateView( int, QDate );
215 void newTodoSignal( QDateTime ,bool ); 215 void newTodoSignal( QDateTime ,bool );
216 void toggleExpand(); 216 void toggleExpand();
217 void selectWeekNum( int ); 217 void selectWeekNum( int );
218 void todoMoved( Todo *, int ); 218 void todoMoved( Todo *, int );
219 void incidenceChanged(Incidence * , int ); 219 void incidenceChanged(Incidence * , int );
220 // void cloneIncidenceSignal(Incidence *); 220 // void cloneIncidenceSignal(Incidence *);
221 221
222 protected: 222 protected:
223 KOAgendaButton* getNewDaylabel(); 223 KOAgendaButton* getNewDaylabel();
224 bool mBlockUpdating; 224 bool mBlockUpdating;
225 int mUpcomingWidth; 225 int mUpcomingWidth;
226 /** Fill agenda beginning with date startDate */ 226 /** Fill agenda beginning with date startDate */
227 void fillAgenda(const QDate &startDate); 227 void fillAgenda(const QDate &startDate);
228 void resizeEvent( QResizeEvent* e ); 228 void resizeEvent( QResizeEvent* e );
229 /** Fill agenda using the current set value for the start date */ 229 /** Fill agenda using the current set value for the start date */
230 void fillAgenda(); 230 void fillAgenda();
231 231
232 /** Create labels for the selected dates. */ 232 /** Create labels for the selected dates. */
233 void createDayLabels(); 233 void createDayLabels();
234 234
235 /** 235 /**
236 Set the masks on the agenda widgets indicating, which days are holidays. 236 Set the masks on the agenda widgets indicating, which days are holidays.
237 */ 237 */
238 void setHolidayMasks(); 238 void setHolidayMasks();
239 239
240 protected slots: 240 protected slots:
241 void slotDaylabelClicked( int ); 241 void slotDaylabelClicked( int );
242 /** Update event belonging to agenda item */ 242 /** Update event belonging to agenda item */
243 void updateEventDates(KOAgendaItem *item, int mode = -1); 243 void updateEventDates(KOAgendaItem *item, int mode = -1);
244 //void updateMovedTodo(); 244 //void updateMovedTodo();
245 245
246 void updateEventIndicatorTop(int newY); 246 void updateEventIndicatorTop(int newY);
247 void updateEventIndicatorBottom(int newY); 247 void updateEventIndicatorBottom(int newY);
248 248
249 /** Updates data for selected timespan */ 249 /** Updates data for selected timespan */
250 void newTimeSpanSelected(int gxStart, int gyStart, int gxEnd, int gyEnd); 250 void newTimeSpanSelected(int gxStart, int gyStart, int gxEnd, int gyEnd);
251 /** Updates data for selected timespan for all day event*/ 251 /** Updates data for selected timespan for all day event*/
252 void newTimeSpanSelectedAllDay(int gxStart, int gyStart, int gxEnd, int gyEnd); 252 void newTimeSpanSelectedAllDay(int gxStart, int gyStart, int gxEnd, int gyEnd);
253 253
254 private: 254 private:
255 // view widgets 255 // view widgets
256 QFrame *mDayLabels; 256 QFrame *mDayLabels;
257 QHBox *mDayLabelsFrame; 257 QHBox *mDayLabelsFrame;
258 QBoxLayout *mLayoutDayLabels; 258 QBoxLayout *mLayoutDayLabels;
259 QFrame *mAllDayFrame; 259 QFrame *mAllDayFrame;
260 KOAgenda *mAllDayAgenda; 260 KOAgenda *mAllDayAgenda;
261 KOAgenda *mAgenda; 261 KOAgenda *mAgenda;
262 TimeLabels *mTimeLabels; 262 TimeLabels *mTimeLabels;
263 QWidget *mDummyAllDayLeft; 263 QWidget *mDummyAllDayLeft;
264 264
265 KDGanttMinimizeSplitter* mSplitterAgenda; 265 KDGanttMinimizeSplitter* mSplitterAgenda;
266 QPushButton *mExpandButton; 266 QPushButton *mExpandButton;
267 267
268 DateList mSelectedDates; // List of dates to be displayed 268 DateList mSelectedDates; // List of dates to be displayed
269 int mViewType; 269 int mViewType;
270 270
271 bool mWeekStartsMonday; 271 bool mWeekStartsMonday;
272 int mStartHour; 272 int mStartHour;
273 273
274 KOEventPopupMenu *mAgendaPopup; 274 KOEventPopupMenu *mAllAgendaPopup;
275 KOEventPopupMenu *mAllDayAgendaPopup; 275 //KOEventPopupMenu *mAllDayAgendaPopup;
276 276
277 EventIndicator *mEventIndicatorTop; 277 EventIndicator *mEventIndicatorTop;
278 EventIndicator *mEventIndicatorBottom; 278 EventIndicator *mEventIndicatorBottom;
279 279
280 QMemArray<int> mMinY; 280 QMemArray<int> mMinY;
281 QMemArray<int> mMaxY; 281 QMemArray<int> mMaxY;
282 282
283 QMemArray<bool> mHolidayMask; 283 QMemArray<bool> mHolidayMask;
284 284
285 QPtrList<KOAgendaButton> mDayLabelsList; 285 QPtrList<KOAgendaButton> mDayLabelsList;
286 QDateTime mTimeSpanBegin; 286 QDateTime mTimeSpanBegin;
287 QDateTime mTimeSpanEnd; 287 QDateTime mTimeSpanEnd;
288 bool mTimeSpanInAllDay; 288 bool mTimeSpanInAllDay;
289 void keyPressEvent ( QKeyEvent * e ); 289 void keyPressEvent ( QKeyEvent * e );
290}; 290};
291 291
292#endif // KOAGENDAVIEW_H 292#endif // KOAGENDAVIEW_H
diff --git a/korganizer/kotodoview.cpp b/korganizer/kotodoview.cpp
index ccc4b01..0a315cb 100644
--- a/korganizer/kotodoview.cpp
+++ b/korganizer/kotodoview.cpp
@@ -1,1394 +1,1413 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 18
19 As a special exception, permission is given to link this program 19 As a special exception, permission is given to link this program
20 with any edition of Qt, and distribute the resulting executable, 20 with any edition of Qt, and distribute the resulting executable,
21 without including the source code for Qt in the source distribution. 21 without including the source code for Qt in the source distribution.
22*/ 22*/
23 23
24#include <qlayout.h> 24#include <qlayout.h>
25#include <qheader.h> 25#include <qheader.h>
26#include <qcursor.h> 26#include <qcursor.h>
27#include <qwhatsthis.h> 27#include <qwhatsthis.h>
28 28
29#include <qvbox.h> 29#include <qvbox.h>
30#include <kdebug.h> 30#include <kdebug.h>
31#include "koprefs.h" 31#include "koprefs.h"
32#include <klocale.h> 32#include <klocale.h>
33#include <kglobal.h> 33#include <kglobal.h>
34#include <kiconloader.h> 34#include <kiconloader.h>
35#include <kmessagebox.h> 35#include <kmessagebox.h>
36 36
37#include <libkcal/icaldrag.h> 37#include <libkcal/icaldrag.h>
38#include <libkcal/vcaldrag.h> 38#include <libkcal/vcaldrag.h>
39#include <libkcal/calfilter.h> 39#include <libkcal/calfilter.h>
40#include <libkcal/dndfactory.h> 40#include <libkcal/dndfactory.h>
41#include <libkcal/calendarresources.h> 41#include <libkcal/calendarresources.h>
42#include <libkcal/resourcecalendar.h> 42#include <libkcal/resourcecalendar.h>
43#include <kresources/resourceselectdialog.h> 43#include <kresources/resourceselectdialog.h>
44#include <libkcal/kincidenceformatter.h> 44#include <libkcal/kincidenceformatter.h>
45#ifndef DESKTOP_VERSION 45#ifndef DESKTOP_VERSION
46#include <qpe/qpeapplication.h> 46#include <qpe/qpeapplication.h>
47#else 47#else
48#include <qapplication.h> 48#include <qapplication.h>
49#endif 49#endif
50#ifndef KORG_NOPRINTER 50#ifndef KORG_NOPRINTER
51#include "calprinter.h" 51#include "calprinter.h"
52#endif 52#endif
53#include "docprefs.h" 53#include "docprefs.h"
54 54
55#include "kotodoview.h" 55#include "kotodoview.h"
56using namespace KOrg; 56using namespace KOrg;
57 57
58 58
59class KOTodoViewWhatsThis :public QWhatsThis 59class KOTodoViewWhatsThis :public QWhatsThis
60{ 60{
61public: 61public:
62 KOTodoViewWhatsThis( QWidget *wid, KOTodoView* view ) : QWhatsThis( wid ), _wid(wid),_view (view) { }; 62 KOTodoViewWhatsThis( QWidget *wid, KOTodoView* view ) : QWhatsThis( wid ), _wid(wid),_view (view) { };
63 63
64protected: 64protected:
65 virtual QString text( const QPoint& p) 65 virtual QString text( const QPoint& p)
66 { 66 {
67 return _view->getWhatsThisText(p) ; 67 return _view->getWhatsThisText(p) ;
68 } 68 }
69private: 69private:
70 QWidget* _wid; 70 QWidget* _wid;
71 KOTodoView * _view; 71 KOTodoView * _view;
72}; 72};
73 73
74KOTodoListView::KOTodoListView(Calendar *calendar,QWidget *parent, 74KOTodoListView::KOTodoListView(Calendar *calendar,QWidget *parent,
75 const char *name) : 75 const char *name) :
76 KListView(parent,name) 76 KListView(parent,name)
77{ 77{
78 mName = QString ( name ); 78 mName = QString ( name );
79 mCalendar = calendar; 79 mCalendar = calendar;
80#ifndef DESKTOP_VERSION 80#ifndef DESKTOP_VERSION
81 QPEApplication::setStylusOperation(viewport(), QPEApplication::RightOnHold ); 81 QPEApplication::setStylusOperation(viewport(), QPEApplication::RightOnHold );
82#endif 82#endif
83 mOldCurrent = 0; 83 mOldCurrent = 0;
84 mMousePressed = false; 84 mMousePressed = false;
85 85
86 setAcceptDrops(true); 86 setAcceptDrops(true);
87 viewport()->setAcceptDrops(true); 87 viewport()->setAcceptDrops(true);
88 int size = 16; 88 int size = 16;
89 if (qApp->desktop()->width() < 300 ) 89 if (qApp->desktop()->width() < 300 )
90 size = 12; 90 size = 12;
91 setTreeStepSize( size + 6 ); 91 setTreeStepSize( size + 6 );
92 92
93} 93}
94 94
95void KOTodoListView::contentsDragEnterEvent(QDragEnterEvent *e) 95void KOTodoListView::contentsDragEnterEvent(QDragEnterEvent *e)
96{ 96{
97#ifndef KORG_NODND 97#ifndef KORG_NODND
98// kdDebug() << "KOTodoListView::contentsDragEnterEvent" << endl; 98// kdDebug() << "KOTodoListView::contentsDragEnterEvent" << endl;
99 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) && 99 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) &&
100 !QTextDrag::canDecode( e ) ) { 100 !QTextDrag::canDecode( e ) ) {
101 e->ignore(); 101 e->ignore();
102 return; 102 return;
103 } 103 }
104 104
105 mOldCurrent = currentItem(); 105 mOldCurrent = currentItem();
106#endif 106#endif
107} 107}
108 108
109 109
110void KOTodoListView::contentsDragMoveEvent(QDragMoveEvent *e) 110void KOTodoListView::contentsDragMoveEvent(QDragMoveEvent *e)
111{ 111{
112#ifndef KORG_NODND 112#ifndef KORG_NODND
113// kdDebug() << "KOTodoListView::contentsDragMoveEvent" << endl; 113// kdDebug() << "KOTodoListView::contentsDragMoveEvent" << endl;
114 114
115 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) && 115 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) &&
116 !QTextDrag::canDecode( e ) ) { 116 !QTextDrag::canDecode( e ) ) {
117 e->ignore(); 117 e->ignore();
118 return; 118 return;
119 } 119 }
120 120
121 e->accept(); 121 e->accept();
122#endif 122#endif
123} 123}
124 124
125void KOTodoListView::contentsDragLeaveEvent(QDragLeaveEvent *) 125void KOTodoListView::contentsDragLeaveEvent(QDragLeaveEvent *)
126{ 126{
127#ifndef KORG_NODND 127#ifndef KORG_NODND
128// kdDebug() << "KOTodoListView::contentsDragLeaveEvent" << endl; 128// kdDebug() << "KOTodoListView::contentsDragLeaveEvent" << endl;
129 129
130 setCurrentItem(mOldCurrent); 130 setCurrentItem(mOldCurrent);
131 setSelected(mOldCurrent,true); 131 setSelected(mOldCurrent,true);
132#endif 132#endif
133} 133}
134 134
135void KOTodoListView::contentsDropEvent(QDropEvent *e) 135void KOTodoListView::contentsDropEvent(QDropEvent *e)
136{ 136{
137#ifndef KORG_NODND 137#ifndef KORG_NODND
138// kdDebug() << "KOTodoListView::contentsDropEvent" << endl; 138// kdDebug() << "KOTodoListView::contentsDropEvent" << endl;
139 139
140 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) && 140 if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) &&
141 !QTextDrag::canDecode( e ) ) { 141 !QTextDrag::canDecode( e ) ) {
142 e->ignore(); 142 e->ignore();
143 return; 143 return;
144 } 144 }
145 145
146 DndFactory factory( mCalendar ); 146 DndFactory factory( mCalendar );
147 Todo *todo = factory.createDropTodo(e); 147 Todo *todo = factory.createDropTodo(e);
148 148
149 if (todo) { 149 if (todo) {
150 e->acceptAction(); 150 e->acceptAction();
151 151
152 KOTodoViewItem *destination = 152 KOTodoViewItem *destination =
153 (KOTodoViewItem *)itemAt(contentsToViewport(e->pos())); 153 (KOTodoViewItem *)itemAt(contentsToViewport(e->pos()));
154 Todo *destinationEvent = 0; 154 Todo *destinationEvent = 0;
155 if (destination) destinationEvent = destination->todo(); 155 if (destination) destinationEvent = destination->todo();
156 156
157 Todo *existingTodo = mCalendar->todo(todo->uid()); 157 Todo *existingTodo = mCalendar->todo(todo->uid());
158 158
159 if(existingTodo) { 159 if(existingTodo) {
160 Incidence *to = destinationEvent; 160 Incidence *to = destinationEvent;
161 while(to) { 161 while(to) {
162 if (to->uid() == todo->uid()) { 162 if (to->uid() == todo->uid()) {
163 KMessageBox::sorry(this, 163 KMessageBox::sorry(this,
164 i18n("Cannot move To-Do to itself\nor a child of itself"), 164 i18n("Cannot move To-Do to itself\nor a child of itself"),
165 i18n("Drop To-Do")); 165 i18n("Drop To-Do"));
166 delete todo; 166 delete todo;
167 return; 167 return;
168 } 168 }
169 to = to->relatedTo(); 169 to = to->relatedTo();
170 } 170 }
171 internalDrop = true; 171 internalDrop = true;
172 if ( destinationEvent ) 172 if ( destinationEvent )
173 reparentTodoSignal( destinationEvent, existingTodo ); 173 reparentTodoSignal( destinationEvent, existingTodo );
174 else 174 else
175 unparentTodoSignal(existingTodo); 175 unparentTodoSignal(existingTodo);
176 delete todo; 176 delete todo;
177 } else { 177 } else {
178 mCalendar->addTodo(todo); 178 mCalendar->addTodo(todo);
179 emit todoDropped(todo, KOGlobals::EVENTADDED); 179 emit todoDropped(todo, KOGlobals::EVENTADDED);
180 if ( destinationEvent ) 180 if ( destinationEvent )
181 reparentTodoSignal( destinationEvent, todo ); 181 reparentTodoSignal( destinationEvent, todo );
182 } 182 }
183 } 183 }
184 else { 184 else {
185 QString text; 185 QString text;
186 if (QTextDrag::decode(e,text)) { 186 if (QTextDrag::decode(e,text)) {
187 //QListViewItem *qlvi = itemAt( contentsToViewport(e->pos()) ); 187 //QListViewItem *qlvi = itemAt( contentsToViewport(e->pos()) );
188 KOTodoViewItem *todoi = static_cast<KOTodoViewItem *>(itemAt( contentsToViewport(e->pos()) )); 188 KOTodoViewItem *todoi = static_cast<KOTodoViewItem *>(itemAt( contentsToViewport(e->pos()) ));
189 qDebug("Dropped : " + text); 189 qDebug("Dropped : " + text);
190 QStringList emails = QStringList::split(",",text); 190 QStringList emails = QStringList::split(",",text);
191 for(QStringList::ConstIterator it = emails.begin();it!=emails.end();++it) { 191 for(QStringList::ConstIterator it = emails.begin();it!=emails.end();++it) {
192 int pos = (*it).find("<"); 192 int pos = (*it).find("<");
193 QString name = (*it).left(pos); 193 QString name = (*it).left(pos);
194 QString email = (*it).mid(pos); 194 QString email = (*it).mid(pos);
195 if (!email.isEmpty() && todoi) { 195 if (!email.isEmpty() && todoi) {
196 todoi->todo()->addAttendee(new Attendee(name,email)); 196 todoi->todo()->addAttendee(new Attendee(name,email));
197 } 197 }
198 } 198 }
199 } 199 }
200 else { 200 else {
201 qDebug("KOTodoListView::contentsDropEvent(): Todo from drop not decodable "); 201 qDebug("KOTodoListView::contentsDropEvent(): Todo from drop not decodable ");
202 e->ignore(); 202 e->ignore();
203 } 203 }
204 } 204 }
205#endif 205#endif
206} 206}
207 207
208void KOTodoListView::contentsMousePressEvent(QMouseEvent* e) 208void KOTodoListView::contentsMousePressEvent(QMouseEvent* e)
209{ 209{
210
211 QPoint p(contentsToViewport(e->pos()));
212 QListViewItem *i = itemAt(p);
213 bool rootClicked = true;
214 if (i) {
215 // if the user clicked into the root decoration of the item, don't
216 // try to start a drag!
217 int X = p.x();
218 //qDebug("%d %d %d", X, header()->sectionPos(0), treeStepSize() );
219 if (X > header()->sectionPos(0) +
220 treeStepSize() * (i->depth() + (rootIsDecorated() ? 1 : 0)) +
221 itemMargin() ||
222 X < header()->sectionPos(0)) {
223 rootClicked = false;
224 }
225 }
210#ifndef KORG_NODND 226#ifndef KORG_NODND
211 QPoint p(contentsToViewport(e->pos())); 227 mMousePressed = false;
212 QListViewItem *i = itemAt(p); 228 if (! rootClicked ) {
213 mMousePressed = false;
214 if (i) {
215 // if the user clicked into the root decoration of the item, don't
216 // try to start a drag!
217 if (p.x() > header()->sectionPos(header()->mapToIndex(0)) +
218 treeStepSize() * (i->depth() + (rootIsDecorated() ? 1 : 0)) +
219 itemMargin() ||
220 p.x() < header()->sectionPos(header()->mapToIndex(0))) {
221 if (e->button()==Qt::LeftButton) {
222 mPressPos = e->pos(); 229 mPressPos = e->pos();
223 mMousePressed = true; 230 mMousePressed = true;
224 }
225 } 231 }
226 }
227#endif 232#endif
228 QListView::contentsMousePressEvent(e); 233 //qDebug("KOTodoListView::contentsMousePressEvent %d", rootClicked);
234#ifndef DESKTOP_VERSION
235 if (!( e->button() == RightButton && rootClicked) )
236 QListView::contentsMousePressEvent(e);
237#else
238 QListView::contentsMousePressEvent(e);
239#endif
229} 240}
230void KOTodoListView::paintEvent(QPaintEvent* e) 241void KOTodoListView::paintEvent(QPaintEvent* e)
231{ 242{
232 emit paintNeeded(); 243 emit paintNeeded();
233 QListView::paintEvent( e); 244 QListView::paintEvent( e);
234} 245}
235void KOTodoListView::contentsMouseMoveEvent(QMouseEvent* e) 246void KOTodoListView::contentsMouseMoveEvent(QMouseEvent* e)
236{ 247{
237 248
238#ifndef KORG_NODND 249#ifndef KORG_NODND
239 //QListView::contentsMouseMoveEvent(e); 250 //QListView::contentsMouseMoveEvent(e);
240 if (mMousePressed && (mPressPos - e->pos()).manhattanLength() > 251 if (mMousePressed && (mPressPos - e->pos()).manhattanLength() >
241 QApplication::startDragDistance()*3) { 252 QApplication::startDragDistance()*3) {
242 mMousePressed = false; 253 mMousePressed = false;
243 QListViewItem *item = itemAt(contentsToViewport(mPressPos)); 254 QListViewItem *item = itemAt(contentsToViewport(mPressPos));
244 if (item) { 255 if (item) {
245 DndFactory factory( mCalendar ); 256 DndFactory factory( mCalendar );
246 ICalDrag *vd = factory.createDrag( 257 ICalDrag *vd = factory.createDrag(
247 ((KOTodoViewItem *)item)->todo(),viewport()); 258 ((KOTodoViewItem *)item)->todo(),viewport());
248 internalDrop = false; 259 internalDrop = false;
249 // we cannot do any senseful here, because the DnD is still broken in Qt 260 // we cannot do any senseful here, because the DnD is still broken in Qt
250 if (vd->drag()) { 261 if (vd->drag()) {
251 if ( !internalDrop ) { 262 if ( !internalDrop ) {
252 //emit deleteTodo( ((KOTodoViewItem *)item)->todo() ); 263 //emit deleteTodo( ((KOTodoViewItem *)item)->todo() );
253 qDebug("Dnd: External move: Delete drag source "); 264 qDebug("Dnd: External move: Delete drag source ");
254 } else 265 } else
255 qDebug("Dnd: Internal move "); 266 qDebug("Dnd: Internal move ");
256 267
257 } else { 268 } else {
258 if ( !internalDrop ) { 269 if ( !internalDrop ) {
259 qDebug("Dnd: External Copy"); 270 qDebug("Dnd: External Copy");
260 } else 271 } else
261 qDebug("DnD: Internal copy: Copy pending"); 272 qDebug("DnD: Internal copy: Copy pending");
262 } 273 }
263 } 274 }
264 } 275 }
265#endif 276#endif
266} 277}
267void KOTodoListView::keyReleaseEvent ( QKeyEvent *e ) 278void KOTodoListView::keyReleaseEvent ( QKeyEvent *e )
268{ 279{
269 if ( !e->isAutoRepeat() ) { 280 if ( !e->isAutoRepeat() ) {
270 mFlagKeyPressed = false; 281 mFlagKeyPressed = false;
271 } 282 }
272} 283}
273 284
274 285
275void KOTodoListView::keyPressEvent ( QKeyEvent * e ) 286void KOTodoListView::keyPressEvent ( QKeyEvent * e )
276{ 287{
277 qApp->processEvents(); 288 qApp->processEvents();
278 if ( e->isAutoRepeat() && !mFlagKeyPressed ) { 289 if ( e->isAutoRepeat() && !mFlagKeyPressed ) {
279 e->ignore(); 290 e->ignore();
280 // qDebug(" ignore %d",e->isAutoRepeat() ); 291 // qDebug(" ignore %d",e->isAutoRepeat() );
281 return; 292 return;
282 } 293 }
283 if (! e->isAutoRepeat() ) 294 if (! e->isAutoRepeat() )
284 mFlagKeyPressed = true; 295 mFlagKeyPressed = true;
285 QListViewItem* cn; 296 QListViewItem* cn;
286 if ( e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter ) { 297 if ( e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter ) {
287 cn = currentItem(); 298 cn = currentItem();
288 if ( cn ) { 299 if ( cn ) {
289 KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); 300 KOTodoViewItem* ci = (KOTodoViewItem*)( cn );
290 if ( ci ){ 301 if ( ci ){
291 if ( e->state() == ShiftButton ) 302 if ( e->state() == ShiftButton )
292 ci->setOn( false ); 303 ci->setOn( false );
293 else 304 else
294 ci->setOn( true ); 305 ci->setOn( true );
295 cn = cn->itemBelow(); 306 cn = cn->itemBelow();
296 if ( cn ) { 307 if ( cn ) {
297 setCurrentItem ( cn ); 308 setCurrentItem ( cn );
298 ensureItemVisible ( cn ); 309 ensureItemVisible ( cn );
299 } 310 }
300 311
301 } 312 }
302 } 313 }
303 314
304 return; 315 return;
305 } 316 }
306 317
307 if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton || mName != "todolistsmall" ) { 318 if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton || mName != "todolistsmall" ) {
308 switch ( e->key() ) { 319 switch ( e->key() ) {
309 case Qt::Key_Down: 320 case Qt::Key_Down:
310 case Qt::Key_Up: 321 case Qt::Key_Up:
311 QListView::keyPressEvent ( e ); 322 QListView::keyPressEvent ( e );
312 break; 323 break;
313 case Qt::Key_Left: 324 case Qt::Key_Left:
314 case Qt::Key_Right: 325 case Qt::Key_Right:
315 QListView::keyPressEvent ( e ); 326 QListView::keyPressEvent ( e );
316 e->accept(); 327 e->accept();
317 return; 328 return;
318 break; 329 break;
319 default: 330 default:
320 e->ignore(); 331 e->ignore();
321 break; 332 break;
322 } 333 }
323 return; 334 return;
324 } 335 }
325 e->ignore(); 336 e->ignore();
326} 337}
327void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e) 338void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e)
328{ 339{
329 QListView::contentsMouseReleaseEvent(e); 340 QListView::contentsMouseReleaseEvent(e);
330 mMousePressed = false; 341 mMousePressed = false;
331} 342}
332 343
333void KOTodoListView::contentsMouseDoubleClickEvent(QMouseEvent *e) 344void KOTodoListView::contentsMouseDoubleClickEvent(QMouseEvent *e)
334{ 345{
335 if (!e) return; 346 if (!e) return;
336 347
337 QPoint vp = contentsToViewport(e->pos()); 348 QPoint vp = contentsToViewport(e->pos());
338 349
339 QListViewItem *item = itemAt(vp); 350 QListViewItem *item = itemAt(vp);
340 351
341 emit double_Clicked(item); 352 emit double_Clicked(item);
342 if (!item) return; 353 if (!item) return;
343 354
344 emit doubleClicked(item,vp,0); 355 emit doubleClicked(item,vp,0);
345} 356}
346 357
347///////////////////////////////////////////////////////////////////////////// 358/////////////////////////////////////////////////////////////////////////////
348 359
349KOQuickTodo::KOQuickTodo(QWidget *parent) : 360KOQuickTodo::KOQuickTodo(QWidget *parent) :
350 QLineEdit(parent) 361 QLineEdit(parent)
351{ 362{
352 setText(i18n("Click to add a new Todo")); 363 setText(i18n("Click to add a new Todo"));
353} 364}
354 365
355void KOQuickTodo::focusInEvent(QFocusEvent *ev) 366void KOQuickTodo::focusInEvent(QFocusEvent *ev)
356{ 367{
357 if ( text()==i18n("Click to add a new Todo") ) 368 if ( text()==i18n("Click to add a new Todo") )
358 setText(""); 369 setText("");
359 QLineEdit::focusInEvent(ev); 370 QLineEdit::focusInEvent(ev);
360} 371}
361 372
362void KOQuickTodo::focusOutEvent(QFocusEvent *ev) 373void KOQuickTodo::focusOutEvent(QFocusEvent *ev)
363{ 374{
364 setText(i18n("Click to add a new Todo")); 375 setText(i18n("Click to add a new Todo"));
365 QLineEdit::focusOutEvent(ev); 376 QLineEdit::focusOutEvent(ev);
366} 377}
367 378
368///////////////////////////////////////////////////////////////////////////// 379/////////////////////////////////////////////////////////////////////////////
369 380
370KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : 381KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) :
371 KOrg::BaseView(calendar,parent,name) 382 KOrg::BaseView(calendar,parent,name)
372{ 383{
373 mPendingUpdateBeforeRepaint = false; 384 mPendingUpdateBeforeRepaint = false;
374 isFlatDisplay = false; 385 isFlatDisplay = false;
375 mNavigator = 0; 386 mNavigator = 0;
376 QBoxLayout *topLayout = new QVBoxLayout(this); 387 QBoxLayout *topLayout = new QVBoxLayout(this);
377 mName = QString ( name ); 388 mName = QString ( name );
378 mBlockUpdate = false; 389 mBlockUpdate = false;
379 mQuickAdd = new KOQuickTodo(this); 390 mQuickAdd = new KOQuickTodo(this);
380 topLayout->addWidget(mQuickAdd); 391 topLayout->addWidget(mQuickAdd);
381 392
382 if ( !KOPrefs::instance()->mEnableQuickTodo ) mQuickAdd->hide(); 393 if ( !KOPrefs::instance()->mEnableQuickTodo ) mQuickAdd->hide();
383 394
384 mTodoListView = new KOTodoListView(calendar,this, name ); 395 mTodoListView = new KOTodoListView(calendar,this, name );
385 topLayout->addWidget(mTodoListView); 396 topLayout->addWidget(mTodoListView);
386 //mTodoListView->header()->setMaximumHeight(30); 397 //mTodoListView->header()->setMaximumHeight(30);
387 mTodoListView->setRootIsDecorated(true); 398 mTodoListView->setRootIsDecorated(true);
388 mTodoListView->setAllColumnsShowFocus(true); 399 mTodoListView->setAllColumnsShowFocus(true);
389 400
390 mTodoListView->setShowSortIndicator(true); 401 mTodoListView->setShowSortIndicator(true);
391 402
392 mTodoListView->addColumn(i18n("Todo")); 403 mTodoListView->addColumn(i18n("Todo"));
393 mTodoListView->addColumn(i18n("Prio")); 404 mTodoListView->addColumn(i18n("Prio"));
394 mTodoListView->setColumnAlignment(1,AlignHCenter); 405 mTodoListView->setColumnAlignment(1,AlignHCenter);
395 mTodoListView->addColumn(i18n("Complete")); 406 mTodoListView->addColumn(i18n("Complete"));
396 mTodoListView->setColumnAlignment(2,AlignCenter); 407 mTodoListView->setColumnAlignment(2,AlignCenter);
397 408
398 mTodoListView->addColumn(i18n("Due Date")); 409 mTodoListView->addColumn(i18n("Due Date"));
399 mTodoListView->setColumnAlignment(3,AlignLeft); 410 mTodoListView->setColumnAlignment(3,AlignLeft);
400 mTodoListView->addColumn(i18n("Due Time")); 411 mTodoListView->addColumn(i18n("Due Time"));
401 mTodoListView->setColumnAlignment(4,AlignHCenter); 412 mTodoListView->setColumnAlignment(4,AlignHCenter);
402 413
403 mTodoListView->addColumn(i18n("Start Date")); 414 mTodoListView->addColumn(i18n("Start Date"));
404 mTodoListView->setColumnAlignment(5,AlignLeft); 415 mTodoListView->setColumnAlignment(5,AlignLeft);
405 mTodoListView->addColumn(i18n("Start Time")); 416 mTodoListView->addColumn(i18n("Start Time"));
406 mTodoListView->setColumnAlignment(6,AlignHCenter); 417 mTodoListView->setColumnAlignment(6,AlignHCenter);
407 418
408 mTodoListView->addColumn(i18n("Cancelled")); 419 mTodoListView->addColumn(i18n("Cancelled"));
409 mTodoListView->addColumn(i18n("Categories")); 420 mTodoListView->addColumn(i18n("Categories"));
410#if 0 421#if 0
411 mTodoListView->addColumn(i18n("Sort Id")); 422 mTodoListView->addColumn(i18n("Sort Id"));
412 mTodoListView->setColumnAlignment(4,AlignHCenter); 423 mTodoListView->setColumnAlignment(4,AlignHCenter);
413#endif 424#endif
414 425
415 mTodoListView->setMinimumHeight( 60 ); 426 mTodoListView->setMinimumHeight( 60 );
416 mTodoListView->setItemsRenameable( true ); 427 mTodoListView->setItemsRenameable( true );
417 mTodoListView->setRenameable( 0 ); 428 mTodoListView->setRenameable( 0 );
418 mTodoListView->setColumnWidth( 0, 120 ); 429 mTodoListView->setColumnWidth( 0, 120 );
419 mTodoListView->setColumnWidthMode(0, QListView::Manual); 430 mTodoListView->setColumnWidthMode(0, QListView::Manual);
420 mTodoListView->setColumnWidthMode(1, QListView::Manual); 431 mTodoListView->setColumnWidthMode(1, QListView::Manual);
421 mTodoListView->setColumnWidthMode(2, QListView::Manual); 432 mTodoListView->setColumnWidthMode(2, QListView::Manual);
422 mTodoListView->setColumnWidthMode(3, QListView::Manual); 433 mTodoListView->setColumnWidthMode(3, QListView::Manual);
423 mTodoListView->setColumnWidthMode(4, QListView::Manual); 434 mTodoListView->setColumnWidthMode(4, QListView::Manual);
424 mTodoListView->setColumnWidthMode(5, QListView::Manual); 435 mTodoListView->setColumnWidthMode(5, QListView::Manual);
425 mTodoListView->setColumnWidthMode(6, QListView::Manual); 436 mTodoListView->setColumnWidthMode(6, QListView::Manual);
426 mTodoListView->setColumnWidthMode(7, QListView::Manual); 437 mTodoListView->setColumnWidthMode(7, QListView::Manual);
427 mTodoListView->setColumnWidthMode(8, QListView::Manual); 438 mTodoListView->setColumnWidthMode(8, QListView::Manual);
428 439
429 440
430 mKOTodoViewWhatsThis = new KOTodoViewWhatsThis(mTodoListView->viewport(),this); 441 mKOTodoViewWhatsThis = new KOTodoViewWhatsThis(mTodoListView->viewport(),this);
431 442
432 mPriorityPopupMenu = new QPopupMenu(this); 443 mPriorityPopupMenu = new QPopupMenu(this);
433 for (int i = 1; i <= 5; i++) { 444 for (int i = 1; i <= 5; i++) {
434 QString label = QString ("%1").arg (i); 445 QString label = QString ("%1").arg (i);
435 mPriority[mPriorityPopupMenu->insertItem (label)] = i; 446 mPriority[mPriorityPopupMenu->insertItem (label)] = i;
436 } 447 }
437 connect (mPriorityPopupMenu, SIGNAL(activated (int)), SLOT (setNewPriority(int))); 448 connect (mPriorityPopupMenu, SIGNAL(activated (int)), SLOT (setNewPriority(int)));
438 449
439 mPercentageCompletedPopupMenu = new QPopupMenu(this); 450 mPercentageCompletedPopupMenu = new QPopupMenu(this);
440 for (int i = 0; i <= 100; i+=20) { 451 for (int i = 0; i <= 100; i+=20) {
441 QString label = QString ("%1 %").arg (i); 452 QString label = QString ("%1 %").arg (i);
442 mPercentage[mPercentageCompletedPopupMenu->insertItem (label)] = i; 453 mPercentage[mPercentageCompletedPopupMenu->insertItem (label)] = i;
443 } 454 }
444 connect (mPercentageCompletedPopupMenu, SIGNAL (activated (int)), SLOT (setNewPercentage (int))); 455 connect (mPercentageCompletedPopupMenu, SIGNAL (activated (int)), SLOT (setNewPercentage (int)));
445 456
446 457
447 458
448 mItemPopupMenu = new QPopupMenu(this); 459 mItemPopupMenu = new QPopupMenu(this);
449 mItemPopupMenu->insertItem(i18n("Show..."), this, 460 mItemPopupMenu->insertItem(i18n("Show..."), this,
450 SLOT (showTodo())); 461 SLOT (showTodo()));
451 mItemPopupMenu->insertItem(i18n("Edit..."), this, 462 mItemPopupMenu->insertItem(i18n("Edit..."), this,
452 SLOT (editTodo())); 463 SLOT (editTodo()));
453 mItemPopupMenu->insertItem( i18n("Delete"), this, 464 mItemPopupMenu->insertItem( i18n("Delete"), this,
454 SLOT (deleteTodo())); 465 SLOT (deleteTodo()));
455 mItemPopupMenu->insertItem( i18n("Clone..."), this, 466 mItemPopupMenu->insertItem( i18n("Clone..."), this,
456 SLOT (cloneTodo())); 467 SLOT (cloneTodo()));
457 mItemPopupMenu->insertItem( i18n("Move..."), this, 468 mItemPopupMenu->insertItem( i18n("Move..."), this,
458 SLOT (moveTodo())); 469 SLOT (moveTodo()));
459 mItemPopupMenu->insertItem( i18n("Beam..."), this, 470 mItemPopupMenu->insertItem( i18n("Beam..."), this,
460 SLOT (beamTodo())); 471 SLOT (beamTodo()));
461 mItemPopupMenu->insertItem( i18n("Toggle Cancel"), this, 472 mItemPopupMenu->insertItem( i18n("Toggle Cancel"), this,
462 SLOT (cancelTodo())); 473 SLOT (cancelTodo()));
463 mItemPopupMenu->insertSeparator(); 474 mItemPopupMenu->insertSeparator();
464 475
465 mItemPopupMenu->insertItem( i18n("New Todo..."), this, 476 mItemPopupMenu->insertItem( i18n("New Todo..."), this,
466 SLOT (newTodo())); 477 SLOT (newTodo()));
467 mItemPopupMenu->insertItem(i18n("New Sub-Todo..."), this, 478 mItemPopupMenu->insertItem(i18n("New Sub-Todo..."), this,
468 SLOT (newSubTodo())); 479 SLOT (newSubTodo()));
469 mItemPopupMenu->insertItem(i18n("Unparent Todo"), this, 480 mItemPopupMenu->insertItem(i18n("Unparent Todo"), this,
470 SLOT (unparentTodo()),0,21); 481 SLOT (unparentTodo()),0,21);
471 mItemPopupMenu->insertItem(i18n("Reparent Todo"), this, 482 mItemPopupMenu->insertItem(i18n("Reparent Todo"), this,
472 SLOT (reparentTodo()),0,22); 483 SLOT (reparentTodo()),0,22);
473 mItemPopupMenu->insertSeparator(); 484 mItemPopupMenu->insertSeparator();
474#if 0 485#if 0
475 mItemPopupMenu->insertItem(i18n("Delete completed To-Dos","Purge Completed"), 486 mItemPopupMenu->insertItem(i18n("Delete completed To-Dos","Purge Completed"),
476 this, SLOT( purgeCompleted() ) ); 487 this, SLOT( purgeCompleted() ) );
477 mItemPopupMenu->insertItem(i18n("toggle completed To-Dos","Show Completed"), 488 mItemPopupMenu->insertItem(i18n("toggle completed To-Dos","Show Completed"),
478 this, SLOT( toggleCompleted() ),0, 33 ); 489 this, SLOT( toggleCompleted() ),0, 33 );
479 mItemPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"), 490 mItemPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"),
480 this, SLOT( toggleQuickTodo() ),0, 34 ); 491 this, SLOT( toggleQuickTodo() ),0, 34 );
481 mItemPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"), 492 mItemPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"),
482 this, SLOT( toggleRunning() ),0, 35 ); 493 this, SLOT( toggleRunning() ),0, 35 );
483 494
484#endif 495#endif
485 mPopupMenu = new QPopupMenu(this); 496 mPopupMenu = new QPopupMenu(this);
486 mPopupMenu->insertItem(SmallIconSet("todo"), i18n("New Todo..."), this, 497 mPopupMenu->insertItem(SmallIconSet("todo"), i18n("New Todo..."), this,
487 SLOT (newTodo()),0,1); 498 SLOT (newTodo()),0,1);
488 mPopupMenu->insertItem(i18n("delete completed To-Dos","Purge Completed"), 499 mPopupMenu->insertItem(i18n("delete completed To-Dos","Purge Completed"),
489 this, SLOT(purgeCompleted()),0,2); 500 this, SLOT(purgeCompleted()),0,2);
490 mPopupMenu->insertItem(i18n("Show Completed"), 501 mPopupMenu->insertItem(i18n("Show Completed"),
491 this, SLOT( toggleCompleted() ),0,3 ); 502 this, SLOT( toggleCompleted() ),0,3 );
492 mPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"), 503 mPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"),
493 this, SLOT( toggleQuickTodo() ),0,4 ); 504 this, SLOT( toggleQuickTodo() ),0,4 );
494 mPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"), 505 mPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"),
495 this, SLOT( toggleRunning() ),0,5 ); 506 this, SLOT( toggleRunning() ),0,5 );
496 mPopupMenu->insertItem(i18n(" set all open","Display all opened"), 507 mPopupMenu->insertItem(i18n(" set all open","Display all opened"),
497 this, SLOT( setAllOpen() ),0,6 ); 508 this, SLOT( setAllOpen() ),0,6 );
498 mPopupMenu->insertItem(i18n(" set all close","Display all closed"), 509 mPopupMenu->insertItem(i18n(" set all close","Display all closed"),
499 this, SLOT( setAllClose() ),0,7 ); 510 this, SLOT( setAllClose() ),0,7 );
500 mPopupMenu->insertItem(i18n(" set all flat","Display all flat"), 511 mPopupMenu->insertItem(i18n(" set all flat","Display all flat"),
501 this, SLOT( setAllFlat() ),0,8 ); 512 this, SLOT( setAllFlat() ),0,8 );
502 mDocPrefs = new DocPrefs( name ); 513 mDocPrefs = new DocPrefs( name );
503 514
504 mItemPopupMenu->insertItem(i18n("Todo View"),mPopupMenu ); 515 mItemPopupMenu->insertItem(i18n("Todo View"),mPopupMenu );
505 mPopupMenu->setCheckable( true ); 516 mPopupMenu->setCheckable( true );
506 mItemPopupMenu->setCheckable( true ); 517 mItemPopupMenu->setCheckable( true );
507 518
508 519
509 mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); 520 mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo );
510 mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); 521 mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo );
511 522
512 mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); 523 mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo);
513 mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); 524 mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo );
514 525
515 mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); 526 mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos);
516 mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); 527 mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos );
517 528
518 529
519 // Double clicking conflicts with opening/closing the subtree 530 // Double clicking conflicts with opening/closing the subtree
520 connect( mTodoListView, SIGNAL( doubleClicked( QListViewItem *) ), 531 connect( mTodoListView, SIGNAL( doubleClicked( QListViewItem *) ),
521 SLOT( editItem( QListViewItem *) ) ); 532 SLOT( editItem( QListViewItem *) ) );
522 /* 533 /*
523 connect( mTodoListView, SIGNAL( rightButtonClicked ( QListViewItem *, 534 connect( mTodoListView, SIGNAL( rightButtonClicked ( QListViewItem *,
524 const QPoint &,int ) ), 535 const QPoint &,int ) ),
525 SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); 536 SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) );
526 */ 537 */
527 connect( mTodoListView, SIGNAL( contextRequest ( QListViewItem *, 538 connect( mTodoListView, SIGNAL( contextRequest ( QListViewItem *,
528 const QPoint &,int ) ), 539 const QPoint &,int ) ),
529 SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); 540 SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) );
530 connect( mTodoListView, SIGNAL( clicked( QListViewItem * ) ), 541 connect( mTodoListView, SIGNAL( clicked( QListViewItem * ) ),
531 SLOT( itemClicked( QListViewItem * ) ) ); 542 SLOT( itemClicked( QListViewItem * ) ) );
532 connect( mTodoListView, SIGNAL( double_Clicked( QListViewItem * ) ), 543 connect( mTodoListView, SIGNAL( double_Clicked( QListViewItem * ) ),
533 SLOT( itemDoubleClicked( QListViewItem * ) ) ); 544 SLOT( itemDoubleClicked( QListViewItem * ) ) );
534 connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), 545 connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ),
535 SLOT( updateView() ) ); 546 SLOT( updateView() ) );
536 connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), 547 connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ),
537 SLOT( todoModified(Todo *, int) ) ); 548 SLOT( todoModified(Todo *, int) ) );
538 connect( mTodoListView, SIGNAL( expanded( QListViewItem * ) ), 549 connect( mTodoListView, SIGNAL( expanded( QListViewItem * ) ),
539 SLOT( itemStateChanged( QListViewItem * ) ) ); 550 SLOT( itemStateChanged( QListViewItem * ) ) );
540 connect( mTodoListView, SIGNAL( collapsed( QListViewItem * ) ), 551 connect( mTodoListView, SIGNAL( collapsed( QListViewItem * ) ),
541 SLOT( itemStateChanged( QListViewItem * ) ) ); 552 SLOT( itemStateChanged( QListViewItem * ) ) );
542 connect( mTodoListView, SIGNAL( paintNeeded() ), 553 connect( mTodoListView, SIGNAL( paintNeeded() ),
543 SLOT( paintNeeded()) ); 554 SLOT( paintNeeded()) );
544 555
545#if 0 556#if 0
546 connect(mTodoListView,SIGNAL(selectionChanged(QListViewItem *)), 557 connect(mTodoListView,SIGNAL(selectionChanged(QListViewItem *)),
547 SLOT(selectionChanged(QListViewItem *))); 558 SLOT(selectionChanged(QListViewItem *)));
548 connect(mTodoListView,SIGNAL(clicked(QListViewItem *)), 559 connect(mTodoListView,SIGNAL(clicked(QListViewItem *)),
549 SLOT(selectionChanged(QListViewItem *))); 560 SLOT(selectionChanged(QListViewItem *)));
550 connect(mTodoListView,SIGNAL(pressed(QListViewItem *)), 561 connect(mTodoListView,SIGNAL(pressed(QListViewItem *)),
551 SLOT(selectionChanged(QListViewItem *))); 562 SLOT(selectionChanged(QListViewItem *)));
552#endif 563#endif
553 564
554 connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) )); 565 connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) ));
555 connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) )); 566 connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) ));
556 connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) )); 567 connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) ));
557 568
558 connect( mTodoListView, SIGNAL(selectionChanged() ), 569 connect( mTodoListView, SIGNAL(selectionChanged() ),
559 SLOT( processSelectionChange() ) ); 570 SLOT( processSelectionChange() ) );
560 connect( mQuickAdd, SIGNAL( returnPressed () ), 571 connect( mQuickAdd, SIGNAL( returnPressed () ),
561 SLOT( addQuickTodo() ) ); 572 SLOT( addQuickTodo() ) );
562 573
563} 574}
564 575
565KOTodoView::~KOTodoView() 576KOTodoView::~KOTodoView()
566{ 577{
567 // delete mKOTodoViewWhatsThis; 578 // delete mKOTodoViewWhatsThis;
568 delete mDocPrefs; 579 delete mDocPrefs;
569} 580}
570QString KOTodoView::getWhatsThisText(QPoint p) 581QString KOTodoView::getWhatsThisText(QPoint p)
571{ 582{
572 KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p ); 583 KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p );
573 if ( item ) 584 if ( item )
574 return KIncidenceFormatter::instance()->getFormattedText( item->todo(), 585 return KIncidenceFormatter::instance()->getFormattedText( item->todo(),
575 KOPrefs::instance()->mWTshowDetails, 586 KOPrefs::instance()->mWTshowDetails,
576 KOPrefs::instance()->mWTshowCreated, 587 KOPrefs::instance()->mWTshowCreated,
577 KOPrefs::instance()->mWTshowChanged); 588 KOPrefs::instance()->mWTshowChanged);
578 return i18n("That is the todo view" ); 589 return i18n("That is the todo view" );
579 590
580} 591}
581 592
582void KOTodoView::jumpToDate () 593void KOTodoView::jumpToDate ()
583{ 594{
584 // if (mActiveItem) { 595 // if (mActiveItem) {
585// mActiveItem->todo()); 596// mActiveItem->todo());
586// if ( mActiveItem->todo()->hasDueDate() ) 597// if ( mActiveItem->todo()->hasDueDate() )
587// emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() ); 598// emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() );
588} 599}
589void KOTodoView::paintNeeded() 600void KOTodoView::paintNeeded()
590{ 601{
591 if ( mPendingUpdateBeforeRepaint ) { 602 if ( mPendingUpdateBeforeRepaint ) {
592 updateView(); 603 updateView();
593 mPendingUpdateBeforeRepaint = false; 604 mPendingUpdateBeforeRepaint = false;
594 } 605 }
595} 606}
596void KOTodoView::paintEvent(QPaintEvent * pevent) 607void KOTodoView::paintEvent(QPaintEvent * pevent)
597{ 608{
598 if ( mPendingUpdateBeforeRepaint ) { 609 if ( mPendingUpdateBeforeRepaint ) {
599 updateView(); 610 updateView();
600 mPendingUpdateBeforeRepaint = false; 611 mPendingUpdateBeforeRepaint = false;
601 } 612 }
602 KOrg::BaseView::paintEvent( pevent); 613 KOrg::BaseView::paintEvent( pevent);
603} 614}
604 615
605void KOTodoView::updateView() 616void KOTodoView::updateView()
606{ 617{
607 pendingSubtodo = 0; 618 pendingSubtodo = 0;
608 if ( mBlockUpdate ) { 619 if ( mBlockUpdate ) {
609 return; 620 return;
610 } 621 }
611 if ( !isVisible() ) { 622 if ( !isVisible() ) {
612 mPendingUpdateBeforeRepaint = true; 623 mPendingUpdateBeforeRepaint = true;
613 return; 624 return;
614 } 625 }
615 storeCurrentItem(); 626 storeCurrentItem();
616 //qDebug("KOTodoView::updateView() %x", this); 627 //qDebug("KOTodoView::updateView() %x", this);
617 if ( isFlatDisplay ) { 628 if ( isFlatDisplay ) {
618 displayAllFlat(); 629 displayAllFlat();
619 resetCurrentItem(); 630 resetCurrentItem();
620 return; 631 return;
621 } 632 }
622 //qDebug("update "); 633 //qDebug("update ");
623// kdDebug() << "KOTodoView::updateView()" << endl; 634// kdDebug() << "KOTodoView::updateView()" << endl;
624 QFont fo = KOPrefs::instance()->mTodoViewFont; 635 QFont fo = KOPrefs::instance()->mTodoViewFont;
625 636
626 637
627 mTodoListView->clear(); 638 mTodoListView->clear();
628 if ( mName == "todolistsmall" ) { 639 if ( mName == "todolistsmall" ) {
629 if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) { 640 if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) {
630 int ps = fo.pointSize() -2; 641 int ps = fo.pointSize() -2;
631 if ( ps > 12 ) 642 if ( ps > 12 )
632 ps -= 2; 643 ps -= 2;
633 fo.setPointSize( ps ); 644 fo.setPointSize( ps );
634 } 645 }
635 } 646 }
636 647
637 mTodoListView->setFont( fo ); 648 mTodoListView->setFont( fo );
638 // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont ); 649 // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont );
639 //mTodoListView->header()->setMaximumHeight(fm.height()); 650 //mTodoListView->header()->setMaximumHeight(fm.height());
640 QPtrList<Todo> todoList = calendar()->todos(); 651 QPtrList<Todo> todoList = calendar()->todos();
641 652
642/* 653/*
643 kdDebug() << "KOTodoView::updateView(): Todo List:" << endl; 654 kdDebug() << "KOTodoView::updateView(): Todo List:" << endl;
644 Event *t; 655 Event *t;
645 for(t = todoList.first(); t; t = todoList.next()) { 656 for(t = todoList.first(); t; t = todoList.next()) {
646 kdDebug() << " " << t->getSummary() << endl; 657 kdDebug() << " " << t->getSummary() << endl;
647 658
648 if (t->getRelatedTo()) { 659 if (t->getRelatedTo()) {
649 kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl; 660 kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl;
650 } 661 }
651 662
652 QPtrList<Event> l = t->getRelations(); 663 QPtrList<Event> l = t->getRelations();
653 Event *c; 664 Event *c;
654 for(c=l.first();c;c=l.next()) { 665 for(c=l.first();c;c=l.next()) {
655 kdDebug() << " - relation: " << c->getSummary() << endl; 666 kdDebug() << " - relation: " << c->getSummary() << endl;
656 } 667 }
657 } 668 }
658*/ 669*/
659 670
660 // Put for each Event a KOTodoViewItem in the list view. Don't rely on a 671 // Put for each Event a KOTodoViewItem in the list view. Don't rely on a
661 // specific order of events. That means that we have to generate parent items 672 // specific order of events. That means that we have to generate parent items
662 // recursively for proper hierarchical display of Todos. 673 // recursively for proper hierarchical display of Todos.
663 mTodoMap.clear(); 674 mTodoMap.clear();
664 Todo *todo; 675 Todo *todo;
665 todo = todoList.first();// todo; todo = todoList.next()) { 676 todo = todoList.first();// todo; todo = todoList.next()) {
666 while ( todo ) { 677 while ( todo ) {
667 bool next = true; 678 bool next = true;
668 // qDebug("todo %s ", todo->summary().latin1()); 679 // qDebug("todo %s ", todo->summary().latin1());
669 Incidence *incidence = todo->relatedTo(); 680 Incidence *incidence = todo->relatedTo();
670 while ( incidence ) { 681 while ( incidence ) {
671 if ( incidence->type() == "Todo") { 682 if ( incidence->type() == "Todo") {
672 //qDebug("related %s ",incidence->summary().latin1() ); 683 //qDebug("related %s ",incidence->summary().latin1() );
673 if ( !(todoList.contains ( ((Todo* )incidence ) ) )) { 684 if ( !(todoList.contains ( ((Todo* )incidence ) ) )) {
674 //qDebug("related not found "); 685 //qDebug("related not found ");
675 todoList.remove( ); 686 todoList.remove( );
676 todo = todoList.current(); 687 todo = todoList.current();
677 next = false; 688 next = false;
678 incidence = 0; 689 incidence = 0;
679 690
680 } else { 691 } else {
681 //qDebug("related found "); 692 //qDebug("related found ");
682 incidence = incidence->relatedTo(); 693 incidence = incidence->relatedTo();
683 } 694 }
684 } else 695 } else
685 incidence = 0; 696 incidence = 0;
686 } 697 }
687 if ( next ) 698 if ( next )
688 todo = todoList.next(); 699 todo = todoList.next();
689 } 700 }
690// qDebug("again .... "); 701// qDebug("again .... ");
691// for(todo = todoList.first(); todo; todo = todoList.next()) { 702// for(todo = todoList.first(); todo; todo = todoList.next()) {
692 703
693// qDebug("yytodo %s ", todo->summary().latin1()); 704// qDebug("yytodo %s ", todo->summary().latin1());
694// } 705// }
695 //qDebug("for "); 706 //qDebug("for ");
696 for(todo = todoList.first(); todo; todo = todoList.next()) { 707 for(todo = todoList.first(); todo; todo = todoList.next()) {
697 if (!mTodoMap.contains(todo) && checkTodo( todo ) ) 708 if (!mTodoMap.contains(todo) && checkTodo( todo ) )
698 { 709 {
699 insertTodoItem(todo); 710 insertTodoItem(todo);
700 } 711 }
701 } 712 }
702 //qDebug("for end "); 713 //qDebug("for end ");
703 // Restore opened/closed state 714 // Restore opened/closed state
704 mTodoListView->blockSignals( true ); 715 mTodoListView->blockSignals( true );
705 if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() ); 716 if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() );
706 mTodoListView->blockSignals( false ); 717 mTodoListView->blockSignals( false );
707 resetCurrentItem(); 718 resetCurrentItem();
708 processSelectionChange(); 719 processSelectionChange();
709} 720}
710 721
711void KOTodoView::storeCurrentItem() 722void KOTodoView::storeCurrentItem()
712{ 723{
713 mCurItem = 0; 724 mCurItem = 0;
714 mCurItemRootParent = 0; 725 mCurItemRootParent = 0;
715 mCurItemAbove = 0; 726 mCurItemAbove = 0;
716 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); 727 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem();
717 if (mActiveItem) { 728 if (mActiveItem) {
718 mCurItem = mActiveItem->todo(); 729 mCurItem = mActiveItem->todo();
719 KOTodoViewItem* activeItemAbove = (KOTodoViewItem*)mActiveItem->itemAbove (); 730 KOTodoViewItem* activeItemAbove = (KOTodoViewItem*)mActiveItem->itemAbove ();
720 if ( activeItemAbove ) 731 if ( activeItemAbove )
721 mCurItemAbove = activeItemAbove->todo(); 732 mCurItemAbove = activeItemAbove->todo();
722 while ( mActiveItem->parent() != 0 ) 733 while ( mActiveItem->parent() != 0 )
723 mActiveItem = (KOTodoViewItem*)mActiveItem->parent(); 734 mActiveItem = (KOTodoViewItem*)mActiveItem->parent();
724 mCurItemRootParent = mActiveItem->todo(); 735 mCurItemRootParent = mActiveItem->todo();
725 } 736 }
726 mActiveItem = 0; 737 mActiveItem = 0;
727} 738}
728 739
729void KOTodoView::resetCurrentItem() 740void KOTodoView::resetCurrentItem()
730{ 741{
731 mTodoListView->setFocus(); 742 mTodoListView->setFocus();
732 KOTodoViewItem* foundItem = 0; 743 KOTodoViewItem* foundItem = 0;
733 KOTodoViewItem* foundItemRoot = 0; 744 KOTodoViewItem* foundItemRoot = 0;
734 KOTodoViewItem* foundItemAbove = 0; 745 KOTodoViewItem* foundItemAbove = 0;
735 if ( mTodoListView->firstChild () ) { 746 if ( mTodoListView->firstChild () ) {
736 if ( mCurItem ) { 747 if ( mCurItem ) {
737 KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild (); 748 KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild ();
738 while ( item ) { 749 while ( item ) {
739 if ( item->todo() == mCurItem ) { 750 if ( item->todo() == mCurItem ) {
740 foundItem = item; 751 foundItem = item;
741 break; 752 break;
742 } else if ( item->todo() == mCurItemAbove ) { 753 } else if ( item->todo() == mCurItemAbove ) {
743 foundItemAbove = item; 754 foundItemAbove = item;
744 755
745 } else if ( item->todo() == mCurItemRootParent ) { 756 } else if ( item->todo() == mCurItemRootParent ) {
746 foundItemRoot = item; 757 foundItemRoot = item;
747 } 758 }
748 item = (KOTodoViewItem*)item->itemBelow(); 759 item = (KOTodoViewItem*)item->itemBelow();
749 } 760 }
750 if ( ! foundItem ) { 761 if ( ! foundItem ) {
751 if ( foundItemAbove ) 762 if ( foundItemAbove )
752 foundItem = foundItemAbove; 763 foundItem = foundItemAbove;
753 else 764 else
754 foundItem = foundItemRoot; 765 foundItem = foundItemRoot;
755 } 766 }
756 } 767 }
757 if ( foundItem ) { 768 if ( foundItem ) {
758 mTodoListView->setCurrentItem( foundItem ); 769 mTodoListView->setCurrentItem( foundItem );
759 mTodoListView->ensureItemVisible( foundItem ); 770 mTodoListView->ensureItemVisible( foundItem );
760 } else { 771 } else {
761 mTodoListView->setCurrentItem( mTodoListView->firstChild () ); 772 mTodoListView->setCurrentItem( mTodoListView->firstChild () );
762 } 773 }
763 } 774 }
764 mTodoListView->setFocus(); 775 mTodoListView->setFocus();
765} 776}
766//Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove; 777//Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove;
767bool KOTodoView::checkTodo( Todo * todo ) 778bool KOTodoView::checkTodo( Todo * todo )
768{ 779{
769 780
770 if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() ) 781 if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() )
771 return false; 782 return false;
772 if ( !todo->isCompleted() ) { 783 if ( !todo->isCompleted() ) {
773 if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() ) 784 if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() )
774 return true; 785 return true;
775 } 786 }
776 if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) { 787 if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) {
777 if ( todo->hasStartDate() ) 788 if ( todo->hasStartDate() )
778 if ( mNavigator->selectedDates().last() < todo->dtStart().date() ) 789 if ( mNavigator->selectedDates().last() < todo->dtStart().date() )
779 return false; 790 return false;
780 if ( todo->hasDueDate() ) 791 if ( todo->hasDueDate() )
781 if ( mNavigator->selectedDates().first() > todo->dtDue().date() ) 792 if ( mNavigator->selectedDates().first() > todo->dtDue().date() )
782 return false; 793 return false;
783 } 794 }
784 return true; 795 return true;
785} 796}
786 797
787void KOTodoView::restoreItemState( QListViewItem *item ) 798void KOTodoView::restoreItemState( QListViewItem *item )
788{ 799{
789 pendingSubtodo = 0; 800 pendingSubtodo = 0;
790 while( item ) { 801 while( item ) {
791 KOTodoViewItem *todoItem = (KOTodoViewItem *)item; 802 KOTodoViewItem *todoItem = (KOTodoViewItem *)item;
792 todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) ); 803 todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) );
793 if( item->childCount() > 0 ) restoreItemState( item->firstChild() ); 804 if( item->childCount() > 0 ) restoreItemState( item->firstChild() );
794 item = item->nextSibling(); 805 item = item->nextSibling();
795 } 806 }
796} 807}
797 808
798 809
799QMap<Todo *,KOTodoViewItem *>::ConstIterator 810QMap<Todo *,KOTodoViewItem *>::ConstIterator
800 KOTodoView::insertTodoItem(Todo *todo) 811 KOTodoView::insertTodoItem(Todo *todo)
801{ 812{
802 813
803// kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl; 814// kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl;
804 // TODO: Check, if dynmaic cast is necessary 815 // TODO: Check, if dynmaic cast is necessary
805 816
806 pendingSubtodo = 0; 817 pendingSubtodo = 0;
807 Incidence *incidence = todo->relatedTo(); 818 Incidence *incidence = todo->relatedTo();
808 if (incidence && incidence->type() == "Todo") { 819 if (incidence && incidence->type() == "Todo") {
809 Todo *relatedTodo = static_cast<Todo *>(incidence); 820 Todo *relatedTodo = static_cast<Todo *>(incidence);
810 821
811// kdDebug() << " has Related" << endl; 822// kdDebug() << " has Related" << endl;
812 QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; 823 QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator;
813 itemIterator = mTodoMap.find(relatedTodo); 824 itemIterator = mTodoMap.find(relatedTodo);
814 if (itemIterator == mTodoMap.end()) { 825 if (itemIterator == mTodoMap.end()) {
815// kdDebug() << " related not yet in list" << endl; 826// kdDebug() << " related not yet in list" << endl;
816 itemIterator = insertTodoItem (relatedTodo); 827 itemIterator = insertTodoItem (relatedTodo);
817 } 828 }
818 // isn't this pretty stupid? We give one Todo to the KOTodoViewItem 829 // isn't this pretty stupid? We give one Todo to the KOTodoViewItem
819 // and one into the map. Sure finding is more easy but why? -zecke 830 // and one into the map. Sure finding is more easy but why? -zecke
820 KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this); 831 KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this);
821 return mTodoMap.insert(todo,todoItem); 832 return mTodoMap.insert(todo,todoItem);
822 } else { 833 } else {
823// kdDebug() << " no Related" << endl; 834// kdDebug() << " no Related" << endl;
824 // see above -zecke 835 // see above -zecke
825 KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); 836 KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this);
826 return mTodoMap.insert(todo,todoItem); 837 return mTodoMap.insert(todo,todoItem);
827 } 838 }
828} 839}
829 840
830 841
831void KOTodoView::updateConfig() 842void KOTodoView::updateConfig()
832{ 843{
833 updateView(); 844 updateView();
834 mTodoListView->repaintContents(); 845 mTodoListView->repaintContents();
835} 846}
836 847
837QPtrList<Incidence> KOTodoView::selectedIncidences() 848QPtrList<Incidence> KOTodoView::selectedIncidences()
838{ 849{
839 QPtrList<Incidence> selected; 850 QPtrList<Incidence> selected;
840 851
841 KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); 852 KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem());
842// if (!item) item = mActiveItem; 853// if (!item) item = mActiveItem;
843 if (item) selected.append(item->todo()); 854 if (item) selected.append(item->todo());
844 855
845 return selected; 856 return selected;
846} 857}
847 858
848QPtrList<Todo> KOTodoView::selectedTodos() 859QPtrList<Todo> KOTodoView::selectedTodos()
849{ 860{
850 QPtrList<Todo> selected; 861 QPtrList<Todo> selected;
851 862
852 KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); 863 KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem());
853// if (!item) item = mActiveItem; 864// if (!item) item = mActiveItem;
854 if (item) selected.append(item->todo()); 865 if (item) selected.append(item->todo());
855 866
856 return selected; 867 return selected;
857} 868}
858 869
859void KOTodoView::changeEventDisplay(Event *, int) 870void KOTodoView::changeEventDisplay(Event *, int)
860{ 871{
861 updateView(); 872 updateView();
862} 873}
863 874
864void KOTodoView::showDates(const QDate &, const QDate &) 875void KOTodoView::showDates(const QDate &, const QDate &)
865{ 876{
866} 877}
867 878
868void KOTodoView::showEvents(QPtrList<Event>) 879void KOTodoView::showEvents(QPtrList<Event>)
869{ 880{
870 kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; 881 kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl;
871} 882}
872 883
873void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, 884void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd,
874 const QDate &td) 885 const QDate &td)
875{ 886{
876#ifndef KORG_NOPRINTER 887#ifndef KORG_NOPRINTER
877 calPrinter->preview(CalPrinter::Todolist, fd, td); 888 calPrinter->preview(CalPrinter::Todolist, fd, td);
878#endif 889#endif
879} 890}
880 891
881void KOTodoView::editItem(QListViewItem *item ) 892void KOTodoView::editItem(QListViewItem *item )
882{ 893{
883 // qDebug("editItem(QListViewItem *item ) "); 894 // qDebug("editItem(QListViewItem *item ) ");
884 emit editTodoSignal(((KOTodoViewItem *)item)->todo()); 895 emit editTodoSignal(((KOTodoViewItem *)item)->todo());
885} 896}
886 897
887void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) 898void KOTodoView::showItem(QListViewItem *item,const QPoint &,int)
888{ 899{
889 emit showTodoSignal(((KOTodoViewItem *)item)->todo()); 900 emit showTodoSignal(((KOTodoViewItem *)item)->todo());
890} 901}
891 902
892void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) 903void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column)
893{ 904{
894 pendingSubtodo = 0; 905 pendingSubtodo = 0;
895 mActiveItem = (KOTodoViewItem *)item; 906 mActiveItem = (KOTodoViewItem *)item;
896 if (item) { 907 if (item) {
897 switch (column){ 908 switch (column){
898 case 1: 909 case 1:
899 mPriorityPopupMenu->popup(QCursor::pos ()); break; 910 mPriorityPopupMenu->popup(QCursor::pos ()); break;
900 case 2: 911 case 2:
901 mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break; 912 mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break;
902 case 3: 913 case 3:
903 moveTodo(); 914 moveTodo();
904 break; 915 break;
905 case 8: 916 case 8:
906 getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break; 917 getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break;
907 default: 918 default:
908 mItemPopupMenu->popup(QCursor::pos()); 919 mItemPopupMenu->popup(QCursor::pos());
909 } 920 }
910 } else mPopupMenu->popup(QCursor::pos()); 921 } else mPopupMenu->popup(QCursor::pos());
911} 922}
912void KOTodoView::newTodo() 923void KOTodoView::newTodo()
913{ 924{
914 emit newTodoSignal(); 925 emit newTodoSignal();
915} 926}
916 927
917void KOTodoView::newSubTodo() 928void KOTodoView::newSubTodo()
918{ 929{
919 if (mActiveItem) { 930 if (mActiveItem) {
920 emit newSubTodoSignal(mActiveItem->todo()); 931 emit newSubTodoSignal(mActiveItem->todo());
921 } 932 }
922} 933}
923void KOTodoView::unparentTodo() 934void KOTodoView::unparentTodo()
924{ 935{
925 if (mActiveItem) { 936 if (mActiveItem) {
926 emit unparentTodoSignal(mActiveItem->todo()); 937 emit unparentTodoSignal(mActiveItem->todo());
927 } 938 }
928} 939}
929 940
930void KOTodoView::reparentTodo() 941void KOTodoView::reparentTodo()
931{ 942{
932 if (mActiveItem) { 943 if (mActiveItem) {
933 qDebug("KOTodoView::reparentTodo() "); 944 qDebug("KOTodoView::reparentTodo() ");
934 topLevelWidget()->setCaption(i18n("Click on new parent item")); 945 topLevelWidget()->setCaption(i18n("Click on new parent item"));
935 pendingSubtodo = mActiveItem; 946 pendingSubtodo = mActiveItem;
936 } 947 }
937} 948}
938void KOTodoView::editTodo() 949void KOTodoView::editTodo()
939{ 950{
940 if (mActiveItem) { 951 if (mActiveItem) {
941 emit editTodoSignal(mActiveItem->todo()); 952 emit editTodoSignal(mActiveItem->todo());
942 } 953 }
943} 954}
944void KOTodoView::cloneTodo() 955void KOTodoView::cloneTodo()
945{ 956{
946 if (mActiveItem) { 957 if (mActiveItem) {
947 emit cloneTodoSignal((Incidence*)mActiveItem->todo()); 958 emit cloneTodoSignal((Incidence*)mActiveItem->todo());
948 } 959 }
949} 960}
950void KOTodoView::cancelTodo() 961void KOTodoView::cancelTodo()
951{ 962{
952 if (mActiveItem) { 963 if (mActiveItem) {
953 emit cancelTodoSignal((Incidence*)mActiveItem->todo()); 964 emit cancelTodoSignal((Incidence*)mActiveItem->todo());
954 } 965 }
955} 966}
956void KOTodoView::moveTodo() 967void KOTodoView::moveTodo()
957{ 968{
958 if (mActiveItem) { 969 if (mActiveItem) {
959 emit moveTodoSignal((Incidence*)mActiveItem->todo()); 970 emit moveTodoSignal((Incidence*)mActiveItem->todo());
960 } 971 }
961} 972}
962void KOTodoView::beamTodo() 973void KOTodoView::beamTodo()
963{ 974{
964 if (mActiveItem) { 975 if (mActiveItem) {
965 emit beamTodoSignal((Incidence*)mActiveItem->todo()); 976 emit beamTodoSignal((Incidence*)mActiveItem->todo());
966 } 977 }
967} 978}
968 979
969 980
970void KOTodoView::showTodo() 981void KOTodoView::showTodo()
971{ 982{
972 if (mActiveItem) { 983 if (mActiveItem) {
973 emit showTodoSignal(mActiveItem->todo()); 984 emit showTodoSignal(mActiveItem->todo());
974 } 985 }
975} 986}
976 987
977void KOTodoView::deleteTodo() 988void KOTodoView::deleteTodo()
978{ 989{
979 if (mActiveItem) { 990 if (mActiveItem) {
980 emit deleteTodoSignal(mActiveItem->todo()); 991 emit deleteTodoSignal(mActiveItem->todo());
981 } 992 }
982} 993}
983 994
984void KOTodoView::setNewPriority(int index) 995void KOTodoView::setNewPriority(int index)
985{ 996{
986 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { 997 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) {
987 mActiveItem->todo()->setPriority(mPriority[index]); 998 mActiveItem->todo()->setPriority(mPriority[index]);
988 mActiveItem->construct(); 999 mActiveItem->construct();
989 todoModified (mActiveItem->todo(), KOGlobals::PRIORITY_MODIFIED); 1000 todoModified (mActiveItem->todo(), KOGlobals::PRIORITY_MODIFIED);
990 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); 1001 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 );
991 } 1002 }
992} 1003}
993 1004
994void KOTodoView::setNewPercentage(int index) 1005void KOTodoView::setNewPercentage(int index)
995{ 1006{
996 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { 1007 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) {
997 1008
998 if ( mPercentage[index] == 100 && !mActiveItem->isOn() ) { 1009 if ( mPercentage[index] == 100 && !mActiveItem->isOn() ) {
999 mActiveItem->setOn( true ); 1010 mActiveItem->setOn( true );
1000 return; 1011 return;
1001 } else if ( mPercentage[index] != 100 && mActiveItem->isOn() ) { 1012 } else if ( mPercentage[index] != 100 && mActiveItem->isOn() ) {
1002 KOTodoViewItem* par = (static_cast<KOTodoViewItem*>(mActiveItem->parent())); 1013 KOTodoViewItem* par = (static_cast<KOTodoViewItem*>(mActiveItem->parent()));
1003 if ( par && par->isOn() ) 1014 if ( par && par->isOn() )
1004 par->setOn( false ); 1015 par->setOn( false );
1005 } 1016 }
1006 if (mPercentage[index] == 100) { 1017 if (mPercentage[index] == 100) {
1007 mActiveItem->todo()->setCompleted(QDateTime::currentDateTime()); 1018 mActiveItem->todo()->setCompleted(QDateTime::currentDateTime());
1008 } else { 1019 } else {
1009 mActiveItem->todo()->setCompleted(false); 1020 mActiveItem->todo()->setCompleted(false);
1010 } 1021 }
1011 mActiveItem->todo()->setPercentComplete(mPercentage[index]); 1022 mActiveItem->todo()->setPercentComplete(mPercentage[index]);
1012 mActiveItem->construct(); 1023 mActiveItem->construct();
1013 todoModified (mActiveItem->todo (), KOGlobals::COMPLETION_MODIFIED); 1024 todoModified (mActiveItem->todo (), KOGlobals::COMPLETION_MODIFIED);
1014 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); 1025 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 );
1015 } 1026 }
1016} 1027}
1017 1028
1018 1029
1019QPopupMenu * KOTodoView::getCategoryPopupMenu (KOTodoViewItem *todoItem) 1030QPopupMenu * KOTodoView::getCategoryPopupMenu (KOTodoViewItem *todoItem)
1020{ 1031{
1021 QPopupMenu* tempMenu = new QPopupMenu (this); 1032 QPopupMenu* tempMenu = new QPopupMenu (this);
1022 QStringList checkedCategories = todoItem->todo()->categories (); 1033 QStringList checkedCategories = todoItem->todo()->categories ();
1023 1034
1024 tempMenu->setCheckable (true); 1035 tempMenu->setCheckable (true);
1025 for (QStringList::Iterator it = KOPrefs::instance()->mCustomCategories.begin (); 1036 for (QStringList::Iterator it = KOPrefs::instance()->mCustomCategories.begin ();
1026 it != KOPrefs::instance()->mCustomCategories.end (); 1037 it != KOPrefs::instance()->mCustomCategories.end ();
1027 ++it) { 1038 ++it) {
1028 int index = tempMenu->insertItem (*it); 1039 int index = tempMenu->insertItem (*it);
1029 mCategory[index] = *it; 1040 mCategory[index] = *it;
1030 if (checkedCategories.find (*it) != checkedCategories.end ()) tempMenu->setItemChecked (index, true); 1041 if (checkedCategories.find (*it) != checkedCategories.end ()) tempMenu->setItemChecked (index, true);
1031 } 1042 }
1032 1043
1033 connect (tempMenu, SIGNAL (activated (int)), SLOT (changedCategories (int))); 1044 connect (tempMenu, SIGNAL (activated (int)), SLOT (changedCategories (int)));
1034 return tempMenu; 1045 return tempMenu;
1035 1046
1036 1047
1037} 1048}
1038void KOTodoView::changedCategories(int index) 1049void KOTodoView::changedCategories(int index)
1039{ 1050{
1040 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { 1051 if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) {
1041 QStringList categories = mActiveItem->todo()->categories (); 1052 QStringList categories = mActiveItem->todo()->categories ();
1042 QString colcat = categories.first(); 1053 QString colcat = categories.first();
1043 if (categories.find (mCategory[index]) != categories.end ()) 1054 if (categories.find (mCategory[index]) != categories.end ())
1044 categories.remove (mCategory[index]); 1055 categories.remove (mCategory[index]);
1045 else 1056 else
1046 categories.insert (categories.end(), mCategory[index]); 1057 categories.insert (categories.end(), mCategory[index]);
1047 categories.sort (); 1058 categories.sort ();
1048 if ( !colcat.isEmpty() ) { 1059 if ( !colcat.isEmpty() ) {
1049 if ( categories.find ( colcat ) != categories.end () ) { 1060 if ( categories.find ( colcat ) != categories.end () ) {
1050 categories.remove( colcat ); 1061 categories.remove( colcat );
1051 categories.prepend( colcat ); 1062 categories.prepend( colcat );
1052 } 1063 }
1053 } 1064 }
1054 mActiveItem->todo()->setCategories (categories); 1065 mActiveItem->todo()->setCategories (categories);
1055 mActiveItem->construct(); 1066 mActiveItem->construct();
1056 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); 1067 mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 );
1057 todoModified (mActiveItem->todo (), KOGlobals::CATEGORY_MODIFIED); 1068 todoModified (mActiveItem->todo (), KOGlobals::CATEGORY_MODIFIED);
1058 } 1069 }
1059} 1070}
1060void KOTodoView::itemDoubleClicked(QListViewItem *item) 1071void KOTodoView::itemDoubleClicked(QListViewItem *item)
1061{ 1072{
1062 if ( pendingSubtodo != 0 ) { 1073 if ( pendingSubtodo != 0 ) {
1063 topLevelWidget()->setCaption(i18n("Reparenting aborted!")); 1074 topLevelWidget()->setCaption(i18n("Reparenting aborted!"));
1064 } 1075 }
1065 pendingSubtodo = 0; 1076 pendingSubtodo = 0;
1077 int row = mTodoListView->header()->sectionAt ( mTodoListView->header()->mapFromGlobal( QCursor::pos()).x() );
1078 //qDebug("ROW %d ", row);
1066 if (!item) { 1079 if (!item) {
1067 newTodo(); 1080 newTodo();
1068 return; 1081 return;
1082 } else {
1083 if ( row == 1 ) {
1084 mActiveItem = (KOTodoViewItem *) item;
1085 newSubTodo();
1086 return;
1087 }
1069 } 1088 }
1070 if ( KOPrefs::instance()->mEditOnDoubleClick ) 1089 if ( KOPrefs::instance()->mEditOnDoubleClick )
1071 editItem( item ); 1090 editItem( item );
1072 else 1091 else
1073 showItem( item , QPoint(), 0 ); 1092 showItem( item , QPoint(), 0 );
1074} 1093}
1075void KOTodoView::itemClicked(QListViewItem *item) 1094void KOTodoView::itemClicked(QListViewItem *item)
1076{ 1095{
1077 1096 //qDebug("KOTodoView::itemClicked %d", item);
1078 if (!item) { 1097 if (!item) {
1079 if ( pendingSubtodo != 0 ) { 1098 if ( pendingSubtodo != 0 ) {
1080 topLevelWidget()->setCaption(i18n("Reparenting aborted!")); 1099 topLevelWidget()->setCaption(i18n("Reparenting aborted!"));
1081 } 1100 }
1082 pendingSubtodo = 0; 1101 pendingSubtodo = 0;
1083 return; 1102 return;
1084 } 1103 }
1085 KOTodoViewItem *todoItem = (KOTodoViewItem *)item; 1104 KOTodoViewItem *todoItem = (KOTodoViewItem *)item;
1086 if ( pendingSubtodo != 0 ) { 1105 if ( pendingSubtodo != 0 ) {
1087 bool allowReparent = true; 1106 bool allowReparent = true;
1088 QListViewItem *par = item; 1107 QListViewItem *par = item;
1089 while ( par ) { 1108 while ( par ) {
1090 if ( par == pendingSubtodo ) { 1109 if ( par == pendingSubtodo ) {
1091 allowReparent = false; 1110 allowReparent = false;
1092 break; 1111 break;
1093 } 1112 }
1094 par = par->parent(); 1113 par = par->parent();
1095 } 1114 }
1096 if ( !allowReparent ) { 1115 if ( !allowReparent ) {
1097 topLevelWidget()->setCaption(i18n("Recursive reparenting not possible!")); 1116 topLevelWidget()->setCaption(i18n("Recursive reparenting not possible!"));
1098 qDebug("Recursive reparenting not possible "); 1117 qDebug("Recursive reparenting not possible ");
1099 pendingSubtodo = 0; 1118 pendingSubtodo = 0;
1100 } else { 1119 } else {
1101 Todo* newParent = todoItem->todo(); 1120 Todo* newParent = todoItem->todo();
1102 Todo* newSub = pendingSubtodo->todo(); 1121 Todo* newSub = pendingSubtodo->todo();
1103 pendingSubtodo = 0; 1122 pendingSubtodo = 0;
1104 emit reparentTodoSignal( newParent,newSub ); 1123 emit reparentTodoSignal( newParent,newSub );
1105 return; 1124 return;
1106 } 1125 }
1107 } 1126 }
1108#if 0 1127#if 0
1109 // handled by the item itself 1128 // handled by the item itself
1110 bool completed = todoItem->todo()->isCompleted(); // Completed or not? 1129 bool completed = todoItem->todo()->isCompleted(); // Completed or not?
1111 qDebug("com %d ",completed ); 1130 qDebug("com %d ",completed );
1112 qDebug("itemclicked "); 1131 qDebug("itemclicked ");
1113 if (todoItem->isOn()) { 1132 if (todoItem->isOn()) {
1114 qDebug("on "); 1133 qDebug("on ");
1115 if (!completed) { 1134 if (!completed) {
1116 qDebug("set true "); 1135 qDebug("set true ");
1117 todoItem->todo()->setCompleted(QDateTime::currentDateTime()); 1136 todoItem->todo()->setCompleted(QDateTime::currentDateTime());
1118 } 1137 }
1119 } else { 1138 } else {
1120 qDebug("not on "); 1139 qDebug("not on ");
1121 if (completed) { 1140 if (completed) {
1122 qDebug("set false "); 1141 qDebug("set false ");
1123 todoItem->todo()->setCompleted(false); 1142 todoItem->todo()->setCompleted(false);
1124 } 1143 }
1125 } 1144 }
1126#endif 1145#endif
1127} 1146}
1128 1147
1129void KOTodoView::setDocumentId( const QString &id ) 1148void KOTodoView::setDocumentId( const QString &id )
1130{ 1149{
1131 kdDebug() << "KOTodoView::setDocumentId()" << endl; 1150 kdDebug() << "KOTodoView::setDocumentId()" << endl;
1132 1151
1133 mDocPrefs->setDoc( id ); 1152 mDocPrefs->setDoc( id );
1134} 1153}
1135 1154
1136void KOTodoView::itemStateChanged( QListViewItem *item ) 1155void KOTodoView::itemStateChanged( QListViewItem *item )
1137{ 1156{
1138 if (!item) return; 1157 if (!item) return;
1139 1158
1140 KOTodoViewItem *todoItem = (KOTodoViewItem *)item; 1159 KOTodoViewItem *todoItem = (KOTodoViewItem *)item;
1141 1160
1142// kdDebug() << "KOTodoView::itemStateChanged(): " << todoItem->todo()->summary() << endl; 1161// kdDebug() << "KOTodoView::itemStateChanged(): " << todoItem->todo()->summary() << endl;
1143 1162
1144 if( mDocPrefs ) mDocPrefs->writeEntry( todoItem->todo()->uid(), todoItem->isOpen() ); 1163 if( mDocPrefs ) mDocPrefs->writeEntry( todoItem->todo()->uid(), todoItem->isOpen() );
1145} 1164}
1146 1165
1147void KOTodoView::saveLayout(KConfig *config, const QString &group) const 1166void KOTodoView::saveLayout(KConfig *config, const QString &group) const
1148{ 1167{
1149 mTodoListView->saveLayout(config,group); 1168 mTodoListView->saveLayout(config,group);
1150} 1169}
1151 1170
1152void KOTodoView::restoreLayout(KConfig *config, const QString &group) 1171void KOTodoView::restoreLayout(KConfig *config, const QString &group)
1153{ 1172{
1154 mTodoListView->restoreLayout(config,group); 1173 mTodoListView->restoreLayout(config,group);
1155} 1174}
1156 1175
1157void KOTodoView::processSelectionChange() 1176void KOTodoView::processSelectionChange()
1158{ 1177{
1159// kdDebug() << "KOTodoView::processSelectionChange()" << endl; 1178// kdDebug() << "KOTodoView::processSelectionChange()" << endl;
1160 1179
1161 KOTodoViewItem *item = 1180 KOTodoViewItem *item =
1162 static_cast<KOTodoViewItem *>( mTodoListView->selectedItem() ); 1181 static_cast<KOTodoViewItem *>( mTodoListView->selectedItem() );
1163 1182
1164 if ( !item ) { 1183 if ( !item ) {
1165 emit incidenceSelected( 0 ); 1184 emit incidenceSelected( 0 );
1166 } else { 1185 } else {
1167 emit incidenceSelected( item->todo() ); 1186 emit incidenceSelected( item->todo() );
1168 } 1187 }
1169} 1188}
1170 1189
1171void KOTodoView::modified(bool b) 1190void KOTodoView::modified(bool b)
1172{ 1191{
1173 emit isModified(b); 1192 emit isModified(b);
1174} 1193}
1175void KOTodoView::setTodoModified( Todo* todo ) 1194void KOTodoView::setTodoModified( Todo* todo )
1176{ 1195{
1177 todoModified( todo, KOGlobals::UNKNOWN_MODIFIED ); 1196 todoModified( todo, KOGlobals::UNKNOWN_MODIFIED );
1178} 1197}
1179void KOTodoView::clearSelection() 1198void KOTodoView::clearSelection()
1180{ 1199{
1181 mTodoListView->selectAll( false ); 1200 mTodoListView->selectAll( false );
1182} 1201}
1183void KOTodoView::setAllOpen() 1202void KOTodoView::setAllOpen()
1184{ 1203{
1185 if ( isFlatDisplay ) { 1204 if ( isFlatDisplay ) {
1186 isFlatDisplay = false; 1205 isFlatDisplay = false;
1187 mPopupMenu->setItemChecked( 8,false ); 1206 mPopupMenu->setItemChecked( 8,false );
1188 updateView(); 1207 updateView();
1189 } 1208 }
1190 setOpen(mTodoListView->firstChild(), true); 1209 setOpen(mTodoListView->firstChild(), true);
1191} 1210}
1192void KOTodoView::setAllClose() 1211void KOTodoView::setAllClose()
1193{ 1212{
1194 if ( isFlatDisplay ) { 1213 if ( isFlatDisplay ) {
1195 isFlatDisplay = false; 1214 isFlatDisplay = false;
1196 mPopupMenu->setItemChecked( 8,false ); 1215 mPopupMenu->setItemChecked( 8,false );
1197 updateView(); 1216 updateView();
1198 } 1217 }
1199 setOpen(mTodoListView->firstChild(), false); 1218 setOpen(mTodoListView->firstChild(), false);
1200} 1219}
1201void KOTodoView::setOpen( QListViewItem* item, bool setOpenI) 1220void KOTodoView::setOpen( QListViewItem* item, bool setOpenI)
1202{ 1221{
1203 1222
1204 while ( item ) { 1223 while ( item ) {
1205 setOpen( item->firstChild(), setOpenI ); 1224 setOpen( item->firstChild(), setOpenI );
1206 item->setOpen( setOpenI ); 1225 item->setOpen( setOpenI );
1207 item = item->nextSibling(); 1226 item = item->nextSibling();
1208 } 1227 }
1209} 1228}
1210 1229
1211void KOTodoView::displayAllFlat() 1230void KOTodoView::displayAllFlat()
1212{ 1231{
1213 pendingSubtodo = 0; 1232 pendingSubtodo = 0;
1214 if ( mBlockUpdate ) { 1233 if ( mBlockUpdate ) {
1215 return; 1234 return;
1216 } 1235 }
1217 mPopupMenu->setItemChecked( 8,true ); 1236 mPopupMenu->setItemChecked( 8,true );
1218 isFlatDisplay = true; 1237 isFlatDisplay = true;
1219 QPtrList<Todo> todoList = calendar()->todos(); 1238 QPtrList<Todo> todoList = calendar()->todos();
1220 mTodoMap.clear(); 1239 mTodoMap.clear();
1221 mTodoListView->clear(); 1240 mTodoListView->clear();
1222 Todo *todo; 1241 Todo *todo;
1223 for(todo = todoList.first(); todo; todo = todoList.next()) { 1242 for(todo = todoList.first(); todo; todo = todoList.next()) {
1224 KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); 1243 KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this);
1225 mTodoMap.insert(todo,todoItem); 1244 mTodoMap.insert(todo,todoItem);
1226 } 1245 }
1227 mTodoListView->setFocus(); 1246 mTodoListView->setFocus();
1228 processSelectionChange(); 1247 processSelectionChange();
1229} 1248}
1230 1249
1231void KOTodoView::setAllFlat() 1250void KOTodoView::setAllFlat()
1232{ 1251{
1233 if ( isFlatDisplay ) { 1252 if ( isFlatDisplay ) {
1234 isFlatDisplay = false; 1253 isFlatDisplay = false;
1235 mPopupMenu->setItemChecked( 8,false ); 1254 mPopupMenu->setItemChecked( 8,false );
1236 updateView(); 1255 updateView();
1237 return; 1256 return;
1238 } 1257 }
1239 displayAllFlat(); 1258 displayAllFlat();
1240} 1259}
1241 1260
1242void KOTodoView::purgeCompleted() 1261void KOTodoView::purgeCompleted()
1243{ 1262{
1244 emit purgeCompletedSignal(); 1263 emit purgeCompletedSignal();
1245} 1264}
1246void KOTodoView::toggleQuickTodo() 1265void KOTodoView::toggleQuickTodo()
1247{ 1266{
1248 if ( mQuickAdd->isVisible() ) { 1267 if ( mQuickAdd->isVisible() ) {
1249 mQuickAdd->hide(); 1268 mQuickAdd->hide();
1250 KOPrefs::instance()->mEnableQuickTodo = false; 1269 KOPrefs::instance()->mEnableQuickTodo = false;
1251 } 1270 }
1252 else { 1271 else {
1253 mQuickAdd->show(); 1272 mQuickAdd->show();
1254 KOPrefs::instance()->mEnableQuickTodo = true; 1273 KOPrefs::instance()->mEnableQuickTodo = true;
1255 } 1274 }
1256 mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); 1275 mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo);
1257 mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); 1276 mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo );
1258} 1277}
1259 1278
1260void KOTodoView::toggleRunning() 1279void KOTodoView::toggleRunning()
1261{ 1280{
1262 KOPrefs::instance()->mHideNonStartedTodos = !KOPrefs::instance()->mHideNonStartedTodos; 1281 KOPrefs::instance()->mHideNonStartedTodos = !KOPrefs::instance()->mHideNonStartedTodos;
1263 mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); 1282 mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos);
1264 mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); 1283 mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos );
1265 updateView(); 1284 updateView();
1266} 1285}
1267 1286
1268void KOTodoView::toggleCompleted() 1287void KOTodoView::toggleCompleted()
1269{ 1288{
1270 KOPrefs::instance()->mShowCompletedTodo = !KOPrefs::instance()->mShowCompletedTodo; 1289 KOPrefs::instance()->mShowCompletedTodo = !KOPrefs::instance()->mShowCompletedTodo;
1271 mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); 1290 mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo );
1272 mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); 1291 mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo );
1273 updateView(); 1292 updateView();
1274} 1293}
1275 1294
1276void KOTodoView::addQuickTodo() 1295void KOTodoView::addQuickTodo()
1277{ 1296{
1278 Todo *todo = new Todo(); 1297 Todo *todo = new Todo();
1279 todo->setSummary(mQuickAdd->text()); 1298 todo->setSummary(mQuickAdd->text());
1280 todo->setOrganizer(KOPrefs::instance()->email()); 1299 todo->setOrganizer(KOPrefs::instance()->email());
1281 CalFilter * cf = mCalendar->filter(); 1300 CalFilter * cf = mCalendar->filter();
1282 if ( cf ) { 1301 if ( cf ) {
1283 if ( cf->isEnabled()&& cf->showCategories()) { 1302 if ( cf->isEnabled()&& cf->showCategories()) {
1284 todo->setCategories(cf->categoryList()); 1303 todo->setCategories(cf->categoryList());
1285 } 1304 }
1286 if ( cf->isEnabled() ) 1305 if ( cf->isEnabled() )
1287 todo->setSecrecy( cf->getSecrecy()); 1306 todo->setSecrecy( cf->getSecrecy());
1288 } 1307 }
1289 mCalendar->addTodo(todo); 1308 mCalendar->addTodo(todo);
1290 mQuickAdd->setText(""); 1309 mQuickAdd->setText("");
1291 todoModified (todo, KOGlobals::EVENTADDED ); 1310 todoModified (todo, KOGlobals::EVENTADDED );
1292 updateView(); 1311 updateView();
1293} 1312}
1294 1313
1295void KOTodoView::keyPressEvent ( QKeyEvent * e ) 1314void KOTodoView::keyPressEvent ( QKeyEvent * e )
1296{ 1315{
1297 // e->ignore(); 1316 // e->ignore();
1298 //return; 1317 //return;
1299 //qDebug("KOTodoView::keyPressEvent "); 1318 //qDebug("KOTodoView::keyPressEvent ");
1300 switch ( e->key() ) { 1319 switch ( e->key() ) {
1301 case Qt::Key_Down: 1320 case Qt::Key_Down:
1302 case Qt::Key_Up: 1321 case Qt::Key_Up:
1303 QWidget::keyPressEvent ( e ); 1322 QWidget::keyPressEvent ( e );
1304 break; 1323 break;
1305 1324
1306 case Qt::Key_Q: 1325 case Qt::Key_Q:
1307 toggleQuickTodo(); 1326 toggleQuickTodo();
1308 break; 1327 break;
1309 case Qt::Key_U: 1328 case Qt::Key_U:
1310 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { 1329 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) {
1311 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); 1330 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem();
1312 unparentTodo(); 1331 unparentTodo();
1313 e->accept(); 1332 e->accept();
1314 } else 1333 } else
1315 e->ignore(); 1334 e->ignore();
1316 break; 1335 break;
1317 case Qt::Key_S: 1336 case Qt::Key_S:
1318 if ( e->state() == Qt::ControlButton ) { 1337 if ( e->state() == Qt::ControlButton ) {
1319 e->ignore(); 1338 e->ignore();
1320 break; 1339 break;
1321 } 1340 }
1322 if ( e->state() == Qt::ShiftButton ) { 1341 if ( e->state() == Qt::ShiftButton ) {
1323 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); 1342 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem();
1324 reparentTodo(); 1343 reparentTodo();
1325 e->accept(); 1344 e->accept();
1326 } else 1345 } else
1327 e->ignore(); 1346 e->ignore();
1328 break; 1347 break;
1329 case Qt::Key_P: 1348 case Qt::Key_P:
1330 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { 1349 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) {
1331 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); 1350 mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem();
1332 if ( pendingSubtodo ) 1351 if ( pendingSubtodo )
1333 itemClicked(mActiveItem); 1352 itemClicked(mActiveItem);
1334 e->accept(); 1353 e->accept();
1335 } else 1354 } else
1336 e->ignore(); 1355 e->ignore();
1337 break; 1356 break;
1338 case Qt::Key_Escape: 1357 case Qt::Key_Escape:
1339 if ( pendingSubtodo ) { 1358 if ( pendingSubtodo ) {
1340 itemClicked(0); 1359 itemClicked(0);
1341 e->accept(); 1360 e->accept();
1342 } else 1361 } else
1343 e->ignore(); 1362 e->ignore();
1344 break; 1363 break;
1345 default: 1364 default:
1346 e->ignore(); 1365 e->ignore();
1347 } 1366 }
1348 1367
1349 if ( true ) { 1368 if ( true ) {
1350 if ( e->key() == Qt::Key_I ) { 1369 if ( e->key() == Qt::Key_I ) {
1351 KOTodoViewItem*cn = (KOTodoViewItem*)mTodoListView->currentItem(); 1370 KOTodoViewItem*cn = (KOTodoViewItem*)mTodoListView->currentItem();
1352 if ( cn ) { 1371 if ( cn ) {
1353 mActiveItem = cn; 1372 mActiveItem = cn;
1354 KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); 1373 KOTodoViewItem* ci = (KOTodoViewItem*)( cn );
1355 if ( ci ){ 1374 if ( ci ){
1356 showTodo(); 1375 showTodo();
1357 cn = (KOTodoViewItem*)cn->itemBelow(); 1376 cn = (KOTodoViewItem*)cn->itemBelow();
1358 if ( cn ) { 1377 if ( cn ) {
1359 mTodoListView->setCurrentItem ( cn ); 1378 mTodoListView->setCurrentItem ( cn );
1360 mTodoListView->ensureItemVisible ( cn ); 1379 mTodoListView->ensureItemVisible ( cn );
1361 } 1380 }
1362 1381
1363 } 1382 }
1364 } 1383 }
1365 e->accept(); 1384 e->accept();
1366 1385
1367 } 1386 }
1368 1387
1369 } 1388 }
1370 1389
1371} 1390}
1372void KOTodoView::updateTodo( Todo * t, int type ) 1391void KOTodoView::updateTodo( Todo * t, int type )
1373{ 1392{
1374 if ( mBlockUpdate) 1393 if ( mBlockUpdate)
1375 return; 1394 return;
1376 1395
1377 QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; 1396 QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator;
1378 itemIterator = mTodoMap.find(t); 1397 itemIterator = mTodoMap.find(t);
1379 if (itemIterator != mTodoMap.end()) { 1398 if (itemIterator != mTodoMap.end()) {
1380 (*itemIterator)->construct(); 1399 (*itemIterator)->construct();
1381 } else { 1400 } else {
1382 if ( type == KOGlobals::EVENTADDED ) { 1401 if ( type == KOGlobals::EVENTADDED ) {
1383 insertTodoItem( t ); 1402 insertTodoItem( t );
1384 } 1403 }
1385 } 1404 }
1386 1405
1387} 1406}
1388 1407
1389void KOTodoView::todoModified(Todo * t , int p ) 1408void KOTodoView::todoModified(Todo * t , int p )
1390{ 1409{
1391 mBlockUpdate = true; 1410 mBlockUpdate = true;
1392 emit todoModifiedSignal ( t, p ); 1411 emit todoModifiedSignal ( t, p );
1393 mBlockUpdate = false; 1412 mBlockUpdate = false;
1394} 1413}
diff --git a/microkde/kcolordialog.cpp b/microkde/kcolordialog.cpp
index 9a76e5e..a3d8973 100644
--- a/microkde/kcolordialog.cpp
+++ b/microkde/kcolordialog.cpp
@@ -1,92 +1,93 @@
1#include "kcolordialog.h" 1#include "kcolordialog.h"
2#include <qdialog.h> 2#include <qdialog.h>
3#include <qlayout.h> 3#include <qlayout.h>
4#include <qlabel.h> 4#include <qlabel.h>
5#include <qslider.h> 5#include <qslider.h>
6#include <qhbox.h> 6#include <qhbox.h>
7#include <qapplication.h> 7#include <qapplication.h>
8#include <qpushbutton.h> 8#include <qpushbutton.h>
9 9
10#include <kglobal.h> 10#include <kglobal.h>
11QColor KColorDialog::getColor( ) const 11QColor KColorDialog::getColor( ) const
12{ 12{
13 QColor c ( r->value(), g->value(), b->value() ); 13 QColor c ( r->value(), g->value(), b->value() );
14 lar->setText ( "R: " + QString::number ( c.red() ) ); 14 lar->setText ( "R: " + QString::number ( c.red() ) );
15 lag->setText ( "G: " + QString::number ( c.green() ) ); 15 lag->setText ( "G: " + QString::number ( c.green() ) );
16 lab->setText ( "B: " + QString::number ( c.blue() ) ); 16 lab->setText ( "B: " + QString::number ( c.blue() ) );
17 return c; 17 return c;
18} 18}
19void KColorDialog::setColor( const QColor & d ) 19void KColorDialog::setColor( const QColor & d )
20{ 20{
21 r->setValue(d.red() ); 21 r->setValue(d.red() );
22 g->setValue(d.green() ); 22 g->setValue(d.green() );
23 b->setValue(d.blue() ); 23 b->setValue(d.blue() );
24 old_color->setPalette( QPalette( d.dark(), d ) ); 24 old_color->setPalette( QPalette( d.dark(), d ) );
25 lar->setText ( "R: " + QString::number ( d.red() ) ); 25 lar->setText ( "R: " + QString::number ( d.red() ) );
26 lag->setText ( "G: " + QString::number ( d.green() ) ); 26 lag->setText ( "G: " + QString::number ( d.green() ) );
27 lab->setText ( "B: " + QString::number ( d.blue() ) ); 27 lab->setText ( "B: " + QString::number ( d.blue() ) );
28 28
29} 29}
30KColorDialog::KColorDialog( QWidget *p ):QDialog( p, "input-dialog", true ) 30KColorDialog::KColorDialog( QWidget *p ):QDialog( p, "input-dialog", true )
31{ 31{
32 setCaption( i18n("Choose Color") ); 32 setCaption( i18n("Choose Color") );
33 33
34 setMaximumSize( QApplication::desktop()->width() - 20, QApplication::desktop()->height() - 40 ); // for zaurus 5500er. 34 setMaximumSize( QApplication::desktop()->width() - 20, QApplication::desktop()->height() - 40 ); // for zaurus 5500er.
35 QGridLayout* lay = new QGridLayout ( this, 4, 2 ); 35 QGridLayout* lay = new QGridLayout ( this, 4, 2 );
36 lay->setSpacing( 6 ); 36 lay->setSpacing( 6 );
37 lay->setMargin( 11 ); 37 lay->setMargin( 11 );
38 38
39 old_color = new QLabel("Old color",this); 39 old_color = new QLabel("Old color",this);
40 old_color->setFrameStyle( QFrame::Panel | QFrame::Plain ); 40 old_color->setFrameStyle( QFrame::Panel | QFrame::Plain );
41 old_color->setLineWidth( 1 ); 41 old_color->setLineWidth( 1 );
42 lay->addWidget(old_color, 0, 0); 42 lay->addWidget(old_color, 0, 0);
43 43
44 new_color = new QLabel("New color", this); 44 new_color = new QLabel("New color", this);
45 new_color->setFrameStyle( QFrame::Panel | QFrame::Plain ); 45 new_color->setFrameStyle( QFrame::Panel | QFrame::Plain );
46 new_color->setLineWidth( 1 ); 46 new_color->setLineWidth( 1 );
47 lay->addWidget(new_color, 0, 1); 47 lay->addWidget(new_color, 0, 1);
48 new_color->setAlignment( AlignCenter ); 48 new_color->setAlignment( AlignCenter );
49 49
50 QHBox* hb = new QHBox ( this ); 50 QHBox* hb = new QHBox ( this );
51 lar = new QLabel( hb ); 51 lar = new QLabel( hb );
52 lag = new QLabel( hb ); 52 lag = new QLabel( hb );
53 lab = new QLabel( hb ); 53 lab = new QLabel( hb );
54 lay->addMultiCellWidget( hb,1,1, 0,1 ); 54 lay->addMultiCellWidget( hb,1,1, 0,1 );
55 55
56 QLabel* lr = new QLabel ( "Red:", this ); 56 QLabel* lr = new QLabel ( "Red:", this );
57 lay->addWidget( lr,2,0 ); 57 lay->addWidget( lr,2,0 );
58 r = new QSlider ( 0, 255, 1, 1, Horizontal, this ); 58 r = new QSlider ( 0, 255, 1, 1, Horizontal, this );
59 lay->addWidget(r ,2,1 ); 59 lay->addWidget(r ,2,1 );
60 60
61 QLabel* lg = new QLabel( "Green:",this ); 61 QLabel* lg = new QLabel( "Green:",this );
62 lay->addWidget(lg ,3,0 ); 62 lay->addWidget(lg ,3,0 );
63 g = new QSlider ( 0, 255, 1, 1, Horizontal, this ); 63 g = new QSlider ( 0, 255, 1, 1, Horizontal, this );
64 lay->addWidget( g ,3,1 ); 64 lay->addWidget( g ,3,1 );
65 65
66 QLabel* lb = new QLabel ( "Blue:",this ); 66 QLabel* lb = new QLabel ( "Blue:",this );
67 lay->addWidget( lb,4,0 ); 67 lay->addWidget( lb,4,0 );
68 b = new QSlider ( 0, 255, 1, 1, Horizontal, this ); 68 b = new QSlider ( 0, 255, 1, 1, Horizontal, this );
69 lay->addWidget(b ,4,1 ); 69 lay->addWidget(b ,4,1 );
70 70
71 QColor d = backgroundColor(); 71 QColor d = backgroundColor();
72 r->setValue(d.red() ); 72 r->setValue(d.red() );
73 g->setValue(d.green() ); 73 g->setValue(d.green() );
74 b->setValue(d.blue() ); 74 b->setValue(d.blue() );
75 old_color->setPalette( QPalette( d.dark() , d ) ); 75 old_color->setPalette( QPalette( d.dark() , d ) );
76 // kannst du wieder reinnehmen, aber es geht auch so. 76 // kannst du wieder reinnehmen, aber es geht auch so.
77 QPushButton * ok = new QPushButton (i18n(" OK "), this ); 77 QPushButton * ok = new QPushButton (i18n(" OK "), this );
78 ok->setDefault( true );
78 QPushButton * cancel = new QPushButton (i18n(" Cancel "), this ); 79 QPushButton * cancel = new QPushButton (i18n(" Cancel "), this );
79 80
80 lay->addWidget(ok ,5,0 ); 81 lay->addWidget(ok ,5,0 );
81 lay->addWidget(cancel ,5,1 ); 82 lay->addWidget(cancel ,5,1 );
82 connect (ok, SIGNAL( clicked() ), this ,SLOT (accept() )); 83 connect (ok, SIGNAL( clicked() ), this ,SLOT (accept() ));
83 connect (cancel, SIGNAL( clicked() ), this ,SLOT (reject() )); 84 connect (cancel, SIGNAL( clicked() ), this ,SLOT (reject() ));
84 connect (r, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) )); 85 connect (r, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) ));
85 connect (g, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) )); 86 connect (g, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) ));
86 connect (b, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) )); 87 connect (b, SIGNAL( valueChanged ( int ) ), this ,SLOT (updateColor( int ) ));
87} 88}
88void KColorDialog::updateColor( int ) 89void KColorDialog::updateColor( int )
89{ 90{
90 QColor c = getColor( ) ; 91 QColor c = getColor( ) ;
91 new_color->setPalette( QPalette( c.dark(), c ) ); 92 new_color->setPalette( QPalette( c.dark(), c ) );
92} 93}
diff --git a/microkde/kdeui/ktoolbar.cpp b/microkde/kdeui/ktoolbar.cpp
index 35d4916..36ede81 100644
--- a/microkde/kdeui/ktoolbar.cpp
+++ b/microkde/kdeui/ktoolbar.cpp
@@ -1,2266 +1,2268 @@
1/* This file is part of the KDE libraries 1/* This file is part of the KDE libraries
2 Copyright 2 Copyright
3 (C) 2000 Reginald Stadlbauer (reggie@kde.org) 3 (C) 2000 Reginald Stadlbauer (reggie@kde.org)
4 (C) 1997, 1998 Stephan Kulow (coolo@kde.org) 4 (C) 1997, 1998 Stephan Kulow (coolo@kde.org)
5 (C) 1997, 1998 Mark Donohoe (donohoe@kde.org) 5 (C) 1997, 1998 Mark Donohoe (donohoe@kde.org)
6 (C) 1997, 1998 Sven Radej (radej@kde.org) 6 (C) 1997, 1998 Sven Radej (radej@kde.org)
7 (C) 1997, 1998 Matthias Ettrich (ettrich@kde.org) 7 (C) 1997, 1998 Matthias Ettrich (ettrich@kde.org)
8 (C) 1999 Chris Schlaeger (cs@kde.org) 8 (C) 1999 Chris Schlaeger (cs@kde.org)
9 (C) 1999 Kurt Granroth (granroth@kde.org) 9 (C) 1999 Kurt Granroth (granroth@kde.org)
10 10
11 This library is free software; you can redistribute it and/or 11 This library is free software; you can redistribute it and/or
12 modify it under the terms of the GNU Library General Public 12 modify it under the terms of the GNU Library General Public
13 License version 2 as published by the Free Software Foundation. 13 License version 2 as published by the Free Software Foundation.
14 14
15 This library is distributed in the hope that it will be useful, 15 This library is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of 16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 Library General Public License for more details. 18 Library General Public License for more details.
19 19
20 You should have received a copy of the GNU Library General Public License 20 You should have received a copy of the GNU Library General Public License
21 along with this library; see the file COPYING.LIB. If not, write to 21 along with this library; see the file COPYING.LIB. If not, write to
22 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, 22 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23 Boston, MA 02111-1307, USA. 23 Boston, MA 02111-1307, USA.
24*/ 24*/
25 25
26#ifdef KDE_USE_FINAL 26#ifdef KDE_USE_FINAL
27#undef Always 27#undef Always
28#include <qdockwindow.h> 28#include <qdockwindow.h>
29#endif 29#endif
30 30
31 31
32 32
33#include "ktoolbar.h" 33#include "ktoolbar.h"
34#include "kmainwindow.h" 34#include "kmainwindow.h"
35 35
36#include <string.h> 36#include <string.h>
37 37
38#include <qpainter.h> 38#include <qpainter.h>
39#include <qtooltip.h> 39#include <qtooltip.h>
40#include <qdrawutil.h> 40#include <qdrawutil.h>
41#include <qstring.h> 41#include <qstring.h>
42#include <qrect.h> 42#include <qrect.h>
43#include <qobjectlist.h> 43#include <qobjectlist.h>
44#include <qtimer.h> 44#include <qtimer.h>
45#include <qstyle.h> 45#include <qstyle.h>
46#include <qapplication.h> 46#include <qapplication.h>
47 47
48//US #include <config.h> 48//US #include <config.h>
49 49
50#include "klineedit.h" 50#include "klineedit.h"
51#include "kseparator.h" 51#include "kseparator.h"
52#include <klocale.h> 52#include <klocale.h>
53#include <kapplication.h> 53#include <kapplication.h>
54#include <kaction.h> 54#include <kaction.h>
55#include <kstdaction.h> 55#include <kstdaction.h>
56#include <kglobal.h> 56#include <kglobal.h>
57#include <kconfig.h> 57#include <kconfig.h>
58#include <kiconloader.h> 58#include <kiconloader.h>
59#include <kcombobox.h> 59#include <kcombobox.h>
60//US #include <kpopupmenu.h> 60//US #include <kpopupmenu.h>
61//US #include <kanimwidget.h> 61//US #include <kanimwidget.h>
62//US #include <kipc.h> 62//US #include <kipc.h>
63//US #include <kwin.h> 63//US #include <kwin.h>
64#include <kdebug.h> 64#include <kdebug.h>
65#include <qlayout.h> 65#include <qlayout.h>
66 66
67#include "ktoolbarbutton.h" 67#include "ktoolbarbutton.h"
68 68
69//US 69//US
70#include "kconfigbase.h" 70#include "kconfigbase.h"
71 71
72#include <qpopupmenu.h> 72#include <qpopupmenu.h>
73#include <qmainwindow.h> 73#include <qmainwindow.h>
74 74
75enum { 75enum {
76 CONTEXT_TOP = 0, 76 CONTEXT_TOP = 0,
77 CONTEXT_LEFT = 1, 77 CONTEXT_LEFT = 1,
78 CONTEXT_RIGHT = 2, 78 CONTEXT_RIGHT = 2,
79 CONTEXT_BOTTOM = 3, 79 CONTEXT_BOTTOM = 3,
80 CONTEXT_FLOAT = 4, 80 CONTEXT_FLOAT = 4,
81 CONTEXT_FLAT = 5, 81 CONTEXT_FLAT = 5,
82 CONTEXT_ICONS = 6, 82 CONTEXT_ICONS = 6,
83 CONTEXT_TEXT = 7, 83 CONTEXT_TEXT = 7,
84 CONTEXT_TEXTRIGHT = 8, 84 CONTEXT_TEXTRIGHT = 8,
85 CONTEXT_TEXTUNDER = 9, 85 CONTEXT_TEXTUNDER = 9,
86 CONTEXT_ICONSIZES = 50 // starting point for the icon size list, put everything else before 86 CONTEXT_ICONSIZES = 50 // starting point for the icon size list, put everything else before
87}; 87};
88 88
89class KToolBarPrivate 89class KToolBarPrivate
90{ 90{
91public: 91public:
92 KToolBarPrivate() { 92 KToolBarPrivate() {
93 m_iconSize = 0; 93 m_iconSize = 0;
94 m_iconText = KToolBar::IconOnly; 94 m_iconText = KToolBar::IconOnly;
95 m_highlight = true; 95 m_highlight = true;
96 m_transparent = true; 96 m_transparent = true;
97 m_honorStyle = false; 97 m_honorStyle = false;
98 98
99 m_enableContext = true; 99 m_enableContext = true;
100 100
101 m_xmlguiClient = 0; 101 m_xmlguiClient = 0;
102 m_configurePlugged = false; 102 m_configurePlugged = false;
103 103
104//US oldPos = Qt::DockUnmanaged; 104//US oldPos = Qt::DockUnmanaged;
105 oldPos = QMainWindow::Unmanaged; 105 oldPos = QMainWindow::Unmanaged;
106 106
107 modified = m_isHorizontal = positioned = FALSE; 107 modified = m_isHorizontal = positioned = FALSE;
108 108
109 HiddenDefault = false; 109 HiddenDefault = false;
110 IconSizeDefault = 0; 110 IconSizeDefault = 0;
111 IconTextDefault = "IconOnly"; 111 IconTextDefault = "IconOnly";
112 IndexDefault = -1; 112 IndexDefault = -1;
113 NewLineDefault = false; 113 NewLineDefault = false;
114 OffsetDefault = -1; 114 OffsetDefault = -1;
115 PositionDefault = "Top"; 115 PositionDefault = "Top";
116 idleButtons.setAutoDelete(true); 116 idleButtons.setAutoDelete(true);
117 } 117 }
118 118
119 int m_iconSize; 119 int m_iconSize;
120 KToolBar::IconText m_iconText; 120 KToolBar::IconText m_iconText;
121 bool m_highlight : 1; 121 bool m_highlight : 1;
122 bool m_transparent : 1; 122 bool m_transparent : 1;
123 bool m_honorStyle : 1; 123 bool m_honorStyle : 1;
124 bool m_isHorizontal : 1; 124 bool m_isHorizontal : 1;
125 bool m_enableContext : 1; 125 bool m_enableContext : 1;
126 bool m_configurePlugged : 1; 126 bool m_configurePlugged : 1;
127 bool modified : 1; 127 bool modified : 1;
128 bool positioned : 1; 128 bool positioned : 1;
129 129
130 QWidget *m_parent; 130 QWidget *m_parent;
131 131
132 QMainWindow::ToolBarDock oldPos; 132 QMainWindow::ToolBarDock oldPos;
133 133
134 KXMLGUIClient *m_xmlguiClient; 134 KXMLGUIClient *m_xmlguiClient;
135 135
136 struct ToolBarInfo 136 struct ToolBarInfo
137 { 137 {
138//US ToolBarInfo() : index( 0 ), offset( -1 ), newline( FALSE ), dock( Qt::DockTop ) {} 138//US ToolBarInfo() : index( 0 ), offset( -1 ), newline( FALSE ), dock( Qt::DockTop ) {}
139 ToolBarInfo() : index( 0 ), offset( -1 ), newline( FALSE ), dock( QMainWindow::Top ) {} 139 ToolBarInfo() : index( 0 ), offset( -1 ), newline( FALSE ), dock( QMainWindow::Top ) {}
140//US ToolBarInfo( Qt::Dock d, int i, bool n, int o ) : index( i ), offset( o ), newline( n ), dock( d ) {} 140//US ToolBarInfo( Qt::Dock d, int i, bool n, int o ) : index( i ), offset( o ), newline( n ), dock( d ) {}
141 ToolBarInfo( QMainWindow::ToolBarDock d, int i, bool n, int o ) : index( i ), offset( o ), newline( n ), dock( d ) {} 141 ToolBarInfo( QMainWindow::ToolBarDock d, int i, bool n, int o ) : index( i ), offset( o ), newline( n ), dock( d ) {}
142 int index, offset; 142 int index, offset;
143 bool newline; 143 bool newline;
144//US Qt::Dock dock; 144//US Qt::Dock dock;
145 QMainWindow::ToolBarDock dock; 145 QMainWindow::ToolBarDock dock;
146 }; 146 };
147 147
148 ToolBarInfo toolBarInfo; 148 ToolBarInfo toolBarInfo;
149 QValueList<int> iconSizes; 149 QValueList<int> iconSizes;
150 QTimer repaintTimer; 150 QTimer repaintTimer;
151 151
152 // Default Values. 152 // Default Values.
153 bool HiddenDefault; 153 bool HiddenDefault;
154 int IconSizeDefault; 154 int IconSizeDefault;
155 QString IconTextDefault; 155 QString IconTextDefault;
156 int IndexDefault; 156 int IndexDefault;
157 bool NewLineDefault; 157 bool NewLineDefault;
158 int OffsetDefault; 158 int OffsetDefault;
159 QString PositionDefault; 159 QString PositionDefault;
160 160
161 QPtrList<QWidget> idleButtons; 161 QPtrList<QWidget> idleButtons;
162}; 162};
163 163
164KToolBarSeparator::KToolBarSeparator(Orientation o , bool l, QToolBar *parent, 164KToolBarSeparator::KToolBarSeparator(Orientation o , bool l, QToolBar *parent,
165 const char* name ) 165 const char* name )
166 :QFrame( parent, name ), line( l ) 166 :QFrame( parent, name ), line( l )
167{ 167{
168 connect( parent, SIGNAL(orientationChanged(Orientation)), 168 connect( parent, SIGNAL(orientationChanged(Orientation)),
169 this, SLOT(setOrientation(Orientation)) ); 169 this, SLOT(setOrientation(Orientation)) );
170 setOrientation( o ); 170 setOrientation( o );
171 setBackgroundMode( parent->backgroundMode() ); 171 setBackgroundMode( parent->backgroundMode() );
172 setBackgroundOrigin( ParentOrigin ); 172 setBackgroundOrigin( ParentOrigin );
173} 173}
174 174
175void KToolBarSeparator::setOrientation( Orientation o ) 175void KToolBarSeparator::setOrientation( Orientation o )
176{ 176{
177 orient = o; 177 orient = o;
178 if ( line ) { 178 if ( line ) {
179 if ( orientation() == Vertical ) 179 if ( orientation() == Vertical )
180 setFrameStyle( HLine + Sunken ); 180 setFrameStyle( HLine + Sunken );
181 else 181 else
182 setFrameStyle( VLine + Sunken ); 182 setFrameStyle( VLine + Sunken );
183 } else { 183 } else {
184 setFrameStyle( NoFrame ); 184 setFrameStyle( NoFrame );
185 } 185 }
186} 186}
187 187
188void KToolBarSeparator::styleChange( QStyle& ) 188void KToolBarSeparator::styleChange( QStyle& )
189{ 189{
190 setOrientation( orient ); 190 setOrientation( orient );
191} 191}
192 192
193QSize KToolBarSeparator::sizeHint() const 193QSize KToolBarSeparator::sizeHint() const
194{ 194{
195 return orientation() == Vertical ? QSize( 0, 6 ) : QSize( 6, 0 ); 195 return orientation() == Vertical ? QSize( 0, 6 ) : QSize( 6, 0 );
196} 196}
197 197
198QSizePolicy KToolBarSeparator::sizePolicy() const 198QSizePolicy KToolBarSeparator::sizePolicy() const
199{ 199{
200 return QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum ); 200 return QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum );
201} 201}
202 202
203KToolBar::KToolBar( QWidget *parent, const char *name, bool honorStyle, bool readConfig ) 203KToolBar::KToolBar( QWidget *parent, const char *name, bool honorStyle, bool readConfig )
204#ifdef DESKTOP_VERSION 204#ifdef DESKTOP_VERSION
205 : QToolBar( QString::fromLatin1( name ), 205 : QToolBar( QString::fromLatin1( name ),
206 parent && parent->inherits( "QMainWindow" ) ? static_cast<QMainWindow*>(parent) : 0, 206 parent && parent->inherits( "QMainWindow" ) ? static_cast<QMainWindow*>(parent) : 0,
207 parent, FALSE, 207 parent, FALSE,
208 name ? name : "mainToolBar") 208 name ? name : "mainToolBar")
209#else 209#else
210 : QPEToolBar( parent && parent->inherits( "QMainWindow" ) ? static_cast<QMainWindow*>(parent) : 0, 210 : QPEToolBar( parent && parent->inherits( "QMainWindow" ) ? static_cast<QMainWindow*>(parent) : 0,
211 QString::fromLatin1( name )) 211 QString::fromLatin1( name ))
212 212
213 213
214#endif 214#endif
215{ 215{
216 init( readConfig, honorStyle ); 216 init( readConfig, honorStyle );
217} 217}
218 218
219KToolBar::KToolBar( QMainWindow *parentWindow, QMainWindow::ToolBarDock dock, bool newLine, const char *name, bool honorStyle, bool readConfig ) 219KToolBar::KToolBar( QMainWindow *parentWindow, QMainWindow::ToolBarDock dock, bool newLine, const char *name, bool honorStyle, bool readConfig )
220#ifdef DESKTOP_VERSION 220#ifdef DESKTOP_VERSION
221 : QToolBar( QString::fromLatin1( name ), 221 : QToolBar( QString::fromLatin1( name ),
222 parentWindow, dock, newLine, 222 parentWindow, dock, newLine,
223 name ? name : "mainToolBar") 223 name ? name : "mainToolBar")
224#else 224#else
225 : QPEToolBar( parentWindow,QString::fromLatin1( name )) 225 : QPEToolBar( parentWindow,QString::fromLatin1( name ))
226 226
227 227
228#endif 228#endif
229 229
230{ 230{
231 init( readConfig, honorStyle ); 231 init( readConfig, honorStyle );
232} 232}
233 233
234KToolBar::KToolBar( QMainWindow *parentWindow, QWidget *dock, bool newLine, const char *name, bool honorStyle, bool readConfig ) 234KToolBar::KToolBar( QMainWindow *parentWindow, QWidget *dock, bool newLine, const char *name, bool honorStyle, bool readConfig )
235#ifdef DESKTOP_VERSION 235#ifdef DESKTOP_VERSION
236 : QToolBar( QString::fromLatin1( name ), 236 : QToolBar( QString::fromLatin1( name ),
237 parentWindow, dock, newLine, 237 parentWindow, dock, newLine,
238 name ? name : "mainToolBar") 238 name ? name : "mainToolBar")
239#else 239#else
240 : QPEToolBar( parentWindow,QString::fromLatin1( name )) 240 : QPEToolBar( parentWindow,QString::fromLatin1( name ))
241 241
242 242
243#endif 243#endif
244 244
245{ 245{
246 init( readConfig, honorStyle ); 246 init( readConfig, honorStyle );
247} 247}
248 248
249KToolBar::~KToolBar() 249KToolBar::~KToolBar()
250{ 250{
251 inshutdownprocess = true; 251 inshutdownprocess = true;
252 emit toolbarDestroyed(); 252 emit toolbarDestroyed();
253 delete d; 253 delete d;
254} 254}
255 255
256void KToolBar::init( bool readConfig, bool honorStyle ) 256void KToolBar::init( bool readConfig, bool honorStyle )
257{ 257{
258 inshutdownprocess = false; 258 inshutdownprocess = false;
259 d = new KToolBarPrivate; 259 d = new KToolBarPrivate;
260 setFullSize( TRUE ); 260 setFullSize( TRUE );
261 d->m_honorStyle = honorStyle; 261 d->m_honorStyle = honorStyle;
262 context = 0; 262 context = 0;
263 layoutTimer = new QTimer( this ); 263 layoutTimer = new QTimer( this );
264 connect( layoutTimer, SIGNAL( timeout() ), 264 connect( layoutTimer, SIGNAL( timeout() ),
265 this, SLOT( rebuildLayout() ) ); 265 this, SLOT( rebuildLayout() ) );
266 connect( &(d->repaintTimer), SIGNAL( timeout() ), 266 connect( &(d->repaintTimer), SIGNAL( timeout() ),
267 this, SLOT( slotRepaint() ) ); 267 this, SLOT( slotRepaint() ) );
268/*US 268/*US
269 if ( kapp ) { // may be null when started inside designer 269 if ( kapp ) { // may be null when started inside designer
270 connect(kapp, SIGNAL(toolbarAppearanceChanged(int)), this, SLOT(slotAppearanceChanged())); 270 connect(kapp, SIGNAL(toolbarAppearanceChanged(int)), this, SLOT(slotAppearanceChanged()));
271 // request notification of changes in icon style 271 // request notification of changes in icon style
272 kapp->addKipcEventMask(KIPC::IconChanged); 272 kapp->addKipcEventMask(KIPC::IconChanged);
273 connect(kapp, SIGNAL(iconChanged(int)), this, SLOT(slotIconChanged(int))); 273 connect(kapp, SIGNAL(iconChanged(int)), this, SLOT(slotIconChanged(int)));
274 } 274 }
275*/ 275*/
276 // finally, read in our configurable settings 276 // finally, read in our configurable settings
277 if ( readConfig ) 277 if ( readConfig )
278 slotReadConfig(); 278 slotReadConfig();
279 279
280 if ( mainWindow() ) 280 if ( mainWindow() )
281 connect( mainWindow(), SIGNAL( toolBarPositionChanged( QToolBar * ) ), 281 connect( mainWindow(), SIGNAL( toolBarPositionChanged( QToolBar * ) ),
282 this, SLOT( toolBarPosChanged( QToolBar * ) ) ); 282 this, SLOT( toolBarPosChanged( QToolBar * ) ) );
283 283
284 // Hack to make sure we recalculate our size when we dock. 284 // Hack to make sure we recalculate our size when we dock.
285//US connect( this, SIGNAL(placeChanged(QDockWindow::Place)), SLOT(rebuildLayout()) ); 285//US connect( this, SIGNAL(placeChanged(QDockWindow::Place)), SLOT(rebuildLayout()) );
286} 286}
287 287
288int KToolBar::insertButton(const QString& icon, int id, bool enabled, 288int KToolBar::insertButton(const QString& icon, int id, bool enabled,
289 const QString& text, int index/*US, KInstance *_instance*/ ) 289 const QString& text, int index/*US, KInstance *_instance*/ )
290{ 290{
291 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text/*US, _instance*/ ); 291 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text/*US, _instance*/ );
292 292
293 insertWidgetInternal( button, index, id ); 293 insertWidgetInternal( button, index, id );
294 button->setEnabled( enabled ); 294 button->setEnabled( enabled );
295 doConnections( button ); 295 doConnections( button );
296 return index; 296 return index;
297} 297}
298 298
299 299
300int KToolBar::insertButton(const QString& icon, int id, const char *signal, 300int KToolBar::insertButton(const QString& icon, int id, const char *signal,
301 const QObject *receiver, const char *slot, 301 const QObject *receiver, const char *slot,
302 bool enabled, const QString& text, int index/*US, KInstance *_instance*/ ) 302 bool enabled, const QString& text, int index/*US, KInstance *_instance*/ )
303{ 303{
304 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text/*US, _instance*/); 304 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text/*US, _instance*/);
305 insertWidgetInternal( button, index, id ); 305 insertWidgetInternal( button, index, id );
306 button->setEnabled( enabled ); 306 button->setEnabled( enabled );
307 connect( button, signal, receiver, slot ); 307 connect( button, signal, receiver, slot );
308 doConnections( button ); 308 doConnections( button );
309 return index; 309 return index;
310} 310}
311 311
312 312
313int KToolBar::insertButton(const QPixmap& pixmap, int id, bool enabled, 313int KToolBar::insertButton(const QPixmap& pixmap, int id, bool enabled,
314 const QString& text, int index ) 314 const QString& text, int index )
315{ 315{
316 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text); 316 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text);
317 insertWidgetInternal( button, index, id ); 317 insertWidgetInternal( button, index, id );
318 button->setEnabled( enabled ); 318 button->setEnabled( enabled );
319 doConnections( button ); 319 doConnections( button );
320 return index; 320 return index;
321} 321}
322#if 0 322#if 0
323 bar->insertButton( icon, id_, SIGNAL( clicked() ), this, 323 bar->insertButton( icon, id_, SIGNAL( clicked() ), this,
324 SLOT( slotActivated() ), 324 SLOT( slotActivated() ),
325 d->isEnabled(), d->plainText(), index/*US, instance*/ ); 325 d->isEnabled(), d->plainText(), index/*US, instance*/ );
326#endif 326#endif
327 327
328int KToolBar::insertButton(const QPixmap& pixmap, int id, const char *signal, 328int KToolBar::insertButton(const QPixmap& pixmap, int id, const char *signal,
329 const QObject *receiver, const char *slot, 329 const QObject *receiver, const char *slot,
330 bool enabled, const QString& text, 330 bool enabled, const QString& text,
331 int index ) 331 int index )
332{ 332{
333 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text); 333 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text);
334 insertWidgetInternal( button, index, id ); 334 insertWidgetInternal( button, index, id );
335 button->setEnabled( enabled ); 335 button->setEnabled( enabled );
336 connect( button, signal, receiver, slot ); 336 connect( button, signal, receiver, slot );
337 doConnections( button ); 337 doConnections( button );
338 return index; 338 return index;
339} 339}
340 340
341 341
342int KToolBar::insertButton(const QString& icon, int id, QPopupMenu *popup, 342int KToolBar::insertButton(const QString& icon, int id, QPopupMenu *popup,
343 bool enabled, const QString &text, int index ) 343 bool enabled, const QString &text, int index )
344{ 344{
345 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text ); 345 KToolBarButton *button = new KToolBarButton( icon, id, this, 0, text );
346 insertWidgetInternal( button, index, id ); 346 insertWidgetInternal( button, index, id );
347 button->setEnabled( enabled ); 347 button->setEnabled( enabled );
348 button->setPopup( popup ); 348 button->setPopup( popup );
349 doConnections( button ); 349 doConnections( button );
350 return index; 350 return index;
351} 351}
352 352
353 353
354int KToolBar::insertButton(const QPixmap& pixmap, int id, QPopupMenu *popup, 354int KToolBar::insertButton(const QPixmap& pixmap, int id, QPopupMenu *popup,
355 bool enabled, const QString &text, int index ) 355 bool enabled, const QString &text, int index )
356{ 356{
357 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text ); 357 KToolBarButton *button = new KToolBarButton( pixmap, id, this, 0, text );
358 insertWidgetInternal( button, index, id ); 358 insertWidgetInternal( button, index, id );
359 button->setEnabled( enabled ); 359 button->setEnabled( enabled );
360 button->setPopup( popup ); 360 button->setPopup( popup );
361 doConnections( button ); 361 doConnections( button );
362 return index; 362 return index;
363} 363}
364 364
365 365
366int KToolBar::insertLined (const QString& text, int id, 366int KToolBar::insertLined (const QString& text, int id,
367 const char *signal, 367 const char *signal,
368 const QObject *receiver, const char *slot, 368 const QObject *receiver, const char *slot,
369 bool enabled , 369 bool enabled ,
370 const QString& toolTipText, 370 const QString& toolTipText,
371 int size, int index ) 371 int size, int index )
372{ 372{
373 KLineEdit *lined = new KLineEdit ( this, 0 ); 373 KLineEdit *lined = new KLineEdit ( this, 0 );
374 if ( !toolTipText.isEmpty() ) 374 if ( !toolTipText.isEmpty() )
375 QToolTip::add( lined, toolTipText ); 375 QToolTip::add( lined, toolTipText );
376 if ( size > 0 ) 376 if ( size > 0 )
377 lined->setMinimumWidth( size ); 377 lined->setMinimumWidth( size );
378 insertWidgetInternal( lined, index, id ); 378 insertWidgetInternal( lined, index, id );
379 connect( lined, signal, receiver, slot ); 379 connect( lined, signal, receiver, slot );
380 lined->setText(text); 380 lined->setText(text);
381 lined->setEnabled( enabled ); 381 lined->setEnabled( enabled );
382 return index; 382 return index;
383} 383}
384 384
385int KToolBar::insertCombo (const QStringList &list, int id, bool writable, 385int KToolBar::insertCombo (const QStringList &list, int id, bool writable,
386 const char *signal, const QObject *receiver, 386 const char *signal, const QObject *receiver,
387 const char *slot, bool enabled, 387 const char *slot, bool enabled,
388 const QString& tooltiptext, 388 const QString& tooltiptext,
389 int size, int index, 389 int size, int index,
390 QComboBox::Policy policy ) 390 QComboBox::Policy policy )
391{ 391{
392//US KComboBox *combo = new KComboBox ( writable, this ); 392//US KComboBox *combo = new KComboBox ( writable, this );
393 KComboBox *combo = new KComboBox ( this ); 393 KComboBox *combo = new KComboBox ( this );
394 combo->setEditable(writable); 394 combo->setEditable(writable);
395 395
396 insertWidgetInternal( combo, index, id ); 396 insertWidgetInternal( combo, index, id );
397 combo->insertStringList (list); 397 combo->insertStringList (list);
398 combo->setInsertionPolicy(policy); 398 combo->setInsertionPolicy(policy);
399 combo->setEnabled( enabled ); 399 combo->setEnabled( enabled );
400 if ( !tooltiptext.isEmpty() ) 400 if ( !tooltiptext.isEmpty() )
401 QToolTip::add( combo, tooltiptext ); 401 QToolTip::add( combo, tooltiptext );
402 if ( size > 0 ) 402 if ( size > 0 )
403 combo->setMinimumWidth( size ); 403 combo->setMinimumWidth( size );
404 if (!tooltiptext.isNull()) 404 if (!tooltiptext.isNull())
405 QToolTip::add( combo, tooltiptext ); 405 QToolTip::add( combo, tooltiptext );
406 406
407 if ( signal && receiver && slot ) 407 if ( signal && receiver && slot )
408 connect ( combo, signal, receiver, slot ); 408 connect ( combo, signal, receiver, slot );
409 return index; 409 return index;
410} 410}
411 411
412 412
413int KToolBar::insertCombo (const QString& text, int id, bool writable, 413int KToolBar::insertCombo (const QString& text, int id, bool writable,
414 const char *signal, QObject *receiver, 414 const char *signal, QObject *receiver,
415 const char *slot, bool enabled, 415 const char *slot, bool enabled,
416 const QString& tooltiptext, 416 const QString& tooltiptext,
417 int size, int index, 417 int size, int index,
418 QComboBox::Policy policy ) 418 QComboBox::Policy policy )
419{ 419{
420//US KComboBox *combo = new KComboBox ( writable, this ); 420//US KComboBox *combo = new KComboBox ( writable, this );
421 KComboBox *combo = new KComboBox ( this ); 421 KComboBox *combo = new KComboBox ( this );
422 combo->setEditable(writable); 422 combo->setEditable(writable);
423 423
424 insertWidgetInternal( combo, index, id ); 424 insertWidgetInternal( combo, index, id );
425 combo->insertItem (text); 425 combo->insertItem (text);
426 combo->setInsertionPolicy(policy); 426 combo->setInsertionPolicy(policy);
427 combo->setEnabled( enabled ); 427 combo->setEnabled( enabled );
428 if ( !tooltiptext.isEmpty() ) 428 if ( !tooltiptext.isEmpty() )
429 QToolTip::add( combo, tooltiptext ); 429 QToolTip::add( combo, tooltiptext );
430 if ( size > 0 ) 430 if ( size > 0 )
431 combo->setMinimumWidth( size ); 431 combo->setMinimumWidth( size );
432 if (!tooltiptext.isNull()) 432 if (!tooltiptext.isNull())
433 QToolTip::add( combo, tooltiptext ); 433 QToolTip::add( combo, tooltiptext );
434 connect (combo, signal, receiver, slot); 434 connect (combo, signal, receiver, slot);
435 return index; 435 return index;
436} 436}
437 437
438int KToolBar::insertSeparator(int index, int id) 438int KToolBar::insertSeparator(int index, int id)
439{ 439{
440 QWidget *w = new KToolBarSeparator( orientation(), FALSE, this, "tool bar separator" ); 440 QWidget *w = new KToolBarSeparator( orientation(), FALSE, this, "tool bar separator" );
441 insertWidgetInternal( w, index, id ); 441 insertWidgetInternal( w, index, id );
442 return index; 442 return index;
443} 443}
444 444
445int KToolBar::insertLineSeparator(int index, int id) 445int KToolBar::insertLineSeparator(int index, int id)
446{ 446{
447 QWidget *w = new KToolBarSeparator( orientation(), TRUE, this, "tool bar separator" ); 447 QWidget *w = new KToolBarSeparator( orientation(), TRUE, this, "tool bar separator" );
448 insertWidgetInternal( w, index, id ); 448 insertWidgetInternal( w, index, id );
449 return index; 449 return index;
450} 450}
451 451
452 452
453int KToolBar::insertWidget(int id, int /*width*/, QWidget *widget, int index) 453int KToolBar::insertWidget(int id, int /*width*/, QWidget *widget, int index)
454{ 454{
455 // removeWidgetInternal( widget ); // in case we already have it ? 455 // removeWidgetInternal( widget ); // in case we already have it ?
456 insertWidgetInternal( widget, index, id ); 456 insertWidgetInternal( widget, index, id );
457 return index; 457 return index;
458} 458}
459/*US 459/*US
460int KToolBar::insertAnimatedWidget(int id, QObject *receiver, const char *slot, 460int KToolBar::insertAnimatedWidget(int id, QObject *receiver, const char *slot,
461 const QString& icons, int index ) 461 const QString& icons, int index )
462{ 462{
463 KAnimWidget *anim = new KAnimWidget( icons, d->m_iconSize, this ); 463 KAnimWidget *anim = new KAnimWidget( icons, d->m_iconSize, this );
464 insertWidgetInternal( anim, index, id ); 464 insertWidgetInternal( anim, index, id );
465 465
466 if ( receiver ) 466 if ( receiver )
467 connect( anim, SIGNAL(clicked()), receiver, slot); 467 connect( anim, SIGNAL(clicked()), receiver, slot);
468 468
469 return index; 469 return index;
470} 470}
471 471
472KAnimWidget *KToolBar::animatedWidget( int id ) 472KAnimWidget *KToolBar::animatedWidget( int id )
473{ 473{
474 Id2WidgetMap::Iterator it = id2widget.find( id ); 474 Id2WidgetMap::Iterator it = id2widget.find( id );
475 if ( it == id2widget.end() ) 475 if ( it == id2widget.end() )
476 return 0; 476 return 0;
477 if ( (*it) && (*it)->inherits( "KAnimWidget" ) ) 477 if ( (*it) && (*it)->inherits( "KAnimWidget" ) )
478 return (KAnimWidget*)(*it); 478 return (KAnimWidget*)(*it);
479 QObjectList *l = queryList( "KAnimWidget" ); 479 QObjectList *l = queryList( "KAnimWidget" );
480 if ( !l || !l->first() ) { 480 if ( !l || !l->first() ) {
481 delete l; 481 delete l;
482 return 0; 482 return 0;
483 } 483 }
484 484
485 for ( QObject *o = l->first(); o; o = l->next() ) { 485 for ( QObject *o = l->first(); o; o = l->next() ) {
486 if ( o->inherits( "KAnimWidget" ) ) 486 if ( o->inherits( "KAnimWidget" ) )
487 { 487 {
488 delete l; 488 delete l;
489 return (KAnimWidget*)o; 489 return (KAnimWidget*)o;
490 } 490 }
491 } 491 }
492 492
493 delete l; 493 delete l;
494 return 0; 494 return 0;
495} 495}
496*/ 496*/
497 497
498void KToolBar::addConnection (int id, const char *signal, 498void KToolBar::addConnection (int id, const char *signal,
499 const QObject *receiver, const char *slot) 499 const QObject *receiver, const char *slot)
500{ 500{
501 Id2WidgetMap::Iterator it = id2widget.find( id ); 501 Id2WidgetMap::Iterator it = id2widget.find( id );
502 if ( it == id2widget.end() ) 502 if ( it == id2widget.end() )
503 return; 503 return;
504 if ( (*it) ) 504 if ( (*it) )
505 connect( (*it), signal, receiver, slot ); 505 connect( (*it), signal, receiver, slot );
506} 506}
507 507
508void KToolBar::setItemEnabled( int id, bool enabled ) 508void KToolBar::setItemEnabled( int id, bool enabled )
509{ 509{
510 Id2WidgetMap::Iterator it = id2widget.find( id ); 510 Id2WidgetMap::Iterator it = id2widget.find( id );
511 if ( it == id2widget.end() ) 511 if ( it == id2widget.end() )
512 return; 512 return;
513 if ( (*it) ) 513 if ( (*it) )
514 (*it)->setEnabled( enabled ); 514 (*it)->setEnabled( enabled );
515} 515}
516 516
517 517
518void KToolBar::setButtonPixmap( int id, const QPixmap& _pixmap ) 518void KToolBar::setButtonPixmap( int id, const QPixmap& _pixmap )
519{ 519{
520 Id2WidgetMap::Iterator it = id2widget.find( id ); 520 Id2WidgetMap::Iterator it = id2widget.find( id );
521 if ( it == id2widget.end() ) 521 if ( it == id2widget.end() )
522 return; 522 return;
523//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 523//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
524 KToolBarButton * button = (KToolBarButton *)( *it ); 524 KToolBarButton * button = (KToolBarButton *)( *it );
525 if ( button ) 525 if ( button )
526 button->setPixmap( _pixmap ); 526 button->setPixmap( _pixmap );
527} 527}
528 528
529 529
530void KToolBar::setButtonIcon( int id, const QString& _icon ) 530void KToolBar::setButtonIcon( int id, const QString& _icon )
531{ 531{
532 Id2WidgetMap::Iterator it = id2widget.find( id ); 532 Id2WidgetMap::Iterator it = id2widget.find( id );
533 if ( it == id2widget.end() ) 533 if ( it == id2widget.end() )
534 return; 534 return;
535//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 535//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
536 KToolBarButton * button = (KToolBarButton *)( *it ); 536 KToolBarButton * button = (KToolBarButton *)( *it );
537 if ( button ) 537 if ( button )
538 button->setIcon( _icon ); 538 button->setIcon( _icon );
539} 539}
540 540
541void KToolBar::setButtonIconSet( int id, const QIconSet& iconset ) 541void KToolBar::setButtonIconSet( int id, const QIconSet& iconset )
542{ 542{
543 Id2WidgetMap::Iterator it = id2widget.find( id ); 543 Id2WidgetMap::Iterator it = id2widget.find( id );
544 if ( it == id2widget.end() ) 544 if ( it == id2widget.end() )
545 return; 545 return;
546//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 546//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
547 KToolBarButton * button = (KToolBarButton *)( *it ); 547 KToolBarButton * button = (KToolBarButton *)( *it );
548 if ( button ) 548 if ( button )
549 button->setIconSet( iconset ); 549 button->setIconSet( iconset );
550} 550}
551 551
552 552
553void KToolBar::setDelayedPopup (int id , QPopupMenu *_popup, bool toggle ) 553void KToolBar::setDelayedPopup (int id , QPopupMenu *_popup, bool toggle )
554{ 554{
555 Id2WidgetMap::Iterator it = id2widget.find( id ); 555 Id2WidgetMap::Iterator it = id2widget.find( id );
556 if ( it == id2widget.end() ) 556 if ( it == id2widget.end() )
557 return; 557 return;
558//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 558//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
559 KToolBarButton * button = (KToolBarButton *)( *it ); 559 KToolBarButton * button = (KToolBarButton *)( *it );
560 if ( button ) 560 if ( button )
561 button->setDelayedPopup( _popup, toggle ); 561 button->setDelayedPopup( _popup, toggle );
562} 562}
563 563
564 564
565void KToolBar::setAutoRepeat (int id, bool flag) 565void KToolBar::setAutoRepeat (int id, bool flag)
566{ 566{
567 Id2WidgetMap::Iterator it = id2widget.find( id ); 567 Id2WidgetMap::Iterator it = id2widget.find( id );
568 if ( it == id2widget.end() ) 568 if ( it == id2widget.end() )
569 return; 569 return;
570//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 570//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
571 KToolBarButton * button = (KToolBarButton *)( *it ); 571 KToolBarButton * button = (KToolBarButton *)( *it );
572 if ( button ) 572 if ( button )
573 button->setAutoRepeat( flag ); 573 button->setAutoRepeat( flag );
574} 574}
575 575
576 576
577void KToolBar::setToggle (int id, bool flag ) 577void KToolBar::setToggle (int id, bool flag )
578{ 578{
579 Id2WidgetMap::Iterator it = id2widget.find( id ); 579 Id2WidgetMap::Iterator it = id2widget.find( id );
580 if ( it == id2widget.end() ) 580 if ( it == id2widget.end() )
581 return; 581 return;
582//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 582//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
583 KToolBarButton * button = (KToolBarButton *)( *it ); 583 KToolBarButton * button = (KToolBarButton *)( *it );
584 if ( button ) 584 if ( button )
585 button->setToggle( flag ); 585 button->setToggle( flag );
586} 586}
587 587
588 588
589void KToolBar::toggleButton (int id) 589void KToolBar::toggleButton (int id)
590{ 590{
591 Id2WidgetMap::Iterator it = id2widget.find( id ); 591 Id2WidgetMap::Iterator it = id2widget.find( id );
592 if ( it == id2widget.end() ) 592 if ( it == id2widget.end() )
593 return; 593 return;
594//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 594//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
595 KToolBarButton * button = (KToolBarButton *)( *it ); 595 KToolBarButton * button = (KToolBarButton *)( *it );
596 if ( button ) 596 if ( button )
597 button->toggle(); 597 button->toggle();
598} 598}
599 599
600 600
601void KToolBar::setButton (int id, bool flag) 601void KToolBar::setButton (int id, bool flag)
602{ 602{
603 Id2WidgetMap::Iterator it = id2widget.find( id ); 603 Id2WidgetMap::Iterator it = id2widget.find( id );
604 if ( it == id2widget.end() ) 604 if ( it == id2widget.end() )
605 return; 605 return;
606//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 606//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
607 KToolBarButton * button = (KToolBarButton *)( *it ); 607 KToolBarButton * button = (KToolBarButton *)( *it );
608 if ( button ) 608 if ( button )
609 button->on( flag ); 609 button->on( flag );
610} 610}
611 611
612 612
613bool KToolBar::isButtonOn (int id) const 613bool KToolBar::isButtonOn (int id) const
614{ 614{
615 Id2WidgetMap::ConstIterator it = id2widget.find( id ); 615 Id2WidgetMap::ConstIterator it = id2widget.find( id );
616 if ( it == id2widget.end() ) 616 if ( it == id2widget.end() )
617 return false; 617 return false;
618//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 618//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
619 KToolBarButton * button = (KToolBarButton *)( *it ); 619 KToolBarButton * button = (KToolBarButton *)( *it );
620 return button ? button->isOn() : false; 620 return button ? button->isOn() : false;
621} 621}
622 622
623 623
624void KToolBar::setLinedText (int id, const QString& text) 624void KToolBar::setLinedText (int id, const QString& text)
625{ 625{
626 Id2WidgetMap::Iterator it = id2widget.find( id ); 626 Id2WidgetMap::Iterator it = id2widget.find( id );
627 if ( it == id2widget.end() ) 627 if ( it == id2widget.end() )
628 return; 628 return;
629//US QLineEdit * lineEdit = dynamic_cast<QLineEdit *>( *it ); 629//US QLineEdit * lineEdit = dynamic_cast<QLineEdit *>( *it );
630 QLineEdit * lineEdit = (QLineEdit *)( *it ); 630 QLineEdit * lineEdit = (QLineEdit *)( *it );
631 if ( lineEdit ) 631 if ( lineEdit )
632 lineEdit->setText( text ); 632 lineEdit->setText( text );
633} 633}
634 634
635 635
636QString KToolBar::getLinedText (int id) const 636QString KToolBar::getLinedText (int id) const
637{ 637{
638 Id2WidgetMap::ConstIterator it = id2widget.find( id ); 638 Id2WidgetMap::ConstIterator it = id2widget.find( id );
639 if ( it == id2widget.end() ) 639 if ( it == id2widget.end() )
640 return QString::null; 640 return QString::null;
641//US QLineEdit * lineEdit = dynamic_cast<QLineEdit *>( *it ); 641//US QLineEdit * lineEdit = dynamic_cast<QLineEdit *>( *it );
642 QLineEdit * lineEdit = (QLineEdit *)( *it ); 642 QLineEdit * lineEdit = (QLineEdit *)( *it );
643 return lineEdit ? lineEdit->text() : QString::null; 643 return lineEdit ? lineEdit->text() : QString::null;
644} 644}
645 645
646 646
647void KToolBar::insertComboItem (int id, const QString& text, int index) 647void KToolBar::insertComboItem (int id, const QString& text, int index)
648{ 648{
649 Id2WidgetMap::Iterator it = id2widget.find( id ); 649 Id2WidgetMap::Iterator it = id2widget.find( id );
650 if ( it == id2widget.end() ) 650 if ( it == id2widget.end() )
651 return; 651 return;
652//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 652//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
653 QComboBox * comboBox = (QComboBox *)( *it ); 653 QComboBox * comboBox = (QComboBox *)( *it );
654 if (comboBox) 654 if (comboBox)
655 comboBox->insertItem( text, index ); 655 comboBox->insertItem( text, index );
656} 656}
657 657
658void KToolBar::insertComboList (int id, const QStringList &list, int index) 658void KToolBar::insertComboList (int id, const QStringList &list, int index)
659{ 659{
660 Id2WidgetMap::Iterator it = id2widget.find( id ); 660 Id2WidgetMap::Iterator it = id2widget.find( id );
661 if ( it == id2widget.end() ) 661 if ( it == id2widget.end() )
662 return; 662 return;
663//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 663//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
664 QComboBox * comboBox = (QComboBox *)( *it ); 664 QComboBox * comboBox = (QComboBox *)( *it );
665 if (comboBox) 665 if (comboBox)
666 comboBox->insertStringList( list, index ); 666 comboBox->insertStringList( list, index );
667} 667}
668 668
669 669
670void KToolBar::removeComboItem (int id, int index) 670void KToolBar::removeComboItem (int id, int index)
671{ 671{
672 Id2WidgetMap::Iterator it = id2widget.find( id ); 672 Id2WidgetMap::Iterator it = id2widget.find( id );
673 if ( it == id2widget.end() ) 673 if ( it == id2widget.end() )
674 return; 674 return;
675//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 675//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
676 QComboBox * comboBox = (QComboBox *)( *it ); 676 QComboBox * comboBox = (QComboBox *)( *it );
677 if (comboBox) 677 if (comboBox)
678 comboBox->removeItem( index ); 678 comboBox->removeItem( index );
679} 679}
680 680
681 681
682void KToolBar::setCurrentComboItem (int id, int index) 682void KToolBar::setCurrentComboItem (int id, int index)
683{ 683{
684 Id2WidgetMap::Iterator it = id2widget.find( id ); 684 Id2WidgetMap::Iterator it = id2widget.find( id );
685 if ( it == id2widget.end() ) 685 if ( it == id2widget.end() )
686 return; 686 return;
687//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 687//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
688 QComboBox * comboBox = (QComboBox *)( *it ); 688 QComboBox * comboBox = (QComboBox *)( *it );
689 if (comboBox) 689 if (comboBox)
690 comboBox->setCurrentItem( index ); 690 comboBox->setCurrentItem( index );
691} 691}
692 692
693 693
694void KToolBar::changeComboItem (int id, const QString& text, int index) 694void KToolBar::changeComboItem (int id, const QString& text, int index)
695{ 695{
696 Id2WidgetMap::Iterator it = id2widget.find( id ); 696 Id2WidgetMap::Iterator it = id2widget.find( id );
697 if ( it == id2widget.end() ) 697 if ( it == id2widget.end() )
698 return; 698 return;
699//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 699//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
700 QComboBox * comboBox = (QComboBox *)( *it ); 700 QComboBox * comboBox = (QComboBox *)( *it );
701 if (comboBox) 701 if (comboBox)
702 comboBox->changeItem( text, index ); 702 comboBox->changeItem( text, index );
703} 703}
704 704
705 705
706void KToolBar::clearCombo (int id) 706void KToolBar::clearCombo (int id)
707{ 707{
708 Id2WidgetMap::Iterator it = id2widget.find( id ); 708 Id2WidgetMap::Iterator it = id2widget.find( id );
709 if ( it == id2widget.end() ) 709 if ( it == id2widget.end() )
710 return; 710 return;
711//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 711//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
712 QComboBox * comboBox = (QComboBox *)( *it ); 712 QComboBox * comboBox = (QComboBox *)( *it );
713 if (comboBox) 713 if (comboBox)
714 comboBox->clear(); 714 comboBox->clear();
715} 715}
716 716
717 717
718QString KToolBar::getComboItem (int id, int index) const 718QString KToolBar::getComboItem (int id, int index) const
719{ 719{
720 Id2WidgetMap::ConstIterator it = id2widget.find( id ); 720 Id2WidgetMap::ConstIterator it = id2widget.find( id );
721 if ( it == id2widget.end() ) 721 if ( it == id2widget.end() )
722 return QString::null; 722 return QString::null;
723//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it ); 723//US QComboBox * comboBox = dynamic_cast<QComboBox *>( *it );
724 QComboBox * comboBox = (QComboBox *)( *it ); 724 QComboBox * comboBox = (QComboBox *)( *it );
725 return comboBox ? comboBox->text( index ) : QString::null; 725 return comboBox ? comboBox->text( index ) : QString::null;
726} 726}
727 727
728 728
729KComboBox * KToolBar::getCombo(int id) 729KComboBox * KToolBar::getCombo(int id)
730{ 730{
731 Id2WidgetMap::Iterator it = id2widget.find( id ); 731 Id2WidgetMap::Iterator it = id2widget.find( id );
732 if ( it == id2widget.end() ) 732 if ( it == id2widget.end() )
733 return 0; 733 return 0;
734//US return dynamic_cast<KComboBox *>( *it ); 734//US return dynamic_cast<KComboBox *>( *it );
735 return (KComboBox *)( *it ); 735 return (KComboBox *)( *it );
736} 736}
737 737
738 738
739KLineEdit * KToolBar::getLined (int id) 739KLineEdit * KToolBar::getLined (int id)
740{ 740{
741 Id2WidgetMap::Iterator it = id2widget.find( id ); 741 Id2WidgetMap::Iterator it = id2widget.find( id );
742 if ( it == id2widget.end() ) 742 if ( it == id2widget.end() )
743 return 0; 743 return 0;
744//US return dynamic_cast<KLineEdit *>( *it ); 744//US return dynamic_cast<KLineEdit *>( *it );
745 return (KLineEdit *)( *it ); 745 return (KLineEdit *)( *it );
746} 746}
747 747
748 748
749KToolBarButton * KToolBar::getButton (int id) 749KToolBarButton * KToolBar::getButton (int id)
750{ 750{
751 Id2WidgetMap::Iterator it = id2widget.find( id ); 751 Id2WidgetMap::Iterator it = id2widget.find( id );
752 if ( it == id2widget.end() ) 752 if ( it == id2widget.end() )
753 return 0; 753 return 0;
754//US return dynamic_cast<KToolBarButton *>( *it ); 754//US return dynamic_cast<KToolBarButton *>( *it );
755 return (KToolBarButton *)( *it ); 755 return (KToolBarButton *)( *it );
756} 756}
757 757
758 758
759void KToolBar::alignItemRight (int id, bool right ) 759void KToolBar::alignItemRight (int id, bool right )
760{ 760{
761 Id2WidgetMap::Iterator it = id2widget.find( id ); 761 Id2WidgetMap::Iterator it = id2widget.find( id );
762 if ( it == id2widget.end() ) 762 if ( it == id2widget.end() )
763 return; 763 return;
764 if ( rightAligned && !right && (*it) == rightAligned ) 764 if ( rightAligned && !right && (*it) == rightAligned )
765 rightAligned = 0; 765 rightAligned = 0;
766 if ( (*it) && right ) 766 if ( (*it) && right )
767 rightAligned = (*it); 767 rightAligned = (*it);
768} 768}
769 769
770 770
771QWidget *KToolBar::getWidget (int id) 771QWidget *KToolBar::getWidget (int id)
772{ 772{
773 Id2WidgetMap::Iterator it = id2widget.find( id ); 773 Id2WidgetMap::Iterator it = id2widget.find( id );
774 return ( it == id2widget.end() ) ? 0 : (*it); 774 return ( it == id2widget.end() ) ? 0 : (*it);
775} 775}
776 776
777 777
778void KToolBar::setItemAutoSized (int id, bool yes ) 778void KToolBar::setItemAutoSized (int id, bool yes )
779{ 779{
780 QWidget *w = getWidget(id); 780 QWidget *w = getWidget(id);
781 if ( w && yes ) 781 if ( w && yes )
782 setStretchableWidget( w ); 782 setStretchableWidget( w );
783} 783}
784 784
785 785
786void KToolBar::clear () 786void KToolBar::clear ()
787{ 787{
788 QToolBar::clear(); 788 QToolBar::clear();
789 widget2id.clear(); 789 widget2id.clear();
790 id2widget.clear(); 790 id2widget.clear();
791} 791}
792 792
793 793
794void KToolBar::removeItem(int id) 794void KToolBar::removeItem(int id)
795{ 795{
796 Id2WidgetMap::Iterator it = id2widget.find( id ); 796 Id2WidgetMap::Iterator it = id2widget.find( id );
797 if ( it == id2widget.end() ) 797 if ( it == id2widget.end() )
798 { 798 {
799 kdDebug(220) << "KToolBar::removeItem item " << id << " not found" << endl; 799 kdDebug(220) << "KToolBar::removeItem item " << id << " not found" << endl;
800 return; 800 return;
801 } 801 }
802 QWidget * w = (*it); 802 QWidget * w = (*it);
803 id2widget.remove( id ); 803 id2widget.remove( id );
804 widget2id.remove( w ); 804 widget2id.remove( w );
805 widgets.removeRef( w ); 805 widgets.removeRef( w );
806 delete w; 806 delete w;
807} 807}
808 808
809 809
810void KToolBar::removeItemDelayed(int id) 810void KToolBar::removeItemDelayed(int id)
811{ 811{
812 Id2WidgetMap::Iterator it = id2widget.find( id ); 812 Id2WidgetMap::Iterator it = id2widget.find( id );
813 if ( it == id2widget.end() ) 813 if ( it == id2widget.end() )
814 { 814 {
815 kdDebug(220) << "KToolBar::removeItem item " << id << " not found" << endl; 815 kdDebug(220) << "KToolBar::removeItem item " << id << " not found" << endl;
816 return; 816 return;
817 } 817 }
818 QWidget * w = (*it); 818 QWidget * w = (*it);
819 id2widget.remove( id ); 819 id2widget.remove( id );
820 widget2id.remove( w ); 820 widget2id.remove( w );
821 widgets.removeRef( w ); 821 widgets.removeRef( w );
822 822
823 w->blockSignals(true); 823 w->blockSignals(true);
824 d->idleButtons.append(w); 824 d->idleButtons.append(w);
825 layoutTimer->start( 50, TRUE ); 825 layoutTimer->start( 50, TRUE );
826} 826}
827 827
828 828
829void KToolBar::hideItem (int id) 829void KToolBar::hideItem (int id)
830{ 830{
831 QWidget *w = getWidget(id); 831 QWidget *w = getWidget(id);
832 if ( w ) 832 if ( w )
833 w->hide(); 833 w->hide();
834} 834}
835 835
836 836
837void KToolBar::showItem (int id) 837void KToolBar::showItem (int id)
838{ 838{
839 QWidget *w = getWidget(id); 839 QWidget *w = getWidget(id);
840 if ( w ) 840 if ( w )
841 w->show(); 841 w->show();
842} 842}
843 843
844 844
845int KToolBar::itemIndex (int id) 845int KToolBar::itemIndex (int id)
846{ 846{
847 QWidget *w = getWidget(id); 847 QWidget *w = getWidget(id);
848 return w ? widgets.findRef(w) : -1; 848 return w ? widgets.findRef(w) : -1;
849} 849}
850 850
851 851
852void KToolBar::setFullSize(bool flag ) 852void KToolBar::setFullSize(bool flag )
853{ 853{
854 setHorizontalStretchable( flag ); 854 setHorizontalStretchable( flag );
855 setVerticalStretchable( flag ); 855 setVerticalStretchable( flag );
856} 856}
857 857
858 858
859bool KToolBar::fullSize() const 859bool KToolBar::fullSize() const
860{ 860{
861 return isHorizontalStretchable() || isVerticalStretchable(); 861 return isHorizontalStretchable() || isVerticalStretchable();
862} 862}
863 863
864 864
865void KToolBar::enableMoving(bool flag ) 865void KToolBar::enableMoving(bool flag )
866{ 866{
867//US setMovingEnabled(flag); 867//US setMovingEnabled(flag);
868 this->mainWindow()->setToolBarsMovable(flag); 868 this->mainWindow()->setToolBarsMovable(flag);
869} 869}
870 870
871 871
872void KToolBar::setBarPos (BarPosition bpos) 872void KToolBar::setBarPos (BarPosition bpos)
873{ 873{
874 if ( !mainWindow() ) 874 if ( !mainWindow() )
875 return; 875 return;
876//US mainWindow()->moveDockWindow( this, (Dock)bpos ); 876//US mainWindow()->moveDockWindow( this, (Dock)bpos );
877 mainWindow()->moveToolBar( this, (QMainWindow::ToolBarDock)bpos ); 877 mainWindow()->moveToolBar( this, (QMainWindow::ToolBarDock)bpos );
878} 878}
879 879
880 880
881const KToolBar::BarPosition KToolBar::barPos() 881const KToolBar::BarPosition KToolBar::barPos()
882{ 882{
883 if ( !(QMainWindow*)mainWindow() ) 883 if ( !(QMainWindow*)mainWindow() )
884 return KToolBar::Top; 884 return KToolBar::Top;
885//US Dock dock; 885//US Dock dock;
886 QMainWindow::ToolBarDock dock; 886 QMainWindow::ToolBarDock dock;
887 int dm1, dm2; 887 int dm1, dm2;
888 bool dm3; 888 bool dm3;
889 ((QMainWindow*)mainWindow())->getLocation( (QToolBar*)this, dock, dm1, dm3, dm2 ); 889 ((QMainWindow*)mainWindow())->getLocation( (QToolBar*)this, dock, dm1, dm3, dm2 );
890//US if ( dock == DockUnmanaged ) { 890//US if ( dock == DockUnmanaged ) {
891 if ( dock == QMainWindow::Unmanaged ) { 891 if ( dock == QMainWindow::Unmanaged ) {
892 return (KToolBar::BarPosition)Top; 892 return (KToolBar::BarPosition)Top;
893 } 893 }
894 return (BarPosition)dock; 894 return (BarPosition)dock;
895} 895}
896 896
897 897
898bool KToolBar::enable(BarStatus stat) 898bool KToolBar::enable(BarStatus stat)
899{ 899{
900 bool mystat = isVisible(); 900 bool mystat = isVisible();
901 901
902 if ( (stat == Toggle && mystat) || stat == Hide ) 902 if ( (stat == Toggle && mystat) || stat == Hide )
903 hide(); 903 hide();
904 else 904 else
905 show(); 905 show();
906 906
907 return isVisible() == mystat; 907 return isVisible() == mystat;
908} 908}
909 909
910 910
911void KToolBar::setMaxHeight ( int h ) 911void KToolBar::setMaxHeight ( int h )
912{ 912{
913 setMaximumHeight( h ); 913 setMaximumHeight( h );
914} 914}
915 915
916int KToolBar::maxHeight() 916int KToolBar::maxHeight()
917{ 917{
918 return maximumHeight(); 918 return maximumHeight();
919} 919}
920 920
921 921
922void KToolBar::setMaxWidth (int dw) 922void KToolBar::setMaxWidth (int dw)
923{ 923{
924 setMaximumWidth( dw ); 924 setMaximumWidth( dw );
925} 925}
926 926
927 927
928int KToolBar::maxWidth() 928int KToolBar::maxWidth()
929{ 929{
930 return maximumWidth(); 930 return maximumWidth();
931} 931}
932 932
933 933
934void KToolBar::setTitle (const QString& _title) 934void KToolBar::setTitle (const QString& _title)
935{ 935{
936 setLabel( _title ); 936 setLabel( _title );
937} 937}
938 938
939 939
940void KToolBar::enableFloating (bool ) 940void KToolBar::enableFloating (bool )
941{ 941{
942} 942}
943 943
944 944
945void KToolBar::setIconText(IconText it) 945void KToolBar::setIconText(IconText it)
946{ 946{
947 setIconText( it, true ); 947 setIconText( it, true );
948} 948}
949 949
950 950
951void KToolBar::setIconText(IconText icontext, bool update) 951void KToolBar::setIconText(IconText icontext, bool update)
952{ 952{
953 bool doUpdate=false; 953 bool doUpdate=false;
954 954
955 if (icontext != d->m_iconText) { 955 if (icontext != d->m_iconText) {
956 d->m_iconText = icontext; 956 d->m_iconText = icontext;
957 doUpdate=true; 957 doUpdate=true;
958 } 958 }
959 959
960 if (update == false) 960 if (update == false)
961 return; 961 return;
962 962
963 if (doUpdate) 963 if (doUpdate)
964 emit modechange(); // tell buttons what happened 964 emit modechange(); // tell buttons what happened
965 965
966 // ugly hack to force a QMainWindow::triggerLayout( TRUE ) 966 // ugly hack to force a QMainWindow::triggerLayout( TRUE )
967 if ( mainWindow() ) { 967 if ( mainWindow() ) {
968 QMainWindow *mw = mainWindow(); 968 QMainWindow *mw = mainWindow();
969 mw->setUpdatesEnabled( FALSE ); 969 mw->setUpdatesEnabled( FALSE );
970 mw->setToolBarsMovable( !mw->toolBarsMovable() ); 970 mw->setToolBarsMovable( !mw->toolBarsMovable() );
971 mw->setToolBarsMovable( !mw->toolBarsMovable() ); 971 mw->setToolBarsMovable( !mw->toolBarsMovable() );
972 mw->setUpdatesEnabled( TRUE ); 972 mw->setUpdatesEnabled( TRUE );
973 } 973 }
974} 974}
975 975
976 976
977KToolBar::IconText KToolBar::iconText() const 977KToolBar::IconText KToolBar::iconText() const
978{ 978{
979 return d->m_iconText; 979 return d->m_iconText;
980} 980}
981 981
982 982
983void KToolBar::setIconSize(int size) 983void KToolBar::setIconSize(int size)
984{ 984{
985 setIconSize( size, true ); 985 setIconSize( size, true );
986} 986}
987 987
988void KToolBar::setIconSize(int size, bool update) 988void KToolBar::setIconSize(int size, bool update)
989{ 989{
990 bool doUpdate=false; 990 bool doUpdate=false;
991 991
992 if ( size != d->m_iconSize ) { 992 if ( size != d->m_iconSize ) {
993 d->m_iconSize = size; 993 d->m_iconSize = size;
994 doUpdate=true; 994 doUpdate=true;
995 } 995 }
996 996
997 if (update == false) 997 if (update == false)
998 return; 998 return;
999 999
1000 if (doUpdate) 1000 if (doUpdate)
1001 emit modechange(); // tell buttons what happened 1001 emit modechange(); // tell buttons what happened
1002 1002
1003 // ugly hack to force a QMainWindow::triggerLayout( TRUE ) 1003 // ugly hack to force a QMainWindow::triggerLayout( TRUE )
1004 if ( mainWindow() ) { 1004 if ( mainWindow() ) {
1005 QMainWindow *mw = mainWindow(); 1005 QMainWindow *mw = mainWindow();
1006 mw->setUpdatesEnabled( FALSE ); 1006 mw->setUpdatesEnabled( FALSE );
1007 mw->setToolBarsMovable( !mw->toolBarsMovable() ); 1007 mw->setToolBarsMovable( !mw->toolBarsMovable() );
1008 mw->setToolBarsMovable( !mw->toolBarsMovable() ); 1008 mw->setToolBarsMovable( !mw->toolBarsMovable() );
1009 mw->setUpdatesEnabled( TRUE ); 1009 mw->setUpdatesEnabled( TRUE );
1010 } 1010 }
1011} 1011}
1012 1012
1013 1013
1014int KToolBar::iconSize() const 1014int KToolBar::iconSize() const
1015{ 1015{
1016/*US 1016/*US
1017 if ( !d->m_iconSize ) // default value? 1017 if ( !d->m_iconSize ) // default value?
1018 { 1018 {
1019 if (!::qstrcmp(QObject::name(), "mainToolBar")) 1019 if (!::qstrcmp(QObject::name(), "mainToolBar"))
1020 return KGlobal::iconLoader()->currentSize(KIcon::MainToolbar); 1020 return KGlobal::iconLoader()->currentSize(KIcon::MainToolbar);
1021 else 1021 else
1022 return KGlobal::iconLoader()->currentSize(KIcon::Toolbar); 1022 return KGlobal::iconLoader()->currentSize(KIcon::Toolbar);
1023 } 1023 }
1024 return d->m_iconSize; 1024 return d->m_iconSize;
1025*/ 1025*/
1026 int ret = 18; 1026 int ret = 18;
1027 if ( QApplication::desktop()->width() > 320 ) 1027 if ( QApplication::desktop()->width() > 320 )
1028 ret = 30; 1028 ret = 30;
1029 return ret; 1029 return ret;
1030} 1030}
1031 1031
1032 1032
1033void KToolBar::setEnableContextMenu(bool enable ) 1033void KToolBar::setEnableContextMenu(bool enable )
1034{ 1034{
1035 d->m_enableContext = enable; 1035 d->m_enableContext = enable;
1036} 1036}
1037 1037
1038 1038
1039bool KToolBar::contextMenuEnabled() const 1039bool KToolBar::contextMenuEnabled() const
1040{ 1040{
1041 return d->m_enableContext; 1041 return d->m_enableContext;
1042} 1042}
1043 1043
1044 1044
1045void KToolBar::setItemNoStyle(int id, bool no_style ) 1045void KToolBar::setItemNoStyle(int id, bool no_style )
1046{ 1046{
1047 Id2WidgetMap::Iterator it = id2widget.find( id ); 1047 Id2WidgetMap::Iterator it = id2widget.find( id );
1048 if ( it == id2widget.end() ) 1048 if ( it == id2widget.end() )
1049 return; 1049 return;
1050//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it ); 1050//US KToolBarButton * button = dynamic_cast<KToolBarButton *>( *it );
1051 KToolBarButton * button = (KToolBarButton *)( *it ); 1051 KToolBarButton * button = (KToolBarButton *)( *it );
1052 if (button) 1052 if (button)
1053 button->setNoStyle( no_style ); 1053 button->setNoStyle( no_style );
1054} 1054}
1055 1055
1056 1056
1057void KToolBar::setFlat (bool flag) 1057void KToolBar::setFlat (bool flag)
1058{ 1058{
1059 if ( !mainWindow() ) 1059 if ( !mainWindow() )
1060 return; 1060 return;
1061 if ( flag ) 1061 if ( flag )
1062//US mainWindow()->moveDockWindow( this, DockMinimized ); 1062//US mainWindow()->moveDockWindow( this, DockMinimized );
1063 mainWindow()->moveToolBar( this, QMainWindow::Minimized ); 1063 mainWindow()->moveToolBar( this, QMainWindow::Minimized );
1064 else 1064 else
1065//US mainWindow()->moveDockWindow( this, DockTop ); 1065//US mainWindow()->moveDockWindow( this, DockTop );
1066 mainWindow()->moveToolBar( this, QMainWindow::Top ); 1066 mainWindow()->moveToolBar( this, QMainWindow::Top );
1067 // And remember to save the new look later 1067 // And remember to save the new look later
1068/*US 1068/*US
1069 if ( mainWindow()->inherits( "KMainWindow" ) ) 1069 if ( mainWindow()->inherits( "KMainWindow" ) )
1070 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty(); 1070 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty();
1071*/ 1071*/
1072} 1072}
1073 1073
1074 1074
1075int KToolBar::count() const 1075int KToolBar::count() const
1076{ 1076{
1077 return id2widget.count(); 1077 return id2widget.count();
1078} 1078}
1079 1079
1080 1080
1081void KToolBar::saveState() 1081void KToolBar::saveState()
1082{ 1082{
1083/*US 1083/*US
1084 // first, try to save to the xml file 1084 // first, try to save to the xml file
1085 if ( d->m_xmlguiClient && !d->m_xmlguiClient->xmlFile().isEmpty() ) { 1085 if ( d->m_xmlguiClient && !d->m_xmlguiClient->xmlFile().isEmpty() ) {
1086 // go down one level to get to the right tags 1086 // go down one level to get to the right tags
1087 QDomElement elem = d->m_xmlguiClient->domDocument().documentElement().toElement(); 1087 QDomElement elem = d->m_xmlguiClient->domDocument().documentElement().toElement();
1088 elem = elem.firstChild().toElement(); 1088 elem = elem.firstChild().toElement();
1089 QString barname(!::qstrcmp(name(), "unnamed") ? "mainToolBar" : name()); 1089 QString barname(!::qstrcmp(name(), "unnamed") ? "mainToolBar" : name());
1090 QDomElement current; 1090 QDomElement current;
1091 // now try to find our toolbar 1091 // now try to find our toolbar
1092 d->modified = false; 1092 d->modified = false;
1093 for( ; !elem.isNull(); elem = elem.nextSibling().toElement() ) { 1093 for( ; !elem.isNull(); elem = elem.nextSibling().toElement() ) {
1094 current = elem; 1094 current = elem;
1095 1095
1096 if ( current.tagName().lower() != "toolbar" ) 1096 if ( current.tagName().lower() != "toolbar" )
1097 continue; 1097 continue;
1098 1098
1099 QString curname(current.attribute( "name" )); 1099 QString curname(current.attribute( "name" ));
1100 1100
1101 if ( curname == barname ) { 1101 if ( curname == barname ) {
1102 saveState( current ); 1102 saveState( current );
1103 break; 1103 break;
1104 } 1104 }
1105 } 1105 }
1106 // if we didn't make changes, then just return 1106 // if we didn't make changes, then just return
1107 if ( !d->modified ) 1107 if ( !d->modified )
1108 return; 1108 return;
1109 1109
1110 // now we load in the (non-merged) local file 1110 // now we load in the (non-merged) local file
1111 QString local_xml(KXMLGUIFactory::readConfigFile(d->m_xmlguiClient->xmlFile(), true, d->m_xmlguiClient->instance())); 1111 QString local_xml(KXMLGUIFactory::readConfigFile(d->m_xmlguiClient->xmlFile(), true, d->m_xmlguiClient->instance()));
1112 QDomDocument local; 1112 QDomDocument local;
1113 local.setContent(local_xml); 1113 local.setContent(local_xml);
1114 1114
1115 // make sure we don't append if this toolbar already exists locally 1115 // make sure we don't append if this toolbar already exists locally
1116 bool just_append = true; 1116 bool just_append = true;
1117 elem = local.documentElement().toElement(); 1117 elem = local.documentElement().toElement();
1118 KXMLGUIFactory::removeDOMComments( elem ); 1118 KXMLGUIFactory::removeDOMComments( elem );
1119 elem = elem.firstChild().toElement(); 1119 elem = elem.firstChild().toElement();
1120 for( ; !elem.isNull(); elem = elem.nextSibling().toElement() ) { 1120 for( ; !elem.isNull(); elem = elem.nextSibling().toElement() ) {
1121 if ( elem.tagName().lower() != "toolbar" ) 1121 if ( elem.tagName().lower() != "toolbar" )
1122 continue; 1122 continue;
1123 1123
1124 QString curname(elem.attribute( "name" )); 1124 QString curname(elem.attribute( "name" ));
1125 1125
1126 if ( curname == barname ) { 1126 if ( curname == barname ) {
1127 just_append = false; 1127 just_append = false;
1128 local.documentElement().replaceChild( current, elem ); 1128 local.documentElement().replaceChild( current, elem );
1129 break; 1129 break;
1130 } 1130 }
1131 } 1131 }
1132 1132
1133 if (just_append) 1133 if (just_append)
1134 local.documentElement().appendChild( current ); 1134 local.documentElement().appendChild( current );
1135 1135
1136 KXMLGUIFactory::saveConfigFile(local, d->m_xmlguiClient->localXMLFile(), d->m_xmlguiClient->instance() ); 1136 KXMLGUIFactory::saveConfigFile(local, d->m_xmlguiClient->localXMLFile(), d->m_xmlguiClient->instance() );
1137 1137
1138 return; 1138 return;
1139 } 1139 }
1140*/ 1140*/
1141 // if that didn't work, we save to the config file 1141 // if that didn't work, we save to the config file
1142 KConfig *config = KGlobal::config(); 1142 KConfig *config = KGlobal::config();
1143 saveSettings(config, QString::null); 1143 saveSettings(config, QString::null);
1144 config->sync(); 1144 config->sync();
1145} 1145}
1146 1146
1147QString KToolBar::settingsGroup() 1147QString KToolBar::settingsGroup()
1148{ 1148{
1149 QString configGroup; 1149 QString configGroup;
1150 if (!::qstrcmp(name(), "unnamed") || !::qstrcmp(name(), "mainToolBar")) 1150 if (!::qstrcmp(name(), "unnamed") || !::qstrcmp(name(), "mainToolBar"))
1151 configGroup = "Toolbar style"; 1151 configGroup = "Toolbar style";
1152 else 1152 else
1153 configGroup = QString(name()) + " Toolbar style"; 1153 configGroup = QString(name()) + " Toolbar style";
1154 if ( this->mainWindow() ) 1154 if ( this->mainWindow() )
1155 { 1155 {
1156 configGroup.prepend(" "); 1156 configGroup.prepend(" ");
1157 configGroup.prepend( this->mainWindow()->name() ); 1157 configGroup.prepend( this->mainWindow()->name() );
1158 } 1158 }
1159 return configGroup; 1159 return configGroup;
1160} 1160}
1161 1161
1162void KToolBar::saveSettings(KConfig *config, const QString &_configGroup) 1162void KToolBar::saveSettings(KConfig *config, const QString &_configGroup)
1163{ 1163{
1164 return;
1164 QString configGroup = _configGroup; 1165 QString configGroup = _configGroup;
1165 if (configGroup.isEmpty()) 1166 if (configGroup.isEmpty())
1166 configGroup = settingsGroup(); 1167 configGroup = settingsGroup();
1167 //kdDebug(220) << "KToolBar::saveSettings group=" << _configGroup << " -> " << configGroup << endl; 1168 //kdDebug(220) << "KToolBar::saveSettings group=" << _configGroup << " -> " << configGroup << endl;
1168 1169
1169 QString position, icontext; 1170 QString position, icontext;
1170 int index; 1171 int index;
1171 getAttributes( position, icontext, index ); 1172 getAttributes( position, icontext, index );
1172 1173
1173 //kdDebug(220) << "KToolBar::saveSettings " << name() << " newLine=" << newLine << endl; 1174 //kdDebug(220) << "KToolBar::saveSettings " << name() << " newLine=" << newLine << endl;
1174 1175
1175 KConfigGroupSaver saver(config, configGroup); 1176 KConfigGroupSaver saver(config, configGroup);
1176 1177
1177 if ( position != d->PositionDefault ) 1178 if ( position != d->PositionDefault )
1178 config->writeEntry("Position", position); 1179 config->writeEntry("Position", position);
1179 else 1180 else
1180 config->deleteEntry("Position"); 1181 config->deleteEntry("Position");
1181 1182
1182 if ( icontext != d->IconTextDefault ) 1183 if ( icontext != d->IconTextDefault )
1183 config->writeEntry("IconText", icontext); 1184 config->writeEntry("IconText", icontext);
1184 else 1185 else
1185 config->deleteEntry("IconText"); 1186 config->deleteEntry("IconText");
1186 1187
1187 if ( iconSize() != d->IconSizeDefault ) 1188 if ( iconSize() != d->IconSizeDefault )
1188 config->writeEntry("IconSize", iconSize()); 1189 config->writeEntry("IconSize", iconSize());
1189 else 1190 else
1190 config->deleteEntry("IconSize"); 1191 config->deleteEntry("IconSize");
1191 1192
1192 if ( isHidden() != d->HiddenDefault ) 1193 if ( isHidden() != d->HiddenDefault )
1193 config->writeEntry("Hidden", isHidden()); 1194 config->writeEntry("Hidden", isHidden());
1194 else 1195 else
1195 config->deleteEntry("Hidden"); 1196 config->deleteEntry("Hidden");
1196 1197
1197 if ( index != d->IndexDefault ) 1198 if ( index != d->IndexDefault )
1198 config->writeEntry( "Index", index ); 1199 config->writeEntry( "Index", index );
1199 else 1200 else
1200 config->deleteEntry("Index"); 1201 config->deleteEntry("Index");
1201//US the older version of KDE (used on the Zaurus) has no Offset property 1202//US the older version of KDE (used on the Zaurus) has no Offset property
1202/* if ( offset() != d->OffsetDefault ) 1203/* if ( offset() != d->OffsetDefault )
1203 config->writeEntry( "Offset", offset() ); 1204 config->writeEntry( "Offset", offset() );
1204 else 1205 else
1205*/ 1206*/
1206 config->deleteEntry("Offset"); 1207 config->deleteEntry("Offset");
1207 1208
1208//US the older version of KDE (used on the Zaurus) has no NewLine property 1209//US the older version of KDE (used on the Zaurus) has no NewLine property
1209/* 1210/*
1210 if ( newLine() != d->NewLineDefault ) 1211 if ( newLine() != d->NewLineDefault )
1211 config->writeEntry( "NewLine", newLine() ); 1212 config->writeEntry( "NewLine", newLine() );
1212 else 1213 else
1213*/ 1214*/
1214 config->deleteEntry("NewLine"); 1215 config->deleteEntry("NewLine");
1215} 1216}
1216 1217
1217void KToolBar::setXMLGUIClient( KXMLGUIClient *client ) 1218void KToolBar::setXMLGUIClient( KXMLGUIClient *client )
1218{ 1219{
1219 d->m_xmlguiClient = client; 1220 d->m_xmlguiClient = client;
1220} 1221}
1221 1222
1222void KToolBar::setText( const QString & txt ) 1223void KToolBar::setText( const QString & txt )
1223{ 1224{
1224//US setLabel( txt + " ( " + kapp->caption() + " ) " ); 1225//US setLabel( txt + " ( " + kapp->caption() + " ) " );
1225 setLabel( txt + " ( " + KGlobal::getAppName() + " ) " ); 1226 setLabel( txt + " ( " + KGlobal::getAppName() + " ) " );
1226} 1227}
1227 1228
1228 1229
1229QString KToolBar::text() const 1230QString KToolBar::text() const
1230{ 1231{
1231 return label(); 1232 return label();
1232} 1233}
1233 1234
1234 1235
1235void KToolBar::doConnections( KToolBarButton *button ) 1236void KToolBar::doConnections( KToolBarButton *button )
1236{ 1237{
1237 connect(button, SIGNAL(clicked(int)), this, SIGNAL( clicked( int ) ) ); 1238 connect(button, SIGNAL(clicked(int)), this, SIGNAL( clicked( int ) ) );
1238 connect(button, SIGNAL(doubleClicked(int)), this, SIGNAL( doubleClicked( int ) ) ); 1239 connect(button, SIGNAL(doubleClicked(int)), this, SIGNAL( doubleClicked( int ) ) );
1239 connect(button, SIGNAL(released(int)), this, SIGNAL( released( int ) ) ); 1240 connect(button, SIGNAL(released(int)), this, SIGNAL( released( int ) ) );
1240 connect(button, SIGNAL(pressed(int)), this, SIGNAL( pressed( int ) ) ); 1241 connect(button, SIGNAL(pressed(int)), this, SIGNAL( pressed( int ) ) );
1241 connect(button, SIGNAL(toggled(int)), this, SIGNAL( toggled( int ) ) ); 1242 connect(button, SIGNAL(toggled(int)), this, SIGNAL( toggled( int ) ) );
1242 connect(button, SIGNAL(highlighted(int, bool)), this, SIGNAL( highlighted( int, bool ) ) ); 1243 connect(button, SIGNAL(highlighted(int, bool)), this, SIGNAL( highlighted( int, bool ) ) );
1243} 1244}
1244 1245
1245void KToolBar::mousePressEvent ( QMouseEvent *m ) 1246void KToolBar::mousePressEvent ( QMouseEvent *m )
1246{ 1247{
1247 if ( !mainWindow() ) 1248 if ( !mainWindow() )
1248 return; 1249 return;
1249 QMainWindow *mw = mainWindow(); 1250 QMainWindow *mw = mainWindow();
1250 if ( mw->toolBarsMovable() && d->m_enableContext ) { 1251 if ( mw->toolBarsMovable() && d->m_enableContext ) {
1251 if ( m->button() == RightButton ) { 1252 if ( m->button() == RightButton ) {
1252 int i = contextMenu()->exec( m->globalPos(), 0 ); 1253 int i = contextMenu()->exec( m->globalPos(), 0 );
1253 switch ( i ) { 1254 switch ( i ) {
1254 case -1: 1255 case -1:
1255 return; // popup cancelled 1256 return; // popup cancelled
1256 case CONTEXT_LEFT: 1257 case CONTEXT_LEFT:
1257//US mw->moveDockWindow( this, DockLeft ); 1258//US mw->moveDockWindow( this, DockLeft );
1258 mw->moveToolBar( this, QMainWindow::Left ); 1259 mw->moveToolBar( this, QMainWindow::Left );
1259 break; 1260 break;
1260 case CONTEXT_RIGHT: 1261 case CONTEXT_RIGHT:
1261//US mw->moveDockWindow( this, DockRight ); 1262//US mw->moveDockWindow( this, DockRight );
1262 mw->moveToolBar( this, QMainWindow::Right ); 1263 mw->moveToolBar( this, QMainWindow::Right );
1263 break; 1264 break;
1264 case CONTEXT_TOP: 1265 case CONTEXT_TOP:
1265//US mw->moveDockWindow( this, DockTop ); 1266//US mw->moveDockWindow( this, DockTop );
1266 mw->moveToolBar( this, QMainWindow::Top ); 1267 mw->moveToolBar( this, QMainWindow::Top );
1267 break; 1268 break;
1268 case CONTEXT_BOTTOM: 1269 case CONTEXT_BOTTOM:
1269//US mw->moveDockWindow( this, DockBottom ); 1270//US mw->moveDockWindow( this, DockBottom );
1270 mw->moveToolBar( this, QMainWindow::Bottom ); 1271 mw->moveToolBar( this, QMainWindow::Bottom );
1271 break; 1272 break;
1272 case CONTEXT_FLOAT: 1273 case CONTEXT_FLOAT:
1273 break; 1274 break;
1274 case CONTEXT_FLAT: 1275 case CONTEXT_FLAT:
1275//US mw->moveDockWindow( this, DockMinimized ); 1276//US mw->moveDockWindow( this, DockMinimized );
1276 mw->moveToolBar( this, QMainWindow::Minimized ); 1277 mw->moveToolBar( this, QMainWindow::Minimized );
1277 break; 1278 break;
1278 case CONTEXT_ICONS: 1279 case CONTEXT_ICONS:
1279 setIconText( IconOnly ); 1280 setIconText( IconOnly );
1280 break; 1281 break;
1281 case CONTEXT_TEXTRIGHT: 1282 case CONTEXT_TEXTRIGHT:
1282 setIconText( IconTextRight ); 1283 setIconText( IconTextRight );
1283 break; 1284 break;
1284 case CONTEXT_TEXT: 1285 case CONTEXT_TEXT:
1285 setIconText( TextOnly ); 1286 setIconText( TextOnly );
1286 break; 1287 break;
1287 case CONTEXT_TEXTUNDER: 1288 case CONTEXT_TEXTUNDER:
1288 setIconText( IconTextBottom ); 1289 setIconText( IconTextBottom );
1289 break; 1290 break;
1290 default: 1291 default:
1291 if ( i >= CONTEXT_ICONSIZES ) 1292 if ( i >= CONTEXT_ICONSIZES )
1292 setIconSize( i - CONTEXT_ICONSIZES ); 1293 setIconSize( i - CONTEXT_ICONSIZES );
1293 else 1294 else
1294 return; // assume this was an action handled elsewhere, no need for setSettingsDirty() 1295 return; // assume this was an action handled elsewhere, no need for setSettingsDirty()
1295 } 1296 }
1296/*US 1297/*US
1297 if ( mw->inherits("KMainWindow") ) 1298 if ( mw->inherits("KMainWindow") )
1298 static_cast<KMainWindow *>(mw)->setSettingsDirty(); 1299 static_cast<KMainWindow *>(mw)->setSettingsDirty();
1299*/ 1300*/
1300 } 1301 }
1301 } 1302 }
1302} 1303}
1303 1304
1304 1305
1305void KToolBar::rebuildLayout() 1306void KToolBar::rebuildLayout()
1306{ 1307{
1307 1308
1308 for(QWidget *w=d->idleButtons.first(); w; w=d->idleButtons.next()) 1309 for(QWidget *w=d->idleButtons.first(); w; w=d->idleButtons.next())
1309 w->blockSignals(false); 1310 w->blockSignals(false);
1310 d->idleButtons.clear(); 1311 d->idleButtons.clear();
1311 1312
1312 layoutTimer->stop(); 1313 layoutTimer->stop();
1313 QApplication::sendPostedEvents( this, QEvent::ChildInserted ); 1314 QApplication::sendPostedEvents( this, QEvent::ChildInserted );
1314 QBoxLayout *l = boxLayout(); 1315 QBoxLayout *l = boxLayout();
1315 l->setMargin( 1 ); 1316 l->setMargin( 1 );
1316 // clear the old layout 1317 // clear the old layout
1317 QLayoutIterator it = l->iterator(); 1318 QLayoutIterator it = l->iterator();
1318 1319
1319 while ( it.current() ) { 1320 while ( it.current() ) {
1320 it.deleteCurrent(); 1321 it.deleteCurrent();
1321 } 1322 }
1322 for ( QWidget *w = widgets.first(); w; w = widgets.next() ) { 1323 for ( QWidget *w = widgets.first(); w; w = widgets.next() ) {
1323 if ( w == rightAligned ) { 1324 if ( w == rightAligned ) {
1324 continue; 1325 continue;
1325 } 1326 }
1326 if ( w->inherits( "KToolBarSeparator" ) && 1327 if ( w->inherits( "KToolBarSeparator" ) &&
1327 !( (KToolBarSeparator*)w )->showLine() ) { 1328 !( (KToolBarSeparator*)w )->showLine() ) {
1328 l->addSpacing( 6 ); 1329 l->addSpacing( 6 );
1329 w->hide(); 1330 w->hide();
1330 continue; 1331 continue;
1331 } 1332 }
1332 if ( w->inherits( "QPopupMenu" ) ) 1333 if ( w->inherits( "QPopupMenu" ) )
1333 continue; 1334 continue;
1334 l->addWidget( w ); 1335 l->addWidget( w );
1335 w->show(); 1336 w->show();
1336 } 1337 }
1337 if ( rightAligned ) { 1338 if ( rightAligned ) {
1338 l->addStretch(); 1339 l->addStretch();
1339 l->addWidget( rightAligned ); 1340 l->addWidget( rightAligned );
1340 rightAligned->show(); 1341 rightAligned->show();
1341 } 1342 }
1342 1343
1343 if ( fullSize() ) { 1344 if ( fullSize() ) {
1344 // This code sucks. It makes the last combo in a toolbar VERY big (e.g. zoom combo in kword). 1345 // This code sucks. It makes the last combo in a toolbar VERY big (e.g. zoom combo in kword).
1345 //if ( !stretchableWidget && widgets.last() && 1346 //if ( !stretchableWidget && widgets.last() &&
1346 // !widgets.last()->inherits( "QButton" ) && !widgets.last()->inherits( "KAnimWidget" ) ) 1347 // !widgets.last()->inherits( "QButton" ) && !widgets.last()->inherits( "KAnimWidget" ) )
1347 // setStretchableWidget( widgets.last() ); 1348 // setStretchableWidget( widgets.last() );
1348 if ( !rightAligned ) 1349 if ( !rightAligned )
1349 l->addStretch(); 1350 l->addStretch();
1350 if ( stretchableWidget ) 1351 if ( stretchableWidget )
1351 l->setStretchFactor( stretchableWidget, 10 ); 1352 l->setStretchFactor( stretchableWidget, 10 );
1352 } 1353 }
1353 l->invalidate(); 1354 l->invalidate();
1354 QApplication::postEvent( this, new QEvent( QEvent::LayoutHint ) ); 1355 QApplication::postEvent( this, new QEvent( QEvent::LayoutHint ) );
1355 //#endif //DESKTOP_VERSION 1356 //#endif //DESKTOP_VERSION
1356} 1357}
1357 1358
1358void KToolBar::childEvent( QChildEvent *e ) 1359void KToolBar::childEvent( QChildEvent *e )
1359{ 1360{
1360 1361
1361 if ( e->child()->isWidgetType() ) { 1362 if ( e->child()->isWidgetType() ) {
1362 QWidget * w = (QWidget*)e->child(); 1363 QWidget * w = (QWidget*)e->child();
1363 if ( e->type() == QEvent::ChildInserted ) { 1364 if ( e->type() == QEvent::ChildInserted ) {
1364 if ( !e->child()->inherits( "QPopupMenu" ) && 1365 if ( !e->child()->inherits( "QPopupMenu" ) &&
1365 ::qstrcmp( "qt_dockwidget_internal", e->child()->name() ) != 0 ) { 1366 ::qstrcmp( "qt_dockwidget_internal", e->child()->name() ) != 0 ) {
1366 1367
1367 // prevent items that have been explicitly inserted by insert*() from 1368 // prevent items that have been explicitly inserted by insert*() from
1368 // being inserted again 1369 // being inserted again
1369 if ( !widget2id.contains( w ) ) 1370 if ( !widget2id.contains( w ) )
1370 { 1371 {
1371 int dummy = -1; 1372 int dummy = -1;
1372 insertWidgetInternal( w, dummy, -1 ); 1373 insertWidgetInternal( w, dummy, -1 );
1373 } 1374 }
1374 } 1375 }
1375 } else { 1376 } else {
1376 removeWidgetInternal( w ); 1377 removeWidgetInternal( w );
1377 } 1378 }
1378 if ( isVisibleTo( 0 ) ) 1379 if ( isVisibleTo( 0 ) )
1379 { 1380 {
1380 QBoxLayout *l = boxLayout(); 1381 QBoxLayout *l = boxLayout();
1381 // QLayout *l = layout(); 1382 // QLayout *l = layout();
1382 1383
1383 // clear the old layout so that we don't get unnecassery layout 1384 // clear the old layout so that we don't get unnecassery layout
1384 // changes till we have rebuild the thing 1385 // changes till we have rebuild the thing
1385 QLayoutIterator it = l->iterator(); 1386 QLayoutIterator it = l->iterator();
1386 while ( it.current() ) { 1387 while ( it.current() ) {
1387 it.deleteCurrent(); 1388 it.deleteCurrent();
1388 } 1389 }
1389 layoutTimer->start( 50, TRUE ); 1390 layoutTimer->start( 50, TRUE );
1390 } 1391 }
1391 } 1392 }
1392 QToolBar::childEvent( e ); 1393 QToolBar::childEvent( e );
1393} 1394}
1394 1395
1395void KToolBar::insertWidgetInternal( QWidget *w, int &index, int id ) 1396void KToolBar::insertWidgetInternal( QWidget *w, int &index, int id )
1396{ 1397{
1397 // we can't have it in widgets, or something is really wrong 1398 // we can't have it in widgets, or something is really wrong
1398 //widgets.removeRef( w ); 1399 //widgets.removeRef( w );
1399 1400
1400 connect( w, SIGNAL( destroyed() ), 1401 connect( w, SIGNAL( destroyed() ),
1401 this, SLOT( widgetDestroyed() ) ); 1402 this, SLOT( widgetDestroyed() ) );
1402 if ( index == -1 || index > (int)widgets.count() ) { 1403 if ( index == -1 || index > (int)widgets.count() ) {
1403 widgets.append( w ); 1404 widgets.append( w );
1404 index = (int)widgets.count(); 1405 index = (int)widgets.count();
1405 } 1406 }
1406 else 1407 else
1407 widgets.insert( index, w ); 1408 widgets.insert( index, w );
1408 if ( id == -1 ) 1409 if ( id == -1 )
1409 id = id2widget.count(); 1410 id = id2widget.count();
1410 id2widget.insert( id, w ); 1411 id2widget.insert( id, w );
1411 widget2id.insert( w, id ); 1412 widget2id.insert( w, id );
1412} 1413}
1413void KToolBar::repaintMe() 1414void KToolBar::repaintMe()
1414{ 1415{
1415 setUpdatesEnabled( true ); 1416 setUpdatesEnabled( true );
1416 QToolBar::repaint( true ); 1417 QToolBar::repaint( true );
1417 //qDebug(" KToolBar::repaintMe() "); 1418 //qDebug(" KToolBar::repaintMe() ");
1418} 1419}
1419 1420
1420void KToolBar::showEvent( QShowEvent *e ) 1421void KToolBar::showEvent( QShowEvent *e )
1421{ 1422{
1422 QToolBar::showEvent( e ); 1423 QToolBar::showEvent( e );
1423 rebuildLayout(); 1424 rebuildLayout();
1424} 1425}
1425 1426
1426void KToolBar::setStretchableWidget( QWidget *w ) 1427void KToolBar::setStretchableWidget( QWidget *w )
1427{ 1428{
1428 QToolBar::setStretchableWidget( w ); 1429 QToolBar::setStretchableWidget( w );
1429 stretchableWidget = w; 1430 stretchableWidget = w;
1430} 1431}
1431 1432
1432QSizePolicy KToolBar::sizePolicy() const 1433QSizePolicy KToolBar::sizePolicy() const
1433{ 1434{
1434 if ( orientation() == Horizontal ) 1435 if ( orientation() == Horizontal )
1435 return QSizePolicy( QSizePolicy::Expanding, QSizePolicy::Fixed ); 1436 return QSizePolicy( QSizePolicy::Expanding, QSizePolicy::Fixed );
1436 else 1437 else
1437 return QSizePolicy( QSizePolicy::Fixed, QSizePolicy::Expanding ); 1438 return QSizePolicy( QSizePolicy::Fixed, QSizePolicy::Expanding );
1438} 1439}
1439 1440
1440QSize KToolBar::sizeHint() const 1441QSize KToolBar::sizeHint() const
1441{ 1442{
1442 return QToolBar::sizeHint(); 1443 return QToolBar::sizeHint();
1443#if 0 1444#if 0
1444 QWidget::polish(); 1445 QWidget::polish();
1445 static int iii = 0; 1446 static int iii = 0;
1446 ++iii; 1447 ++iii;
1447 qDebug("++++++++ KToolBar::sizeHint() %d ", iii ); 1448 qDebug("++++++++ KToolBar::sizeHint() %d ", iii );
1448 int margin = static_cast<QWidget*>(ncThis)->layout()->margin(); 1449 int margin = static_cast<QWidget*>(ncThis)->layout()->margin();
1449 switch( barPos() ) 1450 switch( barPos() )
1450 { 1451 {
1451 case KToolBar::Top: 1452 case KToolBar::Top:
1452 case KToolBar::Bottom: 1453 case KToolBar::Bottom:
1453 for ( QWidget *w = widgets.first(); w; w =widgets.next() ) 1454 for ( QWidget *w = widgets.first(); w; w =widgets.next() )
1454 { 1455 {
1455 if ( w->inherits( "KToolBarSeparator" ) && 1456 if ( w->inherits( "KToolBarSeparator" ) &&
1456 !( static_cast<KToolBarSeparator*>(w)->showLine() ) ) 1457 !( static_cast<KToolBarSeparator*>(w)->showLine() ) )
1457 { 1458 {
1458 minSize += QSize(6, 0); 1459 minSize += QSize(6, 0);
1459 } 1460 }
1460 else 1461 else
1461 { 1462 {
1462 QSize sh = w->sizeHint(); 1463 QSize sh = w->sizeHint();
1463 if (!sh.isValid()) 1464 if (!sh.isValid())
1464 sh = w->minimumSize(); 1465 sh = w->minimumSize();
1465 minSize = minSize.expandedTo(QSize(0, sh.height())); 1466 minSize = minSize.expandedTo(QSize(0, sh.height()));
1466 minSize += QSize(sh.width()+1, 0); 1467 minSize += QSize(sh.width()+1, 0);
1467 } 1468 }
1468 } 1469 }
1469/*US 1470/*US
1470 minSize += QSize(QApplication::style().pixelMetric( QStyle::PM_DockWindowHandleExtent ), 0); 1471 minSize += QSize(QApplication::style().pixelMetric( QStyle::PM_DockWindowHandleExtent ), 0);
1471*/ 1472*/
1472 minSize += QSize(margin*2, margin*2); 1473 minSize += QSize(margin*2, margin*2);
1473 break; 1474 break;
1474 1475
1475 case KToolBar::Left: 1476 case KToolBar::Left:
1476 case KToolBar::Right: 1477 case KToolBar::Right:
1477 for ( QWidget *w = widgets.first(); w; w = widgets.next() ) 1478 for ( QWidget *w = widgets.first(); w; w = widgets.next() )
1478 { 1479 {
1479 if ( w->inherits( "KToolBarSeparator" ) && 1480 if ( w->inherits( "KToolBarSeparator" ) &&
1480 !( static_cast<KToolBarSeparator*>(w)->showLine() ) ) 1481 !( static_cast<KToolBarSeparator*>(w)->showLine() ) )
1481 { 1482 {
1482 minSize += QSize(0, 6); 1483 minSize += QSize(0, 6);
1483 } 1484 }
1484 else 1485 else
1485 { 1486 {
1486 QSize sh = w->sizeHint(); 1487 QSize sh = w->sizeHint();
1487 if (!sh.isValid()) 1488 if (!sh.isValid())
1488 sh = w->minimumSize(); 1489 sh = w->minimumSize();
1489 minSize = minSize.expandedTo(QSize(sh.width(), 0)); 1490 minSize = minSize.expandedTo(QSize(sh.width(), 0));
1490 minSize += QSize(0, sh.height()+1); 1491 minSize += QSize(0, sh.height()+1);
1491 } 1492 }
1492 } 1493 }
1493/*US 1494/*US
1494 minSize += QSize(0, QApplication::style().pixelMetric( QStyle::PM_DockWindowHandleExtent )); 1495 minSize += QSize(0, QApplication::style().pixelMetric( QStyle::PM_DockWindowHandleExtent ));
1495*/ 1496*/
1496 minSize += QSize(margin*2, margin*2); 1497 minSize += QSize(margin*2, margin*2);
1497 break; 1498 break;
1498 1499
1499 default: 1500 default:
1500 minSize = QToolBar::sizeHint(); 1501 minSize = QToolBar::sizeHint();
1501 break; 1502 break;
1502 } 1503 }
1503 return minSize; 1504 return minSize;
1504#endif 1505#endif
1505} 1506}
1506 1507
1507QSize KToolBar::minimumSize() const 1508QSize KToolBar::minimumSize() const
1508{ 1509{
1509 return minimumSizeHint(); 1510 return minimumSizeHint();
1510} 1511}
1511 1512
1512QSize KToolBar::minimumSizeHint() const 1513QSize KToolBar::minimumSizeHint() const
1513{ 1514{
1514 return sizeHint(); 1515 return sizeHint();
1515} 1516}
1516 1517
1517bool KToolBar::highlight() const 1518bool KToolBar::highlight() const
1518{ 1519{
1519 return d->m_highlight; 1520 return d->m_highlight;
1520} 1521}
1521 1522
1522void KToolBar::hide() 1523void KToolBar::hide()
1523{ 1524{
1524 QToolBar::hide(); 1525 QToolBar::hide();
1525} 1526}
1526 1527
1527void KToolBar::show() 1528void KToolBar::show()
1528{ 1529{
1529 QToolBar::show(); 1530 QToolBar::show();
1530} 1531}
1531 1532
1532void KToolBar::resizeEvent( QResizeEvent *e ) 1533void KToolBar::resizeEvent( QResizeEvent *e )
1533{ 1534{
1534 bool b = isUpdatesEnabled(); 1535 bool b = isUpdatesEnabled();
1535 setUpdatesEnabled( FALSE ); 1536 setUpdatesEnabled( FALSE );
1536 QToolBar::resizeEvent( e ); 1537 QToolBar::resizeEvent( e );
1537 if (b) 1538 if (b)
1538 d->repaintTimer.start( 100, true ); 1539 d->repaintTimer.start( 100, true );
1539} 1540}
1540 1541
1541void KToolBar::slotIconChanged(int group) 1542void KToolBar::slotIconChanged(int group)
1542{ 1543{
1543 if ((group != KIcon::Toolbar) && (group != KIcon::MainToolbar)) 1544 if ((group != KIcon::Toolbar) && (group != KIcon::MainToolbar))
1544 return; 1545 return;
1545 if ((group == KIcon::MainToolbar) != !::qstrcmp(name(), "mainToolBar")) 1546 if ((group == KIcon::MainToolbar) != !::qstrcmp(name(), "mainToolBar"))
1546 return; 1547 return;
1547 1548
1548 emit modechange(); 1549 emit modechange();
1549 if (isVisible()) 1550 if (isVisible())
1550 updateGeometry(); 1551 updateGeometry();
1551} 1552}
1552 1553
1553void KToolBar::slotReadConfig() 1554void KToolBar::slotReadConfig()
1554{ 1555{
1555 //kdDebug(220) << "KToolBar::slotReadConfig" << endl; 1556 //kdDebug(220) << "KToolBar::slotReadConfig" << endl;
1556 // Read appearance settings (hmm, we used to do both here, 1557 // Read appearance settings (hmm, we used to do both here,
1557 // but a well behaved application will call applyMainWindowSettings 1558 // but a well behaved application will call applyMainWindowSettings
1558 // anyway, right ?) 1559 // anyway, right ?)
1559 applyAppearanceSettings(KGlobal::config(), QString::null ); 1560 applyAppearanceSettings(KGlobal::config(), QString::null );
1560} 1561}
1561 1562
1562void KToolBar::slotAppearanceChanged() 1563void KToolBar::slotAppearanceChanged()
1563{ 1564{
1564 // Read appearance settings from global file. 1565 // Read appearance settings from global file.
1565 applyAppearanceSettings(KGlobal::config(), QString::null, true /* lose local settings */ ); 1566 applyAppearanceSettings(KGlobal::config(), QString::null, true /* lose local settings */ );
1566 // And remember to save the new look later 1567 // And remember to save the new look later
1567/*US 1568/*US
1568 if ( mainWindow() && mainWindow()->inherits( "KMainWindow" ) ) 1569 if ( mainWindow() && mainWindow()->inherits( "KMainWindow" ) )
1569 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty(); 1570 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty();
1570*/ 1571*/
1571} 1572}
1572 1573
1573//static 1574//static
1574bool KToolBar::highlightSetting() 1575bool KToolBar::highlightSetting()
1575{ 1576{
1576 QString grpToolbar(QString::fromLatin1("Toolbar style")); 1577 QString grpToolbar(QString::fromLatin1("Toolbar style"));
1577 KConfigGroupSaver saver(KGlobal::config(), grpToolbar); 1578 KConfigGroupSaver saver(KGlobal::config(), grpToolbar);
1578 return KGlobal::config()->readBoolEntry(QString::fromLatin1("Highlighting"),true); 1579 return KGlobal::config()->readBoolEntry(QString::fromLatin1("Highlighting"),true);
1579} 1580}
1580 1581
1581//static 1582//static
1582bool KToolBar::transparentSetting() 1583bool KToolBar::transparentSetting()
1583{ 1584{
1584 QString grpToolbar(QString::fromLatin1("Toolbar style")); 1585 QString grpToolbar(QString::fromLatin1("Toolbar style"));
1585 KConfigGroupSaver saver(KGlobal::config(), grpToolbar); 1586 KConfigGroupSaver saver(KGlobal::config(), grpToolbar);
1586 return KGlobal::config()->readBoolEntry(QString::fromLatin1("TransparentMoving"),true); 1587 return KGlobal::config()->readBoolEntry(QString::fromLatin1("TransparentMoving"),true);
1587} 1588}
1588 1589
1589//static 1590//static
1590KToolBar::IconText KToolBar::iconTextSetting() 1591KToolBar::IconText KToolBar::iconTextSetting()
1591{ 1592{
1592 QString grpToolbar(QString::fromLatin1("Toolbar style")); 1593 QString grpToolbar(QString::fromLatin1("Toolbar style"));
1593 KConfigGroupSaver saver(KGlobal::config(), grpToolbar); 1594 KConfigGroupSaver saver(KGlobal::config(), grpToolbar);
1594 QString icontext = KGlobal::config()->readEntry(QString::fromLatin1("IconText"),QString::fromLatin1("IconOnly")); 1595 QString icontext = KGlobal::config()->readEntry(QString::fromLatin1("IconText"),QString::fromLatin1("IconOnly"));
1595 if ( icontext == "IconTextRight" ) 1596 if ( icontext == "IconTextRight" )
1596 return IconTextRight; 1597 return IconTextRight;
1597 else if ( icontext == "IconTextBottom" ) 1598 else if ( icontext == "IconTextBottom" )
1598 return IconTextBottom; 1599 return IconTextBottom;
1599 else if ( icontext == "TextOnly" ) 1600 else if ( icontext == "TextOnly" )
1600 return TextOnly; 1601 return TextOnly;
1601 else 1602 else
1602 return IconOnly; 1603 return IconOnly;
1603} 1604}
1604 1605
1605void KToolBar::applyAppearanceSettings(KConfig *config, const QString &_configGroup, bool forceGlobal) 1606void KToolBar::applyAppearanceSettings(KConfig *config, const QString &_configGroup, bool forceGlobal)
1606{ 1607{
1608 return;
1607 QString configGroup = _configGroup.isEmpty() ? settingsGroup() : _configGroup; 1609 QString configGroup = _configGroup.isEmpty() ? settingsGroup() : _configGroup;
1608 //kdDebug(220) << "KToolBar::applyAppearanceSettings: configGroup=" << configGroup << endl; 1610 //kdDebug(220) << "KToolBar::applyAppearanceSettings: configGroup=" << configGroup << endl;
1609 // We have application-specific settings in the XML file, 1611 // We have application-specific settings in the XML file,
1610 // and nothing in the application's config file 1612 // and nothing in the application's config file
1611 // -> don't apply the global defaults, the XML ones are preferred 1613 // -> don't apply the global defaults, the XML ones are preferred
1612 // See applySettings for a full explanation 1614 // See applySettings for a full explanation
1613/*US :we do not support xml files 1615/*US :we do not support xml files
1614 if ( d->m_xmlguiClient && !d->m_xmlguiClient->xmlFile().isEmpty() && 1616 if ( d->m_xmlguiClient && !d->m_xmlguiClient->xmlFile().isEmpty() &&
1615 !config->hasGroup(configGroup) ) 1617 !config->hasGroup(configGroup) )
1616 { 1618 {
1617 //kdDebug(220) << "skipping global defaults, using XML ones instead" << endl; 1619 //kdDebug(220) << "skipping global defaults, using XML ones instead" << endl;
1618 return; 1620 return;
1619 } 1621 }
1620*/ 1622*/
1621 if ( !config->hasGroup(configGroup) ) 1623 if ( !config->hasGroup(configGroup) )
1622 { 1624 {
1623 //kdDebug(220) << "skipping global defaults, using XML ones instead" << endl; 1625 //kdDebug(220) << "skipping global defaults, using XML ones instead" << endl;
1624 return; 1626 return;
1625 } 1627 }
1626 1628
1627 1629
1628 KConfig *gconfig = KGlobal::config(); 1630 KConfig *gconfig = KGlobal::config();
1629/*US 1631/*US
1630 static const QString &attrIconText = KGlobal::staticQString("IconText"); 1632 static const QString &attrIconText = KGlobal::staticQString("IconText");
1631 static const QString &attrHighlight = KGlobal::staticQString("Highlighting"); 1633 static const QString &attrHighlight = KGlobal::staticQString("Highlighting");
1632 static const QString &attrTrans = KGlobal::staticQString("TransparentMoving"); 1634 static const QString &attrTrans = KGlobal::staticQString("TransparentMoving");
1633 static const QString &attrSize = KGlobal::staticQString("IconSize"); 1635 static const QString &attrSize = KGlobal::staticQString("IconSize");
1634*/ 1636*/
1635 // we actually do this in two steps. 1637 // we actually do this in two steps.
1636 // First, we read in the global styles [Toolbar style] (from the KControl module). 1638 // First, we read in the global styles [Toolbar style] (from the KControl module).
1637 // Then, if the toolbar is NOT 'mainToolBar', we will also try to read in [barname Toolbar style] 1639 // Then, if the toolbar is NOT 'mainToolBar', we will also try to read in [barname Toolbar style]
1638 bool highlight; 1640 bool highlight;
1639 int transparent; 1641 int transparent;
1640 QString icontext; 1642 QString icontext;
1641 int iconsize = 0; 1643 int iconsize = 0;
1642 1644
1643 // this is the first iteration 1645 // this is the first iteration
1644 QString grpToolbar(QString::fromLatin1("Toolbar style")); 1646 QString grpToolbar(QString::fromLatin1("Toolbar style"));
1645 { // start block for KConfigGroupSaver 1647 { // start block for KConfigGroupSaver
1646 KConfigGroupSaver saver(gconfig, grpToolbar); 1648 KConfigGroupSaver saver(gconfig, grpToolbar);
1647 1649
1648 // first, get the generic settings 1650 // first, get the generic settings
1649//US highlight = gconfig->readBoolEntry(attrHighlight, true); 1651//US highlight = gconfig->readBoolEntry(attrHighlight, true);
1650 highlight = gconfig->readBoolEntry("Highlighting", true); 1652 highlight = gconfig->readBoolEntry("Highlighting", true);
1651//US transparent = gconfig->readBoolEntry(attrTrans, true); 1653//US transparent = gconfig->readBoolEntry(attrTrans, true);
1652 transparent = gconfig->readBoolEntry("TransparentMoving", true); 1654 transparent = gconfig->readBoolEntry("TransparentMoving", true);
1653 1655
1654 // we read in the IconText property *only* if we intend on actually 1656 // we read in the IconText property *only* if we intend on actually
1655 // honoring it 1657 // honoring it
1656 if (d->m_honorStyle) 1658 if (d->m_honorStyle)
1657//US d->IconTextDefault = gconfig->readEntry(attrIconText, d->IconTextDefault); 1659//US d->IconTextDefault = gconfig->readEntry(attrIconText, d->IconTextDefault);
1658 d->IconTextDefault = gconfig->readEntry("IconText", d->IconTextDefault); 1660 d->IconTextDefault = gconfig->readEntry("IconText", d->IconTextDefault);
1659 else 1661 else
1660 d->IconTextDefault = "IconOnly"; 1662 d->IconTextDefault = "IconOnly";
1661 1663
1662 // Use the default icon size for toolbar icons. 1664 // Use the default icon size for toolbar icons.
1663//US d->IconSizeDefault = gconfig->readNumEntry(attrSize, d->IconSizeDefault); 1665//US d->IconSizeDefault = gconfig->readNumEntry(attrSize, d->IconSizeDefault);
1664 d->IconSizeDefault = gconfig->readNumEntry("IconSize", d->IconSizeDefault); 1666 d->IconSizeDefault = gconfig->readNumEntry("IconSize", d->IconSizeDefault);
1665 1667
1666 if ( !forceGlobal && config->hasGroup(configGroup) ) 1668 if ( !forceGlobal && config->hasGroup(configGroup) )
1667 { 1669 {
1668 config->setGroup(configGroup); 1670 config->setGroup(configGroup);
1669 1671
1670 // first, get the generic settings 1672 // first, get the generic settings
1671//US highlight = config->readBoolEntry(attrHighlight, highlight); 1673//US highlight = config->readBoolEntry(attrHighlight, highlight);
1672 highlight = config->readBoolEntry("Highlighting", highlight); 1674 highlight = config->readBoolEntry("Highlighting", highlight);
1673//US transparent = config->readBoolEntry(attrTrans, transparent); 1675//US transparent = config->readBoolEntry(attrTrans, transparent);
1674 transparent = config->readBoolEntry("TransparentMoving", transparent); 1676 transparent = config->readBoolEntry("TransparentMoving", transparent);
1675 // now we always read in the IconText property 1677 // now we always read in the IconText property
1676//US icontext = config->readEntry(attrIconText, d->IconTextDefault); 1678//US icontext = config->readEntry(attrIconText, d->IconTextDefault);
1677 icontext = config->readEntry("IconText", d->IconTextDefault); 1679 icontext = config->readEntry("IconText", d->IconTextDefault);
1678 1680
1679 // now get the size 1681 // now get the size
1680//US iconsize = config->readNumEntry(attrSize, d->IconSizeDefault); 1682//US iconsize = config->readNumEntry(attrSize, d->IconSizeDefault);
1681 iconsize = config->readNumEntry("IconSize", d->IconSizeDefault); 1683 iconsize = config->readNumEntry("IconSize", d->IconSizeDefault);
1682 } 1684 }
1683 else 1685 else
1684 { 1686 {
1685 iconsize = d->IconSizeDefault; 1687 iconsize = d->IconSizeDefault;
1686 icontext = d->IconTextDefault; 1688 icontext = d->IconTextDefault;
1687 } 1689 }
1688 1690
1689 // revert back to the old group 1691 // revert back to the old group
1690 } // end block for KConfigGroupSaver 1692 } // end block for KConfigGroupSaver
1691 1693
1692 bool doUpdate = false; 1694 bool doUpdate = false;
1693 1695
1694 IconText icon_text; 1696 IconText icon_text;
1695 if ( icontext == "IconTextRight" ) 1697 if ( icontext == "IconTextRight" )
1696 icon_text = IconTextRight; 1698 icon_text = IconTextRight;
1697 else if ( icontext == "IconTextBottom" ) 1699 else if ( icontext == "IconTextBottom" )
1698 icon_text = IconTextBottom; 1700 icon_text = IconTextBottom;
1699 else if ( icontext == "TextOnly" ) 1701 else if ( icontext == "TextOnly" )
1700 icon_text = TextOnly; 1702 icon_text = TextOnly;
1701 else 1703 else
1702 icon_text = IconOnly; 1704 icon_text = IconOnly;
1703 1705
1704 // check if the icon/text has changed 1706 // check if the icon/text has changed
1705 if (icon_text != d->m_iconText) { 1707 if (icon_text != d->m_iconText) {
1706 //kdDebug(220) << "KToolBar::applyAppearanceSettings setIconText " << icon_text << endl; 1708 //kdDebug(220) << "KToolBar::applyAppearanceSettings setIconText " << icon_text << endl;
1707 setIconText(icon_text, false); 1709 setIconText(icon_text, false);
1708 doUpdate = true; 1710 doUpdate = true;
1709 } 1711 }
1710 1712
1711 // ...and check if the icon size has changed 1713 // ...and check if the icon size has changed
1712 if (iconsize != d->m_iconSize) { 1714 if (iconsize != d->m_iconSize) {
1713 setIconSize(iconsize, false); 1715 setIconSize(iconsize, false);
1714 doUpdate = true; 1716 doUpdate = true;
1715 } 1717 }
1716 1718
1717 QMainWindow *mw = mainWindow(); 1719 QMainWindow *mw = mainWindow();
1718 1720
1719 // ...and if we should highlight 1721 // ...and if we should highlight
1720 if ( highlight != d->m_highlight ) { 1722 if ( highlight != d->m_highlight ) {
1721 d->m_highlight = highlight; 1723 d->m_highlight = highlight;
1722 doUpdate = true; 1724 doUpdate = true;
1723 } 1725 }
1724 1726
1725 // ...and if we should move transparently 1727 // ...and if we should move transparently
1726 if ( mw && transparent != (!mw->opaqueMoving()) ) { 1728 if ( mw && transparent != (!mw->opaqueMoving()) ) {
1727 mw->setOpaqueMoving( !transparent ); 1729 mw->setOpaqueMoving( !transparent );
1728 } 1730 }
1729 1731
1730 if (doUpdate) 1732 if (doUpdate)
1731 emit modechange(); // tell buttons what happened 1733 emit modechange(); // tell buttons what happened
1732 if (isVisible ()) 1734 if (isVisible ())
1733 updateGeometry(); 1735 updateGeometry();
1734} 1736}
1735 1737
1736void KToolBar::applySettings(KConfig *config, const QString &_configGroup) 1738void KToolBar::applySettings(KConfig *config, const QString &_configGroup)
1737{ 1739{
1738 //kdDebug(220) << "KToolBar::applySettings group=" << _configGroup << endl; 1740 //kdDebug(220) << "KToolBar::applySettings group=" << _configGroup << endl;
1739 1741
1740 QString configGroup = _configGroup.isEmpty() ? settingsGroup() : _configGroup; 1742 QString configGroup = _configGroup.isEmpty() ? settingsGroup() : _configGroup;
1741 1743
1742 /* 1744 /*
1743 Let's explain this a bit more in details. 1745 Let's explain this a bit more in details.
1744 The order in which we apply settings is : 1746 The order in which we apply settings is :
1745 Global config / <appnamerc> user settings if no XMLGUI is used 1747 Global config / <appnamerc> user settings if no XMLGUI is used
1746 Global config / App-XML attributes / <appnamerc> user settings if XMLGUI is used 1748 Global config / App-XML attributes / <appnamerc> user settings if XMLGUI is used
1747 1749
1748 So in the first case, we simply read everything from KConfig as below, 1750 So in the first case, we simply read everything from KConfig as below,
1749 but in the second case we don't do anything here if there is no app-specific config, 1751 but in the second case we don't do anything here if there is no app-specific config,
1750 and the XMLGUI uses the static methods of this class to get the global defaults. 1752 and the XMLGUI uses the static methods of this class to get the global defaults.
1751 1753
1752 Global config doesn't include position (index, offset, newline and hidden/shown). 1754 Global config doesn't include position (index, offset, newline and hidden/shown).
1753 */ 1755 */
1754 1756
1755 // First the appearance stuff - the one which has a global config 1757 // First the appearance stuff - the one which has a global config
1756 applyAppearanceSettings( config, _configGroup ); 1758 applyAppearanceSettings( config, _configGroup );
1757 1759
1758 // ...and now the position stuff 1760 // ...and now the position stuff
1759 if ( config->hasGroup(configGroup) ) 1761 if ( config->hasGroup(configGroup) )
1760 { 1762 {
1761 KConfigGroupSaver cgs(config, configGroup); 1763 KConfigGroupSaver cgs(config, configGroup);
1762/*US 1764/*US
1763 static const QString &attrPosition = KGlobal::staticQString("Position"); 1765 static const QString &attrPosition = KGlobal::staticQString("Position");
1764 static const QString &attrIndex = KGlobal::staticQString("Index"); 1766 static const QString &attrIndex = KGlobal::staticQString("Index");
1765 static const QString &attrOffset = KGlobal::staticQString("Offset"); 1767 static const QString &attrOffset = KGlobal::staticQString("Offset");
1766 static const QString &attrNewLine = KGlobal::staticQString("NewLine"); 1768 static const QString &attrNewLine = KGlobal::staticQString("NewLine");
1767 static const QString &attrHidden = KGlobal::staticQString("Hidden"); 1769 static const QString &attrHidden = KGlobal::staticQString("Hidden");
1768 1770
1769 QString position = config->readEntry(attrPosition, d->PositionDefault); 1771 QString position = config->readEntry(attrPosition, d->PositionDefault);
1770 int index = config->readNumEntry(attrIndex, d->IndexDefault); 1772 int index = config->readNumEntry(attrIndex, d->IndexDefault);
1771 int offset = config->readNumEntry(attrOffset, d->OffsetDefault); 1773 int offset = config->readNumEntry(attrOffset, d->OffsetDefault);
1772 bool newLine = config->readBoolEntry(attrNewLine, d->NewLineDefault); 1774 bool newLine = config->readBoolEntry(attrNewLine, d->NewLineDefault);
1773 bool hidden = config->readBoolEntry(attrHidden, d->HiddenDefault); 1775 bool hidden = config->readBoolEntry(attrHidden, d->HiddenDefault);
1774*/ 1776*/
1775 1777
1776 QString position = config->readEntry("Position", d->PositionDefault); 1778 QString position = config->readEntry("Position", d->PositionDefault);
1777 int index = config->readNumEntry("Index", d->IndexDefault); 1779 int index = config->readNumEntry("Index", d->IndexDefault);
1778 int offset = config->readNumEntry("Offset", d->OffsetDefault); 1780 int offset = config->readNumEntry("Offset", d->OffsetDefault);
1779 bool newLine = config->readBoolEntry("NewLine", d->NewLineDefault); 1781 bool newLine = config->readBoolEntry("NewLine", d->NewLineDefault);
1780 bool hidden = config->readBoolEntry("Hidden", d->HiddenDefault); 1782 bool hidden = config->readBoolEntry("Hidden", d->HiddenDefault);
1781 1783
1782/*US Dock pos(DockTop); 1784/*US Dock pos(DockTop);
1783 if ( position == "Top" ) 1785 if ( position == "Top" )
1784 pos = DockTop; 1786 pos = DockTop;
1785 else if ( position == "Bottom" ) 1787 else if ( position == "Bottom" )
1786 pos = DockBottom; 1788 pos = DockBottom;
1787 else if ( position == "Left" ) 1789 else if ( position == "Left" )
1788 pos = DockLeft; 1790 pos = DockLeft;
1789 else if ( position == "Right" ) 1791 else if ( position == "Right" )
1790 pos = DockRight; 1792 pos = DockRight;
1791 else if ( position == "Floating" ) 1793 else if ( position == "Floating" )
1792 pos = DockTornOff; 1794 pos = DockTornOff;
1793 else if ( position == "Flat" ) 1795 else if ( position == "Flat" )
1794 pos = DockMinimized; 1796 pos = DockMinimized;
1795*/ 1797*/
1796 QMainWindow::ToolBarDock pos(QMainWindow::Top); 1798 QMainWindow::ToolBarDock pos(QMainWindow::Top);
1797 if ( position == "Top" ) 1799 if ( position == "Top" )
1798 pos = QMainWindow::Top; 1800 pos = QMainWindow::Top;
1799 else if ( position == "Bottom" ) 1801 else if ( position == "Bottom" )
1800 pos = QMainWindow::Bottom; 1802 pos = QMainWindow::Bottom;
1801 else if ( position == "Left" ) 1803 else if ( position == "Left" )
1802 pos = QMainWindow::Left; 1804 pos = QMainWindow::Left;
1803 else if ( position == "Right" ) 1805 else if ( position == "Right" )
1804 pos = QMainWindow::Right; 1806 pos = QMainWindow::Right;
1805 else if ( position == "Floating" ) 1807 else if ( position == "Floating" )
1806 pos = QMainWindow::TornOff; 1808 pos = QMainWindow::TornOff;
1807 else if ( position == "Flat" ) 1809 else if ( position == "Flat" )
1808 pos = QMainWindow::Minimized; 1810 pos = QMainWindow::Minimized;
1809 1811
1810 //kdDebug(220) << "KToolBar::applySettings hidden=" << hidden << endl; 1812 //kdDebug(220) << "KToolBar::applySettings hidden=" << hidden << endl;
1811 if (hidden) 1813 if (hidden)
1812 hide(); 1814 hide();
1813 else 1815 else
1814 show(); 1816 show();
1815 1817
1816 if ( mainWindow() ) 1818 if ( mainWindow() )
1817 { 1819 {
1818 QMainWindow *mw = mainWindow(); 1820 QMainWindow *mw = mainWindow();
1819 1821
1820 //kdDebug(220) << "KToolBar::applySettings updating ToolbarInfo" << endl; 1822 //kdDebug(220) << "KToolBar::applySettings updating ToolbarInfo" << endl;
1821 d->toolBarInfo = KToolBarPrivate::ToolBarInfo( pos, index, newLine, offset ); 1823 d->toolBarInfo = KToolBarPrivate::ToolBarInfo( pos, index, newLine, offset );
1822 1824
1823 // moveDockWindow calls QDockArea which does a reparent() on us with 1825 // moveDockWindow calls QDockArea which does a reparent() on us with
1824 // showIt = true, so we loose our visibility status 1826 // showIt = true, so we loose our visibility status
1825 bool doHide = isHidden(); 1827 bool doHide = isHidden();
1826 1828
1827//US mw->moveDockWindow( this, pos, newLine, index, offset ); 1829//US mw->moveDockWindow( this, pos, newLine, index, offset );
1828 mw->moveToolBar( this, pos, newLine, index, offset ); 1830 mw->moveToolBar( this, pos, newLine, index, offset );
1829 1831
1830 //kdDebug(220) << "KToolBar::applySettings " << name() << " moveDockWindow with pos=" << pos << " newLine=" << newLine << " idx=" << index << " offs=" << offset << endl; 1832 //kdDebug(220) << "KToolBar::applySettings " << name() << " moveDockWindow with pos=" << pos << " newLine=" << newLine << " idx=" << index << " offs=" << offset << endl;
1831 if ( doHide ) 1833 if ( doHide )
1832 hide(); 1834 hide();
1833 } 1835 }
1834 if (isVisible ()) 1836 if (isVisible ())
1835 updateGeometry(); 1837 updateGeometry();
1836 } 1838 }
1837} 1839}
1838 1840
1839bool KToolBar::event( QEvent *e ) 1841bool KToolBar::event( QEvent *e )
1840{ 1842{
1841 if ( (e->type() == QEvent::LayoutHint) && isUpdatesEnabled() ) 1843 if ( (e->type() == QEvent::LayoutHint) && isUpdatesEnabled() )
1842 d->repaintTimer.start( 100, true ); 1844 d->repaintTimer.start( 100, true );
1843 1845
1844 if (e->type() == QEvent::ChildInserted ) 1846 if (e->type() == QEvent::ChildInserted )
1845 { 1847 {
1846 // By pass QToolBar::event, 1848 // By pass QToolBar::event,
1847 // it will show() the inserted child and we don't want to 1849 // it will show() the inserted child and we don't want to
1848 // do that until we have rebuild the layout. 1850 // do that until we have rebuild the layout.
1849 childEvent((QChildEvent *)e); 1851 childEvent((QChildEvent *)e);
1850 return true; 1852 return true;
1851 } 1853 }
1852 1854
1853 return QToolBar::event( e ); 1855 return QToolBar::event( e );
1854} 1856}
1855 1857
1856void KToolBar::slotRepaint() 1858void KToolBar::slotRepaint()
1857{ 1859{
1858 setUpdatesEnabled( FALSE ); 1860 setUpdatesEnabled( FALSE );
1859 // Send a resizeEvent to update the "toolbar extension arrow" 1861 // Send a resizeEvent to update the "toolbar extension arrow"
1860 // (The button you get when your toolbar-items don't fit in 1862 // (The button you get when your toolbar-items don't fit in
1861 // the available space) 1863 // the available space)
1862 QResizeEvent ev(size(), size()); 1864 QResizeEvent ev(size(), size());
1863 resizeEvent(&ev); 1865 resizeEvent(&ev);
1864 //#ifdef DESKTOP_VERSION 1866 //#ifdef DESKTOP_VERSION
1865 QApplication::sendPostedEvents( this, QEvent::LayoutHint ); 1867 QApplication::sendPostedEvents( this, QEvent::LayoutHint );
1866 //#endif //DESKTOP_VERSION 1868 //#endif //DESKTOP_VERSION
1867 setUpdatesEnabled( TRUE ); 1869 setUpdatesEnabled( TRUE );
1868 repaint( TRUE ); 1870 repaint( TRUE );
1869} 1871}
1870 1872
1871void KToolBar::toolBarPosChanged( QToolBar *tb ) 1873void KToolBar::toolBarPosChanged( QToolBar *tb )
1872{ 1874{
1873 if ( tb != this ) 1875 if ( tb != this )
1874 return; 1876 return;
1875//US if ( d->oldPos == DockMinimized ) 1877//US if ( d->oldPos == DockMinimized )
1876 if ( d->oldPos == QMainWindow::Minimized ) 1878 if ( d->oldPos == QMainWindow::Minimized )
1877 rebuildLayout(); 1879 rebuildLayout();
1878 d->oldPos = (QMainWindow::ToolBarDock)barPos(); 1880 d->oldPos = (QMainWindow::ToolBarDock)barPos();
1879/*US 1881/*US
1880 if ( mainWindow() && mainWindow()->inherits( "KMainWindow" ) ) 1882 if ( mainWindow() && mainWindow()->inherits( "KMainWindow" ) )
1881 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty(); 1883 static_cast<KMainWindow *>(mainWindow())->setSettingsDirty();
1882*/ 1884*/
1883} 1885}
1884 1886
1885/*US 1887/*US
1886void KToolBar::loadState( const QDomElement &element ) 1888void KToolBar::loadState( const QDomElement &element )
1887{ 1889{
1888 //kdDebug(220) << "KToolBar::loadState " << this << endl; 1890 //kdDebug(220) << "KToolBar::loadState " << this << endl;
1889 if ( !mainWindow() ) 1891 if ( !mainWindow() )
1890 return; 1892 return;
1891 1893
1892 { 1894 {
1893 QCString text = element.namedItem( "text" ).toElement().text().utf8(); 1895 QCString text = element.namedItem( "text" ).toElement().text().utf8();
1894 if ( text.isEmpty() ) 1896 if ( text.isEmpty() )
1895 text = element.namedItem( "Text" ).toElement().text().utf8(); 1897 text = element.namedItem( "Text" ).toElement().text().utf8();
1896 if ( !text.isEmpty() ) 1898 if ( !text.isEmpty() )
1897 setText( i18n( text ) ); 1899 setText( i18n( text ) );
1898 } 1900 }
1899 1901
1900 { 1902 {
1901 QCString attrFullWidth = element.attribute( "fullWidth" ).lower().latin1(); 1903 QCString attrFullWidth = element.attribute( "fullWidth" ).lower().latin1();
1902 if ( !attrFullWidth.isEmpty() ) 1904 if ( !attrFullWidth.isEmpty() )
1903 setFullSize( attrFullWidth == "true" ); 1905 setFullSize( attrFullWidth == "true" );
1904 } 1906 }
1905 1907
1906 Dock dock = DockTop; 1908 Dock dock = DockTop;
1907 { 1909 {
1908 QCString attrPosition = element.attribute( "position" ).lower().latin1(); 1910 QCString attrPosition = element.attribute( "position" ).lower().latin1();
1909 //kdDebug(220) << "KToolBar::loadState attrPosition=" << attrPosition << endl; 1911 //kdDebug(220) << "KToolBar::loadState attrPosition=" << attrPosition << endl;
1910 if ( !attrPosition.isEmpty() ) { 1912 if ( !attrPosition.isEmpty() ) {
1911 if ( attrPosition == "top" ) 1913 if ( attrPosition == "top" )
1912 dock = DockTop; 1914 dock = DockTop;
1913 else if ( attrPosition == "left" ) 1915 else if ( attrPosition == "left" )
1914 dock = DockLeft; 1916 dock = DockLeft;
1915 else if ( attrPosition == "right" ) 1917 else if ( attrPosition == "right" )
1916 dock = DockRight; 1918 dock = DockRight;
1917 else if ( attrPosition == "bottom" ) 1919 else if ( attrPosition == "bottom" )
1918 dock = DockBottom; 1920 dock = DockBottom;
1919 else if ( attrPosition == "floating" ) 1921 else if ( attrPosition == "floating" )
1920 dock = DockTornOff; 1922 dock = DockTornOff;
1921 else if ( attrPosition == "flat" ) 1923 else if ( attrPosition == "flat" )
1922 dock = DockMinimized; 1924 dock = DockMinimized;
1923 } 1925 }
1924 } 1926 }
1925 1927
1926 { 1928 {
1927 QCString attrIconText = element.attribute( "iconText" ).lower().latin1(); 1929 QCString attrIconText = element.attribute( "iconText" ).lower().latin1();
1928 if ( !attrIconText.isEmpty() ) { 1930 if ( !attrIconText.isEmpty() ) {
1929 //kdDebug(220) << "KToolBar::loadState attrIconText=" << attrIconText << endl; 1931 //kdDebug(220) << "KToolBar::loadState attrIconText=" << attrIconText << endl;
1930 if ( attrIconText == "icontextright" ) 1932 if ( attrIconText == "icontextright" )
1931 setIconText( KToolBar::IconTextRight ); 1933 setIconText( KToolBar::IconTextRight );
1932 else if ( attrIconText == "textonly" ) 1934 else if ( attrIconText == "textonly" )
1933 setIconText( KToolBar::TextOnly ); 1935 setIconText( KToolBar::TextOnly );
1934 else if ( attrIconText == "icontextbottom" ) 1936 else if ( attrIconText == "icontextbottom" )
1935 setIconText( KToolBar::IconTextBottom ); 1937 setIconText( KToolBar::IconTextBottom );
1936 else if ( attrIconText == "icononly" ) 1938 else if ( attrIconText == "icononly" )
1937 setIconText( KToolBar::IconOnly ); 1939 setIconText( KToolBar::IconOnly );
1938 } else 1940 } else
1939 // Use global setting 1941 // Use global setting
1940 setIconText( iconTextSetting() ); 1942 setIconText( iconTextSetting() );
1941 } 1943 }
1942 1944
1943 { 1945 {
1944 QString attrIconSize = element.attribute( "iconSize" ).lower(); 1946 QString attrIconSize = element.attribute( "iconSize" ).lower();
1945 if ( !attrIconSize.isEmpty() ) 1947 if ( !attrIconSize.isEmpty() )
1946 d->IconSizeDefault = attrIconSize.toInt(); 1948 d->IconSizeDefault = attrIconSize.toInt();
1947 setIconSize( d->IconSizeDefault ); 1949 setIconSize( d->IconSizeDefault );
1948 } 1950 }
1949 1951
1950 { 1952 {
1951 QString attrIndex = element.attribute( "index" ).lower(); 1953 QString attrIndex = element.attribute( "index" ).lower();
1952 if ( !attrIndex.isEmpty() ) 1954 if ( !attrIndex.isEmpty() )
1953 d->IndexDefault = attrIndex.toInt(); 1955 d->IndexDefault = attrIndex.toInt();
1954 } 1956 }
1955 1957
1956 { 1958 {
1957 QString attrOffset = element.attribute( "offset" ).lower(); 1959 QString attrOffset = element.attribute( "offset" ).lower();
1958 if ( !attrOffset.isEmpty() ) 1960 if ( !attrOffset.isEmpty() )
1959 d->OffsetDefault = attrOffset.toInt(); 1961 d->OffsetDefault = attrOffset.toInt();
1960 } 1962 }
1961 1963
1962 { 1964 {
1963 QString attrNewLine = element.attribute( "newline" ).lower(); 1965 QString attrNewLine = element.attribute( "newline" ).lower();
1964 if ( !attrNewLine.isEmpty() ) 1966 if ( !attrNewLine.isEmpty() )
1965 d->NewLineDefault = attrNewLine == "true"; 1967 d->NewLineDefault = attrNewLine == "true";
1966 } 1968 }
1967 1969
1968 { 1970 {
1969 QString attrHidden = element.attribute( "hidden" ).lower(); 1971 QString attrHidden = element.attribute( "hidden" ).lower();
1970 if ( !attrHidden.isEmpty() ) 1972 if ( !attrHidden.isEmpty() )
1971 d->HiddenDefault = attrHidden == "true"; 1973 d->HiddenDefault = attrHidden == "true";
1972 } 1974 }
1973 1975
1974 d->toolBarInfo = KToolBarPrivate::ToolBarInfo( dock, d->IndexDefault, d->NewLineDefault, d->OffsetDefault ); 1976 d->toolBarInfo = KToolBarPrivate::ToolBarInfo( dock, d->IndexDefault, d->NewLineDefault, d->OffsetDefault );
1975 mainWindow()->addDockWindow( this, dock, d->NewLineDefault ); 1977 mainWindow()->addDockWindow( this, dock, d->NewLineDefault );
1976//US mainWindow()->moveDockWindow( this, dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault ); 1978//US mainWindow()->moveDockWindow( this, dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault );
1977 mainWindow()->moveToolBar( this, dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault ); 1979 mainWindow()->moveToolBar( this, dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault );
1978 1980
1979 // Apply the highlight button setting 1981 // Apply the highlight button setting
1980 d->m_highlight = highlightSetting(); 1982 d->m_highlight = highlightSetting();
1981 1983
1982 // Apply transparent-toolbar-moving setting (ok, this is global to the mainwindow, 1984 // Apply transparent-toolbar-moving setting (ok, this is global to the mainwindow,
1983 // but we do it only if there are toolbars...) 1985 // but we do it only if there are toolbars...)
1984 if ( transparentSetting() != !mainWindow()->opaqueMoving() ) 1986 if ( transparentSetting() != !mainWindow()->opaqueMoving() )
1985 mainWindow()->setOpaqueMoving( !transparentSetting() ); 1987 mainWindow()->setOpaqueMoving( !transparentSetting() );
1986 1988
1987 if ( d->HiddenDefault ) 1989 if ( d->HiddenDefault )
1988 hide(); 1990 hide();
1989 else 1991 else
1990 show(); 1992 show();
1991 1993
1992 getAttributes( d->PositionDefault, d->IconTextDefault, d->IndexDefault ); 1994 getAttributes( d->PositionDefault, d->IconTextDefault, d->IndexDefault );
1993} 1995}
1994*/ 1996*/
1995 1997
1996void KToolBar::getAttributes( QString &position, QString &icontext, int &index ) 1998void KToolBar::getAttributes( QString &position, QString &icontext, int &index )
1997{ 1999{
1998 // get all of the stuff to save 2000 // get all of the stuff to save
1999 switch ( barPos() ) { 2001 switch ( barPos() ) {
2000 case KToolBar::Flat: 2002 case KToolBar::Flat:
2001 position = "Flat"; 2003 position = "Flat";
2002 break; 2004 break;
2003 case KToolBar::Bottom: 2005 case KToolBar::Bottom:
2004 position = "Bottom"; 2006 position = "Bottom";
2005 break; 2007 break;
2006 case KToolBar::Left: 2008 case KToolBar::Left:
2007 position = "Left"; 2009 position = "Left";
2008 break; 2010 break;
2009 case KToolBar::Right: 2011 case KToolBar::Right:
2010 position = "Right"; 2012 position = "Right";
2011 break; 2013 break;
2012 case KToolBar::Floating: 2014 case KToolBar::Floating:
2013 position = "Floating"; 2015 position = "Floating";
2014 break; 2016 break;
2015 case KToolBar::Top: 2017 case KToolBar::Top:
2016 default: 2018 default:
2017 position = "Top"; 2019 position = "Top";
2018 break; 2020 break;
2019 } 2021 }
2020 2022
2021 if ( mainWindow() ) { 2023 if ( mainWindow() ) {
2022 QMainWindow::ToolBarDock dock; 2024 QMainWindow::ToolBarDock dock;
2023 bool newLine; 2025 bool newLine;
2024 int offset; 2026 int offset;
2025 mainWindow()->getLocation( this, dock, index, newLine, offset ); 2027 mainWindow()->getLocation( this, dock, index, newLine, offset );
2026 } 2028 }
2027 2029
2028 switch (d->m_iconText) { 2030 switch (d->m_iconText) {
2029 case KToolBar::IconTextRight: 2031 case KToolBar::IconTextRight:
2030 icontext = "IconTextRight"; 2032 icontext = "IconTextRight";
2031 break; 2033 break;
2032 case KToolBar::IconTextBottom: 2034 case KToolBar::IconTextBottom:
2033 icontext = "IconTextBottom"; 2035 icontext = "IconTextBottom";
2034 break; 2036 break;
2035 case KToolBar::TextOnly: 2037 case KToolBar::TextOnly:
2036 icontext = "TextOnly"; 2038 icontext = "TextOnly";
2037 break; 2039 break;
2038 case KToolBar::IconOnly: 2040 case KToolBar::IconOnly:
2039 default: 2041 default:
2040 icontext = "IconOnly"; 2042 icontext = "IconOnly";
2041 break; 2043 break;
2042 } 2044 }
2043} 2045}
2044/*US 2046/*US
2045void KToolBar::saveState( QDomElement &current ) 2047void KToolBar::saveState( QDomElement &current )
2046{ 2048{
2047 QString position, icontext; 2049 QString position, icontext;
2048 int index = -1; 2050 int index = -1;
2049 getAttributes( position, icontext, index ); 2051 getAttributes( position, icontext, index );
2050 2052
2051 current.setAttribute( "noMerge", "1" ); 2053 current.setAttribute( "noMerge", "1" );
2052 current.setAttribute( "position", position ); 2054 current.setAttribute( "position", position );
2053 current.setAttribute( "iconText", icontext ); 2055 current.setAttribute( "iconText", icontext );
2054 current.setAttribute( "index", index ); 2056 current.setAttribute( "index", index );
2055 current.setAttribute( "offset", offset() ); 2057 current.setAttribute( "offset", offset() );
2056 current.setAttribute( "newline", newLine() ); 2058 current.setAttribute( "newline", newLine() );
2057 if ( isHidden() ) 2059 if ( isHidden() )
2058 current.setAttribute( "hidden", "true" ); 2060 current.setAttribute( "hidden", "true" );
2059 d->modified = true; 2061 d->modified = true;
2060} 2062}
2061*/ 2063*/
2062 2064
2063void KToolBar::positionYourself( bool force ) 2065void KToolBar::positionYourself( bool force )
2064{ 2066{
2065 if (force) 2067 if (force)
2066 d->positioned = false; 2068 d->positioned = false;
2067 2069
2068 if ( d->positioned || !mainWindow() ) 2070 if ( d->positioned || !mainWindow() )
2069 { 2071 {
2070 //kdDebug(220) << "KToolBar::positionYourself d->positioned=true ALREADY DONE" << endl; 2072 //kdDebug(220) << "KToolBar::positionYourself d->positioned=true ALREADY DONE" << endl;
2071 return; 2073 return;
2072 } 2074 }
2073 // we can't test for ForceHide after moveDockWindow because QDockArea 2075 // we can't test for ForceHide after moveDockWindow because QDockArea
2074 // does a reparent() with showIt == true 2076 // does a reparent() with showIt == true
2075 bool doHide = isHidden(); 2077 bool doHide = isHidden();
2076 //kdDebug(220) << "positionYourself " << name() << " dock=" << d->toolBarInfo.dock << " newLine=" << d->toolBarInfo.newline << " offset=" << d->toolBarInfo.offset << endl; 2078 //kdDebug(220) << "positionYourself " << name() << " dock=" << d->toolBarInfo.dock << " newLine=" << d->toolBarInfo.newline << " offset=" << d->toolBarInfo.offset << endl;
2077/*US mainWindow()->moveDockWindow( this, d->toolBarInfo.dock, 2079/*US mainWindow()->moveDockWindow( this, d->toolBarInfo.dock,
2078 d->toolBarInfo.newline, 2080 d->toolBarInfo.newline,
2079 d->toolBarInfo.index, 2081 d->toolBarInfo.index,
2080 d->toolBarInfo.offset ); 2082 d->toolBarInfo.offset );
2081*/ 2083*/
2082 mainWindow()->moveToolBar( this, d->toolBarInfo.dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault ); 2084 mainWindow()->moveToolBar( this, d->toolBarInfo.dock, d->NewLineDefault, d->IndexDefault, d->OffsetDefault );
2083 2085
2084 if ( doHide ) 2086 if ( doHide )
2085 hide(); 2087 hide();
2086 // This method can only have an effect once - unless force is set 2088 // This method can only have an effect once - unless force is set
2087 d->positioned = TRUE; 2089 d->positioned = TRUE;
2088} 2090}
2089 2091
2090//US KPopupMenu *KToolBar::contextMenu() 2092//US KPopupMenu *KToolBar::contextMenu()
2091QPopupMenu *KToolBar::contextMenu() 2093QPopupMenu *KToolBar::contextMenu()
2092{ 2094{
2093 if ( context ) 2095 if ( context )
2094 return context; 2096 return context;
2095 2097
2096 // Construct our context popup menu. Name it qt_dockwidget_internal so it 2098 // Construct our context popup menu. Name it qt_dockwidget_internal so it
2097 // won't be deleted by QToolBar::clear(). 2099 // won't be deleted by QToolBar::clear().
2098//US context = new KPopupMenu( this, "qt_dockwidget_internal" ); 2100//US context = new KPopupMenu( this, "qt_dockwidget_internal" );
2099 context = new QPopupMenu( this, "qt_dockwidget_internal" ); 2101 context = new QPopupMenu( this, "qt_dockwidget_internal" );
2100//US context->insertTitle(i18n("Toolbar Menu")); 2102//US context->insertTitle(i18n("Toolbar Menu"));
2101 2103
2102//US KPopupMenu *orient = new KPopupMenu( context, "orient" ); 2104//US KPopupMenu *orient = new KPopupMenu( context, "orient" );
2103 QPopupMenu *orient = new QPopupMenu( context, "orient" ); 2105 QPopupMenu *orient = new QPopupMenu( context, "orient" );
2104 orient->insertItem( i18n("toolbar position string","Top"), CONTEXT_TOP ); 2106 orient->insertItem( i18n("toolbar position string","Top"), CONTEXT_TOP );
2105 orient->insertItem( i18n("toolbar position string","Left"), CONTEXT_LEFT ); 2107 orient->insertItem( i18n("toolbar position string","Left"), CONTEXT_LEFT );
2106 orient->insertItem( i18n("toolbar position string","Right"), CONTEXT_RIGHT ); 2108 orient->insertItem( i18n("toolbar position string","Right"), CONTEXT_RIGHT );
2107 orient->insertItem( i18n("toolbar position string","Bottom"), CONTEXT_BOTTOM ); 2109 orient->insertItem( i18n("toolbar position string","Bottom"), CONTEXT_BOTTOM );
2108 orient->insertSeparator(-1); 2110 orient->insertSeparator(-1);
2109 //orient->insertItem( i18n("toolbar position string","Floating"), CONTEXT_FLOAT ); 2111 //orient->insertItem( i18n("toolbar position string","Floating"), CONTEXT_FLOAT );
2110 orient->insertItem( i18n("min toolbar", "Flat"), CONTEXT_FLAT ); 2112 orient->insertItem( i18n("min toolbar", "Flat"), CONTEXT_FLAT );
2111 2113
2112//US KPopupMenu *mode = new KPopupMenu( context, "mode" ); 2114//US KPopupMenu *mode = new KPopupMenu( context, "mode" );
2113 QPopupMenu *mode = new QPopupMenu( context, "mode" ); 2115 QPopupMenu *mode = new QPopupMenu( context, "mode" );
2114 mode->insertItem( i18n("Icons Only"), CONTEXT_ICONS ); 2116 mode->insertItem( i18n("Icons Only"), CONTEXT_ICONS );
2115 mode->insertItem( i18n("Text Only"), CONTEXT_TEXT ); 2117 mode->insertItem( i18n("Text Only"), CONTEXT_TEXT );
2116 mode->insertItem( i18n("Text Alongside Icons"), CONTEXT_TEXTRIGHT ); 2118 mode->insertItem( i18n("Text Alongside Icons"), CONTEXT_TEXTRIGHT );
2117 mode->insertItem( i18n("Text Under Icons"), CONTEXT_TEXTUNDER ); 2119 mode->insertItem( i18n("Text Under Icons"), CONTEXT_TEXTUNDER );
2118 2120
2119//US KPopupMenu *size = new KPopupMenu( context, "size" ); 2121//US KPopupMenu *size = new KPopupMenu( context, "size" );
2120 QPopupMenu *size = new QPopupMenu( context, "size" ); 2122 QPopupMenu *size = new QPopupMenu( context, "size" );
2121 size->insertItem( i18n("Default"), CONTEXT_ICONSIZES ); 2123 size->insertItem( i18n("Default"), CONTEXT_ICONSIZES );
2122 // Query the current theme for available sizes 2124 // Query the current theme for available sizes
2123 QValueList<int> avSizes; 2125 QValueList<int> avSizes;
2124/*US 2126/*US
2125 KIconTheme *theme = KGlobal::instance()->iconLoader()->theme(); 2127 KIconTheme *theme = KGlobal::instance()->iconLoader()->theme();
2126 if (!::qstrcmp(QObject::name(), "mainToolBar")) 2128 if (!::qstrcmp(QObject::name(), "mainToolBar"))
2127 avSizes = theme->querySizes( KIcon::MainToolbar); 2129 avSizes = theme->querySizes( KIcon::MainToolbar);
2128 else 2130 else
2129 avSizes = theme->querySizes( KIcon::Toolbar); 2131 avSizes = theme->querySizes( KIcon::Toolbar);
2130*/ 2132*/
2131 avSizes << 16; 2133 avSizes << 16;
2132 avSizes << 32; 2134 avSizes << 32;
2133 2135
2134 d->iconSizes = avSizes; 2136 d->iconSizes = avSizes;
2135 2137
2136 QValueList<int>::Iterator it; 2138 QValueList<int>::Iterator it;
2137 for (it=avSizes.begin(); it!=avSizes.end(); it++) { 2139 for (it=avSizes.begin(); it!=avSizes.end(); it++) {
2138 QString text; 2140 QString text;
2139 if ( *it < 19 ) 2141 if ( *it < 19 )
2140 text = i18n("Small (%1x%2)").arg(*it).arg(*it); 2142 text = i18n("Small (%1x%2)").arg(*it).arg(*it);
2141 else if (*it < 25) 2143 else if (*it < 25)
2142 text = i18n("Medium (%1x%2)").arg(*it).arg(*it); 2144 text = i18n("Medium (%1x%2)").arg(*it).arg(*it);
2143 else 2145 else
2144 text = i18n("Large (%1x%2)").arg(*it).arg(*it); 2146 text = i18n("Large (%1x%2)").arg(*it).arg(*it);
2145 //we use the size as an id, with an offset 2147 //we use the size as an id, with an offset
2146 size->insertItem( text, CONTEXT_ICONSIZES + *it ); 2148 size->insertItem( text, CONTEXT_ICONSIZES + *it );
2147 } 2149 }
2148 2150
2149 context->insertItem( i18n("Orientation"), orient ); 2151 context->insertItem( i18n("Orientation"), orient );
2150 orient->setItemChecked(CONTEXT_TOP, true); 2152 orient->setItemChecked(CONTEXT_TOP, true);
2151 context->insertItem( i18n("Text Position"), mode ); 2153 context->insertItem( i18n("Text Position"), mode );
2152 context->setItemChecked(CONTEXT_ICONS, true); 2154 context->setItemChecked(CONTEXT_ICONS, true);
2153 context->insertItem( i18n("Icon Size"), size ); 2155 context->insertItem( i18n("Icon Size"), size );
2154 2156
2155/*US 2157/*US
2156 if (mainWindow()->inherits("KMainWindow")) 2158 if (mainWindow()->inherits("KMainWindow"))
2157 { 2159 {
2158 if ( (static_cast<KMainWindow*>(mainWindow())->toolBarMenuAction()) && 2160 if ( (static_cast<KMainWindow*>(mainWindow())->toolBarMenuAction()) &&
2159 (static_cast<KMainWindow*>(mainWindow())->hasMenuBar()) ) 2161 (static_cast<KMainWindow*>(mainWindow())->hasMenuBar()) )
2160 2162
2161 (static_cast<KMainWindow*>(mainWindow()))->toolBarMenuAction()->plug(context); 2163 (static_cast<KMainWindow*>(mainWindow()))->toolBarMenuAction()->plug(context);
2162 } 2164 }
2163*/ 2165*/
2164 2166
2165 connect( context, SIGNAL( aboutToShow() ), this, SLOT( slotContextAboutToShow() ) ); 2167 connect( context, SIGNAL( aboutToShow() ), this, SLOT( slotContextAboutToShow() ) );
2166 return context; 2168 return context;
2167} 2169}
2168 2170
2169void KToolBar::slotContextAboutToShow() 2171void KToolBar::slotContextAboutToShow()
2170{ 2172{
2171 if (!d->m_configurePlugged) 2173 if (!d->m_configurePlugged)
2172 { 2174 {
2173 // try to find "configure toolbars" action 2175 // try to find "configure toolbars" action
2174 2176
2175 KXMLGUIClient *xmlGuiClient = d->m_xmlguiClient; 2177 KXMLGUIClient *xmlGuiClient = d->m_xmlguiClient;
2176 if ( !xmlGuiClient && mainWindow() && mainWindow()->inherits( "KMainWindow" ) ) 2178 if ( !xmlGuiClient && mainWindow() && mainWindow()->inherits( "KMainWindow" ) )
2177 xmlGuiClient = (KXMLGUIClient *)mainWindow(); 2179 xmlGuiClient = (KXMLGUIClient *)mainWindow();
2178 if ( xmlGuiClient ) 2180 if ( xmlGuiClient )
2179 { 2181 {
2180 KAction *configureAction = xmlGuiClient->actionCollection()->action(KStdAction::stdName(KStdAction::ConfigureToolbars)); 2182 KAction *configureAction = xmlGuiClient->actionCollection()->action(KStdAction::stdName(KStdAction::ConfigureToolbars));
2181 if ( configureAction ) 2183 if ( configureAction )
2182 { 2184 {
2183 configureAction->plug(context); 2185 configureAction->plug(context);
2184 d->m_configurePlugged = true; 2186 d->m_configurePlugged = true;
2185 } 2187 }
2186 } 2188 }
2187 } 2189 }
2188 2190
2189 for(int i = CONTEXT_ICONS; i <= CONTEXT_TEXTUNDER; ++i) 2191 for(int i = CONTEXT_ICONS; i <= CONTEXT_TEXTUNDER; ++i)
2190 context->setItemChecked(i, false); 2192 context->setItemChecked(i, false);
2191 2193
2192 switch( d->m_iconText ) 2194 switch( d->m_iconText )
2193 { 2195 {
2194 case IconOnly: 2196 case IconOnly:
2195 default: 2197 default:
2196 context->setItemChecked(CONTEXT_ICONS, true); 2198 context->setItemChecked(CONTEXT_ICONS, true);
2197 break; 2199 break;
2198 case IconTextRight: 2200 case IconTextRight:
2199 context->setItemChecked(CONTEXT_TEXTRIGHT, true); 2201 context->setItemChecked(CONTEXT_TEXTRIGHT, true);
2200 break; 2202 break;
2201 case TextOnly: 2203 case TextOnly:
2202 context->setItemChecked(CONTEXT_TEXT, true); 2204 context->setItemChecked(CONTEXT_TEXT, true);
2203 break; 2205 break;
2204 case IconTextBottom: 2206 case IconTextBottom:
2205 context->setItemChecked(CONTEXT_TEXTUNDER, true); 2207 context->setItemChecked(CONTEXT_TEXTUNDER, true);
2206 break; 2208 break;
2207 } 2209 }
2208 2210
2209 QValueList<int>::ConstIterator iIt = d->iconSizes.begin(); 2211 QValueList<int>::ConstIterator iIt = d->iconSizes.begin();
2210 QValueList<int>::ConstIterator iEnd = d->iconSizes.end(); 2212 QValueList<int>::ConstIterator iEnd = d->iconSizes.end();
2211 for (; iIt != iEnd; ++iIt ) 2213 for (; iIt != iEnd; ++iIt )
2212 context->setItemChecked( CONTEXT_ICONSIZES + *iIt, false ); 2214 context->setItemChecked( CONTEXT_ICONSIZES + *iIt, false );
2213 2215
2214 context->setItemChecked( CONTEXT_ICONSIZES, false ); 2216 context->setItemChecked( CONTEXT_ICONSIZES, false );
2215 2217
2216 context->setItemChecked( CONTEXT_ICONSIZES + d->m_iconSize, true ); 2218 context->setItemChecked( CONTEXT_ICONSIZES + d->m_iconSize, true );
2217 2219
2218 for ( int i = CONTEXT_TOP; i <= CONTEXT_FLAT; ++i ) 2220 for ( int i = CONTEXT_TOP; i <= CONTEXT_FLAT; ++i )
2219 context->setItemChecked( i, false ); 2221 context->setItemChecked( i, false );
2220 2222
2221 switch ( barPos() ) 2223 switch ( barPos() )
2222 { 2224 {
2223 case KToolBar::Flat: 2225 case KToolBar::Flat:
2224 context->setItemChecked( CONTEXT_FLAT, true ); 2226 context->setItemChecked( CONTEXT_FLAT, true );
2225 break; 2227 break;
2226 case KToolBar::Bottom: 2228 case KToolBar::Bottom:
2227 context->setItemChecked( CONTEXT_BOTTOM, true ); 2229 context->setItemChecked( CONTEXT_BOTTOM, true );
2228 break; 2230 break;
2229 case KToolBar::Left: 2231 case KToolBar::Left:
2230 context->setItemChecked( CONTEXT_LEFT, true ); 2232 context->setItemChecked( CONTEXT_LEFT, true );
2231 break; 2233 break;
2232 case KToolBar::Right: 2234 case KToolBar::Right:
2233 context->setItemChecked( CONTEXT_RIGHT, true ); 2235 context->setItemChecked( CONTEXT_RIGHT, true );
2234 break; 2236 break;
2235 case KToolBar::Floating: 2237 case KToolBar::Floating:
2236 context->setItemChecked( CONTEXT_FLOAT, true ); 2238 context->setItemChecked( CONTEXT_FLOAT, true );
2237 break; 2239 break;
2238 case KToolBar::Top: 2240 case KToolBar::Top:
2239 context->setItemChecked( CONTEXT_TOP, true ); 2241 context->setItemChecked( CONTEXT_TOP, true );
2240 break; 2242 break;
2241 default: break; 2243 default: break;
2242 } 2244 }
2243} 2245}
2244 2246
2245void KToolBar::widgetDestroyed() 2247void KToolBar::widgetDestroyed()
2246{ 2248{
2247 removeWidgetInternal( (QWidget*)sender() ); 2249 removeWidgetInternal( (QWidget*)sender() );
2248} 2250}
2249 2251
2250void KToolBar::removeWidgetInternal( QWidget * w ) 2252void KToolBar::removeWidgetInternal( QWidget * w )
2251{ 2253{
2252 if ( inshutdownprocess ) 2254 if ( inshutdownprocess )
2253 return; 2255 return;
2254 widgets.removeRef( w ); 2256 widgets.removeRef( w );
2255 QMap< QWidget*, int >::Iterator it = widget2id.find( w ); 2257 QMap< QWidget*, int >::Iterator it = widget2id.find( w );
2256 if ( it == widget2id.end() ) 2258 if ( it == widget2id.end() )
2257 return; 2259 return;
2258 id2widget.remove( *it ); 2260 id2widget.remove( *it );
2259 widget2id.remove( it ); 2261 widget2id.remove( it );
2260} 2262}
2261 2263
2262void KToolBar::virtual_hook( int, void* ) 2264void KToolBar::virtual_hook( int, void* )
2263{ /*BASE::virtual_hook( id, data );*/ } 2265{ /*BASE::virtual_hook( id, data );*/ }
2264 2266
2265//US #include "ktoolbar.moc" 2267//US #include "ktoolbar.moc"
2266 2268