use super::{RenderContext, TextAlign, TextBaseline, rgba_to_hex};
use uzor::types::{Rect, WidgetState};
use uzor::widgets::text_input::types::TextInputType;
use uzor::widgets::text_input::theme::TextInputTheme;
pub fn render_default(
ctx: &mut dyn RenderContext,
input: &TextInputType,
rect: Rect,
state: WidgetState,
theme: &dyn TextInputTheme,
) {
let border_color = match state {
WidgetState::Pressed | WidgetState::Active => rgba_to_hex(theme.focused_border_color()),
WidgetState::Hovered => rgba_to_hex(theme.border_color()), WidgetState::Disabled => rgba_to_hex(theme.border_color()),
WidgetState::Normal | WidgetState::Toggled => rgba_to_hex(theme.border_color()),
};
match input {
TextInputType::Text { value, placeholder, .. } => {
let bg_color = rgba_to_hex(theme.background_color());
ctx.set_fill_color(&bg_color);
ctx.fill_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
ctx.set_stroke_color(&border_color);
ctx.set_stroke_width(1.0);
ctx.stroke_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
let display_text = if value.is_empty() {
placeholder.as_str()
} else {
value.as_str()
};
let text_color = if value.is_empty() {
rgba_to_hex(theme.placeholder_color())
} else {
rgba_to_hex(theme.text_color())
};
ctx.set_fill_color(&text_color);
ctx.set_font("13px sans-serif");
ctx.set_text_align(TextAlign::Left);
ctx.set_text_baseline(TextBaseline::Middle);
ctx.fill_text(display_text, rect.x + theme.padding(), rect.center_y());
}
TextInputType::Number { value, .. } => {
let bg_color = rgba_to_hex(theme.background_color());
ctx.set_fill_color(&bg_color);
ctx.fill_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
ctx.set_stroke_color(&border_color);
ctx.set_stroke_width(1.0);
ctx.stroke_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
let text_color = rgba_to_hex(theme.text_color());
ctx.set_fill_color(&text_color);
ctx.set_font("13px sans-serif");
ctx.set_text_align(TextAlign::Right);
ctx.set_text_baseline(TextBaseline::Middle);
ctx.fill_text(value, rect.x + rect.width - theme.padding(), rect.center_y());
}
TextInputType::Search { value, .. } => {
let bg_color = rgba_to_hex(theme.background_color());
ctx.set_fill_color(&bg_color);
ctx.fill_rounded_rect(rect.x, rect.y, rect.width, rect.height, 16.0);
ctx.set_stroke_color(&border_color);
ctx.set_stroke_width(1.0);
ctx.stroke_rounded_rect(rect.x, rect.y, rect.width, rect.height, 16.0);
let text_color = rgba_to_hex(theme.text_color());
ctx.set_fill_color(&text_color);
ctx.set_font("14px sans-serif");
ctx.set_text_align(TextAlign::Left);
ctx.set_text_baseline(TextBaseline::Middle);
ctx.fill_text("🔍", rect.x + 8.0, rect.center_y());
ctx.set_font("13px sans-serif");
ctx.fill_text(value, rect.x + 32.0, rect.center_y());
if !value.is_empty() {
ctx.set_text_align(TextAlign::Right);
ctx.fill_text("×", rect.x + rect.width - 12.0, rect.center_y());
}
}
TextInputType::Password { value, .. } => {
let bg_color = rgba_to_hex(theme.background_color());
ctx.set_fill_color(&bg_color);
ctx.fill_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
ctx.set_stroke_color(&border_color);
ctx.set_stroke_width(1.0);
ctx.stroke_rounded_rect(rect.x, rect.y, rect.width, rect.height, 4.0);
let masked = "•".repeat(value.len());
let text_color = rgba_to_hex(theme.text_color());
ctx.set_fill_color(&text_color);
ctx.set_font("13px sans-serif");
ctx.set_text_align(TextAlign::Left);
ctx.set_text_baseline(TextBaseline::Middle);
ctx.fill_text(&masked, rect.x + theme.padding(), rect.center_y());
}
}
}