use crate::*;
#[derive(Clone, Copy)]
pub struct UseSelect {
pub selected_fruit: Signal<String>,
pub selected_country: Signal<String>,
pub selected_city: Signal<String>,
pub feedback: Signal<String>,
pub textarea_content: Signal<String>,
}
pub fn use_select() -> UseSelect {
UseSelect {
selected_fruit: use_signal(|| "apple".to_string()),
selected_country: use_signal(|| "".to_string()),
selected_city: use_signal(|| "".to_string()),
feedback: use_signal(|| "".to_string()),
textarea_content: use_signal(|| "".to_string()),
}
}
pub fn select_on_country_change(state: UseSelect) -> NativeEventHandler {
NativeEventHandler::new(NativeEventName::Change, move |event: NativeEvent| {
if let NativeEvent::Change(change_event) = event {
state.selected_country.set(change_event.get_value().clone());
state.selected_city.set("".to_string());
}
})
}
pub fn select_on_submit_feedback(state: UseSelect) -> NativeEventHandler {
NativeEventHandler::new(NativeEventName::Click, move |_event: NativeEvent| {
let content: String = state.textarea_content.get();
if content.trim().is_empty() {
state
.feedback
.set("Please enter some feedback.".to_string());
} else if content.len() > 200 {
state
.feedback
.set("Feedback is too long (max 200 chars).".to_string());
} else {
state
.feedback
.set(format!("Thank you for your feedback: \"{}\"", content));
state.textarea_content.set("".to_string());
}
})
}