Версия 0.9.0
parent
a05fa3ee98
commit
30c73da8b3
|
@ -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>
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
v0.9.0 (2017-01-30)
|
||||||
|
- Сделан весь функционал, кроме поиска
|
||||||
|
|
||||||
v0.1.0 (2017-01-29)
|
v0.1.0 (2017-01-29)
|
||||||
- Сделан весь функционал фидеозаписей и фотографий
|
- Сделан весь функционал фидеозаписей и фотографий
|
||||||
|
|
||||||
|
|
|
@ -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']
|
||||||
|
|
Loading…
Reference in New Issue