gumbo-lib 0.1.6

Best of the best rust projects all mixed together into a website framework
Documentation
use actix_web::HttpResponse;
use yew::html::BaseComponent;
use yew::ServerRenderer;

/// Returns the web facing path to a resource in your application
pub fn app_path(src: impl Into<String>) -> String {
    let src: String = src.into();
    if let Some(tail) = src.strip_prefix("/") {
        let root = crate::app_root();
        return format!("{root}{tail}");
    }
    src
}

/// Render a Yew view to send out in an Actix Response
pub async fn render<V, VM, E>(args: VM) -> Result<HttpResponse, E>
where
    V: BaseComponent,
    V: BaseComponent<Properties = VM>,
    VM: Send + 'static,
{
    let renderer = ServerRenderer::<V>::with_props(|| args);
    let html = renderer.render().await;
    // add the doctype markup. Yew doesn't like to render this.
    let html = format!("<!DOCTYPE html>\n{html}");
    Ok(HttpResponse::Ok()
        .content_type("text/html; charset=utf-8")
        .body(html))
}

/// Render a Yew view to send out in an Actix Response for a Turbo Stream
pub async fn render_turbo_stream<V, VM, E>(args: VM) -> Result<HttpResponse, E>
where
    V: BaseComponent,
    V: BaseComponent<Properties = VM>,
    VM: Send + 'static,
{
    let renderer = ServerRenderer::<V>::with_props(|| args);
    let html = renderer.render().await;
    Ok(HttpResponse::Ok()
        .content_type("text/vnd.turbo-stream.html")
        .body(html))
}

/// Render a Yew view to send out in an Actix Response
/// Used when a form is not valid
pub fn redirect<E>(path: impl Into<String>) -> Result<HttpResponse, E> {
    let path: String = app_path(path);
    Ok(HttpResponse::SeeOther()
        .insert_header(("Location", path))
        .finish())
}