npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

ng-easycommerce-v18

v0.6.18-auth-cart.1

Published

- Forgot password: el submit pasa de `input` a `button`, muestra `app-loading-inline-ec` durante la petición y queda deshabilitado mientras `loading` está activo o el formulario es inválido. - Forgot password: `recoverPassword(...)` agrega guard clause pa

Readme

Version 0.6.18-auth-cart.1

  • Forgot password: el submit pasa de input a button, muestra app-loading-inline-ec durante la petición y queda deshabilitado mientras loading está activo o el formulario es inválido.
  • Forgot password: recoverPassword(...) agrega guard clause para cortar submits duplicados o inválidos y marca el formulario como tocado antes de salir.
  • Register form: se incorpora FormService para exponer countries$, provinces$ y documentTypes$ y preparar formularios de registro con datos extendidos.
  • Register form: se amplía registerForm con campos opcionales compatibles con /register (birthday, gender, phoneNumber, documento, domicilio, empresa y contacto) manteniendo compatibilidad con el registro simple existente.
  • Register form: el alta envía un payload normalizado desde buildRegisterPayload(), mapeando phone -> phoneNumber, newsletter -> subscribedToNewsletter, eliminando campos internos (terms, plainPassword2) y omitiendo valores vacíos antes de llamar a singUp(...).
  • Register form: se agregan handlers onCountrySelected(...) y onProvincesSelected(...) para sincronizar país/provincia y persistir provinceName/provinceCode en el payload.
  • Cart item: la marca de descuento sólo se renderiza cuando saleprice existe y además es menor al price original, evitando badges falsos cuando ambos importes son iguales o inválidos.
  • Cart item: createDiscountMessage(...) endurece la validación de precios y sólo devuelve "% OFF" cuando el porcentaje calculado es finito y positivo.

Version 0.6.18

  • Checkout: se agrega channelReady en CheckoutEcComponent para evitar que el checkout se renderice durante SSR. El flag solo pasa a true en el browser, una vez que channel$ emite la configuración del canal, garantizando que checkoutView ya tenga el valor correcto antes de renderizar. Esto elimina el hydration mismatch que causaba que el checkout legacy apareciera aleatoriamente cuando el canal tenía configurado el single.
  • Checkout single: al completarse los 3 pasos y habilitarse el botón de finalizar pedido, se ejecuta un scroll suave al inicio de la página (window.scrollTo({ top: 0, behavior: 'smooth' })). El scroll solo ocurre una vez por transición "no listos → todos listos" y se reinicia si el usuario edita algún paso.

