1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
use crate::theme::{ThemeColor, ThemeProps, ThemedWidgetProps}; use raui_core::prelude::*; use serde::{Deserialize, Serialize}; #[derive(Debug, Default, Clone, Serialize, Deserialize)] pub struct IconImage { #[serde(default)] pub id: String, #[serde(default)] pub source_rect: Option<Rect>, #[serde(default)] pub scaling: ImageBoxImageScaling, } #[derive(Debug, Default, Clone, Serialize, Deserialize)] pub struct IconPaperProps { #[serde(default)] pub image: IconImage, #[serde(default)] pub size_level: usize, #[serde(default)] pub transform: Transform, } implement_props_data!(IconPaperProps, "IconPaperProps"); widget_component! { pub icon_paper(key, props, shared_props) { let themed_props = props.read_cloned_or_default::<ThemedWidgetProps>(); let tint = match shared_props.read::<ThemeProps>() { Ok(props) => match themed_props.color { ThemeColor::Default => props.active_colors.contrast.default.main, ThemeColor::Primary => props.active_colors.contrast.primary.main, ThemeColor::Secondary => props.active_colors.contrast.secondary.main, }, Err(_) => Default::default(), }; let icon_props = props.read_cloned_or_default::<IconPaperProps>(); let size = match shared_props.read::<ThemeProps>() { Ok(props) => props .icons_level_sizes .get(icon_props.size_level) .copied() .unwrap_or(24.0), Err(_) => 24.0, }; let IconImage {id, source_rect, scaling } = icon_props.image; let image = ImageBoxImage { id, source_rect, scaling, tint, }; let props = ImageBoxProps { width: ImageBoxSizeValue::Exact(size), height: ImageBoxSizeValue::Exact(size), content_keep_aspect_ratio: Some(ImageBoxAspectRatio { horizontal_alignment: 0.5, vertical_alignment: 0.5, }), material: ImageBoxMaterial::Image(image), transform: icon_props.transform, }; widget! { (#{key} image_box: {props}) } } }