2021-01-02 20:50:23 -08:00
{% extends "base.html" %}
{% import "utils.html" as utils %}
2023-12-26 18:25:52 -05:00
{% block title %}Redlib Settings{% endblock %}
2021-01-02 20:50:23 -08:00
2024-09-05 11:59:21 -04:00
{% block subscriptions %}
{% call utils::sub_list("") %}
{% endblock %}
2021-01-02 20:50:23 -08:00
{% block search %}
2023-12-26 16:12:00 -05:00
{% call utils::search("".to_owned(), "") %}
2021-01-02 20:50:23 -08:00
{% endblock %}
2021-01-10 13:08:36 -08:00
{% block content %}
2021-01-30 21:21:46 -08:00
< div id = "settings" >
2021-03-17 17:28:05 -07:00
< form action = "/settings" method = "POST" >
2021-01-30 21:21:46 -08:00
< div class = "prefs" >
2023-01-01 09:56:09 +01:00
< fieldset >
< legend > Appearance< / legend >
< div class = "prefs-group" >
< label for = "theme" > Theme:< / label >
< select name = "theme" id = "theme" >
{% call utils::options(prefs.theme, prefs.available_themes, "system") %}
< / select >
< / div >
2024-06-17 22:29:52 +12:00
< div class = "prefs-group" >
< label for = "mascot" > Mascot:< / label >
< select name = "mascot" id = "mascot" >
{% call utils::options(prefs.mascot, prefs.available_mascots, "system") %}
< / select >
< / div >
2025-01-06 07:15:24 +13:00
< div class = "prefs-group" >
2025-01-06 08:04:41 +13:00
< label for = "redsunlib_colorway" > Force redsunlib colorway< / label >
< input type = "hidden" value = "off" name = "redsunlib_colorway" >
< input type = "checkbox" name = "redsunlib_colorway" { % if prefs . redsunlib_colorway = = " on " % } checked { % endif % } >
2025-01-06 07:15:24 +13:00
< / div >
2023-01-01 09:56:09 +01:00
< / fieldset >
< fieldset >
< legend > Interface< / legend >
< div class = "prefs-group" >
< label for = "front_page" > Front page:< / label >
< select name = "front_page" id = "front_page" >
{% call utils::options(prefs.front_page, ["default", "popular", "all"], "default") %}
< / select >
< / div >
< div class = "prefs-group" >
< label for = "layout" > Layout:< / label >
< select name = "layout" id = "layout" >
2024-07-07 18:35:53 +12:00
{% call utils::options(prefs.layout, ["card", "clean", "compact", "old", "waterfall"], "card") %}
2023-01-01 09:56:09 +01:00
< / select >
< / div >
< div class = "prefs-group" >
< label for = "wide" > Wide UI:< / label >
< input type = "hidden" value = "off" name = "wide" >
2024-07-07 18:35:53 +12:00
< input type = "checkbox" name = "wide" id = "wide" { % if prefs . layout = = " old " | | prefs . layout = = " waterfall " % } disabled { % endif % } { % if prefs . wide = = " on " | | prefs . layout = = " old " | | prefs . layout = = " waterfall " % } checked { % endif % } >
{% if prefs.layout == "old" || prefs.layout == "waterfall" %}< span > ⓘ Wide UI is required for this layout< / span > {% endif %}
2023-01-01 09:56:09 +01:00
< / div >
2024-10-20 18:06:26 +13:00
< div class = "prefs-group" >
< label for = "fixed_navbar" > Keep navbar fixed< / label >
< input type = "hidden" value = "off" name = "fixed_navbar" >
< input type = "checkbox" name = "fixed_navbar" { % if prefs . fixed_navbar = = " on " % } checked { % endif % } >
< / div >
< div class = "prefs-group" >
< label for = "hide_sidebar_and_summary" > Hide the summary and sidebar< / label >
< input type = "hidden" value = "off" name = "hide_sidebar_and_summary" >
< input type = "checkbox" name = "hide_sidebar_and_summary" { % if prefs . hide_sidebar_and_summary = = " on " % } checked { % endif % } >
< / div >
< div class = "prefs-group" >
< label for = "disable_visit_reddit_confirmation" > Do not confirm before visiting content on Reddit< / label >
< input type = "hidden" value = "off" name = "disable_visit_reddit_confirmation" >
< input type = "checkbox" name = "disable_visit_reddit_confirmation" { % if prefs . disable_visit_reddit_confirmation = = " on " % } checked { % endif % } >
< / div >
2023-01-01 09:56:09 +01:00
< / fieldset >
< fieldset >
< legend > Content< / legend >
< div class = "prefs-group" >
< label for = "post_sort" title = "Applies only to subreddit feeds" > Default subreddit post sort:< / label >
< select name = "post_sort" >
{% call utils::options(prefs.post_sort, ["hot", "new", "top", "rising", "controversial"], "hot") %}
< / select >
< / div >
< div class = "prefs-group" >
< label for = "comment_sort" > Default comment sort:< / label >
< select name = "comment_sort" id = "comment_sort" >
{% call utils::options(prefs.comment_sort, ["confidence", "top", "new", "controversial", "old"], "confidence") %}
< / select >
< / div >
2024-06-22 12:16:12 +02:00
< div class = "prefs-group" >
< label for = "blur_spoiler" > Blur spoiler previews:< / label >
< input type = "hidden" value = "off" name = "blur_spoiler" >
< input type = "checkbox" name = "blur_spoiler" id = "blur_spoiler" { % if prefs . blur_spoiler = = " on " % } checked { % endif % } >
< / div >
2023-01-03 02:39:45 -07:00
{% if !crate::utils::sfw_only() %}
2023-01-01 09:56:09 +01:00
< div class = "prefs-group" >
< label for = "show_nsfw" > Show NSFW posts:< / label >
< input type = "hidden" value = "off" name = "show_nsfw" >
< input type = "checkbox" name = "show_nsfw" id = "show_nsfw" { % if prefs . show_nsfw = = " on " % } checked { % endif % } >
< / div >
< div class = "prefs-group" >
< label for = "blur_nsfw" > Blur NSFW previews:< / label >
< input type = "hidden" value = "off" name = "blur_nsfw" >
< input type = "checkbox" name = "blur_nsfw" id = "blur_nsfw" { % if prefs . blur_nsfw = = " on " % } checked { % endif % } >
< / div >
2023-01-03 02:39:45 -07:00
{% endif %}
2023-01-01 09:56:09 +01:00
< div class = "prefs-group" >
2024-10-20 18:06:26 +13:00
< label for = "hide_awards" > Hide awards< / label >
< input type = "hidden" value = "off" name = "hide_awards" >
< input type = "checkbox" name = "hide_awards" id = "hide_awards" { % if prefs . hide_awards = = " on " % } checked { % endif % } >
2023-01-01 09:56:09 +01:00
< / div >
2024-05-13 23:49:59 +02:00
< div class = "prefs-group" >
2024-10-20 18:06:26 +13:00
< label for = "hide_score" > Hide score< / label >
< input type = "hidden" value = "off" name = "hide_score" >
< input type = "checkbox" name = "hide_score" id = "hide_score" { % if prefs . hide_score = = " on " % } checked { % endif % } >
2024-05-13 23:49:59 +02:00
< / div >
2024-10-20 18:06:26 +13:00
< / fieldset >
< fieldset >
< legend > Media< / legend >
2025-01-09 08:55:58 +13:00
< div class = "prefs-group" >
< label for = "video_quality" > Video quality:< / label >
< select name = "video_quality" id = "video_quality" >
{% call utils::options(prefs.video_quality, ["best", "medium", "worst"], "best") %}
< / select >
< / div >
2024-05-13 23:49:59 +02:00
< div class = "prefs-group" >
2024-10-20 18:06:26 +13:00
< label for = "autoplay_videos" > Autoplay videos< / label >
< input type = "hidden" value = "off" name = "autoplay_videos" >
< input type = "checkbox" name = "autoplay_videos" id = "autoplay_videos" { % if prefs . autoplay_videos = = " on " % } checked { % endif % } >
2024-05-13 23:49:59 +02:00
< / div >
2023-01-01 09:56:09 +01:00
< div class = "prefs-group" >
< label for = "use_hls" > Use HLS for videos< / label >
2024-06-23 19:57:23 +12:00
{% if prefs.ffmpeg_video_downloads != "on" %}
2021-11-23 22:43:25 -08:00
< details id = "feeds" >
< summary > Why?< / summary >
2023-12-26 18:25:52 -05:00
< div id = "feed_list" class = "helper" > Reddit videos require JavaScript (via HLS.js) to be enabled to be played with audio. Therefore, this toggle lets you either use Redlib JS-free or utilize this feature.< / div >
2021-11-23 22:43:25 -08:00
< / details >
2024-06-23 19:57:23 +12:00
{% endif %}
{% if prefs.ffmpeg_video_downloads == "on" %}< u > ⓘ HLS is required for downloads< / u > {% endif %}
2023-01-01 09:56:09 +01:00
< input type = "hidden" value = "off" name = "use_hls" >
2024-06-23 19:57:23 +12:00
< input type = "checkbox" name = "use_hls" id = "use_hls" { % if prefs . ffmpeg_video_downloads = = " on " % } disabled { % endif % } { % if prefs . use_hls = = " on " | | prefs . ffmpeg_video_downloads = = " on " % } checked { % endif % } >
2023-01-01 09:56:09 +01:00
< / div >
2024-06-16 15:01:17 +12:00
< div class = "prefs-group" >
2024-06-16 18:59:47 +12:00
< label for = "ffmpeg_video_downloads" > Use FFmpeg to download videos< / label >
2024-06-16 15:01:17 +12:00
< details id = "feeds" >
< summary > Why?< / summary >
< div id = "feed_list" class = "helper" > Downloading videos with audio requires ffmpeg (via ffmpeg.wasm) to be enabled to combine video and audio tracks. Therefore, this toggle lets you either use Redlib WebAssembly-free or utilize this feature. (videos will still play with audio)< / div >
< / details >
< input type = "hidden" value = "off" name = "ffmpeg_video_downloads" >
< input type = "checkbox" name = "ffmpeg_video_downloads" id = "ffmpeg_video_downloads" { % if prefs . ffmpeg_video_downloads = = " on " % } checked { % endif % } >
2023-01-01 09:56:09 +01:00
< / div >
< div class = "prefs-group" >
< label for = "hide_hls_notification" > Hide notification about possible HLS usage< / label >
< input type = "hidden" value = "off" name = "hide_hls_notification" >
< input type = "checkbox" name = "hide_hls_notification" id = "hide_hls_notification" { % if prefs . hide_hls_notification = = " on " % } checked { % endif % } >
< / div >
< / fieldset >
2021-02-13 21:55:23 +01:00
< input id = "save" type = "submit" value = "Save" >
2021-01-10 18:15:34 -08:00
< / div >
2021-01-30 21:21:46 -08:00
< / form >
2024-06-28 12:30:04 +12:00
< div id = "settings_note" >
< p > < b > Note:< / b > settings and subscriptions are saved in browser cookies. Clearing your cookies will reset them.< / p > < br >
2025-01-06 12:44:33 +13:00
< p > You can restore your current settings and subscriptions after clearing your cookies using < a href = "/settings/restore/?theme={{ prefs.theme }}&mascot={{ prefs.mascot }}&redsunlib_colorway={{ prefs.redsunlib_colorway }}&front_page={{ prefs.front_page }}&layout={{ prefs.layout }}&wide={{ prefs.wide }}&post_sort={{ prefs.post_sort }}&comment_sort={{ prefs.comment_sort }}&show_nsfw={{ prefs.show_nsfw }}&use_hls={{ prefs.use_hls }}&ffmpeg_video_downloads={{ prefs.ffmpeg_video_downloads }}&hide_hls_notification={{ prefs.hide_hls_notification }}&hide_awards={{ prefs.hide_awards }}&fixed_navbar={{ prefs.fixed_navbar }}&hide_sidebar_and_summary={{ prefs.hide_sidebar_and_summary}}&subscriptions={{ prefs.subscriptions.join(" % 2B " ) } } & filters = {{ prefs . filters . join ( " % 2B " ) } } & quicklist = {{ prefs . quicklist . join ( " % 2B " ) } } " > this link< / a > .< / p >
2024-06-28 12:30:04 +12:00
< / div >
2021-02-13 21:55:23 +01:00
{% if prefs.subscriptions.len() > 0 %}
< div class = "prefs" id = "settings_subs" >
2021-12-27 13:43:44 -08:00
< legend > Subscribed Feeds< / legend >
2021-02-13 21:55:23 +01:00
{% for sub in prefs.subscriptions %}
< div >
2021-11-21 22:30:44 -08:00
{% let feed -%}
{% if sub.starts_with("u_") -%}{% let feed = format!("u/{}", & sub[2..]) -%}{% else -%}{% let feed = format!("r/{}", sub) -%}{% endif -%}
< a href = "/{{ feed }}" > {{ feed }}< / a >
2021-02-13 21:55:23 +01:00
< form action = "/r/{{ sub }}/unsubscribe/?redirect=settings" method = "POST" >
< button class = "unsubscribe" > Unsubscribe< / button >
< / form >
< / div >
{% endfor %}
< / div >
2021-01-30 22:27:49 +11:00
{% endif %}
2021-11-25 21:02:04 -07:00
{% if !prefs.filters.is_empty() %}
< div class = "prefs" id = "settings_filters" >
2021-12-27 13:43:44 -08:00
< legend > Filtered Feeds< / legend >
2021-11-25 21:02:04 -07:00
{% for sub in prefs.filters %}
< div >
{% let feed -%}
{% if sub.starts_with("u_") -%}{% let feed = format!("u/{}", & sub[2..]) -%}{% else -%}{% let feed = format!("r/{}", sub) -%}{% endif -%}
< a href = "/{{ feed }}" > {{ feed }}< / a >
< form action = "/r/{{ sub }}/unfilter/?redirect=settings" method = "POST" >
< button class = "unfilter" > Unfilter< / button >
< / form >
< / div >
{% endfor %}
< / div >
{% endif %}
2021-01-30 21:21:46 -08:00
< / div >
2021-01-30 22:27:49 +11:00
2021-01-17 20:39:57 +01:00
{% endblock %}