-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | kaddressbook/kabprefs.cpp | 73 | ||||
-rw-r--r-- | kaddressbook/kabprefs.h | 1 | ||||
-rw-r--r-- | kmicromail/koprefs.h | 2 | ||||
-rw-r--r-- | korganizer/kodialogmanager.cpp | 5 | ||||
-rw-r--r-- | korganizer/koprefs.cpp | 88 | ||||
-rw-r--r-- | korganizer/koprefs.h | 16 | ||||
-rw-r--r-- | korganizer/ktimeedit.cpp | 5 | ||||
-rw-r--r-- | korganizer/mainwindow.cpp | 3 | ||||
-rw-r--r-- | libkdepim/kpimglobalprefs.cpp | 76 | ||||
-rw-r--r-- | libkdepim/kpimglobalprefs.h | 2 | ||||
-rw-r--r-- | microkde/kstaticdeleter.h | 5 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmprefs.cpp | 12 |
13 files changed, 105 insertions, 185 deletions
@@ -1,67 +1,67 @@ | |||
1 | ############################################################################# | 1 | ############################################################################# |
2 | # Makefile for building: kdepim-desktop | 2 | # Makefile for building: kdepim-desktop |
3 | # Generated by qmake (1.07a) (Qt 3.3.3) on: Sat Oct 23 09:29:11 2004 | 3 | # Generated by qmake (1.07a) (Qt 3.3.3) on: Sat Oct 23 12:23:49 2004 |
4 | # Project: kdepim-desktop.pro | 4 | # Project: kdepim-desktop.pro |
5 | # Template: subdirs | 5 | # Template: subdirs |
6 | # Command: $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kdepim-desktop.pro | 6 | # Command: $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kdepim-desktop.pro |
7 | ############################################################################# | 7 | ############################################################################# |
8 | 8 | ||
9 | MAKEFILE =Makefile | 9 | MAKEFILE =Makefile |
10 | QMAKE =qmake | 10 | QMAKE =qmake |
11 | DEL_FILE = rm -f | 11 | DEL_FILE = rm -f |
12 | CHK_DIR_EXISTS= test -d | 12 | CHK_DIR_EXISTS= test -d |
13 | MKDIR = mkdir -p | 13 | MKDIR = mkdir -p |
14 | INSTALL_FILE= | 14 | INSTALL_FILE= |
15 | INSTALL_DIR = | 15 | INSTALL_DIR = |
16 | SUBTARGETS = \ | 16 | SUBTARGETS = \ |
17 | sub-gammu-emb-common \ | 17 | sub-gammu-emb-common \ |
18 | sub-gammu-emb-gammu \ | 18 | sub-gammu-emb-gammu \ |
19 | sub-libical \ | 19 | sub-libical \ |
20 | sub-libkcal \ | 20 | sub-libkcal \ |
21 | sub-microkde \ | 21 | sub-microkde \ |
22 | sub-libkdepim \ | 22 | sub-libkdepim \ |
23 | sub-kabc \ | 23 | sub-kabc \ |
24 | sub-korganizer \ | 24 | sub-korganizer \ |
25 | sub-kaddressbook \ | 25 | sub-kaddressbook \ |
26 | sub-kabc-plugins-file \ | 26 | sub-kabc-plugins-file \ |
27 | sub-kabc-plugins-dir \ | 27 | sub-kabc-plugins-dir \ |
28 | sub-pwmanager-libcrypt-cipher \ | 28 | sub-pwmanager-libcrypt-cipher \ |
29 | sub-pwmanager-libcrypt-error \ | 29 | sub-pwmanager-libcrypt-error \ |
30 | sub-pwmanager-libcrypt-mpi \ | 30 | sub-pwmanager-libcrypt-mpi \ |
31 | sub-pwmanager-libcrypt-zlib \ | 31 | sub-pwmanager-libcrypt-zlib \ |
32 | sub-pwmanager-pwmanager | 32 | sub-pwmanager-pwmanager |
33 | 33 | ||
34 | first: all | 34 | first: all |
35 | 35 | ||
36 | all: Makefile $(SUBTARGETS) | 36 | all: Makefile $(SUBTARGETS) |
37 | 37 | ||
38 | gammu/emb/common/$(MAKEFILE): | 38 | gammu/emb/common/$(MAKEFILE): |
39 | @$(CHK_DIR_EXISTS) "gammu/emb/common" || $(MKDIR) "gammu/emb/common" | 39 | @$(CHK_DIR_EXISTS) "gammu/emb/common" || $(MKDIR) "gammu/emb/common" |
40 | cd gammu/emb/common && $(QMAKE) common.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 40 | cd gammu/emb/common && $(QMAKE) common.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
41 | sub-gammu-emb-common: gammu/emb/common/$(MAKEFILE) FORCE | 41 | sub-gammu-emb-common: gammu/emb/common/$(MAKEFILE) FORCE |
42 | cd gammu/emb/common && $(MAKE) -f $(MAKEFILE) | 42 | cd gammu/emb/common && $(MAKE) -f $(MAKEFILE) |
43 | 43 | ||
44 | gammu/emb/gammu/$(MAKEFILE): | 44 | gammu/emb/gammu/$(MAKEFILE): |
45 | @$(CHK_DIR_EXISTS) "gammu/emb/gammu" || $(MKDIR) "gammu/emb/gammu" | 45 | @$(CHK_DIR_EXISTS) "gammu/emb/gammu" || $(MKDIR) "gammu/emb/gammu" |
46 | cd gammu/emb/gammu && $(QMAKE) gammu.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 46 | cd gammu/emb/gammu && $(QMAKE) gammu.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
47 | sub-gammu-emb-gammu: gammu/emb/gammu/$(MAKEFILE) FORCE | 47 | sub-gammu-emb-gammu: gammu/emb/gammu/$(MAKEFILE) FORCE |
48 | cd gammu/emb/gammu && $(MAKE) -f $(MAKEFILE) | 48 | cd gammu/emb/gammu && $(MAKE) -f $(MAKEFILE) |
49 | 49 | ||
50 | libical/$(MAKEFILE): | 50 | libical/$(MAKEFILE): |
51 | @$(CHK_DIR_EXISTS) "libical" || $(MKDIR) "libical" | 51 | @$(CHK_DIR_EXISTS) "libical" || $(MKDIR) "libical" |
52 | cd libical && $(QMAKE) libical.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 52 | cd libical && $(QMAKE) libical.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
53 | sub-libical: libical/$(MAKEFILE) FORCE | 53 | sub-libical: libical/$(MAKEFILE) FORCE |
54 | cd libical && $(MAKE) -f $(MAKEFILE) | 54 | cd libical && $(MAKE) -f $(MAKEFILE) |
55 | 55 | ||
56 | libkcal/$(MAKEFILE): | 56 | libkcal/$(MAKEFILE): |
57 | @$(CHK_DIR_EXISTS) "libkcal" || $(MKDIR) "libkcal" | 57 | @$(CHK_DIR_EXISTS) "libkcal" || $(MKDIR) "libkcal" |
58 | cd libkcal && $(QMAKE) libkcal.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 58 | cd libkcal && $(QMAKE) libkcal.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
59 | sub-libkcal: libkcal/$(MAKEFILE) FORCE | 59 | sub-libkcal: libkcal/$(MAKEFILE) FORCE |
60 | cd libkcal && $(MAKE) -f $(MAKEFILE) | 60 | cd libkcal && $(MAKE) -f $(MAKEFILE) |
61 | 61 | ||
62 | microkde/$(MAKEFILE): | 62 | microkde/$(MAKEFILE): |
63 | @$(CHK_DIR_EXISTS) "microkde" || $(MKDIR) "microkde" | 63 | @$(CHK_DIR_EXISTS) "microkde" || $(MKDIR) "microkde" |
64 | cd microkde && $(QMAKE) microkde.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 64 | cd microkde && $(QMAKE) microkde.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
65 | sub-microkde: microkde/$(MAKEFILE) FORCE | 65 | sub-microkde: microkde/$(MAKEFILE) FORCE |
66 | cd microkde && $(MAKE) -f $(MAKEFILE) | 66 | cd microkde && $(MAKE) -f $(MAKEFILE) |
67 | 67 | ||
diff --git a/kaddressbook/kabprefs.cpp b/kaddressbook/kabprefs.cpp index 01c935f..3cbcc9a 100644 --- a/kaddressbook/kabprefs.cpp +++ b/kaddressbook/kabprefs.cpp | |||
@@ -1,213 +1,150 @@ | |||
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 | //US#ifdef KAB_EMBEDDED | 24 | //US#ifdef KAB_EMBEDDED |
25 | //#include <qstring.h> | 25 | //#include <qstring.h> |
26 | //#endif //KAB_EMBEDDED | 26 | //#endif //KAB_EMBEDDED |
27 | 27 | ||
28 | #include <qtextstream.h> | 28 | #include <qtextstream.h> |
29 | #include <qfile.h> | 29 | #include <qfile.h> |
30 | #include <qregexp.h> | 30 | #include <qregexp.h> |
31 | #include <stdlib.h> | 31 | #include <stdlib.h> |
32 | #include <libkdepim/kpimglobalprefs.h> | 32 | #include <libkdepim/kpimglobalprefs.h> |
33 | 33 | ||
34 | #include <kconfig.h> | 34 | #include <kconfig.h> |
35 | #include <klocale.h> | 35 | #include <klocale.h> |
36 | #include <kstaticdeleter.h> | 36 | #include <kstaticdeleter.h> |
37 | //US#include <kdebug.h> // defines kdDebug() | 37 | //US#include <kdebug.h> // defines kdDebug() |
38 | 38 | ||
39 | #include "kabprefs.h" | 39 | #include "kabprefs.h" |
40 | 40 | ||
41 | #ifdef DESKTOP_VERSION | 41 | #ifdef DESKTOP_VERSION |
42 | #include <qapplication.h> | 42 | #include <qapplication.h> |
43 | #endif | 43 | #endif |
44 | 44 | ||
45 | KABPrefs *KABPrefs::sInstance = 0; | 45 | KABPrefs *KABPrefs::sInstance = 0; |
46 | static KStaticDeleter<KABPrefs> staticDeleter; | 46 | static KStaticDeleter<KABPrefs> staticDeleterAB; |
47 | 47 | ||
48 | KABPrefs::KABPrefs() | 48 | KABPrefs::KABPrefs() |
49 | : KPimPrefs("kaddressbookrc") | 49 | : KPimPrefs("kaddressbookrc") |
50 | { | 50 | { |
51 | |||
52 | mLocaleDict = 0; | ||
53 | mDetailsFont = QFont("helvetica",12); | 51 | mDetailsFont = QFont("helvetica",12); |
54 | KPrefs::setCurrentGroup( "Views" ); | 52 | KPrefs::setCurrentGroup( "Views" ); |
55 | addItemBool( "HonorSingleClick", &mHonorSingleClick, false ); | 53 | addItemBool( "HonorSingleClick", &mHonorSingleClick, false ); |
56 | 54 | ||
57 | KPrefs::setCurrentGroup( "General" ); | 55 | KPrefs::setCurrentGroup( "General" ); |
58 | addItemBool( "AutomaticNameParsing", &mAutomaticNameParsing, true ); | 56 | addItemBool( "AutomaticNameParsing", &mAutomaticNameParsing, true ); |
59 | addItemInt( "CurrentIncSearchField", &mCurrentIncSearchField, 0 ); | 57 | addItemInt( "CurrentIncSearchField", &mCurrentIncSearchField, 0 ); |
60 | 58 | ||
61 | #ifdef KAB_EMBEDDED | 59 | #ifdef KAB_EMBEDDED |
62 | addItemBool("AskForQuit",&mAskForQuit,true); | 60 | addItemBool("AskForQuit",&mAskForQuit,true); |
63 | addItemBool("ToolBarHor",&mToolBarHor, true ); | 61 | addItemBool("ToolBarHor",&mToolBarHor, true ); |
64 | addItemBool("ToolBarUp",&mToolBarUp, false ); | 62 | addItemBool("ToolBarUp",&mToolBarUp, false ); |
65 | addItemBool("SearchWithReturn",&mSearchWithReturn, true ); | 63 | addItemBool("SearchWithReturn",&mSearchWithReturn, true ); |
66 | addItemFont("DetailsFont",&mDetailsFont); | 64 | addItemFont("DetailsFont",&mDetailsFont); |
67 | 65 | ||
68 | 66 | ||
69 | #endif //KAB_EMBEDDED | 67 | #endif //KAB_EMBEDDED |
70 | 68 | ||
71 | KPrefs::setCurrentGroup( "MainWindow" ); | 69 | KPrefs::setCurrentGroup( "MainWindow" ); |
72 | addItemBool( "JumpButtonBarVisible", &mJumpButtonBarVisible, false ); | 70 | addItemBool( "JumpButtonBarVisible", &mJumpButtonBarVisible, false ); |
73 | addItemBool( "DetailsPageVisible", &mDetailsPageVisible, true ); | 71 | addItemBool( "DetailsPageVisible", &mDetailsPageVisible, true ); |
74 | addItemIntList( "ExtensionsSplitter", &mExtensionsSplitter ); | 72 | addItemIntList( "ExtensionsSplitter", &mExtensionsSplitter ); |
75 | addItemIntList( "DetailsSplitter", &mDetailsSplitter ); | 73 | addItemIntList( "DetailsSplitter", &mDetailsSplitter ); |
76 | addItemBool( "MultipleViewsAtOnce", &mMultipleViewsAtOnce, true ); | 74 | addItemBool( "MultipleViewsAtOnce", &mMultipleViewsAtOnce, true ); |
77 | 75 | ||
78 | 76 | ||
79 | KPrefs::setCurrentGroup( "Extensions_General" ); | 77 | KPrefs::setCurrentGroup( "Extensions_General" ); |
80 | QStringList defaultExtensions; | 78 | QStringList defaultExtensions; |
81 | defaultExtensions << "merge"; | 79 | defaultExtensions << "merge"; |
82 | defaultExtensions << "distribution_list_editor"; | 80 | defaultExtensions << "distribution_list_editor"; |
83 | addItemInt( "CurrentExtension", &mCurrentExtension, 0 ); | 81 | addItemInt( "CurrentExtension", &mCurrentExtension, 0 ); |
84 | addItemStringList( "ActiveExtensions", &mActiveExtensions, defaultExtensions ); | 82 | addItemStringList( "ActiveExtensions", &mActiveExtensions, defaultExtensions ); |
85 | 83 | ||
86 | KPrefs::setCurrentGroup( "Views" ); | 84 | KPrefs::setCurrentGroup( "Views" ); |
87 | QString defaultView = i18n( "Default Table View" ); | 85 | QString defaultView = i18n( "Default Table View" ); |
88 | addItemString( "CurrentView", &mCurrentView, defaultView ); | 86 | addItemString( "CurrentView", &mCurrentView, defaultView ); |
89 | addItemStringList( "ViewNames", &mViewNames, defaultView ); | 87 | addItemStringList( "ViewNames", &mViewNames, defaultView ); |
90 | 88 | ||
91 | KPrefs::setCurrentGroup( "Filters" ); | 89 | KPrefs::setCurrentGroup( "Filters" ); |
92 | addItemInt( "CurrentFilter", &mCurrentFilter, 0 ); | 90 | addItemInt( "CurrentFilter", &mCurrentFilter, 0 ); |
93 | 91 | ||
94 | } | 92 | } |
95 | 93 | ||
96 | KABPrefs::~KABPrefs() | 94 | KABPrefs::~KABPrefs() |
97 | { | 95 | { |
98 | //qDebug("KABPrefs::~KABPrefs() "); | 96 | //qDebug("KABPrefs::~KABPrefs() "); |
99 | setLocaleDict( 0 ); | 97 | if (sInstance == this) |
100 | if ( mLocaleDict ) | 98 | sInstance = staticDeleterAB.setObject(0); |
101 | delete mLocaleDict; | ||
102 | } | 99 | } |
103 | 100 | ||
104 | KABPrefs *KABPrefs::instance() | 101 | KABPrefs *KABPrefs::instance() |
105 | { | 102 | { |
106 | if ( !sInstance ) { | 103 | if ( !sInstance ) { |
107 | #ifdef KAB_EMBEDDED | 104 | #ifdef KAB_EMBEDDED |
108 | sInstance = staticDeleter.setObject( new KABPrefs() ); | 105 | sInstance = staticDeleterAB.setObject( new KABPrefs() ); |
109 | #else //KAB_EMBEDDED | 106 | #else //KAB_EMBEDDED |
110 | //US the following line has changed ???. Why | 107 | //US the following line has changed ???. Why |
111 | staticDeleter.setObject( sInstance, new KABPrefs() ); | 108 | staticDeleterAB.setObject( sInstance, new KABPrefs() ); |
112 | #endif //KAB_EMBEDDED | 109 | #endif //KAB_EMBEDDED |
113 | sInstance->readConfig(); | 110 | sInstance->readConfig(); |
114 | } | 111 | } |
115 | 112 | ||
116 | return sInstance; | 113 | return sInstance; |
117 | } | 114 | } |
118 | 115 | ||
119 | void KABPrefs::setCategoryDefaults() | 116 | void KABPrefs::setCategoryDefaults() |
120 | { | 117 | { |
121 | mCustomCategories.clear(); | 118 | mCustomCategories.clear(); |
122 | 119 | ||
123 | mCustomCategories << i18n( "Business" ) << i18n( "Family" ) << i18n( "School" ) | 120 | mCustomCategories << i18n( "Business" ) << i18n( "Family" ) << i18n( "School" ) |
124 | << i18n( "Customer" ) << i18n( "Friend" ); | 121 | << i18n( "Customer" ) << i18n( "Friend" ); |
125 | } | 122 | } |
126 | 123 | ||
127 | // US introduce a nonconst way to return the config object. | 124 | // US introduce a nonconst way to return the config object. |
128 | KConfig* KABPrefs::getConfig() | 125 | KConfig* KABPrefs::getConfig() |
129 | { | 126 | { |
130 | return config(); | 127 | return config(); |
131 | } | 128 | } |
132 | void KABPrefs::usrReadConfig() | 129 | void KABPrefs::usrReadConfig() |
133 | { | 130 | { |
134 | QString fileName ; | ||
135 | #ifndef DESKTOP_VERSION | ||
136 | fileName= QString(getenv("QPEDIR"))+"/pics/kdepim/kaddressbook/"; | ||
137 | #else | ||
138 | fileName = qApp->applicationDirPath () + "/kdepim/kaddressbook/"; | ||
139 | #endif | ||
140 | int mPreferredLanguage = KPimGlobalPrefs::instance()->mPreferredLanguage; | ||
141 | mLocaleDict = 0; | ||
142 | if ( mPreferredLanguage > 0 && mPreferredLanguage < 5 ) { | ||
143 | |||
144 | if ( mPreferredLanguage == 1 ) | ||
145 | fileName = fileName+"germantranslation.txt"; | ||
146 | else if ( mPreferredLanguage == 4 ) | ||
147 | fileName = fileName+"usertranslation.txt"; | ||
148 | else if ( mPreferredLanguage == 2 ) | ||
149 | fileName = fileName+"frenchtranslation.txt"; | ||
150 | else if ( mPreferredLanguage == 3 ) | ||
151 | fileName = fileName+"italiantranslation.txt"; | ||
152 | QFile file( fileName ); | ||
153 | if (file.open( IO_ReadOnly ) ) { | ||
154 | QTextStream ts( &file ); | ||
155 | ts.setEncoding( QTextStream::Latin1 ); | ||
156 | //ts.setCodec( QTextCodec::latin1 ); | ||
157 | QString text = ts.read(); | ||
158 | file.close(); | ||
159 | text.replace( QRegExp("\\\\n"), "\n" ); | ||
160 | QString line; | ||
161 | QString we; | ||
162 | QString wt; | ||
163 | int br = 0; | ||
164 | int nbr; | ||
165 | nbr = text.find ( "},", br ); | ||
166 | line = text.mid( br, nbr - br ); | ||
167 | br = nbr+1; | ||
168 | int se, ee, st, et; | ||
169 | mLocaleDict = new QDict<QString>; | ||
170 | QString end = "{ \"\",\"\" }"; | ||
171 | while ( (line != end) && (br > 1) ) { | ||
172 | //qDebug("%d *%s* ", br, line.latin1()); | ||
173 | se = line.find("\"")+1; | ||
174 | et = line.findRev("\"",-1); | ||
175 | ee = line.find("\",\""); | ||
176 | st = ee+3; | ||
177 | we = line.mid( se, ee-se ); | ||
178 | wt = line.mid( st, et-st ); | ||
179 | //qDebug("*%s* *%s* ", we.latin1(), wt.latin1()); | ||
180 | mLocaleDict->insert( we, new QString (wt) ); | ||
181 | nbr = text.find ( "}", br ); | ||
182 | line = text.mid( br, nbr - br ); | ||
183 | br = nbr+1; | ||
184 | } | ||
185 | //qDebug("end *%s* ", end.latin1()); | ||
186 | |||
187 | setLocaleDict( mLocaleDict ); | ||
188 | } else { | ||
189 | qDebug("KO: Cannot find translation file %s",fileName.latin1() ); | ||
190 | } | ||
191 | |||
192 | |||
193 | } | ||
194 | KPimPrefs::usrReadConfig(); | 131 | KPimPrefs::usrReadConfig(); |
195 | } | 132 | } |
196 | 133 | ||
197 | 134 | ||
198 | /*US | 135 | /*US |
199 | void KABPrefs::usrSetDefaults() | 136 | void KABPrefs::usrSetDefaults() |
200 | { | 137 | { |
201 | KPimPrefs::usrSetDefaults(); | 138 | KPimPrefs::usrSetDefaults(); |
202 | } | 139 | } |
203 | 140 | ||
204 | void KABPrefs::usrReadConfig() | 141 | void KABPrefs::usrReadConfig() |
205 | { | 142 | { |
206 | KPimPrefs::usrReadConfig(); | 143 | KPimPrefs::usrReadConfig(); |
207 | } | 144 | } |
208 | 145 | ||
209 | void KABPrefs::usrWriteConfig() | 146 | void KABPrefs::usrWriteConfig() |
210 | { | 147 | { |
211 | KPimPrefs::usrWriteConfig(); | 148 | KPimPrefs::usrWriteConfig(); |
212 | } | 149 | } |
213 | */ | 150 | */ |
diff --git a/kaddressbook/kabprefs.h b/kaddressbook/kabprefs.h index 1098f4c..cc8413e 100644 --- a/kaddressbook/kabprefs.h +++ b/kaddressbook/kabprefs.h | |||
@@ -28,69 +28,68 @@ | |||
28 | #include <qdict.h> | 28 | #include <qdict.h> |
29 | 29 | ||
30 | #include <libkdepim/kpimprefs.h> | 30 | #include <libkdepim/kpimprefs.h> |
31 | 31 | ||
32 | class KConfig; | 32 | class KConfig; |
33 | 33 | ||
34 | class KABPrefs : public KPimPrefs | 34 | class KABPrefs : public KPimPrefs |
35 | { | 35 | { |
36 | public: | 36 | public: |
37 | virtual ~KABPrefs(); | 37 | virtual ~KABPrefs(); |
38 | 38 | ||
39 | static KABPrefs *instance(); | 39 | static KABPrefs *instance(); |
40 | 40 | ||
41 | // General | 41 | // General |
42 | bool mHonorSingleClick; | 42 | bool mHonorSingleClick; |
43 | bool mAutomaticNameParsing; | 43 | bool mAutomaticNameParsing; |
44 | int mCurrentIncSearchField; | 44 | int mCurrentIncSearchField; |
45 | 45 | ||
46 | #ifdef KAB_EMBEDDED | 46 | #ifdef KAB_EMBEDDED |
47 | // US introduce a nonconst way to return the config object. | 47 | // US introduce a nonconst way to return the config object. |
48 | KConfig* getConfig(); | 48 | KConfig* getConfig(); |
49 | 49 | ||
50 | bool mToolBarHor; | 50 | bool mToolBarHor; |
51 | bool mToolBarUp; | 51 | bool mToolBarUp; |
52 | bool mAskForQuit; | 52 | bool mAskForQuit; |
53 | 53 | ||
54 | 54 | ||
55 | /** Set preferences to default values */ | 55 | /** Set preferences to default values */ |
56 | // void usrSetDefaults(); | 56 | // void usrSetDefaults(); |
57 | 57 | ||
58 | /** Read preferences from config file */ | 58 | /** Read preferences from config file */ |
59 | // void usrReadConfig(); | 59 | // void usrReadConfig(); |
60 | 60 | ||
61 | /** Write preferences to config file */ | 61 | /** Write preferences to config file */ |
62 | // void usrWriteConfig(); | 62 | // void usrWriteConfig(); |
63 | #endif //KAB_EMBEDDED | 63 | #endif //KAB_EMBEDDED |
64 | void usrReadConfig(); | 64 | void usrReadConfig(); |
65 | 65 | ||
66 | 66 | ||
67 | // GUI | 67 | // GUI |
68 | bool mJumpButtonBarVisible; | 68 | bool mJumpButtonBarVisible; |
69 | bool mDetailsPageVisible; | 69 | bool mDetailsPageVisible; |
70 | bool mMultipleViewsAtOnce; | 70 | bool mMultipleViewsAtOnce; |
71 | bool mSearchWithReturn; | 71 | bool mSearchWithReturn; |
72 | QValueList<int> mExtensionsSplitter; | 72 | QValueList<int> mExtensionsSplitter; |
73 | QValueList<int> mDetailsSplitter; | 73 | QValueList<int> mDetailsSplitter; |
74 | 74 | ||
75 | // Extensions stuff | 75 | // Extensions stuff |
76 | int mCurrentExtension; | 76 | int mCurrentExtension; |
77 | QStringList mActiveExtensions; | 77 | QStringList mActiveExtensions; |
78 | 78 | ||
79 | // Views stuff | 79 | // Views stuff |
80 | QString mCurrentView; | 80 | QString mCurrentView; |
81 | QStringList mViewNames; | 81 | QStringList mViewNames; |
82 | 82 | ||
83 | // Filter | 83 | // Filter |
84 | int mCurrentFilter; | 84 | int mCurrentFilter; |
85 | 85 | ||
86 | void setCategoryDefaults(); | 86 | void setCategoryDefaults(); |
87 | QFont mDetailsFont; | 87 | QFont mDetailsFont; |
88 | 88 | ||
89 | private: | 89 | private: |
90 | KABPrefs(); | 90 | KABPrefs(); |
91 | 91 | ||
92 | QDict<QString> *mLocaleDict; | ||
93 | static KABPrefs *sInstance; | 92 | static KABPrefs *sInstance; |
94 | }; | 93 | }; |
95 | 94 | ||
96 | #endif | 95 | #endif |
diff --git a/kmicromail/koprefs.h b/kmicromail/koprefs.h index a47642b..f0a4463 100644 --- a/kmicromail/koprefs.h +++ b/kmicromail/koprefs.h | |||
@@ -1,79 +1,77 @@ | |||
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 KOPREFS_H | 23 | #ifndef KOPREFS_H |
24 | #define KOPREFS_H | 24 | #define KOPREFS_H |
25 | 25 | ||
26 | #include <qdict.h> | ||
27 | 26 | ||
28 | #include <libkdepim/kpimprefs.h> | 27 | #include <libkdepim/kpimprefs.h> |
29 | 28 | ||
30 | class KConfig; | 29 | class KConfig; |
31 | class QFont; | 30 | class QFont; |
32 | class QColor; | 31 | class QColor; |
33 | class QStringList; | 32 | class QStringList; |
34 | 33 | ||
35 | class KOPrefs : public KPimPrefs | 34 | class KOPrefs : public KPimPrefs |
36 | { | 35 | { |
37 | public: | 36 | public: |
38 | virtual ~KOPrefs(); | 37 | virtual ~KOPrefs(); |
39 | 38 | ||
40 | /** Get instance of KOPrefs. It is made sure that there is only one | 39 | /** Get instance of KOPrefs. It is made sure that there is only one |
41 | instance. */ | 40 | instance. */ |
42 | static KOPrefs *instance(); | 41 | static KOPrefs *instance(); |
43 | 42 | ||
44 | /** Set preferences to default values */ | 43 | /** Set preferences to default values */ |
45 | void usrSetDefaults(); | 44 | void usrSetDefaults(); |
46 | 45 | ||
47 | /** Read preferences from config file */ | 46 | /** Read preferences from config file */ |
48 | void usrReadConfig(); | 47 | void usrReadConfig(); |
49 | 48 | ||
50 | /** Write preferences to config file */ | 49 | /** Write preferences to config file */ |
51 | void usrWriteConfig(); | 50 | void usrWriteConfig(); |
52 | void setCategoryDefaults(){;}; | 51 | void setCategoryDefaults(){;}; |
53 | 52 | ||
54 | protected: | 53 | protected: |
55 | 54 | ||
56 | /** Fill empty mail fields with default values. */ | 55 | /** Fill empty mail fields with default values. */ |
57 | void fillMailDefaults(); | 56 | void fillMailDefaults(); |
58 | 57 | ||
59 | private: | 58 | private: |
60 | /** Constructor disabled for public. Use instance() to create a KOPrefs | 59 | /** Constructor disabled for public. Use instance() to create a KOPrefs |
61 | object. */ | 60 | object. */ |
62 | KOPrefs(); | 61 | KOPrefs(); |
63 | 62 | ||
64 | static KOPrefs *mInstance; | 63 | static KOPrefs *mInstance; |
65 | QDict<QString> *mLocaleDict; | ||
66 | public: | 64 | public: |
67 | // preferences data | 65 | // preferences data |
68 | KConfig* getConfig(); | 66 | KConfig* getConfig(); |
69 | QFont mAppFont; | 67 | QFont mAppFont; |
70 | QFont mComposeFont; | 68 | QFont mComposeFont; |
71 | QFont mReadFont; | 69 | QFont mReadFont; |
72 | QString mName; | 70 | QString mName; |
73 | QString mEmail; | 71 | QString mEmail; |
74 | bool mSendLater, mViewAsHtml, mUseKapi; | 72 | bool mSendLater, mViewAsHtml, mUseKapi; |
75 | private: | 73 | private: |
76 | 74 | ||
77 | }; | 75 | }; |
78 | 76 | ||
79 | #endif | 77 | #endif |
diff --git a/korganizer/kodialogmanager.cpp b/korganizer/kodialogmanager.cpp index 58198a2..db7c3f2 100644 --- a/korganizer/kodialogmanager.cpp +++ b/korganizer/kodialogmanager.cpp | |||
@@ -28,149 +28,148 @@ | |||
28 | #include "koeventeditor.h" | 28 | #include "koeventeditor.h" |
29 | #include "koprefs.h" | 29 | #include "koprefs.h" |
30 | #include "datenavigator.h" | 30 | #include "datenavigator.h" |
31 | #include "kotodoeditor.h" | 31 | #include "kotodoeditor.h" |
32 | #include "searchdialog.h" | 32 | #include "searchdialog.h" |
33 | #include "filtereditdialog.h" | 33 | #include "filtereditdialog.h" |
34 | #ifndef KORG_NOPLUGINS | 34 | #ifndef KORG_NOPLUGINS |
35 | #include "plugindialog.h" | 35 | #include "plugindialog.h" |
36 | #endif | 36 | #endif |
37 | #ifndef KORG_NOARCHIVE | 37 | #ifndef KORG_NOARCHIVE |
38 | #include "archivedialog.h" | 38 | #include "archivedialog.h" |
39 | #endif | 39 | #endif |
40 | 40 | ||
41 | #include "kconfig.h" | 41 | #include "kconfig.h" |
42 | #include "kodialogmanager.h" | 42 | #include "kodialogmanager.h" |
43 | 43 | ||
44 | KODialogManager::KODialogManager( CalendarView *mainView ) : | 44 | KODialogManager::KODialogManager( CalendarView *mainView ) : |
45 | QObject(), mMainView( mainView ) | 45 | QObject(), mMainView( mainView ) |
46 | { | 46 | { |
47 | mOutgoingDialog = 0; | 47 | mOutgoingDialog = 0; |
48 | mIncomingDialog = 0; | 48 | mIncomingDialog = 0; |
49 | mOptionsDialog = 0; | 49 | mOptionsDialog = 0; |
50 | mSearchDialog = 0; | 50 | mSearchDialog = 0; |
51 | mArchiveDialog = 0; | 51 | mArchiveDialog = 0; |
52 | mFilterEditDialog = 0; | 52 | mFilterEditDialog = 0; |
53 | mPluginDialog = 0; | 53 | mPluginDialog = 0; |
54 | 54 | ||
55 | // mCategoryEditDialog = new KPIM::CategoryEditDialog(KOPrefs::instance(),mMainView); | 55 | // mCategoryEditDialog = new KPIM::CategoryEditDialog(KOPrefs::instance(),mMainView); |
56 | //KOGlobals::fitDialogToScreen( mCategoryEditDialog ); | 56 | //KOGlobals::fitDialogToScreen( mCategoryEditDialog ); |
57 | } | 57 | } |
58 | 58 | ||
59 | KODialogManager::~KODialogManager() | 59 | KODialogManager::~KODialogManager() |
60 | { | 60 | { |
61 | delete mOutgoingDialog; | 61 | delete mOutgoingDialog; |
62 | delete mIncomingDialog; | 62 | delete mIncomingDialog; |
63 | delete mOptionsDialog; | 63 | delete mOptionsDialog; |
64 | delete mSearchDialog; | 64 | delete mSearchDialog; |
65 | #ifndef KORG_NOARCHIVE | 65 | #ifndef KORG_NOARCHIVE |
66 | delete mArchiveDialog; | 66 | delete mArchiveDialog; |
67 | #endif | 67 | #endif |
68 | delete mFilterEditDialog; | 68 | delete mFilterEditDialog; |
69 | #ifndef KORG_NOPLUGINS | 69 | #ifndef KORG_NOPLUGINS |
70 | delete mPluginDialog; | 70 | delete mPluginDialog; |
71 | #endif | 71 | #endif |
72 | } | 72 | } |
73 | 73 | ||
74 | OutgoingDialog *KODialogManager::outgoingDialog() | 74 | OutgoingDialog *KODialogManager::outgoingDialog() |
75 | { | 75 | { |
76 | createOutgoingDialog(); | 76 | createOutgoingDialog(); |
77 | return mOutgoingDialog; | 77 | return mOutgoingDialog; |
78 | } | 78 | } |
79 | 79 | ||
80 | void KODialogManager::createOutgoingDialog() | 80 | void KODialogManager::createOutgoingDialog() |
81 | { | 81 | { |
82 | if (!mOutgoingDialog) { | 82 | if (!mOutgoingDialog) { |
83 | mOutgoingDialog = new OutgoingDialog(mMainView->calendar(),mMainView); | 83 | mOutgoingDialog = new OutgoingDialog(mMainView->calendar(),mMainView); |
84 | if (mIncomingDialog) mIncomingDialog->setOutgoingDialog(mOutgoingDialog); | 84 | if (mIncomingDialog) mIncomingDialog->setOutgoingDialog(mOutgoingDialog); |
85 | connect(mOutgoingDialog,SIGNAL(numMessagesChanged(int)), | 85 | connect(mOutgoingDialog,SIGNAL(numMessagesChanged(int)), |
86 | mMainView,SIGNAL(numOutgoingChanged(int))); | 86 | mMainView,SIGNAL(numOutgoingChanged(int))); |
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | void KODialogManager::showOptionsDialog( bool showSync ) | 90 | void KODialogManager::showOptionsDialog( bool showSync ) |
91 | { | 91 | { |
92 | int curLanguage = KOPrefs::instance()->mPreferredLanguage; | 92 | |
93 | if (!mOptionsDialog) { | 93 | if (!mOptionsDialog) { |
94 | mOptionsDialog = new KOPrefsDialog(mMainView); | 94 | mOptionsDialog = new KOPrefsDialog(mMainView); |
95 | //mOptionsDialog->readConfig(); | 95 | //mOptionsDialog->readConfig(); |
96 | connect(mOptionsDialog,SIGNAL(configChanged()), | 96 | connect(mOptionsDialog,SIGNAL(configChanged()), |
97 | mMainView,SLOT(updateConfig())); | 97 | mMainView,SLOT(updateConfig())); |
98 | //connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), | 98 | //connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), |
99 | // mOptionsDialog,SLOT(updateCategories())); | 99 | // mOptionsDialog,SLOT(updateCategories())); |
100 | 100 | ||
101 | } | 101 | } |
102 | mOptionsDialog->readConfig(); | 102 | mOptionsDialog->readConfig(); |
103 | #ifndef DESKTOP_VERSION | 103 | #ifndef DESKTOP_VERSION |
104 | mOptionsDialog->showMaximized(); | 104 | mOptionsDialog->showMaximized(); |
105 | #else | 105 | #else |
106 | mOptionsDialog->show(); | 106 | mOptionsDialog->show(); |
107 | #endif | 107 | #endif |
108 | if ( showSync ) | 108 | if ( showSync ) |
109 | mOptionsDialog->showSyncPage(); | 109 | mOptionsDialog->showSyncPage(); |
110 | mOptionsDialog->exec(); | 110 | mOptionsDialog->exec(); |
111 | if ( curLanguage != KOPrefs::instance()->mPreferredLanguage ) | 111 | |
112 | KOPrefs::instance()->mLanguageChanged = true; | ||
113 | } | 112 | } |
114 | void KODialogManager::showSyncOptions() | 113 | void KODialogManager::showSyncOptions() |
115 | { | 114 | { |
116 | showOptionsDialog( true ); | 115 | showOptionsDialog( true ); |
117 | 116 | ||
118 | } | 117 | } |
119 | void KODialogManager::showOutgoingDialog() | 118 | void KODialogManager::showOutgoingDialog() |
120 | { | 119 | { |
121 | createOutgoingDialog(); | 120 | createOutgoingDialog(); |
122 | mOutgoingDialog->show(); | 121 | mOutgoingDialog->show(); |
123 | mOutgoingDialog->raise(); | 122 | mOutgoingDialog->raise(); |
124 | } | 123 | } |
125 | 124 | ||
126 | IncomingDialog *KODialogManager::incomingDialog() | 125 | IncomingDialog *KODialogManager::incomingDialog() |
127 | { | 126 | { |
128 | createOutgoingDialog(); | 127 | createOutgoingDialog(); |
129 | if (!mIncomingDialog) { | 128 | if (!mIncomingDialog) { |
130 | mIncomingDialog = new IncomingDialog(mMainView->calendar(),mOutgoingDialog,mMainView); | 129 | mIncomingDialog = new IncomingDialog(mMainView->calendar(),mOutgoingDialog,mMainView); |
131 | connect(mIncomingDialog,SIGNAL(numMessagesChanged(int)), | 130 | connect(mIncomingDialog,SIGNAL(numMessagesChanged(int)), |
132 | mMainView,SIGNAL(numIncomingChanged(int))); | 131 | mMainView,SIGNAL(numIncomingChanged(int))); |
133 | connect(mIncomingDialog,SIGNAL(calendarUpdated()), | 132 | connect(mIncomingDialog,SIGNAL(calendarUpdated()), |
134 | mMainView,SLOT(updateView())); | 133 | mMainView,SLOT(updateView())); |
135 | } | 134 | } |
136 | return mIncomingDialog; | 135 | return mIncomingDialog; |
137 | } | 136 | } |
138 | 137 | ||
139 | void KODialogManager::createIncomingDialog() | 138 | void KODialogManager::createIncomingDialog() |
140 | { | 139 | { |
141 | createOutgoingDialog(); | 140 | createOutgoingDialog(); |
142 | if (!mIncomingDialog) { | 141 | if (!mIncomingDialog) { |
143 | mIncomingDialog = new IncomingDialog(mMainView->calendar(),mOutgoingDialog,mMainView); | 142 | mIncomingDialog = new IncomingDialog(mMainView->calendar(),mOutgoingDialog,mMainView); |
144 | connect(mIncomingDialog,SIGNAL(numMessagesChanged(int)), | 143 | connect(mIncomingDialog,SIGNAL(numMessagesChanged(int)), |
145 | mMainView,SIGNAL(numIncomingChanged(int))); | 144 | mMainView,SIGNAL(numIncomingChanged(int))); |
146 | connect(mIncomingDialog,SIGNAL(calendarUpdated()), | 145 | connect(mIncomingDialog,SIGNAL(calendarUpdated()), |
147 | mMainView,SLOT(updateView())); | 146 | mMainView,SLOT(updateView())); |
148 | } | 147 | } |
149 | } | 148 | } |
150 | 149 | ||
151 | void KODialogManager::showIncomingDialog() | 150 | void KODialogManager::showIncomingDialog() |
152 | { | 151 | { |
153 | createIncomingDialog(); | 152 | createIncomingDialog(); |
154 | mIncomingDialog->show(); | 153 | mIncomingDialog->show(); |
155 | mIncomingDialog->raise(); | 154 | mIncomingDialog->raise(); |
156 | } | 155 | } |
157 | /* | 156 | /* |
158 | void KODialogManager::showCategoryEditDialog() | 157 | void KODialogManager::showCategoryEditDialog() |
159 | { | 158 | { |
160 | mCategoryEditDialog->show(); | 159 | mCategoryEditDialog->show(); |
161 | } | 160 | } |
162 | */ | 161 | */ |
163 | void KODialogManager::hideSearchDialog() | 162 | void KODialogManager::hideSearchDialog() |
164 | { | 163 | { |
165 | if (mSearchDialog) | 164 | if (mSearchDialog) |
166 | mSearchDialog->hide(); | 165 | mSearchDialog->hide(); |
167 | } | 166 | } |
168 | 167 | ||
169 | void KODialogManager::showSearchDialog() | 168 | void KODialogManager::showSearchDialog() |
170 | { | 169 | { |
171 | if (!mSearchDialog) { | 170 | if (!mSearchDialog) { |
172 | mSearchDialog = new SearchDialog(mMainView->calendar(),mMainView); | 171 | mSearchDialog = new SearchDialog(mMainView->calendar(),mMainView); |
173 | KOListView * lview = mSearchDialog->listview(); | 172 | KOListView * lview = mSearchDialog->listview(); |
174 | 173 | ||
175 | connect(lview, SIGNAL(showIncidenceSignal(Incidence *)), | 174 | connect(lview, SIGNAL(showIncidenceSignal(Incidence *)), |
176 | mMainView, SLOT(showIncidence(Incidence *))); | 175 | mMainView, SLOT(showIncidence(Incidence *))); |
diff --git a/korganizer/koprefs.cpp b/korganizer/koprefs.cpp index ba1c6d1..f44debc 100644 --- a/korganizer/koprefs.cpp +++ b/korganizer/koprefs.cpp | |||
@@ -1,517 +1,439 @@ | |||
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 <time.h> | 24 | #include <time.h> |
25 | #ifndef _WIN32_ | 25 | #ifndef _WIN32_ |
26 | #include <unistd.h> | 26 | #include <unistd.h> |
27 | #endif | 27 | #endif |
28 | #include <qdir.h> | 28 | #include <qdir.h> |
29 | #include <qtextstream.h> | 29 | #include <qtextstream.h> |
30 | #include <qtextcodec.h> | 30 | #include <qtextcodec.h> |
31 | #include <qstring.h> | 31 | #include <qstring.h> |
32 | #include <qregexp.h> | 32 | #include <qregexp.h> |
33 | #include <qfont.h> | 33 | #include <qfont.h> |
34 | #include <qcolor.h> | 34 | #include <qcolor.h> |
35 | #include <qstringlist.h> | 35 | #include <qstringlist.h> |
36 | #include <stdlib.h> | 36 | #include <stdlib.h> |
37 | 37 | ||
38 | #include <kglobal.h> | 38 | #include <kglobal.h> |
39 | #include <kconfig.h> | 39 | #include <kconfig.h> |
40 | #include <klocale.h> | 40 | #include <klocale.h> |
41 | #include <kdebug.h> | 41 | #include <kdebug.h> |
42 | #include <kemailsettings.h> | 42 | #include <kemailsettings.h> |
43 | #include <kstaticdeleter.h> | 43 | #include <kstaticdeleter.h> |
44 | #include <libkdepim/kpimglobalprefs.h> | 44 | #include <libkdepim/kpimglobalprefs.h> |
45 | 45 | ||
46 | #include "koprefs.h" | 46 | #include "koprefs.h" |
47 | #include "mainwindow.h" | 47 | #include "mainwindow.h" |
48 | 48 | ||
49 | const char *germanwords[][2] = { | ||
50 | #include "wordsgerman.h" | ||
51 | "", "" | ||
52 | }; | ||
53 | |||
54 | KOPrefs *KOPrefs::mInstance = 0; | 49 | KOPrefs *KOPrefs::mInstance = 0; |
55 | static KStaticDeleter<KOPrefs> insd; | 50 | static KStaticDeleter<KOPrefs> insd; |
56 | 51 | ||
57 | KOPrefs::KOPrefs() : | 52 | KOPrefs::KOPrefs() : |
58 | KPimPrefs("korganizerrc") | 53 | KPimPrefs("korganizerrc") |
59 | { | 54 | { |
60 | mCategoryColors.setAutoDelete(true); | 55 | mCategoryColors.setAutoDelete(true); |
61 | mLocaleDict = 0; | ||
62 | fillMailDefaults(); | 56 | fillMailDefaults(); |
63 | mDefaultCategoryColor = QColor(175,210,255);//196,196,196); | 57 | mDefaultCategoryColor = QColor(175,210,255);//196,196,196); |
64 | QColor defaultHolidayColor = QColor(255,0,0); | 58 | QColor defaultHolidayColor = QColor(255,0,0); |
65 | QColor defaultHighlightColor = QColor(129,112,255);//64,64,255); | 59 | QColor defaultHighlightColor = QColor(129,112,255);//64,64,255); |
66 | QColor defaultAgendaBgColor = QColor(239,241,169);//128,128,128); | 60 | QColor defaultAgendaBgColor = QColor(239,241,169);//128,128,128); |
67 | QColor defaultWorkingHoursColor = QColor(170,223,150);//160,160,160); | 61 | QColor defaultWorkingHoursColor = QColor(170,223,150);//160,160,160); |
68 | QColor defaultTodoDueTodayColor = QColor(255,220,100); | 62 | QColor defaultTodoDueTodayColor = QColor(255,220,100); |
69 | QColor defaultTodoOverdueColor = QColor(255,153,125); | 63 | QColor defaultTodoOverdueColor = QColor(255,153,125); |
70 | 64 | ||
71 | mTimeBarFont = QFont("helvetica",10);//,QFont::Bold); | 65 | mTimeBarFont = QFont("helvetica",10);//,QFont::Bold); |
72 | mDefaultViewFont = QFont("helvetica",10); | 66 | mDefaultViewFont = QFont("helvetica",10); |
73 | mDefaultMonthViewFont = QFont("helvetica",8); | 67 | mDefaultMonthViewFont = QFont("helvetica",8); |
74 | mMarcusBainsFont= QFont("helvetica",10); | 68 | mMarcusBainsFont= QFont("helvetica",10); |
75 | mDateNavigatorFont= QFont("helvetica",10, QFont::Bold); | 69 | mDateNavigatorFont= QFont("helvetica",10, QFont::Bold); |
76 | mEditBoxFont = QFont("helvetica",12); | 70 | mEditBoxFont = QFont("helvetica",12); |
77 | mJornalViewFont = QFont("helvetica",12); | 71 | mJornalViewFont = QFont("helvetica",12); |
78 | 72 | ||
79 | KPrefs::setCurrentGroup("General"); | 73 | KPrefs::setCurrentGroup("General"); |
80 | 74 | ||
81 | 75 | ||
82 | addItemBool("Enable Group Scheduling",&mEnableGroupScheduling,false); | 76 | addItemBool("Enable Group Scheduling",&mEnableGroupScheduling,false); |
83 | 77 | ||
84 | addItemBool("ShowIconNewTodo",&mShowIconNewTodo,true); | 78 | addItemBool("ShowIconNewTodo",&mShowIconNewTodo,true); |
85 | addItemBool("ShowIconNewEvent",&mShowIconNewEvent,true); | 79 | addItemBool("ShowIconNewEvent",&mShowIconNewEvent,true); |
86 | addItemBool("ShowIconSearch",&mShowIconSearch,true); | 80 | addItemBool("ShowIconSearch",&mShowIconSearch,true); |
87 | addItemBool("ShowIconList",&mShowIconList,true); | 81 | addItemBool("ShowIconList",&mShowIconList,true); |
88 | addItemBool("ShowIconDay1",&mShowIconDay1,true); | 82 | addItemBool("ShowIconDay1",&mShowIconDay1,true); |
89 | addItemBool("ShowIconDay5",&mShowIconDay5,true); | 83 | addItemBool("ShowIconDay5",&mShowIconDay5,true); |
90 | addItemBool("ShowIconDay7",&mShowIconDay7,true); | 84 | addItemBool("ShowIconDay7",&mShowIconDay7,true); |
91 | addItemBool("ShowIconMonth",&mShowIconMonth,true); | 85 | addItemBool("ShowIconMonth",&mShowIconMonth,true); |
92 | addItemBool("ShowIconTodoview",&mShowIconTodoview,true); | 86 | addItemBool("ShowIconTodoview",&mShowIconTodoview,true); |
93 | addItemBool("ShowIconBackFast",&mShowIconBackFast,true); | 87 | addItemBool("ShowIconBackFast",&mShowIconBackFast,true); |
94 | addItemBool("ShowIconBack",&mShowIconBack,true); | 88 | addItemBool("ShowIconBack",&mShowIconBack,true); |
95 | addItemBool("ShowIconToday",&mShowIconToday,true); | 89 | addItemBool("ShowIconToday",&mShowIconToday,true); |
96 | addItemBool("ShowIconForward",&mShowIconForward,true); | 90 | addItemBool("ShowIconForward",&mShowIconForward,true); |
97 | addItemBool("ShowIconForwardFast",&mShowIconForwardFast,true); | 91 | addItemBool("ShowIconForwardFast",&mShowIconForwardFast,true); |
98 | addItemBool("ShowIconWhatsThis",&mShowIconWhatsThis,false); | 92 | addItemBool("ShowIconWhatsThis",&mShowIconWhatsThis,false); |
99 | addItemBool("ShowIconNextDays",&mShowIconNextDays,true); | 93 | addItemBool("ShowIconNextDays",&mShowIconNextDays,true); |
100 | addItemBool("ShowIconNext",&mShowIconNext,true); | 94 | addItemBool("ShowIconNext",&mShowIconNext,true); |
101 | addItemBool("ShowIconJournal",&mShowIconJournal,true); | 95 | addItemBool("ShowIconJournal",&mShowIconJournal,true); |
102 | addItemBool("ShowIconStretch",&mShowIconStretch,true); | 96 | addItemBool("ShowIconStretch",&mShowIconStretch,true); |
103 | addItemBool("LanguageChanged",&mLanguageChanged,false); | 97 | addItemInt("LastLoadedLanguage",&mOldLanguage,0); |
104 | 98 | ||
105 | addItemBool("AskForQuit",&mAskForQuit,false); | 99 | addItemBool("AskForQuit",&mAskForQuit,false); |
106 | 100 | ||
107 | #ifndef DESKTOP_VERSION | 101 | #ifndef DESKTOP_VERSION |
108 | addItemBool("ShowFullMenu",&mShowFullMenu,false); | 102 | addItemBool("ShowFullMenu",&mShowFullMenu,false); |
109 | #else | 103 | #else |
110 | addItemBool("ShowFullMenu",&mShowFullMenu,true); | 104 | addItemBool("ShowFullMenu",&mShowFullMenu,true); |
111 | #endif | 105 | #endif |
112 | addItemBool("ToolBarHor",&mToolBarHor, true ); | 106 | addItemBool("ToolBarHor",&mToolBarHor, true ); |
113 | addItemBool("ToolBarUp",&mToolBarUp, false ); | 107 | addItemBool("ToolBarUp",&mToolBarUp, false ); |
114 | addItemBool("ToolBarMiniIcons",&mToolBarMiniIcons, false ); | 108 | addItemBool("ToolBarMiniIcons",&mToolBarMiniIcons, false ); |
115 | addItemInt("Whats Next Days",&mWhatsNextDays,3); | 109 | addItemInt("Whats Next Days",&mWhatsNextDays,3); |
116 | addItemInt("Whats Next Prios",&mWhatsNextPrios,1); | 110 | addItemInt("Whats Next Prios",&mWhatsNextPrios,1); |
117 | 111 | ||
118 | addItemBool("ShowTodoInAgenda",&mShowTodoInAgenda,true); | 112 | addItemBool("ShowTodoInAgenda",&mShowTodoInAgenda,true); |
119 | addItemBool("ShowCompletedTodo",&mShowCompletedTodo,true); | 113 | addItemBool("ShowCompletedTodo",&mShowCompletedTodo,true); |
120 | addItemInt("AllDay Size",&mAllDaySize,28); | 114 | addItemInt("AllDay Size",&mAllDaySize,28); |
121 | QString defAlarm = KGlobal::iconLoader()->iconPath()+"koalarm.wav"; | 115 | QString defAlarm = KGlobal::iconLoader()->iconPath()+"koalarm.wav"; |
122 | addItemString("DefaultAlarmFile",&mDefaultAlarmFile,defAlarm ); | 116 | addItemString("DefaultAlarmFile",&mDefaultAlarmFile,defAlarm ); |
123 | 117 | ||
124 | addItemStringList("LocationDefaults",&mLocationDefaults ); | 118 | addItemStringList("LocationDefaults",&mLocationDefaults ); |
125 | addItemStringList("EventSummary User",&mEventSummaryUser); | 119 | addItemStringList("EventSummary User",&mEventSummaryUser); |
126 | addItemStringList("TodoSummary User",&mTodoSummaryUser); | 120 | addItemStringList("TodoSummary User",&mTodoSummaryUser); |
127 | 121 | ||
128 | addItemBool("Enable Group Scheduling",&mEnableGroupScheduling,false); | 122 | addItemBool("Enable Group Scheduling",&mEnableGroupScheduling,false); |
129 | addItemBool("Enable Project View",&mEnableProjectView,false); | 123 | addItemBool("Enable Project View",&mEnableProjectView,false); |
130 | addItemBool("Auto Save",&mAutoSave,false); | 124 | addItemBool("Auto Save",&mAutoSave,false); |
131 | addItemInt("Auto Save Interval",&mAutoSaveInterval,3); | 125 | addItemInt("Auto Save Interval",&mAutoSaveInterval,3); |
132 | addItemBool("Confirm Deletes",&mConfirm,true); | 126 | addItemBool("Confirm Deletes",&mConfirm,true); |
133 | addItemString("Archive File",&mArchiveFile); | 127 | addItemString("Archive File",&mArchiveFile); |
134 | addItemString("Html Export File",&mHtmlExportFile, | 128 | addItemString("Html Export File",&mHtmlExportFile, |
135 | QDir::homeDirPath() + "/" + i18n("Default export file", "calendar.html")); | 129 | QDir::homeDirPath() + "/" + i18n("Default export file", "calendar.html")); |
136 | addItemBool("Html With Save",&mHtmlWithSave,false); | 130 | addItemBool("Html With Save",&mHtmlWithSave,false); |
137 | 131 | ||
138 | KPrefs::setCurrentGroup("Personal Settings"); | 132 | KPrefs::setCurrentGroup("Personal Settings"); |
139 | 133 | ||
140 | addItemInt("Mail Client",&mMailClient,MailClientKMail); | 134 | addItemInt("Mail Client",&mMailClient,MailClientKMail); |
141 | addItemBool("Use Control Center Email",&mEmailControlCenter,false); | 135 | addItemBool("Use Control Center Email",&mEmailControlCenter,false); |
142 | addItemBool("Bcc",&mBcc,false); | 136 | addItemBool("Bcc",&mBcc,false); |
143 | 137 | ||
144 | KPrefs::setCurrentGroup("Time & Date"); | 138 | KPrefs::setCurrentGroup("Time & Date"); |
145 | 139 | ||
146 | 140 | ||
147 | addItemInt("Default Start Time",&mStartTime,10); | 141 | addItemInt("Default Start Time",&mStartTime,10); |
148 | addItemInt("Default Duration",&mDefaultDuration,2); | 142 | addItemInt("Default Duration",&mDefaultDuration,2); |
149 | addItemInt("Default Alarm Time",&mAlarmTime,3); | 143 | addItemInt("Default Alarm Time",&mAlarmTime,3); |
150 | KPrefs::setCurrentGroup("AlarmSettings"); | 144 | KPrefs::setCurrentGroup("AlarmSettings"); |
151 | addItemInt("AlarmPlayBeeps",&mAlarmPlayBeeps,20); | 145 | addItemInt("AlarmPlayBeeps",&mAlarmPlayBeeps,20); |
152 | addItemInt("AlarmSuspendTime",&mAlarmSuspendTime,7); | 146 | addItemInt("AlarmSuspendTime",&mAlarmSuspendTime,7); |
153 | addItemInt("AlarmSuspendCount",&mAlarmSuspendCount,5); | 147 | addItemInt("AlarmSuspendCount",&mAlarmSuspendCount,5); |
154 | addItemInt("AlarmBeepInterval",&mAlarmBeepInterval,3); | 148 | addItemInt("AlarmBeepInterval",&mAlarmBeepInterval,3); |
155 | 149 | ||
156 | 150 | ||
157 | KPrefs::setCurrentGroup("Calendar"); | 151 | KPrefs::setCurrentGroup("Calendar"); |
158 | 152 | ||
159 | addItemInt("Default Calendar Format",&mDefaultFormat,FormatICalendar); | 153 | addItemInt("Default Calendar Format",&mDefaultFormat,FormatICalendar); |
160 | 154 | ||
161 | KPrefs::setCurrentGroup("Fonts"); | 155 | KPrefs::setCurrentGroup("Fonts"); |
162 | // qDebug(" KPrefs::setCurrentGroup(Fonts); "); | 156 | // qDebug(" KPrefs::setCurrentGroup(Fonts); "); |
163 | addItemFont("TimeBar Font",&mTimeBarFont); | 157 | addItemFont("TimeBar Font",&mTimeBarFont); |
164 | addItemFont("MonthView Font",&mMonthViewFont); | 158 | addItemFont("MonthView Font",&mMonthViewFont); |
165 | addItemFont("AgendaView Font",&mAgendaViewFont); | 159 | addItemFont("AgendaView Font",&mAgendaViewFont); |
166 | addItemFont("MarcusBains Font",&mMarcusBainsFont); | 160 | addItemFont("MarcusBains Font",&mMarcusBainsFont); |
167 | addItemFont("TimeLabels Font",&mTimeLabelsFont); | 161 | addItemFont("TimeLabels Font",&mTimeLabelsFont); |
168 | addItemFont("TodoView Font",&mTodoViewFont); | 162 | addItemFont("TodoView Font",&mTodoViewFont); |
169 | addItemFont("ListView Font",&mListViewFont); | 163 | addItemFont("ListView Font",&mListViewFont); |
170 | addItemFont("DateNavigator Font",&mDateNavigatorFont); | 164 | addItemFont("DateNavigator Font",&mDateNavigatorFont); |
171 | addItemFont("EditBox Font",&mEditBoxFont); | 165 | addItemFont("EditBox Font",&mEditBoxFont); |
172 | addItemFont("JournalView Font",&mJornalViewFont); | 166 | addItemFont("JournalView Font",&mJornalViewFont); |
173 | addItemFont("WhatsNextView Font",&mWhatsNextFont); | 167 | addItemFont("WhatsNextView Font",&mWhatsNextFont); |
174 | addItemFont("EventView Font",&mEventViewFont); | 168 | addItemFont("EventView Font",&mEventViewFont); |
175 | 169 | ||
176 | // KPrefs::setCurrentGroup("SyncProfiles"); | 170 | // KPrefs::setCurrentGroup("SyncProfiles"); |
177 | // addItemString("LocalMachineName",&mLocalMachineName, "undefined"); | 171 | // addItemString("LocalMachineName",&mLocalMachineName, "undefined"); |
178 | // addItemStringList("SyncProfileNames",&mSyncProfileNames); | 172 | // addItemStringList("SyncProfileNames",&mSyncProfileNames); |
179 | // addItemStringList("ExternSyncProfiles",&mExternSyncProfileNames); | 173 | // addItemStringList("ExternSyncProfiles",&mExternSyncProfileNames); |
180 | 174 | ||
181 | KPrefs::setCurrentGroup("RemoteSyncing"); | 175 | KPrefs::setCurrentGroup("RemoteSyncing"); |
182 | // addItemBool("UsePasswd",&mUsePassWd,false); | 176 | // addItemBool("UsePasswd",&mUsePassWd,false); |
183 | // addItemBool("WriteBackFile",&mWriteBackFile,true); | 177 | // addItemBool("WriteBackFile",&mWriteBackFile,true); |
184 | // addItemBool("WriteBackExistingOnly",&mWriteBackExistingOnly,false); | 178 | // addItemBool("WriteBackExistingOnly",&mWriteBackExistingOnly,false); |
185 | // addItemBool("AskForPreferences",&mAskForPreferences,true); | 179 | // addItemBool("AskForPreferences",&mAskForPreferences,true); |
186 | // addItemBool("ShowSyncSummary",&mShowSyncSummary,true); | 180 | // addItemBool("ShowSyncSummary",&mShowSyncSummary,true); |
187 | addItemString("ActiveSyncPort",&mActiveSyncPort,"9197" ); | 181 | addItemString("ActiveSyncPort",&mActiveSyncPort,"9197" ); |
188 | addItemString("ActiveSyncIP",&mActiveSyncIP,"192.168.0.40" ); | 182 | addItemString("ActiveSyncIP",&mActiveSyncIP,"192.168.0.40" ); |
189 | addItemBool("ShowSyncEvents",&mShowSyncEvents,false); | 183 | addItemBool("ShowSyncEvents",&mShowSyncEvents,false); |
190 | addItemInt("LastSyncTime",&mLastSyncTime,0); | 184 | addItemInt("LastSyncTime",&mLastSyncTime,0); |
191 | 185 | ||
192 | #ifdef _WIN32_ | 186 | #ifdef _WIN32_ |
193 | QString hdp= locateLocal("data","korganizer")+"\\\\"; | 187 | QString hdp= locateLocal("data","korganizer")+"\\\\"; |
194 | #else | 188 | #else |
195 | QString hdp= locateLocal("data","korganizer")+"/"; | 189 | QString hdp= locateLocal("data","korganizer")+"/"; |
196 | #endif | 190 | #endif |
197 | 191 | ||
198 | KPrefs::setCurrentGroup("LoadSaveFileNames"); | 192 | KPrefs::setCurrentGroup("LoadSaveFileNames"); |
199 | 193 | ||
200 | addItemString("LastImportFile", &mLastImportFile ,hdp +"import.ics" ); | 194 | addItemString("LastImportFile", &mLastImportFile ,hdp +"import.ics" ); |
201 | addItemString("LastVcalFile", &mLastVcalFile ,hdp +"export.vcs" ); | 195 | addItemString("LastVcalFile", &mLastVcalFile ,hdp +"export.vcs" ); |
202 | addItemString("LastSaveFile", &mLastSaveFile ,hdp +"mybackup.ics" ); | 196 | addItemString("LastSaveFile", &mLastSaveFile ,hdp +"mybackup.ics" ); |
203 | addItemString("LastLoadFile", &mLastLoadFile ,hdp +"mybackup.ics" ); | 197 | addItemString("LastLoadFile", &mLastLoadFile ,hdp +"mybackup.ics" ); |
204 | 198 | ||
205 | 199 | ||
206 | KPrefs::setCurrentGroup("Locale"); | 200 | KPrefs::setCurrentGroup("Locale"); |
207 | addItemInt("PreferredLanguage",&mPreferredLanguage,0); | ||
208 | addItemInt("PreferredTime",&mPreferredTime,0); | ||
209 | addItemInt("PreferredDate",&mPreferredDate,0); | ||
210 | addItemBool("WeekStartsOnSunday",&mWeekStartsOnSunday,false); | ||
211 | addItemBool("ShortDateInViewer",&mShortDateInViewer,false); | 201 | addItemBool("ShortDateInViewer",&mShortDateInViewer,false); |
212 | addItemString("UserDateFormatLong", &mUserDateFormatLong, "%A %d %b %y"); | ||
213 | addItemString("UserDateFormatShort", &mUserDateFormatShort, "%aK %d.%m.%y"); | ||
214 | 202 | ||
215 | 203 | ||
216 | KPrefs::setCurrentGroup("Colors"); | 204 | KPrefs::setCurrentGroup("Colors"); |
217 | addItemColor("Holiday Color",&mHolidayColor,defaultHolidayColor); | 205 | addItemColor("Holiday Color",&mHolidayColor,defaultHolidayColor); |
218 | addItemColor("Highlight Color",&mHighlightColor,defaultHighlightColor); | 206 | addItemColor("Highlight Color",&mHighlightColor,defaultHighlightColor); |
219 | addItemColor("Event Color",&mEventColor,mDefaultCategoryColor); | 207 | addItemColor("Event Color",&mEventColor,mDefaultCategoryColor); |
220 | addItemColor("Agenda Background Color",&mAgendaBgColor,defaultAgendaBgColor); | 208 | addItemColor("Agenda Background Color",&mAgendaBgColor,defaultAgendaBgColor); |
221 | addItemColor("WorkingHours Color",&mWorkingHoursColor,defaultWorkingHoursColor); | 209 | addItemColor("WorkingHours Color",&mWorkingHoursColor,defaultWorkingHoursColor); |
222 | addItemColor("Todo due today Color",&mTodoDueTodayColor,defaultTodoDueTodayColor); | 210 | addItemColor("Todo due today Color",&mTodoDueTodayColor,defaultTodoDueTodayColor); |
223 | addItemColor("Todo overdue Color",&mTodoOverdueColor,defaultTodoOverdueColor); | 211 | addItemColor("Todo overdue Color",&mTodoOverdueColor,defaultTodoOverdueColor); |
224 | addItemColor("MonthViewEvenColor",&mMonthViewEvenColor,QColor( 160,160,255 )); | 212 | addItemColor("MonthViewEvenColor",&mMonthViewEvenColor,QColor( 160,160,255 )); |
225 | addItemColor("MonthViewOddColor",&mMonthViewOddColor,QColor( 160,255,160 )); | 213 | addItemColor("MonthViewOddColor",&mMonthViewOddColor,QColor( 160,255,160 )); |
226 | addItemColor("MonthViewHolidayColor",&mMonthViewHolidayColor,QColor( 255,160,160 )); | 214 | addItemColor("MonthViewHolidayColor",&mMonthViewHolidayColor,QColor( 255,160,160 )); |
227 | addItemBool("MonthViewUsesDayColors",&mMonthViewUsesDayColors,true); | 215 | addItemBool("MonthViewUsesDayColors",&mMonthViewUsesDayColors,true); |
228 | addItemBool("MonthViewSatSunTog",&mMonthViewSatSunTog,true); | 216 | addItemBool("MonthViewSatSunTog",&mMonthViewSatSunTog,true); |
229 | addItemBool("HightlightDateTimeEdit",&mHightlightDateTimeEdit,false); | 217 | addItemBool("HightlightDateTimeEdit",&mHightlightDateTimeEdit,false); |
230 | addItemColor("AppColor1",&mAppColor1,QColor( 130,170,255 )); | 218 | addItemColor("AppColor1",&mAppColor1,QColor( 130,170,255 )); |
231 | addItemColor("AppColor2",&mAppColor2,QColor( 174,216,255 )); | 219 | addItemColor("AppColor2",&mAppColor2,QColor( 174,216,255 )); |
232 | addItemBool("UseAppColors",&mUseAppColors,false); | 220 | addItemBool("UseAppColors",&mUseAppColors,false); |
233 | 221 | ||
234 | 222 | ||
235 | 223 | ||
236 | KPrefs::setCurrentGroup("Views"); | 224 | KPrefs::setCurrentGroup("Views"); |
237 | addItemInt("Hour Size",&mHourSize,8); | 225 | addItemInt("Hour Size",&mHourSize,8); |
238 | addItemBool("Show Daily Recurrences",&mDailyRecur,true); | 226 | addItemBool("Show Daily Recurrences",&mDailyRecur,true); |
239 | addItemBool("Show Weekly Recurrences",&mWeeklyRecur,true); | 227 | addItemBool("Show Weekly Recurrences",&mWeeklyRecur,true); |
240 | addItemBool("Show Month Daily Recurrences",&mMonthDailyRecur,true); | 228 | addItemBool("Show Month Daily Recurrences",&mMonthDailyRecur,true); |
241 | addItemBool("Show Month Weekly Recurrences",&mMonthWeeklyRecur,true); | 229 | addItemBool("Show Month Weekly Recurrences",&mMonthWeeklyRecur,true); |
242 | addItemBool("ShowShortMonthName",&mMonthShowShort,false); | 230 | addItemBool("ShowShortMonthName",&mMonthShowShort,false); |
243 | addItemBool("ShowIconsInMonthCell",&mMonthShowIcons,true); | 231 | addItemBool("ShowIconsInMonthCell",&mMonthShowIcons,true); |
244 | addItemBool("Enable ToolTips",&mEnableToolTips,false); | 232 | addItemBool("Enable ToolTips",&mEnableToolTips,false); |
245 | addItemBool("Enable MonthView ScrollBars",&mEnableMonthScroll,false); | 233 | addItemBool("Enable MonthView ScrollBars",&mEnableMonthScroll,false); |
246 | addItemBool("Marcus Bains shows seconds",&mMarcusBainsShowSeconds,false); | 234 | addItemBool("Marcus Bains shows seconds",&mMarcusBainsShowSeconds,false); |
247 | addItemBool("Show Marcus Bains",&mMarcusBainsEnabled,true); | 235 | addItemBool("Show Marcus Bains",&mMarcusBainsEnabled,true); |
248 | addItemBool("EditOnDoubleClick",&mEditOnDoubleClick,true); | 236 | addItemBool("EditOnDoubleClick",&mEditOnDoubleClick,true); |
249 | addItemBool("ViewChangeHoldFullscreen",&mViewChangeHoldFullscreen,false); | 237 | addItemBool("ViewChangeHoldFullscreen",&mViewChangeHoldFullscreen,false); |
250 | addItemBool("ViewChangeHoldNonFullscreen",&mViewChangeHoldNonFullscreen,false); | 238 | addItemBool("ViewChangeHoldNonFullscreen",&mViewChangeHoldNonFullscreen,false); |
251 | addItemBool("CenterOnCurrentTime",&mCenterOnCurrentTime,false); | 239 | addItemBool("CenterOnCurrentTime",&mCenterOnCurrentTime,false); |
252 | addItemBool("SetTimeToDayStartAt",&mSetTimeToDayStartAt,true); | 240 | addItemBool("SetTimeToDayStartAt",&mSetTimeToDayStartAt,true); |
253 | addItemBool("HighlightCurrentDay",&mHighlightCurrentDay,true); | 241 | addItemBool("HighlightCurrentDay",&mHighlightCurrentDay,true); |
254 | addItemBool("WNViewShowsParents",&mWNViewShowsParents,true); | 242 | addItemBool("WNViewShowsParents",&mWNViewShowsParents,true); |
255 | addItemBool("WNViewShowLocation",&mWNViewShowLocation,false); | 243 | addItemBool("WNViewShowLocation",&mWNViewShowLocation,false); |
256 | addItemBool("UseHighlightLightColor",&mUseHighlightLightColor,false); | 244 | addItemBool("UseHighlightLightColor",&mUseHighlightLightColor,false); |
257 | addItemBool("ListViewMonthTimespan",&mListViewMonthTimespan,true); | 245 | addItemBool("ListViewMonthTimespan",&mListViewMonthTimespan,true); |
258 | addItemBool("TodoViewUsesCatColors",&mTodoViewUsesCatColors,false); | 246 | addItemBool("TodoViewUsesCatColors",&mTodoViewUsesCatColors,false); |
259 | addItemBool("TodoViewShowsPercentage",&mTodoViewShowsPercentage,false); | 247 | addItemBool("TodoViewShowsPercentage",&mTodoViewShowsPercentage,false); |
260 | addItemBool("TodoViewUsesSmallFont",&mTodoViewUsesSmallFont,false); | 248 | addItemBool("TodoViewUsesSmallFont",&mTodoViewUsesSmallFont,false); |
261 | addItemBool("TodoViewUsesForegroundColor",&mTodoViewUsesForegroundColor,false); | 249 | addItemBool("TodoViewUsesForegroundColor",&mTodoViewUsesForegroundColor,false); |
262 | addItemBool("MonthViewUsesForegroundColor",&mMonthViewUsesForegroundColor,false); | 250 | addItemBool("MonthViewUsesForegroundColor",&mMonthViewUsesForegroundColor,false); |
263 | #ifdef DESKTOP_VERSION | 251 | #ifdef DESKTOP_VERSION |
264 | addItemBool("UseInternalAlarmNotification",&mUseInternalAlarmNotification,true); | 252 | addItemBool("UseInternalAlarmNotification",&mUseInternalAlarmNotification,true); |
265 | #else | 253 | #else |
266 | addItemBool("UseInternalAlarmNotification",&mUseInternalAlarmNotification,false); | 254 | addItemBool("UseInternalAlarmNotification",&mUseInternalAlarmNotification,false); |
267 | #endif | 255 | #endif |
268 | addItemInt("Day Begins",&mDayBegins,7); | 256 | addItemInt("Day Begins",&mDayBegins,7); |
269 | addItemInt("Working Hours Start",&mWorkingHoursStart,8); | 257 | addItemInt("Working Hours Start",&mWorkingHoursStart,8); |
270 | addItemInt("Working Hours End",&mWorkingHoursEnd,17); | 258 | addItemInt("Working Hours End",&mWorkingHoursEnd,17); |
271 | addItemBool("Exclude Holidays",&mExcludeHolidays,true); | 259 | addItemBool("Exclude Holidays",&mExcludeHolidays,true); |
272 | addItemBool("Exclude Saturdays",&mExcludeSaturdays,true); | 260 | addItemBool("Exclude Saturdays",&mExcludeSaturdays,true); |
273 | 261 | ||
274 | addItemBool("Month View Uses Category Color",&mMonthViewUsesCategoryColor,false); | 262 | addItemBool("Month View Uses Category Color",&mMonthViewUsesCategoryColor,false); |
275 | addItemBool("Full View Month",&mFullViewMonth,true); | 263 | addItemBool("Full View Month",&mFullViewMonth,true); |
276 | addItemBool("Full View Todo",&mFullViewTodo,true); | 264 | addItemBool("Full View Todo",&mFullViewTodo,true); |
277 | addItemBool("Quick Todo",&mEnableQuickTodo,false); | 265 | addItemBool("Quick Todo",&mEnableQuickTodo,false); |
278 | 266 | ||
279 | addItemInt("Next X Days",&mNextXDays,3); | 267 | addItemInt("Next X Days",&mNextXDays,3); |
280 | 268 | ||
281 | KPrefs::setCurrentGroup("Printer"); | 269 | KPrefs::setCurrentGroup("Printer"); |
282 | 270 | ||
283 | KPrefs::setCurrentGroup("Layout"); | 271 | KPrefs::setCurrentGroup("Layout"); |
284 | 272 | ||
285 | addItemBool("CompactDialogs",&mCompactDialogs,false); | 273 | addItemBool("CompactDialogs",&mCompactDialogs,false); |
286 | addItemBool("VerticalScreen",&mVerticalScreen,true); | 274 | addItemBool("VerticalScreen",&mVerticalScreen,true); |
287 | 275 | ||
288 | KPrefs::setCurrentGroup("KOrganizer Plugins"); | 276 | KPrefs::setCurrentGroup("KOrganizer Plugins"); |
289 | 277 | ||
290 | addItemStringList("SelectedPlugins",&mSelectedPlugins,"holidays"); | 278 | addItemStringList("SelectedPlugins",&mSelectedPlugins,"holidays"); |
291 | 279 | ||
292 | KPrefs::setCurrentGroup("Group Scheduling"); | 280 | KPrefs::setCurrentGroup("Group Scheduling"); |
293 | 281 | ||
294 | addItemInt("IMIPScheduler",&mIMIPScheduler,IMIPKMail); | 282 | addItemInt("IMIPScheduler",&mIMIPScheduler,IMIPKMail); |
295 | addItemInt("IMIPSend",&mIMIPSend,IMIPdirectsend); | 283 | addItemInt("IMIPSend",&mIMIPSend,IMIPdirectsend); |
296 | addItemStringList("AdditionalMails",&mAdditionalMails,""); | 284 | addItemStringList("AdditionalMails",&mAdditionalMails,""); |
297 | addItemInt("IMIP auto refresh",&mIMIPAutoRefresh,neverAuto); | 285 | addItemInt("IMIP auto refresh",&mIMIPAutoRefresh,neverAuto); |
298 | addItemInt("IMIP auto insert request",&mIMIPAutoInsertRequest,neverAuto); | 286 | addItemInt("IMIP auto insert request",&mIMIPAutoInsertRequest,neverAuto); |
299 | addItemInt("IMIP auto insert reply",&mIMIPAutoInsertReply,neverAuto); | 287 | addItemInt("IMIP auto insert reply",&mIMIPAutoInsertReply,neverAuto); |
300 | addItemInt("IMIP auto FreeBusy",&mIMIPAutoFreeBusy,neverAuto); | 288 | addItemInt("IMIP auto FreeBusy",&mIMIPAutoFreeBusy,neverAuto); |
301 | addItemInt("IMIP auto save FreeBusy",&mIMIPAutoFreeBusyReply,neverAuto); | 289 | addItemInt("IMIP auto save FreeBusy",&mIMIPAutoFreeBusyReply,neverAuto); |
302 | 290 | ||
303 | KPrefs::setCurrentGroup( "Editors" ); | 291 | KPrefs::setCurrentGroup( "Editors" ); |
304 | 292 | ||
305 | addItemStringList( "EventTemplates", &mEventTemplates ); | 293 | addItemStringList( "EventTemplates", &mEventTemplates ); |
306 | addItemStringList( "TodoTemplates", &mTodoTemplates ); | 294 | addItemStringList( "TodoTemplates", &mTodoTemplates ); |
307 | 295 | ||
308 | addItemInt("DestinationPolicy",&mDestination,standardDestination); | 296 | addItemInt("DestinationPolicy",&mDestination,standardDestination); |
309 | 297 | ||
310 | 298 | ||
311 | 299 | ||
312 | } | 300 | } |
313 | 301 | ||
314 | 302 | ||
315 | KOPrefs::~KOPrefs() | 303 | KOPrefs::~KOPrefs() |
316 | { | 304 | { |
317 | if (mInstance == this) | 305 | if (mInstance == this) |
318 | mInstance = insd.setObject(0); | 306 | mInstance = insd.setObject(0); |
319 | setLocaleDict( 0 ); | 307 | |
320 | if ( mLocaleDict ) | ||
321 | delete mLocaleDict; | ||
322 | //qDebug("KOPrefs::~KOPrefs() "); | 308 | //qDebug("KOPrefs::~KOPrefs() "); |
323 | } | 309 | } |
324 | 310 | ||
325 | 311 | ||
326 | KOPrefs *KOPrefs::instance() | 312 | KOPrefs *KOPrefs::instance() |
327 | { | 313 | { |
328 | if (!mInstance) { | 314 | if (!mInstance) { |
329 | mInstance = insd.setObject(new KOPrefs()); | 315 | mInstance = insd.setObject(new KOPrefs()); |
330 | mInstance->readConfig(); | 316 | mInstance->readConfig(); |
331 | } | 317 | } |
332 | 318 | ||
333 | return mInstance; | 319 | return mInstance; |
334 | } | 320 | } |
335 | 321 | ||
336 | void KOPrefs::usrSetDefaults() | 322 | void KOPrefs::usrSetDefaults() |
337 | { | 323 | { |
338 | 324 | ||
339 | } | 325 | } |
340 | 326 | ||
341 | void KOPrefs::fillMailDefaults() | 327 | void KOPrefs::fillMailDefaults() |
342 | { | 328 | { |
343 | if (mName.isEmpty()) mName = i18n("Anonymous"); | 329 | if (mName.isEmpty()) mName = i18n("Anonymous"); |
344 | if (mEmail.isEmpty()) mEmail = i18n("nobody@nowhere"); | 330 | if (mEmail.isEmpty()) mEmail = i18n("nobody@nowhere"); |
345 | } | 331 | } |
346 | 332 | ||
347 | void KOPrefs::setTimeZoneIdDefault() | 333 | void KOPrefs::setTimeZoneIdDefault() |
348 | { | 334 | { |
349 | ; | 335 | ; |
350 | } | 336 | } |
351 | 337 | ||
352 | void KOPrefs::setCategoryDefaults() | 338 | void KOPrefs::setCategoryDefaults() |
353 | { | 339 | { |
354 | mCustomCategories.clear(); | 340 | mCustomCategories.clear(); |
355 | mCustomCategories = getDefaultList(); | 341 | mCustomCategories = getDefaultList(); |
356 | 342 | ||
357 | QStringList::Iterator it; | 343 | QStringList::Iterator it; |
358 | for (it = mCustomCategories.begin();it != mCustomCategories.end();++it ) { | 344 | for (it = mCustomCategories.begin();it != mCustomCategories.end();++it ) { |
359 | setCategoryColor(*it,mDefaultCategoryColor); | 345 | setCategoryColor(*it,mDefaultCategoryColor); |
360 | } | 346 | } |
361 | } | 347 | } |
362 | 348 | ||
363 | QStringList KOPrefs::getDefaultList() | 349 | QStringList KOPrefs::getDefaultList() |
364 | { | 350 | { |
365 | QStringList retval ; | 351 | QStringList retval ; |
366 | retval << i18n("Anniversary") << i18n("Appointment") << i18n("Birthday") << i18n("Business") << i18n("Business Travel") << i18n("Cinema") << i18n("Customer") | 352 | retval << i18n("Anniversary") << i18n("Appointment") << i18n("Birthday") << i18n("Business") << i18n("Business Travel") << i18n("Cinema") << i18n("Customer") |
367 | << i18n("Break")<< i18n("Breakfast")<< i18n("Competition")<< i18n("Dinner") | 353 | << i18n("Break")<< i18n("Breakfast")<< i18n("Competition")<< i18n("Dinner") |
368 | << i18n("Education")<< i18n("Family") << i18n("Favorites") << i18n("Festival")<< i18n("Fishing")<< i18n("Flight") << i18n("Gifts") | 354 | << i18n("Education")<< i18n("Family") << i18n("Favorites") << i18n("Festival")<< i18n("Fishing")<< i18n("Flight") << i18n("Gifts") |
369 | << i18n("Holiday") << i18n("Holiday Cards")<< i18n("Hot Contacts") << i18n("Hiking") << i18n("Hunting") << i18n("Key Customer") << i18n("Kids") | 355 | << i18n("Holiday") << i18n("Holiday Cards")<< i18n("Hot Contacts") << i18n("Hiking") << i18n("Hunting") << i18n("Key Customer") << i18n("Kids") |
370 | << i18n("Lunch") << i18n("Meeting") << i18n("Miscellaneous") << i18n("Partner")<< i18n("Party") << i18n("Personal") << i18n("Personal Travel") | 356 | << i18n("Lunch") << i18n("Meeting") << i18n("Miscellaneous") << i18n("Partner")<< i18n("Party") << i18n("Personal") << i18n("Personal Travel") |
371 | << i18n("PHB") << i18n("Phone Calls") << i18n("Projects") << i18n("Recurring") << i18n("School") << i18n("Shopping") | 357 | << i18n("PHB") << i18n("Phone Calls") << i18n("Projects") << i18n("Recurring") << i18n("School") << i18n("Shopping") |
372 | << i18n("Speach") << i18n("Special Occasion") << i18n("Sports") << i18n("Talk") << i18n("Travel") << i18n("TV")<< i18n("University") | 358 | << i18n("Speach") << i18n("Special Occasion") << i18n("Sports") << i18n("Talk") << i18n("Travel") << i18n("TV")<< i18n("University") |
373 | << i18n("Vacation") << i18n("VIP") << i18n("SyncEvent") ; | 359 | << i18n("Vacation") << i18n("VIP") << i18n("SyncEvent") ; |
374 | retval.sort(); | 360 | retval.sort(); |
375 | return retval; | 361 | return retval; |
376 | } | 362 | } |
377 | 363 | ||
378 | void KOPrefs::usrReadConfig() | 364 | void KOPrefs::usrReadConfig() |
379 | { | 365 | { |
380 | mPreferredLanguage = KPimGlobalPrefs::instance()->mPreferredLanguage; | ||
381 | mLocaleDict = 0; | ||
382 | // pending LR fix translation | ||
383 | // qDebug("KOPrefs::usrReadConfig() fix translation "); | ||
384 | if ( mPreferredLanguage > 0 && mPreferredLanguage < 5 ) { | ||
385 | if ( mPreferredLanguage == 1 ) { | ||
386 | mLocaleDict = new QDict<QString>; | ||
387 | int i = 0; | ||
388 | QString fw ( germanwords[i] [0]); | ||
389 | while ( !fw.isEmpty() ) { | ||
390 | mLocaleDict->insert( fw, new QString (germanwords[i] [1] )); | ||
391 | ++i; | ||
392 | fw = germanwords[i] [0]; | ||
393 | } | ||
394 | |||
395 | setLocaleDict( mLocaleDict ); | ||
396 | } else { | ||
397 | QString fileName ; | ||
398 | if ( mPreferredLanguage == 4 ) | ||
399 | fileName = MainWindow::resourcePath()+"usertranslation.txt"; | ||
400 | else if ( mPreferredLanguage == 2 ) | ||
401 | fileName = MainWindow::resourcePath()+"frenchtranslation.txt"; | ||
402 | else if ( mPreferredLanguage == 3 ) | ||
403 | fileName = MainWindow::resourcePath()+"italiantranslation.txt"; | ||
404 | QFile file( fileName ); | ||
405 | if (file.open( IO_ReadOnly ) ) { | ||
406 | QTextStream ts( &file ); | ||
407 | ts.setEncoding( QTextStream::Latin1 ); | ||
408 | //ts.setCodec( QTextCodec::latin1 ); | ||
409 | QString text = ts.read(); | ||
410 | file.close(); | ||
411 | text.replace( QRegExp("\\\\n"), "\n" ); | ||
412 | QString line; | ||
413 | QString we; | ||
414 | QString wt; | ||
415 | int br = 0; | ||
416 | int nbr; | ||
417 | nbr = text.find ( "},", br ); | ||
418 | line = text.mid( br, nbr - br ); | ||
419 | br = nbr+1; | ||
420 | int se, ee, st, et; | ||
421 | mLocaleDict = new QDict<QString>; | ||
422 | QString end = "{ \"\",\"\" }"; | ||
423 | while ( (line != end) && (br > 1) ) { | ||
424 | //qDebug("%d *%s* ", br, line.latin1()); | ||
425 | se = line.find("\"")+1; | ||
426 | et = line.findRev("\"",-1); | ||
427 | ee = line.find("\",\""); | ||
428 | st = ee+3; | ||
429 | we = line.mid( se, ee-se ); | ||
430 | wt = line.mid( st, et-st ); | ||
431 | //qDebug("*%s* *%s* ", we.latin1(), wt.latin1()); | ||
432 | mLocaleDict->insert( we, new QString (wt) ); | ||
433 | nbr = text.find ( "}", br ); | ||
434 | line = text.mid( br, nbr - br ); | ||
435 | br = nbr+1; | ||
436 | } | ||
437 | //qDebug("end *%s* ", end.latin1()); | ||
438 | |||
439 | setLocaleDict( mLocaleDict ); | ||
440 | } else { | ||
441 | qDebug("KO: Cannot find translation file %s",fileName.latin1() ); | ||
442 | } | ||
443 | |||
444 | } | ||
445 | } | ||
446 | config()->setGroup("General"); | 366 | config()->setGroup("General"); |
447 | 367 | ||
448 | mCustomCategories = config()->readListEntry("Custom Categories"); | 368 | mCustomCategories = config()->readListEntry("Custom Categories"); |
449 | if ( KOPrefs::instance()->mLanguageChanged ) { | 369 | if ( KPimGlobalPrefs::instance()->mPreferredLanguage != mOldLanguage ) { |
450 | mLocationDefaults.clear(); | 370 | mLocationDefaults.clear(); |
451 | mEventSummaryUser.clear(); | 371 | mEventSummaryUser.clear(); |
452 | mTodoSummaryUser.clear(); | 372 | mTodoSummaryUser.clear(); |
453 | } | 373 | } |
374 | mOldLoadedLanguage = mOldLanguage ; | ||
375 | mOldLanguage = KPimGlobalPrefs::instance()->mPreferredLanguage; | ||
454 | if (mLocationDefaults.isEmpty()) { | 376 | if (mLocationDefaults.isEmpty()) { |
455 | mLocationDefaults << i18n("Home") << i18n("Office") << i18n("Library") << i18n("School") << i18n("Doctor") << i18n("Beach") | 377 | mLocationDefaults << i18n("Home") << i18n("Office") << i18n("Library") << i18n("School") << i18n("Doctor") << i18n("Beach") |
456 | << i18n("University") << i18n("Restaurant") << i18n("Bar") << i18n("Conference room") << i18n("Cinema") << i18n("Lake") << i18n("Kindergarten") | 378 | << i18n("University") << i18n("Restaurant") << i18n("Bar") << i18n("Conference room") << i18n("Cinema") << i18n("Lake") << i18n("Kindergarten") |
457 | << i18n("Germany") << i18n("Sweden") << i18n("Forest") << i18n("Desert") << i18n("Kitchen") ; | 379 | << i18n("Germany") << i18n("Sweden") << i18n("Forest") << i18n("Desert") << i18n("Kitchen") ; |
458 | // << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") | 380 | // << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") << i18n("") |
459 | mLocationDefaults.sort(); | 381 | mLocationDefaults.sort(); |
460 | } | 382 | } |
461 | 383 | ||
462 | if (mEventSummaryUser.isEmpty()) { | 384 | if (mEventSummaryUser.isEmpty()) { |
463 | mEventSummaryUser = getDefaultList() ; | 385 | mEventSummaryUser = getDefaultList() ; |
464 | } | 386 | } |
465 | if (mTodoSummaryUser.isEmpty()) { | 387 | if (mTodoSummaryUser.isEmpty()) { |
466 | mTodoSummaryUser = getDefaultList() ; | 388 | mTodoSummaryUser = getDefaultList() ; |
467 | } | 389 | } |
468 | 390 | ||
469 | if (mCustomCategories.isEmpty()) setCategoryDefaults(); | 391 | if (mCustomCategories.isEmpty()) setCategoryDefaults(); |
470 | 392 | ||
471 | config()->setGroup("Personal Settings"); | 393 | config()->setGroup("Personal Settings"); |
472 | mName = config()->readEntry("user_name",""); | 394 | mName = config()->readEntry("user_name",""); |
473 | mEmail = config()->readEntry("user_email",""); | 395 | mEmail = config()->readEntry("user_email",""); |
474 | fillMailDefaults(); | 396 | fillMailDefaults(); |
475 | 397 | ||
476 | config()->setGroup("Category Colors"); | 398 | config()->setGroup("Category Colors"); |
477 | QStringList::Iterator it; | 399 | QStringList::Iterator it; |
478 | for (it = mCustomCategories.begin();it != mCustomCategories.end();++it ) { | 400 | for (it = mCustomCategories.begin();it != mCustomCategories.end();++it ) { |
479 | setCategoryColor(*it,config()->readColorEntry(*it,&mDefaultCategoryColor)); | 401 | setCategoryColor(*it,config()->readColorEntry(*it,&mDefaultCategoryColor)); |
480 | 402 | ||
481 | } | 403 | } |
482 | 404 | ||
483 | KPimPrefs::usrReadConfig(); | 405 | KPimPrefs::usrReadConfig(); |
484 | } | 406 | } |
485 | 407 | ||
486 | 408 | ||
487 | void KOPrefs::usrWriteConfig() | 409 | void KOPrefs::usrWriteConfig() |
488 | { | 410 | { |
489 | config()->setGroup("General"); | 411 | config()->setGroup("General"); |
490 | config()->writeEntry("Custom Categories",mCustomCategories); | 412 | config()->writeEntry("Custom Categories",mCustomCategories); |
491 | 413 | ||
492 | config()->setGroup("Personal Settings"); | 414 | config()->setGroup("Personal Settings"); |
493 | config()->writeEntry("user_name",mName); | 415 | config()->writeEntry("user_name",mName); |
494 | config()->writeEntry("user_email",mEmail); | 416 | config()->writeEntry("user_email",mEmail); |
495 | 417 | ||
496 | config()->setGroup("Category Colors"); | 418 | config()->setGroup("Category Colors"); |
497 | QDictIterator<QColor> it(mCategoryColors); | 419 | QDictIterator<QColor> it(mCategoryColors); |
498 | while (it.current()) { | 420 | while (it.current()) { |
499 | config()->writeEntry(it.currentKey(),*(it.current())); | 421 | config()->writeEntry(it.currentKey(),*(it.current())); |
500 | ++it; | 422 | ++it; |
501 | } | 423 | } |
502 | 424 | ||
503 | 425 | ||
504 | KPimPrefs::usrWriteConfig(); | 426 | KPimPrefs::usrWriteConfig(); |
505 | } | 427 | } |
506 | 428 | ||
507 | void KOPrefs::setCategoryColor(QString cat,const QColor & color) | 429 | void KOPrefs::setCategoryColor(QString cat,const QColor & color) |
508 | { | 430 | { |
509 | mCategoryColors.replace(cat,new QColor(color)); | 431 | mCategoryColors.replace(cat,new QColor(color)); |
510 | } | 432 | } |
511 | 433 | ||
512 | QColor *KOPrefs::categoryColor(QString cat) | 434 | QColor *KOPrefs::categoryColor(QString cat) |
513 | { | 435 | { |
514 | QColor *color = 0; | 436 | QColor *color = 0; |
515 | 437 | ||
516 | if (!cat.isEmpty()) color = mCategoryColors[cat]; | 438 | if (!cat.isEmpty()) color = mCategoryColors[cat]; |
517 | 439 | ||
diff --git a/korganizer/koprefs.h b/korganizer/koprefs.h index c74b0ef..0656644 100644 --- a/korganizer/koprefs.h +++ b/korganizer/koprefs.h | |||
@@ -1,283 +1,273 @@ | |||
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 KOPREFS_H | 23 | #ifndef KOPREFS_H |
24 | #define KOPREFS_H | 24 | #define KOPREFS_H |
25 | 25 | ||
26 | #include <qdict.h> | ||
27 | 26 | ||
28 | #include <libkdepim/kpimprefs.h> | 27 | #include <libkdepim/kpimprefs.h> |
28 | #include <qdict.h> | ||
29 | 29 | ||
30 | class KConfig; | 30 | class KConfig; |
31 | class QFont; | 31 | class QFont; |
32 | class QColor; | 32 | class QColor; |
33 | class QStringList; | 33 | class QStringList; |
34 | 34 | ||
35 | class KOPrefs : public KPimPrefs | 35 | class KOPrefs : public KPimPrefs |
36 | { | 36 | { |
37 | public: | 37 | public: |
38 | enum { FormatVCalendar, FormatICalendar }; | 38 | enum { FormatVCalendar, FormatICalendar }; |
39 | enum { MailClientKMail, MailClientSendmail }; | 39 | enum { MailClientKMail, MailClientSendmail }; |
40 | enum { IMIPDummy, IMIPKMail }; | 40 | enum { IMIPDummy, IMIPKMail }; |
41 | enum { IMIPOutbox, IMIPdirectsend }; | 41 | enum { IMIPOutbox, IMIPdirectsend }; |
42 | enum { neverAuto, addressbookAuto, selectedAuto }; | 42 | enum { neverAuto, addressbookAuto, selectedAuto }; |
43 | enum { standardDestination, askDestination }; | 43 | enum { standardDestination, askDestination }; |
44 | 44 | ||
45 | virtual ~KOPrefs(); | 45 | virtual ~KOPrefs(); |
46 | 46 | ||
47 | /** Get instance of KOPrefs. It is made sure that there is only one | 47 | /** Get instance of KOPrefs. It is made sure that there is only one |
48 | instance. */ | 48 | instance. */ |
49 | static KOPrefs *instance(); | 49 | static KOPrefs *instance(); |
50 | 50 | ||
51 | /** Set preferences to default values */ | 51 | /** Set preferences to default values */ |
52 | void usrSetDefaults(); | 52 | void usrSetDefaults(); |
53 | 53 | ||
54 | /** Read preferences from config file */ | 54 | /** Read preferences from config file */ |
55 | void usrReadConfig(); | 55 | void usrReadConfig(); |
56 | 56 | ||
57 | /** Write preferences to config file */ | 57 | /** Write preferences to config file */ |
58 | void usrWriteConfig(); | 58 | void usrWriteConfig(); |
59 | void setCategoryDefaults(); | 59 | void setCategoryDefaults(); |
60 | 60 | ||
61 | protected: | 61 | protected: |
62 | void setTimeZoneIdDefault(); | 62 | void setTimeZoneIdDefault(); |
63 | 63 | ||
64 | /** Fill empty mail fields with default values. */ | 64 | /** Fill empty mail fields with default values. */ |
65 | void fillMailDefaults(); | 65 | void fillMailDefaults(); |
66 | 66 | ||
67 | private: | 67 | private: |
68 | /** Constructor disabled for public. Use instance() to create a KOPrefs | 68 | /** Constructor disabled for public. Use instance() to create a KOPrefs |
69 | object. */ | 69 | object. */ |
70 | KOPrefs(); | 70 | KOPrefs(); |
71 | 71 | ||
72 | static KOPrefs *mInstance; | 72 | static KOPrefs *mInstance; |
73 | QDict<QString> *mLocaleDict; | ||
74 | QStringList getDefaultList(); | 73 | QStringList getDefaultList(); |
75 | public: | 74 | public: |
76 | // preferences data | 75 | // preferences data |
77 | KConfig* getConfig(); | 76 | KConfig* getConfig(); |
78 | void setFullName(const QString &); | 77 | void setFullName(const QString &); |
79 | QString fullName(); | 78 | QString fullName(); |
80 | void setEmail(const QString &); | 79 | void setEmail(const QString &); |
81 | QString email(); | 80 | QString email(); |
82 | 81 | ||
83 | QString mAdditional; | 82 | QString mAdditional; |
84 | 83 | ||
85 | bool mEmailControlCenter; | 84 | bool mEmailControlCenter; |
86 | 85 | ||
87 | bool mBcc; | 86 | bool mBcc; |
88 | bool mAutoSave; | 87 | bool mAutoSave; |
89 | int mAutoSaveInterval; | 88 | int mAutoSaveInterval; |
90 | bool mConfirm; | 89 | bool mConfirm; |
91 | 90 | ||
92 | bool mEnableGroupScheduling; | 91 | bool mEnableGroupScheduling; |
93 | bool mEnableProjectView; | 92 | bool mEnableProjectView; |
94 | 93 | ||
95 | int mDefaultFormat; | 94 | int mDefaultFormat; |
96 | int mMailClient; | 95 | int mMailClient; |
97 | 96 | ||
98 | int mStartTime; | 97 | int mStartTime; |
99 | int mDefaultDuration; | 98 | int mDefaultDuration; |
100 | int mAlarmTime; | 99 | int mAlarmTime; |
101 | 100 | ||
102 | int mWorkingHoursStart; | 101 | int mWorkingHoursStart; |
103 | int mWorkingHoursEnd; | 102 | int mWorkingHoursEnd; |
104 | bool mExcludeHolidays; | 103 | bool mExcludeHolidays; |
105 | bool mExcludeSaturdays; | 104 | bool mExcludeSaturdays; |
106 | bool mMarcusBainsShowSeconds; | 105 | bool mMarcusBainsShowSeconds; |
107 | 106 | ||
108 | QFont mTimeBarFont; | 107 | QFont mTimeBarFont; |
109 | QFont mMonthViewFont; | 108 | QFont mMonthViewFont; |
110 | QFont mAgendaViewFont; | 109 | QFont mAgendaViewFont; |
111 | QFont mMarcusBainsFont; | 110 | QFont mMarcusBainsFont; |
112 | QFont mTimeLabelsFont; | 111 | QFont mTimeLabelsFont; |
113 | QFont mTodoViewFont; | 112 | QFont mTodoViewFont; |
114 | QFont mListViewFont; | 113 | QFont mListViewFont; |
115 | QFont mDateNavigatorFont; | 114 | QFont mDateNavigatorFont; |
116 | QFont mEditBoxFont; | 115 | QFont mEditBoxFont; |
117 | QFont mJornalViewFont; | 116 | QFont mJornalViewFont; |
118 | QFont mWhatsNextFont; | 117 | QFont mWhatsNextFont; |
119 | QFont mEventViewFont; | 118 | QFont mEventViewFont; |
120 | 119 | ||
121 | 120 | ||
122 | 121 | ||
123 | 122 | ||
124 | QColor mHolidayColor; | 123 | QColor mHolidayColor; |
125 | QColor mHighlightColor; | 124 | QColor mHighlightColor; |
126 | QColor mEventColor; | 125 | QColor mEventColor; |
127 | QColor mAgendaBgColor; | 126 | QColor mAgendaBgColor; |
128 | QColor mWorkingHoursColor; | 127 | QColor mWorkingHoursColor; |
129 | QColor mTodoDueTodayColor; | 128 | QColor mTodoDueTodayColor; |
130 | QColor mTodoOverdueColor; | 129 | QColor mTodoOverdueColor; |
131 | QColor mMonthViewEvenColor; | 130 | QColor mMonthViewEvenColor; |
132 | QColor mMonthViewOddColor; | 131 | QColor mMonthViewOddColor; |
133 | QColor mMonthViewHolidayColor; | 132 | QColor mMonthViewHolidayColor; |
134 | bool mMonthViewUsesDayColors; | 133 | bool mMonthViewUsesDayColors; |
135 | bool mMonthViewSatSunTog; | 134 | bool mMonthViewSatSunTog; |
136 | QColor mAppColor1; | 135 | QColor mAppColor1; |
137 | QColor mAppColor2; | 136 | QColor mAppColor2; |
138 | bool mUseAppColors; | 137 | bool mUseAppColors; |
139 | 138 | ||
140 | int mDayBegins; | 139 | int mDayBegins; |
141 | int mHourSize; | 140 | int mHourSize; |
142 | int mAllDaySize; | 141 | int mAllDaySize; |
143 | bool mShowFullMenu; | 142 | bool mShowFullMenu; |
144 | bool mDailyRecur; | 143 | bool mDailyRecur; |
145 | bool mWeeklyRecur; | 144 | bool mWeeklyRecur; |
146 | bool mMonthDailyRecur; | 145 | bool mMonthDailyRecur; |
147 | bool mMonthWeeklyRecur; | 146 | bool mMonthWeeklyRecur; |
148 | bool mMonthShowIcons; | 147 | bool mMonthShowIcons; |
149 | bool mMonthShowShort; | 148 | bool mMonthShowShort; |
150 | bool mEnableToolTips; | 149 | bool mEnableToolTips; |
151 | bool mEnableMonthScroll; | 150 | bool mEnableMonthScroll; |
152 | bool mFullViewMonth; | 151 | bool mFullViewMonth; |
153 | bool mMonthViewUsesCategoryColor; | 152 | bool mMonthViewUsesCategoryColor; |
154 | bool mFullViewTodo; | 153 | bool mFullViewTodo; |
155 | bool mShowCompletedTodo; | 154 | bool mShowCompletedTodo; |
156 | bool mMarcusBainsEnabled; | 155 | bool mMarcusBainsEnabled; |
157 | int mNextXDays; | 156 | int mNextXDays; |
158 | int mWhatsNextDays; | 157 | int mWhatsNextDays; |
159 | int mWhatsNextPrios; | 158 | int mWhatsNextPrios; |
160 | bool mEnableQuickTodo; | 159 | bool mEnableQuickTodo; |
161 | bool mLanguageChanged; | ||
162 | 160 | ||
163 | bool mCompactDialogs; | 161 | bool mCompactDialogs; |
164 | bool mVerticalScreen; | 162 | bool mVerticalScreen; |
165 | 163 | ||
166 | bool mShowIconNewTodo; | 164 | bool mShowIconNewTodo; |
167 | bool mShowIconNewEvent; | 165 | bool mShowIconNewEvent; |
168 | bool mShowIconSearch; | 166 | bool mShowIconSearch; |
169 | bool mShowIconList; | 167 | bool mShowIconList; |
170 | bool mShowIconDay1; | 168 | bool mShowIconDay1; |
171 | bool mShowIconDay5; | 169 | bool mShowIconDay5; |
172 | bool mShowIconDay7; | 170 | bool mShowIconDay7; |
173 | bool mShowIconMonth; | 171 | bool mShowIconMonth; |
174 | bool mShowIconTodoview; | 172 | bool mShowIconTodoview; |
175 | bool mShowIconBackFast; | 173 | bool mShowIconBackFast; |
176 | bool mShowIconBack; | 174 | bool mShowIconBack; |
177 | bool mShowIconToday; | 175 | bool mShowIconToday; |
178 | bool mShowIconForward; | 176 | bool mShowIconForward; |
179 | bool mShowIconForwardFast; | 177 | bool mShowIconForwardFast; |
180 | bool mShowIconWhatsThis; | 178 | bool mShowIconWhatsThis; |
181 | bool mShowIconNextDays; | 179 | bool mShowIconNextDays; |
182 | bool mShowIconNext; | 180 | bool mShowIconNext; |
183 | bool mShowIconJournal; | 181 | bool mShowIconJournal; |
184 | 182 | ||
185 | bool mShowIconStretch; | 183 | bool mShowIconStretch; |
186 | 184 | ||
187 | bool mToolBarHor; | 185 | bool mToolBarHor; |
188 | bool mToolBarUp; | 186 | bool mToolBarUp; |
189 | bool mToolBarMiniIcons; | 187 | bool mToolBarMiniIcons; |
190 | 188 | ||
191 | bool mAskForQuit; | 189 | bool mAskForQuit; |
192 | bool mUsePassWd; | 190 | bool mUsePassWd; |
193 | bool mShowSyncEvents; | 191 | bool mShowSyncEvents; |
194 | bool mShowTodoInAgenda; | 192 | bool mShowTodoInAgenda; |
195 | 193 | ||
196 | int mLastSyncTime; | 194 | int mLastSyncTime; |
197 | void setCategoryColor(QString cat,const QColor & color); | 195 | void setCategoryColor(QString cat,const QColor & color); |
198 | QColor *categoryColor(QString cat); | 196 | QColor *categoryColor(QString cat); |
199 | 197 | ||
200 | QString mArchiveFile; | 198 | QString mArchiveFile; |
201 | QString mHtmlExportFile; | 199 | QString mHtmlExportFile; |
202 | bool mHtmlWithSave; | 200 | bool mHtmlWithSave; |
203 | 201 | ||
204 | QStringList mSelectedPlugins; | 202 | QStringList mSelectedPlugins; |
205 | 203 | ||
206 | QString mLastImportFile; | 204 | QString mLastImportFile; |
207 | QString mLastVcalFile; | 205 | QString mLastVcalFile; |
208 | QString mLastSaveFile; | 206 | QString mLastSaveFile; |
209 | QString mLastLoadFile; | 207 | QString mLastLoadFile; |
210 | 208 | ||
211 | 209 | ||
212 | QString mDefaultAlarmFile; | 210 | QString mDefaultAlarmFile; |
213 | int mIMIPScheduler; | 211 | int mIMIPScheduler; |
214 | int mIMIPSend; | 212 | int mIMIPSend; |
215 | QStringList mAdditionalMails; | 213 | QStringList mAdditionalMails; |
216 | int mIMIPAutoRefresh; | 214 | int mIMIPAutoRefresh; |
217 | int mIMIPAutoInsertReply; | 215 | int mIMIPAutoInsertReply; |
218 | int mIMIPAutoInsertRequest; | 216 | int mIMIPAutoInsertRequest; |
219 | int mIMIPAutoFreeBusy; | 217 | int mIMIPAutoFreeBusy; |
220 | int mIMIPAutoFreeBusyReply; | 218 | int mIMIPAutoFreeBusyReply; |
221 | 219 | ||
222 | QStringList mTodoTemplates; | 220 | QStringList mTodoTemplates; |
223 | QStringList mEventTemplates; | 221 | QStringList mEventTemplates; |
224 | 222 | ||
225 | int mDestination; | 223 | int mDestination; |
226 | 224 | ||
227 | 225 | ||
228 | bool mEditOnDoubleClick; | 226 | bool mEditOnDoubleClick; |
229 | bool mViewChangeHoldFullscreen; | 227 | bool mViewChangeHoldFullscreen; |
230 | bool mViewChangeHoldNonFullscreen; | 228 | bool mViewChangeHoldNonFullscreen; |
231 | bool mCenterOnCurrentTime; | 229 | bool mCenterOnCurrentTime; |
232 | bool mSetTimeToDayStartAt; | 230 | bool mSetTimeToDayStartAt; |
233 | bool mHighlightCurrentDay; | 231 | bool mHighlightCurrentDay; |
234 | bool mUseHighlightLightColor; | 232 | bool mUseHighlightLightColor; |
235 | bool mListViewMonthTimespan; | 233 | bool mListViewMonthTimespan; |
236 | bool mWNViewShowsParents; | 234 | bool mWNViewShowsParents; |
237 | bool mWNViewShowLocation; | 235 | bool mWNViewShowLocation; |
238 | bool mTodoViewShowsPercentage; | 236 | bool mTodoViewShowsPercentage; |
239 | bool mTodoViewUsesCatColors; | 237 | bool mTodoViewUsesCatColors; |
240 | bool mTodoViewUsesSmallFont; | 238 | bool mTodoViewUsesSmallFont; |
241 | bool mTodoViewUsesForegroundColor; | 239 | bool mTodoViewUsesForegroundColor; |
242 | bool mMonthViewUsesForegroundColor; | 240 | bool mMonthViewUsesForegroundColor; |
243 | 241 | ||
244 | bool mHightlightDateTimeEdit; | 242 | bool mHightlightDateTimeEdit; |
245 | bool mShortDateInViewer; | 243 | bool mShortDateInViewer; |
246 | 244 | ||
247 | QStringList mLocationDefaults; | 245 | QStringList mLocationDefaults; |
248 | QStringList mEventSummaryUser; | 246 | QStringList mEventSummaryUser; |
249 | QStringList mTodoSummaryUser; | 247 | QStringList mTodoSummaryUser; |
250 | 248 | ||
251 | bool mUseInternalAlarmNotification; | 249 | bool mUseInternalAlarmNotification; |
252 | int mAlarmPlayBeeps; | 250 | int mAlarmPlayBeeps; |
253 | int mAlarmSuspendTime; | 251 | int mAlarmSuspendTime; |
254 | int mAlarmSuspendCount; | 252 | int mAlarmSuspendCount; |
255 | int mAlarmBeepInterval; | 253 | int mAlarmBeepInterval; |
254 | int mOldLanguage; | ||
255 | int mOldLoadedLanguage; | ||
256 | 256 | ||
257 | 257 | ||
258 | QString mActiveSyncPort; | 258 | QString mActiveSyncPort; |
259 | QString mActiveSyncIP; | 259 | QString mActiveSyncIP; |
260 | 260 | ||
261 | |||
262 | //US I copied the following settings into KPimGlobalPrefs | ||
263 | // that allows us later to easily remove the settings from here. | ||
264 | int mPreferredDate; | ||
265 | QString mUserDateFormatLong; | ||
266 | QString mUserDateFormatShort; | ||
267 | int mPreferredLanguage; | ||
268 | int mPreferredTime; | ||
269 | bool mWeekStartsOnSunday; | ||
270 | |||
271 | private: | 261 | private: |
272 | QDict<QColor> mCategoryColors; | 262 | QDict<QColor> mCategoryColors; |
273 | QColor mDefaultCategoryColor; | 263 | QColor mDefaultCategoryColor; |
274 | 264 | ||
275 | QFont mDefaultTimeBarFont; | 265 | QFont mDefaultTimeBarFont; |
276 | QFont mDefaultViewFont; | 266 | QFont mDefaultViewFont; |
277 | QFont mDefaultMonthViewFont; | 267 | QFont mDefaultMonthViewFont; |
278 | 268 | ||
279 | QString mName; | 269 | QString mName; |
280 | QString mEmail; | 270 | QString mEmail; |
281 | }; | 271 | }; |
282 | 272 | ||
283 | #endif | 273 | #endif |
diff --git a/korganizer/ktimeedit.cpp b/korganizer/ktimeedit.cpp index cf07a1a..f5a1c50 100644 --- a/korganizer/ktimeedit.cpp +++ b/korganizer/ktimeedit.cpp | |||
@@ -1,305 +1,306 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 1999 Preston Brown, Ian Dawes | 3 | Copyright (c) 1999 Preston Brown, Ian Dawes |
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 <qkeycode.h> | 24 | #include <qkeycode.h> |
25 | #include <qcombobox.h> | 25 | #include <qcombobox.h> |
26 | #include <qdatetime.h> | 26 | #include <qdatetime.h> |
27 | #include <qlineedit.h> | 27 | #include <qlineedit.h> |
28 | #include <qapplication.h> | 28 | #include <qapplication.h> |
29 | 29 | ||
30 | #include <kmessagebox.h> | 30 | #include <kmessagebox.h> |
31 | #include <kglobal.h> | 31 | #include <kglobal.h> |
32 | #include <kdebug.h> | 32 | #include <kdebug.h> |
33 | #include <klocale.h> | 33 | #include <klocale.h> |
34 | #include <kpimglobalprefs.h> | ||
34 | 35 | ||
35 | #include "ktimeedit.h" | 36 | #include "ktimeedit.h" |
36 | #include "koprefs.h" | 37 | #include "koprefs.h" |
37 | #include <qvalidator.h> | 38 | #include <qvalidator.h> |
38 | 39 | ||
39 | // Validator for a time value with only hours and minutes (no seconds) | 40 | // Validator for a time value with only hours and minutes (no seconds) |
40 | // Mostly locale aware. Author: David Faure <faure@kde.org> | 41 | // Mostly locale aware. Author: David Faure <faure@kde.org> |
41 | class KOTimeValidator : public QValidator | 42 | class KOTimeValidator : public QValidator |
42 | { | 43 | { |
43 | public: | 44 | public: |
44 | KOTimeValidator(QWidget* parent, const char* name=0) : QValidator(parent, name) {} | 45 | KOTimeValidator(QWidget* parent, const char* name=0) : QValidator(parent, name) {} |
45 | 46 | ||
46 | virtual State validate(QString& str, int& /*cursorPos*/) const | 47 | virtual State validate(QString& str, int& /*cursorPos*/) const |
47 | { | 48 | { |
48 | return Acceptable; | 49 | return Acceptable; |
49 | bool ok = false; | 50 | bool ok = false; |
50 | // TODO use KLocale::WithoutSeconds in HEAD | 51 | // TODO use KLocale::WithoutSeconds in HEAD |
51 | /*QTime time =*/ KGlobal::locale()->readTime(str, &ok); | 52 | /*QTime time =*/ KGlobal::locale()->readTime(str, &ok); |
52 | if ( ok ) | 53 | if ( ok ) |
53 | return Acceptable; | 54 | return Acceptable; |
54 | // readTime doesn't help knowing when the string is "Intermediate". | 55 | // readTime doesn't help knowing when the string is "Intermediate". |
55 | int length = str.length(); | 56 | int length = str.length(); |
56 | if ( !str ) // empty string? | 57 | if ( !str ) // empty string? |
57 | return Invalid; // there should always be a ':' in it, right? | 58 | return Invalid; // there should always be a ':' in it, right? |
58 | // HACK. Not fully locale aware etc. (esp. the separator is '.' in sv_SE...) | 59 | // HACK. Not fully locale aware etc. (esp. the separator is '.' in sv_SE...) |
59 | QChar sep = ':'; | 60 | QChar sep = ':'; |
60 | // I want to allow "HH:", ":MM" and ":" to make editing easier | 61 | // I want to allow "HH:", ":MM" and ":" to make editing easier |
61 | if ( str[0] == sep ) | 62 | if ( str[0] == sep ) |
62 | { | 63 | { |
63 | if ( length == 1 ) // just ":" | 64 | if ( length == 1 ) // just ":" |
64 | return Intermediate; | 65 | return Intermediate; |
65 | QString minutes = str.mid(1); | 66 | QString minutes = str.mid(1); |
66 | int m = minutes.toInt(&ok); | 67 | int m = minutes.toInt(&ok); |
67 | if ( ok && m >= 0 && m < 60 ) | 68 | if ( ok && m >= 0 && m < 60 ) |
68 | return Intermediate; | 69 | return Intermediate; |
69 | } else if ( str.at(str.length()-1) == sep ) | 70 | } else if ( str.at(str.length()-1) == sep ) |
70 | { | 71 | { |
71 | QString hours = str.left(length-1); | 72 | QString hours = str.left(length-1); |
72 | int h = hours.toInt(&ok); | 73 | int h = hours.toInt(&ok); |
73 | if ( ok && h >= 0 && h < 24 ) | 74 | if ( ok && h >= 0 && h < 24 ) |
74 | return Intermediate; | 75 | return Intermediate; |
75 | } | 76 | } |
76 | return Invalid; | 77 | return Invalid; |
77 | } | 78 | } |
78 | }; | 79 | }; |
79 | 80 | ||
80 | // KTimeWidget/QTimeEdit provide nicer editing, but don't provide a combobox. | 81 | // KTimeWidget/QTimeEdit provide nicer editing, but don't provide a combobox. |
81 | // Difficult to get all in one... | 82 | // Difficult to get all in one... |
82 | // But Qt-3.2 will offer QLineEdit::setMask, so a "99:99" mask would help. | 83 | // But Qt-3.2 will offer QLineEdit::setMask, so a "99:99" mask would help. |
83 | KOTimeEdit::KOTimeEdit(QWidget *parent, QTime qt, const char *name) | 84 | KOTimeEdit::KOTimeEdit(QWidget *parent, QTime qt, const char *name) |
84 | : QComboBox(TRUE, parent, name) | 85 | : QComboBox(TRUE, parent, name) |
85 | { | 86 | { |
86 | setInsertionPolicy(NoInsertion); | 87 | setInsertionPolicy(NoInsertion); |
87 | setValidator( new KOTimeValidator( this ) ); | 88 | setValidator( new KOTimeValidator( this ) ); |
88 | mFlagKeyPressed = false; | 89 | mFlagKeyPressed = false; |
89 | 90 | ||
90 | if ( QApplication::desktop()->width() < 650 ) | 91 | if ( QApplication::desktop()->width() < 650 ) |
91 | setSizeLimit ( 6 ); | 92 | setSizeLimit ( 6 ); |
92 | mTime = qt; | 93 | mTime = qt; |
93 | 94 | ||
94 | // mNoTimeString = i18n("No Time"); | 95 | // mNoTimeString = i18n("No Time"); |
95 | // insertItem( mNoTimeString ); | 96 | // insertItem( mNoTimeString ); |
96 | 97 | ||
97 | // Fill combo box with selection of times in localized format. | 98 | // Fill combo box with selection of times in localized format. |
98 | QTime timeEntry(0,0,0); | 99 | QTime timeEntry(0,0,0); |
99 | do { | 100 | do { |
100 | insertItem(KGlobal::locale()->formatTime(timeEntry)); | 101 | insertItem(KGlobal::locale()->formatTime(timeEntry)); |
101 | timeEntry = timeEntry.addSecs(60*15); | 102 | timeEntry = timeEntry.addSecs(60*15); |
102 | } while (!timeEntry.isNull()); | 103 | } while (!timeEntry.isNull()); |
103 | // Add end of day. | 104 | // Add end of day. |
104 | insertItem( KGlobal::locale()->formatTime( QTime( 23, 59, 59 ) ) ); | 105 | insertItem( KGlobal::locale()->formatTime( QTime( 23, 59, 59 ) ) ); |
105 | 106 | ||
106 | updateText(); | 107 | updateText(); |
107 | setFocusPolicy(QWidget::StrongFocus); | 108 | setFocusPolicy(QWidget::StrongFocus); |
108 | 109 | ||
109 | connect(this, SIGNAL(activated(int)), this, SLOT(activ(int))); | 110 | connect(this, SIGNAL(activated(int)), this, SLOT(activ(int))); |
110 | connect(this, SIGNAL(highlighted(int)), this, SLOT(hilit(int))); | 111 | connect(this, SIGNAL(highlighted(int)), this, SLOT(hilit(int))); |
111 | connect(this,SIGNAL(textChanged(const QString&)),this,SLOT(changedText())); | 112 | connect(this,SIGNAL(textChanged(const QString&)),this,SLOT(changedText())); |
112 | QFontMetrics fm ( font() ); | 113 | QFontMetrics fm ( font() ); |
113 | QString timeString = "24:00"; | 114 | QString timeString = "24:00"; |
114 | if ( KOPrefs::instance()->mPreferredTime == 1 ) | 115 | if ( KPimGlobalPrefs::instance()->mPreferredTime == 1 ) |
115 | timeString = "02:00pm"; | 116 | timeString = "02:00pm"; |
116 | int addSpace = 32; | 117 | int addSpace = 32; |
117 | if ( QApplication::desktop()->width() > 320 ) | 118 | if ( QApplication::desktop()->width() > 320 ) |
118 | timeString += ":00"; | 119 | timeString += ":00"; |
119 | setFixedWidth(fm.width( timeString ) + 32 ); | 120 | setFixedWidth(fm.width( timeString ) + 32 ); |
120 | 121 | ||
121 | // Highlight Background and Textcolor change from default | 122 | // Highlight Background and Textcolor change from default |
122 | QPalette palette = QWidget::palette(); | 123 | QPalette palette = QWidget::palette(); |
123 | unsigned char red, green, blue; | 124 | unsigned char red, green, blue; |
124 | red = palette.color( QPalette::Normal , QColorGroup::Background ).red() - 10; | 125 | red = palette.color( QPalette::Normal , QColorGroup::Background ).red() - 10; |
125 | green = palette.color( QPalette::Normal , QColorGroup::Background ).green() - 10; | 126 | green = palette.color( QPalette::Normal , QColorGroup::Background ).green() - 10; |
126 | blue = palette.color( QPalette::Normal , QColorGroup::Background ).blue() - 10; | 127 | blue = palette.color( QPalette::Normal , QColorGroup::Background ).blue() - 10; |
127 | palette.setColor( QColorGroup::Highlight, QColor(red,green,blue) ); | 128 | palette.setColor( QColorGroup::Highlight, QColor(red,green,blue) ); |
128 | palette.setColor( QColorGroup::HighlightedText, palette.color( QPalette::Normal , QColorGroup::Foreground ) ); | 129 | palette.setColor( QColorGroup::HighlightedText, palette.color( QPalette::Normal , QColorGroup::Foreground ) ); |
129 | setPalette( palette ); | 130 | setPalette( palette ); |
130 | } | 131 | } |
131 | 132 | ||
132 | KOTimeEdit::~KOTimeEdit() | 133 | KOTimeEdit::~KOTimeEdit() |
133 | { | 134 | { |
134 | } | 135 | } |
135 | 136 | ||
136 | bool KOTimeEdit::hasTime() const | 137 | bool KOTimeEdit::hasTime() const |
137 | { | 138 | { |
138 | // Can't happen | 139 | // Can't happen |
139 | if ( currentText().isEmpty() ) return false; | 140 | if ( currentText().isEmpty() ) return false; |
140 | //if ( currentText() == mNoTimeString ) return false; | 141 | //if ( currentText() == mNoTimeString ) return false; |
141 | 142 | ||
142 | return true; // always | 143 | return true; // always |
143 | } | 144 | } |
144 | 145 | ||
145 | QTime KOTimeEdit::getTime() const | 146 | QTime KOTimeEdit::getTime() const |
146 | { | 147 | { |
147 | //kdDebug(5850) << "KOTimeEdit::getTime(), currentText() = " << currentText() << endl; | 148 | //kdDebug(5850) << "KOTimeEdit::getTime(), currentText() = " << currentText() << endl; |
148 | // TODO use KLocale::WithoutSeconds in HEAD | 149 | // TODO use KLocale::WithoutSeconds in HEAD |
149 | QTime time = KGlobal::locale()->readTime(currentText()); | 150 | QTime time = KGlobal::locale()->readTime(currentText()); |
150 | // kdDebug(5850) << "KOTimeEdit::getTime(): " << time.toString() << endl; | 151 | // kdDebug(5850) << "KOTimeEdit::getTime(): " << time.toString() << endl; |
151 | return time; | 152 | return time; |
152 | } | 153 | } |
153 | /* | 154 | /* |
154 | QSizePolicy KOTimeEdit::sizePolicy() const | 155 | QSizePolicy KOTimeEdit::sizePolicy() const |
155 | { | 156 | { |
156 | // Set size policy to Fixed, because edit cannot contain more text than the | 157 | // Set size policy to Fixed, because edit cannot contain more text than the |
157 | // string representing the time. It doesn't make sense to provide more space. | 158 | // string representing the time. It doesn't make sense to provide more space. |
158 | QSizePolicy sizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed); | 159 | QSizePolicy sizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed); |
159 | 160 | ||
160 | return sizePolicy; | 161 | return sizePolicy; |
161 | } | 162 | } |
162 | */ | 163 | */ |
163 | void KOTimeEdit::setTime(QTime newTime) | 164 | void KOTimeEdit::setTime(QTime newTime) |
164 | { | 165 | { |
165 | if ( mTime != newTime ) | 166 | if ( mTime != newTime ) |
166 | { | 167 | { |
167 | kdDebug(5850) << "KOTimeEdit::setTime(): " << newTime.toString() << endl; | 168 | kdDebug(5850) << "KOTimeEdit::setTime(): " << newTime.toString() << endl; |
168 | 169 | ||
169 | mTime = newTime; | 170 | mTime = newTime; |
170 | updateText(); | 171 | updateText(); |
171 | } | 172 | } |
172 | 173 | ||
173 | } | 174 | } |
174 | 175 | ||
175 | void KOTimeEdit::activ(int i) | 176 | void KOTimeEdit::activ(int i) |
176 | { | 177 | { |
177 | // The last entry, 23:59, is a special case | 178 | // The last entry, 23:59, is a special case |
178 | if( i == count() - 1 ) | 179 | if( i == count() - 1 ) |
179 | mTime = QTime( 23, 59, 0 ); | 180 | mTime = QTime( 23, 59, 0 ); |
180 | else | 181 | else |
181 | mTime = QTime(0,0,0).addSecs(i*15*60); | 182 | mTime = QTime(0,0,0).addSecs(i*15*60); |
182 | emit timeChanged(mTime); | 183 | emit timeChanged(mTime); |
183 | } | 184 | } |
184 | 185 | ||
185 | void KOTimeEdit::hilit(int ) | 186 | void KOTimeEdit::hilit(int ) |
186 | { | 187 | { |
187 | // we don't currently need to do anything here. | 188 | // we don't currently need to do anything here. |
188 | } | 189 | } |
189 | 190 | ||
190 | void KOTimeEdit::addTime(QTime qt, bool update) | 191 | void KOTimeEdit::addTime(QTime qt, bool update) |
191 | { | 192 | { |
192 | // Calculate the new time. | 193 | // Calculate the new time. |
193 | //qDebug("add h %d min %d ", qt.hour(),qt.minute() ); | 194 | //qDebug("add h %d min %d ", qt.hour(),qt.minute() ); |
194 | mTime = mTime.addSecs(qt.minute()*60+qt.hour()*3600); | 195 | mTime = mTime.addSecs(qt.minute()*60+qt.hour()*3600); |
195 | // if ( update ) | 196 | // if ( update ) |
196 | updateText(); | 197 | updateText(); |
197 | emit timeChanged(mTime); | 198 | emit timeChanged(mTime); |
198 | } | 199 | } |
199 | 200 | ||
200 | void KOTimeEdit::subTime(QTime qt, bool update) | 201 | void KOTimeEdit::subTime(QTime qt, bool update) |
201 | { | 202 | { |
202 | int h, m; | 203 | int h, m; |
203 | //qDebug("sub h %d min %d ", qt.hour(),qt.minute() ); | 204 | //qDebug("sub h %d min %d ", qt.hour(),qt.minute() ); |
204 | 205 | ||
205 | mTime = mTime.addSecs(-(qt.minute()*60+qt.hour()*3600)); | 206 | mTime = mTime.addSecs(-(qt.minute()*60+qt.hour()*3600)); |
206 | // store the newly calculated time. | 207 | // store the newly calculated time. |
207 | // mTime.setHMS(h, m, 0); | 208 | // mTime.setHMS(h, m, 0); |
208 | //if ( update ) | 209 | //if ( update ) |
209 | updateText(); | 210 | updateText(); |
210 | emit timeChanged(mTime); | 211 | emit timeChanged(mTime); |
211 | } | 212 | } |
212 | 213 | ||
213 | // void KOTimeEdit::mouseReleaseEvent ( QMouseEvent * ) | 214 | // void KOTimeEdit::mouseReleaseEvent ( QMouseEvent * ) |
214 | // { | 215 | // { |
215 | // qDebug("mouseReleaseEvent ( QMouseEvent * ) "); | 216 | // qDebug("mouseReleaseEvent ( QMouseEvent * ) "); |
216 | // } | 217 | // } |
217 | 218 | ||
218 | // void KOTimeEdit::focusInEvent ( QFocusEvent * ) | 219 | // void KOTimeEdit::focusInEvent ( QFocusEvent * ) |
219 | // { | 220 | // { |
220 | // qDebug("focusInEvent ( QFocusEvent * ) "); | 221 | // qDebug("focusInEvent ( QFocusEvent * ) "); |
221 | // } | 222 | // } |
222 | 223 | ||
223 | void KOTimeEdit::keyReleaseEvent(QKeyEvent *e) | 224 | void KOTimeEdit::keyReleaseEvent(QKeyEvent *e) |
224 | { | 225 | { |
225 | if ( !e->isAutoRepeat() ) { | 226 | if ( !e->isAutoRepeat() ) { |
226 | mFlagKeyPressed = false; | 227 | mFlagKeyPressed = false; |
227 | } | 228 | } |
228 | 229 | ||
229 | } | 230 | } |
230 | void KOTimeEdit::setSelect( int from, int to ) | 231 | void KOTimeEdit::setSelect( int from, int to ) |
231 | { | 232 | { |
232 | if ( KOPrefs::instance()->mHightlightDateTimeEdit) | 233 | if ( KOPrefs::instance()->mHightlightDateTimeEdit) |
233 | lineEdit()->setSelection( from , to ); | 234 | lineEdit()->setSelection( from , to ); |
234 | } | 235 | } |
235 | 236 | ||
236 | 237 | ||
237 | void KOTimeEdit::keyPressEvent(QKeyEvent *e) | 238 | void KOTimeEdit::keyPressEvent(QKeyEvent *e) |
238 | { | 239 | { |
239 | 240 | ||
240 | qApp->processEvents(); | 241 | qApp->processEvents(); |
241 | bool hour12Format = ( KOPrefs::instance()->mPreferredTime == 1 ); | 242 | bool hour12Format = ( KPimGlobalPrefs::instance()->mPreferredTime == 1 ); |
242 | int maxpos = hour12Format?7:5; | 243 | int maxpos = hour12Format?7:5; |
243 | if ( e->isAutoRepeat() && !mFlagKeyPressed ) { | 244 | if ( e->isAutoRepeat() && !mFlagKeyPressed ) { |
244 | e->ignore(); | 245 | e->ignore(); |
245 | // qDebug(" ignore %d",e->isAutoRepeat() ); | 246 | // qDebug(" ignore %d",e->isAutoRepeat() ); |
246 | return; | 247 | return; |
247 | } | 248 | } |
248 | if (! e->isAutoRepeat() ) { | 249 | if (! e->isAutoRepeat() ) { |
249 | mFlagKeyPressed = true; | 250 | mFlagKeyPressed = true; |
250 | } | 251 | } |
251 | // Tap -> Focus Next Widget | 252 | // Tap -> Focus Next Widget |
252 | if ( e->key() == Key_Tab ) { | 253 | if ( e->key() == Key_Tab ) { |
253 | QComboBox::keyPressEvent(e); | 254 | QComboBox::keyPressEvent(e); |
254 | return; | 255 | return; |
255 | } | 256 | } |
256 | 257 | ||
257 | // save Text from QLineEdit and CursorPosition | 258 | // save Text from QLineEdit and CursorPosition |
258 | QString text = lineEdit()->text(); | 259 | QString text = lineEdit()->text(); |
259 | int cpos = lineEdit()->cursorPosition(); | 260 | int cpos = lineEdit()->cursorPosition(); |
260 | // qDebug("cpos %d ", cpos); | 261 | // qDebug("cpos %d ", cpos); |
261 | 262 | ||
262 | // Switch for arrows, backspace and escape | 263 | // Switch for arrows, backspace and escape |
263 | switch(e->key()) { | 264 | switch(e->key()) { |
264 | case Key_Escape: | 265 | case Key_Escape: |
265 | lineEdit()->deselect(); | 266 | lineEdit()->deselect(); |
266 | case Key_Tab: | 267 | case Key_Tab: |
267 | QComboBox::keyPressEvent(e); | 268 | QComboBox::keyPressEvent(e); |
268 | break; | 269 | break; |
269 | case Key_Up: | 270 | case Key_Up: |
270 | if ( e->state () == Qt::ControlButton ) { | 271 | if ( e->state () == Qt::ControlButton ) { |
271 | addTime(QTime(0,15,0), false ); | 272 | addTime(QTime(0,15,0), false ); |
272 | lineEdit()->setCursorPosition(3); | 273 | lineEdit()->setCursorPosition(3); |
273 | setSelect( 3 , 2 ); | 274 | setSelect( 3 , 2 ); |
274 | } | 275 | } |
275 | else | 276 | else |
276 | if ( e->state () == Qt::ShiftButton ) { | 277 | if ( e->state () == Qt::ShiftButton ) { |
277 | addTime(QTime(1,0,0), false ); | 278 | addTime(QTime(1,0,0), false ); |
278 | lineEdit()->setCursorPosition(0); | 279 | lineEdit()->setCursorPosition(0); |
279 | setSelect( 0 , 2 ); | 280 | setSelect( 0 , 2 ); |
280 | } | 281 | } |
281 | else | 282 | else |
282 | // switch time up, cursor location depend | 283 | // switch time up, cursor location depend |
283 | switch (cpos) { | 284 | switch (cpos) { |
284 | case 7: | 285 | case 7: |
285 | case 6: | 286 | case 6: |
286 | case 5: | 287 | case 5: |
287 | if(!hour12Format) { | 288 | if(!hour12Format) { |
288 | lineEdit()->setCursorPosition(cpos = 4); | 289 | lineEdit()->setCursorPosition(cpos = 4); |
289 | } else { | 290 | } else { |
290 | addTime(QTime(12,0,0), false ); | 291 | addTime(QTime(12,0,0), false ); |
291 | setSelect ( 5 , 2 ); | 292 | setSelect ( 5 , 2 ); |
292 | break; | 293 | break; |
293 | } | 294 | } |
294 | case 4: | 295 | case 4: |
295 | addTime(QTime(0,1,0), false ); | 296 | addTime(QTime(0,1,0), false ); |
296 | setSelect ( cpos , 1 ); | 297 | setSelect ( cpos , 1 ); |
297 | break; | 298 | break; |
298 | case 3: | 299 | case 3: |
299 | addTime(QTime(0,10,0), false ); | 300 | addTime(QTime(0,10,0), false ); |
300 | setSelect ( cpos , 1 ); | 301 | setSelect ( cpos , 1 ); |
301 | break; | 302 | break; |
302 | case 2: | 303 | case 2: |
303 | lineEdit()->setCursorPosition(--cpos); | 304 | lineEdit()->setCursorPosition(--cpos); |
304 | case 1: | 305 | case 1: |
305 | case 0: | 306 | case 0: |
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index fbfcd20..dc2026b 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -164,132 +164,131 @@ MainWindow::MainWindow( QWidget *parent, const char *name, QString msg) : | |||
164 | mCalendarModifiedFlag = false; | 164 | mCalendarModifiedFlag = false; |
165 | 165 | ||
166 | QLabel* splash = new QLabel(i18n("KO/Pi is starting ... "), this ); | 166 | QLabel* splash = new QLabel(i18n("KO/Pi is starting ... "), this ); |
167 | splash->setAlignment ( AlignCenter ); | 167 | splash->setAlignment ( AlignCenter ); |
168 | setCentralWidget( splash ); | 168 | setCentralWidget( splash ); |
169 | #ifndef DESKTOP_VERSION | 169 | #ifndef DESKTOP_VERSION |
170 | showMaximized(); | 170 | showMaximized(); |
171 | #endif | 171 | #endif |
172 | //qDebug("Mainwidget x %d y %d w %d h %d", x(), y(), width(), height ()); | 172 | //qDebug("Mainwidget x %d y %d w %d h %d", x(), y(), width(), height ()); |
173 | setDefaultPreferences(); | 173 | setDefaultPreferences(); |
174 | mCalendar = new CalendarLocal(); | 174 | mCalendar = new CalendarLocal(); |
175 | mView = new CalendarView( mCalendar, this,"mCalendar " ); | 175 | mView = new CalendarView( mCalendar, this,"mCalendar " ); |
176 | mView->hide(); | 176 | mView->hide(); |
177 | //mView->resize(splash->size() ); | 177 | //mView->resize(splash->size() ); |
178 | initActions(); | 178 | initActions(); |
179 | mSyncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)mView, KSyncManager::KOPI, KOPrefs::instance(), syncMenu); | 179 | mSyncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)mView, KSyncManager::KOPI, KOPrefs::instance(), syncMenu); |
180 | mSyncManager->setBlockSave(false); | 180 | mSyncManager->setBlockSave(false); |
181 | mView->setSyncManager(mSyncManager); | 181 | mView->setSyncManager(mSyncManager); |
182 | #ifndef DESKTOP_VERSION | 182 | #ifndef DESKTOP_VERSION |
183 | iconToolBar->show(); | 183 | iconToolBar->show(); |
184 | qApp->processEvents(); | 184 | qApp->processEvents(); |
185 | #endif | 185 | #endif |
186 | //qDebug("Splashwidget x %d y %d w %d h %d", splash-> x(), splash->y(), splash->width(),splash-> height ()); | 186 | //qDebug("Splashwidget x %d y %d w %d h %d", splash-> x(), splash->y(), splash->width(),splash-> height ()); |
187 | int vh = height() ; | 187 | int vh = height() ; |
188 | int vw = width(); | 188 | int vw = width(); |
189 | //qDebug("Toolbar hei %d ",iconToolBar->height() ); | 189 | //qDebug("Toolbar hei %d ",iconToolBar->height() ); |
190 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { | 190 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { |
191 | vh -= iconToolBar->height(); | 191 | vh -= iconToolBar->height(); |
192 | } else { | 192 | } else { |
193 | vw -= iconToolBar->height(); | 193 | vw -= iconToolBar->height(); |
194 | } | 194 | } |
195 | //mView->setMaximumSize( splash->size() ); | 195 | //mView->setMaximumSize( splash->size() ); |
196 | //mView->resize( splash->size() ); | 196 | //mView->resize( splash->size() ); |
197 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); | 197 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); |
198 | mView->readSettings(); | 198 | mView->readSettings(); |
199 | bool newFile = false; | 199 | bool newFile = false; |
200 | if( !QFile::exists( defaultFileName() ) ) { | 200 | if( !QFile::exists( defaultFileName() ) ) { |
201 | QFileInfo finfo ( defaultFileName() ); | 201 | QFileInfo finfo ( defaultFileName() ); |
202 | QString oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/Applications/korganizer/mycalendar.ics"); | 202 | QString oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/Applications/korganizer/mycalendar.ics"); |
203 | qDebug("oldfile %s ", oldFile.latin1()); | 203 | qDebug("oldfile %s ", oldFile.latin1()); |
204 | QString message = "You are starting KO/Pi for the\nfirst time after updating to a\nversion >= 1.9.1. The location of the\ndefault calendar file has changed.\nA mycalendar.ics file was detected\nat the old location.\nThis file will be loaded now\nand stored at the new location!\n(Config file location has changed, too!)\nPlease read menu Help-What's New!\n"; | 204 | QString message = "You are starting KO/Pi for the\nfirst time after updating to a\nversion >= 1.9.1. The location of the\ndefault calendar file has changed.\nA mycalendar.ics file was detected\nat the old location.\nThis file will be loaded now\nand stored at the new location!\n(Config file location has changed, too!)\nPlease read menu Help-What's New!\n"; |
205 | finfo.setFile( oldFile ); | 205 | finfo.setFile( oldFile ); |
206 | if (finfo.exists() ) { | 206 | if (finfo.exists() ) { |
207 | KMessageBox::information( this, message); | 207 | KMessageBox::information( this, message); |
208 | mView->openCalendar( oldFile ); | 208 | mView->openCalendar( oldFile ); |
209 | qApp->processEvents(); | 209 | qApp->processEvents(); |
210 | } else { | 210 | } else { |
211 | oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/korganizer/mycalendar.ics"); | 211 | oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/korganizer/mycalendar.ics"); |
212 | finfo.setFile( oldFile ); | 212 | finfo.setFile( oldFile ); |
213 | if (finfo.exists() ) { | 213 | if (finfo.exists() ) { |
214 | KMessageBox::information( this, message); | 214 | KMessageBox::information( this, message); |
215 | mView->openCalendar( oldFile ); | 215 | mView->openCalendar( oldFile ); |
216 | qApp->processEvents(); | 216 | qApp->processEvents(); |
217 | } | 217 | } |
218 | } | 218 | } |
219 | mView->saveCalendar( defaultFileName() ); | 219 | mView->saveCalendar( defaultFileName() ); |
220 | newFile = true; | 220 | newFile = true; |
221 | } | 221 | } |
222 | 222 | ||
223 | QTime neededSaveTime = QDateTime::currentDateTime().time(); | 223 | QTime neededSaveTime = QDateTime::currentDateTime().time(); |
224 | mView->openCalendar( defaultFileName() ); | 224 | mView->openCalendar( defaultFileName() ); |
225 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); | 225 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); |
226 | qDebug("KO: Calendar loading time: %d ms",msNeeded ); | 226 | qDebug("KO: Calendar loading time: %d ms",msNeeded ); |
227 | 227 | ||
228 | if ( KOPrefs::instance()->mLanguageChanged ) { | 228 | if ( KPimGlobalPrefs::instance()->mPreferredLanguage != KOPrefs::instance()->mOldLoadedLanguage ) { |
229 | KOPrefs::instance()->setCategoryDefaults(); | 229 | KOPrefs::instance()->setCategoryDefaults(); |
230 | int count = mView->addCategories(); | 230 | int count = mView->addCategories(); |
231 | KOPrefs::instance()->mLanguageChanged = false; | ||
232 | } | 231 | } |
233 | processIncidenceSelection( 0 ); | 232 | processIncidenceSelection( 0 ); |
234 | connect( mView, SIGNAL( incidenceSelected( Incidence * ) ), | 233 | connect( mView, SIGNAL( incidenceSelected( Incidence * ) ), |
235 | SLOT( processIncidenceSelection( Incidence * ) ) ); | 234 | SLOT( processIncidenceSelection( Incidence * ) ) ); |
236 | connect( mView, SIGNAL( modifiedChanged( bool ) ), | 235 | connect( mView, SIGNAL( modifiedChanged( bool ) ), |
237 | SLOT( slotModifiedChanged( bool ) ) ); | 236 | SLOT( slotModifiedChanged( bool ) ) ); |
238 | 237 | ||
239 | 238 | ||
240 | connect( mView, SIGNAL( tempDisableBR(bool) ), | 239 | connect( mView, SIGNAL( tempDisableBR(bool) ), |
241 | SLOT( disableBR(bool) ) ); | 240 | SLOT( disableBR(bool) ) ); |
242 | connect( &mSaveTimer, SIGNAL( timeout() ), SLOT( save() ) ); | 241 | connect( &mSaveTimer, SIGNAL( timeout() ), SLOT( save() ) ); |
243 | mView->setModified( false ); | 242 | mView->setModified( false ); |
244 | mBlockAtStartup = false; | 243 | mBlockAtStartup = false; |
245 | mView->setModified( false ); | 244 | mView->setModified( false ); |
246 | setCentralWidget( mView ); | 245 | setCentralWidget( mView ); |
247 | globalFlagBlockStartup = 0; | 246 | globalFlagBlockStartup = 0; |
248 | mView->show(); | 247 | mView->show(); |
249 | delete splash; | 248 | delete splash; |
250 | if ( newFile ) | 249 | if ( newFile ) |
251 | mView->updateConfig(); | 250 | mView->updateConfig(); |
252 | // qApp->processEvents(); | 251 | // qApp->processEvents(); |
253 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); | 252 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); |
254 | //fillSyncMenu(); | 253 | //fillSyncMenu(); |
255 | 254 | ||
256 | 255 | ||
257 | connect(mSyncManager , SIGNAL( save() ), this, SLOT( save() ) ); | 256 | connect(mSyncManager , SIGNAL( save() ), this, SLOT( save() ) ); |
258 | connect(mSyncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); | 257 | connect(mSyncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); |
259 | connect(mSyncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); | 258 | connect(mSyncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); |
260 | mSyncManager->setDefaultFileName( defaultFileName()); | 259 | mSyncManager->setDefaultFileName( defaultFileName()); |
261 | connect ( syncMenu, SIGNAL( activated ( int ) ), mSyncManager, SLOT (slotSyncMenu( int ) ) ); | 260 | connect ( syncMenu, SIGNAL( activated ( int ) ), mSyncManager, SLOT (slotSyncMenu( int ) ) ); |
262 | mSyncManager->fillSyncMenu(); | 261 | mSyncManager->fillSyncMenu(); |
263 | 262 | ||
264 | 263 | ||
265 | 264 | ||
266 | mView->viewManager()->agendaView()->setStartHour( KOPrefs::instance()->mDayBegins ); | 265 | mView->viewManager()->agendaView()->setStartHour( KOPrefs::instance()->mDayBegins ); |
267 | if ( showWarning ) { | 266 | if ( showWarning ) { |
268 | KMessageBox::information( this, | 267 | KMessageBox::information( this, |
269 | "You are starting KO/Pi for the first time.\nPlease read menu: Help-What's New,\nif you did an update!\nPlease choose your timezone in the \nConfigure Dialog TAB Time Zone!\nPlease choose your language\nin the TAB Locale!\nYou get the Configure Dialog\nvia Menu: Actions - Configure....\nClick OK to show the Configure Dialog!\n", "KO/Pi information"); | 268 | "You are starting KO/Pi for the first time.\nPlease read menu: Help-What's New,\nif you did an update!\nPlease choose your timezone in the \nConfigure Dialog TAB Time Zone!\nPlease choose your language\nin the TAB Locale!\nYou get the Configure Dialog\nvia Menu: Actions - Configure....\nClick OK to show the Configure Dialog!\n", "KO/Pi information"); |
270 | qApp->processEvents(); | 269 | qApp->processEvents(); |
271 | mView->dialogManager()->showSyncOptions(); | 270 | mView->dialogManager()->showSyncOptions(); |
272 | } | 271 | } |
273 | 272 | ||
274 | //US listen for result adressed from Ka/Pi | 273 | //US listen for result adressed from Ka/Pi |
275 | #ifndef DESKTOP_VERSION | 274 | #ifndef DESKTOP_VERSION |
276 | connect(qApp, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); | 275 | connect(qApp, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); |
277 | #endif | 276 | #endif |
278 | #ifndef DESKTOP_VERSION | 277 | #ifndef DESKTOP_VERSION |
279 | infrared = 0; | 278 | infrared = 0; |
280 | #endif | 279 | #endif |
281 | 280 | ||
282 | mBRdisabled = false; | 281 | mBRdisabled = false; |
283 | toggleBeamReceive(); | 282 | toggleBeamReceive(); |
284 | } | 283 | } |
285 | MainWindow::~MainWindow() | 284 | MainWindow::~MainWindow() |
286 | { | 285 | { |
287 | //qDebug("MainWindow::~MainWindow() "); | 286 | //qDebug("MainWindow::~MainWindow() "); |
288 | //save toolbar location | 287 | //save toolbar location |
289 | delete mCalendar; | 288 | delete mCalendar; |
290 | delete mSyncManager; | 289 | delete mSyncManager; |
291 | #ifndef DESKTOP_VERSION | 290 | #ifndef DESKTOP_VERSION |
292 | if ( infrared ) | 291 | if ( infrared ) |
293 | delete infrared; | 292 | delete infrared; |
294 | #endif | 293 | #endif |
295 | 294 | ||
diff --git a/libkdepim/kpimglobalprefs.cpp b/libkdepim/kpimglobalprefs.cpp index 0a580ca..5298f0c 100644 --- a/libkdepim/kpimglobalprefs.cpp +++ b/libkdepim/kpimglobalprefs.cpp | |||
@@ -1,139 +1,207 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkdepim. | 2 | This file is part of libkdepim. |
3 | Copyright (c) 2002 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2002 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 | /* | 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 | #include <kglobal.h> | 31 | #include <kglobal.h> |
32 | #include <kconfig.h> | 32 | #include <kconfig.h> |
33 | #include <klocale.h> | 33 | #include <klocale.h> |
34 | #include <kdebug.h> | 34 | #include <kdebug.h> |
35 | #include <kstaticdeleter.h> | 35 | #include <kstaticdeleter.h> |
36 | 36 | ||
37 | #include <qregexp.h> | 37 | #include <qregexp.h> |
38 | #include <qfile.h> | ||
39 | #include <qtextstream.h> | ||
40 | #include <qapplication.h> | ||
38 | #include "kpimglobalprefs.h" | 41 | #include "kpimglobalprefs.h" |
39 | 42 | ||
40 | KPimGlobalPrefs *KPimGlobalPrefs::sInstance = 0; | 43 | KPimGlobalPrefs *KPimGlobalPrefs::sInstance = 0; |
41 | static KStaticDeleter<KPimGlobalPrefs> staticDeleter; | 44 | static KStaticDeleter<KPimGlobalPrefs> staticDeleterGP; |
42 | 45 | ||
43 | 46 | ||
44 | KPimGlobalPrefs::KPimGlobalPrefs( const QString &name ) | 47 | KPimGlobalPrefs::KPimGlobalPrefs( const QString &name ) |
45 | : KPrefs("microkdeglobalrc") | 48 | : KPrefs("microkdeglobalrc") |
46 | { | 49 | { |
47 | 50 | mLocaleDict = 0; | |
48 | KPrefs::setCurrentGroup("Locale"); | 51 | KPrefs::setCurrentGroup("Locale"); |
49 | addItemInt("PreferredLanguage",&mPreferredLanguage,0); | 52 | addItemInt("PreferredLanguage",&mPreferredLanguage,0); |
50 | addItemInt("PreferredTime",&mPreferredTime,0); | 53 | addItemInt("PreferredTime",&mPreferredTime,0); |
51 | addItemInt("PreferredDate",&mPreferredDate,0); | 54 | addItemInt("PreferredDate",&mPreferredDate,0); |
52 | addItemBool("WeekStartsOnSunday",&mWeekStartsOnSunday,false); | 55 | addItemBool("WeekStartsOnSunday",&mWeekStartsOnSunday,false); |
53 | //addItemBool("QuickSavingWOUnicode",&mUseQuicksave,false); | 56 | //addItemBool("QuickSavingWOUnicode",&mUseQuicksave,false); |
54 | // addItemBool("ShortDateInViewer",&mShortDateInViewer,false); | 57 | // addItemBool("ShortDateInViewer",&mShortDateInViewer,false); |
55 | addItemString("UserDateFormatLong", &mUserDateFormatLong, "%A %d %b %y"); | 58 | addItemString("UserDateFormatLong", &mUserDateFormatLong, "%A %d %b %y"); |
56 | addItemString("UserDateFormatShort", &mUserDateFormatShort, "%aK %d.%m.%y"); | 59 | addItemString("UserDateFormatShort", &mUserDateFormatShort, "%aK %d.%m.%y"); |
57 | 60 | ||
58 | KPrefs::setCurrentGroup("Time & Date"); | 61 | KPrefs::setCurrentGroup("Time & Date"); |
59 | 62 | ||
60 | addItemString("TimeZoneName",&mTimeZoneId, ("+01:00 Europe/Oslo(CET)") ); | 63 | addItemString("TimeZoneName",&mTimeZoneId, ("+01:00 Europe/Oslo(CET)") ); |
61 | addItemBool("UseDaylightsaving",&mUseDaylightsaving,true); | 64 | addItemBool("UseDaylightsaving",&mUseDaylightsaving,true); |
62 | addItemBool("TimeZoneAdd30min",&mTimeZoneAdd30min,false); | 65 | addItemBool("TimeZoneAdd30min",&mTimeZoneAdd30min,false); |
63 | addItemInt("DaylightsavingStart",&mDaylightsavingStart,90); | 66 | addItemInt("DaylightsavingStart",&mDaylightsavingStart,90); |
64 | addItemInt("DaylightsavingEnd",&mDaylightsavingEnd,304); | 67 | addItemInt("DaylightsavingEnd",&mDaylightsavingEnd,304); |
65 | 68 | ||
66 | KPrefs::setCurrentGroup( "ExternalApplications" ); | 69 | KPrefs::setCurrentGroup( "ExternalApplications" ); |
67 | 70 | ||
68 | addItemInt( "EmailChannelType", &mEmailClient, OMPI_EMC ); | 71 | addItemInt( "EmailChannelType", &mEmailClient, OMPI_EMC ); |
69 | addItemString( "EmailChannel", &mEmailOtherChannel, "" ); | 72 | addItemString( "EmailChannel", &mEmailOtherChannel, "" ); |
70 | addItemString( "EmailChannelMessage", &mEmailOtherMessage, "" ); | 73 | addItemString( "EmailChannelMessage", &mEmailOtherMessage, "" ); |
71 | addItemString( "EmailChannelParameters", &mEmailOtherMessageParameters, "" ); | 74 | addItemString( "EmailChannelParameters", &mEmailOtherMessageParameters, "" ); |
72 | addItemString( "EmailChannelMessage2", &mEmailOtherMessage2, "" ); | 75 | addItemString( "EmailChannelMessage2", &mEmailOtherMessage2, "" ); |
73 | addItemString( "EmailChannelParameters2", &mEmailOtherMessageParameters2, "" ); | 76 | addItemString( "EmailChannelParameters2", &mEmailOtherMessageParameters2, "" ); |
74 | 77 | ||
75 | addItemInt( "PhoneChannelType", &mPhoneClient, KPPI_PHC ); | 78 | addItemInt( "PhoneChannelType", &mPhoneClient, KPPI_PHC ); |
76 | addItemString( "PhoneChannel", &mPhoneOtherChannel, "" ); | 79 | addItemString( "PhoneChannel", &mPhoneOtherChannel, "" ); |
77 | addItemString( "PhoneChannelMessage", &mPhoneOtherMessage, "" ); | 80 | addItemString( "PhoneChannelMessage", &mPhoneOtherMessage, "" ); |
78 | addItemString( "PhoneChannelParameters", &mPhoneOtherMessageParameters, "" ); | 81 | addItemString( "PhoneChannelParameters", &mPhoneOtherMessageParameters, "" ); |
79 | 82 | ||
80 | addItemInt( "FaxChannelType", &mFaxClient, NONE_FAC ); | 83 | addItemInt( "FaxChannelType", &mFaxClient, NONE_FAC ); |
81 | addItemString( "FaxChannel", &mFaxOtherChannel, "" ); | 84 | addItemString( "FaxChannel", &mFaxOtherChannel, "" ); |
82 | addItemString( "FaxChannelMessage", &mFaxOtherMessage, "" ); | 85 | addItemString( "FaxChannelMessage", &mFaxOtherMessage, "" ); |
83 | addItemString( "FaxChannelParameters", &mFaxOtherMessageParameters, "" ); | 86 | addItemString( "FaxChannelParameters", &mFaxOtherMessageParameters, "" ); |
84 | 87 | ||
85 | addItemInt( "SMSChannelType", &mSMSClient, NONE_SMC ); | 88 | addItemInt( "SMSChannelType", &mSMSClient, NONE_SMC ); |
86 | addItemString( "SMSChannel", &mSMSOtherChannel, "" ); | 89 | addItemString( "SMSChannel", &mSMSOtherChannel, "" ); |
87 | addItemString( "SMSChannelMessage", &mSMSOtherMessage, "" ); | 90 | addItemString( "SMSChannelMessage", &mSMSOtherMessage, "" ); |
88 | addItemString( "SMSChannelParameters", &mSMSOtherMessageParameters, "" ); | 91 | addItemString( "SMSChannelParameters", &mSMSOtherMessageParameters, "" ); |
89 | 92 | ||
90 | addItemInt( "PagerChannelType", &mPagerClient, NONE_PAC ); | 93 | addItemInt( "PagerChannelType", &mPagerClient, NONE_PAC ); |
91 | addItemString( "PagerChannel", &mPagerOtherChannel, "" ); | 94 | addItemString( "PagerChannel", &mPagerOtherChannel, "" ); |
92 | addItemString( "PagerChannelMessage", &mPagerOtherMessage, "" ); | 95 | addItemString( "PagerChannelMessage", &mPagerOtherMessage, "" ); |
93 | addItemString( "PagerChannelParameters", &mPagerOtherMessageParameters, "" ); | 96 | addItemString( "PagerChannelParameters", &mPagerOtherMessageParameters, "" ); |
94 | 97 | ||
95 | addItemInt( "SIPChannelType", &mSipClient, KPPI_SIC ); | 98 | addItemInt( "SIPChannelType", &mSipClient, KPPI_SIC ); |
96 | addItemString( "SIPChannel", &mSipOtherChannel, "" ); | 99 | addItemString( "SIPChannel", &mSipOtherChannel, "" ); |
97 | addItemString( "SIPChannelMessage", &mSipOtherMessage, "" ); | 100 | addItemString( "SIPChannelMessage", &mSipOtherMessage, "" ); |
98 | addItemString( "SIPChannelParameters", &mSipOtherMessageParameters, "" ); | 101 | addItemString( "SIPChannelParameters", &mSipOtherMessageParameters, "" ); |
99 | 102 | ||
100 | KPrefs::setCurrentGroup( "PhoneAccess" ); | 103 | KPrefs::setCurrentGroup( "PhoneAccess" ); |
101 | addItemString("Ex2PhoneDevice",&mEx2PhoneDevice,"/dev/ircomm"); | 104 | addItemString("Ex2PhoneDevice",&mEx2PhoneDevice,"/dev/ircomm"); |
102 | addItemString("Ex2PhoneConnection",&mEx2PhoneConnection,"irda"); | 105 | addItemString("Ex2PhoneConnection",&mEx2PhoneConnection,"irda"); |
103 | addItemString("Ex2PhoneModel",&mEx2PhoneModel,"6310i"); | 106 | addItemString("Ex2PhoneModel",&mEx2PhoneModel,"6310i"); |
104 | 107 | ||
105 | } | 108 | } |
106 | 109 | ||
107 | |||
108 | void KPimGlobalPrefs::setGlobalConfig() | 110 | void KPimGlobalPrefs::setGlobalConfig() |
109 | { | 111 | { |
112 | if ( mLocaleDict == 0 ) { | ||
113 | QString fileName ; | ||
114 | QString name = KGlobal::getAppName() +"/"; | ||
115 | #ifndef DESKTOP_VERSION | ||
116 | fileName= QString(getenv("QPEDIR"))+"/pics/kdepim/"+name | ||
117 | #else | ||
118 | fileName = qApp->applicationDirPath () + "/kdepim/"+ name; | ||
119 | #endif | ||
120 | mLocaleDict = 0; | ||
121 | if ( mPreferredLanguage > 0 && mPreferredLanguage < 5 ) { | ||
122 | |||
123 | if ( mPreferredLanguage == 1 ) | ||
124 | fileName = fileName+"germantranslation.txt"; | ||
125 | else if ( mPreferredLanguage == 4 ) | ||
126 | fileName = fileName+"usertranslation.txt"; | ||
127 | else if ( mPreferredLanguage == 2 ) | ||
128 | fileName = fileName+"frenchtranslation.txt"; | ||
129 | else if ( mPreferredLanguage == 3 ) | ||
130 | fileName = fileName+"italiantranslation.txt"; | ||
131 | QFile file( fileName ); | ||
132 | if (file.open( IO_ReadOnly ) ) { | ||
133 | QTextStream ts( &file ); | ||
134 | ts.setEncoding( QTextStream::Latin1 ); | ||
135 | //ts.setCodec( QTextCodec::latin1 ); | ||
136 | QString text = ts.read(); | ||
137 | file.close(); | ||
138 | text.replace( QRegExp("\\\\n"), "\n" ); | ||
139 | QString line; | ||
140 | QString we; | ||
141 | QString wt; | ||
142 | int br = 0; | ||
143 | int nbr; | ||
144 | nbr = text.find ( "},", br ); | ||
145 | line = text.mid( br, nbr - br ); | ||
146 | br = nbr+1; | ||
147 | int se, ee, st, et; | ||
148 | mLocaleDict = new QDict<QString>; | ||
149 | QString end = "{ \"\",\"\" }"; | ||
150 | while ( (line != end) && (br > 1) ) { | ||
151 | //qDebug("%d *%s* ", br, line.latin1()); | ||
152 | se = line.find("\"")+1; | ||
153 | et = line.findRev("\"",-1); | ||
154 | ee = line.find("\",\""); | ||
155 | st = ee+3; | ||
156 | we = line.mid( se, ee-se ); | ||
157 | wt = line.mid( st, et-st ); | ||
158 | //qDebug("*%s* *%s* ", we.latin1(), wt.latin1()); | ||
159 | mLocaleDict->insert( we, new QString (wt) ); | ||
160 | nbr = text.find ( "}", br ); | ||
161 | line = text.mid( br, nbr - br ); | ||
162 | br = nbr+1; | ||
163 | } | ||
164 | //qDebug("end *%s* ", end.latin1()); | ||
165 | |||
166 | setLocaleDict( mLocaleDict ); | ||
167 | } else { | ||
168 | qDebug("KO: Cannot find translation file %s",fileName.latin1() ); | ||
169 | } | ||
170 | } | ||
171 | } | ||
110 | 172 | ||
111 | KGlobal::locale()->setHore24Format( !mPreferredTime ); | 173 | KGlobal::locale()->setHore24Format( !mPreferredTime ); |
112 | KGlobal::locale()->setWeekStartMonday( !mWeekStartsOnSunday ); | 174 | KGlobal::locale()->setWeekStartMonday( !mWeekStartsOnSunday ); |
113 | KGlobal::locale()->setIntDateFormat( (KLocale::IntDateFormat)mPreferredDate ); | 175 | KGlobal::locale()->setIntDateFormat( (KLocale::IntDateFormat)mPreferredDate ); |
114 | KGlobal::locale()->setLanguage( mPreferredLanguage ); | 176 | KGlobal::locale()->setLanguage( mPreferredLanguage ); |
115 | QString dummy = mUserDateFormatLong; | 177 | QString dummy = mUserDateFormatLong; |
116 | KGlobal::locale()->setDateFormat(dummy.replace( QRegExp("K"), QString(",") )); | 178 | KGlobal::locale()->setDateFormat(dummy.replace( QRegExp("K"), QString(",") )); |
117 | dummy = mUserDateFormatShort; | 179 | dummy = mUserDateFormatShort; |
118 | KGlobal::locale()->setDateFormatShort(dummy.replace( QRegExp("K"), QString(",") )); | 180 | KGlobal::locale()->setDateFormatShort(dummy.replace( QRegExp("K"), QString(",") )); |
119 | KGlobal::locale()->setDaylightSaving( mUseDaylightsaving, | 181 | KGlobal::locale()->setDaylightSaving( mUseDaylightsaving, |
120 | mDaylightsavingStart, | 182 | mDaylightsavingStart, |
121 | mDaylightsavingEnd ); | 183 | mDaylightsavingEnd ); |
122 | KGlobal::locale()->setTimezone( mTimeZoneId, mTimeZoneAdd30min ); | 184 | KGlobal::locale()->setTimezone( mTimeZoneId, mTimeZoneAdd30min ); |
123 | 185 | ||
124 | } | 186 | } |
125 | KPimGlobalPrefs::~KPimGlobalPrefs() | 187 | KPimGlobalPrefs::~KPimGlobalPrefs() |
126 | { | 188 | { |
189 | if (sInstance == this) | ||
190 | sInstance = staticDeleterGP.setObject(0); | ||
191 | else | ||
192 | qDebug("Whats this? Error in KPimGlobalPrefs::~KPimGlobalPrefs() ?"); | ||
127 | //qDebug("KPimGlobalPrefs::~KPimGlobalPrefs() "); | 193 | //qDebug("KPimGlobalPrefs::~KPimGlobalPrefs() "); |
128 | writeConfig(); | 194 | writeConfig(); |
195 | if ( mLocaleDict ) | ||
196 | delete mLocaleDict; | ||
129 | } | 197 | } |
130 | 198 | ||
131 | KPimGlobalPrefs *KPimGlobalPrefs::instance() | 199 | KPimGlobalPrefs *KPimGlobalPrefs::instance() |
132 | { | 200 | { |
133 | if ( !sInstance ) { | 201 | if ( !sInstance ) { |
134 | sInstance = staticDeleter.setObject( new KPimGlobalPrefs() ); | 202 | sInstance = staticDeleterGP.setObject( new KPimGlobalPrefs() ); |
135 | sInstance->readConfig(); | 203 | sInstance->readConfig(); |
136 | } | 204 | } |
137 | 205 | ||
138 | return sInstance; | 206 | return sInstance; |
139 | } | 207 | } |
diff --git a/libkdepim/kpimglobalprefs.h b/libkdepim/kpimglobalprefs.h index d09c3da..11c534a 100644 --- a/libkdepim/kpimglobalprefs.h +++ b/libkdepim/kpimglobalprefs.h | |||
@@ -1,140 +1,142 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkdepim. | 2 | This file is part of libkdepim. |
3 | Copyright (c) 2004 Ulf Schenk | 3 | Copyright (c) 2004 Ulf Schenk |
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 | #ifndef KPIMGLOBALPREFS_H | 31 | #ifndef KPIMGLOBALPREFS_H |
32 | #define KPIMGLOBALPREFS_H | 32 | #define KPIMGLOBALPREFS_H |
33 | 33 | ||
34 | #include "kprefs.h" | 34 | #include "kprefs.h" |
35 | #include <qdict.h> | ||
35 | 36 | ||
36 | class KPimGlobalPrefs : public KPrefs | 37 | class KPimGlobalPrefs : public KPrefs |
37 | { | 38 | { |
38 | public: | 39 | public: |
39 | 40 | ||
40 | void setGlobalConfig(); | 41 | void setGlobalConfig(); |
41 | static KPimGlobalPrefs *instance(); | 42 | static KPimGlobalPrefs *instance(); |
42 | 43 | ||
43 | 44 | ||
44 | virtual ~KPimGlobalPrefs(); | 45 | virtual ~KPimGlobalPrefs(); |
45 | 46 | ||
46 | 47 | ||
47 | enum EMailClients { | 48 | enum EMailClients { |
48 | NONE_EMC = 0, | 49 | NONE_EMC = 0, |
49 | OTHER_EMC = 1, | 50 | OTHER_EMC = 1, |
50 | OMPI_EMC = 2, | 51 | OMPI_EMC = 2, |
51 | QTOPIA_EMC = 3, | 52 | QTOPIA_EMC = 3, |
52 | OPIE_EMC = 4 | 53 | OPIE_EMC = 4 |
53 | }; | 54 | }; |
54 | 55 | ||
55 | enum PhoneClients { | 56 | enum PhoneClients { |
56 | NONE_PHC = 0, | 57 | NONE_PHC = 0, |
57 | OTHER_PHC = 1, | 58 | OTHER_PHC = 1, |
58 | KPPI_PHC = 2 | 59 | KPPI_PHC = 2 |
59 | }; | 60 | }; |
60 | 61 | ||
61 | enum FaxClients { | 62 | enum FaxClients { |
62 | NONE_FAC = 0, | 63 | NONE_FAC = 0, |
63 | OTHER_FAC = 1 | 64 | OTHER_FAC = 1 |
64 | }; | 65 | }; |
65 | 66 | ||
66 | enum SMSClients { | 67 | enum SMSClients { |
67 | NONE_SMC = 0, | 68 | NONE_SMC = 0, |
68 | OTHER_SMC = 1 | 69 | OTHER_SMC = 1 |
69 | }; | 70 | }; |
70 | 71 | ||
71 | enum PagerClients { | 72 | enum PagerClients { |
72 | NONE_PAC = 0, | 73 | NONE_PAC = 0, |
73 | OTHER_PAC = 1 | 74 | OTHER_PAC = 1 |
74 | }; | 75 | }; |
75 | 76 | ||
76 | enum SIPClients { | 77 | enum SIPClients { |
77 | NONE_SIC = 0, | 78 | NONE_SIC = 0, |
78 | OTHER_SIC = 1, | 79 | OTHER_SIC = 1, |
79 | KPPI_SIC = 2 | 80 | KPPI_SIC = 2 |
80 | }; | 81 | }; |
81 | 82 | ||
82 | private: | 83 | private: |
83 | KPimGlobalPrefs( const QString &name = QString::null ); | 84 | KPimGlobalPrefs( const QString &name = QString::null ); |
84 | 85 | ||
85 | static KPimGlobalPrefs *sInstance; | 86 | static KPimGlobalPrefs *sInstance; |
87 | QDict<QString> *mLocaleDict; | ||
86 | 88 | ||
87 | 89 | ||
88 | public: | 90 | public: |
89 | //US I copied the following "locale" settings from KOPrefs | 91 | //US I copied the following "locale" settings from KOPrefs |
90 | int mPreferredDate; | 92 | int mPreferredDate; |
91 | QString mUserDateFormatLong; | 93 | QString mUserDateFormatLong; |
92 | QString mUserDateFormatShort; | 94 | QString mUserDateFormatShort; |
93 | int mPreferredLanguage; | 95 | int mPreferredLanguage; |
94 | int mPreferredTime; | 96 | int mPreferredTime; |
95 | bool mWeekStartsOnSunday; | 97 | bool mWeekStartsOnSunday; |
96 | QString mTimeZoneId; | 98 | QString mTimeZoneId; |
97 | bool mUseDaylightsaving; | 99 | bool mUseDaylightsaving; |
98 | int mDaylightsavingStart; | 100 | int mDaylightsavingStart; |
99 | int mDaylightsavingEnd; | 101 | int mDaylightsavingEnd; |
100 | bool mTimeZoneAdd30min; | 102 | bool mTimeZoneAdd30min; |
101 | 103 | ||
102 | int mEmailClient; | 104 | int mEmailClient; |
103 | QString mEmailOtherChannel; | 105 | QString mEmailOtherChannel; |
104 | QString mEmailOtherMessage; | 106 | QString mEmailOtherMessage; |
105 | QString mEmailOtherMessageParameters; | 107 | QString mEmailOtherMessageParameters; |
106 | QString mEmailOtherMessage2; | 108 | QString mEmailOtherMessage2; |
107 | QString mEmailOtherMessageParameters2; | 109 | QString mEmailOtherMessageParameters2; |
108 | 110 | ||
109 | int mPhoneClient; | 111 | int mPhoneClient; |
110 | QString mPhoneOtherChannel; | 112 | QString mPhoneOtherChannel; |
111 | QString mPhoneOtherMessage; | 113 | QString mPhoneOtherMessage; |
112 | QString mPhoneOtherMessageParameters; | 114 | QString mPhoneOtherMessageParameters; |
113 | 115 | ||
114 | int mFaxClient; | 116 | int mFaxClient; |
115 | QString mFaxOtherChannel; | 117 | QString mFaxOtherChannel; |
116 | QString mFaxOtherMessage; | 118 | QString mFaxOtherMessage; |
117 | QString mFaxOtherMessageParameters; | 119 | QString mFaxOtherMessageParameters; |
118 | 120 | ||
119 | int mSMSClient; | 121 | int mSMSClient; |
120 | QString mSMSOtherChannel; | 122 | QString mSMSOtherChannel; |
121 | QString mSMSOtherMessage; | 123 | QString mSMSOtherMessage; |
122 | QString mSMSOtherMessageParameters; | 124 | QString mSMSOtherMessageParameters; |
123 | 125 | ||
124 | int mPagerClient; | 126 | int mPagerClient; |
125 | QString mPagerOtherChannel; | 127 | QString mPagerOtherChannel; |
126 | QString mPagerOtherMessage; | 128 | QString mPagerOtherMessage; |
127 | QString mPagerOtherMessageParameters; | 129 | QString mPagerOtherMessageParameters; |
128 | 130 | ||
129 | int mSipClient; | 131 | int mSipClient; |
130 | QString mSipOtherChannel; | 132 | QString mSipOtherChannel; |
131 | QString mSipOtherMessage; | 133 | QString mSipOtherMessage; |
132 | QString mSipOtherMessageParameters; | 134 | QString mSipOtherMessageParameters; |
133 | 135 | ||
134 | QString mEx2PhoneDevice; | 136 | QString mEx2PhoneDevice; |
135 | QString mEx2PhoneConnection; | 137 | QString mEx2PhoneConnection; |
136 | QString mEx2PhoneModel; | 138 | QString mEx2PhoneModel; |
137 | 139 | ||
138 | }; | 140 | }; |
139 | 141 | ||
140 | #endif | 142 | #endif |
diff --git a/microkde/kstaticdeleter.h b/microkde/kstaticdeleter.h index dfd3929..d9c2b72 100644 --- a/microkde/kstaticdeleter.h +++ b/microkde/kstaticdeleter.h | |||
@@ -1,37 +1,38 @@ | |||
1 | /* | 1 | /* |
2 | * This file is part of the KDE Libraries | 2 | * This file is part of the KDE Libraries |
3 | * Copyright (C) 2000 Stephan Kulow <coolo@kde.org> | 3 | * Copyright (C) 2000 Stephan Kulow <coolo@kde.org> |
4 | * 2001 KDE Team | 4 | * 2001 KDE Team |
5 | * | 5 | * |
6 | * This library is free software; you can redistribute it and/or | 6 | * This library is free software; you can redistribute it and/or |
7 | * modify it under the terms of the GNU Library General Public | 7 | * modify it under the terms of the GNU Library General Public |
8 | * License as published by the Free Software Foundation; either | 8 | * License as published by the Free Software Foundation; either |
9 | * version 2 of the License, or (at your option) any later version. | 9 | * version 2 of the License, or (at your option) any later version. |
10 | * | 10 | * |
11 | * This library is distributed in the hope that it will be useful, | 11 | * This library is distributed in the hope that it will be useful, |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 | * Library General Public License for more details. | 14 | * Library General Public License for more details. |
15 | * | 15 | * |
16 | * You should have received a copy of the GNU Library General Public License | 16 | * You should have received a copy of the GNU Library General Public License |
17 | * along with this library; see the file COPYING.LIB. If not, write to | 17 | * along with this library; see the file COPYING.LIB. If not, write to |
18 | * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 18 | * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
19 | * Boston, MA 02111-1307, USA. | 19 | * Boston, MA 02111-1307, USA. |
20 | * | 20 | * |
21 | */ | 21 | */ |
22 | 22 | ||
23 | #ifndef _KSTATIC_DELETER_H_ | 23 | #ifndef _KSTATIC_DELETER_H_ |
24 | #define _KSTATIC_DELETER_H_ | 24 | #define _KSTATIC_DELETER_H_ |
25 | 25 | ||
26 | template<class type> | 26 | template<class type> |
27 | class KStaticDeleter | 27 | class KStaticDeleter |
28 | { | 28 | { |
29 | public: | 29 | public: |
30 | KStaticDeleter() {}; | 30 | KStaticDeleter() {}; |
31 | type *setObject( type *obj, bool isArray = false) { _mobj = obj;return obj; } | 31 | type *setObject( type *obj, bool isArray = false) { _mobj = obj;_isArray = isArray;return obj; } |
32 | virtual ~KStaticDeleter() {delete _mobj;}; | 32 | virtual ~KStaticDeleter() {if (_isArray) delete[] _mobj; else delete _mobj;}; |
33 | private: | 33 | private: |
34 | type* _mobj; | 34 | type* _mobj; |
35 | bool _isArray; | ||
35 | }; | 36 | }; |
36 | 37 | ||
37 | #endif | 38 | #endif |
diff --git a/pwmanager/pwmanager/pwmprefs.cpp b/pwmanager/pwmanager/pwmprefs.cpp index fdc34e0..68d5b68 100644 --- a/pwmanager/pwmanager/pwmprefs.cpp +++ b/pwmanager/pwmanager/pwmprefs.cpp | |||
@@ -1,145 +1,149 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of PwManager/Pi | 2 | This file is part of PwManager/Pi |
3 | Copyright (c) 2004 Ulf Schenk | 3 | Copyright (c) 2004 Ulf Schenk |
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 | $Id$ | 23 | $Id$ |
24 | */ | 24 | */ |
25 | 25 | ||
26 | 26 | ||
27 | #include <kconfig.h> | 27 | #include <kconfig.h> |
28 | #include <klocale.h> | 28 | #include <klocale.h> |
29 | #include <kstaticdeleter.h> | 29 | #include <kstaticdeleter.h> |
30 | 30 | ||
31 | #include "pwmprefs.h" | 31 | #include "pwmprefs.h" |
32 | 32 | ||
33 | PWMPrefs *PWMPrefs::sInstance = 0; | 33 | PWMPrefs *PWMPrefs::sInstance = 0; |
34 | static KStaticDeleter<PWMPrefs> staticDeleter; | 34 | static KStaticDeleter<PWMPrefs> staticDeleterPP; |
35 | 35 | ||
36 | PWMPrefs::PWMPrefs() | 36 | PWMPrefs::PWMPrefs() |
37 | : KPimPrefs("pwmanagerrc") | 37 | : KPimPrefs("pwmanagerrc") |
38 | { | 38 | { |
39 | KPrefs::setCurrentGroup( "Global" ); | 39 | KPrefs::setCurrentGroup( "Global" ); |
40 | 40 | ||
41 | addItemString( "autoStart", &mAutoStart, "" ); | 41 | addItemString( "autoStart", &mAutoStart, "" ); |
42 | addItemString( "browserCommand", &mBrowserCommand, "" ); | 42 | addItemString( "browserCommand", &mBrowserCommand, "" ); |
43 | addItemString( "xtermCommand", &mXTermCommand, CONF_DEFAULT_XTERMCOMMAND); | 43 | addItemString( "xtermCommand", &mXTermCommand, CONF_DEFAULT_XTERMCOMMAND); |
44 | addItemFont( "entryFont", &mEntryFont); | 44 | addItemFont( "entryFont", &mEntryFont); |
45 | addItemInt( "pwTimeout", &mPwTimeout, CONF_DEFAULT_PWTIMEOUT ); | 45 | addItemInt( "pwTimeout", &mPwTimeout, CONF_DEFAULT_PWTIMEOUT ); |
46 | addItemInt( "lockTimeout", &mLockTimeout, CONF_DEFAULT_LOCKTIMEOUT ); | 46 | addItemInt( "lockTimeout", &mLockTimeout, CONF_DEFAULT_LOCKTIMEOUT ); |
47 | addItemInt( "compression", &mCompression, CONF_DEFAULT_COMPRESSION ); | 47 | addItemInt( "compression", &mCompression, CONF_DEFAULT_COMPRESSION ); |
48 | addItemInt("cryptAlgo", &mCryptAlgo, CONF_DEFAULT_CRYPTALGO); | 48 | addItemInt("cryptAlgo", &mCryptAlgo, CONF_DEFAULT_CRYPTALGO); |
49 | addItemInt("hashAlgo", &mHashAlgo, CONF_DEFAULT_HASHALGO); | 49 | addItemInt("hashAlgo", &mHashAlgo, CONF_DEFAULT_HASHALGO); |
50 | addItemInt( "filePermissions", &mFilePermissions, CONF_DEFAULT_FILEPERMISSIONS ); | 50 | addItemInt( "filePermissions", &mFilePermissions, CONF_DEFAULT_FILEPERMISSIONS ); |
51 | addItemInt( "minimizeLock", &mMinimizeLock, CONF_DEFAULT_MINIMIZELOCK ); | 51 | addItemInt( "minimizeLock", &mMinimizeLock, CONF_DEFAULT_MINIMIZELOCK ); |
52 | addItemBool( "unlockOnOpen", &mUnlockOnOpen, CONF_DEFAULT_UNLOCKONOPEN ); | 52 | addItemBool( "unlockOnOpen", &mUnlockOnOpen, CONF_DEFAULT_UNLOCKONOPEN ); |
53 | addItemBool( "tray", &mTray, CONF_DEFAULT_TRAY ); | 53 | addItemBool( "tray", &mTray, CONF_DEFAULT_TRAY ); |
54 | addItemBool( "makeFileBackup", &mMakeFileBackup, CONF_DEFAULT_MAKEFILEBACKUP ); | 54 | addItemBool( "makeFileBackup", &mMakeFileBackup, CONF_DEFAULT_MAKEFILEBACKUP ); |
55 | addItemBool( "autostartDeepLocked", &mAutostartDeeplocked, CONF_DEFAULT_AUTOSTART_DEEPL ); | 55 | addItemBool( "autostartDeepLocked", &mAutostartDeeplocked, CONF_DEFAULT_AUTOSTART_DEEPL ); |
56 | addItemBool( "autoDeepLock", &mAutoDeeplock, CONF_DEFAULT_AUTODEEPLOCK ); | 56 | addItemBool( "autoDeepLock", &mAutoDeeplock, CONF_DEFAULT_AUTODEEPLOCK ); |
57 | addItemBool( "kwalletEmu", &mKWalletEmu, CONF_DEFAULT_KWALLETEMU ); | 57 | addItemBool( "kwalletEmu", &mKWalletEmu, CONF_DEFAULT_KWALLETEMU ); |
58 | addItemBool( "newEntrLockStat", &mNewEntrLockStat, CONF_DEFAULT_NEWENTRLOCKSTAT ); | 58 | addItemBool( "newEntrLockStat", &mNewEntrLockStat, CONF_DEFAULT_NEWENTRLOCKSTAT ); |
59 | 59 | ||
60 | KPrefs::setCurrentGroup( "Wnd" ); | 60 | KPrefs::setCurrentGroup( "Wnd" ); |
61 | 61 | ||
62 | addItemSize( "MainWndSize", &mMainWndSize); | 62 | addItemSize( "MainWndSize", &mMainWndSize); |
63 | addItemInt( "MainViewStyle", &mMainViewStyle, CONF_DEFAULT_MAINVIEWSTYLE ); | 63 | addItemInt( "MainViewStyle", &mMainViewStyle, CONF_DEFAULT_MAINVIEWSTYLE ); |
64 | addItemBool( "autoMinimizeOnStart", &mAutoMinimizeOnStart, CONF_DEFAULT_AUTOMINIMIZE ); | 64 | addItemBool( "autoMinimizeOnStart", &mAutoMinimizeOnStart, CONF_DEFAULT_AUTOMINIMIZE ); |
65 | addItemBool( "close", &mClose, CONF_DEFAULT_WNDCLOSE ); | 65 | addItemBool( "close", &mClose, CONF_DEFAULT_WNDCLOSE ); |
66 | addItemIntList( "commentSplitter", &mCommentSplitter ); | 66 | addItemIntList( "commentSplitter", &mCommentSplitter ); |
67 | addItemIntList( "categorySplitter", &mCategorySplitter ); | 67 | addItemIntList( "categorySplitter", &mCategorySplitter ); |
68 | } | 68 | } |
69 | 69 | ||
70 | PWMPrefs::~PWMPrefs() | 70 | PWMPrefs::~PWMPrefs() |
71 | { | 71 | { |
72 | if (sInstance == this) | ||
73 | sInstance = staticDeleterPP.setObject(0); | ||
74 | else | ||
75 | qDebug("Whats this? Error in PWMPrefs::~PWMPrefs()?"); | ||
72 | } | 76 | } |
73 | 77 | ||
74 | PWMPrefs *PWMPrefs::instance() | 78 | PWMPrefs *PWMPrefs::instance() |
75 | { | 79 | { |
76 | if ( !sInstance ) { | 80 | if ( !sInstance ) { |
77 | #ifdef PWM_EMBEDDED | 81 | #ifdef PWM_EMBEDDED |
78 | sInstance = staticDeleter.setObject( new PWMPrefs() ); | 82 | sInstance = staticDeleterPP.setObject( new PWMPrefs() ); |
79 | #else //PWM_EMBEDDED | 83 | #else //PWM_EMBEDDED |
80 | //US the following line has changed ???. Why | 84 | //US the following line has changed ???. Why |
81 | staticDeleter.setObject( sInstance, new PWMPrefs() ); | 85 | staticDeleterPP.setObject( sInstance, new PWMPrefs() ); |
82 | #endif //KAB_EMBEDDED | 86 | #endif //KAB_EMBEDDED |
83 | sInstance->readConfig(); | 87 | sInstance->readConfig(); |
84 | } | 88 | } |
85 | 89 | ||
86 | return sInstance; | 90 | return sInstance; |
87 | } | 91 | } |
88 | 92 | ||
89 | // US introduce a nonconst way to return the config object. | 93 | // US introduce a nonconst way to return the config object. |
90 | KConfig* PWMPrefs::getConfig() | 94 | KConfig* PWMPrefs::getConfig() |
91 | { | 95 | { |
92 | return config(); | 96 | return config(); |
93 | } | 97 | } |
94 | 98 | ||
95 | /******************************************************************* | 99 | /******************************************************************* |
96 | * functions for reading the configuration settings | 100 | * functions for reading the configuration settings |
97 | *******************************************************************/ | 101 | *******************************************************************/ |
98 | 102 | ||
99 | QString PWMPrefs::confGlobAutoStart() | 103 | QString PWMPrefs::confGlobAutoStart() |
100 | { | 104 | { |
101 | return mAutoStart; | 105 | return mAutoStart; |
102 | } | 106 | } |
103 | 107 | ||
104 | QString PWMPrefs::confGlobBrowserCommand() | 108 | QString PWMPrefs::confGlobBrowserCommand() |
105 | { | 109 | { |
106 | return mBrowserCommand; | 110 | return mBrowserCommand; |
107 | } | 111 | } |
108 | 112 | ||
109 | QString PWMPrefs::confGlobXtermCommand() | 113 | QString PWMPrefs::confGlobXtermCommand() |
110 | { | 114 | { |
111 | return mXTermCommand; | 115 | return mXTermCommand; |
112 | } | 116 | } |
113 | 117 | ||
114 | QFont PWMPrefs::confGlobEntryFont() | 118 | QFont PWMPrefs::confGlobEntryFont() |
115 | { | 119 | { |
116 | return mEntryFont; | 120 | return mEntryFont; |
117 | } | 121 | } |
118 | 122 | ||
119 | int PWMPrefs::confGlobPwTimeout() | 123 | int PWMPrefs::confGlobPwTimeout() |
120 | { | 124 | { |
121 | return mPwTimeout; | 125 | return mPwTimeout; |
122 | } | 126 | } |
123 | 127 | ||
124 | int PWMPrefs::confGlobLockTimeout() | 128 | int PWMPrefs::confGlobLockTimeout() |
125 | { | 129 | { |
126 | return mLockTimeout; | 130 | return mLockTimeout; |
127 | } | 131 | } |
128 | 132 | ||
129 | int PWMPrefs::confGlobCompression() | 133 | int PWMPrefs::confGlobCompression() |
130 | { | 134 | { |
131 | return mCompression; | 135 | return mCompression; |
132 | } | 136 | } |
133 | 137 | ||
134 | int PWMPrefs::confGlobFilePermissions() | 138 | int PWMPrefs::confGlobFilePermissions() |
135 | { | 139 | { |
136 | return mFilePermissions; | 140 | return mFilePermissions; |
137 | } | 141 | } |
138 | 142 | ||
139 | int PWMPrefs::confGlobMinimizeLock() | 143 | int PWMPrefs::confGlobMinimizeLock() |
140 | { | 144 | { |
141 | return mMinimizeLock; | 145 | return mMinimizeLock; |
142 | } | 146 | } |
143 | 147 | ||
144 | bool PWMPrefs::confGlobUnlockOnOpen() | 148 | bool PWMPrefs::confGlobUnlockOnOpen() |
145 | { | 149 | { |