parent
e0f86458c8
commit
b427b73ac4
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<addon id="kodi-vk.inpos.ru" version="1.1.3" name="VK Add-on" provider-name="inpos">
|
<addon id="kodi-vk.inpos.ru" version="1.2.0" name="VK Add-on" provider-name="inpos">
|
||||||
<requires>
|
<requires>
|
||||||
<import addon="xbmc.python" version="2.14.0"/>
|
<import addon="xbmc.python" version="2.14.0"/>
|
||||||
<import addon="script.module.vk"/>
|
<import addon="script.module.vk"/>
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
v1.2.0 (2017-02-12)
|
||||||
|
- Сообщество или пользователя можно добавить в избранное из контекстного меню заголовка (Пользователь: или Сообщество:).
|
||||||
|
- У каждой видеозаписи добавлен пункт контекстного меню с указанием владельца, через который можно перейти к странице.
|
||||||
|
|
||||||
v1.1.0 (2017-02-04)
|
v1.1.0 (2017-02-04)
|
||||||
- Добавил информационнаые оповещения, где необходимо. Сделал пункт "Выход из учётной записи" главного экрана.
|
- Добавил информационнаые оповещения, где необходимо. Сделал пункт "Выход из учётной записи" главного экрана.
|
||||||
|
|
||||||
|
|
38
default.py
38
default.py
|
@ -7,7 +7,7 @@ import urllib2
|
||||||
from urllib import urlencode
|
from urllib import urlencode
|
||||||
import re
|
import re
|
||||||
|
|
||||||
_VERSION = '1.1.3'
|
_VERSION = '1.2.0'
|
||||||
|
|
||||||
_ADDON_NAME = 'kodi-vk.inpos.ru'
|
_ADDON_NAME = 'kodi-vk.inpos.ru'
|
||||||
_addon = xbmcaddon.Addon(id = _ADDON_NAME)
|
_addon = xbmcaddon.Addon(id = _ADDON_NAME)
|
||||||
|
@ -21,6 +21,7 @@ _SCOPE = 'friends,photos,audio,video,groups,messages,offline'
|
||||||
|
|
||||||
_SETTINGS_ID_TOKEN = 'vk_token'
|
_SETTINGS_ID_TOKEN = 'vk_token'
|
||||||
_SETTINGS_ID_MAX_RES = 'video_resolution'
|
_SETTINGS_ID_MAX_RES = 'video_resolution'
|
||||||
|
_SETTINGS_ID_LIST_LEN = 'list_len'
|
||||||
_SETTINGS_ID_VIDEO_SEARCH_SORT = 'v_search_sort'
|
_SETTINGS_ID_VIDEO_SEARCH_SORT = 'v_search_sort'
|
||||||
_SETTINGS_ID_VIDEO_SEARCH_HD = 'search_hd_video'
|
_SETTINGS_ID_VIDEO_SEARCH_HD = 'search_hd_video'
|
||||||
_SETTINGS_ID_VIDEO_SEARCH_ADULT = 'dont_search_adult_video'
|
_SETTINGS_ID_VIDEO_SEARCH_ADULT = 'dont_search_adult_video'
|
||||||
|
@ -28,7 +29,7 @@ _SETTINGS_ID_VIDEO_SEARCH_ADULT = 'dont_search_adult_video'
|
||||||
_SETTINGS_BOOL = {'true': 1, 'false': 0}
|
_SETTINGS_BOOL = {'true': 1, 'false': 0}
|
||||||
_SETTINGS_INV_BOOL = {'true': 0, 'false': 1}
|
_SETTINGS_INV_BOOL = {'true': 0, 'false': 1}
|
||||||
|
|
||||||
_SETTINGS_PAGE_ITEMS = 20
|
_SETTINGS_PAGE_ITEMS = int(_addon.getSetting(_SETTINGS_ID_LIST_LEN))
|
||||||
_SETTINGS_MAX_RES = int(_addon.getSetting(_SETTINGS_ID_MAX_RES))
|
_SETTINGS_MAX_RES = int(_addon.getSetting(_SETTINGS_ID_MAX_RES))
|
||||||
_SETTINGS_VIDEO_SEARCH_SORT = int(_addon.getSetting(_SETTINGS_ID_VIDEO_SEARCH_SORT))
|
_SETTINGS_VIDEO_SEARCH_SORT = int(_addon.getSetting(_SETTINGS_ID_VIDEO_SEARCH_SORT))
|
||||||
_SETTINGS_VIDEO_SEARCH_HD = _SETTINGS_BOOL[_addon.getSetting(_SETTINGS_ID_VIDEO_SEARCH_HD)]
|
_SETTINGS_VIDEO_SEARCH_HD = _SETTINGS_BOOL[_addon.getSetting(_SETTINGS_ID_VIDEO_SEARCH_HD)]
|
||||||
|
@ -189,7 +190,12 @@ def media_entries(e_method, conn, oid, **kwargs):
|
||||||
e = Entry(e_method, entry_id, conn)
|
e = Entry(e_method, entry_id, conn)
|
||||||
e.info = i
|
e.info = i
|
||||||
l.append(e)
|
l.append(e)
|
||||||
return {'pages': pages, 'total': count, 'items': l}
|
del entries['count']
|
||||||
|
del entries['items']
|
||||||
|
res = {'pages': pages, 'total': count, 'items': l}
|
||||||
|
for k in entries.keys():
|
||||||
|
res[k] = entries[k]
|
||||||
|
return res
|
||||||
|
|
||||||
class Entry(object):
|
class Entry(object):
|
||||||
def __init__(self, e_method, eid, conn):
|
def __init__(self, e_method, eid, conn):
|
||||||
|
@ -515,7 +521,8 @@ class KodiVKGUIVideos(object):
|
||||||
'sort': _SETTINGS_VIDEO_SEARCH_SORT,
|
'sort': _SETTINGS_VIDEO_SEARCH_SORT,
|
||||||
'hd' : _SETTINGS_VIDEO_SEARCH_HD,
|
'hd' : _SETTINGS_VIDEO_SEARCH_HD,
|
||||||
'adult': _SETTINGS_VIDEO_SEARCH_ADULT,
|
'adult': _SETTINGS_VIDEO_SEARCH_ADULT,
|
||||||
'q': q
|
'q': q,
|
||||||
|
'extended': 1
|
||||||
}
|
}
|
||||||
search_res = media_entries('video.search', self.root.conn, _NO_OWNER, **kwargs)
|
search_res = media_entries('video.search', self.root.conn, _NO_OWNER, **kwargs)
|
||||||
if page < search_res['pages']:
|
if page < search_res['pages']:
|
||||||
|
@ -536,6 +543,17 @@ class KodiVKGUIVideos(object):
|
||||||
def __create_video_list_(self, vids):
|
def __create_video_list_(self, vids):
|
||||||
for v in vids['items']:
|
for v in vids['items']:
|
||||||
list_item = xbmcgui.ListItem(v.info['title'])
|
list_item = xbmcgui.ListItem(v.info['title'])
|
||||||
|
oid = v.info['owner_id']
|
||||||
|
if int(oid) < 0:
|
||||||
|
gid = oid * -1
|
||||||
|
g = filter(lambda x: x['id'] == gid, vids['groups'])[0]
|
||||||
|
cm_title = u'%s [I]%s[/I]' % (self.root.gui._string(400604).decode('utf-8'), g['name'])
|
||||||
|
else:
|
||||||
|
u = filter(lambda x: x['id'] == oid, vids['profiles'])[0]
|
||||||
|
cm_title = u'%s [I]%s %s[/I]' % (self.root.gui._string(400603).decode('utf-8'), u['last_name'], u['first_name'])
|
||||||
|
cm_params = {'do': _DO_HOME, 'oid': oid}
|
||||||
|
cm_url = self.root.url(**cm_params)
|
||||||
|
list_item.addContextMenuItems([(cm_title, 'xbmc.Container.update(%s)' % (cm_url,))])
|
||||||
list_item.setInfo('video', {
|
list_item.setInfo('video', {
|
||||||
'title' : v.info['title'],
|
'title' : v.info['title'],
|
||||||
'duration' : int(v.info['duration']),
|
'duration' : int(v.info['duration']),
|
||||||
|
@ -573,7 +591,10 @@ class KodiVKGUIVideos(object):
|
||||||
def _video_albums(self):
|
def _video_albums(self):
|
||||||
page = int(self.root.params['page'])
|
page = int(self.root.params['page'])
|
||||||
oid = self.root.params['oid']
|
oid = self.root.params['oid']
|
||||||
kwargs = {'page': page, 'extended': 1}
|
kwargs = {
|
||||||
|
'page': page,
|
||||||
|
'extended': 1
|
||||||
|
}
|
||||||
albums = media_entries('video.getAlbums', self.root.conn, oid, **kwargs)
|
albums = media_entries('video.getAlbums', self.root.conn, oid, **kwargs)
|
||||||
if page < albums['pages']:
|
if page < albums['pages']:
|
||||||
params = {'do': _DO_VIDEO_ALBUMS,'oid': oid,'page': page + 1}
|
params = {'do': _DO_VIDEO_ALBUMS,'oid': oid,'page': page + 1}
|
||||||
|
@ -594,7 +615,7 @@ class KodiVKGUIVideos(object):
|
||||||
page = int(self.root.params['page'])
|
page = int(self.root.params['page'])
|
||||||
oid = self.root.params['oid']
|
oid = self.root.params['oid']
|
||||||
album = self.root.params.get('album', None)
|
album = self.root.params.get('album', None)
|
||||||
kwargs = {'page': page}
|
kwargs = {'page': page, 'extended': 1}
|
||||||
if album: kwargs['album'] = album
|
if album: kwargs['album'] = album
|
||||||
vids = media_entries('video.get', self.root.conn, oid, **kwargs)
|
vids = media_entries('video.get', self.root.conn, oid, **kwargs)
|
||||||
if page < vids['pages']:
|
if page < vids['pages']:
|
||||||
|
@ -684,7 +705,8 @@ class KodiVkGUI:
|
||||||
icon_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)
|
h_url = self.root.url({'do': _DO_HOME, 'oid': oid})
|
||||||
|
xbmcplugin.addDirectoryItem(_addon_id, h_url, list_item, isFolder = True)
|
||||||
if c_type == _CTYPE_VIDEO:
|
if c_type == _CTYPE_VIDEO:
|
||||||
self.root.add_folder(self._string(400502), {'do': _DO_MAIN_VIDEO, 'oid': oid})
|
self.root.add_folder(self._string(400502), {'do': _DO_MAIN_VIDEO, 'oid': oid})
|
||||||
#elif c_type == _CTYPE_AUDIO:
|
#elif c_type == _CTYPE_AUDIO:
|
||||||
|
@ -890,9 +912,9 @@ class KodiVk:
|
||||||
self.u = User(u_info['id'], self.conn)
|
self.u = User(u_info['id'], self.conn)
|
||||||
self.u.set_info()
|
self.u.set_info()
|
||||||
p = {'do': _DO_HOME}
|
p = {'do': _DO_HOME}
|
||||||
p['oid'] = self.u.info['id']
|
|
||||||
if sys.argv[2]:
|
if sys.argv[2]:
|
||||||
p.update(dict(urlparse.parse_qsl(sys.argv[2][1:])))
|
p.update(dict(urlparse.parse_qsl(sys.argv[2][1:])))
|
||||||
|
p['oid'] = int(p.get('oid', self.u.info['id']))
|
||||||
self.params = p
|
self.params = p
|
||||||
if 'content_type' not in self.params.keys():
|
if 'content_type' not in self.params.keys():
|
||||||
cw_id = xbmcgui.getCurrentWindowId()
|
cw_id = xbmcgui.getCurrentWindowId()
|
||||||
|
|
BIN
icon.png
BIN
icon.png
Binary file not shown.
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 9.2 KiB |
|
@ -124,6 +124,10 @@ msgctxt "#400529"
|
||||||
msgid "No"
|
msgid "No"
|
||||||
msgstr "No"
|
msgstr "No"
|
||||||
|
|
||||||
|
msgctxt "#400530"
|
||||||
|
msgid "List length"
|
||||||
|
msgstr "List length"
|
||||||
|
|
||||||
msgctxt "#400601"
|
msgctxt "#400601"
|
||||||
msgid "Previous page"
|
msgid "Previous page"
|
||||||
msgstr "[B]Previous page[/B]"
|
msgstr "[B]Previous page[/B]"
|
||||||
|
|
|
@ -124,6 +124,10 @@ msgctxt "#400529"
|
||||||
msgid "No"
|
msgid "No"
|
||||||
msgstr "Нет"
|
msgstr "Нет"
|
||||||
|
|
||||||
|
msgctxt "#400530"
|
||||||
|
msgid "List length"
|
||||||
|
msgstr "Длина списка"
|
||||||
|
|
||||||
msgctxt "#400601"
|
msgctxt "#400601"
|
||||||
msgid "Previous page"
|
msgid "Previous page"
|
||||||
msgstr "[B]Предыдущая страница[/B]"
|
msgstr "[B]Предыдущая страница[/B]"
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
<settings>
|
<settings>
|
||||||
<setting id="vk_token" type="text" label="400507" default="" visible="false" />
|
<setting id="vk_token" type="text" label="400507" default="" visible="false" />
|
||||||
<setting id="video_resolution" type="select" label="400517" default="1080" values="240|360|480|720|1080" />
|
<setting id="video_resolution" type="select" label="400517" default="1080" values="240|360|480|720|1080" />
|
||||||
|
<setting id="list_len" type="select" label="400530" default="20" values="20|50|100" />
|
||||||
<setting label="400518" type="enum" id="v_search_sort" default="2" lvalues="400519|400520|400521"/>
|
<setting label="400518" type="enum" id="v_search_sort" default="2" lvalues="400519|400520|400521"/>
|
||||||
<setting label="400522" type="bool" id="search_hd_video" default="false"/>
|
<setting label="400522" type="bool" id="search_hd_video" default="false"/>
|
||||||
<setting label="400523" type="bool" id="dont_search_adult_video" default="true"/>
|
<setting label="400523" type="bool" id="dont_search_adult_video" default="true"/>
|
||||||
|
|
Loading…
Reference in New Issue