From 9d8f2498e88819cbad07fb704dfb9bb5ee9ae1ad Mon Sep 17 00:00:00 2001 From: yggverse Date: Wed, 4 Dec 2024 07:29:20 +0200 Subject: [PATCH] implement link color change on mouse hover --- .../item/page/content/text/gemini/reader.rs | 37 +++++++++++++++++-- 1 file changed, 34 insertions(+), 3 deletions(-) diff --git a/src/app/browser/window/tab/item/page/content/text/gemini/reader.rs b/src/app/browser/window/tab/item/page/content/text/gemini/reader.rs index 8eda05cf..40697587 100644 --- a/src/app/browser/window/tab/item/page/content/text/gemini/reader.rs +++ b/src/app/browser/window/tab/item/page/content/text/gemini/reader.rs @@ -19,10 +19,10 @@ use gemtext::line::{ quote::Quote, }; use gtk::{ - gdk::{BUTTON_MIDDLE, BUTTON_PRIMARY}, + gdk::{BUTTON_MIDDLE, BUTTON_PRIMARY, RGBA}, gio::Cancellable, glib::{TimeZone, Uri}, - prelude::{TextBufferExt, TextBufferExtManual, TextViewExt, WidgetExt}, + prelude::{TextBufferExt, TextBufferExtManual, TextTagExt, TextViewExt, WidgetExt}, EventControllerMotion, GestureClick, TextBuffer, TextTag, TextWindowType, UriLauncher, Window, WrapMode, }; @@ -33,6 +33,10 @@ pub const EXTERNAL_LINK_INDICATOR: &str = "⇖"; pub const LIST_ITEM: &str = "•"; pub const NEW_LINE: &str = "\n"; +// @TODO use accent colors in adw 1.6 / ubuntu 24.10+ +const LINK_COLOR_DEFAULT: (f32, f32, f32, f32) = (53.0, 132.0, 228.0, 1.0); +const LINK_COLOR_ONHOVER: (f32, f32, f32, f32) = (53.0, 132.0, 228.0, 0.9); + pub struct Reader { pub title: Option, pub widget: Rc, @@ -54,6 +58,12 @@ impl Reader { // Init multiline code builder features let mut multiline = None; + // Init colors + let link_color = ( + new_rgba_from(LINK_COLOR_DEFAULT), + new_rgba_from(LINK_COLOR_ONHOVER), + ); + // Init syntect highlight features let syntax = Syntax::new(); @@ -223,7 +233,7 @@ impl Reader { // Create new tag for new link let a = TextTag::builder() - .foreground("#3584e4") + .foreground_rgba(&link_color.0) // .foreground_rgba(&adw::StyleManager::default().accent_color_rgba()) @TODO adw 1.6 / ubuntu 24.10+ .sentence(true) .wrap_mode(WrapMode::Word) @@ -389,10 +399,19 @@ impl Reader { window_y as i32, ); + // Reset link colors to default + for (tag, _) in _links_.iter() { + tag.set_foreground_rgba(Some(&link_color.0)); + } + + // Apply hover effect if let Some(iter) = text_view.iter_at_location(buffer_x, buffer_y) { for tag in iter.tags() { // Tag is link if let Some(uri) = _links_.get(&tag) { + // Toggle color + tag.set_foreground_rgba(Some(&link_color.1)); + // Toggle cursor text_view.set_cursor_from_name(Some("pointer")); @@ -418,3 +437,15 @@ impl Reader { Ok(Self { title, widget }) } } + +// Private helpers + +/// Create new [RGBA](https://docs.gtk.org/gdk4/struct.RGBA.html) from tuple +fn new_rgba_from(value: (f32, f32, f32, f32)) -> RGBA { + // Extract values + let (r, g, b, a) = value; + + /* @TODO #1931 + RGBA::new(r, g, b, a)*/ + RGBA::parse(format!("rgba({r},{g},{b},{a})")).unwrap() +}