7 个版本
0.3.0 | 2023年2月16日 |
---|---|
0.2.3 | 2023年1月14日 |
0.2.2 | 2022年10月29日 |
0.1.1 | 2022年10月24日 |
#54 in #dioxus
每月下载量:21
35KB
760 行
Patternfly 组件用于 Dioxus
Dioxus 组件用于 Patternfly.
设置
npm i @patternfly/patternfly --save
添加到 index.html
<link data-trunk rel="scss" href="node_modules/@patternfly/patternfly/patternfly.scss">
<link data-trunk rel="scss" href="node_modules/@patternfly/patternfly/patternfly-addons.scss">
<link data-trunk rel="copy-dir" href="node_modules/@patternfly/patternfly/assets">
不兼容更改
v0.2.1
PfTab 组件:该组件之前使用 GlobalState,但已将其更改为向父级和子级传递 UseState。
当前可用的组件。
- PfBadge
- PfAlert
- PfAccordion
- PfTooltip
- PfDatePicker
- Spinner
- PfLargeSpinner
- PfMiddleSpinner
- PfSmallSpinner
- PfTabs
- 卡片
- 模态框
- 芯片
- 下拉菜单
- Toast
- DatePicker
- 选项卡
- 标签,标签组
工作...
- 导航
- 剪贴板
例如...
fn App(cx: Scope) -> Element {
let date = use_state(&cx, || "2020-03-05".to_string());
let modal_is_open = use_state(&cx, || false);
let smallmodal_is_open = use_state(&cx, || false);
let chips = vec!["chip1".to_string(), "chip2".to_string(),"chip3".to_string()];
let chip_states = use_state(&cx, || chips);
let chips = chip_states.get().clone();
let chips_str:String = chips.iter().map(|x| x.clone()).collect::<Vec<_>>().join(", ");
let str_state = use_state(&cx, || "".to_string());
let vec_state: &UseState<Vec<String>> = use_state(&cx, || vec!["aaa".to_string(),"bbb".to_string()]);
let tab_selected_contents = use_state(&cx, || "".to_string());
cx.render(rsx! {
div{
"aaa",
PfBadge {
read: true,
"1"
}
PfBadge {
read: false,
"1"
}
PfAlert {
variation: Variation::Info,
"bbb"
}
PfAlert {
variation: Variation::Danger,
title: "title",
"body"
}
PfAccordion {
title: "title",is_open:true,
"body"
}
PfTooltip {
content: "tooltip", orientation: Orientation::Right,
"ccc"
}
PfDatePicker {
date: date,
}
div { "{date}"}
PfLargeSpinner {}
PfMiddleSpinner {}
PfSmallSpinner {}
// Set the same state for the selected_contents attribute.
// The content information of the tab selected by this UseState<String> is synchronized with the upper element.
PfTabs {
selected_contents: tab_selected_contents.clone(),
PfTab {
selected_contents: tab_selected_contents.clone(),
title: "tab1",
"tab1-content"
},
PfTab {
selected_contents: tab_selected_contents.clone(),
title: "tab2",
span {style:"color:red;", "tab2-content"}
}
}
}
PfModal {
title: "modal", is_close: modal_is_open,
"modal-content"
}
span {hidden: "true",
PfSmallModal{
title: "smallmodal", is_close: smallmodal_is_open,
PfAlert{
variation: Variation::Danger,
title: "title",
"smallmodal-content"
}
}
}
PfToast {
timeout: Duration::from_secs(5),
PfSmallModal{
title: "toast", is_close: smallmodal_is_open,
PfAlert{
variation: Variation::Danger,
title: "title",
"this modal will be close after 5 seconds"
}
}
PfAlert{
variation: Variation::Danger,
title: "title",
"this alert will be closed after 5 seconds"
}
}
PfChip{
"chip"
}
PfChipGroup{
chips: chip_states,
}
"{chips_str}"
br{}
PfDropDown{
list: chips.clone(),selected: str_state.clone(),
}
PfDropDownRaw{
selected: str_state.clone(),
PfDropDownItem{
item_str: "item1".to_string(),
selected: str_state.clone(),
div {
"item1"
i {class: "fas fa-angle-right", aria_hidden: "false" }
}
},
PfDropDownItem{
item_str: "item2".to_string(),
selected: str_state.clone(),
div {
"item2"
i {class: "fas fa-angle-right", aria_hidden: "false" }
}
},
div { class: "pf-l-bullseye",
PfCard {
PfCardBody{
div {style:"color: red; width: 220px;text-align: center;","aaa",}
}
}
PfCard {
PfCardBody{
div {style:"color: red;","bbb",}
}
}
}
PfLabel{
"label"
}
PfLabel {
icon_name: "fa-info-circle",
append_class: "pf-m-blue",
"blue label"
}
PfLabelGroup{
selected: vec_state,
}
})
}
div { class: "pf-l-bullseye",
PfCard {
PfCardBody{
div {style:"color: red; width: 220px;text-align: center;","aaa",}
}
}
PfCard {
PfCardBody{
div {style:"color: red;","bbb",}
}
}
}
PfLabel{
"label"
}
PfLabel {
icon_name: "fa-info-circle",
append_class: "pf-m-blue",
"blue label"
}
PfLabelGroup{
selected: vec_state,
}
})
}
依赖
约14-23MB
约332K SLoC