X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fpython%2FComponents%2FConfigList.py;h=7ed6031a7fbc7612e5a26c54c93125f29793b037;hp=4dd401f9475a0e0c5b3da27f6f82add44a5d330e;hb=67b53c1cb06988394c35a6e965c99b72b67fe1be;hpb=0e7f46d6379dbf08183caadfa33b8d0648418d9e diff --git a/lib/python/Components/ConfigList.py b/lib/python/Components/ConfigList.py index 4dd401f..7ed6031 100644 --- a/lib/python/Components/ConfigList.py +++ b/lib/python/Components/ConfigList.py @@ -1,8 +1,9 @@ -from HTMLComponent import * -from GUIComponent import * +from HTMLComponent import HTMLComponent +from GUIComponent import GUIComponent from config import KEY_LEFT, KEY_RIGHT, KEY_0, KEY_DELETE, KEY_OK, KEY_TIMEOUT, ConfigElement from Components.ActionMap import NumberActionMap from enigma import eListbox, eListboxPythonConfigContent, eTimer +from Screens.MessageBox import MessageBox class ConfigList(HTMLComponent, GUIComponent, object): def __init__(self, list, session = None): @@ -44,6 +45,9 @@ class ConfigList(HTMLComponent, GUIComponent, object): def getCurrent(self): return self.l.getCurrentSelection() + def getCurrentIndex(self): + return self.l.getCurrentSelectionIndex() + def invalidateCurrent(self): self.l.invalidateEntry(self.l.getCurrentSelectionIndex()) @@ -94,6 +98,13 @@ class ConfigList(HTMLComponent, GUIComponent, object): def timeout(self): self.handleKey(KEY_TIMEOUT) + def isChanged(self): + is_changed = False + for x in self.list: + is_changed |= x[1].isChanged() + + return is_changed + class ConfigListScreen: def __init__(self, list, session = None, on_change = None): self["config_actions"] = NumberActionMap(["SetupActions", "TextInputActions"], @@ -139,3 +150,23 @@ class ConfigListScreen: self["config"].handleKey(KEY_0 + number) self.__changed() + # keySave and keyCancel are just provided in case you need them. + # you have to call them by yourself. + def keySave(self): + for x in self["config"].list: + x[1].save() + self.close() + + def cancelConfirm(self, result): + if not result: + return + + for x in self["config"].list: + x[1].cancel() + self.close() + + def keyCancel(self): + if self["config"].isChanged(): + self.session.openWithCallback(self.cancelConfirm, MessageBox, _("Really close without saving settings?")) + else: + self.close()