X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fpython%2FScreens%2FLanguageSelection.py;h=f60852ec5cbc1e553f331281a6f6362597c07447;hp=0fe53d654da7caa5828df63134e93603af583ac2;hb=HEAD;hpb=60c335d6a15c3c6e417833bac39273bae4fc89f7 diff --git a/lib/python/Screens/LanguageSelection.py b/lib/python/Screens/LanguageSelection.py old mode 100644 new mode 100755 index 0fe53d6..f60852e --- a/lib/python/Screens/LanguageSelection.py +++ b/lib/python/Screens/LanguageSelection.py @@ -6,17 +6,21 @@ from Components.config import config from Components.Sources.List import List from Components.Label import Label from Components.Pixmap import Pixmap +from Components.language_cache import LANG_TEXT + +def _cached(x): + return LANG_TEXT.get(config.osd.language.value, {}).get(x, "") from Screens.Rc import Rc -from Tools.Directories import resolveFilename, SCOPE_SKIN_IMAGE +from Tools.Directories import resolveFilename, SCOPE_CURRENT_SKIN from Tools.LoadPixmap import LoadPixmap def LanguageEntryComponent(file, name, index): - png = LoadPixmap(resolveFilename(SCOPE_SKIN_IMAGE, "countries/" + file + ".png")) + png = LoadPixmap(resolveFilename(SCOPE_CURRENT_SKIN, "countries/" + file + ".png")) if png == None: - png = LoadPixmap(resolveFilename(SCOPE_SKIN_IMAGE, "countries/missing.png")) + png = LoadPixmap(resolveFilename(SCOPE_CURRENT_SKIN, "countries/missing.png")) res = (index, name, png) return res @@ -32,8 +36,7 @@ class LanguageSelection(Screen): self.updateList() self.onLayoutFinish.append(self.selectActiveLanguage) - - self["actions"] = ActionMap(["OkCancelActions"], + self["actions"] = ActionMap(["OkCancelActions"], { "ok": self.save, "cancel": self.cancel, @@ -56,38 +59,42 @@ class LanguageSelection(Screen): language.activateLanguage(self.oldActiveLanguage) self.close() - def run(self): + def run(self, justlocal = False): print "updating language..." lang = self["languages"].getCurrent()[0] - language.activateLanguage(lang) config.osd.language.value = lang config.osd.language.save() + self.setTitle(_cached("T2")) + + if justlocal: + return + + language.activateLanguage(lang) config.misc.languageselected.value = 0 config.misc.languageselected.save() - self.setTitle(_("Language selection")) print "ok" def updateList(self): - print "update list" - first_time = len(self.list) == 0 + first_time = not self.list - self.list = [] - if len(language.getLanguageList()) == 0: # no language available => display only english - self.list.append(LanguageEntryComponent("en", _("English"), "en_EN")) + languageList = language.getLanguageList() + if not languageList: # no language available => display only english + list = [ LanguageEntryComponent("en", _cached("en_EN"), "en_EN") ] else: - for x in language.getLanguageList(): - self.list.append(LanguageEntryComponent(file = x[1][2].lower(), name = _(x[1][0]), index = x[0])) - #self.list.sort(key=lambda x: x[1][7]) + list = [ LanguageEntryComponent(file = x[1][2].lower(), name = _cached("%s_%s" % x[1][1:3]), index = x[0]) for x in languageList] + self.list = list + + #list.sort(key=lambda x: x[1][7]) print "updateList" if first_time: - self["languages"].list = self.list + self["languages"].list = list else: - self["languages"].updateList(self.list) + self["languages"].updateList(list) print "done" def changed(self): - self.run() + self.run(justlocal = True) self.updateList() class LanguageWizard(LanguageSelection, Rc): @@ -106,10 +113,10 @@ class LanguageWizard(LanguageSelection, Rc): self.selectKey("DOWN") def changed(self): - self.run() + self.run(justlocal = True) self.updateList() self.setText() def setText(self): - self["text"].setText(_("Please use the UP and DOWN keys to select your language. Afterwards press the OK button.")) - + + self["text"].setText(_cached("T1"))