Version 0.6.17

  • auth.service: se agrega canAccessMyAccountMenu() para controlar la visibilidad de Mi cuenta en header (clientes: visible; sellers: solo con cliente activo).
  • auth.service: setCustomer(...) deja de forzar recarga completa (location.href) al cambiar cliente y pasa a emitir estado reactivo por customer$.
  • auth.service: en setCustomer(null) se corrige el orden de persistencia/emisión para evitar rehidratación accidental del cliente desde storage en el mismo ciclo.
  • auth.service: las validaciones de UI (isAbleToBuy, canAccessSellerDashboard, canAccessMyAccountMenu) usan snapshot sin side effects para evitar loops de render/logout.
  • auth.service: al resolver usuario por canal, no se fuerza logout por mismatch cuando hay impersonación activa de cliente.
  • header-ec: se suscribe a AuthService.customer$ para refrescar inmediatamente la UI cuando seller entra/sale de modo cliente.
  • seller-dashboard-container-ec: se normaliza el click de OPERAR COMO/SALIR y se agrega guard temporal anti doble ejecución para evitar transiciones duplicadas.
  • seller-dashboard-container-ec: se agrega hardening de sesión para limpiar clientes y redirigir a /auth/login cuando loggedIn$ pasa a false, evitando que un usuario deslogueado siga operando sobre el dashboard ya montado.
  • menu-ec: en logout, si el usuario estaba en /seller-dashboard, se fuerza redirección inmediata a /auth/login antes del resolver de home para evitar estados intermedios o vistas protegidas en blanco.
  • Configuración hideTaxes: se corrige el alcance para que oculte impuestos únicamente en sidebar, cart y checkout (como indica backend), sin impactar la leyenda fiscal en product-detail ni el detalle de pedido (account/orders/:id).
  • Product detail (impuestos): cuando un producto tiene variantes y todas comparten el mismo precio/saleprice y la misma leyenda fiscal (base imponible, monto y tasa), la leyenda de impuestos se muestra desde la carga inicial sin requerir selección de variante; si difieren entre variantes, se mantiene el comportamiento actual (mostrar al seleccionar).
  • SEO: se estandariza la gestión de metadatos por ruta (title, description y canonical) para evitar títulos stale y faltantes de meta description en páginas clave.
  • SEO: se corrigen enlaces no crawlables en componentes compartidos, separando navegación real (a con href/routerLink) de acciones de UI (button).
  • SEO: mejoras de semántica base en templates compartidos (jerarquía de headings, estructura de listas y atributos alt/title en imágenes dinámicas donde aplica).
  • Accessibility: se agregan nombres accesibles (aria-label) en controles icon-only (desktop/mobile) y en acciones que quedaban sin texto visible.
  • Accessibility: se asocian labels en formularios y selects de flujos auth/checkout/dashboard, incluyendo labels ocultos cuando corresponde para mantener diseño.
  • Accessibility: se corrigen usos de ARIA incompatibles y se eliminan ids/atributos conflictivos en componentes reutilizables.
  • Seller dashboard: se mantiene comportamiento de impersonación sin recarga completa y se refuerza compatibilidad SEO/Accessibility en acciones OPERAR COMO / SALIR.
  • Estilos: se ajustan selectores compartidos para conservar apariencia visual al migrar controles de a a button.
  • Carrito: se incorpora preimpresión de presupuesto como funcionalidad opt-in del core (setCartPreprintEnabled + printCartBudget), con plantilla de impresión dedicada, imágenes de productos y textos traducibles (print-budget, print-budget-title).
  • Carrito / Preimpresión de presupuesto: el resumen impreso incluye impuestos cuando corresponde (hideTaxes = false y monto > 0).
  • Carrito / Preimpresión de presupuesto: se agrega línea de descuento al resumen impreso cuando aplica.
  • Carrito / Preimpresión de presupuesto: se respeta la visibilidad de precios configurada en core (PriceVisibilityService), ocultando importes en impresión cuando no deben mostrarse.
  • Cuenta / Pedidos: se actualiza la grilla de Mis pedidos con nueva disposición de columnas, acción de detalle con ícono de ojo y alineación consistente de columna de acciones.
  • Cuenta / Pedidos: se ajusta el orden de columnas en pedidos.
  • Cuenta / Pedidos: la columna Estado de pago reemplaza el texto previo ambiguo y se prepara soporte para orderState cuando el endpoint lo expone.
  • Cuenta / Pedidos: se agregan filtros por estado de orden, estado de pago, estado de envío, método de envío y rango/condición de total (=, >, <, rango).
  • Cuenta / Pedidos: se agrega filtro de fecha con modos exacta (por día, ignora hora), anterior a, posterior a y rango.
  • Cuenta / Pedidos: se reemplazan operadores simbólicos por etiquetas de texto en filtros de fecha y total para mayor claridad de uso.
  • Cuenta / Pedidos: se mejora la UX de filtros en orders-list-ec con layout más robusto para filtros compuestos (fecha/total en rango) y mejor adaptación responsive.
  • Cuenta / Pedidos: en mobile se agrega toggle para mostrar/ocultar filtros y reducir ocupación vertical inicial.
  • Cuenta / Pedidos: mejora de ordenamiento visual con indicadores explícitos por columna y mejoras de experiencia responsive/mobile en listado y detalle.

Version 0.6.16

  • Se agregan nuevos enpoints para borrado y agregado masivo de productos de una lista.
  • Se cambia el proceso de agregar producto creando una lista, ahora toma el token que devuelve el endpoint al crearla y agrega sin tener que hacer get de todas las listas.
  • Se agregan traducciones para el tipo de documento en las ordenes
  • Se centraliza en el core la lógica común de wishlist en WishlistService, WishlistEcComponent, WishlistModalEcComponent, ProductEcComponent, ProductDetailEcComponent y SharedWishlistEcComponent.
  • El modal de wishlist pasa a soportar selección múltiple con checkboxes para guardar un mismo producto en más de una lista y crear listas nuevas desde el mismo flujo.
  • Se agregan al core las acciones comunes de wishlist: renombrar lista, compartir, eliminar con confirmación, búsqueda dentro de la lista, selección masiva y guardado de productos seleccionados en otra lista.
  • La wishlist compartida pasa a resolver su metadata y vista base desde el core, incluyendo helpers para meta tags y fallback de preview.
  • WishlistService refresca y resuelve la wishlist creada real luego de createWishlist, como workaround para el problema actual de backend con el token devuelto al crear listas.
  • Se amplían las traducciones de wishlist en el core.
  • Se agregan traducciones para wishlist.
  • Se modifica para que la wishlist se pueda mostrar/ocultar por app component con public showWishlist: boolean = false/true;
  • Se hace merge de 0.5.7-wishlist-beta.1
  • Se agrega en Mis Pedidos la carga de varios documentos si así se recibe en el endpoint.
  • Se agrega innerHTML en metodos de pago para mostrar la info tal y como se carga en el backoffice.
  • Se muestra las devoluciones en Mis Pedidos, con el motivo y el total tras la devolución.
  • Se agrega funcionalidad de Wishlist. Servicios y componentes.

