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
use dioxus::prelude::*;
#[allow(non_snake_case)]
#[inline_props]
pub fn PfAccordion<'a>(
cx: Scope<'a>,
children: Element<'a>,
title: &'a str,
is_open: Option<bool>,
) -> Element {
let default_open_flag = !is_open.unwrap_or(false);
let is_close_accordion = use_state(&cx, || default_open_flag);
let buttoncss = if *is_close_accordion.get() {
"pf-c-accordion__toggle"
} else {
"pf-c-accordion__toggle pf-m-expanded"
};
cx.render(rsx! {
div {class: "pf-c-accordion",
h3 {
button { class: "{buttoncss} ", r#type: "button", aria_expanded: "false",
onclick: move |_| { is_close_accordion.set(!is_close_accordion.get()); },
span { class: "pf-c-accordion__toggle-text", "{title}" },
span { class: "pf-c-accordion__toggle-icon",
i { class: "fas fa-angle-right", aria_hidden: "false" }
}
}
}
div { class: "pf-c-accordion__expanded-content pf-m-expanded",
div { class: "pf-c-accordion__expanded-content-body", hidden:"{is_close_accordion}" , children, }
}
}
})
}