From 495985f449e46b24e6b734d3aa9e135a779a8b77 Mon Sep 17 00:00:00 2001 From: pml68 Date: Sun, 13 Apr 2025 03:40:38 +0200 Subject: refactor: move `material_theme` and `iced_drop` into separate crates dir --- crates/material_theme/src/scrollable.rs | 153 ++++++++++++++++++++++++++++++++ 1 file changed, 153 insertions(+) create mode 100644 crates/material_theme/src/scrollable.rs (limited to 'crates/material_theme/src/scrollable.rs') diff --git a/crates/material_theme/src/scrollable.rs b/crates/material_theme/src/scrollable.rs new file mode 100644 index 0000000..ee739ba --- /dev/null +++ b/crates/material_theme/src/scrollable.rs @@ -0,0 +1,153 @@ +use iced_widget::core::{Border, Color, border}; +use iced_widget::scrollable::{ + Catalog, Rail, Scroller, Status, Style, StyleFn, +}; + +use super::Theme; +use super::container::surface_container; +use super::utils::mix; +use crate::utils::{ + DISABLED_CONTAINER_OPACITY, DISABLED_TEXT_OPACITY, HOVERED_LAYER_OPACITY, + PRESSED_LAYER_OPACITY, +}; + +impl Catalog for Theme { + type Class<'a> = StyleFn<'a, Self>; + + fn default<'a>() -> Self::Class<'a> { + Box::new(default) + } + + fn style(&self, class: &Self::Class<'_>, status: Status) -> Style { + class(self, status) + } +} + +pub fn default(theme: &Theme, status: Status) -> Style { + let colors = theme.colorscheme.surface; + + let active = Rail { + background: None, + scroller: Scroller { + color: colors.on_surface, + border: border::rounded(400), + }, + border: Border::default(), + }; + + let disabled = Rail { + background: Some( + Color { + a: DISABLED_CONTAINER_OPACITY, + ..colors.on_surface + } + .into(), + ), + scroller: Scroller { + color: Color { + a: DISABLED_TEXT_OPACITY, + ..colors.on_surface + }, + border: border::rounded(400), + }, + ..active + }; + + let style = Style { + container: surface_container(theme), + vertical_rail: active, + horizontal_rail: active, + gap: None, + }; + + match status { + Status::Active { + is_horizontal_scrollbar_disabled, + is_vertical_scrollbar_disabled, + } => Style { + horizontal_rail: if is_horizontal_scrollbar_disabled { + disabled + } else { + active + }, + vertical_rail: if is_vertical_scrollbar_disabled { + disabled + } else { + active + }, + ..style + }, + Status::Hovered { + is_horizontal_scrollbar_hovered, + is_vertical_scrollbar_hovered, + is_horizontal_scrollbar_disabled, + is_vertical_scrollbar_disabled, + } => { + let hovered_rail = Rail { + scroller: Scroller { + color: mix( + colors.on_surface, + colors.color, + HOVERED_LAYER_OPACITY, + ), + border: border::rounded(400), + }, + ..active + }; + + Style { + horizontal_rail: if is_horizontal_scrollbar_disabled { + disabled + } else if is_horizontal_scrollbar_hovered { + hovered_rail + } else { + active + }, + vertical_rail: if is_vertical_scrollbar_disabled { + disabled + } else if is_vertical_scrollbar_hovered { + hovered_rail + } else { + active + }, + ..style + } + } + Status::Dragged { + is_horizontal_scrollbar_dragged, + is_vertical_scrollbar_dragged, + is_horizontal_scrollbar_disabled, + is_vertical_scrollbar_disabled, + } => { + let dragged_rail = Rail { + scroller: Scroller { + color: mix( + colors.on_surface, + colors.color, + PRESSED_LAYER_OPACITY, + ), + border: border::rounded(400), + }, + ..active + }; + + Style { + horizontal_rail: if is_horizontal_scrollbar_disabled { + disabled + } else if is_horizontal_scrollbar_dragged { + dragged_rail + } else { + active + }, + vertical_rail: if is_vertical_scrollbar_disabled { + disabled + } else if is_vertical_scrollbar_dragged { + dragged_rail + } else { + active + }, + ..style + } + } + } +} -- cgit v1.2.3