Saltar a contenido

Leaf

Leaf es un potente lenguaje de plantillas con una sintaxis inspirada en Swift. Puedes usarlo para generar páginas HTML dinámicas para el front-end de un sitio web o generar correos electrónicos enriquecidos para enviar desde una API.

Paquete

El primer paso para usar Leaf es agregarlo como una dependencia en tu proyecto en tu archivo de manifiesto del paquete SPM.

// swift-tools-version:5.9
import PackageDescription

let package = Package(
    name: "MyApp",
    platforms: [
       .macOS(.v10_15)
    ],
    dependencies: [
        /// Cualquier otra dependencia ...
        .package(url: "https://github.com/vapor/leaf.git", from: "4.4.0"),
    ],
    targets: [
        .target(name: "App", dependencies: [
            .product(name: "Leaf", package: "leaf"),
            // Cualquier otra dependencia
        ]),
        // Otros targets
    ]
)

Configuración

Una vez agregado el paquete a tu proyecto, puedes configurar Vapor para usarlo. Esto generalmente se hace en configure.swift.

import Leaf

app.views.use(.leaf)

Esto le indica a Vapor que uses el LeafRenderer cuando llames a req.view en tu código.

Advertencia

Para que Leaf pueda encontrar las plantillas al ejecutar desde Xcode, debes establecer el directorio de trabajo personalizado para tu espacio de trabajo en Xcode.

Caché para Renderizar Páginas

Leaf tiene una caché interna para renderizar páginas. Cuando el entorno de Application está configurado como .development, esa caché está deshabilitada, de modo que los cambios en las plantillas tienen efecto inmediatamente. En .production y todos los demás entornos, la caché está habilitada por defecto. Cualquier cambio realizado en las plantillas no tendrá efecto hasta que se reinicie la aplicación.

Para desactivar la caché de Leaf haz lo siguiente:

app.leaf.cache.isEnabled = false

Advertencia

Si bien deshabilitar la caché es útil para la depuración, no se recomienda para entornos de producción dado que puede afectar significativamente al rendimiento debido a la necesidad de recompilar las plantillas en cada solicitud.

Estructura de Carpetas

Una vez que hayas configurado Leaf, deberás asegurarte de tener una carpeta Views para almacenar tus archivos .leaf. Por defecto, Leaf espera que la carpeta de vistas esté en ./Resources/Views relativo a la raíz de tu proyecto.

También es probable que quieras habilitar el FileMiddleware de Vapor para servir archivos desde tu carpeta /Public si planeas servir archivos Javascript y CSS, por ejemplo.

VaporApp
├── Package.swift
├── Resources
│   ├── Views
│   │   └── hello.leaf
├── Public
│   ├── images (recursos de imágenes)
│   ├── styles (recursos css)
└── Sources
    └── ...

Renderizando una Vista

Ahora que Leaf está configurado, vamos a renderizar tu primera plantilla. Dentro de la carpeta Resources/Views, crea un nuevo archivo llamado hello.leaf con el siguiente contenido:

Hello, #(name)!

Consejo

Si estás usando VSCode como tu editor de código, te recomendamos instalar la extensión de Leaf para habilitar el resaltado de sintaxis: Leaf HTML.

Luego, registra una ruta (generalmente en routes.swift o en un controlador) para renderizar la vista.

app.get("hello") { req -> EventLoopFuture<View> in
    return req.view.render("hello", ["name": "Leaf"])
}

// o

app.get("hello") { req async throws -> View in
    return try await req.view.render("hello", ["name": "Leaf"])
}

Esto utiliza la propiedad genérica view en Request en lugar de llamar directamente a Leaf, permitiéndote cambiar a otro renderizador en tus pruebas.

Abre tu navegador y visita /hello. Deberías ver Hello, Leaf!. ¡Felicidades por renderizar tu primera vista Leaf!