X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/90d9f3e7624282749eb59b57d4996f5d1d06c6b1..aa4c8cba2870da29c89ea6015770ed37c0cc1ffb:/lib/python/Screens/LanguageSelection.py diff --git a/lib/python/Screens/LanguageSelection.py b/lib/python/Screens/LanguageSelection.py index a0441b6d..79cd25fc 100644 --- a/lib/python/Screens/LanguageSelection.py +++ b/lib/python/Screens/LanguageSelection.py @@ -3,23 +3,25 @@ from Screen import Screen from Components.MenuList import MenuList from Components.ActionMap import ActionMap from Components.Language import language +from Components.LanguageList import * +from Components.config import config + class LanguageSelection(Screen): def __init__(self, session): Screen.__init__(self, session) self.list = [] - list = language.getLanguageList() - for x in list: - self.list.append((x, None)) - - self["list"] = MenuList(self.list) + self["list"] = LanguageList(self.list) + self.updateList() - self["actions"] = ActionMap(["OkCancelActions"], + self["actions"] = ActionMap(["WizardActions"], { "ok": self.save, - "cancel": self.close - }) + "back": self.close, + "up": self.up, + "down": self.down + }, -1) def save(self): self.run() @@ -27,3 +29,25 @@ class LanguageSelection(Screen): def run(self): language.activateLanguage(self["list"].l.getCurrentSelectionIndex()) + config.osd.language.value = self["list"].l.getCurrentSelectionIndex() + config.osd.language.save() + + def updateList(self): + self.list = [] + if len(language.lang) == 0: # no language available => display only english + self.list.append(LanguageEntryComponent("en", _("English"))) + else: + for x in language.lang: + self.list.append(LanguageEntryComponent(x[2], _(x[0]))) + + self["list"].l.setList(self.list) + + def up(self): + self["list"].instance.moveSelection(self["list"].instance.moveUp) + self.run() + self.updateList() + + def down(self): + self["list"].instance.moveSelection(self["list"].instance.moveDown) + self.run() + self.updateList()