CursosEmpresasBlogLiveConfPrecios

¡Prueba de fuego!

Clase 13 de 15 • Curso de Creación de Librerías UI para React

Contenido del curso

Introducción al curso

  • 1
    Bienvenida al curso

    Bienvenida al curso

    02:34 min
  • 2
    ¿Cuando construir nuestra propia Librería UI?

    ¿Cuando construir nuestra propia Librería UI?

    04:28 min

Pre-coding

  • 3
    Definir requerimientos

    Definir requerimientos

    16:38 min

Desarollo components

  • 4
    Button component

    Button component

    22:02 min
  • 5
    Button test

    Button test

    09:55 min
  • 6
    Container component

    Container component

    23:06 min
  • 7
    Container test

    Container test

    07:45 min
  • 8
    Media img component

    Media img component

    12:12 min
  • 9
    Media img test

    Media img test

    08:05 min
  • 10
    Text component

    Text component

    20:25 min
  • 11
    Text test

    Text test

    07:09 min

Publicación

  • 12
    Publicación de librería en npm

    Publicación de librería en npm

    11:25 min

Prueba de fuego

  • 13
    ¡Prueba de fuego!

    ¡Prueba de fuego!

    Viendo ahora

Despedida

  • 14
    Resumen del curso

    Resumen del curso

    02:29 min
  • 15
    Despedida

    Despedida

    01:46 min
