rumtk-web 0.5.3

Web framework part of the RUMTK framework that attempts to simplify and expedite dashboard development in Healthcare.
Documentation
/*
 * rumtk attempts to implement HL7 and medical protocols for interoperability in medicine.
 * This toolkit aims to be reliable, simple, performant, and standards compliant.
 * Copyright (C) 2025  Luis M. Santos, M.D. <lsantos@medicalmasses.com>
 * Copyright (C) 2025  Ethan Dixon
 * Copyright (C) 2025  MedicalMasses L.L.C. <contact@medicalmasses.com>
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 */
use crate::defaults::SECTION_ALT;
use crate::utils::defaults::{
    DEFAULT_CONTACT_ITEM, DEFAULT_TEXT_ITEM, PARAMS_CSS_CLASS, PARAMS_TYPE, SECTION_CONTACT,
};
use crate::utils::types::{HTMLResult, RUMString, SharedAppState, TextMap, URLParams, URLPath};
use crate::utils::DEFAULT_TEXTMAP;
use crate::{
    rumtk_web_get_config, rumtk_web_get_config_string, rumtk_web_get_text_item, rumtk_web_render_html,
    RUMWebTemplate, DEFAULT_TEXT,
};

#[derive(RUMWebTemplate, Debug)]
#[template(
    source = "
        {% if custom_css_enabled %}
            <link href='/static/components/contact_card.css' rel='stylesheet'>
        {% endif %}
        <div class='f14 centered'>
            <div class='f18 contact-card-{{ css_class }}-container'>
                {% for (details_typ, details_data) in contact_lines %}
                    {% if details_typ == &\"phrase\" && !details_data.is_empty() %}
                    <p class='italics f18' >
                        '{{ details_data }}'
                    </p>
                    {% else if details_typ == &\"email\" && !details_data.is_empty() %}
                    <p>
                        <a  class=' f14 no-text-color' href='mailto:{{ details_data }}'>{{ details_data }}</a>
                    </p>
                    {% else if details_typ == &\"phone\" && !details_data.is_empty() %}
                    <p>
                        <a  class='f14 no-text-color' href='tel:{{ details_data }}'>{{ details_data }}</a>
                    </p>
                    {% else if details_typ == &\"portrait\" && !details_data.is_empty() %}
                    <img src='{{ details_data }}' alt='{{ alt }}' class='contact-card-{{ css_class }}-portrait' fetchpriority='low' />
                    {% else if !details_data.is_empty() %}
                    <p class='f14' >
                        {{ details_data }}
                    </p>
                    {% endif %}
                {% endfor %}
            </div>
        </div>
    ",
    ext = "html"
)]
pub struct ContactCard<'a> {
    alt: &'a str,
    contact_lines: &'a TextMap,
    css_class: RUMString,
    custom_css_enabled: bool,
}

pub fn contact_card(
    _path_components: URLPath,
    params: URLParams,
    state: SharedAppState,
) -> HTMLResult {
    let typ = rumtk_web_get_text_item!(params, PARAMS_TYPE, DEFAULT_CONTACT_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 text_conf = rumtk_web_get_config_string!(state, SECTION_CONTACT);
    let contact_lines = rumtk_web_get_text_item!(&text_conf, typ, &DEFAULT_TEXTMAP());
    let alt_text = rumtk_web_get_text_item!(&contact_lines, SECTION_ALT, &DEFAULT_TEXT());

    rumtk_web_render_html!(ContactCard {
        alt: &alt_text,
        contact_lines,
        css_class: RUMString::from(css_class),
        custom_css_enabled
    })
}