-rw-r--r-- | core/pim/addressbook/TODO | 9 | ||||
-rw-r--r-- | core/pim/addressbook/abview.cpp | 9 |
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 @@ | |||
1 | Stuff todo until OPIE 1.0 : | 1 | Stuff todo until OPIE 1.0 : |
2 | =========================== | 2 | =========================== |
3 | 3 | ||
4 | Feature requests: | 4 | Feature 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 | ||
16 | Known Bugs: | 16 | Known 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 | ||
24 | Bugs but not in addressbook: | 20 | Bugs 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 | ||
31 | Urgent: | 27 | Urgent: |
32 | -------- | 28 | -------- |
33 | ContactEditor: | 29 | ContactEditor: |
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 | ||
41 | Important: | 38 | Important: |
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 | ||
49 | Less important: | 46 | Less 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 | ||
57 | Should be Fixed (not absolute sure, need further validation): | 54 | Should be Fixed (not absolute sure, need further validation): |
58 | ------------------------------------------------------------- | 55 | ------------------------------------------------------------- |
59 | 56 | ||
60 | 57 | ||
61 | Fixed: | 58 | Fixed: |
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 | } |
110 | void AbView::removeEntry( const int UID ) | 110 | void 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 | ||
117 | void AbView::replaceEntry( const OContact &contact ) | 117 | void 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 | ||
125 | OContact AbView::currentEntry() | 125 | OContact 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 | ||
141 | bool AbView::save() | 141 | bool 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 | ||
148 | void AbView::load() | 148 | void 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 | ||
168 | void AbView::reload() | 169 | void 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 | ||
176 | void AbView::clear() | 177 | void AbView::clear() |
177 | { | 178 | { |
178 | // :SX | 179 | // :SX |
179 | } | 180 | } |
180 | 181 | ||
181 | void AbView::setShowByCategory( const QString& cat ) | 182 | void 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 | ||
205 | void AbView::setShowToView( Views view ) | 206 | void 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 | ||
220 | void AbView::setShowByLetter( char c ) | 221 | void 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 | ||
236 | void AbView::setListOrder( const QValueList<int>& ordered ) | 243 | void 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 | ||
243 | QString AbView::showCategory() const | 250 | QString 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 | ||
248 | void AbView::showPersonal( bool personal ) | 255 | void 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 | ||