use super::state::TODOS; use crate::recoil::use_atom_family; use dioxus_core::prelude::*; #[derive(PartialEq, Props)] pub struct TodoEntryProps { id: uuid::Uuid, } pub fn TodoEntry(ctx: Context, props: &TodoEntryProps) -> VNode { let (is_editing, set_is_editing) = use_state(&ctx, || false); let todo = use_atom_family(&ctx, &TODOS, ctx.id); ctx.render(rsx! ( li { "{todo.id}" input { class: "toggle" type: "checkbox" "{todo.checked}" } {is_editing.then(|| rsx!( input { value: "{todo.contents}" } ))} } )) }