small fix
[enigma2.git] / lib / python / Components / Input.py
index a3ab764e8840016b4e399e2c4ccc007750f0f429..e6e27fab6e12c1351ce81ca7c215ef4fec8f4ffe 100644 (file)
@@ -2,11 +2,11 @@ from HTMLComponent import *
 from GUIComponent import *
 from VariableText import *
 
-from enigma import eLabel
+from enigma import eLabel, isUTF8, convertUTF8DVB, convertDVBUTF8
 
 from Tools.NumericalTextInput import NumericalTextInput
 
-class Input(HTMLComponent, GUIComponent, VariableText):
+class Input(VariableText, HTMLComponent, GUIComponent):
        TEXT = 0
        PIN = 1
        NUMBER = 2      
@@ -18,67 +18,83 @@ class Input(HTMLComponent, GUIComponent, VariableText):
                self.type = type
                self.maxSize = maxSize
                self.currPos = 0
-               self.text = text
+               self.Text = text
                self.update()
 
        def update(self):
                self.setMarkedPos(self.currPos)
-               text = self.text
                if self.type == self.PIN:
-                       text = "*" * len(self.text)
-               self.setText(text)
-               #self.setText(self.text[0:self.currPos] + "_" + self.text[self.currPos] + "_" + self.text[self.currPos + 1:])
+                       self.message = "*" * len(self.Text)
+               else:
+                       self.message = convertDVBUTF8(self.Text, 0)
+               if self.instance:
+                       self.instance.setText(self.message)
+
+       def setText(self, text):
+               if not len(text):
+                       self.currPos = 0
+                       self.Text = ""
+               elif isUTF8(text):
+                       self.Text = convertUTF8DVB(text, 0)
+               else:
+                       self.Text = text
+               self.update()
 
        def getText(self):
-               return self.text
-       
+               return convertDVBUTF8(self.Text, 0)
+
        def createWidget(self, parent):
                return eLabel(parent, self.currPos)
-       
+
        def getSize(self):
                s = self.instance.calculateSize()
                return (s.width(), s.height())
        
        def right(self):
                self.currPos += 1
-               if self.currPos == len(self.text):
+               if self.currPos == len(self.Text):
                        if self.maxSize:
                                self.currPos -= 1
                        else:
-                               self.text = self.text + " "
-                       
+                               self.Text = self.Text + " "
                self.update()
-               
+
        def left(self):
-               self.currPos -= 1
-               self.update()
-               
+               if self.currPos > 0:
+                       self.currPos -= 1
+                       self.update()
+
        def up(self):
-               if self.text[self.currPos] == "9":
+               if self.Text[self.currPos] == "9" or self.Text[self.currPos] == " ":
                        newNumber = "0"
                else:
-                       newNumber = str(int(self.text[self.currPos]) + 1)
-               self.text = self.text[0:self.currPos] + newNumber + self.text[self.currPos + 1:]
+                       newNumber = str(int(self.Text[self.currPos]) + 1)
+               self.Text = self.Text[0:self.currPos] + newNumber + self.Text[self.currPos + 1:]
                self.update()
-               
+
        def down(self):
-               if self.text[self.currPos] == "0":
+               if self.Text[self.currPos] == "0" or self.Text[self.currPos] == " ":
                        newNumber = "9"
                else:
-                       newNumber = str(int(self.text[self.currPos]) - 1)
-               self.text = self.text[0:self.currPos] + newNumber + self.text[self.currPos + 1:]
+                       newNumber = str(int(self.Text[self.currPos]) - 1)
+               self.Text = self.Text[0:self.currPos] + newNumber + self.Text[self.currPos + 1:]
                self.update()
-               
+
        def delete(self):
-               self.text = self.text[:self.currPos] + self.text[self.currPos + 1:]
+               self.Text = self.Text[:self.currPos] + self.Text[self.currPos + 1:]
                self.update()
-               
+
+       def handleAscii(self, code):
+               newChar = chr(code)
+               self.Text = self.Text[0:self.currPos] + newChar + self.Text[self.currPos + 1:]
+               self.right()
+
        def number(self, number):
                if self.type == self.TEXT:
                        newChar = self.numericalTextInput.getKey(number)
                elif self.type == self.PIN or self.type == self.NUMBER:
                        newChar = str(number)
-               self.text = self.text[0:self.currPos] + newChar + self.text[self.currPos + 1:]
+               self.Text = self.Text[0:self.currPos] + newChar + self.Text[self.currPos + 1:]
                if self.type == self.PIN or self.type == self.NUMBER:
                        self.right()
                self.update()