Version 0.6.15

  • DataformEcComponent: se agregan DestroyRef y takeUntilDestroyed a todas las suscripciones del constructor y ngOnInit (checkoutForm.statusChanges/valueChanges, checkoutFormFacturacion.statusChanges/valueChanges, isLastStep$, loadingStep$, associatedData$, channel$, getParameters(), cartItems$, loggedIn$, countries$, documentTypes$, state$, countriesFacturacion$) para que se completen automáticamente cuando Angular destruye el componente.
  • Checkout seller: se corrige bug por el cual al cambiar de cliente desde el seller dashboard, el componente de dirección destruido seguía activo en memoria y ejecutaba scheduleAutoSelect() con el addressBook del cliente anterior, provocando que se persistiera la dirección incorrecta antes de que cargara la del cliente actual.
  • ShipmentEcComponent.preloadSingleOptions(): se agrega un contador preloadRequestId para detectar y descartar resultados de llamadas asíncronas obsoletas; si una segunda llamada se inicia antes de que resuelva la primera, los resultados de la primera se descartan, eliminando el bug de métodos de envío duplicados en vista single.

Version 0.6.14

  • Se agregó soporte para contención de slides en Embla para evitar que se vea el inicio del siguiente item cuando no entra en la página.
  • Se mejoró la estrategia de layout de embla__container y embla__slide para carruseles de productos con spacing configurable.
  • Se ajustó la sincronización de estado/eventos del wrapper de Embla para mantener navegación y snaps consistentes.

Version 0.6.13

  • AuthService.isAuthenticated(): se elimina el logout implícito y cualquier escritura de estado durante validación; ahora sólo valida token/expiración y retorna false si no corresponde sesión válida.
  • auth.interceptor: ante 401/403 se ejecuta limpieza completa de sesión (doLogoutUser) y redirección controlada a /auth/login (evitando redirecciones redundantes).
  • auth.interceptor: se usa inyección diferida de AuthService mediante Injector para evitar dependencia circular de DI (NG0200).
  • ProductsService: en la hidratación inicial/paginación se reemplaza siempre el listado con products || [], evitando estados stale cuando backend responde vacío.

Version 0.6.12

  • Collection: ProductsService aplica la separación de productos por variante también en la carga inicial, no sólo al paginar.
  • Collection: la deduplicación de productos ahora usa una clave sensible a variante (variant_id/currentOption.variantCode), evitando que variantes del mismo producto se colapsen en una sola tarjeta.
  • Variantes en listado: cuando productWithUniqueVariant está activo, cada tarjeta usa la imagen, stock, precio, precio tachado y variante seleccionada correspondientes a la variante materializada.
  • Filtros dinámicos: al filtrar por opciones de variante (optionCodes), el listado conserva sólo las variantes que coinciden con los filtros seleccionados.
  • Stock: si una variante filtrada no tiene stock o no puede materializarse, ya no se reemplaza por otra variante disponible del mismo producto.
  • Bulk add: las tarjetas materializadas por variante mantienen la variante seleccionada como primera opción del producto para que el agregado masivo valide stock y agregue el SKU correcto.
  • Filtros: FiltersService.hydrateFromRoute() preserva opciones dinámicas ya cargadas al volver desde detalle a la misma collection, evitando que desaparezcan filtros como color o talle cuando la URL no cambia.
  • Tests: se agrega cobertura para la preservación de filtros dinámicos al rehidratar la misma ruta.
  • Variantes: variants-ec ahora muestra las opciones como selector desplegable, con selección única, sin deselección y con estados visuales para opciones sin stock.
  • Product detail: se soporta ?variant=CODIGO para precargar la variante seleccionada, actualizar imágenes/precio/stock y mantener el estado al recargar o compartir la URL.
  • Product detail: el botón de agregar al carrito queda deshabilitado y muestra loading mientras espera la respuesta del carrito.
  • Carrito/sidebar: los links de items con variante apuntan al producto base con ?variant, y el detalle de variantes usa la variante correcta del item.
  • Carrito: al sumar un producto existente se usa la variante exacta y se evita que el loading quede activo si falla la validación.
  • Productos visitados: se agrega RecentlyViewedService para guardar hasta 5 productos vistos junto con su variante opcional en browser storage.
  • Formularios: se agrega LowercaseEmailDirective para normalizar inputs de email a minúsculas.
  • Moneda: el pipe de moneda reacciona a cambios de moneda activa y respeta metadatos actualizados de posición y decimales.
  • API: ConnectionService normaliza URLs relativas/absolutas para evitar rutas mal concatenadas.
  • Alertas: ToastService muestra botón de cierre y barra de progreso por defecto en todos los mensajes.
  • Product detail: se agrega el componente ProductCommentEcComponent para capturar notas por producto cuando enableFieldNotesInArticleFile está activo.
  • Carrito/sidebar/pedidos: las notas del item se muestran de forma truncada y se preservan al actualizar cantidades.
  • Carrito: CartService envía y mantiene comments al agregar, repetir o actualizar items del carrito.

