Remove message + protect option
This commit is contained in:
@@ -43,6 +43,10 @@ def show_option(channel, itemlist, text_color='yellow', thumbnail=None, fanart=N
|
|||||||
:return:
|
:return:
|
||||||
'''
|
'''
|
||||||
logger.info()
|
logger.info()
|
||||||
|
|
||||||
|
if not config.is_xbmc():
|
||||||
|
return itemlist
|
||||||
|
|
||||||
if thumbnail == None:
|
if thumbnail == None:
|
||||||
thumbnail = 'https://s7.postimg.org/65ooga04b/Auto_Play.png'
|
thumbnail = 'https://s7.postimg.org/65ooga04b/Auto_Play.png'
|
||||||
if fanart == None:
|
if fanart == None:
|
||||||
@@ -74,228 +78,228 @@ def start(itemlist, item):
|
|||||||
:return: intenta autoreproducir, en caso de fallar devuelve el itemlist que recibio en un principio
|
:return: intenta autoreproducir, en caso de fallar devuelve el itemlist que recibio en un principio
|
||||||
'''
|
'''
|
||||||
logger.info()
|
logger.info()
|
||||||
global autoplay_node
|
|
||||||
|
|
||||||
if not config.is_xbmc():
|
if not config.is_xbmc():
|
||||||
platformtools.dialog_notification('AutoPlay ERROR', 'Sólo disponible para XBMC/Kodi')
|
#platformtools.dialog_notification('AutoPlay ERROR', 'Sólo disponible para XBMC/Kodi')
|
||||||
return itemlist
|
return itemlist
|
||||||
else:
|
|
||||||
if not autoplay_node:
|
|
||||||
# Obtiene el nodo AUTOPLAY desde el json
|
|
||||||
autoplay_node = jsontools.get_node_from_file('autoplay', 'AUTOPLAY')
|
|
||||||
|
|
||||||
# Agrega servidores y calidades que no estaban listados a autoplay_node
|
global autoplay_node
|
||||||
new_options = check_value(item.channel, itemlist)
|
if not autoplay_node:
|
||||||
|
# Obtiene el nodo AUTOPLAY desde el json
|
||||||
|
autoplay_node = jsontools.get_node_from_file('autoplay', 'AUTOPLAY')
|
||||||
|
|
||||||
# Obtiene el nodo del canal desde autoplay_node
|
# Agrega servidores y calidades que no estaban listados a autoplay_node
|
||||||
channel_node = autoplay_node.get(item.channel, {})
|
new_options = check_value(item.channel, itemlist)
|
||||||
# Obtiene los ajustes des autoplay para este canal
|
|
||||||
settings_node = channel_node.get('settings', {})
|
|
||||||
|
|
||||||
if settings_node['active']:
|
# Obtiene el nodo del canal desde autoplay_node
|
||||||
url_list_valid = []
|
channel_node = autoplay_node.get(item.channel, {})
|
||||||
autoplay_list = []
|
# Obtiene los ajustes des autoplay para este canal
|
||||||
favorite_servers = []
|
settings_node = channel_node.get('settings', {})
|
||||||
favorite_quality = []
|
|
||||||
|
|
||||||
# Guarda el valor actual de "Accion y Player Mode" en preferencias
|
if settings_node['active']:
|
||||||
user_config_setting_action = config.get_setting("default_action")
|
url_list_valid = []
|
||||||
user_config_setting_player = config.get_setting("player_mode")
|
autoplay_list = []
|
||||||
# Habilita la accion "Ver en calidad alta" (si el servidor devuelve más de una calidad p.e. gdrive)
|
favorite_servers = []
|
||||||
if user_config_setting_action != 2:
|
favorite_quality = []
|
||||||
config.set_setting("default_action", 2)
|
|
||||||
if user_config_setting_player != 0:
|
|
||||||
config.set_setting("player_mode", 0)
|
|
||||||
|
|
||||||
# Informa que AutoPlay esta activo
|
# Guarda el valor actual de "Accion y Player Mode" en preferencias
|
||||||
platformtools.dialog_notification('AutoPlay Activo', '', sound=False)
|
user_config_setting_action = config.get_setting("default_action")
|
||||||
|
user_config_setting_player = config.get_setting("player_mode")
|
||||||
|
# Habilita la accion "Ver en calidad alta" (si el servidor devuelve más de una calidad p.e. gdrive)
|
||||||
|
if user_config_setting_action != 2:
|
||||||
|
config.set_setting("default_action", 2)
|
||||||
|
if user_config_setting_player != 0:
|
||||||
|
config.set_setting("player_mode", 0)
|
||||||
|
|
||||||
# Prioridades a la hora de ordenar itemlist:
|
# Informa que AutoPlay esta activo
|
||||||
# 0: Servidores y calidades
|
platformtools.dialog_notification('AutoPlay Activo', '', sound=False)
|
||||||
# 1: Calidades y servidores
|
|
||||||
# 2: Solo servidores
|
|
||||||
# 3: Solo calidades
|
|
||||||
# 4: No ordenar
|
|
||||||
if settings_node['custom_servers'] and settings_node['custom_quality']:
|
|
||||||
priority = settings_node['priority'] # 0: Servidores y calidades o 1: Calidades y servidores
|
|
||||||
elif settings_node['custom_servers']:
|
|
||||||
priority = 2 # Solo servidores
|
|
||||||
elif settings_node['custom_quality']:
|
|
||||||
priority = 3 # Solo calidades
|
|
||||||
else:
|
|
||||||
priority = 4 # No ordenar
|
|
||||||
|
|
||||||
# Obtiene las listas servidores, calidades disponibles desde el nodo del json de AutoPlay
|
# Prioridades a la hora de ordenar itemlist:
|
||||||
server_list = channel_node.get('servers', [])
|
# 0: Servidores y calidades
|
||||||
quality_list = channel_node.get('quality', [])
|
# 1: Calidades y servidores
|
||||||
|
# 2: Solo servidores
|
||||||
|
# 3: Solo calidades
|
||||||
|
# 4: No ordenar
|
||||||
|
if settings_node['custom_servers'] and settings_node['custom_quality']:
|
||||||
|
priority = settings_node['priority'] # 0: Servidores y calidades o 1: Calidades y servidores
|
||||||
|
elif settings_node['custom_servers']:
|
||||||
|
priority = 2 # Solo servidores
|
||||||
|
elif settings_node['custom_quality']:
|
||||||
|
priority = 3 # Solo calidades
|
||||||
|
else:
|
||||||
|
priority = 4 # No ordenar
|
||||||
|
|
||||||
# Se guardan los textos de cada servidor y calidad en listas p.e. favorite_servers = ['openload',
|
# Obtiene las listas servidores, calidades disponibles desde el nodo del json de AutoPlay
|
||||||
# 'streamcloud']
|
server_list = channel_node.get('servers', [])
|
||||||
for num in range(1, 4):
|
quality_list = channel_node.get('quality', [])
|
||||||
favorite_servers.append(channel_node['servers'][settings_node['server_%s' % num]])
|
|
||||||
favorite_quality.append(channel_node['quality'][settings_node['quality_%s' % num]])
|
|
||||||
|
|
||||||
# Se filtran los enlaces de itemlist y que se correspondan con los valores de autoplay
|
# Se guardan los textos de cada servidor y calidad en listas p.e. favorite_servers = ['openload',
|
||||||
for item in itemlist:
|
# 'streamcloud']
|
||||||
autoplay_elem = dict()
|
for num in range(1, 4):
|
||||||
|
favorite_servers.append(channel_node['servers'][settings_node['server_%s' % num]])
|
||||||
|
favorite_quality.append(channel_node['quality'][settings_node['quality_%s' % num]])
|
||||||
|
|
||||||
# Comprobamos q se trata de un item de video
|
# Se filtran los enlaces de itemlist y que se correspondan con los valores de autoplay
|
||||||
if 'server' not in item:
|
for item in itemlist:
|
||||||
|
autoplay_elem = dict()
|
||||||
|
|
||||||
|
# Comprobamos q se trata de un item de video
|
||||||
|
if 'server' not in item:
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Agrega la opcion configurar AutoPlay al menu contextual
|
||||||
|
if 'context' not in item:
|
||||||
|
item.context = list()
|
||||||
|
if not filter(lambda x: x['action'] == 'autoplay_config', context):
|
||||||
|
item.context.append({"title": "Configurar AutoPlay",
|
||||||
|
"action": "autoplay_config",
|
||||||
|
"channel": "autoplay",
|
||||||
|
"from_channel": item.channel})
|
||||||
|
|
||||||
|
# Si no tiene calidad definida le asigna calidad 'default'
|
||||||
|
if item.quality == '':
|
||||||
|
item.quality = 'default'
|
||||||
|
|
||||||
|
# Se crea la lista para configuracion personalizada
|
||||||
|
if priority < 2: # 0: Servidores y calidades o 1: Calidades y servidores
|
||||||
|
|
||||||
|
# si el servidor y la calidad no se encuentran en las listas de favoritos o la url esta repetida,
|
||||||
|
# descartamos el item
|
||||||
|
if item.server not in favorite_servers or item.quality not in favorite_quality \
|
||||||
|
or item.url in url_list_valid:
|
||||||
continue
|
continue
|
||||||
|
autoplay_elem["indice_server"] = favorite_servers.index(item.server)
|
||||||
# Agrega la opcion configurar AutoPlay al menu contextual
|
autoplay_elem["indice_quality"] = favorite_quality.index(item.quality)
|
||||||
if 'context' not in item:
|
|
||||||
item.context = list()
|
|
||||||
if not filter(lambda x: x['action'] == 'autoplay_config', context):
|
|
||||||
item.context.append({"title": "Configurar AutoPlay",
|
|
||||||
"action": "autoplay_config",
|
|
||||||
"channel": "autoplay",
|
|
||||||
"from_channel": item.channel})
|
|
||||||
|
|
||||||
# Si no tiene calidad definida le asigna calidad 'default'
|
|
||||||
if item.quality == '':
|
|
||||||
item.quality = 'default'
|
|
||||||
|
|
||||||
# Se crea la lista para configuracion personalizada
|
|
||||||
if priority < 2: # 0: Servidores y calidades o 1: Calidades y servidores
|
|
||||||
|
|
||||||
# si el servidor y la calidad no se encuentran en las listas de favoritos o la url esta repetida,
|
|
||||||
# descartamos el item
|
|
||||||
if item.server not in favorite_servers or item.quality not in favorite_quality \
|
|
||||||
or item.url in url_list_valid:
|
|
||||||
continue
|
|
||||||
autoplay_elem["indice_server"] = favorite_servers.index(item.server)
|
|
||||||
autoplay_elem["indice_quality"] = favorite_quality.index(item.quality)
|
|
||||||
|
|
||||||
elif priority == 2: # Solo servidores
|
|
||||||
|
|
||||||
# si el servidor no se encuentra en la lista de favoritos o la url esta repetida,
|
|
||||||
# descartamos el item
|
|
||||||
if item.server not in favorite_servers or item.url in url_list_valid:
|
|
||||||
continue
|
|
||||||
autoplay_elem["indice_server"] = favorite_servers.index(item.server)
|
|
||||||
|
|
||||||
elif priority == 3: # Solo calidades
|
|
||||||
|
|
||||||
# si la calidad no se encuentra en la lista de favoritos o la url esta repetida,
|
|
||||||
# descartamos el item
|
|
||||||
if item.quality not in favorite_quality or item.url in url_list_valid:
|
|
||||||
continue
|
|
||||||
autoplay_elem["indice_quality"] = favorite_quality.index(item.quality)
|
|
||||||
|
|
||||||
else: # No ordenar
|
|
||||||
|
|
||||||
# si la url esta repetida, descartamos el item
|
|
||||||
if item.url in url_list_valid:
|
|
||||||
continue
|
|
||||||
|
|
||||||
# Si el item llega hasta aqui lo añadimos al listado de urls validas y a autoplay_list
|
|
||||||
url_list_valid.append(item.url)
|
|
||||||
autoplay_elem['videoitem'] = item
|
|
||||||
# autoplay_elem['server'] = item.server
|
|
||||||
# autoplay_elem['quality'] = item.quality
|
|
||||||
autoplay_list.append(autoplay_elem)
|
|
||||||
|
|
||||||
# Ordenamos segun la prioridad
|
|
||||||
if priority == 0: # Servidores y calidades
|
|
||||||
autoplay_list.sort(key=lambda orden: (orden['indice_server'], orden['indice_quality']))
|
|
||||||
|
|
||||||
elif priority == 1: # Calidades y servidores
|
|
||||||
autoplay_list.sort(key=lambda orden: (orden['indice_quality'], orden['indice_server']))
|
|
||||||
|
|
||||||
elif priority == 2: # Solo servidores
|
elif priority == 2: # Solo servidores
|
||||||
autoplay_list.sort(key=lambda orden: orden['indice_server'])
|
|
||||||
|
# si el servidor no se encuentra en la lista de favoritos o la url esta repetida,
|
||||||
|
# descartamos el item
|
||||||
|
if item.server not in favorite_servers or item.url in url_list_valid:
|
||||||
|
continue
|
||||||
|
autoplay_elem["indice_server"] = favorite_servers.index(item.server)
|
||||||
|
|
||||||
elif priority == 3: # Solo calidades
|
elif priority == 3: # Solo calidades
|
||||||
autoplay_list.sort(key=lambda orden: orden['indice_quality'])
|
|
||||||
|
|
||||||
# Si hay elementos en la lista de autoplay se intenta reproducir cada elemento, hasta encontrar uno
|
# si la calidad no se encuentra en la lista de favoritos o la url esta repetida,
|
||||||
# funcional o fallen todos
|
# descartamos el item
|
||||||
if autoplay_list:
|
if item.quality not in favorite_quality or item.url in url_list_valid:
|
||||||
played = False
|
continue
|
||||||
max_intentos = 5
|
autoplay_elem["indice_quality"] = favorite_quality.index(item.quality)
|
||||||
max_intentos_servers = {}
|
|
||||||
|
|
||||||
# Si se esta reproduciendo algo detiene la reproduccion
|
else: # No ordenar
|
||||||
if platformtools.is_playing():
|
|
||||||
platformtools.stop_video()
|
|
||||||
|
|
||||||
for autoplay_elem in autoplay_list:
|
# si la url esta repetida, descartamos el item
|
||||||
if not platformtools.is_playing() and not played:
|
if item.url in url_list_valid:
|
||||||
videoitem = autoplay_elem['videoitem']
|
continue
|
||||||
|
|
||||||
if videoitem.server not in max_intentos_servers:
|
# Si el item llega hasta aqui lo añadimos al listado de urls validas y a autoplay_list
|
||||||
|
url_list_valid.append(item.url)
|
||||||
|
autoplay_elem['videoitem'] = item
|
||||||
|
# autoplay_elem['server'] = item.server
|
||||||
|
# autoplay_elem['quality'] = item.quality
|
||||||
|
autoplay_list.append(autoplay_elem)
|
||||||
|
|
||||||
|
# Ordenamos segun la prioridad
|
||||||
|
if priority == 0: # Servidores y calidades
|
||||||
|
autoplay_list.sort(key=lambda orden: (orden['indice_server'], orden['indice_quality']))
|
||||||
|
|
||||||
|
elif priority == 1: # Calidades y servidores
|
||||||
|
autoplay_list.sort(key=lambda orden: (orden['indice_quality'], orden['indice_server']))
|
||||||
|
|
||||||
|
elif priority == 2: # Solo servidores
|
||||||
|
autoplay_list.sort(key=lambda orden: orden['indice_server'])
|
||||||
|
|
||||||
|
elif priority == 3: # Solo calidades
|
||||||
|
autoplay_list.sort(key=lambda orden: orden['indice_quality'])
|
||||||
|
|
||||||
|
# Si hay elementos en la lista de autoplay se intenta reproducir cada elemento, hasta encontrar uno
|
||||||
|
# funcional o fallen todos
|
||||||
|
if autoplay_list:
|
||||||
|
played = False
|
||||||
|
max_intentos = 5
|
||||||
|
max_intentos_servers = {}
|
||||||
|
|
||||||
|
# Si se esta reproduciendo algo detiene la reproduccion
|
||||||
|
if platformtools.is_playing():
|
||||||
|
platformtools.stop_video()
|
||||||
|
|
||||||
|
for autoplay_elem in autoplay_list:
|
||||||
|
if not platformtools.is_playing() and not played:
|
||||||
|
videoitem = autoplay_elem['videoitem']
|
||||||
|
|
||||||
|
if videoitem.server not in max_intentos_servers:
|
||||||
|
max_intentos_servers[videoitem.server] = max_intentos
|
||||||
|
|
||||||
|
# Si se han alcanzado el numero maximo de intentos de este servidor saltamos al siguiente
|
||||||
|
if max_intentos_servers[videoitem.server] == 0:
|
||||||
|
continue
|
||||||
|
|
||||||
|
lang = " "
|
||||||
|
if hasattr(videoitem, 'language') and videoitem.language != "":
|
||||||
|
lang = " '%s' " % videoitem.language
|
||||||
|
|
||||||
|
platformtools.dialog_notification("AutoPlay", "%s%s%s" % (
|
||||||
|
videoitem.server.upper(), lang, videoitem.quality.upper()), sound=False)
|
||||||
|
# TODO videoitem.server es el id del server, pero podria no ser el nombre!!!
|
||||||
|
|
||||||
|
# Intenta reproducir los enlaces
|
||||||
|
# Si el canal tiene metodo play propio lo utiliza
|
||||||
|
channel = __import__('channels.%s' % item.channel, None, None, ["channels.%s" % item.channel])
|
||||||
|
if hasattr(channel, 'play'):
|
||||||
|
resolved_item = getattr(channel, 'play')(videoitem)
|
||||||
|
if len(resolved_item) > 0:
|
||||||
|
if isinstance(resolved_item[0], list):
|
||||||
|
videoitem.video_urls = resolved_item
|
||||||
|
else:
|
||||||
|
videoitem = resolved_item[0]
|
||||||
|
|
||||||
|
# si no directamente reproduce
|
||||||
|
platformtools.play_video(videoitem)
|
||||||
|
|
||||||
|
try:
|
||||||
|
if platformtools.is_playing():
|
||||||
|
played = True
|
||||||
|
break
|
||||||
|
except: # TODO evitar el informe de que el conector fallo o el video no se encuentra
|
||||||
|
logger.debug(str(len(autoplay_list)))
|
||||||
|
|
||||||
|
# Si hemos llegado hasta aqui es por q no se ha podido reproducir
|
||||||
|
max_intentos_servers[videoitem.server] -= 1
|
||||||
|
|
||||||
|
# Si se han alcanzado el numero maximo de intentos de este servidor
|
||||||
|
# preguntar si queremos seguir probando o lo ignoramos
|
||||||
|
if max_intentos_servers[videoitem.server] == 0:
|
||||||
|
text = "Parece que los enlaces de %s no estan funcionando." % videoitem.server.upper()
|
||||||
|
if not platformtools.dialog_yesno("AutoPlay", text,
|
||||||
|
"¿Desea ignorar todos los enlaces de este servidor?"):
|
||||||
max_intentos_servers[videoitem.server] = max_intentos
|
max_intentos_servers[videoitem.server] = max_intentos
|
||||||
|
|
||||||
# Si se han alcanzado el numero maximo de intentos de este servidor saltamos al siguiente
|
else:
|
||||||
if max_intentos_servers[videoitem.server] == 0:
|
platformtools.dialog_notification('AutoPlay No Fue Posible', 'No Hubo Coincidencias')
|
||||||
continue
|
if new_options:
|
||||||
|
platformtools.dialog_notification("AutoPlay", "Nueva Calidad/Servidor disponible en la "
|
||||||
|
"configuracion", sound=False)
|
||||||
|
|
||||||
lang = " "
|
# Restaura si es necesario el valor previo de "Accion y Player Mode" en preferencias
|
||||||
if hasattr(videoitem, 'language') and videoitem.language != "":
|
if user_config_setting_action != 2:
|
||||||
lang = " '%s' " % videoitem.language
|
config.set_setting("default_action", user_config_setting_action)
|
||||||
|
if user_config_setting_player != 0:
|
||||||
|
config.set_setting("player_mode", user_config_setting_player)
|
||||||
|
|
||||||
platformtools.dialog_notification("AutoPlay", "%s%s%s" % (
|
# devuelve la lista de enlaces para la eleccion manual
|
||||||
videoitem.server.upper(), lang, videoitem.quality.upper()), sound=False)
|
return itemlist
|
||||||
# TODO videoitem.server es el id del server, pero podria no ser el nombre!!!
|
|
||||||
|
|
||||||
# Intenta reproducir los enlaces
|
|
||||||
# Si el canal tiene metodo play propio lo utiliza
|
|
||||||
channel = __import__('channels.%s' % item.channel, None, None, ["channels.%s" % item.channel])
|
|
||||||
if hasattr(channel, 'play'):
|
|
||||||
resolved_item = getattr(channel, 'play')(videoitem)
|
|
||||||
if len(resolved_item) > 0:
|
|
||||||
if isinstance(resolved_item[0], list):
|
|
||||||
videoitem.video_urls = resolved_item
|
|
||||||
else:
|
|
||||||
videoitem = resolved_item[0]
|
|
||||||
|
|
||||||
# si no directamente reproduce
|
|
||||||
platformtools.play_video(videoitem)
|
|
||||||
|
|
||||||
try:
|
|
||||||
if platformtools.is_playing():
|
|
||||||
played = True
|
|
||||||
break
|
|
||||||
except: # TODO evitar el informe de que el conector fallo o el video no se encuentra
|
|
||||||
logger.debug(str(len(autoplay_list)))
|
|
||||||
|
|
||||||
# Si hemos llegado hasta aqui es por q no se ha podido reproducir
|
|
||||||
max_intentos_servers[videoitem.server] -= 1
|
|
||||||
|
|
||||||
# Si se han alcanzado el numero maximo de intentos de este servidor
|
|
||||||
# preguntar si queremos seguir probando o lo ignoramos
|
|
||||||
if max_intentos_servers[videoitem.server] == 0:
|
|
||||||
text = "Parece que los enlaces de %s no estan funcionando." % videoitem.server.upper()
|
|
||||||
if not platformtools.dialog_yesno("AutoPlay", text,
|
|
||||||
"¿Desea ignorar todos los enlaces de este servidor?"):
|
|
||||||
max_intentos_servers[videoitem.server] = max_intentos
|
|
||||||
|
|
||||||
else:
|
|
||||||
platformtools.dialog_notification('AutoPlay No Fue Posible', 'No Hubo Coincidencias')
|
|
||||||
if new_options:
|
|
||||||
platformtools.dialog_notification("AutoPlay", "Nueva Calidad/Servidor disponible en la "
|
|
||||||
"configuracion", sound=False)
|
|
||||||
|
|
||||||
# Restaura si es necesario el valor previo de "Accion y Player Mode" en preferencias
|
|
||||||
if user_config_setting_action != 2:
|
|
||||||
config.set_setting("default_action", user_config_setting_action)
|
|
||||||
if user_config_setting_player != 0:
|
|
||||||
config.set_setting("player_mode", user_config_setting_player)
|
|
||||||
|
|
||||||
# devuelve la lista de enlaces para la eleccion manual
|
|
||||||
return itemlist
|
|
||||||
|
|
||||||
|
|
||||||
def init(channel, list_servers, list_quality):
|
def init(channel, list_servers, list_quality):
|
||||||
'''
|
'''
|
||||||
Comprueba la existencia de canal en el archivo de configuracion de Autoplay y si no existe lo añade.
|
Comprueba la existencia de canal en el archivo de configuracion de Autoplay y si no existe lo añade.
|
||||||
Es necesario llamar a esta funcion al entrar a cualquier canal que incluya la funcion Autoplay.
|
Es necesario llamar a esta funcion al entrar a cualquier canal que incluya la funcion Autoplay.
|
||||||
|
|
||||||
:param channel: (str) id del canal
|
:param channel: (str) id del canal
|
||||||
:param list_servers: (list) lista inicial de servidores validos para el canal. No es necesario incluirlos todos,
|
:param list_servers: (list) lista inicial de servidores validos para el canal. No es necesario incluirlos todos,
|
||||||
ya que la lista de servidores validos se ira actualizando dinamicamente.
|
ya que la lista de servidores validos se ira actualizando dinamicamente.
|
||||||
:param list_quality: (list) lista inicial de calidades validas para el canal. No es necesario incluirlas todas,
|
:param list_quality: (list) lista inicial de calidades validas para el canal. No es necesario incluirlas todas,
|
||||||
ya que la lista de calidades validas se ira actualizando dinamicamente.
|
ya que la lista de calidades validas se ira actualizando dinamicamente.
|
||||||
:return: (bool) True si la inicializacion ha sido correcta.
|
:return: (bool) True si la inicializacion ha sido correcta.
|
||||||
'''
|
'''
|
||||||
@@ -304,7 +308,7 @@ def init(channel, list_servers, list_quality):
|
|||||||
result = True
|
result = True
|
||||||
|
|
||||||
if not config.is_xbmc():
|
if not config.is_xbmc():
|
||||||
platformtools.dialog_notification('AutoPlay ERROR', 'Sólo disponible para XBMC/Kodi')
|
# platformtools.dialog_notification('AutoPlay ERROR', 'Sólo disponible para XBMC/Kodi')
|
||||||
result = False
|
result = False
|
||||||
else:
|
else:
|
||||||
autoplay_path = os.path.join(config.get_data_path(), "settings_channels", 'autoplay_data.json')
|
autoplay_path = os.path.join(config.get_data_path(), "settings_channels", 'autoplay_data.json')
|
||||||
@@ -517,9 +521,9 @@ def autoplay_config(item):
|
|||||||
def save(item, dict_data_saved):
|
def save(item, dict_data_saved):
|
||||||
'''
|
'''
|
||||||
Guarda los datos de la ventana de configuracion
|
Guarda los datos de la ventana de configuracion
|
||||||
|
|
||||||
:param item: item
|
:param item: item
|
||||||
:param dict_data_saved: dict
|
:param dict_data_saved: dict
|
||||||
:return:
|
:return:
|
||||||
'''
|
'''
|
||||||
logger.info()
|
logger.info()
|
||||||
|
|||||||
Reference in New Issue
Block a user