CursosEmpresasBlogLiveConfPrecios

Crea la vista de productos en la pantalla principal

Clase 6 de 15 • Curso de App Mobile utilizando Woocommerce

Clase anteriorSiguiente clase

Contenido del curso

Presentación

  • 1
    Bienvenida y presentación

    Bienvenida y presentación

    01:24 min

Preparando el proyecto

  • 2
    Análisis del proyecto y conexión con la API de WooCommerce

    Análisis del proyecto y conexión con la API de WooCommerce

    10:29 min
  • 3
    ¿Cómo puedo comenzar un proyecto con React Native?

    ¿Cómo puedo comenzar un proyecto con React Native?

    14:44 min

Creando tu app

  • 4
    Planifica y crea el estado global de tu app

    Planifica y crea el estado global de tu app

    20:12 min
  • 5
    Crea la pantalla de productos

    Crea la pantalla de productos

    17:39 min
  • 6
    Crea la vista de productos en la pantalla principal

    Crea la vista de productos en la pantalla principal

    Viendo ahora
  • 7
    Aprende a crear la navegación de tu app

    Aprende a crear la navegación de tu app

    20:34 min
  • 8
    Crea la pantalla de detalles de productos

    Crea la pantalla de detalles de productos

    20:54 min
  • 9
    ¿Cómo agregar el carrito a tu app?

    ¿Cómo agregar el carrito a tu app?

    11:55 min
  • 10
    Crea la vista de productos de tu carrito

    Crea la vista de productos de tu carrito

    17:56 min
  • 11
    Implementa cambios visuales basados en el carrito

    Implementa cambios visuales basados en el carrito

    20:49 min
  • 12
    Comprende cómo funcionan los payment gateways para tu app

    Comprende cómo funcionan los payment gateways para tu app

    04:08 min
  • 13
    Crea la pantalla de checkout

    Crea la pantalla de checkout

    24:58 min
  • 14
    Guarda los pedidos de tu app

    Guarda los pedidos de tu app

    19:22 min

Conclusiones

  • 15
    ¿Por dónde puedes seguir tu ruta?

    ¿Por dónde puedes seguir tu ruta?

    01:06 min