Tomar examen

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads

      Comentarios

      Rubén Hernández Hernández

      Rubén Hernández Hernández

      student•
      hace 4 años
        Gilbert Ardila

        Gilbert Ardila

        student•
        hace 3 años
      fabian.quintanilla03

      fabian.quintanilla03

      student•
      hace 3 años
        Daniel Rodrigo Valdivieso Merino

        Daniel Rodrigo Valdivieso Merino

        teacher•
        hace 3 años
      Cesidio Antonio Di Benedetto Carri

      Cesidio Antonio Di Benedetto Carri

      student•
      hace 3 años
        Cesidio Antonio Di Benedetto Carri

        Cesidio Antonio Di Benedetto Carri

        student•
        hace 3 años
      Diego Vergara

      Diego Vergara

      student•
      hace 4 años
      Luis Eduardo Martínez Espinoza

      Luis Eduardo Martínez Espinoza

      student•
      hace 4 años
      Juan Camilo Lentino Villalba

      Juan Camilo Lentino Villalba

      student•
      hace 4 años

      En mi caso no me funcionaba porque faltaba la dependencia de prop-types(hice mi proyecto con Vite). La solución fué poner prop-types como dependencia normal (no de desarrollo) en la librería:

      "dependencies": { "@emotion/css": "^11.9.0", "prop-types": "^15.8.1" }, "devDependencies": { ... }

      bueno y como la hiciste con vite ¿tuviste que hacer toda la configuración del inicio o no? me nació esa pregunta desde el principio

      que pasa si quiero separar las cosas por carpetas, es decir supongamos que en la misma carpeta Buttons tengo dos componentes, Button y ButtonFlat y quiero poder importarlos de la siguiente manera

      import {ButtonFlat} from 'basico-creacion-libreriasui/Button'

      Como tendrian que estar exportando mis archivos index los componentes ?

      Depende, de si se repite mucho código.

      En programación tenemos en cuenta el principio DRY 'Don't Repeat Yourself'

      Si vez que el código del componente se repite, así sea lógica, layout o estilos lo mejor posiblemente sea hacer un componente que por props sea modificado.

      Ahora, si vez que te tardará mucho tiempo hacer un componente robusto y agnostico que se modifique por props tal vez es mejor hacer dos componentes.

      Ten encuenta que debes tomar las desiciones de acuerdo a lo que crees que tu equipo necesita, velocidad o altísima calidad en los componentes.

      Saludos 💚

      Me manda error como si la libreria no existiria

      ERROR in ./node_modules/green-design/src/index.js 1:0-45 Module not found: Error: Can't resolve './Button' in 'D:\cursos\material-UI-React\node_modules\green-design\src'

      No me acordaba que habia creado una carpeta extra para separar componentes simples y complejos XD... corregi la ruta y funciono!

      Yupi!!!

      Screenshot from 2022-09-23 13-14-44.png

      Ascribe la función para el botón before de esta manera para evitar que el ID sea menor a 1

      const handleDecrease = () => { idChar > 1 ? setIdChar(idChar - 1) : setIdChar(1) }

      yo le añadí 2 nuevos estados

      const [back, setBack] = useState(true) const [next, setNext] = useState(false)

      y se los di como valor de la propiedad disabled de los botones, y estos mismos estados los utilice como sentencia para un operador ternario para controlar el valor de la propiedad bgColorHover

      <Button disabled={back} width="150px" height="40px" bgColorHover={back ? '' : 'red'} onClick={handleDecrement}>{'<Back'}</Button> <Button disabled={next} width="150px" height="40px" bgColorHover={next ? '' : 'green'} onClick={handleIncrement}>{'Next>'}</Button>

      todo esto con el fin de limitar el valor de numCharacter, que nunca pueda ser menor a 1 o mayor a 826 (numero de personajes de la API), la interfaz no lo permitirá, y para eso utilice una función para controlar los estados de back y next

      const handleDisabled = ()=> { if (numCharacter === 1){ setBack(true) } else { setBack(false) } if (numCharacter === 826){ setNext(true) } else { setNext(false) } }

      esta función se ejecutara cada vez que el valor de numCharacter cambie

      useEffect(()=> { gettinCharacter(numCharacter) handleDisabled() }, [numCharacter])

      el código completo quedaría de esta manera src/App.js:

      import { useEffect, useState } from 'react'; import { Button, ContainerFlex, MediaImg, Text } from 'curso-creacion-librerias-ui' import { gettinData } from './services'; function App() { const [back, setBack] = useState(true) const [next, setNext] = useState(false) const [numCharacter, setNumCharacter] = useState(1) const [characters, setCharacters] = useState({}) const gettinCharacter = async (character)=> { const response = await gettinData(character) setCharacters(response) console.log(response) } useEffect(()=> { gettinCharacter(numCharacter) handleDisabled() }, [numCharacter]) const handleDisabled = ()=> { if (numCharacter === 1){ setBack(true) } else { setBack(false) } if (numCharacter === 826){ setNext(true) } else { setNext(false) } } const handleIncrement = ()=> { setNumCharacter(numCharacter+1) } const handleDecrement = ()=> { setNumCharacter(numCharacter-1) } return ( <div className="App"> <ContainerFlex flexDirection="column" justifyContent="space-evenly" alignItems="center" height="100vh" gap="8px" > <MediaImg src={characters.image || ''} width="200px" height="200px" alt={characters.name || ''} /> <Text component="h3" fontSize="18px" lineHeight="10px">{characters.name}</Text> <Text component="p" fontSize="18px" lineHeight="10px">{characters.id}</Text> <Text component="p" fontSize="18px" lineHeight="10px">{characters.species}</Text> <Text component="p" fontSize="18px" lineHeight="10px">{characters.status}</Text> <ContainerFlex flexDirection="row" justifyContent="center" alignItems="center" gap="8px" > <Button disabled={back} width="150px" height="40px" bgColorHover={back ? '' : 'red'} onClick={handleDecrement}>{'<Back'}</Button> <Button disabled={next} width="150px" height="40px" bgColorHover={next ? '' : 'green'} onClick={handleIncrement}>{'Next>'}</Button> </ContainerFlex> </ContainerFlex> </div> ); } export default App;

      src/services.js:

      const urlFetch = 'https://rickandmortyapi.com/api/character/' export const gettinData = async (character)=> { const response = await fetch(`${urlFetch}${character}`, { method: 'GET' }) const payload = response.json() return payload }