CursosEmpresasBlogLiveConfPrecios

Mostrando la localización del usuario

Clase 20 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

    Viendo ahora
  • 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

    02:17 min

Despedida

  • 24
    Resumen del curso

    Resumen del curso

    01:40 min
  • Tomar el examen del curso
    • Fernando Quinteros Gutierrez

      Fernando Quinteros Gutierrez

      student•
      hace 3 años

      🧩 Importaciones de los iconos

      import LocationOnIcon from "@mui/icons-material/LocationOn"; import TwitterIcon from '@mui/icons-material/Twitter'; import LanguageIcon from "@mui/icons-material/Language"; import BusinessIcon from '@mui/icons-material/Business';
        Hernán David Mercado Fernández

        Hernán David Mercado Fernández

        student•
        hace 3 años

        Me has salvado la patría

      Nicolas Agustin Goitia

      Nicolas Agustin Goitia

      student•
      hace 3 años

      Para verificar si existe un Blog, el profe hace blog !== null pero en la respuesta de la API, si no existe el blog devuelve un string vacio. Entonces deberiamos hacer esta validacion: {blog !== "" ? <Typography>{blog}</Typography> : <Typography>Not Available</Typography> }

      Fernando Quinteros Gutierrez

      Fernando Quinteros Gutierrez

      student•
      hace 3 años

      Mi solución para la arroba fue utilizar los template literals de JS

      <Typography> {twitter_username ? `@${twitter_username}` : "Not Avaible"} </Typography>
        Juan Camilo Lentino Villalba

        Juan Camilo Lentino Villalba

        student•
        hace 3 años

        también podemos hacerlo de esta forma :

        <Stack> <TwitterIcon /> { twitter_username !== null ? <Typography>@{twitter_username}</Typography> : <Typography>Not Available</Typography> } </Stack>
      Fidel Parabacuto

      Fidel Parabacuto

      student•
      hace 3 años

      Así se pueden ahorrar el ternario

      <Grid item xs={6}> <Stack> <TwitterIcon /> <Typography>{twitter_username || 'No indica'}</Typography> </Stack> </Grid>
        Roberth Salazar

        Roberth Salazar

        student•
        hace 3 años

        creo que el agregar el arroba te obliga a un ternario, porque si no le agregarías el arroba al 'No indica'

      Erlyn David Ascarate Lachi

      Erlyn David Ascarate Lachi

      student•
      hace 3 años

      @Not Available 😅¿Qué les parece?

      <Typography> @{twitter_username ?? 'Not Available'} </Typography>
      Diana Florez

      Diana Florez

      student•
      hace 3 años

      Dejo el cod

      import React from "react"; import { Grid, Stack, Typography } from "@mui/material"; import LocationOnIcon from '@mui/icons-material/LocationOn'; import TwitterIcon from '@mui/icons-material/Twitter'; import LanguageIcon from '@mui/icons-material/Language'; import BusinessIcon from '@mui/icons-material/Business'; const LocationInformation = (props) => { const { userState } = props const { location, twitter_username, blog, company } = userState; return( <Grid container> <Grid item xs={6}> <Stack> <LocationOnIcon/> <Typography>{location}</Typography> </Stack> </Grid> <Grid item xs={6}> <Stack> <TwitterIcon/> {twitter_username !== null ? <Typography>{twitter_username}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> <Grid item xs={6}> <Stack> <LanguageIcon/> {blog !== null ? <Typography>{blog}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> <Grid item xs={6}> <Stack> <BusinessIcon /> {company !== null ? <Typography>{company}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> </Grid> ) } export default LocationInformation;
      Eduardo Lemus Zavala

      Eduardo Lemus Zavala

      student•
      hace 3 años

      Mi solución al reto:

      <Typography>{twitter_username ? `@${twitter_username}` :'Not Available'}</Typography>
      Roberth Salazar

      Roberth Salazar

      student•
      hace 3 años
      <Grid item xs={6}> <Stack> <Twitter /> <Typography>{twitter_username ? `@${twitter_username}` :'Not Available'}</Typography> </Stack> </Grid> <Grid item xs={6}> <Stack> <Language /> <Typography>{blog ?? 'Not Available'}</Typography> </Stack> </Grid>
      Santiago Rodriguez Palacio

      Santiago Rodriguez Palacio

      student•
      hace 3 años

      Si lo quieren trabajar con Typescript, se deben declarar 2 interfaces.

      interface User { location: string, twitter_username: string, blog: string, company: string } interface Props { userState: User } const LocationInformation = ({ userState }: Props) => { const { location, twitter_username, blog, company } = userState; return ( <Grid container> <Grid item xs={6}> <Stack> <LocationOnIcon /> {location !== null ? <Typography variant="body1" color="initial">{location}</Typography> : <Typography variant="body1" color="initial">Not Available</Typography> } </Stack> </Grid> ) }
      Maury Sugheiry Alcalá Romero

      Maury Sugheiry Alcalá Romero

      student•
      hace 3 años

      Facil, colocar el @ antes del {twitter_username}, quedando asi: ? <Typography>@{twitter_username}</Typography>

      Gaston Blanco

      Gaston Blanco

      student•
      hace 3 años

      Para no tener tantos Grid también puedes hacer:

      <Grid item xs={6}> <Stack direction="row"> <LocationOnIcon /> <Typography>{location}</Typography> </Stack> <Stack direction="row"> <TwitterIcon /> <Typography>{twitter_username ? `@${twitter_username}` : "Not Avaible"}</Typography> </Stack> </Grid>
      Kike Vanegas

      Kike Vanegas

      student•
      hace 3 años

      Pero esto no tiene nada de re-usabilidad. Estamos copiando y pegando el mismo bloque una y otra vez. Creo que sería mejor crear un componente que se encargue de evaluar la prop que le enviemos, y solo importar y usar el componente.

      Diego Vergara

      Diego Vergara

      student•
      hace 3 años

      Agregar @ a la izquierda de la variale de username.

      <Typography>@{twitter_username}</Typography>
      Juan Camilo Lentino Villalba

      Juan Camilo Lentino Villalba

      student•
      hace 3 años

      la solución al reto la hice de esta forma

      <Stack> <TwitterIcon /> { twitter_username !== null ? <Typography>@{twitter_username}</Typography> : <Typography>Not Available</Typography> } </Stack>

      adicionalmente, añadí pequeños cambios, utilice el operador ternario con location

      <Stack> <LocationOnIcon /> { location !== null ? <Typography>{location}</Typography> : <Typography>Not Available</Typography> } </Stack>

      blog lo compare con un string vacio y no con null, de esta manera puede funcionar correctamente el operador ternario ya que ese es el tipo de dato que estamos esperando en caso de que el usuario no tenga habilitada esta opción

      <Stack> <LanguageIcon /> { blog !== '' ? <Typography>{blog}</Typography> : <Typography>Not Available</Typography> } </Stack>

      así quedaría el código completo

      import { Grid, Stack, Typography } from "@mui/material"; import React from "react"; import LocationOnIcon from "@mui/icons-material/LocationOn"; import TwitterIcon from '@mui/icons-material/Twitter'; import LanguageIcon from "@mui/icons-material/Language"; import BusinessIcon from '@mui/icons-material/Business'; const LocationInformation = (props)=> { const { userState } = props const { location, twitter_username, blog, company } = userState return ( <> <Grid container > <Grid item xs={6}> <Stack> <LocationOnIcon /> { location !== null ? <Typography>{location}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> <Grid item xs={6}> <Stack> <TwitterIcon /> { twitter_username !== null ? <Typography>@{twitter_username}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> <Grid item xs={6}> <Stack> <LanguageIcon /> { blog !== '' ? <Typography>{blog}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> <Grid item xs={6} > <Stack> <BusinessIcon /> { company !== null ? <Typography>{company}</Typography> : <Typography>Not Available</Typography> } </Stack> </Grid> </Grid> </> ) } export default LocationInformation

    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