From 02205d851df89e82ef297e3ceb305551f37ee944 Mon Sep 17 00:00:00 2001 From: Jared Moulton Date: Wed, 26 Jun 2024 10:24:42 -0600 Subject: [PATCH] tooltip improvements (#499) --- src/views/label.rs | 8 ++++---- src/views/tooltip.rs | 42 +++++++++++++++++++++++++++++++++++++----- 2 files changed, 41 insertions(+), 9 deletions(-) diff --git a/src/views/label.rs b/src/views/label.rs index cc7915c2..cf5e4ccb 100644 --- a/src/views/label.rs +++ b/src/views/label.rs @@ -182,11 +182,11 @@ impl Label { let padding_left = match style.padding_left() { PxPct::Px(padding) => padding as f32, - PxPct::Pct(pct) => pct as f32 * layout.size.width, + PxPct::Pct(pct) => (pct / 100.) as f32 * layout.size.width, }; let padding_top = match style.padding_top() { PxPct::Px(padding) => padding as f32, - PxPct::Pct(pct) => pct as f32 * layout.size.width, + PxPct::Pct(pct) => (pct / 100.) as f32 * layout.size.width, }; self.text_layout.as_ref().unwrap().hit( point.x as f32 - padding_left, @@ -436,11 +436,11 @@ impl View for Label { let style = view_state.combined_style.builtin(); let padding_left = match style.padding_left() { PxPct::Px(padding) => padding as f32, - PxPct::Pct(pct) => pct as f32 * layout.size.width, + PxPct::Pct(pct) => (pct / 100.) as f32 * layout.size.width, }; let padding_right = match style.padding_right() { PxPct::Px(padding) => padding as f32, - PxPct::Pct(pct) => pct as f32 * layout.size.width, + PxPct::Pct(pct) => (pct / 100.) as f32 * layout.size.width, }; let text_overflow = style.text_overflow(); (text_overflow, padding_left + padding_right) diff --git a/src/views/tooltip.rs b/src/views/tooltip.rs index 9e22cd79..b5b57474 100644 --- a/src/views/tooltip.rs +++ b/src/views/tooltip.rs @@ -2,6 +2,7 @@ use peniko::kurbo::Point; use std::cell::RefCell; use std::{rc::Rc, time::Duration}; +use crate::style::{Style, StyleClass as _}; use crate::views::Decorators; use crate::{ action::{add_overlay, exec_after, remove_overlay, TimerToken}, @@ -12,9 +13,8 @@ use crate::{ view::{default_compute_layout, IntoView, View}, }; -use super::container; - style_class!(pub TooltipClass); +style_class!(pub TooltipContainerClass); prop!(pub Delay: f64 {} = 0.6); @@ -31,6 +31,8 @@ pub struct Tooltip { overlay: Rc>>, tip: Rc Box>, style: TooltipStyle, + tip_style: Style, + scale: f64, window_origin: Option, } @@ -45,12 +47,15 @@ pub fn tooltip( let overlay = Rc::new(RefCell::new(None)); Tooltip { id, - tip: Rc::new(move || container(tip()).class(TooltipClass).into_any()), + tip: Rc::new(move || tip().into_any()), hover: None, overlay: overlay.clone(), style: Default::default(), + tip_style: Default::default(), + scale: 1.0, window_origin: None, } + .class(TooltipContainerClass) .on_cleanup(move || { if let Some(overlay_id) = overlay.borrow_mut().take() { remove_overlay(overlay_id); @@ -68,16 +73,33 @@ impl View for Tooltip { if let Some(window_origin) = self.window_origin { if self.hover.map(|(_, t)| t) == Some(*token) { let tip = self.tip.clone(); + + let tip_style = self.tip_style.clone(); let overlay_id = add_overlay( - window_origin + self.hover.unwrap().0.to_vec2() + (10., 10.), - move |_| tip(), + window_origin + + self.hover.unwrap().0.to_vec2() + + (10. / self.scale, 10. / self.scale), + move |_| tip().style(move |_| tip_style.clone()), ); + // overlay_id.request_all(); *self.overlay.borrow_mut() = Some(overlay_id); } } } } + fn style_pass(&mut self, cx: &mut crate::context::StyleCx<'_>) { + self.style.read(cx); + self.scale = cx.app_state.scale; + + self.tip_style = + Style::new().apply_classes_from_context(&[TooltipClass::class_ref()], &cx.current); + + for child in self.id.children() { + cx.style_view(child); + } + } + fn event_before_children(&mut self, cx: &mut EventCx, event: &Event) -> EventPropagation { match &event { Event::PointerMove(e) => { @@ -114,3 +136,13 @@ impl View for Tooltip { default_compute_layout(self.id, cx) } } + +pub trait TooltipTrait { + fn tooltip(self, tip: impl Fn() -> V + 'static) -> Tooltip; +} + +impl TooltipTrait for T { + fn tooltip(self, tip: impl Fn() -> V + 'static) -> Tooltip { + tooltip(self, tip) + } +}