aboutsummaryrefslogtreecommitdiff
path: root/lib/python/Components
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2008-02-11 23:42:08 +0000
committerFelix Domke <tmbinc@elitedvb.net>2008-02-11 23:42:08 +0000
commite66f4bdb5fd20a77e5db713d732275aa32b22af5 (patch)
tree1db2063d2991f1005d72efdd3a690a0a6705119e /lib/python/Components
parent5ce65d82dcb11e8c5886be467fefecc5e70d4868 (diff)
downloadenigma2-e66f4bdb5fd20a77e5db713d732275aa32b22af5.tar.gz
enigma2-e66f4bdb5fd20a77e5db713d732275aa32b22af5.zip
text edit patch #5 by Anders Holst
Diffstat (limited to 'lib/python/Components')
-rw-r--r--lib/python/Components/ConfigList.py36
-rw-r--r--lib/python/Components/config.py29
2 files changed, 34 insertions, 31 deletions
diff --git a/lib/python/Components/ConfigList.py b/lib/python/Components/ConfigList.py
index a54d27b1..f42d6a96 100644
--- a/lib/python/Components/ConfigList.py
+++ b/lib/python/Components/ConfigList.py
@@ -14,8 +14,7 @@ class ConfigList(HTMLComponent, GUIComponent, object):
self.list = list
self.onSelectionChanged = [ ]
self.current = None
- self.help_window = None
- self.setHelpWindowSession(session)
+ self.session = session
def execBegin(self):
rcinput = eRCInput.getInstance()
@@ -27,10 +26,6 @@ class ConfigList(HTMLComponent, GUIComponent, object):
rcinput.setKeyboardMode(rcinput.kmNone)
self.timer.timeout.get().remove(self.timeout)
- def setHelpWindowSession(self, session):
- assert self.help_window is None, "you can't move a help window to another session"
- self.session = session
-
def toggle(self):
selection = self.getCurrent()
selection[1].toggle()
@@ -41,8 +36,6 @@ class ConfigList(HTMLComponent, GUIComponent, object):
if selection and selection[1].enabled:
selection[1].handleKey(key)
self.invalidateCurrent()
- if self.help_window:
- self.help_window.update(selection[1])
if key in KEY_NUMBERS:
self.timer.start(1000, 1)
@@ -68,25 +61,21 @@ class ConfigList(HTMLComponent, GUIComponent, object):
GUI_WIDGET = eListbox
def selectionChanged(self):
- n = self.getCurrent()
-
- if self.help_window:
- self.session.deleteDialog(self.help_window)
-
- nh = n and n[1].helpWindow()
- if nh is not None and self.session is not None:
- self.help_window = self.session.instantiateDialog(*nh)
- self.help_window.show()
-
- self.current = n
+ if self.current:
+ self.current[1].onDeselect(self.session)
+ self.current = self.getCurrent()
+ if self.current:
+ self.current[1].onSelect(self.session)
for x in self.onSelectionChanged:
x()
def postWidgetCreate(self, instance):
- instance.setContent(self.l)
instance.selectionChanged.get().append(self.selectionChanged)
+ instance.setContent(self.l)
def preWidgetRemove(self, instance):
+ if self.current:
+ self.current[1].onDeselect(self.session)
instance.selectionChanged.get().remove(self.selectionChanged)
def setList(self, l):
@@ -119,13 +108,10 @@ class ConfigListScreen:
{
"gotAsciiCode": self.keyGotAscii,
"ok": self.keyOK,
- "accept": self.keyOK,
"left": self.keyLeft,
"right": self.keyRight,
- "moveLeft": self.keyLeft,
- "moveRight": self.keyRight,
- "moveHome": self.keyHome,
- "moveEnd": self.keyEnd,
+ "home": self.keyHome,
+ "end": self.keyEnd,
"deleteForward": self.keyDelete,
"deleteBackward": self.keyBackspace,
"toggleOverwrite": self.keyToggleOW,
diff --git a/lib/python/Components/config.py b/lib/python/Components/config.py
index f8ef0ec8..861e70bf 100644
--- a/lib/python/Components/config.py
+++ b/lib/python/Components/config.py
@@ -98,8 +98,11 @@ class ConfigElement(object):
def __call__(self, selected):
return self.getMulti(selected)
- def helpWindow(self):
- return None
+ def onSelect(self, session):
+ pass
+
+ def onDeselect(self, session):
+ pass
KEY_LEFT = 0
KEY_RIGHT = 1
@@ -558,7 +561,7 @@ class ConfigText(ConfigElement, NumericalTextInput):
self.visible_width = visible_width
self.offset = 0
self.overwrite = fixed_size
-
+ self.help_window = None
self.value = self.default = default
def validateMarker(self):
@@ -668,8 +671,12 @@ class ConfigText(ConfigElement, NumericalTextInput):
self.insertChar(newChar, self.marked_pos, owr)
elif key == KEY_TIMEOUT:
self.timeout()
+ if self.help_window:
+ self.help_window.update(self)
return
+ if self.help_window:
+ self.help_window.update(self)
self.validateMarker()
self.changed()
@@ -708,9 +715,19 @@ class ConfigText(ConfigElement, NumericalTextInput):
mark = [self.marked_pos]
return ("mtext"[1-selected:], self.value+" ", mark)
- def helpWindow(self):
- from Screens.NumericalTextInputHelpDialog import NumericalTextInputHelpDialog
- return (NumericalTextInputHelpDialog,self)
+ def onSelect(self, session):
+ self.allmarked = (self.value != "")
+ if session is not None:
+ from Screens.NumericalTextInputHelpDialog import NumericalTextInputHelpDialog
+ self.help_window = session.instantiateDialog(NumericalTextInputHelpDialog, self)
+ self.help_window.show()
+
+ def onDeselect(self, session):
+ self.marked_pos = 0
+ self.offset = 0
+ if self.help_window:
+ session.deleteDialog(self.help_window)
+ self.help_window = None
def getHTML(self, id):
return '<input type="text" name="' + id + '" value="' + self.value + '" /><br>\n'