aboutsummaryrefslogtreecommitdiffstats
path: root/html_builders/builder.py
diff options
context:
space:
mode:
authorPinapelz <donaldshan1@outlook.com>2023-06-20 02:14:34 -0700
committerPinapelz <donaldshan1@outlook.com>2023-06-20 02:14:34 -0700
commit70237b5a5d82e8425eb5870a975bde497a6def08 (patch)
tree6930d7ae771fb188fc6a3a0f7f1f81bad5bf84f2 /html_builders/builder.py
parentc929c11f9006db67e10ddd7fa599124a6edeadeb (diff)
Refactored entire codebase
- Replaced most code with HTML templates - Fixed some janky SQL queries - Replaced config.py with ini and json
Diffstat (limited to 'html_builders/builder.py')
-rw-r--r--html_builders/builder.py109
1 files changed, 109 insertions, 0 deletions
diff --git a/html_builders/builder.py b/html_builders/builder.py
new file mode 100644
index 0000000..dea2e8c
--- /dev/null
+++ b/html_builders/builder.py
@@ -0,0 +1,109 @@
+from jinja2 import Environment, FileSystemLoader
+import html_builders.elements as elements
+import html_builders.graphs as graphs
+import html_builders.tables as tables
+import os
+import time
+
+MENU_ITEMS = [
+ ("Nijitracker", "https://www.nijitracker.com"),
+ ("Pettantracker", "https://nijitracker.com/pettantrack")
+]
+
+
+def build_ranking_page(server, CONFIG: dict, exclude_channels: list = []):
+ page_path = os.path.join(CONFIG["PATH"]["root_html"], "index.html")
+ if not os.path.exists(page_path):
+ os.makedirs(os.path.dirname(page_path), exist_ok=True)
+ file_loader = FileSystemLoader("templates")
+ env = Environment(loader=file_loader)
+ template = env.get_template("ranking.html")
+
+ input_dict = {
+ "meta_image_url": CONFIG["WEBSITE"]["icon"],
+ "meta_description": CONFIG["WEBSITE"]["description"],
+ "meta_title": CONFIG["WEBSITE"]["title"],
+ "title_banner": elements.build_title_banner(
+ CONFIG["WEBSITE"]["title"],
+ MENU_ITEMS
+ ),
+ "ranking_graph": graphs.plot_subscriber_count_over_time(server, CONFIG["TABLES"]["historical"], exclude_channels=exclude_channels),
+ "divider": "Last Updated: " + time.strftime('%Y-%m-%d %H:%M:%S') + " " + CONFIG["WEBSITE"]["timezone"],
+ "ranking_table": tables.generate_html_table(server, CONFIG["TABLES"]["live"], CONFIG["TABLES"]["daily"]),
+ "footer": CONFIG["WEBSITE"]["footer_message"]
+ }
+ output = template.render(input_dict)
+ with open(page_path, "w", encoding="utf-8") as f:
+ f.write(output)
+
+def build_individual_page(server, CONFIG: dict, channel_data: str):
+ def transform_sql_string(string: str) -> str:
+ return string.encode("ascii", "ignore").decode().replace("'", "''")
+ channel_id = channel_data["id"]
+ desc = channel_data["description"]
+ pfp = channel_data["photo"]
+ sub_count = channel_data["subscriber_count"]
+ channel_name = channel_data["english_name"]
+ if channel_name is None:
+ channel_name = channel_data["name"]
+ channel_name = transform_sql_string(channel_name)
+ sub_count_str = "{:,.0f}".format(int(sub_count))
+ page_path = os.path.join(CONFIG["PATH"]["root_html"], channel_name + ".html")
+ file_loader = FileSystemLoader("templates")
+ env = Environment(loader=file_loader)
+ template = env.get_template("individual.html")
+ input_dict = {
+ "meta_image_url": CONFIG["WEBSITE"]["icon"],
+ "meta_description": CONFIG["WEBSITE"]["description"],
+ "meta_title": channel_name + " - " + CONFIG["WEBSITE"]["title"],
+ "homepage_url": CONFIG["WEBSITE"]["homepage"],
+ "sub_text": sub_count_str + " Subscribers",
+ "name": channel_name,
+ "profile_pic": pfp,
+ "description": desc,
+ "channel_id": channel_id,
+ "projection_card": elements.build_projection_card(server, CONFIG["TABLES"]["historical"], int(sub_count), channel_name, timezone = CONFIG["WEBSITE"]["timezone"]),
+ "subscriber_trend": graphs.plot_subscriber_count_over_time(server, CONFIG["TABLES"]["historical"], gtitle = "Subscriber Count Over Time for " + channel_name, overrideQuery = f"SELECT name, subscriber_count, timestamp, channel_id FROM {CONFIG['TABLES']['historical']} WHERE channel_id = '{channel_id}' ORDER by timestamp DESC", markers = "lines+markers"),
+ "divider": "Recent Subscriber Data:",
+ "weekly_trend": graphs.plot_subscriber_count_over_time(server, CONFIG["TABLES"]["historical"], gtitle = "Weekly Subscriber Count Over Time for " + channel_name, overrideQuery = f"SELECT name, subscriber_count, timestamp, channel_id FROM {CONFIG['TABLES']['historical']} WHERE channel_id = '{channel_id}' AND timestamp >= DATE_SUB(NOW(), INTERVAL 7 DAY) ORDER by timestamp DESC", markers = "lines+markers"),
+ "full_table_url": CONFIG["WEBSITE"]["homepage"] + "/tables/"+channel_name
+ }
+ output = template.render(input_dict)
+ with open(page_path, "w", encoding="utf-8") as f:
+ f.write(output)
+
+def build_table_page(server, CONFIG: dict, channel_data: str):
+ def transform_sql_string(string: str) -> str:
+ return string.encode("ascii", "ignore").decode().replace("'", "''")
+ channel_id = channel_data["id"]
+ desc = channel_data["description"]
+ pfp = channel_data["photo"]
+ sub_count = channel_data["subscriber_count"]
+ channel_name = channel_data["english_name"]
+ if channel_name is None:
+ channel_name = channel_data["name"]
+ channel_name = transform_sql_string(channel_name)
+
+ file_loader = FileSystemLoader("templates")
+ env = Environment(loader=file_loader)
+ template = env.get_template("full_table.html")
+
+ input_dict = {
+ "meta_image_url": CONFIG["WEBSITE"]["icon"],
+ "meta_description": CONFIG["WEBSITE"]["description"],
+ "meta_title": channel_name + " - " + CONFIG["WEBSITE"]["title"],
+ "homepage_url": CONFIG["WEBSITE"]["homepage"],
+ "sub_text": channel_name,
+ "full_table": tables.generate_individual_table(server, CONFIG["TABLES"]["historical"], channel_name),
+ "name": channel_name,
+ "profile_pic": pfp,
+ "description": desc,
+ "channel_id": channel_id,
+ }
+ output = template.render(input_dict)
+ page_path = os.path.join("tables", channel_name + ".html")
+ with open(page_path, "w", encoding="utf-8") as f:
+ f.write(output)
+
+
+ \ No newline at end of file
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage