use rdxl::xrender;
use crate::*;
use std::time::SystemTime;
fn unique_identifier(prefix: &str) -> String {
let e = SystemTime::now().duration_since(SystemTime::UNIX_EPOCH);
if let Ok(e) = e {
format!("_uid_{}_{}_{}", prefix, e.as_secs(), e.subsec_nanos())
} else {
format!("_uid_{}_error", prefix)
}
}
fn show_hide_js(class_name:&str, id_name:&str) -> String {
format!(r#"'
let cs = document.getElementsByClassName("{}");
for(var ci=0; ci<cs.length; ci++){{ cs[ci].style.display = "none"; }}
document.getElementById("{}").style.display = "initial";'"#, class_name, id_name)
}
xrender!(InputButton, <input type="button" name={{ format!("'{}'",self.name) }} value={{ format!("'{}'",self.name) }}/>);
xrender!(InputCheckbox, <input type="checkbox" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputButtonGroup, <span style="background-color:#CCCCCC;">
{{ for bc in self.children.iter() {{
{{ let InputButtonGroupChildren::InputButton(b) = bc; }}
{{ b }}
}} }}
</span>);
xrender!(InputRadio, <span style="background-color:#CCCCCC;">
{{ for rc in self.children.iter() {{
{{ let InputRadioChildren::InputRadioOption(r) = rc; }}
<input type="radio" name={{ format!(r#""{}""#, self.name) }} value={{ format!(r#""{}""#, r.value) }}/>
}} }}
</span>);
xrender!(InputText, <input type="text" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputEmail, <input type="email" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputSearch, <input type="search" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputPassword, <input type="password" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputNumber, <input type="number" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputTelephoneNumber, <input type="tel" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputUrl, <input type="url" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputRange, <input type="range" name={{ format!("'{}'",self.name) }} min={{self.min}} max={{self.max}}/>);
xrender!(InputColor, <input type="color" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputDate, <input type="date" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputDatetime, <input type="datetime-local" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputMonth, <input type="month" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputWeek, <input type="week" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputTime, <input type="time" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputFile, <input type="file" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputImage, <input type="image" name={{ format!("'{}'",self.name) }}/>);
xrender!(InputSubmit, <input type="submit"/>);
xrender!(ProgressBar, <div style="position:relative; height:30px; width:300px; background-color:#CCCCCC;">
<div style={{ format!("\"position:absolute; top:0; left:0; height:30px; width:{}px; background-color:#999999;\"", self.numerator*300/self.denominator ) }}></div>
<div style="line-height:30px; width:300px; text-align:center; font-family:sans;">{{ self.numerator }} / {{ self.denominator }} {{ self.unit }}</div>
</div>);
xrender!(IndexTabs, <div>
{{ let tabs_classname = unique_identifier("index_tabs"); }}
{{ for (tabi,tab) in self.children.iter().enumerate() {{
{{ let IndexTabsChildren::IndexTab(tab) = tab }}
{{ let tab_id = format!("{}_{}", tabs_classname, tabi); }}
<div style="float:left; margin-left:5px; padding:4px; cursor:pointer; background-color:#CCCCCC;"
onclick={{ show_hide_js(&tabs_classname, &tab_id) }}>
{{ tab.name }}
</div>
}} }}
<div style="clear:both;"></div>
{{ for (tabi,tab) in self.children.iter().enumerate() {{
{{ let tab_id = format!("{}_{}", tabs_classname, tabi); }}
{{ let IndexTabsChildren::IndexTab(tab) = tab; }}
<div id={{tab_id}} class={{tabs_classname}} style={{ if tabi==0 {{"''"}} else {{"'display:none'"}} }}>
{{ for tc in tab.children.iter() {{
{{ let IndexTabChildren::Display(d) = tc; }}
{{ d }}
}} }}
</div>
}} }}
</div>);
xrender!(ContactList, <ul>
{{ for ContactListChildren::Contact(c) in self.children.iter() {{ <li>{{c}}</li> }} }}
</ul>);
xrender!(Contact, <span>
<b>{{ self.person.name.name }}</b>:
{{ for ch in self.children.iter() {{
{{ if let ContactChildren::Title(t) = ch {{
{{ t.title }},
}} }}
}} }}
{{ for ch in self.children.iter() {{
{{ if let ContactChildren::Email(e) = ch {{
e-mail: {{ e.email }}
}} }}
}} }}
{{ for ch in self.children.iter() {{
{{ if let ContactChildren::PhoneNumber(p) = ch {{
phone: {{ p.number }}
}} }}
}} }}
{{ for ch in self.children.iter() {{
{{ if let ContactChildren::Website(w) = ch {{
website: {{ w.url }}
}} }}
}} }}
</span>);