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!