Version 0.6.11

  • Collection: se agrega PaginationService.refreshCurrentQuery() para forzar recarga del listado al reingresar a la misma ruta/filtros, incluso cuando la URL final no cambió.
  • collection-ec: luego de hydrateFromRoute(...) dispara refreshCurrentQuery() para evitar reutilización de resultados previos entre navegaciones collection -> home -> collection.
  • PaginationService.paginationData$: se incorpora refreshNonce al pipeline (combineLatest) para invalidar el distinctUntilChanged cuando se requiere refresh explícito.
  • PaginationService.paginationData$: shareReplay pasa a shareReplay({ bufferSize: 1, refCount: true }) para mejorar el ciclo de suscripción de consumidores activos.

Version 0.6.10

  • Checkout: se centraliza el manejo de errores de stock agotado (450 / out_of_stock) para mostrar al usuario el mensaje devuelto por backend.
  • Checkout single: al seleccionar método de envío con /shipping-option, si backend responde falta de stock, se muestra feedback y no se avanza al siguiente paso.
  • Checkout single: al seleccionar método de pago con /payment/{method}, si backend responde falta de stock, se notifica al usuario y no queda persistido el método seleccionado.
  • Checkout legacy: selección de envío y contrato ahora notifican errores de stock en lugar de fallar silenciosamente.
  • Finalización de checkout: /complete queda preparado para mostrar el mensaje de falta de stock cuando backend devuelva out_of_stock, evitando duplicar toasts en los componentes.
  • PaymentService.putPayment vuelve a propagar el error HTTP original para que los componentes puedan interpretar correctamente el payload del backend.
  • Se agregan tests focalizados para el manejo de out_of_stock en checkout service, envío y pago.

Version 0.6.9

  • Categorías: OptionsService.getCategories() ahora expone solo taxons visibles (isVisible !== false) para menús, footer y filtros, filtrando recursivamente hijos ocultos.
  • Categorías ocultas: se conserva internamente el árbol completo de taxons para que los deep links a /collection/categories/{slug} sigan resolviendo el code y consultando productos al backend.
  • CategoryFilter: cuando una categoría oculta llega por URL directa o por ?category=CODE, mantiene el filtro interno aunque no se muestre como opción seleccionable en la UI.

Version 0.6.8

  • Checkout legacy: se refuerza el avance real por pasos para que envío y pago no queden visualmente listos antes de que respondan los endpoints del backend.
  • Envío legacy: Siguiente ahora puede mostrar feedback al usuario cuando el paso sigue incompleto y falta seleccionar una opción válida de envío.
  • ShipmentService vuelve segura la autoselección: sólo persiste contrato automáticamente cuando backend devuelve una única alternativa real; si hay varias, exige selección explícita.
  • Envío y pago distinguen estado de carga vs estado vacío, mostrando loaders mientras esperan /shipping, costos/contratos de envío, /payment y la validación de /payment/{metodo}.
  • Se agrega no-payment-methods a i18n y se actualizan tests focalizados de checkout para cubrir estos estados.

Version 0.6.7

  • credit-account-banner-ec: los montos de cuenta corriente ahora se formatean con el locale configurado en el canal, corrigiendo separadores de miles y decimales.
  • Filtros dinámicos: se vuelve a soportar la carga desde options en product-search, preservando selección e hidratación desde optionCodes.
  • Cuenta corriente: cart.service y product-detail.service ahora respetan allowExceedBalance también al sumar cantidades en carrito y al reintentar agregar desde detalle/listado.
  • Checkout single mobile: se aumenta la prioridad visual de la barra flotante de resumen/finalización para que quede por encima de widgets flotantes externos como WhatsApp.
  • checkout-ec.component.scss: la barra summary-mobile-bar ahora usa la variable CSS --ec-checkout-summary-mobile-z-index con fallback 10040.
  • checkout-ec.component.scss: el overlay de carga ahora usa la variable CSS --ec-checkout-overlay-z-index con fallback 10050 para mantenerse por encima del resumen.
  • Checkout single mobile: cuando hay un modal abierto (.modal-open), la barra de resumen baja a --ec-checkout-summary-mobile-z-index-modal-open con fallback 1030 para no interferir con overlays/modales.
  • cart.service: el reset de carrito ahora marca la inicialización cuando llega la nueva respuesta y el logout limpia siempre en transición real logueado -> deslogueado, incluso si antes hubo cambio de cliente en seller-dashboard.
  • auth.service: al cerrar sesión se limpia también el cliente impersonado en memoria (_customer), evitando que queden rastros de seller impersonation en header, permisos y requests posteriores.
  • menu-ec: el logout deja de recargar la página completa y navega por router a /home, evitando que seller-dashboard permanezca visible mientras resuelve un reload duro.
  • auth.service: agrega resolveHomeNavigation() para centralizar la resolución del home configurado por cada frontend y reutilizarla en login/logout sin hardcodes por componente.
  • menu-ec y account-ec: el logout delega en resolveHomeNavigation() con fallback a /home, respetando frontends que configuren un resolver propio y manteniendo compatibilidad con paths explícitos en cuenta.
  • seller-dashboard-container-ec: al cambiar de cliente desde el dashboard de vendedor ahora se ejecuta clearAndResetCustomerCart() para recargar carrito y balanceCustomer (cuenta corriente) con el cliente activo.
  • header-ec: getGreetingName prioriza el cliente impersonado (AuthService.getCustomer()), mostrando su username/email (o nombre/apellido como fallback) en lugar del usuario vendedor cuando corresponde.

