use crate::*;
pub(crate) fn use_select() -> UseSelect {
UseSelect::new(
use_signal(|| "apple".to_string()),
use_signal(String::new),
use_signal(String::new),
use_signal(String::new),
use_signal(String::new),
use_signal(String::new),
)
}
pub(crate) fn validate_select_textarea(state: UseSelect) {
let textarea_value: String = state.get_textarea_content().get();
if textarea_value.trim().is_empty() {
state
.get_textarea_error()
.set("Please enter some feedback.".to_string());
} else if textarea_value.len() > 200 {
state
.get_textarea_error()
.set("Feedback is too long (max 200 chars).".to_string());
} else {
state.get_textarea_error().set(String::new());
}
}
pub(crate) fn select_on_country_change(state: UseSelect) -> Option<Rc<dyn Fn(Event)>> {
Some(Rc::new(move |event: Event| {
if let Some(target) = event.target()
&& let Ok(select) = target.clone().dyn_into::<HtmlSelectElement>()
{
state.get_selected_country().set(select.value());
state.get_selected_city().set(String::new());
}
}))
}
pub(crate) fn select_on_input_textarea(state: UseSelect) -> Option<Rc<dyn Fn(Event)>> {
Some(Rc::new(move |event: Event| {
if let Some(target) = event.target()
&& let Ok(textarea) = target.clone().dyn_into::<HtmlTextAreaElement>()
{
state.get_textarea_content().set(textarea.value());
}
validate_select_textarea(state);
}))
}
pub(crate) fn select_on_submit_feedback(state: UseSelect) -> Option<Rc<dyn Fn(Event)>> {
Some(Rc::new(move |_event: Event| {
validate_select_textarea(state);
let textarea_error_value: String = state.get_textarea_error().get();
if textarea_error_value.is_empty() {
let content: String = state.get_textarea_content().get();
state
.get_feedback()
.set(format!("Thank you for your feedback: \"{}\"", content));
state.get_textarea_content().set(String::new());
}
}))
}