Mix.install([
{:req, "~> 0.5.6"},
{:kino, "~> 0.14.0"}
])
Revisar los capítulos del Libro Elixir FullStack:
El Proyecto Explora CONICYT de Valoración y Divulgación de la Ciencia y la Tecnología junto al Centro de Gestión Ambiental - FAVET le han solicitado elaborar un buscador de aves de Chile. Para esto le han proporcionado una API Rest que contiene información de las aves.
Utilizando las herramientas Req y Kino debe elaborar un buscador de las aves de Chile.
- Aprender cómo realizar llamadas HTTP GET con Elixir.
- Aprender a usar mapas JSON.
- Obtener información de las aves disponibles al endpoint https://aves.ninjas.cl/api/birds (Usando
Req
). - Solicitar al usuario el ave a buscar mediante un
Kino.Input.text
yKino.Input.read
. - Llamar al endpoint para obtener información específica del ave. Para esto se debe buscar entre los nombres del ave y entregar su URL. Ejemplo: Buscar "Aguilucho Chico" entrega la URL https://aves.ninjas.cl/api/birds/76-buteo-albigula. Para esto se puede usar las funciones
Enum.map
,Enum.filter
yget_in
. Puede apoyarse también en las funciones deString.downcase
,String.split
y la interpolación de strings con#{}
. - Mostrar los datos del ave usando
Kino.Layout.grid
. - Si el ave no se encuentra, mostrar mensaje "Ave No Encontrada".
- Si hay más de un resultado. Mostrar todas las aves encontradas.
El resultado final debe mostrar:
- Nombre en Español (Título)
- Nombre en Latin (Subtítulo)
- Descripción (Si es que existe)
- Imagen principal
Ejemplo
Super Tip
Podemos buscar si un texto existe dentro de un String utilizando in
y split
. Combinado con Enum.filter
se puede filtrar los resultados.
buscar = "Camilo"
|> String.downcase()
palabras = "Hola como estas Camilo"
|> String.downcase()
|> String.split()
# true
buscar in palabras
Super Tip 2
La función get_in
nos permite obtener datos anidados dentro de un mapa.
datos = %{
"name" => %{
"english" => "Mi Nombre"
}
}
get_in(datos, ["name", "english"])
Super Tip
Se puede usar Kino.Layout.grid
y Kino.Markdown.new
para elaborar el resultado.
Más detalles en Intro to Kino.
Enum.map(resultados, fn url_ave ->
Kino.Layout.grid([
Kino.Markdown.new("# Título"),
Kino.Markdown.new("## Subtítulo"),
Kino.Markdown.new("Párrafo"),
Kino.Markdown.new("![Titulo Imagen](URL Imagen)")
], boxed: true)
end)
|> Kino.Layout.grid(columns: 2)