summaryrefslogtreecommitdiff
path: root/library
authorerik <erik>2007-01-10 16:52:08 (UTC)
committer erik <erik>2007-01-10 16:52:08 (UTC)
commit51bd5e8d542372ad54898ce642fe9b82b8ba83f3 (patch) (unidiff)
treef2d6649a26347239e992082b22deca343939fc33 /library
parent3c4c894bcdb1e49ce4d3e8167c8a21b1c617037d (diff)
downloadopie-51bd5e8d542372ad54898ce642fe9b82b8ba83f3.zip
opie-51bd5e8d542372ad54898ce642fe9b82b8ba83f3.tar.gz
opie-51bd5e8d542372ad54898ce642fe9b82b8ba83f3.tar.bz2
BUG: If the global category is checked in the category dialog the
'New Category' entry is still in local application scope. This means that the 'New Category' entry is in the wrong scope and all hell breaks loose. Actually the user will probably get confused that the category they are wanting to change is not in the right scope. FIX: Check to see that the global checkbox is checked before trying to add the new category. NOTE: This patch was originally submitted by Paul Eggleton (Blue Lightning). Thanks for the fix!
Diffstat (limited to 'library') (more/less context) (ignore whitespace changes)
-rw-r--r--library/categoryedit_p.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/library/categoryedit_p.cpp b/library/categoryedit_p.cpp
index 14ac2e1..ee0da22 100644
--- a/library/categoryedit_p.cpp
+++ b/library/categoryedit_p.cpp
@@ -64,134 +64,137 @@ CategoryEdit::CategoryEdit( const QArray<int> &recCats,
64 d = 0; 64 d = 0;
65 setCategories( recCats, appName, visibleName ); 65 setCategories( recCats, appName, visibleName );
66} 66}
67 67
68void CategoryEdit::setCategories( const QArray<int> &recCats, 68void CategoryEdit::setCategories( const QArray<int> &recCats,
69 const QString &appName, const QString &visibleName ) 69 const QString &appName, const QString &visibleName )
70{ 70{
71 if ( !d ) 71 if ( !d )
72 d = new CategoryEditPrivate( (QWidget*)parent(), name() ); 72 d = new CategoryEditPrivate( (QWidget*)parent(), name() );
73 d->mStrApp = appName; 73 d->mStrApp = appName;
74 d->mVisible = visibleName; 74 d->mVisible = visibleName;
75 75
76 QStringList appCats = d->mCategories.labels( d->mStrApp ); 76 QStringList appCats = d->mCategories.labels( d->mStrApp );
77 QArray<int> cats = d->mCategories.ids(d->mStrApp, appCats); 77 QArray<int> cats = d->mCategories.ids(d->mStrApp, appCats);
78 lvView->clear(); 78 lvView->clear();
79 79
80 QStringList::ConstIterator it; 80 QStringList::ConstIterator it;
81 int i, j; 81 int i, j;
82 for ( i = 0, it = appCats.begin(); it != appCats.end(); i++, ++it ) { 82 for ( i = 0, it = appCats.begin(); it != appCats.end(); i++, ++it ) {
83 QCheckListItem *chk; 83 QCheckListItem *chk;
84 chk = new QCheckListItem( lvView, (*it), QCheckListItem::CheckBox ); 84 chk = new QCheckListItem( lvView, (*it), QCheckListItem::CheckBox );
85 if ( !d->mCategories.isGlobal((*it)) ) 85 if ( !d->mCategories.isGlobal((*it)) )
86 chk->setText( 1, tr(d->mVisible) ); 86 chk->setText( 1, tr(d->mVisible) );
87 else 87 else
88 chk->setText( 1, tr("All") ); 88 chk->setText( 1, tr("All") );
89 // Is this record using this category, then we should check it 89 // Is this record using this category, then we should check it
90 for ( j = 0; j < int(recCats.count()); j++ ) { 90 for ( j = 0; j < int(recCats.count()); j++ ) {
91 if ( cats[i] == recCats[j] ) { 91 if ( cats[i] == recCats[j] ) {
92 chk->setOn( true ); 92 chk->setOn( true );
93 break; 93 break;
94 } 94 }
95 } 95 }
96 } 96 }
97 lvView->setSorting( 0, TRUE ); 97 lvView->setSorting( 0, TRUE );
98 lvView->sort(); 98 lvView->sort();
99 if ( lvView->childCount() < 1 ) 99 if ( lvView->childCount() < 1 )
100 txtCat->setEnabled( FALSE ); 100 txtCat->setEnabled( FALSE );
101 else { 101 else {
102 lvView->setSelected( lvView->firstChild(), true ); 102 lvView->setSelected( lvView->firstChild(), true );
103 } 103 }
104} 104}
105 105
106CategoryEdit::~CategoryEdit() 106CategoryEdit::~CategoryEdit()
107{ 107{
108 if ( d ) 108 if ( d )
109 delete d; 109 delete d;
110} 110}
111 111
112void CategoryEdit::slotSetText( QListViewItem *selected ) 112void CategoryEdit::slotSetText( QListViewItem *selected )
113{ 113{
114 d->editItem = selected; 114 d->editItem = selected;
115 if ( !d->editItem ) 115 if ( !d->editItem )
116 return; 116 return;
117 txtCat->setText( d->editItem->text(0) ); 117 txtCat->setText( d->editItem->text(0) );
118 txtCat->setEnabled( true ); 118 txtCat->setEnabled( true );
119 if ( d->editItem->text(1) == tr("All") ) 119 if ( d->editItem->text(1) == tr("All") )
120 chkGlobal->setChecked( true ); 120 chkGlobal->setChecked( true );
121 else 121 else
122 chkGlobal->setChecked( false ); 122 chkGlobal->setChecked( false );
123} 123}
124 124
125void CategoryEdit::slotAdd() 125void CategoryEdit::slotAdd()
126{ 126{
127 QString name = tr( "New Category" ); 127 QString name = tr( "New Category" );
128 bool insertOk = FALSE; 128 int uid = 0;
129 int num = 0; 129 int num = 0;
130 while ( !insertOk ) { 130 while ( !uid ) {
131 if ( num++ > 0 ) 131 if ( num++ > 0 )
132 name = tr("New Category ") + QString::number(num); 132 name = tr("New Category ") + QString::number(num);
133 insertOk = d->mCategories.addCategory( d->mStrApp, name ); 133 if ( chkGlobal->isChecked() )
134 uid = d->mCategories.addGlobalCategory( name );
135 else
136 uid = d->mCategories.addCategory( d->mStrApp, name );
134 } 137 }
135 QCheckListItem *chk; 138 QCheckListItem *chk;
136 chk = new QCheckListItem( lvView, name, QCheckListItem::CheckBox ); 139 chk = new QCheckListItem( lvView, name, QCheckListItem::CheckBox );
137 if ( !chkGlobal->isChecked() ) 140 if ( !chkGlobal->isChecked() )
138 chk->setText( 1, tr(d->mVisible) ); 141 chk->setText( 1, tr(d->mVisible) );
139 else 142 else
140 chk->setText( 1, tr("All") ); 143 chk->setText( 1, tr("All") );
141 144
142 lvView->setSelected( chk, TRUE ); 145 lvView->setSelected( chk, TRUE );
143 txtCat->selectAll(); 146 txtCat->selectAll();
144 txtCat->setFocus(); 147 txtCat->setFocus();
145} 148}
146 149
147void CategoryEdit::slotRemove() 150void CategoryEdit::slotRemove()
148{ 151{
149 d->editItem = lvView->selectedItem(); 152 d->editItem = lvView->selectedItem();
150 if ( d->editItem ) { 153 if ( d->editItem ) {
151 QListViewItem *sibling = d->editItem->nextSibling(); 154 QListViewItem *sibling = d->editItem->nextSibling();
152 155
153 d->mCategories.removeCategory( d->mStrApp, d->editItem->text(0) ); 156 d->mCategories.removeCategory( d->mStrApp, d->editItem->text(0) );
154 157
155 delete d->editItem; 158 delete d->editItem;
156 d->editItem = 0; 159 d->editItem = 0;
157 160
158 if ( sibling ) 161 if ( sibling )
159 lvView->setSelected( sibling, TRUE ); 162 lvView->setSelected( sibling, TRUE );
160 } 163 }
161 if ( lvView->childCount() < 1 ) { 164 if ( lvView->childCount() < 1 ) {
162 txtCat->clear(); 165 txtCat->clear();
163 txtCat->setEnabled( FALSE ); 166 txtCat->setEnabled( FALSE );
164 } 167 }
165} 168}
166 169
167void CategoryEdit::slotSetGlobal( bool isChecked ) 170void CategoryEdit::slotSetGlobal( bool isChecked )
168{ 171{
169 if ( d->editItem ) { 172 if ( d->editItem ) {
170 if ( isChecked ) 173 if ( isChecked )
171 d->editItem->setText( 1, tr("All") ); 174 d->editItem->setText( 1, tr("All") );
172 else 175 else
173 d->editItem->setText( 1, tr(d->mVisible) ); 176 d->editItem->setText( 1, tr(d->mVisible) );
174 177
175 d->mCategories.setGlobal( d->mStrApp, d->editItem->text( 0 ), isChecked ); 178 d->mCategories.setGlobal( d->mStrApp, d->editItem->text( 0 ), isChecked );
176 } 179 }
177} 180}
178 181
179void CategoryEdit::slotTextChanged( const QString &strNew ) 182void CategoryEdit::slotTextChanged( const QString &strNew )
180{ 183{
181 if ( d->editItem ) { 184 if ( d->editItem ) {
182 if ( chkGlobal->isChecked() ) 185 if ( chkGlobal->isChecked() )
183 d->mCategories.renameGlobalCategory( d->editItem->text(0), strNew ); 186 d->mCategories.renameGlobalCategory( d->editItem->text(0), strNew );
184 else 187 else
185 d->mCategories.renameCategory( d->mStrApp, d->editItem->text(0), strNew ); 188 d->mCategories.renameCategory( d->mStrApp, d->editItem->text(0), strNew );
186 d->editItem->setText( 0, strNew ); 189 d->editItem->setText( 0, strNew );
187 } 190 }
188} 191}
189 192
190QArray<int> CategoryEdit::newCategories() 193QArray<int> CategoryEdit::newCategories()
191{ 194{
192 QArray<int> a; 195 QArray<int> a;
193 if ( d ) { 196 if ( d ) {
194 d->mCategories.save( categoryFileName() ); 197 d->mCategories.save( categoryFileName() );
195 QListViewItemIterator it( lvView ); 198 QListViewItemIterator it( lvView );
196 QValueList<int> l; 199 QValueList<int> l;
197 for ( ; it.current(); ++it ) { 200 for ( ; it.current(); ++it ) {