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
Keywords
Readme
Version 0.6.18-auth-cart.1
- Forgot password: el submit pasa de
inputabutton, muestraapp-loading-inline-ecdurante la petición y queda deshabilitado mientrasloadingestá 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
FormServicepara exponercountries$,provinces$ydocumentTypes$y preparar formularios de registro con datos extendidos. - Register form: se amplía
registerFormcon 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(), mapeandophone -> phoneNumber,newsletter -> subscribedToNewsletter, eliminando campos internos (terms,plainPassword2) y omitiendo valores vacíos antes de llamar asingUp(...). - Register form: se agregan handlers
onCountrySelected(...)yonProvincesSelected(...)para sincronizar país/provincia y persistirprovinceName/provinceCodeen el payload. - Cart item: la marca de descuento sólo se renderiza cuando
salepriceexiste y además es menor alpriceoriginal, 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
channelReadyenCheckoutEcComponentpara evitar que el checkout se renderice durante SSR. El flag solo pasa atrueen el browser, una vez quechannel$emite la configuración del canal, garantizando quecheckoutViewya 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 agregacanAccessMyAccountMenu()para controlar la visibilidad deMi cuentaen 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 porcustomer$.auth.service: ensetCustomer(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 fuerzalogoutpor mismatch cuando hay impersonación activa de cliente.header-ec: se suscribe aAuthService.customer$para refrescar inmediatamente la UI cuando seller entra/sale de modo cliente.seller-dashboard-container-ec: se normaliza el click deOPERAR COMO/SALIRy 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/logincuandologgedIn$pasa afalse, 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/loginantes 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 ensidebar,cartycheckout(como indica backend), sin impactar la leyenda fiscal enproduct-detailni el detalle de pedido (account/orders/:id). - Product detail (impuestos): cuando un producto tiene variantes y todas comparten el mismo precio/
salepricey 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 (
aconhref/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/titleen 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
aabutton. - 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 = falsey 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 pedidoscon 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 pagoreemplaza el texto previo ambiguo y se prepara soporte paraorderStatecuando 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 ayrango. - 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-eccon 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,ProductDetailEcComponentySharedWishlistEcComponent. - 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.
WishlistServicerefresca y resuelve la wishlist creada real luego decreateWishlist, 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 agreganDestroyRefytakeUntilDestroyeda todas las suscripciones del constructor yngOnInit(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 eladdressBookdel cliente anterior, provocando que se persistiera la dirección incorrecta antes de que cargara la del cliente actual. ShipmentEcComponent.preloadSingleOptions(): se agrega un contadorpreloadRequestIdpara 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 vistasingle.
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__containeryembla__slidepara 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 retornafalsesi no corresponde sesión válida.auth.interceptor: ante401/403se ejecuta limpieza completa de sesión (doLogoutUser) y redirección controlada a/auth/login(evitando redirecciones redundantes).auth.interceptor: se usa inyección diferida deAuthServicemedianteInjectorpara evitar dependencia circular de DI (NG0200).ProductsService: en la hidratación inicial/paginación se reemplaza siempre el listado conproducts || [], evitando estados stale cuando backend responde vacío.
Version 0.6.12
- Collection:
ProductsServiceaplica 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
productWithUniqueVariantestá 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-ecahora 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=CODIGOpara 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
RecentlyViewedServicepara guardar hasta 5 productos vistos junto con su variante opcional en browser storage. - Formularios: se agrega
LowercaseEmailDirectivepara 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:
ConnectionServicenormaliza URLs relativas/absolutas para evitar rutas mal concatenadas. - Alertas:
ToastServicemuestra botón de cierre y barra de progreso por defecto en todos los mensajes. - Product detail: se agrega el componente
ProductCommentEcComponentpara capturar notas por producto cuandoenableFieldNotesInArticleFileestá activo. - Carrito/sidebar/pedidos: las notas del item se muestran de forma truncada y se preservan al actualizar cantidades.
- Carrito:
CartServiceenvía y mantienecommentsal 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 dehydrateFromRoute(...)dispararefreshCurrentQuery()para evitar reutilización de resultados previos entre navegacionescollection -> home -> collection.PaginationService.paginationData$: se incorporarefreshNonceal pipeline (combineLatest) para invalidar eldistinctUntilChangedcuando se requiere refresh explícito.PaginationService.paginationData$:shareReplaypasa ashareReplay({ 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:
/completequeda preparado para mostrar el mensaje de falta de stock cuando backend devuelvaout_of_stock, evitando duplicar toasts en los componentes. PaymentService.putPaymentvuelve 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_stocken 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 elcodey 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:
Siguienteahora puede mostrar feedback al usuario cuando el paso sigue incompleto y falta seleccionar una opción válida de envío. ShipmentServicevuelve 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,/paymenty la validación de/payment/{metodo}. - Se agrega
no-payment-methodsa 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
optionsenproduct-search, preservando selección e hidratación desdeoptionCodes. - Cuenta corriente:
cart.serviceyproduct-detail.serviceahora respetanallowExceedBalancetambié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 barrasummary-mobile-barahora usa la variable CSS--ec-checkout-summary-mobile-z-indexcon fallback10040.checkout-ec.component.scss: el overlay de carga ahora usa la variable CSS--ec-checkout-overlay-z-indexcon fallback10050para 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-opencon fallback1030para 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 reallogueado -> 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: agregaresolveHomeNavigation()para centralizar la resolución del home configurado por cada frontend y reutilizarla en login/logout sin hardcodes por componente.menu-ecyaccount-ec: el logout delega enresolveHomeNavigation()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 ejecutaclearAndResetCustomerCart()para recargar carrito ybalanceCustomer(cuenta corriente) con el cliente activo.header-ec:getGreetingNameprioriza el cliente impersonado (AuthService.getCustomer()), mostrando suusername/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
Siguientevuelve a quedar deshabilitado hasta confirmar un nuevo contrato. ShipmentService.setMethoddeja 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-ecagrega 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,RelatedProductsyProductDetail. - Corrección de accesos a propiedades
privateen 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.htmlyshipment-ec-single.component.html: se fuerzaecCurrencySymbol:'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.setContractahora espera la respuesta del backend antes de actualizar el estado del checkout, evitando errores de navegación y condiciones de carrera.dataform-ec,shipment-ecypayment-ecsincronizan 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 deSiguiente. - En pago se bloquean acciones sensibles (
Anteriory botones de confirmación) mientras hay carga para evitar peticiones duplicadas en el flujo legacy.
Version 0.6.3
- Formularios:
block-newsletter-ecyblock-form-contact-ecincorporan el honeypothp_email_verification(prefijohp_) y lo envían al backend para que pueda bloquear/bypassear solicitudes de bots.
Version 0.6.2
- Checkout:
dataform-ecahora tomacheckoutRequiredFields.postalCodedesde/shop-api/{canal}/countriespara definir la visibilidad y obligatoriedad del campopostcode. - Si
checkoutRequiredFields.postalCodeviene entrue, el campo código postal se muestra y se valida como obligatorio. - Si
checkoutRequiredFields.postalCodeviene enfalse, el campo se oculta y se eliminan sus validaciones del formulario. - Se mantiene compatibilidad con backends legacy: si
checkoutRequiredFields.postalCodeno viene en la respuesta, se conserva el comportamiento anterior basado enviewForms.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-optionpara 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
phoneNumberen registro mayorista.
Version 0.6.0
- Se incorpora
embla-carousel-eccomo 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-ecyblock-banner-box-eca Embla. - Se mantiene compatibilidad legacy para frontends que heredan y aún usan lógica de Swiper en TS (hooks,
swiperOptionsy 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-ecdesdeec-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-ecyblock-banner-box-ecahora 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,ProductMobileImageViewerEcComponentyProductImageExperienceEcComponent. widgets-ec/index.tsahora exporta estos tres componentes para su uso desde la librería.ProductImageExperienceEcComponentcentraliza el flujo de imagen (zoom desktop con panel externo + visor mobile fullscreen) y sincroniza índice activo conactiveIndexChange.- Se agrega Input de configuración por objetos:
zoomConfigymobileViewerConfig, manteniendo compatibilidad con inputs legacy. ProductMobileImageViewerEcComponentsumaattachToBody,activeIndex/activeIndexChange, cierre por historial/escape/backdrop y flechas desktop configurables.product-detail-ec.component.tsmejorasanitizedHtmlfiltrandoweb-shareenallowde iframes y agrega utilidades para control deswipere interacciones hover.
Version 0.5.8
- Checkout: al confirmar dirección (
/headquartery/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.
ChannelServiceaplica la configuración completa del canal (incluyecheckoutView) 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.htmlagrega 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-ecevita envíos duplicados del formulario de newsletter mientras la request está en curso (loadingguard).- Se refactoriza
sendFormaasync/awaitcontry/catch/finallypara centralizar manejo de errores y asegurar el reset deloading. - 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-ecprioriza el email del cliente activo cuando hay impersonación de vendedor.auth.interceptoragrega el headercustomeren 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
addAllToCartenCartServiceybulkAddEnabledenCoreConstantsServicepara habilitar agregado masivo, con selección y sincronización encollection-ecyproduct-ec. product-ecycart-item-ecunifican 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.validateQuantityvalida sobre la nueva cantidad del ítem para actualizaciones.collection-ecvalida stock acumulado en agregado masivo y muestra un toast con productos afectados; se agrega i18nbulk-stock-insufficient(es/en).ProductsServicecentraliza el append de productos y escuchanextProducts$para paginación;PaginationServicedeja de reinyectarnextProducts$desdegetDatapara evitar duplicados en la collection.auth.interceptorahora maneja 401/403 con logout y redirección a/auth/login.
Version 0.4.9
- Se agrega el header
customeral interceptor de auth para sostener la impersonación en checkout. - Se evita la dependencia directa de
AuthServiceen 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
CHANNELSELLERal cambiar de cliente. - Se agrega
fuse.jscomo 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
modeSelectAddresssegúnheadquarterSelectionOnly. - DataformEcComponent expone
modeSelectAddressví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
PriceVisibilityServicepara 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
CartServiceyProductDetailServicepara 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.componentpara 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>_idcuando no exista el específico por canal. - Se agrega
IS_PRODUCTIONenApiConstantsServicey 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.tsse hacen public algunos injectores para poder usarlo en elheader.component.tsde 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-ecpara 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.
