use crate::{button::StyleSheet, Primitive, Renderer}; use iced_native::{Background, MouseCursor, Point, Rectangle}; impl iced_native::button::Renderer for Renderer { type Style = Box; fn draw( &mut self, bounds: Rectangle, cursor_position: Point, is_pressed: bool, style: &Box, (content, _): Self::Output, ) -> Self::Output { let is_mouse_over = bounds.contains(cursor_position); // TODO: Render proper shadows let styling = if is_mouse_over { if is_pressed { style.pressed() } else { style.hovered() } } else { style.active() }; ( match styling.background { None => content, Some(background) => Primitive::Group { primitives: vec![ Primitive::Quad { bounds: Rectangle { x: bounds.x + 1.0, y: bounds.y + styling.shadow_offset, ..bounds }, background: Background::Color( [0.0, 0.0, 0.0, 0.5].into(), ), border_radius: styling.border_radius, }, Primitive::Quad { bounds, background, border_radius: styling.border_radius, }, content, ], }, }, if is_mouse_over { MouseCursor::Pointer } else { MouseCursor::OutOfBounds }, ) } }