iced-yoda/style/src/scrollable.rs

71 lines
2.2 KiB
Rust
Raw Normal View History

2022-11-10 01:10:28 +01:00
//! Change the appearance of a scrollable.
2020-01-06 21:01:09 +01:00
use iced_core::{Background, Color};
/// The appearance of a scrollable.
#[derive(Debug, Clone, Copy)]
pub struct Scrollbar {
2022-11-10 01:10:28 +01:00
/// The [`Background`] of a scrollable.
2020-01-06 21:01:09 +01:00
pub background: Option<Background>,
2022-11-10 01:10:28 +01:00
/// The border radius of a scrollable.
pub border_radius: f32,
2022-11-10 01:10:28 +01:00
/// The border width of a scrollable.
pub border_width: f32,
2022-11-10 01:10:28 +01:00
/// The border [`Color`] of a scrollable.
2020-01-06 21:01:09 +01:00
pub border_color: Color,
2022-11-10 01:10:28 +01:00
/// The appearance of the [`Scroller`] of a scrollable.
2020-01-06 21:01:09 +01:00
pub scroller: Scroller,
}
/// The appearance of the scroller of a scrollable.
#[derive(Debug, Clone, Copy)]
pub struct Scroller {
2022-11-10 01:10:28 +01:00
/// The [`Color`] of the scroller.
2020-01-06 21:01:09 +01:00
pub color: Color,
2022-11-10 01:10:28 +01:00
/// The border radius of the scroller.
pub border_radius: f32,
2022-11-10 01:10:28 +01:00
/// The border width of the scroller.
pub border_width: f32,
2022-11-10 01:10:28 +01:00
/// The border [`Color`] of the scroller.
2020-01-06 21:01:09 +01:00
pub border_color: Color,
}
/// A set of rules that dictate the style of a scrollable.
pub trait StyleSheet {
2022-11-10 01:10:28 +01:00
/// The supported style of the [`StyleSheet`].
type Style: Default;
2020-01-06 21:01:09 +01:00
/// Produces the style of an active scrollbar.
fn active(&self, style: &Self::Style) -> Scrollbar;
2020-01-06 21:01:09 +01:00
/// Produces the style of a scrollbar when the scrollable is being hovered.
fn hovered(
&self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> Scrollbar;
2020-01-06 21:01:09 +01:00
/// Produces the style of a scrollbar that is being dragged.
fn dragging(&self, style: &Self::Style) -> Scrollbar {
self.hovered(style, true)
}
/// Produces the style of an active horizontal scrollbar.
fn active_horizontal(&self, style: &Self::Style) -> Scrollbar {
self.active(style)
}
/// Produces the style of a horizontal scrollbar when the scrollable is being hovered.
fn hovered_horizontal(
&self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> Scrollbar {
self.hovered(style, is_mouse_over_scrollbar)
}
/// Produces the style of a horizontal scrollbar that is being dragged.
fn dragging_horizontal(&self, style: &Self::Style) -> Scrollbar {
self.hovered_horizontal(style, true)
}
2020-01-06 21:01:09 +01:00
}