+
{{ post.body|safe }}
From 4d051361d8268e572a9a9b238598933f01986610 Mon Sep 17 00:00:00 2001
From: DokterKaj <54882101+DokterKaj@users.noreply.github.com>
Date: Wed, 16 Oct 2024 18:27:18 +0800
Subject: [PATCH 7/9] simplify focus detection + add option to settings
---
.env.example | 2 ++
README.md | 1 +
app.json | 3 ++
contrib/redlib.conf | 1 +
src/config.rs | 6 ++++
src/instance_info.rs | 3 ++
src/settings.rs | 3 +-
src/utils.rs | 2 ++
static/style.css | 62 ++++++++++++++++-------------------------
templates/settings.html | 5 ++++
templates/utils.html | 18 ++++++------
11 files changed, 58 insertions(+), 48 deletions(-)
diff --git a/.env.example b/.env.example
index 5e60b08..d4d85c6 100644
--- a/.env.example
+++ b/.env.example
@@ -30,6 +30,8 @@ REDLIB_DEFAULT_BLUR_SPOILER=off
REDLIB_DEFAULT_SHOW_NSFW=off
# Enable blurring NSFW content by default
REDLIB_DEFAULT_BLUR_NSFW=off
+# Enable unblurring content on hover by default
+REDLIB_DEFAULT_UNBLUR_ON_HOVER=off
# Enable HLS video format by default
REDLIB_DEFAULT_USE_HLS=off
# Hide HLS notification by default
diff --git a/README.md b/README.md
index 16be29e..c3fe270 100644
--- a/README.md
+++ b/README.md
@@ -398,6 +398,7 @@ Assign a default value for each user-modifiable setting by passing environment v
| `BLUR_SPOILER` | `["on", "off"]` | `off` |
| `SHOW_NSFW` | `["on", "off"]` | `off` |
| `BLUR_NSFW` | `["on", "off"]` | `off` |
+| `UNBLUR_ON_HOVER` | `["on", "off"]` | `off` |
| `USE_HLS` | `["on", "off"]` | `off` |
| `HIDE_HLS_NOTIFICATION` | `["on", "off"]` | `off` |
| `AUTOPLAY_VIDEOS` | `["on", "off"]` | `off` |
diff --git a/app.json b/app.json
index c05b26d..04884f5 100644
--- a/app.json
+++ b/app.json
@@ -38,6 +38,9 @@
"REDLIB_DEFAULT_BLUR_NSFW": {
"required": false
},
+ "REDLIB_DEFAULT_UNBLUR_ON_HOVER" : {
+ "required": false
+ },
"REDLIB_USE_HLS": {
"required": false
},
diff --git a/contrib/redlib.conf b/contrib/redlib.conf
index e670455..012d3dd 100644
--- a/contrib/redlib.conf
+++ b/contrib/redlib.conf
@@ -9,6 +9,7 @@ PORT=12345
#REDLIB_DEFAULT_BLUR_SPOILER=off
#REDLIB_DEFAULT_SHOW_NSFW=off
#REDLIB_DEFAULT_BLUR_NSFW=off
+#REDLIB_DEFAULT_UNBLUR_ON_HOVER=off
#REDLIB_DEFAULT_USE_HLS=off
#REDLIB_DEFAULT_HIDE_HLS_NOTIFICATION=off
#REDLIB_DEFAULT_AUTOPLAY_VIDEOS=off
diff --git a/src/config.rs b/src/config.rs
index 034afc7..ab01bb6 100644
--- a/src/config.rs
+++ b/src/config.rs
@@ -60,6 +60,10 @@ pub struct Config {
#[serde(alias = "LIBREDDIT_DEFAULT_BLUR_NSFW")]
pub(crate) default_blur_nsfw: Option
,
+ #[serde(rename = "REDLIB_DEFAULT_UNBLUR_ON_HOVER")]
+ #[serde(alias = "LIBREDDIT_DEFAULT_UNBLUR_ON_HOVER")]
+ pub(crate) default_unblur_on_hover: Option,
+
#[serde(rename = "REDLIB_DEFAULT_USE_HLS")]
#[serde(alias = "LIBREDDIT_DEFAULT_USE_HLS")]
pub(crate) default_use_hls: Option,
@@ -143,6 +147,7 @@ impl Config {
default_blur_spoiler: parse("REDLIB_DEFAULT_BLUR_SPOILER"),
default_show_nsfw: parse("REDLIB_DEFAULT_SHOW_NSFW"),
default_blur_nsfw: parse("REDLIB_DEFAULT_BLUR_NSFW"),
+ default_unblur_on_hover: parse("REDLIB_DEFAULT_UNBLUR_ON_HOVER"),
default_use_hls: parse("REDLIB_DEFAULT_USE_HLS"),
default_hide_hls_notification: parse("REDLIB_DEFAULT_HIDE_HLS_NOTIFICATION"),
default_hide_awards: parse("REDLIB_DEFAULT_HIDE_AWARDS"),
@@ -171,6 +176,7 @@ fn get_setting_from_config(name: &str, config: &Config) -> Option {
"REDLIB_DEFAULT_BLUR_SPOILER" => config.default_blur_spoiler.clone(),
"REDLIB_DEFAULT_SHOW_NSFW" => config.default_show_nsfw.clone(),
"REDLIB_DEFAULT_BLUR_NSFW" => config.default_blur_nsfw.clone(),
+ "REDLIB_DEFAULT_UNBLUR_ON_HOVER" => config.default_unblur_on_hover.clone(),
"REDLIB_DEFAULT_USE_HLS" => config.default_use_hls.clone(),
"REDLIB_DEFAULT_HIDE_HLS_NOTIFICATION" => config.default_hide_hls_notification.clone(),
"REDLIB_DEFAULT_WIDE" => config.default_wide.clone(),
diff --git a/src/instance_info.rs b/src/instance_info.rs
index c05ce5c..8d5c681 100644
--- a/src/instance_info.rs
+++ b/src/instance_info.rs
@@ -146,6 +146,7 @@ impl InstanceInfo {
["Blur Spoiler", &convert(&self.config.default_blur_spoiler)],
["Show NSFW", &convert(&self.config.default_show_nsfw)],
["Blur NSFW", &convert(&self.config.default_blur_nsfw)],
+ ["Unblur on hover", &convert(&self.config.default_unblur_on_hover)],
["Use HLS", &convert(&self.config.default_use_hls)],
["Hide HLS notification", &convert(&self.config.default_hide_hls_notification)],
["Subscriptions", &convert(&self.config.default_subscriptions)],
@@ -182,6 +183,7 @@ impl InstanceInfo {
Default blur Spoiler: {:?}\n
Default show NSFW: {:?}\n
Default blur NSFW: {:?}\n
+ Default unblur on hover: {:?}\n
Default use HLS: {:?}\n
Default hide HLS notification: {:?}\n
Default subscriptions: {:?}\n
@@ -208,6 +210,7 @@ impl InstanceInfo {
self.config.default_blur_spoiler,
self.config.default_show_nsfw,
self.config.default_blur_nsfw,
+ self.config.default_unblur_on_hover,
self.config.default_use_hls,
self.config.default_hide_hls_notification,
self.config.default_subscriptions,
diff --git a/src/settings.rs b/src/settings.rs
index 5db1a03..67bd143 100644
--- a/src/settings.rs
+++ b/src/settings.rs
@@ -19,7 +19,7 @@ struct SettingsTemplate {
// CONSTANTS
-const PREFS: [&str; 17] = [
+const PREFS: [&str; 18] = [
"theme",
"front_page",
"layout",
@@ -29,6 +29,7 @@ const PREFS: [&str; 17] = [
"blur_spoiler",
"show_nsfw",
"blur_nsfw",
+ "unblur_on_hover",
"use_hls",
"hide_hls_notification",
"autoplay_videos",
diff --git a/src/utils.rs b/src/utils.rs
index 6f97775..67484c9 100644
--- a/src/utils.rs
+++ b/src/utils.rs
@@ -600,6 +600,7 @@ pub struct Preferences {
pub blur_spoiler: String,
pub show_nsfw: String,
pub blur_nsfw: String,
+ pub unblur_on_hover: String,
pub hide_hls_notification: String,
pub hide_sidebar_and_summary: String,
pub use_hls: String,
@@ -639,6 +640,7 @@ impl Preferences {
show_nsfw: setting(req, "show_nsfw"),
hide_sidebar_and_summary: setting(req, "hide_sidebar_and_summary"),
blur_nsfw: setting(req, "blur_nsfw"),
+ unblur_on_hover: setting(req, "unblur_on_hover"),
use_hls: setting(req, "use_hls"),
hide_hls_notification: setting(req, "hide_hls_notification"),
autoplay_videos: setting(req, "autoplay_videos"),
diff --git a/static/style.css b/static/style.css
index 9130ce0..4911f30 100644
--- a/static/style.css
+++ b/static/style.css
@@ -1146,49 +1146,35 @@ a.search_subreddit:hover {
}
/* Unblur on hover */
-.post_blurred .post_media_content:not([tabindex]):hover *,
-.post_blurred .post_media_content:not([tabindex]):hover ~ .post_body,
-.post_blurred .post_media_content:not([tabindex]):has(~ .post_body:hover) *,
-.post_blurred .post_body:not([tabindex]):hover,
-.post_blurred .post_thumbnail:not([tabindex]):hover * {
- filter: none;
+.post_blurred:has(:is(.post_media_content, .post_body, .post_thumbnail):hover) {
+ .post_media_content:not([tabindex]) *,
+ .post_body:not([tabindex]),
+ .post_thumbnail:not([tabindex]) * {
+ filter: none;
+ }
}
/* Unblur on click */
-.post_blurred .post_media_content[tabindex]:not(:focus-within) *,
-.post_blurred .post_body[tabindex]:not(:focus-within) a,
-.post_blurred .post_thumbnail[tabindex]:not(:focus-within) a {
- pointer-events: none;
+.post_blurred:not(:has(:is(.post_media_content, .post_body, .post_thumbnail):focus-within)) {
+ .post_media_content[tabindex] *,
+ .post_body[tabindex] a,
+ .post_thumbnail[tabindex] a {
+ pointer-events: none;
+ }
+
+ .post_media_content[tabindex],
+ .post_body[tabindex],
+ .post_thumbnail[tabindex] {
+ cursor: pointer;
+ }
}
-.post_blurred .post_media_content[tabindex]:not(:focus-within),
-.post_blurred .post_body[tabindex]:not(:focus-within),
-.post_blurred .post_thumbnail[tabindex]:not(:focus-within) {
- cursor: pointer;
-}
-
-.post_blurred .post_media_content:focus-within *,
-.post_blurred .post_media_content:focus-within ~ .post_body,
-.post_blurred .post_media_content:has(~ .post_body:focus-within) *,
-.post_blurred .post_body:focus-within,
-.post_blurred .post_thumbnail:focus-within * {
- filter: none;
-}
-
-.post_blurred .post_media_content:focus-within *,
-.post_blurred .post_media_content:focus-within ~ .post_body a,
-.post_blurred .post_media_content:has(~ .post_body:focus-within) *,
-.post_blurred .post_body:focus-within a,
-.post_blurred .post_thumbnail:focus-within a {
- pointer-events: unset !important;
-}
-
-.post_blurred .post_media_content:focus-within,
-.post_blurred .post_media_content:focus-within ~ .post_body,
-.post_blurred .post_media_content:has(~ .post_body:focus-within),
-.post_blurred .post_body:focus-within,
-.post_blurred .post_thumbnail:focus-within {
- cursor: unset !important;
+.post_blurred:has(:is(.post_media_content, .post_body, .post_thumbnail):focus-within) {
+ .post_media_content[tabindex] *,
+ .post_body[tabindex],
+ .post_thumbnail[tabindex] * {
+ filter: none;
+ }
}
.post_media_image svg {
diff --git a/templates/settings.html b/templates/settings.html
index 3940cc7..4b36a2b 100644
--- a/templates/settings.html
+++ b/templates/settings.html
@@ -75,6 +75,11 @@