--- misc/xbmc/plugin.video.todic/default.py 2013/04/18 16:18:22 1972 +++ misc/xbmc/plugin.video.todic/default.py 2015/06/29 14:54:29 2593 @@ -3,7 +3,7 @@ ''' Todic plugin for XBMC - Version 0.0.9 + Version 0.0.14 ''' import sys @@ -26,6 +26,45 @@ fanartImage = os.path.join(__addon__.getAddonInfo('path'), 'fanart.jpg') datapath = xbmc.translatePath('special://profile/addon_data/plugin.video.todic/') +ADDON_PATH = __addon__.getAddonInfo('path') +SkinMasterPath = os.path.join(ADDON_PATH, 'skins' ) + '/' +MySkinPath = (os.path.join(SkinMasterPath, '720p')) + '/' +MySkin = 'main.xml' + + +class TodicMovieDialog(xbmcgui.WindowXMLDialog): + def __new__(cls): + return super(TodicMovieDialog, cls).__new__(cls, "main.xml", ADDON_PATH) + + def __init__(self): + super(TodicMovieDialog, self).__init__() + + def onClick( self, controlId ): + print "OnClick: " + str(controlId) + + if (controlId == 50): + self.close() + play_real_video(self.url, self.name) + + if ( controlId == 98 ): + self.close() + + + def onInit(self): + + print "ONINIT" + self.getControl( 1 ).setLabel( self.name); + self.getControl( 2 ).setLabel( self.description ); + + def setUrl( self, url): + self.url = url + + def setName( self, name ): + self.name = name + + def setDescription( self, description ): + self.description = description + class TodicPlayer(xbmc.Player): def __init__(self, *args, **kwargs): @@ -106,6 +145,13 @@ u = sys.argv[0] + "?mode=10&name=" ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) + #add search series + listitem = xbmcgui.ListItem(label = "Søg Serier ...", iconImage = 'DefaultFolder.png', thumbnailImage = 'DefaultFolder.png') + listitem.setProperty('Fanart_Image', fanartImage) + + u = sys.argv[0] + "?mode=11&name=" + ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) + xbmcplugin.endOfDirectory(int(sys.argv[1])) @@ -159,7 +205,7 @@ description = description.encode('UTF-8') - u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(name) + "&url=" + urllib.quote(url) + u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(name) + "&url=" + urllib.quote(url) + "&description=" + urllib.quote(description) ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = folder, totalItems = l) if (endlist == True): @@ -168,8 +214,20 @@ -def play_video(url, name): - xml = open_url(url) +def play_video(url, name,description): + if (description == None or description == ""): + play_real_video(url,name) + else: + d = TodicMovieDialog() + d.setUrl( url) + d.setName( name ) + d.setDescription( description ) + + d.doModal() + + +def play_real_video(url, name): + xml = open_url(url) print 'TODIC url: ' + str(url) print 'TODIC xml: '+ xml @@ -229,6 +287,17 @@ buildList(url, "søgning") +def searchSeries(): + search = getUserInput("Todic Serie Søgning") + + if (search != None and search != ""): + url = __backend__ + "&action=searchseries&search=" + urllib.quote_plus(search) + + #print "[TODIC] Search start: " + search + #print "[TODIC] Search url: " + url + + buildList(url, "serie søgning") + @@ -280,6 +349,7 @@ url = None name = None mode = None +description = None try: url = urllib.unquote_plus(params["url"]) @@ -293,6 +363,17 @@ mode = int(params["mode"]) except: pass +try: + description = urllib.unquote_plus(params["description"]) +except: + pass + +try: + open_url("http://todic.dk") +except: + showMessage("Fejl", "Kunne ikke forbinde til todic.dk") + exit() + if url == 'refresh': #xbmc.output("[tvserver] Container.Refresh") #20130418 xbmc.output virker ikke med XBMC12 @@ -309,10 +390,13 @@ elif mode == 10: search() + +elif mode == 11: + searchSeries() elif mode == 50: - play_video(url, name) + play_video(url, name, description)