1#[doc(alias = "audio")]
5#[non_exhaustive]
6#[derive(Debug, Clone, PartialEq, Default)]
7pub struct Audio {
8 pub data_map: crate::DataMap,
9 global_attrs: crate::GlobalAttributes,
10 pub src: std::option::Option<std::borrow::Cow<'static, str>>,
12 pub crossorigin: std::option::Option<std::borrow::Cow<'static, str>>,
14 pub preload: std::option::Option<std::borrow::Cow<'static, str>>,
16 pub autoplay: std::option::Option<std::borrow::Cow<'static, str>>,
18 pub loop_: std::option::Option<std::borrow::Cow<'static, str>>,
20 pub muted: std::option::Option<std::borrow::Cow<'static, str>>,
22 pub controls: std::option::Option<std::borrow::Cow<'static, str>>,
24 pub role: std::option::Option<std::borrow::Cow<'static, str>>,
26 pub aria_active_descendant_element: std::option::Option<
28 std::borrow::Cow<'static, str>,
29 >,
30 pub aria_atomic: bool,
32 pub aria_braille_label: std::option::Option<std::borrow::Cow<'static, str>>,
34 pub aria_braille_role_description: std::option::Option<
36 std::borrow::Cow<'static, str>,
37 >,
38 pub aria_busy: bool,
40 pub aria_controls_elements: std::option::Option<std::borrow::Cow<'static, str>>,
42 pub aria_current: std::option::Option<std::borrow::Cow<'static, str>>,
44 pub aria_described_by_elements: std::option::Option<std::borrow::Cow<'static, str>>,
46 pub aria_description: std::option::Option<std::borrow::Cow<'static, str>>,
48 pub aria_details_elements: std::option::Option<std::borrow::Cow<'static, str>>,
50 pub aria_disabled: bool,
52 pub aria_drop_effect: std::option::Option<std::borrow::Cow<'static, str>>,
54 pub aria_error_message_elements: std::option::Option<std::borrow::Cow<'static, str>>,
56 pub aria_expanded: bool,
58 pub aria_flow_to_elements: std::option::Option<std::borrow::Cow<'static, str>>,
60 pub aria_grabbed: bool,
62 pub aria_has_popup: std::option::Option<std::borrow::Cow<'static, str>>,
64 pub aria_hidden: bool,
66 pub aria_invalid: std::option::Option<std::borrow::Cow<'static, str>>,
68 pub aria_key_shortcuts: std::option::Option<std::borrow::Cow<'static, str>>,
70 pub aria_label: std::option::Option<std::borrow::Cow<'static, str>>,
72 pub aria_labelled_by_elements: std::option::Option<std::borrow::Cow<'static, str>>,
74 pub aria_live: std::option::Option<std::borrow::Cow<'static, str>>,
76 pub aria_owns_elements: std::option::Option<std::borrow::Cow<'static, str>>,
78 pub aria_relevant: std::option::Option<std::borrow::Cow<'static, str>>,
80 pub aria_role_description: std::option::Option<std::borrow::Cow<'static, str>>,
82}
83impl crate::RenderElement for Audio {
84 fn write_opening_tag<W: std::fmt::Write>(&self, writer: &mut W) -> std::fmt::Result {
85 write!(writer, "<audio")?;
86 if let Some(field) = self.src.as_ref() {
87 write!(writer, r#" src="{field}""#)?;
88 }
89 if let Some(field) = self.crossorigin.as_ref() {
90 write!(writer, r#" crossorigin="{field}""#)?;
91 }
92 if let Some(field) = self.preload.as_ref() {
93 write!(writer, r#" preload="{field}""#)?;
94 }
95 if let Some(field) = self.autoplay.as_ref() {
96 write!(writer, r#" autoplay="{field}""#)?;
97 }
98 if let Some(field) = self.loop_.as_ref() {
99 write!(writer, r#" loop="{field}""#)?;
100 }
101 if let Some(field) = self.muted.as_ref() {
102 write!(writer, r#" muted="{field}""#)?;
103 }
104 if let Some(field) = self.controls.as_ref() {
105 write!(writer, r#" controls="{field}""#)?;
106 }
107 if let Some(field) = self.role.as_ref() {
108 write!(writer, r#" role="{field}""#)?;
109 }
110 if let Some(field) = self.aria_active_descendant_element.as_ref() {
111 write!(writer, r#" aria-activedescendant="{field}""#)?;
112 }
113 if self.aria_atomic {
114 write!(writer, r#" aria-atomic"#)?;
115 }
116 if let Some(field) = self.aria_braille_label.as_ref() {
117 write!(writer, r#" aria-braillelabel="{field}""#)?;
118 }
119 if let Some(field) = self.aria_braille_role_description.as_ref() {
120 write!(writer, r#" aria-brailleroledescription="{field}""#)?;
121 }
122 if self.aria_busy {
123 write!(writer, r#" aria-busy"#)?;
124 }
125 if let Some(field) = self.aria_controls_elements.as_ref() {
126 write!(writer, r#" aria-controls="{field}""#)?;
127 }
128 if let Some(field) = self.aria_current.as_ref() {
129 write!(writer, r#" aria-current="{field}""#)?;
130 }
131 if let Some(field) = self.aria_described_by_elements.as_ref() {
132 write!(writer, r#" aria-describedby="{field}""#)?;
133 }
134 if let Some(field) = self.aria_description.as_ref() {
135 write!(writer, r#" aria-description="{field}""#)?;
136 }
137 if let Some(field) = self.aria_details_elements.as_ref() {
138 write!(writer, r#" aria-details="{field}""#)?;
139 }
140 if self.aria_disabled {
141 write!(writer, r#" aria-disabled"#)?;
142 }
143 if let Some(field) = self.aria_drop_effect.as_ref() {
144 write!(writer, r#" aria-dropeffect="{field}""#)?;
145 }
146 if let Some(field) = self.aria_error_message_elements.as_ref() {
147 write!(writer, r#" aria-errormessage="{field}""#)?;
148 }
149 if self.aria_expanded {
150 write!(writer, r#" aria-expanded"#)?;
151 }
152 if let Some(field) = self.aria_flow_to_elements.as_ref() {
153 write!(writer, r#" aria-flowto="{field}""#)?;
154 }
155 if self.aria_grabbed {
156 write!(writer, r#" aria-grabbed"#)?;
157 }
158 if let Some(field) = self.aria_has_popup.as_ref() {
159 write!(writer, r#" aria-haspopup="{field}""#)?;
160 }
161 if self.aria_hidden {
162 write!(writer, r#" aria-hidden"#)?;
163 }
164 if let Some(field) = self.aria_invalid.as_ref() {
165 write!(writer, r#" aria-invalid="{field}""#)?;
166 }
167 if let Some(field) = self.aria_key_shortcuts.as_ref() {
168 write!(writer, r#" aria-keyshortcuts="{field}""#)?;
169 }
170 if let Some(field) = self.aria_label.as_ref() {
171 write!(writer, r#" aria-label="{field}""#)?;
172 }
173 if let Some(field) = self.aria_labelled_by_elements.as_ref() {
174 write!(writer, r#" aria-labelledby="{field}""#)?;
175 }
176 if let Some(field) = self.aria_live.as_ref() {
177 write!(writer, r#" aria-live="{field}""#)?;
178 }
179 if let Some(field) = self.aria_owns_elements.as_ref() {
180 write!(writer, r#" aria-owns="{field}""#)?;
181 }
182 if let Some(field) = self.aria_relevant.as_ref() {
183 write!(writer, r#" aria-relevant="{field}""#)?;
184 }
185 if let Some(field) = self.aria_role_description.as_ref() {
186 write!(writer, r#" aria-roledescription="{field}""#)?;
187 }
188 write!(writer, "{}", self.global_attrs)?;
189 write!(writer, "{}", self.data_map)?;
190 write!(writer, ">")?;
191 Ok(())
192 }
193 #[allow(unused_variables)]
194 fn write_closing_tag<W: std::fmt::Write>(&self, writer: &mut W) -> std::fmt::Result {
195 write!(writer, "</audio>")?;
196 Ok(())
197 }
198}
199impl std::fmt::Display for Audio {
200 fn fmt(&self, writer: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
201 use crate::RenderElement;
202 self.write_opening_tag(writer)?;
203 self.write_closing_tag(writer)?;
204 Ok(())
205 }
206}
207impl std::ops::Deref for Audio {
208 type Target = crate::GlobalAttributes;
209 fn deref(&self) -> &Self::Target {
210 &self.global_attrs
211 }
212}
213impl std::ops::DerefMut for Audio {
214 fn deref_mut(&mut self) -> &mut Self::Target {
215 &mut self.global_attrs
216 }
217}