CursosEmpresasBlogLiveConfPrecios

Crear un nuevo board: UI

Clase 12 de 22 • Curso Práctico de Angular: Construye un Clon de Trello

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Bienvenida y setup del proyecto

    Bienvenida y setup del proyecto

    05:31 min
  • 2
    Funcionamiento de la API y análisis del proyecto

    Funcionamiento de la API y análisis del proyecto

    04:32 min

Integración entre UI y API

  • 3
    Conectando los boards del usuario

    Conectando los boards del usuario

    11:28 min
  • 4
    Creando el card color component

    Creando el card color component

    19:00 min
  • 5
    Typing Colors

    Typing Colors

    12:35 min
  • 6
    Detalle de un board

    Detalle de un board

    23:53 min

Drag and Drop

  • 7
    Algoritmo para detectar la posición de la card

    Algoritmo para detectar la posición de la card

    12:16 min
  • 8
    Detectar tipo de movimiento: drag and drop

    Detectar tipo de movimiento: drag and drop

    11:10 min
  • 9
    Calcular la posición

    Calcular la posición

    09:36 min
  • 10
    Actualizar una sola card

    Actualizar una sola card

    12:28 min
  • 11
    Actualizar lista

    Actualizar lista

    07:28 min

Boards

  • 12
    Crear un nuevo board: UI

    Crear un nuevo board: UI

    Viendo ahora
  • 13
    Crear un nuevo board: conectar con la API

    Crear un nuevo board: conectar con la API

    11:24 min
  • 14
    Cerrar el overlay

    Cerrar el overlay

    05:36 min

Cards

  • 15
    Crear una nueva card: UI

    Crear una nueva card: UI

    11:38 min
  • 16
    Crear una nueva card: formulario

    Crear una nueva card: formulario

    07:54 min
  • 17
    Crear una nueva card: conectar con la API

    Crear una nueva card: conectar con la API

    15:39 min

Listas

  • 18
    Crear una nueva lista: UI

    Crear una nueva lista: UI

    05:20 min
  • 19
    Crear una nueva list: conectar con la API

    Crear una nueva list: conectar con la API

    09:46 min

Backgrounds

  • 20
    Background dinámico

    Background dinámico

    08:28 min
  • 21
    Estado para el Background

    Estado para el Background

    15:08 min

Próximos pasos

  • 22
    ¿Quieres más cursos de Angular?

    ¿Quieres más cursos de Angular?

    05:26 min
  • Tomar el examen del curso
    • Adrian Silva

      Adrian Silva

      student•
      hace 2 años

      Mi solución al reto:

      <input id="sky-radio" type="radio" value="sky" name="backgroundColor" formControlName="backgroundColor" class="hidden peer" /> <label for="sky-radio" class="inline-flex items-center justify-center w-8 h-8 text-transparent border border-gray-200 rounded cursor-pointer bg-sky-700 hover:bg-sky-500 peer-checked:text-white" > <fa-icon [icon]="faCheck"></fa-icon> </label>
      Luis Jose Marquez Gonzalez

      Luis Jose Marquez Gonzalez

      student•
      hace un año

      Para hacer más dinámico el selector de colores, he hecho lo siguiente:

      1. He creado un array de colores para los boars

        export const BOARD_COLORS: string[] = ['sky','green', 'violet', 'yellow', 'gray'];
      2. En el ts del componente he creado una variable que contiene esos valores y una función para que tailwind agregue las clases correspondientes:

      colorList: string[] = BOARD_COLORS; getcolorClass(color: string): string { return COLORS[color as Colors]; } ```Si los estilos están un poco rotos, hay que agregar las clases variantes para los hover, focus y checked: ```js checked:bg-sky-500 focus:bg-sky-500 checked:focus:bg-sky-500 hover:checked:bg-sky-500

      3. En el HTML he utilizado el siguiente código para generar los inputs en forma de rectángulos:

      <div class="grid gap-2 mb-4 relative" [ngClass]="'grid-cols-5'" > @for(color of colorList; track color){ <div class="relative mb-4"> <input formControlName="color" type="radio" placeholder="Board color" class="border-0 cursor-pointer h-10 w-full rounded bg-gray-100 p-2 border-gray-300 checked:border-2 checked:border-gray-400" [ngClass]="getcolorClass(color)" [value]="color" > </div> } </div> ```Este ha sido el resultado: ![](https://static.platzi.com/media/user_upload/image-3e63406e-c7fa-4880-967b-2a92b1e756a3.jpg)
      Camilo Del Valle Ledesma

      Camilo Del Valle Ledesma

      student•
      hace un año

      board-form.component.html

      <form [formGroup]="form" novalidate class="space-y-4" (ngSubmit)="doSave()"> <div> <div class="flex flex-wrap"> <div class="flex items-center mr-4"> <input id="sky-radio" type="radio" value="sky" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-sky-600 bg-gray-100 border-gray-300 focus:ring-sky-500 dark:focus:ring-sky-600 " /> <label for="sky-radio" class="ml-2 text-sm font-medium text-gray-900 " >Sky</label > </div> <div class="flex items-center mr-4"> <input id="yellow-radio" type="radio" value="yellow" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-yellow-600 bg-gray-100 border-gray-300 focus:ring-yellow-500 dark:focus:ring-yellow-600 " /> <label for="yellow-radio" class="ml-2 text-sm font-medium text-gray-900" >Yellow</label > </div> <div class="flex items-center mr-4"> <input id="green-radio" type="radio" value="green" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-green-600 bg-gray-100 border-gray-300 focus:ring-green-500 dark:focus:ring-green-600 " /> <label for="green-radio" class="ml-2 text-sm font-medium text-gray-900" >green</label > </div> <div class="flex items-center mr-4"> <input id="red-radio" type="radio" value="red" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-red-600 bg-gray-100 border-gray-300 focus:ring-red-500 dark:focus:ring-red-600 " /> <label for="red-radio" class="ml-2 text-sm font-medium text-gray-900" >red</label > </div> <div class="flex items-center mr-4"> <input id="violet-radio" type="radio" value="violet" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-violet-600 bg-gray-100 border-gray-300 focus:ring-violet-500 dark:focus:ring-violet-600 " /> <label for="violet-radio" class="ml-2 text-sm font-medium text-gray-900" >violet</label > </div> <div class="flex items-center mr-4"> <input id="gray-radio" type="radio" value="gray" name="backgroundColor" formControlName="backgroundColor" class="w-4 h-4 text-gray-600 bg-gray-100 border-gray-300 focus:ring-gray-500 dark:focus:ring-gray-600 " /> <label for="gray-radio" class="ml-2 text-sm font-medium text-gray-900" >gray</label > </div> </div> </div> <div> <div class="relative"> <input formControlName="title" placeholder="Enter title" type="text" class="w-full rounded bg-gray-100 border-gray-300 border-2" /> </div> </div> <div> <app-btn typeBtn="submit" color="success"> Create </app-btn> </div> </form>

      arlingholguin

      arlingholguin

      student•
      hace 2 años
      ng g c modules/layout/components/board-form --skip-tests --style=none

    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