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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
use super::{ElementRender, Nodes, NodesOwned, StaticNodes, StaticNodesOwned};
use crate::{
component::Component,
render::{
base::{ElementUpdater, NodesUpdaterMut},
html::HtmlTag,
ListElementCreation,
},
};
pub trait HemsForPartialList<'a, C: Component>: Sized + NodesUpdaterMut<C> {
fn list_with_render<I, II, R>(
mut self,
items: II,
mode: ListElementCreation,
tag: &'static str,
render: R,
) -> Self
where
II: Iterator<Item = I>,
R: Fn(I, crate::Element<C>),
{
let tag = HtmlTag(tag);
let (comp, state, mut r) = self
.nodes_updater_mut()
.get_list_updater(mode.use_template());
let _do_we_have_to_care_about_this_returned_value_ =
r.render(comp, state, items, tag, |item: I, er: ElementUpdater<C>| {
render(item, er.into())
});
self
}
fn lwr_clone<I, II, R>(self, items: II, tag: &'static str, render: R) -> Self
where
II: Iterator<Item = I>,
R: Fn(I, crate::Element<C>),
{
self.list_with_render(items, ListElementCreation::Clone, tag, render)
}
fn list<I, II>(self, items: II, mode: ListElementCreation) -> Self
where
I: ElementRender<C>,
II: Iterator<Item = I>,
{
self.list_with_render(items, mode, I::ELEMENT_TAG, I::render)
}
fn list_clone<I, II>(self, items: II) -> Self
where
I: ElementRender<C>,
II: Iterator<Item = I>,
{
self.list_with_render(items, ListElementCreation::Clone, I::ELEMENT_TAG, I::render)
}
}
impl<'a, C: Component> HemsForPartialList<'a, C> for NodesOwned<'a, C> {}
impl<'a, C: Component> HemsForPartialList<'a, C> for StaticNodesOwned<'a, C> {}
impl<'h, 'n: 'h, C: Component> HemsForPartialList<'h, C> for Nodes<'h, 'n, C> {}
impl<'h, 'n: 'h, C: Component> HemsForPartialList<'h, C> for StaticNodes<'h, 'n, C> {}