author | mickeyl <mickeyl> | 2004-01-04 14:22:59 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2004-01-04 14:22:59 (UTC) |
commit | 5c4c2a789c19e727bb9ca323ea1fec1b7d1bd057 (patch) (unidiff) | |
tree | c2e1b4a090ca53efd3b3e0c20d12a633e01470d4 /inputmethods | |
parent | 84f039ef3799c5310a4f94057b9d76d4ee55f499 (diff) | |
download | opie-5c4c2a789c19e727bb9ca323ea1fec1b7d1bd057.zip opie-5c4c2a789c19e727bb9ca323ea1fec1b7d1bd057.tar.gz opie-5c4c2a789c19e727bb9ca323ea1fec1b7d1bd057.tar.bz2 |
more patches to multikey+applet courtesy Anton Kachalov <mouse@altlinux.ru>
-rw-r--r-- | inputmethods/multikey/configdlg.cpp | 161 | ||||
-rw-r--r-- | inputmethods/multikey/configdlg.h | 12 |
2 files changed, 83 insertions, 90 deletions
diff --git a/inputmethods/multikey/configdlg.cpp b/inputmethods/multikey/configdlg.cpp index f127d0e..d29109a 100644 --- a/inputmethods/multikey/configdlg.cpp +++ b/inputmethods/multikey/configdlg.cpp | |||
@@ -14,2 +14,3 @@ | |||
14 | 14 | ||
15 | #include <qlayout.h> | ||
15 | #include <qwidget.h> | 16 | #include <qwidget.h> |
@@ -35,3 +36,3 @@ | |||
35 | // ConfigDlg::ConfigDlg() {{{1 | 36 | // ConfigDlg::ConfigDlg() {{{1 |
36 | ConfigDlg::ConfigDlg () : QTabWidget () | 37 | ConfigDlg::ConfigDlg () : QDialog () |
37 | { | 38 | { |
@@ -46,6 +47,9 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
46 | 47 | ||
47 | QVBox *gen_box = new QVBox (this); | 48 | QVBoxLayout *base_lay = new QVBoxLayout(this); |
48 | gen_box->setMargin(3); | 49 | |
49 | addTab(gen_box, tr("General Settings")); | 50 | QTabWidget *tabs = new QTabWidget(this, "tabs"); |
50 | 51 | ||
52 | QWidget *gen_box = new QWidget(tabs, "gen_tab"); | ||
53 | QVBoxLayout *gen_lay = new QVBoxLayout(gen_box); | ||
54 | gen_lay->setMargin(3); | ||
51 | QGroupBox *map_group = new QGroupBox (2, Qt::Vertical, tr("Keymap File"), gen_box); | 55 | QGroupBox *map_group = new QGroupBox (2, Qt::Vertical, tr("Keymap File"), gen_box); |
@@ -131,3 +135,2 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
131 | // have to "+1" because the "current language" listItem... remember? | 135 | // have to "+1" because the "current language" listItem... remember? |
132 | |||
133 | connect(keymaps, SIGNAL(highlighted(int)), SLOT(setMap(int))); | 136 | connect(keymaps, SIGNAL(highlighted(int)), SLOT(setMap(int))); |
@@ -144,3 +147,3 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
144 | remove_button->setFlat(TRUE); | 147 | remove_button->setFlat(TRUE); |
145 | if (default_maps.find(QFileInfo(current_map).fileName()) != default_maps.end()) | 148 | if (keymaps->currentItem() == 0 || default_maps.find(QFileInfo(current_map).fileName()) != default_maps.end()) |
146 | remove_button->setDisabled(true); | 149 | remove_button->setDisabled(true); |
@@ -148,2 +151,4 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
148 | 151 | ||
152 | gen_lay->addWidget(map_group); | ||
153 | |||
149 | // make a box that will contain the buttons on the bottom | 154 | // make a box that will contain the buttons on the bottom |
@@ -159,5 +164,2 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
159 | 164 | ||
160 | // by connecting it after checking it, the signal isn't emmited | ||
161 | connect (pick_button, SIGNAL(clicked()), this, SLOT(pickTog())); | ||
162 | |||
163 | repeat_button = new QCheckBox(tr("Key Repeat"), other_grid); | 165 | repeat_button = new QCheckBox(tr("Key Repeat"), other_grid); |
@@ -169,3 +171,5 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
169 | } | 171 | } |
170 | connect (repeat_button, SIGNAL(clicked()), this, SLOT(repeatTog())); | 172 | |
173 | gen_lay->addWidget(other_grid); | ||
174 | tabs->addTab(gen_box, tr("General Settings")); | ||
171 | 175 | ||
@@ -175,7 +179,11 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
175 | 179 | ||
176 | QGrid *color_box = new QGrid(2, this); | 180 | QWidget *color_box = new QWidget(tabs, "color_tab"); |
177 | color_box->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed)); | 181 | |
178 | color_box->setMargin(3); | 182 | QGridLayout *color_lay = new QGridLayout(color_box); |
179 | color_box->setSpacing(3); | 183 | QGrid *color_grid = new QGrid(2, color_box); |
180 | addTab(color_box, tr("Colors")); | 184 | color_lay->setAlignment(Qt::AlignTop); |
185 | color_grid->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed)); | ||
186 | color_grid->layout()->setAlignment(Qt::AlignTop); | ||
187 | color_grid->setMargin(3); | ||
188 | color_grid->setSpacing(3); | ||
181 | 189 | ||
@@ -185,4 +193,4 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
185 | 193 | ||
186 | label = new QLabel(tr("Key Color"), color_box); | 194 | label = new QLabel(tr("Key Color"), color_grid); |
187 | keycolor_button = new QPushButton(color_box); | 195 | keycolor_button = new QPushButton(color_grid); |
188 | connect(keycolor_button, SIGNAL(clicked()), SLOT(keyColorClicked())); | 196 | connect(keycolor_button, SIGNAL(clicked()), SLOT(keyColorClicked())); |
@@ -202,4 +210,4 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
202 | 210 | ||
203 | label = new QLabel(tr("Key Pressed Color"), color_box); | 211 | label = new QLabel(tr("Key Pressed Color"), color_grid); |
204 | keycolor_pressed_button = new QPushButton(color_box); | 212 | keycolor_pressed_button = new QPushButton(color_grid); |
205 | connect(keycolor_pressed_button, SIGNAL(clicked()), SLOT(keyColorPressedClicked())); | 213 | connect(keycolor_pressed_button, SIGNAL(clicked()), SLOT(keyColorPressedClicked())); |
@@ -209,4 +217,4 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
209 | 217 | ||
210 | label = new QLabel(tr("Line Color"), color_box); | 218 | label = new QLabel(tr("Line Color"), color_grid); |
211 | keycolor_lines_button = new QPushButton(color_box); | 219 | keycolor_lines_button = new QPushButton(color_grid); |
212 | connect(keycolor_lines_button, SIGNAL(clicked()), SLOT(keyColorLinesClicked())); | 220 | connect(keycolor_lines_button, SIGNAL(clicked()), SLOT(keyColorLinesClicked())); |
@@ -217,4 +225,4 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
217 | 225 | ||
218 | label = new QLabel(tr("Text Color"), color_box); | 226 | label = new QLabel(tr("Text Color"), color_grid); |
219 | textcolor_button = new QPushButton(color_box); | 227 | textcolor_button = new QPushButton(color_grid); |
220 | connect(textcolor_button, SIGNAL(clicked()), SLOT(textColorClicked())); | 228 | connect(textcolor_button, SIGNAL(clicked()), SLOT(textColorClicked())); |
@@ -224,9 +232,12 @@ ConfigDlg::ConfigDlg () : QTabWidget () | |||
224 | 232 | ||
225 | label = new QLabel("", color_box); // a spacer so the above buttons dont expand | 233 | label = new QLabel("", color_grid); // a spacer so the above buttons dont expand |
226 | label->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding)); | 234 | label->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding)); |
227 | } | 235 | /* FIXME: hacked spacer height */ |
236 | QSpacerItem *spacer = new QSpacerItem(0, 300, QSizePolicy::Expanding, QSizePolicy::Maximum); | ||
228 | 237 | ||
229 | ConfigDlg::~ConfigDlg() | 238 | color_lay->addWidget(color_grid, 0, 0); |
230 | { | 239 | color_lay->addItem(spacer); |
231 | emit reloadSw(); | 240 | |
241 | tabs->addTab(color_box, tr("Colors")); | ||
242 | base_lay->addWidget(tabs); | ||
232 | } | 243 | } |
@@ -250,3 +261,3 @@ QStringList ConfigDlg::loadSw() | |||
250 | /* Clear non existents entries */ | 261 | /* Clear non existents entries */ |
251 | QStringList s_copy = s_maps; | 262 | QStringList s_copy(s_maps); |
252 | for (uint i = 0; i < s_copy.count(); ++i) { | 263 | for (uint i = 0; i < s_copy.count(); ++i) { |
@@ -274,2 +285,40 @@ QStringList ConfigDlg::loadSw() | |||
274 | 285 | ||
286 | void ConfigDlg::accept() | ||
287 | { | ||
288 | /* Writing all stuffs to config */ | ||
289 | Config *config = new Config("multikey"); | ||
290 | config->setGroup("general"); | ||
291 | config->writeEntry("usePickboard", pick_button->isChecked()); // default closed | ||
292 | config->writeEntry("useRepeat", repeat_button->isChecked()); // default closed | ||
293 | |||
294 | config->setGroup("keymaps"); | ||
295 | config->writeEntry("sw", sw_maps, QChar('|')); | ||
296 | config->writeEntry("maps", custom_maps, QChar('|')); | ||
297 | delete config; | ||
298 | |||
299 | int index = keymaps->currentItem(); | ||
300 | if (index == 0) { | ||
301 | |||
302 | remove_button->setDisabled(true); | ||
303 | emit setMapToDefault(); | ||
304 | } | ||
305 | else if (default_maps.find(sw_maps[index-1]) != default_maps.end()) { | ||
306 | |||
307 | remove_button->setDisabled(true); | ||
308 | emit setMapToFile(QPEApplication::qpeDir() + "share/multikey/" + sw_maps[index - 1]); | ||
309 | |||
310 | } else { | ||
311 | |||
312 | remove_button->setEnabled(true); | ||
313 | emit setMapToFile(sw_maps[index - 1]); | ||
314 | } | ||
315 | |||
316 | emit pickboardToggled(pick_button->isChecked()); | ||
317 | emit repeatToggled(repeat_button->isChecked()); | ||
318 | emit reloadSw(); | ||
319 | |||
320 | QDialog::accept(); | ||
321 | emit configDlgClosed(); | ||
322 | } | ||
323 | |||
275 | void ConfigDlg::moveSelectedUp() | 324 | void ConfigDlg::moveSelectedUp() |
@@ -287,6 +336,2 @@ void ConfigDlg::moveSelectedUp() | |||
287 | keymaps->setCurrentItem(i-1); | 336 | keymaps->setCurrentItem(i-1); |
288 | |||
289 | Config config("multikey"); | ||
290 | config.setGroup("keymaps"); | ||
291 | config.writeEntry("sw", sw_maps, QChar('|')); | ||
292 | } | 337 | } |
@@ -307,6 +352,2 @@ void ConfigDlg::moveSelectedDown() | |||
307 | keymaps->setCurrentItem(i+1); | 352 | keymaps->setCurrentItem(i+1); |
308 | |||
309 | Config config("multikey"); | ||
310 | config.setGroup("keymaps"); | ||
311 | config.writeEntry("sw", sw_maps, QChar('|')); | ||
312 | } | 353 | } |
@@ -314,20 +355,2 @@ void ConfigDlg::moveSelectedDown() | |||
314 | 355 | ||
315 | void ConfigDlg::pickTog() { | ||
316 | |||
317 | Config config ("multikey"); | ||
318 | config.setGroup ("general"); | ||
319 | config.writeEntry ("usePickboard", pick_button->isChecked()); // default closed | ||
320 | |||
321 | emit pickboardToggled(pick_button->isChecked()); | ||
322 | } | ||
323 | |||
324 | void ConfigDlg::repeatTog() { | ||
325 | |||
326 | Config config ("multikey"); | ||
327 | config.setGroup ("general"); | ||
328 | config.writeEntry ("useRepeat", repeat_button->isChecked()); // default closed | ||
329 | |||
330 | emit repeatToggled(repeat_button->isChecked()); | ||
331 | } | ||
332 | |||
333 | void ConfigDlg::closeEvent(QCloseEvent *) { | 356 | void ConfigDlg::closeEvent(QCloseEvent *) { |
@@ -338,11 +361,2 @@ void ConfigDlg::closeEvent(QCloseEvent *) { | |||
338 | 361 | ||
339 | // ConfigDlg::setMap {{{1 | ||
340 | |||
341 | /* | ||
342 | * the index is kinda screwy, because in the config file, index 0 is just the | ||
343 | * first element in the QStringList, but here it's the "Current Language" | ||
344 | * listItem. therefor you have to minus one to the index before you access it. | ||
345 | * | ||
346 | */ | ||
347 | |||
348 | void ConfigDlg::setMap(int index) { | 362 | void ConfigDlg::setMap(int index) { |
@@ -350,15 +364,8 @@ void ConfigDlg::setMap(int index) { | |||
350 | if (index == 0) { | 364 | if (index == 0) { |
351 | |||
352 | remove_button->setDisabled(true); | 365 | remove_button->setDisabled(true); |
353 | emit setMapToDefault(); | ||
354 | } | 366 | } |
355 | else if (default_maps.find(sw_maps[index-1]) != default_maps.end()) { | 367 | else if (default_maps.find(sw_maps[index-1]) != default_maps.end()) { |
356 | |||
357 | remove_button->setDisabled(true); | 368 | remove_button->setDisabled(true); |
358 | emit setMapToFile(QPEApplication::qpeDir() + "share/multikey/" + sw_maps[index - 1]); | ||
359 | |||
360 | } else { | 369 | } else { |
361 | |||
362 | remove_button->setEnabled(true); | 370 | remove_button->setEnabled(true); |
363 | emit setMapToFile(sw_maps[index - 1]); | ||
364 | } | 371 | } |
@@ -403,8 +410,2 @@ void ConfigDlg::addMap() { | |||
403 | keymaps->setSelected(keymaps->count() - 1, true); | 410 | keymaps->setSelected(keymaps->count() - 1, true); |
404 | |||
405 | |||
406 | config.writeEntry("maps", maps, QChar('|')); | ||
407 | config.writeEntry("sw", sw_maps, QChar('|')); | ||
408 | config.writeEntry("current", map); | ||
409 | |||
410 | } | 411 | } |
@@ -421,8 +422,2 @@ void ConfigDlg::removeMap() { | |||
421 | sw_maps.remove(sw_maps.at(keymaps->currentItem())); | 422 | sw_maps.remove(sw_maps.at(keymaps->currentItem())); |
422 | |||
423 | // write the changes | ||
424 | Config config ("multikey"); | ||
425 | config.setGroup("keymaps"); | ||
426 | config.writeEntry("maps", custom_maps, QChar('|')); | ||
427 | config.writeEntry("sw", sw_maps, QChar('|')); | ||
428 | } | 423 | } |
diff --git a/inputmethods/multikey/configdlg.h b/inputmethods/multikey/configdlg.h index ea157c5..91ae429 100644 --- a/inputmethods/multikey/configdlg.h +++ b/inputmethods/multikey/configdlg.h | |||
@@ -1,3 +1,3 @@ | |||
1 | #include <qpe/qpeapplication.h> | 1 | #include <qpe/qpeapplication.h> |
2 | #include <qtabwidget.h> | 2 | #include <qdialog.h> |
3 | #include <qcheckbox.h> | 3 | #include <qcheckbox.h> |
@@ -9,3 +9,3 @@ | |||
9 | 9 | ||
10 | class ConfigDlg : public QTabWidget | 10 | class ConfigDlg : public QDialog |
11 | { | 11 | { |
@@ -15,3 +15,2 @@ public: | |||
15 | ConfigDlg (); | 15 | ConfigDlg (); |
16 | ~ConfigDlg (); | ||
17 | static QStringList ConfigDlg::loadSw(); | 16 | static QStringList ConfigDlg::loadSw(); |
@@ -27,2 +26,5 @@ signals: | |||
27 | 26 | ||
27 | protected: | ||
28 | virtual void accept(); | ||
29 | |||
28 | protected slots: | 30 | protected slots: |
@@ -32,4 +34,2 @@ protected slots: | |||
32 | private slots: | 34 | private slots: |
33 | void pickTog(); | ||
34 | void repeatTog(); | ||
35 | void setMap(int index); | 35 | void setMap(int index); |
@@ -39,3 +39,2 @@ private slots: | |||
39 | 39 | ||
40 | |||
41 | // all those required slots for the color push buttons | 40 | // all those required slots for the color push buttons |
@@ -53,3 +52,2 @@ private: | |||
53 | 52 | ||
54 | |||
55 | QStringList default_maps; // the maps in your share/multikey/ dir | 53 | QStringList default_maps; // the maps in your share/multikey/ dir |