import type { Directive } from "vue"; import { getScrollContainer, getScrollPosition } from "@/scripts/scroll"; export default { mounted(src, binding, vn) { if (binding.value === false) return; let isBottom = true; const container = getScrollContainer(src)!; container.addEventListener( "scroll", () => { const pos = getScrollPosition(container); const viewHeight = container.clientHeight; const height = container.scrollHeight; isBottom = pos + viewHeight > height - 32; }, { passive: true }, ); container.scrollTop = container.scrollHeight; const ro = new ResizeObserver((entries, observer) => { if (isBottom) { const height = container.scrollHeight; container.scrollTop = height; } }); ro.observe(src); // TODO: 新たにプロパティを作るのをやめMapを使う src._ro_ = ro; }, unmounted(src, binding, vn) { if (src._ro_) src._ro_.unobserve(src); }, } as Directive;