use crate::utils::defaults::{DEFAULT_TEXT_ITEM, PARAMS_CSS_CLASS, PARAMS_TYPE};
use crate::utils::types::{HTMLResult, RUMString, SharedAppState, URLParams, URLPath};
use crate::{
rumtk_web_get_config, rumtk_web_get_text_item, rumtk_web_render_component, rumtk_web_render_html,
RUMWebTemplate,
};
#[derive(RUMWebTemplate, Debug, Clone)]
#[template(
source = "
{% if custom_css_enabled %}
<link href='/static/components/text_card.css' rel='stylesheet'>
{% endif %}
<div class='centered text-card-{{css_class}}'>
{{formatted_label|safe}}
</div>
",
ext = "html"
)]
pub struct TextCard {
formatted_label: RUMString,
css_class: RUMString,
custom_css_enabled: bool,
}
pub fn text_card(
_path_components: URLPath,
params: URLParams,
state: SharedAppState,
) -> HTMLResult {
let typ = rumtk_web_get_text_item!(params, PARAMS_TYPE, DEFAULT_TEXT_ITEM);
let css_class = rumtk_web_get_text_item!(params, PARAMS_CSS_CLASS, DEFAULT_TEXT_ITEM);
let custom_css_enabled = rumtk_web_get_config!(state).custom_css;
let formatted_label = rumtk_web_render_component!("formatted_label", [("type", typ)], state)?.to_rumstring();
rumtk_web_render_html!(TextCard {
formatted_label,
css_class: RUMString::from(css_class),
custom_css_enabled
})
}