CursosEmpresasBlogLiveConfPrecios

Evaluación del proyecto

Clase 23 de 24 • Curso Fundamental de Material UI con React

Clase anteriorSiguiente clase

Contenido del curso

Introducción al curso

  • 1
    Bienvenida al curso

    Bienvenida al curso

    00:58 min
  • 2
    Presentación proyecto

    Presentación proyecto

    02:23 min
  • 3
    ¿Qué es Material UI?

    ¿Qué es Material UI?

    06:15 min
  • 4
    Preparación de entorno de desarrollo

    Preparación de entorno de desarrollo

    10:59 min

Herramientas dentro de Material UI

  • 5
    Componentes simples

    Componentes simples

    05:40 min
  • 6
    Componentes compuestos

    Componentes compuestos

    03:39 min
  • 7
    Contenedores responsive

    Contenedores responsive

    03:41 min
  • 8
    Material icons

    Material icons

    01:51 min
  • 9
    Bonus

    Bonus

    04:01 min

Construcción del proyecto

  • 10
    Análisis detallado del proyecto

    Análisis detallado del proyecto

    06:14 min
  • 11
    Creando el contenedor y el text field

    Creando el contenedor y el text field

    09:43 min
  • 12
    Colocando los estilos del buscador

    Colocando los estilos del buscador

    10:14 min
  • 13
    Construyendo la lógica del buscador

    Construyendo la lógica del buscador

    16:02 min
  • 14
    Conectando nuestro proyecto a la API de GitHub

    Conectando nuestro proyecto a la API de GitHub

    11:42 min
  • 15
    Conectando el buscador con la API

    Conectando el buscador con la API

    12:12 min
  • 16
    Creando el contenedor y trayendo la imagen de perfil del usuario

    Creando el contenedor y trayendo la imagen de perfil del usuario

    09:47 min
  • 17
    Trayendo la información principal del usuario

    Trayendo la información principal del usuario

    11:00 min
  • 18
    Trayendo la descripción del usuario

    Trayendo la descripción del usuario

    09:05 min
  • 19
    Creando el componente con las estadísticas del usuario

    Creando el componente con las estadísticas del usuario

    08:17 min
  • 20
    Mostrando la localización del usuario

    Mostrando la localización del usuario

    12:46 min
  • 21
    Ajuste de estilos con SX a los componentes de descripción e información principal

    Ajuste de estilos con SX a los componentes de descripción e información principal

    11:17 min
  • 22
    Ajuste de estilos con SX al componente de descripción, PaperInformation y LocationInformation

    Ajuste de estilos con SX al componente de descripción, PaperInformation y LocationInformation

    08:40 min
  • 23
    Evaluación del proyecto

    Evaluación del proyecto

    Viendo ahora

