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 69 70 71 72
use crate::{ widget, widget::{ component::WidgetAlpha, context::WidgetContext, node::WidgetNode, unit::text::{ TextBoxAlignment, TextBoxDirection, TextBoxFont, TextBoxNode, TextBoxSizeValue, }, utils::{Color, Transform}, }, }; use serde::{Deserialize, Serialize}; #[derive(Debug, Default, Clone, Serialize, Deserialize)] pub struct TextBoxProps { #[serde(default)] pub text: String, #[serde(default)] pub width: TextBoxSizeValue, #[serde(default)] pub height: TextBoxSizeValue, #[serde(default)] pub alignment: TextBoxAlignment, #[serde(default)] pub direction: TextBoxDirection, #[serde(default)] pub font: TextBoxFont, #[serde(default)] pub color: Color, #[serde(default)] pub transform: Transform, } implement_props_data!(TextBoxProps); pub fn text_box(context: WidgetContext) -> WidgetNode { let WidgetContext { id, props, shared_props, .. } = context; let TextBoxProps { width, height, text, alignment, direction, font, mut color, transform, } = props.read_cloned_or_default(); let alpha = shared_props.read_cloned_or_default::<WidgetAlpha>().0; color.a *= alpha; widget! {{{ TextBoxNode { id: id.to_owned(), props: props.clone(), text, width, height, alignment, direction, font, color, transform, } }}} }