Добавил немного игрищ и блудниц. 1.2.0

master 1.2.0
inpos 2017-02-12 14:30:11 +03:00
parent e0f86458c8
commit b427b73ac4
7 changed files with 45 additions and 10 deletions

View File

@ -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"/>

View File

@ -1,3 +1,7 @@
v1.2.0 (2017-02-12)
- Сообщество или пользователя можно добавить в избранное из контекстного меню заголовка (Пользователь: или Сообщество:).
- У каждой видеозаписи добавлен пункт контекстного меню с указанием владельца, через который можно перейти к странице.
v1.1.0 (2017-02-04) v1.1.0 (2017-02-04)
- Добавил информационнаые оповещения, где необходимо. Сделал пункт "Выход из учётной записи" главного экрана. - Добавил информационнаые оповещения, где необходимо. Сделал пункт "Выход из учётной записи" главного экрана.

View File

@ -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

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

After

Width:  |  Height:  |  Size: 9.2 KiB

View File

@ -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]"

View File

@ -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]"

View File

@ -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"/>