X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fpython%2FScreens%2FLanguageSelection.py;h=83d03403782bf63c517385026e68622230721ad0;hb=4e81b86a327fd71320b97413145a969f2071ee8e;hp=41857375d9512233b4f7cf1f8fcd17e3e9ee3cb1;hpb=29dda647f09e42ac3a621bbb537558c2d1bbc7b4;p=vuplus_dvbapp diff --git a/lib/python/Screens/LanguageSelection.py b/lib/python/Screens/LanguageSelection.py index 4185737..83d0340 100644 --- a/lib/python/Screens/LanguageSelection.py +++ b/lib/python/Screens/LanguageSelection.py @@ -11,38 +11,56 @@ class LanguageSelection(Screen): def __init__(self, session): Screen.__init__(self, session) + self.oldActiveLanguage = language.getActiveLanguage() + self.list = [] self["list"] = LanguageList(self.list) self.updateList() - + self.onLayoutFinish.append(self.selectActiveLanguage) + self["actions"] = ActionMap(["OkCancelActions", "DirectionActions"], { "ok": self.save, - "cancel": self.close, + "cancel": self.cancel, "up": self.up, "down": self.down, "left": self.left, "right": self.right }, -1) + def selectActiveLanguage(self): + activeLanguage = language.getActiveLanguage() + pos = 0 + for x in self.list: + if x[0] == activeLanguage: + self["list"].instance.moveSelectionTo(pos) + break + pos += 1 + def save(self): self.run() self.close() + def cancel(self): + language.activateLanguage(self.oldActiveLanguage) + self.close() + def run(self): - language.activateLanguage(self["list"].l.getCurrentSelectionIndex()) - config.osd.language.value = self["list"].l.getCurrentSelectionIndex() + language.activateLanguage(self["list"].l.getCurrentSelection()[0]) + config.osd.language.value = self["list"].l.getCurrentSelection()[0] config.osd.language.save() - self.session.currentDialog.instance.setTitle(_("Language selection")) + config.misc.languageselected.value = 0 + config.misc.languageselected.save() + self.setTitle(_("Language selection")) def updateList(self): self.list = [] - if len(language.lang) == 0: # no language available => display only english - self.list.append(LanguageEntryComponent("en", _("English"))) + if len(language.getLanguageList()) == 0: # no language available => display only english + self.list.append(LanguageEntryComponent("en", _("English"), "en_EN")) else: - for x in language.lang: - self.list.append(LanguageEntryComponent(x[3].lower(), _(x[0]))) - + for x in language.getLanguageList(): + self.list.append(LanguageEntryComponent(file = x[1][3].lower(), name = _(x[1][0]), index = x[0])) + #self.list.sort(key=lambda x: x[1][7]) self["list"].l.setList(self.list) def up(self):