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
|
use leptos::{IntoView, component, view};
use crate::{
api::recipes_wrapped,
components::{async_fetch::AsyncFetch, container::Container, icon_p::IconP},
};
#[component]
pub fn Recipies() -> impl IntoView {
view! {
<Container
header="Recipies"
buttons=vec![
(view! { <IconP icon=icondata_io::IoFastFood text="Recipies" /> }, "recipies"),
(view! { <IconP icon=icondata_io::IoPin text="Create recipe" /> }, "create-recipe"),
(view! { <IconP icon=icondata_io::IoCalendarSharp text="Mealplan" /> }, "mealplan"),
]
>
{
AsyncFetch! {
@map_error_in_producer
fetcher = recipes_wrapped(),
producer = |recipes| {
view! {
<p>{format!("You have {} recipies.", recipes.len())}</p>
}
}
}
}
</Container>
}
}
|