Добавил начальный экран

master
inpos 2017-01-26 19:47:37 +03:00
parent 56ed18091a
commit 586b021dac
2 changed files with 60 additions and 4 deletions

View File

@ -20,6 +20,15 @@ _USERNAME = 'vk_username'
_LOGIN_RETRY = 3 _LOGIN_RETRY = 3
_VK_API_VERSION = '5.62' _VK_API_VERSION = '5.62'
_CTYPE_VIDEO = 'video'
_CTYPE_AUDIO = 'audio'
_CTYPE_IMAGE = 'image'
_DO_HOME = 'home'
_DO_MY_VIDEO = 'my_video'
_DO_MY_AUDIO = 'my_audio'
_DO_MY_PHOTO = 'my_photo'
DELAY = 1.0 / 3 # 3 запроса в секунду DELAY = 1.0 / 3 # 3 запроса в секунду
# Служебные классы # Служебные классы
@ -137,6 +146,8 @@ class User(object):
class KodiVkGUI: class KodiVkGUI:
'''Окошки, диалоги, сообщения''' '''Окошки, диалоги, сообщения'''
def __init__(self, root):
self.root = root
def _string(self, string_id): def _string(self, string_id):
return _addon.getLocalizedString(string_id).encode('utf-8') return _addon.getLocalizedString(string_id).encode('utf-8')
def _login_form(self): def _login_form(self):
@ -157,19 +168,41 @@ class KodiVkGUI:
raise Exception("Password input was cancelled.") raise Exception("Password input was cancelled.")
else: else:
raise Exception("Login input was cancelled.") raise Exception("Login input was cancelled.")
def _home(self):
c_type = self.root.params.get('content_type', None)
if not c_type:
xbmc.log('No content_type')
return
if c_type == _CTYPE_VIDEO:
self.root.add_folder(self._string(400502), {'do': _DO_MY_VIDEO})
elif c_type == _CTYPE_AUDIO:
self.root.add_folder(self._string(400503), {'do': _DO_MY_AUDIO})
elif c_type == _CTYPE_IMAGE:
self.root.add_folder(self._string(400504), {'do': _DO_MY_PHOTO})
else:
xbmc.log('Unknown content_type: %s' % (c_type,))
return
class KodiVk: class KodiVk:
conn = None conn = None
def __init__(self): def __init__(self):
self.gui = KodiVkGUI() self.gui = KodiVkGUI(self)
self.paramstring = sys.argv[2] p = {'do': _DO_HOME}
if sys.argv[2]:
p.update(dict(urlparse.parse_qsl(sys.argv[2][1:])))
self.params = p
self.conn = self.__connect_() self.conn = self.__connect_()
u_info = self.conn.users.get()[0] u_info = self.conn.users.get()[0]
self.u = User(u_info['id'], self.conn) self.u = User(u_info['id'], self.conn)
self.u.info = u_info self.u.info = u_info
@property @property
def params(self): def params(self):
return dict(urlparse.parse_qsl(self.paramstring[1:])) p = {'do': _DO_HOME}
if self.paramstring:
p.update(dict(urlparse.parse_qsl(self.paramstring[1:])))
return p
def url(self, params=dict(), **kwparams): def url(self, params=dict(), **kwparams):
params.update(kwparams) params.update(kwparams)
return _addon_url + "?" + urlencode(params) return _addon_url + "?" + urlencode(params)
@ -197,4 +230,8 @@ class KodiVk:
except vk.api.VkAuthError: except vk.api.VkAuthError:
continue continue
return conn return conn
if __name__ == '__main__':
kvk = KodiVk()
if kvk.params['do'] == _DO_HOME:
kvk.gui._home()

View File

@ -12,3 +12,22 @@ msgctxt "#400501"
msgid "Password:" msgid "Password:"
msgstr "Password:" msgstr "Password:"
msgctxt "#400502"
msgid "Videos"
msgstr "My video"
msgctxt "#400503"
msgid "My audio"
msgstr "My audio"
msgctxt "#400504"
msgid "My photo"
msgstr "My photo"
msgctxt "#400505"
msgid "Friends"
msgstr "Friends"
msgctxt "#400506"
msgid "Groups"
msgstr "Groups"