2019-04-18 23:05:19 +03:00
|
|
|
from app.commons import run_idle
|
|
|
|
|
from app.tools.epg import EPG
|
|
|
|
|
from .main_helper import on_popup_menu
|
2019-04-21 01:18:54 +03:00
|
|
|
from .uicommons import Gtk, UI_RESOURCES_PATH, TEXT_DOMAIN, Column, EPG_ICON
|
2019-04-18 23:05:19 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class EpgDialog:
|
|
|
|
|
|
2019-04-21 01:18:54 +03:00
|
|
|
def __init__(self, transient, options, services, bouquet, fav_model):
|
2019-04-18 23:05:19 +03:00
|
|
|
|
2019-04-21 01:18:54 +03:00
|
|
|
handlers = {"on_apply": self.on_apply,
|
|
|
|
|
"on_save_to_xml": self.on_save_to_xml,
|
|
|
|
|
"on_options": self.on_options,
|
|
|
|
|
"on_auto_configuration": self.on_auto_configuration,
|
|
|
|
|
"on_filter_toggled": self.on_filter_toggled,
|
|
|
|
|
"on_filter_changed": self.on_filter_changed,
|
|
|
|
|
"on_info_bar_close": self.on_info_bar_close,
|
2019-04-18 23:05:19 +03:00
|
|
|
"on_popup_menu": on_popup_menu}
|
|
|
|
|
|
|
|
|
|
self._services = services
|
|
|
|
|
self._ex_fav_model = fav_model
|
|
|
|
|
self._options = options
|
2019-04-21 01:18:54 +03:00
|
|
|
self._bouquet = bouquet
|
2019-04-18 23:05:19 +03:00
|
|
|
|
|
|
|
|
builder = Gtk.Builder()
|
|
|
|
|
builder.set_translation_domain(TEXT_DOMAIN)
|
|
|
|
|
builder.add_from_file(UI_RESOURCES_PATH + "epg_dialog.glade")
|
|
|
|
|
builder.connect_signals(handlers)
|
|
|
|
|
|
|
|
|
|
self._dialog = builder.get_object("epg_dialog_window")
|
|
|
|
|
self._dialog.set_transient_for(transient)
|
|
|
|
|
self._bouquet_model = builder.get_object("bouquet_list_store")
|
|
|
|
|
self._services_model = builder.get_object("services_list_store")
|
|
|
|
|
self._info_bar = builder.get_object("info_bar")
|
|
|
|
|
self._message_label = builder.get_object("info_bar_message_label")
|
2019-04-21 01:18:54 +03:00
|
|
|
# Filter
|
|
|
|
|
self._filter_bar = builder.get_object("filter_bar")
|
|
|
|
|
self._filter_entry = builder.get_object("filter_entry")
|
|
|
|
|
self._services_filter_model = builder.get_object("services_filter_model")
|
|
|
|
|
self._bouquet_filter_model = builder.get_object("bouquet_filter_model")
|
|
|
|
|
self._services_filter_model.set_visible_func(self.services_filter_function)
|
|
|
|
|
self._bouquet_filter_model.set_visible_func(self.bouquet_filter_function)
|
2019-04-18 23:05:19 +03:00
|
|
|
|
|
|
|
|
self.init_data()
|
|
|
|
|
|
|
|
|
|
@run_idle
|
|
|
|
|
def init_data(self):
|
|
|
|
|
for r in self._ex_fav_model:
|
2019-04-21 01:18:54 +03:00
|
|
|
row = [*r[:]]
|
|
|
|
|
self._bouquet_model.append(row)
|
2019-04-18 23:05:19 +03:00
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
refs = EPG.get_epg_refs(self._options.get("data_dir_path", "") + "epg.dat")
|
|
|
|
|
|
|
|
|
|
# for source lamedb
|
|
|
|
|
srvs = {k[:k.rfind(":")]: v for k, v in self._services.items()}
|
|
|
|
|
list(map(self._services_model.append,
|
|
|
|
|
map(lambda s: (s.service, s.fav_id),
|
|
|
|
|
filter(None, [srvs.get(ref) for ref in refs]))))
|
|
|
|
|
|
|
|
|
|
except (FileNotFoundError, ValueError) as e:
|
|
|
|
|
self.show_info_message("Read epg.dat error: {}".format(e), Gtk.MessageType.ERROR)
|
|
|
|
|
else:
|
|
|
|
|
if len(self._services_model) == 0:
|
|
|
|
|
msg = "Current epg.dat file does not contains references for the services of this bouquet!"
|
|
|
|
|
self.show_info_message(msg, Gtk.MessageType.ERROR)
|
|
|
|
|
|
|
|
|
|
def show(self):
|
|
|
|
|
self._dialog.show()
|
|
|
|
|
|
2019-04-21 01:18:54 +03:00
|
|
|
def on_apply(self, item):
|
|
|
|
|
self._bouquet.clear()
|
|
|
|
|
list(map(self._bouquet.append, [r[Column.FAV_ID] for r in self._bouquet_model]))
|
|
|
|
|
|
|
|
|
|
def on_save_to_xml(self, item):
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
def on_options(self, item):
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
def on_auto_configuration(self, item):
|
|
|
|
|
source = {r[0]: r[1] for r in self._services_model}
|
|
|
|
|
success_count = 0
|
|
|
|
|
|
|
|
|
|
for r in self._bouquet_filter_model:
|
|
|
|
|
ref = source.get(r[Column.FAV_SERVICE], None)
|
|
|
|
|
if ref:
|
|
|
|
|
r[Column.FAV_LOCKED] = EPG_ICON
|
|
|
|
|
print("Found for {}".format(r[Column.FAV_SERVICE]))
|
|
|
|
|
success_count += 1
|
|
|
|
|
|
|
|
|
|
self.show_info_message("Done! Count of successfully configured services: {}".format(success_count),
|
|
|
|
|
Gtk.MessageType.INFO)
|
|
|
|
|
|
|
|
|
|
def on_filter_toggled(self, button: Gtk.ToggleButton):
|
|
|
|
|
self._filter_bar.set_search_mode(button.get_active())
|
|
|
|
|
|
|
|
|
|
def on_filter_changed(self, entry):
|
|
|
|
|
self._bouquet_filter_model.refilter()
|
|
|
|
|
self._services_filter_model.refilter()
|
|
|
|
|
|
|
|
|
|
def bouquet_filter_function(self, model, itr, data):
|
|
|
|
|
txt = self._filter_entry.get_text().upper()
|
|
|
|
|
return model is None or model == "None" or txt in model.get_value(itr, Column.FAV_SERVICE).upper()
|
|
|
|
|
|
|
|
|
|
def services_filter_function(self, model, itr, data):
|
|
|
|
|
txt = self._filter_entry.get_text().upper()
|
|
|
|
|
return model is None or model == "None" or txt in model.get_value(itr, 0).upper()
|
|
|
|
|
|
2019-04-18 23:05:19 +03:00
|
|
|
def on_info_bar_close(self, bar=None, resp=None):
|
|
|
|
|
self._info_bar.set_visible(False)
|
|
|
|
|
|
|
|
|
|
@run_idle
|
|
|
|
|
def show_info_message(self, text, message_type):
|
|
|
|
|
self._info_bar.set_visible(True)
|
|
|
|
|
self._info_bar.set_message_type(message_type)
|
|
|
|
|
self._message_label.set_text(text)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
pass
|