From 66a3beec2c71ff0c716e914217618edc73fbd25d Mon Sep 17 00:00:00 2001 From: RoyceDa Date: Thu, 19 Feb 2026 22:45:37 +0200 Subject: [PATCH] =?UTF-8?q?=D0=A3=D0=BB=D1=83=D1=87=D1=88=D0=B5=D0=BD?= =?UTF-8?q?=D0=BD=D1=8B=D0=B9=20=D0=BC=D0=B5=D1=82=D0=BE=D0=B4=20=D0=BE?= =?UTF-8?q?=D1=82=D1=81=D0=BB=D0=B5=D0=B6=D0=B8=D0=B2=D0=B0=D0=BD=D0=B8?= =?UTF-8?q?=D1=8F=20=D0=B8=D0=B7=D0=BC=D0=B5=D0=BD=D0=B5=D0=BD=D0=B8=D1=8F?= =?UTF-8?q?=20=D0=B2=D1=8B=D1=81=D0=BE=D1=82=D1=8B=20=D0=B4=D0=BB=D1=8F=20?= =?UTF-8?q?=D1=81=D0=BA=D1=80=D0=BE=D0=BB=D0=BB=D0=B8=D0=BD=D0=B3=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/components/Messages/Messages.tsx | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/app/components/Messages/Messages.tsx b/app/components/Messages/Messages.tsx index 8ee6b21..e08df20 100644 --- a/app/components/Messages/Messages.tsx +++ b/app/components/Messages/Messages.tsx @@ -74,25 +74,25 @@ export function Messages() { return () => observer.disconnect(); }, [messages.length, loading]); - // MutationObserver - отслеживаем изменения контента (загрузка картинок, видео) useEffect(() => { - if (!contentRef.current) return; + if (!contentRef.current || !viewportRef.current) return; - const observer = new MutationObserver(() => { - // Скроллим только если нужен авто-скролл - if (shouldAutoScrollRef.current) { + const contentEl = contentRef.current; + //const viewportEl = viewportRef.current; + let lastHeight = contentEl.scrollHeight; + + const ro = new ResizeObserver(() => { + const newHeight = contentEl.scrollHeight; + const grew = newHeight > lastHeight; + lastHeight = newHeight; + + if (grew && shouldAutoScrollRef.current) { scrollToBottom(true); } }); - observer.observe(contentRef.current, { - childList: true, - subtree: true, - attributes: true, - attributeFilter: ['src', 'style', 'class'] - }); - - return () => observer.disconnect(); + ro.observe(contentEl); + return () => ro.disconnect(); }, [scrollToBottom]); // Первый рендер - скроллим вниз моментально