use crate::defaults::{DEFAULT_NO_TEXT, PARAMS_ID};
use crate::utils::defaults::{DEFAULT_TEXT_ITEM, PARAMS_CSS_CLASS, PARAMS_TYPE, SECTION_SERVICES};
use crate::utils::types::{HTMLResult, SharedAppState, TextMap, URLParams, URLPath};
use crate::{
rumtk_web_get_config, rumtk_web_get_config_section, rumtk_web_get_text_item, rumtk_web_modify_state,
rumtk_web_render_html, rumtk_web_set_config, AppState, RUMWebTemplate,
};
use rumtk_core::strings::RUMStringConversions;
#[derive(RUMWebTemplate, Debug, Clone)]
#[template(
source = "
{% if custom_css_enabled %}
<link href='/static/components/list.css' rel='stylesheet'>
{% endif %}
<div class='item-{{css_class}}-container'>
{% for (item_name, item_description) in items %}
<div>
<details>
<summary class='f16 item-{{css_class}}-title'>
{{ item_name.to_uppercase() }}
</summary>
<pre class='item-{{css_class}}-details'>
{{ item_description }}
</pre>
</details>
</div>
{% endfor %}
</div>
",
ext = "html"
)]
pub struct List<'a> {
items: TextMap,
css_class: &'a str,
custom_css_enabled: bool,
}
pub fn list(_path_components: URLPath, params: URLParams, state: SharedAppState) -> HTMLResult {
let typ = rumtk_web_get_text_item!(params, PARAMS_TYPE, SECTION_SERVICES);
let clipboard_id = rumtk_web_get_text_item!(params, PARAMS_ID, DEFAULT_NO_TEXT);
let css_class = rumtk_web_get_text_item!(params, PARAMS_CSS_CLASS, DEFAULT_TEXT_ITEM);
let item_list = rumtk_web_modify_state!(state).pop_clipboard(&clipboard_id.to_rumstring());
let items = match item_list {
Some(items) => items,
None => rumtk_web_get_config_section!(state, typ),
};
let custom_css_enabled = rumtk_web_get_config!(state).custom_css;
rumtk_web_render_html!(List {
items,
css_class,
custom_css_enabled
})
}