simplify GUIcreate/createWidget, fix base class order
[enigma2.git] / lib / python / Components / PluginList.py
index 226820334d25e7d8d74e681850973648c0cd2b90..7220f0a9349d4f09d33895fafa6aeb7cb8edf0d3 100644 (file)
@@ -4,7 +4,7 @@ from GUIComponent import *
 from MenuList import MenuList
 
 from Tools.Directories import resolveFilename, SCOPE_SKIN_IMAGE
-from Components.MultiContent import RT_HALIGN_LEFT, MultiContentEntryText, MultiContentEntryPixmap
+from Components.MultiContent import RT_HALIGN_LEFT, MultiContentEntryText, MultiContentEntryPixmapAlphaTest
 
 from enigma import *
 
@@ -15,14 +15,36 @@ def PluginEntryComponent(plugin):
        res.append(MultiContentEntryText(pos=(80, 26), size=(300, 17), font=1, text=plugin.description))
 
        if plugin.icon is None:
-               png = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "/plugin.png"))
+               png = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "plugin.png"))
        else:
                png = plugin.icon
-       res.append(MultiContentEntryPixmap(pos=(10, 5), size=(60, 40), png = png))
+       res.append(MultiContentEntryPixmapAlphaTest(pos=(10, 5), size=(60, 40), png = png))
        
        return res
 
-class PluginList(HTMLComponent, GUIComponent, MenuList):
+def PluginCategoryComponent(name, png):
+       res = [ name ]
+       
+       res.append(MultiContentEntryText(pos=(80, 5), size=(300, 25), font=0, text=name))
+       res.append(MultiContentEntryPixmapAlphaTest(pos=(0, 0), size=(60, 50), png = png))
+       
+       return res
+
+def PluginDownloadComponent(plugin, name):
+       res = [ plugin ]
+       
+       res.append(MultiContentEntryText(pos=(80, 5), size=(300, 25), font=0, text=name))
+       res.append(MultiContentEntryText(pos=(80, 26), size=(300, 17), font=1, text=plugin.description))
+
+       if plugin.icon is None:
+               png = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "plugin.png"))
+       else:
+               png = plugin.icon
+       res.append(MultiContentEntryPixmapAlphaTest(pos=(0, 0), size=(60, 50), png = png))
+       
+       return res
+
+class PluginList(MenuList, HTMLComponent, GUIComponent):
        def __init__(self, list):
                GUIComponent.__init__(self)
                self.l = eListboxPythonMultiContent()
@@ -30,8 +52,9 @@ class PluginList(HTMLComponent, GUIComponent, MenuList):
                self.l.setList(list)
                self.l.setFont(0, gFont("Regular", 20))
                self.l.setFont(1, gFont("Regular", 14))
-       
-       def GUIcreate(self, parent):
-               self.instance = eListbox(parent)
-               self.instance.setContent(self.l)
-               self.instance.setItemHeight(50)
+
+       GUI_WIDGET = eListbox
+
+       def postWidgetCreate(self, instance):
+               instance.setContent(self.l)
+               instance.setItemHeight(50)