author | ar <ar> | 2004-08-21 10:08:44 (UTC) |
---|---|---|
committer | ar <ar> | 2004-08-21 10:08:44 (UTC) |
commit | 2304c546ec73f2643621f04d61128c2686812cd1 (patch) (side-by-side diff) | |
tree | 9ab2b011fcdd376fbbd70000bb035e7521ef5490 | |
parent | e67b6a8748af0856d77eeb46048d36e58314793e (diff) | |
download | opie-2304c546ec73f2643621f04d61128c2686812cd1.zip opie-2304c546ec73f2643621f04d61128c2686812cd1.tar.gz opie-2304c546ec73f2643621f04d61128c2686812cd1.tar.bz2 |
- BugFix: #1383 - Language settings doesn't warn about losing open apps (Thanks to Markus Litz for the patch)
-rw-r--r-- | noncore/settings/language/language.cpp | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/noncore/settings/language/language.cpp b/noncore/settings/language/language.cpp index d30a041..8dff063 100644 --- a/noncore/settings/language/language.cpp +++ b/noncore/settings/language/language.cpp @@ -72,50 +72,63 @@ LanguageSettings::LanguageSettings( QWidget* parent, const char* name, WFlags fl QString langName = conf.readEntry( "Name" ); QString ownName = conf.readEntryDirect( "Name[" + name + "]" ); if ( ownName.isEmpty() ) ownName = conf.readEntryDirect( "Name" ); if ( !ownName.isEmpty() && ownName != langName ) langName = langName + " [" + ownName + "]"; languages->insertItem( langName ); } } if ( langAvail. find ( "en" ) == -1 ) { langAvail. prepend ( "" ); // no tr languages-> insertItem ( QString ( "English [%1] (%2)" /* no tr (!) */ ). arg ( tr ( "English" )). arg ( tr( "default" )), 0 ); } dl = new QPEDialogListener(this); reset(); } LanguageSettings::~LanguageSettings() {} void LanguageSettings::accept() { - applyLanguage(); - QDialog::accept(); + switch( QMessageBox::warning( this, "Language", + "Attention, all windows will be closed\n" + "by changing the language\n" + "without saving the Data.\n\n" + "Go on?", + "Ok", "Cancel", 0, + 0, 1 )) + { + case 0: // OK + applyLanguage(); + QDialog::accept(); + break; + case 1: // Abbruch + break; + } } void LanguageSettings::applyLanguage() { setLanguage ( langAvail. at ( languages-> currentItem ( ))); } void LanguageSettings::reject() { reset(); QDialog::reject(); } void LanguageSettings::reset() { QString l = getenv("LANG"); Config config("locale"); config.setGroup("Language"); l = config.readEntry( "Language", l ); actualLanguage = l; if (l.isEmpty()) l = "en"; |