summaryrefslogtreecommitdiff
authoreilers <eilers>2003-01-02 14:26:06 (UTC)
committer eilers <eilers>2003-01-02 14:26:06 (UTC)
commit12e9ed4ac80ac7fa042059b48d7447db0e59a86c (patch) (unidiff)
tree3165bc8422ca5560a30de2a7bf54c0a319516ce7
parent85a6acb57bb6a0b7c5340f3f3107c1b39884c023 (diff)
downloadopie-12e9ed4ac80ac7fa042059b48d7447db0e59a86c.zip
opie-12e9ed4ac80ac7fa042059b48d7447db0e59a86c.tar.gz
opie-12e9ed4ac80ac7fa042059b48d7447db0e59a86c.tar.bz2
Letterpicker now works for lowercase names..
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/TODO9
-rw-r--r--core/pim/addressbook/abview.cpp9
2 files changed, 13 insertions, 5 deletions
diff --git a/core/pim/addressbook/TODO b/core/pim/addressbook/TODO
index df55b2d..1eb537f 100644
--- a/core/pim/addressbook/TODO
+++ b/core/pim/addressbook/TODO
@@ -1,109 +1,110 @@
1Stuff todo until OPIE 1.0 : 1Stuff todo until OPIE 1.0 :
2=========================== 2===========================
3 3
4Feature requests: 4Feature requests:
5----------------- 5-----------------
6- Dial by mobile phone by tapping the number.. 6- Dial by mobile phone by tapping the number..
7 (Maybe using gsmtool. And we may 7 (Maybe using gsmtool. And we may
8 add a library class for this) 8 add a library class for this)
9- dial with dtmfdial incase it's installed and there's no mobile 9- dial with dtmfdial incase it's installed and there's no mobile
10- 3rd column for 2. Contact 10- 3rd column for 2. Contact
11- Implementing additional Views (Phonebook, ...) 11- Implementing additional Views (Phonebook, ...)
12- Birthday & Anniversary Reminder 12- Birthday & Anniversary Reminder
13- Plugin for Today for Birthdays and Anniversaries 13- Plugin for Today for Birthdays and Anniversaries
14- Beaming of multiple contacts (current list/ by search or by category) 14- Beaming of multiple contacts (current list/ by search or by category)
15 15
16Known Bugs: 16Known Bugs:
17----------- 17-----------
18- Language not English (tested with german opie-translation):
19 1. Configure nicht übersetzt (alles leer).
20 2. Contacteditor nur teilweise übersetzt.
21 3. Kategorie-Picker geht nicht.
22 18
23 19
24Bugs but not in addressbook: 20Bugs but not in addressbook:
25----------------------------- 21-----------------------------
26- VCARD: If umlaut (äöüß) in address, the parser gets confused.. 22- VCARD: If umlaut (äöüß) in address, the parser gets confused..
27 23
28- Exporting and reimporting of Jobtitle was reported to fail (Could not reproduce this ! (se)) 24- Exporting and reimporting of Jobtitle was reported to fail (Could not reproduce this ! (se))
29 25
30 26
31Urgent: 27Urgent:
32-------- 28--------
33ContactEditor: 29ContactEditor:
34- Contact-Editor is temporarely reenabled. Wait for replacement. 30- Contact-Editor is temporarely reenabled. Wait for replacement.
35- Redesign of Contacteditor 31- Redesign of Contacteditor
36- Store last settings of combo-boxes 32- Store last settings of combo-boxes
37- Category is on the wrong position after changing to personal and back to normal 33- Category is on the wrong position after changing to personal and back to normal
38 ( Temporarily workaround: Category is never deactivated.. :S ) 34 ( Temporarily workaround: Category is never deactivated.. :S )
35
39- Personal and Business Web-page is not editable 36- Personal and Business Web-page is not editable
40 37
41Important: 38Important:
42---------- 39----------
43 40
44- Implement a picker/combo for the default email. 41- Implement a picker/combo for the default email.
45- After search (Started with Return): KeyFocus should be on Tabelle 42- After search (Started with Return): KeyFocus should be on Tabelle
46 43
47- "What's this" should be added (Deleyed after Feature Freeze) 44- "What's this" should be added (Deleyed after Feature Freeze)
48 45
49Less important: 46Less important:
50--------------- 47---------------
51- Reload if contacts were changed externally 48- Reload if contacts were changed externally
52- Overview window cleanup needed.. 49- Overview window cleanup needed..
53- The picker (alphabetical sort widget) should be 50- The picker (alphabetical sort widget) should be
54 placed verticaly or horizontally (configurable) 51 placed verticaly or horizontally (configurable)
55- Find a smart solution for activating/deactivating the "send email" event 52- Find a smart solution for activating/deactivating the "send email" event
56 53
57Should be Fixed (not absolute sure, need further validation): 54Should be Fixed (not absolute sure, need further validation):
58------------------------------------------------------------- 55-------------------------------------------------------------
59 56
60 57
61Fixed: 58Fixed:
62------- 59-------
63- Syncing: abtable not reloaded after sync. 60- Syncing: abtable not reloaded after sync.
64- Find widget should be replaced by something like 61- Find widget should be replaced by something like
65 qpdf has. 62 qpdf has.
66- Adding a configuration dialog 63- Adding a configuration dialog
67- Picker: Activated letter schould be more visible 64- Picker: Activated letter schould be more visible
68- Advanced handling of cursor keys (search..) 65- Advanced handling of cursor keys (search..)
69- Mail-Icon is missing 66- Mail-Icon is missing
70- Use opie-mail insted of qt-mail if possible. 67- Use opie-mail insted of qt-mail if possible.
71- Font menu is invisible using german translation 68- Font menu is invisible using german translation
72- Personal contact editor: Disable categories 69- Personal contact editor: Disable categories
73- "Nonenglish" translation bug has to be fixed. 70- "Nonenglish" translation bug has to be fixed.
74- contacteditor: Birthday, annyversary, ... : Use Dateselector 71- contacteditor: Birthday, annyversary, ... : Use Dateselector
75- The names of the countries are sorted by there english names, only.. 72- The names of the countries are sorted by there english names, only..
76 Even if they are translated.. :S 73 Even if they are translated.. :S
77- Cursor keys should work in detail-view (ablabel) 74- Cursor keys should work in detail-view (ablabel)
78 -> Ablabel should be removed and Abtable should be increased with 75 -> Ablabel should be removed and Abtable should be increased with
79 different views (as started by darwin zins).. 76 different views (as started by darwin zins)..
80- Use advanced database functions in abtable to decrease 77- Use advanced database functions in abtable to decrease
81 memory footprint and to make everything more easy ! 78 memory footprint and to make everything more easy !
82 (abtable should store Iterator for selected Category) 79 (abtable should store Iterator for selected Category)
83- Abtable: Configure Contact column (internally already available, 80- Abtable: Configure Contact column (internally already available,
84 need configuration) 81 need configuration)
85- Select of primary contact (see #274 on mantis) 82- Select of primary contact (see #274 on mantis)
86- Category-select does not work completely: "Unfiled" is always in listview .. 83- Category-select does not work completely: "Unfiled" is always in listview ..
87- Return from Contacteditor: Category resettet to all 84- Return from Contacteditor: Category resettet to all
88- Personal Details not working 85- Personal Details not working
89- If category changed, the letterpicker should be resetted 86- If category changed, the letterpicker should be resetted
90- There should be some icons for List and Cardview 87- There should be some icons for List and Cardview
91- If in Cardview and a category change removes all entries: 88- If in Cardview and a category change removes all entries:
92 There are already entries in Cardview after up/down 89 There are already entries in Cardview after up/down
93- Personal Details: Anniversary zeigt Fantasie-Werte 90- Personal Details: Anniversary zeigt Fantasie-Werte
94- Unfiled shown just in Category "All" and "Unfiled". 91- Unfiled shown just in Category "All" and "Unfiled".
95- After finising search and after Edit: Clear Picker 92- After finising search and after Edit: Clear Picker
96- After Edit: Table position back to edited entry. 93- After Edit: Table position back to edited entry.
97- Optimize Table Update... 94- Optimize Table Update...
98- Change MyDialog to Config 95- Change MyDialog to Config
99- Store position and state of toolbar 96- Store position and state of toolbar
100- Searchwidget closed: Selected user is jumping 97- Searchwidget closed: Selected user is jumping
101- Wenn suchen beendet, dann dauert das Tabellenupdate (was überhaupt überflüssig ist) 98- Wenn suchen beendet, dann dauert das Tabellenupdate (was überhaupt überflüssig ist)
102 zu lange.. 99 zu lange..
103- VCARD: Import of Anniversary does not work correctly (currently disabled) 100- VCARD: Import of Anniversary does not work correctly (currently disabled)
104- Name order selected in "contacteditor" not used in list view. 101- Name order selected in "contacteditor" not used in list view.
105- OK-Key does not switch from Detailview (ablable) to Listview 102- OK-Key does not switch from Detailview (ablable) to Listview
106- Receiving of beams should open a dialog 103- Receiving of beams should open a dialog
107- Fix start of opie-mail 104- Fix start of opie-mail
108- Implement Button Pics 105- Implement Button Pics
109- Add a dialog to accept and optionally edit received contacts by IRDA. 106- Add a dialog to accept and optionally edit received contacts by IRDA.
107- Language not English (tested with german opie-translation):
108 1. Configure nicht übersetzt (alles leer).
109 2. Contacteditor nur teilweise übersetzt.
110 3. Kategorie-Picker geht nicht.
diff --git a/core/pim/addressbook/abview.cpp b/core/pim/addressbook/abview.cpp
index 161b163..93e57ca 100644
--- a/core/pim/addressbook/abview.cpp
+++ b/core/pim/addressbook/abview.cpp
@@ -108,170 +108,177 @@ void AbView::addEntry( const OContact &newContact )
108 108
109} 109}
110void AbView::removeEntry( const int UID ) 110void AbView::removeEntry( const int UID )
111{ 111{
112 qWarning("abview:RemoveContact"); 112 qWarning("abview:RemoveContact");
113 m_contactdb->remove( UID ); 113 m_contactdb->remove( UID );
114 load(); 114 load();
115} 115}
116 116
117void AbView::replaceEntry( const OContact &contact ) 117void AbView::replaceEntry( const OContact &contact )
118{ 118{
119 qWarning("abview:ReplaceContact"); 119 qWarning("abview:ReplaceContact");
120 m_contactdb->replace( contact ); 120 m_contactdb->replace( contact );
121 load(); 121 load();
122 122
123} 123}
124 124
125OContact AbView::currentEntry() 125OContact AbView::currentEntry()
126{ 126{
127 OContact currentContact; 127 OContact currentContact;
128 128
129 switch ( (int) m_curr_View ) { 129 switch ( (int) m_curr_View ) {
130 case TableView: 130 case TableView:
131 currentContact = m_abTable -> currentEntry(); 131 currentContact = m_abTable -> currentEntry();
132 break; 132 break;
133 case CardView: 133 case CardView:
134 currentContact = m_ablabel -> currentEntry(); 134 currentContact = m_ablabel -> currentEntry();
135 break; 135 break;
136 } 136 }
137 m_curr_Contact = currentContact.uid(); 137 m_curr_Contact = currentContact.uid();
138 return currentContact; 138 return currentContact;
139} 139}
140 140
141bool AbView::save() 141bool AbView::save()
142{ 142{
143 qWarning("abView:Save data"); 143 qWarning("abView:Save data");
144 144
145 return m_contactdb->save(); 145 return m_contactdb->save();
146} 146}
147 147
148void AbView::load() 148void AbView::load()
149{ 149{
150 qWarning("abView:Load data"); 150 qWarning("abView:Load data");
151 151
152 // Letter Search is stopped at this place 152 // Letter Search is stopped at this place
153 emit signalClearLetterPicker(); 153 emit signalClearLetterPicker();
154 154
155 if ( m_inPersonal ) 155 if ( m_inPersonal )
156 // VCard Backend does not sort..
156 m_list = m_contactdb->allRecords(); 157 m_list = m_contactdb->allRecords();
157 else{ 158 else{
158 m_list = m_contactdb->sorted( true, 0, 0, 0 ); 159 m_list = m_contactdb->sorted( true, 0, 0, 0 );
159 clearForCategory(); 160 clearForCategory();
160 } 161 }
161 162
162 qWarning ("Number of contacts: %d", m_list.count()); 163 qWarning ("Number of contacts: %d", m_list.count());
163 164
164 updateView( true ); 165 updateView( true );
165 166
166} 167}
167 168
168void AbView::reload() 169void AbView::reload()
169{ 170{
170 qWarning( "void AbView::reload()" ); 171 qWarning( "void AbView::reload()" );
171 172
172 m_contactdb->reload(); 173 m_contactdb->reload();
173 load(); 174 load();
174} 175}
175 176
176void AbView::clear() 177void AbView::clear()
177{ 178{
178 // :SX 179 // :SX
179} 180}
180 181
181void AbView::setShowByCategory( const QString& cat ) 182void AbView::setShowByCategory( const QString& cat )
182{ 183{
183 qWarning("AbView::setShowCategory( const QString& cat )"); 184 qWarning("AbView::setShowCategory( const QString& cat )");
184 185
185 int intCat = 0; 186 int intCat = 0;
186 187
187 // All (cat == NULL) will be stored as -1 188 // All (cat == NULL) will be stored as -1
188 if ( cat.isNull() ) 189 if ( cat.isNull() )
189 intCat = -1; 190 intCat = -1;
190 else 191 else
191 intCat = mCat.id("Contacts", cat ); 192 intCat = mCat.id("Contacts", cat );
192 193
193 // Just do anything if we really change the category 194 // Just do anything if we really change the category
194 if ( intCat != m_curr_category ){ 195 if ( intCat != m_curr_category ){
195 qWarning ("Categories: Selected %s.. Number: %d", cat.latin1(), m_curr_category); 196 qWarning ("Categories: Selected %s.. Number: %d", cat.latin1(), m_curr_category);
196 197
197 m_curr_category = intCat; 198 m_curr_category = intCat;
198 emit signalClearLetterPicker(); 199 emit signalClearLetterPicker();
199 200
200 load(); 201 load();
201 } 202 }
202 203
203} 204}
204 205
205void AbView::setShowToView( Views view ) 206void AbView::setShowToView( Views view )
206{ 207{
207 qWarning("void AbView::setShowToView( View %d )", view); 208 qWarning("void AbView::setShowToView( View %d )", view);
208 209
209 qWarning ("Change the View (Category is: %d)", m_curr_category); 210 qWarning ("Change the View (Category is: %d)", m_curr_category);
210 211
211 if ( m_curr_View != view ){ 212 if ( m_curr_View != view ){
212 m_prev_View = m_curr_View; 213 m_prev_View = m_curr_View;
213 m_curr_View = view; 214 m_curr_View = view;
214 215
215 updateView(); 216 updateView();
216 } 217 }
217 218
218} 219}
219 220
220void AbView::setShowByLetter( char c ) 221void AbView::setShowByLetter( char c )
221{ 222{
222 qWarning("void AbView::setShowByLetter( %c )", c ); 223 qWarning("void AbView::setShowByLetter( %c )", c );
223 OContact query; 224 OContact query;
224 if ( c == 0 ){ 225 if ( c == 0 ){
225 load(); 226 load();
226 return; 227 return;
227 }else{ 228 }else{
229 // If the current Backend is unable to solve the query, we will
230 // ignore the request ..
231 if ( ! m_contactdb->hasQuerySettings( OContactAccess::WildCards | OContactAccess::IgnoreCase ) ){
232 return;
233 }
234
228 query.setLastName( QString("%1*").arg(c) ); 235 query.setLastName( QString("%1*").arg(c) );
229 m_list = m_contactdb->queryByExample( query, OContactAccess::WildCards ); 236 m_list = m_contactdb->queryByExample( query, OContactAccess::WildCards | OContactAccess::IgnoreCase );
230 clearForCategory(); 237 clearForCategory();
231 m_curr_Contact = 0; 238 m_curr_Contact = 0;
232 } 239 }
233 updateView( true ); 240 updateView( true );
234} 241}
235 242
236void AbView::setListOrder( const QValueList<int>& ordered ) 243void AbView::setListOrder( const QValueList<int>& ordered )
237{ 244{
238 m_orderedFields = ordered; 245 m_orderedFields = ordered;
239 updateView(); 246 updateView();
240} 247}
241 248
242 249
243QString AbView::showCategory() const 250QString AbView::showCategory() const
244{ 251{
245 return mCat.label( "Contacts", m_curr_category ); 252 return mCat.label( "Contacts", m_curr_category );
246} 253}
247 254
248void AbView::showPersonal( bool personal ) 255void AbView::showPersonal( bool personal )
249{ 256{
250 qWarning ("void AbView::showPersonal( %d )", personal); 257 qWarning ("void AbView::showPersonal( %d )", personal);
251 258
252 if ( personal ){ 259 if ( personal ){
253 260
254 if ( m_inPersonal ) 261 if ( m_inPersonal )
255 return; 262 return;
256 263
257 // Now switch to vCard Backend and load data. 264 // Now switch to vCard Backend and load data.
258 // The current default backend will be stored 265 // The current default backend will be stored
259 // to avoid unneeded load/stores. 266 // to avoid unneeded load/stores.
260 m_storedDB = m_contactdb; 267 m_storedDB = m_contactdb;
261 268
262 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null, 269 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null,
263 addressbookPersonalVCardName() ); 270 addressbookPersonalVCardName() );
264 m_contactdb = new OContactAccess ( "addressbook", QString::null , vcard_backend, true ); 271 m_contactdb = new OContactAccess ( "addressbook", QString::null , vcard_backend, true );
265 272
266 m_inPersonal = true; 273 m_inPersonal = true;
267 m_curr_View = CardView; 274 m_curr_View = CardView;
268 275
269 }else{ 276 }else{
270 277
271 if ( !m_inPersonal ) 278 if ( !m_inPersonal )
272 return; 279 return;
273 280
274 // Remove vCard Backend and restore default 281 // Remove vCard Backend and restore default
275 m_contactdb->save(); 282 m_contactdb->save();
276 delete m_contactdb; 283 delete m_contactdb;
277 284