Version 0.6.6

  • Se corrige bug en registro que lanzaba mensaje erroneo si no llegaba la info desde el endpoint de channel.
  • Se agregan traducciones de register-success.
  • Se corrige bug que no permite avanzar al retroceder desde metodo de envio a direcciones y volver a avanzar.
  • Ajuste para que no salte mensaje el monto minimo aleatorio.
  • Checkout legacy: al cambiar de método de envío se invalida la selección anterior y Siguiente vuelve a quedar deshabilitado hasta confirmar un nuevo contrato.
  • ShipmentService.setMethod deja de persistir automáticamente el primer contrato disponible y espera una selección explícita del usuario antes de marcar el paso como válido.
  • shipment-ec agrega una guarda en TS para impedir el avance si el paso de envío no quedó realmente listo, aunque el botón sea forzado desde el HTML.
  • En el listado de contratos de envío se elimina el marcado visual automático de la primera opción para evitar que parezca seleccionada sin confirmación real.

Version 0.6.5

  • Eliminación de overrides redundantes en BlockBannerBox, BlockBannerFull, RelatedProducts y ProductDetail.
  • Corrección de accesos a propiedades private en subclases del core.
  • Checkout (legacy y single): las opciones de métodos de envío ahora muestran siempre decimales, sin respetar currency.withoutDecimal.
  • shipment-ec.component.html y shipment-ec-single.component.html: se fuerza ecCurrencySymbol:'alwaysShowDecimals' para mantener consistencia con el resumen del checkout.

Version 0.6.4

  • Checkout legacy: se evita avanzar de paso antes de que termine la sincronización del contrato de envío con /shipping-contract.
  • ShipmentService.setContract ahora espera la respuesta del backend antes de actualizar el estado del checkout, evitando errores de navegación y condiciones de carrera.
  • dataform-ec, shipment-ec y payment-ec sincronizan sus botones con los estados de carga globales y locales para bloquear reintentos y navegación durante requests asíncronas.
  • En envío se mantienen visibles las opciones mientras carga, se bloquean radio buttons y botón Anterior, y el spinner pasa a mostrarse dentro de Siguiente.
  • En pago se bloquean acciones sensibles (Anterior y botones de confirmación) mientras hay carga para evitar peticiones duplicadas en el flujo legacy.

Version 0.6.3

  • Formularios: block-newsletter-ec y block-form-contact-ec incorporan el honeypot hp_email_verification (prefijo hp_) y lo envían al backend para que pueda bloquear/bypassear solicitudes de bots.

Version 0.6.2

  • Checkout: dataform-ec ahora toma checkoutRequiredFields.postalCode desde /shop-api/{canal}/countries para definir la visibilidad y obligatoriedad del campo postcode.
  • Si checkoutRequiredFields.postalCode viene en true, el campo código postal se muestra y se valida como obligatorio.
  • Si checkoutRequiredFields.postalCode viene en false, el campo se oculta y se eliminan sus validaciones del formulario.
  • Se mantiene compatibilidad con backends legacy: si checkoutRequiredFields.postalCode no viene en la respuesta, se conserva el comportamiento anterior basado en viewForms.postcode.
  • Se agregan tests unitarios para cubrir el override del backend nuevo y el fallback legacy.

Version 0.6.1

  • Checkout single: soporte estable de dirección de facturación independiente, con selección de dirección guardada o carga de una nueva, alineado al flujo legacy.
  • Facturación: visualización completa de la dirección seleccionada y compatibilidad con provincias y zonas de países no AR mediante provinceCode.
  • Envíos (single): payload completo en /shipping-option para compatibilidad con contrato y sucursal del flujo legacy.
  • Productos, filtros y collection: mejoras en sincronización de atributos dinámicos, rango de precios, navegación por categoría y estados de carga del listado.
  • Servicios base (ChannelService, OptionsService, ParametersService, ProductsService): mejoras de estabilidad para evitar requests duplicados, concurrencia innecesaria y estados bloqueados.
  • Precios y cantidades: unificación de visibilidad de precios y validación de configuraciones inválidas de múltiplos en producto.
  • Formularios y UX: prevención de doble submit en registro y reset de contraseña, mejoras en el buscador/header, scroll automático al listado y ajustes visuales en cart, order detail y block products.
  • Traducciones y validaciones: textos de ordenamiento unificados y validación ampliada de phoneNumber en registro mayorista.

