#[doc(alias = "input")]
#[non_exhaustive]
#[derive(Debug, Clone, PartialEq, PartialOrd, Default)]
pub struct Input {
global_attrs: crate::GlobalAttributes,
pub accept: std::option::Option<std::borrow::Cow<'static, str>>,
pub alt: std::option::Option<std::borrow::Cow<'static, str>>,
pub autocomplete: std::option::Option<std::borrow::Cow<'static, str>>,
pub checked: std::option::Option<std::borrow::Cow<'static, str>>,
pub dirname: std::option::Option<std::borrow::Cow<'static, str>>,
pub disabled: std::option::Option<std::borrow::Cow<'static, str>>,
pub form: std::option::Option<std::borrow::Cow<'static, str>>,
pub formaction: std::option::Option<std::borrow::Cow<'static, str>>,
pub formenctype: std::option::Option<std::borrow::Cow<'static, str>>,
pub formmethod: std::option::Option<std::borrow::Cow<'static, str>>,
pub formnovalidate: std::option::Option<std::borrow::Cow<'static, str>>,
pub formtarget: std::option::Option<std::borrow::Cow<'static, str>>,
pub height: std::option::Option<std::borrow::Cow<'static, str>>,
pub list: std::option::Option<std::borrow::Cow<'static, str>>,
pub max: std::option::Option<std::borrow::Cow<'static, str>>,
pub maxlength: std::option::Option<std::borrow::Cow<'static, str>>,
pub min: std::option::Option<std::borrow::Cow<'static, str>>,
pub minlength: std::option::Option<std::borrow::Cow<'static, str>>,
pub multiple: std::option::Option<std::borrow::Cow<'static, str>>,
pub name: std::option::Option<std::borrow::Cow<'static, str>>,
pub pattern: std::option::Option<std::borrow::Cow<'static, str>>,
pub placeholder: std::option::Option<std::borrow::Cow<'static, str>>,
pub readonly: std::option::Option<std::borrow::Cow<'static, str>>,
pub required: std::option::Option<std::borrow::Cow<'static, str>>,
pub size: std::option::Option<std::borrow::Cow<'static, str>>,
pub src: std::option::Option<std::borrow::Cow<'static, str>>,
pub step: std::option::Option<std::borrow::Cow<'static, str>>,
pub type_: std::option::Option<std::borrow::Cow<'static, str>>,
pub value: std::option::Option<std::borrow::Cow<'static, str>>,
pub width: std::option::Option<std::borrow::Cow<'static, str>>,
}
impl crate::RenderElement for Input {
fn write_opening_tag<W: std::fmt::Write>(&self, writer: &mut W) -> std::fmt::Result {
write!(writer, "<input")?;
if let Some(field) = self.accept.as_ref() {
write!(writer, r#" accept="{field}""#)?;
}
if let Some(field) = self.alt.as_ref() {
write!(writer, r#" alt="{field}""#)?;
}
if let Some(field) = self.autocomplete.as_ref() {
write!(writer, r#" autocomplete="{field}""#)?;
}
if let Some(field) = self.checked.as_ref() {
write!(writer, r#" checked="{field}""#)?;
}
if let Some(field) = self.dirname.as_ref() {
write!(writer, r#" dirname="{field}""#)?;
}
if let Some(field) = self.disabled.as_ref() {
write!(writer, r#" disabled="{field}""#)?;
}
if let Some(field) = self.form.as_ref() {
write!(writer, r#" form="{field}""#)?;
}
if let Some(field) = self.formaction.as_ref() {
write!(writer, r#" formaction="{field}""#)?;
}
if let Some(field) = self.formenctype.as_ref() {
write!(writer, r#" formenctype="{field}""#)?;
}
if let Some(field) = self.formmethod.as_ref() {
write!(writer, r#" formmethod="{field}""#)?;
}
if let Some(field) = self.formnovalidate.as_ref() {
write!(writer, r#" formnovalidate="{field}""#)?;
}
if let Some(field) = self.formtarget.as_ref() {
write!(writer, r#" formtarget="{field}""#)?;
}
if let Some(field) = self.height.as_ref() {
write!(writer, r#" height="{field}""#)?;
}
if let Some(field) = self.list.as_ref() {
write!(writer, r#" list="{field}""#)?;
}
if let Some(field) = self.max.as_ref() {
write!(writer, r#" max="{field}""#)?;
}
if let Some(field) = self.maxlength.as_ref() {
write!(writer, r#" maxlength="{field}""#)?;
}
if let Some(field) = self.min.as_ref() {
write!(writer, r#" min="{field}""#)?;
}
if let Some(field) = self.minlength.as_ref() {
write!(writer, r#" minlength="{field}""#)?;
}
if let Some(field) = self.multiple.as_ref() {
write!(writer, r#" multiple="{field}""#)?;
}
if let Some(field) = self.name.as_ref() {
write!(writer, r#" name="{field}""#)?;
}
if let Some(field) = self.pattern.as_ref() {
write!(writer, r#" pattern="{field}""#)?;
}
if let Some(field) = self.placeholder.as_ref() {
write!(writer, r#" placeholder="{field}""#)?;
}
if let Some(field) = self.readonly.as_ref() {
write!(writer, r#" readonly="{field}""#)?;
}
if let Some(field) = self.required.as_ref() {
write!(writer, r#" required="{field}""#)?;
}
if let Some(field) = self.size.as_ref() {
write!(writer, r#" size="{field}""#)?;
}
if let Some(field) = self.src.as_ref() {
write!(writer, r#" src="{field}""#)?;
}
if let Some(field) = self.step.as_ref() {
write!(writer, r#" step="{field}""#)?;
}
if let Some(field) = self.type_.as_ref() {
write!(writer, r#" type="{field}""#)?;
}
if let Some(field) = self.value.as_ref() {
write!(writer, r#" value="{field}""#)?;
}
if let Some(field) = self.width.as_ref() {
write!(writer, r#" width="{field}""#)?;
}
write!(writer, "{}", self.global_attrs)?;
write!(writer, ">")?;
Ok(())
}
#[allow(unused_variables)]
fn write_closing_tag<W: std::fmt::Write>(&self, writer: &mut W) -> std::fmt::Result {
Ok(())
}
}
impl std::fmt::Display for Input {
fn fmt(&self, writer: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
use crate::RenderElement;
self.write_opening_tag(writer)?;
self.write_closing_tag(writer)?;
Ok(())
}
}
impl std::ops::Deref for Input {
type Target = crate::GlobalAttributes;
fn deref(&self) -> &Self::Target {
&self.global_attrs
}
}
impl std::ops::DerefMut for Input {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.global_attrs
}
}