thaw/demo_markdown/docs/auto_complete/mod.md
2024-06-14 17:23:02 +08:00

3.1 KiB

Auto Complete

let value = RwSignal::new(String::new());
let options = Memo::<Vec<_>>::new(move |_| {
    let prefix = value
        .get()
        .split_once('@')
        .map_or(value.get(), |v| v.0.to_string());
    vec!["@gmail.com", "@163.com"]
        .into_iter()
        .map(|suffix| (format!("{prefix}{suffix}"), format!("{prefix}{suffix}")))
        .collect()
});

view! {
    <AutoComplete value placeholder="Email">
        <For
            each=move || options.get()
            key=|option| option.0.clone()
            let:option
        >
            <AutoCompleteOption2 key=option.0>
                {option.1}
            </AutoCompleteOption2>
        </For>
    </AutoComplete>
}

Disabled

view! {
    <AutoComplete placeholder="Email" disabled=true/>
}

Invalid

view! {
    <AutoComplete placeholder="Email" invalid=true/>
}

Prefix & Suffix

view! {
    <Space vertical=true>
        <AutoComplete>
            <AutoCompletePrefix slot>
                <Icon icon=icondata::AiUserOutlined/>
            </AutoCompletePrefix>
        </AutoComplete>
        <AutoComplete>
            <AutoCompleteSuffix slot>
                <Icon icon=icondata::AiGithubOutlined/>
            </AutoCompleteSuffix>
        </AutoComplete>
    </Space>
}

AutoComplete Props

Name Type Default Description
class OptionalProp<MaybeSignal<String>> Default::default() Additional classes for the autocomplete element.
value Model<String> Default::default() Input of autocomplete.
placeholder OptionalProp<RwSignal<String>> Default::default() Autocomplete's placeholder.
options MaybeSignal<Vec<AutoCompleteOption>> Default::default() Options to autocomplete from.
disabled MaybeSignal<bool> false Whether the input is disabled.
allow_free_input bool false Whether free text input is allowed.
invalid MaybeSignal<bool> false Whether the input is invalid.
clear_after_select MaybeSignal<bool> false Whether to clear after selection.
blur_after_select MaybeSignal<bool> false Whether to blur after selection.
on_select Option<Callback<String>> None On select callback function.
attr: Vec<(&'static str, Attribute)> Default::default() The dom attrs of the input element inside the component.

AutoCompleteOption Properties

Name Type Description
value String Option ID.
label String Option label value.

AutoCompleteOption Slots

Name Default Description
AutoCompletePrefix None AutoCompletePrefix content.
AutoCompleteSuffix None AutoCompleteSuffix content.

AutoComplete Ref

Name Type Description
focus Fn(&self) Focus the input element.
blur Fn(&self) Blur the input element.