CursosEmpresasBlogLiveConfPrecios

Componente de botón reutilizable

Clase 5 de 24 • Curso de Maquetación con Angular CDK y Tailwind CSS

Clase anteriorSiguiente clase

Contenido del curso

Introducción
  • 1
    ¿Qué es el Angular CDK?

    ¿Qué es el Angular CDK?

    05:55
  • 2
    Instalando Angular CDK y TailwindCSS

    Instalando Angular CDK y TailwindCSS

    12:37
Maquetando con Tailwind
  • 3
    Maquetando la página de login con Tailwind

    Maquetando la página de login con Tailwind

    14:40
  • 4
    Maquetando formularios con Tailwind

    Maquetando formularios con Tailwind

    09:23
  • 5
    Componente de botón reutilizable

    Componente de botón reutilizable

    15:53
  • 6
    Reto: colores y propiedades dinámicas

    Reto: colores y propiedades dinámicas

    11:29
Componentes interactivos con Angular CDK
  • 7
    Creando Overlays

    Creando Overlays

    16:38
  • 8
    Múltiples Overlays

    Múltiples Overlays

    05:44
  • 9
    Iconos en Angular con Font Awesome

    Iconos en Angular con Font Awesome

    13:38
  • 10
    Creando acordeones

    Creando acordeones

    11:53
  • 11
    Acordeones dinámicos

    Acordeones dinámicos

    08:49
Drag and drop
  • 12
    Drag and drop con ordenamiento

    Drag and drop con ordenamiento

    17:06
  • 13
    Drag and drop con transferencia entre columnas

    Drag and drop con transferencia entre columnas

    14:07
  • 14
    Drag and drop con columnas dinámicas

    Drag and drop con columnas dinámicas

    13:34
Modales y listas
  • 15
    Modales y diálogos

    Modales y diálogos

    16:21
  • 16
    Modales recibiendo información

    Modales recibiendo información

    13:04
  • 17
    Listas con scroll

    Listas con scroll

    12:04
  • 18
    Listas con virtual scrolling

    Listas con virtual scrolling

    05:14
Table CDK
  • 19
    Tablas

    Tablas

    14:33
  • 20
    Estilos en Tablas

    Estilos en Tablas

    13:25
  • 21
    Usando un DataSource en Tablas

    Usando un DataSource en Tablas

    14:39
  • 22
    Tablas con filtros y debounce

    Tablas con filtros y debounce

    09:02
