author | zautrix <zautrix> | 2005-04-02 12:16:34 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-04-02 12:16:34 (UTC) |
commit | 997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe (patch) (unidiff) | |
tree | f788b37459574b5cea0d2ab874882c6a396c240d | |
parent | e0d51120d2f0c178115746e0c1357af40f95bc77 (diff) | |
download | kdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.zip kdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.tar.gz kdepimpi-997e7660a81baa2b8aeb1b66a3cc3ebe54e00ebe.tar.bz2 |
more fixes
-rw-r--r-- | kaddressbook/kabcore.cpp | 5 | ||||
-rw-r--r-- | kaddressbook/viewmanager.cpp | 2 | ||||
-rw-r--r-- | kaddressbook/views/colorlistbox.cpp | 7 | ||||
-rw-r--r-- | kaddressbook/views/colorlistbox.h | 1 | ||||
-rw-r--r-- | kaddressbook/views/configurecardviewdialog.cpp | 4 | ||||
-rw-r--r-- | kaddressbook/views/configuretableviewdialog.cpp | 6 | ||||
-rw-r--r-- | korganizer/koagenda.cpp | 57 | ||||
-rw-r--r-- | korganizer/koagenda.h | 4 | ||||
-rw-r--r-- | korganizer/koagendaview.cpp | 18 | ||||
-rw-r--r-- | korganizer/koagendaview.h | 4 | ||||
-rw-r--r-- | korganizer/kotodoview.cpp | 49 | ||||
-rw-r--r-- | microkde/kcolordialog.cpp | 1 | ||||
-rw-r--r-- | microkde/kdeui/ktoolbar.cpp | 2 |
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 |
25 | Enhanced Version of the file for platform independent KDE tools. | 25 | Enhanced Version of the file for platform independent KDE tools. |
26 | Copyright (c) 2004 Ulf Schenk | 26 | Copyright (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 | ||
169 | class KABCatPrefs : public QDialog | 169 | class 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(); } |
197 | private: | 197 | private: |
198 | QRadioButton* addCatBut; | 198 | QRadioButton* addCatBut; |
199 | }; | 199 | }; |
200 | 200 | ||
201 | class KABFormatPrefs : public QDialog | 201 | class 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 | } |
232 | public: | 232 | public: |
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 | ||
239 | class KAex2phonePrefs : public QDialog | 239 | class 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 | ||
279 | public: | 279 | public: |
280 | QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel; | 280 | QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel; |
281 | QCheckBox* mWriteToSim; | 281 | QCheckBox* mWriteToSim; |
282 | }; | 282 | }; |
283 | 283 | ||
284 | 284 | ||
285 | bool pasteWithNewUid = true; | 285 | bool pasteWithNewUid = true; |
286 | 286 | ||
287 | #ifdef KAB_EMBEDDED | 287 | #ifdef KAB_EMBEDDED |
288 | KABCore::KABCore( KAddressBookMain *client, bool readWrite, QWidget *parent, const char *name ) | 288 | KABCore::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 |
293 | KABCore::KABCore( KXMLGUIClient *client, bool readWrite, QWidget *parent, const char *name ) | 293 | KABCore::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 | ||
407 | void KABCore::updateToolBar() | 407 | void 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 | } |
415 | KABCore::~KABCore() | 415 | KABCore::~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 | } |
430 | void KABCore::receive( const QCString& cmsg, const QByteArray& data ) | 430 | void 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 | } |
441 | void KABCore::toggleBeamReceive( ) | 441 | void 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 | ||
462 | void KABCore::disableBR(bool b) | 462 | void 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 | } |
479 | void KABCore::recieve( QString fn ) | 479 | void 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 | } |
490 | void KABCore::restoreSettings() | 490 | void 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 | ||
556 | void KABCore::saveSettings() | 556 | void 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 | ||
576 | KABC::AddressBook *KABCore::addressBook() const | 576 | KABC::AddressBook *KABCore::addressBook() const |
577 | { | 577 | { |
578 | return mAddressBook; | 578 | return mAddressBook; |
579 | } | 579 | } |
580 | 580 | ||
581 | KConfig *KABCore::config() | 581 | KConfig *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 | ||
590 | KActionCollection *KABCore::actionCollection() const | 590 | KActionCollection *KABCore::actionCollection() const |
591 | { | 591 | { |
592 | return mGUIClient->actionCollection(); | 592 | return mGUIClient->actionCollection(); |
593 | } | 593 | } |
594 | 594 | ||
595 | KABC::Field *KABCore::currentSearchField() const | 595 | KABC::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 | ||
603 | QStringList KABCore::selectedUIDs() const | 603 | QStringList KABCore::selectedUIDs() const |
604 | { | 604 | { |
605 | return mViewManager->selectedUids(); | 605 | return mViewManager->selectedUids(); |
606 | } | 606 | } |
607 | 607 | ||
608 | KABC::Resource *KABCore::requestResource( QWidget *parent ) | 608 | KABC::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 |
629 | KAboutData *KABCore::createAboutData() | 629 | KAboutData *KABCore::createAboutData() |
630 | #else //KAB_EMBEDDED | 630 | #else //KAB_EMBEDDED |
631 | void KABCore::createAboutData() | 631 | void 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 | ||
685 | void KABCore::setContactSelected( const QString &uid ) | 685 | void 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 | ||
728 | void KABCore::sendMail() | 728 | void KABCore::sendMail() |
729 | { | 729 | { |
730 | sendMail( mViewManager->selectedEmails().join( ", " ) ); | 730 | sendMail( mViewManager->selectedEmails().join( ", " ) ); |
731 | } | 731 | } |
732 | 732 | ||
733 | void KABCore::sendMail( const QString& emaillist ) | 733 | void 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 | ||
744 | void KABCore::mailVCard() | 744 | void 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 | ||
751 | void KABCore::mailVCard( const QStringList& uids ) | 751 | void 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 | */ |
807 | void KABCore::beamMySelf() | 807 | void 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 | } |
822 | void KABCore::updateMainWindow() | 822 | void KABCore::updateMainWindow() |
823 | { | 823 | { |
824 | mMainWindow->showMaximized(); | 824 | mMainWindow->showMaximized(); |
825 | mMainWindow->update(); | 825 | mMainWindow->update(); |
826 | } | 826 | } |
827 | void KABCore::resizeEvent(QResizeEvent* e ) | 827 | void 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 | } |
869 | void KABCore::export2phone() | 869 | void 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 | } |
907 | QString KABCore::getPhoneFile() | 907 | QString 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 | } |
916 | void KABCore::writeToPhone( ) | 916 | void 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 | } |
923 | void KABCore::beamVCard() | 923 | void 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 | ||
937 | void KABCore::beamVCard(const QStringList& uids) | 937 | void 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 | ||
999 | void KABCore::beamDone( Ir *ir ) | 999 | void 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 | ||
1009 | void KABCore::browse( const QString& url ) | 1009 | void 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 | ||
1018 | void KABCore::selectAllContacts() | 1018 | void KABCore::selectAllContacts() |
1019 | { | 1019 | { |
1020 | mViewManager->setSelected( QString::null, true ); | 1020 | mViewManager->setSelected( QString::null, true ); |
1021 | } | 1021 | } |
1022 | 1022 | ||
1023 | void KABCore::deleteContacts() | 1023 | void KABCore::deleteContacts() |
1024 | { | 1024 | { |
1025 | QStringList uidList = mViewManager->selectedUids(); | 1025 | QStringList uidList = mViewManager->selectedUids(); |
1026 | deleteContacts( uidList ); | 1026 | deleteContacts( uidList ); |
1027 | } | 1027 | } |
1028 | 1028 | ||
1029 | void KABCore::deleteContacts( const QStringList &uids ) | 1029 | void 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 | ||
1042 | void KABCore::copyContacts() | 1042 | void 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 | ||
1054 | void KABCore::cutContacts() | 1054 | void 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 | ||
1068 | void KABCore::pasteContacts() | 1068 | void 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 | ||
1077 | void KABCore::pasteContacts( KABC::Addressee::List &list ) | 1077 | void 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 | ||
1091 | void KABCore::setWhoAmI() | 1091 | void 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 | } |
1104 | void KABCore::editCategories() | 1104 | void 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 | } |
1109 | void KABCore::setCategories() | 1109 | void 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 | ||
1161 | void KABCore::setSearchFields( const KABC::Field::List &fields ) | 1161 | void KABCore::setSearchFields( const KABC::Field::List &fields ) |
1162 | { | 1162 | { |
1163 | mIncSearchWidget->setFields( fields ); | 1163 | mIncSearchWidget->setFields( fields ); |
1164 | } | 1164 | } |
1165 | 1165 | ||
1166 | void KABCore::incrementalSearch( const QString& text ) | 1166 | void 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 | } |
1176 | void KABCore::incrementalSearchJump( const QString& text ) | 1176 | void KABCore::incrementalSearchJump( const QString& text ) |
1177 | { | 1177 | { |
1178 | mViewManager->doSearch( text, mIncSearchWidget->currentField() ); | 1178 | mViewManager->doSearch( text, mIncSearchWidget->currentField() ); |
1179 | } | 1179 | } |
1180 | 1180 | ||
1181 | void KABCore::setModified() | 1181 | void KABCore::setModified() |
1182 | { | 1182 | { |
1183 | setModified( true ); | 1183 | setModified( true ); |
1184 | } | 1184 | } |
1185 | 1185 | ||
1186 | void KABCore::setModifiedWOrefresh() | 1186 | void 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 | } |
1194 | void KABCore::setModified( bool modified ) | 1194 | void 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 | ||
1206 | bool KABCore::modified() const | 1206 | bool KABCore::modified() const |
1207 | { | 1207 | { |
1208 | return mModified; | 1208 | return mModified; |
1209 | } | 1209 | } |
1210 | 1210 | ||
1211 | void KABCore::contactModified( const KABC::Addressee &addr ) | 1211 | void 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 | ||
1220 | void KABCore::addrModified( const KABC::Addressee &addr ,bool updateDetails ) | 1220 | void 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 | ||
1242 | void KABCore::newContact() | 1242 | void 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 | ||
1278 | void KABCore::addEmail( QString aStr ) | 1278 | void 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 | ||
1312 | void KABCore::importVCard( const KURL &url, bool showPreview ) | 1312 | void KABCore::importVCard( const KURL &url, bool showPreview ) |
1313 | { | 1313 | { |
1314 | mXXPortManager->importVCard( url, showPreview ); | 1314 | mXXPortManager->importVCard( url, showPreview ); |
1315 | } | 1315 | } |
1316 | void KABCore::importFromOL() | 1316 | void 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 | ||
1345 | void KABCore::importVCard( const QString &vCard, bool showPreview ) | 1345 | void 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 |
1351 | void KABCore::editContact2() { | 1351 | void KABCore::editContact2() { |
1352 | editContact( QString::null ); | 1352 | editContact( QString::null ); |
1353 | } | 1353 | } |
1354 | 1354 | ||
1355 | void KABCore::editContact( const QString &uid ) | 1355 | void 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 | */ |
1380 | void KABCore::executeContact( const QString &uid /*US = QString::null*/ ) | 1380 | void 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 | ||
1394 | void KABCore::save() | 1394 | void 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 | ||
1425 | void KABCore::undo() | 1425 | void 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 | ||
1433 | void KABCore::redo() | 1433 | void 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 | } |
1440 | void KABCore::setJumpButtonBar( bool visible ) | 1440 | void KABCore::setJumpButtonBar( bool visible ) |
1441 | { | 1441 | { |
1442 | setJumpButtonBarVisible(visible ); | 1442 | setJumpButtonBarVisible(visible ); |
1443 | saveSettings(); | 1443 | saveSettings(); |
1444 | } | 1444 | } |
1445 | void KABCore::setJumpButtonBarVisible( bool visible ) | 1445 | void 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 | ||
1477 | void KABCore::setDetailsToState() | 1477 | void KABCore::setDetailsToState() |
1478 | { | 1478 | { |
1479 | setDetailsVisible( mActionDetails->isChecked() ); | 1479 | setDetailsVisible( mActionDetails->isChecked() ); |
1480 | } | 1480 | } |
1481 | void KABCore::setDetailsToggle() | 1481 | void 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 | ||
1489 | void KABCore::setDetailsVisible( bool visible ) | 1489 | void 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 | ||
1524 | void KABCore::extensionChanged( int id ) | 1524 | void 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 | ||
1566 | void KABCore::extensionModified( const KABC::Addressee::List &list ) | 1566 | void 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 | ||
1587 | QString KABCore::getNameByPhone( const QString &phone ) | 1587 | QString 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 | ||
1618 | void KABCore::openConfigDialog() | 1618 | void 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 | ||
1639 | void KABCore::openLDAPDialog() | 1639 | void 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 | ||
1658 | void KABCore::print() | 1658 | void 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 | ||
1676 | void KABCore::addGUIClient( KXMLGUIClient *client ) | 1676 | void 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 | ||
1685 | void KABCore::configurationChanged() | 1685 | void KABCore::configurationChanged() |
1686 | { | 1686 | { |
1687 | mExtensionManager->reconfigure(); | 1687 | mExtensionManager->reconfigure(); |
1688 | } | 1688 | } |
1689 | 1689 | ||
1690 | void KABCore::addressBookChanged() | 1690 | void 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 | ||
1720 | AddresseeEditorDialog *KABCore::createAddresseeEditorDialog( QWidget *parent, | 1720 | AddresseeEditorDialog *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 | ||
1738 | void KABCore::slotEditorDestroyed( const QString &uid ) | 1738 | void KABCore::slotEditorDestroyed( const QString &uid ) |
1739 | { | 1739 | { |
1740 | //mEditorDict.remove( uid ); | 1740 | //mEditorDict.remove( uid ); |
1741 | } | 1741 | } |
1742 | 1742 | ||
1743 | void KABCore::initGUI() | 1743 | void 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 | } |
1911 | void KABCore::initActions() | 1911 | void 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. |
2123 | void KABCore::addActionsManually() | 2123 | void 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 | } |
2322 | void KABCore::showLicence() | 2323 | void KABCore::showLicence() |
2323 | { | 2324 | { |
2324 | KApplication::showLicence(); | 2325 | KApplication::showLicence(); |
2325 | } | 2326 | } |
2326 | 2327 | ||
2327 | void KABCore::manageCategories( ) | 2328 | void 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 | } |
2393 | void KABCore::removeVoice() | 2394 | void 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 | ||
2420 | void KABCore::setFormattedName() | 2421 | void 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 | ||
2462 | void KABCore::clipboardDataChanged() | 2463 | void 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 | ||
2470 | void KABCore::updateActionMenu() | 2471 | void 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 | ||
2490 | void KABCore::configureKeyBindings() | 2491 | void 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 |
2500 | void KABCore::configureResources() | 2501 | void 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 | */ |
2514 | void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid) | 2515 | void 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 | } |
2542 | void KABCore::resizeAndCallContactdialog() | 2543 | void 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 | ||
2548 | void KABCore::callContactdialog() | 2549 | void 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 | */ |
2570 | void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid) | 2571 | void 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 | */ |
2637 | void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid) | 2638 | void 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 | ||
2726 | void KABCore::whatsnew() | 2727 | void 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 | } |
2730 | void KABCore::synchowto() | 2731 | void 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 | } |
2734 | void KABCore::kdesynchowto() | 2735 | void 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 | } |
2738 | void KABCore::multisynchowto() | 2739 | void 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 | } |
2742 | void KABCore::faq() | 2743 | void 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 | ||
2749 | KABC::Addressee KABCore::getLastSyncAddressee() | 2750 | KABC::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 | } |
2769 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) | 2770 | int 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 | ||
2898 | bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode) | 2899 | bool 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 |
3208 | bool KABCore::sync(KSyncManager* manager, QString filename, int mode) | 3209 | bool 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 | } |
3270 | void KABCore::removeSyncInfo( QString syncProfile) | 3271 | void 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 |
3279 | bool KABCore::syncExternal(KSyncManager* manager, QString resource) | 3280 | bool 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 | } |
3320 | void KABCore::message( QString m, bool startTimer) | 3321 | void 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 | } |
3329 | bool KABCore::syncPhone() | 3330 | bool 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 | } |
3363 | void KABCore::getFile( bool success ) | 3364 | void 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 | } |
3375 | void KABCore::syncFileRequest() | 3376 | void 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 | } |
3382 | QString KABCore::sentSyncFile() | 3383 | QString 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 | ||
3391 | void KABCore::setCaptionBack() | 3392 | void 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 | /* |
25 | Enhanced Version of the file for platform independent KDE tools. | 25 | Enhanced Version of the file for platform independent KDE tools. |
26 | Copyright (c) 2004 Ulf Schenk | 26 | Copyright (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 | ||
73 | ViewManager::ViewManager( KABCore *core, QWidget *parent, const char *name ) | 73 | ViewManager::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 | ||
84 | ViewManager::~ViewManager() | 84 | ViewManager::~ViewManager() |
85 | { | 85 | { |
86 | unloadViews(); | 86 | unloadViews(); |
87 | mViewFactoryDict.clear(); | 87 | mViewFactoryDict.clear(); |
88 | } | 88 | } |
89 | void ViewManager::scrollUP() | 89 | void ViewManager::scrollUP() |
90 | { | 90 | { |
91 | if ( mActiveView ) | 91 | if ( mActiveView ) |
92 | mActiveView->scrollUP(); | 92 | mActiveView->scrollUP(); |
93 | } | 93 | } |
94 | void ViewManager::scrollDOWN() | 94 | void ViewManager::scrollDOWN() |
95 | { | 95 | { |
96 | if ( mActiveView ) | 96 | if ( mActiveView ) |
97 | mActiveView->scrollDOWN(); | 97 | mActiveView->scrollDOWN(); |
98 | } | 98 | } |
99 | void ViewManager::restoreSettings() | 99 | void 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 | ||
128 | void ViewManager::saveSettings() | 128 | void 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 | ||
151 | QStringList ViewManager::selectedUids() const | 151 | QStringList 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 | ||
159 | QStringList ViewManager::selectedEmails() const | 159 | QStringList 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 | ||
167 | KABC::Addressee::List ViewManager::selectedAddressees() const | 167 | KABC::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. |
183 | void ViewManager::setSelected() | 183 | void ViewManager::setSelected() |
184 | { | 184 | { |
185 | setSelected( QString::null, true ); | 185 | setSelected( QString::null, true ); |
186 | } | 186 | } |
187 | 187 | ||
188 | void ViewManager::setSelected( const QString &uid, bool selected ) | 188 | void 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 | ||
194 | void ViewManager::setListSelected(QStringList list) | 194 | void 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 | } |
201 | void ViewManager::unloadViews() | 201 | void ViewManager::unloadViews() |
202 | { | 202 | { |
203 | mViewDict.clear(); | 203 | mViewDict.clear(); |
204 | mActiveView = 0; | 204 | mActiveView = 0; |
205 | } | 205 | } |
206 | 206 | ||
207 | void ViewManager::selectView( const QString &name ) | 207 | void ViewManager::selectView( const QString &name ) |
208 | { | 208 | { |
209 | setActiveView( name ); | 209 | setActiveView( name ); |
210 | mCore->saveSettings(); | 210 | mCore->saveSettings(); |
211 | } | 211 | } |
212 | void ViewManager::setActiveView( const QString &name ) | 212 | void 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. |
299 | void ViewManager::refreshView() | 299 | void ViewManager::refreshView() |
300 | { | 300 | { |
301 | refreshView( QString::null ); | 301 | refreshView( QString::null ); |
302 | } | 302 | } |
303 | 303 | ||
304 | void ViewManager::refreshView( const QString &uid ) | 304 | void 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 | ||
310 | void ViewManager::setFocusAV() | 310 | void ViewManager::setFocusAV() |
311 | { | 311 | { |
312 | if ( mActiveView ) | 312 | if ( mActiveView ) |
313 | mActiveView->setFocusAV(); | 313 | mActiveView->setFocusAV(); |
314 | } | 314 | } |
315 | void ViewManager::editView() | 315 | void 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 | ||
376 | void ViewManager::deleteView() | 376 | void 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 | ||
407 | void ViewManager::addView() | 407 | void 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 | ||
451 | void ViewManager::createViewFactories() | 451 | void 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 | ||
494 | void ViewManager::dropped( QDropEvent *e ) | 494 | void 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 |
531 | qDebug("ViewManager::dropped() has to be changed!!" ); | 531 | qDebug("ViewManager::dropped() has to be changed!!" ); |
532 | #endif //KAB_EMBEDDED | 532 | #endif //KAB_EMBEDDED |
533 | 533 | ||
534 | } | 534 | } |
535 | 535 | ||
536 | void ViewManager::startDrag() | 536 | void 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 |
565 | qDebug("ViewManager::startDrag() has to be changed!!" ); | 565 | qDebug("ViewManager::startDrag() has to be changed!!" ); |
566 | #endif //KAB_EMBEDDED | 566 | #endif //KAB_EMBEDDED |
567 | 567 | ||
568 | } | 568 | } |
569 | void ViewManager::doSearch( const QString& s,KABC::Field *field ) | 569 | void 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 | } |
575 | void ViewManager::setActiveFilter( int index ) | 575 | void 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 | ||
593 | void ViewManager::configureFilters() | 593 | void 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 | ||
613 | QStringList ViewManager::filterNames() const | 613 | QStringList 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 | } |
623 | Filter ViewManager::getFilterByName( const QString &name ) const | 623 | Filter 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 | ||
633 | int ViewManager::filterPosition( const QString &name ) const | 633 | int 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 | ||
645 | void ViewManager::initActions() | 645 | void 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 | ||
728 | void ViewManager::initGUI() | 728 | void 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 | ||
31 | ColorListBox::ColorListBox( QWidget *parent, const char *name, WFlags f ) | 31 | ColorListBox::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 | ||
39 | void ColorListBox::setEnabled( bool state ) | 40 | void 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 | ||
54 | void ColorListBox::setColor( uint index, const QColor &color ) | 55 | void 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 | ||
65 | QColor ColorListBox::color( uint index ) const | 66 | QColor 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 | 78 | void ColorListBox::slotNewColor(QListBoxItem * i) | |
79 | { | ||
80 | if ( i ) | ||
81 | newColor( index( i ) ); | ||
82 | } | ||
78 | 83 | ||
79 | void ColorListBox::newColor( int index ) | 84 | void 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 | ||
108 | void ColorListBox::dragEnterEvent( QDragEnterEvent *e ) | 113 | void 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 |
122 | qDebug("ColorListBox::dragEnterEvent drag&drop currently not supported"); | 127 | qDebug("ColorListBox::dragEnterEvent drag&drop currently not supported"); |
123 | #endif //KAB_EMBEDDED | 128 | #endif //KAB_EMBEDDED |
124 | 129 | ||
125 | } | 130 | } |
126 | 131 | ||
127 | 132 | ||
128 | void ColorListBox::dragLeaveEvent( QDragLeaveEvent * ) | 133 | void 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 |
138 | qDebug("ColorListBox::dragLeaveEvent drag&drop currently not supported"); | 143 | qDebug("ColorListBox::dragLeaveEvent drag&drop currently not supported"); |
139 | #endif //KAB_EMBEDDED | 144 | #endif //KAB_EMBEDDED |
140 | } | 145 | } |
141 | 146 | ||
142 | 147 | ||
143 | void ColorListBox::dragMoveEvent( QDragMoveEvent *e ) | 148 | void 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 |
155 | qDebug("ColorListBox::dragMoveEvent drag&drop currently not supported"); | 160 | qDebug("ColorListBox::dragMoveEvent drag&drop currently not supported"); |
156 | #endif //KAB_EMBEDDED | 161 | #endif //KAB_EMBEDDED |
157 | 162 | ||
158 | } | 163 | } |
159 | 164 | ||
160 | 165 | ||
161 | void ColorListBox::dropEvent( QDropEvent *e ) | 166 | void 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 |
178 | qDebug("ColorListBox::dropEvent drag&drop currently not supported"); | 183 | qDebug("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 | ||
185 | ColorListItem::ColorListItem( const QString &text, const QColor &color ) | 190 | ColorListItem::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 | ||
192 | const QColor &ColorListItem::color( void ) | 197 | const QColor &ColorListItem::color( void ) |
193 | { | 198 | { |
194 | return( mColor ); | 199 | return( mColor ); |
195 | } | 200 | } |
196 | 201 | ||
197 | 202 | ||
198 | void ColorListItem::setColor( const QColor &color ) | 203 | void ColorListItem::setColor( const QColor &color ) |
199 | { | 204 | { |
200 | mColor = color; | 205 | mColor = color; |
201 | } | 206 | } |
202 | 207 | ||
203 | 208 | ||
204 | void ColorListItem::paint( QPainter *p ) | 209 | void 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 | ||
217 | int ColorListItem::height(const QListBox *lb ) const | 222 | int 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 | ||
223 | int ColorListItem::width(const QListBox *lb ) const | 228 | int 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 | ||
26 | class QDragEnterEvent; | 26 | class QDragEnterEvent; |
27 | class QDragLeaveEvent; | 27 | class QDragLeaveEvent; |
28 | class QDragMoveEvent; | 28 | class QDragMoveEvent; |
29 | class QDropEvent; | 29 | class QDropEvent; |
30 | 30 | ||
31 | class ColorListBox : public KListBox | 31 | class 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 | ||
58 | class ColorListItem : public QListBoxItem | 59 | class 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 | ||
55 | ConfigureCardViewWidget::ConfigureCardViewWidget( KABC::AddressBook *ab, QWidget *parent, | 55 | ConfigureCardViewWidget::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 | ||
71 | ConfigureCardViewWidget::~ConfigureCardViewWidget() | 71 | ConfigureCardViewWidget::~ConfigureCardViewWidget() |
72 | { | 72 | { |
73 | } | 73 | } |
74 | 74 | ||
75 | void ConfigureCardViewWidget::restoreSettings( KConfig *config ) | 75 | void 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 | ||
82 | void ConfigureCardViewWidget::saveSettings( KConfig *config ) | 82 | void 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 |
91 | CardViewLookNFeelPage::CardViewLookNFeelPage( QWidget *parent, const char *name ) | 91 | CardViewLookNFeelPage::CardViewLookNFeelPage( QWidget *parent, const char *name ) |
92 | : QVBox( parent, name ) | 92 | : QVBox( parent, name ) |
93 | { | 93 | { |
94 | initGUI(); | 94 | initGUI(); |
95 | } | 95 | } |
96 | 96 | ||
97 | CardViewLookNFeelPage::~CardViewLookNFeelPage() | 97 | CardViewLookNFeelPage::~CardViewLookNFeelPage() |
98 | { | 98 | { |
99 | } | 99 | } |
100 | 100 | ||
101 | void CardViewLookNFeelPage::restoreSettings( KConfig *config ) | 101 | void 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; |
106 | qDebug("CardViewLookNFeelPage::restoreSettings make base color configurable"); | 106 | qDebug("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 | ||
155 | void CardViewLookNFeelPage::saveSettings( KConfig *config ) | 155 | void 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 | ||
187 | void CardViewLookNFeelPage::setTextFont() | 187 | void 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 | ||
201 | void CardViewLookNFeelPage::setHeaderFont() | 201 | void 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 | ||
215 | void CardViewLookNFeelPage::enableFonts() | 215 | void 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 | ||
220 | void CardViewLookNFeelPage::enableColors() | 222 | void 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 | ||
225 | void CardViewLookNFeelPage::initGUI() | 229 | void 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 | ||
357 | void CardViewLookNFeelPage::updateFontLabel( QFont fnt, QLabel *l ) | 361 | void 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 | ||
54 | ConfigureTableViewWidget::ConfigureTableViewWidget( KABC::AddressBook *ab, | 54 | ConfigureTableViewWidget::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 | ||
66 | ConfigureTableViewWidget::~ConfigureTableViewWidget() | 66 | ConfigureTableViewWidget::~ConfigureTableViewWidget() |
67 | { | 67 | { |
68 | } | 68 | } |
69 | 69 | ||
70 | void ConfigureTableViewWidget::restoreSettings( KConfig *config ) | 70 | void ConfigureTableViewWidget::restoreSettings( KConfig *config ) |
71 | { | 71 | { |
72 | ViewConfigureWidget::restoreSettings( config ); | 72 | ViewConfigureWidget::restoreSettings( config ); |
73 | 73 | ||
74 | mPage->restoreSettings( config ); | 74 | mPage->restoreSettings( config ); |
75 | } | 75 | } |
76 | 76 | ||
77 | void ConfigureTableViewWidget::saveSettings( KConfig *config ) | 77 | void ConfigureTableViewWidget::saveSettings( KConfig *config ) |
78 | { | 78 | { |
79 | ViewConfigureWidget::saveSettings( config ); | 79 | ViewConfigureWidget::saveSettings( config ); |
80 | 80 | ||
81 | mPage->saveSettings( config ); | 81 | mPage->saveSettings( config ); |
82 | } | 82 | } |
83 | 83 | ||
84 | 84 | ||
85 | 85 | ||
86 | LookAndFeelPage::LookAndFeelPage(QWidget *parent, const char *name) | 86 | LookAndFeelPage::LookAndFeelPage(QWidget *parent, const char *name) |
87 | : QVBox(parent, name) | 87 | : QVBox(parent, name) |
88 | { | 88 | { |
89 | initGUI(); | 89 | initGUI(); |
90 | 90 | ||
91 | // Set initial state | 91 | // Set initial state |
92 | enableBackgroundToggled(mBackgroundBox->isChecked()); | 92 | enableBackgroundToggled(mBackgroundBox->isChecked()); |
93 | } | 93 | } |
94 | 94 | ||
95 | void LookAndFeelPage::restoreSettings( KConfig *config ) | 95 | void LookAndFeelPage::restoreSettings( KConfig *config ) |
96 | { | 96 | { |
97 | mAlternateButton->setChecked(config->readBoolEntry("ABackground", true)); | 97 | mAlternateButton->setChecked(config->readBoolEntry("ABackground", true)); |
98 | mLineButton->setChecked(config->readBoolEntry("SingleLine", false)); | 98 | mLineButton->setChecked(config->readBoolEntry("SingleLine", false)); |
99 | mToolTipBox->setChecked(config->readBoolEntry("ToolTips", true)); | 99 | mToolTipBox->setChecked(config->readBoolEntry("ToolTips", true)); |
100 | 100 | ||
101 | if (!mAlternateButton->isChecked() & !mLineButton->isChecked()) | 101 | if (!mAlternateButton->isChecked() & !mLineButton->isChecked()) |
102 | mNoneButton->setChecked(true); | 102 | mNoneButton->setChecked(true); |
103 | 103 | ||
104 | mBackgroundBox->setChecked(config->readBoolEntry("Background", false)); | 104 | mBackgroundBox->setChecked(config->readBoolEntry("Background", false)); |
105 | mBackgroundName->lineEdit()->setText(config->readEntry("BackgroundName")); | 105 | mBackgroundName->lineEdit()->setText(config->readEntry("BackgroundName")); |
106 | 106 | ||
107 | // colors | 107 | // colors |
108 | cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) ); | 108 | cbEnableCustomColors->setChecked( config->readBoolEntry( "EnableCustomColors", false ) ); |
109 | QColor c; | 109 | QColor c; |
110 | qDebug("LookAndFeelPage::restoreSettings make base color configurable"); | 110 | qDebug("LookAndFeelPage::restoreSettings make base color configurable"); |
111 | 111 | ||
112 | #ifndef KAB_EMBEDDED | 112 | #ifndef KAB_EMBEDDED |
113 | c = KGlobalSettings::baseColor(); | 113 | c = KGlobalSettings::baseColor(); |
114 | #else //KAB_EMBEDDED | 114 | #else //KAB_EMBEDDED |
115 | c = QColor(0,0,0); | 115 | c = QColor(0,0,0); |
116 | #endif //KAB_EMBEDDED | 116 | #endif //KAB_EMBEDDED |
117 | 117 | ||
118 | c = colorGroup().background(); | 118 | c = colorGroup().background(); |
119 | lbColors->insertItem( new ColorListItem( i18n("Background Color"), | 119 | lbColors->insertItem( new ColorListItem( i18n("Background Color"), |
120 | config->readColorEntry( "BackgroundColor", &c ) ) ); | 120 | config->readColorEntry( "BackgroundColor", &c ) ) ); |
121 | c = colorGroup().foreground(); | 121 | c = colorGroup().foreground(); |
122 | lbColors->insertItem( new ColorListItem( i18n("Text Color"), | 122 | lbColors->insertItem( new ColorListItem( i18n("Text Color"), |
123 | config->readColorEntry( "TextColor", &c ) ) ); | 123 | config->readColorEntry( "TextColor", &c ) ) ); |
124 | c = colorGroup().button(); | 124 | c = colorGroup().button(); |
125 | lbColors->insertItem( new ColorListItem( i18n("Header Background Color"), | 125 | lbColors->insertItem( new ColorListItem( i18n("Header Background Color"), |
126 | config->readColorEntry( "HeaderBackgroundColor", &c ) ) ); | 126 | config->readColorEntry( "HeaderBackgroundColor", &c ) ) ); |
127 | c = colorGroup().buttonText(); | 127 | c = colorGroup().buttonText(); |
128 | lbColors->insertItem( new ColorListItem( i18n("Header Text Color"), | 128 | lbColors->insertItem( new ColorListItem( i18n("Header Text Color"), |
129 | config->readColorEntry( "HeaderTextColor", &c ) ) ); | 129 | config->readColorEntry( "HeaderTextColor", &c ) ) ); |
130 | c = colorGroup().highlight(); | 130 | c = colorGroup().highlight(); |
131 | lbColors->insertItem( new ColorListItem( i18n("Highlight Color"), | 131 | lbColors->insertItem( new ColorListItem( i18n("Highlight Color"), |
132 | config->readColorEntry( "HighlightColor", &c ) ) ); | 132 | config->readColorEntry( "HighlightColor", &c ) ) ); |
133 | c = colorGroup().highlightedText(); | 133 | c = colorGroup().highlightedText(); |
134 | lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"), | 134 | lbColors->insertItem( new ColorListItem( i18n("Highlighted Text Color"), |
135 | config->readColorEntry( "HighlightedTextColor", &c ) ) ); | 135 | config->readColorEntry( "HighlightedTextColor", &c ) ) ); |
136 | c = colorGroup().background(); | 136 | c = colorGroup().background(); |
137 | lbColors->insertItem( new ColorListItem( i18n("Alternating Background Color"), | 137 | lbColors->insertItem( new ColorListItem( i18n("Alternating Background Color"), |
138 | config->readColorEntry( "AlternatingBackgroundColor", &c ) ) ); | 138 | config->readColorEntry( "AlternatingBackgroundColor", &c ) ) ); |
139 | 139 | ||
140 | enableColors(); | 140 | enableColors(); |
141 | 141 | ||
142 | // fonts | 142 | // fonts |
143 | QFont fnt = font(); | 143 | QFont fnt = font(); |
144 | updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont ); | 144 | updateFontLabel( config->readFontEntry( "TextFont", &fnt ), (QLabel*)lTextFont ); |
145 | fnt.setBold( true ); | 145 | fnt.setBold( true ); |
146 | updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont ); | 146 | updateFontLabel( config->readFontEntry( "HeaderFont", &fnt ), (QLabel*)lHeaderFont ); |
147 | cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) ); | 147 | cbEnableCustomFonts->setChecked( config->readBoolEntry( "EnableCustomFonts", false ) ); |
148 | enableFonts(); | 148 | enableFonts(); |
149 | 149 | ||
150 | } | 150 | } |
151 | 151 | ||
152 | void LookAndFeelPage::saveSettings( KConfig *config ) | 152 | void LookAndFeelPage::saveSettings( KConfig *config ) |
153 | { | 153 | { |
154 | config->writeEntry("ABackground", mAlternateButton->isChecked()); | 154 | config->writeEntry("ABackground", mAlternateButton->isChecked()); |
155 | config->writeEntry("SingleLine", mLineButton->isChecked()); | 155 | config->writeEntry("SingleLine", mLineButton->isChecked()); |
156 | config->writeEntry("ToolTips", mToolTipBox->isChecked()); | 156 | config->writeEntry("ToolTips", mToolTipBox->isChecked()); |
157 | config->writeEntry("Background", mBackgroundBox->isChecked()); | 157 | config->writeEntry("Background", mBackgroundBox->isChecked()); |
158 | config->writeEntry("BackgroundName", mBackgroundName->lineEdit()->text()); | 158 | config->writeEntry("BackgroundName", mBackgroundName->lineEdit()->text()); |
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 | ||
182 | void LookAndFeelPage::setTextFont() | 182 | void 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 | ||
196 | void LookAndFeelPage::setHeaderFont() | 196 | void 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 | ||
210 | void LookAndFeelPage::enableFonts() | 210 | void 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 | ||
215 | void LookAndFeelPage::enableColors() | 217 | void 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 | ||
220 | void LookAndFeelPage::initGUI() | 224 | void 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 | ||
327 | void LookAndFeelPage::enableBackgroundToggled(bool enabled) | 331 | void LookAndFeelPage::enableBackgroundToggled(bool enabled) |
328 | { | 332 | { |
329 | mBackgroundName->setEnabled(enabled); | 333 | mBackgroundName->setEnabled(enabled); |
330 | } | 334 | } |
331 | 335 | ||
332 | 336 | ||
333 | void LookAndFeelPage::updateFontLabel( QFont fnt, QLabel *l ) | 337 | void 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; |
58 | extern int globalFlagBlockAgenda; | 58 | extern int globalFlagBlockAgenda; |
59 | extern int globalFlagBlockAgendaItemPaint; | 59 | extern int globalFlagBlockAgendaItemPaint; |
60 | extern int globalFlagBlockAgendaItemUpdate; | 60 | extern int globalFlagBlockAgendaItemUpdate; |
61 | extern int globalFlagBlockStartup; | 61 | extern int globalFlagBlockStartup; |
62 | 62 | ||
63 | //////////////////////////////////////////////////////////////////////////// | 63 | //////////////////////////////////////////////////////////////////////////// |
64 | MarcusBains::MarcusBains(KOAgenda *_agenda,const char *name) | 64 | MarcusBains::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 | ||
85 | MarcusBains::~MarcusBains() | 85 | MarcusBains::~MarcusBains() |
86 | { | 86 | { |
87 | delete minutes; | 87 | delete minutes; |
88 | } | 88 | } |
89 | 89 | ||
90 | int MarcusBains::todayColumn() | 90 | int 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 | } |
106 | void MarcusBains::updateLoc() | 106 | void MarcusBains::updateLoc() |
107 | { | 107 | { |
108 | updateLocation(); | 108 | updateLocation(); |
109 | } | 109 | } |
110 | void MarcusBains::updateLocation(bool recalculate) | 110 | void 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 | */ |
166 | KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, | 166 | KOAgenda::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 | */ |
187 | KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : | 187 | KOAgenda::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 | ||
204 | KOAgenda::~KOAgenda() | 205 | KOAgenda::~KOAgenda() |
205 | { | 206 | { |
206 | if(mMarcusBains) delete mMarcusBains; | 207 | if(mMarcusBains) delete mMarcusBains; |
207 | 208 | ||
208 | } | 209 | } |
209 | 210 | ||
210 | Incidence *KOAgenda::selectedIncidence() const | 211 | Incidence *KOAgenda::selectedIncidence() const |
211 | { | 212 | { |
212 | return (mSelectedItem ? mSelectedItem->incidence() : 0); | 213 | return (mSelectedItem ? mSelectedItem->incidence() : 0); |
213 | } | 214 | } |
214 | 215 | ||
215 | 216 | ||
216 | QDate KOAgenda::selectedIncidenceDate() const | 217 | QDate KOAgenda::selectedIncidenceDate() const |
217 | { | 218 | { |
218 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); | 219 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); |
219 | } | 220 | } |
220 | 221 | ||
221 | 222 | ||
222 | void KOAgenda::init() | 223 | void 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 | ||
321 | void KOAgenda::clear() | 322 | void 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 | ||
333 | void KOAgenda::clearSelection() | 334 | void 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 | ||
340 | void KOAgenda::marcus_bains() | 341 | void KOAgenda::marcus_bains() |
341 | { | 342 | { |
342 | if(mMarcusBains) mMarcusBains->updateLocation(true); | 343 | if(mMarcusBains) mMarcusBains->updateLocation(true); |
343 | } | 344 | } |
344 | 345 | ||
345 | 346 | ||
346 | void KOAgenda::changeColumns(int columns) | 347 | void 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 | */ |
361 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) | 362 | bool 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 | } |
380 | void KOAgenda::popupMenu() | 381 | void 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 | ||
405 | bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) | 410 | bool 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 | ||
749 | void KOAgenda::newItem( int item ) | 788 | void 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 | } |
765 | void KOAgenda::startSelectAction(QPoint viewportPos) | 804 | void 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 | ||
800 | void KOAgenda::performSelectAction(QPoint viewportPos) | 839 | void 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 | ||
854 | void KOAgenda::endSelectAction( bool emitNewEvent ) | 893 | void 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 | ||
867 | void KOAgenda::startItemAction(QPoint viewportPos) | 906 | void 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 | ||
915 | void KOAgenda::performItemAction(QPoint viewportPos) | 954 | void 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 | ||
1034 | void KOAgenda::endItemAction() | 1073 | void 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 | ||
1159 | void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) | 1198 | void 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 | */ |
1212 | void KOAgenda::placeSubCells(KOAgendaItem *placeItem) | 1251 | void 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 | ||
1322 | void KOAgenda::drawContents(QPainter* p, int cx, int cy, int cw, int ch) | 1361 | void 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 | ||
1354 | void KOAgenda::finishUpdate() | 1393 | void 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 | */ |
1403 | void KOAgenda::drawContentsToPainter( QPainter* paint, bool backgroundOnly )// int cx, int cy, int cw, int ch) | 1442 | void 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 | */ |
1553 | void KOAgenda::contentsToGrid (int x, int y, int& gx, int& gy) | 1592 | void 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 | */ |
1563 | void KOAgenda::gridToContents (int gx, int gy, int& x, int& y) | 1602 | void 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 | */ |
1575 | int KOAgenda::timeToY(const QTime &time) | 1614 | int 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 | */ |
1588 | QTime KOAgenda::gyToTime(int gy) | 1627 | QTime 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 | ||
1605 | void KOAgenda::setStartHour(int startHour) | 1644 | void 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 | } |
1610 | void KOAgenda::hideUnused() | 1649 | void 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 | ||
1621 | KOAgendaItem *KOAgenda::getNewItem(Incidence * event,QDate qd, QWidget* view) | 1660 | KOAgendaItem *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 | } |
1645 | KOAgendaItem * KOAgenda::getItemForTodo ( Todo * todo ) | 1684 | KOAgendaItem * 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 | ||
1658 | void KOAgenda::updateTodo( Todo * todo, int days, bool remove) | 1697 | void 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 | */ |
1748 | KOAgendaItem *KOAgenda::insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom) | 1787 | KOAgendaItem *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 | */ |
1784 | KOAgendaItem *KOAgenda::insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd) | 1823 | KOAgendaItem *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 | ||
1807 | void KOAgenda::insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, | 1846 | void 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 | //} |
1866 | void KOAgenda::finishResize ( ) | 1905 | void 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 | */ |
1877 | void KOAgenda::resizeEvent ( QResizeEvent *ev ) | 1916 | void 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 | } |
1885 | void KOAgenda::computeSizes() | 1924 | void 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 | ||
1947 | void KOAgenda::scrollUp() | 1986 | void KOAgenda::scrollUp() |
1948 | { | 1987 | { |
1949 | scrollBy(0,-mScrollOffset); | 1988 | scrollBy(0,-mScrollOffset); |
1950 | } | 1989 | } |
1951 | 1990 | ||
1952 | 1991 | ||
1953 | void KOAgenda::scrollDown() | 1992 | void KOAgenda::scrollDown() |
1954 | { | 1993 | { |
1955 | scrollBy(0,mScrollOffset); | 1994 | scrollBy(0,mScrollOffset); |
1956 | } | 1995 | } |
1957 | 1996 | ||
1958 | void KOAgenda::popupAlarm() | 1997 | void 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 | */ |
1978 | int KOAgenda::minimumWidth() const | 2017 | int 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 | ||
1986 | void KOAgenda::updateConfig() | 2025 | void 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 | ||
2006 | void KOAgenda::checkScrollBoundaries() | 2045 | void 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 | ||
2015 | void KOAgenda::checkScrollBoundaries(int v) | 2054 | void 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 | ||
2034 | void KOAgenda::deselectItem() | 2073 | void 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 | ||
2041 | void KOAgenda::selectItem(KOAgendaItem *item) | 2080 | void 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. |
2055 | void KOAgenda::keyPressEvent( QKeyEvent *kev ) | 2094 | void 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 | ||
2075 | void KOAgenda::calculateWorkingHours() | 2114 | void 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 | ||
2087 | DateList KOAgenda::dateList() const | 2126 | DateList KOAgenda::dateList() const |
2088 | { | 2127 | { |
2089 | return mSelectedDates; | 2128 | return mSelectedDates; |
2090 | } | 2129 | } |
2091 | 2130 | ||
2092 | void KOAgenda::setDateList(const DateList &selectedDates) | 2131 | void KOAgenda::setDateList(const DateList &selectedDates) |
2093 | { | 2132 | { |
2094 | mSelectedDates = selectedDates; | 2133 | mSelectedDates = selectedDates; |
2095 | marcus_bains(); | 2134 | marcus_bains(); |
2096 | } | 2135 | } |
2097 | 2136 | ||
2098 | void KOAgenda::setHolidayMask(QMemArray<bool> *mask) | 2137 | void 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 | ||
2111 | void KOAgenda::contentsMousePressEvent ( QMouseEvent *event ) | 2150 | void KOAgenda::contentsMousePressEvent ( QMouseEvent *event ) |
2112 | { | 2151 | { |
2113 | 2152 | ||
2114 | QScrollView::contentsMousePressEvent(event); | 2153 | QScrollView::contentsMousePressEvent(event); |
2115 | } | 2154 | } |
2116 | 2155 | ||
2117 | void KOAgenda::storePosition() | 2156 | void 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 | } |
2130 | void KOAgenda::restorePosition() | 2169 | void 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 | } |
2145 | void KOAgenda::moveChild( QWidget *w, int x , int y ) | 2184 | void 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 |
2157 | void KOAgenda::printSelection() | 2196 | void 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 | ||
35 | class QPopupMenu; | 36 | class QPopupMenu; |
36 | class QTime; | 37 | class QTime; |
37 | class KConfig; | 38 | class KConfig; |
38 | class QFrame; | 39 | class QFrame; |
39 | class KOAgenda; | 40 | class KOAgenda; |
40 | class KCal::Event; | 41 | class KCal::Event; |
41 | class KCal::Todo; | 42 | class KCal::Todo; |
42 | 43 | ||
43 | using namespace KCal; | 44 | using namespace KCal; |
44 | 45 | ||
45 | class MarcusBains : public QFrame { | 46 | class 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 | ||
65 | class KOAgenda : public QScrollView | 66 | class 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; |
72 | extern int globalFlagBlockAgenda; | 72 | extern int globalFlagBlockAgenda; |
73 | extern int globalFlagBlockStartup; | 73 | extern int globalFlagBlockStartup; |
74 | extern int globalFlagBlockAgendaItemPaint; | 74 | extern int globalFlagBlockAgendaItemPaint; |
75 | extern int globalFlagBlockAgendaItemUpdate; | 75 | extern int globalFlagBlockAgendaItemUpdate; |
76 | extern int globalFlagBlockLabel; | 76 | extern int globalFlagBlockLabel; |
77 | using namespace KOrg; | 77 | using namespace KOrg; |
78 | 78 | ||
79 | 79 | ||
80 | 80 | ||
81 | TimeLabels::TimeLabels(int rows,QWidget *parent,const char *name,WFlags f) : | 81 | TimeLabels::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 | ||
101 | void TimeLabels::setCellHeight(int height) | 101 | void 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 | */ |
110 | void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) | 110 | void 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 | */ |
264 | int TimeLabels::minimumWidth() const | 264 | int 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 */ |
270 | void TimeLabels::updateConfig() | 270 | void 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 */ |
302 | void TimeLabels::positionChanged() | 302 | void 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 | /** */ |
309 | void TimeLabels::setAgenda(KOAgenda* agenda) | 309 | void TimeLabels::setAgenda(KOAgenda* agenda) |
310 | { | 310 | { |
311 | mAgenda = agenda; | 311 | mAgenda = agenda; |
312 | } | 312 | } |
313 | 313 | ||
314 | void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) | 314 | void 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 | ||
320 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) | 320 | void 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 | } |
334 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) | 334 | void 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() */ |
353 | void TimeLabels::paintEvent(QPaintEvent*) | 353 | void 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 | ||
365 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) | 365 | EventIndicator::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 | ||
381 | EventIndicator::~EventIndicator() | 381 | EventIndicator::~EventIndicator() |
382 | { | 382 | { |
383 | } | 383 | } |
384 | 384 | ||
385 | void EventIndicator::drawContents(QPainter *p) | 385 | void 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 | ||
429 | void EventIndicator::setXOffset( int x ) | 429 | void EventIndicator::setXOffset( int x ) |
430 | { | 430 | { |
431 | mXOffset = x; | 431 | mXOffset = x; |
432 | } | 432 | } |
433 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) | 433 | void 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 | } |
439 | void EventIndicator::changeColumns(int columns) | 439 | void 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 | ||
447 | void EventIndicator::enableColumn(int column, bool enable) | 447 | void 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 | ||
457 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : | 457 | KOAgendaView::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 | ||
650 | void KOAgendaView::toggleAllDay() | 652 | void KOAgendaView::toggleAllDay() |
651 | { | 653 | { |
652 | if ( mSplitterAgenda->firstHandle() ) | 654 | if ( mSplitterAgenda->firstHandle() ) |
653 | mSplitterAgenda->firstHandle()->toggle(); | 655 | mSplitterAgenda->firstHandle()->toggle(); |
654 | } | 656 | } |
655 | void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) | 657 | void 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 | ||
668 | KOAgendaView::~KOAgendaView() | 670 | KOAgendaView::~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 | } |
675 | void KOAgendaView::resizeEvent( QResizeEvent* e ) | 677 | void 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 | } |
700 | void KOAgendaView::slotDaylabelClicked( int num ) | 702 | void 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 | ||
716 | KOAgendaButton* KOAgendaView::getNewDaylabel() | 718 | KOAgendaButton* 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 | ||
726 | void KOAgendaView::createDayLabels() | 728 | void 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 | ||
937 | int KOAgendaView::maxDatesHint() | 939 | int 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 | ||
943 | int KOAgendaView::currentDateCount() | 945 | int KOAgendaView::currentDateCount() |
944 | { | 946 | { |
945 | return mSelectedDates.count(); | 947 | return mSelectedDates.count(); |
946 | } | 948 | } |
947 | 949 | ||
948 | QPtrList<Incidence> KOAgendaView::selectedIncidences() | 950 | QPtrList<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 | ||
962 | DateList KOAgendaView::selectedDates() | 964 | DateList 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 | ||
977 | void KOAgendaView::updateView() | 979 | void 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 | */ |
991 | void KOAgendaView::updateConfig() | 993 | void 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 | ||
1029 | void KOAgendaView::updateEventDates(KOAgendaItem *item, int type) | 1031 | void 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 | ||
1122 | void KOAgendaView::showDates( const QDate &start, const QDate &end ) | 1124 | void 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 | ||
1139 | void KOAgendaView::showEvents(QPtrList<Event>) | 1141 | void 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 | ||
1144 | void KOAgendaView::changeEventDisplay(Event *, int) | 1146 | void 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 | ||
1153 | void KOAgendaView::fillAgenda(const QDate &) | 1155 | void KOAgendaView::fillAgenda(const QDate &) |
1154 | { | 1156 | { |
1155 | // qDebug("KOAgendaView::fillAgenda "); | 1157 | // qDebug("KOAgendaView::fillAgenda "); |
1156 | fillAgenda(); | 1158 | fillAgenda(); |
1157 | } | 1159 | } |
1158 | 1160 | ||
1159 | void KOAgendaView::fillAgenda() | 1161 | void 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 | } |
1364 | void KOAgendaView::repaintAgenda() | 1366 | void 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 | ||
1381 | void KOAgendaView::clearView() | 1383 | void 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 | ||
1388 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 1390 | void 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 | ||
1405 | void KOAgendaView::slotShowDateView( int mode , int d ) | 1407 | void 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 | } |
1416 | void KOAgendaView::newEvent(int gx, int gy) | 1418 | void 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 | ||
1429 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) | 1431 | void 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 | ||
1445 | void KOAgendaView::newEventAllDay(int gx, int ) | 1447 | void 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 | } |
1453 | void KOAgendaView::newTodoAllDay(int gx, int ) | 1455 | void 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 | } |
1460 | void KOAgendaView::newTodo(int gx, int gy ) | 1462 | void 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 | ||
1469 | void KOAgendaView::updateEventIndicatorTop(int newY) | 1471 | void 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 | ||
1480 | void KOAgendaView::updateEventIndicatorBottom(int newY) | 1482 | void 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 | ||
1491 | void KOAgendaView::startDrag(Event *event) | 1493 | void 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 | ||
1502 | void KOAgendaView::readSettings() | 1504 | void KOAgendaView::readSettings() |
1503 | { | 1505 | { |
1504 | readSettings(KOGlobals::config()); | 1506 | readSettings(KOGlobals::config()); |
1505 | } | 1507 | } |
1506 | 1508 | ||
1507 | void KOAgendaView::readSettings(KConfig *config) | 1509 | void 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 | ||
1528 | void KOAgendaView::writeSettings(KConfig *config) | 1530 | void 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 | ||
1541 | void KOAgendaView::setHolidayMasks() | 1543 | void 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 | ||
1580 | void KOAgendaView::setContentsPos(int y) | 1582 | void KOAgendaView::setContentsPos(int y) |
1581 | { | 1583 | { |
1582 | mAgenda->setContentsPos(0,y); | 1584 | mAgenda->setContentsPos(0,y); |
1583 | } | 1585 | } |
1584 | 1586 | ||
1585 | void KOAgendaView::clearSelection() | 1587 | void KOAgendaView::clearSelection() |
1586 | { | 1588 | { |
1587 | mAgenda->deselectItem(); | 1589 | mAgenda->deselectItem(); |
1588 | mAllDayAgenda->deselectItem(); | 1590 | mAllDayAgenda->deselectItem(); |
1589 | } | 1591 | } |
1590 | 1592 | ||
1591 | void KOAgendaView::newTimeSpanSelectedAllDay(int gxStart, int gyStart, | 1593 | void 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 | ||
1601 | void KOAgendaView::newTimeSpanSelected(int gxStart, int gyStart, | 1603 | void 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 | ||
1620 | void KOAgendaView::deleteSelectedDateTime() | 1622 | void 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 | ||
1627 | void KOAgendaView::keyPressEvent ( QKeyEvent * e ) | 1629 | void KOAgendaView::keyPressEvent ( QKeyEvent * e ) |
1628 | { | 1630 | { |
1629 | e->ignore(); | 1631 | e->ignore(); |
1630 | } | 1632 | } |
1631 | 1633 | ||
1632 | void KOAgendaView::scrollOneHourUp() | 1634 | void KOAgendaView::scrollOneHourUp() |
1633 | { | 1635 | { |
1634 | 1636 | ||
1635 | mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 ); | 1637 | mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 ); |
1636 | } | 1638 | } |
1637 | void KOAgendaView::scrollOneHourDown() | 1639 | void KOAgendaView::scrollOneHourDown() |
1638 | { | 1640 | { |
1639 | mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 ); | 1641 | mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 ); |
1640 | } | 1642 | } |
1641 | 1643 | ||
1642 | void KOAgendaView::setStartHour( int h ) | 1644 | void KOAgendaView::setStartHour( int h ) |
1643 | { | 1645 | { |
1644 | mAgenda->setStartHour( h ); | 1646 | mAgenda->setStartHour( h ); |
1645 | 1647 | ||
1646 | } | 1648 | } |
1647 | void KOAgendaView::setInitStartHour() | 1649 | void 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 | ||
1658 | void KOAgendaView::updateTodo( Todo * t, int ) | 1660 | void 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 | ||
39 | class QHBox; | 39 | class QHBox; |
40 | class QFrame; | 40 | class QFrame; |
41 | class QLabel; | 41 | class QLabel; |
42 | class QPushButton; | 42 | class QPushButton; |
43 | class CalendarView; | 43 | class CalendarView; |
44 | class KOAgenda; | 44 | class KOAgenda; |
45 | class KOAgendaItem; | 45 | class KOAgendaItem; |
46 | class KConfig; | 46 | class KConfig; |
47 | class KDGanttMinimizeSplitter; | 47 | class KDGanttMinimizeSplitter; |
48 | 48 | ||
49 | class KOAgendaButton : public QPushButton | 49 | class 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; } |
65 | private slots: | 65 | private slots: |
66 | void bClicked() {emit numClicked( mNum);} | 66 | void bClicked() {emit numClicked( mNum);} |
67 | signals: | 67 | signals: |
68 | void numClicked( int ); | 68 | void numClicked( int ); |
69 | private: | 69 | private: |
70 | int mNum; | 70 | int mNum; |
71 | }; | 71 | }; |
72 | 72 | ||
73 | class TimeLabels : public QScrollView { | 73 | class 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 | ||
116 | class EventIndicator : public QFrame { | 116 | class 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 | */ |
146 | class KOAgendaView : public KOEventView { | 146 | class 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" |
56 | using namespace KOrg; | 56 | using namespace KOrg; |
57 | 57 | ||
58 | 58 | ||
59 | class KOTodoViewWhatsThis :public QWhatsThis | 59 | class KOTodoViewWhatsThis :public QWhatsThis |
60 | { | 60 | { |
61 | public: | 61 | public: |
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 | ||
64 | protected: | 64 | protected: |
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 | } |
69 | private: | 69 | private: |
70 | QWidget* _wid; | 70 | QWidget* _wid; |
71 | KOTodoView * _view; | 71 | KOTodoView * _view; |
72 | }; | 72 | }; |
73 | 73 | ||
74 | KOTodoListView::KOTodoListView(Calendar *calendar,QWidget *parent, | 74 | KOTodoListView::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 | ||
95 | void KOTodoListView::contentsDragEnterEvent(QDragEnterEvent *e) | 95 | void 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 | ||
110 | void KOTodoListView::contentsDragMoveEvent(QDragMoveEvent *e) | 110 | void 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 | ||
125 | void KOTodoListView::contentsDragLeaveEvent(QDragLeaveEvent *) | 125 | void 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 | ||
135 | void KOTodoListView::contentsDropEvent(QDropEvent *e) | 135 | void 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 | ||
208 | void KOTodoListView::contentsMousePressEvent(QMouseEvent* e) | 208 | void 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 | } |
230 | void KOTodoListView::paintEvent(QPaintEvent* e) | 241 | void KOTodoListView::paintEvent(QPaintEvent* e) |
231 | { | 242 | { |
232 | emit paintNeeded(); | 243 | emit paintNeeded(); |
233 | QListView::paintEvent( e); | 244 | QListView::paintEvent( e); |
234 | } | 245 | } |
235 | void KOTodoListView::contentsMouseMoveEvent(QMouseEvent* e) | 246 | void 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 | } |
267 | void KOTodoListView::keyReleaseEvent ( QKeyEvent *e ) | 278 | void 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 | ||
275 | void KOTodoListView::keyPressEvent ( QKeyEvent * e ) | 286 | void 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 | } |
327 | void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e) | 338 | void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e) |
328 | { | 339 | { |
329 | QListView::contentsMouseReleaseEvent(e); | 340 | QListView::contentsMouseReleaseEvent(e); |
330 | mMousePressed = false; | 341 | mMousePressed = false; |
331 | } | 342 | } |
332 | 343 | ||
333 | void KOTodoListView::contentsMouseDoubleClickEvent(QMouseEvent *e) | 344 | void 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 | ||
349 | KOQuickTodo::KOQuickTodo(QWidget *parent) : | 360 | KOQuickTodo::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 | ||
355 | void KOQuickTodo::focusInEvent(QFocusEvent *ev) | 366 | void 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 | ||
362 | void KOQuickTodo::focusOutEvent(QFocusEvent *ev) | 373 | void 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 | ||
370 | KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : | 381 | KOTodoView::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 | ||
565 | KOTodoView::~KOTodoView() | 576 | KOTodoView::~KOTodoView() |
566 | { | 577 | { |
567 | // delete mKOTodoViewWhatsThis; | 578 | // delete mKOTodoViewWhatsThis; |
568 | delete mDocPrefs; | 579 | delete mDocPrefs; |
569 | } | 580 | } |
570 | QString KOTodoView::getWhatsThisText(QPoint p) | 581 | QString 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 | ||
582 | void KOTodoView::jumpToDate () | 593 | void 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 | } |
589 | void KOTodoView::paintNeeded() | 600 | void KOTodoView::paintNeeded() |
590 | { | 601 | { |
591 | if ( mPendingUpdateBeforeRepaint ) { | 602 | if ( mPendingUpdateBeforeRepaint ) { |
592 | updateView(); | 603 | updateView(); |
593 | mPendingUpdateBeforeRepaint = false; | 604 | mPendingUpdateBeforeRepaint = false; |
594 | } | 605 | } |
595 | } | 606 | } |
596 | void KOTodoView::paintEvent(QPaintEvent * pevent) | 607 | void 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 | ||
605 | void KOTodoView::updateView() | 616 | void 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 | ||
711 | void KOTodoView::storeCurrentItem() | 722 | void 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 | ||
729 | void KOTodoView::resetCurrentItem() | 740 | void 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; |
767 | bool KOTodoView::checkTodo( Todo * todo ) | 778 | bool 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 | ||
787 | void KOTodoView::restoreItemState( QListViewItem *item ) | 798 | void 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 | ||
799 | QMap<Todo *,KOTodoViewItem *>::ConstIterator | 810 | QMap<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 | ||
831 | void KOTodoView::updateConfig() | 842 | void KOTodoView::updateConfig() |
832 | { | 843 | { |
833 | updateView(); | 844 | updateView(); |
834 | mTodoListView->repaintContents(); | 845 | mTodoListView->repaintContents(); |
835 | } | 846 | } |
836 | 847 | ||
837 | QPtrList<Incidence> KOTodoView::selectedIncidences() | 848 | QPtrList<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 | ||
848 | QPtrList<Todo> KOTodoView::selectedTodos() | 859 | QPtrList<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 | ||
859 | void KOTodoView::changeEventDisplay(Event *, int) | 870 | void KOTodoView::changeEventDisplay(Event *, int) |
860 | { | 871 | { |
861 | updateView(); | 872 | updateView(); |
862 | } | 873 | } |
863 | 874 | ||
864 | void KOTodoView::showDates(const QDate &, const QDate &) | 875 | void KOTodoView::showDates(const QDate &, const QDate &) |
865 | { | 876 | { |
866 | } | 877 | } |
867 | 878 | ||
868 | void KOTodoView::showEvents(QPtrList<Event>) | 879 | void 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 | ||
873 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 884 | void 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 | ||
881 | void KOTodoView::editItem(QListViewItem *item ) | 892 | void 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 | ||
887 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) | 898 | void 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 | ||
892 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) | 903 | void 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 | } |
912 | void KOTodoView::newTodo() | 923 | void KOTodoView::newTodo() |
913 | { | 924 | { |
914 | emit newTodoSignal(); | 925 | emit newTodoSignal(); |
915 | } | 926 | } |
916 | 927 | ||
917 | void KOTodoView::newSubTodo() | 928 | void KOTodoView::newSubTodo() |
918 | { | 929 | { |
919 | if (mActiveItem) { | 930 | if (mActiveItem) { |
920 | emit newSubTodoSignal(mActiveItem->todo()); | 931 | emit newSubTodoSignal(mActiveItem->todo()); |
921 | } | 932 | } |
922 | } | 933 | } |
923 | void KOTodoView::unparentTodo() | 934 | void 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 | ||
930 | void KOTodoView::reparentTodo() | 941 | void 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 | } |
938 | void KOTodoView::editTodo() | 949 | void KOTodoView::editTodo() |
939 | { | 950 | { |
940 | if (mActiveItem) { | 951 | if (mActiveItem) { |
941 | emit editTodoSignal(mActiveItem->todo()); | 952 | emit editTodoSignal(mActiveItem->todo()); |
942 | } | 953 | } |
943 | } | 954 | } |
944 | void KOTodoView::cloneTodo() | 955 | void 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 | } |
950 | void KOTodoView::cancelTodo() | 961 | void 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 | } |
956 | void KOTodoView::moveTodo() | 967 | void 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 | } |
962 | void KOTodoView::beamTodo() | 973 | void 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 | ||
970 | void KOTodoView::showTodo() | 981 | void 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 | ||
977 | void KOTodoView::deleteTodo() | 988 | void 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 | ||
984 | void KOTodoView::setNewPriority(int index) | 995 | void 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 | ||
994 | void KOTodoView::setNewPercentage(int index) | 1005 | void 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 | ||
1019 | QPopupMenu * KOTodoView::getCategoryPopupMenu (KOTodoViewItem *todoItem) | 1030 | QPopupMenu * 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 | } |
1038 | void KOTodoView::changedCategories(int index) | 1049 | void 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 | } |
1060 | void KOTodoView::itemDoubleClicked(QListViewItem *item) | 1071 | void 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 | } |
1075 | void KOTodoView::itemClicked(QListViewItem *item) | 1094 | void 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 | ||
1129 | void KOTodoView::setDocumentId( const QString &id ) | 1148 | void 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 | ||
1136 | void KOTodoView::itemStateChanged( QListViewItem *item ) | 1155 | void 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 | ||
1147 | void KOTodoView::saveLayout(KConfig *config, const QString &group) const | 1166 | void KOTodoView::saveLayout(KConfig *config, const QString &group) const |
1148 | { | 1167 | { |
1149 | mTodoListView->saveLayout(config,group); | 1168 | mTodoListView->saveLayout(config,group); |
1150 | } | 1169 | } |
1151 | 1170 | ||
1152 | void KOTodoView::restoreLayout(KConfig *config, const QString &group) | 1171 | void KOTodoView::restoreLayout(KConfig *config, const QString &group) |
1153 | { | 1172 | { |
1154 | mTodoListView->restoreLayout(config,group); | 1173 | mTodoListView->restoreLayout(config,group); |
1155 | } | 1174 | } |
1156 | 1175 | ||
1157 | void KOTodoView::processSelectionChange() | 1176 | void 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 | ||
1171 | void KOTodoView::modified(bool b) | 1190 | void KOTodoView::modified(bool b) |
1172 | { | 1191 | { |
1173 | emit isModified(b); | 1192 | emit isModified(b); |
1174 | } | 1193 | } |
1175 | void KOTodoView::setTodoModified( Todo* todo ) | 1194 | void KOTodoView::setTodoModified( Todo* todo ) |
1176 | { | 1195 | { |
1177 | todoModified( todo, KOGlobals::UNKNOWN_MODIFIED ); | 1196 | todoModified( todo, KOGlobals::UNKNOWN_MODIFIED ); |
1178 | } | 1197 | } |
1179 | void KOTodoView::clearSelection() | 1198 | void KOTodoView::clearSelection() |
1180 | { | 1199 | { |
1181 | mTodoListView->selectAll( false ); | 1200 | mTodoListView->selectAll( false ); |
1182 | } | 1201 | } |
1183 | void KOTodoView::setAllOpen() | 1202 | void 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 | } |
1192 | void KOTodoView::setAllClose() | 1211 | void 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 | } |
1201 | void KOTodoView::setOpen( QListViewItem* item, bool setOpenI) | 1220 | void 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 | ||
1211 | void KOTodoView::displayAllFlat() | 1230 | void 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 | ||
1231 | void KOTodoView::setAllFlat() | 1250 | void 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 | ||
1242 | void KOTodoView::purgeCompleted() | 1261 | void KOTodoView::purgeCompleted() |
1243 | { | 1262 | { |
1244 | emit purgeCompletedSignal(); | 1263 | emit purgeCompletedSignal(); |
1245 | } | 1264 | } |
1246 | void KOTodoView::toggleQuickTodo() | 1265 | void 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 | ||
1260 | void KOTodoView::toggleRunning() | 1279 | void 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 | ||
1268 | void KOTodoView::toggleCompleted() | 1287 | void 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 | ||
1276 | void KOTodoView::addQuickTodo() | 1295 | void 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 | ||
1295 | void KOTodoView::keyPressEvent ( QKeyEvent * e ) | 1314 | void 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 | } |
1372 | void KOTodoView::updateTodo( Todo * t, int type ) | 1391 | void 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 | ||
1389 | void KOTodoView::todoModified(Todo * t , int p ) | 1408 | void 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> |
11 | QColor KColorDialog::getColor( ) const | 11 | QColor 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 | } |
19 | void KColorDialog::setColor( const QColor & d ) | 19 | void 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 | } |
30 | KColorDialog::KColorDialog( QWidget *p ):QDialog( p, "input-dialog", true ) | 30 | KColorDialog::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 | } |
88 | void KColorDialog::updateColor( int ) | 89 | void 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 | ||
75 | enum { | 75 | enum { |
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 | ||
89 | class KToolBarPrivate | 89 | class KToolBarPrivate |
90 | { | 90 | { |
91 | public: | 91 | public: |
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 | ||
164 | KToolBarSeparator::KToolBarSeparator(Orientation o , bool l, QToolBar *parent, | 164 | KToolBarSeparator::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 | ||
175 | void KToolBarSeparator::setOrientation( Orientation o ) | 175 | void 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 | ||
188 | void KToolBarSeparator::styleChange( QStyle& ) | 188 | void KToolBarSeparator::styleChange( QStyle& ) |
189 | { | 189 | { |
190 | setOrientation( orient ); | 190 | setOrientation( orient ); |
191 | } | 191 | } |
192 | 192 | ||
193 | QSize KToolBarSeparator::sizeHint() const | 193 | QSize 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 | ||
198 | QSizePolicy KToolBarSeparator::sizePolicy() const | 198 | QSizePolicy KToolBarSeparator::sizePolicy() const |
199 | { | 199 | { |
200 | return QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum ); | 200 | return QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum ); |
201 | } | 201 | } |
202 | 202 | ||
203 | KToolBar::KToolBar( QWidget *parent, const char *name, bool honorStyle, bool readConfig ) | 203 | KToolBar::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 | ||
219 | KToolBar::KToolBar( QMainWindow *parentWindow, QMainWindow::ToolBarDock dock, bool newLine, const char *name, bool honorStyle, bool readConfig ) | 219 | KToolBar::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 | ||
234 | KToolBar::KToolBar( QMainWindow *parentWindow, QWidget *dock, bool newLine, const char *name, bool honorStyle, bool readConfig ) | 234 | KToolBar::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 | ||
249 | KToolBar::~KToolBar() | 249 | KToolBar::~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 | ||
256 | void KToolBar::init( bool readConfig, bool honorStyle ) | 256 | void 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 | ||
288 | int KToolBar::insertButton(const QString& icon, int id, bool enabled, | 288 | int 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 | ||
300 | int KToolBar::insertButton(const QString& icon, int id, const char *signal, | 300 | int 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 | ||
313 | int KToolBar::insertButton(const QPixmap& pixmap, int id, bool enabled, | 313 | int 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 | ||
328 | int KToolBar::insertButton(const QPixmap& pixmap, int id, const char *signal, | 328 | int 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 | ||
342 | int KToolBar::insertButton(const QString& icon, int id, QPopupMenu *popup, | 342 | int 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 | ||
354 | int KToolBar::insertButton(const QPixmap& pixmap, int id, QPopupMenu *popup, | 354 | int 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 | ||
366 | int KToolBar::insertLined (const QString& text, int id, | 366 | int 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 | ||
385 | int KToolBar::insertCombo (const QStringList &list, int id, bool writable, | 385 | int 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 | ||
413 | int KToolBar::insertCombo (const QString& text, int id, bool writable, | 413 | int 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 | ||
438 | int KToolBar::insertSeparator(int index, int id) | 438 | int 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 | ||
445 | int KToolBar::insertLineSeparator(int index, int id) | 445 | int 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 | ||
453 | int KToolBar::insertWidget(int id, int /*width*/, QWidget *widget, int index) | 453 | int 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 |
460 | int KToolBar::insertAnimatedWidget(int id, QObject *receiver, const char *slot, | 460 | int 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 | ||
472 | KAnimWidget *KToolBar::animatedWidget( int id ) | 472 | KAnimWidget *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 | ||
498 | void KToolBar::addConnection (int id, const char *signal, | 498 | void 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 | ||
508 | void KToolBar::setItemEnabled( int id, bool enabled ) | 508 | void 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 | ||
518 | void KToolBar::setButtonPixmap( int id, const QPixmap& _pixmap ) | 518 | void 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 | ||
530 | void KToolBar::setButtonIcon( int id, const QString& _icon ) | 530 | void 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 | ||
541 | void KToolBar::setButtonIconSet( int id, const QIconSet& iconset ) | 541 | void 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 | ||
553 | void KToolBar::setDelayedPopup (int id , QPopupMenu *_popup, bool toggle ) | 553 | void 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 | ||
565 | void KToolBar::setAutoRepeat (int id, bool flag) | 565 | void 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 | ||
577 | void KToolBar::setToggle (int id, bool flag ) | 577 | void 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 | ||
589 | void KToolBar::toggleButton (int id) | 589 | void 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 | ||
601 | void KToolBar::setButton (int id, bool flag) | 601 | void 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 | ||
613 | bool KToolBar::isButtonOn (int id) const | 613 | bool 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 | ||
624 | void KToolBar::setLinedText (int id, const QString& text) | 624 | void 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 | ||
636 | QString KToolBar::getLinedText (int id) const | 636 | QString 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 | ||
647 | void KToolBar::insertComboItem (int id, const QString& text, int index) | 647 | void 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 | ||
658 | void KToolBar::insertComboList (int id, const QStringList &list, int index) | 658 | void 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 | ||
670 | void KToolBar::removeComboItem (int id, int index) | 670 | void 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 | ||
682 | void KToolBar::setCurrentComboItem (int id, int index) | 682 | void 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 | ||
694 | void KToolBar::changeComboItem (int id, const QString& text, int index) | 694 | void 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 | ||
706 | void KToolBar::clearCombo (int id) | 706 | void 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 | ||
718 | QString KToolBar::getComboItem (int id, int index) const | 718 | QString 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 | ||
729 | KComboBox * KToolBar::getCombo(int id) | 729 | KComboBox * 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 | ||
739 | KLineEdit * KToolBar::getLined (int id) | 739 | KLineEdit * 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 | ||
749 | KToolBarButton * KToolBar::getButton (int id) | 749 | KToolBarButton * 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 | ||
759 | void KToolBar::alignItemRight (int id, bool right ) | 759 | void 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 | ||
771 | QWidget *KToolBar::getWidget (int id) | 771 | QWidget *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 | ||
778 | void KToolBar::setItemAutoSized (int id, bool yes ) | 778 | void 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 | ||
786 | void KToolBar::clear () | 786 | void 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 | ||
794 | void KToolBar::removeItem(int id) | 794 | void 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 | ||
810 | void KToolBar::removeItemDelayed(int id) | 810 | void 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 | ||
829 | void KToolBar::hideItem (int id) | 829 | void 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 | ||
837 | void KToolBar::showItem (int id) | 837 | void 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 | ||
845 | int KToolBar::itemIndex (int id) | 845 | int 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 | ||
852 | void KToolBar::setFullSize(bool flag ) | 852 | void KToolBar::setFullSize(bool flag ) |
853 | { | 853 | { |
854 | setHorizontalStretchable( flag ); | 854 | setHorizontalStretchable( flag ); |
855 | setVerticalStretchable( flag ); | 855 | setVerticalStretchable( flag ); |
856 | } | 856 | } |
857 | 857 | ||
858 | 858 | ||
859 | bool KToolBar::fullSize() const | 859 | bool KToolBar::fullSize() const |
860 | { | 860 | { |
861 | return isHorizontalStretchable() || isVerticalStretchable(); | 861 | return isHorizontalStretchable() || isVerticalStretchable(); |
862 | } | 862 | } |
863 | 863 | ||
864 | 864 | ||
865 | void KToolBar::enableMoving(bool flag ) | 865 | void 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 | ||
872 | void KToolBar::setBarPos (BarPosition bpos) | 872 | void 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 | ||
881 | const KToolBar::BarPosition KToolBar::barPos() | 881 | const 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 | ||
898 | bool KToolBar::enable(BarStatus stat) | 898 | bool 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 | ||
911 | void KToolBar::setMaxHeight ( int h ) | 911 | void KToolBar::setMaxHeight ( int h ) |
912 | { | 912 | { |
913 | setMaximumHeight( h ); | 913 | setMaximumHeight( h ); |
914 | } | 914 | } |
915 | 915 | ||
916 | int KToolBar::maxHeight() | 916 | int KToolBar::maxHeight() |
917 | { | 917 | { |
918 | return maximumHeight(); | 918 | return maximumHeight(); |
919 | } | 919 | } |
920 | 920 | ||
921 | 921 | ||
922 | void KToolBar::setMaxWidth (int dw) | 922 | void KToolBar::setMaxWidth (int dw) |
923 | { | 923 | { |
924 | setMaximumWidth( dw ); | 924 | setMaximumWidth( dw ); |
925 | } | 925 | } |
926 | 926 | ||
927 | 927 | ||
928 | int KToolBar::maxWidth() | 928 | int KToolBar::maxWidth() |
929 | { | 929 | { |
930 | return maximumWidth(); | 930 | return maximumWidth(); |
931 | } | 931 | } |
932 | 932 | ||
933 | 933 | ||
934 | void KToolBar::setTitle (const QString& _title) | 934 | void KToolBar::setTitle (const QString& _title) |
935 | { | 935 | { |
936 | setLabel( _title ); | 936 | setLabel( _title ); |
937 | } | 937 | } |
938 | 938 | ||
939 | 939 | ||
940 | void KToolBar::enableFloating (bool ) | 940 | void KToolBar::enableFloating (bool ) |
941 | { | 941 | { |
942 | } | 942 | } |
943 | 943 | ||
944 | 944 | ||
945 | void KToolBar::setIconText(IconText it) | 945 | void KToolBar::setIconText(IconText it) |
946 | { | 946 | { |
947 | setIconText( it, true ); | 947 | setIconText( it, true ); |
948 | } | 948 | } |
949 | 949 | ||
950 | 950 | ||
951 | void KToolBar::setIconText(IconText icontext, bool update) | 951 | void 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 | ||
977 | KToolBar::IconText KToolBar::iconText() const | 977 | KToolBar::IconText KToolBar::iconText() const |
978 | { | 978 | { |
979 | return d->m_iconText; | 979 | return d->m_iconText; |
980 | } | 980 | } |
981 | 981 | ||
982 | 982 | ||
983 | void KToolBar::setIconSize(int size) | 983 | void KToolBar::setIconSize(int size) |
984 | { | 984 | { |
985 | setIconSize( size, true ); | 985 | setIconSize( size, true ); |
986 | } | 986 | } |
987 | 987 | ||
988 | void KToolBar::setIconSize(int size, bool update) | 988 | void 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 | ||
1014 | int KToolBar::iconSize() const | 1014 | int 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 | ||
1033 | void KToolBar::setEnableContextMenu(bool enable ) | 1033 | void KToolBar::setEnableContextMenu(bool enable ) |
1034 | { | 1034 | { |
1035 | d->m_enableContext = enable; | 1035 | d->m_enableContext = enable; |
1036 | } | 1036 | } |
1037 | 1037 | ||
1038 | 1038 | ||
1039 | bool KToolBar::contextMenuEnabled() const | 1039 | bool KToolBar::contextMenuEnabled() const |
1040 | { | 1040 | { |
1041 | return d->m_enableContext; | 1041 | return d->m_enableContext; |
1042 | } | 1042 | } |
1043 | 1043 | ||
1044 | 1044 | ||
1045 | void KToolBar::setItemNoStyle(int id, bool no_style ) | 1045 | void 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 | ||
1057 | void KToolBar::setFlat (bool flag) | 1057 | void 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 | ||
1075 | int KToolBar::count() const | 1075 | int KToolBar::count() const |
1076 | { | 1076 | { |
1077 | return id2widget.count(); | 1077 | return id2widget.count(); |
1078 | } | 1078 | } |
1079 | 1079 | ||
1080 | 1080 | ||
1081 | void KToolBar::saveState() | 1081 | void 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 | ||
1147 | QString KToolBar::settingsGroup() | 1147 | QString 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 | ||
1162 | void KToolBar::saveSettings(KConfig *config, const QString &_configGroup) | 1162 | void 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 | ||
1217 | void KToolBar::setXMLGUIClient( KXMLGUIClient *client ) | 1218 | void KToolBar::setXMLGUIClient( KXMLGUIClient *client ) |
1218 | { | 1219 | { |
1219 | d->m_xmlguiClient = client; | 1220 | d->m_xmlguiClient = client; |
1220 | } | 1221 | } |
1221 | 1222 | ||
1222 | void KToolBar::setText( const QString & txt ) | 1223 | void 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 | ||
1229 | QString KToolBar::text() const | 1230 | QString KToolBar::text() const |
1230 | { | 1231 | { |
1231 | return label(); | 1232 | return label(); |
1232 | } | 1233 | } |
1233 | 1234 | ||
1234 | 1235 | ||
1235 | void KToolBar::doConnections( KToolBarButton *button ) | 1236 | void 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 | ||
1245 | void KToolBar::mousePressEvent ( QMouseEvent *m ) | 1246 | void 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 | ||
1305 | void KToolBar::rebuildLayout() | 1306 | void 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 | ||
1358 | void KToolBar::childEvent( QChildEvent *e ) | 1359 | void 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 | ||
1395 | void KToolBar::insertWidgetInternal( QWidget *w, int &index, int id ) | 1396 | void 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 | } |
1413 | void KToolBar::repaintMe() | 1414 | void 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 | ||
1420 | void KToolBar::showEvent( QShowEvent *e ) | 1421 | void KToolBar::showEvent( QShowEvent *e ) |
1421 | { | 1422 | { |
1422 | QToolBar::showEvent( e ); | 1423 | QToolBar::showEvent( e ); |
1423 | rebuildLayout(); | 1424 | rebuildLayout(); |
1424 | } | 1425 | } |
1425 | 1426 | ||
1426 | void KToolBar::setStretchableWidget( QWidget *w ) | 1427 | void KToolBar::setStretchableWidget( QWidget *w ) |
1427 | { | 1428 | { |
1428 | QToolBar::setStretchableWidget( w ); | 1429 | QToolBar::setStretchableWidget( w ); |
1429 | stretchableWidget = w; | 1430 | stretchableWidget = w; |
1430 | } | 1431 | } |
1431 | 1432 | ||
1432 | QSizePolicy KToolBar::sizePolicy() const | 1433 | QSizePolicy 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 | ||
1440 | QSize KToolBar::sizeHint() const | 1441 | QSize 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 | ||
1507 | QSize KToolBar::minimumSize() const | 1508 | QSize KToolBar::minimumSize() const |
1508 | { | 1509 | { |
1509 | return minimumSizeHint(); | 1510 | return minimumSizeHint(); |
1510 | } | 1511 | } |
1511 | 1512 | ||
1512 | QSize KToolBar::minimumSizeHint() const | 1513 | QSize KToolBar::minimumSizeHint() const |
1513 | { | 1514 | { |
1514 | return sizeHint(); | 1515 | return sizeHint(); |
1515 | } | 1516 | } |
1516 | 1517 | ||
1517 | bool KToolBar::highlight() const | 1518 | bool KToolBar::highlight() const |
1518 | { | 1519 | { |
1519 | return d->m_highlight; | 1520 | return d->m_highlight; |
1520 | } | 1521 | } |
1521 | 1522 | ||
1522 | void KToolBar::hide() | 1523 | void KToolBar::hide() |
1523 | { | 1524 | { |
1524 | QToolBar::hide(); | 1525 | QToolBar::hide(); |
1525 | } | 1526 | } |
1526 | 1527 | ||
1527 | void KToolBar::show() | 1528 | void KToolBar::show() |
1528 | { | 1529 | { |
1529 | QToolBar::show(); | 1530 | QToolBar::show(); |
1530 | } | 1531 | } |
1531 | 1532 | ||
1532 | void KToolBar::resizeEvent( QResizeEvent *e ) | 1533 | void 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 | ||
1541 | void KToolBar::slotIconChanged(int group) | 1542 | void 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 | ||
1553 | void KToolBar::slotReadConfig() | 1554 | void 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 | ||
1562 | void KToolBar::slotAppearanceChanged() | 1563 | void 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 |
1574 | bool KToolBar::highlightSetting() | 1575 | bool 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 |
1582 | bool KToolBar::transparentSetting() | 1583 | bool 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 |
1590 | KToolBar::IconText KToolBar::iconTextSetting() | 1591 | KToolBar::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 | ||
1605 | void KToolBar::applyAppearanceSettings(KConfig *config, const QString &_configGroup, bool forceGlobal) | 1606 | void 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 | ||
1736 | void KToolBar::applySettings(KConfig *config, const QString &_configGroup) | 1738 | void 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 | ||
1839 | bool KToolBar::event( QEvent *e ) | 1841 | bool 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 | ||
1856 | void KToolBar::slotRepaint() | 1858 | void 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 | ||
1871 | void KToolBar::toolBarPosChanged( QToolBar *tb ) | 1873 | void 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 |
1886 | void KToolBar::loadState( const QDomElement &element ) | 1888 | void 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 | ||
1996 | void KToolBar::getAttributes( QString &position, QString &icontext, int &index ) | 1998 | void 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 |
2045 | void KToolBar::saveState( QDomElement ¤t ) | 2047 | void KToolBar::saveState( QDomElement ¤t ) |
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 | ||
2063 | void KToolBar::positionYourself( bool force ) | 2065 | void 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() |
2091 | QPopupMenu *KToolBar::contextMenu() | 2093 | QPopupMenu *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 | ||
2169 | void KToolBar::slotContextAboutToShow() | 2171 | void 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 | ||
2245 | void KToolBar::widgetDestroyed() | 2247 | void KToolBar::widgetDestroyed() |
2246 | { | 2248 | { |
2247 | removeWidgetInternal( (QWidget*)sender() ); | 2249 | removeWidgetInternal( (QWidget*)sender() ); |
2248 | } | 2250 | } |
2249 | 2251 | ||
2250 | void KToolBar::removeWidgetInternal( QWidget * w ) | 2252 | void 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 | ||
2262 | void KToolBar::virtual_hook( int, void* ) | 2264 | void 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 | ||