Vista para extraer datos de cohetes desde SpaceX API 馃崑

joseamayadev

Jos茅 Antonio Fern谩ndez

Posted on August 20, 2021

Vista para extraer datos de cohetes desde SpaceX API 馃崑

Imagen de portada

Hablemos r谩pidamente sobre como hacer renderizado desde el cliente con Literal Strings (ES6).

No necesitas manipular un Shadow Dom, o crear custom elements, ni tampoco templates con todas tus funcionalidades porque puedes implementar o inyectar c贸digo Javascript directamente desde el cliente y pasarlo como parte del contenido HTML de un elemento contenedor con el famoso innerHTML.

  • El famoso innerHTML:
        contenedorCardsData.innerHTML += `
                            <div class="contenedorCardsItems">
                                <h4>${element.serial}</h4>
                                <div class="contenedorStatus">
                                    <span class="blue">${element.type}</span>
                                    <span class="yellow">${element.status}</span>
                                </div>

                                <div class="contenedorTextos">
                                    <p class="descripcion">${element.last_update}</p>
                                    <p class="fechaLanzamiento">Fecha de Lanzamiento</p>
                                    <p class="fechaLanzamientoContent">${element.original_launch}</p>
                                </div>
                            </div>
                            `;
    } else {

        // Pasar c贸digo para mostrar advertencia de que no existen resultados

    }
}
Enter fullscreen mode Exit fullscreen mode

Siendo este un desarrollo que me tom贸 mas o menos 15 min crearlo, tiene muchas cosas que mejorar por lo que puedes agrear tus propias mejoras, puedes agregar filtros, de hecho el bot贸n del filtro esta listado en la UI solo debes agregarle funcionalidad y practicar ya que el c贸digo para pasar peticiones fetch lo tienes ac谩:

async function busqueda() {
    var categorie = document.querySelector('#categoria').value;
    var spacexApi = await fetch(`https://api.spacexdata.com/v4/${categorie}`);
    return spacexApi;
}
Enter fullscreen mode Exit fullscreen mode

Tres lineas de c贸digo que te permiten obtener la respuesta y poder manejarla como promesa para poder hacer con ella lo que quieras.

Veamos como se ve el dise帽o final 馃崑

Dashboard UI SpaceX

Los elementos amarrillos tienen una peque帽a animaci贸n de loading, abajo ver谩s el c贸digo.



馃崑 Solo se basa en un par de parametros que pasas a trav茅s de Fetch



Como siempre, trato de dejar el c贸digo de la forma mas entendible posible para que puedas reutilizar los estilos en cualquiera de tus frameworks favoritos, finalmente cuando envias la petici贸n a trav茅s de fetch puedes manejar directamente esa respuesta, gracias a que el endpoint de SpaceX API te genera el resultado en base al query que estas haciendo y sin usar n铆 una sola clase.



Dashboard Results Space X

驴Conocimiento importantes para el desarrollo?

  • fetch API
:root {
    --main-bg-color: #0E0E0E;
    --secondary-bg-color: #161616;
    --blue-color: #4E54FF;
    --yellow-color: #F4E236;
    --bg-cards: rgba(255, 255, 255, 0.103);
}
}
Enter fullscreen mode Exit fullscreen mode
  • CSS ( Grid / Flex / Keyframes )
header {
    height: 200px;
    width: 100%;
    display: grid;
    grid-template-columns: 20% 30% 20% 15% 15%;
    grid-template-rows: 100px;
}

Enter fullscreen mode Exit fullscreen mode
  • CSS / Animaci贸n previa a la b煤squeda
.loading::before {
    content: "";
    width: 40px;
    height: 100%;
    background: linear-gradient(96.4deg, rgba(255, 255, 255, 0) 4.54%, rgba(255, 255, 255, 0.265283) 57.15%, rgba(255, 255, 255, 0) 94.26%);
    position: absolute;
    opacity: .4;
    animation: move 1s infinite;
}

//el keyframe
@keyframes move {
    0% {
        transform: translateX(0px) rotate(0deg);
    }
    50% {
        transform: translateX(200px) rotate(20deg);
    }
    100% {
        transform: translateX(0px) rotate(0deg);
    }
}

Enter fullscreen mode Exit fullscreen mode
  • CSS / Estilizaci贸n de la lista
.listaSeleccion {
    display: flex;
    justify-content: center;
    align-items: center;
}

.listaSeleccion select {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100px;
    background-color: transparent;
    border: none;
    outline: none;
    font-family: Montserrat;
    font-weight: 500;
    color: var(--main-yellow);
}

.listaSeleccion select * {
    background-color: var(--main-blue);
    border: none;
    box-shadow: none;
}

.listaSeleccion select>option {
    background-color: var(--main-blue);
    border: none;
    box-shadow: none;
    color: var(--main-yellow);
}


Enter fullscreen mode Exit fullscreen mode
  • Javascript / Manejador de eventos principal

search.addEventListener('click', function(e) {
    let select = categorie.value;
    let string = txtSearch.value;
    busqueda()
        .then(data => { return data.json() })
        .then(res => {
            // console.log(res);
            contenedorCardsData.innerHTML = "";
            if (select == "capsules") {
                res.forEach(element => {
                    busquedaCapsules(element, string);
                })
            } else if (select == "history") {
                res.forEach(element => {
                    buscarHistory(element, string);
                })
            }

        });


});

Enter fullscreen mode Exit fullscreen mode
  • CSS / Microinteraction para el filtro

.contenedorFilter span {
    width: 25px;
    height: 2px;
    margin: 3px;
    background-color: var(--main-blue);
    transition: .4s;
    cursor: pointer;
}

.contenedorFilter:hover span {
    width: 35px;
}

.contenedorFilter:hover span:nth-child(2) {
    width: 10px;
}

.contenedorFilter span:nth-child(2) {
    width: 15px;
    height: 2px;
    margin: 3px;
    background-color: var(--main-yellow);
}

.contenedorFilter span:nth-child(3) {
    width: 10px;
    height: 2px;
    margin: 3px;
    background-color: var(--main-yellow);
}

.contenedorFilter:hover span:nth-child(3) {
    width: 5px;
}

Enter fullscreen mode Exit fullscreen mode

S铆 no conoces CSS, JS te costar谩 mil veces .

Este c贸digo no ha sido testeado, por lo tanto lo puedes mejorar mil veces mas



Parte importante de tu aprendizaje en web design, es la utilizaci贸n de APIs y manejo del DOM con un enfoque en desarrollo web 2021, evita esmerarte en que tu aplicaci贸n sea compatible con IE, ya tiene una muerte anunciada as铆 que mejorar preparate para adentrarte en del desarrollo mordenos, APIS, Frameworks, Javascript Moderno...

Es el encarga de cambiar la propiedad de display none a block y viceversa, puedes animar la transici贸n del elemento contenedor como pr谩ctica o simplemente dejarlo como est谩 actualmente.

Este es mi correo profesional jose@joseamaya.tech, si me escribes te aseguro que tendr谩s una respuesta.

Atentamente,

Perfil

Jos茅 A. Amaya

Link al repo

Link a la demo

Siguemente en las redes como @syntaxter

馃挅 馃挭 馃檯 馃毄
joseamayadev
Jos茅 Antonio Fern谩ndez

Posted on August 20, 2021

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related