Version 0.6.0

  • Se incorpora embla-carousel-ec como componente base reutilizable para carruseles (navegación, paginación, estado y autoplay).
  • Se migra el HTML de carrusel de block-products-ec, block-banner-full-ec y block-banner-box-ec a Embla.
  • Se mantiene compatibilidad legacy para frontends que heredan y aún usan lógica de Swiper en TS (hooks, swiperOptions y bridges de inicialización).
  • Se agregan utilidades compartidas para mapear configuración legacy (SwiperOptions) a Embla, incluyendo breakpoints y estilo responsive de slides.
  • Se exporta el nuevo módulo embla-carousel-ec desde ec-components/index.ts.
  • Se ajustan manifiestos de paquete para incluir dependencias de Embla y permitir su empaquetado en la librería.
  • block-products-ec, block-banner-full-ec y block-banner-box-ec ahora preservan overrides de frontend en Embla (emblaOptions, emblaPlugins, emblaSlideStyle) y evitan que el core los pise al recalcular configuración.
  • Se agregan referencias internas de valores por defecto y último estado core para diferenciar entre configuración base y personalizaciones aplicadas desde frontends heredados.
  • Se incorporan guards (hasFrontendEmblaOptionsOverride, hasFrontendEmblaPluginsOverride, hasFrontendEmblaSlideStyleOverride) para aplicar configuración de core sólo cuando no existe override externo.

Version 0.5.9

  • Se incorporan ProductImageZoomEcComponent, ProductMobileImageViewerEcComponent y ProductImageExperienceEcComponent.
  • widgets-ec/index.ts ahora exporta estos tres componentes para su uso desde la librería.
  • ProductImageExperienceEcComponent centraliza el flujo de imagen (zoom desktop con panel externo + visor mobile fullscreen) y sincroniza índice activo con activeIndexChange.
  • Se agrega Input de configuración por objetos: zoomConfig y mobileViewerConfig, manteniendo compatibilidad con inputs legacy.
  • ProductMobileImageViewerEcComponent suma attachToBody, activeIndex/activeIndexChange, cierre por historial/escape/backdrop y flechas desktop configurables.
  • product-detail-ec.component.ts mejora sanitizedHtml filtrando web-share en allow de iframes y agrega utilidades para control de swiper e interacciones hover.

Version 0.5.8

  • Checkout: al confirmar dirección (/headquarter y /address) se actualiza inmediatamente el resumen asociado para reflejar impuestos y totales sin esperar el paso de envío.
  • Legacy con envío y pago omitidos: se separa sincronización de dirección y finalización. Primer click sincroniza con backend y actualiza resumen; segundo click habilita/ejecuta finish-checkout.
  • En legacy de un solo paso, si cambian los totales tras sincronizar dirección, se fuerza scroll al inicio para que el usuario vea el resumen actualizado antes de finalizar.
  • ChannelService aplica la configuración completa del canal (incluye checkoutView) al recibir /channel.
  • Checkout: ajuste de checkoutView (sin persistencia) y sincronización con la config del canal.
  • Implementación del nuevo diseño del checkout single (UI/UX y lógica de flujo).
  • Envíos (single): payload incluye contrato/sucursal, y el precio se muestra tachado cuando el envío es gratis.
  • Se agregan tests unitarios para checkout y servicios relacionados.

Version 0.5.7

  • Al agregar nueva direccion de facturación se deja setteado el email para los usuarios ya autenticados.
  • En el checkout se agrega la posibilidad de usar una dirección de facturación ya creada o crearlas desde cero.
  • Se modifica la forma de enviar la info de direcciones en el endpoint para que backend reciba las dos opciones.

Version 0.5.6

  • fix(filters): improve selection handling and breadcrumb display for attributes

Version 0.5.5

  • decidirFormEc.html agrega guard para evitar doble submit (isSubmitting) y bloqueo de reintentos mientras se procesa el pago.
  • En éxito se mantiene el spinner para evitar reintentos hasta que se cierre la modal.
  • En error se libera el bloqueo y se oculta el spinner para permitir reintentar.

Version 0.5.4

  • block-newsletter-ec evita envíos duplicados del formulario de newsletter mientras la request está en curso (loading guard).
  • Se refactoriza sendForm a async/await con try/catch/finally para centralizar manejo de errores y asegurar el reset de loading.
  • Limpieza menor del componente: se elimina import no utilizado y se ajustan llamadas async con void.

Version 0.5.3

  • Se modifica servicio de producto y paginacion porque el collection lanza endpoint de pagina 2 pero no la muestra y el resto si.

Version 0.5.2

  • Se agrega descrption2 al observable Product para recibirlo del endpoint.
  • Se modifica la funcion para limpiar la descripcion sin html ni css.

Version 0.5.1

  • dataform-ec prioriza el email del cliente activo cuando hay impersonación de vendedor.
  • auth.interceptor agrega el header customer en requests autenticadas para sostener la selección de cliente en checkout (address-book).

Version 0.5.0

  • Se modifica servicio de productos ya que en el collection solo mostraba los primeros traidos en el endpoint y no los que cargaban con la paginación.
  • Se agrega funcion en servicio de product-detail para vaciar el observable y que al entrar a la vista no cargue el producto que vimos anteriormente durante 2 segundos.
  • Runtime levanta bien los entornos tomando la configuracion de kubernetes.

