Версия 0.9.0

master
inpos 2017-01-30 23:16:23 +03:00
parent a05fa3ee98
commit 30c73da8b3
3 changed files with 61 additions and 12 deletions

View File

@ -1,10 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<addon id="kodi-vk.inpos.ru" <addon id="kodi-vk.inpos.ru"
version="0.1.0" version="0.9.0"
name="VK Add-on" name="VK Add-on"
provider-name="inpos"> provider-name="inpos">
<requires> <requires>
<import addon="xbmc.python" version="2.1"/> <import addon="xbmc.python" version="2.1"/>
<import addon="script.module.vk" />
</requires> </requires>
<extension point="xbmc.python.pluginsource" library="default.py"> <extension point="xbmc.python.pluginsource" library="default.py">
<provides>image video audio</provides> <provides>image video audio</provides>

View File

@ -1,3 +1,6 @@
v0.9.0 (2017-01-30)
- Сделан весь функционал, кроме поиска
v0.1.0 (2017-01-29) v0.1.0 (2017-01-29)
- Сделан весь функционал фидеозаписей и фотографий - Сделан весь функционал фидеозаписей и фотографий

View File

@ -94,7 +94,7 @@ class Group(object):
def set_info(self): def set_info(self):
self.info = self.conn.groups.getById(group_id = int(self.id) * -1)[0] self.info = self.conn.groups.getById(group_id = int(self.id) * -1)[0]
def members(self, page_items = _SETTINGS_PAGE_ITEMS, page = 1): def members(self, page_items = _SETTINGS_PAGE_ITEMS, page = 1):
m = self.conn.groups.get(group_id = self.id, m = self.conn.groups.getMembers(group_id = self.id,
offset = ((page_items * page) - page_items), offset = ((page_items * page) - page_items),
fields = 'first_name,last_name,photo_50,photo_100,photo_200', fields = 'first_name,last_name,photo_50,photo_100,photo_200',
count = page_items) count = page_items)
@ -317,13 +317,14 @@ class KodiVKGUIVideos(object):
'plot' : v.info['description'] 'plot' : v.info['description']
} }
) )
list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info['photo_320']}) p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), v.info.keys()))),)
list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info[p_key]})
list_item.setProperty('IsPlayable', 'true') list_item.setProperty('IsPlayable', 'true')
v_source = self.__get_video_source_(v) v_source = self.__get_video_source_(v)
if v_source == _VK_VIDEO_SOURCE: if v_source == _VK_VIDEO_SOURCE:
params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE} params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE}
url = self.root.url(**params) url = self.root.url(**params)
if v_source == _YOUTUBE_VIDEO_SOURCE: elif v_source == _YOUTUBE_VIDEO_SOURCE:
if 'files' in v.info.keys(): if 'files' in v.info.keys():
y_url = v.info['files']['external'] y_url = v.info['files']['external']
else: else:
@ -335,6 +336,7 @@ class KodiVKGUIVideos(object):
y_id = sr[0][1] y_id = sr[0][1]
url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id
else: else:
xbmc.log(repr(v.info))
continue continue
xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = False) xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = False)
if page < vids['pages']: if page < vids['pages']:
@ -398,14 +400,16 @@ class KodiVkGUI:
g = Group(oid, self.root.conn) g = Group(oid, self.root.conn)
g.set_info() g.set_info()
header_string = u'%s [I]%s[/I]' % (self._string(400604).decode('utf-8'), g.info['name']) header_string = u'%s [I]%s[/I]' % (self._string(400604).decode('utf-8'), g.info['name'])
thumb_url = g.info['photo_200'] p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), g.info.keys()))),)
icon_url = g.info['photo_100'] thumb_url = g.info[p_key]
icon_url = g.info[p_key]
else: else:
u = User(oid, self.root.conn) u = User(oid, self.root.conn)
u.set_info() u.set_info()
header_string = u'%s [I]%s %s[/I]' % (self._string(400603).decode('utf-8'), u.info['last_name'], u.info['first_name']) header_string = u'%s [I]%s %s[/I]' % (self._string(400603).decode('utf-8'), u.info['last_name'], u.info['first_name'])
thumb_url = u.info['photo_200'] p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), u.info.keys()))),)
icon_url = u.info['photo_100'] thumb_url = u.info[p_key]
icon_url = u.info[p_key]
list_item = xbmcgui.ListItem(header_string) list_item = xbmcgui.ListItem(header_string)
list_item.setArt({'thumb': thumb_url, 'icon': icon_url}) list_item.setArt({'thumb': thumb_url, 'icon': icon_url})
xbmcplugin.addDirectoryItem(_addon_id, None, list_item, isFolder = False) xbmcplugin.addDirectoryItem(_addon_id, None, list_item, isFolder = False)
@ -419,10 +423,10 @@ class KodiVkGUI:
xbmc.log('Unknown content_type: %s' % (c_type,)) xbmc.log('Unknown content_type: %s' % (c_type,))
return return
if int(oid) > 0: if int(oid) > 0:
self.root.add_folder(self._string(400505), {'do': _DO_FRIENDS, 'oid': oid}) self.root.add_folder(self._string(400505), {'do': _DO_FRIENDS, 'oid': oid, 'page': 1})
self.root.add_folder(self._string(400506), {'do': _DO_GROUPS, 'oid': oid, 'page': 1}) self.root.add_folder(self._string(400506), {'do': _DO_GROUPS, 'oid': oid, 'page': 1})
else: else:
self.root.add_folder(self._string(400512), {'do': _DO_MEMBERS, 'oid': oid}) self.root.add_folder(self._string(400512), {'do': _DO_MEMBERS, 'oid': -int(oid), 'page': 1})
xbmcplugin.endOfDirectory(_addon_id) xbmcplugin.endOfDirectory(_addon_id)
def _groups(self): def _groups(self):
oid = self.root.params['oid'] oid = self.root.params['oid']
@ -434,7 +438,8 @@ class KodiVkGUI:
self.root.add_folder(self.root.gui._string(400602), params) self.root.add_folder(self.root.gui._string(400602), params)
for g in groups['items']: for g in groups['items']:
list_item = xbmcgui.ListItem(g.info['name']) list_item = xbmcgui.ListItem(g.info['name'])
list_item.setArt({'thumb': g.info['photo_100'], 'icon': g.info['photo_200']}) p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), g.info.keys()))),)
list_item.setArt({'thumb': g.info[p_key], 'icon': g.info[p_key]})
params = {'do': _DO_HOME, 'oid': -g.id} params = {'do': _DO_HOME, 'oid': -g.id}
url = self.root.url(**params) url = self.root.url(**params)
xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = True) xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = True)
@ -442,6 +447,44 @@ class KodiVkGUI:
params = {'do': _DO_GROUPS, 'oid': oid, 'page': page + 1} params = {'do': _DO_GROUPS, 'oid': oid, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params) self.root.add_folder(self.root.gui._string(400602), params)
xbmcplugin.endOfDirectory(_addon_id) xbmcplugin.endOfDirectory(_addon_id)
def _friends(self):
oid = self.root.params['oid']
page = int(self.root.params['page'])
user = User(oid, self.root.conn)
friends = user.friends(page = page)
if page < friends['pages']:
params = {'do': _DO_FRIENDS, 'oid': oid, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params)
for f in friends['items']:
list_item = xbmcgui.ListItem(u'%s %s' % (f.info['last_name'], f.info['first_name']))
p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), f.info.keys()))),)
list_item.setArt({'thumb': f.info[p_key], 'icon': f.info[p_key]})
params = {'do': _DO_HOME, 'oid': f.id}
url = self.root.url(**params)
xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = True)
if page < friends['pages']:
params = {'do': _DO_FRIENDS, 'oid': oid, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params)
xbmcplugin.endOfDirectory(_addon_id)
def _members(self):
oid = self.root.params['oid']
page = int(self.root.params['page'])
group = Group(oid, self.root.conn)
members = group.members(page = page)
if page < members['pages']:
params = {'do': _DO_MEMBERS, 'oid': oid, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params)
for m in members['items']:
list_item = xbmcgui.ListItem(u'%s %s' % (m.info['last_name'], m.info['first_name']))
p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), m.info.keys()))),)
list_item.setArt({'thumb': m.info[p_key], 'icon': m.info[p_key]})
params = {'do': _DO_HOME, 'oid': m.id}
url = self.root.url(**params)
xbmcplugin.addDirectoryItem(_addon_id, url, list_item, isFolder = True)
if page < members['pages']:
params = {'do': _DO_MEMBERS, 'oid': oid, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params)
xbmcplugin.endOfDirectory(_addon_id)
class KodiVk: class KodiVk:
conn = None conn = None
@ -510,7 +553,9 @@ if __name__ == '__main__':
_DO_VIDEO: kvk.gui.videos._video, _DO_VIDEO: kvk.gui.videos._video,
_DO_VIDEO_ALBUMS: kvk.gui.videos._video_albums, _DO_VIDEO_ALBUMS: kvk.gui.videos._video_albums,
_DO_PLAY_VIDEO: kvk.gui.videos._play_video, _DO_PLAY_VIDEO: kvk.gui.videos._play_video,
_DO_GROUPS: kvk.gui._groups _DO_GROUPS: kvk.gui._groups,
_DO_FRIENDS: kvk.gui._friends,
_DO_MEMBERS: kvk.gui._members
} }
_do_method = kvk.params['do'] _do_method = kvk.params['do']