Tomar examen
    Juanito Ortega Guzmán

    Juanito Ortega Guzmán

    student•
    hace 4 años

    Los estilos pegados en el min: 2:58

    itemContainer: { width: Dimensions.get('window').width / 2, padding: 8, alignContent: 'center', }, itemImage: { width: '100%', height: 160, borderRadius: 8, overflow: 'hidden', marginBottom: 4 }, itemData: { flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center' }, itemMeta: { width: '70%' }, itemTitle: { color: colors.darkGrey, fontWeight: '300' }, itemPrice: { color: colors.darkGrey, fontWeight: 'bold' }, itemBtn: { width: '25%' }, productBtn: { width: 30, height: 30 }
    Juanito Ortega Guzmán

    Juanito Ortega Guzmán

    student•
    hace 4 años

    Hola Lucio... al principio podía ver las imágenes de los productos pero cuando intenté continuar para ver el título y precio de cada producto, se me rompió todo, ahora no puedo ver nada, solo veo un screen vacío en el emulador.

    Screen Shot 2022-01-20 at 21.56.22.png
    En la consola... muy raro... me sale esto.
    Screen Shot 2022-01-20 at 21.58.03.png
    Estos son mis códigos en: ProductItem.js

    import React from 'react'; import { StyleSheet, Dimensions, Text, View, Image } from 'react-native'; import { colors } from '../../resources/constants'; import config from '../../resources/config'; const ProductItem = props => { const { item } = props; const { id, name, price, images } = item; return ( <View key={id} style={styles.itemContainer}> <Image resizeMode="cover" style={styles.itemImage} source={{ uri: images[0].src, headers: { Authorization: config.liveLinkCredentials } }} /> <View style={styles.itemData}> <View style={styles.itemMeta}> <Text style={styles.itemPrice}>{`$ ${price}`}</Text> <Text style={styles.itemTitle}>{name}</Text> </View> </View> </View> ); } const styles = StyleSheet.create({ itemContainer: { width: Dimensions.get('window').width / 2, padding: 8, alignContent: 'center', }, itemImage: { width: '100%', height: 160, borderRadius: 8, overflow: 'hidden', marginBottom: 4 }, itemData: { flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center' }, itemMeta: { width: '70%' }, itemTitle: { color: colors.darkGrey, fontWeight: '300' }, itemPrice: { color: colors.darkGrey, fontWeight: 'bold' }, itemBtn: { width: '25%' }, productBtn: { width: 30, height: 30 } }); export default ProductItem;

    ProductsScreen.js

    import React, { useContext } from "react"; import { SafeAreaView } from "react-native-safe-area-context"; import { StyleSheet, Dimensions, Platform, Text, FlatList } from "react-native"; import ProductItem from "./ProductItem"; import Context from "../../context/Context"; import { sizes } from "../../resources/constants"; const ProductsScreen = props => { const { products } = useContext(Context); return ( <SafeAreaView> <FlatList style={styles.container} data={products} renderItem={({item}) => <ProductItem item={item} {...props} />} /> </SafeAreaView> ); } const styles = StyleSheet.create({ container: { height: Platform.OS === 'ios' ? Dimensions.get('window').height - sizes.headerHeight - 30 - 50 : Dimensions.get('window').height - sizes.headerHeight - 30 } }); export default ProductsScreen;

    Saludos.

      Lucio Negrello

      Lucio Negrello

      teacher•
      hace 4 años

      Hola Juanito, cómo estás? Por el error, entiendo que el problema no es con la maqueta, sino con el fetch a la API. Al parecer la promesa está devolviendo un archivo JSON inválido. Tendrías que revisar la función en la que se hace el fetch y que esté encendido el servidor para responder la petición. Espero que con esta info, puedas resolverlo. Saludos!

      Juanito Ortega Guzmán

      Juanito Ortega Guzmán

      student•
      hace 4 años

      Que raro, pude imprimir los name, luego pude imprimir las imágenes, pero cuando quise imprimir el precio y el name ya no pude y aunque probé revirtiendo estos últimos cambios, no pude volver a ver los name impresos. Por si acaso te dejo mi repo, podrías revisarlo por favor?... yo revisé, pero no encuentro el error, mis conocimientos son limitados. https://github.com/JuanitoOrtega/wp-react-native-store

    David Rangel

    David Rangel

    student•
    hace un mes

    Les dejo el código pero adaptado a Typescript:

    // constants/types/ProductTypes.ts export type ImageType = { src: string; }; export type ItemType = { id: string; name: string; price: number; images: ImageType[]; }; export interface ProductItemProps { item: ItemType; } // components/products/ProductsScreen.tsx import { useContext } from 'react'; import { Dimensions, FlatList, Platform, StyleSheet } from 'react-native'; import { SafeAreaView } from 'react-native-safe-area-context'; import { StoreContext } from '@/src/context/storeContext'; import { sizes } from '../../src/resources/constants'; import { ProductItem } from './ProductItem'; export const ProductsScreen = () => { const { products } = useContext(StoreContext); return ( <SafeAreaView> <FlatList style={styles.container} data={products} renderItem={(item: any) => <ProductItem item={item} />} numColumns={2} /> </SafeAreaView> ); }; const styles = StyleSheet.create({ container: { height: Platform.OS === 'ios' ? Dimensions.get('window').height - sizes.headerHeight - 30 - 50 : Dimensions.get('window').height - sizes.headerHeight - 30, }, }); // components/products/ProductItem.tsx import { Dimensions, Image, StyleSheet, Text, View } from 'react-native'; import { ProductItemProps } from '@/constants/types/ProductTypes'; import { config } from '@/src/config/config'; import { colors } from '@/src/resources/constants'; export const ProductItem = ({ item }: ProductItemProps) => { const { id, name, price, images } = item; return ( <View key={id} style={styles.itemContainer}> <Image resizeMode='cover' style={styles.itemImage} source={{ uri: images[0].src, headers: { Authorization: config.liveLinkCredentials, }, }} /> <View style={styles.itemData}> <View style={styles.itemData}> <Text style={styles.itemPrice}>{`$ ${item.price}`}</Text> <Text style={styles.itemTitle}>{item.name}</Text> </View> </View> </View> ); }; const styles = StyleSheet.create({ itemContainer: { width: Dimensions.get('window').width / 2, padding: 8, alignContent: 'center', }, itemImage: { width: '100%', height: 160, borderRadius: 8, overflow: 'hidden', marginBottom: 4, }, itemData: { flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center', }, itemMeta: { width: '70%', }, itemTitle: { color: colors.darkGrey, fontWeight: '300', }, itemPrice: { color: colors.darkGrey, fontWeight: 'bold', }, itemBtn: { width: '25%', }, productBtn: { width: 30, height: 30, }, });

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