author | erik <erik> | 2007-01-10 16:52:08 (UTC) |
---|---|---|
committer | erik <erik> | 2007-01-10 16:52:08 (UTC) |
commit | 51bd5e8d542372ad54898ce642fe9b82b8ba83f3 (patch) (unidiff) | |
tree | f2d6649a26347239e992082b22deca343939fc33 /library | |
parent | 3c4c894bcdb1e49ce4d3e8167c8a21b1c617037d (diff) | |
download | opie-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!
-rw-r--r-- | library/categoryedit_p.cpp | 9 |
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 | ||
68 | void CategoryEdit::setCategories( const QArray<int> &recCats, | 68 | void 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 | ||
106 | CategoryEdit::~CategoryEdit() | 106 | CategoryEdit::~CategoryEdit() |
107 | { | 107 | { |
108 | if ( d ) | 108 | if ( d ) |
109 | delete d; | 109 | delete d; |
110 | } | 110 | } |
111 | 111 | ||
112 | void CategoryEdit::slotSetText( QListViewItem *selected ) | 112 | void 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 | ||
125 | void CategoryEdit::slotAdd() | 125 | void 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 | ||
147 | void CategoryEdit::slotRemove() | 150 | void 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 | ||
167 | void CategoryEdit::slotSetGlobal( bool isChecked ) | 170 | void 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 | ||
179 | void CategoryEdit::slotTextChanged( const QString &strNew ) | 182 | void 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 | ||
190 | QArray<int> CategoryEdit::newCategories() | 193 | QArray<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 ) { |