2022-04-08 22:45:29 +01:00
|
|
|
from collections import OrderedDict
|
|
|
|
|
2022-04-16 09:43:51 +01:00
|
|
|
from bookstack import Bookstack
|
2022-12-09 20:45:50 +00:00
|
|
|
from markdown_utils import MarkdownUtils
|
2022-04-08 22:45:29 +01:00
|
|
|
from vcinema_utils import VCinemaUtils
|
|
|
|
|
|
|
|
# Page ID of https://wiki.jacknet.io/books/vcinema/page/films-by-reference
|
2022-04-15 17:29:19 +01:00
|
|
|
PAGE_ID = 63
|
2022-04-08 22:45:29 +01:00
|
|
|
|
|
|
|
|
|
|
|
def get_hidden_themes(viewings, token_id, token_secret):
|
|
|
|
# Bit horrible to need to request this again, but it affects the order of the result table
|
|
|
|
viewings_ungrouped = VCinemaUtils.get_vcinema_viewings(token_id, token_secret, combine_repeat_viewings=False)
|
|
|
|
|
|
|
|
# Copy keywords from grouped viewings to ungrouped viewings
|
|
|
|
for viewing_ungrouped in viewings_ungrouped:
|
|
|
|
for viewing in viewings:
|
|
|
|
if viewing['imdb_id'] == viewing_ungrouped['imdb_id']:
|
|
|
|
if 'keywords' in viewing:
|
|
|
|
viewing_ungrouped['keywords'] = viewing['keywords']
|
|
|
|
break
|
|
|
|
|
|
|
|
viewings_filtered_watch_date = VCinemaUtils.filter_viewings(viewings_ungrouped, "date_watched")
|
|
|
|
|
|
|
|
for date, viewings in viewings_filtered_watch_date.items():
|
|
|
|
viewing_dict = {"viewings": viewings}
|
|
|
|
|
|
|
|
viewings_filtered_watch_date[date] = viewing_dict
|
|
|
|
|
|
|
|
# Add hidden themes
|
|
|
|
for date, data in viewings_filtered_watch_date.items():
|
2022-07-01 15:17:27 +01:00
|
|
|
keyword_counts = {}
|
2022-04-08 22:45:29 +01:00
|
|
|
|
|
|
|
if len(data['viewings']) > 1:
|
|
|
|
for viewing in data['viewings']:
|
|
|
|
if 'keywords' in viewing:
|
2022-07-01 15:17:27 +01:00
|
|
|
for keyword in viewing['keywords']:
|
|
|
|
if keyword in keyword_counts.keys():
|
|
|
|
keyword_counts[keyword] += 1
|
|
|
|
else:
|
|
|
|
keyword_counts[keyword] = 1
|
|
|
|
|
|
|
|
keyword_counts = {k: v for k, v in sorted(keyword_counts.items(), key=lambda item: item[1], reverse=True)}
|
|
|
|
hidden_themes = {}
|
2022-04-08 22:45:29 +01:00
|
|
|
|
2022-07-01 15:17:27 +01:00
|
|
|
for keyword in keyword_counts:
|
|
|
|
rating = float(keyword_counts[keyword]) / float(len(data['viewings']))
|
|
|
|
if rating > 0.5:
|
|
|
|
hidden_themes[keyword] = rating
|
2022-04-08 22:45:29 +01:00
|
|
|
|
2022-07-01 15:17:27 +01:00
|
|
|
viewings_filtered_watch_date[date]['hidden_themes'] = hidden_themes
|
2022-04-08 22:45:29 +01:00
|
|
|
|
|
|
|
return viewings_filtered_watch_date
|
|
|
|
|
|
|
|
|
2022-04-16 09:43:51 +01:00
|
|
|
def update_page(token_id, token_secret, hidden_themes):
|
|
|
|
page = build_page(hidden_themes)
|
2022-06-27 00:21:07 +01:00
|
|
|
Bookstack.update_page(VCinemaUtils.JACKNET_WIKI_URL, token_id, token_secret, PAGE_ID, markdown=page)
|
2022-04-16 09:43:51 +01:00
|
|
|
|
|
|
|
|
2022-04-08 22:45:29 +01:00
|
|
|
def build_page(hidden_themes):
|
|
|
|
hidden_themes = OrderedDict(sorted(hidden_themes.items(), key=lambda t: t[0]))
|
|
|
|
|
2022-12-09 20:45:50 +00:00
|
|
|
table = MarkdownUtils.MarkdownTable(["Date", "Films", "Hidden Themes"])
|
2022-04-08 22:45:29 +01:00
|
|
|
|
|
|
|
for date, data in hidden_themes.items():
|
2022-12-10 16:46:22 +00:00
|
|
|
films = VCinemaUtils.get_film_list(data['viewings'])
|
2022-04-08 22:45:29 +01:00
|
|
|
|
2022-07-01 15:17:27 +01:00
|
|
|
if 'hidden_themes' in data and data['hidden_themes'] != {}:
|
2022-07-01 15:26:16 +01:00
|
|
|
hidden_theme_labels = []
|
|
|
|
|
|
|
|
for hidden_theme in sorted(data['hidden_themes'].keys()):
|
|
|
|
if data['hidden_themes'][hidden_theme] == 1:
|
|
|
|
hidden_theme_labels.append(hidden_theme)
|
|
|
|
else:
|
|
|
|
hidden_theme_labels.append("<i>{} ({}%)</i>".format(hidden_theme, round(data['hidden_themes'][hidden_theme] * 100)))
|
|
|
|
|
2022-12-10 16:46:22 +00:00
|
|
|
hidden_themes = "<br>".join(hidden_theme_labels)
|
2022-07-01 15:17:27 +01:00
|
|
|
else:
|
2022-12-10 16:46:22 +00:00
|
|
|
hidden_themes = "N/A"
|
2022-04-08 22:45:29 +01:00
|
|
|
|
2022-12-10 16:46:22 +00:00
|
|
|
row_data = [date, films, hidden_themes]
|
2022-12-09 20:45:50 +00:00
|
|
|
table.add_row(row_data)
|
2022-04-08 22:45:29 +01:00
|
|
|
|
2022-12-10 16:46:22 +00:00
|
|
|
return str(table)
|