Skip to content

v1.0.0

Latest
Compare
Choose a tag to compare
@miguelgargallo miguelgargallo released this 05 Dec 17:15
4f3c2be

v1.0.0 contains:

Full Changelog: https://github.com/miguelgargallo/Prueba-Tecnica_Front-end/commits/v1.0.0

API de usuarios de GitHub

Este contenido puede ser actualizado siempre dentro del plazo de entrega

Concepto Screenshot
Input Input
Input mas selector Input mas selector
Componente de error Componente de error
10 resultados de búsqueda con gráfica 10 resultados de búsqueda con gráfica
Input Tarjeta con regalo

Instalación

  • ✅ Se requiere token
  • ✅ Se debe cp a .env.example .env y luego añadir su token para el acceso de la API, por temas de limitaciones de github, lo mejor es usarlo, actualmente esta tarea se puede ver en vivo en unow.vercel.app

Comprobar versiones

Para comprobar la versión de Node.js y npm, abra la línea de comandos y ejecute node -v && npm -v. Esto verificará que tiene las versiones correctas de Node.js y npm. Si no está en la versión LTS (Long Term Support), use nvm install 20 para obtener la versión 20.10.0.

Creación de app con framework React

A la hora de instalar y configurar Vite para React, utilice npm create vite@latest seguido de pruebareactunow para crear un nuevo proyecto de React con Vite. Luego, navegue al directorio del proyecto con cd pruebareactunow.
Screenshot demo de seleccion de framework: React

  • Se hace con React
  • React está deprecado por el propio equipo de React, pero se puede usar de forma segura a través de npm create vite@latest y seleccionando React.
  • Al no mencionar si JavaScript o TypeScript, se hace con TypeScript
  • Se crea la branch git checkout -b "miguelgargallo"`` y se hace un commit con el nombre de la branch .
  • Se crea el repositorio en GitHub con el nombre pruebareactunow..
    Por motivos de privacidad, y no mostrar mi progreso, se crea el repositorio en local y luego se copia todo en el repositorio de GitHub que toca. No hay problema en dar permisos a este una vez terminado la prueba.

Instalación de dependencias

Opcionalmente, puede instalar pnpm, en este caso se hará globalmente con npm install -g pnpm. Luego, en el directorio del proyecto, ejecute pnpm install para instalar las dependencias del proyecto.

node -v && npm -v

Debemos estar en la LTS, sino es así, nvm install 20, y tendremos la 20.10.0 a fecha de semana 3 de Diciembre de 2023.

Procedemos a instalar R

npm create vite@latest
pruebareactunow
cd pruebareactunow
npm install -g pnpm
pnpm install
pnpm add sass

(Porque pnpm)[https://pnpm.io/pnpm-vs-npm]

RRRR

Requerimientos

Crear una aplicación React para obtener y mostrar una lista de usuarios de GitHub, incluyendo detalles como el nombre de usuario, ID, y más. Incorporar validadores de entrada, un gráfico de barras para mostrar seguidores y un sistema para gestionar errores.

Recursos

Usar CSS Grid/Flexbox para el diseño, librerías de iconos como Font Awesome o Glyphicons, y cualquier librería de gráficos para el gráfico de barras.

Razonar

La aplicación debe mostrar eficientemente los datos de los usuarios de GitHub, manejar la entrada de datos correctamente y presentar la información de manera clara y atractiva.

Respuestas

La aplicación final debe cumplir con los requisitos funcionales especificados, ser eficiente en términos de código y algoritmos, y reflejar la creatividad y las buenas prácticas de programación.

¿Por qué usar Vite?

Vite se utiliza por su eficiencia en el desarrollo y la producción. Ofrece un servidor de desarrollo ultrarrápido gracias a su enfoque en el módulo nativo de ES y una construcción de producción optimizada. Además, Vite incluye configuraciones de linting avanzadas en su tsconfig.json que mejoran la calidad del código y ayudan a evitar errores comunes.

Configuración de Linting en tsconfig.json

Se configura el linter para garantizar la calidad del código. Las opciones clave incluyen:

  • strict: Habilita todas las opciones estrictas de tipo.
  • noUnusedLocals y noUnusedParameters: Ayudan a mantener el código limpio y libre de variables y parámetros no utilizados.
  • noFallthroughCasesInSwitch: Previene casos no intencionados en declaraciones de switch.

Uso del Plugin de React en Vite

Para integrar React en Vite, se utiliza el plugin @vitejs/plugin-react-swc. Este plugin facilita el desarrollo con React y mejora el rendimiento.

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [react()],
})

Este enfoque proporciona una experiencia de desarrollo más fluida y rápida, ideal para proyectos con limitaciones de tiempo.

Pasos

La idea es reutilizar código del setup del proyecto.
Screenshot del setup

Limpiamos un poco los scss, y el punto de entrada un poco también. Y mas adelante, SEO con server side rendering.

De este modo reutilizamos partes y limpiamos el código.

import './App.scss'

function App() {
  return (
    <>
      <main>
        <h1>Miguel Gargallo - Unow</h1>
      </main>
    </>
  )
}

export default App

Comenzamos con pensar la aplicación y la semántica del html, voy a imaginarme como voy a crear la aplicación.

Para planificar la aplicación, considere la estructura y la semántica del HTML teniendo en cuenta los requerimientos del ejercicio. Algunos puntos clave a tener en cuenta son:

Campo de Entrada y Botón: Necesitará un formulario con un campo de entrada para buscar usuarios y un botón para enviar la búsqueda.

Listado de Usuarios: Una sección para mostrar los resultados de la búsqueda, idealmente utilizando tarjetas o una lista para cada usuario con su nombre de usuario e ID.

Enlaces a Perfiles de Usuario: Cada usuario listado deberá ser un enlace que lleve a una ruta con el 'user.login' como parámetro.

Componente de Detalles del Usuario: Crear un componente para mostrar detalles de un usuario específico, incluyendo su imagen y otra información elegida.

Validadores: Añadir validaciones para la entrada del usuario, asegurando un mínimo de 4 caracteres y restringiendo la búsqueda de ciertas palabras.

Gráfico de Barras: Incorporar un gráfico de barras para mostrar el número de seguidores de los usuarios.

Gestión de Errores: Implementar un sistema para mostrar mensajes de error en la aplicación.

Acerca del SCSS

He optimizado los archivos SCSS en los archivos, App e Index en formato SCSS, para que sea más fácil de leer y mantener. Usando los archivos de variables para los colores y fuentes con estilos reutilizables.