lucide/packages/yew/src/dna.rs
2024-11-24 19:28:48 +01:00

54 lines
1.7 KiB
Rust

use yew::prelude::*;
#[derive(PartialEq, Properties)]
pub struct DnaProps {
#[prop_or(24)]
pub size: usize,
#[prop_or(AttrValue::from("currentColor"))]
pub color: AttrValue,
#[prop_or(AttrValue::from("none"))]
pub fill: AttrValue,
#[prop_or(2)]
pub stroke_width: usize,
#[prop_or(false)]
pub absolute_stroke_width: bool,
#[prop_or_default]
pub class: Classes,
#[prop_or_default]
pub node_ref: NodeRef,
}
#[function_component]
pub fn Dna(props: &DnaProps) -> Html {
let stroke_width = if props.absolute_stroke_width {
props.stroke_width * 24 / props.size
} else {
props.stroke_width
};
html! {
<svg
ref={props.node_ref.clone()}
class={classes!("lucide", props.class
.clone())}
xmlns="http://www.w3.org/2000/svg"
width={props.size.to_string()}
height={props.size.to_string()}
viewBox="0 0 24 24"
fill={& props.fill}
stroke={& props.color}
stroke-width={stroke_width.to_string()}
stroke-linecap="round"
stroke-linejoin="round"
>
<path d="m10 16 1.5 1.5" />
<path d="m14 8-1.5-1.5" />
<path d="M15 2c-1.798 1.998-2.518 3.995-2.807 5.993" />
<path d="m16.5 10.5 1 1" />
<path d="m17 6-2.891-2.891" />
<path d="M2 15c6.667-6 13.333 0 20-6" />
<path d="m20 9 .891.891" />
<path d="M3.109 14.109 4 15" />
<path d="m6.5 12.5 1 1" />
<path d="m7 18 2.891 2.891" />
<path d="M9 22c1.798-1.998 2.518-3.995 2.807-5.993" />
</svg>
}
}