X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0ad8a5e3943746735fa6de06e089ac58c40800b6..aa4c8cba2870da29c89ea6015770ed37c0cc1ffb:/lib/python/Screens/LanguageSelection.py diff --git a/lib/python/Screens/LanguageSelection.py b/lib/python/Screens/LanguageSelection.py index ca7f2198..79cd25fc 100644 --- a/lib/python/Screens/LanguageSelection.py +++ b/lib/python/Screens/LanguageSelection.py @@ -2,24 +2,52 @@ 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 = [] - self.list.append(("English", None)) - self.list.append(("German", 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): - pass + self.run() + self.close() def run(self): - print "select the language here" \ No newline at end of file + 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()