use ratatui::{
Frame,
layout::Rect,
widgets::Paragraph,
};
use crate::core::model::component_context::ComponentContext;
use crate::tui::component_impl::TuiComponent;
pub struct IconComponent;
impl TuiComponent for IconComponent {
fn name(&self) -> &'static str {
"Icon"
}
fn render(
&self,
ctx: &ComponentContext,
area: Rect,
frame: &mut Frame,
_render_child: &mut dyn FnMut(&str, Rect, &mut Frame),
) {
let comp_model = match ctx.components.get(&ctx.component_id) {
Some(m) => m,
None => return,
};
let inner = Rect {
x: area.x + 1,
y: area.y + 1,
width: area.width.saturating_sub(2),
height: area.height.saturating_sub(2),
};
if inner.width == 0 || inner.height == 0 {
return;
}
let name: Option<String> = comp_model.get_property("name");
let symbol = match name.as_deref() {
Some(n) => map_icon(n),
None => String::from("[?]"),
};
let paragraph = Paragraph::new(symbol);
frame.render_widget(paragraph, inner);
}
}
fn map_icon(name: &str) -> String {
let symbol = match name {
"mail" => "✉",
"send" => "➤",
"search" => "🔍",
"settings" => "⚙",
"star" => "★",
"accountCircle" => "👤",
"home" => "🏠",
"heart" => "♥",
"check" => "✓",
"close" => "✕",
"add" => "+",
"remove" => "−",
"edit" => "✎",
"delete" => "🗑",
"refresh" => "⟳",
"arrowBack" => "←",
"arrowForward" => "→",
"arrowUp" => "↑",
"arrowDown" => "↓",
"info" => "ℹ",
"warning" => "⚠",
"error" => "✗",
"success" => "✔",
_ => return fallback_icon(name),
};
symbol.to_string()
}
fn fallback_icon(name: &str) -> String {
let chars: String = name.chars().take(2).collect();
format!("[{}]", chars)
}