fix for inconsistency when moving the selection while callback is not called
[enigma2.git] / lib / python / Components / config.py
index b5a767a23c13b9635e3a81720a8bc8dfbef4b2a0..c433f01bb47b619240f9c5ce767457fa0861fbd0 100644 (file)
@@ -1,4 +1,5 @@
 from time import *
+from Tools.NumericalTextInput import *
 
 class configFile:
        def __init__(self):
@@ -76,7 +77,7 @@ class configSelection:
                
                self.checkValues()                      
 
-               self.parent.change()    
+               self.parent.change()
 
        def __call__(self, selected):                   #needed by configlist
                self.checkValues()
@@ -265,6 +266,61 @@ class configSequence:
                        # (this code is heavily ink optimized!)
                return ("mtext"[1-selected:], value, [mPos])
 
+class configText:
+       # used as first parameter
+       # is the text of a fixed size or is the user able to extend the length of the text
+       extendableSize = 1
+       fixedSize = 2
+
+       def __init__(self, parent):
+               self.parent = parent
+               self.markedPos = 0
+               self.mode = self.parent.vals[0]
+               self.textInput = NumericalTextInput(self.nextEntry)
+
+       def checkValues(self):
+               if (self.markedPos < 0):
+                       self.markedPos = 0
+               if (self.markedPos >= len(self.parent.value)):
+                       self.markedPos = len(self.parent.value) - 1
+                       
+       def cancel(self):
+               self.parent.reload()
+
+       def save(self):
+               self.parent.save()
+               
+       def nextEntry(self):
+               print self.parent
+               self.parent.vals[1](self.parent.getConfigPath())
+
+       def handleKey(self, key):
+               #this will no change anything on the value itself
+               #so we can handle it here in gui element
+               if key == config.key["prevElement"]:
+                       self.textInput.nextKey()
+                       self.markedPos -= 1
+
+               if key == config.key["nextElement"]:
+                       self.textInput.nextKey()
+                       self.markedPos += 1
+                       if (self.mode == self.extendableSize):
+                               if (self.markedPos >= len(self.parent.value)):
+                                       self.parent.value = self.parent.value.ljust(len(self.parent.value) + 1)
+                       
+                               
+               if key >= config.key["0"] and key <= config.key["9"]:
+                       number = 9 - config.key["9"] + key
+
+                       self.parent.value = self.parent.value[0:self.markedPos] + str(self.textInput.getKey(number)) + self.parent.value[self.markedPos + 1:]
+               
+               self.checkValues()                      
+               
+               self.parent.change()    
+
+       def __call__(self, selected):                   #needed by configlist
+               return ("mtext"[1-selected:], str(self.parent.value), [self.markedPos])
+               
 class configValue:
        def __init__(self, obj):
                self.obj = obj
@@ -337,16 +393,18 @@ class configElement:
                                        tcnt = cnt
                        cnt += 1
                if tcnt != -1:
-                       return tcnt                     
+                       return tcnt
                return 0        #prevent bigger then array
 
        def datafromFile(self, control, data):
                if control == ConfigSlider:
-                       return int(data);
+                       return int(data)
                elif control == configSelection:
-                       return int(data);
+                       return int(data)
                elif control == configDateTime:
-                       return int(data);
+                       return int(data)
+               elif control == configText:
+                       return str(data)
                elif control == configSequence:
                        list = [ ]
                        part = data.split(self.vals[0])
@@ -360,11 +418,14 @@ class configElement:
 
        def datatoFile(self, control, data):
                if control == ConfigSlider:
-                       return str(data);
+                       return str(data)
                elif control == configSelection:
-                       return str(data);
+                       return str(data)
                elif control == configDateTime:
-                       return str(data);
+                       return str(data)
+               elif control == configText:
+                       return str(data.strip())
+
                elif control == configSequence:
                        value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data)
 #                      just in case you don't understand the above, here an equivalent:
@@ -408,6 +469,10 @@ class configElement:
                self.notifierList = [ ]
                self.enabled = True
                self.loadData()         
+               
+       def getConfigPath(self):
+               return self.configPath
+       
        def addNotifier(self, notifier):
                self.notifierList.append(notifier);
                notifier(self);