Despedida

  • 24
    Resumen del curso

    Resumen del curso

    01:40 min
  • Tomar el examen del curso
    • Patrick Jhonatan Hernandez Blanco

      Patrick Jhonatan Hernandez Blanco

      student•
      hace 3 años

      Yo realicé el proyecto con la API de Pokemon por si alguien la quiere utilizar es genial!! y les comparto el código de mi proyecto Buscador de Pokemons (Aún falta separar el código en componentes)

      Screenshot 2022-09-02 200123.png
      Screenshot 2022-09-02 200203.png
      Captura de pantalla (272).png
        Francisco Murillo

        Francisco Murillo

        student•
        hace 3 años

        Me gusta!!!🤌🏻

        Jason Francisco Macas Mora

        Jason Francisco Macas Mora

        student•
        hace 3 años

        Muy buen diseño. 🥹

      Fidel Parabacuto

      Fidel Parabacuto

      student•
      hace 3 años

      Para arreglar el formato de fecha

      {new Date(created_at).toLocaleDateString('en-us')}
      Juan Camilo Lentino Villalba

      Juan Camilo Lentino Villalba

      student•
      hace 3 años

      como solución al reto numero dos, lo que yo hice, fue inicialmente desde el componente App pasar por props el estado notFound a el componente Searcher

      const App = ()=> { ... const [notFound, setNotFound] = useState(false) ... return ( <Container sx={containerStyles}> <Searcher inputUser={inputUser} setInputUser={setInputUser} notFound={notFound} /> <UserCard userState={userState} /> </Container> ); }

      recibo en el componente Searcher ese valor

      const Searcher = ({ setInputUser, notFound }) => { ... }

      ubicado en el componente Searcher, envuelvo a el componente Stack con Fragment y al mismo nivel del componente Stack añado un nuevo componente Typography que validara si el valor de notFound el cual fue recibido por props, es true o false y dependiendo su valor mostrara un mensaje de error o un string vacio

      const Searcher = ({ setInputUser, notFound }) => { .... return ( <> <Stack ... </Stack> <Typography color='red' > { notFound ? 'Error: usuario no existe' : '' } </Typography> </> ) }

      cada vez que busquemos un usuario que no exista o este mal escrito, este mensaje aparecerá y igualmente desaparecerá cuando el usuario sea encontrado, ya que toda esta logica que nos permite contralar esto se encuentra en el componente App en su funcion gettinUser

      const App = ()=> { const [inputUser, setInputUser] = useState('octocat'); const [userState, setUserState] = useState(inputUser) const [notFound, setNotFound] = useState(false) const gettinUser = async (user)=> { const userResponse = await getGitHubUser(user) if (userState === 'octocat'){ localStorage.setItem('octocat',JSON.stringify(userResponse)) } if (userResponse.message === 'Not Found'){ const { octocat } = localStorage setInputUser(octocat) setUserState(JSON.parse(octocat)) setNotFound(true) } else { setUserState(userResponse) setNotFound(false) } } useEffect(()=> { gettinUser(inputUser) }, [inputUser]) const containerStyles = { .... } return ( <Container sx={containerStyles}> <Searcher inputUser={inputUser} setInputUser={setInputUser} notFound={notFound} /> <UserCard userState={userState} /> </Container> ); }

      el código completo quedaría de esta forma src/App.jsx:

      import React, { useState, useEffect } from "react"; import { Container } from "@mui/material"; import Searcher from "./components/Searcher"; import { getGitHubUser } from "./services/users"; import UserCard from "./containers/UserCard"; const App = ()=> { const [inputUser, setInputUser] = useState('octocat'); const [userState, setUserState] = useState(inputUser) const [notFound, setNotFound] = useState(false) const gettinUser = async (user)=> { const userResponse = await getGitHubUser(user) if (userState === 'octocat'){ localStorage.setItem('octocat',JSON.stringify(userResponse)) } if (userResponse.message === 'Not Found'){ const { octocat } = localStorage setInputUser(octocat) setUserState(JSON.parse(octocat)) setNotFound(true) } else { setUserState(userResponse) setNotFound(false) } } useEffect(()=> { gettinUser(inputUser) }, [inputUser]) const containerStyles = { background: 'whitesmoke', width: '80vw', height: '500px', borderRadius: '16px', marginTop: '20px', display: 'flex', flexDirection: 'column', alignItems: 'center' } return ( <Container sx={containerStyles}> <Searcher inputUser={inputUser} setInputUser={setInputUser} notFound={notFound} /> <UserCard userState={userState} /> </Container> ); } export default App;

      src/components/Searcher/index.js:

      import React, { useState } from "react"; import { IconButton, Stack, TextField, Typography } from "@mui/material" import SearchIcon from '@mui/icons-material/Search'; const Searcher = ({ setInputUser, notFound }) => { const [valueInput, setValueInput] = useState('') const onSearchValueChange = (event)=> { setValueInput(event.target.value) } const handleSubmit = ()=> { setInputUser(valueInput) } return ( <> <Stack direction='row' sx={{ marginTop: '30px', width: '80%' }} > <TextField id="outlined-basic" label="Github User" placeholder="Octocat" variant="outlined" size="small" value={valueInput} onChange={onSearchValueChange} sx={{ width: '90%', }} /> <IconButton onClick={handleSubmit} size="small" sx={{ left: '-45px' }} > <SearchIcon /> </IconButton> </Stack> <Typography color='red' > { notFound ? 'Error: usuario no existe' : '' } </Typography> </> ) } export default Searcher;
      Benjamín Arturo Pérez García

      Benjamín Arturo Pérez García

      student•
      hace 3 años

      Les comparto mi proyecto terminado con error y responsive. Muy buen curso y el ánimo del profe lo hacía mucho más liviano! Proyecto terminado

      Mauricio Combariza

      Mauricio Combariza

      student•
      hace 3 años

      Listo, ya estoy listo para aprender material ui. Alguna sugerencia??

      Brandon Argel Verdeja Domínguez

      Brandon Argel Verdeja Domínguez

      student•
      hace 2 años

      Al fin terminé el proyecto, me tardé mucho porque implemente para cambiar de tema light/dark con Material UI, entre otras cosas. 😅

      • Proyecto
      • Código
      Sergio Valbuena

      Sergio Valbuena

      student•
      hace 3 años

      La solucion al reto de los errores: usar Vite! . Todo fue tan hermoso con Vite, la primera clase son como 10 segundos y ya está todo listo

    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