summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/okeyfilter.cpp8
-rw-r--r--libopie2/opieui/big-screen/omodalhelper.h2
-rw-r--r--libopie2/opieui/otabinfo.h5
3 files changed, 5 insertions, 10 deletions
diff --git a/libopie2/opiecore/okeyfilter.cpp b/libopie2/opiecore/okeyfilter.cpp
index a517333..61b7909 100644
--- a/libopie2/opiecore/okeyfilter.cpp
+++ b/libopie2/opiecore/okeyfilter.cpp
@@ -1,148 +1,148 @@
1/* 1/*
2 This file is part of the Opie Project 2 This file is part of the Opie Project
3 =. Copyright (C) 2004 Rajko 'Alwin' Albrecht <alwin@handhelds.org> 3 =. Copyright (C) 2004 Rajko 'Alwin' Albrecht <alwin@handhelds.org>
4 .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org> 4 .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .>+-= 5 .>+-=
6_;:, .> :=|. This program is free software; you can 6_;:, .> :=|. This program is free software; you can
7.> <`_, > . <= redistribute it and/or modify it under 7.> <`_, > . <= redistribute it and/or modify it under
8:`=1 )Y*s>-.-- : the terms of the GNU Library General Public 8:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
9.="- .-=="i, .._ License as published by the Free Software 9.="- .-=="i, .._ License as published by the Free Software
10- . .-<_> .<> Foundation; either version 2 of the License, 10- . .-<_> .<> Foundation; either version 2 of the License,
11 ._= =} : or (at your option) any later version. 11 ._= =} : or (at your option) any later version.
12 .%`+i> _;_. 12 .%`+i> _;_.
13 .i_,=:_. -<s. This program is distributed in the hope that 13 .i_,=:_. -<s. This program is distributed in the hope that
14 + . -:. = it will be useful, but WITHOUT ANY WARRANTY; 14 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
15 : .. .:, . . . without even the implied warranty of 15 : .. .:, . . . without even the implied warranty of
16 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A 16 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
17 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU 17 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
18..}^=.= = ; Library General Public License for more 18..}^=.= = ; Library General Public License for more
19++= -. .` .: details. 19++= -. .` .: details.
20: = ...= . :.=- 20: = ...= . :.=-
21-. .:....=;==+<; You should have received a copy of the GNU 21-. .:....=;==+<; You should have received a copy of the GNU
22 -_. . . )=. = Library General Public License along with 22 -_. . . )=. = Library General Public License along with
23 -- :-=` this library; see the file COPYING.LIB. 23 -- :-=` this library; see the file COPYING.LIB.
24 If not, write to the Free Software Foundation, 24 If not, write to the Free Software Foundation,
25 Inc., 59 Temple Place - Suite 330, 25 Inc., 59 Temple Place - Suite 330,
26 Boston, MA 02111-1307, USA. 26 Boston, MA 02111-1307, USA.
27*/ 27*/
28 28
29#include "okeyfilter.h" 29#include "okeyfilter.h"
30#include "device/odevice.h" 30#include "device/odevice.h"
31#include "odebug.h" 31#include "odebug.h"
32 32
33namespace Opie { 33namespace Opie {
34namespace Core { 34namespace Core {
35 35
36class OKeyFilterPrivate:public OKeyFilter, QWSServer::KeyboardFilter 36class OKeyFilterPrivate:public OKeyFilter, QWSServer::KeyboardFilter
37{ 37{
38 static QValueList<QWSServer::KeyboardFilter*> filterList; 38 static QValueList<QWSServer::KeyboardFilter*> filterList;
39 static QValueList<QWSServer::KeyboardFilter*> preFilterList; 39 static QValueList<QWSServer::KeyboardFilter*> preFilterList;
40protected: 40protected:
41 OKeyFilterPrivate(const OKeyFilterPrivate&):OKeyFilter(),QWSServer::KeyboardFilter(){}; 41 OKeyFilterPrivate(const OKeyFilterPrivate&):OKeyFilter(),QWSServer::KeyboardFilter(){};
42 virtual void addPreHandler(QWSServer::KeyboardFilter*); 42 virtual void addPreHandler(QWSServer::KeyboardFilter* aFilter);
43 virtual void remPreHandler(QWSServer::KeyboardFilter*); 43 virtual void remPreHandler(QWSServer::KeyboardFilter* aFilter);
44 44
45public: 45public:
46 OKeyFilterPrivate(); 46 OKeyFilterPrivate();
47 virtual ~OKeyFilterPrivate(); 47 virtual ~OKeyFilterPrivate();
48 virtual bool filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ); 48 virtual bool filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat );
49 virtual void addHandler(QWSServer::KeyboardFilter*); 49 virtual void addHandler(QWSServer::KeyboardFilter* aFilter);
50 virtual void remHandler(QWSServer::KeyboardFilter*); 50 virtual void remHandler(QWSServer::KeyboardFilter* aFilter);
51}; 51};
52 52
53QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::filterList; 53QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::filterList;
54QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::preFilterList; 54QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::preFilterList;
55 55
56OKeyFilter::OKeyFilter() 56OKeyFilter::OKeyFilter()
57{ 57{
58} 58}
59 59
60OKeyFilter::~OKeyFilter() 60OKeyFilter::~OKeyFilter()
61{ 61{
62} 62}
63 63
64OKeyFilter* OKeyFilter::inst() 64OKeyFilter* OKeyFilter::inst()
65{ 65{
66 static OKeyFilter*ofilter = 0; 66 static OKeyFilter*ofilter = 0;
67 if (!ofilter) { 67 if (!ofilter) {
68 ofilter = new OKeyFilterPrivate; 68 ofilter = new OKeyFilterPrivate;
69 } 69 }
70 return ofilter; 70 return ofilter;
71} 71}
72 72
73bool OKeyFilterPrivate::filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat ) 73bool OKeyFilterPrivate::filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat )
74{ 74{
75 QValueList<QWSServer::KeyboardFilter*>::Iterator iter; 75 QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
76 for (iter=preFilterList.begin();iter!=preFilterList.end();++iter) { 76 for (iter=preFilterList.begin();iter!=preFilterList.end();++iter) {
77 if ((*iter)->filter(unicode,keycode,modifiers,isPress,autoRepeat)) { 77 if ((*iter)->filter(unicode,keycode,modifiers,isPress,autoRepeat)) {
78 return true; 78 return true;
79 } 79 }
80 } 80 }
81 for (iter=filterList.begin();iter!=filterList.end();++iter) { 81 for (iter=filterList.begin();iter!=filterList.end();++iter) {
82 if ((*iter)->filter(unicode,keycode,modifiers,isPress,autoRepeat)) { 82 if ((*iter)->filter(unicode,keycode,modifiers,isPress,autoRepeat)) {
83 return true; 83 return true;
84 } 84 }
85 } 85 }
86 return false; 86 return false;
87} 87}
88 88
89void OKeyFilterPrivate::addHandler(QWSServer::KeyboardFilter*aF) 89void OKeyFilterPrivate::addHandler(QWSServer::KeyboardFilter*aF)
90{ 90{
91 if (!aF) return; 91 if (!aF) return;
92 if (filterList.find(aF)!=filterList.end()) { 92 if (filterList.find(aF)!=filterList.end()) {
93 return; 93 return;
94 } 94 }
95 odebug << "adding a keyboard filter handler"<<oendl; 95 odebug << "adding a keyboard filter handler"<<oendl;
96 filterList.append(aF); 96 filterList.append(aF);
97} 97}
98 98
99void OKeyFilterPrivate::remHandler(QWSServer::KeyboardFilter*aF) 99void OKeyFilterPrivate::remHandler(QWSServer::KeyboardFilter*aF)
100{ 100{
101 if (!aF) return; 101 if (!aF) return;
102 QValueList<QWSServer::KeyboardFilter*>::Iterator iter; 102 QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
103 if ( (iter=filterList.find(aF))==filterList.end() ) { 103 if ( (iter=filterList.find(aF))==filterList.end() ) {
104 return; 104 return;
105 } 105 }
106 odebug << "removing a keyboard filter handler"<<oendl; 106 odebug << "removing a keyboard filter handler"<<oendl;
107 filterList.remove(iter); 107 filterList.remove(iter);
108} 108}
109 109
110void OKeyFilterPrivate::addPreHandler(QWSServer::KeyboardFilter*aF) 110void OKeyFilterPrivate::addPreHandler(QWSServer::KeyboardFilter*aF)
111{ 111{
112 if (!aF) return; 112 if (!aF) return;
113 if (preFilterList.find(aF)!=preFilterList.end()) { 113 if (preFilterList.find(aF)!=preFilterList.end()) {
114 return; 114 return;
115 } 115 }
116 odebug << "adding a preferred keyboard filter handler"<<oendl; 116 odebug << "adding a preferred keyboard filter handler"<<oendl;
117 preFilterList.append(aF); 117 preFilterList.append(aF);
118} 118}
119 119
120void OKeyFilterPrivate::remPreHandler(QWSServer::KeyboardFilter*aF) 120void OKeyFilterPrivate::remPreHandler(QWSServer::KeyboardFilter*aF)
121{ 121{
122 if (!aF) return; 122 if (!aF) return;
123 QValueList<QWSServer::KeyboardFilter*>::Iterator iter; 123 QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
124 if ( (iter=preFilterList.find(aF))==preFilterList.end() ) { 124 if ( (iter=preFilterList.find(aF))==preFilterList.end() ) {
125 return; 125 return;
126 } 126 }
127 odebug << "removing a preferred keyboard filter handler"<<oendl; 127 odebug << "removing a preferred keyboard filter handler"<<oendl;
128 preFilterList.remove(iter); 128 preFilterList.remove(iter);
129} 129}
130 130
131OKeyFilterPrivate::OKeyFilterPrivate() 131OKeyFilterPrivate::OKeyFilterPrivate()
132 :OKeyFilter(),QWSServer::KeyboardFilter() 132 :OKeyFilter(),QWSServer::KeyboardFilter()
133{ 133{
134 filterList.clear(); 134 filterList.clear();
135 preFilterList.clear(); 135 preFilterList.clear();
136 if ( isQWS( ) ) { 136 if ( isQWS( ) ) {
137 QWSServer::setKeyboardFilter ( this ); 137 QWSServer::setKeyboardFilter ( this );
138 } 138 }
139} 139}
140 140
141OKeyFilterPrivate::~OKeyFilterPrivate() 141OKeyFilterPrivate::~OKeyFilterPrivate()
142{ 142{
143} 143}
144 144
145/* namespace Core */ 145/* namespace Core */
146} 146}
147/* namespace Opie */ 147/* namespace Opie */
148} 148}
diff --git a/libopie2/opieui/big-screen/omodalhelper.h b/libopie2/opieui/big-screen/omodalhelper.h
index 096cec4..ed6fee3 100644
--- a/libopie2/opieui/big-screen/omodalhelper.h
+++ b/libopie2/opieui/big-screen/omodalhelper.h
@@ -47,385 +47,385 @@ class OModalHelperControler;
47class OModalHelperSignal; 47class OModalHelperSignal;
48 48
49struct OModalHelperBase 49struct OModalHelperBase
50{ 50{
51 virtual void done( int status, TransactionID ) = 0; 51 virtual void done( int status, TransactionID ) = 0;
52 virtual void next( TransactionID ) = 0; 52 virtual void next( TransactionID ) = 0;
53 virtual void prev( TransactionID ) = 0; 53 virtual void prev( TransactionID ) = 0;
54}; 54};
55 55
56/** 56/**
57 * Modality sucks! ;) But it is easy to work with 57 * Modality sucks! ;) But it is easy to work with
58 * do exec() on a dialog and you know everything is funky. 58 * do exec() on a dialog and you know everything is funky.
59 * You only need to have one Dialog loaded and so on. 59 * You only need to have one Dialog loaded and so on.
60 * This class helps you to work like with modality and help 60 * This class helps you to work like with modality and help
61 * you to keep things in sync 61 * you to keep things in sync
62 * It's a template class but it sends signals once one Item is ready 62 * It's a template class but it sends signals once one Item is ready
63 * the signals contains the status and id of the item and then you 63 * the signals contains the status and id of the item and then you
64 * need fetch it. 64 * need fetch it.
65 * Handled Records will stay available until the first call to retrieve 65 * Handled Records will stay available until the first call to retrieve
66 * either the record via the TransactionID or via the QValueList<Record>. Note 66 * either the record via the TransactionID or via the QValueList<Record>. Note
67 * that most functions do not take handled records into account. 67 * that most functions do not take handled records into account.
68 * Also if you edit an record external you can tell this class and it'll 68 * Also if you edit an record external you can tell this class and it'll
69 * call the merge() function of your widget to maybe merge in these changes. 69 * call the merge() function of your widget to maybe merge in these changes.
70 * It also supports multiple modes. Either it can create new dialogs 70 * It also supports multiple modes. Either it can create new dialogs
71 * for each item or it can queue them depending on your usage. But it is 71 * for each item or it can queue them depending on your usage. But it is
72 * so smart that if only one item is shown that the queue bar is not shown 72 * so smart that if only one item is shown that the queue bar is not shown
73 * See the example for simple usage. 73 * See the example for simple usage.
74 * 74 *
75 * @short helps to life without modaility 75 * @short helps to life without modaility
76 * @author hOlgAr 76 * @author hOlgAr
77 * @version 0.01 77 * @version 0.01
78 */ 78 */
79template<class Dialog, class Record, typename Id = int> 79template<class Dialog, class Record, typename Id = int>
80class OModalHelper : private OModalHelperBase 80class OModalHelper : private OModalHelperBase
81{ 81{
82 friend class OModalHelperSignal; 82 friend class OModalHelperSignal;
83 friend class OModalHelperControler; 83 friend class OModalHelperControler;
84public: 84public:
85 typedef QValueList<Record> RecordList; 85 typedef QValueList<Record> RecordList;
86 typedef QMap<Id, Record> IdMap; 86 typedef QMap<Id, Record> IdMap;
87 typedef QMap<TransactionID, Id> TransactionMap; 87 typedef QMap<TransactionID, Id> TransactionMap;
88 typedef QMap<QDialog*, TransactionID> DialogMap 88 typedef QMap<QDialog*, TransactionID> DialogMap
89 enum Mode { Queue, New }; 89 enum Mode { Queue, New };
90 OModalHelper(enum Mode mode, QObject* parnet ); 90 OModalHelper(enum Mode mode, QObject* parnet );
91 91
92 bool handles( Id id)const; 92 bool handles( Id id)const;
93 TransactionID transactionID( Id id)const; 93 TransactionID transactionID( Id id)const;
94 94
95 void suspend( bool = true ); 95 void suspend( bool = true );
96 96
97 void cancel(); 97 void cancel();
98 void cancel( TransactionID ); 98 void cancel( TransactionID );
99 99
100 void connectDone( QObject* rec, const char* slot ); 100 void connectDone( QObject* rec, const char* slot );
101 void connectAccepted( QObject* rec, const char* slot ); 101 void connectAccepted( QObject* rec, const char* slot );
102 void connectRejected( QObject* rec, const char* slot ); 102 void connectRejected( QObject* rec, const char* slot );
103 103
104 TransactionID handle( Id id, const Record& rec = Record() ); 104 TransactionID handle( Id id, const Record& rec = Record() );
105 105
106 void edited( Id, int what, const QVariant& data ); 106 void edited( Id, int what, const QVariant& data );
107 107
108 Record record( TransactionID )const; 108 Record record( TransactionID )const;
109 RecordList recordsDone()const; 109 RecordList recordsDone()const;
110private: 110private:
111 virtual void done( int, TransactionID ); 111 virtual void done( int, TransactionID );
112 virtual void next( TransactionID ); 112 virtual void next( TransactionID );
113 virtual void prev( TransactionID ); 113 virtual void prev( TransactionID );
114 114
115 Record nextRecord( TransactionID &, int & )const; 115 Record nextRecord( TransactionID &, int & )const;
116 Record prevRecord( TransactionID &, int & )const; 116 Record prevRecord( TransactionID &, int & )const;
117 int pos( TransactionID )const; 117 int pos( TransactionID )const;
118 Dialog* newDialogRecord( const Record& ); 118 Dialog* newDialogRecord( const Record& );
119 119
120private: 120private:
121 OModalHelperDialog *queuedDialog()const; // generate or recycle 121 OModalHelperDialog *queuedDialog()const; // generate or recycle
122 OModalHelperDialog *m_dialog; 122 OModalHelperDialog *m_dialog;
123 OModalHelperSignal *m_signal; // our signal 123 OModalHelperSignal *m_signal; // our signal
124 OModalHelperControler *m_controler; 124 OModalHelperControler *m_controler;
125 IdMap m_ids; // maps ids (uids) to a record 125 IdMap m_ids; // maps ids (uids) to a record
126 IdMap m_doneIds; 126 IdMap m_doneIds;
127 TransactionMap m_transactions; // activate transactions 127 TransactionMap m_transactions; // activate transactions
128 TransactionMap m_done; // done and waiting for getting picked 128 TransactionMap m_done; // done and waiting for getting picked
129 DialogMap m_editing; // only used for New Mode 129 DialogMap m_editing; // only used for New Mode
130 enum Mode m_mode; // the mode we're in 130 enum Mode m_mode; // the mode we're in
131bool m_disabled :1; 131bool m_disabled :1;
132}; 132};
133 133
134 134
135 135
136/* ### FIXME use namespace with Qt3 */ 136/* ### FIXME use namespace with Qt3 */
137 137
138/* 138/*
139 * A note on flow. The Signal is used for QT Signals when 139 * A note on flow. The Signal is used for QT Signals when
140 * a record is done. 140 * a record is done.
141 * There is either one controler and this controler slot will 141 * There is either one controler and this controler slot will
142 * be connected to a dialog signal. 142 * be connected to a dialog signal.
143 * In Queue we get the next and prev signals and call the Helper. 143 * In Queue we get the next and prev signals and call the Helper.
144 * this then changes the Record of the dialog and sets the transactionId 144 * this then changes the Record of the dialog and sets the transactionId
145 * of the controler. 145 * of the controler.
146 * For the new mode 146 * For the new mode
147 * 147 *
148 */ 148 */
149 149
150class OModalHelperSignal : public QObject 150class OModalHelperSignal : public QObject
151{ 151{
152 Q_OBJECT 152 Q_OBJECT
153public: 153public:
154 OModalHelperSignal(OModalHelperBase* base, QObject* parent); 154 OModalHelperSignal(OModalHelperBase* base, QObject* parent);
155 ~OModalHelperSignal(); 155 ~OModalHelperSignal();
156 156
157signals: 157signals:
158 done( int status, TransactionID transaction ); 158 done( int status, TransactionID transaction );
159 accepted( TransactionID transaction ); 159 accepted( TransactionID transaction );
160 rejected( TransactionID transaction ); 160 rejected( TransactionID transaction );
161 161
162private: 162private:
163 OModalHelperBase* m_base; 163 OModalHelperBase* m_base;
164}; 164};
165 165
166 166
167class OModalHelperControler : public QObject 167class OModalHelperControler : public QObject
168{ 168{
169 Q_OBJECT 169 Q_OBJECT
170public: 170public:
171 OModalHelperControler( OModalHelperBase* , QObject* parent); 171 OModalHelperControler( OModalHelperBase* , QObject* parent);
172 virtual TransactionID transactionID()const; 172 virtual TransactionID transactionID()const;
173 void setTransactionID( TransactionID id ); 173 void setTransactionID( TransactionID id );
174 QDialog* dialog()const; 174 QDialog* dialog()const;
175 175
176public slots: 176public slots:
177 virtual void done(int result ); 177 virtual void done(int result );
178 virtual void next(); 178 virtual void next();
179 virtual void prev(); 179 virtual void prev();
180private: 180private:
181 QDialog *m_dia; 181 QDialog *m_dia;
182 TransactionID m_id; 182 TransactionID m_id;
183 OModalHelperBase *m_base; 183 OModalHelperBase *m_base;
184} 184}
185 185
186struct OModalQueueBar; 186struct OModalQueueBar;
187class OModalQueuedDialog : public QDialog 187class OModalQueuedDialog : public QDialog
188{ 188{
189 Q_OBJECT 189 Q_OBJECT
190public: 190public:
191 OModalQueuedDialog(QDialog *mainWidget); 191 OModalQueuedDialog(QDialog *mainWidget);
192 ~OModalQueuedDialog(); 192 ~OModalQueuedDialog();
193 193
194 QDialog* centerDialog()const; 194 QDialog* centerDialog()const;
195 195
196 void setQueueBarEnabled( bool = true ); 196 void setQueueBarEnabled( bool = true );
197 void setRecord( int record, int count ); 197 void setRecord( int record, int count );
198 198
199signals: 199signals:
200 void next(); 200 void next();
201 void prev(); 201 void prev();
202 202
203private: 203private:
204 OModalQueueBar *m_bar; 204 OModalQueueBar *m_bar;
205 QDialog *m_center; 205 QDialog *m_center;
206}; 206};
207 207
208 208
209/* 209/*
210 * Tcpp Template Implementation 210 * Tcpp Template Implementation
211 */ 211 */
212 212
213/** 213/**
214 * This is the simple Template c'tor. It takes the mode 214 * This is the simple Template c'tor. It takes the mode
215 * this helper should operate in and the parent object. 215 * this helper should operate in and the parent object.
216 * This helper will be deleted when the parent gets deleted 216 * This helper will be deleted when the parent gets deleted
217 * or you delete it yourself. 217 * or you delete it yourself.
218 * 218 *
219 * @param mode The mode this dialog should be in 219 * @param mode The mode this dialog should be in
220 * @param parent The parent QObject of this helper. 220 * @param parent The parent QObject of this helper.
221 */ 221 */
222template<class Dialog, class Record, typename Id> 222template<class Dialog, class Record, typename Id>
223OModalHelper<Dialog, Record, Id>::OModalHelper( enum Mode mode, QObject* parent ) 223OModalHelper<Dialog, Record, Id>::OModalHelper( enum Mode mode, QObject* parent )
224{ 224{
225 m_disabled = false; 225 m_disabled = false;
226 m_mode = mode; 226 m_mode = mode;
227 m_signal = new OModalHelperSignal( this, parent ); 227 m_signal = new OModalHelperSignal( this, parent );
228 m_controler = new OModalHelperControler( this, m_signal ); 228 m_controler = new OModalHelperControler( this, m_signal );
229} 229}
230 230
231 231
232/** 232/**
233 * This functions looks for your record and sees if it is 233 * This functions looks for your record and sees if it is
234 * handled with this helper. Note that done records 234 * handled with this helper. Note that done records
235 * will not be returned. 235 * will not be returned.
236 * 236 *
237 * @return true if the record is currenlty edited otherwise false 237 * @return true if the record is currenlty edited otherwise false
238 * 238 *
239 * @param Id The id which might be handled 239 * @param id The id which might be handled
240 */ 240 */
241template<class Dialog, class Record, typename Id> 241template<class Dialog, class Record, typename Id>
242bool OModalHelper<Dialog, Record, Id>::handles( Id id )const 242bool OModalHelper<Dialog, Record, Id>::handles( Id id )const
243{ 243{
244 if ( m_transactions.isEmpty() ) 244 if ( m_transactions.isEmpty() )
245 return false; 245 return false;
246 246
247 TransactionMap::ConstIterator it = m_transactions.begin(); 247 TransactionMap::ConstIterator it = m_transactions.begin();
248 for ( ; it != m_transactions.end(); ++it ) 248 for ( ; it != m_transactions.end(); ++it )
249 if ( it.data() == id ) 249 if ( it.data() == id )
250 return true; 250 return true;
251 251
252 return false; 252 return false;
253} 253}
254 254
255 255
256/** 256/**
257 * just like handles( Id ) but returns the TransactionId 257 * just like handles( Id ) but returns the TransactionId
258 */ 258 */
259template<class Dialog, class Record, typename Id> 259template<class Dialog, class Record, typename Id>
260TransactionID OModalHelper<Dialog, Record, Id>::transactionID( Id id)const 260TransactionID OModalHelper<Dialog, Record, Id>::transactionID( Id id)const
261{ 261{
262 if ( m_transactions.isEmpty() || !m_ids.contains( id ) ) 262 if ( m_transactions.isEmpty() || !m_ids.contains( id ) )
263 return 0; 263 return 0;
264 264
265 TransactionMap::ConstIterator it = m_transactions.begin(); 265 TransactionMap::ConstIterator it = m_transactions.begin();
266 for ( ; it != m_transactions.end(); ++it ) 266 for ( ; it != m_transactions.end(); ++it )
267 if ( it.data() == id ) 267 if ( it.data() == id )
268 return it.key(); 268 return it.key();
269 269
270 return 0; 270 return 0;
271} 271}
272 272
273/** 273/**
274 * If you're requested to flush your data and you do not want 274 * If you're requested to flush your data and you do not want
275 * to call cancel with this method you can disable and enabled 275 * to call cancel with this method you can disable and enabled
276 * all dialogs. 276 * all dialogs.
277 * The state gets saved so if you want to handle a new record the dialog 277 * The state gets saved so if you want to handle a new record the dialog
278 * will be disabled as well. 278 * will be disabled as well.
279 * 279 *
280 * @param sus If true setDisabled(TRUE) will be called otherwise FALSE 280 * @param sus If true setDisabled(TRUE) will be called otherwise FALSE
281 */ 281 */
282template<class Dialog, class Record, typename Id> 282template<class Dialog, class Record, typename Id>
283void OModalHelper<Dialog, Record, Id>::suspend(bool sus) 283void OModalHelper<Dialog, Record, Id>::suspend(bool sus)
284{ 284{
285 m_disabled = sus; 285 m_disabled = sus;
286 if (m_mode == New ) 286 if (m_mode == New )
287 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it ) 287 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it )
288 it.key()->setDisabled( sus ); 288 it.key()->setDisabled( sus );
289 else if (m_dialog ) 289 else if (m_dialog )
290 queuedDialog()->setDisabled( sus ); 290 queuedDialog()->setDisabled( sus );
291} 291}
292 292
293/** 293/**
294 * Cancel will cancel all current operations and clear the list 294 * Cancel will cancel all current operations and clear the list
295 * of done operations as well. 295 * of done operations as well.
296 * This also clears all done operations you did not popped 296 * This also clears all done operations you did not popped
297 */ 297 */
298template<class Dialog, class Record, typename Id> 298template<class Dialog, class Record, typename Id>
299void OModalHelper<Dialog, Record, Id>::cancel() 299void OModalHelper<Dialog, Record, Id>::cancel()
300{ 300{
301 m_ids.clear(); 301 m_ids.clear();
302 m_doneIds.clear(); 302 m_doneIds.clear();
303 m_done.clear(); 303 m_done.clear();
304 m_transactions.clear(); 304 m_transactions.clear();
305 305
306 /* we also need to remove the QDialogs */ 306 /* we also need to remove the QDialogs */
307 /* and hide the queue dialog if present */ 307 /* and hide the queue dialog if present */
308 if (m_mode == New && !m_editing.isEmpty() ) 308 if (m_mode == New && !m_editing.isEmpty() )
309 { 309 {
310 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it ) 310 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it )
311 delete it.key(); 311 delete it.key();
312 312
313 m_editing.clear(); 313 m_editing.clear();
314 } 314 }
315 else if (m_dialog ) 315 else if (m_dialog )
316 queuedDialog()->setRecord( 0, 0 ); 316 queuedDialog()->setRecord( 0, 0 );
317 317
318 m_controler->setTransactionID( 0 ); 318 m_controler->setTransactionID( 0 );
319} 319}
320 320
321 321
322/** 322/**
323 * This cancels editing of the record behind the Transaction Number 323 * This cancels editing of the record behind the Transaction Number
324 * Note that if editing is already done it will also be removed from this list 324 * Note that if editing is already done it will also be removed from this list
325 */ 325 */
326template<class Dialog, class Record, typename Id> 326template<class Dialog, class Record, typename Id>
327void OModalHelper::cancel( TransactionID tid ) 327void OModalHelper::cancel( TransactionID tid )
328{ 328{
329 /* wrong tid */ 329 /* wrong tid */
330 if (!m_transactions.contains( tid ) && !m_done.contains( tid) ) 330 if (!m_transactions.contains( tid ) && !m_done.contains( tid) )
331 return; 331 return;
332 332
333 if (m_mode == New ) 333 if (m_mode == New )
334 /* reverse map eek */ 334 /* reverse map eek */
335 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it ) 335 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it )
336 if ( it.data() == tid ) 336 if ( it.data() == tid )
337 { 337 {
338 it.key()->hide(); 338 it.key()->hide();
339 delete it.key(); 339 delete it.key();
340 it = m_editing.remove( it ); 340 it = m_editing.remove( it );
341 break; 341 break;
342 } 342 }
343 343
344 /* now remove from the various maps done and currently editing map*/ 344 /* now remove from the various maps done and currently editing map*/
345 if (m_transactions.contains( tid ) ) 345 if (m_transactions.contains( tid ) )
346 m_ids.remove( m_transactions[tid] ); 346 m_ids.remove( m_transactions[tid] );
347 if (m_done.contains( tid ) ) 347 if (m_done.contains( tid ) )
348 m_doneIds.remove( m_done[tid ] ); 348 m_doneIds.remove( m_done[tid ] );
349 m_done.remove( tid ); 349 m_done.remove( tid );
350 m_transactions.remove( tid ); 350 m_transactions.remove( tid );
351 351
352 next( 0 ); 352 next( 0 );
353} 353}
354 354
355/** 355/**
356 * Connect to the done Signal. SIGNAL( done(int, TransactionID ) ) 356 * Connect to the done Signal. SIGNAL( done(int, TransactionID ) )
357 * This signal gets emitted whenever a Record was accepted or rejected 357 * This signal gets emitted whenever a Record was accepted or rejected
358 * 358 *
359 * @param rec The object where the slot belongs to 359 * @param rec The object where the slot belongs to
360 * @param slot The slot which should be called. See the needed parameter above 360 * @param slot The slot which should be called. See the needed parameter above
361 */ 361 */
362template<class Dialog, class Record, typename Id> 362template<class Dialog, class Record, typename Id>
363void OModalHelper<Dialog, Record, Id>::connectDone( QObject* rec, const char* slot ) 363void OModalHelper<Dialog, Record, Id>::connectDone( QObject* rec, const char* slot )
364{ 364{
365 QObject::connect(m_signal, SIGNAL(done(int, TransactionID) ), 365 QObject::connect(m_signal, SIGNAL(done(int, TransactionID) ),
366 rec, slot ); 366 rec, slot );
367} 367}
368 368
369/** 369/**
370 * Connect to the accepted Signal. SIGNAL( accepted(TransactionID ) ) 370 * Connect to the accepted Signal. SIGNAL( accepted(TransactionID ) )
371 * This signal gets emitted whenever a Record was accepted 371 * This signal gets emitted whenever a Record was accepted
372 * 372 *
373 * @param rec The object where the slot belongs to 373 * @param rec The object where the slot belongs to
374 * @param slot The slot which should be called. See the needed parameter above 374 * @param slot The slot which should be called. See the needed parameter above
375 */ 375 */
376template<class Dialog, class Record, typename Id> 376template<class Dialog, class Record, typename Id>
377void OModalHelper<Dialog, Record, Id>::connectAccepted( QObject* rec, const char* slot ) 377void OModalHelper<Dialog, Record, Id>::connectAccepted( QObject* rec, const char* slot )
378{ 378{
379 QObject::connect(m_signal, SIGNAL(accepted(TransactionID) ), 379 QObject::connect(m_signal, SIGNAL(accepted(TransactionID) ),
380 rec, slot ); 380 rec, slot );
381} 381}
382 382
383/** 383/**
384 * Same as the accepted method but this one gets emitted if the dialog 384 * Same as the accepted method but this one gets emitted if the dialog
385 * got rejected. 385 * got rejected.
386 * SIGNAL( rejected(TransactionID) ) 386 * SIGNAL( rejected(TransactionID) )
387 * 387 *
388 * @param rec The QObject of the slot 388 * @param rec The QObject of the slot
389 * @param slot The slot make sure the signature is correct 389 * @param slot The slot make sure the signature is correct
390 */ 390 */
391template<class Dialog, class Record, typename Id> 391template<class Dialog, class Record, typename Id>
392void OModalHelper<Dialog, Record, Id>::connectRejected( QObject* rec, const char* slot ) 392void OModalHelper<Dialog, Record, Id>::connectRejected( QObject* rec, const char* slot )
393{ 393{
394 QObject::connect(m_signal, SIGNAL(rejected(TransactionID) ), 394 QObject::connect(m_signal, SIGNAL(rejected(TransactionID) ),
395 rec, slot ); 395 rec, slot );
396} 396}
397 397
398/** 398/**
399 * Tell the helper to handle a record. If the record is currently handled 399 * Tell the helper to handle a record. If the record is currently handled
400 * it will be made active. 400 * it will be made active.
401 * Already handled record which are waiting getting popped are not taken into account 401 * Already handled record which are waiting getting popped are not taken into account
402 * Otherwise this helpers make the record editable. 402 * Otherwise this helpers make the record editable.
403 * The record supplied needs to have a valid copy operator and constructor. 403 * The record supplied needs to have a valid copy operator and constructor.
404 * In the case where the record is already present the parameter gets discarded. 404 * In the case where the record is already present the parameter gets discarded.
405 * If you want the new record to be taken you need to cancel the Transaction first 405 * If you want the new record to be taken you need to cancel the Transaction first
406 * 406 *
407 * @param id The Identification of the Record. For PIM it would uid() 407 * @param id The Identification of the Record. For PIM it would uid()
408 * @param rec The record we want to be edited 408 * @param rec The record we want to be edited
409 * 409 *
410 * @returns This functions returns the TransactionId assigned to the record 410 * @returns This functions returns the TransactionId assigned to the record
411 * 411 *
412 */ 412 */
413template<class Dialog, class Record, typename Id> 413template<class Dialog, class Record, typename Id>
414TransactionID OModalHelper<Dialog, Record, Id>::handle( Id id, const Record& rec ) 414TransactionID OModalHelper<Dialog, Record, Id>::handle( Id id, const Record& rec )
415{ 415{
416 static TransactionID t_id = 0; 416 static TransactionID t_id = 0;
417 /* 417 /*
418 *this method consists out of two parts divided each into New and Queued Mode. 418 *this method consists out of two parts divided each into New and Queued Mode.
419 * Either we have the dialog already, in this case we need to highlight the widget 419 * Either we have the dialog already, in this case we need to highlight the widget
420 * Or we need to add it. 420 * Or we need to add it.
421 */ 421 */
422 TransactionID tid = 0; 422 TransactionID tid = 0;
423 /* we already have the record lets see if it was done or not */ 423 /* we already have the record lets see if it was done or not */
424 if ( !(tid = transactionID( id ) ) ) 424 if ( !(tid = transactionID( id ) ) )
425 { 425 {
426 if (m_mode == New ) 426 if (m_mode == New )
427 { 427 {
428 /* lets find the dialog and show it need to reverse map*/ 428 /* lets find the dialog and show it need to reverse map*/
429 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it ) 429 for (DialogMap::Iterator it = m_editing.begin(); it != m_editing.end(); ++it )
430 if ( it.data() == tid ) 430 if ( it.data() == tid )
431 it.key()->show(); 431 it.key()->show();
diff --git a/libopie2/opieui/otabinfo.h b/libopie2/opieui/otabinfo.h
index 426c45a..d6d5abf 100644
--- a/libopie2/opieui/otabinfo.h
+++ b/libopie2/opieui/otabinfo.h
@@ -1,141 +1,136 @@
1/* 1/*
2                This file is part of the Opie Project 2                This file is part of the Opie Project
3 3
4              Copyright (c) 2002 Dan Williams <williamsdr@acm.org> 4              Copyright (c) 2002 Dan Williams <williamsdr@acm.org>
5 =. 5 =.
6 .=l. 6 .=l.
7           .>+-= 7           .>+-=
8 _;:,     .>    :=|. This program is free software; you can 8 _;:,     .>    :=|. This program is free software; you can
9.> <`_,   >  .   <= redistribute it and/or modify it under 9.> <`_,   >  .   <= redistribute it and/or modify it under
10:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 10:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
11.="- .-=="i,     .._ License as published by the Free Software 11.="- .-=="i,     .._ License as published by the Free Software
12 - .   .-<_>     .<> Foundation; either version 2 of the License, 12 - .   .-<_>     .<> Foundation; either version 2 of the License,
13     ._= =}       : or (at your option) any later version. 13     ._= =}       : or (at your option) any later version.
14    .%`+i>       _;_. 14    .%`+i>       _;_.
15    .i_,=:_.      -<s. This program is distributed in the hope that 15    .i_,=:_.      -<s. This program is distributed in the hope that
16     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 16     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
17    : ..    .:,     . . . without even the implied warranty of 17    : ..    .:,     . . . without even the implied warranty of
18    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 18    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
19  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 19  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
20..}^=.=       =       ; Library General Public License for more 20..}^=.=       =       ; Library General Public License for more
21++=   -.     .`     .: details. 21++=   -.     .`     .: details.
22 :     =  ...= . :.=- 22 :     =  ...= . :.=-
23 -.   .:....=;==+<; You should have received a copy of the GNU 23 -.   .:....=;==+<; You should have received a copy of the GNU
24  -_. . .   )=.  = Library General Public License along with 24  -_. . .   )=.  = Library General Public License along with
25    --        :-=` this library; see the file COPYING.LIB. 25    --        :-=` this library; see the file COPYING.LIB.
26 If not, write to the Free Software Foundation, 26 If not, write to the Free Software Foundation,
27 Inc., 59 Temple Place - Suite 330, 27 Inc., 59 Temple Place - Suite 330,
28 Boston, MA 02111-1307, USA. 28 Boston, MA 02111-1307, USA.
29 29
30*/ 30*/
31 31
32#ifndef OTABINFO_H 32#ifndef OTABINFO_H
33#define OTABINFO_H 33#define OTABINFO_H
34 34
35/* QT */ 35/* QT */
36#include <qlist.h> 36#include <qlist.h>
37#include <qstring.h> 37#include <qstring.h>
38 38
39class QWidget; 39class QWidget;
40 40
41namespace Opie{ 41namespace Opie{
42namespace Ui { 42namespace Ui {
43 43
44/** 44/**
45 * @class OTabInfo 45 * @class OTabInfo
46 * @brief The OTabInfo class is used internally by OTabWidget to keep track 46 * @brief The OTabInfo class is used internally by OTabWidget to keep track
47 * of widgets added to the control. 47 * of widgets added to the control.
48 * 48 *
49 * OTabInfo provides the following information about a widget added to an 49 * OTabInfo provides the following information about a widget added to an
50 * OTabWidget control: 50 * OTabWidget control:
51 * 51 *
52 * ID - integer tab bar ID 52 * ID - integer tab bar ID
53 * Control - QWidget pointer to child widget 53 * Control - QWidget pointer to child widget
54 * Label - QString text label for OTabWidget selection control 54 * Label - QString text label for OTabWidget selection control
55 * Icon - QString name of icon file 55 * Icon - QString name of icon file
56 */ 56 */
57class OTabInfo 57class OTabInfo
58{ 58{
59public: 59public:
60 /** 60 /**
61 * @fn OTabInfo() 61 * @fn OTabInfo()
62 * @brief Object constructor. 62 * @brief Object constructor.
63 *
64 * @param parent Pointer to parent of this control.
65 * @param name Name of control.
66 * @param s Style of widget selection control.
67 * @param p Position of the widget selection control.
68 */ 63 */
69 OTabInfo() : i( -1 ), c( 0 ), p( 0 ), l( QString::null ) {} 64 OTabInfo() : i( -1 ), c( 0 ), p( 0 ), l( QString::null ) {}
70 65
71 /** 66 /**
72 * @fn OTabInfo( int id, QWidget *control, const QString &icon, const QString &label ) 67 * @fn OTabInfo( int id, QWidget *control, const QString &icon, const QString &label )
73 * @brief Object constructor. 68 * @brief Object constructor.
74 * 69 *
75 * @param id TabBar identifier for widget. 70 * @param id TabBar identifier for widget.
76 * @param control QWidget pointer to widget. 71 * @param control QWidget pointer to widget.
77 * @param icon QString name of icon file. 72 * @param icon QString name of icon file.
78 * @param label QString text label for OTabWidget selection control. 73 * @param label QString text label for OTabWidget selection control.
79 */ 74 */
80 OTabInfo( int id, QWidget *control, const QString &icon, const QString &label ) 75 OTabInfo( int id, QWidget *control, const QString &icon, const QString &label )
81 : i( id ), c( control ), p( icon ), l( label ) {} 76 : i( id ), c( control ), p( icon ), l( label ) {}
82 77
83 /** 78 /**
84 * @fn id()const 79 * @fn id()const
85 * @brief Returns TabBar ID. 80 * @brief Returns TabBar ID.
86 */ 81 */
87 int id() const { return i; } 82 int id() const { return i; }
88 83
89 /** 84 /**
90 * @fn label()const 85 * @fn label()const
91 * @brief Returns text label for widget. 86 * @brief Returns text label for widget.
92 */ 87 */
93 const QString &label() const { return l; } 88 const QString &label() const { return l; }
94 89
95 /** 90 /**
96 * @fn setLabel( const QString &label ) 91 * @fn setLabel( const QString &label )
97 * @brief Set label for tab. 92 * @brief Set label for tab.
98 * 93 *
99 * @param label QString text label for OTabWidget selection control. 94 * @param label QString text label for OTabWidget selection control.
100 */ 95 */
101 void setLabel( const QString &label ) { l = label; } 96 void setLabel( const QString &label ) { l = label; }
102 97
103 /** 98 /**
104 * @fn control()const 99 * @fn control()const
105 * @brief Returns pointer to widget. 100 * @brief Returns pointer to widget.
106 */ 101 */
107 QWidget *control() const { return c; } 102 QWidget *control() const { return c; }
108 103
109 /** 104 /**
110 * @fn icon()const 105 * @fn icon()const
111 * @brief Returns name of icon file. 106 * @brief Returns name of icon file.
112 */ 107 */
113 const QString &icon() const { return p; } 108 const QString &icon() const { return p; }
114 109
115 /** 110 /**
116 * @fn setIcon( const QString &icon ) 111 * @fn setIcon( const QString &icon )
117 * @brief Set icon for tab. 112 * @brief Set icon for tab.
118 * 113 *
119 * @param icon QString name of icon file. 114 * @param icon QString name of icon file.
120 */ 115 */
121 void setIcon( const QString &icon ) { p = icon; } 116 void setIcon( const QString &icon ) { p = icon; }
122 117
123private: 118private:
124 int i; 119 int i;
125 QWidget *c; 120 QWidget *c;
126 QString p; 121 QString p;
127 QString l; 122 QString l;
128 class Private; 123 class Private;
129 Private *d; 124 Private *d;
130}; 125};
131 126
132/** 127/**
133 * @class OTabInfoList 128 * @class OTabInfoList
134 * @brief A list of OTabInfo objects used by OTabWidget. 129 * @brief A list of OTabInfo objects used by OTabWidget.
135 */ 130 */
136typedef QList<OTabInfo> OTabInfoList; 131typedef QList<OTabInfo> OTabInfoList;
137 132
138} 133}
139} 134}
140 135
141#endif 136#endif