use vertigo::{
AttrGroup, Computed, Value, bind, component, computed_tuple, dom, render::render_list,
};
#[component]
pub fn DictSelect<T: Clone + From<String> + PartialEq + ToString + 'static>(
value: Value<i64>,
options: Computed<Vec<(i64, T)>>,
select: AttrGroup,
) {
let on_change = bind!(value, |new_value: String| {
value.set(new_value.parse().unwrap_or_default());
});
let empty = computed_tuple!(value, options).render_value_option(|(value, options)| {
options
.iter()
.all(|(key, _)| key != &value)
.then(|| dom! { <option value="" selected="selected" /> })
});
let list = bind!(
options,
value.render_value(move |value| render_list(
&options,
|(key, _)| key.to_string(),
move |(key, item)| {
let text_item = item.to_string();
if key == &value {
dom! { <option value={&key} selected="selected">{text_item}</option> }
} else {
dom! { <option value={&key}>{text_item}</option> }
}
}
))
);
dom! {
<select {on_change} {..select}>
{empty}
{list}
</select>
}
}