Version 0.4.10

  • Se agrega addAllToCart en CartService y bulkAddEnabled en CoreConstantsService para habilitar agregado masivo, con selección y sincronización en collection-ec y product-ec.
  • product-ec y cart-item-ec unifican validación y clamp de cantidades (stock, maximumItemsQuantity, mínimos, máximos y múltiplos), actualizan el input final y muestran toasts cuando se exceden límites.
  • CartService.validateQuantity valida sobre la nueva cantidad del ítem para actualizaciones.
  • collection-ec valida stock acumulado en agregado masivo y muestra un toast con productos afectados; se agrega i18n bulk-stock-insufficient (es/en).
  • ProductsService centraliza el append de productos y escucha nextProducts$ para paginación; PaginationService deja de reinyectar nextProducts$ desde getData para evitar duplicados en la collection.
  • auth.interceptor ahora maneja 401/403 con logout y redirección a /auth/login.

Version 0.4.9

  • Se agrega el header customer al interceptor de auth para sostener la impersonación en checkout.
  • Se evita la dependencia directa de AuthService en el interceptor para prevenir ciclos DI en SSR.
  • Se agrega el dashboard de vendedores con búsqueda, ordenamiento e impersonación de clientes.
  • Se endurece el ordenamiento de clientes para evitar errores con datos incompletos.
  • Se normaliza el uso de storage para CHANNELSELLER al cambiar de cliente.
  • Se agrega fuse.js como peer dependency.

Version 0.4.8

  • se cambio las variables platformId, de privadas a protected

Version 0.4.7

  • AddressingService ahora escucha el canal activo y ajusta modeSelectAddress según headquarterSelectionOnly.
  • DataformEcComponent expone modeSelectAddress vía getter para reflejar cambios de canal en el formulario.
  • Limpieza de código comentado en ChannelService tras mover la configuración del modo de selección.

Version 0.4.6

  • Primera direccion en checkout predeterminada por defecto

Version 0.4.2

  • Se añade platformID en contact para comprobacion ssr.

Version 0.4.1

  • Se agrega PriceVisibilityService para centralizar la visibilidad global de precios (canal + login + cuenta corriente).
  • Se refactorizan componentes para evitar condiciones largas de precios y reutilizar el gate global.
  • Se agrega CreditAccountBannerEcComponent (standalone) para mostrar créditos/límite con barra de progreso.
  • Se agregan keys de i18n para el banner: credit-account-banner.* (es/en/fr/pr/ct/gl).
  • Cuenta corriente: mejoras en validaciones de crédito y selección de método de pago (bloqueo cuando no corresponde y mensaje en success para balance_in_account).
  • Ajustes en CartService y ProductDetailService para validar stock/cantidad y créditos antes de agregar al carrito.

Version 0.4.0

  • Ajuste en verifyValidate: los métodos de pago manuales (transferencia/offline) vuelven a finalizar el checkout aunque no emitan evento, manteniendo el flujo de Mercado Pago sin cambios.
  • eliminar logs
  • Ajuste adicional en el flujo de Mercado Pago para móviles: se ejecutan los eventos de estado dentro de NgZone para asegurar la correcta detección de cambios y avanzar al siguiente paso del checkout.
  • Mejora en el flujo de pago con Mercado Pago en dispositivos móviles: se agrega fallback de redirección cuando window.close() es ignorado, asegurando que la pantalla de resultado no quede bloqueada en el catch.
  • Se modifica runtimeconfig ya que toma un canal por defecto.
  • Se mergea con la rama de deployment_ssr
  • Se añade en carrito sidebar product detail y producto las validaciones necesarias para que compruebe si hay un maximo , un minimo o multiplo.
  • Se optimizar y comenta codigo para que el runtime no sea un bucle y se haga antes de la primera carga
  • Se modifican servicios y componentes para que funcione el deploy SSR.
  • Se elimina uso de DOM ya que en SSR tira error.
  • Se agrega if platformID en mas archivos para que no de error al navegar elden.
  • Ya estaba contemplado isVisible en el componente menu-ec.component, pero se adapto para que devuelva solo las categorias, atributos y secciones visibles y no tener que filtrarlos en el frontend.
  • Se agrego el isVisible de las categorias a su interfaz

Version 0.3.22

  • Limpieza de importaciones innecesarias en header-ec.component para reducir peso y evitar dependencias sin uso.
  • Se reactiva la inicialización de herramientas de analytics (Facebook Pixel, Google Analytics, GTM, Metricool y Doppler) en el core Angular 18 a partir de los parámetros del endpoint /parameters.
  • Se respeta la nomenclatura de glosario facebook_<canal>_id, google_<canal>_id, gtm_<canal>_id, metricool_<canal>_id, doppler_<canal>_id, usando como fallback los códigos genéricos <servicio>_id cuando no exista el específico por canal.
  • Se agrega IS_PRODUCTION en ApiConstantsService y se limita la inicialización de analytics sólo a entornos productivos.