Próximos pasos para completar el Clon de Trello
  • 23
    Mejoras en UX y reusabilidad

    Mejoras en UX y reusabilidad

    13:19
  • 24
    Toma el Curso de Autenticación con Angular

    Toma el Curso de Autenticación con Angular

    01:38
    Diego Lozano

    Diego Lozano

    student•
    hace 3 años
    <div class="w-screen h-screen bg-gray-50 sm:bg-gray-50 relative"> <div class="absolute w-full h-full hidden sm:block"> <img loading="lazy" class="absolute w-60 lg:w-96 left-0 bottom-0" src="/assets/svg/login-bg-left.svg" alt="bg left" /> <img loading="lazy" class="absolute w-60 lg:w-96 right-0 bottom-0" src="/assets/svg/login-bg-rigth.svg" alt="bg rigth" /> </div> <div class="relative w-full sm:w-7/12 md:w-6/12 lg:w-4/12 m-auto"> <header class="pt-6 pb-2 flex justify-center"> <img loading="lazy" class="w-56" src="/assets/images/logo/logo-gradient-blue-trello.png" alt="Logo" /> </header> <div class="bg-white rounded shadow-none sm:shadow-lg py-4 px-6 md:px-10"> <div class="mb-4"> <h1 class="text-center font-semibold pt-4 pb-8 text-gray-600"> Log In to Trello </h2> <form novalidate class="space-y-4"> <div class="relative"> <input placeholder="Enter email" type="email" class="w-full rounded bg-gray-100 border-2 border-gray-300" /> </div> <div class="relative"> <input placeholder="Enter password" type="password" class="w-full rounded bg-gray-100 border-gray-300" /> </div> <div> <button class="text-white w-full px-5 py-2 font-medium rounded text-sm bg-green-700" type="submit" > Log In </button> </div> </form> <hr class="my-4 border-b-1 border-r-gray-300" /> <div class="flex justify-center items-center space-x-0 space-y-2 md:space-x-2 md:space-y-0 gap-" > <a href="/forgot-password" class="text-blue-600 font-light" >Can't log in?</a > <span class="text-gray-500 hidden md:block">*</span> <a href="/register" class="text-blue-600 font-light m-0" >Sign up for an account</a > </div> </div> </div> <hr class="mt-10 border-b-1 border-r-gray-300" /> <div class="flex justify-center"> <img loading="lazy" class="w-32 mt-4" src="/assets/images/logo/logo-atlassian-gray.png" alt="logo" /> </div> </div> </div>
    David Trespalacios

    David Trespalacios

    student•
    hace 2 años

    Para el reto de reutilizar el boton con otros alias de color:

    1. Agregué un input para recibir el 'alias' en el componente del botón, luego con el ngOnChanges, concadeno el alias con el resto de string para crear la clase de bg y hover:bg así:
    @Input() colorBtn: string = ''; classBtnCustom: string = ''; ngOnChanges(changes: SimpleChanges): void { const colorBtn = changes['colorBtn']?.currentValue; if (colorBtn) { this.classBtnCustom = `bg-${colorBtn}-500 hover:bg-${colorBtn}-800`; } }

    Finalmente en el Html, uso binding para leer la variable creada 'classBtnCustom':

    <button class="text-white w-full px-5 py-2 mb-6 font-medium rounded text-sm {{classBtnCustom}} focus:right-4" [type]="typeBtn" > <ng-content></ng-content> </button>
    Alexander Gallo

    Alexander Gallo

    student•
    hace 3 años

    Funciones de los valores de los estilo0s en línea con TailwindCSS:

    • w-screen y h-screen: El elemento ocupará todo el espacio en pantalla

    • bg-'Nombre_del_color': Color de fondo del elemento

    • space-y-#: Espaciado entre elementos en el eje Y

    Wilmion Navarrete

    Wilmion Navarrete

    student•
    hace 2 años

    Si desean que el tipo sea mas preciso ya que estaria usando desde los mismos props del button

    @Input() typeBtn: HTMLButtonElement['type'] = 'submit';

    Victor Alfredo Matzar Say

    Victor Alfredo Matzar Say

    student•
    hace 3 años

    Un poco más sobre ng-content :) : https://www.youtube.com/watch?v=pjINr3StGtI

    Max Andy Diaz Neyra

    Max Andy Diaz Neyra

    student•
    hace 7 meses

    Mi solucion:

    export class BtnComponent { // @Input() typeBtn: HTMLButtonElement['type'] = 'button'; // @Input() bgColor = ''; // classBtnCustom = ''; // ngOnChanges(changes: SimpleChanges) { // const colorBtn = changes['bgColor']?.currentValue; // if (colorBtn) { // this.classBtnCustom = `bg-${colorBtn}-700 hover:bg-${colorBtn}-800`; // } // console.log(this.bgColor, this.classBtnCustom); // } typeBtn = input<HTMLButtonElement['type']>('button'); bgColor = input('primary'); classBtnCustom = computed(() => { const bgColor = this.bgColor(); return `bg-${bgColor}-700 hover:bg-${bgColor}-800`; }); }

    Html:

    <button class="text-white w-full px-5 py-2 font-medium rounded text-sm {{ classBtnCustom() }}" [type]="typeBtn()" > <ng-content></ng-content> </button>
      Max Andy Diaz Neyra

      Max Andy Diaz Neyra

      student•
      hace 7 meses

      Tuve que agregar safelits

    Gabriel Oswaldo Montoya Huamani

    Gabriel Oswaldo Montoya Huamani

    student•
    hace 2 años

    Reto de la clase:

    import { Component, Input, OnInit } from '@angular/core'; type typeBtn = 'submit' | 'button' | 'reset';type moodBtn = 'dangerous' | 'main' |'disabled'; @Component({  selector: 'app-button',  templateUrl: './button.component.html',}) export class ButtonComponent implements OnInit{  // typeButton para saber que tipo de boton es  @Input() typeButton: typeBtn = 'button';  // moodButton es un input para saber que estilos debemos agregar a nuestro boton, usamos los type para tener un buen tipado.  @Input() moodButton: moodBtn = 'main';  // isDisabled para cuando el boton tiene el mood "disabled".  public isDisabled!: boolean;   ngOnInit(): void {    this.moodButton == 'disabled' ? this.isDisabled = true : this.isDisabled = false;  }}

    Edwin Jesús

    Edwin Jesús

    student•
    hace 2 años

    before:content-['value'] text-[#color] bg-[#color]

    <div class="w-screen h-screen bg-gray-50 sm:bg-gray-50 relative"> <div class="absolute w-full h-full hidden sm:block"> <img loading="lazy" class="absolute w-60 lg:w-96 left-0 bottom-0" src="/assets/svg/login-bg-left.svg" alt="bg left" /> <img loading="lazy" class="absolute w-60 lg:w-96 right-0 bottom-0" src="/assets/svg/login-bg-right.svg" alt="bg rigth" /> </div> <div class="relative w-full sm:w-7/12 md:w-6/12 lg:w-4/12 m-auto bg-white"> <header class="pt-6 pb-2 flex justify-center"> <img loading="lazy" class="w-56" src="/assets/images/logo/logo-gradient-blue-trello.png" alt="Logo" /> </header> <div class="bg-white rounded shadow-none sm:shadow-lg py-4 px-6 md:px-10"> <div class="mb-4"> <h1 class="text-center font-semibold pt-4 pb-8 text-gray-600"> Log In to Trello </h2> <form novalidate class="space-y-4"> <div class="relative"> <input placeholder="Enter email" type="email" class="w-full rounded bg-gray-100 border-2 border-gray-300" /> </div> <div class="relative"> <input placeholder="Enter password" type="password" class="w-full rounded bg-gray-100 border-gray-300" /> </div> <div> <button class="text-white w-full px-5 py-2 font-medium rounded text-sm bg-green-700" type="submit"> Log In </button> </div> </form> <hr class="my-4 border-b-1 border-r-gray-300" /> <div class="text-center"> <a href="/forgot-password" class="text-[#0052cc] text-sm mr-2">Can't log in?</a> <span class="before:content-['\2022'] text-[#0052cc] text-sm"></span> <a href="/register" class="text-[#0052cc] text-sm m-0 ml-2">Sign up for an account</a> </div> </div> </div> <hr class="mt-10 border-b-1 border-r-gray-300" /> <div class="flex justify-center"> <img loading="lazy" class="w-32 mt-4" src="/assets/images/logo/logo-atlassian-gray.png" alt="logo" /> </div> </div> </div>

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