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_param_eq, rumtk_web_get_text_item, rumtk_web_render_html,
RUMWebTemplate,
};
#[derive(RUMWebTemplate, Debug, Clone)]
#[template(
source = "
{% if custom_css_enabled %}
<link href='/static/components/logo.css' rel='stylesheet'>
{% endif %}
<div class='centered logo'>
{% if diamond %}
<img src='/static/img/logo.webp' alt='Webp Logo' class='logo-{{ css_class }}' fetchpriority='high' />
{% else %}
<img src='/static/img/logo.svg' alt='SVG Logo' fetchpriority='high'/>
{% endif %}
</div>
",
ext = "html"
)]
pub struct Logo {
diamond: bool,
css_class: RUMString,
custom_css_enabled: bool,
}
const DEFAULT_TYPE: &str = "diamond";
pub fn logo(_path_components: URLPath, params: URLParams, state: SharedAppState) -> HTMLResult {
let diamond = rumtk_web_get_param_eq!(params, PARAMS_TYPE, DEFAULT_TYPE, false);
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;
rumtk_web_render_html!(Logo {
diamond,
css_class: RUMString::from(css_class),
custom_css_enabled
})
}