summaryrefslogtreecommitdiff
authorzecke <zecke>2002-11-30 11:31:24 (UTC)
committer zecke <zecke>2002-11-30 11:31:24 (UTC)
commitcfb09f9ae7b710b3079320f3b268c45c3fae8979 (patch) (unidiff)
tree7dda9c82a59f8ca6a2cf55271b2749b71e29b26e
parent9b8b30fa6cbdf1424b29cde21fae112e8bf96e6d (diff)
downloadopie-cfb09f9ae7b710b3079320f3b268c45c3fae8979.zip
opie-cfb09f9ae7b710b3079320f3b268c45c3fae8979.tar.gz
opie-cfb09f9ae7b710b3079320f3b268c45c3fae8979.tar.bz2
pelling updates
libopie.pro additions
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/libopie.pro6
-rw-r--r--libopie/orecurrancewidget.cpp20
-rw-r--r--libopie/orecurrancewidget.h6
3 files changed, 27 insertions, 5 deletions
diff --git a/libopie/libopie.pro b/libopie/libopie.pro
index b7537cc..2e76cb1 100644
--- a/libopie/libopie.pro
+++ b/libopie/libopie.pro
@@ -1,93 +1,99 @@
1TEMPLATE = lib 1TEMPLATE = lib
2CONFIG += qte warn_on release 2CONFIG += qte warn_on release
3HEADERS = ofontmenu.h \ 3HEADERS = ofontmenu.h \
4 ocolorbutton.h \ 4 ocolorbutton.h \
5 ofiledialog.h ofileselector.h tododb.h \ 5 ofiledialog.h ofileselector.h tododb.h \
6 ocheckitem.h todoevent.h todoresource.h \ 6 ocheckitem.h todoevent.h todoresource.h \
7 todovcalresource.h xmltree.h \ 7 todovcalresource.h xmltree.h \
8 colordialog.h colorpopupmenu.h \ 8 colordialog.h colorpopupmenu.h \
9 oclickablelabel.h oprocctrl.h \ 9 oclickablelabel.h oprocctrl.h \
10 oprocess.h odevice.h \ 10 oprocess.h odevice.h \
11 otimepicker.h otabwidget.h \ 11 otimepicker.h otabwidget.h \
12 otabbar.h otabinfo.h \ 12 otabbar.h otabinfo.h \
13 ofontselector.h \ 13 ofontselector.h \
14 pim/opimrecord.h \ 14 pim/opimrecord.h \
15 pim/otodo.h \ 15 pim/otodo.h \
16 pim/orecordlist.h \ 16 pim/orecordlist.h \
17 pim/opimaccesstemplate.h \ 17 pim/opimaccesstemplate.h \
18 pim/opimaccessbackend.h \ 18 pim/opimaccessbackend.h \
19 pim/otodoaccess.h \ 19 pim/otodoaccess.h \
20 pim/otodoaccessbackend.h \ 20 pim/otodoaccessbackend.h \
21 pim/ocontact.h \ 21 pim/ocontact.h \
22 pim/ocontactaccess.h \ 22 pim/ocontactaccess.h \
23 pim/ocontactaccessbackend.h \ 23 pim/ocontactaccessbackend.h \
24 pim/ocontactaccessbackend_xml.h \ 24 pim/ocontactaccessbackend_xml.h \
25 pim/ocontactaccessbackend_vcard.h \ 25 pim/ocontactaccessbackend_vcard.h \
26 pim/obackendfactory.h \ 26 pim/obackendfactory.h \
27 pim/opimcache.h \ 27 pim/opimcache.h \
28 pim/otodoaccessvcal.h \ 28 pim/otodoaccessvcal.h \
29 pim/orecur.h \ 29 pim/orecur.h \
30 pim/opimstate.h \ 30 pim/opimstate.h \
31 pim/opimxrefpartner.h \ 31 pim/opimxrefpartner.h \
32 pim/opimxref.h \ 32 pim/opimxref.h \
33 pim/opimxrefmanager.h \ 33 pim/opimxrefmanager.h \
34 pim/opimmaintainer.h \ 34 pim/opimmaintainer.h \
35 pim/opimnotify.h \
36 pim/opimnotifymanager.h \
37 pim/opimmainwindow.h \
35 orecurrancewidget.h \ 38 orecurrancewidget.h \
36 oticker.h 39 oticker.h
37# pim/otodoaccesssql.h \ 40# pim/otodoaccesssql.h \
38 41
39SOURCES = ofontmenu.cc \ 42SOURCES = ofontmenu.cc \
40 ocolorbutton.cpp \ 43 ocolorbutton.cpp \
41 sharp_compat.cpp \ 44 sharp_compat.cpp \
42 xmltree.cc \ 45 xmltree.cc \
43 ofiledialog.cc ofileselector.cc \ 46 ofiledialog.cc ofileselector.cc \
44 ocheckitem.cpp tododb.cpp todoevent.cpp \ 47 ocheckitem.cpp tododb.cpp todoevent.cpp \
45 todovcalresource.cpp colordialog.cpp \ 48 todovcalresource.cpp colordialog.cpp \
46 colorpopupmenu.cpp oclickablelabel.cpp \ 49 colorpopupmenu.cpp oclickablelabel.cpp \
47 oprocctrl.cpp oprocess.cpp \ 50 oprocctrl.cpp oprocess.cpp \
48 odevice.cpp otimepicker.cpp \ 51 odevice.cpp otimepicker.cpp \
49 otabwidget.cpp otabbar.cpp \ 52 otabwidget.cpp otabbar.cpp \
50 ofontselector.cpp \ 53 ofontselector.cpp \
51 pim/otodo.cpp \ 54 pim/otodo.cpp \
52 pim/opimrecord.cpp \ 55 pim/opimrecord.cpp \
53 pim/otodoaccess.cpp \ 56 pim/otodoaccess.cpp \
54 pim/otodoaccessbackend.cpp \ 57 pim/otodoaccessbackend.cpp \
55 pim/otodoaccessxml.cpp \ 58 pim/otodoaccessxml.cpp \
56 pim/ocontact.cpp \ 59 pim/ocontact.cpp \
57 pim/ocontactaccess.cpp \ 60 pim/ocontactaccess.cpp \
58 pim/ocontactaccessbackend_vcard.cpp \ 61 pim/ocontactaccessbackend_vcard.cpp \
59 pim/otodoaccessvcal.cpp \ 62 pim/otodoaccessvcal.cpp \
60 pim/orecur.cpp \ 63 pim/orecur.cpp \
61 pim/opimstate.cpp \ 64 pim/opimstate.cpp \
62 pim/opimxrefpartner.cpp \ 65 pim/opimxrefpartner.cpp \
63 pim/opimxref.cpp \ 66 pim/opimxref.cpp \
64 pim/opimxrefmanager.cpp \ 67 pim/opimxrefmanager.cpp \
65 pim/opimmaintainer.cpp \ 68 pim/opimmaintainer.cpp \
69 pim/opimnotify.cpp \
70 pim/opimnotifymanager.cpp \
71 pim/opimmainwindow.cpp \
66 orecurrancewidget.cpp \ 72 orecurrancewidget.cpp \
67 oticker.cpp 73 oticker.cpp
68# pim/otodoaccesssql.cpp \ 74# pim/otodoaccesssql.cpp \
69 75
70TARGET = opie 76TARGET = opie
71INCLUDEPATH += $(OPIEDIR)/include 77INCLUDEPATH += $(OPIEDIR)/include
72DESTDIR = $(QTDIR)/lib$(PROJMAK) 78DESTDIR = $(QTDIR)/lib$(PROJMAK)
73#VERSION = 1.0.0 79#VERSION = 1.0.0
74 80
75# LIBS += -lopiesql 81# LIBS += -lopiesql
76 82
77INTERFACES = otimepickerbase.ui orecurrancebase.ui 83INTERFACES = otimepickerbase.ui orecurrancebase.ui
78 84
79TRANSLATIONS = ../i18n/de/libopie.ts \ 85TRANSLATIONS = ../i18n/de/libopie.ts \
80 ../i18n/en/libopie.ts \ 86 ../i18n/en/libopie.ts \
81 ../i18n/es/libopie.ts \ 87 ../i18n/es/libopie.ts \
82 ../i18n/fr/libopie.ts \ 88 ../i18n/fr/libopie.ts \
83 ../i18n/hu/libopie.ts \ 89 ../i18n/hu/libopie.ts \
84 ../i18n/ja/libopie.ts \ 90 ../i18n/ja/libopie.ts \
85 ../i18n/ko/libopie.ts \ 91 ../i18n/ko/libopie.ts \
86 ../i18n/no/libopie.ts \ 92 ../i18n/no/libopie.ts \
87 ../i18n/pl/libopie.ts \ 93 ../i18n/pl/libopie.ts \
88 ../i18n/pt/libopie.ts \ 94 ../i18n/pt/libopie.ts \
89 ../i18n/pt_BR/libopie.ts \ 95 ../i18n/pt_BR/libopie.ts \
90 ../i18n/sl/libopie.ts \ 96 ../i18n/sl/libopie.ts \
91 ../i18n/zh_CN/libopie.ts \ 97 ../i18n/zh_CN/libopie.ts \
92 ../i18n/zh_TW/libopie.ts \ 98 ../i18n/zh_TW/libopie.ts \
93 ../i18n/da/libopie.ts 99 ../i18n/da/libopie.ts
diff --git a/libopie/orecurrancewidget.cpp b/libopie/orecurrancewidget.cpp
index 53cee65..0484ab9 100644
--- a/libopie/orecurrancewidget.cpp
+++ b/libopie/orecurrancewidget.cpp
@@ -1,498 +1,510 @@
1#include <qapplication.h> 1#include <qapplication.h>
2#include <qlabel.h> 2#include <qlabel.h>
3#include <qpopupmenu.h> 3#include <qpopupmenu.h>
4#include <qspinbox.h> 4#include <qspinbox.h>
5 5
6#include <qpe/timestring.h> 6#include <qpe/timestring.h>
7 7
8#include "orecurrancewidget.h" 8#include "orecurrancewidget.h"
9 9
10// Global Templates for use in setting up the repeat label... 10// Global Templates for use in setting up the repeat label...
11const QString strDayTemplate = QObject::tr("Every"); 11const QString strDayTemplate = QObject::tr("Every");
12const QString strYearTemplate = QObject::tr("%1 %2 every "); 12const QString strYearTemplate = QObject::tr("%1 %2 every ");
13const QString strMonthDateTemplate = QObject::tr("The %1 every "); 13const QString strMonthDateTemplate = QObject::tr("The %1 every ");
14const QString strMonthDayTemplate = QObject::tr("The %1 %1 of every"); 14const QString strMonthDayTemplate = QObject::tr("The %1 %1 of every");
15const QString strWeekTemplate = QObject::tr("Every "); 15const QString strWeekTemplate = QObject::tr("Every ");
16const QString dayLabel[] = { QObject::tr("Monday"), 16const QString dayLabel[] = { QObject::tr("Monday"),
17 QObject::tr("Tuesday"), 17 QObject::tr("Tuesday"),
18 QObject::tr("Wednesday"), 18 QObject::tr("Wednesday"),
19 QObject::tr("Thursday"), 19 QObject::tr("Thursday"),
20 QObject::tr("Friday"), 20 QObject::tr("Friday"),
21 QObject::tr("Saturday"), 21 QObject::tr("Saturday"),
22 QObject::tr("Sunday") }; 22 QObject::tr("Sunday") };
23 23
24 24
25 static QString numberPlacing( int x );// return the proper word format for 25 static QString numberPlacing( int x );// return the proper word format for
26 // x (1st, 2nd, etc) 26 // x (1st, 2nd, etc)
27static int week( const QDate &dt ); // what week in the month is dt? 27static int week( const QDate &dt ); // what week in the month is dt?
28 28
29 29
30ORecurranceWidget::ORecurranceWidget( bool startOnMonday, 30ORecurranceWidget::ORecurranceWidget( bool startOnMonday,
31 const QDate& newStart, 31 const QDate& newStart,
32 QWidget* parent, 32 QWidget* parent,
33 const char* name, 33 const char* name,
34 bool modal, 34 bool modal,
35 WFlags fl ) 35 WFlags fl )
36 : ORecurranceBase( parent, name, modal, fl ), 36 : ORecurranceBase( parent, name, modal, fl ),
37 start( newStart ), 37 start( newStart ),
38 currInterval( None ), 38 currInterval( None ),
39 startWeekOnMonday( startOnMonday ) 39 startWeekOnMonday( startOnMonday )
40{ 40{
41 init(); 41 init();
42 fraType->setButton( currInterval ); 42 fraType->setButton( currInterval );
43 chkNoEnd->setChecked( TRUE ); 43 chkNoEnd->setChecked( TRUE );
44 setupNone(); 44 setupNone();
45} 45}
46ORecurranceWidget::ORecurranceWidget( bool startOnMonday, 46ORecurranceWidget::ORecurranceWidget( bool startOnMonday,
47 const ORecur& rp, const QDate& startDate, 47 const ORecur& rp, const QDate& startDate,
48 QWidget* parent, const char* name, 48 QWidget* parent, const char* name,
49 bool modal, WFlags fl) 49 bool modal, WFlags fl)
50 : ORecurranceBase( parent, name, modal, fl ), 50 : ORecurranceBase( parent, name, modal, fl ),
51 start( startDate ), 51 start( startDate ),
52 end( rp.endDate() ), 52 end( rp.endDate() ),
53 startWeekOnMonday( startOnMonday ) 53 startWeekOnMonday( startOnMonday )
54{ 54{
55 // do some stuff with the repeat pattern 55 // do some stuff with the repeat pattern
56 init(); 56 init();
57 setRecurrence( rp );
58}
59
60ORecurranceWidget::~ORecurranceWidget() {
61}
62void ORecurranceWidget::setStartDate( const QDate& date ) {
63 qWarning("ORecurranceWidget::setStartDate");
64 setRecurrence( recurrence(), date );
65}
66void ORecurranceWidget::setRecurrence( const ORecur& rp ) {
67 setRecurrence( rp, start );
68}
69void ORecurranceWidget::setRecurrence( const ORecur& rp, const QDate& date ) {
70 start = date;
71 end = rp.endDate();
57 switch ( rp.type() ) { 72 switch ( rp.type() ) {
58 default: 73 default:
59 case ORecur::NoRepeat: 74 case ORecur::NoRepeat:
60 currInterval = None; 75 currInterval = None;
61 setupNone(); 76 setupNone();
62 break; 77 break;
63 case ORecur::Daily: 78 case ORecur::Daily:
64 currInterval = Day; 79 currInterval = Day;
65 setupDaily(); 80 setupDaily();
66 break; 81 break;
67 case ORecur::Weekly: 82 case ORecur::Weekly:
68 currInterval = Week; 83 currInterval = Week;
69 setupWeekly(); 84 setupWeekly();
70 int day, buttons; 85 int day, buttons;
71 for ( day = 0x01, buttons = 0; buttons < 7; 86 for ( day = 0x01, buttons = 0; buttons < 7;
72 day = day << 1, buttons++ ) { 87 day = day << 1, buttons++ ) {
73 if ( rp.days() & day ) { 88 if ( rp.days() & day ) {
74 if ( startWeekOnMonday ) 89 if ( startWeekOnMonday )
75 fraExtra->setButton( buttons ); 90 fraExtra->setButton( buttons );
76 else { 91 else {
77 if ( buttons == 7 ) 92 if ( buttons == 7 )
78 fraExtra->setButton( 0 ); 93 fraExtra->setButton( 0 );
79 else 94 else
80 fraExtra->setButton( buttons + 1 ); 95 fraExtra->setButton( buttons + 1 );
81 } 96 }
82 } 97 }
83 } 98 }
84 slotWeekLabel(); 99 slotWeekLabel();
85 break; 100 break;
86 case ORecur::MonthlyDay: 101 case ORecur::MonthlyDay:
87 currInterval = Month; 102 currInterval = Month;
88 setupMonthly(); 103 setupMonthly();
89 fraExtra->setButton( 0 ); 104 fraExtra->setButton( 0 );
90 slotMonthLabel( 0 ); 105 slotMonthLabel( 0 );
91 break; 106 break;
92 case ORecur::MonthlyDate: 107 case ORecur::MonthlyDate:
93 currInterval = Month; 108 currInterval = Month;
94 setupMonthly(); 109 setupMonthly();
95 fraExtra->setButton( 1 ); 110 fraExtra->setButton( 1 );
96 slotMonthLabel( 1 ); 111 slotMonthLabel( 1 );
97 break; 112 break;
98 case ORecur::Yearly: 113 case ORecur::Yearly:
99 currInterval = Year; 114 currInterval = Year;
100 setupYearly(); 115 setupYearly();
101 break; 116 break;
102 } 117 }
103 fraType->setButton( currInterval ); 118 fraType->setButton( currInterval );
104 spinFreq->setValue( rp.frequency() ); 119 spinFreq->setValue( rp.frequency() );
105 if ( !rp.hasEndDate() ) { 120 if ( !rp.hasEndDate() ) {
106 cmdEnd->setText( tr("No End Date") ); 121 cmdEnd->setText( tr("No End Date") );
107 chkNoEnd->setChecked( TRUE ); 122 chkNoEnd->setChecked( TRUE );
108 } else 123 } else
109 cmdEnd->setText( TimeString::shortDate( end ) ); 124 cmdEnd->setText( TimeString::shortDate( end ) );
110} 125}
111ORecurranceWidget::~ORecurranceWidget() { 126ORecur ORecurranceWidget::recurrence()const {
112
113}
114ORecur ORecurranceWidget::recurrance()const {
115 QListIterator<QToolButton> it( listRTypeButtons ); 127 QListIterator<QToolButton> it( listRTypeButtons );
116 QListIterator<QToolButton> itExtra( listExtra ); 128 QListIterator<QToolButton> itExtra( listExtra );
117 ORecur rpTmp; 129 ORecur rpTmp;
118 int i; 130 int i;
119 for ( i = 0; *it; ++it, i++ ) { 131 for ( i = 0; *it; ++it, i++ ) {
120 if ( (*it)->isOn() ) { 132 if ( (*it)->isOn() ) {
121 switch ( i ) { 133 switch ( i ) {
122 case None: 134 case None:
123 rpTmp.setType( ORecur::NoRepeat ); 135 rpTmp.setType( ORecur::NoRepeat );
124 break; 136 break;
125 case Day: 137 case Day:
126 rpTmp.setType( ORecur::Daily ); 138 rpTmp.setType( ORecur::Daily );
127 break; 139 break;
128 case Week:{ 140 case Week:{
129 rpTmp.setType( ORecur::Weekly ); 141 rpTmp.setType( ORecur::Weekly );
130 int day; 142 int day;
131 int day2 = 0; 143 int day2 = 0;
132 for ( day = 1; *itExtra; ++itExtra, day = day << 1 ) { 144 for ( day = 1; *itExtra; ++itExtra, day = day << 1 ) {
133 if ( (*itExtra)->isOn() ) { 145 if ( (*itExtra)->isOn() ) {
134 if ( startWeekOnMonday ) 146 if ( startWeekOnMonday )
135 day2 |= day; 147 day2 |= day;
136 else { 148 else {
137 if ( day == 1 ) 149 if ( day == 1 )
138 day2 |= Event::SUN; 150 day2 |= Event::SUN;
139 else 151 else
140 day2 |= day >> 1; 152 day2 |= day >> 1;
141 } 153 }
142 } 154 }
143 } 155 }
144 rpTmp.setDays( day2 ); 156 rpTmp.setDays( day2 );
145 } 157 }
146 break; 158 break;
147 case Month: 159 case Month:
148 if ( cmdExtra1->isOn() ) 160 if ( cmdExtra1->isOn() )
149 rpTmp.setType( ORecur::MonthlyDay ); 161 rpTmp.setType( ORecur::MonthlyDay );
150 else if ( cmdExtra2->isOn() ) 162 else if ( cmdExtra2->isOn() )
151 rpTmp.setType( ORecur::MonthlyDate ); 163 rpTmp.setType( ORecur::MonthlyDate );
152 // figure out the montly day... 164 // figure out the montly day...
153 rpTmp.setPosition( week( start ) ); 165 rpTmp.setPosition( week( start ) );
154 break; 166 break;
155 case Year: 167 case Year:
156 rpTmp.setType( ORecur::Yearly ); 168 rpTmp.setType( ORecur::Yearly );
157 break; 169 break;
158 } 170 }
159 break; // no need to keep looking! 171 break; // no need to keep looking!
160 } 172 }
161 } 173 }
162 rpTmp.setFrequency(spinFreq->value() ); 174 rpTmp.setFrequency(spinFreq->value() );
163 rpTmp.setHasEndDate( !chkNoEnd->isChecked() ); 175 rpTmp.setHasEndDate( !chkNoEnd->isChecked() );
164 if ( rpTmp.hasEndDate() ) { 176 if ( rpTmp.hasEndDate() ) {
165 rpTmp.setEndDate( end ); 177 rpTmp.setEndDate( end );
166 } 178 }
167 // timestamp it... 179 // timestamp it...
168 rpTmp.setCreateTime( time( NULL ) ); 180 rpTmp.setCreateTime( time( NULL ) );
169 return rpTmp; 181 return rpTmp;
170} 182}
171QDate ORecurranceWidget::endDate()const { 183QDate ORecurranceWidget::endDate()const {
172 return end; 184 return end;
173} 185}
174void ORecurranceWidget::slotSetRType(int rtype) { 186void ORecurranceWidget::slotSetRType(int rtype) {
175 // now call the right function based on the type... 187 // now call the right function based on the type...
176 currInterval = static_cast<repeatButtons>(rtype); 188 currInterval = static_cast<repeatButtons>(rtype);
177 switch ( currInterval ) { 189 switch ( currInterval ) {
178 case None: 190 case None:
179 setupNone(); 191 setupNone();
180 break; 192 break;
181 case Day: 193 case Day:
182 setupDaily(); 194 setupDaily();
183 break; 195 break;
184 case Week: 196 case Week:
185 setupWeekly(); 197 setupWeekly();
186 slotWeekLabel(); 198 slotWeekLabel();
187 break; 199 break;
188 case Month: 200 case Month:
189 setupMonthly(); 201 setupMonthly();
190 cmdExtra2->setOn( TRUE ); 202 cmdExtra2->setOn( TRUE );
191 slotMonthLabel( 1 ); 203 slotMonthLabel( 1 );
192 break; 204 break;
193 case Year: 205 case Year:
194 setupYearly(); 206 setupYearly();
195 break; 207 break;
196 } 208 }
197} 209}
198void ORecurranceWidget::endDateChanged(int y, int m, int d) { 210void ORecurranceWidget::endDateChanged(int y, int m, int d) {
199 end.setYMD( y, m, d ); 211 end.setYMD( y, m, d );
200 if ( end < start ) 212 if ( end < start )
201 end = start; 213 end = start;
202 cmdEnd->setText( TimeString::shortDate( end ) ); 214 cmdEnd->setText( TimeString::shortDate( end ) );
203 repeatPicker->setDate( end.year(), end.month(), end.day() ); 215 repeatPicker->setDate( end.year(), end.month(), end.day() );
204} 216}
205void ORecurranceWidget::slotNoEnd( bool unused) { 217void ORecurranceWidget::slotNoEnd( bool unused) {
206 // if the item was toggled, then go ahead and set it to the maximum date 218 // if the item was toggled, then go ahead and set it to the maximum date
207 if ( unused ) { 219 if ( unused ) {
208 end.setYMD( 3000, 12, 31 ); 220 end.setYMD( 3000, 12, 31 );
209 cmdEnd->setText( tr("No End Date") ); 221 cmdEnd->setText( tr("No End Date") );
210 } else { 222 } else {
211 end = start; 223 end = start;
212 cmdEnd->setText( TimeString::shortDate(end) ); 224 cmdEnd->setText( TimeString::shortDate(end) );
213 } 225 }
214} 226}
215void ORecurranceWidget::setupRepeatLabel( const QString& s) { 227void ORecurranceWidget::setupRepeatLabel( const QString& s) {
216 lblVar1->setText( s ); 228 lblVar1->setText( s );
217} 229}
218void ORecurranceWidget::setupRepeatLabel( int x) { 230void ORecurranceWidget::setupRepeatLabel( int x) {
219 // change the spelling based on the value of x 231 // change the spelling based on the value of x
220 QString strVar2; 232 QString strVar2;
221 233
222 if ( x > 1 ) 234 if ( x > 1 )
223 lblVar1->show(); 235 lblVar1->show();
224 else 236 else
225 lblVar1->hide(); 237 lblVar1->hide();
226 238
227 switch ( currInterval ) { 239 switch ( currInterval ) {
228 case None: 240 case None:
229 break; 241 break;
230 case Day: 242 case Day:
231 if ( x > 1 ) 243 if ( x > 1 )
232 strVar2 = tr( "days" ); 244 strVar2 = tr( "days" );
233 else 245 else
234 strVar2 = tr( "day" ); 246 strVar2 = tr( "day" );
235 break; 247 break;
236 case Week: 248 case Week:
237 if ( x > 1 ) 249 if ( x > 1 )
238 strVar2 = tr( "weeks" ); 250 strVar2 = tr( "weeks" );
239 else 251 else
240 strVar2 = tr( "week" ); 252 strVar2 = tr( "week" );
241 break; 253 break;
242 case Month: 254 case Month:
243 if ( x > 1 ) 255 if ( x > 1 )
244 strVar2 = tr( "months" ); 256 strVar2 = tr( "months" );
245 else 257 else
246 strVar2 = tr( "month" ); 258 strVar2 = tr( "month" );
247 break; 259 break;
248 case Year: 260 case Year:
249 if ( x > 1 ) 261 if ( x > 1 )
250 strVar2 = tr( "years" ); 262 strVar2 = tr( "years" );
251 else 263 else
252 strVar2 = tr( "year" ); 264 strVar2 = tr( "year" );
253 break; 265 break;
254 } 266 }
255 if ( !strVar2.isNull() ) 267 if ( !strVar2.isNull() )
256 lblVar2->setText( strVar2 ); 268 lblVar2->setText( strVar2 );
257} 269}
258void ORecurranceWidget::slotWeekLabel() { 270void ORecurranceWidget::slotWeekLabel() {
259 QString str; 271 QString str;
260 QListIterator<QToolButton> it( listExtra ); 272 QListIterator<QToolButton> it( listExtra );
261 unsigned int i; 273 unsigned int i;
262 unsigned int keepMe; 274 unsigned int keepMe;
263 bool bNeedCarriage = FALSE; 275 bool bNeedCarriage = FALSE;
264 // don't do something we'll regret!!! 276 // don't do something we'll regret!!!
265 if ( currInterval != Week ) 277 if ( currInterval != Week )
266 return; 278 return;
267 279
268 if ( startWeekOnMonday ) 280 if ( startWeekOnMonday )
269 keepMe = start.dayOfWeek() - 1; 281 keepMe = start.dayOfWeek() - 1;
270 else 282 else
271 keepMe = start.dayOfWeek() % 7; 283 keepMe = start.dayOfWeek() % 7;
272 284
273 QStringList list; 285 QStringList list;
274 for ( i = 0; *it; ++it, i++ ) { 286 for ( i = 0; *it; ++it, i++ ) {
275 // a crazy check, if you are repeating weekly, the current day 287 // a crazy check, if you are repeating weekly, the current day
276 // must be selected!!! 288 // must be selected!!!
277 if ( i == keepMe && !( (*it)->isOn() ) ) 289 if ( i == keepMe && !( (*it)->isOn() ) )
278 (*it)->setOn( TRUE ); 290 (*it)->setOn( TRUE );
279 if ( (*it)->isOn() ) { 291 if ( (*it)->isOn() ) {
280 if ( startWeekOnMonday ) 292 if ( startWeekOnMonday )
281 list.append( dayLabel[i] ); 293 list.append( dayLabel[i] );
282 else { 294 else {
283 if ( i == 0 ) 295 if ( i == 0 )
284 list.append( dayLabel[6] ); 296 list.append( dayLabel[6] );
285 else 297 else
286 list.append( dayLabel[i - 1] ); 298 list.append( dayLabel[i - 1] );
287 } 299 }
288 } 300 }
289 } 301 }
290 QStringList::Iterator itStr; 302 QStringList::Iterator itStr;
291 for ( i = 0, itStr = list.begin(); itStr != list.end(); ++itStr, i++ ) { 303 for ( i = 0, itStr = list.begin(); itStr != list.end(); ++itStr, i++ ) {
292 if ( i == 3 ) 304 if ( i == 3 )
293 bNeedCarriage = TRUE; 305 bNeedCarriage = TRUE;
294 else 306 else
295 bNeedCarriage = FALSE; 307 bNeedCarriage = FALSE;
296 if ( str.isNull() ) 308 if ( str.isNull() )
297 str = *itStr; 309 str = *itStr;
298 else if ( i == list.count() - 1 ) { 310 else if ( i == list.count() - 1 ) {
299 if ( i < 2 ) 311 if ( i < 2 )
300 str += tr(" and ") + *itStr; 312 str += tr(" and ") + *itStr;
301 else { 313 else {
302 if ( bNeedCarriage ) 314 if ( bNeedCarriage )
303 str += tr( ",\nand " ) + *itStr; 315 str += tr( ",\nand " ) + *itStr;
304 else 316 else
305 str += tr( ", and " ) + *itStr; 317 str += tr( ", and " ) + *itStr;
306 } 318 }
307 } else { 319 } else {
308 if ( bNeedCarriage ) 320 if ( bNeedCarriage )
309 str += ",\n" + *itStr; 321 str += ",\n" + *itStr;
310 else 322 else
311 str += ", " + *itStr; 323 str += ", " + *itStr;
312 } 324 }
313 } 325 }
314 str = str.prepend( "on " ); 326 str = str.prepend( "on " );
315 lblWeekVar->setText( str ); 327 lblWeekVar->setText( str );
316} 328}
317void ORecurranceWidget::slotMonthLabel(int type) { 329void ORecurranceWidget::slotMonthLabel(int type) {
318 QString str; 330 QString str;
319 if ( currInterval != Month || type > 1 ) 331 if ( currInterval != Month || type > 1 )
320 return; 332 return;
321 if ( type == 1 ) 333 if ( type == 1 )
322 str = strMonthDateTemplate.arg( numberPlacing(start.day()) ); 334 str = strMonthDateTemplate.arg( numberPlacing(start.day()) );
323 else 335 else
324 str = strMonthDayTemplate.arg( numberPlacing(week(start))) 336 str = strMonthDayTemplate.arg( numberPlacing(week(start)))
325 .arg( dayLabel[start.dayOfWeek() - 1] ); 337 .arg( dayLabel[start.dayOfWeek() - 1] );
326 lblRepeat->setText( str ); 338 lblRepeat->setText( str );
327} 339}
328void ORecurranceWidget::slotChangeStartOfWeek( bool onMonday ) { 340void ORecurranceWidget::slotChangeStartOfWeek( bool onMonday ) {
329 startWeekOnMonday = onMonday; 341 startWeekOnMonday = onMonday;
330 // we need to make this unintrusive as possible... 342 // we need to make this unintrusive as possible...
331 int saveSpin = spinFreq->value(); 343 int saveSpin = spinFreq->value();
332 char days = 0; 344 char days = 0;
333 int day; 345 int day;
334 QListIterator<QToolButton> itExtra( listExtra ); 346 QListIterator<QToolButton> itExtra( listExtra );
335 for ( day = 1; *itExtra; ++itExtra, day = day << 1 ) { 347 for ( day = 1; *itExtra; ++itExtra, day = day << 1 ) {
336 if ( (*itExtra)->isOn() ) { 348 if ( (*itExtra)->isOn() ) {
337 if ( !startWeekOnMonday ) 349 if ( !startWeekOnMonday )
338 days |= day; 350 days |= day;
339 else { 351 else {
340 if ( day == 1 ) 352 if ( day == 1 )
341 days |= ORecur::SUN; 353 days |= ORecur::SUN;
342 else 354 else
343 days |= day >> 1; 355 days |= day >> 1;
344 } 356 }
345 } 357 }
346 } 358 }
347 setupWeekly(); 359 setupWeekly();
348 spinFreq->setValue( saveSpin ); 360 spinFreq->setValue( saveSpin );
349 int buttons; 361 int buttons;
350 for ( day = 0x01, buttons = 0; buttons < 7; 362 for ( day = 0x01, buttons = 0; buttons < 7;
351 day = day << 1, buttons++ ) { 363 day = day << 1, buttons++ ) {
352 if ( days & day ) { 364 if ( days & day ) {
353 if ( startWeekOnMonday ) 365 if ( startWeekOnMonday )
354 fraExtra->setButton( buttons ); 366 fraExtra->setButton( buttons );
355 else { 367 else {
356 if ( buttons == 7 ) 368 if ( buttons == 7 )
357 fraExtra->setButton( 0 ); 369 fraExtra->setButton( 0 );
358 else 370 else
359 fraExtra->setButton( buttons + 1 ); 371 fraExtra->setButton( buttons + 1 );
360 } 372 }
361 } 373 }
362 } 374 }
363 slotWeekLabel(); 375 slotWeekLabel();
364} 376}
365void ORecurranceWidget::setupNone() { 377void ORecurranceWidget::setupNone() {
366 lblRepeat->setText( tr("No Repeat") ); 378 lblRepeat->setText( tr("No Repeat") );
367 lblVar1->hide(); 379 lblVar1->hide();
368 lblVar2->hide(); 380 lblVar2->hide();
369 hideExtras(); 381 hideExtras();
370 cmdEnd->hide(); 382 cmdEnd->hide();
371 lblFreq->hide(); 383 lblFreq->hide();
372 lblEvery->hide(); 384 lblEvery->hide();
373 lblFreq->hide(); 385 lblFreq->hide();
374 spinFreq->hide(); 386 spinFreq->hide();
375 lblEnd->hide(); 387 lblEnd->hide();
376 lblWeekVar->hide(); 388 lblWeekVar->hide();
377} 389}
378void ORecurranceWidget::setupDaily() { 390void ORecurranceWidget::setupDaily() {
379 hideExtras(); 391 hideExtras();
380 lblWeekVar->hide(); 392 lblWeekVar->hide();
381 spinFreq->setValue( 1 ); 393 spinFreq->setValue( 1 );
382 lblFreq->setText( tr("day(s)") ); 394 lblFreq->setText( tr("day(s)") );
383 lblVar2->show(); 395 lblVar2->show();
384 showRepeatStuff(); 396 showRepeatStuff();
385 lblRepeat->setText( strDayTemplate ); 397 lblRepeat->setText( strDayTemplate );
386 setupRepeatLabel( 1 ); 398 setupRepeatLabel( 1 );
387} 399}
388void ORecurranceWidget::setupWeekly() { 400void ORecurranceWidget::setupWeekly() {
389// reshow the buttons... 401// reshow the buttons...
390 fraExtra->setTitle( tr("Repeat On") ); 402 fraExtra->setTitle( tr("Repeat On") );
391 fraExtra->setExclusive( FALSE ); 403 fraExtra->setExclusive( FALSE );
392 fraExtra->show(); 404 fraExtra->show();
393 if ( startWeekOnMonday ) { 405 if ( startWeekOnMonday ) {
394 cmdExtra1->setText( tr("Mon") ); 406 cmdExtra1->setText( tr("Mon") );
395 cmdExtra2->setText( tr("Tue") ); 407 cmdExtra2->setText( tr("Tue") );
396 cmdExtra3->setText( tr("Wed") ); 408 cmdExtra3->setText( tr("Wed") );
397 cmdExtra4->setText( tr("Thu") ); 409 cmdExtra4->setText( tr("Thu") );
398 cmdExtra5->setText( tr("Fri") ); 410 cmdExtra5->setText( tr("Fri") );
399 cmdExtra6->setText( tr("Sat") ); 411 cmdExtra6->setText( tr("Sat") );
400 cmdExtra7->setText( tr("Sun") ); 412 cmdExtra7->setText( tr("Sun") );
401 } else { 413 } else {
402 cmdExtra1->setText( tr("Sun") ); 414 cmdExtra1->setText( tr("Sun") );
403 cmdExtra2->setText( tr("Mon") ); 415 cmdExtra2->setText( tr("Mon") );
404 cmdExtra3->setText( tr("Tue") ); 416 cmdExtra3->setText( tr("Tue") );
405 cmdExtra4->setText( tr("Wed") ); 417 cmdExtra4->setText( tr("Wed") );
406 cmdExtra5->setText( tr("Thu") ); 418 cmdExtra5->setText( tr("Thu") );
407 cmdExtra6->setText( tr("Fri") ); 419 cmdExtra6->setText( tr("Fri") );
408 cmdExtra7->setText( tr("Sat") ); 420 cmdExtra7->setText( tr("Sat") );
409 } 421 }
410 // I hope clustering these improve performance.... 422 // I hope clustering these improve performance....
411 cmdExtra1->setOn( FALSE ); 423 cmdExtra1->setOn( FALSE );
412 cmdExtra2->setOn( FALSE ); 424 cmdExtra2->setOn( FALSE );
413 cmdExtra3->setOn( FALSE ); 425 cmdExtra3->setOn( FALSE );
414 cmdExtra4->setOn( FALSE ); 426 cmdExtra4->setOn( FALSE );
415 cmdExtra5->setOn( FALSE ); 427 cmdExtra5->setOn( FALSE );
416 cmdExtra6->setOn( FALSE ); 428 cmdExtra6->setOn( FALSE );
417 cmdExtra7->setOn( FALSE ); 429 cmdExtra7->setOn( FALSE );
418 430
419 cmdExtra1->show(); 431 cmdExtra1->show();
420 cmdExtra2->show(); 432 cmdExtra2->show();
421 cmdExtra3->show(); 433 cmdExtra3->show();
422 cmdExtra4->show(); 434 cmdExtra4->show();
423 cmdExtra5->show(); 435 cmdExtra5->show();
424 cmdExtra6->show(); 436 cmdExtra6->show();
425 cmdExtra7->show(); 437 cmdExtra7->show();
426 438
427 lblWeekVar->show(); 439 lblWeekVar->show();
428 spinFreq->setValue( 1 ); 440 spinFreq->setValue( 1 );
429 // might as well set the day too... 441 // might as well set the day too...
430 if ( startWeekOnMonday ) { 442 if ( startWeekOnMonday ) {
431 fraExtra->setButton( start.dayOfWeek() - 1 ); 443 fraExtra->setButton( start.dayOfWeek() - 1 );
432 } else { 444 } else {
433 fraExtra->setButton( start.dayOfWeek() % 7 ); 445 fraExtra->setButton( start.dayOfWeek() % 7 );
434 } 446 }
435 lblFreq->setText( tr("week(s)") ); 447 lblFreq->setText( tr("week(s)") );
436 lblVar2->show(); 448 lblVar2->show();
437 showRepeatStuff(); 449 showRepeatStuff();
438 setupRepeatLabel( 1 ); 450 setupRepeatLabel( 1 );
439} 451}
440void ORecurranceWidget::setupMonthly() { 452void ORecurranceWidget::setupMonthly() {
441 hideExtras(); 453 hideExtras();
442 lblWeekVar->hide(); 454 lblWeekVar->hide();
443 fraExtra->setTitle( tr("Repeat By") ); 455 fraExtra->setTitle( tr("Repeat By") );
444 fraExtra->setExclusive( TRUE ); 456 fraExtra->setExclusive( TRUE );
445 fraExtra->show(); 457 fraExtra->show();
446 cmdExtra1->setText( tr("Day") ); 458 cmdExtra1->setText( tr("Day") );
447 cmdExtra1->show(); 459 cmdExtra1->show();
448 cmdExtra2->setText( tr("Date") ); 460 cmdExtra2->setText( tr("Date") );
449 cmdExtra2->show(); 461 cmdExtra2->show();
450 spinFreq->setValue( 1 ); 462 spinFreq->setValue( 1 );
451 lblFreq->setText( tr("month(s)") ); 463 lblFreq->setText( tr("month(s)") );
452 lblVar2->show(); 464 lblVar2->show();
453 showRepeatStuff(); 465 showRepeatStuff();
454 setupRepeatLabel( 1 ); 466 setupRepeatLabel( 1 );
455} 467}
456void ORecurranceWidget::setupYearly() { 468void ORecurranceWidget::setupYearly() {
457hideExtras(); 469hideExtras();
458 lblWeekVar->hide(); 470 lblWeekVar->hide();
459 spinFreq->setValue( 1 ); 471 spinFreq->setValue( 1 );
460 lblFreq->setText( tr("year(s)") ); 472 lblFreq->setText( tr("year(s)") );
461 lblFreq->show(); 473 lblFreq->show();
462 lblFreq->show(); 474 lblFreq->show();
463 showRepeatStuff(); 475 showRepeatStuff();
464 lblVar2->show(); 476 lblVar2->show();
465 QString strEvery = strYearTemplate.arg( start.monthName(start.month()) ).arg( numberPlacing(start.day()) ); 477 QString strEvery = strYearTemplate.arg( start.monthName(start.month()) ).arg( numberPlacing(start.day()) );
466 lblRepeat->setText( strEvery ); 478 lblRepeat->setText( strEvery );
467 setupRepeatLabel( 1 ); 479 setupRepeatLabel( 1 );
468 480
469} 481}
470void ORecurranceWidget::init() { 482void ORecurranceWidget::init() {
471 QPopupMenu *m1 = new QPopupMenu( this ); 483 QPopupMenu *m1 = new QPopupMenu( this );
472 repeatPicker = new DateBookMonth( m1, 0, TRUE ); 484 repeatPicker = new DateBookMonth( m1, 0, TRUE );
473 m1->insertItem( repeatPicker ); 485 m1->insertItem( repeatPicker );
474 cmdEnd->setPopup( m1 ); 486 cmdEnd->setPopup( m1 );
475 cmdEnd->setPopupDelay( 0 ); 487 cmdEnd->setPopupDelay( 0 );
476 488
477 QObject::connect( repeatPicker, SIGNAL(dateClicked(int, int, int)), 489 QObject::connect( repeatPicker, SIGNAL(dateClicked(int, int, int)),
478 this, SLOT(endDateChanged(int, int, int)) ); 490 this, SLOT(endDateChanged(int, int, int)) );
479 QObject::connect( qApp, SIGNAL(weekChanged(bool)), 491 QObject::connect( qApp, SIGNAL(weekChanged(bool)),
480 this, SLOT(slotChangeStartOfWeek(bool)) ); 492 this, SLOT(slotChangeStartOfWeek(bool)) );
481 493
482 listRTypeButtons.setAutoDelete( TRUE ); 494 listRTypeButtons.setAutoDelete( TRUE );
483 listRTypeButtons.append( cmdNone ); 495 listRTypeButtons.append( cmdNone );
484 listRTypeButtons.append( cmdDay ); 496 listRTypeButtons.append( cmdDay );
485 listRTypeButtons.append( cmdWeek ); 497 listRTypeButtons.append( cmdWeek );
486 listRTypeButtons.append( cmdMonth ); 498 listRTypeButtons.append( cmdMonth );
487 listRTypeButtons.append( cmdYear ); 499 listRTypeButtons.append( cmdYear );
488 500
489 listExtra.setAutoDelete( TRUE ); 501 listExtra.setAutoDelete( TRUE );
490 listExtra.append( cmdExtra1 ); 502 listExtra.append( cmdExtra1 );
491 listExtra.append( cmdExtra2 ); 503 listExtra.append( cmdExtra2 );
492 listExtra.append( cmdExtra3 ); 504 listExtra.append( cmdExtra3 );
493 listExtra.append( cmdExtra4 ); 505 listExtra.append( cmdExtra4 );
494 listExtra.append( cmdExtra5 ); 506 listExtra.append( cmdExtra5 );
495 listExtra.append( cmdExtra6 ); 507 listExtra.append( cmdExtra6 );
496 listExtra.append( cmdExtra7 ); 508 listExtra.append( cmdExtra7 );
497} 509}
498void ORecurranceWidget::hideExtras() { 510void ORecurranceWidget::hideExtras() {
diff --git a/libopie/orecurrancewidget.h b/libopie/orecurrancewidget.h
index f2d7f87..4a8dd08 100644
--- a/libopie/orecurrancewidget.h
+++ b/libopie/orecurrancewidget.h
@@ -1,68 +1,72 @@
1/* 1/*
2 * GPL and based on the widget from TT 2 * GPL and based on the widget from TT
3 */ 3 */
4 4
5#ifndef OPIE_RECURRANCE_WIDGET_H 5#ifndef OPIE_RECURRANCE_WIDGET_H
6#define OPIE_RECURRANCE_WIDGET_H 6#define OPIE_RECURRANCE_WIDGET_H
7 7
8#include <qlist.h> 8#include <qlist.h>
9#include <qtoolbutton.h> 9#include <qtoolbutton.h>
10#include <qcheckbox.h> 10#include <qcheckbox.h>
11#include <qdatetime.h> 11#include <qdatetime.h>
12#include <qbuttongroup.h> 12#include <qbuttongroup.h>
13 13
14#include <qpe/datebookmonth.h> 14#include <qpe/datebookmonth.h>
15 15
16#include "orecurrancebase.h" 16#include "orecurrancebase.h"
17#include <opie/orecur.h> 17#include <opie/orecur.h>
18 18
19// FIXME spelling!!!! -zecke
19class ORecurranceWidget : public ORecurranceBase { 20class ORecurranceWidget : public ORecurranceBase {
20 Q_OBJECT 21 Q_OBJECT
21public: 22public:
22 ORecurranceWidget( bool startOnMonday, 23 ORecurranceWidget( bool startOnMonday,
23 const QDate& start, QWidget* parent = 0, 24 const QDate& start, QWidget* parent = 0,
24 const char* name = 0, bool modal = TRUE, 25 const char* name = 0, bool modal = TRUE,
25 WFlags fl = 0 ); 26 WFlags fl = 0 );
26 ORecurranceWidget( bool startOnMonday, 27 ORecurranceWidget( bool startOnMonday,
27 const ORecur& rp, const QDate& start, 28 const ORecur& rp, const QDate& start,
28 QWidget* parent = 0, const char* name =0, 29 QWidget* parent = 0, const char* name =0,
29 bool modal = TRUE, WFlags = 0 ); 30 bool modal = TRUE, WFlags = 0 );
30 ~ORecurranceWidget(); 31 ~ORecurranceWidget();
31 ORecur recurrance()const; 32 ORecur recurrence()const;
32 QDate endDate()const; 33 QDate endDate()const;
33 34
34public slots: 35public slots:
35 void slotSetRType( int ); 36 void slotSetRType( int );
36 void endDateChanged( int, int, int ); 37 void endDateChanged( int, int, int );
37 void slotNoEnd( bool unused ); 38 void slotNoEnd( bool unused );
39 void setStartDate( const QDate& );
40 void setRecurrence( const ORecur& recur, const QDate& start );
41 void setRecurrence( const ORecur& recur );
38 42
39private slots: 43private slots:
40 void setupRepeatLabel( const QString& ); 44 void setupRepeatLabel( const QString& );
41 void setupRepeatLabel( int ); 45 void setupRepeatLabel( int );
42 void slotWeekLabel(); 46 void slotWeekLabel();
43 void slotMonthLabel( int ); 47 void slotMonthLabel( int );
44 void slotChangeStartOfWeek( bool onMonday ); 48 void slotChangeStartOfWeek( bool onMonday );
45 49
46private: 50private:
47 void setupNone(); 51 void setupNone();
48 void setupDaily(); 52 void setupDaily();
49 void setupWeekly(); 53 void setupWeekly();
50 void setupMonthly(); 54 void setupMonthly();
51 void setupYearly(); 55 void setupYearly();
52 56
53 enum repeatButtons { None, Day, Week, Month, Year }; 57 enum repeatButtons { None, Day, Week, Month, Year };
54 void init(); 58 void init();
55 void hideExtras(); 59 void hideExtras();
56 void showRepeatStuff(); 60 void showRepeatStuff();
57 61
58 QList<QToolButton> listRTypeButtons; 62 QList<QToolButton> listRTypeButtons;
59 QList<QToolButton> listExtra; 63 QList<QToolButton> listExtra;
60 QDate start; // only used in one spot... 64 QDate start; // only used in one spot...
61 QDate end; 65 QDate end;
62 repeatButtons currInterval; 66 repeatButtons currInterval;
63 bool startWeekOnMonday : 1; 67 bool startWeekOnMonday : 1;
64 DateBookMonth *repeatPicker; 68 DateBookMonth *repeatPicker;
65 69
66}; 70};
67 71
68#endif 72#endif