La modificación para que no permita editar tareas ya completadas.
Introducción a Angular y Fundamentos
Desarrollo de Aplicaciones Modernas con Angular
Creando tu primer proyecto en Angular
Creación de componentes y rutas en Angular para gestión de tareas
String Interpolation en Angular: Transmisión de Datos a Templates
Modificación de Propiedades HTML con Angular: Property Binding
Eventos en Angular: click, doble click y cambio de input
Eventos de Teclado en JavaScript: Uso de KeyDown y Change
Reactividad Granular con Signals en Angular
Reactividad en HTML: Implementación de Signals en JavaScript
Estructuras de control en Angular
Estructuras de Control y Renderizado Dinámico en Angular
Gestión Dinámica de Tareas en JavaScript: Creación y Eliminación
Estructuración de Tareas en JavaScript: Uso de Interfaces y Typing
Actualización de tareas con Angular y programación inmutable
Uso de ngIf y ngFor para control de flujos en Angular
Pluralización y ngSwitch en Angular para manejo de condiciones múltiples
Manejo Avanzado de Formularios Reactivos en Angular
Validaciones de Inputs en Formularios Reactivos con Angular
Alistando tu aplicación para producción
Validación de formularios y estilos dinámicos en Angular
Activación dinámica de clases en Angular con validaciones
Edición de Tareas Dinámicas en Aplicaciones Web
Estados Computados en Programación Reactiva con Signals
Persistencia de Tareas con LocalStorage en Angular
Compilación y Optimización de Aplicaciones Angular para Producción
Lanzamiento de Aplicaciones con Fiverr Hosting y Angular
Nuevas Sintaxis Declarativas en Angular Inspiradas en Svelte
Sintaxis y rendimiento de for y switch en JavaScript moderno
Migración Automática a Nueva Sintaxis de Angular
Componentes Reutilizables y Comunicación
Creación de Tienda en Línea con Angular y Tailwind CSS
Creación y Organización de Componentes en Angular
Componentes Reutilizables en Angular: Creación y Maquetado de Productos
Uso de Angular DevTools para Debugging en Angular
Inputs en Angular: Comunicación de Datos entre Componentes
Outputs en Angular: Comunicación del Hijo al Padre
Maquetación de Galería de Productos con Tailwind CSS
Ciclo de vida de los componentes
Ciclo de Vida de Componentes en Angular
Creación y Uso de Componentes en Angular: Ciclo de Vida y Comunicación
Ciclo de Vida de Componentes en Angular: Eventos Clave
Detección de Cambios en Inputs con ngOnChange en Angular
Prevención de fugas de memoria con ngOnDestroy en Angular
Creación de un Reproductor de Audio con WaveSurfer.js en Angular
Mejoras de la página About en e-commerce: audio y contador dinámico
Mejorando la interfaz del producto
Componentización y Manejo de Datos en Angular
Creación de Headers en Páginas Web con Angular
Implementación de Interfaz Gráfica para Carrito de Compras Interactivo
Implementación de Reactividad en Carrito de Compras con Angular
Gestión de Carrito de Compras en Angular con ngOnChanges
Gestión de Estado en Angular: Solución al InputDrilling
Gestión de Estado Global en Angular con Servicios y Señales
Inyección de Dependencias en Angular: Conceptos y Prácticas
Integración y Datos
Conexión de Angular a REST API usando Fake Store API de Platzi
Creación de Alias para Imports Cortos en Proyectos JavaScript
Transformación de Datos con Pipes en Angular
Creación y uso de pipes personalizados en Angular
Manipulación de Fechas en Angular con Date Functions
Manipulación del DOM con Directivas en Angular
Deployment de Aplicaciones Angular en Vercel
Enrutamiento y Navegación
Creación de Página 404 en Angular: Manejo de Rutas No Encontradas
Implementación de Router Link en Angular para SPA eficiente
Implementación de Layouts Compartidos en Angular para Vistas Anidadas
Uso de RouterLinkActive en Angular para Navegación Activa
Routing en Angular: Creación de Páginas de Detalle de Producto
Consulta dinámica de detalles de producto con Angular y REST API
Galería de Productos Dinámica con Angular y TypeScript
Mejoras en Detalle de Producto: Precio, Carrito e Imagen Activa
Perfeccionando tu e-commerce
Filtrado de Productos por Categoría en E-commerce
Filtros de Productos con Query Params en Angular
Optimización de Aplicaciones con Lazy Loading y Code Splitting
Optimización de JavaScript en Angular con Lazy Loading
Optimización de Carga de Chunks con Preloading en Angular
Migración de Angular a Nueva Sintaxis con ng generate
Despliegue de Aplicaciones con Verzal en Entornos Productivos
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
Para completar una clase de manera dinámica, necesitas asegurarte de que cada elemento li (lista) tenga la clase "completed" activada solo si la tarea está finalizada. Dado que el estado de una tarea es un booleano, la asignación puede ser directa, reflejándose inmediatamente en la interfaz gracias al uso de programación reactiva con signals. Esto permite que, al marcar una tarea como completada, aparezca una línea de tachado que la distingue visualmente como terminada.
Para activar el modo de edición en una tarea, necesitas asignar una clase dinámica llamada "editing". Esta clase revela un input que permite editar el título de la tarea al hacer doble clic en él. A continuación, te mostramos los pasos para habilitar este modo:
En el modelo de tareas (tasks
), se puede agregar un estado opcional editing
, que indica si una tarea está en modo de edición o no. Este estado se cambia al hacer doble clic sobre una tarea.
Define un estado opcional editing
en tu modelo de datos para gestionar el modo de edición:
let task = {
title: 'Nombre de la tarea',
completed: false,
editing: false // Estado opcional
};
Este estado ayuda a determinar qué tarea está en edición, para que al hacer doble clic solo actives el input de esa tarea y se oculte el resto.
Añade un método para cambiar el modo de edición al hacer doble clic:
function updateEditingMode(taskIndex) {
tasks.forEach((task, index) => {
task.editing = (index === taskIndex);
});
}
Con este método, al hacer doble clic en una tarea específica, se activa su estado de edición y los demás se desactivan, permitiendo editar una tarea a la vez.
Al terminar de editar, presiona Enter para guardar cambios. Aquí te mostramos cómo lograrlo:
Configura un listener para capturar el evento Enter en el input de edición:
function handleEnterKey(event, taskIndex) {
if (event.key === 'Enter') {
updateTaskTitle(taskIndex, event.target.value);
}
}
Crea un método para actualizar el título de la tarea y salir del modo de edición:
function updateTaskTitle(taskIndex, newTitle) {
tasks[taskIndex].title = newTitle;
tasks[taskIndex].editing = false;
}
Este método asegura que el nuevo título se guarda en la tarea específica, y el modo de edición se desactiva al guardar.
Finalmente, prueba la funcionalidad verificando que al editar y presionar Enter, el título de la tarea se actualiza correctamente sin perder los estados visuales previos como la línea de tachado si la tarea está completada.
Siguiendo estos pasos, podrás implementar una edición dinámica y eficiente en tus tareas, mejorando la interacción del usuario con la aplicación. La clave está en usar programación reactiva y manipular el DOM de forma dinámica y efectiva. ¡Adelante, sigue practicando y perfecciona tus habilidades en desarrollo web!
Aportes 29
Preguntas 4
La modificación para que no permita editar tareas ya completadas.
Si google keep deja que yo edite las tareas completadas, voy a hacer lo mismo jaja
La Versión de Angular 17, ya no tiene el metodo mutate sino el metodo update,
const count = signal(0);
// Increment the count by 1.
count.update(value => value + 1);
En que momento cambio tanto el código , se ve en el código que no usa update, sino que usa mutate eso no fue explicado ? updateTask tenia una lógica y ahora tiene otra, ademas si es una propiedad opcional debería ser [class.editing]=“task?.editing” sino esto generará problemas
✅
Validation to not allow an already completed task to be edited
<updateTaskEditingMode( index: number ) {
this.tasks.update(( tasks ) => tasks.map(( task, position ) => {
if ( position === index && !task.completed ) {
return {
...task,
editing: true
}
}
return {
...task,
editing: false
}
}));
}
>
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?