Version 0.3.20

  • Refactor completo de filtros, paginación y productos para soportar correctamente SSR (Server-Side Rendering).
  • Unificación del flujo de filtrado: ahora toda la lógica se basa en URL (params + queryParams) y se hidrata desde FiltersService.hydrateFromRoute().
  • Se optimiza el runtime inicial para evitar ciclos innecesarios y cargar filtros antes del primer render.
  • Se centraliza la sincronización de rangos de precio (filters ↔ pagination ↔ products).

Version 0.3.17

  • En el header-ec.component.ts se hacen public algunos injectores para poder usarlo en el header.component.ts de los frontends.

Version 0.3.16

  • Se añaden traducciones al core

Version 0.3.15

  • Refactor del flujo de pago con Mercado Pago (redirect/popup unificado).
  • Compatibilidad completa con mobile y desktop: cierre automático de pestaña o redirección según navegador.
  • Nuevo control de estado visual (idle / pagando / finalizando) para evitar repeticiones o confusión del usuario.
  • Simplificación de catch (RedsysCatchEcComponent) y limpieza de código legacy.

Version 0.3.13

  • Se hace estable 0.3.12-beta.1.
  • Se hace estable feature/pop-up-inicial.
  • Se hace estable feature/add-product-block.
  • Se hace estable feature/logged,showpassword,otros.

Version 0.3.12-beta.1

  • Se añade ruta por si falla MP redirija y de error.

Version 0.3.11

  • se añade funcionalidad para ocultar categorias en header footer y filtros

Version 0.3.10

  • se añade funcionalidades para excluir paises en el formulario del proceso de compra

Version 0.3.9

  • mejorar la función hasParams para buscar primero el parametro con codigo exacto, sino parcial.

Version 0.3.8

  • Se cambia construccion de etiquetas META

Version 0.3.7

  • Se cambia construccion de etiquetas META

Version 0.3.6

  • Se cambia construccion de etiquetas META

Version 0.3.5

  • Se cambia construccion de etiquetas META

Version 0.3.4

  • Se cambia construccion de etiquetas META

Version 0.3.3

  • Se cambia construccion de etiquetas META

Version 0.3.2

  • Se cambia construccion de etiquetas META

Version 0.3.1

  • Se cambia construccion de etiquetas META

Version 0.3.0

  • HideTaxes en carrito (ocultar impuestos)
  • se fuerza a numero en las funciones pluss y less (+/-) para evitar que se concatene el 1 al darle al mas
  • en cart.service y order-utility.service se cambia para que el subtotal se guarde correctamente
  • se cambia la funcion updateAsociatedData del checkout.service para mostrar impuestos en el checkout

Version 0.2.29

  • Cambios en dataform para que no se autoseleccione la provincia ya que daba error.

Version 0.2.28

  • product-detail-ec.component: se incorpora resetReviewModal() para resetear el estado del modal de reseñas al cambiar de producto.

Version 0.2.27

  • traducciones y hideprice en filters-ec para ocultar rango de precio.

Version 0.2.26

  • Se implementa la funcionalidad de repetir pedido

Version 0.2.25

  • Se implementa una funcion que me devuelove si el producto tiene stock o no

Version 0.2.24

  • Se implementa funcionalidades para el recargo de pagina al hacer click en algun producto relacionado

Version 0.2.23

  • Ajustes en funcionalidad filtro atributos y cambios en variantes y vista producto en carrito.

Version 0.2.22

  • Ajustes de estilos y funcionalidad.

Version 0.2.21

  • No se enviaba info de metodo de envio en endpoint shipping-contract

Version 0.2.20

  • No permitia agregar cosas al carrito despues de hacer pedido.
  • Checkout se quedaba con los datos guardados al hacer 2 pedidos seguidos.

Version 0.2.19

  • Campo notas que respete check de backoffice.
  • Se corrije que carrito lanzaba endpoint duplicado y al recargar se perdia.

Version 0.2.18

  • Se implementa el check de ocultar precios para usuarios no logueados en el filter para el rango de precio
  • Se implementa en el metodo de envio la clase .active para el que el metodo seleccionado quede diferenciado

Version 0.2.17

  • Se implementa pipe safe url.
  • Se comentan console.log

Version 0.2.16

  • Se modifica funcionamiento del carrito con login y logout

Version 0.2.15

  • Se implementa decidir

Version 0.2.14

  • Se agrega hidePrice en product y en price en html

Version 0.2.13

  • Se agrega en los metodos de envio la descripcion
  • check ocultar precios en usuarios no logueados
  • check ocultar precios (hidePrice)

Version 0.2.12

  • Se agrega logia al app-price para funcion de mostrar precios logeados o no

Version 0.2.11

  • se cambia el block-banner-full para personalizar las flechas

Version 0.2.10

  • Se modifica las constantes de apiURL para probar.

Version 0.2.5

  • Se prueba el apiURL

Version 0.2.4

  • Se cambia para que en environment no sea obligatorio el apiURL

Version 0.2.3

  • Actualiza el manejo de precios y tasas en el servicio de detalles del producto para soportar la nueva estructura del backend.